:root{
  --ocean-deep:#07406F; --ocean:#1273C9; --ocean-light:#4BA3E3;
  --sun:#FBB511; --sun-deep:#F2950C; --sand:#FFF7EA; --sand-deep:#FBEAD0;
  --night:#052744; --ink:#0B2A45; --muted:#5b6b7c; --ok:#0b7a3b; --danger:#c0392b;
  --r:16px; --shadow:0 14px 40px -18px rgba(7,64,111,.35); --shadow-sm:0 6px 18px -10px rgba(7,64,111,.4);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter','Segoe UI',system-ui,sans-serif;background:var(--sand);color:var(--ink);-webkit-font-smoothing:antialiased}
h1,h2,h3,.display{font-family:'Sora','Segoe UI',sans-serif;letter-spacing:-.01em}
a{color:var(--ocean);text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;border:2px solid transparent;border-radius:100px;
  font-family:'Sora',sans-serif;font-weight:600;font-size:1rem;padding:.8em 1.4em;transition:transform .15s,box-shadow .15s,background .15s}
.btn:active{transform:translateY(1px)}
.btn-sun{background:linear-gradient(135deg,var(--sun),var(--sun-deep));color:#3a2400;box-shadow:0 10px 24px -10px rgba(242,149,12,.6)}
.btn-sun:hover{transform:translateY(-2px)}
.btn-ocean{background:var(--ocean-deep);color:#fff}
.btn-ocean:hover{background:#0a4f87}
.btn-line{background:#fff;border-color:#dce4ec;color:var(--ocean-deep)}
.btn-line:hover{border-color:var(--ocean)}
.btn-danger{background:#fff;border-color:#f0c9c4;color:var(--danger)}
.btn-danger:hover{background:#fdf0ee}
.btn-block{width:100%}
.btn-lg{font-size:1.2rem;padding:1em 1.6em}

/* fields */
label.lab{display:block;font-family:'Sora';font-size:.82rem;font-weight:600;color:var(--ocean-deep);margin:0 0 6px}
.inp,select.inp,textarea.inp{width:100%;padding:13px 15px;border:1.5px solid #dce4ec;border-radius:12px;font-size:1rem;font-family:inherit;background:#fff;color:var(--ink);transition:border .2s}
.inp:focus{outline:none;border-color:var(--ocean)}
textarea.inp{resize:vertical;min-height:84px}
.field{margin-bottom:16px}
.row{display:flex;gap:14px;flex-wrap:wrap}
.row>*{flex:1;min-width:140px}

/* login */
.login-wrap{min-height:100vh;min-height:100svh;display:grid;place-items:center;padding:24px;
  background:linear-gradient(160deg,#07406F,#0a4f87 55%,#1273C9)}
.login-card{width:100%;max-width:420px;background:#fff;border-radius:24px;padding:38px 32px;box-shadow:0 30px 70px -30px rgba(0,0,0,.5)}
.login-logo{width:96px;height:120px;margin:0 auto 14px;background:url('/assets/logo-transparent.png') center/contain no-repeat}
.login-card h1{text-align:center;color:var(--ocean-deep);font-size:1.5rem;margin-bottom:4px}
.login-card .sub{text-align:center;color:var(--muted);font-size:.92rem;margin-bottom:26px}
.login-err{background:#fdecea;color:var(--danger);border:1px solid #f5c6c2;border-radius:10px;padding:10px 12px;font-size:.9rem;margin-bottom:14px;display:none}
.login-err.show{display:block}
.login-hint{margin-top:18px;font-size:.78rem;color:var(--muted);text-align:center;line-height:1.5}

/* app shell */
.shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.side{background:var(--night);color:#fff;padding:24px 18px;display:flex;flex-direction:column;gap:6px}
.side .brand{display:flex;align-items:center;gap:10px;margin-bottom:8px;padding:0 6px 16px;border-bottom:1px solid rgba(255,255,255,.12)}
.side .brand .lg{width:42px;height:52px;background:url('/assets/logo-transparent.png') center/contain no-repeat;flex:none}
.side .brand b{font-family:'Sora';font-size:1rem;line-height:1.1}
.side .brand small{display:block;color:rgba(255,255,255,.6);font-size:.72rem;font-weight:400}
.navi{display:flex;flex-direction:column;gap:4px;margin-top:10px}
.navi button{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:transparent;border:none;color:rgba(255,255,255,.82);
  font-family:'Sora';font-weight:600;font-size:1rem;padding:13px 14px;border-radius:12px;transition:.15s}
.navi button .ic{width:22px;height:22px;flex:none}
.navi button:hover{background:rgba(255,255,255,.08);color:#fff}
.navi button.active{background:linear-gradient(135deg,var(--sun),var(--sun-deep));color:#3a2400}
.navi .soon{margin-left:auto;font-size:.62rem;background:rgba(255,255,255,.18);color:#fff;padding:2px 7px;border-radius:100px;font-weight:700}
.side .foot{margin-top:auto;padding-top:16px;border-top:1px solid rgba(255,255,255,.12);font-size:.84rem;color:rgba(255,255,255,.7)}
.side .foot b{color:#fff;display:block;font-family:'Sora'}
.side .logout{margin-top:10px;background:rgba(255,255,255,.1);color:#fff;border:none;border-radius:10px;padding:10px;width:100%;font-weight:600}
.side .logout:hover{background:rgba(255,255,255,.18)}

.main{padding:34px 38px;overflow:auto}
.page-head{margin-bottom:24px}
.page-head h2{color:var(--ocean-deep);font-size:1.7rem}
.page-head p{color:var(--muted);margin-top:4px}

.card{background:#fff;border:1px solid var(--sand-deep);border-radius:var(--r);padding:24px;box-shadow:var(--shadow-sm);margin-bottom:20px}
.card h3{color:var(--ocean-deep);font-size:1.15rem;margin-bottom:14px}

/* photos grid */
.photos{display:flex;flex-wrap:wrap;gap:12px}
.photo{position:relative;width:120px;height:90px;border-radius:12px;overflow:hidden;border:1px solid var(--sand-deep);background:#f3f6f9}
.photo img{width:100%;height:100%;object-fit:cover}
.photo .del{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;background:rgba(192,57,43,.92);color:#fff;border:none;font-weight:700;line-height:1}
.addphoto{width:120px;height:90px;border:2px dashed #c5d3e0;border-radius:12px;display:grid;place-items:center;color:var(--ocean);background:#f7fafd;font-weight:600;font-size:.85rem}
.addphoto:hover{border-color:var(--ocean)}

/* menu list */
.cat-block{margin-bottom:22px}
.cat-block .cat-title{font-family:'Sora';color:var(--ocean-deep);font-size:1.05rem;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.cat-block .cat-title .pill{font-size:.68rem;background:rgba(18,115,201,.12);color:var(--ocean);padding:2px 9px;border-radius:100px}
.item{display:flex;gap:14px;align-items:center;background:#fff;border:1px solid var(--sand-deep);border-radius:12px;padding:12px 14px;margin-bottom:8px}
.item .thumb{width:56px;height:56px;border-radius:10px;background:#eef3f7 center/cover no-repeat;flex:none}
.item .info{flex:1;min-width:0}
.item .info b{color:var(--ocean-deep)}
.item .info span{display:block;color:var(--muted);font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.item .price{font-family:'Sora';font-weight:700;color:var(--ink);white-space:nowrap}
.item .price small{display:block;color:var(--muted);font-weight:500;font-size:.72rem}
.item .acts{display:flex;gap:6px}
.icbtn{width:38px;height:38px;border-radius:10px;border:1px solid #dce4ec;background:#fff;display:grid;place-items:center;color:var(--ocean-deep)}
.icbtn:hover{border-color:var(--ocean)}
.icbtn.danger{color:var(--danger);border-color:#f0c9c4}

/* tables grid */
.mesas{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}
.mesa{background:#eafaef;border:1px solid #bfe3c8;border-radius:14px;padding:18px;text-align:center;position:relative}
.mesa b{font-family:'Sora';color:var(--ocean-deep);font-size:1.1rem}
.mesa .stt{display:block;font-size:.72rem;font-weight:700;margin-top:4px;color:#0b7a3b}
.mesa.open{background:linear-gradient(135deg,#fbeae8,#f6d6d1);border-color:#e0a59c}
.mesa.open b{color:#a82c20}
.mesa.open .stt{color:#a82c20}
.mesa.waiting{background:linear-gradient(135deg,#fdf3da,#f9e7b8);border-color:#e7b54e}
.mesa.waiting b{color:#7a5200}
.mesa.waiting .stt{color:#8a5a00}
.mesa .del{position:absolute;top:6px;right:6px;width:24px;height:24px;border-radius:50%;border:none;background:#fdecea;color:var(--danger);font-weight:700}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(5,24,52,.55);display:none;align-items:center;justify-content:center;padding:18px;z-index:50}
.modal-bg.show{display:flex}
.modal{background:#fff;border-radius:20px;width:100%;max-width:560px;max-height:92vh;overflow:auto;padding:26px}
.modal h3{color:var(--ocean-deep);font-size:1.3rem;margin-bottom:16px}
.modal .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:10px}

/* toast */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ocean-deep);color:#fff;
  padding:13px 20px;border-radius:12px;font-weight:600;opacity:0;transition:.3s;z-index:100;box-shadow:var(--shadow)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.err{background:var(--danger)}
.toast.ok{background:var(--ok)}

.empty{color:var(--muted);text-align:center;padding:30px;border:2px dashed #d9e2ec;border-radius:14px}
.soon-box{background:#fff;border:1px solid var(--sand-deep);border-radius:var(--r);padding:40px;text-align:center}
.soon-box .big{font-size:2.6rem;margin-bottom:8px}
.soon-box h3{color:var(--ocean-deep);font-size:1.4rem;margin-bottom:8px}
.soon-box p{color:var(--muted);max-width:46ch;margin:0 auto}

.topbar{display:none}
@media (max-width:820px){
  .shell{grid-template-columns:1fr}
  .side{position:fixed;inset:0 0 0 auto;width:min(280px,82vw);transform:translateX(100%);transition:transform .3s;z-index:60;box-shadow:-16px 0 50px -18px rgba(0,0,0,.5)}
  .side.open{transform:none}
  .topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--night);color:#fff;position:sticky;top:0;z-index:40}
  .topbar .lg{width:34px;height:42px;background:url('/assets/logo-transparent.png') center/contain no-repeat}
  .topbar .burger{background:rgba(255,255,255,.12);border:none;color:#fff;border-radius:10px;padding:9px 12px;font-size:1.1rem}
  .main{padding:22px 18px}
  .scrim{position:fixed;inset:0;background:rgba(5,24,52,.5);z-index:55;display:none}
  .scrim.show{display:block}
}

/* ===== Fase 2 ===== */
/* dashboard */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-bottom:22px}
.stat{background:#fff;border:1px solid var(--sand-deep);border-radius:var(--r);padding:20px;box-shadow:var(--shadow-sm)}
.stat .k{font-size:.8rem;color:var(--muted);font-family:'Sora';font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.stat .v{font-family:'Sora';font-weight:800;color:var(--ocean-deep);font-size:1.9rem;margin-top:6px;line-height:1}
.stat .s{color:var(--muted);font-size:.82rem;margin-top:4px}
.stat.sun{background:linear-gradient(135deg,#fff7ea,#ffedcf);border-color:#f4d79a}
.stat.sun .v{color:var(--sun-deep)}
.rank-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px dashed #e7eef4}
.rank-row:last-child{border-bottom:none}
.rank-row .pos{width:30px;height:30px;border-radius:50%;background:var(--ocean-deep);color:#fff;display:grid;place-items:center;font-family:'Sora';font-weight:700;font-size:.85rem;flex:none}
.rank-row .nm{flex:1;font-weight:600;color:var(--ink)}
.rank-row .qt{font-family:'Sora';font-weight:700;color:var(--ocean)}
.rank-row .vl{color:var(--muted);min-width:90px;text-align:right}

/* comanda cards (master) */
.cmd-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.cmd{background:#fff;border:1px solid var(--sand-deep);border-left:5px solid var(--ocean);border-radius:14px;padding:16px;box-shadow:var(--shadow-sm);cursor:pointer;transition:.15s}
.cmd:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.cmd.closed{border-left-color:var(--sun-deep)}
.cmd .mesa-nm{font-family:'Sora';font-weight:700;color:var(--ocean-deep);font-size:1.1rem}
.cmd .seq{font-size:.78rem;color:var(--muted)}
.cmd .tot{font-family:'Sora';font-weight:800;font-size:1.5rem;color:var(--ink);margin-top:8px}
.cmd .meta{font-size:.78rem;color:var(--muted);margin-top:4px}
.section-h{font-family:'Sora';font-weight:700;color:var(--ocean-deep);font-size:1.1rem;margin:22px 0 12px;display:flex;align-items:center;gap:8px}
.section-h .badge{background:var(--ocean);color:#fff;border-radius:100px;font-size:.72rem;padding:2px 9px}
.section-h .badge.warn{background:var(--sun-deep);color:#3a2400}

/* ===== Garçom ===== */
.gx{min-height:100vh;min-height:100svh;display:flex;flex-direction:column;background:var(--sand)}
.gx-top{background:var(--night);color:#fff;display:flex;align-items:center;gap:12px;padding:14px 18px;position:sticky;top:0;z-index:30}
.gx-top .lg{width:36px;height:44px;background:url('/assets/logo-transparent.png') center/contain no-repeat;flex:none}
.gx-top b{font-family:'Sora';font-size:1.05rem}
.gx-top small{display:block;color:rgba(255,255,255,.6);font-size:.72rem}
.gx-top .right{margin-left:auto;display:flex;gap:8px;align-items:center}
.gx-top .right button{background:rgba(255,255,255,.12);border:none;color:#fff;border-radius:10px;padding:10px 14px;font-weight:600;font-family:'Sora'}
.gx-body{padding:18px;flex:1}
.gx-h{font-family:'Sora';font-weight:800;color:var(--ocean-deep);font-size:1.5rem;margin-bottom:4px}
.gx-sub{color:var(--muted);margin-bottom:16px}

.gmesas{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px}
.gmesa{border-radius:18px;padding:22px 14px;text-align:center;cursor:pointer;border:2px solid #bfe3c8;background:#eafaef;transition:.12s;min-height:120px;display:flex;flex-direction:column;justify-content:center;gap:6px}
.gmesa:active{transform:scale(.97)}
.gmesa .nm{font-family:'Sora';font-weight:800;color:var(--ocean-deep);font-size:1.4rem}
.gmesa .st{font-size:.82rem;font-weight:600;color:#0b7a3b}
.gmesa .tt{font-family:'Sora';font-weight:800;font-size:1.05rem;color:var(--ocean-deep)}
/* 🔴 comanda aberta */
.gmesa.open{background:linear-gradient(135deg,#c0392b,#a82c20);border-color:#a82c20}
.gmesa.open .nm,.gmesa.open .tt{color:#fff}
.gmesa.open .st{color:#ffe08a}
/* 🟡 aguardando pagamento */
.gmesa.waiting{background:linear-gradient(135deg,#fbe7b3,#f7d27a);border-color:#e7b54e}
.gmesa.waiting .nm,.gmesa.waiting .tt{color:#5a3d00}
.gmesa.waiting .st{color:#8a5a00}

/* comanda screen */
.gc{display:flex;flex-direction:column;min-height:100vh;min-height:100svh;background:var(--sand)}
.gc-head{background:var(--night);color:#fff;padding:12px 16px;position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:12px}
.gc-head .back{background:rgba(255,255,255,.14);border:none;color:#fff;border-radius:10px;padding:10px 14px;font-weight:700;font-size:1.1rem}
.gc-head .ti{font-family:'Sora';font-weight:800}
.gc-head .ti small{display:block;color:rgba(255,255,255,.6);font-weight:400;font-size:.74rem}
.gc-head .tot{margin-left:auto;text-align:right}
.gc-head .tot .l{font-size:.7rem;color:rgba(255,255,255,.6)}
.gc-head .tot .v{font-family:'Sora';font-weight:800;font-size:1.5rem;color:var(--sun)}
.gc-tabs{display:flex;background:#fff;border-bottom:1px solid var(--sand-deep);position:sticky;top:56px;z-index:20}
.gc-tabs button{flex:1;background:none;border:none;padding:14px;font-family:'Sora';font-weight:700;color:var(--muted);font-size:1rem;border-bottom:3px solid transparent}
.gc-tabs button.active{color:var(--ocean-deep);border-bottom-color:var(--sun)}
.gc-body{flex:1;padding:14px;padding-bottom:96px}
.menu-item{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--sand-deep);border-radius:14px;padding:14px;margin-bottom:10px;cursor:pointer}
.menu-item:active{background:#f2f7fb}
.menu-item .thumb{width:50px;height:50px;border-radius:10px;background:#eef3f7 center/cover no-repeat;flex:none}
.menu-item .info{flex:1;min-width:0}
.menu-item .info b{color:var(--ocean-deep);font-size:1.05rem}
.menu-item .info span{display:block;color:var(--muted);font-size:.84rem}
.menu-item .pr{font-family:'Sora';font-weight:800;color:var(--ink);white-space:nowrap}
.menu-item .pr small{display:block;color:var(--muted);font-weight:600;font-size:.7rem}
.menu-item .plus{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--sun),var(--sun-deep));color:#3a2400;border:none;font-size:1.5rem;font-weight:700;flex:none}
.cat-h{font-family:'Sora';font-weight:700;color:var(--ocean-deep);font-size:1rem;margin:16px 0 8px}

.citem{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--sand-deep);border-radius:12px;padding:12px 14px;margin-bottom:8px}
.citem .q{font-family:'Sora';font-weight:800;color:var(--ocean);min-width:34px}
.citem .nm{flex:1}
.citem .nm b{color:var(--ink)}
.citem .nm small{display:block;color:var(--muted);font-size:.78rem}
.citem .sb{font-family:'Sora';font-weight:700;color:var(--ink)}
.citem .rm{width:34px;height:34px;border-radius:8px;border:1px solid #f0c9c4;background:#fff;color:var(--danger);font-weight:700}

.gc-foot{position:fixed;left:0;right:0;bottom:0;background:#fff;border-top:1px solid var(--sand-deep);padding:12px 14px;display:flex;gap:10px;z-index:25;box-shadow:0 -8px 24px -16px rgba(0,0,0,.3)}
.gc-foot .btn{flex:1}

/* qty stepper */
.stepper{display:flex;align-items:center;gap:18px;justify-content:center;margin:10px 0 18px}
.stepper button{width:54px;height:54px;border-radius:50%;border:2px solid var(--ocean);background:#fff;color:var(--ocean-deep);font-size:1.8rem;font-weight:700}
.stepper .n{font-family:'Sora';font-weight:800;font-size:2rem;min-width:48px;text-align:center;color:var(--ink)}
.portion{display:flex;gap:10px;margin:8px 0 18px}
.portion button{flex:1;padding:14px;border-radius:12px;border:2px solid #dce4ec;background:#fff;font-family:'Sora';font-weight:700;color:var(--muted)}
.portion button.active{border-color:var(--ocean);color:var(--ocean-deep);background:#eef6fd}

.summary{background:#f7fafd;border:1px solid var(--sand-deep);border-radius:12px;padding:14px;margin:8px 0 16px}
.summary .l{display:flex;justify-content:space-between;padding:5px 0;color:var(--ink)}
.summary .l.tot{font-family:'Sora';font-weight:800;font-size:1.3rem;color:var(--ocean-deep);border-top:1px dashed #cdd9e3;margin-top:6px;padding-top:10px}
.svc-toggle{display:flex;align-items:center;gap:10px;margin:6px 0 14px;cursor:pointer;user-select:none}
.svc-toggle input{width:22px;height:22px}

/* impressão térmica */
#print-area{display:none}
@media print{
  body{background:#fff}
  body *{visibility:hidden}
  #print-area,#print-area *{visibility:visible}
  #print-area{display:block;position:absolute;left:0;top:0;width:76mm;padding:4mm;font-family:'Courier New',monospace;color:#000}
  #print-area h2{font-size:15pt;text-align:center;margin:0 0 2mm}
  #print-area .ctr{text-align:center;font-size:9pt}
  #print-area hr{border:none;border-top:1px dashed #000;margin:2mm 0}
  #print-area .ln{display:flex;justify-content:space-between;font-size:9.5pt;margin:1mm 0}
  #print-area .big{font-size:13pt;font-weight:bold}
  .no-print{display:none !important}
}

/* ===== Cashback ===== */
.switch{position:relative;display:inline-block;width:52px;height:30px;flex:none}
.switch input{opacity:0;width:0;height:0}
.switch .sl{position:absolute;inset:0;background:#cdd9e3;border-radius:100px;transition:.2s;cursor:pointer}
.switch .sl::before{content:"";position:absolute;height:24px;width:24px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
.switch input:checked + .sl{background:var(--ok)}
.switch input:checked + .sl::before{transform:translateX(22px)}
.switch-row{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.switch-row b{font-family:'Sora';color:var(--ocean-deep)}
.ctable{width:100%;border-collapse:collapse}
.ctable th{text-align:left;font-family:'Sora';font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;padding:8px 10px;border-bottom:2px solid var(--sand-deep)}
.ctable td{padding:11px 10px;border-bottom:1px solid #eef3f7;font-size:.92rem}
.ctable tr:hover td{background:#f7fafd}
.ctable .bal{font-family:'Sora';font-weight:700;color:var(--ok)}
.tag-ok{background:#e7f7ec;color:#0b7a3b;border-radius:100px;padding:2px 9px;font-size:.72rem;font-weight:700}
.tag-no{background:#fdecea;color:#c0392b;border-radius:100px;padding:2px 9px;font-size:.72rem;font-weight:700}
.cashback-btn{background:linear-gradient(135deg,#0b7a3b,#0a9c4a);color:#fff;border:none;border-radius:100px;padding:.8em 1.4em;font-family:'Sora';font-weight:700;font-size:1rem}
.redeem-box{background:#f0faf3;border:1px solid #bfe3c8;border-radius:12px;padding:14px;margin:8px 0 14px}
.stat.cash{background:linear-gradient(135deg,#e9f9ef,#cdeed8);border-color:#a6dab8}
.stat.cash .v{color:#0b7a3b}

/* ===== Admin (super) ===== */
.admin-top{display:flex;align-items:center;gap:14px;margin-bottom:24px}
.admin-top .lg{width:44px;height:54px;background:url('/assets/logo-transparent.png') center/contain no-repeat;flex:none}
.admin-top h2{color:var(--ocean-deep);font-size:1.7rem;line-height:1.1}
.admin-top small{color:var(--muted)}
.admin-top .sp{margin-left:auto}
.chart-card{background:#fff;border:1px solid var(--sand-deep);border-radius:var(--r);padding:22px;box-shadow:var(--shadow-sm);margin-bottom:20px}
.chart-card h3{color:var(--ocean-deep);font-size:1.1rem;margin-bottom:4px}
.chart-card .hint{color:var(--muted);font-size:.85rem;margin-bottom:14px}
.chart{width:100%;height:auto;display:block}
.lead-row{display:flex;align-items:center;gap:12px;padding:9px 0;border-bottom:1px dashed #e7eef4}
.lead-row:last-child{border-bottom:none}
.lead-row .nm{flex:1;font-weight:600;color:var(--ink)}
.lead-row .ph{color:var(--ocean);font-size:.88rem}
.lead-row .co{color:var(--muted);font-size:.8rem;min-width:120px;text-align:right}

/* status de conexão (offline) */
.netbar{position:fixed;left:50%;transform:translateX(-50%);bottom:14px;z-index:120;display:none;align-items:center;gap:8px;
  background:#a82c20;color:#fff;padding:9px 16px;border-radius:100px;font-family:'Sora';font-weight:600;font-size:.85rem;box-shadow:var(--shadow)}
.netbar.show{display:flex}
.netbar .dot{width:9px;height:9px;border-radius:50%;background:#ffd2cc;animation:pulse 1.4s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.netbar.sync{background:#0b7a3b}

/* ===== Admin top-nav painel ===== */
.adminwrap{max-width:1120px;margin:0 auto;padding:26px 22px 90px}
.adminnav{display:flex;align-items:center;gap:6px;flex-wrap:wrap;background:#052744;border-radius:16px;padding:10px 14px;margin-bottom:22px;box-shadow:var(--shadow-sm)}
.adminnav .lg{width:34px;height:42px;background:url('/assets/logo-transparent.png') center/contain no-repeat;flex:none;margin-right:6px}
.adminnav button{background:transparent;border:none;color:rgba(255,255,255,.82);font-family:'Sora';font-weight:600;font-size:.95rem;padding:9px 14px;border-radius:10px;cursor:pointer}
.adminnav button:hover{background:rgba(255,255,255,.1);color:#fff}
.adminnav button.active{background:linear-gradient(135deg,var(--sun),var(--sun-deep));color:#3a2400}
.adminnav .badge-root{margin-left:auto;border:1.5px solid var(--sun);color:var(--sun);border-radius:100px;padding:4px 12px;font-family:'Sora';font-weight:700;font-size:.72rem;letter-spacing:.06em}
.adminnav .sair{background:rgba(255,255,255,.12);color:#fff}
.admin-title h2{color:var(--ocean-deep);font-size:1.7rem;line-height:1.1}
.admin-title p{color:var(--muted);margin:3px 0 22px}
.stat.acc{position:relative;overflow:hidden;padding-top:24px}
.stat.acc::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--ocean-light),var(--sun))}
