/* CabinetBook — Redesigned UI
   Aesthetic: Midnight Emerald — dark premium admin with emerald accents
   Fonts: Plus Jakarta Sans (body) + Syne (headings)
*/

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@600;700;800&family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&display=swap');

:root {
  --bg:          #090c15;
  --bg-elev:     #0f1422;
  --bg-hover:    #141928;
  --bg-card:     #111624;
  --sidebar-bg:  #060810;
  --sidebar-bdr: rgba(255,255,255,.05);
  --text:        #e8edf5;
  --text-2:      #8899b0;
  --muted:       #4d5e78;
  --border:      rgba(255,255,255,.06);
  --border-md:   rgba(255,255,255,.10);
  --shadow:      0 24px 60px rgba(0,0,0,.65);
  --shadow-soft: 0 8px 28px rgba(0,0,0,.4);
  --shadow-sm:   0 2px 8px rgba(0,0,0,.35);
  --primary:      #10b981;
  --primary-600:  #059669;
  --primary-400:  #34d399;
  --primary-50:   rgba(16,185,129,.10);
  --primary-100:  rgba(16,185,129,.16);
  --ring:         rgba(16,185,129,.28);
  --success:      #10b981;
  --warning:      #f59e0b;
  --danger:       #f43f5e;
  --info:         #38bdf8;
  --accent:       #818cf8;
  --radius:    16px;
  --radius-sm: 12px;
  --radius-xs: 8px;
  --sidebar-w: 272px;
  --topbar-h:  68px;
  --grid-gap:  16px;
  --font: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;
}

[data-theme="light"] {
  --bg:          #f0f4fb;
  --bg-elev:     #ffffff;
  --bg-hover:    #f5f8ff;
  --bg-card:     #ffffff;
  --sidebar-bg:  #0c1525;
  --sidebar-bdr: rgba(255,255,255,.06);
  --text:        #0c1525;
  --text-2:      #4a5a72;
  --muted:       #8696ae;
  --border:      rgba(12,21,37,.07);
  --border-md:   rgba(12,21,37,.12);
  --shadow:      0 20px 50px rgba(12,21,37,.14);
  --shadow-soft: 0 6px 20px rgba(12,21,37,.09);
  --shadow-sm:   0 2px 6px rgba(12,21,37,.07);
  --primary:      #059669;
  --primary-600:  #047857;
  --primary-400:  #10b981;
  --primary-50:   rgba(5,150,105,.08);
  --primary-100:  rgba(5,150,105,.14);
  --ring:         rgba(5,150,105,.25);
  --success:      #059669;
  --warning:      #d97706;
  --danger:       #e11d48;
  --info:         #0284c7;
  --accent:       #6366f1;
}

*,*::before,*::after{box-sizing:border-box;}
html,body{height:100%;}
body{
  margin:0;
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.5;
  font-size:14px;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;}

body::before{
  content:'';
  position:fixed;inset:0;
  pointer-events:none;z-index:999;
  opacity:.018;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px;
}

/* Layout */
.container{display:flex;min-height:100vh;}

/* Sidebar */
.sidebar{
  width:var(--sidebar-w);
  background:var(--sidebar-bg);
  border-right:1px solid var(--sidebar-bdr);
  position:sticky;top:0;
  height:100vh;
  display:flex;flex-direction:column;
  overflow:hidden;
}
.sidebar-inner{
  display:flex;flex-direction:column;
  height:100%;
  padding:20px 14px 20px 16px;
  overflow-y:auto;
  scrollbar-width:none;
}
.sidebar-inner::-webkit-scrollbar{display:none;}

.brand{
  display:flex;align-items:center;gap:11px;
  padding:8px 10px 18px;
  border-bottom:1px solid rgba(255,255,255,.05);
  margin-bottom:8px;
}
.brand-icon{
  width:38px;height:38px;border-radius:11px;
  background:linear-gradient(135deg,var(--primary),var(--primary-600));
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  box-shadow:0 0 20px rgba(16,185,129,.28);
}
.brand .title strong{
  display:block;
  font-family:'Syne',sans-serif;
  font-size:15px;font-weight:700;
  color:#fff;letter-spacing:-.01em;
}
.brand .title span{font-size:11px;color:rgba(255,255,255,.3);}

