/* ============================================================
   BridgeQuest — Cockpit primitives ("Aurora Night")
   Shared shell for all full-screen serious-game screens.
   Tokens live in bridgequest/brand-tokens.css — do not fork them here.
   ============================================================ */

/* --ease alias (brand-tokens exposes --ease-spring with same value) */
:root { --ease: var(--ease-spring); --line-3: rgba(255,255,255,.26); }

*  { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body.cockpit {
  background: #05030c;
  color: var(--ink);
  font-family: var(--font-ui);
  -webkit-font-smoothing: antialiased;
  overflow: hidden;
}
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
img    { display: block; max-width: 100%; }
a      { color: inherit; text-decoration: none; }

/* ---------- Fixed-canvas stage (letterboxes 1600×900) ---------- */
.stage {
  position: fixed; inset: 0;
  display: grid; place-items: center;
  overflow: hidden;
  background: radial-gradient(1400px 900px at 50% 40%, #0d0a1e, #05030c 80%);
}
.screen {
  position: relative;
  width: 1600px; height: 900px; flex: none;
  transform-origin: center center;
  background:
    radial-gradient(1100px 700px at 82% -10%, color-mix(in oklab, var(--c-violet) 20%, transparent), transparent 60%),
    radial-gradient(900px 620px at 4% 112%,  color-mix(in oklab, var(--c-coral)  14%, transparent), transparent 55%),
    var(--bg);
  overflow: hidden;
  box-shadow: inset 0 0 200px rgba(0,0,0,.55);
}
.screen::before {
  content: ""; position: absolute; inset: 0;
  pointer-events: none; z-index: 50;
  background: repeating-linear-gradient(0deg, rgba(255,255,255,.020) 0 1px, transparent 1px 3px);
  mix-blend-mode: overlay; opacity: .5;
}

/* Decorative starfield — safe to omit for performance */
.dust { position: absolute; inset: 0; pointer-events: none; z-index: 1; opacity: .5; }
.dust i {
  position: absolute; width: 2px; height: 2px; border-radius: 50%;
  background: var(--c-sky);
  box-shadow: 0 0 6px 1px color-mix(in oklab, var(--c-sky) 70%, transparent);
  animation: twinkle 4s ease-in-out infinite;
}
@keyframes twinkle { 0%, 100% { opacity: .15 } 50% { opacity: .8 } }

/* Back-to-hub control (lives OUTSIDE the scaled screen) */
.hub-link {
  position: fixed; top: 16px; left: 16px; z-index: 100;
  display: flex; align-items: center; gap: 8px;
  padding: 9px 15px; border-radius: 99px;
  background: rgba(36,29,64,.85); backdrop-filter: blur(8px);
  border: 1px solid var(--line-2); color: var(--ink-mute);
  font-size: 13px; font-weight: 700;
  font-family: var(--font-mono); letter-spacing: .04em;
  transition: color .15s, border-color .15s, transform .15s;
}
.hub-link:hover { color: var(--ink); border-color: var(--line-3); transform: translateX(-2px); }

.screen-tag {
  position: fixed; top: 16px; right: 16px; z-index: 100;
  font-family: var(--font-mono); font-size: 12px;
  letter-spacing: .16em; text-transform: uppercase; color: var(--ink-faint);
  padding: 9px 14px; border-radius: 99px;
  background: rgba(36,29,64,.7); border: 1px solid var(--line);
  white-space: nowrap;
}

/* ---------- HUD top bar ---------- */
.hud {
  position: absolute; top: 0; left: 0; right: 0; height: 78px;
  display: flex; align-items: center; padding: 0 38px; z-index: 20;
}
.hud__side { display: flex; align-items: center; gap: 14px; flex: 1; }
.hud__side.right { justify-content: flex-end; }
.hud__title {
  font-family: var(--font-display); font-weight: 800; font-size: 26px;
  letter-spacing: .14em; text-transform: uppercase; white-space: nowrap;
  background: linear-gradient(180deg, #fff, var(--ink-mute));
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 0 30px color-mix(in oklab, var(--c-sky) 30%, transparent);
}
.hud::after {
  content: ""; position: absolute; left: 38px; right: 38px; bottom: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--line-3) 18%, var(--line-3) 82%, transparent);
}
.hud-icon {
  width: 42px; height: 42px; border-radius: 12px;
  display: grid; place-items: center; flex: none;
  background: var(--surface-2); border: 1px solid var(--line-2); color: var(--ink-mute);
}

/* ---------- Resource chips ---------- */
.res {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 14px; border-radius: 14px;
  background: linear-gradient(180deg, var(--surface-2), var(--surface));
  border: 1px solid var(--line-2);
  font-weight: 800; font-size: 16px; min-width: 120px;
}
.res__glyph { width: 22px; height: 22px; display: grid; place-items: center; flex: none; }
.res__num   { font-family: var(--font-mono); }
.res__lbl   {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--ink-faint); margin-left: auto; font-weight: 700;
}

