/* ============================================================
   osapiens PLG Deck — app shell
   Map mode + Cinema mode over the design-system slide canvas.
   ============================================================ */

html,body{margin:0;background:#000;color:#fff;height:100%;width:100%;overflow:hidden;
  font-family:"Roboto",system-ui,sans-serif}

/* ─── Deck root ───────────────────────────────────────────── */
#deck{position:fixed;inset:0;background:#000;overflow:hidden}

/* The "stage" holds every section. In cinema mode it translates+scales
   to center one section in the viewport. In map mode it scales down so
   all 24 sections fit at once. */
#stage{position:absolute;left:0;top:0;
  transform-origin:0 0;
  transition:transform 600ms cubic-bezier(0.2,0,0,1);
  will-change:transform}

/* Each section is a 1280×720 slide canvas, positioned in the map grid.
   Cinema mode just translates/scales the stage so this one centers. */
.slide{position:absolute;width:1280px;height:720px;background:#000;overflow:hidden;
  border-radius:0;box-shadow:0 0 0 1px rgba(255,255,255,0.04);
  transition:opacity 320ms cubic-bezier(0.2,0,0,1) 180ms}

/* In cinema mode, fade neighbors so they don't bleed into the viewport
   on tall aspect-ratios (e.g. preview at 4:3). The .active slide stays at 1. */
body[data-mode="cinema"] .slide{opacity:0;pointer-events:none}
body[data-mode="cinema"] .slide.active{opacity:1;pointer-events:auto}

/* In map mode, slides get a hover lift + thin border + label. */
body[data-mode="map"] .slide{cursor:pointer;
  transition:transform 240ms cubic-bezier(0.2,0,0,1),
             box-shadow 240ms cubic-bezier(0.2,0,0,1),
             outline-color 240ms cubic-bezier(0.2,0,0,1);
  outline:1px solid rgba(255,255,255,0.06);outline-offset:0}
body[data-mode="map"] .slide:hover{
  outline-color:rgba(0,179,190,0.45);
  box-shadow:0 0 60px rgba(0,179,190,0.25),0 0 0 1px rgba(0,179,190,0.5);
  z-index:30}

/* Peak sections get a soft glow + thumbnail label in map mode. */
body[data-mode="map"] .slide.peak{
  outline:1px solid rgba(0,179,190,0.35);
  box-shadow:0 0 120px rgba(0,179,190,0.18),0 0 200px rgba(75,198,118,0.12)}
body[data-mode="map"] .slide.peak:hover{
  box-shadow:0 0 160px rgba(0,179,190,0.45),0 0 220px rgba(75,198,118,0.25),
             0 0 0 1px rgba(0,179,190,0.7)}

/* Act labels shown in map mode only (positioned via inline style per act). */
.act-label{position:absolute;font-family:"Space Grotesk",sans-serif;font-weight:500;
  font-size:18px;letter-spacing:.02em;color:rgba(255,255,255,0.32);
  text-transform:none;pointer-events:none;opacity:0;
  transition:opacity 240ms cubic-bezier(0.2,0,0,1)}
.act-label .num{color:rgba(255,255,255,0.18);font-size:14px;margin-right:8px;
  letter-spacing:0.08em;font-variant-numeric:tabular-nums}
body[data-mode="map"] .act-label{opacity:1}

/* Map-mode legend (top-left) */
.deck-hud{position:fixed;left:24px;top:20px;z-index:60;
  font-family:"Space Grotesk",sans-serif;font-weight:500;
  font-size:12px;letter-spacing:.04em;color:rgba(255,255,255,0.55);
  display:flex;gap:18px;align-items:baseline;pointer-events:none;
  transition:opacity 240ms cubic-bezier(0.2,0,0,1)}
.deck-hud b{font-weight:500;color:rgba(255,255,255,0.85)}
.deck-hud .sep{color:rgba(255,255,255,0.18)}
body[data-mode="cinema"] .deck-hud{opacity:0}

/* Cinema HUD: hidden in cinema mode (the slide footer already shows
   the counter); only kept around for debug / non-slide presentation. */
