/* ═══════════════════════════════════════════════════════════════════
   ДОСТАВА — design tokens / TERRITORY LEDGER (6 виборів, до коду):
   1) Layout-архетип : sidebar-app shell (адмінка) + phone-frame (кур'єр/трекінг)
   2) Шрифти         : Sora (заголовки) + Inter (текст)
   3) Логіка кольору : duotone — глибокий нейві #16324F + теплий помаранч #FF7A1A
   4) Радіус/щільність: squared/dense (8–12px, тісно, багато структури/даних)
   5) Рух            : субтильний fade+підйом на завантаженні (respect reduced-motion)
   6) Підпис-фішка   : намальована inline-SVG карта міста з маркерами кур'єрів + маршрути
   ═══════════════════════════════════════════════════════════════════ */

:root{
  /* duotone core */
  --navy:#16324F;
  --navy-700:#0F2238;     /* dark sidebar */
  --navy-600:#1B3E61;
  --navy-100:#E3EAF1;
  --navy-50:#EEF3F8;
  --orange:#FF7A1A;
  --orange-600:#E8650A;
  --orange-100:#FFE7D2;
  --orange-50:#FFF3E8;

  /* canvas + ink (нейтрали тоновані в бік нейві) */
  --canvas:#F6F7F9;
  --surface:#FFFFFF;
  --ink:#15202B;
  --ink-2:#4A5867;
  --ink-3:#8492A1;
  --line:#E2E7ED;
  --line-2:#EDF0F4;

  /* dark sidebar tints */
  --side:#0F2238;
  --side-2:#173552;
  --side-ink:#B7C6D6;
  --side-ink-2:#6B8198;

  /* semantic */
  --ok:#16A34A;   --ok-bg:#E6F6EC;
  --warn:#C2710C; --warn-bg:#FCF1DC;
  --bad:#DC2626;  --bad-bg:#FCE9E9;
  --info:#1B6FB3; --info-bg:#E3F0FA;

  /* courier status */
  --st-free:#16A34A;   --st-free-bg:#E6F6EC;
  --st-road:#FF7A1A;   --st-road-bg:#FFE7D2;
  --st-spot:#1B6FB3;   --st-spot-bg:#E3F0FA;

  /* shape — squared/dense */
  --r-lg:12px; --r-md:10px; --r-sm:8px; --r-xs:6px;
  --pad:clamp(14px,3vw,26px);
  --shadow:0 1px 2px rgba(15,34,56,.05), 0 6px 18px -12px rgba(15,34,56,.22);
  --shadow-lg:0 18px 46px -22px rgba(15,34,56,.36);

  --sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --display:'Sora','Inter',system-ui,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--sans);background:var(--canvas);color:var(--ink);
  font-size:15px;line-height:1.5;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{font-family:var(--display);margin:0;line-height:1.14;letter-spacing:-.015em;font-weight:600}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}
:focus-visible{outline:3px solid var(--orange);outline-offset:2px;border-radius:6px}

/* ── motion: subtle fade+rise ── */
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.rise{animation:rise .5s cubic-bezier(.2,.7,.2,1) both}
.d1{animation-delay:.04s}.d2{animation-delay:.09s}.d3{animation-delay:.14s}
.d4{animation-delay:.19s}.d5{animation-delay:.24s}.d6{animation-delay:.29s}
@keyframes pulse{0%{transform:scale(.6);opacity:.7}70%{transform:scale(2.4);opacity:0}100%{opacity:0}}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .map-pulse{display:none!important}
}

