/* =============================================================
   SudBuds Rewards — "Daylight" v2 design system
   Authoritative tokens: docs/design-system-v2.md
   Visual target: docs/ui-reference.html
   A deliberate, clean break from the sales app's navy-glass HUD.
   Light canvas · one indigo + one mint · whitespace · soft shadow.
============================================================= */

/* ---------------- TOKENS ---------------- */
:root{
  --indigo-50:#EEF1FF;--indigo-100:#DDE3FF;--indigo-200:#BCC6FF;--indigo-300:#93A4FF;
  --indigo-400:#6B82FF;--indigo-500:#3D5AFE;--indigo-600:#2F46DB;--indigo-700:#2438B0;
  --indigo-800:#1B2A86;--indigo-900:#131E5E;
  --mint-50:#E8FBF3;--mint-100:#C9F5E3;--mint-200:#97ECCB;--mint-300:#5FDDB0;
  --mint-400:#2FC994;--mint-500:#10B981;--mint-600:#0E9E6E;--mint-700:#0B7C57;--mint-800:#075E42;
  --coral-300:#FFB59C;--coral-400:#FF8A65;--coral-500:#FF6B3D;
  --canvas:#F7F9FC;--surface:#FFFFFF;--surface-2:#F1F4F9;--line:#E6EAF2;--line-strong:#D4DAE6;
  --ink-900:#0F1729;--ink-700:#344056;--ink-500:#5B677E;--ink-400:#8A94A8;--ink-300:#B6BECD;
  --success:#10B981;--success-ink:#0B7C57;--success-bg:#E8FBF3;
  --warn:#F59E0B;--warn-ink:#92560A;--warn-bg:#FEF3E2;
  --danger:#E5484D;--danger-ink:#B42318;--danger-bg:#FDECEC;
  --info:#3D5AFE;--info-ink:#2438B0;--info-bg:#EEF1FF;
  --pending:#8A94A8;--pending-bg:#F1F4F9;
  --xp:var(--indigo-500);--xp-track:var(--indigo-100);
  --reward:var(--mint-500);--reward-ink:var(--mint-700);
  --streak:var(--coral-400);--reveal:var(--coral-400);
  --rank-gold:#C9A227;--rank-gold-bg:#FBF4DD;--rank-silver:#8B97A8;--rank-silver-bg:#EEF1F6;
  --rank-bronze:#B07A4B;--rank-bronze-bg:#F6ECE2;
  --grad-brand:linear-gradient(135deg,#4E68FF 0%,#3D5AFE 55%,#2F46DB 100%);
  --grad-reward:linear-gradient(135deg,#2FC994 0%,#10B981 100%);
  --grad-reveal:radial-gradient(120% 120% at 50% 0%,#FFE7DC 0%,#FFFFFF 60%);
  --font-display:'Plus Jakarta Sans','Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --font-text:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --s-1:4px;--s-2:8px;--s-3:12px;--s-4:16px;--s-5:20px;--s-6:24px;--s-8:32px;--s-10:40px;--s-12:48px;--s-16:64px;
  --gutter:16px;--gutter-d:24px;--card-pad:20px;
  --r-sm:10px;--r-md:14px;--r-lg:18px;--r-xl:24px;--r-pill:999px;
  --sh-1:0 1px 2px rgba(15,23,41,.04),0 1px 3px rgba(15,23,41,.06);
  --sh-2:0 4px 12px rgba(15,23,41,.06),0 2px 4px rgba(15,23,41,.04);
  --sh-3:0 12px 28px rgba(15,23,41,.10),0 6px 10px rgba(15,23,41,.06);
  --sh-focus:0 0 0 3px rgba(61,90,254,.35);
  --sh-focus-reward:0 0 0 3px rgba(16,185,129,.35);
  --e-out:cubic-bezier(.16,1,.3,1);--e-in:cubic-bezier(.4,0,1,1);--e-spring:cubic-bezier(.34,1.56,.64,1);
  --d-1:120ms;--d-2:200ms;--d-3:320ms;--d-4:520ms;
  --nav-h:64px;--sidebar-w:248px;--appbar-h:56px;--content-max:1160px;
}

/* ---------------- BASE ---------------- */
*{box-sizing:border-box;}
html,body{height:100%;}
body{margin:0;background:var(--canvas);color:var(--ink-700);
  font:400 15px/24px var(--font-text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
h1,h2,h3{margin:0;color:var(--ink-900);font-family:var(--font-display);}
h1{font:700 27px/34px var(--font-display);}
h2{font:700 22px/30px var(--font-display);}
h3{font:600 18px/26px var(--font-display);}
a{color:var(--indigo-500);text-decoration:none;}
img{max-width:100%;}
.tnum{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;}
.muted{color:var(--ink-500);}
.tiny{font:500 12px/16px var(--font-text);}
.hidden{display:none;}
.grad{background:linear-gradient(90deg,var(--indigo-600),var(--indigo-500));
  -webkit-background-clip:text;background-clip:text;color:transparent;}
:focus-visible{outline:none;box-shadow:var(--sh-focus);border-radius:var(--r-sm);}
.row{display:flex;align-items:center;gap:var(--s-3);}
.row--between{justify-content:space-between;}
.row--end{justify-content:flex-end;}
.stack{display:flex;flex-direction:column;}
.eyebrow,.section-label,.card__label,.field__label,.lbl{
  font:600 13px/18px var(--font-text);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-500);}
.section-label{margin:18px 0 -2px;}
.view-title{font:700 26px/32px var(--font-display);color:var(--ink-900);margin:2px 0 6px;}
::-webkit-scrollbar{width:10px;height:10px;}
::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:99px;border:3px solid var(--canvas);}

/* ---------------- BOOT ---------------- */
.boot{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:var(--canvas);}
.boot__logo{width:72px;height:72px;border-radius:20px;object-fit:contain;background:#fff;box-shadow:var(--sh-1);padding:8px;}
.boot__txt{color:var(--ink-500);font:600 14px var(--font-text);}
.spinner{width:30px;height:30px;border-radius:50%;border:3px solid var(--indigo-100);
  border-top-color:var(--indigo-500);animation:spin .8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.skel{padding:28px;color:var(--ink-400);font:500 13px var(--font-text);text-align:center;}

/* ---------------- BUTTONS ---------------- */
.btn{font:600 16px/24px var(--font-text);border:0;border-radius:var(--r-md);padding:12px 18px;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;color:var(--ink-900);background:var(--surface);
  transition:transform var(--d-1) var(--e-out),box-shadow var(--d-2) var(--e-out),background var(--d-2);}
.btn:active{transform:scale(.97);}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none;}
.btn--primary{background:var(--indigo-500);color:#fff;}
.btn--primary:hover{background:var(--indigo-600);box-shadow:var(--sh-2);}
.btn--primary:active{background:var(--indigo-700);}
.btn--reward,.btn--gold{background:var(--mint-500);color:#06281C;}
.btn--reward:hover,.btn--gold:hover{background:var(--mint-400);box-shadow:var(--sh-2);}
.btn--reward:focus-visible,.btn--gold:focus-visible{box-shadow:var(--sh-focus-reward);}
.btn--secondary{background:var(--surface);color:var(--ink-900);box-shadow:inset 0 0 0 1px var(--line-strong);}
.btn--secondary:hover{background:var(--surface-2);}
.btn--ghost{background:transparent;color:var(--indigo-500);}
.btn--ghost:hover{background:var(--indigo-50);}
.btn--danger{background:var(--danger-bg);color:var(--danger-ink);}
.btn--danger:hover{background:#FBDDDD;}
.btn--lg,.btn--block{width:100%;padding:15px 22px;}
.btn--sm{padding:8px 12px;font:600 13px/1 var(--font-text);border-radius:var(--r-sm);}

/* ---------------- CARDS ---------------- */
.card{background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--sh-1);padding:var(--card-pad);}
.card+.card{margin-top:12px;}
.card--accent{box-shadow:var(--sh-2),inset 0 0 0 1.5px var(--indigo-100);}
.card--hover{transition:box-shadow var(--d-2) var(--e-out),transform var(--d-2) var(--e-out);cursor:pointer;}
.card--hover:hover{box-shadow:var(--sh-2);transform:translateY(-2px);}
.card--inset{background:var(--surface-2);box-shadow:none;}
.card--brand{background:var(--grad-brand);color:#fff;}
.card.empty{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;color:var(--ink-500);padding:34px 20px;}
.empty__ic{font-size:30px;}

/* ---------------- TAGS / PILLS / CHIPS ---------------- */
.tag,.pill{display:inline-flex;align-items:center;gap:6px;font:600 12px/16px var(--font-text);
  padding:4px 10px;border-radius:var(--r-pill);white-space:nowrap;}
.tag--reward{background:var(--mint-50);color:var(--mint-700);}
.tag--xp{background:var(--indigo-50);color:var(--indigo-700);}
.tag--pending{background:var(--pending-bg);color:var(--ink-500);}
.tag--approved,.tag--paid{background:var(--success-bg);color:var(--success-ink);}
.tag--rejected{background:var(--danger-bg);color:var(--danger-ink);}
.tag--warn,.tag--changes{background:var(--warn-bg);color:var(--warn-ink);}
.pill__ic{font-weight:700;}
.pill--warn{background:var(--warn-bg);color:var(--warn-ink);}
.pill--ok{background:var(--success-bg);color:var(--success-ink);}
.pill--paid{background:var(--success-bg);color:var(--success-ink);}
.pill--err{background:var(--danger-bg);color:var(--danger-ink);}
.pill--muted{background:var(--pending-bg);color:var(--ink-500);}
.gold,.reward-money{color:var(--reward-ink);font-weight:700;}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0;}
.chip{padding:8px 14px;border-radius:var(--r-pill);font:600 14px/1 var(--font-text);
  background:var(--surface);box-shadow:inset 0 0 0 1px var(--line);color:var(--ink-700);cursor:pointer;border:0;}
.chip.active,.chip[aria-selected="true"]{background:var(--indigo-500);color:#fff;box-shadow:none;}

/* ---------------- BARS ---------------- */
.bar,.xpbar{height:10px;border-radius:var(--r-pill);background:var(--xp-track);overflow:hidden;}
.bar--thin{height:6px;}
.bar__fill,.xpbar>i{display:block;height:100%;border-radius:inherit;
  background:linear-gradient(90deg,var(--indigo-400),var(--indigo-500));transition:width var(--d-4) var(--e-out);}
.fill--pending{background:var(--warn);}
.fill--approved{background:var(--mint-500);}
.fill--rejected{background:var(--danger);}
.fill--needs_changes{background:var(--ink-400);}

/* ---------------- LOGIN ---------------- */
.login{min-height:100vh;display:flex;flex-direction:column;background:var(--canvas);}
.login__hero{background:var(--grad-brand);color:#fff;padding:54px 28px 44px;border-radius:0 0 28px 28px;position:relative;overflow:hidden;}
.login__hero:after{content:"";position:absolute;right:-40px;top:-40px;width:170px;height:170px;border-radius:50%;background:rgba(255,255,255,.10);}
.login__hero:before{content:"";position:absolute;left:-30px;bottom:-56px;width:140px;height:140px;border-radius:50%;background:rgba(255,255,255,.08);}
.wordmark{display:flex;align-items:center;gap:10px;}
.wordmark .drop{width:34px;height:34px;border-radius:11px;background:#fff;display:grid;place-items:center;color:var(--indigo-600);font:800 18px/1 var(--font-display);}
.wordmark b{font:800 22px/1 var(--font-display);letter-spacing:-.01em;color:#fff;}
.login__hero h1{color:#fff;font:800 28px/34px var(--font-display);margin:26px 0 6px;}
.login__hero p{color:rgba(255,255,255,.85);margin:0;max-width:300px;}
.login__form{padding:26px 24px;display:flex;flex-direction:column;gap:14px;flex:1;max-width:440px;width:100%;margin:0 auto;}
.login__meta{display:flex;justify-content:space-between;align-items:center;font:500 13px/1 var(--font-text);color:var(--ink-500);}
.login__meta a{color:var(--indigo-500);font-weight:600;}
.login__foot{text-align:center;color:var(--ink-400);font:500 12px/16px var(--font-text);padding-top:6px;}
.login__err{color:var(--danger-ink);font:600 13px var(--font-text);background:var(--danger-bg);padding:10px 12px;border-radius:var(--r-sm);}

/* ---------------- FIELDS ---------------- */
.field-group{display:flex;flex-direction:column;gap:6px;}
.field,.input,input.field,select.field,textarea.field{font:400 15px/24px var(--font-text);
  padding:12px 14px;border-radius:var(--r-sm);background:var(--surface);
  border:1px solid var(--line-strong);color:var(--ink-900);width:100%;
  transition:border-color var(--d-2),box-shadow var(--d-2);}
.field::placeholder,.input::placeholder{color:var(--ink-400);}
.field:focus,.input:focus,input.field:focus,select.field:focus,textarea.field:focus{
  border-color:var(--indigo-400);box-shadow:var(--sh-focus);outline:none;}
.field--sm{padding:9px 12px;}
.lbl{display:block;margin:10px 0 4px;}
.toggle-line{display:flex;align-items:center;gap:10px;font:500 14px var(--font-text);color:var(--ink-700);cursor:pointer;padding:6px 0;}
.toggle-line input{width:18px;height:18px;accent-color:var(--indigo-500);}
.err-text{color:var(--danger-ink);}

/* ---------------- APP SHELL ---------------- */
.shell{min-height:100vh;display:flex;flex-direction:column;}
.shell__main{flex:1;display:flex;flex-direction:column;min-width:0;}
.content{flex:1;padding:var(--gutter);max-width:640px;width:100%;margin:0 auto;
  padding-bottom:calc(var(--nav-h) + 24px + env(safe-area-inset-bottom));}

.appbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:10px;padding:12px 16px;
  background:rgba(255,255,255,.92);backdrop-filter:saturate(1.2) blur(6px);box-shadow:0 1px 0 var(--line);}
.appbar__logo{width:28px;height:28px;border-radius:9px;object-fit:contain;}
.appbar__title{font:700 17px/1 var(--font-display);color:var(--ink-900);}
.appbar__spacer{flex:1;}
.appbar__menu{background:none;border:0;font-size:20px;color:var(--ink-400);cursor:pointer;padding:4px 8px;}
.appbar__av,.lb__av{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  color:#fff;font:700 14px/1 var(--font-display);background:var(--indigo-500);flex:none;}

.bottomnav{position:fixed;left:0;right:0;bottom:0;z-index:6;height:var(--nav-h);background:var(--surface);
  box-shadow:0 -1px 0 var(--line),0 -8px 24px rgba(15,23,41,.04);
  display:grid;grid-template-columns:repeat(5,1fr);align-items:center;padding-bottom:env(safe-area-inset-bottom);}
.bottomnav-a{display:flex;flex-direction:column;align-items:center;gap:3px;
  font:600 11px/1 var(--font-text);color:var(--ink-400);text-decoration:none;min-height:44px;justify-content:center;}
.bottomnav-a .ic{color:var(--ink-400);display:grid;place-items:center;}
.bottomnav-a.active,.bottomnav-a.active .ic{color:var(--indigo-500);}
.bottomnav__fab{justify-self:center;width:56px;height:56px;border-radius:50%;background:var(--grad-brand);
  box-shadow:var(--sh-3);color:#fff;display:grid;place-items:center;transform:translateY(-12px);text-decoration:none;}
.bottomnav__fabic{display:grid;place-items:center;}
.navlbl{}
.sidenav{display:none;}

/* ---------------- BOOST BANNER ---------------- */
.boost{display:flex;align-items:center;gap:8px;margin:0 0 14px;padding:10px 14px;border-radius:var(--r-md);
  background:var(--indigo-50);color:var(--indigo-700);font:600 13px/1.3 var(--font-text);}
.boost .dot{width:8px;height:8px;border-radius:50%;background:var(--indigo-500);flex:none;animation:pulse 1.6s var(--e-out) infinite;}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(61,90,254,.4)}50%{box-shadow:0 0 0 6px rgba(61,90,254,0)}}

/* ---------------- XP HUD ---------------- */
.hud{padding:18px;}
.hud__top{display:flex;align-items:center;justify-content:space-between;gap:8px;}
.hud__emblem{font-size:22px;}
.hud__id{flex:1;margin-left:4px;}
.hud__rank{font:700 16px/1.2 var(--font-display);color:var(--ink-900);}
.hud__title{font:500 12px/1.2 var(--font-text);color:var(--ink-500);}
.hud__xp{font:800 24px/1 var(--font-display);color:var(--ink-900);}
.hud__xp small{font:600 12px var(--font-text);color:var(--ink-500);}
.hud .bar{margin:12px 0 8px;}
.hud__next{font:500 12px/16px var(--font-text);color:var(--ink-500);}
.hud__next b{color:var(--indigo-600);}
.rankchip{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:var(--r-pill);
  font:600 14px/1 var(--font-text);background:var(--rank-gold-bg);color:#7A6312;}
.rankchip .medal{width:16px;height:16px;border-radius:50%;background:var(--rank-gold);}
.streak{display:inline-flex;align-items:center;gap:3px;color:var(--streak);font:600 12px/1 var(--font-text);}
.remblem{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--r-pill);
  font:700 12px var(--font-display);background:var(--indigo-50);color:var(--indigo-700);}
.remblem--sm{padding:2px 6px;font-size:11px;}
.remblem__e{font-size:14px;}

/* ---------------- TODAY'S JOB + UPSELL ---------------- */
.job__head{display:flex;justify-content:space-between;align-items:baseline;gap:8px;}
.job__head strong{font:700 18px/24px var(--font-display);color:var(--ink-900);}
.job__price{font:700 16px/1 var(--font-display);color:var(--ink-900);}
.job__meta{color:var(--ink-500);font:500 13px/1.4 var(--font-text);margin:4px 0 10px;}
.upsell{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:var(--r-md);background:var(--mint-50);}
.upsell+.upsell{margin-top:8px;}
.upsell__name{font:600 14px/1.2 var(--font-text);color:var(--ink-900);}
.upsell__sub{font:500 11px/1 var(--font-text);color:var(--mint-700);opacity:.85;}
.upsell__reward{margin-left:auto;font:700 14px/1 var(--font-display);color:var(--reward-ink);white-space:nowrap;}
.upsell .btn--sm{background:var(--mint-500);color:#06281C;flex:none;}
.upsell-list{margin:8px 0;}

/* ---------------- CAMPAIGN CARDS ---------------- */
.campaign-card{cursor:pointer;}
.campaign-card+.campaign-card{margin-top:10px;}
.campaign-card__head{display:flex;align-items:center;gap:8px;}
.campaign-card__emblem{font-size:18px;}
.campaign-card__head strong{font:700 16px/1.2 var(--font-display);color:var(--ink-900);flex:1;}
.campaign--featured{box-shadow:var(--sh-2),inset 0 0 0 1.5px var(--mint-200);}
.reward-chip{font:700 15px/1 var(--font-display);color:var(--reward-ink);white-space:nowrap;}
.reward-card{}
.reward-card__line{font:700 16px var(--font-display);color:var(--reward-ink);margin-top:4px;}

/* ---------------- DROPZONE ---------------- */
.dropzone{background:var(--surface-2);border:1.5px dashed var(--line-strong);border-radius:var(--r-xl);
  min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  text-align:center;color:var(--ink-500);cursor:pointer;overflow:hidden;transition:border-color var(--d-2),background var(--d-2);}
.dropzone:hover,.dropzone--over{border-color:var(--indigo-400);background:var(--indigo-50);}
.dz__ic{font-size:34px;}
.dz__text{font:600 15px var(--font-text);color:var(--indigo-500);}
.dz__preview{width:100%;max-height:360px;border-radius:var(--r-lg);background:#000;}

/* ---------------- SPEC CHECKLIST ---------------- */
.spec{display:flex;flex-direction:column;gap:2px;margin-top:8px;}
.spec-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r-sm);
  font:600 15px var(--font-text);color:var(--ink-700);cursor:pointer;}
.spec-row--auto{background:var(--surface-2);cursor:default;}
.spec__mark{width:22px;height:22px;border-radius:7px;flex:none;display:grid;place-items:center;
  box-shadow:inset 0 0 0 2px var(--line-strong);color:transparent;font-size:13px;
  transition:all var(--d-2) var(--e-spring);}
.spec-row--ok{color:var(--ink-900);}
.spec-row--ok .spec__mark{background:var(--mint-500);box-shadow:none;color:#fff;}
.spec__by{margin-left:auto;font:500 12px var(--font-text);color:var(--ink-400);}

/* ---------------- WALLET ---------------- */
.wallet-owed{background:var(--grad-reward);color:#fff;border-radius:var(--r-xl);padding:22px 24px;box-shadow:var(--sh-2);}
.wallet-owed .section-label{color:rgba(255,255,255,.85);}
.wallet-owed__amt{font:800 38px/1.05 var(--font-display);margin-top:8px;font-variant-numeric:tabular-nums;}
.wallet-owed .muted{color:rgba(255,255,255,.92)!important;}
.stat-2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px;}
.kpi{background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--sh-1);padding:16px 18px;}
.kpi--pending{background:var(--surface-2);box-shadow:none;}
.kpi__label{font:600 12px/16px var(--font-text);letter-spacing:.05em;text-transform:uppercase;color:var(--ink-500);}
.kpi__value{font:800 24px/30px var(--font-display);color:var(--ink-900);margin-top:6px;}
.kpi__value.gold{color:var(--reward-ink);}
.kpi__value.muted{color:var(--ink-400);}
.kpi__sub{margin-top:4px;}
.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:6px 0;}

/* ---------------- LEADERBOARD ---------------- */
.lb{display:flex;flex-direction:column;gap:8px;margin-top:8px;}
.lb__row{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--r-md);
  background:var(--surface);box-shadow:var(--sh-1);flex-wrap:wrap;}
.lb__num{width:24px;text-align:center;font:700 16px var(--font-display);color:var(--ink-400);flex:none;}
.lb__name{font:600 15px var(--font-text);color:var(--ink-900);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.lb__val{font:700 14px var(--font-display);color:var(--ink-900);font-variant-numeric:tabular-nums;}
.lb__bar{flex-basis:100%;order:5;}
.lb__row--top1{background:var(--rank-gold-bg);box-shadow:inset 0 0 0 1.5px var(--rank-gold);}
.lb__row--top1 .lb__num{color:#7A6312;}
.lb__row--top2{background:var(--rank-silver-bg);}
.lb__row--top3{background:var(--rank-bronze-bg);}
.lb__row--me{box-shadow:inset 0 0 0 1.5px var(--indigo-400);background:var(--indigo-50);}

/* ---------------- DASHBOARD ---------------- */
.statusbars{display:flex;flex-direction:column;gap:12px;margin-top:10px;}
.statusbar__top{display:flex;justify-content:space-between;font:600 13px var(--font-text);color:var(--ink-700);text-transform:capitalize;margin-bottom:6px;}

/* ---------------- BUILDER ---------------- */
.builder{display:flex;flex-direction:column;gap:16px;}
.builder__form{display:flex;flex-direction:column;gap:12px;}
.builder__preview{}

/* ---------------- REVIEW QUEUE ---------------- */
.review-card{margin-bottom:12px;}
.review-card__media{border-radius:var(--r-md);overflow:hidden;background:var(--surface-2);margin-bottom:12px;min-height:120px;display:grid;place-items:center;}
.review-card__meta{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;}
.review-card__actions{gap:8px;flex-wrap:wrap;}
.qrow{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--r-md);background:var(--surface);box-shadow:var(--sh-1);cursor:pointer;transition:background var(--d-2);}
.qrow+.qrow{margin-top:8px;}
.qrow:hover{background:var(--surface-2);}
.qrow.sel{background:var(--indigo-50);box-shadow:inset 3px 0 0 var(--indigo-500);}
.qrow__poster{width:44px;height:58px;border-radius:9px;flex:none;background:linear-gradient(160deg,#cfd8ea,#aab6d4);position:relative;}
.qrow__main{flex:1;min-width:0;}
.qrow__name{font:600 15px/1.2 var(--font-text);color:var(--ink-900);}
.qrow__sub{font:500 12px/16px var(--font-text);color:var(--ink-500);display:flex;gap:8px;align-items:center;margin-top:3px;flex-wrap:wrap;}
.mc{font:600 11px/1 var(--font-text);color:var(--success-ink);}
.mc.open{color:var(--ink-400);}

/* ---------------- MAP (door-hanger) ---------------- */
.map{position:relative;border-radius:var(--r-lg);overflow:hidden;background:var(--surface-2);min-height:340px;box-shadow:var(--sh-1);}
.map__canvas{position:absolute;inset:0;}
.map__overlay{position:absolute;left:12px;top:12px;z-index:500;background:var(--surface);border-radius:var(--r-md);
  box-shadow:var(--sh-2);padding:10px 14px;font:600 14px var(--font-text);color:var(--ink-900);}
.map__counter b{color:var(--reward-ink);font-variant-numeric:tabular-nums;}
.map__doors{display:flex;align-items:center;gap:10px;position:absolute;right:12px;top:12px;z-index:500;
  background:var(--surface);border-radius:var(--r-pill);box-shadow:var(--sh-2);padding:6px 8px;}
.map__doorbtn{width:38px;height:38px;border-radius:50%;border:0;background:var(--surface-2);color:var(--ink-900);
  font:700 20px/1 var(--font-display);cursor:pointer;display:grid;place-items:center;}
.map__doorbtn:active{transform:scale(.94);}
.map__doorbtn--plus{background:var(--mint-500);color:#06281C;}
.map__doornum{font:800 22px/1 var(--font-display);min-width:36px;text-align:center;color:var(--ink-900);font-variant-numeric:tabular-nums;}
.map__fab{position:absolute;right:16px;bottom:16px;z-index:500;}
.run-stat{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:12px 0;}
.run-stat .kpi{padding:12px 14px;text-align:center;}
.run-stat .kpi__value{font-size:20px;}
.minimap{height:160px;border-radius:var(--r-md);overflow:hidden;background:var(--surface-2);margin-top:8px;}
.leaflet-container{font:500 11px var(--font-text);background:#dfe6f1;}
.leaflet-bar a{color:var(--ink-700)!important;}

/* ---------------- REWARD REVEAL ---------------- */
.reveal{text-align:center;padding:8px 4px;}
.reveal__burst{width:84px;height:84px;border-radius:50%;margin:0 auto 16px;display:grid;place-items:center;
  background:var(--grad-reward);box-shadow:0 8px 24px rgba(16,185,129,.35);color:#fff;font-size:38px;
  animation:revealPop var(--d-4) var(--e-spring) both;}
.reveal__amt{font:800 36px/40px var(--font-display);color:var(--reward-ink);font-variant-numeric:tabular-nums;margin-top:4px;}
.reveal__xp{font:600 16px/1 var(--font-text);color:var(--indigo-600);margin-top:8px;}
@keyframes revealPop{from{opacity:0;transform:scale(.9) translateY(8px);}to{opacity:1;transform:none;}}

/* ---------------- MODAL ---------------- */
.modal-bg{position:fixed;inset:0;z-index:60;background:rgba(15,23,41,.42);display:flex;align-items:flex-end;justify-content:center;animation:fade var(--d-2) var(--e-out);}
@keyframes fade{from{opacity:0;}to{opacity:1;}}
.modal{background:var(--surface);width:100%;max-width:520px;border-radius:var(--r-xl) var(--r-xl) 0 0;
  box-shadow:var(--sh-3);padding:20px;max-height:92vh;overflow:auto;animation:slideup var(--d-3) var(--e-out);}
@keyframes slideup{from{transform:translateY(40px);opacity:.6;}to{transform:none;opacity:1;}}
.modal__head{display:flex;align-items:center;gap:10px;margin-bottom:14px;}
.modal__head h3{flex:1;font:700 18px var(--font-display);color:var(--ink-900);}
.modal__emblem{font-size:20px;}
.modal__x{margin-left:auto;background:var(--surface-2);border:0;border-radius:10px;width:34px;height:34px;display:grid;place-items:center;cursor:pointer;color:var(--ink-500);}
body.modal-open{overflow:hidden;}

/* ---------------- TOASTS ---------------- */
#toasts{position:fixed;left:0;right:0;bottom:calc(var(--nav-h) + 16px);z-index:80;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none;padding:0 16px;}
.toast{background:var(--ink-900);color:#fff;border-radius:var(--r-md);padding:12px 16px;font:600 14px var(--font-text);box-shadow:var(--sh-3);max-width:520px;transition:all .3s;}
.toast--ok{background:var(--mint-600);}
.toast--err{background:var(--danger);}

/* ---------------- SBFx confetti ---------------- */
.sbfx{position:fixed;inset:0;z-index:90;pointer-events:none;overflow:hidden;}
.sbfx i{position:absolute;top:-12px;width:9px;height:9px;border-radius:2px;animation:fall 1.2s var(--e-out) forwards;}
@keyframes fall{to{transform:translateY(105vh) rotate(380deg);opacity:0;}}

/* =============================================================
   DESKTOP (>=900px) — sidebar cockpit for staff
============================================================= */
@media (min-width:900px){
  .shell--staff{flex-direction:row;}
  .shell--staff .appbar,.shell--staff .bottomnav{display:none;}
  .shell--staff .sidenav{display:flex;flex-direction:column;position:sticky;top:0;height:100vh;width:var(--sidebar-w);flex:none;
    background:var(--surface);border-right:1px solid var(--line);padding:18px 12px;}
  .sidenav__logo{display:flex;align-items:center;gap:10px;padding:6px 10px 18px;font:800 18px var(--font-display);color:var(--ink-900);}
  .sidenav__logo img{width:30px;height:30px;border-radius:9px;}
  .sidenav__logo span{font:600 12px var(--font-text);color:var(--ink-500);text-transform:uppercase;letter-spacing:.06em;}
  .sidenav__items{display:flex;flex-direction:column;gap:2px;flex:1;}
  .sidenav-a{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--r-md);font:600 15px var(--font-text);color:var(--ink-700);text-decoration:none;}
  .sidenav-a:hover{background:var(--surface-2);}
  .sidenav-a.active{background:var(--indigo-50);color:var(--indigo-700);}
  .sidenav-a.active .ic{color:var(--indigo-500);}
  .sidenav-a .ic{color:var(--ink-400);display:grid;place-items:center;}
  .sidenav__foot{border-top:1px solid var(--line);padding-top:12px;}
  .sidenav__user{display:flex;align-items:center;gap:10px;margin-bottom:10px;font:500 13px var(--font-text);}
  .sidenav__user strong{color:var(--ink-900);font-weight:600;display:block;}
  .shell--staff .content{max-width:var(--content-max);padding:var(--gutter-d);padding-bottom:var(--gutter-d);}
  .kpi-grid{grid-template-columns:repeat(4,1fr);}
  .builder{display:grid;grid-template-columns:1.4fr 1fr;align-items:start;gap:24px;}
  .builder__preview{position:sticky;top:24px;}
  .shell:not(.shell--staff) .content{max-width:560px;}
  #toasts{bottom:24px;}
}
@media (max-width:899px){.sidenav{display:none!important;}}

/* ---------------- REDUCED MOTION ---------------- */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;}
  .sbfx{display:none;}
}