/* ---------- Bracketed frame (core HUD panel) ---------- */
.frame {
  position: relative;
  background: linear-gradient(180deg,
    color-mix(in oklab, var(--surface)  80%, transparent),
    color-mix(in oklab, var(--bg-2)     70%, transparent));
  border: 1px solid var(--line-2); border-radius: 6px;
}
.frame--glow {
  box-shadow:
    0 0 0 1px color-mix(in oklab, var(--c-sky) 18%, transparent),
    0 24px 60px -30px rgba(0,0,0,.9),
    inset 0 0 60px -30px color-mix(in oklab, var(--c-sky) 40%, transparent);
}
.bracket {
  position: absolute; width: 22px; height: 22px;
  border: 2px solid var(--accent, var(--c-sky));
  pointer-events: none;
  filter: drop-shadow(0 0 6px color-mix(in oklab, var(--accent, var(--c-sky)) 60%, transparent));
}
.bracket.tl { top: -1px; left: -1px;   border-right: 0; border-bottom: 0; border-top-left-radius:     5px; }
.bracket.tr { top: -1px; right: -1px;  border-left:  0; border-bottom: 0; border-top-right-radius:    5px; }
.bracket.bl { bottom: -1px; left: -1px;  border-right: 0; border-top: 0;  border-bottom-left-radius:  5px; }
.bracket.br { bottom: -1px; right: -1px; border-left:  0; border-top: 0;  border-bottom-right-radius: 5px; }

/* ---------- Typography atoms ---------- */
.mono       { font-family: var(--font-mono); letter-spacing: .1em; text-transform: uppercase; }
.eyebrow    {
  font-family: var(--font-mono); font-size: 12px;
  letter-spacing: .18em; text-transform: uppercase; color: var(--c-sky);
}
.panel-label {
  font-family: var(--font-mono); font-size: 12px;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--ink-mute); display: flex; align-items: center; gap: 8px;
}
.panel-label::before {
  content: ""; width: 7px; height: 7px; border-radius: 2px;
  background: var(--accent, var(--c-sky));
  box-shadow: 0 0 8px var(--accent, var(--c-sky));
}