/* ════ APP SHELL (admin) ════ */
.app{display:flex;min-height:100vh}
.side{
  width:240px;flex:0 0 240px;background:var(--side);color:var(--side-ink);
  display:flex;flex-direction:column;padding:20px 14px;position:sticky;top:0;
  height:100vh;
}
.side__brand{display:flex;align-items:center;gap:10px;padding:6px 8px 20px;font-family:var(--display);font-weight:700;font-size:19px;color:#fff;letter-spacing:-.02em}
.logo-mark{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,var(--orange),var(--orange-600));display:grid;place-items:center;flex:0 0 auto;box-shadow:0 6px 16px -7px rgba(255,122,26,.8)}
.logo-mark svg{width:18px;height:18px}
.side__sec{font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--side-ink-2);padding:14px 12px 6px;font-weight:600}
.nav-i{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;color:var(--side-ink);font-weight:500;font-size:14px;min-height:44px}
.nav-i svg{width:18px;height:18px;flex:0 0 auto;opacity:.8}
.nav-i:hover{background:var(--side-2);color:#fff}
.nav-i.on{background:linear-gradient(120deg,rgba(255,122,26,.30),rgba(255,122,26,.08));color:#fff;box-shadow:inset 2px 0 0 var(--orange)}
.nav-i.on svg{opacity:1;color:var(--orange)}
.nav-i.dis{opacity:.4;pointer-events:none}
.side__foot{margin-top:auto;padding:14px 12px 4px;font-size:11.5px;color:var(--side-ink-2);line-height:1.45}
.side__foot a{color:var(--side-ink)}

.main{flex:1 1 auto;min-width:0;display:flex;flex-direction:column}
.topbar{
  display:flex;align-items:center;gap:13px;padding:14px var(--pad);
  background:rgba(246,247,249,.86);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30;
}
.topbar h1{font-size:clamp(1.05rem,2.4vw,1.35rem)}
.topbar .sub{color:var(--ink-3);font-size:12.5px;margin-top:2px}
.live-chip{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:6px 13px 6px 11px;font-size:12.5px;font-weight:600;box-shadow:var(--shadow)}
.live-chip .blip{width:8px;height:8px;border-radius:50%;background:var(--ok);position:relative}
.live-chip .blip::after{content:'';position:absolute;inset:-3px;border-radius:50%;background:var(--ok);animation:pulse 1.8s ease-out infinite}
.grow{flex:1 1 auto}
.btn-ghost{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--line);border-radius:9px;padding:9px 13px;font-size:13.5px;font-weight:600;color:var(--ink);min-height:42px}
.btn-ghost:hover{border-color:var(--orange);color:var(--orange-600)}
.btn-ghost svg{width:16px;height:16px}

.content{padding:var(--pad);max-width:1240px;width:100%;margin:0 auto}

/* mobile sidebar → top pill nav (flex-direction:column shell) */
.m-nav{display:none}
@media(max-width:900px){
  .app{flex-direction:column}
  .side{display:none}
  .m-nav{
    display:flex;align-items:center;gap:7px;overflow-x:auto;padding:10px var(--pad);
    background:var(--side);position:sticky;top:0;z-index:40;
    scrollbar-width:none;-webkit-overflow-scrolling:touch;
  }
  .m-nav::-webkit-scrollbar{display:none}
  .m-nav a{flex:0 0 auto;color:var(--side-ink);background:var(--side-2);padding:9px 14px;border-radius:999px;font-size:13px;font-weight:600;min-height:40px;display:flex;align-items:center;white-space:nowrap}
  .m-nav a.on{background:linear-gradient(120deg,var(--orange),var(--orange-600));color:#fff}
  .m-nav a.dis{opacity:.4}
  .m-brand{flex:0 0 auto;display:flex;align-items:center;gap:8px;color:#fff;font-family:var(--display);font-weight:700;padding-right:4px}
  .m-brand .logo-mark{width:26px;height:26px}
}

/* ════ BENTO GRID ════ */
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:16px;box-shadow:var(--shadow);min-width:0;
}
.card h3{font-size:13px;color:var(--ink-2);font-weight:600;display:flex;align-items:center;gap:7px;margin-bottom:3px;letter-spacing:0}
.card .hd{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:13px}
.span3{grid-column:span 3}.span4{grid-column:span 4}.span5{grid-column:span 5}
.span6{grid-column:span 6}.span7{grid-column:span 7}.span8{grid-column:span 8}
.span9{grid-column:span 9}.span12{grid-column:span 12}
@media(max-width:1024px){
  .span3{grid-column:span 6}.span4{grid-column:span 6}.span5{grid-column:span 6}
  .span7{grid-column:span 12}.span8{grid-column:span 12}.span6{grid-column:span 12}
  .span9{grid-column:span 12}
}
@media(max-width:560px){
  .bento{gap:11px}
  .span3,.span4,.span5,.span6,.span7,.span8,.span9{grid-column:span 12}
}

/* ── KPI strip ── */
.kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:14px}
@media(max-width:760px){.kpi-strip{grid-template-columns:repeat(2,1fr)}}
@media(max-width:380px){.kpi-strip{grid-template-columns:1fr}}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:15px 16px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--orange)}
.kpi .lbl{font-size:11.5px;color:var(--ink-3);font-weight:600;text-transform:uppercase;letter-spacing:.04em;display:flex;align-items:center;gap:6px}
.kpi .lbl svg{width:15px;height:15px;color:var(--navy);opacity:.7}
.kpi .val{font-family:var(--display);font-weight:700;font-size:clamp(1.5rem,3vw,1.95rem);letter-spacing:-.02em;margin-top:7px;display:flex;align-items:baseline;gap:6px;color:var(--navy)}
.kpi .val .unit{font-size:.5em;color:var(--ink-3);font-weight:600}
.kpi .delta{font-size:11.5px;font-weight:700;display:inline-flex;align-items:center;gap:3px;margin-top:7px}
.delta.up{color:var(--ok)}
.delta.down{color:var(--bad)}

