/* =====================================================
   DENTASAAS — Complete Stylesheet
   Deep Blue Professional Theme | Mobile-First SaaS
   ===================================================== */

:root {
  --p:        #1649FF;
  --p2:       #3B82F6;
  --p3:       #DBEAFE;
  --navy:     #0A1628;
  --navy2:    #132040;
  --navy3:    #1C3060;
  --teal:     #0D9488;
  --gold:     #F59E0B;
  --rose:     #F43F5E;
  --ok:       #059669;
  --warn:     #D97706;
  --err:      #DC2626;

  --bg:       #F0F4FF;
  --bg2:      #E8EFFC;
  --surf:     #FFFFFF;
  --surf2:    #F7FAFF;
  --bdr:      #D4DCF0;
  --bdr2:     #E8EEF8;

  --tx:       #0A1628;
  --tx2:      #2A3F6A;
  --tx3:      #5A6E96;
  --tx4:      #9AAAC8;

  --r:        16px;
  --r2:       12px;
  --r3:       8px;
  --r4:       24px;

  --sh0:      0 1px 3px rgba(10,22,40,.07);
  --sh1:      0 4px 16px rgba(10,22,40,.10);
  --sh2:      0 10px 40px rgba(10,22,40,.15);
  --shb:      0 6px 24px rgba(22,73,255,.22);

  --sb:       256px;   /* sidebar width */
  --tb:       64px;    /* topbar height */
  --bn:       60px;    /* bottom nav height */

  --f:        'Sora', sans-serif;
  --fh:       'Noto Sans Devanagari', sans-serif;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;}
body{font-family:var(--f);background:var(--bg);color:var(--tx);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;}
body.hi{font-family:var(--fh);}
input,select,textarea,button{font-family:inherit;}
body.hi input,body.hi select,body.hi textarea,body.hi button{font-family:var(--fh);}