.nav{display:flex;flex-direction:column;gap:2px;margin-top:6px;}
.nav .section{
  padding:14px 10px 5px;
  font-size:10px;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.2);
}
.nav a.item{
  display:flex;align-items:center;justify-content:space-between;
  gap:10px;padding:9px 10px;
  border-radius:var(--radius-sm);
  border:1px solid transparent;
  transition:all .15s ease;
  position:relative;
}
.nav a.item .left{display:flex;align-items:center;gap:10px;min-width:0;}
.nav a.item .left .icon{
  width:32px;height:32px;border-radius:9px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.06);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  transition:all .15s;
  color:rgba(255,255,255,.4);
}
.nav a.item .left span{
  font-size:13.5px;font-weight:500;
  color:rgba(255,255,255,.5);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  transition:color .15s;
}
.nav a.item .badge{
  font-size:10px;font-weight:600;
  padding:3px 7px;border-radius:999px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.32);min-width:22px;text-align:center;
}
.nav a.item:hover{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.05);}
.nav a.item:hover .left .icon{background:rgba(255,255,255,.08);color:rgba(255,255,255,.7);}
.nav a.item:hover .left span{color:rgba(255,255,255,.82);}
.nav a.item.active{background:rgba(16,185,129,.10);border-color:rgba(16,185,129,.18);}
.nav a.item.active .left .icon{background:rgba(16,185,129,.18);border-color:rgba(16,185,129,.28);color:var(--primary);}
.nav a.item.active .left span{color:var(--primary-400);font-weight:600;}
.nav a.item.active::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:18px;border-radius:0 3px 3px 0;background:var(--primary);
}
.sidebar-footer{
  margin-top:auto;padding:14px 10px 0;
  border-top:1px solid rgba(255,255,255,.05);
}
.sidebar-footer .help{font-size:11.5px;color:rgba(255,255,255,.22);line-height:1.6;}

/* Main */
.main{flex:1;min-width:0;padding:0 26px 32px;}

/* Topbar */
.topbar{
  height:var(--topbar-h);
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;position:sticky;top:0;z-index:20;
  padding:12px 0;
  background:linear-gradient(to bottom,var(--bg) 65%,transparent);
}
.topbar .left{display:flex;align-items:center;gap:10px;min-width:0;flex:1;}
.hamburger{
  display:none;
  width:40px;height:40px;border-radius:var(--radius-sm);
  background:var(--bg-elev);border:1px solid var(--border-md);
  box-shadow:var(--shadow-sm);cursor:pointer;
  align-items:center;justify-content:center;
  flex-shrink:0;color:var(--text-2);
}
.search{
  flex:1;max-width:560px;
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;
  border:1px solid var(--border-md);border-radius:14px;
  background:var(--bg-elev);box-shadow:var(--shadow-sm);
  transition:border-color .2s,box-shadow .2s;
}
.search:focus-within{border-color:var(--ring);box-shadow:0 0 0 3px var(--primary-50);}
.search input{
  border:none;outline:none;background:transparent;
  width:100%;font-size:13.5px;color:var(--text);font-family:var(--font);
}
.search input::placeholder{color:var(--muted);}
.search .hint{
  font-size:11px;color:var(--muted);
  border:1px solid var(--border-md);border-radius:6px;
  padding:2px 7px;white-space:nowrap;
}
.topbar .right{display:flex;align-items:center;gap:8px;flex-shrink:0;}

.pill{
  display:flex;align-items:center;gap:9px;
  padding:6px 10px;border-radius:14px;
  background:var(--bg-elev);border:1px solid var(--border-md);
  box-shadow:var(--shadow-sm);cursor:pointer;
}
.pill .avatar{
  width:32px;height:32px;border-radius:10px;
  background:linear-gradient(135deg,rgba(16,185,129,.25),rgba(16,185,129,.08));
  border:1px solid rgba(16,185,129,.28);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:13px;color:var(--primary);
}
.pill .meta{display:flex;flex-direction:column;gap:1px;}
.pill .meta strong{font-size:13px;font-weight:600;}
.pill .meta span{font-size:11px;color:var(--text-2);}