/* ── status chips ── */
.chip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:6px;line-height:1.4;white-space:nowrap}
.chip.dot::before{content:'';width:7px;height:7px;border-radius:50%;background:currentColor;flex:0 0 auto}
.chip.free{color:var(--st-free);background:var(--st-free-bg)}
.chip.road{color:var(--st-road);background:var(--st-road-bg)}
.chip.spot{color:var(--st-spot);background:var(--st-spot-bg)}
.chip.queued{color:var(--ink-2);background:var(--navy-100)}
.chip.done{color:var(--ok);background:var(--ok-bg)}

/* ── data table ── */
.table-wrap{overflow:hidden;border-radius:var(--r-md)}
table.qtab{width:100%;border-collapse:collapse;font-size:13.5px}
table.qtab th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);font-weight:600;padding:9px 12px;border-bottom:1px solid var(--line)}
table.qtab td{padding:11px 12px;border-bottom:1px solid var(--line-2);vertical-align:middle;color:var(--ink-2)}
table.qtab tr:last-child td{border-bottom:0}
table.qtab tr:hover td{background:var(--navy-50)}
table.qtab .num{font-family:var(--display);font-weight:600;color:var(--navy)}
table.qtab .addr{color:var(--ink);font-weight:500}
table.qtab .eta{font-family:var(--display);font-weight:700;color:var(--navy)}
.cr-mini{display:inline-flex;align-items:center;gap:7px}
.cr-mini .dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.cr-mini .nm{color:var(--ink);font-weight:500}

@media(max-width:640px){
  table.qtab thead{position:absolute;left:-9999px}
  table.qtab,table.qtab tbody,table.qtab tr,table.qtab td{display:block;width:100%}
  table.qtab tr{border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:11px;padding:6px 4px;background:var(--surface)}
  table.qtab tr:hover td{background:transparent}
  table.qtab td{border:0;padding:7px 14px;display:flex;justify-content:space-between;align-items:center;gap:14px;text-align:right}
  table.qtab td::before{content:attr(data-label);font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-3);font-weight:600;text-align:left;flex:0 0 auto}
  table.qtab td .addr,table.qtab td .num{text-align:right}
}

