/* ============================================================
   AppNexaClínica — estilo principal
   Dark SaaS · identidade neutra: azul + grafite (cores do logo)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@500;600;700;800&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --bg:#0d0e12;
  --surface:#15171e;
  --surface-2:#1c1f28;
  --border:#262a36;
  --text:#eef0f4;
  --muted:#9aa1b2;
  --accent:#2f6fdd;          /* azul do logo */
  --accent-soft:rgba(47,111,221,.16);
  --slate:#38414a;           /* grafite do logo */
  --warn:#d9a84e;            /* avisos (atraso, estoque baixo, trial) */
  --gold:var(--warn);
  --gold-soft:rgba(217,168,78,.14);
  --green:#3ecf8e;
  --green-soft:rgba(62,207,142,.14);
  --red:#ff5d5d;
  --red-soft:rgba(255,93,93,.14);
  --blue:#5b8def;
  --blue-soft:rgba(91,141,239,.14);
  --radius:14px;
  --shadow:0 10px 30px rgba(0,0,0,.35);
  --font-display:'Outfit',sans-serif;
  --font-body:'Inter',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:15px;line-height:1.55;min-height:100vh}
h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:-.01em}
a{color:var(--accent);text-decoration:none}
img{max-width:100%}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit;font-size:15px}

/* ---------- componentes base ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:10px;
  padding:11px 18px;font-weight:600;font-size:14px;transition:.18s;white-space:nowrap}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{filter:brightness(1.1)}
.btn-gold{background:var(--slate);color:#eef0f4;border:1px solid #4a5560}
.btn-gold:hover{filter:brightness(1.15)}
.btn-ghost{background:transparent;border:1px dashed var(--border);color:var(--muted)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}
.btn-green{background:var(--green);color:#06281a}
.btn-red{background:var(--red-soft);color:var(--red);border:1px solid transparent}
.btn-red:hover{border-color:var(--red)}
.btn-sm{padding:7px 12px;font-size:13px;border-radius:8px}
.btn-block{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed}

.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;background:var(--surface-2);border:1px solid var(--border);
  border-radius:10px;padding:11px 13px;color:var(--text);outline:none;transition:border .15s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent)}
.field small{color:var(--muted);font-size:12px}
.row{display:grid;gap:12px}
.row.c2{grid-template-columns:1fr 1fr}
.row.c3{grid-template-columns:1fr 1fr 1fr}
@media(max-width:640px){.row.c2,.row.c3{grid-template-columns:1fr}}

.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600}
.badge.rose{background:var(--accent-soft);color:var(--accent)}
.badge.gold{background:var(--gold-soft);color:var(--gold)}
.badge.green{background:var(--green-soft);color:var(--green)}
.badge.red{background:var(--red-soft);color:var(--red)}
.badge.blue{background:var(--blue-soft);color:var(--blue)}
.badge.muted{background:var(--surface-2);color:var(--muted)}

.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}
table{width:100%;border-collapse:collapse;font-size:14px;background:var(--surface)}
th{text-align:left;padding:12px 14px;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);white-space:nowrap}
td{padding:12px 14px;border-bottom:1px solid var(--border);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(255,255,255,.015)}

.avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;background:var(--surface-2);border:1px solid var(--border)}
.avatar.lg{width:72px;height:72px}
.thumb{width:44px;height:44px;border-radius:10px;object-fit:cover;background:var(--surface-2);border:1px solid var(--border)}

/* ---------- toast ---------- */
#toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--surface-2);
  border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:10px;padding:13px 20px;
  font-size:14px;opacity:0;pointer-events:none;transition:.25s;z-index:9999;box-shadow:var(--shadow);max-width:90vw}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast.ok{border-left-color:var(--green)}
#toast.err{border-left-color:var(--red)}