/* ── Auth ── */
.auth{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr;}
.auth-l{
  background:linear-gradient(150deg,var(--navy) 0%,var(--navy2) 45%,var(--navy3) 100%);
  display:flex;flex-direction:column;justify-content:center;
  padding:3.5rem 3.5rem 3.5rem 4rem;position:relative;overflow:hidden;
}
.auth-l::before{content:'';position:absolute;top:-120px;right:-120px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(22,73,255,.14) 0%,transparent 70%);}
.auth-l::after {content:'';position:absolute;bottom:-80px;left:-80px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(96,165,250,.08) 0%,transparent 70%);}
.auth-logo{display:flex;align-items:center;gap:.9rem;margin-bottom:3rem;position:relative;z-index:1;}
.auth-logo-icon{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--p),var(--p2));display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#fff;box-shadow:var(--shb);}
.auth-logo h1{font-size:1.7rem;font-weight:800;color:#fff;letter-spacing:-.03em;}
.auth-logo small{display:block;font-size:.65rem;color:rgba(255,255,255,.4);letter-spacing:.1em;text-transform:uppercase;margin-top:2px;}
.auth-hero{position:relative;z-index:1;}
.auth-hero h2{font-size:2.4rem;font-weight:800;color:#fff;line-height:1.2;margin-bottom:.85rem;letter-spacing:-.02em;}
.auth-hero h2 em{color:#60A5FA;font-style:normal;}
.auth-hero p{font-size:.875rem;color:rgba(255,255,255,.6);line-height:1.75;max-width:340px;}
.auth-feats{display:flex;flex-direction:column;gap:.6rem;margin-top:2rem;position:relative;z-index:1;}
.auth-feat{display:flex;align-items:center;gap:.7rem;font-size:.82rem;color:rgba(255,255,255,.72);}
.auth-feat-ico{width:30px;height:30px;border-radius:8px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-size:.78rem;color:#60A5FA;flex-shrink:0;}
.auth-r{background:var(--surf);display:flex;align-items:center;justify-content:center;padding:2.5rem 2rem;}
.auth-box{width:100%;max-width:400px;animation:up .45s ease;}
.auth-box-hd{margin-bottom:1.75rem;}
.auth-box-hd h2{font-size:1.9rem;font-weight:800;color:var(--navy);letter-spacing:-.03em;}
.auth-box-hd p{font-size:.82rem;color:var(--tx3);margin-top:4px;}
.auth-tabs{display:flex;background:var(--bg);border-radius:var(--r2);padding:3px;margin-bottom:1.6rem;}
.auth-tab{flex:1;padding:.52rem;border:none;background:none;border-radius:9px;cursor:pointer;font-size:.8rem;font-weight:700;color:var(--tx3);transition:all .2s;}
.auth-tab.on{background:var(--surf);color:var(--p);box-shadow:var(--sh0);}
.lang-row{display:flex;justify-content:flex-end;margin-bottom:1rem;}
.lang-sw{display:flex;background:var(--bg);border-radius:20px;padding:3px;border:1.5px solid var(--bdr2);}
.lang-btn{padding:.26rem .62rem;border:none;background:none;border-radius:16px;cursor:pointer;font-size:.7rem;font-weight:700;color:var(--tx3);transition:all .18s;}
.lang-btn.on{background:var(--p);color:#fff;}

/* ── Form ── */
.fg{margin-bottom:.95rem;}
.fg label{display:block;font-size:.7rem;font-weight:700;color:var(--tx2);margin-bottom:.36rem;letter-spacing:.04em;text-transform:uppercase;}
body.hi .fg label{text-transform:none;font-size:.75rem;letter-spacing:0;}
.fg input,.fg select,.fg textarea{
  width:100%;padding:.68rem 1rem;border:1.5px solid var(--bdr);border-radius:var(--r3);
  font-size:.9rem;color:var(--tx);background:var(--surf);outline:none;
  transition:border-color .18s,box-shadow .18s;-webkit-appearance:none;
}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--p);box-shadow:0 0 0 3px rgba(22,73,255,.11);}
.fg textarea{resize:vertical;min-height:72px;}
.fg select{cursor:pointer;}
.ico-w{position:relative;}
.ico-w i{position:absolute;left:.85rem;top:50%;transform:translateY(-50%);color:var(--tx4);font-size:.82rem;pointer-events:none;}
.ico-w input{padding-left:2.35rem;}
.r2{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;}
.r3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.85rem;}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.42rem;padding:.66rem 1.3rem;border:none;border-radius:var(--r3);cursor:pointer;font-size:.82rem;font-weight:700;transition:all .18s cubic-bezier(.23,1,.32,1);white-space:nowrap;text-decoration:none;position:relative;overflow:hidden;}
.btn-p   {background:linear-gradient(135deg,var(--p),#3B69FF);color:#fff;box-shadow:0 4px 14px rgba(22,73,255,.28);}
.btn-p:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(22,73,255,.38);}
.btn-navy{background:var(--navy);color:#fff;}
.btn-navy:hover{background:var(--navy2);}
.btn-ok  {background:linear-gradient(135deg,#059669,#10B981);color:#fff;}
.btn-err {background:linear-gradient(135deg,#DC2626,#EF4444);color:#fff;}
.btn-warn{background:linear-gradient(135deg,#D97706,#F59E0B);color:#fff;}
.btn-out {background:transparent;border:1.5px solid var(--bdr);color:var(--tx2);}
.btn-out:hover{border-color:var(--p);color:var(--p);background:rgba(22,73,255,.04);}
.btn-ghost{background:transparent;color:var(--tx3);}
.btn-ghost:hover{background:var(--bg);color:var(--tx2);}
.btn-sm{padding:.4rem .82rem;font-size:.75rem;}
.btn-xs{padding:.28rem .58rem;font-size:.68rem;}
.btn-fl{width:100%;}
.btn-ico{padding:.48rem;}
.btn-ico.btn-sm{padding:.36rem;}

/* ── App shell ── */
.app{display:flex;min-height:100vh;}

/* ── Sidebar ── */
.sb{
  width:var(--sb);background:var(--navy);
  position:fixed;top:0;left:0;height:100vh;z-index:400;
  display:flex;flex-direction:column;
  transition:transform .3s cubic-bezier(.23,1,.32,1);overflow:hidden;
}
.sb::before{content:'';position:absolute;top:0;left:0;right:0;height:200px;background:linear-gradient(180deg,rgba(22,73,255,.18) 0%,transparent 100%);pointer-events:none;}
.sb-brand{display:flex;align-items:center;gap:.8rem;padding:1.2rem 1.3rem 1rem;border-bottom:1px solid rgba(255,255,255,.07);position:relative;z-index:1;}
.sb-logo{width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,var(--p),var(--p2));display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#fff;flex-shrink:0;overflow:hidden;box-shadow:0 3px 10px rgba(22,73,255,.35);}
.sb-logo img{width:100%;height:100%;object-fit:cover;}
.sb-brand-txt h2{font-size:1rem;font-weight:800;color:#fff;line-height:1.1;letter-spacing:-.02em;}
.sb-brand-txt small{font-size:.62rem;color:rgba(255,255,255,.35);}
.sb-nav{flex:1;overflow-y:auto;padding:.85rem .65rem;position:relative;z-index:1;}
.sb-nav::-webkit-scrollbar{width:3px;}
.sb-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px;}
.sb-sec{font-size:.58rem;font-weight:700;color:rgba(255,255,255,.25);letter-spacing:.14em;text-transform:uppercase;padding:.65rem .7rem .32rem;margin-top:.2rem;}
.sb-link{display:flex;align-items:center;gap:.65rem;padding:.65rem .75rem;border-radius:var(--r3);cursor:pointer;color:rgba(255,255,255,.48);font-size:.82rem;font-weight:600;transition:all .16s;border:none;background:none;width:100%;text-align:left;margin-bottom:1px;position:relative;}
body.hi .sb-link{font-family:var(--fh);font-size:.8rem;}
.sb-link i{width:17px;text-align:center;font-size:.88rem;flex-shrink:0;}
.sb-link:hover{background:rgba(255,255,255,.07);color:rgba(255,255,255,.88);}
.sb-link.on{background:linear-gradient(90deg,rgba(22,73,255,.65),rgba(59,105,255,.32));color:#fff;box-shadow:0 2px 10px rgba(22,73,255,.28);}
.sb-link.on::before{content:'';position:absolute;left:0;top:22%;bottom:22%;width:3px;background:#60A5FA;border-radius:0 2px 2px 0;}
.sb-link.on i{color:#60A5FA;}
.sb-foot{padding:.8rem .65rem .95rem;border-top:1px solid rgba(255,255,255,.07);position:relative;z-index:1;}
.user-pill{display:flex;align-items:center;gap:.65rem;padding:.65rem;border-radius:var(--r3);background:rgba(255,255,255,.06);cursor:pointer;transition:background .18s;}
.user-pill:hover{background:rgba(255,255,255,.1);}
.av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--p),var(--p2));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;flex-shrink:0;}
.up-info{flex:1;min-width:0;}
.up-info h4{font-size:.78rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.up-info span{font-size:.62rem;color:rgba(255,255,255,.35);}

/* ── Main area ── */
.main{margin-left:var(--sb);flex:1;display:flex;flex-direction:column;min-height:100vh;}

/* ── Topbar ── */
.tb{height:var(--tb);background:var(--surf);border-bottom:1px solid var(--bdr2);display:flex;align-items:center;justify-content:space-between;padding:0 1.6rem;position:sticky;top:0;z-index:200;box-shadow:var(--sh0);}
.tb-l{display:flex;align-items:center;gap:.9rem;}
.tb-r{display:flex;align-items:center;gap:.55rem;}
.hbg{display:none;background:none;border:none;cursor:pointer;color:var(--tx2);font-size:1.15rem;padding:.5rem;border-radius:var(--r3);}
.hbg:hover{background:var(--bg);}
.pg-ttl h2{font-size:1.25rem;font-weight:800;color:var(--navy);letter-spacing:-.02em;line-height:1.1;}
.pg-ttl p{font-size:.68rem;color:var(--tx3);margin-top:2px;}
.tb-btn{width:38px;height:38px;border-radius:50%;border:none;background:var(--bg);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--tx2);font-size:.88rem;transition:all .18s;position:relative;}
.tb-btn:hover{background:var(--bg2);color:var(--p);}
.ndot{position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;background:var(--rose);border:2px solid var(--surf);}

/* ── Page ── */
.page{padding:1.5rem;flex:1;animation:up .25s ease;}
.pg-hd{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;gap:.85rem;flex-wrap:wrap;}
.pg-hd-txt h1{font-size:1.6rem;font-weight:800;color:var(--navy);letter-spacing:-.02em;}
.pg-hd-txt p{font-size:.78rem;color:var(--tx3);margin-top:3px;}

/* ── Stat cards ── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem;}
.sc{background:var(--surf);border-radius:var(--r);padding:1.25rem;border:1px solid var(--bdr2);box-shadow:var(--sh0);position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s;cursor:default;}
.sc:hover{transform:translateY(-3px);box-shadow:var(--sh1);}
.sc::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--r) var(--r) 0 0;}
.sc.c1::after{background:linear-gradient(90deg,var(--p),var(--p2));}
.sc.c2::after{background:linear-gradient(90deg,var(--teal),#2DD4BF);}
.sc.c3::after{background:linear-gradient(90deg,var(--gold),#FCD34D);}
.sc.c4::after{background:linear-gradient(90deg,var(--rose),#FB7185);}
.sc-ico{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;margin-bottom:.85rem;}
.sc.c1 .sc-ico{background:rgba(22,73,255,.1);color:var(--p);}
.sc.c2 .sc-ico{background:rgba(13,148,136,.1);color:var(--teal);}
.sc.c3 .sc-ico{background:rgba(245,158,11,.1);color:var(--gold);}
.sc.c4 .sc-ico{background:rgba(244,63,94,.1);color:var(--rose);}
.sc-num{font-size:1.9rem;font-weight:800;color:var(--navy);line-height:1;margin-bottom:3px;letter-spacing:-.03em;}
.sc-lbl{font-size:.72rem;color:var(--tx3);font-weight:600;}
.sc-tag{display:inline-flex;align-items:center;gap:3px;font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:20px;margin-top:7px;}
.sc-tag.up{background:rgba(5,150,105,.1);color:var(--ok);}
.sc-tag.neu{background:rgba(90,110,150,.1);color:var(--tx3);}

/* ── Card ── */
.card{background:var(--surf);border-radius:var(--r);padding:1.3rem;border:1px solid var(--bdr2);box-shadow:var(--sh0);margin-bottom:1rem;}
.card-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;}
.card-ttl{display:flex;align-items:center;gap:.5rem;font-size:.95rem;font-weight:700;color:var(--navy);}
.card-ttl i{color:var(--p);font-size:.88rem;}

/* ── Grids ── */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;}
.ga{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1rem;}
.dash-g{display:grid;grid-template-columns:1.35fr 1fr;gap:1rem;align-items:start;}
.ch-g{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.set-g{display:grid;grid-template-columns:repeat(auto-fit,minmax(310px,1fr));gap:1rem;}

/* ── Table ── */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r3);}
.tbl{width:100%;border-collapse:collapse;font-size:.82rem;}
.tbl thead th{padding:.65rem .95rem;text-align:left;font-size:.65rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--tx3);background:var(--surf2);border-bottom:1px solid var(--bdr2);white-space:nowrap;}
body.hi .tbl thead th{text-transform:none;letter-spacing:0;font-size:.7rem;}
.tbl tbody td{padding:.82rem .95rem;border-bottom:1px solid var(--bdr2);vertical-align:middle;}
.tbl tbody tr:last-child td{border-bottom:none;}
.tbl tbody tr{transition:background .1s;}
.tbl tbody tr:hover{background:var(--surf2);}
.tn{font-weight:700;color:var(--navy);font-size:.85rem;}
.ts{font-size:.68rem;color:var(--tx3);margin-top:1px;}

/* ── Pills ── */
.pill{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:.65rem;font-weight:700;white-space:nowrap;}
.pill::before{content:'';width:5px;height:5px;border-radius:50%;flex-shrink:0;}
.pill-confirmed{background:rgba(5,150,105,.1); color:var(--ok);}   .pill-confirmed::before{background:var(--ok);}
.pill-pending   {background:rgba(217,119,6,.1); color:var(--warn);}  .pill-pending::before{background:var(--warn);}
.pill-completed {background:rgba(22,73,255,.1); color:var(--p);}    .pill-completed::before{background:var(--p);}
.pill-cancelled {background:rgba(220,38,38,.1); color:var(--err);}  .pill-cancelled::before{background:var(--err);}
.pill-paid      {background:rgba(5,150,105,.1); color:var(--ok);}   .pill-paid::before{background:var(--ok);}
.pill-unpaid    {background:rgba(220,38,38,.1); color:var(--err);}  .pill-unpaid::before{background:var(--err);}

/* ── Filter bar ── */
.fbar{display:flex;gap:.6rem;margin-bottom:1rem;flex-wrap:wrap;align-items:center;}
.srch{position:relative;flex:1;min-width:200px;}
.srch i{position:absolute;left:.82rem;top:50%;transform:translateY(-50%);color:var(--tx4);font-size:.8rem;pointer-events:none;}
.srch input{padding-left:2.3rem;}
.fsel{padding:.62rem .95rem;border:1.5px solid var(--bdr);border-radius:var(--r3);font-size:.8rem;color:var(--tx2);background:var(--surf);outline:none;cursor:pointer;min-width:140px;transition:border-color .18s;}
body.hi .fsel{font-family:var(--fh);}
.fsel:focus{border-color:var(--p);}

/* ── Apt row ── */
.apt-list{display:flex;flex-direction:column;gap:.42rem;}
.apt-row{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:var(--r3);border:1px solid var(--bdr2);transition:background .12s;}
.apt-row:hover{background:var(--surf2);}
.apt-time{min-width:52px;text-align:center;background:rgba(22,73,255,.08);color:var(--p);font-weight:700;font-size:.72rem;padding:4px 5px;border-radius:7px;flex-shrink:0;}
.apt-info{flex:1;}
.apt-info h4{font-size:.82rem;font-weight:700;color:var(--navy);}
.apt-info p{font-size:.68rem;color:var(--tx3);margin-top:1px;}

/* ── Service card ── */
.svc-card{background:var(--surf);border-radius:var(--r);padding:1.15rem;border:1px solid var(--bdr2);box-shadow:var(--sh0);transition:all .2s;position:relative;overflow:hidden;}
.svc-card:hover{transform:translateY(-3px);box-shadow:var(--sh1);}
.svc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--p),var(--p2));}
.svc-ico{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--navy),var(--p));color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.15rem;margin-bottom:.8rem;box-shadow:0 3px 10px rgba(22,73,255,.22);}
.svc-nm{font-weight:700;font-size:.9rem;color:var(--navy);margin-bottom:1px;}
.svc-pr{color:var(--p);font-weight:800;font-size:1.1rem;}
.svc-dur{color:var(--tx3);font-size:.7rem;display:flex;align-items:center;gap:3px;margin-top:2px;}
.svc-dsc{font-size:.72rem;color:var(--tx3);margin-top:.45rem;line-height:1.55;}
.svc-acts{display:flex;gap:.4rem;margin-top:.8rem;}