/* ── courier list ── */
.cr-list{display:flex;flex-direction:column;gap:2px}
.cr-row{display:flex;align-items:center;gap:12px;padding:11px 4px;border-bottom:1px solid var(--line-2)}
.cr-row:last-child{border-bottom:0}
.cr-av{width:38px;height:38px;border-radius:9px;flex:0 0 auto;display:grid;place-items:center;font-weight:700;font-family:var(--display);font-size:14px;color:#fff;background:linear-gradient(135deg,var(--navy),var(--navy-600));position:relative}
.cr-bd{min-width:0;flex:1}
.cr-bd .nm{font-weight:600;color:var(--ink);font-size:14px}
.cr-bd .sub{color:var(--ink-3);font-size:12px;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cr-load{font-family:var(--display);font-weight:700;color:var(--navy);font-size:13px;flex:0 0 auto;text-align:right}
.cr-load .cap{display:block;font-size:10.5px;color:var(--ink-3);font-weight:600;text-transform:uppercase;letter-spacing:.03em}

/* ── AI note line ── */
.ai-line{display:flex;align-items:flex-start;gap:11px;background:var(--orange-50);border:1px solid var(--orange-100);border-radius:var(--r-md);padding:13px 15px;font-size:13.5px;color:var(--ink-2);line-height:1.5}
.ai-line svg{width:19px;height:19px;flex:0 0 auto;color:var(--orange-600)}
.ai-line b{color:var(--ink)}

/* ── map (signature) ── */
.map-shell{position:relative;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--line);background:#EAF0F6}
.map-svg{display:block;width:100%;height:auto}
.map-key{display:flex;flex-wrap:wrap;gap:14px;margin-top:13px;font-size:12.5px;color:var(--ink-2)}
.map-key .k{display:inline-flex;align-items:center;gap:7px}
.map-key .sw{width:11px;height:11px;border-radius:50%;flex:0 0 auto}

/* ── buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:9px;font-weight:600;font-size:14.5px;padding:11px 17px;min-height:46px;border:1px solid transparent;transition:transform .12s ease,box-shadow .2s ease,background .18s ease;width:100%}
.btn svg{width:18px;height:18px}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--orange);color:#fff;box-shadow:0 10px 22px -12px rgba(255,122,26,.85)}
.btn-primary:hover{background:var(--orange-600)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-600)}
.btn-out{background:var(--surface);border-color:var(--line);color:var(--ink)}
.btn-out:hover{border-color:var(--orange);color:var(--orange-600)}
.btn-ok{background:var(--ok);color:#fff}
.btn-ok:hover{filter:brightness(.96)}

/* ════ PHONE FRAME (courier / tracking) ════ */
.phone-page{display:flex;flex-direction:column;align-items:center;padding:clamp(18px,5vw,42px) var(--pad);gap:18px;min-height:100vh}
.phone-back{align-self:center;display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--ink-2);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:8px 15px;min-height:42px;box-shadow:var(--shadow)}
.phone-back:hover{border-color:var(--orange);color:var(--orange-600)}
.phone-back svg{width:15px;height:15px}
.phone{
  width:min(100%,390px);background:var(--navy-700);border-radius:38px;padding:11px;
  box-shadow:var(--shadow-lg),0 0 0 1px rgba(15,34,56,.5);
}
.phone-screen{
  position:relative;background:var(--canvas);border-radius:28px;overflow:hidden;
  height:min(76vh,720px);min-height:560px;display:flex;flex-direction:column;
}
.phone-notch{position:absolute;top:0;left:50%;transform:translateX(-50%);width:44%;height:24px;background:var(--navy-700);border-radius:0 0 14px 14px;z-index:20}
.ph-status{display:flex;align-items:center;justify-content:space-between;padding:9px 20px 5px;font-size:12px;font-weight:600;color:var(--ink);flex:0 0 auto}
.ph-status .sig{display:inline-flex;gap:3px;align-items:flex-end}
.ph-status .sig i{width:3px;background:var(--ink);border-radius:1px;display:block}
.ph-head{display:flex;align-items:center;gap:11px;padding:8px 18px 12px;flex:0 0 auto;border-bottom:1px solid var(--line)}
.ph-head .logo-mark{width:28px;height:28px}
.ph-head .ttl{font-family:var(--display);font-weight:700;font-size:16px;color:var(--navy)}
.ph-head .ttl .sub{display:block;font-family:var(--sans);font-weight:500;font-size:11px;color:var(--ink-3);letter-spacing:0;margin-top:1px}
.ph-body{flex:1 1 auto;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:14px 16px calc(16px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:13px}
.ph-body::-webkit-scrollbar{width:0}

.ph-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:15px;box-shadow:var(--shadow)}
.ph-card .lbl{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);font-weight:600}
.ph-eyebrow{display:flex;align-items:center;justify-content:space-between;gap:10px}
.task-addr{font-family:var(--display);font-weight:700;font-size:18px;color:var(--ink);margin-top:6px;line-height:1.25}
.task-meta{display:flex;flex-wrap:wrap;gap:9px;margin-top:11px}
.meta-pill{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:var(--ink-2);background:var(--navy-50);border:1px solid var(--line);border-radius:7px;padding:6px 10px}
.meta-pill svg{width:14px;height:14px;color:var(--navy);opacity:.75}
.meta-pill.accent{background:var(--orange-50);border-color:var(--orange-100);color:var(--orange-600)}
.meta-pill.accent svg{color:var(--orange-600);opacity:1}

