/* ============================================================
   Bremanger — "Everything within reach" (interactive distance map)
   Ported from the Claude Design handoff (deep-luxe glass map UI),
   re-scoped from a full viewport into a framed, fullscreen-able box.
   All experience UI lives inside `.reach-stage`; the article chrome
   (heading + ingress) lives in `.reach-page` around it.
   ============================================================ */

@font-face {
  font-family: 'Glacial';
  src: url('/assets/fonts/GlacialIndifference-Regular.woff2') format('woff2'),
       url('/assets/fonts/GlacialIndifference-Regular.woff') format('woff');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Glacial';
  src: url('/assets/fonts/GlacialIndifference-Bold.woff2') format('woff2'),
       url('/assets/fonts/GlacialIndifference-Bold.woff') format('woff');
  font-weight: 700; font-style: normal; font-display: swap;
}

/* ---- design tokens (scoped to the page) ---- */
.reach-page {
  --navy:#0e2950;
  --navy-2:#0a1f3e;
  --navy-deep:#06122a;
  --blue:#5b8cf0;
  --blue-light:#cfe0fb;
  --pink:#fb3ea9;
  --pink-deep:#e02b92;
  --gold:#e7c873;
  --gold-dim:#c9ab63;

  --glass:rgba(13,29,58,.74);
  --glass-strong:rgba(9,22,46,.86);
  --glass-soft:rgba(255,255,255,.07);
  --glass-soft-2:rgba(255,255,255,.04);
  --glass-brd:rgba(255,255,255,.13);
  --glass-hi:rgba(255,255,255,.18);
  --on-glass:#eaf1ff;
  --on-glass-dim:#9fb2da;

  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Glacial',system-ui,-apple-system,sans-serif;

  --shadow-lux:0 34px 90px -32px rgba(4,12,30,.78), 0 10px 30px -16px rgba(4,12,30,.6);
  --shadow-sm:0 14px 34px -16px rgba(4,12,30,.62);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ============================================================
   Article chrome — heading + ingress around the box
   ============================================================ */
.reach-main {
  background: #06122a;
  color: #eaf1ff;
  /* top padding clears the Freysta header (~77px) + the Bremanger stripe (~60px) */
  padding: clamp(150px, 16vh, 188px) 0 clamp(56px, 8vh, 104px);
}
.reach-intro {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 clamp(20px, 5vw, 64px) clamp(28px, 4vh, 48px);
}
.reach-intro__eyebrow {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 14px;
}
.reach-intro__title {
  font-family: var(--serif);
  font-size: clamp(2.4rem, 1.6rem + 3.4vw, 4.4rem);
  font-weight: 600;
  line-height: 1.02;
  letter-spacing: -0.01em;
  color: #fff;
  margin: 0;
  text-wrap: balance;
}
.reach-intro__ingress {
  font-family: var(--sans);
  font-size: clamp(1rem, 0.95rem + 0.4vw, 1.2rem);
  line-height: 1.6;
  color: var(--on-glass-dim);
  max-width: 720px;
  margin: clamp(16px, 2.4vh, 24px) 0 0;
  text-wrap: pretty;
}

.reach-wrap {
  padding: 0 clamp(14px, 3vw, 40px);
}
.reach-note {
  max-width: 1180px;
  margin: clamp(16px, 2.4vh, 24px) auto 0;
  padding: 0 clamp(20px, 5vw, 64px);
  font-family: var(--sans);
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--on-glass-dim);
}

/* ============================================================
   The box (.reach-stage) — frames the whole experience
   ============================================================ */
.reach-stage {
  position: relative;
  width: 100%;
  max-width: 1640px;
  margin: 0 auto;
  height: clamp(560px, 78vh, 880px);
  border-radius: 28px;
  overflow: hidden;
  background: var(--navy-deep);
  color: var(--on-glass);
  font-family: var(--sans);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 50px 120px -40px rgba(4,12,30,.9), 0 18px 50px -24px rgba(4,12,30,.7);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  isolation: isolate;
}
.reach-stage *, .reach-stage *::before, .reach-stage *::after { box-sizing: border-box; }