.icon-btn{
  width:40px;height:40px;border-radius:var(--radius-sm);
  background:var(--bg-elev);border:1px solid var(--border-md);
  box-shadow:var(--shadow-sm);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--text-2);font-size:15px;
  transition:all .15s;
}
.icon-btn:hover{background:var(--bg-hover);color:var(--text);}

/* Page head */
.page-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:16px;margin:0 0 22px;
  padding-bottom:18px;border-bottom:1px solid var(--border);
}
.page-head h1{
  margin:0;
  font-family:'Syne',sans-serif;
  font-size:23px;font-weight:700;
  letter-spacing:-.025em;color:var(--text);
}
.page-head p{margin:5px 0 0;color:var(--text-2);font-size:13px;}
.page-actions{display:flex;flex-wrap:wrap;gap:8px;flex-shrink:0;}

/* Buttons */
.btn{
  border:none;cursor:pointer;
  padding:9px 16px;border-radius:var(--radius-sm);
  font-weight:600;font-size:13px;font-family:var(--font);
  letter-spacing:.01em;
  display:inline-flex;align-items:center;gap:8px;
  transition:all .15s ease;line-height:1;text-decoration:none;
}
.btn:active{transform:translateY(1px) scale(.99);}
.btn-primary{
  background:var(--primary);color:#fff;
  box-shadow:0 4px 16px rgba(16,185,129,.28);
}
.btn-primary:hover{
  background:var(--primary-400);
  box-shadow:0 6px 22px rgba(16,185,129,.38);
  transform:translateY(-1px);
}
.btn-ghost{
  background:transparent;
  border:1px solid var(--border-md);color:var(--text-2);
}
.btn-ghost:hover{background:var(--bg-hover);color:var(--text);}
.btn-danger{
  background:rgba(244,63,94,.10);color:var(--danger);
  border:1px solid rgba(244,63,94,.2);
}
.btn-danger:hover{background:rgba(244,63,94,.16);border-color:rgba(244,63,94,.32);}
.btn-sm{padding:6px 11px;border-radius:var(--radius-xs);font-size:12px;}
.btn-block{width:100%;justify-content:center;}

/* Grid */
.grid{display:grid;gap:var(--grid-gap);}
.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr));}
.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr));}
.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr));}
.grid.cols-1{grid-template-columns:1fr;}

/* Cards */
.card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
  transition:border-color .2s;
}
.card:hover{border-color:var(--border-md);}
.card .card-head{
  padding:18px 18px 12px;
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
}
.card .card-head .title{display:flex;flex-direction:column;gap:3px;}
.card .card-head .title strong{font-size:14px;font-weight:600;}
.card .card-head .title span{font-size:12px;color:var(--text-2);}
.card .card-body{padding:0 18px 18px;}
.card .divider{height:1px;background:var(--border);}