/* ---------- modal ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(5,6,9,.7);backdrop-filter:blur(4px);display:none;
  align-items:flex-start;justify-content:center;z-index:1000;padding:24px;overflow-y:auto}
.modal-bg.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  width:100%;max-width:560px;padding:24px;box-shadow:var(--shadow);margin:auto 0}
.modal.wide{max-width:760px}
.modal h3{margin-bottom:16px;font-size:19px}
.modal-close{float:right;background:none;border:none;color:var(--muted);font-size:22px;line-height:1}
.modal-close:hover{color:var(--text)}

/* ---------- layout login ---------- */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(1100px 500px at 70% -10%, rgba(224,86,110,.12), transparent),
             radial-gradient(800px 400px at 10% 110%, rgba(217,168,78,.08), transparent), var(--bg)}
.auth-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);
  border-radius:18px;padding:34px;box-shadow:var(--shadow)}
.brand{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.brand-mark{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:#fff;overflow:hidden}
.brand-mark img{width:100%;height:100%;object-fit:contain;padding:3px}
.brand h1{font-size:22px}
.brand h1 span{color:var(--accent)}
.auth-sub{color:var(--muted);font-size:13.5px;margin-bottom:22px}
.auth-tabs{display:flex;gap:6px;background:var(--surface-2);border-radius:10px;padding:4px;margin-bottom:20px}
.auth-tabs button{flex:1;border:none;background:transparent;color:var(--muted);padding:9px;border-radius:8px;font-weight:600;font-size:13.5px}
.auth-tabs button.on{background:var(--accent);color:#fff}

/* ---------- layout app ---------- */
.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.sidebar{background:var(--surface);border-right:1px solid var(--border);padding:20px 14px;display:flex;
  flex-direction:column;gap:4px;position:sticky;top:0;height:100vh;overflow-y:auto}
.sidebar .brand{padding:0 8px;margin-bottom:18px}
.sidebar .brand h1{font-size:18px}
.nav-item{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:10px;color:var(--muted);
  font-weight:500;font-size:14px;border:none;background:none;width:100%;text-align:left;transition:.15s}
.nav-item:hover{color:var(--text);background:var(--surface-2)}
.nav-item.on{color:var(--accent);background:var(--accent-soft);font-weight:600}
.nav-item .ico{width:20px;text-align:center}
.nav-sep{height:1px;background:var(--border);margin:10px 8px}
.sidebar-foot{margin-top:auto;padding:10px 8px;font-size:12px;color:var(--muted)}
.userchip{display:flex;align-items:center;gap:10px;padding:10px 8px;border-top:1px solid var(--border);margin-top:8px}
.userchip .nm{font-size:13px;font-weight:600;line-height:1.2}
.userchip .rl{font-size:11px;color:var(--muted)}

.main{padding:26px 30px;max-width:1280px;width:100%}
.page-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:22px;flex-wrap:wrap}
.page-head h2{font-size:23px}
.page-head p{color:var(--muted);font-size:13.5px;margin-top:2px}
.head-actions{display:flex;gap:10px;flex-wrap:wrap}

.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:22px}
.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.stat .lbl{color:var(--muted);font-size:12.5px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.stat .val{font-family:var(--font-display);font-size:25px;font-weight:700;margin-top:6px}
.stat .val.rose{color:var(--accent)} .stat .val.gold{color:var(--gold)}
.stat .val.green{color:var(--green)} .stat .val.red{color:var(--red)}

.searchbar{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.searchbar input,.searchbar select{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;
  padding:11px 13px;color:var(--text);outline:none;min-width:0}
.searchbar input{flex:1;min-width:180px}
.searchbar input:focus{border-color:var(--accent)}

.empty{padding:46px 20px;text-align:center;color:var(--muted)}
.empty .big{font-size:34px;margin-bottom:10px}

/* ---------- PDV ---------- */
.pdv{display:grid;grid-template-columns:1.4fr 1fr;gap:18px;align-items:start}
@media(max-width:980px){.pdv{grid-template-columns:1fr}}
.scan-box{display:flex;gap:10px;margin-bottom:14px}
.scan-box input{flex:1;background:var(--surface-2);border:2px solid var(--accent);border-radius:12px;
  padding:14px 16px;color:var(--text);font-size:16px;outline:none}
.scan-box input:focus{box-shadow:0 0 0 3px var(--gold-soft)}
.scan-hint{font-size:12.5px;color:var(--muted);margin-bottom:14px}
.cart-item{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--border)}
.cart-item:last-child{border-bottom:none}
.cart-item .info{flex:1;min-width:0}
.cart-item .nm{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cart-item .dt{font-size:12.5px;color:var(--muted)}
.qty-ctrl{display:flex;align-items:center;gap:8px}
.qty-ctrl button{width:28px;height:28px;border-radius:8px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:15px}
.totline{display:flex;justify-content:space-between;padding:7px 0;font-size:14px;color:var(--muted)}
.totline.big{font-size:21px;font-weight:700;color:var(--text);font-family:var(--font-display);
  border-top:1px solid var(--border);margin-top:8px;padding-top:14px}
.totline.big .v{color:var(--accent)}
.pay-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin:14px 0}
.pay-grid button{border:1px solid var(--border);background:var(--surface-2);color:var(--text);border-radius:10px;
  padding:12px 8px;font-weight:600;font-size:13.5px;transition:.15s}
.pay-grid button.on{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}

/* ---------- grid de produtos ---------- */
.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px}
.prod-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:.15s}
.prod-card:hover{border-color:var(--accent)}
.prod-card .ph{aspect-ratio:1;background:var(--surface-2);display:flex;align-items:center;justify-content:center;
  font-size:34px;overflow:hidden}