/* cinematic vignette framing the bright map — scoped to the box */
.reach-stage::after {
  content: "";
  position: absolute; inset: 0; z-index: 3; pointer-events: none;
  background:
    radial-gradient(130% 100% at 50% 0%, transparent 52%, rgba(6,18,42,.10) 78%, rgba(6,18,42,.30) 100%),
    radial-gradient(120% 120% at 50% 120%, transparent 55%, rgba(6,18,42,.22) 100%);
}

.reach-stage #map { position: absolute; inset: 0; }
.reach-stage .mapboxgl-ctrl-logo { opacity: .45; }
.reach-stage .mapboxgl-ctrl-attrib { font-family: var(--sans); font-size: 10px; background: rgba(255,255,255,.7) !important; }

/* fullscreen: drop the framing, fill the screen */
.reach-stage:fullscreen,
.reach-stage:-webkit-full-screen {
  width: 100%; height: 100%; max-width: none;
  border-radius: 0; border: none; margin: 0;
}

/* ---- maximize / fullscreen button ---- */
.reach-max {
  position: absolute; left: 50%; bottom: 18px; transform: translateX(-50%); z-index: 11;
  display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--sans); font-size: 12px; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase; color: #fff;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,0) 40%), var(--glass);
  -webkit-backdrop-filter: blur(20px) saturate(150%); backdrop-filter: blur(20px) saturate(150%);
  border: 1px solid var(--glass-brd); border-radius: 12px; padding: 10px 14px;
  cursor: pointer; box-shadow: var(--shadow-sm), inset 0 1px 0 var(--glass-hi);
  transition: background .2s var(--ease), transform .2s var(--ease), border-color .2s var(--ease);
}
.reach-max:hover { background: rgba(255,255,255,.13); transform: translateX(-50%) translateY(-1px); border-color: rgba(251,62,169,.5); }
.reach-max svg { width: 16px; height: 16px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.reach-max__exit { display: none; }
.reach-stage:fullscreen .reach-max__enter,
.reach-stage:-webkit-full-screen .reach-max__enter { display: none; }
.reach-stage:fullscreen .reach-max__exit,
.reach-stage:-webkit-full-screen .reach-max__exit { display: inline; }

/* glass utility */
.reach-stage .glass{
  background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,0) 38%), var(--glass);
  -webkit-backdrop-filter:blur(26px) saturate(150%);
  backdrop-filter:blur(26px) saturate(150%);
  border:1px solid var(--glass-brd);
  box-shadow:var(--shadow-lux), inset 0 1px 0 var(--glass-hi);
}