/* KPI */
.kpi{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:12px;padding:20px 18px 14px;
}
.kpi .kpi-left{display:flex;flex-direction:column;gap:4px;}
.kpi .kpi-icon{
  width:42px;height:42px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.kpi .help{font-size:12px;color:var(--text-2);font-weight:500;}
.kpi .value{
  font-family:'Syne',sans-serif;
  font-size:32px;font-weight:700;
  letter-spacing:-.04em;line-height:1;color:var(--text);
}
.kpi .trend{
  font-size:11px;color:var(--text-2);
  padding:5px 9px;border-radius:999px;
  border:1px solid var(--border-md);
  background:rgba(255,255,255,.03);
  white-space:nowrap;
}
.kpi-card-emerald .kpi-icon{background:rgba(16,185,129,.12);color:var(--primary);}
.kpi-card-blue .kpi-icon{background:rgba(56,189,248,.12);color:var(--info);}
.kpi-card-amber .kpi-icon{background:rgba(245,158,11,.12);color:var(--warning);}
.kpi-card-rose .kpi-icon{background:rgba(244,63,94,.12);color:var(--danger);}

/* Pills */
.pills{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;}
.pills .chip{
  font-size:11.5px;padding:5px 10px;border-radius:999px;
  border:1px solid var(--border-md);color:var(--text-2);
  background:rgba(255,255,255,.02);font-weight:500;
}

/* Badges */
.badge{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 9px;border-radius:999px;
  font-size:11.5px;font-weight:600;border:1px solid transparent;
}
.badge.success{background:rgba(16,185,129,.12);color:#34d399;border-color:rgba(16,185,129,.2);}
.badge.warning{background:rgba(245,158,11,.12);color:#fbbf24;border-color:rgba(245,158,11,.22);}
.badge.danger{background:rgba(244,63,94,.12);color:#fb7185;border-color:rgba(244,63,94,.22);}
.badge.info{background:rgba(56,189,248,.12);color:#7dd3fc;border-color:rgba(56,189,248,.22);}
.badge.neutral{background:rgba(255,255,255,.04);color:var(--text-2);border-color:var(--border-md);}

/* Forms */
.form{display:grid;gap:14px;}
.field{display:grid;gap:6px;}
label{font-size:12px;font-weight:600;color:var(--text-2);letter-spacing:.02em;}
input,select,textarea{
  width:100%;border:1px solid var(--border-md);
  background:var(--bg-hover);color:var(--text);
  border-radius:var(--radius-sm);
  padding:10px 13px;font-size:13.5px;font-family:var(--font);
  outline:none;transition:border-color .18s,box-shadow .18s;
  -webkit-appearance:none;
}
[data-theme="light"] input,[data-theme="light"] select,[data-theme="light"] textarea{background:var(--bg);}
input::placeholder,textarea::placeholder{color:var(--muted);}
textarea{min-height:90px;resize:vertical;}
input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50);}
input:disabled,select:disabled{opacity:.5;cursor:not-allowed;}
.help{font-size:12px;color:var(--text-2);line-height:1.5;}
.inline{display:flex;gap:12px;}
.inline>*{flex:1;}

/* Tables */
.table-wrap{overflow:auto;}
table{width:100%;border-collapse:collapse;font-size:13px;}
th,td{padding:12px 14px;border-bottom:1px solid var(--border);text-align:left;}
th{
  color:var(--muted);font-weight:600;
  font-size:11px;letter-spacing:.07em;text-transform:uppercase;
  background:rgba(255,255,255,.015);white-space:nowrap;
}
td{white-space:nowrap;color:var(--text);vertical-align:middle;}
tr:last-child td{border-bottom:none;}
tr:hover td{background:rgba(255,255,255,.02);}
[data-theme="light"] tr:hover td{background:rgba(0,0,0,.02);}

/* Calendar */
.calendar{display:grid;grid-template-columns:1.2fr 1fr;gap:16px;}
.slots{display:grid;gap:8px;}
.slot{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:12px 14px;
  border-radius:var(--radius-sm);border:1px solid var(--border);
  background:rgba(255,255,255,.02);
  transition:border-color .15s,background .15s;
}
.slot .left{display:flex;flex-direction:column;gap:2px;}
.slot .left strong{font-size:13px;font-weight:600;}
.slot .left span{font-size:11.5px;color:var(--text-2);}
.slot .right{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.slot.free{border-color:rgba(16,185,129,.18);background:rgba(16,185,129,.04);}
.slot.free:hover{border-color:rgba(16,185,129,.32);background:rgba(16,185,129,.08);}
.slot.busy{border-color:rgba(244,63,94,.14);background:rgba(244,63,94,.03);}

/* Modal */
.modal-backdrop{
  position:fixed;inset:0;
  background:rgba(0,0,0,.72);
  backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;
  padding:20px;z-index:999;
}
.modal{
  width:min(580px,100%);
  background:var(--bg-elev);
  border-radius:20px;border:1px solid var(--border-md);
  box-shadow:var(--shadow);overflow:hidden;
  animation:modalIn .2s ease;
}
@keyframes modalIn{
  from{opacity:0;transform:translateY(10px) scale(.97);}
  to{opacity:1;transform:translateY(0) scale(1);}
}
.modal .m-head{
  padding:16px 18px;
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid var(--border);
}
.modal .m-head strong{font-size:15px;font-weight:600;}
.modal .m-body{padding:18px;}
.modal .m-actions{
  padding:14px 18px;border-top:1px solid var(--border);
  display:flex;justify-content:flex-end;gap:8px;
}
.modal-backdrop.show{display:flex;}

/* Toasts */
.toasts{position:fixed;right:20px;top:20px;display:grid;gap:8px;z-index:1000;pointer-events:none;}
.toast{
  width:340px;background:var(--bg-elev);
  border:1px solid var(--border-md);border-radius:14px;
  box-shadow:var(--shadow);
  padding:13px 14px;display:flex;gap:11px;align-items:flex-start;
  animation:toastIn .18s ease-out;pointer-events:all;
}
@keyframes toastIn{
  from{transform:translateX(12px) scale(.96);opacity:0;}
  to{transform:translateX(0) scale(1);opacity:1;}
}
.toast .dot{width:8px;height:8px;border-radius:999px;margin-top:5px;flex-shrink:0;background:var(--info);}
.toast.success .dot{background:var(--success);}
.toast.warning .dot{background:var(--warning);}
.toast.danger .dot{background:var(--danger);}
.toast .content{display:flex;flex-direction:column;gap:2px;flex:1;}
.toast .content strong{font-size:13px;font-weight:600;}
.toast .content span{font-size:12px;color:var(--text-2);}
.toast button{
  margin-left:auto;flex-shrink:0;background:transparent;border:none;
  cursor:pointer;color:var(--muted);font-size:14px;padding:0 0 0 6px;
  line-height:1;transition:color .15s;
}
.toast button:hover{color:var(--text);}

/* Tabs */
.tabs{display:flex;gap:6px;flex-wrap:wrap;}
.tabs .tab{
  padding:8px 14px;border-radius:var(--radius-xs);
  border:1px solid var(--border-md);background:transparent;
  cursor:pointer;font-weight:600;font-size:13px;font-family:var(--font);
  color:var(--text-2);transition:all .15s;
}
.tabs .tab:hover{background:var(--bg-hover);color:var(--text);}
.tabs .tab.active{background:var(--primary-50);border-color:var(--ring);color:var(--primary-400);}

/* Auth wrap */
.auth-wrap{
  min-height:100vh;display:grid;place-items:center;padding:24px;
  position:relative;overflow:hidden;
}
.auth-wrap::before{
  content:'';position:fixed;
  width:700px;height:700px;top:-250px;left:-200px;
  border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(16,185,129,.07),transparent 65%);
}
.auth-wrap::after{
  content:'';position:fixed;
  width:500px;height:500px;bottom:-150px;right:-100px;
  border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(129,140,248,.06),transparent 65%);
}
.auth-card{
  width:min(1000px,100%);
  display:grid;grid-template-columns:1.1fr .9fr;
  gap:20px;align-items:stretch;position:relative;z-index:1;
}
.auth-hero{
  border-radius:22px;overflow:hidden;
  border:1px solid var(--border-md);
  background:linear-gradient(145deg,rgba(16,185,129,.08) 0%,rgba(16,185,129,.03) 45%,rgba(129,140,248,.05) 100%);
  position:relative;padding:28px;
  display:flex;flex-direction:column;
}
.auth-hero .brand-row{display:flex;align-items:center;gap:12px;margin-bottom:26px;}
.auth-hero .brand-row .logo-box{
  width:44px;height:44px;border-radius:13px;
  background:linear-gradient(135deg,var(--primary),var(--primary-600));
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 24px rgba(16,185,129,.3);
}
.auth-hero .brand-row strong{
  display:block;font-family:'Syne',sans-serif;
  font-size:17px;font-weight:700;color:var(--text);
}
.auth-hero .brand-row span{font-size:12px;color:var(--text-2);}
.auth-hero h2{
  font-family:'Syne',sans-serif;
  font-size:26px;font-weight:700;
  line-height:1.25;letter-spacing:-.025em;
  margin:0 0 12px;color:var(--text);
}
.auth-hero>p{
  color:var(--text-2);font-size:14px;line-height:1.65;
  max-width:36ch;margin:0 0 24px;
}
.hero-cards{display:grid;gap:10px;flex:1;}
.hero-mini{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  border-radius:14px;padding:14px 16px;
  transition:border-color .2s;
}
.hero-mini:hover{border-color:rgba(16,185,129,.2);}
.hero-mini .mini-icon{font-size:18px;margin-bottom:8px;}
.hero-mini strong{font-size:13px;font-weight:600;display:block;margin-bottom:4px;color:var(--text);}
.hero-mini span{font-size:12px;color:var(--text-2);line-height:1.5;}
.footer-hint{
  margin-top:20px;display:flex;justify-content:space-between;
  align-items:center;gap:12px;color:var(--muted);font-size:12px;
}

.auth-form{
  border-radius:22px;border:1px solid var(--border-md);
  background:var(--bg-elev);box-shadow:var(--shadow-soft);
  padding:28px;display:flex;flex-direction:column;justify-content:center;
}
.auth-form h1{
  font-family:'Syne',sans-serif;margin:0 0 6px;
  font-size:22px;font-weight:700;letter-spacing:-.02em;
}
.auth-form>p{margin:0 0 22px;color:var(--text-2);font-size:13.5px;line-height:1.55;}
.divider-row{display:flex;align-items:center;gap:10px;margin:16px 0;}
.divider-row .line{height:1px;background:var(--border-md);flex:1;}
.divider-row span{color:var(--muted);font-size:12px;white-space:nowrap;}

/* Animations */
@keyframes fadeUp{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:translateY(0);}}
.main>*{animation:fadeUp .3s ease both;}
.main>*:nth-child(1){animation-delay:.04s;}
.main>*:nth-child(2){animation-delay:.09s;}
.main>*:nth-child(3){animation-delay:.14s;}
.main>*:nth-child(4){animation-delay:.19s;}

/* Light theme sidebar */
[data-theme="light"] .sidebar{background:#0c1525;}
[data-theme="light"] .brand .title strong{color:#fff;}
[data-theme="light"] .brand .title span{color:rgba(255,255,255,.32);}
[data-theme="light"] .nav .section{color:rgba(255,255,255,.22);}
[data-theme="light"] .nav a.item .left span{color:rgba(255,255,255,.52);}
[data-theme="light"] .nav a.item .left .icon{color:rgba(255,255,255,.42);}
[data-theme="light"] .nav a.item:hover .left span{color:rgba(255,255,255,.82);}
[data-theme="light"] .nav a.item:hover .left .icon{color:rgba(255,255,255,.7);}
[data-theme="light"] .nav a.item.active .left span{color:#6ee7b7;}
[data-theme="light"] .sidebar-footer .help{color:rgba(255,255,255,.22);}
[data-theme="light"] .nav a.item .badge{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.1);color:rgba(255,255,255,.38);}
[data-theme="light"] .hero-mini{background:rgba(0,0,0,.03);border-color:rgba(0,0,0,.07);}
[data-theme="light"] .slot{background:rgba(0,0,0,.02);}
[data-theme="light"] .slot.free{background:rgba(5,150,105,.04);}
[data-theme="light"] th{background:rgba(0,0,0,.015);}
[data-theme="light"] .pills .chip{background:rgba(0,0,0,.03);}
[data-theme="light"] .badge.neutral{background:rgba(0,0,0,.04);color:var(--text-2);border-color:var(--border-md);}

/* Responsive */
@media(max-width:1060px){
  .grid.cols-4{grid-template-columns:repeat(2,minmax(0,1fr));}
  .calendar{grid-template-columns:1fr;}
  .auth-card{grid-template-columns:1fr;}
}
@media(max-width:840px){
  .sidebar{
    position:fixed;left:-300px;z-index:100;
    transition:left .2s ease;
    width:min(var(--sidebar-w),88vw);
    height:100vh;box-shadow:var(--shadow);
  }
  .sidebar.open{left:0;}
  .hamburger{display:flex;}
  .search{min-width:0;}
  .main{padding:0 16px 24px;}
  .grid.cols-3{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media(max-width:580px){
  .grid.cols-3,.grid.cols-2,.grid.cols-4{grid-template-columns:1fr;}
  .inline{flex-direction:column;}
  .toast{width:min(94vw,360px);}
  .page-head{flex-direction:column;align-items:flex-start;}
  .pill .meta{display:none;}
  .auth-card{grid-template-columns:1fr;}
  .auth-hero h2{font-size:20px;}
}


/* === CabinetBook Pro visual layer === */
.card, .slot, .btn, input, select, textarea { transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease; }
.card:hover{ transform:translateY(-1px); box-shadow:var(--shadow-soft); }
.btn:hover{ transform:translateY(-1px); }
.fade-in{animation:fadeInUp .32s ease both;} @keyframes fadeInUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.search{position:relative}.search-results{position:absolute;top:calc(100% + 8px);left:0;right:0;background:var(--bg-elev);border:1px solid var(--border-md);border-radius:14px;box-shadow:var(--shadow);padding:10px;display:none;z-index:50}.search-results.show{display:grid;gap:6px}.search-results strong{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.search-results a{display:flex;justify-content:space-between;gap:10px;padding:9px;border-radius:10px;color:var(--text);font-size:13px}.search-results a:hover{background:var(--bg-hover)}.search-results span{color:var(--text-2);font-size:12px}.empty-mini{padding:14px;color:var(--text-2);text-align:center;border:1px dashed var(--border-md);border-radius:12px}
.notify-dot{position:absolute;right:-4px;top:-5px;min-width:18px;height:18px;border-radius:999px;background:var(--danger);color:#fff;font-size:10px;display:grid;place-items:center;border:2px solid var(--bg-elev)}.icon-btn{position:relative}.notice{display:grid;gap:3px;padding:12px;border:1px solid var(--border);border-left:3px solid var(--info);border-radius:12px;background:var(--bg-card);margin-bottom:8px}.notice.success{border-left-color:var(--success)}.notice.warning{border-left-color:var(--warning)}.notice.danger{border-left-color:var(--danger)}.notice span{color:var(--text-2);font-size:13px}.notice em{color:var(--muted);font-size:11px;font-style:normal}.guide-card{position:fixed;right:22px;bottom:22px;max-width:360px;background:linear-gradient(135deg,var(--bg-elev),var(--bg-card));border:1px solid var(--ring);box-shadow:var(--shadow);border-radius:18px;padding:18px;z-index:80;display:grid;gap:10px}.guide-card strong{font-family:'Syne',sans-serif;font-size:17px}.guide-card span{color:var(--text-2);font-size:13px}.guide-close{position:absolute;right:10px;top:8px;border:0;background:transparent;color:var(--muted);cursor:pointer}
.analytics-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:16px;margin-top:16px}.bar-list{display:grid;gap:10px}.bar-row{display:grid;grid-template-columns:110px 1fr 42px;align-items:center;gap:10px;font-size:12px;color:var(--text-2)}.bar{height:10px;border-radius:999px;background:var(--bg-hover);overflow:hidden}.bar i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--primary),var(--accent))}.donut{width:168px;height:168px;border-radius:50%;background:conic-gradient(var(--primary) var(--p,0%), var(--bg-hover) 0);display:grid;place-items:center;margin:auto;box-shadow:inset 0 0 0 16px var(--bg-card)}.donut strong{font-size:30px}.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:end}.view-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.room-card{padding:15px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);display:grid;gap:10px}.room-card .top{display:flex;justify-content:space-between;gap:12px}.fav-btn{border:1px solid var(--border-md);background:var(--bg-hover);color:var(--text-2);border-radius:10px;min-width:34px;height:34px;cursor:pointer}.fav-btn.active{color:#fbbf24;border-color:rgba(251,191,36,.4);background:rgba(251,191,36,.12)}.progress-line{height:7px;background:var(--bg-hover);border-radius:999px;overflow:hidden}.progress-line i{display:block;height:100%;background:linear-gradient(90deg,var(--primary),var(--info));border-radius:999px}.calendar-week{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.day-card{border:1px solid var(--border);background:var(--bg-card);border-radius:14px;padding:10px;min-height:92px}.day-card strong{display:block;font-size:12px}.day-card span{display:block;color:var(--text-2);font-size:11px;margin-top:4px}.day-card .mini-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--primary);margin-right:4px}.conflict-box{padding:10px 12px;border-radius:12px;margin-top:10px;border:1px solid var(--border-md);background:var(--bg-hover);font-size:13px}.conflict-box.ok{border-color:rgba(16,185,129,.35);color:var(--success)}.conflict-box.bad{border-color:rgba(244,63,94,.35);color:var(--danger)}
@media(max-width:980px){.analytics-grid{grid-template-columns:1fr}.calendar-week{grid-template-columns:1fr 1fr}.toolbar{display:grid}.bar-row{grid-template-columns:80px 1fr 34px}}@media(max-width:580px){.guide-card{left:12px;right:12px;bottom:12px}.calendar-week{grid-template-columns:1fr}.view-grid{grid-template-columns:1fr}}