.prod-card .ph img{width:100%;height:100%;object-fit:cover}
.prod-card .bd{padding:12px;display:flex;flex-direction:column;gap:4px;flex:1}
.prod-card .nm{font-weight:600;font-size:13.5px;line-height:1.3}
.prod-card .pr{color:var(--accent);font-weight:700;font-family:var(--font-display)}
.prod-card .st{font-size:12px;color:var(--muted)}

/* ---------- mobile nav ---------- */
.mobile-top{display:none}
@media(max-width:860px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-260px;width:250px;z-index:900;transition:left .22s;box-shadow:var(--shadow)}
  .sidebar.open{left:0}
  .mobile-top{display:flex;align-items:center;gap:12px;background:var(--surface);border-bottom:1px solid var(--border);
    padding:13px 16px;position:sticky;top:0;z-index:800}
  .mobile-top .burger{background:none;border:1px solid var(--border);border-radius:9px;color:var(--text);
    width:38px;height:38px;font-size:17px}
  .mobile-top .t{font-family:var(--font-display);font-weight:700}
  .mobile-top .t span{color:var(--accent)}
  .main{padding:18px 14px}
  .sidebar-mask{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:850;display:none}
  .sidebar-mask.open{display:block}
}

/* ---------- impressão (recibo / carnê) ---------- */
.print-area{display:none}
@media print{
  body *{visibility:hidden}
  .print-area,.print-area *{visibility:visible}
  .print-area{display:block;position:absolute;left:0;top:0;width:100%;background:#fff;color:#000}
}


/* ---------- ícones SVG ---------- */
svg.i{flex:none;vertical-align:-3px}
.nav-item .ico{display:inline-flex;align-items:center;width:22px}
.badge svg.i{vertical-align:-2px;margin-right:2px}
.scan-hint svg.i{vertical-align:-2px;color:var(--muted)}
.empty .big{display:flex;justify-content:center;color:var(--muted);opacity:.7;margin-bottom:10px}
.pay-grid button{display:inline-flex;align-items:center;justify-content:center;gap:7px}


/* ---------- agenda (grade do dia) ---------- */
.agenda-dia{display:flex;flex-direction:column;gap:8px}
.consulta-row{display:flex;align-items:center;gap:12px;background:var(--surface-2);border:1px solid var(--border);
  border-radius:12px;padding:11px 14px;border-left:3px solid var(--accent)}
.consulta-row.aguardando{border-left-color:var(--warn)}
.consulta-row.realizada{border-left-color:var(--green)}
.consulta-row.faltou,.consulta-row.cancelada{border-left-color:var(--red);opacity:.65}
.consulta-row .hora{font-family:var(--font-display);font-weight:700;font-size:15px;min-width:46px}
.consulta-row .info{flex:1;min-width:0}
.consulta-row .info .pac{font-weight:600}
.consulta-row .info .det{font-size:12.5px;color:var(--muted)}
.consulta-row .acts{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}

/* ---------- calendário (página pública e interna) ---------- */
.cal{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:12px}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.cal-head b{font-family:var(--font-display);text-transform:capitalize}
.cal-head button{background:none;border:1px solid var(--border);border-radius:8px;color:var(--text);
  width:30px;height:30px;display:flex;align-items:center;justify-content:center}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;text-align:center}
