@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:wght@300;400;500;600&display=swap');

*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'DM Sans',sans-serif;background:#060A12;color:#F8FAFF;display:flex;min-height:100vh;}

/* SIDEBAR */
.sidebar{width:220px;background:#0A1020;border-right:1px solid rgba(99,179,237,0.12);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100;}
.sidebar-logo{padding:0 20px;height:73px;display:flex;align-items:center;font-family:'DM Serif Display',serif;font-size:18px;border-bottom:1px solid rgba(99,179,237,0.12);flex-shrink:0;}
.sidebar-logo span{color:#2563EB;}
.sidebar-nav{padding:12px 8px;flex:1;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:rgba(99,179,237,0.2) transparent;}.sidebar-nav::-webkit-scrollbar{width:3px;}.sidebar-nav::-webkit-scrollbar-track{background:transparent;}.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(99,179,237,0.2);border-radius:100px;}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:rgba(99,179,237,0.4);}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;font-size:13px;color:#94A3B8;margin-bottom:2px;text-decoration:none;transition:all 0.15s;}
.nav-item:hover{background:rgba(99,179,237,0.08);color:#F8FAFF;}
.nav-item.active{background:rgba(37,99,235,0.15);color:#63B3ED;font-weight:500;}
.nav-icon{font-size:16px;width:18px;text-align:center;}.nav-item svg,.nav-sub-item svg{width:16px;height:16px;flex-shrink:0;opacity:0.7;transition:opacity 0.15s;}.nav-item:hover svg,.nav-item.active svg{opacity:1;}.nav-sub-item:hover svg{opacity:1;}
.sidebar-bottom{padding:16px;border-top:1px solid rgba(99,179,237,0.12);}
.biz-name{font-size:13px;font-weight:500;margin-bottom:4px;}
.plan-badge{font-size:11px;background:rgba(37,99,235,0.2);color:#63B3ED;padding:3px 8px;border-radius:100px;font-weight:600;display:inline-block;}

/* MAIN */
.main{margin-left:220px;flex:1;display:flex;flex-direction:column;}
.topbar{height:73px;padding:0 32px;border-bottom:1px solid rgba(99,179,237,0.12);display:flex;align-items:center;justify-content:space-between;background:#060A12;position:sticky;top:0;z-index:10;flex-shrink:0;}
.topbar h1{font-family:'DM Serif Display',serif;font-size:22px;letter-spacing:-0.5px;}
.topbar-sub{font-size:13px;color:#94A3B8;margin-top:2px;}
.content{padding:32px;flex:1;}

/* BADGES */
.badge{font-size:11px;padding:5px 12px;border-radius:100px;font-weight:600;}
.badge-green{background:rgba(34,197,94,0.15);color:#22C55E;}
.badge-blue{background:rgba(37,99,235,0.15);color:#63B3ED;}
.badge-amber{background:rgba(234,179,8,0.15);color:#EAB308;}
.badge-red{background:rgba(239,68,68,0.15);color:#EF4444;}
.badge-gray{background:rgba(148,163,184,0.15);color:#94A3B8;}

/* STATUS BADGES */
.status-pending,.status-confirmed,.status-completed,.status-cancelled{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;padding:4px 10px;border-radius:100px;}
.status-pending::before,.status-confirmed::before,.status-completed::before,.status-cancelled::before{content:'';width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.status-pending{background:rgba(234,179,8,0.12);color:#EAB308;}
.status-pending::before{background:#EAB308;box-shadow:0 0 6px rgba(234,179,8,0.6);}
.status-confirmed{background:rgba(34,197,94,0.12);color:#22C55E;}
.status-confirmed::before{background:#22C55E;box-shadow:0 0 6px rgba(34,197,94,0.6);}
.status-completed{background:rgba(99,179,237,0.12);color:#63B3ED;}
.status-completed::before{background:#63B3ED;box-shadow:0 0 6px rgba(99,179,237,0.6);}
.status-cancelled{background:rgba(239,68,68,0.12);color:#EF4444;}
.status-cancelled::before{background:#EF4444;box-shadow:0 0 6px rgba(239,68,68,0.5);}

/* CARDS */
.card{background:#0F1729;border:1px solid rgba(99,179,237,0.1);border-radius:14px;padding:20px;}
.card-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:#94A3B8;margin-bottom:14px;}

/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px;}
.stat-card{background:#0F1729;border:1px solid rgba(99,179,237,0.1);border-radius:14px;padding:20px;}
.stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:#94A3B8;margin-bottom:8px;}
.stat-num{font-family:'DM Serif Display',serif;font-size:36px;letter-spacing:-1px;}
.stat-sub{font-size:12px;color:#22C55E;margin-top:4px;}
.stat-sub.warn{color:#EAB308;}

/* TABLE */
.table-wrap{background:#0F1729;border:1px solid rgba(99,179,237,0.1);border-radius:14px;overflow:hidden;margin-bottom:24px;}
table{width:100%;border-collapse:collapse;}
thead{background:rgba(37,99,235,0.06);}
th{text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:#94A3B8;padding:12px 16px;border-bottom:1px solid rgba(99,179,237,0.1);white-space:nowrap;}
td{padding:13px 16px;font-size:13px;border-bottom:1px solid rgba(99,179,237,0.06);vertical-align:top;line-height:1.5;}
tr:last-child td{border-bottom:none;}
tr:hover td{background:rgba(37,99,235,0.04);}

/* AVATAR */
.avatar{width:30px;height:30px;border-radius:50%;background:rgba(37,99,235,0.2);color:#63B3ED;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;margin-right:8px;flex-shrink:0;}
.name-cell{display:flex;align-items:center;}

/* ACTION BUTTONS */
.act-btn{background:transparent;border:1px solid rgba(99,179,237,0.2);color:#94A3B8;padding:5px 10px;border-radius:6px;font-size:11px;cursor:pointer;transition:all 0.15s;font-family:'DM Sans',sans-serif;margin-right:4px;}
.act-btn:hover{border-color:#2563EB;color:#63B3ED;}
.act-btn.green{border-color:rgba(34,197,94,0.3);color:#22C55E;}
.act-btn.green:hover{background:rgba(34,197,94,0.1);}
.act-btn.red{border-color:rgba(239,68,68,0.3);color:#EF4444;}
.act-btn.red:hover{background:rgba(239,68,68,0.1);}

/* FORM */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;}
.form-grid.one{grid-template-columns:1fr;}
.field{display:flex;flex-direction:column;gap:6px;}
label{font-size:11px;font-weight:600;letter-spacing:0.05em;text-transform:uppercase;color:#94A3B8;}
input,select,textarea{background:#1A2235;border:1px solid rgba(99,179,237,0.2);border-radius:8px;padding:10px 14px;font-size:13px;color:#F8FAFF;font-family:'DM Sans',sans-serif;outline:none;transition:border 0.2s;width:100%;-webkit-appearance:none;appearance:none;color-scheme:dark;}
input:focus,select:focus,textarea:focus{border-color:#2563EB;}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394A3B8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;}
select option{background:#1A2235;color:#F8FAFF;}
input[readonly]{opacity:0.6;cursor:default;}

/* BUTTONS */
.btn{background:#2563EB;color:#fff;border:none;border-radius:8px;padding:10px 24px;font-size:13px;font-weight:600;cursor:pointer;transition:background 0.2s;font-family:'DM Sans',sans-serif;}
.btn:hover{background:#1d4ed8;}
.btn:disabled{opacity:0.5;cursor:not-allowed;}
.btn-ghost{background:transparent;border:1px solid rgba(99,179,237,0.2);color:#94A3B8;border-radius:8px;padding:10px 24px;font-size:13px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all 0.15s;}
.btn-ghost:hover{border-color:#2563EB;color:#63B3ED;}

/* FILTERS */
.filters{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap;}
.filter-btn{background:transparent;border:1px solid rgba(99,179,237,0.2);color:#94A3B8;padding:7px 16px;border-radius:100px;font-size:12px;cursor:pointer;transition:all 0.15s;font-family:'DM Sans',sans-serif;}
.filter-btn:hover,.filter-btn.active{border-color:#2563EB;color:#63B3ED;background:rgba(37,99,235,0.1);}

/* SECTION */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.section-title{font-size:12px;font-weight:600;color:#94A3B8;text-transform:uppercase;letter-spacing:0.06em;}

/* ALERTS */
.alert-error{background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.3);color:#FCA5A5;padding:12px;border-radius:8px;font-size:13px;margin-top:12px;}
.alert-success{background:rgba(34,197,94,0.1);border:1px solid rgba(34,197,94,0.3);color:#86EFAC;padding:12px;border-radius:8px;font-size:13px;margin-top:12px;}

/* MISC */
.empty{color:#94A3B8;font-size:13px;padding:40px;text-align:center;}
.loading{color:#94A3B8;font-size:13px;padding:20px;text-align:center;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.divider{border:none;border-top:1px solid rgba(99,179,237,0.1);margin:20px 0;}

/* Mini calendar in sidebar */
.nav-dropdown-toggle{cursor:pointer;display:flex;align-items:center;}
.mini-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-top:6px;}
.mini-cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;font-size:11px;font-weight:600;color:#94A3B8;}
.mc-day{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:4px;font-size:10px;cursor:default;color:#475569;}
.mc-day.today{background:rgba(37,99,235,0.3);color:#63B3ED;font-weight:700;}
.mc-day.has-appt{background:rgba(34,197,94,0.2);color:#22C55E;font-weight:600;}
.mc-day.has-appt.today{background:rgba(37,99,235,0.5);color:#fff;}
.mc-day.full{background:rgba(239,68,68,0.2);color:#EF4444;font-weight:600;}
.mc-day-label{font-size:9px;color:#475569;text-align:center;}

/* Phone dropdown sub-items */
.nav-sub-item{display:flex;align-items:center;gap:8px;padding:7px 12px;border-radius:8px;font-size:13px;color:#94A3B8;text-decoration:none;transition:all 0.15s;margin-bottom:2px;}
.nav-sub-item:hover{background:rgba(99,179,237,0.08);color:#F8FAFF;}
.nav-sub-item.active{background:rgba(37,99,235,0.15);color:#63B3ED;font-weight:500;}

/* ── MOBILE RESPONSIVE ── */
@media (max-width: 768px) {
  .sidebar{transform:translateX(-100%);transition:transform 0.25s ease;z-index:200;}
  .sidebar.open{transform:translateX(0);}
  .main{margin-left:0;}
  .topbar{padding:0 16px;}
  .topbar h1{font-size:18px;}
  .content{padding:16px;}
  .mobile-menu-btn{display:flex!important;}
  .mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:199;}
  .mobile-overlay.open{display:block;}
  .dash-grid,.an-grid,.stats-row{grid-template-columns:1fr 1fr!important;}
  .two-col,.three-col{grid-template-columns:1fr!important;}
  .form-grid{grid-template-columns:1fr!important;}
  .field.full{grid-column:span 1!important;}
  table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .topbar{gap:10px;}
  .topbar>div:last-child{display:none;}
}
@media (max-width: 480px) {
  .dash-grid,.an-grid,.stats-row{grid-template-columns:1fr!important;}
  .metric-num,.stat-num{font-size:28px!important;}
}
.mobile-menu-btn{display:none;background:transparent;border:none;color:#94A3B8;font-size:22px;cursor:pointer;padding:4px;line-height:1;}

/* ── Content area SVG icons ── */
.metric-icon svg{width:22px;height:22px;opacity:0.35;}
.panel-title svg{width:14px;height:14px;opacity:0.7;margin-right:4px;vertical-align:middle;}
.ai-badge{font-size:11px;font-weight:600;letter-spacing:0.04em;}
.empty-chat-icon{display:flex;justify-content:center;align-items:center;padding:24px 0;color:#475569;}
.activity-icon svg{width:16px;height:16px;}

@media(max-width:768px){
  #notif-panel{
    left:8px!important;
    right:8px!important;
    top:56px!important;
    bottom:auto!important;
    width:auto!important;
    max-height:70vh!important;
  }
}

@media(max-width:480px){
  .topbar h1{font-size:16px;}
  .content{padding:12px;}
  .card{padding:14px;}
  .btn{font-size:13px;padding:10px 16px;}
  .stats-row .metric-num{font-size:24px!important;}
  /* Booking page */
  .book-card{padding:20px 16px!important;}
  /* Admin settings on small phones */
  .settings-nav-item span, .settings-nav-item svg + *{display:none;}
  /* Make topbar buttons smaller */
  .topbar .btn{font-size:11px;padding:7px 10px;}
}