.cinema-hud{position:fixed;right:24px;bottom:20px;z-index:60;
  font-family:"Space Grotesk",sans-serif;font-size:11px;letter-spacing:.08em;
  color:rgba(255,255,255,0.4);pointer-events:none;
  transition:opacity 240ms cubic-bezier(0.2,0,0,1);opacity:0}
body[data-mode="map"] .cinema-hud{opacity:0}
body[data-presenter="true"] .cinema-hud,
body[data-presenter="true"] .deck-hud{opacity:0}

/* Key-hint chip (bottom-center, only on first load) */
.key-hint{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);
  z-index:60;font-family:"Space Grotesk",sans-serif;font-size:11px;
  letter-spacing:.08em;color:rgba(255,255,255,0.5);
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);
  padding:8px 14px;border-radius:999px;backdrop-filter:blur(8px);
  transition:opacity 400ms cubic-bezier(0.2,0,0,1);pointer-events:none}
.key-hint kbd{font-family:"Space Grotesk",sans-serif;font-weight:500;
  color:rgba(255,255,255,0.85);background:rgba(255,255,255,0.08);
  padding:2px 6px;border-radius:4px;margin:0 2px}
body[data-presenter="true"] .key-hint{opacity:0}
.key-hint.hidden{opacity:0}

/* ─── Reveal animations inside cinema mode ───────────────── */
/* Children of .reveal start invisible; once .show is added (in cinema
   mode, after the camera lands), they fade up in sequence. */
.reveal > *{opacity:0;transform:translateY(12px);
  transition:opacity 520ms cubic-bezier(0.2,0,0,1),
             transform 520ms cubic-bezier(0.2,0,0,1);
  transition-delay:var(--d,0ms)}
.slide.active .reveal > *{opacity:1;transform:none}

/* ─── Print: linear sequence of 24 slides ───────────────── */
@media print{
  @page{size:1280px 720px;margin:0}
  html,body{overflow:visible;height:auto;background:#000}
  #deck{position:static;overflow:visible;height:auto}
  #stage{position:static;transform:none !important;
    transition:none;width:auto;height:auto}
  .slide{position:relative !important;left:0 !important;top:0 !important;
    page-break-after:always;break-after:page;margin:0;outline:none !important;
    box-shadow:none !important}
  .deck-hud,.cinema-hud,.key-hint,.act-label{display:none !important}
  .reveal > *{opacity:1 !important;transform:none !important}
}

/* ─── Shared section styles (extracted from DS templates) ─── */
.slide .lg{position:absolute;right:60px;top:54px;height:32px;z-index:5;
  pointer-events:none}
.slide .eyebrow-rooflines{font-family:"Space Grotesk",sans-serif;font-weight:500;
  font-size:13px;line-height:1;letter-spacing:.02em;color:#828282;
  text-transform:none;margin:0 0 14px}
.slide .h1-slide{font-family:"Space Grotesk",sans-serif;font-weight:500;
  font-size:56px;line-height:1.05;letter-spacing:-.02em;color:#fff;margin:0;
  max-width:920px}
.slide .h1-slide.small{font-size:44px}
.slide .h1-slide.large{font-size:68px}
.slide .head{position:absolute;left:60px;top:60px;z-index:5;max-width:920px}
.slide .footer{position:absolute;left:60px;right:60px;bottom:30px;
  display:flex;justify-content:space-between;font-family:"Space Grotesk",sans-serif;
  font-size:11px;letter-spacing:.08em;color:rgba(255,255,255,.5);z-index:5;
  text-transform:none}
.slide .footer span{font-variant-numeric:tabular-nums}
.slide .vignette{position:absolute;inset:0;
  background:radial-gradient(ellipse at center,rgba(0,0,0,0) 55%,rgba(0,0,0,.5) 100%);
  pointer-events:none;z-index:1}