/* ── Invoice preview ── */
.inv-prev{background:#fff;border-radius:var(--r);padding:2rem;box-shadow:var(--sh1);max-width:680px;margin:0 auto;}
.inv-hd{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.75rem;padding-bottom:1.5rem;border-bottom:2px solid var(--bdr2);}
.inv-logo{width:56px;height:56px;border-radius:12px;background:linear-gradient(135deg,var(--navy),var(--p));display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;overflow:hidden;margin-bottom:.65rem;}
.inv-logo img{width:100%;height:100%;object-fit:cover;}
.inv-title{font-size:2.5rem;font-weight:800;color:var(--navy);letter-spacing:-.04em;}
.inv-tot-sec{max-width:265px;margin-left:auto;}
.inv-row{display:flex;justify-content:space-between;padding:.3rem 0;font-size:.85rem;color:var(--tx2);}
.inv-row.grand{font-size:1.1rem;font-weight:800;color:var(--navy);border-top:2px solid var(--navy);padding-top:.55rem;margin-top:.25rem;}

/* ── Progress bar ── */
.prog{height:5px;background:var(--bdr2);border-radius:3px;overflow:hidden;margin-top:4px;}
.prog-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--p),var(--p2));transition:width .5s ease;}

/* ── Modal ── */
.ov{position:fixed;inset:0;background:rgba(10,22,40,.58);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fi .18s ease;}
.modal{background:var(--surf);border-radius:22px;padding:1.85rem;width:100%;max-width:520px;max-height:92vh;overflow-y:auto;animation:si .28s cubic-bezier(.23,1,.32,1);box-shadow:var(--sh2);position:relative;}
.modal-lg{max-width:660px;}
.modal-sm{max-width:390px;}
.modal-hd{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.4rem;gap:1rem;}
.modal-hd h2{font-size:1.4rem;font-weight:800;color:var(--navy);letter-spacing:-.02em;}
.modal-hd p{font-size:.72rem;color:var(--tx3);margin-top:3px;}
.modal-x{width:32px;height:32px;border-radius:50%;background:var(--bg);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--tx2);font-size:.88rem;transition:all .18s;flex-shrink:0;}
.modal-x:hover{background:var(--err);color:#fff;transform:rotate(90deg);}
.modal-ft{display:flex;gap:.6rem;justify-content:flex-end;margin-top:1.4rem;padding-top:.95rem;border-top:1px solid var(--bdr2);}

/* ── Toast ── */
#toast-wrap{position:fixed;z-index:9999;display:flex;flex-direction:column;gap:.42rem;pointer-events:none;bottom:1.4rem;right:1.4rem;}
.toast{display:flex;align-items:center;gap:.55rem;padding:.75rem 1.1rem;border-radius:var(--r3);font-size:.82rem;font-weight:600;box-shadow:var(--sh2);animation:tr .32s cubic-bezier(.23,1,.32,1);max-width:320px;pointer-events:all;background:var(--surf);border-left:4px solid;}
body.hi .toast{font-family:var(--fh);}
.toast.ok  {color:var(--ok);border-color:var(--ok);}
.toast.err {color:var(--err);border-color:var(--err);}
.toast.warn{color:var(--warn);border-color:var(--warn);}

/* ── Empty state ── */
.empty{text-align:center;padding:2.75rem 1.5rem;color:var(--tx3);}
.empty i{font-size:2.8rem;color:var(--bdr);display:block;margin-bottom:.8rem;}
.empty h3{font-size:.92rem;color:var(--tx2);margin-bottom:.35rem;font-weight:700;}
.empty p{font-size:.78rem;}

/* ── Swatches ── */
.swatches{display:flex;flex-wrap:wrap;gap:.48rem;margin-top:.5rem;}
.swatch{width:36px;height:36px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:all .18s;position:relative;}
.swatch:hover{transform:scale(1.12);}
.swatch.on{border-color:var(--navy);transform:scale(1.12);}
.swatch.on::after{content:'✓';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.68rem;font-weight:900;}

/* ── Logo drop ── */
.logo-drop{border:2px dashed var(--bdr);border-radius:var(--r3);padding:1.6rem;text-align:center;cursor:pointer;transition:all .18s;}
.logo-drop:hover{border-color:var(--p);background:rgba(22,73,255,.02);}
.logo-drop i{font-size:2.2rem;color:var(--bdr);display:block;margin-bottom:.6rem;}

/* ── Mob overlay ── */
#mob-ov{display:none;position:fixed;inset:0;background:rgba(10,22,40,.55);z-index:399;backdrop-filter:blur(2px);}

/* ══════════════════════════════════════════════
   MOBILE BOTTOM NAV — the correct implementation
   ══════════════════════════════════════════════ */
.bnav{
  display: none;                    /* hidden on desktop */
  position: fixed;
  bottom: 0; left: 0; right: 0;
  height: var(--bn);
  background: var(--surf);
  border-top: 1.5px solid var(--bdr2);
  box-shadow: 0 -6px 24px rgba(10,22,40,.12);
  z-index: 500;   /* below modal overlay (900) and below .ov backdrop */
  padding-bottom: env(safe-area-inset-bottom, 0);
}
/* When modal is open, hide bottom nav so it can't intercept touches */
body.modal-open .bnav { display: none !important; }
.bnav-inner{
  display: flex;
  align-items: stretch;
  height: 100%;
  width: 100%;
  overflow-x: auto;
  scrollbar-width: none;
}
.bnav-inner::-webkit-scrollbar{display:none;}
.bnav-btn{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  flex: 1;
  min-width: 52px;
  border: none;
  background: none;
  cursor: pointer;
  color: var(--tx4);
  transition: color .18s;
  padding: .2rem .1rem;
  position: relative;
  -webkit-tap-highlight-color: transparent;
}
.bnav-btn i{font-size:1.1rem;line-height:1;transition:transform .2s cubic-bezier(.23,1,.32,1);}
.bnav-btn span{font-size:.52rem;font-weight:700;white-space:nowrap;line-height:1;}
body.hi .bnav-btn span{font-family:var(--fh);font-size:.58rem;}
.bnav-btn.on{color:var(--p);}
.bnav-btn.on i{transform:scale(1.18) translateY(-1px);}
.bnav-btn.on::after{content:'';position:absolute;top:0;left:15%;right:15%;height:3px;background:var(--p);border-radius:0 0 5px 5px;}
.bnav-ndot{position:absolute;top:5px;right:calc(50% - 18px);width:7px;height:7px;border-radius:50%;background:var(--rose);border:2px solid var(--surf);}

/* ── Loading spinner ── */
.spin{display:inline-block;width:20px;height:20px;border:2px solid var(--bdr);border-top-color:var(--p);border-radius:50%;animation:spin .6s linear infinite;}
.loading-page{display:flex;align-items:center;justify-content:center;min-height:200px;flex-direction:column;gap:1rem;color:var(--tx3);}

/* ── Info box ── */
.info-box{background:rgba(22,73,255,.06);border:1px solid rgba(22,73,255,.18);border-radius:var(--r3);padding:.85rem 1rem;font-size:.78rem;color:var(--tx2);margin-bottom:1rem;display:flex;align-items:flex-start;gap:.6rem;}
.info-box i{color:var(--p);margin-top:1px;flex-shrink:0;}

/* ── Divider ── */
.div{height:1px;background:var(--bdr2);margin:.85rem 0;}

/* ── Animations ── */
@keyframes up{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}
@keyframes fi{from{opacity:0;}to{opacity:1;}}
@keyframes si{from{opacity:0;transform:scale(.94) translateY(10px);}to{opacity:1;transform:scale(1) translateY(0);}}
@keyframes tr{from{opacity:0;transform:translateX(100%);}to{opacity:1;transform:translateX(0);}}
@keyframes spin{to{transform:rotate(360deg);}}

/* ══ RESPONSIVE ══════════════════════════════ */
/* Tablet */
@media(max-width:1100px){
  .stats{grid-template-columns:1fr 1fr;}
  .ch-g{grid-template-columns:1fr;}
  .dash-g{grid-template-columns:1fr;}
}

/* Tablet — hide sidebar, show hamburger */
@media(max-width:960px){
  .sb{transform:translateX(-100%);}
  .sb.open{transform:translateX(0);}
  #mob-ov{display:block;}
  .main{margin-left:0;}
  .hbg{display:flex;}
}

/* Mobile — bottom nav takes over */
@media(max-width:768px){
  /* Show bottom nav */
  .bnav{display:block !important;}
  /* Sidebar hidden (use bottom nav) */
  .sb{display:none !important;}
  .hbg{display:none !important;}
  #mob-ov{display:none !important;}
  .main{margin-left:0;}
  /* Page padding clears bottom nav */
  .page{padding:.95rem .95rem calc(var(--bn) + 1.1rem) !important;}
  .tb{padding:0 .95rem;}

  /* Grid collapses */
  .stats{grid-template-columns:1fr 1fr;}
  .r2,.r3,.g2,.g3,.dash-g,.ch-g{grid-template-columns:1fr;}
  .ga{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));}
  .pg-hd{flex-direction:column;align-items:flex-start;}
  .fbar{flex-direction:column;align-items:stretch;}
  .fsel,.srch{width:100%;min-width:unset;}

  /* Modal slides up from bottom on mobile */
  .ov{align-items:flex-end;padding:0;}
  .ov .modal{border-radius:22px 22px 0 0;max-height:88vh;padding:1.5rem 1.25rem;width:100%;max-width:100%;}
  /* When modal open, page doesn't scroll and bnav is hidden */
  body.modal-open{overflow:hidden;}
  body.modal-open .bnav{display:none !important;}

  /* Invoice */
  .inv-prev{padding:1rem;}
  .inv-hd{flex-direction:column;gap:.8rem;}
  .inv-tot-sec{max-width:100%;}

  /* Auth */
  .auth{grid-template-columns:1fr;}
  .auth-l{display:none;}
  .auth-r{background:linear-gradient(160deg,var(--navy) 0%,var(--navy2) 100%);padding:2rem 1.25rem;min-height:100vh;display:flex;align-items:center;justify-content:center;}
  .auth-box{background:var(--surf);border-radius:22px;padding:1.75rem 1.4rem;}

  /* Toasts above bottom nav */
  #toast-wrap{bottom:calc(var(--bn) + .65rem);right:.75rem;left:.75rem;}
  .toast{max-width:100%;}

  /* Table compact */
  .tbl thead th,.tbl tbody td{padding:.6rem .7rem;}
}

@media(max-width:480px){
  .stats{grid-template-columns:1fr 1fr;}
  .sc-num{font-size:1.5rem;}
}

@media(max-width:380px){
  .stats{grid-template-columns:1fr;}
  /* Very small: hide label text on bottom nav, bigger icon */
  .bnav-btn span{display:none;}
  .bnav-btn i{font-size:1.25rem;}
}