/* ---- Travelling token ---- */
.travel-token{
  width:48px;height:48px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #ff66bf, var(--pink,#fb3ea9));
  border:2.5px solid rgba(255,255,255,.92);
  box-shadow:0 10px 24px -6px rgba(6,18,42,.7), 0 0 0 7px rgba(251,62,169,.16), 0 0 26px rgba(251,62,169,.55);
  display:grid;place-items:center;
  transition:background .25s var(--ease,ease), box-shadow .25s var(--ease,ease);
}
.travel-token--fly{
  background:radial-gradient(circle at 35% 30%, #2b4f8f, #0e2950);
  box-shadow:0 10px 24px -6px rgba(6,18,42,.7), 0 0 0 7px rgba(91,140,240,.18), 0 0 24px rgba(91,140,240,.5);
}
.travel-token__icon{width:24px;height:24px;display:block;color:#fff;transition:transform .12s linear;}
.travel-token__icon svg{width:100%;height:100%;display:block;fill:currentColor;}

/* ---- Place pins ---- */
.pin{display:flex;flex-direction:column;align-items:center;gap:7px;pointer-events:none;}
.pin__dot{
  width:15px;height:15px;border-radius:50%;
  background:#0e2950;border:2.5px solid #fff;
  box-shadow:0 5px 14px -3px rgba(6,18,42,.6);
}
.pin--hub .pin__dot{
  width:20px;height:20px;
  background:radial-gradient(circle at 35% 30%, #ff66bf, #fb3ea9);
  box-shadow:0 0 0 5px rgba(251,62,169,.18), 0 0 18px rgba(251,62,169,.55), 0 5px 14px -3px rgba(6,18,42,.6);
}
.pin--air .pin__dot{background:#5b8cf0;}
.pin--dest .pin__dot{background:radial-gradient(circle at 35% 30%, #ff66bf, #fb3ea9);box-shadow:0 0 0 4px rgba(251,62,169,.16),0 5px 14px -3px rgba(6,18,42,.6);}
.pin__label{
  font-family:var(--sans);font-size:12.5px;font-weight:700;letter-spacing:.015em;color:var(--on-glass);
  background:var(--glass-strong);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  padding:4px 11px;border-radius:999px;white-space:nowrap;
  border:1px solid var(--glass-brd);
  box-shadow:0 8px 20px -8px rgba(6,18,42,.7), inset 0 1px 0 var(--glass-hi);
}
.pin--hub .pin__label{border-color:rgba(251,62,169,.4);box-shadow:0 8px 20px -8px rgba(6,18,42,.7), 0 0 0 1px rgba(251,62,169,.18), inset 0 1px 0 var(--glass-hi);}

/* ===== UI overlay (anchored to the box) ===== */
.reach-stage .ui{position:absolute;inset:0;pointer-events:none;z-index:5;}
.reach-stage .ui > *{pointer-events:auto;}

/* top-left cluster: brand + language switch */
.topbar{position:absolute;top:22px;left:24px;display:flex;align-items:center;gap:12px;z-index:6;
  opacity:0;transform:translateY(-10px);}
.is-ready .topbar{animation:riseIn .7s var(--ease) .05s forwards;}

.brand{
  display:flex;align-items:center;gap:13px;
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,0) 40%), var(--glass);
  -webkit-backdrop-filter:blur(22px) saturate(150%);backdrop-filter:blur(22px) saturate(150%);
  padding:11px 19px 11px 13px;border-radius:16px;
  border:1px solid var(--glass-brd);
  box-shadow:var(--shadow-sm), inset 0 1px 0 var(--glass-hi);
}
.brand__logo{width:36px;height:36px;flex:none;filter:drop-shadow(0 4px 10px rgba(251,62,169,.35));}
.brand__txt{line-height:1.05;}
.brand__name{font-family:var(--sans);font-size:18px;font-weight:700;color:#fff;letter-spacing:.01em;}
.brand__tag{font-family:var(--sans);font-size:10px;color:var(--gold);letter-spacing:.22em;text-transform:uppercase;margin-top:3px;}

.lang{
  display:flex;align-items:center;gap:2px;
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,0) 40%), var(--glass);
  -webkit-backdrop-filter:blur(22px) saturate(150%);backdrop-filter:blur(22px) saturate(150%);
  padding:4px;border-radius:13px;
  border:1px solid var(--glass-brd);
  box-shadow:var(--shadow-sm), inset 0 1px 0 var(--glass-hi);
}
.lang__btn{
  font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.1em;
  color:var(--on-glass-dim);background:transparent;border:none;border-radius:9px;
  padding:8px 13px;cursor:pointer;transition:color .2s var(--ease), background .2s var(--ease);
}
.lang__btn:hover{color:#fff;}
.lang__btn[aria-pressed="true"]{background:var(--glass-soft);color:#fff;box-shadow:inset 0 0 0 1px var(--glass-brd);}

/* ---- left control panel ---- */
.panel{
  position:absolute;top:96px;left:24px;width:352px;max-height:calc(100% - 140px);
  display:flex;flex-direction:column;gap:20px;
  background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,0) 30%), var(--glass);
  -webkit-backdrop-filter:blur(28px) saturate(150%);backdrop-filter:blur(28px) saturate(150%);
  border:1px solid var(--glass-brd);
  border-radius:26px;padding:26px 24px 22px;
  box-shadow:var(--shadow-lux), inset 0 1px 0 var(--glass-hi);overflow:auto;
  transition:opacity .55s var(--ease), transform .55s var(--ease);
  opacity:0;transform:translateY(14px);
}
.is-ready .panel{animation:riseIn .8s var(--ease) .12s forwards;}
.panel.is-hidden{opacity:0!important;transform:translateX(-22px);pointer-events:none;}
.panel::-webkit-scrollbar{width:8px;}
.panel::-webkit-scrollbar-thumb{background:rgba(255,255,255,.16);border-radius:4px;border:2px solid transparent;background-clip:content-box;}

.panel__kicker{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);}
.panel__title{font-family:var(--serif);font-size:34px;font-weight:600;line-height:1.0;margin:11px 0 0;letter-spacing:0;color:#fff;text-wrap:balance;}
.panel__lead{font-family:var(--sans);font-size:14px;line-height:1.55;color:var(--on-glass-dim);margin:12px 0 0;}

.story-cta{
  width:100%;display:flex;align-items:center;justify-content:center;gap:11px;
  font-family:var(--sans);font-size:14px;font-weight:700;letter-spacing:.01em;color:#fff;
  background:var(--glass-soft);border:1px solid var(--glass-brd);border-radius:14px;padding:14px;cursor:pointer;
  box-shadow:inset 0 1px 0 var(--glass-hi);
  transition:background .2s var(--ease), transform .2s var(--ease), border-color .2s var(--ease);
}
.story-cta:hover{background:rgba(255,255,255,.12);transform:translateY(-1px);border-color:rgba(251,62,169,.5);}
.story-cta__play{width:25px;height:25px;border-radius:50%;background:radial-gradient(circle at 35% 30%, #ff66bf, var(--pink));display:grid;place-items:center;flex:none;box-shadow:0 0 16px rgba(251,62,169,.55);}
.story-cta__play svg{width:11px;height:11px;fill:#fff;margin-left:1px;}

.dgroup{display:flex;flex-direction:column;gap:11px;}
.dgroup__head{display:flex;align-items:baseline;justify-content:space-between;margin-top:4px;
  padding-bottom:9px;border-bottom:1px solid rgba(255,255,255,.09);}
.dgroup__label{font-family:var(--serif);font-size:21px;font-weight:600;color:#fff;letter-spacing:0;}
.dgroup__sub{font-family:var(--sans);font-size:10px;color:var(--gold-dim);letter-spacing:.14em;text-transform:uppercase;}
.chips{display:flex;flex-wrap:wrap;gap:8px;}
.chip{
  font-family:var(--sans);font-size:13.5px;font-weight:700;color:var(--on-glass);
  background:var(--glass-soft);border:1px solid var(--glass-brd);border-radius:999px;
  padding:9px 16px;cursor:pointer;transition:all .2s var(--ease);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.chip:hover{background:rgba(255,255,255,.13);transform:translateY(-1.5px);border-color:rgba(255,255,255,.28);}
.chip[aria-pressed="true"]{
  background:radial-gradient(circle at 30% 20%, #ff58b9, var(--pink));color:#fff;border-color:transparent;
  box-shadow:0 10px 24px -8px rgba(251,62,169,.75), 0 0 20px rgba(251,62,169,.4);
}
.chip:disabled{opacity:.4;cursor:default;transform:none;}

/* ---- summary card ---- */
.summary{
  position:absolute;right:24px;bottom:24px;width:336px;
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,0) 26%), var(--glass-strong);
  -webkit-backdrop-filter:blur(30px) saturate(150%);backdrop-filter:blur(30px) saturate(150%);
  border:1px solid var(--glass-brd);border-radius:24px;
  box-shadow:var(--shadow-lux), inset 0 1px 0 var(--glass-hi);
  overflow:hidden;transform:translateY(16px) scale(.99);opacity:0;filter:blur(4px);
  transition:opacity .75s var(--ease),transform .8s var(--ease),filter .75s var(--ease);
}
.summary.is-on{opacity:1;transform:translateY(0) scale(1);filter:blur(0);}
.summary__head{padding:18px 24px 0;display:flex;align-items:center;gap:9px;}
.summary__head::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 10px var(--gold);flex:none;}
.summary__route{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--on-glass-dim);}
.summary__body{padding:8px 24px 24px;}
.summary__big{display:flex;align-items:baseline;gap:11px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.1);position:relative;}
.summary__big::after{content:"";position:absolute;left:0;bottom:-1px;width:54px;height:1px;background:linear-gradient(90deg, var(--gold), transparent);}
.summary__num{font-family:var(--serif);font-size:74px;font-weight:600;line-height:.82;color:#fff;letter-spacing:-.01em;font-variant-numeric:lining-nums;}
.summary__unit{font-family:var(--sans);font-size:14px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);}
.summary__approx{font-family:var(--sans);font-size:11.5px;color:var(--on-glass-dim);margin:14px 0 0;letter-spacing:.01em;}
.legs{list-style:none;margin:16px 0 0;padding:0;display:flex;flex-direction:column;gap:12px;}
.leg{display:flex;align-items:center;gap:12px;}
.leg__ico{width:32px;height:32px;border-radius:10px;flex:none;display:grid;place-items:center;background:var(--glass-soft);border:1px solid var(--glass-brd);color:var(--on-glass);}
.leg__ico svg{width:17px;height:17px;fill:currentColor;}
.leg--fly .leg__ico{background:radial-gradient(circle at 35% 30%, #2b4f8f, var(--navy));color:#fff;border-color:transparent;}
.leg__txt{font-family:var(--sans);font-size:13px;font-weight:700;color:var(--on-glass);line-height:1.2;}
.leg__time{margin-left:auto;font-family:var(--sans);font-size:12.5px;color:var(--on-glass-dim);font-weight:700;white-space:nowrap;font-variant-numeric:tabular-nums;}

.summary__replay{
  margin-top:20px;width:100%;font-family:var(--sans);font-size:12px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:#fff;
  background:radial-gradient(circle at 30% 20%, #ff58b9, var(--pink));
  border:none;border-radius:999px;padding:13px;cursor:pointer;transition:transform .2s var(--ease), box-shadow .2s var(--ease);
  box-shadow:0 10px 24px -10px rgba(251,62,169,.7);
}
.summary__replay:hover{transform:translateY(-1px);box-shadow:0 14px 30px -10px rgba(251,62,169,.85), 0 0 22px rgba(251,62,169,.4);}
.summary__place{font-family:var(--serif);font-size:24px;font-weight:600;color:#fff;margin:14px 0 4px;letter-spacing:0;}

/* progress chip while travelling */
.status{
  position:absolute;left:50%;top:24px;transform:translateX(-50%) translateY(-8px);
  background:var(--glass-strong);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);
  color:#fff;border:1px solid var(--glass-brd);border-radius:999px;padding:10px 22px;
  font-family:var(--sans);font-size:13px;font-weight:700;letter-spacing:.04em;
  box-shadow:var(--shadow-sm), inset 0 1px 0 var(--glass-hi);
  opacity:0;transition:opacity .35s var(--ease), transform .35s var(--ease);display:flex;align-items:center;gap:11px;z-index:7;}
.status.is-on{opacity:1;transform:translateX(-50%) translateY(0);}
.status__dot{width:8px;height:8px;border-radius:50%;background:var(--pink);box-shadow:0 0 10px var(--pink);animation:pulse 1.1s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.35;transform:scale(.8);}}

/* ---- loading: cinematic brand reveal ---- */
.loading{position:absolute;inset:0;display:grid;place-items:center;z-index:20;
  background:
    radial-gradient(120% 90% at 50% 30%, #143a6b 0%, var(--navy-2) 45%, var(--navy-deep) 100%);
  transition:opacity .7s var(--ease);}
.loading.is-hidden{opacity:0;pointer-events:none;}
.loading__inner{text-align:center;display:flex;flex-direction:column;align-items:center;}
.loading__logo{width:60px;height:60px;opacity:0;transform:scale(.7) translateY(8px);
  filter:drop-shadow(0 8px 24px rgba(251,62,169,.45));
  animation:logoIn 1s var(--ease) .1s forwards;}
.loading__name{font-family:var(--serif);font-size:34px;font-weight:600;color:#fff;margin-top:16px;letter-spacing:.02em;
  opacity:0;animation:fadeUp .9s var(--ease) .35s forwards;}
.loading__bar{width:120px;height:2px;border-radius:2px;background:rgba(255,255,255,.14);overflow:hidden;margin:22px 0 14px;
  opacity:0;animation:fadeUp .9s var(--ease) .5s forwards;}
.loading__bar span{display:block;height:100%;width:40%;border-radius:2px;
  background:linear-gradient(90deg, transparent, var(--pink), var(--gold), transparent);
  animation:slide 1.4s ease-in-out infinite;}
.loading__txt{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--on-glass-dim);
  opacity:0;animation:fadeUp .9s var(--ease) .65s forwards;}

@keyframes logoIn{to{opacity:1;transform:scale(1) translateY(0);}}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
@keyframes slide{0%{transform:translateX(-120%);}100%{transform:translateX(320%);}}
@keyframes riseIn{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:translateY(0);}}

/* ===== story narration card (top-right) ===== */
.storybar{
  position:absolute;top:22px;right:24px;width:418px;max-height:calc(100% - 44px);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,0) 24%), var(--glass-strong);
  -webkit-backdrop-filter:blur(30px) saturate(150%);backdrop-filter:blur(30px) saturate(150%);
  border:1px solid var(--glass-brd);
  border-radius:26px;box-shadow:var(--shadow-lux), inset 0 1px 0 var(--glass-hi);overflow:hidden;
  display:flex;flex-direction:column;
  opacity:0;pointer-events:none;transform:translateY(-16px) scale(.985);
  transition:opacity .75s var(--ease), transform .75s var(--ease), filter .75s var(--ease);z-index:9;
  filter:blur(4px);
}
.storybar.is-on{opacity:1;transform:none;pointer-events:auto;filter:blur(0);}
.storybar__media{width:100%;height:220px;background:var(--navy-2);flex:none;position:relative;}
.storybar__media::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg, transparent 55%, rgba(9,22,46,.5) 100%);}
.storybar__media .sb-img{position:absolute;inset:0;display:block;width:100%;height:100%;object-fit:cover;opacity:1;transition:opacity .8s var(--ease);}
.storybar__media .sb-img--enter{opacity:0;}
.storybar__body{padding:22px 24px 22px;display:flex;flex-direction:column;}

@keyframes settleIn{from{opacity:0;}to{opacity:1;}}
.storybar.is-swap .storybar__body{animation:settleIn .85s var(--ease) both;}
.storybar__kicker{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);}
.storybar__title{font-family:var(--serif);font-size:34px;font-weight:600;color:#fff;letter-spacing:0;line-height:1.0;margin:7px 0 10px;}
.storybar__text{font-family:var(--sans);font-size:15px;line-height:1.55;color:var(--on-glass-dim);margin:0;text-wrap:pretty;}
.storybar__meta{margin-top:16px;display:flex;align-items:center;gap:14px;}
.storybar__badge{display:inline-flex;align-items:center;gap:8px;background:var(--glass-soft);border:1px solid var(--glass-brd);color:#fff;border-radius:999px;padding:6px 14px 6px 9px;font-family:var(--sans);font-size:13px;font-weight:700;white-space:nowrap;box-shadow:inset 0 1px 0 rgba(255,255,255,.08);}
.storybar__ico{width:18px;height:18px;display:grid;place-items:center;}
.storybar__ico svg{width:16px;height:16px;fill:var(--gold);}
.storybar__dots{display:flex;gap:6px;}
.storybar__dots i{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.2);transition:all .3s var(--ease);}
.storybar__dots i.on{background:var(--pink);width:20px;border-radius:4px;box-shadow:0 0 12px rgba(251,62,169,.6);}
.storybar__foot{display:flex;align-items:center;justify-content:space-between;margin-top:20px;padding-top:16px;border-top:1px solid rgba(255,255,255,.1);}
.storybar__skip{border:none;background:none;color:var(--on-glass-dim);font-family:var(--sans);font-size:13px;font-weight:700;cursor:pointer;padding:0;transition:color .2s var(--ease);}
.storybar__skip:hover{color:#fff;}
.storybar__next{border:none;background:none;color:#fff;font-family:var(--sans);font-weight:700;font-size:13.5px;cursor:pointer;opacity:.8;padding:0;transition:opacity .2s var(--ease);}
.storybar__next:hover{opacity:1;}
.storybar__end{padding:30px 26px 30px;}
.storybar__end .storybar__kicker{color:var(--gold);}
.storybar__end .storybar__title{font-size:38px;margin-top:8px;}
.storybar__end .storybar__text{margin-top:10px;}
.storybar__cta{margin-top:20px;border:none;background:radial-gradient(circle at 30% 20%, #ff58b9, var(--pink));color:#fff;font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.1em;text-transform:uppercase;padding:14px 26px;border-radius:999px;cursor:pointer;transition:transform .2s var(--ease), box-shadow .2s var(--ease);box-shadow:0 10px 24px -10px rgba(251,62,169,.7);}
.storybar__cta:hover{transform:translateY(-1px);box-shadow:0 14px 30px -10px rgba(251,62,169,.85), 0 0 22px rgba(251,62,169,.4);}

/* detail card swap during story */
.summary.is-swap .summary__head,
.summary.is-swap .summary__body{animation:settleIn .8s var(--ease) both;}

@media (prefers-reduced-motion:reduce){
  .loading__logo,.loading__name,.loading__bar,.loading__txt,.is-ready .topbar,.is-ready .panel{animation:none!important;opacity:1!important;transform:none!important;}
  .storybar,.summary{filter:none!important;}
  .storybar.is-swap *,.summary.is-swap *{animation:none!important;}
  .storybar__media .sb-img{transition:none!important;}
}

/* ===== responsive: cards reflow inside the box on narrow widths ===== */
@media (max-width:900px){
  .reach-stage{height:clamp(540px, 82vh, 760px);border-radius:22px;}
  .topbar{top:14px;left:14px;}
  .panel{top:auto;bottom:0;left:0;right:0;width:auto;max-height:56%;border-radius:22px 22px 0 0;padding-bottom:24px;}
  .summary{left:12px;right:12px;bottom:auto;top:74px;width:auto;}
  .brand__tag{display:none;}
  .panel__title{font-size:30px;}
  .reach-max{left:auto;right:12px;bottom:auto;top:14px;transform:none;padding:10px;gap:0;}
  .reach-max:hover{transform:translateY(-1px);}
  .reach-max .reach-max__label{display:none;}
  .storybar{top:12px;left:12px;right:12px;width:auto;}
  .storybar__media{height:150px;}
  .storybar__title{font-size:28px;}
  .summary__num{font-size:60px;}
}
