/* ============================================================================
   DIVONCI WORLD — MOBILE · LAYOUT
   A real phone viewport: the whole app lives inside #device. On a phone it
   fills the screen; on desktop it renders as a centred device frame.
   Reuses component styles from os.css (.stat, .mission, .list, .pill, …).
   ========================================================================== */
html,body{ height:100%; margin:0; overflow:hidden; }
body{ font-family:var(--font-ui); color:var(--ink); overscroll-behavior:none;
  -webkit-font-smoothing:antialiased; display:flex; align-items:center; justify-content:center;
  min-height:100dvh; background:
   radial-gradient(120% 80% at 70% -10%, rgba(139,92,246,0.10), transparent 60%),
   radial-gradient(80% 60% at 10% 110%, rgba(217,70,239,0.06), transparent 55%),
   #050409; }
#device, #device *{ -webkit-tap-highlight-color:transparent; }
#device button, #device [role="button"], #device [data-toggle], #device [data-action]{
  -webkit-user-select:none; user-select:none;
}

/* ----------------------------------------------------------- DEVICE ----- */
#device{ position:relative; overflow:hidden; flex:none;
  /* always sized & proportioned like a phone, scaled to fit the pane */
  --h: min(94vh, calc(96vw * 852 / 393));
  height:var(--h); width:calc(var(--h) * 393 / 852);
  background:var(--void); border-radius:46px; border:1px solid var(--hairline-2);
  box-shadow:0 44px 120px rgba(0,0,0,0.72), 0 0 0 11px #131019, 0 0 0 12px #221c30, var(--glow-soft); }
/* a real phone — fill the screen, drop the bezel */
@media (pointer:coarse){
  html,body{ background:var(--void); }
  #device{ width:100vw; height:100dvh; --h:100dvh; border-radius:0; border:none; box-shadow:none; }
}

/* ---------------------------------------------------------------- STAGE -- */
#mstage{ position:absolute; inset:0; background:
  radial-gradient(120% 80% at 78% -8%, rgba(139,92,246,0.12), transparent 58%),
  radial-gradient(80% 60% at 6% 10%, rgba(217,70,239,0.07), transparent 55%),
  linear-gradient(180deg, var(--void), #07060e 55%, var(--void)); }
#mmap{ position:absolute; inset:0; width:100%; height:100%; display:block; cursor:grab; touch-action:none; }
#mmap:active{ cursor:grabbing; }

/* faint top + bottom vignette so chrome reads over the map */
#mstage::before{ content:""; position:absolute; left:0; right:0; top:0; height:150px; pointer-events:none;
  background:linear-gradient(180deg, rgba(6,6,12,0.8), transparent); }
#mstage::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:200px; pointer-events:none;
  background:linear-gradient(0deg, rgba(6,6,12,0.84), transparent); }

/* ------------------------------------------------------------- HEADER --- */
.m-top{ position:absolute; top:0; left:0; right:0; z-index:30; padding:12px 16px 8px;
  display:flex; align-items:center; gap:12px; pointer-events:none; }
.m-top > *{ pointer-events:auto; }
.m-statusbar{ position:absolute; top:8px; left:20px; right:20px; display:flex; justify-content:space-between;
  font-family:var(--font-mono); font-size:11px; color:var(--ink-2); letter-spacing:0.02em; }
.m-brand{ display:flex; align-items:center; gap:10px; margin-top:16px; }
.m-brand .gem{ width:22px; height:22px; border-radius:7px; background:var(--violet);
  box-shadow:0 0 0 1px rgba(168,85,247,0.5), 0 0 20px rgba(168,85,247,0.7); animation:gemPulse 4s var(--ease-inout) infinite; }
@keyframes gemPulse{ 0%,100%{filter:brightness(1)} 50%{filter:brightness(1.4)} }
.m-brand .wm{ font-family:var(--font-display); font-weight:700; font-size:14px; letter-spacing:0.03em; line-height:1; }
.m-brand .wm small{ display:block; font-family:var(--font-mono); font-size:7px; color:var(--ink-3); letter-spacing:0.2em; font-weight:400; margin-top:3px; }
.m-live{ margin-left:auto; margin-top:16px; display:inline-flex; align-items:center; gap:6px;
  font-family:var(--font-mono); font-size:9px; letter-spacing:0.08em; text-transform:uppercase; color:var(--state-clear);
  background:rgba(16,14,25,0.55); backdrop-filter:blur(8px); border:1px solid var(--hairline-2); border-radius:var(--r-pill); padding:6px 11px; }
.m-live::before{ content:""; width:6px; height:6px; border-radius:99px; background:var(--state-clear); box-shadow:0 0 8px var(--state-clear); animation:blink 1.6s infinite; }
@keyframes blink{ 0%,100%{opacity:1} 50%{opacity:.3} }

/* --------------------------------------------------------- MAP CONTROLS - */
.m-zoom{ position:absolute; left:14px; bottom:104px; z-index:30; display:flex; flex-direction:column; gap:7px; }
.m-zoom button{ width:42px; height:42px; border-radius:var(--r-md); border:1px solid var(--hairline-2);
  background:rgba(29,25,41,0.6); backdrop-filter:blur(10px); color:var(--ink-2); font-size:19px; cursor:pointer;
  display:flex; align-items:center; justify-content:center; transition:all var(--dur-fast); }
.m-zoom button:active{ color:var(--ink); background:var(--panel-3); }
.m-zoom button.sm{ font-size:15px; }
.m-zoom button.gear{ font-size:17px; }
.m-zoom button.gear.on{ color:var(--ultraviolet); border-color:rgba(192,132,252,0.5);
  background:rgba(192,132,252,0.12); box-shadow:0 0 12px -4px var(--ultraviolet); }

/* ------------------------------------------------- WITHDRAW / PAYOUT DRAW */
.wd .of-total{ background:rgba(212,176,98,0.08); border-color:rgba(212,176,98,0.3); }
.wd .of-total b{ color:var(--gold-bright); }
.wd-methods{ display:grid; grid-template-columns:repeat(3,1fr); gap:8px; }
.wd-method{ display:flex; flex-direction:column; align-items:flex-start; gap:3px; text-align:left;
  padding:10px 10px; border-radius:var(--r-md); cursor:pointer; transition:all var(--dur-fast);
  background:rgba(16,14,25,0.5); border:1px solid var(--hairline-2); color:var(--ink-2); }
.wd-method:active{ transform:scale(0.97); }
.wd-method.on{ color:var(--ink); border-color:rgba(212,176,98,0.55); background:rgba(212,176,98,0.1);
  box-shadow:inset 0 0 0 1px rgba(212,176,98,0.2); }