/* phone bottom nav */
.ph-nav{flex:0 0 auto;display:flex;background:var(--surface);border-top:1px solid var(--line);padding:8px 6px calc(8px + env(safe-area-inset-bottom))}
.ph-nav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 2px;color:var(--ink-3);font-size:10.5px;font-weight:600;min-height:46px;border-radius:8px}
.ph-nav a svg{width:21px;height:21px}
.ph-nav a.on{color:var(--orange-600)}
.ph-nav a.on svg{color:var(--orange-600)}

/* progress stepper (tracking) */
.stepper{display:flex;flex-direction:column;gap:0;position:relative;padding-left:6px}
.step{display:flex;gap:13px;position:relative;padding-bottom:16px}
.step:last-child{padding-bottom:0}
.step .rail{position:relative;flex:0 0 auto;width:24px;display:flex;flex-direction:column;align-items:center}
.step .node{width:24px;height:24px;border-radius:50%;background:var(--surface);border:2px solid var(--line);display:grid;place-items:center;z-index:2;color:var(--ink-3)}
.step .node svg{width:13px;height:13px}
.step .line{position:absolute;top:24px;bottom:-2px;width:2px;background:var(--line);z-index:1}
.step:last-child .line{display:none}
.step.done .node{background:var(--ok);border-color:var(--ok);color:#fff}
.step.done .line{background:var(--ok)}
.step.active .node{background:var(--orange);border-color:var(--orange);color:#fff;box-shadow:0 0 0 4px var(--orange-100)}
.step .txt{padding-top:2px;min-width:0;flex:1}
.step .txt .t{font-weight:600;color:var(--ink);font-size:14px}
.step .txt .s{color:var(--ink-3);font-size:12px;margin-top:2px}
.step.active .txt .t{color:var(--orange-600)}

/* earnings (courier) */
.earn-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.earn-cell{background:var(--navy-50);border:1px solid var(--line);border-radius:var(--r-md);padding:13px}
.earn-cell .v{font-family:var(--display);font-weight:700;font-size:22px;color:var(--navy);letter-spacing:-.02em}
.earn-cell .c{font-size:11.5px;color:var(--ink-3);font-weight:600;text-transform:uppercase;letter-spacing:.03em;margin-top:3px}

/* photo-proof mock */
.photo-drop{border:2px dashed var(--line);border-radius:var(--r-md);padding:22px 16px;text-align:center;color:var(--ink-3);background:var(--navy-50);transition:border-color .18s,background .18s;cursor:pointer}
.photo-drop svg{width:32px;height:32px;color:var(--navy);opacity:.5;margin:0 auto 8px}
.photo-drop .pt{font-size:13px;font-weight:600;color:var(--ink-2)}
.photo-drop .ps{font-size:11.5px;margin-top:3px}
.photo-drop.added{border-style:solid;border-color:var(--ok);background:var(--ok-bg);cursor:default}
.photo-drop.added svg{color:var(--ok);opacity:1}
.photo-drop.added .pt{color:var(--ok)}

/* delivered photo (tracking) */
.delivered-photo{border-radius:var(--r-md);overflow:hidden;border:1px solid var(--line);background:#DCE6EF}
.delivered-photo svg{display:block;width:100%;height:auto}

/* courier badge (tracking) */
.cr-badge{display:flex;align-items:center;gap:12px}
.cr-badge .cr-av{width:46px;height:46px;border-radius:50%}
.cr-badge .nm{font-weight:700;color:var(--ink);font-size:15px;font-family:var(--display)}
.cr-badge .stars{color:var(--orange);font-size:13px;letter-spacing:1px;margin-top:2px}
.cr-badge .stars .o{color:var(--line)}

/* eta countdown */
.eta-big{text-align:center;padding:4px 0}
.eta-big .num{font-family:var(--display);font-weight:700;font-size:clamp(2.4rem,12vw,3.2rem);color:var(--orange-600);letter-spacing:-.03em;line-height:1}
.eta-big .cap{font-size:12.5px;color:var(--ink-3);font-weight:600;margin-top:4px}

/* ── footer ── */
.site-foot{padding:20px var(--pad) 32px;color:var(--ink-3);font-size:12.5px;text-align:center}
.site-foot a{color:var(--orange-600);font-weight:600}