/* Big number gradient (used for the green/teal hero numbers) */
.num-grad{font-family:"Space Grotesk",sans-serif;font-weight:500;
  letter-spacing:-.04em;line-height:1;
  background:linear-gradient(115deg,#5CB675 0%,#1FCBA8 45%,#00B4BE 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.num-white{font-family:"Space Grotesk",sans-serif;font-weight:500;
  letter-spacing:-.04em;line-height:1;color:#fff}

/* Soft mesh blob (for non-peak ambient slides) */
.blob{position:absolute;border-radius:50%;mix-blend-mode:screen;
  pointer-events:none;filter:blur(120px)}

/* ─── Icon-circle (Lucide in brand-gradient circle) ───────── */
/* "Warmth cue" — Lucide outline icons in monochrome circles read cold;
   inside the gradient circle they read osapiens-warm.            */
.icon-circle{display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#4BC676 0%,#00B3BE 100%);
  border-radius:50%;flex:none;
  box-shadow:0 8px 20px rgba(0,179,190,0.18),0 0 0 1px rgba(255,255,255,0.05)}
.icon-circle.s56{width:56px;height:56px}
.icon-circle.s48{width:48px;height:48px}
.icon-circle.s64{width:64px;height:64px}
.icon-circle.s40{width:40px;height:40px}
.icon-circle.s32{width:32px;height:32px}
.icon-circle svg{stroke:#fff;stroke-width:2;width:50%;height:50%}
.icon-circle.s64 svg{width:48%;height:48%}
.icon-circle.s56 svg{width:46%;height:46%}
/* Soft variant for small mosaic chips (§4) — lower-key gradient */
.icon-circle.muted{background:linear-gradient(135deg,
  rgba(75,198,118,0.5) 0%,rgba(0,179,190,0.5) 100%);
  box-shadow:0 4px 12px rgba(0,179,190,0.1)}

/* WIP banner — used in §13–16 where Storylane is not yet live.
   Prominent red block by explicit patch instruction.             */
.wip-banner{width:100%;background:#D55341;color:white;
  padding:32px 24px;text-align:center;border-radius:8px;
  font-family:"Space Grotesk",sans-serif;font-weight:700;
  letter-spacing:0.08em;text-transform:uppercase;font-size:28px;line-height:1.2;
  box-shadow:0 16px 48px rgba(213,83,65,.22),0 0 0 1px rgba(213,83,65,.45)}
.wip-banner .sub{font-size:14px;font-weight:500;letter-spacing:0.02em;
  text-transform:none;opacity:0.9;margin-top:8px}

/* ─── Map-mode bird's-eye layer (active when zoom-out triggered) ─── */
body[data-mode="overview"] #stage{
  transition:transform 1400ms cubic-bezier(0.2,0,0,1)}
.closing-overlay{position:fixed;inset:0;z-index:70;display:none;
  align-items:center;justify-content:center;text-align:center;
  pointer-events:none}
body[data-mode="overview"] .closing-overlay{display:flex}
.closing-overlay .line{font-family:"Space Grotesk",sans-serif;font-weight:500;
  font-size:54px;color:#fff;letter-spacing:-.02em;line-height:1.1;
  max-width:1100px;opacity:0;transform:translateY(20px);
  transition:opacity 800ms cubic-bezier(0.2,0,0,1) 600ms,
             transform 800ms cubic-bezier(0.2,0,0,1) 600ms;
  text-shadow:0 0 60px rgba(0,179,190,0.4)}
body[data-mode="overview"] .closing-overlay .line{opacity:1;transform:none}

/* ============================================================
   MINI-MAP SIDEBAR · v4 navigation layer
   ============================================================ */
.mini-map{position:fixed;left:0;top:0;bottom:0;width:100px;z-index:55;
  background:rgba(8,12,14,0.85);backdrop-filter:blur(10px);
  border-right:1px solid rgba(255,255,255,0.06);
  display:flex;flex-direction:column;
  opacity:0;pointer-events:none;
  transition:opacity 320ms cubic-bezier(0.2,0,0,1)}
body[data-mode="cinema"] .mini-map{opacity:1;pointer-events:auto}
body[data-presenter="true"] .mini-map{opacity:0;pointer-events:none}

.mm-bands{display:flex;flex-direction:column;height:100%;width:100%;padding:18px 0}
.mm-band{position:relative;display:flex;align-items:center;justify-content:center;
  padding:14px 8px 14px 8px;background:transparent;border:0;color:inherit;
  cursor:pointer;text-align:center;outline:0;
  border-top:1px solid rgba(255,255,255,0.04);
  transition:background 220ms cubic-bezier(0.2,0,0,1)}
.mm-band:first-child{border-top:0}
.mm-band:hover{background:rgba(255,255,255,0.04)}
.mm-band.active{background:rgba(0,179,190,0.06)}

.mm-stack{display:flex;flex-direction:column;align-items:center;gap:8px;
  width:100%}
.mm-num{font-family:"Space Grotesk",sans-serif;font-weight:500;font-size:11px;
  letter-spacing:.08em;color:rgba(255,255,255,0.45);line-height:1}
.mm-band.active .mm-num{color:#fff}
.mm-name{font-family:"Space Grotesk",sans-serif;font-weight:500;font-size:11px;
  letter-spacing:.02em;color:rgba(255,255,255,0.7);line-height:1.1;
  max-width:84px;text-align:center;word-wrap:break-word}
.mm-band.active .mm-name{color:#fff}
.mm-dots{display:flex;flex-wrap:wrap;justify-content:center;gap:5px;
  max-width:80px;margin-top:4px}
.mm-dot{display:inline-block;width:6px;height:6px;border-radius:50%;
  background:transparent;border:1px solid rgba(255,255,255,0.32);
  transition:all 220ms cubic-bezier(0.2,0,0,1)}
.mm-band:hover .mm-dot{border-color:rgba(255,255,255,0.55)}
.mm-dot.active{width:10px;height:10px;background:#4BC676;
  border-color:#4BC676;box-shadow:0 0 12px rgba(75,198,118,0.7)}

/* Color-coded band lefts (subtle vertical strip) */
.mm-band::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;
  background:#4BC676;border-radius:0 2px 2px 0;
  opacity:.55;transition:opacity 220ms cubic-bezier(0.2,0,0,1)}
.mm-band.active::before{opacity:1;box-shadow:0 0 16px rgba(75,198,118,0.55)}
.mm-band.ch-1::before{background:rgba(75,198,118,0.8)}
.mm-band.ch-2::before{background:rgba(75,198,118,0.65)}
.mm-band.ch-3::before{background:rgba(0,179,190,0.65)}
.mm-band.ch-4::before{background:rgba(0,179,190,0.8)}
.mm-band.ch-5::before{background:rgba(75,198,118,0.5)}
.mm-band.ch-6::before{background:linear-gradient(180deg,#4BC676,#00B3BE)}

/* Hover flyout — chapter-expanded view (Level 2) */
.mm-flyout{position:absolute;left:100%;top:0;bottom:0;width:240px;
  background:rgba(8,12,14,0.95);backdrop-filter:blur(14px);
  border-left:1px solid rgba(0,179,190,0.18);
  border-right:1px solid rgba(255,255,255,0.04);
  padding:18px 16px;display:none;flex-direction:column;gap:14px;
  pointer-events:none;
  box-shadow:24px 0 60px rgba(0,0,0,0.45)}
.mm-band:hover .mm-flyout,
.mm-band.flyout-open .mm-flyout{display:flex;pointer-events:auto}
.mm-flyout-head{font-family:"Space Grotesk",sans-serif;font-weight:500;font-size:12px;
  letter-spacing:.08em;color:#00B3BE;text-transform:uppercase;
  border-bottom:1px solid rgba(255,255,255,0.10);padding-bottom:8px}
.mm-tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.mm-tile{position:relative;padding:10px 8px;background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.08);border-radius:4px;
  font-family:"Space Grotesk",sans-serif;font-size:13px;color:rgba(255,255,255,0.78);
  letter-spacing:.02em;cursor:pointer;text-align:left;
  transition:all 180ms cubic-bezier(0.2,0,0,1)}
.mm-tile:hover{background:rgba(0,179,190,0.10);border-color:rgba(0,179,190,0.35);
  color:#fff}
.mm-tile.active{background:linear-gradient(135deg,rgba(75,198,118,0.15),rgba(0,179,190,0.15));
  border-color:rgba(0,179,190,0.55);color:#fff;
  box-shadow:0 0 20px rgba(0,179,190,0.18)}
.mm-tile-n{font-weight:500;letter-spacing:.04em}

/* In Cinema mode, shift the deck-hud + cinema-hud to clear the sidebar */
body[data-mode="cinema"] .deck-hud{display:none}

/* ============================================================
   MAP VIEW · chapter containers (level 3)
   ============================================================ */
.chapter-box{position:absolute;border-radius:24px;
  border:2px solid rgba(255,255,255,0.16);
  background:rgba(255,255,255,0.02);
  pointer-events:none;
  transition:opacity 320ms cubic-bezier(0.2,0,0,1) 80ms,
             border-color 220ms cubic-bezier(0.2,0,0,1);
  opacity:0;z-index:5}
body[data-mode="map"] .chapter-box,
body[data-mode="overview"] .chapter-box{opacity:1;pointer-events:auto}
body[data-mode="map"] .chapter-box:hover{
  border-color:rgba(0,179,190,0.55);
  background:rgba(0,179,190,0.04);
  cursor:pointer;
  box-shadow:0 0 80px rgba(0,179,190,0.15)}
.chapter-box .ch-label{position:absolute;top:0;left:24px;
  display:flex;align-items:baseline;gap:18px;padding:14px 22px;
  background:#000;border:2px solid rgba(255,255,255,0.18);
  border-radius:10px;
  /* Counter-scale: in map mode the stage shrinks (~0.13×), so we
     enlarge the label by the inverse to keep it readable at viewport size. */
  transform:translateY(-50%) scale(calc(1 / var(--stage-scale, 1)));
  transform-origin:left center;
  font-family:"Space Grotesk",sans-serif;line-height:1;
  white-space:nowrap;z-index:6}
.chapter-box .ch-num{font-weight:600;font-size:13px;letter-spacing:.10em;
  color:#00B3BE}
.chapter-box .ch-name{font-weight:500;font-size:22px;letter-spacing:-.01em;color:#fff}
.chapter-box .ch-count{font-size:13px;letter-spacing:.04em;color:rgba(255,255,255,0.5)}

/* Per-chapter color tint on the border */
.chapter-box.ch-1{border-color:rgba(75,198,118,0.45)}
.chapter-box.ch-1 .ch-label{border-color:rgba(75,198,118,0.55)}
.chapter-box.ch-1 .ch-num{color:#4BC676}
.chapter-box.ch-2{border-color:rgba(75,198,118,0.36)}
.chapter-box.ch-2 .ch-label{border-color:rgba(75,198,118,0.45)}
.chapter-box.ch-3{border-color:rgba(0,179,190,0.36)}
.chapter-box.ch-3 .ch-label{border-color:rgba(0,179,190,0.45)}
.chapter-box.ch-4{border-color:rgba(0,179,190,0.45)}
.chapter-box.ch-4 .ch-label{border-color:rgba(0,179,190,0.55)}
.chapter-box.ch-5{border-color:rgba(75,198,118,0.30)}
.chapter-box.ch-5 .ch-label{border-color:rgba(75,198,118,0.42)}
.chapter-box.ch-6{border-color:rgba(0,179,190,0.45)}
.chapter-box.ch-6 .ch-label{border-color:rgba(75,198,118,0.55);
  background:linear-gradient(135deg,rgba(75,198,118,0.04),rgba(0,179,190,0.04)),#000}

/* Map mode: slides become non-clickable as boxes (we click the box's hit area). */
body[data-mode="map"] .slide{pointer-events:auto}
body[data-mode="cinema"] .chapter-box{pointer-events:none}

/* ============================================================
   FIRST LOAD · agenda caption
   ============================================================ */
.first-load-caption{position:fixed;left:50%;bottom:80px;
  transform:translateX(-50%);z-index:80;pointer-events:none;
  font-family:"Space Grotesk",sans-serif;font-weight:500;font-size:14px;
  letter-spacing:.06em;color:rgba(255,255,255,0.55);
  background:rgba(8,12,14,0.6);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,0.08);
  padding:14px 24px;border-radius:999px;
  opacity:0;transition:opacity 600ms cubic-bezier(0.2,0,0,1) 1800ms}
.first-load-caption kbd{font-family:"Space Grotesk",sans-serif;font-weight:600;
  color:#fff;background:rgba(255,255,255,0.10);
  padding:3px 8px;border-radius:4px;margin:0 4px;font-size:12px}
body.first-load[data-mode="map"] .first-load-caption{opacity:1}
body:not(.first-load) .first-load-caption{display:none}