.wd-mic{ font-family:var(--font-display); font-weight:700; font-size:15px; color:var(--gold-bright); line-height:1; }
.wd-method.on .wd-mic{ text-shadow:0 0 10px rgba(236,208,138,0.6); }
.wd-mt{ font-size:12px; font-weight:500; }
.wd-ms{ font-family:var(--font-mono); font-size:8px; letter-spacing:0.04em; text-transform:uppercase; color:var(--ink-4); }
.wd-pane{ display:flex; flex-direction:column; gap:10px; }
.wd-pane[hidden]{ display:none !important; }
textarea.wd-area{ resize:vertical; min-height:62px; line-height:1.45; }
.wd-verify{ color:#F5B544 !important; display:flex; align-items:flex-start; gap:7px; line-height:1.45; }
.wd-verify > span:first-child{ flex:none; }
.wd .of-submit{ border-color:rgba(212,176,98,0.5); background:rgba(212,176,98,0.16); color:#FFE3A0; }
.wd .of-submit:hover{ background:rgba(212,176,98,0.26); color:#fff; }

/* ------------------------------------------------- MAP LAYER MENU (icons) */
.m-layers{ position:absolute; top:34px; left:12px; right:12px; z-index:31;
  display:flex; align-items:center; justify-content:space-between; gap:2px; padding:6px 10px;
  background:linear-gradient(180deg, rgba(37,31,51,0.62), rgba(16,14,25,0.66));
  -webkit-backdrop-filter:blur(14px) saturate(1.3); backdrop-filter:blur(14px) saturate(1.3);
  border:1px solid var(--hairline-2); border-radius:var(--r-pill);
  box-shadow:0 12px 34px rgba(0,0,0,0.5), var(--shadow-inset);
  /* hidden until the gear is pressed → slides down from above */
  transform:translateY(-140%); opacity:0; pointer-events:none;
  transition:transform var(--dur-slow) var(--ease-out), opacity var(--dur-base) var(--ease-out); }
.m-layers.open{ transform:translateY(0); opacity:1; pointer-events:auto; }
.ml-btn{ display:inline-flex; align-items:center; justify-content:center; width:31px; height:31px; flex:none;
  cursor:pointer; padding:0; border:1px solid transparent; border-radius:var(--r-sm); background:transparent;
  color:var(--c,var(--ink-2)); transition:all var(--dur-fast); }
.ml-btn .ml-ic{ font-size:13px; line-height:1; font-family:var(--font-display); }
.ml-btn.on{ color:var(--c); background:color-mix(in oklab, var(--c) 13%, transparent);
  border-color:color-mix(in oklab, var(--c) 38%, transparent); box-shadow:0 0 10px -4px var(--c); }
.ml-btn.off{ color:var(--ink-4); opacity:0.5; }
.ml-btn:active{ transform:scale(0.92); }
.ml-sep{ width:1px; height:16px; background:var(--hairline-2); margin:0 3px; flex:none; }
.m-hint{ position:absolute; left:16px; bottom:108px; z-index:30; font-family:var(--font-mono); font-size:9px;
  letter-spacing:0.1em; color:var(--violet-ink); background:rgba(16,14,25,0.5); backdrop-filter:blur(8px);
  border:1px solid var(--hairline); border-radius:var(--r-pill); padding:7px 12px; pointer-events:none; }

/* ============================================== SKULL ISLAND CHROME ====== */
/* --skr (0..1) is written each frame from the map's kingdom-reveal level.
   The whole chrome is tied to it: the bar slides down + fades in as you pinch
   into Skull Island, and snaps back up when you zoom out. */
#device{ --skr:0; }
.skull-chrome{ position:absolute; inset:0; z-index:60; pointer-events:none; }
/* --- top bar (slides down with zoom) --- */
.sk-bar{ position:absolute; top:0; left:0; right:0; display:flex; align-items:center; gap:11px;
  padding:calc(10px + env(safe-area-inset-top,0px)) 14px 11px; pointer-events:none;
  background:linear-gradient(180deg, rgba(16,8,26,0.94) 0%, rgba(16,8,26,0.74) 62%, rgba(16,8,26,0));
  transform:translateY(-110%); opacity:0; will-change:transform, opacity; }
.skull-chrome.live .sk-bar > *{ pointer-events:auto; }
.sk-burger{ flex:none; width:40px; height:40px; border-radius:var(--r-md); cursor:pointer;
  border:1px solid rgba(192,132,252,0.4); background:rgba(40,18,58,0.7); backdrop-filter:blur(10px);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px; padding:0;
  transition:background var(--dur-fast), border-color var(--dur-fast); }
.sk-burger span{ display:block; width:17px; height:2px; border-radius:2px; background:#E4CBFF;
  transition:transform 0.26s var(--ease-out), opacity 0.2s var(--ease-out); }
.sk-burger:active{ background:rgba(60,28,86,0.85); }
.skull-chrome.menu-open .sk-burger{ border-color:rgba(216,180,254,0.8); background:rgba(60,28,86,0.85); }
.skull-chrome.menu-open .sk-burger span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
.skull-chrome.menu-open .sk-burger span:nth-child(2){ opacity:0; }
.skull-chrome.menu-open .sk-burger span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }
.sk-brand{ display:flex; align-items:center; gap:9px; min-width:0; }
.sk-skull{ font-size:21px; line-height:1; color:#C084FC; text-shadow:0 0 14px rgba(168,85,247,0.85); flex:none; }
.sk-bt{ display:flex; flex-direction:column; font-family:var(--font-display); font-weight:700; font-size:14px;
  letter-spacing:0.04em; color:#F0E6FF; line-height:1.05; }
.sk-bs{ font-family:var(--font-mono); font-weight:500; font-size:8px; letter-spacing:0.16em;
  color:rgba(192,132,252,0.85); margin-top:2px; }
.sk-tier{ margin-left:auto; flex:none; font-family:var(--font-mono); font-size:8.5px; letter-spacing:0.14em;
  text-transform:uppercase; color:#E4CBFF; padding:6px 10px; border-radius:var(--r-pill);
  border:1px solid rgba(168,85,247,0.45); background:rgba(40,18,58,0.6); white-space:nowrap; }
/* --- district slide-in menu (burger toggles; snaps shut on zoom-out) --- */
.sk-menu{ position:absolute; top:calc(58px + env(safe-area-inset-top,0px)); left:12px; width:min(280px, 78vw);
  max-height:calc(100% - 150px); overflow-y:auto; -webkit-overflow-scrolling:touch; pointer-events:none; scrollbar-width:none;
  display:flex; flex-direction:column; gap:7px; padding:13px; border-radius:var(--r-xl);
  background:linear-gradient(180deg, rgba(30,14,46,0.92), rgba(14,8,24,0.94)); backdrop-filter:blur(20px) saturate(1.2);
  border:1px solid rgba(168,85,247,0.34); box-shadow:0 26px 60px rgba(0,0,0,0.6), inset 0 0 30px -16px rgba(168,85,247,0.5);
  transform:translateX(-118%); opacity:0; }
.sk-menu::-webkit-scrollbar{ width:0; height:0; }
/* the slide is driven by JS rAF (see buildSkullChrome) — CSS transition on this
   element stalls in some engines, so we animate transform/opacity inline instead */
.skull-chrome.menu-open .sk-menu{ pointer-events:auto; }
.sk-menu-h{ font-family:var(--font-mono); font-size:8.5px; letter-spacing:0.18em; text-transform:uppercase;
  color:rgba(192,132,252,0.7); padding:1px 2px 4px; }
.sk-menu-list{ display:flex; flex-direction:column; gap:6px; }
.sk-node{ display:flex; align-items:center; gap:11px; padding:10px 11px; cursor:pointer; text-align:left;
  border-radius:var(--r-md); border:1px solid var(--hairline-2); background:rgba(11,8,20,0.5);
  transition:border-color var(--dur-fast), background var(--dur-fast), transform var(--dur-fast); }
.sk-node:active{ transform:scale(0.98); background:rgba(40,18,58,0.7); }
.sk-node-ic{ flex:none; width:30px; height:30px; border-radius:8px; display:grid; place-items:center;
  font-size:15px; border:1.5px solid; background:rgba(11,8,20,0.7); }
.sk-node-tx{ display:flex; flex-direction:column; min-width:0; flex:1; }
.sk-node-n{ font-family:var(--font-mono); font-weight:600; font-size:10.5px; letter-spacing:0.04em; color:#F0E6FF;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sk-node-s{ font-family:var(--font-mono); font-size:8px; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--ink-4); margin-top:2px; }
.sk-node-dot{ flex:none; width:7px; height:7px; border-radius:99px; }
.sk-cta{ width:100%; margin-top:2px; padding:13px; cursor:pointer; border-radius:var(--r-md);
  font-family:var(--font-mono); font-size:11px; letter-spacing:0.08em; text-transform:uppercase; font-weight:600;
  color:#E4CBFF; border:1px solid rgba(168,85,247,0.5);
  background:linear-gradient(180deg, rgba(168,85,247,0.22), rgba(168,85,247,0.08)); }
.sk-cta:active{ background:rgba(168,85,247,0.3); }
/* when deep in Skull Island, recede the world-map chrome that doesn't belong here */
#device.sk-live .m-statusbar{ opacity:0.25; transition:opacity 0.3s var(--ease-out); }
#device.sk-live #mLayersToggle{ opacity:0.25; pointer-events:none; transition:opacity 0.3s var(--ease-out); }

/* -------------------------------------------------- SLIDE BAR (bottom nav) */
.tabbar{ position:absolute; left:12px; right:12px; bottom:12px; z-index:90;
  display:grid; grid-template-columns:repeat(5,1fr); gap:2px; padding:7px;
  background:linear-gradient(180deg, rgba(37,31,51,0.72), rgba(16,14,25,0.74)); backdrop-filter:blur(22px) saturate(1.3);
  border:1px solid var(--hairline-2); border-radius:var(--r-2xl);
  box-shadow:0 18px 50px rgba(0,0,0,0.55), var(--shadow-inset); }
.tabbar button{ position:relative; background:none; border:none; cursor:pointer; padding:9px 0 8px;
  display:flex; flex-direction:column; align-items:center; gap:5px; border-radius:var(--r-lg);
  color:var(--ink-3); font-family:var(--font-mono); font-size:8px; letter-spacing:0.06em; text-transform:uppercase;
  transition:color var(--dur-fast); }
.tabbar button .ic{ font-size:17px; line-height:1; transition:transform var(--dur-fast); }
.tabbar button:active .ic{ transform:scale(0.9); }
.tabbar button.on{ color:var(--ink); background:var(--active-dim); }
.tabbar button.on .ic{ color:var(--ultraviolet); text-shadow:0 0 12px rgba(192,132,252,0.7); }
.tabbar button.on::before{ content:""; position:absolute; top:3px; left:50%; transform:translateX(-50%);
  width:18px; height:3px; border-radius:99px; background:var(--ultraviolet); box-shadow:0 0 10px var(--ultraviolet); }

/* ------------------------------------------------- SLIDE-UP SHEET (glass) */
.sheet-scrim{ position:absolute; inset:0; z-index:75; background:rgba(4,4,9,0.26);
  opacity:0; pointer-events:none; transition:opacity var(--dur-base); }
.sheet-scrim.show{ opacity:1; pointer-events:auto; }
.sheet{ position:absolute; left:0; right:0; bottom:0; z-index:80; height:80%; max-height:80%;
  display:flex; flex-direction:column; transform:translateY(101%);
  transition:transform var(--dur-slow) var(--ease-out);
  background:linear-gradient(180deg, rgba(34,28,49,0.20), rgba(12,11,19,0.34));
  -webkit-backdrop-filter:blur(11px) saturate(1.3); backdrop-filter:blur(11px) saturate(1.3);
  border-top:1px solid var(--hairline-3); border-radius:26px 26px 0 0;
  box-shadow:0 -30px 90px rgba(0,0,0,0.6), var(--shadow-inset); }
.sheet.open{ transform:translateY(0); }
/* chat window only — expand to full screen while the user is composing,
   collapses back to the normal draw height when they hit return */
.sheet.chat-full{ height:100%; max-height:100%; border-radius:0; }
.sheet-accent{ position:absolute; top:0; left:26px; right:26px; height:2px; border-radius:99px; background:var(--ac,var(--violet)); box-shadow:0 0 16px var(--ac,var(--violet)); }

.sheet-grip{ padding:11px 0 4px; display:flex; justify-content:center; cursor:grab; touch-action:none; }
.sheet-grip span{ width:42px; height:5px; border-radius:99px; background:var(--hairline-3); }
.sheet-head{ display:flex; align-items:flex-start; gap:12px; padding:4px 20px 14px; border-bottom:1px solid var(--hairline); }
.sheet-eyebrow{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:0.16em; text-transform:uppercase;
  color:var(--violet-ink); display:flex; align-items:center; gap:8px; }
.sheet-eyebrow .g{ width:9px; height:9px; border-radius:3px; background:var(--ac,var(--violet)); box-shadow:0 0 10px var(--ac,var(--violet)); }
.sheet-head h2{ font-family:var(--font-display); font-weight:600; font-size:22px; margin:7px 0 0; line-height:1.1; }
.sheet-close{ margin-left:auto; flex:none; width:32px; height:32px; border-radius:var(--r-sm);
  background:var(--panel-2); border:1px solid var(--hairline-2); color:var(--ink-3); cursor:pointer;
  font-size:16px; display:flex; align-items:center; justify-content:center; }
.sheet-close:active{ color:var(--ink); background:var(--panel-3); }
.sheet-back{ flex:none; width:32px; height:32px; margin:2px 2px 0 0; border-radius:var(--r-sm);
  background:var(--panel-2); border:1px solid var(--hairline-2); color:var(--ink-2); cursor:pointer;
  font-size:20px; line-height:1; display:flex; align-items:center; justify-content:center; }
.sheet-back[hidden]{ display:none; }
.sheet-back:active{ color:var(--ink); background:var(--panel-3); }

/* transient action toast */
.toast{ position:absolute; left:50%; bottom:96px; transform:translate(-50%,14px); z-index:95;
  background:linear-gradient(180deg, rgba(40,33,56,0.92), rgba(16,14,25,0.94)); backdrop-filter:blur(14px);
  border:1px solid var(--hairline-3); border-radius:var(--r-pill); padding:9px 16px; max-width:80%;
  font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.04em; color:var(--ink); text-align:center;
  box-shadow:0 12px 30px rgba(0,0,0,0.5); opacity:0; pointer-events:none; transition:opacity .2s, transform .2s; }
.toast.show{ opacity:1; transform:translate(-50%,0); }
.toast::before{ content:""; display:inline-block; width:6px; height:6px; border-radius:99px; margin-right:8px;
  background:var(--state-clear); box-shadow:0 0 8px var(--state-clear); vertical-align:middle; }
.sheet-body{ flex:1; min-height:0; overflow-y:auto; -webkit-overflow-scrolling:touch;
  touch-action:pan-y; overscroll-behavior:contain; padding:16px 16px 96px;
  display:flex; flex-direction:column; gap:16px; scrollbar-width:none; -ms-overflow-style:none; }
.sheet-body::-webkit-scrollbar{ width:0; }
.sheet-sub{ font-size:12.5px; color:var(--ink-3); line-height:1.5; margin-top:-2px; }

.twl-live-panel{ display:flex; flex-direction:column; gap:10px; }
.twl-live-head{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.twl-live-head .sect-label{ margin:0; }
.twl-live-state{ flex:none; font-family:var(--font-mono); font-size:8.5px; letter-spacing:0.14em;
  color:var(--state-clear); border:1px solid rgba(47,224,161,0.28); border-radius:var(--r-pill);
  padding:4px 7px; background:rgba(47,224,161,0.07); }
.twl-live-panel.is-empty .twl-live-state{ color:var(--ink-4); border-color:var(--hairline-2); background:rgba(255,255,255,0.03); }
.twl-live-body{ display:flex; flex-direction:column; gap:9px; }
.twl-live-host{ border:1px solid var(--hairline-2); border-radius:var(--r-sm);
  background:linear-gradient(180deg, rgba(37,31,51,0.5), rgba(16,14,25,0.45)); overflow:hidden; }
.twl-live-host-title{ padding:8px 10px; border-bottom:1px solid var(--hairline);
  font-family:var(--font-mono); font-size:9px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-4); }
.twl-live-host-body{ display:flex; flex-direction:column; gap:1px; }
.twl-live-clone{ display:grid; grid-template-columns:minmax(0,1fr) auto; gap:8px; align-items:center;
  padding:9px 10px; border:0; border-bottom:1px solid rgba(255,255,255,0.055);
  background:rgba(255,255,255,0.018); color:var(--ink-2); font-size:11.5px; line-height:1.35; text-align:left; }
.twl-live-clone:last-child{ border-bottom:0; }
.twl-live-clone span,
.twl-live-clone div{ min-width:0; overflow-wrap:anywhere; }
.twl-live-clone [data-field],
.twl-live-clone [data-potm-part],
.twl-live-clone [data-potm-wrap]{ display:inline-flex; align-items:center; gap:4px; margin-right:6px; }
.twl-live-clone [data-field="rank"],
.twl-live-clone [data-field$="medal"],
.twl-live-clone [data-potm-part="position"]{ color:var(--gold-bright); }
.twl-live-clone [data-field$="name"],
.twl-live-clone [data-field="username"],
.twl-live-clone [data-field="contact-name"],
.twl-live-clone [data-field="campaign-name"],
.twl-live-clone [data-field="order-customer"]{ color:var(--ink); font-weight:650; }
.twl-live-clone [data-live-action],
.twl-live-clone button{ pointer-events:none; opacity:0.75; }
.twl-live-text{ padding:9px 10px; color:var(--ink-3); font-size:11.5px; line-height:1.4; overflow-wrap:anywhere; }
.twl-live-more{ padding:8px 10px; color:var(--violet-ink); font-family:var(--font-mono);
  font-size:9px; letter-spacing:0.1em; text-transform:uppercase; background:rgba(168,85,247,0.06); }

/* component surfaces read on glass — lift the recessed wells slightly */
.sheet-body .stat,
.sheet-body .mission,
.sheet-body .bar-track,
.sheet-body .m-prog{ background:rgba(16,14,25,0.5); }
.sheet-body .m-card{ background:linear-gradient(180deg, rgba(37,31,51,0.55), rgba(22,19,31,0.5)); }
.sheet-body .stat{ border-color:var(--hairline-2); }

/* ---- create-order form (raised as a sub-sheet) ---- */
.oform{ display:flex; flex-direction:column; gap:14px; }
.of-field{ display:flex; flex-direction:column; gap:7px; }
.of-label{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:0.14em; text-transform:uppercase; color:var(--ink-4); }
.of-label em{ font-style:normal; color:var(--ink-4); opacity:0.65; margin-left:5px; }
.of-grid{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.of-input{ width:100%; box-sizing:border-box; font-family:var(--font-ui); font-size:14px; color:var(--ink);
  background:rgba(16,14,25,0.6); border:1px solid var(--hairline-2); border-radius:var(--r-sm);
  padding:11px 12px; outline:none; transition:border-color var(--dur-fast); -webkit-appearance:none; appearance:none; }
.of-input:focus{ border-color:rgba(77,159,255,0.65); }
.of-input::placeholder{ color:var(--ink-4); }
.of-sel{ position:relative; }
.of-sel::after{ content:""; position:absolute; right:14px; top:50%; width:7px; height:7px;
  border-right:1.5px solid var(--ink-3); border-bottom:1.5px solid var(--ink-3);
  transform:translateY(-70%) rotate(45deg); pointer-events:none; }
.of-sel .of-input{ padding-right:30px; cursor:pointer; }
.of-total{ display:flex; align-items:center; justify-content:space-between; padding:13px 14px; border-radius:var(--r-sm);
  background:rgba(77,159,255,0.08); border:1px solid rgba(77,159,255,0.28); }
.of-total span{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-3); }
.of-total b{ font-family:var(--font-display); font-weight:600; font-size:20px; color:var(--ink); font-variant-numeric:tabular-nums; }
.of-submit{ margin-top:2px; font-family:var(--font-mono); font-size:12px; letter-spacing:0.1em; text-transform:uppercase; font-weight:600;
  padding:14px; border-radius:var(--r-sm); border:1px solid rgba(77,159,255,0.5);
  background:rgba(77,159,255,0.16); color:#cfe4ff; cursor:pointer; transition:all var(--dur-fast); }
.of-submit:hover{ background:rgba(77,159,255,0.26); color:#fff; }
.of-submit:active{ transform:translateY(1px); }

/* ---- order summary · credits + commission split ---- */
.of-summary{ display:flex; flex-direction:column; gap:11px; padding:13px 14px; border-radius:var(--r-sm);
  background:rgba(77,159,255,0.08); border:1px solid rgba(77,159,255,0.28); }
.of-sumrow{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.of-sumrow > span{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-3); }
.of-sumrow b{ font-family:var(--font-display); font-weight:600; font-size:16px; color:var(--ink); font-variant-numeric:tabular-nums; }
.of-sumrow b.neg{ color:#2FE0A1; font-size:15px; }
.of-sumrow.due{ padding-top:10px; border-top:1px solid rgba(77,159,255,0.2); }
.of-sumrow.due b{ font-size:21px; }
.of-sumrow[hidden]{ display:none; }
.of-split{ display:flex; flex-direction:column; gap:9px; padding-top:11px; border-top:1px solid rgba(77,159,255,0.2); }
.of-split-head{ display:flex; align-items:baseline; justify-content:space-between; }
.of-split-head > span:first-child{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-3); }
.of-split-tot{ font-family:var(--font-mono); font-size:12px; color:#9FC6FF; font-variant-numeric:tabular-nums; }
.of-split-bar{ display:flex; gap:2px; height:7px; border-radius:4px; overflow:hidden; background:rgba(255,255,255,0.06); }
.of-split-bar i{ display:block; height:100%; border-radius:2px; }
.of-split-bar i.you{ background:#4D9FFF; }
.of-split-bar i.courier{ background:#F5B544; }
.of-split-rows{ display:flex; flex-direction:column; gap:7px; }
.of-srow{ display:grid; grid-template-columns:auto 1fr auto; gap:9px; align-items:center; }
.of-sdot{ width:9px; height:9px; border-radius:50%; }
.of-sdot.you{ background:#4D9FFF; box-shadow:0 0 8px -2px #4D9FFF; }
.of-sdot.courier{ background:#F5B544; box-shadow:0 0 8px -2px #F5B544; }
.of-srow .of-sk{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.04em; text-transform:uppercase; color:var(--ink-2); }
.of-srow .of-sv{ font-family:var(--font-display); font-weight:600; font-size:13.5px; color:var(--ink); font-variant-numeric:tabular-nums; }
.of-credits{ display:flex; align-items:center; justify-content:center; gap:8px; cursor:pointer;
  font-family:var(--font-mono); font-size:11px; letter-spacing:0.08em; text-transform:uppercase; font-weight:600;
  padding:13px; border-radius:var(--r-sm); transition:all var(--dur-fast);
  color:#9FC6FF; border:1px solid rgba(77,159,255,0.4); background:rgba(77,159,255,0.1); }
.of-credits .of-cr-ic{ font-size:12px; line-height:1; }
.of-credits:active{ transform:translateY(1px); }
.of-credits.on{ color:#bff4df; border-color:rgba(47,224,161,0.55); background:rgba(47,224,161,0.16); }
.of-credits.on .of-cr-ic{ color:#2FE0A1; }

/* ---- order receipt drawer ---- */
.rcpt-meta{ display:flex; flex-direction:column; border:1px solid var(--hairline); border-radius:var(--r-lg); overflow:hidden; }
.rcpt-mrow{ display:flex; justify-content:space-between; gap:14px; padding:11px 13px; border-top:1px solid var(--hairline); }
.rcpt-mrow:first-child{ border-top:none; }
.rcpt-mk{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-4); white-space:nowrap; }
.rcpt-mv{ font-size:13px; color:var(--ink); text-align:right; }
.rcpt-items{ display:flex; flex-direction:column; border:1px solid var(--hairline); border-radius:var(--r-lg); overflow:hidden; }
.rcpt-line{ display:grid; grid-template-columns:1fr auto auto; gap:12px; align-items:center; padding:10px 13px; border-top:1px solid var(--hairline); }
.rcpt-line:first-child{ border-top:none; }
.rcpt-ln{ font-size:13px; color:var(--ink); }
.rcpt-lq{ font-family:var(--font-mono); font-size:11px; color:var(--ink-4); min-width:26px; text-align:right; }
.rcpt-lv{ font-family:var(--font-display); font-weight:600; font-size:13px; color:var(--ink); font-variant-numeric:tabular-nums; min-width:62px; text-align:right; }
.rcpt-line.total{ background:rgba(77,159,255,0.08); }
.rcpt-line.total .rcpt-ln{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-3); }
.rcpt-line.total .rcpt-lv{ font-size:15px; }
.rcpt-earn{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:13px 14px; border-radius:var(--r-lg);
  background:rgba(47,224,161,0.1); border:1px solid rgba(47,224,161,0.35); }
.rcpt-earn-l{ display:flex; flex-direction:column; gap:3px; }
.rcpt-earn-k{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.1em; text-transform:uppercase; color:#9ff0cf; }
.rcpt-earn-s{ font-size:11px; color:var(--ink-3); }
.rcpt-earn b{ font-family:var(--font-display); font-weight:600; font-size:21px; color:#2FE0A1; font-variant-numeric:tabular-nums; }

/* ---- order cancel drawer ---- */
.btn-sm.danger{ color:#FF8A9B; border-color:rgba(255,77,94,0.45); background:rgba(255,77,94,0.1); }
.btn-sm.danger:hover{ color:#fff; border-color:rgba(255,77,94,0.7); background:rgba(255,77,94,0.2); }
.ocn{ display:flex; flex-direction:column; gap:8px; }
.ocn-label{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.04em; color:var(--ink-3); }
.ocn-label b{ color:#FF8A9B; font-weight:600; }
.ocn-input{ letter-spacing:0.06em; }
.ocn-input:focus{ border-color:rgba(255,77,94,0.55); }
.ocn-btn{ font-family:var(--font-mono); font-size:12px; letter-spacing:0.1em; text-transform:uppercase; font-weight:600;
  padding:14px; border-radius:var(--r-sm); cursor:pointer; transition:all var(--dur-fast);
  border:1px solid rgba(255,77,94,0.3); background:rgba(255,77,94,0.08); color:rgba(255,138,155,0.5); }
.ocn-btn:disabled{ cursor:not-allowed; }
.ocn-btn.armed{ color:#fff; border-color:rgba(255,77,94,0.6); background:linear-gradient(180deg, rgba(255,77,94,0.42), rgba(255,77,94,0.28)); }
.ocn-btn.armed:active{ transform:translateY(1px); }

/* ---- Chat ▸ Squad · full-screen crew chat ---- */
.sheet.chat-full [data-pane="Squad"]{ flex:1; min-height:0; display:flex; flex-direction:column; }
.sheet.chat-full .sqgc{ flex:1; min-height:0; }
.sheet.chat-full .sqgc-body{ flex:1; max-height:none; }
/* pull the composer down close to the bottom nav instead of leaving a wide gap */
.sheet.chat-full .sheet-body{ padding-bottom:74px; }
.sheet.chat-full .sqgc-composer{ position:sticky; bottom:-2px; padding:8px 0 4px;
  background:linear-gradient(180deg, transparent, rgba(14,12,22,0.72) 34%); }

/* ---- order form · delivery contact (tied to customer) ---- */
.occ{ display:flex; flex-direction:column; padding:11px 13px; border-radius:var(--r-sm);
  background:rgba(16,14,25,0.5); border:1px solid var(--hairline-2); }
.occ-line{ display:flex; justify-content:space-between; align-items:baseline; gap:12px; padding:6px 0; }
.occ-line + .occ-line{ border-top:1px solid var(--hairline); }
.occ-k{ font-family:var(--font-mono); font-size:9px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-4); flex:none; }
.occ-v{ font-size:12.5px; color:var(--ink-2); text-align:right; }
.occ-add{ margin-top:9px; display:flex; align-items:center; gap:9px; width:100%; cursor:pointer; text-align:left;
  font-family:var(--font-mono); font-size:10px; letter-spacing:0.03em; color:#9ec5ff;
  background:transparent; border:1px dashed rgba(77,159,255,0.4); border-radius:var(--r-sm); padding:9px 11px; }
.occ-add:active{ background:rgba(77,159,255,0.08); }
.occ-add.on{ border-style:solid; border-color:rgba(77,159,255,0.55); }
.occ-add-ic{ display:inline-flex; align-items:center; justify-content:center; width:17px; height:17px; border-radius:5px;
  background:rgba(77,159,255,0.18); color:#cfe4ff; font-size:13px; line-height:1; flex:none; }
.occ-oneoff{ margin-top:9px; display:flex; flex-direction:column; gap:6px; }
.occ-hint{ font-family:var(--font-mono); font-size:9px; color:var(--ink-4); line-height:1.4; }

/* ---- order form · multi-select item picker ---- */
.of-itemwrap{ display:flex; flex-direction:column; gap:8px; }
.of-itemslabel{ color:var(--ink-3); }
.of-itemslabel span{ color:var(--ink-2); text-transform:none; letter-spacing:0; }
.oi-list{ display:flex; flex-direction:column; gap:8px; }
.oi-card{ border:1px solid var(--hairline-2); border-radius:var(--r-md); overflow:hidden;
  background:rgba(16,14,25,0.5); transition:border-color var(--dur-fast), box-shadow var(--dur-fast); }
.oi-card.on{ border-color:rgba(47,224,161,0.5); box-shadow:inset 0 0 0 1px rgba(47,224,161,0.16); }
.oi-row{ display:grid; grid-template-columns:auto 1fr auto auto; gap:11px; align-items:center; padding:9px 11px; cursor:pointer; }
.oi-thumb{ position:relative; width:42px; height:42px; border-radius:10px; flex:none; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  background:
    radial-gradient(circle at 30% 25%, color-mix(in oklab, var(--ic) 36%, transparent), transparent 70%),
    repeating-linear-gradient(135deg, rgba(255,255,255,0.05) 0 2px, transparent 2px 6px),
    rgba(11,10,19,0.7);
  border:1px solid color-mix(in oklab, var(--ic) 30%, var(--hairline)); }
.oi-thumb-l{ font-family:var(--font-display); font-weight:700; font-size:13px; color:color-mix(in oklab, var(--ic) 70%, #fff); }
.oi-id{ min-width:0; }
.oi-nm{ font-size:13px; color:var(--ink); font-weight:500; }
.oi-sub{ display:flex; align-items:center; gap:9px; margin-top:3px; }
.oi-price{ font-family:var(--font-mono); font-size:11px; color:var(--ink-2); }
.cc-stars.sm{ font-size:10px; letter-spacing:1.5px; }
.oi-qbadge{ flex:none; min-width:20px; height:20px; padding:0 6px; border-radius:99px;
  background:var(--state-clear); color:#0b0a13; font-family:var(--font-mono); font-size:10px; font-weight:600;
  display:flex; align-items:center; justify-content:center; box-shadow:0 0 10px rgba(47,224,161,0.5); }
.oi-card .cc-chev{ font-size:18px; color:var(--ink-4); line-height:1; transition:transform var(--dur-fast); }
.oi-card.open .cc-chev{ transform:rotate(90deg); color:var(--ink-2); }
.oi-detail{ padding:0 11px 12px; display:flex; flex-direction:column; gap:11px; }
.oi-hero{ position:relative; height:96px; border-radius:var(--r-sm); overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  background:
    radial-gradient(circle at 50% 35%, color-mix(in oklab, var(--ic) 26%, transparent), transparent 70%),
    repeating-linear-gradient(135deg, rgba(255,255,255,0.045) 0 3px, transparent 3px 9px),
    rgba(11,10,19,0.7);
  border:1px solid color-mix(in oklab, var(--ic) 26%, var(--hairline)); }
.oi-hero-l{ font-family:var(--font-display); font-weight:600; font-size:16px; color:color-mix(in oklab, var(--ic) 60%, #fff); }
.oi-hero-tag{ position:absolute; bottom:7px; right:9px; font-family:var(--font-mono); font-size:8px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-4); }
.oi-blurb{ font-size:12px; color:var(--ink-3); line-height:1.45; }
.oi-detrow{ display:flex; align-items:center; justify-content:space-between; }
.oi-price-lg{ font-family:var(--font-display); font-weight:600; font-size:17px; color:var(--ink); }
.oi-step{ display:flex; align-items:center; justify-content:space-between; }
.oi-step-l{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-4); }
.oi-stepper{ display:flex; align-items:center; border:1px solid var(--hairline-3); border-radius:var(--r-pill); overflow:hidden; }
.oi-stepper button{ width:40px; height:34px; border:none; background:rgba(255,255,255,0.03); color:var(--ink-2); font-size:18px; cursor:pointer; display:flex; align-items:center; justify-content:center; }
.oi-stepper button:active{ background:rgba(255,255,255,0.09); color:var(--ink); }
.oi-q{ min-width:36px; text-align:center; font-family:var(--font-mono); font-size:14px; color:var(--ink); font-variant-numeric:tabular-nums; }

/* keep the hidden attribute authoritative over display:flex/grid above */
.occ-oneoff[hidden], .oi-detail[hidden], .oi-qbadge[hidden]{ display:none !important; }

/* of-total · two-line layout + item count */
.of-total-l{ display:flex; flex-direction:column; gap:3px; align-items:flex-start; }
.of-total-sub{ font-family:var(--font-mono); font-size:9px !important; letter-spacing:0.1em !important; color:var(--ink-4) !important; text-transform:none !important; }

/* HQ suggested-order CTA star */
.sg-cta-ic{ color:var(--gold-bright); margin-right:3px; }

/* ---- chat / comms rows (Chat tab) ---- */
.chat-row{ display:grid; grid-template-columns:auto 1fr; gap:11px; align-items:center;
  padding:11px 2px; border-bottom:1px solid var(--hairline); cursor:pointer; }
.chat-row:last-child{ border-bottom:none; }
.chat-row:active{ background:rgba(255,255,255,0.03); }
.twl-live-chat-row{ width:100%; border:0; background:transparent; text-align:left; font:inherit; color:inherit; }
.chat-av{ position:relative; width:40px; height:40px; border-radius:12px; overflow:hidden; flex:none;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:700; font-size:14px; letter-spacing:0.02em;
  background:var(--graphite); }
.chat-av img{ width:100%; height:100%; object-fit:cover; }
.chat-av .on-dot{ position:absolute; right:-1px; bottom:-1px; width:11px; height:11px; border-radius:99px;
  background:var(--state-clear); border:2px solid #100e19; box-shadow:0 0 6px var(--state-clear); }
.chat-main{ min-width:0; }
.chat-top{ display:flex; align-items:baseline; justify-content:space-between; gap:8px; }
.chat-nm{ font-weight:600; font-size:13.5px; color:var(--ink); }
.chat-time{ font-family:var(--font-mono); font-size:10px; color:var(--ink-4); flex:none; }
.chat-bot{ display:flex; align-items:center; justify-content:space-between; gap:8px; margin-top:3px; }
.chat-msg{ font-size:12px; color:var(--ink-3); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.chat-unread{ flex:none; min-width:18px; height:18px; padding:0 5px; border-radius:99px;
  background:var(--ultraviolet); color:#0b0a13; font-family:var(--font-mono); font-size:10px; font-weight:600;
  display:flex; align-items:center; justify-content:center; box-shadow:0 0 10px rgba(192,132,252,0.55); }
.chat-receipt{ flex:none; font-size:11px; color:var(--state-clear); letter-spacing:-1px; }

/* ---- empty state ---- */
.m-empty{ display:flex; flex-direction:column; align-items:center; gap:9px; text-align:center;
  padding:38px 20px; color:var(--ink-4); font-size:12.5px; }
.m-empty-ic{ font-size:30px; color:var(--ink-4); opacity:0.7; }

/* ---- contacts · expandable customer-intelligence cards ---- */
.contact-list{ display:flex; flex-direction:column; gap:8px; }
.contact-card{ border:1px solid var(--hairline-2); border-radius:var(--r-md);
  background:linear-gradient(180deg, rgba(37,31,51,0.5), rgba(22,19,31,0.46));
  overflow:hidden; transition:border-color var(--dur-fast); }
.contact-card.open{ border-color:var(--hairline-3); }
.cc-row{ display:grid; grid-template-columns:1fr auto auto; align-items:center; gap:10px;
  padding:12px 13px; cursor:pointer; }
.cc-row:active{ background:rgba(255,255,255,0.02); }
.cc-id{ min-width:0; }
.cc-id .nm{ font-weight:600; font-size:13.5px; color:var(--ink); }
.cc-id .mut{ font-family:var(--font-mono); font-size:10.5px; color:var(--ink-3); margin-top:2px;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.cc-chev{ display:inline-block; font-size:18px; color:var(--ink-4); line-height:1; transform:rotate(0deg); }
.contact-card.open .cc-chev{ transform:rotate(90deg); color:var(--ink-2); }
.cc-detail{ padding:0 13px 13px; display:none; flex-direction:column; gap:12px;
  border-top:1px solid var(--hairline); margin-top:0; padding-top:12px; }
.contact-card.open .cc-detail{ display:flex; }
.order-card.open .cc-chev{ transform:rotate(90deg); color:var(--ink-2); }
.camp-card.open .cc-chev{ transform:rotate(90deg); color:var(--ink-2); }
.registry .dtabs{ margin-bottom:12px; }
.cc-rating{ display:flex; align-items:center; gap:9px; }
.cc-stars{ position:relative; display:inline-block; font-size:15px; letter-spacing:2px; line-height:1; }
.cc-stars-bg{ color:var(--graphite); }
.cc-stars-fg{ position:absolute; left:0; top:0; overflow:hidden; white-space:nowrap; color:var(--gold-bright); }
.cc-rating .cc-stars-bg{ color:var(--graphite); }
.cc-rating .cc-stars-fg{ color:var(--gold-bright); }
.cc-rating b{ font-family:var(--font-display); font-weight:600; font-size:16px; color:var(--ink); }
.cc-rating span{ font-family:var(--font-mono); font-size:10px; color:var(--ink-4); }
.cc-metrics{ display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.cc-m{ background:rgba(16,14,25,0.5); border:1px solid var(--hairline); border-radius:var(--r-sm); padding:9px 11px; }
.cc-k{ display:block; font-family:var(--font-mono); font-size:8.5px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-4); }
.cc-v{ display:block; font-size:13px; color:var(--ink); font-weight:500; margin-top:3px; }
.cc-v.gold{ color:var(--gold-bright); font-family:var(--font-display); font-weight:600; }
.cc-cravings .cc-k{ margin-bottom:7px; }
.cc-chips{ display:flex; flex-wrap:wrap; gap:6px; }
.cc-chips span{ font-family:var(--font-mono); font-size:10.5px; color:var(--ink-2);
  background:rgba(168,85,247,0.1); border:1px solid rgba(168,85,247,0.28); border-radius:var(--r-pill); padding:4px 10px; }
.cc-chips .cc-none{ background:transparent; border:none; color:var(--ink-4); padding:0; }

/* ---- orders · expandable live / legacy transit cards ---- */
.order-list{ display:flex; flex-direction:column; gap:8px; }
.order-card{ border:1px solid var(--hairline-2); border-radius:var(--r-md);
  background:linear-gradient(180deg, rgba(37,31,51,0.5), rgba(22,19,31,0.46)); overflow:hidden; }
.order-card.legacy{ background:linear-gradient(180deg, rgba(26,28,30,0.5), rgba(18,20,22,0.46)); }
.order-card.open{ border-color:var(--hairline-3); }
.oc-row{ display:grid; grid-template-columns:1fr auto auto; align-items:center; gap:10px; padding:12px 13px; cursor:pointer; }
.oc-row:active{ background:rgba(255,255,255,0.02); }
.oc-id{ min-width:0; }
.oc-id .nm{ font-family:var(--font-mono); font-weight:600; font-size:13px; color:var(--ink); }
.oc-id .mut{ font-size:11px; color:var(--ink-3); margin-top:3px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.oc-detail{ display:none; flex-direction:column; gap:12px; padding:12px 13px 13px; border-top:1px solid var(--hairline); }
.order-card.open .oc-detail{ display:flex; }
.oc-badge{ display:inline-flex; align-items:center; gap:7px; align-self:flex-start;
  font-family:var(--font-mono); font-size:9px; letter-spacing:0.12em; text-transform:uppercase; padding:4px 10px; border-radius:var(--r-pill); }
.oc-badge .d{ width:6px; height:6px; border-radius:99px; background:currentColor; box-shadow:0 0 7px currentColor; }
.oc-badge.live{ color:#4D9FFF; background:rgba(77,159,255,0.1); border:1px solid rgba(77,159,255,0.3); }
.oc-badge.legacy{ color:var(--state-clear); background:rgba(47,224,161,0.08); border:1px solid rgba(47,224,161,0.28); }
.oc-route-top{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:6px; }
.oc-pct{ font-family:var(--font-mono); font-size:11px; color:var(--ink-2); }
.oc-timeline{ display:flex; justify-content:space-between; position:relative; padding:2px 0 0; }
.oc-timeline::before{ content:""; position:absolute; left:7%; right:7%; top:7px; height:1.5px; background:var(--hairline-2); }
.oc-stage{ display:flex; flex-direction:column; align-items:center; gap:7px; flex:1; position:relative; z-index:1; }
.oc-dot{ width:11px; height:11px; border-radius:99px; background:var(--graphite); border:1.5px solid var(--hairline-3); }
.oc-stage.done .oc-dot{ background:var(--state-clear); border-color:var(--state-clear); box-shadow:0 0 7px var(--state-clear); }
.oc-stage.now .oc-dot{ background:#4D9FFF; border-color:#4D9FFF; box-shadow:0 0 9px #4D9FFF; }
.oc-st{ font-family:var(--font-mono); font-size:8px; letter-spacing:0.04em; text-transform:uppercase; color:var(--ink-4); text-align:center; }
.oc-stage.done .oc-st, .oc-stage.now .oc-st{ color:var(--ink-2); }
.oc-flag{ font-size:11.5px; color:#FF8088; background:rgba(255,77,94,0.08); border:1px solid rgba(255,77,94,0.28); border-radius:var(--r-sm); padding:8px 10px; }
.oc-proof{ display:flex; justify-content:space-between; align-items:center; gap:8px; }
.oc-proof-v{ font-family:var(--font-mono); font-size:11px; color:var(--ink-2); }

/* ---- rewards vault (draw from Orders) ---- */
.reward-hero{ position:relative; flex:none; overflow:hidden; border-radius:var(--r-lg); padding:18px 17px 17px;
  border:1px solid rgba(245,181,68,0.42);
  background:linear-gradient(158deg, rgba(245,181,68,0.20), rgba(40,33,56,0.5) 52%, rgba(22,19,31,0.5));
  box-shadow:0 18px 50px rgba(0,0,0,0.45), inset 0 0 30px rgba(245,181,68,0.05); }
.rh-glow{ position:absolute; top:-45%; right:-22%; width:240px; height:240px; border-radius:50%;
  background:radial-gradient(circle, rgba(245,181,68,0.38), transparent 65%); pointer-events:none;
  animation:rhPulse 4.2s var(--ease-inout) infinite; }
@keyframes rhPulse{ 0%,100%{opacity:.55;transform:scale(1)} 50%{opacity:1;transform:scale(1.12)} }
.rh-top{ display:flex; justify-content:space-between; align-items:center; position:relative; z-index:1; }
.rh-eyebrow{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:0.16em; text-transform:uppercase; color:var(--gold-bright); }
.rh-gem{ font-size:18px; color:var(--gold-bright); text-shadow:0 0 14px rgba(245,181,68,0.85); }
.rh-title{ font-family:var(--font-display); font-weight:700; font-size:26px; color:var(--ink); margin:9px 0 13px; position:relative; z-index:1; }
.rh-chips{ display:grid; grid-template-columns:repeat(4,1fr); gap:7px; position:relative; z-index:1; }
.rh-chip{ background:rgba(11,10,19,0.5); border:1px solid rgba(245,181,68,0.25); border-radius:var(--r-sm); padding:8px 5px; text-align:center; }
.rh-chip .rk{ display:block; font-family:var(--font-mono); font-size:8px; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-4); }
.rh-chip .rv{ display:block; font-family:var(--font-display); font-weight:600; font-size:13px; color:var(--gold-bright); margin-top:3px; }
.rh-prog-row{ display:flex; justify-content:space-between; font-family:var(--font-mono); font-size:10px; color:var(--ink-2); margin:15px 0 6px; position:relative; z-index:1; }
.rh-togo{ color:var(--ink-4); }
.rh-prog{ height:8px; border-radius:99px; background:rgba(11,10,19,0.6); overflow:hidden; position:relative; z-index:1; }
.rh-prog > i{ display:block; height:100%; border-radius:99px; background:linear-gradient(90deg,#F5B544,#FFE3A0); box-shadow:0 0 12px rgba(245,181,68,0.7); }
.rh-claim{ width:100%; margin-top:14px; padding:13px; border-radius:var(--r-sm); cursor:pointer; position:relative; z-index:1;
  font-family:var(--font-mono); font-size:11px; letter-spacing:0.1em; text-transform:uppercase; font-weight:600;
  border:1px solid rgba(245,181,68,0.5); background:linear-gradient(180deg, rgba(245,181,68,0.24), rgba(245,181,68,0.1)); color:#FFE3A0; }
.rh-claim:active{ transform:translateY(1px); }

.reward-grid{ display:grid; grid-template-columns:1fr 1fr; gap:9px; }
.reward-card{ border:1px solid var(--hairline-2); border-top:2px solid var(--rc); border-radius:var(--r-md); padding:12px;
  background:linear-gradient(180deg, rgba(37,31,51,0.5), rgba(22,19,31,0.46)); }
.rc-top{ display:flex; justify-content:space-between; align-items:center; }
.rc-glyph{ font-size:14px; color:var(--rc); text-shadow:0 0 10px var(--rc); }
.rc-tier{ font-family:var(--font-mono); font-size:8px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-4); }
.rc-name{ font-family:var(--font-display); font-weight:600; font-size:14px; color:var(--ink); margin:9px 0 3px; }
.rc-value{ font-family:var(--font-mono); font-size:11px; color:var(--rc); margin-bottom:9px; }
.rc-prog{ height:5px; border-radius:99px; background:var(--graphite); overflow:hidden; }
.rc-prog > i{ display:block; height:100%; border-radius:99px; background:var(--rc); }
.rc-pct{ font-family:var(--font-mono); font-size:9.5px; color:var(--ink-3); margin-top:5px; text-align:right; }

.earned-row{ display:flex; align-items:center; padding-left:8px; }
.earned-av{ position:relative; width:38px; height:38px; margin-left:-9px; }
.earned-av img{ width:100%; height:100%; border-radius:50%; object-fit:cover; border:2px solid #100e19; box-shadow:0 0 0 1.5px rgba(245,181,68,0.5); }
.earned-check{ position:absolute; right:-2px; bottom:-2px; width:15px; height:15px; border-radius:50%;
  background:var(--state-clear); color:#06231a; font-size:9px; font-weight:700; border:2px solid #100e19;
  display:flex; align-items:center; justify-content:center; }
.earned-more{ margin-left:12px; font-family:var(--font-mono); font-size:11px; color:var(--ink-3); }

.hist-av{ width:28px; height:28px; border-radius:8px; overflow:hidden; display:inline-block; }
.hist-av img{ width:100%; height:100%; object-fit:cover; }
.hist-val{ font-family:var(--font-mono); font-size:12px; color:var(--gold-bright); }

/* ---- campaigns · hero + expandable tier cards ---- */
.camp-pane{ display:flex; flex-direction:column; gap:10px; }
.camp-pane[hidden]{ display:none; }
.camp-card{ flex:none; border:1px solid var(--hairline-2); border-radius:var(--r-md); overflow:hidden;
  background:linear-gradient(180deg, rgba(37,31,51,0.5), rgba(22,19,31,0.46)); }
.camp-card.open{ border-color:var(--hairline-3); }
.camp-small{ border-top:2px solid var(--rc); }
/* hero (most valuable) */
.camp-hero{ border-color:rgba(245,181,68,0.42);
  background:linear-gradient(158deg, rgba(245,181,68,0.16), rgba(40,33,56,0.5) 54%, rgba(22,19,31,0.5));
  box-shadow:0 14px 40px rgba(0,0,0,0.4), inset 0 0 28px rgba(245,181,68,0.05); }
.ch-row{ position:relative; overflow:hidden; padding:16px 15px 15px; cursor:pointer; }
.ch-head{ display:flex; justify-content:space-between; align-items:center; position:relative; z-index:1; }
.ch-badge{ font-family:var(--font-mono); font-size:8.5px; letter-spacing:0.1em; text-transform:uppercase;
  padding:4px 9px; border:1px solid; border-radius:var(--r-pill); background:rgba(11,10,19,0.4); }
.ch-title{ font-family:var(--font-display); font-weight:700; font-size:21px; color:var(--ink); margin:11px 0 4px; position:relative; z-index:1; }
.ch-desc{ font-size:12.5px; color:var(--ink-2); margin-bottom:11px; position:relative; z-index:1; }
.ch-stars{ display:flex; align-items:center; gap:8px; margin-bottom:12px; position:relative; z-index:1; }
.ch-diff-l{ font-family:var(--font-mono); font-size:9px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-4); }
.camp-hero .rh-chips{ margin-bottom:0; }
/* small tier cards */
.cs-row{ display:grid; grid-template-columns:1fr auto; align-items:center; gap:10px; padding:16px 16px; cursor:pointer; }
.cs-main{ min-width:0; }
.cs-top{ display:flex; justify-content:space-between; align-items:baseline; gap:8px; }
.cs-name{ font-family:var(--font-display); font-weight:600; font-size:16.5px; color:var(--ink); }
.cs-xp{ font-family:var(--font-mono); font-size:12px; color:var(--gold-bright); flex:none; }
.cs-desc{ font-size:13px; color:var(--ink-3); margin:5px 0 11px; line-height:1.4; }
.cs-stars{ display:flex; align-items:center; justify-content:space-between; margin-bottom:9px; }
.cs-stars .cc-stars{ font-size:15px; }
.cs-pct{ font-family:var(--font-mono); font-size:11px; color:var(--ink-3); }
.cs-prog{ height:7px; border-radius:99px; background:var(--graphite); overflow:hidden; }
.cs-prog > i{ display:block; height:100%; border-radius:99px; }
/* shared detail */
.camp-detail{ display:none; flex-direction:column; gap:12px; padding:0 15px 14px; border-top:1px solid var(--hairline); padding-top:12px; }
.camp-card.open .camp-detail{ display:flex; }
.cd-metrics{ display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.cd-stand-top{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:6px; }
.cd-reqs .cc-k{ display:block; margin-bottom:6px; }
.req{ display:flex; align-items:center; gap:10px; padding:7px 0; border-bottom:1px solid var(--hairline); font-size:12.5px; color:var(--ink-3); }
.req:last-child{ border-bottom:none; }
.req-box{ width:18px; height:18px; border-radius:5px; border:1.5px solid var(--hairline-3); flex:none;
  display:flex; align-items:center; justify-content:center; font-size:11px; color:transparent; }
.req.on .req-box{ background:var(--state-clear); border-color:var(--state-clear); color:#06231a; font-weight:700; }
.req.on .req-t{ color:var(--ink); }
.cd-agents .cc-k{ display:block; margin-bottom:8px; }

/* ---- chat thread draw (platform tabs + conversation) ---- */
.thread{ display:flex; flex-direction:column; gap:12px; min-height:100%; }
.plat-tabs{ position:sticky; top:0; z-index:3; flex-wrap:nowrap; padding:6px 0; background:linear-gradient(180deg, rgba(14,12,22,0.9), rgba(14,12,22,0.55)); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px); }
.plat-tabs .dtab{ flex:1; text-align:center; }
.plat-tabs .dtab.on{ color:var(--pc); border-color:var(--pc); background:rgba(255,255,255,0.05); box-shadow:0 0 12px -4px var(--pc); }
.thread-body{ display:flex; flex-direction:column; flex:1; padding-bottom:98px; }
.thread-pane{ display:flex; flex-direction:column; gap:9px; }
.thread-pane[hidden]{ display:none; }
.plat-note{ align-self:center; font-family:var(--font-mono); font-size:9px; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--pc); background:rgba(255,255,255,0.03); border:1px solid var(--hairline); border-radius:var(--r-pill); padding:4px 11px; margin-bottom:4px; }
.msg{ display:flex; flex-direction:column; max-width:82%; }
.msg.in{ align-self:flex-start; align-items:flex-start; }
.msg.out{ align-self:flex-end; align-items:flex-end; }
.bub{ padding:9px 12px; border-radius:14px; font-size:13px; line-height:1.42; }
.msg.in .bub{ background:rgba(40,33,56,0.7); border:1px solid var(--hairline-2); color:var(--ink); border-bottom-left-radius:4px; }
.msg.out .bub{ background:linear-gradient(180deg, rgba(168,85,247,0.34), rgba(168,85,247,0.2)); border:1px solid rgba(168,85,247,0.42); color:#fff; border-bottom-right-radius:4px; }
.msg-t{ font-family:var(--font-mono); font-size:9px; color:var(--ink-4); margin-top:3px; padding:0 4px; }
.msg-t .rcpt{ color:var(--state-clear); }
.composer{ position:sticky; bottom:-2px; display:flex; gap:8px; padding:10px 0 6px; margin-top:auto;
  background:linear-gradient(180deg, transparent, rgba(14,12,22,0.72) 32%); }
.composer-in{ flex:1; box-sizing:border-box; font-family:var(--font-ui); font-size:14px; color:var(--ink);
  background:rgba(16,14,25,0.78); border:1px solid var(--hairline-2); border-radius:var(--r-pill); padding:11px 15px; outline:none; }
.composer-in:focus{ border-color:var(--hairline-3); }
.composer-in::placeholder{ color:var(--ink-4); }
.composer-send{ flex:none; width:42px; height:42px; border-radius:50%; border:1px solid rgba(168,85,247,0.5);
  background:rgba(168,85,247,0.22); color:#E9D5FF; font-size:15px; cursor:pointer; display:flex; align-items:center; justify-content:center; }
.composer-send:active{ transform:scale(0.94); }

/* ---- broadcast composer (Chat · Broadcast tab) ---- */
.bc{ display:flex; flex-direction:column; gap:17px; }
.bc-block{ display:flex; flex-direction:column; gap:9px; }
.bc-block .sect-label{ margin-bottom:0; }
.bc-head{ display:flex; align-items:center; justify-content:space-between; }
.bc-all{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:0.08em; text-transform:uppercase;
  padding:5px 12px; border-radius:var(--r-pill); cursor:pointer; transition:all var(--dur-fast);
  border:1px solid var(--hairline-2); background:var(--panel); color:var(--ink-3); }
.bc-all:active{ transform:scale(0.96); }
.bc-all.on{ color:#0b0a13; background:var(--state-clear); border-color:var(--state-clear); box-shadow:0 0 12px -3px var(--state-clear); }

.bc-recips{ display:flex; flex-direction:column; gap:6px; max-height:214px; overflow-y:auto; padding-right:2px; scrollbar-width:none; }
.bc-recips::-webkit-scrollbar{ width:0; }
.bc-recip{ display:grid; grid-template-columns:auto auto 1fr; gap:10px; align-items:center; text-align:left;
  padding:8px 11px; border-radius:var(--r-sm); cursor:pointer; transition:all var(--dur-fast);
  border:1px solid var(--hairline-2); background:rgba(16,14,25,0.5); }
.bc-recip:active{ background:rgba(255,255,255,0.04); }
.bc-recip.on{ border-color:rgba(47,224,161,0.5); background:rgba(47,224,161,0.08); }
.bc-check{ position:relative; width:19px; height:19px; border-radius:6px; flex:none;
  border:1.5px solid var(--hairline-3); transition:all var(--dur-fast); }
.bc-recip.on .bc-check{ background:var(--state-clear); border-color:var(--state-clear); }
.bc-recip.on .bc-check::after{ content:"\2713"; position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:700; color:#0b0a13; }
.bc-rec-av{ width:30px; height:30px; border-radius:9px; flex:none; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:700; font-size:11px; color:#0b0a13; }
.bc-rec-nm{ font-size:13px; color:var(--ink); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

.bc-greets{ display:flex; flex-direction:column; gap:6px; }
.bc-greet{ text-align:left; font-family:var(--font-ui); font-size:12.5px; line-height:1.4; color:var(--ink-2);
  padding:10px 13px; border-radius:var(--r-sm); cursor:pointer; transition:all var(--dur-fast);
  border:1px solid var(--hairline-2); background:rgba(16,14,25,0.5); }
.bc-greet:active{ background:rgba(255,255,255,0.04); }
.bc-greet.on{ border-color:rgba(47,224,161,0.5); background:rgba(47,224,161,0.08); color:var(--ink); }

.bc-items{ display:flex; flex-wrap:wrap; gap:7px; }
.bc-item{ display:flex; align-items:center; gap:9px; padding:6px 12px 6px 6px; border-radius:var(--r-pill);
  cursor:pointer; transition:all var(--dur-fast); border:1px solid var(--hairline-2); background:rgba(16,14,25,0.5); }
.bc-item:active{ transform:scale(0.97); }
.bc-item.on{ border-color:rgba(47,224,161,0.5); background:rgba(47,224,161,0.1); }
.bc-it-thumb{ width:26px; height:26px; border-radius:8px; flex:none; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:700; font-size:10px; color:color-mix(in oklab, var(--ic) 72%, #fff);
  background:radial-gradient(circle at 30% 25%, color-mix(in oklab, var(--ic) 36%, transparent), transparent 70%), rgba(11,10,19,0.7);
  border:1px solid color-mix(in oklab, var(--ic) 30%, var(--hairline)); }
.bc-it-id{ display:flex; flex-direction:column; gap:1px; }
.bc-it-nm{ font-size:12px; color:var(--ink); }
.bc-it-pr{ font-family:var(--font-mono); font-size:9.5px; color:var(--ink-3); }
.bc-it-add{ width:18px; height:18px; border-radius:99px; flex:none; display:flex; align-items:center; justify-content:center;
  font-size:14px; line-height:1; color:var(--ink-3); border:1px solid var(--hairline-3); transition:all var(--dur-fast); }
.bc-item.on .bc-it-add{ font-size:0; background:var(--state-clear); border-color:var(--state-clear); }
.bc-item.on .bc-it-add::before{ content:"\2713"; font-size:11px; font-weight:700; color:#0b0a13; }

.bc-msg{ box-sizing:border-box; width:100%; resize:vertical; min-height:128px;
  font-family:var(--font-ui); font-size:13px; line-height:1.55; color:var(--ink); white-space:pre-wrap;
  background:rgba(16,14,25,0.7); border:1px solid var(--hairline-2); border-radius:var(--r-sm); padding:12px 14px; outline:none; }
.bc-msg:focus{ border-color:var(--hairline-3); }
.bc-msg::placeholder{ color:var(--ink-4); }

.bc-send{ font-family:var(--font-mono); font-size:12px; letter-spacing:0.1em; text-transform:uppercase; font-weight:600;
  padding:14px; border-radius:var(--r-sm); cursor:pointer; transition:all var(--dur-fast);
  border:1px solid rgba(47,224,161,0.5); background:rgba(47,224,161,0.16); color:#bff4df; }
.bc-send:hover{ background:rgba(47,224,161,0.26); color:#fff; }
.bc-send:active{ transform:translateY(1px); }
.bc-send:disabled{ opacity:0.45; cursor:not-allowed; border-color:var(--hairline-2); background:var(--panel-2); color:var(--ink-4); box-shadow:none; }

/* ---- ocean ship → supplier category MENU (view-only draw) ---- */
.menu-port{ display:flex; align-items:center; gap:9px; padding:9px 12px; border-radius:var(--r-pill);
  background:rgba(34,211,238,0.08); border:1px solid rgba(34,211,238,0.28); }
.menu-port-ic{ font-size:15px; color:#22D3EE; line-height:1; }
.menu-port-t{ flex:1; font-family:var(--font-mono); font-size:10px; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-2); }
.menu-viewonly{ font-family:var(--font-mono); font-size:8.5px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-4);
  padding:3px 9px; border-radius:var(--r-pill); border:1px solid var(--hairline-2); }

.menu-summary{ display:grid; grid-template-columns:repeat(3,1fr); gap:8px; }
.menu-sum{ display:flex; flex-direction:column; gap:3px; padding:11px 12px; border-radius:var(--r-md);
  background:rgba(16,14,25,0.5); border:1px solid var(--hairline-2); }
.menu-sum-k{ font-family:var(--font-mono); font-size:9px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-4); }
.menu-sum-v{ font-family:var(--font-display); font-weight:600; font-size:18px; color:var(--ink); font-variant-numeric:tabular-nums; }

.menu-feat{ border:1px solid color-mix(in oklab, var(--ic) 32%, var(--hairline)); border-radius:var(--r-lg); overflow:hidden; background:rgba(16,14,25,0.5); }
.mf-img{ position:relative; height:152px; display:flex; align-items:center; justify-content:center; text-align:center; padding:0 16px;
  background:
    radial-gradient(circle at 50% 30%, color-mix(in oklab, var(--ic) 30%, transparent), transparent 72%),
    repeating-linear-gradient(135deg, rgba(255,255,255,0.05) 0 3px, transparent 3px 10px),
    rgba(11,10,19,0.72);
  border-bottom:1px solid color-mix(in oklab, var(--ic) 24%, var(--hairline)); }
.mf-img-l{ font-family:var(--font-display); font-weight:600; font-size:21px; letter-spacing:0.01em; color:color-mix(in oklab, var(--ic) 56%, #fff); }
.mf-img-tag{ position:absolute; bottom:9px; right:11px; font-family:var(--font-mono); font-size:8px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-4); }
.mf-badge{ position:absolute; top:11px; left:11px; font-family:var(--font-mono); font-size:9px; letter-spacing:0.08em; text-transform:uppercase; font-weight:600;
  color:#0b0a13; background:var(--ic); padding:5px 11px; border-radius:var(--r-pill); box-shadow:0 0 16px -2px var(--ic); }
.mf-body{ padding:13px 14px 15px; display:flex; flex-direction:column; gap:9px; }
.mf-row{ display:flex; align-items:baseline; justify-content:space-between; gap:10px; }
.mf-nm{ font-family:var(--font-display); font-weight:600; font-size:18px; color:var(--ink); }
.mf-price{ font-family:var(--font-display); font-weight:600; font-size:18px; color:color-mix(in oklab, var(--ic) 60%, #fff); font-variant-numeric:tabular-nums; }
.mf-blurb{ font-size:12.5px; color:var(--ink-3); line-height:1.45; }
.mf-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-top:2px; }
.mf-supplier{ display:flex; align-items:center; gap:6px; font-size:11.5px; color:var(--ink-3); margin-top:-2px; }
.mf-supplier b{ color:color-mix(in oklab, var(--ic) 62%, var(--ink)); font-weight:600; }
.mf-sup-ic{ color:color-mix(in oklab, var(--ic) 70%, #fff); font-size:10px; line-height:1; }
.mi-sup{ display:flex; align-items:center; gap:6px; font-family:var(--font-mono); font-size:10px; color:var(--ink-3); }
.mi-sup .mf-sup-ic{ color:color-mix(in oklab, var(--ic) 70%, #fff); }
.mf-stat{ display:flex; flex-direction:column; gap:2px; padding:9px 10px; border-radius:var(--r-sm); background:rgba(255,255,255,0.03); border:1px solid var(--hairline); }
.mf-stat-k{ font-family:var(--font-mono); font-size:8.5px; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-4); }
.mf-stat-v{ font-family:var(--font-display); font-weight:600; font-size:15px; color:var(--ink); font-variant-numeric:tabular-nums; }

.menu-list{ display:flex; flex-direction:column; gap:9px; }
.menu-item{ display:grid; grid-template-columns:auto 1fr; gap:12px; align-items:center; padding:10px;
  border-radius:var(--r-md); background:rgba(16,14,25,0.5); border:1px solid color-mix(in oklab, var(--ic) 20%, var(--hairline-2)); }
.mi-thumb{ position:relative; width:64px; height:64px; border-radius:12px; flex:none; overflow:hidden; display:flex; align-items:center; justify-content:center;
  background:
    radial-gradient(circle at 30% 25%, color-mix(in oklab, var(--ic) 34%, transparent), transparent 70%),
    repeating-linear-gradient(135deg, rgba(255,255,255,0.05) 0 2px, transparent 2px 7px),
    rgba(11,10,19,0.7);
  border:1px solid color-mix(in oklab, var(--ic) 28%, var(--hairline)); }
.mi-thumb-l{ font-family:var(--font-display); font-weight:700; font-size:16px; color:color-mix(in oklab, var(--ic) 66%, #fff); }
.mi-rank{ position:absolute; top:4px; left:5px; font-family:var(--font-mono); font-size:8px; font-weight:600; color:var(--ink-2);
  background:rgba(8,7,14,0.72); padding:2px 5px; border-radius:99px; }
.mi-thumb-tag{ position:absolute; bottom:4px; right:5px; font-family:var(--font-mono); font-size:6.5px; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-4); }
.mi-main{ min-width:0; display:flex; flex-direction:column; gap:5px; }
.mi-top{ display:flex; align-items:baseline; justify-content:space-between; gap:10px; }
.mi-nm{ font-size:14px; font-weight:500; color:var(--ink); }
.mi-price{ font-family:var(--font-mono); font-size:12px; color:color-mix(in oklab, var(--ic) 55%, #fff); }
.mi-stars{ display:flex; align-items:center; gap:7px; }
.mi-rate{ font-family:var(--font-mono); font-size:10px; color:var(--ink-3); }
.mi-pills{ display:flex; flex-wrap:wrap; gap:5px; }
.mi-pill{ font-family:var(--font-mono); font-size:9px; letter-spacing:0.03em; color:var(--ink-3);
  padding:3px 8px; border-radius:var(--r-pill); background:rgba(255,255,255,0.04); border:1px solid var(--hairline); }

/* ---- warehouse FULFILMENT SITE (manager header + crew · view-only) ---- */
.wh-head{ flex:none; border:1px solid color-mix(in oklab, var(--wc) 30%, var(--hairline)); border-radius:var(--r-lg); overflow:hidden;
  background:linear-gradient(180deg, color-mix(in oklab, var(--wc) 11%, rgba(16,14,25,0.6)), rgba(16,14,25,0.5)); }
.wh-mgr{ display:grid; grid-template-columns:auto 1fr; gap:13px; padding:14px 14px 12px; }
.wh-mgr-av{ position:relative; width:62px; height:62px; border-radius:14px; overflow:hidden; flex:none;
  border:1px solid color-mix(in oklab, var(--wc) 42%, var(--hairline)); box-shadow:0 0 20px -7px var(--wc); }
.wh-mgr-av img{ width:100%; height:100%; object-fit:cover; }
.wh-mgr-crown{ position:absolute; top:-3px; right:-3px; width:20px; height:20px; border-radius:99px; display:flex; align-items:center; justify-content:center;
  font-size:10px; color:#1a1405; background:#ECD08A; box-shadow:0 0 10px -2px #ECD08A; }
.wh-mgr-id{ min-width:0; display:flex; flex-direction:column; gap:4px; }
.wh-mgr-role{ font-family:var(--font-mono); font-size:9px; letter-spacing:0.1em; text-transform:uppercase; color:color-mix(in oklab, var(--wc) 55%, #fff); }
.wh-mgr-nm{ font-family:var(--font-display); font-weight:600; font-size:18px; color:var(--ink); line-height:1.1; }
.wh-mgr-rating{ display:flex; align-items:center; gap:7px; margin-top:1px; }
.wh-mgr-rating b{ font-family:var(--font-display); font-weight:600; font-size:13px; color:var(--ink); }
.wh-mgr-rating span{ font-family:var(--font-mono); font-size:8.5px; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-4); }

.ws-econ{ display:flex; gap:8px; margin-top:4px; }
.ws-e{ display:flex; flex-direction:column; gap:1px; padding:6px 10px; border-radius:var(--r-sm); background:rgba(255,255,255,0.03); border:1px solid var(--hairline); }
.ws-k{ font-family:var(--font-mono); font-size:8px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-4); }
.ws-v{ font-family:var(--font-mono); font-size:12px; color:var(--ink); font-variant-numeric:tabular-nums; }

.wh-mgr-chat{ align-self:flex-start; display:inline-flex; align-items:center; gap:7px; margin-top:7px; cursor:pointer;
  font-family:var(--font-mono); font-size:10px; letter-spacing:0.06em; text-transform:uppercase; font-weight:600;
  padding:8px 13px; border-radius:var(--r-pill); transition:all var(--dur-fast);
  border:1px solid rgba(47,224,161,0.5); background:rgba(47,224,161,0.14); color:#bff4df; }
.wh-mgr-chat:hover{ background:rgba(47,224,161,0.24); color:#fff; }
.wh-mgr-chat:active{ transform:scale(0.97); }
.wh-chat-ic{ font-size:12px; line-height:1; }

.wh-info{ padding:0 14px 14px; display:flex; flex-direction:column; gap:11px; }
.wh-info-tags{ display:flex; flex-wrap:wrap; gap:6px; }
.wh-chip{ font-family:var(--font-mono); font-size:9px; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-3);
  padding:4px 9px; border-radius:var(--r-pill); background:rgba(255,255,255,0.03); border:1px solid var(--hairline-2); }
.wh-chip.on{ color:#cfe4ff; background:color-mix(in oklab, var(--wc) 16%, transparent); border-color:color-mix(in oklab, var(--wc) 45%, transparent); }
.wh-fill{ display:flex; flex-direction:column; gap:6px; }
.wh-fill-top{ display:flex; justify-content:space-between; font-family:var(--font-mono); font-size:9.5px; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-4); }

.wh-crew{ display:flex; flex-direction:column; gap:9px; }
.wh-staff{ display:grid; grid-template-columns:auto 1fr; gap:12px; padding:11px; border-radius:var(--r-md);
  background:rgba(16,14,25,0.5); border:1px solid var(--hairline-2); border-left:2px solid var(--wc); }
.ws-av{ width:48px; height:48px; border-radius:12px; overflow:hidden; flex:none; align-self:flex-start;
  border:1px solid color-mix(in oklab, var(--wc) 34%, var(--hairline)); }
.ws-av img{ width:100%; height:100%; object-fit:cover; }
.ws-id{ min-width:0; display:flex; flex-direction:column; gap:5px; }
.ws-top{ display:flex; align-items:center; gap:9px; }
.ws-nm{ font-size:14px; font-weight:500; color:var(--ink); }
.ws-type{ font-family:var(--font-mono); font-size:9px; letter-spacing:0.05em; text-transform:uppercase; color:#0b0a13;
  background:var(--wc); padding:3px 8px; border-radius:var(--r-pill); white-space:nowrap; }
.ws-house{ display:flex; align-items:center; gap:6px; font-family:var(--font-mono); font-size:10px; color:var(--ink-3); }
.ws-dot{ width:6px; height:6px; border-radius:99px; background:var(--wc); box-shadow:0 0 6px var(--wc); flex:none; }

/* ---- dispatch centre · stock held (view-only) ---- */
.dc-stocklist{ display:flex; flex-direction:column; gap:8px; }
.dc-stock{ display:grid; grid-template-columns:auto 1fr; gap:11px; align-items:center; padding:9px 10px;
  border-radius:var(--r-md); background:rgba(16,14,25,0.5); border:1px solid color-mix(in oklab, var(--ic) 20%, var(--hairline-2)); }
.ds-thumb{ position:relative; width:54px; height:54px; border-radius:11px; flex:none; overflow:hidden; display:flex; align-items:center; justify-content:center;
  background:
    radial-gradient(circle at 30% 25%, color-mix(in oklab, var(--ic) 34%, transparent), transparent 70%),
    repeating-linear-gradient(135deg, rgba(255,255,255,0.05) 0 2px, transparent 2px 7px),
    rgba(11,10,19,0.7);
  border:1px solid color-mix(in oklab, var(--ic) 28%, var(--hairline)); }
.ds-thumb-l{ font-family:var(--font-display); font-weight:700; font-size:14px; color:color-mix(in oklab, var(--ic) 66%, #fff); }
.ds-thumb-tag{ position:absolute; bottom:3px; right:4px; font-family:var(--font-mono); font-size:6px; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-4); }
.ds-main{ min-width:0; display:flex; flex-direction:column; gap:5px; }
.ds-top{ display:flex; align-items:baseline; justify-content:space-between; gap:10px; }
.ds-nm{ font-size:14px; font-weight:500; color:var(--ink); }
.ds-val{ font-family:var(--font-display); font-weight:600; font-size:15px; color:color-mix(in oklab, var(--ic) 58%, #fff); font-variant-numeric:tabular-nums; }
.ds-stars{ display:flex; align-items:center; gap:7px; }
.ds-rate{ font-family:var(--font-mono); font-size:10px; color:var(--ink-3); }
.ds-metrics{ display:flex; flex-wrap:wrap; gap:5px; }
.ds-pill{ font-family:var(--font-mono); font-size:9px; letter-spacing:0.03em; color:var(--ink-3);
  padding:3px 8px; border-radius:var(--r-pill); background:rgba(255,255,255,0.04); border:1px solid var(--hairline); }

/* ---- contact node · large dossier card (intelligence + chat) ---- */
.cd-hero{ flex:none; display:grid; grid-template-columns:auto 1fr; gap:14px; align-items:center; padding:14px;
  border-radius:var(--r-lg); border:1px solid color-mix(in oklab, var(--sc) 26%, var(--hairline));
  background:linear-gradient(180deg, color-mix(in oklab, var(--sc) 10%, rgba(16,14,25,0.6)), rgba(16,14,25,0.5)); }
.cd-av{ position:relative; width:86px; height:86px; border-radius:18px; flex:none; overflow:hidden; display:flex; align-items:center; justify-content:center;
  background:
    radial-gradient(circle at 32% 26%, color-mix(in oklab, var(--cc) 42%, transparent), transparent 70%),
    repeating-linear-gradient(135deg, rgba(255,255,255,0.05) 0 3px, transparent 3px 9px),
    rgba(11,10,19,0.72);
  border:1px solid color-mix(in oklab, var(--cc) 40%, var(--hairline)); box-shadow:0 0 22px -8px var(--cc); }
.cd-av-l{ font-family:var(--font-display); font-weight:700; font-size:27px; color:color-mix(in oklab, var(--cc) 62%, #fff); }
.cd-av-tag{ position:absolute; bottom:6px; left:0; right:0; text-align:center; font-family:var(--font-mono); font-size:6.5px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-4); }
.cd-hero-id{ min-width:0; display:flex; flex-direction:column; gap:6px; }
.cd-name{ font-family:var(--font-display); font-weight:600; font-size:21px; color:var(--ink); line-height:1.1; }
.cd-rating{ display:flex; align-items:center; gap:8px; }
.cd-rating b{ font-family:var(--font-display); font-weight:600; font-size:14px; color:var(--ink); }
.cd-rating span{ font-family:var(--font-mono); font-size:10px; color:var(--ink-4); }
.cd-badges{ display:flex; flex-wrap:wrap; gap:6px; align-items:center; }
.cd-rank{ font-family:var(--font-mono); font-size:9px; letter-spacing:0.04em; text-transform:uppercase; font-weight:600; color:#1a1405; white-space:nowrap;
  background:linear-gradient(180deg,#ECD08A,#D4B062); padding:4px 9px; border-radius:var(--r-pill); }

/* ---- HQ · elite ops dispatcher profile + settings ---- */
.hq-wrap{ display:flex; flex-direction:column; gap:14px; margin-top:-16px; }
.hq-wrap > [data-pane]{ display:flex; flex-direction:column; gap:16px; }
.hq-wrap > [data-pane][hidden]{ display:none; }
.hq-wrap > .dtabs{ position:sticky; top:0; z-index:3; display:flex; gap:4px; flex-wrap:nowrap;
  background:var(--obsidian); padding:11px 16px; margin:0 -16px; border-bottom:1px solid var(--hairline); }
.hq-wrap > .dtabs .dtab{ flex:1; text-align:center; padding:8px 4px; border-radius:var(--r-md); letter-spacing:0.04em; }
.cd-av img{ width:100%; height:100%; object-fit:cover; }
.op-hero .cd-av{ border-radius:18px; }
.op-handle{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.04em; color:var(--ink-3); }
.op-idgrid{ display:flex; flex-direction:column; border:1px solid var(--hairline); border-radius:var(--r-lg); overflow:hidden; }
.op-idrow{ display:flex; justify-content:space-between; gap:12px; padding:11px 13px; border-top:1px solid var(--hairline); }
.op-idrow:first-child{ border-top:none; }
.op-idk{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.04em; text-transform:uppercase; color:var(--ink-4); }
.op-idv{ font-size:12.5px; color:var(--ink); text-align:right; }
.op-chips{ display:flex; flex-wrap:wrap; gap:7px; }
.op-chip{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.03em; color:var(--ink-2); padding:6px 11px; border-radius:var(--r-pill);
  border:1px solid color-mix(in oklab, #A855F7 34%, var(--hairline)); background:color-mix(in oklab, #A855F7 11%, transparent); }
.op-sec{ display:flex; align-items:center; gap:8px; font-family:var(--font-mono); font-size:10px; letter-spacing:0.02em; color:var(--ink-4);
  border:1px dashed var(--hairline-2); border-radius:var(--r-md); padding:10px 12px; }
.op-sec-dot{ width:7px; height:7px; border-radius:50%; background:var(--state-clear); box-shadow:0 0 8px var(--state-clear); flex:none; }
.op-set{ display:flex; flex-direction:column; gap:9px; padding:13px; border:1px solid var(--hairline); border-radius:var(--r-lg); background:rgba(16,14,25,0.4); }
.op-set .oform{ gap:11px; }
.op-tg{ display:flex; align-items:center; justify-content:space-between; gap:12px; width:100%; text-align:left; cursor:pointer;
  background:var(--graphite); border:1px solid var(--hairline); border-radius:var(--r-md); padding:11px 13px; font:inherit; }
.op-tg-tx{ display:flex; flex-direction:column; gap:2px; min-width:0; }
.op-tg-l{ font-size:12.5px; color:var(--ink); }
.op-tg-s{ font-family:var(--font-mono); font-size:9.5px; color:var(--ink-4); }
.op-tg-sw{ position:relative; width:38px; height:22px; border-radius:99px; background:var(--hairline-2); flex:none; transition:background var(--dur-fast); }
.op-tg-sw::after{ content:""; position:absolute; top:2px; left:2px; width:18px; height:18px; border-radius:50%; background:#0b0a13; transition:transform var(--dur-fast); }
.op-tg.on .op-tg-sw{ background:linear-gradient(180deg,#B36BFF,#A855F7); }
.op-tg.on .op-tg-sw::after{ transform:translateX(16px); background:#fff; }
.op-verify{ display:flex; gap:8px; align-items:flex-start; font-family:var(--font-mono); font-size:9.5px; line-height:1.5; color:var(--ink-4);
  border-left:2px solid color-mix(in oklab,#A855F7 50%,transparent); padding:2px 0 2px 10px; }

/* ---- HQ · Rings trophy room ---- */
/* Profile teaser */
.op-troph{ display:flex; flex-direction:column; gap:11px; }
.troph-head{ display:flex; align-items:baseline; justify-content:space-between; gap:12px; }
.troph-count{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.03em; color:var(--ink-3); }
.troph-count b{ font-family:var(--font-display); font-size:14px; color:var(--ink); }
.ring-rail{ display:flex; gap:12px; padding:4px 2px; }
.ring-mini{ position:relative; width:40px; height:40px; border-radius:50%; flex:none;
  border:1.5px solid color-mix(in oklab, var(--rc) 60%, var(--hairline));
  background:radial-gradient(circle, color-mix(in oklab, var(--rc) 24%, transparent), transparent 70%);
  box-shadow:0 0 14px -4px var(--rc); display:grid; place-items:center; }
.ring-mini i{ position:absolute; width:3px; height:3px; border-radius:50%; background:var(--rc); box-shadow:0 0 5px var(--rc);
  animation:ringTwinkle 2.6s ease-in-out infinite; }
.ring-mini i:nth-child(1){ left:30%; top:38%; animation-delay:0s; }
.ring-mini i:nth-child(2){ left:58%; top:32%; animation-delay:.7s; }
.ring-mini i:nth-child(3){ left:46%; top:62%; animation-delay:1.4s; }
.ring-mini.locked{ border-style:dashed; border-color:var(--hairline-2); box-shadow:none; filter:grayscale(.6) opacity(.6); }
.op-roomopen{ display:flex; align-items:center; justify-content:space-between; gap:12px; width:100%; cursor:pointer; font:inherit;
  padding:12px 14px; border-radius:var(--r-lg); color:var(--ink);
  border:1px solid color-mix(in oklab, #ECD08A 34%, var(--hairline));
  background:linear-gradient(180deg, color-mix(in oklab, #ECD08A 12%, transparent), transparent); font-size:12.5px; }
.op-roomopen:active{ background:color-mix(in oklab, #ECD08A 18%, transparent); }
.op-roomarrow{ font-size:16px; color:#ECD08A; }

/* ---- SQUADS · Skull Island team node ---- */
.sq-hero{ position:relative; overflow:hidden; flex:none; display:grid; grid-template-columns:auto 1fr; gap:15px; align-items:center;
  padding:16px; border-radius:var(--r-lg); border:1px solid color-mix(in oklab, var(--cc) 38%, var(--hairline));
  background:linear-gradient(180deg, color-mix(in oklab, var(--cc) 14%, rgba(16,14,25,0.7)), rgba(16,14,25,0.55)); }
.sq-hero-glow{ position:absolute; top:-60%; left:-10%; width:170px; height:170px; border-radius:50%; pointer-events:none;
  background:radial-gradient(circle, color-mix(in oklab, var(--cc) 36%, transparent), transparent 68%); filter:blur(4px); }
.sq-crest{ position:relative; width:64px; height:64px; flex:none; display:grid; place-items:center; border-radius:16px;
  font-size:32px; color:color-mix(in oklab, var(--cc) 70%, #fff);
  background:radial-gradient(circle at 34% 26%, color-mix(in oklab, var(--cc) 40%, transparent), transparent 70%), rgba(11,10,19,0.7);
  border:1px solid color-mix(in oklab, var(--cc) 46%, var(--hairline)); box-shadow:0 0 24px -8px var(--cc); }
.sq-hero-id{ position:relative; min-width:0; display:flex; flex-direction:column; gap:5px; }
.sq-hero-name{ font-family:var(--font-display); font-weight:600; font-size:21px; color:var(--ink); line-height:1.05; }
.sq-hero-tag{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.07em; text-transform:uppercase; color:color-mix(in oklab, var(--cc) 58%, var(--ink-3)); }
.sq-hero-motto{ font-size:12px; font-style:italic; color:var(--ink-3); }
.sq-hero-chips{ display:flex; flex-wrap:wrap; gap:6px; margin-top:2px; }
.sq-chip{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:0.04em; text-transform:uppercase; color:var(--ink-2);
  padding:4px 9px; border-radius:var(--r-pill); border:1px solid var(--hairline-2); background:rgba(255,255,255,0.03); }
.sq-chip.hot{ color:color-mix(in oklab, var(--cc) 72%, #fff); border-color:color-mix(in oklab, var(--cc) 50%, var(--hairline));
  background:color-mix(in oklab, var(--cc) 16%, transparent); }
.sq-syn{ display:flex; flex-direction:column; gap:8px; }
.sq-syn-top{ display:flex; align-items:baseline; justify-content:space-between; }
.sq-syn-val{ font-family:var(--font-display); font-weight:600; font-size:15px; color:#FF8A3D; }
.sq-ops{ display:flex; flex-direction:column; gap:10px; }
.sq-op{ display:flex; flex-direction:column; gap:8px; padding:12px 13px; border-radius:var(--r-lg);
  border:1px solid color-mix(in oklab, var(--oc) 26%, var(--hairline)); background:rgba(16,14,25,0.42); }
.sq-op-top{ display:grid; grid-template-columns:auto 1fr auto; gap:10px; align-items:center; }
.sq-op-glyph{ width:28px; height:28px; flex:none; display:grid; place-items:center; border-radius:9px; font-size:14px;
  color:var(--oc); background:color-mix(in oklab, var(--oc) 16%, transparent); border:1px solid color-mix(in oklab, var(--oc) 40%, var(--hairline)); }
.sq-op-idb{ min-width:0; display:flex; flex-direction:column; gap:2px; }
.sq-op-name{ font-size:13.5px; font-weight:600; color:var(--ink); }
.sq-op-meta{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:0.04em; text-transform:uppercase; color:var(--ink-4); }
.sq-op-pct{ font-family:var(--font-display); font-weight:600; font-size:14px; color:var(--oc); }
.sq-op-target{ font-size:11.5px; color:var(--ink-3); }
.sq-rings{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.sq-ring{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:7px; padding:14px 11px; border-radius:var(--r-lg);
  border:1px solid color-mix(in oklab, var(--rc) 30%, var(--hairline)); background:rgba(16,14,25,0.4); }
.sq-ring.locked{ border-color:var(--hairline-2); filter:grayscale(.5) opacity(.7); }
.sq-ring-orb{ width:46px; height:46px; border-radius:50%; display:grid; place-items:center; font-size:21px;
  color:color-mix(in oklab, var(--rc) 72%, #fff);
  background:radial-gradient(circle, color-mix(in oklab, var(--rc) 26%, transparent), transparent 70%);
  border:1.5px solid color-mix(in oklab, var(--rc) 56%, var(--hairline)); box-shadow:0 0 16px -5px var(--rc); }
.sq-ring.locked .sq-ring-orb{ box-shadow:none; border-style:dashed; font-size:17px; }
.sq-ring-name{ font-family:var(--font-display); font-weight:600; font-size:13px; color:var(--ink); }
.sq-ring-desc{ font-size:10.5px; color:var(--ink-4); line-height:1.3; }
.sq-ring-badge{ font-family:var(--font-mono); font-size:9px; letter-spacing:0.08em; text-transform:uppercase;
  color:color-mix(in oklab, var(--rc) 70%, #fff); padding:3px 9px; border-radius:var(--r-pill);
  background:color-mix(in oklab, var(--rc) 16%, transparent); }
.sq-ring-pbar{ width:100%; height:5px; border-radius:3px; overflow:hidden; background:rgba(255,255,255,0.07); }
.sq-ring-pbar i{ display:block; height:100%; border-radius:3px; background:var(--rc); }
.sq-roster{ display:flex; flex-direction:column; gap:9px; }
.sq-mem{ display:grid; grid-template-columns:auto 1fr auto auto; gap:11px; align-items:center; width:100%; cursor:pointer; font:inherit; text-align:left;
  padding:10px 12px; border-radius:var(--r-lg); color:var(--ink);
  border:1px solid color-mix(in oklab, var(--mc) 30%, var(--hairline));
  background:linear-gradient(180deg, color-mix(in oklab, var(--mc) 9%, transparent), transparent); }
.sq-mem:active{ background:color-mix(in oklab, var(--mc) 16%, transparent); }
.sq-mem-av{ width:42px; height:42px; flex:none; border-radius:11px; overflow:hidden; display:block;
  border:1px solid color-mix(in oklab, var(--mc) 44%, var(--hairline)); box-shadow:0 0 16px -7px var(--mc); }
.sq-mem-av img{ width:100%; height:100%; object-fit:cover; }
.sq-mem-id{ min-width:0; display:flex; flex-direction:column; gap:2px; }
.sq-mem-name{ font-family:var(--font-display); font-weight:600; font-size:14.5px; color:var(--ink); }
.sq-mem-role{ font-size:11px; color:var(--ink-3); }
.sq-mem-meta{ display:flex; flex-direction:column; align-items:flex-end; gap:3px; flex:none; }
.sq-mem-rate{ font-family:var(--font-mono); font-size:11px; white-space:nowrap; color:color-mix(in oklab, var(--mc) 64%, #fff); }
.sq-mem-clr{ font-family:var(--font-mono); font-size:8.5px; letter-spacing:0.06em; text-transform:uppercase; white-space:nowrap; color:var(--ink-4); }
.sq-mem-go{ font-size:20px; flex:none; color:color-mix(in oklab, var(--mc) 60%, var(--ink-4)); }
.sq-mem-captag{ font-size:11px; margin-left:5px; color:#FF8A3D; }
.sq-av-init{ display:grid; place-items:center;
  background:radial-gradient(circle at 32% 26%, color-mix(in oklab, var(--cc) 42%, transparent), transparent 70%), rgba(11,10,19,0.72);
  border:1px solid color-mix(in oklab, var(--cc) 40%, var(--hairline)); }
.sq-av-init .cd-av-l{ font-size:16px; }
.cd-av.sq-av-init .cd-av-l{ font-size:27px; }

/* member-dossier add/remove action */
.sq-prof-act{ display:flex; gap:8px; }
.sq-prof-btn{ flex:1; font:inherit; cursor:pointer; font-family:var(--font-mono); font-size:11px; letter-spacing:0.06em; text-transform:uppercase;
  padding:12px; border-radius:var(--r-md); border:1px solid; transition:all var(--dur-fast); }
.sq-prof-btn.add{ color:#0c1a12; background:linear-gradient(180deg,#3DF0A1,#2FE0A1); border-color:transparent; }
.sq-prof-btn.add:active{ transform:translateY(1px); }
.sq-prof-btn.remove{ color:#FF8A9B; background:rgba(251,113,133,0.1); border-color:rgba(251,113,133,0.4); }
.sq-prof-btn.remove:active{ background:rgba(251,113,133,0.18); }
.sq-prof-cap{ flex:1; text-align:center; font-family:var(--font-mono); font-size:11px; letter-spacing:0.06em; text-transform:uppercase;
  padding:12px; border-radius:var(--r-md); color:#FF8A3D; background:rgba(255,138,61,0.1); border:1px solid rgba(255,138,61,0.4); }

/* Contacts ▸ Squad management pane */
.sq-mng-wrap{ display:flex; flex-direction:column; gap:13px; padding-top:4px; }
.sq-mng-head{ display:grid; grid-template-columns:auto 1fr auto; gap:12px; align-items:center; padding:13px;
  border-radius:var(--r-lg); border:1px solid color-mix(in oklab, #FF8A3D 34%, var(--hairline));
  background:linear-gradient(180deg, color-mix(in oklab, #FF8A3D 12%, rgba(16,14,25,0.6)), rgba(16,14,25,0.5)); }
.sq-mng-crest{ width:44px; height:44px; flex:none; display:grid; place-items:center; border-radius:12px; font-size:22px; color:#FFB063;
  background:radial-gradient(circle at 34% 26%, rgba(255,138,61,0.4), transparent 70%), rgba(11,10,19,0.7); border:1px solid rgba(255,138,61,0.46); }
.sq-mng-hid{ min-width:0; display:flex; flex-direction:column; gap:3px; }
.sq-mng-name{ font-family:var(--font-display); font-weight:600; font-size:17px; color:var(--ink); }
.sq-mng-sub{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.05em; text-transform:uppercase; color:var(--ink-3); }
.sq-mng-cap-pill{ font-family:var(--font-mono); font-size:9px; letter-spacing:0.05em; text-transform:uppercase; white-space:nowrap;
  padding:5px 9px; border-radius:var(--r-pill); color:#FFB063; background:rgba(255,138,61,0.14); border:1px solid rgba(255,138,61,0.4); }
.sq-mng-list{ display:flex; flex-direction:column; gap:8px; }
.sq-mng{ display:grid; grid-template-columns:1fr auto; gap:8px; align-items:center;
  padding:8px 11px 8px 9px; border-radius:var(--r-lg); border:1px solid color-mix(in oklab, var(--mc) 28%, var(--hairline));
  background:linear-gradient(180deg, color-mix(in oklab, var(--mc) 8%, transparent), transparent); }
.sq-mng.bench{ background:rgba(16,14,25,0.4); }
.sq-mng-main{ display:grid; grid-template-columns:auto 1fr; gap:10px; align-items:center; min-width:0;
  font:inherit; text-align:left; cursor:pointer; color:var(--ink); background:none; border:none; padding:0; }
.sq-mng-main .sq-mem-av{ width:38px; height:38px; border-radius:10px; }
.sq-mng-cap{ font-family:var(--font-mono); font-size:9px; letter-spacing:0.05em; text-transform:uppercase; white-space:nowrap;
  padding:5px 9px; border-radius:var(--r-pill); color:#FFB063; background:rgba(255,138,61,0.14); border:1px solid rgba(255,138,61,0.4); }
.sq-mng-del{ width:30px; height:30px; flex:none; display:grid; place-items:center; cursor:pointer; font-size:19px; line-height:1;
  border-radius:9px; color:#FF8A9B; background:rgba(251,113,133,0.1); border:1px solid rgba(251,113,133,0.35); transition:all var(--dur-fast); }
.sq-mng-del:active{ background:rgba(251,113,133,0.22); }
.sq-mng-add{ font-family:var(--font-mono); font-size:10px; letter-spacing:0.05em; text-transform:uppercase; white-space:nowrap; cursor:pointer;
  padding:8px 12px; border-radius:var(--r-pill); color:#0c1a12; background:linear-gradient(180deg,#3DF0A1,#2FE0A1); border:1px solid transparent; transition:all var(--dur-fast); }
.sq-mng-add:active{ transform:translateY(1px); }
.sq-slot{ display:grid; place-items:center; padding:13px; border-radius:var(--r-lg); border:1px dashed var(--hairline-2);
  font-family:var(--font-mono); font-size:10px; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-4); }
.sq-bench{ display:flex; flex-direction:column; gap:8px; }

/* Create-squad button — squad emblem + orange accent */
.btn-sm.squad{ display:inline-flex; align-items:center; gap:6px; color:#FFB877;
  border-color:rgba(255,138,61,0.45); background:rgba(255,138,61,0.12); }
.btn-sm.squad:hover{ color:#fff; border-color:rgba(255,138,61,0.7); background:rgba(255,138,61,0.2); }
.sq-btn-ic{ font-size:13px; line-height:1; color:#FF8A3D; }
.btn-sm.chat .wh-chat-ic{ margin-right:5px; }

/* member-dossier chat button (sits beside add/remove) */
.sq-prof-chat{ flex:1; display:flex; align-items:center; justify-content:center; gap:7px; cursor:pointer;
  font-family:var(--font-mono); font-size:11px; letter-spacing:0.05em; text-transform:uppercase; font-weight:600;
  padding:12px; border-radius:var(--r-md); transition:all var(--dur-fast);
  color:color-mix(in oklab, var(--cc) 70%, #fff);
  border:1px solid color-mix(in oklab, var(--cc) 48%, var(--hairline)); background:color-mix(in oklab, var(--cc) 14%, transparent); }
.sq-prof-chat:active{ transform:translateY(1px); }
.sq-prof-chat .wh-chat-ic{ font-size:13px; }

/* Chat ▸ Squad group chat */
.sqgc{ display:flex; flex-direction:column; gap:11px; }
.sqgc-head{ display:grid; grid-template-columns:auto 1fr auto; gap:12px; align-items:center; padding:11px 13px;
  border-radius:var(--r-lg); border:1px solid color-mix(in oklab, var(--cc) 34%, var(--hairline));
  background:linear-gradient(180deg, color-mix(in oklab, var(--cc) 12%, rgba(16,14,25,0.6)), rgba(16,14,25,0.5)); }
.sqgc-crest{ width:40px; height:40px; flex:none; display:grid; place-items:center; border-radius:11px; font-size:20px; color:#FFB063;
  background:radial-gradient(circle at 34% 26%, rgba(255,138,61,0.4), transparent 70%), rgba(11,10,19,0.7); border:1px solid rgba(255,138,61,0.46); }
.sqgc-hid{ min-width:0; display:flex; flex-direction:column; gap:2px; }
.sqgc-name{ font-family:var(--font-display); font-weight:600; font-size:15px; color:var(--ink); }
.sqgc-sub{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:0.05em; text-transform:uppercase; color:var(--ink-3); }
.sqgc-pips{ display:flex; }
.sqgc-pip{ width:26px; height:26px; margin-left:-7px; border-radius:50%; display:grid; place-items:center;
  font-family:var(--font-mono); font-size:9px; font-weight:600; color:#0b0a13; background:var(--mc);
  border:1.5px solid var(--obsidian); box-shadow:0 0 8px -2px var(--mc); }
.sqgc-pip:first-child{ margin-left:0; }
.sqgc-body{ display:flex; flex-direction:column; gap:9px; max-height:46vh; overflow-y:auto; padding:2px; scrollbar-width:none; -ms-overflow-style:none; }
.sqgc-body::-webkit-scrollbar{ width:0; height:0; }
.sqgc-from{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:0.05em; text-transform:uppercase; font-weight:600; margin:0 0 3px 4px; }
.sqgc-composer{ display:flex; gap:8px; padding-top:2px; }
.sqgc-in{ flex:1; box-sizing:border-box; font-family:var(--font-ui); font-size:14px; color:var(--ink);
  background:rgba(16,14,25,0.78); border:1px solid var(--hairline-2); border-radius:var(--r-pill); padding:11px 15px; outline:none; }
.sqgc-in:focus{ border-color:rgba(255,138,61,0.55); }
.sqgc-in::placeholder{ color:var(--ink-4); }
.sqgc-send{ flex:none; width:42px; height:42px; border-radius:50%; cursor:pointer; font-size:15px;
  display:flex; align-items:center; justify-content:center; color:#FFD9B8;
  border:1px solid rgba(255,138,61,0.5); background:rgba(255,138,61,0.22); }
.sqgc-send:active{ transform:scale(0.94); }

/* The room */
.rings-room{ display:flex; flex-direction:column; gap:18px; }
.rr-hero{ position:relative; overflow:hidden; text-align:center; padding:20px 16px 18px; border-radius:var(--r-xl);
  border:1px solid var(--hairline-2); background:linear-gradient(180deg, rgba(30,25,44,0.7), rgba(14,12,21,0.65)); }
.rr-hero-glow{ position:absolute; top:-40%; left:50%; transform:translateX(-50%); width:240px; height:240px; border-radius:50%; pointer-events:none;
  background:radial-gradient(circle, rgba(236,208,138,0.22), transparent 65%); filter:blur(6px); }
.rr-title{ position:relative; font-family:var(--font-display); font-weight:600; font-size:24px; letter-spacing:0.01em;
  background:linear-gradient(180deg,#fff,#ECD08A); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.rr-sub{ position:relative; font-size:11.5px; color:var(--ink-3); line-height:1.5; margin:6px auto 0; max-width:280px; text-wrap:balance; }
.rr-stats{ position:relative; display:flex; justify-content:center; gap:18px; margin-top:13px; }
.rr-stats span{ font-family:var(--font-mono); font-size:9px; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-4); display:flex; flex-direction:column; gap:2px; }
.rr-stats b{ font-family:var(--font-display); font-size:18px; color:var(--ink); }
.rings-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px 12px; }
.ring-troph{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:7px; }
.ring-orb{ position:relative; width:138px; height:138px; border-radius:50%; isolation:isolate;
  border:1.5px solid color-mix(in oklab, var(--rc) 55%, var(--hairline));
  background:radial-gradient(circle at 50% 50%, color-mix(in oklab, var(--rc) 16%, transparent), transparent 68%), rgba(9,8,15,0.55);
  box-shadow:0 0 30px -8px var(--rc), inset 0 0 32px -14px var(--rc);
  animation:ringPulse 3.4s ease-in-out infinite; }
.ring-canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:1; pointer-events:none; }
.ring-core{ position:absolute; inset:0; z-index:2; display:grid; place-items:center; font-size:30px; color:#fff;
  text-shadow:0 1px 4px rgba(0,0,0,0.6); filter:drop-shadow(0 0 8px color-mix(in oklab, var(--rc) 75%, transparent)); }
.ring-tier{ font-family:var(--font-mono); font-size:7.5px; letter-spacing:0.14em; text-transform:uppercase; font-weight:700;
  color:color-mix(in oklab, var(--rc) 78%, #fff);
  border:1px solid color-mix(in oklab, var(--rc) 48%, var(--hairline)); border-radius:var(--r-pill); padding:3px 10px;
  background:color-mix(in oklab, var(--rc) 13%, transparent); }
.ring-name{ font-family:var(--font-display); font-weight:600; font-size:15px; color:var(--ink); line-height:1.1; }
.ring-desc{ font-size:10.5px; color:var(--ink-3); line-height:1.35; text-wrap:balance; max-width:150px; }
.ring-foot{ font-family:var(--font-mono); font-size:8.5px; letter-spacing:0.04em; text-transform:uppercase; color:var(--ink-4); margin-top:1px; }
.ring-prog{ display:flex; align-items:center; gap:7px; width:128px; text-transform:none; }
.ring-pbar{ flex:1; height:5px; border-radius:99px; background:var(--hairline); overflow:hidden; }
.ring-pbar > i{ display:block; height:100%; border-radius:99px; background:linear-gradient(90deg, color-mix(in oklab, var(--rc) 55%, #000), var(--rc)); }
.ring-prog.done .ring-pbar > i{ background:linear-gradient(90deg, color-mix(in oklab, var(--rc) 70%, #fff), var(--rc)); box-shadow:0 0 8px -1px var(--rc); }
.ring-prog.done > span{ color:color-mix(in oklab, var(--rc) 70%, #fff); }
.ring-troph.locked .ring-orb{ border-style:dashed; box-shadow:inset 0 0 24px -14px var(--rc); filter:saturate(.5); animation:none; }
.ring-troph.locked .ring-core{ font-size:22px; filter:none; opacity:.85; }
.ring-troph.locked .ring-name{ color:var(--ink-2); }
.ring-troph.locked .ring-tier{ color:var(--ink-4); border-color:var(--hairline-2); background:transparent; }
@keyframes ringTwinkle{ 0%,100%{ opacity:.18; transform:translate(-50%,-50%) scale(.65); } 50%{ opacity:1; transform:translate(-50%,-50%) scale(1.18); } }
@keyframes ringPulse{ 0%,100%{ box-shadow:0 0 26px -10px var(--rc), inset 0 0 30px -14px var(--rc); } 50%{ box-shadow:0 0 42px -4px var(--rc), inset 0 0 36px -10px var(--rc); } }
@media (prefers-reduced-motion: reduce){ .ring-orb,.ring-mini i{ animation:none; } }

.cd-chat{ display:flex; align-items:center; justify-content:center; gap:8px; cursor:pointer;
  font-family:var(--font-mono); font-size:11px; letter-spacing:0.08em; text-transform:uppercase; font-weight:600;
  padding:13px; border-radius:var(--r-sm); transition:all var(--dur-fast);
  border:1px solid rgba(47,224,161,0.5); background:rgba(47,224,161,0.14); color:#bff4df; }
.cd-chat:hover{ background:rgba(47,224,161,0.24); color:#fff; }
.cd-chat:active{ transform:translateY(1px); }

.cd-sect{ display:flex; flex-direction:column; gap:9px; }
.cd-craves{ display:flex; flex-wrap:wrap; gap:7px; }
.cd-crave{ display:inline-flex; align-items:center; gap:7px; font-size:12px; color:var(--ink-2);
  padding:7px 12px 7px 7px; border-radius:var(--r-pill); background:rgba(16,14,25,0.5); border:1px solid var(--hairline-2); }
.cd-crave-n{ width:18px; height:18px; border-radius:99px; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-mono); font-size:9px; font-weight:600; color:#0b0a13; background:#C084FC; }

.cd-contact{ display:flex; flex-direction:column; border-radius:var(--r-md); overflow:hidden; border:1px solid var(--hairline-2); }
.cd-cline{ display:grid; grid-template-columns:auto 1fr; gap:11px; align-items:center; padding:11px 13px; background:rgba(16,14,25,0.5); }
.cd-cline + .cd-cline{ border-top:1px solid var(--hairline); }
.cd-cic{ width:26px; height:26px; border-radius:8px; display:flex; align-items:center; justify-content:center; flex:none;
  font-size:13px; color:var(--ink-2); background:rgba(255,255,255,0.04); border:1px solid var(--hairline); }
.cd-cline > div{ display:flex; flex-direction:column; gap:2px; min-width:0; }
.cd-ck{ font-family:var(--font-mono); font-size:8.5px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-4); }
.cd-cv{ font-size:13px; color:var(--ink); }

.cd-notes{ font-size:12.5px; line-height:1.5; color:var(--ink-2); padding:12px 13px; border-radius:var(--r-md);
  background:rgba(16,14,25,0.5); border:1px solid var(--hairline-2); border-left:2px solid var(--sc); }

.cd-links{ display:flex; flex-direction:column; gap:8px; }
.cd-link{ display:grid; grid-template-columns:auto 1fr auto auto; gap:11px; align-items:center; cursor:pointer; text-align:left;
  padding:9px 11px; border-radius:var(--r-md); background:rgba(16,14,25,0.5); border:1px solid var(--hairline-2); transition:all var(--dur-fast); }
.cd-link:active{ background:rgba(255,255,255,0.04); }
.cd-link-av{ width:34px; height:34px; border-radius:10px; flex:none; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:700; font-size:12px; color:#0b0a13; }
.cd-link-id{ min-width:0; display:flex; flex-direction:column; gap:2px; }
.cd-link-nm{ font-size:13px; color:var(--ink); }
.cd-link-sub{ font-family:var(--font-mono); font-size:9.5px; color:var(--ink-4); }
.cd-link .cc-chev{ font-size:18px; color:var(--ink-4); line-height:1; }
.cd-empty{ font-size:12px; color:var(--ink-4); padding:6px 2px; }
.cd-rankings{ display:flex; align-items:center; justify-content:center; gap:8px; cursor:pointer;
  font-family:var(--font-mono); font-size:11px; letter-spacing:0.08em; text-transform:uppercase; font-weight:600;
  padding:13px; border-radius:var(--r-sm); transition:all var(--dur-fast);
  border:1px solid rgba(192,132,252,0.5); background:rgba(192,132,252,0.14); color:#e9d5ff; }
.cd-rankings:hover{ background:rgba(192,132,252,0.24); color:#fff; }
.cd-rankings:active{ transform:translateY(1px); }

/* ---- customer ranking · deep-zoom leaderboards ---- */
.cr-list{ display:flex; flex-direction:column; gap:8px; }
.cr-row{ display:grid; grid-template-columns:auto auto 1fr auto auto; gap:11px; align-items:center; cursor:pointer; text-align:left; width:100%;
  padding:9px 11px; border-radius:var(--r-md); background:rgba(16,14,25,0.5); border:1px solid var(--hairline-2); transition:all var(--dur-fast); }
.cr-row:active{ background:rgba(255,255,255,0.04); }
.cr-rk{ width:22px; height:22px; border-radius:7px; flex:none; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-mono); font-size:11px; font-weight:600; color:var(--ink-3); background:rgba(255,255,255,0.04); border:1px solid var(--hairline); }
.cr-row.top .cr-rk{ color:#1a1405; background:linear-gradient(180deg,#ECD08A,#D4B062); border-color:transparent; }
.cr-av{ width:34px; height:34px; border-radius:10px; flex:none; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:700; font-size:12px; color:#0b0a13; }
.cr-id{ min-width:0; display:flex; flex-direction:column; gap:2px; }
.cr-nm{ font-size:13px; font-weight:500; color:var(--ink); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.cr-sub{ font-family:var(--font-mono); font-size:9px; color:var(--ink-4); }
.cr-val{ font-family:var(--font-display); font-weight:600; font-size:15px; color:var(--ink); font-variant-numeric:tabular-nums; white-space:nowrap; }
.cr-val small{ font-family:var(--font-mono); font-weight:400; font-size:9px; color:var(--ink-4); margin-left:2px; }
.cr-row .cc-chev{ font-size:18px; color:var(--ink-4); line-height:1; }

/* ---- performance · streak grid ---- */
.streak-grid{ display:grid; grid-template-columns:repeat(14,1fr); gap:4px; }
.streak-cell{ aspect-ratio:1; border-radius:4px; background:rgba(255,255,255,0.05); border:1px solid var(--hairline); }
.streak-cell.on{ background:linear-gradient(180deg, color-mix(in oklab,#FB7185 80%,#fff 14%), #FB7185); border-color:transparent; box-shadow:0 0 8px -2px #FB7185; }

/* ---- command · council avatar row ---- */
.council-row{ display:flex; gap:7px; flex-wrap:wrap; }
.council-av{ width:42px; height:42px; border-radius:11px; overflow:hidden; border:1px solid var(--hairline-2); box-shadow:0 0 0 2px rgba(11,10,19,0.6); }
.council-av img{ width:100%; height:100%; object-fit:cover; }

/* ---- HQ · suggested orders ---- */
.suggest{ display:flex; flex-direction:column; gap:8px; }
.sg-row{ display:grid; grid-template-columns:auto 1fr auto; gap:11px; align-items:center; cursor:pointer;
  padding:10px 12px; border-radius:var(--r-md); background:rgba(16,14,25,0.5); border:1px solid var(--hairline-2);
  transition:border-color var(--dur-fast), background var(--dur-fast); }
.sg-row:active{ background:rgba(255,255,255,0.04); border-color:var(--hairline-3); }
.sg-av{ width:34px; height:34px; border-radius:10px; flex:none; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:700; font-size:12px; color:#0b0a13; }
.sg-main{ min-width:0; }
.sg-nm{ font-size:13px; color:var(--ink); font-weight:500; }
.sg-rs{ font-size:11px; color:var(--ink-3); margin-top:2px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.sg-cta{ flex:none; font-family:var(--font-mono); font-size:9px; letter-spacing:0.06em; text-transform:uppercase;
  color:var(--ink-2); border:1px solid var(--hairline-3); border-radius:var(--r-pill); padding:5px 10px; white-space:nowrap; }
.sg-row:active .sg-cta{ color:var(--ink); }

/* ---- HQ · mission reward cards (dotted-ripple, by rarity) ---- */
.rewards{ display:flex; flex-direction:column; gap:11px; }
.hq-reward{ position:relative; display:grid; grid-template-columns:auto 1fr; gap:14px; align-items:center;
  padding:13px 15px 14px 13px; border-radius:var(--r-md); overflow:hidden;
  background:linear-gradient(180deg, color-mix(in oklab, var(--rc) 13%, rgba(22,19,31,0.5)), rgba(15,13,23,0.55));
  border:1px solid color-mix(in oklab, var(--rc) 38%, var(--hairline));
  box-shadow:0 10px 30px rgba(0,0,0,0.34), inset 0 0 24px color-mix(in oklab, var(--rc) 8%, transparent); }
.rw-medallion{ position:relative; width:56px; height:56px; flex:none; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:
    radial-gradient(circle at 50% 50%, color-mix(in oklab,var(--rc) 28%, transparent), transparent 68%),
    radial-gradient(color-mix(in oklab,var(--rc) 55%, transparent) 0.9px, transparent 1.2px);
  background-size:100% 100%, 6px 6px; background-position:center, center; }
.rw-medallion::before, .rw-medallion::after{ content:""; position:absolute; inset:2px; border-radius:50%;
  border:1.5px dotted var(--rc); opacity:0; transform:scale(0.55);
  animation:rwRipple 3s var(--ease-out) infinite; }
.rw-medallion::after{ animation-delay:1.5s; }
@keyframes rwRipple{ 0%{ transform:scale(0.55); opacity:0; } 14%{ opacity:0.7; } 100%{ transform:scale(1.55); opacity:0; } }
@media (prefers-reduced-motion: reduce){ .rw-medallion::before, .rw-medallion::after{ animation:none; opacity:0.4; transform:scale(1); } }
.rw-gem{ position:relative; z-index:1; width:24px; height:24px; transform:rotate(45deg); border-radius:7px;
  background:linear-gradient(150deg, color-mix(in oklab,var(--rc) 80%, #fff 18%), var(--rc));
  box-shadow:0 0 16px var(--rc), inset 0 0 8px rgba(255,255,255,0.35); }
.rw-body{ min-width:0; }
.rw-top{ display:flex; align-items:center; gap:9px; flex-wrap:wrap; }
.rw-name{ font-family:var(--font-display); font-weight:600; font-size:14.5px; color:var(--ink); line-height:1.1; }
.rw-tag{ font-family:var(--font-mono); font-size:8px; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--rc); border:1px solid color-mix(in oklab,var(--rc) 45%, transparent);
  background:color-mix(in oklab,var(--rc) 12%, transparent); border-radius:var(--r-pill); padding:3px 7px; }
.rw-reward{ font-size:11px; color:var(--ink-3); margin:5px 0 9px; }
.rw-reward b{ color:color-mix(in oklab,var(--rc) 65%, var(--ink)); font-weight:600; }
.rw-prog{ height:6px; border-radius:99px; background:rgba(11,10,19,0.6); overflow:hidden; }
.rw-prog > i{ display:block; height:100%; border-radius:99px;
  background:linear-gradient(90deg, var(--rc), color-mix(in oklab,var(--rc) 45%, #fff));
  box-shadow:0 0 10px var(--rc); }

/* ---- campaign node · top-5 agents progress list ---- */
.agp-list{ display:flex; flex-direction:column; gap:8px; }
.agp-row{ display:grid; grid-template-columns:auto auto 1fr auto; gap:11px; align-items:center;
  padding:9px 11px; border-radius:var(--r-md); background:rgba(16,14,25,0.5); border:1px solid var(--hairline-2); }
.agp-rk{ width:22px; height:22px; border-radius:7px; flex:none; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-mono); font-size:11px; font-weight:600; color:var(--ink-3); background:rgba(255,255,255,0.04); border:1px solid var(--hairline); }
.agp-rk.top{ color:#1a1405; background:linear-gradient(180deg,#ECD08A,#D4B062); border-color:transparent; }
.agp-av{ width:34px; height:34px; border-radius:9px; overflow:hidden; flex:none; border:1px solid var(--hairline-2); }
.agp-av img{ width:100%; height:100%; object-fit:cover; }
.agp-main{ min-width:0; display:flex; flex-direction:column; gap:5px; }
.agp-top{ display:flex; align-items:baseline; justify-content:space-between; gap:10px; }
.agp-nm{ font-size:13px; font-weight:500; color:var(--ink); }
.agp-lv{ font-family:var(--font-mono); font-size:10px; }
.agp-bar{ height:5px; border-radius:99px; background:rgba(11,10,19,0.6); overflow:hidden; }
.agp-bar > i{ display:block; height:100%; border-radius:99px; }
.agp-pct{ font-family:var(--font-mono); font-size:11px; color:var(--ink-2); font-variant-numeric:tabular-nums; min-width:30px; text-align:right; }
.rw-pct{ display:flex; justify-content:space-between; font-family:var(--font-mono); font-size:9px; color:var(--ink-4); margin-top:6px; }

/* ============================================ SKULL DISTRICT DRAWERS ===== */
/* Per-district control rooms opened from the deep-zoom kingdom. Accent comes
   from --ac (set on .sheet by paint()). */
.sd-sub{ font-size:12.5px; color:var(--ink-3); line-height:1.55; margin:-2px 0 2px; }
.sd-sec{ display:flex; flex-direction:column; gap:9px; }
.sd-lbl{ font-family:var(--font-mono); font-size:9px; letter-spacing:0.16em; text-transform:uppercase; color:var(--ink-4); }
.sd-strip{ display:grid; grid-template-columns:repeat(4,1fr); gap:7px; }
.sd-mini{ display:flex; flex-direction:column; gap:3px; padding:10px 6px; text-align:center; border-radius:var(--r-md);
  background:rgba(16,14,25,0.5); border:1px solid var(--hairline-2); }
.sd-mk{ font-family:var(--font-mono); font-size:7.5px; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-4); }
.sd-mv{ font-family:var(--font-display); font-weight:600; font-size:15px; color:var(--ink); }
.sd-list{ display:flex; flex-direction:column; gap:7px; }
.sd-row{ display:flex; align-items:center; gap:9px; padding:11px 12px; border-radius:var(--r-md);
  background:rgba(16,14,25,0.5); border:1px solid var(--hairline-2); }
.sd-dot{ width:7px; height:7px; border-radius:99px; flex:none; background:var(--ink-4); }
.sd-dot.ok{ background:var(--state-clear,#2FE0A1); box-shadow:0 0 7px var(--state-clear,#2FE0A1); }
.sd-dot.warn{ background:#F5B544; box-shadow:0 0 7px rgba(245,181,68,0.7); }
.sd-rn{ flex:1; min-width:0; font-size:12.5px; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sd-rv{ font-family:var(--font-mono); font-size:11px; color:var(--ink-2); font-variant-numeric:tabular-nums; flex:none; }
.sd-obj{ padding:12px; border-radius:var(--r-md); background:rgba(16,14,25,0.5); border:1px solid var(--hairline-2); }
.sd-obj-top{ display:flex; justify-content:space-between; align-items:baseline; gap:10px; font-size:13px; font-weight:500; color:var(--ink); }
.sd-obj-top span:first-child{ flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sd-obj-top span:last-child{ font-family:var(--font-mono); font-size:11px; font-weight:600; flex:none; }
.sd-obj-meta{ font-family:var(--font-mono); font-size:9.5px; color:var(--ink-4); margin:4px 0 9px; letter-spacing:0.02em; }
.sd-bar{ height:6px; border-radius:99px; background:rgba(11,10,19,0.6); overflow:hidden; }
.sd-bar > i{ display:block; height:100%; border-radius:99px; }
.sd-tags{ display:flex; flex-wrap:wrap; gap:6px; }
.sd-tag{ font-family:var(--font-mono); font-size:9px; letter-spacing:0.06em; text-transform:uppercase; padding:5px 9px;
  border:1px solid var(--hairline-3); border-radius:var(--r-pill); color:var(--ink-3); }
.sd-kv{ display:flex; align-items:center; justify-content:space-between; padding:13px 14px; border-radius:var(--r-md);
  background:linear-gradient(180deg, rgba(40,33,56,0.55), rgba(22,19,31,0.5)); border:1px solid var(--hairline-2); }
.sd-kv span{ font-size:12px; color:var(--ink-3); }
.sd-bal{ font-family:var(--font-display); font-weight:700; font-size:18px; color:#ECD08A; text-shadow:0 0 14px rgba(236,208,138,0.5); }
/* shop grid */
.sd-shop{ display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.sd-buy{ display:flex; flex-direction:column; gap:4px; text-align:left; cursor:pointer; padding:11px; border-radius:var(--r-md);
  background:rgba(16,14,25,0.55); border:1px solid var(--hairline-2); transition:border-color var(--dur-fast), transform var(--dur-fast); }
.sd-buy:active{ transform:scale(0.97); }
.sd-buy.bought{ border-color:rgba(236,208,138,0.5); background:rgba(236,208,138,0.08); }
.sd-buy-ic{ font-size:16px; color:var(--ac); }
.sd-buy-n{ font-size:12px; font-weight:600; color:var(--ink); }
.sd-buy-d{ font-family:var(--font-mono); font-size:8.5px; color:var(--ink-4); line-height:1.3; min-height:22px; }
.sd-buy-p{ font-family:var(--font-mono); font-size:11px; font-weight:600; color:#ECD08A; }
.sd-owned{ display:flex; flex-wrap:wrap; gap:6px; }
.sd-empty{ font-family:var(--font-mono); font-size:10px; color:var(--ink-4); }
/* lots + mini-cta */
.sd-lot{ display:flex; align-items:center; gap:10px; padding:11px 12px; border-radius:var(--r-md);
  background:rgba(16,14,25,0.5); border:1px solid var(--hairline-2); }
.sd-lot-tx{ flex:1; min-width:0; }
.sd-mini-cta{ flex:none; cursor:pointer; font-family:var(--font-mono); font-size:9.5px; letter-spacing:0.06em; text-transform:uppercase;
  padding:7px 12px; border-radius:var(--r-pill); color:var(--ac); border:1px solid color-mix(in oklab, var(--ac) 55%, transparent);
  background:color-mix(in oklab, var(--ac) 14%, transparent); }
.sd-mini-cta:active{ background:color-mix(in oklab, var(--ac) 26%, transparent); }
/* segmented control */
.sd-seg{ display:flex; gap:5px; padding:4px; border-radius:var(--r-md); background:rgba(11,10,19,0.5); border:1px solid var(--hairline-2); }
.sd-seg-b{ flex:1; cursor:pointer; padding:8px 4px; border-radius:var(--r-sm); border:none; background:none;
  font-family:var(--font-mono); font-size:10px; letter-spacing:0.04em; color:var(--ink-3); transition:all var(--dur-fast); }
.sd-seg-b.on{ background:color-mix(in oklab, var(--ac) 20%, transparent); color:var(--ink); box-shadow:inset 0 0 0 1px color-mix(in oklab, var(--ac) 45%, transparent); }
/* inputs */
.sd-input{ width:100%; box-sizing:border-box; padding:12px 13px; border-radius:var(--r-md); font-family:var(--font-sans,inherit); font-size:13px;
  color:var(--ink); background:rgba(11,10,19,0.55); border:1px solid var(--hairline-2); outline:none; transition:border-color var(--dur-fast); }
.sd-input::placeholder{ color:var(--ink-4); }
.sd-input:focus{ border-color:color-mix(in oklab, var(--ac) 60%, transparent); }
.sd-planner{ display:flex; flex-direction:column; gap:9px; padding:13px; border-radius:var(--r-lg);
  background:rgba(11,10,19,0.4); border:1px dashed color-mix(in oklab, var(--ac) 40%, transparent); }
/* pick rows */
.sd-pick{ display:flex; align-items:center; gap:10px; width:100%; cursor:pointer; text-align:left; padding:11px 12px; border-radius:var(--r-md);
  background:rgba(16,14,25,0.5); border:1px solid var(--hairline-2); transition:all var(--dur-fast); }
.sd-tick{ width:18px; height:18px; flex:none; border-radius:5px; display:grid; place-items:center; font-size:11px; color:transparent;
  border:1.5px solid var(--hairline-3); }
.sd-pick.on{ border-color:color-mix(in oklab, var(--ac) 55%, transparent); background:color-mix(in oklab, var(--ac) 10%, transparent); }
.sd-pick.on .sd-tick{ color:#0b0a13; background:var(--ac); border-color:var(--ac); }
/* bounty */
.sd-bounty{ padding:12px; border-radius:var(--r-md); background:rgba(16,14,25,0.5); border:1px solid var(--hairline-2); }
.sd-bounty-foot{ display:flex; align-items:center; justify-content:space-between; margin-top:10px; }
.sd-reward{ font-family:var(--font-mono); font-size:10px; color:#ECD08A; }
/* ghost cta + secondary */
.sk-cta{ width:100%; margin-top:2px; padding:13px; cursor:pointer; border-radius:var(--r-md);
  font-family:var(--font-mono); font-size:11px; letter-spacing:0.08em; text-transform:uppercase; font-weight:600;
  color:var(--ink); border:1px solid color-mix(in oklab, var(--ac) 55%, transparent);
  background:linear-gradient(180deg, color-mix(in oklab, var(--ac) 26%, transparent), color-mix(in oklab, var(--ac) 10%, transparent)); }
.sk-cta:active{ background:color-mix(in oklab, var(--ac) 34%, transparent); }
.sk-cta.on{ box-shadow:inset 0 0 0 1px color-mix(in oklab, var(--ac) 60%, transparent); }
.sd-cta2{ width:100%; padding:11px; cursor:pointer; border-radius:var(--r-md);
  font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.06em; color:var(--ink-2);
  background:rgba(16,14,25,0.5); border:1px dashed var(--hairline-3); }
.sd-cta2:active{ color:var(--ink); border-color:color-mix(in oklab, var(--ac) 50%, transparent); }
/* toggle */
.sd-toggle2{ width:46px; height:26px; flex:none; cursor:pointer; border-radius:99px; padding:0; position:relative;
  background:rgba(11,10,19,0.7); border:1px solid var(--hairline-3); transition:background var(--dur-fast); }
.sd-toggle2-k{ position:absolute; top:2px; left:2px; width:20px; height:20px; border-radius:99px; background:var(--ink-3);
  transition:transform var(--dur-base), background var(--dur-fast); }
.sd-toggle2.on{ background:color-mix(in oklab, var(--ac) 35%, transparent); border-color:color-mix(in oklab, var(--ac) 55%, transparent); }
.sd-toggle2.on .sd-toggle2-k{ transform:translateX(20px); background:var(--ac); }

/* ---- storefront builder (Blackwater Port) ---- */
.sf-prev{ --sf:#A855F7; flex:none; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--hairline-2);
  background:rgba(11,10,19,0.6); }
.sf-banner{ height:64px; background:linear-gradient(135deg, color-mix(in oklab, var(--sf) 80%, #000 6%), color-mix(in oklab, var(--sf) 30%, #14101d)); }
.sf-card{ padding:0 15px 15px; margin-top:-22px; }
.sf-card-top{ display:flex; align-items:flex-end; justify-content:space-between; }
.sf-avatar{ width:46px; height:46px; border-radius:13px; display:grid; place-items:center; flex:none;
  font-family:var(--font-display); font-weight:700; font-size:21px; color:#0b0a13; background:var(--sf);
  border:2.5px solid var(--obsidian,#0b0a13); box-shadow:0 6px 18px -6px var(--sf); }
.sf-badge{ font-family:var(--font-mono); font-size:8px; letter-spacing:0.12em; padding:4px 9px; border-radius:var(--r-pill); margin-bottom:3px; }
.sf-badge.open{ color:#0b0a13; background:var(--sf); }
.sf-badge.shut{ color:var(--ink-3); background:rgba(255,255,255,0.06); border:1px solid var(--hairline-2); }
.sf-name{ font-family:var(--font-display); font-weight:700; font-size:19px; color:var(--ink); margin-top:9px; }
.sf-tag{ font-size:11.5px; color:var(--ink-3); margin-top:3px; line-height:1.4; }
.sf-chips{ display:flex; flex-wrap:wrap; gap:6px; margin-top:11px; }
.sf-chip{ font-family:var(--font-mono); font-size:9px; padding:5px 9px; border-radius:var(--r-pill);
  color:var(--ink-2); background:rgba(255,255,255,0.04); border:1px solid var(--hairline-2); }
.sf-chip-empty{ color:var(--ink-4); }
.sf-swatches{ display:flex; gap:9px; }
.sf-sw{ --sf:#A855F7; width:34px; height:34px; cursor:pointer; border-radius:10px; background:var(--sf); padding:0;
  border:2px solid transparent; transition:transform var(--dur-fast); }
.sf-sw.on{ border-color:#fff; transform:scale(1.06); box-shadow:0 0 14px -2px var(--sf); }
.sf-prods{ display:flex; flex-direction:column; gap:8px; }
.sf-prod-row{ display:flex; align-items:center; gap:7px; }
.sf-prod-row .sf-pn{ flex:1; min-width:0; }
.sf-price{ display:flex; align-items:center; gap:3px; flex:none; width:86px; padding-left:11px; border-radius:var(--r-md);
  background:rgba(11,10,19,0.55); border:1px solid var(--hairline-2); }
.sf-price span{ font-family:var(--font-mono); font-size:12px; color:var(--ink-3); }
.sf-price .sf-pp{ border:none; background:none; padding:11px 8px 11px 2px; width:100%; }
.sf-price:focus-within{ border-color:color-mix(in oklab, var(--ac) 60%, transparent); }
.sf-del{ flex:none; width:34px; height:38px; cursor:pointer; border-radius:var(--r-md); font-size:12px; color:var(--ink-4);
  background:rgba(16,14,25,0.5); border:1px solid var(--hairline-2); }
.sf-del:active{ color:#FB7185; border-color:rgba(251,113,133,0.5); }
.sf-openrow{ align-items:center; }
.sf-handle{ font-family:var(--font-mono); font-size:10px; color:var(--ink-3); text-align:center; padding:4px 0 2px;
  letter-spacing:0.02em; word-break:break-all; }