.cal-grid .wd{font-size:11px;color:var(--muted);font-weight:600;padding:4px 0}
.cal-grid .dia{border:none;background:transparent;color:var(--text);border-radius:9px;padding:8px 0;font-size:13.5px}
.cal-grid .dia:hover:not(:disabled){background:var(--accent-soft)}
.cal-grid .dia.on{background:var(--accent);color:#fff;font-weight:700}
.cal-grid .dia:disabled{opacity:.25;cursor:default}
.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(76px,1fr));gap:8px;margin-top:12px}
.slots button{background:var(--surface-2);border:1px solid var(--border);border-radius:9px;color:var(--text);
  padding:9px 0;font-weight:600;font-size:13.5px}
.slots button.on{background:var(--accent);border-color:var(--accent);color:#fff}
.slots button:hover:not(.on){border-color:var(--accent)}

/* ---------- página pública de agendamento ---------- */
.pub-wrap{max-width:680px;margin:0 auto;padding:22px 16px 60px}
.pub-head{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.pub-head img.logo{width:52px;height:52px;border-radius:13px;background:#fff;object-fit:contain;padding:4px}
.pub-head h1{font-size:21px}
.pub-head p{color:var(--muted);font-size:13px}
.passos{display:flex;gap:6px;margin-bottom:18px}
.passos .p{flex:1;height:4px;border-radius:4px;background:var(--border)}
.passos .p.on{background:var(--accent)}
.prof-pick{display:flex;flex-direction:column;gap:10px}
.prof-card{display:flex;align-items:center;gap:13px;background:var(--surface-2);border:1px solid var(--border);
  border-radius:13px;padding:13px;cursor:pointer;text-align:left;color:var(--text);width:100%}
.prof-card:hover{border-color:var(--accent)}
.prof-card.on{border-color:var(--accent);background:var(--accent-soft)}
.prof-card img,.prof-card .ph{width:54px;height:54px;border-radius:50%;object-fit:cover;flex:none;
  background:var(--surface);display:flex;align-items:center;justify-content:center;color:var(--muted)}
.prof-card .nm{font-weight:700}
.prof-card .sp{font-size:12.5px;color:var(--muted)}
.serv-pick{display:flex;flex-direction:column;gap:8px}
.serv-card{display:flex;justify-content:space-between;align-items:center;background:var(--surface-2);
  border:1px solid var(--border);border-radius:11px;padding:12px 14px;cursor:pointer;color:var(--text);width:100%}
.serv-card.on{border-color:var(--accent);background:var(--accent-soft)}
.pix-box{background:var(--surface-2);border:1px dashed var(--accent);border-radius:12px;padding:14px;margin:12px 0}
.pix-box .chave{display:flex;align-items:center;gap:8px;background:var(--bg);border-radius:9px;
  padding:9px 12px;margin-top:8px;font-family:monospace;font-size:13.5px;word-break:break-all}
.resumo-ag{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:14px;margin-bottom:14px}
.resumo-ag .totline{font-size:14px}

/* ---------- divulgação (link + mensagem pronta) ---------- */
.share-box{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:14px}
.share-box .lk{display:flex;gap:8px;align-items:center;background:var(--bg);border-radius:9px;
  padding:9px 12px;font-family:monospace;font-size:13px;word-break:break-all;margin:8px 0}
.share-box textarea{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:9px;
  padding:10px 12px;color:var(--text);font-size:13.5px;min-height:130px;resize:vertical}

/* ---------- comprovante no modal ---------- */
.comp-view img{max-width:100%;border-radius:10px;border:1px solid var(--border)}
.aniv-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border)}
.aniv-row:last-child{border-bottom:none}
