/* Três Marias Churrascaria — Design System (tokens só aqui). Light + Dark. */
:root{
  --accent:#C0392B; --accent-hover:#A93226; --accent-soft:#FBEBE9; --gold:#C98A00;
  --bg:#F7F4EF; --surface:#FFFFFF; --surface-2:#F2ECE3; --surface-3:#EAE0D3;
  --ink:#241610; --ink-text:#F4E9DE; --ink-text-2:#C2AE9C;
  --border:#E7DDCF; --border-strong:#D6C7B4;
  --text:#2A1D15; --text-2:#6C5B4D; --text-3:#9C8B7B;
  --ok:#2E9E6B; --ok-bg:#E7F6EE; --warn:#B87400; --warn-bg:#FBF1DF;
  --danger:#D0402F; --danger-bg:#FBE9E6; --info:#2D7FF9; --info-bg:#EAF2FE;
  --r:10px; --r-lg:16px; --r-xl:22px; --r-full:999px;
  --shadow-s:0 1px 2px rgba(40,20,10,.06); --shadow:0 12px 34px rgba(40,20,10,.12); --shadow-l:0 26px 64px rgba(40,20,10,.2);
  --topbar-h:60px; --transition:.16s ease;
  --font:'Plus Jakarta Sans','Inter',-apple-system,system-ui,sans-serif;
}
[data-theme="dark"]{
  --accent:#E4694E; --accent-hover:#EE7D63; --accent-soft:#3A201A; --gold:#E0A83A;
  --bg:#17110C; --surface:#211711; --surface-2:#2A1E16; --surface-3:#33261B;
  --ink:#0F0A07; --ink-text:#F4E9DE; --ink-text-2:#B6A28F;
  --border:#33261B; --border-strong:#4A3726;
  --text:#F1E7DC; --text-2:#C7B5A3; --text-3:#8F7D6D;
  --ok:#34D399; --ok-bg:#122A20; --warn:#F0B429; --warn-bg:#2E2410;
  --danger:#F2765F; --danger-bg:#331A16; --info:#5A9DFF; --info-bg:#16263F;
  --shadow-s:0 1px 2px rgba(0,0,0,.5); --shadow:0 12px 34px rgba(0,0,0,.55); --shadow-l:0 26px 64px rgba(0,0,0,.7);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14.5px;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
h1,h2,h3,h4{letter-spacing:-.02em;line-height:1.15}

/* ── Marca ───────────────────────────────────────────────────────── */
.brand{display:inline-flex;align-items:center;gap:10px}
.brand .flame{width:38px;height:38px;border-radius:11px;background:linear-gradient(150deg,var(--accent),var(--gold));
  display:grid;place-items:center;color:#fff;flex-shrink:0;box-shadow:var(--shadow-s)}
.brand .flame svg{width:22px;height:22px}
.brand .nm{font-weight:800;font-size:16px;letter-spacing:-.02em;line-height:1.05}
.brand .nm span{display:block;font-size:10.5px;font-weight:600;color:var(--text-3);letter-spacing:.02em}
.brand.lg .flame{width:60px;height:60px;border-radius:16px}.brand.lg .flame svg{width:34px;height:34px}
.brand.lg .nm{font-size:22px}

/* ── Botões ──────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:var(--r);
  font-weight:700;font-size:14.5px;cursor:pointer;border:1px solid transparent;transition:var(--transition);font-family:inherit;background:none;color:var(--text)}
.btn svg{width:17px;height:17px}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-hover)}
.btn-gold{background:var(--gold);color:#2A1D10}
.btn-ghost{background:var(--surface);color:var(--text-2);border-color:var(--border-strong)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-ok{background:var(--ok);color:#fff}
.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:transparent}
.btn-sm{padding:8px 13px;font-size:13px}
.btn-block{width:100%}
.btn:disabled{opacity:.55;cursor:not-allowed}

/* ── Cards / inputs / badges ─────────────────────────────────────── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-s)}
.card-pad{padding:22px}
.card-head{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-head h2{font-size:16px;font-weight:700}
.field{margin-bottom:15px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--text-2);margin-bottom:6px}
.field .hint{font-weight:400;color:var(--text-3);font-size:12px}
.input,input[type=text],input[type=tel],input[type=number],input[type=password],select,textarea{
  width:100%;padding:12px 14px;border:1px solid var(--border-strong);border-radius:var(--r);
  background:var(--surface);color:var(--text);font-size:15px;font-family:inherit;transition:var(--transition)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
textarea{min-height:96px;resize:vertical}
.row{display:flex;gap:14px}.row>*{flex:1}
@media(max-width:520px){.row{flex-direction:column}}
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:var(--r-full);font-size:12px;font-weight:700}
.badge-ok{background:var(--ok-bg);color:var(--ok)} .badge-warn{background:var(--warn-bg);color:var(--warn)}
.badge-danger{background:var(--danger-bg);color:var(--danger)} .badge-add{background:var(--surface-3);color:var(--text-2)}
.alert{padding:12px 15px;border-radius:var(--r);font-size:14px;margin-bottom:16px}
.alert-ok{background:var(--ok-bg);color:var(--ok)} .alert-err{background:var(--danger-bg);color:var(--danger)}
.alert-info{background:var(--info-bg);color:var(--info)}
.muted{color:var(--text-3)} .tcenter{text-align:center}

/* ── Theme toggle ────────────────────────────────────────────────── */
.theme-toggle{width:38px;height:38px;border-radius:var(--r);border:1px solid var(--border);background:var(--surface);
  display:grid;place-items:center;cursor:pointer;color:var(--text-2)}
.theme-toggle svg{width:18px;height:18px}
.theme-toggle .i-moon{display:none}
[data-theme="dark"] .theme-toggle .i-sun{display:none}
[data-theme="dark"] .theme-toggle .i-moon{display:block}

/* ── Público: topbar + shell centralizado (mobile-first) ─────────── */
.pub-top{height:var(--topbar-h);display:flex;align-items:center;justify-content:space-between;padding:0 18px;
  border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:10}
.pub-wrap{max-width:560px;margin:0 auto;padding:24px 18px 60px}
.auth-screen{min-height:100vh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(700px 380px at 80% -6%,var(--accent-soft),transparent 60%)}
.auth-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);
  padding:34px 30px;box-shadow:var(--shadow)}
