/* VAKTIN design tokens + base components
   Unified system reconciling ARRIVALS·AUDIT (cool slate) and KEY·ENVELOPES (warm stationery):
   warm paper, cool ink, teal brand accent, rescue-orange reserved for "needs action". */

:root{
  --paper:#EEEDE0;          /* warm oat canvas (envelope heritage) */
  --card:#FFFFFF;
  --ink:#16222E;            /* midnight slate (audit heritage) */
  --ink-soft:#3D4F5F;
  --ink-faint:#787263;
  --line:#DCD9CB;
  --accent:#4599B4;         /* brand / interactive */
  --accent-hover:#37809A;
  --accent-tint:#E4F0F4;
  --bronze:#B39B50;
  --fix:#E4572E;            /* critical / needs-action */
  --fix-soft:#FBE3DA;
  --warn:#C08A00;
  --warn-soft:#F7ECCB;
  --note:#4A6B8A;
  --note-soft:#DFE9F1;
  --ok:#3E7C59;
  --ok-soft:#DCEDE3;
  --mono:'Spline Sans Mono',ui-monospace,SFMono-Regular,monospace;
  --sans:'Familjen Grotesk',system-ui,sans-serif;
  --e-2:0 1px 4px rgba(64,64,65,.10);
  --e-modal:0 12px 40px rgba(0,0,0,.28);
}
body.dark{
  --paper:#17171A; --card:#212126; --ink:#E8E6DC; --ink-soft:#A19E92;
  --line:#35353B; --accent-tint:#1E3038;
  --fix-soft:#3C2320; --warn-soft:#3A2F16; --note-soft:#243B4A; --ok-soft:#1E3A28;
  --e-2:0 1px 10px rgba(0,0,0,.5);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{transition:none!important;animation:none!important}}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:15px;line-height:1.45}
a{color:inherit}
button,select,input,textarea{font-family:var(--sans)}
button{cursor:pointer}
.mono{font-family:var(--mono)}
:focus-visible{outline:2.5px solid var(--accent);outline-offset:2px}

/* ---------- app bar ---------- */
.appbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:14px;
  background:var(--ink);color:#E8EEF2;padding:14px 24px;border-bottom:1px solid var(--line)}
body.dark .appbar{background:#1B1B1F}
.appbar .wordmark{font-size:19px;font-weight:700;letter-spacing:.05em;text-decoration:none;white-space:nowrap}
.appbar .wordmark span{color:var(--accent)}
.appbar .sub{font-family:var(--mono);font-size:12px;opacity:.7}
.appbar .grow{margin-left:auto;display:flex;align-items:center;gap:10px}
.hotelsel{border:1px solid transparent;background:transparent;font-family:var(--mono);font-size:12.5px;
  color:#CBD6DE;padding:6px 8px;border-radius:7px;max-width:240px;cursor:pointer}
.hotelsel:hover{border-color:#3D4F5F;color:#fff}
.hotelsel option{color:#16222E;background:#fff}
.iconbtn{width:34px;height:34px;border-radius:8px;border:1.5px solid #3D4F5F;background:transparent;
  color:#CBD6DE;font-size:15px;line-height:1}
.iconbtn:hover{border-color:#E8EEF2;color:#fff}

/* ---------- buttons ---------- */
.btn{display:inline-block;background:var(--ink);color:var(--paper);border:none;border-radius:8px;
  padding:10px 20px;font-size:14px;font-weight:600;text-decoration:none;text-align:center}
body.dark .btn{background:#E8E6DC;color:#17171A}
.btn:hover{background:#2A3B4C}
body.dark .btn:hover{background:#fff}
.btn.ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--paper)}
.btn.accent{background:var(--accent);color:#fff}
.btn.accent:hover{background:var(--accent-hover)}

/* ---------- cards & sections ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px 18px}
.seclabel{font-size:11.5px;font-weight:600;letter-spacing:.10em;text-transform:uppercase;color:var(--ink-soft)}

/* ---------- drop zone ---------- */
.dropzone{border:2px dashed var(--line);border-radius:14px;background:var(--card);
  padding:38px 26px;text-align:center;transition:border-color .15s,background .15s;cursor:pointer}
.dropzone.drag{border-color:var(--accent);background:var(--accent-tint)}
.dropzone h2{font-size:22px;font-weight:600;margin-bottom:6px}
.dropzone p{color:var(--ink-soft);font-size:14px;margin-bottom:14px}
.privacy{font-family:var(--mono);font-size:11.5px;color:var(--ok);margin-top:14px}

/* ---------- chips / pills / badges ---------- */
.chip{display:inline-block;font-family:var(--mono);font-size:10.5px;font-weight:700;
  padding:2px 7px;border-radius:4px;vertical-align:1px}
.chip.s1{background:var(--fix-soft);color:var(--fix)}
.chip.s3{background:var(--warn-soft);color:var(--warn)}
.chip.s5{background:var(--note-soft);color:var(--note)}
.chip.ok{background:var(--ok-soft);color:var(--ok)}
.chip.bed{background:var(--note-soft);color:var(--note)}
.chip.acc{background:var(--accent-tint);color:var(--accent)}
body.dark .chip.acc{color:#7FC1D6}
.pill{display:inline-block;font-family:var(--mono);font-size:11.5px;border:1px solid var(--line);
  border-radius:999px;padding:3px 10px;color:var(--ink-soft)}
.reqtxt{display:inline-block;background:#FFF3D6;border:1px solid #E8D9A8;color:#6B5200;
  border-radius:6px;padding:2px 8px;font-size:12px;margin:2px 4px 2px 0}
body.dark .reqtxt{background:#3A2F16;border-color:#5a4a20;color:#E8D9A8}

/* ---------- stat rack ---------- */
.rack{display:flex;flex-wrap:wrap;gap:26px;align-items:flex-end}
.rack .big{font-size:44px;font-weight:700;line-height:1;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.rack .big small{display:block;font-size:11.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft);margin-top:4px}
.rack .big.fixnum{color:var(--fix)}

/* ---------- record row ---------- */
.res{display:grid;grid-template-columns:118px 1fr;gap:4px 14px;padding:12px 6px;border-top:1px solid var(--line)}
.res:first-of-type{border-top:none}
.res .conf{font-family:var(--mono);font-size:13.5px;font-weight:600}
.res .room{font-family:var(--mono);font-size:11.5px;color:var(--ink-soft)}
.res .name{font-weight:600}
.res .meta{font-family:var(--mono);font-size:11.5px;color:var(--ink-soft);margin-top:2px;overflow-wrap:anywhere}
.res .note{font-style:italic;font-size:12.5px;color:var(--ink-soft);margin-top:4px;max-width:78ch}
.res.flagged{box-shadow:inset 3px 0 0 var(--fix)}
@media (max-width:680px){.res{grid-template-columns:1fr}}

/* ---------- banner ---------- */
.banner{background:var(--card);border:1px solid var(--line);border-left:4px solid var(--accent);
  border-radius:10px;padding:10px 14px;font-size:13.5px;display:flex;gap:10px;align-items:center}
.banner.warn{border-left-color:var(--warn)}
.banner.crit{border-left-color:var(--fix)}
.banner.good{border-left-color:var(--ok)}