/* ---------- Buttons ---------- */
.gbtn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  padding: 14px 26px; border-radius: 12px;
  font-weight: 800; font-size: 15px; letter-spacing: .04em;
  position: relative;
  transition: transform .15s, filter .15s, box-shadow .15s;
}
.gbtn--primary {
  background: linear-gradient(180deg, #ff8a6f, var(--c-coral));
  color: #2a0d05;
  box-shadow: 0 14px 30px -12px var(--c-coral), inset 0 1px 0 rgba(255,255,255,.5);
  text-transform: uppercase;
}
.gbtn--primary:hover { transform: translateY(-2px); filter: brightness(1.05); }
.gbtn--ghost {
  background: var(--surface-2); border: 1px solid var(--line-2);
  color: var(--ink); text-transform: uppercase;
}
.gbtn--ghost:hover { border-color: var(--line-3); transform: translateY(-2px); }
.gbtn[disabled] { opacity: .4; pointer-events: none; }

/* Filter pills */
.pill {
  padding: 8px 15px; border-radius: 10px;
  font-weight: 700; font-size: 14px;
  background: var(--surface-2); border: 1px solid var(--line-2); color: var(--ink-mute);
  transition: all .15s; letter-spacing: .02em;
}
.pill:hover { color: var(--ink); border-color: var(--line-3); }
.pill.on {
  background: color-mix(in oklab, var(--c-sky) 20%, var(--surface));
  color: #fff;
  border-color: color-mix(in oklab, var(--c-sky) 55%, transparent);
  box-shadow: 0 0 16px -4px var(--c-sky);
}

/* Accessibility: reduced motion */
@media (prefers-reduced-motion: reduce) {
  .screen *, .screen *::before, .screen *::after {
    animation-duration: .001ms !important;
    transition-duration: .001ms !important;
  }
}
.reduced * { animation-duration: .001ms !important; transition-duration: .001ms !important; }

/* ============================================================
   FX layer — juice / reward feedback (driven by fx.js)
   ============================================================ */
.fx-canvas{position:fixed;inset:0;z-index:9000;pointer-events:none;}
.fx-layer{position:fixed;inset:0;z-index:9100;pointer-events:none;overflow:hidden;
  font-family:var(--font-display);}

/* floating score / dial pops */
.fx-pop{position:absolute;transform:translate(-50%,-50%);white-space:nowrap;
  font-weight:800;font-size:20px;letter-spacing:-.01em;color:var(--c-mint);
  text-shadow:0 2px 12px rgba(0,0,0,.6),0 0 18px currentColor;
  animation:fxPop 1.5s cubic-bezier(.2,.8,.3,1) forwards;}
.fx-pop.down{color:var(--c-coral);}
.fx-pop__a{font-size:.8em;margin-right:3px;}
@keyframes fxPop{
  0%{opacity:0;transform:translate(-50%,-30%) scale(.6);}
  18%{opacity:1;transform:translate(-50%,-60%) scale(1.12);}
  32%{transform:translate(-50%,-72%) scale(1);}
  100%{opacity:0;transform:translate(-50%,-160%) scale(.95);}
}

/* milestone banner / ribbon */
.fx-banner{--bn:var(--c-amber);position:absolute;top:84px;left:50%;translate:-50% 0;
  display:flex;align-items:center;gap:16px;
  padding:16px 30px;border-radius:16px;opacity:0;transform:translateY(-140%);
  background:linear-gradient(180deg,color-mix(in oklab,var(--bn) 30%,#161029),color-mix(in oklab,var(--bn) 14%,#120c22));
  border:1.5px solid color-mix(in oklab,var(--bn) 60%,transparent);
  box-shadow:0 24px 60px -20px color-mix(in oklab,var(--bn) 70%,black),inset 0 1px 0 rgba(255,255,255,.18),0 0 0 1px rgba(255,255,255,.04);
  transition:transform .6s cubic-bezier(.2,1.1,.3,1),opacity .5s;}
.fx-banner.in{transform:translateY(0);opacity:1;}
.fx-banner.out{transform:translateY(-30px);opacity:0;}
.fx-banner__ic{width:42px;height:42px;flex:none;display:grid;place-items:center;border-radius:12px;
  background:color-mix(in oklab,var(--bn) 26%,transparent);color:var(--bn);}
.fx-banner__ic svg{width:26px;height:26px;}
.fx-banner__txt{display:flex;flex-direction:column;line-height:1.1;}
.fx-banner__txt b{font-family:var(--font-display);font-weight:800;font-size:24px;color:#fff;letter-spacing:-.01em;}
.fx-banner__txt i{font-family:var(--font-mono);font-style:normal;font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:color-mix(in oklab,var(--bn) 70%,#fff);margin-top:3px;}

/* badge / card reveals */
.fx-badge-in{animation:fxBadge .6s cubic-bezier(.2,1.4,.4,1);}
@keyframes fxBadge{0%{transform:scale(.2) rotate(-12deg);opacity:0;}60%{transform:scale(1.15) rotate(4deg);opacity:1;}100%{transform:scale(1) rotate(0);}}
.fx-card-in{animation:fxCard .7s cubic-bezier(.2,1.1,.3,1) backwards;}
@keyframes fxCard{0%{transform:perspective(700px) rotateY(80deg) translateY(20px);opacity:0;}100%{transform:perspective(700px) rotateY(0) translateY(0);opacity:1;}}

/* progress-bar flare at 100% */
.fx-flare{animation:fxFlare 1s ease;}
@keyframes fxFlare{0%,100%{filter:none;}40%{filter:brightness(1.5) drop-shadow(0 0 16px var(--c-amber));}}

/* camera shake */
.fx-shake{animation:fxShake .5s cubic-bezier(.36,.07,.19,.97);}
@keyframes fxShake{
  10%,90%{transform:translate(calc(var(--sh,6px) * -.4),0);}
  20%,80%{transform:translate(calc(var(--sh,6px) * .8),0);}
  30%,50%,70%{transform:translate(calc(var(--sh,6px) * -1),calc(var(--sh,6px) * .5));}
  40%,60%{transform:translate(var(--sh,6px),calc(var(--sh,6px) * -.5));}
}
/* zoom-punch */
.fx-zoom{animation:fxZoom .5s cubic-bezier(.3,1.2,.4,1);}
@keyframes fxZoom{0%{transform:scale(1);}45%{transform:scale(1.035);}100%{transform:scale(1);}}

.reduced .fx-banner{transition-duration:.001ms;}

/* ============================================================
   Responsive layout (≤ 900px — phones + tablets)
   cockpit_stage.js adds .bq-mobile to <body> at this breakpoint,
   bypassing the fixed 1600×900 scale transform.
   Each screen's own CSS handles its specific reflow below.
   ============================================================ */
@media (max-width: 900px) {
  body.cockpit { overflow: auto; }

  /* Stage becomes a normal block container */
  .stage {
    position: relative !important;
    display: block !important;
    height: auto !important;
    overflow: visible !important;
    background: none;
  }

  /* Screen is full-width flow, not a fixed 1600×900 box */
  .screen {
    position: relative !important;
    width: 100% !important;
    height: auto !important;
    transform: none !important;
    min-height: 100dvh;
    box-shadow: none;
  }

  /* Navigation chrome */
  .hub-link {
    position: fixed; top: 12px; left: 12px;
    padding: 8px 14px; font-size: 12px;
    touch-action: manipulation;
  }
  .screen-tag {
    position: fixed; top: 12px; right: 12px;
    padding: 8px 12px; font-size: 10px;
  }

  /* HUD bar — full width, shorter */
  .hud {
    position: sticky; top: 0; z-index: 20;
    padding: 10px 16px;
  }
  .hud__title { font-size: 14px; }

  /* Disable aurora drift animation on mobile (GPU cost) */
  .aura { animation: none !important; }
  .dust { display: none; }

  /* Globally enforce tap target minimum and eliminate 300ms delay */
  button, a, [role="button"], .opt-btn, .choice, .gbtn, .tg, .pill {
    touch-action: manipulation;
    min-height: 44px;
  }

  /* Bracket decorators are desktop-only */
  .bracket { display: none; }

  /* Frame glow too subtle at mobile; simplify */
  .frame { border-color: rgba(255,255,255,.08); box-shadow: none; }
}

/* Ensure .gbtn is tappable at all sizes */
.gbtn { touch-action: manipulation; }
button { touch-action: manipulation; }

/* ============================================================
   Data-light mode (.bq-data-light on <body>)
   Disables animations, background art, persona avatars.
   Target: < 150 KB page weight.
   Applied server-side via UserProfile.data_light_mode
   or client-side when navigator.connection.saveData / 2g detected.
   ============================================================ */
.bq-data-light .aura,
.bq-data-light .dust,
.bq-data-light .vignette { display: none !important; }

.bq-data-light *,
.bq-data-light *::before,
.bq-data-light *::after {
  animation: none !important;
  transition-duration: .001ms !important;
  background-image: none !important;
}

/* Keep readable backgrounds */
.bq-data-light .screen { background: #05030c !important; box-shadow: none; }
.bq-data-light .screen::before { display: none; }

/* Hide persona figure images — show initials placeholder instead */
.bq-data-light .figure__head img { display: none; }
.bq-data-light .figure__body { display: none; }
.bq-data-light .char.left,
.bq-data-light .char.right { display: none; }

/* ── Settings modal support (bq-modal-overlay from styles.css) ── */
.bq-hidden { display: none !important; }

.bq-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.85);
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

.bq-modal {
  width: min(560px, 100%);
  background: var(--bg-surface, #1a1830);
  border: 1px solid var(--border-subtle, rgba(255,255,255,.12));
  border-radius: var(--radius-lg, 16px);
  padding: var(--space-lg, 1.5rem);
  max-height: min(86vh, 820px);
  overflow: auto;
  color: var(--text-main, #e8e4ff);
}

.bq-modal__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-md, 1rem);
  margin-bottom: var(--space-md, 1rem);
}

.bq-modal__title { margin: 0; }

.bq-modal__row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-md, 1rem);
  padding: 0.5rem 0;
}

.bq-modal__row label { font-weight: 600; }

.bq-modal__hint {
  margin: 4px 0 0;
  color: var(--text-muted, rgba(255,255,255,.5));
  font-size: 0.9rem;
}

.bq-modal__control {
  display: flex;
  align-items: center;
  gap: var(--space-sm, .5rem);
  min-width: 180px;
  justify-content: flex-end;
}

.bq-modal__value {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 64px;
  padding: 6px 10px;
  border-radius: var(--radius-full, 999px);
  background: var(--bg-surface-alt, rgba(255,255,255,.06));
  border: 1px solid var(--border-subtle, rgba(255,255,255,.12));
  font-weight: 700;
}

.bq-modal__row-inline {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm, .5rem);
}

.bq-modal__toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  font-weight: 600;
}

.bq-modal input[type="checkbox"] {
  width: 18px;
  height: 18px;
}

.bq-modal--settings .bq-modal__header {
  position: sticky;
  top: 0;
  background: var(--bg-surface, #1a1830);
  padding: 0 0 var(--space-md, 1rem) 0;
  z-index: 1;
}

.bq-modal__footer--sticky {
  position: sticky;
  bottom: 0;
  background: var(--bg-surface, #1a1830);
  padding-top: var(--space-md, 1rem);
}

.bq-modal__footer {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-sm, .5rem);
  margin-top: var(--space-lg, 1.5rem);
}

.bq-settings-divider {
  height: 1px;
  background: var(--border-subtle, rgba(255,255,255,.12));
  margin: 14px 0;
}

.bq-settings-section-head {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-muted, rgba(255,255,255,.5));
  padding: 2px 0 8px;
}

.bq-settings-form {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm, .5rem);
  align-items: flex-end;
}

.bq-settings-form__row {
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1 1 280px;
}

.bq-settings-form__label { font-weight: 700; }

.bq-settings-form__input {
  width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--border-subtle, rgba(255,255,255,.12));
  background: var(--bg-surface-alt, rgba(255,255,255,.06));
  color: var(--text-main, #e8e4ff);
  font-family: inherit;
}

.bq-settings-form__input:disabled { opacity: 0.6; }