.auth-card .brand{justify-content:center;margin-bottom:20px}
.auth-card h1{font-size:21px;text-align:center;margin-bottom:6px}
.auth-card .sub{text-align:center;color:var(--text-3);font-size:14px;margin-bottom:24px}
.auth-links{text-align:center;margin-top:18px;font-size:13.5px;color:var(--text-3)}
.auth-links a{color:var(--accent);font-weight:600}

/* saldo de pontos (hero) */
.points-hero{background:linear-gradient(150deg,var(--accent),var(--gold));color:#fff;border-radius:var(--r-xl);
  padding:26px 24px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.points-hero::after{content:"";position:absolute;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.14);top:-80px;right:-50px}
.points-hero .lbl{font-size:13px;opacity:.9;position:relative}
.points-hero .val{font-size:52px;font-weight:800;line-height:1;margin:6px 0 2px;position:relative}
.points-hero .val small{font-size:20px;font-weight:700}
.points-hero .who{font-size:13px;opacity:.9;position:relative}

.action-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:18px 0}
@media(max-width:440px){.action-grid{grid-template-columns:1fr}}
.action{display:flex;flex-direction:column;gap:10px;padding:20px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);box-shadow:var(--shadow-s);transition:var(--transition)}
.action:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:var(--shadow)}
.action .ic{width:46px;height:46px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center}
.action .ic svg{width:24px;height:24px}
.action h3{font-size:16px}.action p{font-size:13px;color:var(--text-3)}

.list-row{display:flex;align-items:center;gap:14px;padding:14px 0;border-top:1px solid var(--border)}
.list-row:first-child{border-top:none}
.list-row .g{flex:1;min-width:0}
.list-row .g h4{font-size:14.5px;font-weight:700}
.list-row .g p{font-size:12.5px;color:var(--text-3)}
.list-row .pts{font-weight:800;color:var(--accent);white-space:nowrap}

/* pesquisa */
.q-block{padding:18px 0;border-top:1px solid var(--border)}
.q-block:first-of-type{border-top:none}
.q-block .q{font-weight:700;font-size:15px;margin-bottom:12px}
.notes{display:flex;gap:8px;flex-wrap:wrap}
.note-opt{flex:1;min-width:52px}
.note-opt input{position:absolute;opacity:0}
.note-opt label{display:block;text-align:center;padding:12px 0;border:1.5px solid var(--border-strong);border-radius:var(--r);
  font-weight:700;cursor:pointer;transition:var(--transition);color:var(--text-2)}
.note-opt input:checked+label{background:var(--accent);border-color:var(--accent);color:#fff}
.yn{display:flex;gap:10px}
.yn .note-opt label{padding:12px}

/* upload */
.drop{border:2px dashed var(--border-strong);border-radius:var(--r-lg);background:var(--surface-2);padding:28px 20px;text-align:center;cursor:pointer;transition:var(--transition)}
.drop:hover{border-color:var(--accent)}
.drop svg{width:40px;height:40px;color:var(--accent);margin:0 auto 10px}
.drop b{font-size:15px}.drop span{display:block;font-size:12.5px;color:var(--text-3);margin-top:4px}
.preview{margin-top:14px;border-radius:var(--r);overflow:hidden;border:1px solid var(--border);display:none}
.preview img{width:100%;max-height:280px;object-fit:contain;background:var(--surface-2)}
.cam-actions{display:flex;gap:10px}
.cam-actions .btn{flex:1}
#camModal{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.93);display:none;align-items:center;justify-content:center;padding:16px}
#camModal.open{display:flex}
.cam-inner{width:100%;max-width:520px;display:flex;flex-direction:column;gap:14px}
#camVideo{width:100%;border-radius:var(--r-lg);background:#000;max-height:70vh;object-fit:contain}
.cam-bar{display:flex;align-items:center;justify-content:space-between;gap:12px}
.cam-shot{width:66px;height:66px;border-radius:50%;background:#fff;border:5px solid rgba(255,255,255,.45);cursor:pointer;flex-shrink:0;transition:transform .1s}
.cam-shot:active{transform:scale(.92)}
.cam-bar .btn{background:rgba(255,255,255,.15);color:#fff;border-color:transparent}
.cam-bar .btn:hover{background:rgba(255,255,255,.25);color:#fff}

/* ── Admin ───────────────────────────────────────────────────────── */
.adm-top{height:var(--topbar-h);background:var(--ink);color:var(--ink-text);display:flex;align-items:center;
  justify-content:space-between;padding:0 22px;position:sticky;top:0;z-index:20}
.adm-top .brand .nm{color:var(--ink-text)} .adm-top .brand .nm span{color:var(--ink-text-2)}
.adm-nav{display:flex;gap:4px;align-items:center}
.adm-nav a{padding:9px 14px;border-radius:var(--r);color:var(--ink-text-2);font-weight:600;font-size:14px;transition:var(--transition)}
.adm-nav a:hover{background:rgba(255,255,255,.08);color:var(--ink-text)}
.adm-nav a.active{background:var(--accent);color:#fff}
.adm-nav .theme-toggle{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12);color:var(--ink-text-2)}
.adm-content{max-width:1100px;margin:0 auto;padding:26px 22px 70px}
.page-title{font-size:22px;font-weight:800;margin-bottom:4px}
.page-sub{color:var(--text-3);margin-bottom:22px}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--shadow-s)}
.kpi .n{font-size:30px;font-weight:800;color:var(--accent);line-height:1}
.kpi .l{color:var(--text-3);font-size:13px;margin-top:6px}
@media(max-width:720px){.kpis{grid-template-columns:1fr 1fr}}

.approve{display:flex;gap:18px;padding:18px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);box-shadow:var(--shadow-s);margin-bottom:14px}
.approve .thumb{width:104px;height:104px;border-radius:var(--r);overflow:hidden;flex-shrink:0;background:var(--surface-2);border:1px solid var(--border);display:grid;place-items:center}
.approve .thumb img{width:100%;height:100%;object-fit:cover}
.approve .thumb.na{color:var(--text-3);font-size:12px;text-align:center;padding:6px}
.approve .body{flex:1;min-width:0}
.approve .body h3{font-size:16px}
.approve .body .sub{color:var(--text-3);font-size:13px;margin-bottom:8px}
.approve .resp{background:var(--surface-2);border-radius:var(--r);padding:12px 14px;margin:8px 0;font-size:13.5px}
.approve .resp .qa{padding:3px 0}.approve .resp .qa b{color:var(--text-2)}
.approve .acts{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:10px}
.approve .acts input[type=number]{width:110px}
@media(max-width:560px){.approve{flex-direction:column}.approve .thumb{width:100%;height:180px}}

table.tbl{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.tbl th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);padding:11px 14px;border-bottom:1px solid var(--border);background:var(--surface-2)}
.tbl td{padding:13px 14px;border-bottom:1px solid var(--border);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:var(--surface-2)}
.num{text-align:right;font-variant-numeric:tabular-nums}
.tbl-wrap{overflow-x:auto}

.empty-state{text-align:center;padding:44px 20px;color:var(--text-3)}
.empty-state svg{width:44px;height:44px;margin:0 auto 12px;color:var(--ok)}
.section-h{display:flex;align-items:center;gap:10px;margin:26px 0 12px;font-size:17px;font-weight:800}
.section-h .count{background:var(--accent);color:#fff;border-radius:var(--r-full);font-size:12px;padding:2px 10px;font-weight:700}
