/* ============================================================
   MON MOORE - "the crown is earned, not worn"
   A worldly, gold-led journey. Introspective, personal, gifted.
   System first, then compose. Mobile is the main stage.
   ============================================================ */

/* ---- TOKENS ------------------------------------------------ */
:root{
  /* spacing - 4-based ramp, 16px heartbeat */
  --space-1:4px;  --space-2:8px;  --space-3:12px; --space-4:16px;
  --space-5:24px; --space-6:32px; --space-7:48px; --space-8:64px;
  --space-9:96px; --space-10:128px; --space-11:160px; --space-12:224px;

  /* type ramp - 1.333 perfect fourth, base 16 */
  --ms-0:1rem; --ms-1:1.333rem; --ms-2:1.777rem; --ms-3:2.369rem;
  --ms-4:3.157rem; --ms-5:4.209rem; --ms-6:5.61rem; --ms-7:7.478rem;
  --ms-dn1:0.8rem; --ms-dn2:0.64rem;

  /* color - gold leads; warm dark for depth, his real worlds for life */
  --ink:#0B0908; --ink-2:#13100B; --ink-3:#1d1810; --ink-deep:#060504;
  --gold:#E6A52B; --gold-bright:#F7C24A; --gold-deep:#A9761B;
  --bone:#F3ECDD; --bone-mut:#b3a892;

  /* his real worlds - sampled from his photos, used as living washes */
  --w-cafe:#E0A21B;    /* the yellow Onitsuka Tiger café */
  --w-autumn:#C0492A;  /* red-orange leaves */
  --w-venice:#C8765A;  /* Venice terracotta */
  --w-canal:#365C4B;   /* canal green */
  --w-water:#1E94B8;   /* tropical turquoise */
  --w-sky:#79B7D6;

  /* semantic */
  --surface:var(--ink); --ink-fg:var(--bone); --ink-muted:#9a8f7c;
  --accent:var(--gold); --accent-ink:#1a1206;
  --line:color-mix(in srgb, var(--bone) 12%, transparent);
  --wash:var(--gold); /* current section wash, swapped live on the Story page */

  /* radius */
  --r-xs:4px; --r-sm:8px; --r-md:12px; --r-lg:16px; --r-xl:24px; --r-pill:999px;

  /* elevation - warm ink, light from above */
  --e1:0 1px 2px color-mix(in srgb,#000 30%,transparent), 0 1px 1px color-mix(in srgb,#000 22%,transparent);
  --e2:0 1px 2px color-mix(in srgb,#000 32%,transparent), 0 6px 14px color-mix(in srgb,#000 26%,transparent);
  --e3:0 2px 4px color-mix(in srgb,#000 36%,transparent), 0 16px 30px color-mix(in srgb,#000 30%,transparent);
  --glow:0 0 24px color-mix(in srgb,var(--gold) 40%,transparent);

  /* motion */
  --ease-standard:cubic-bezier(.22,.61,.36,1);
  --ease-expressive:cubic-bezier(.16,1,.30,1);
  --dur-micro:120ms; --dur-element:200ms; --dur-section:320ms; --dur-cinematic:600ms;
  --stagger:75ms;

  /* layout */
  font-size:clamp(1rem,.93rem + .31vw,1.1875rem);
  --section-y:clamp(4rem,2.6rem + 6vw,8.5rem);
  --gutter:clamp(1.25rem,.8rem + 2vw,3rem);
  --edge:clamp(1.1rem,.6rem + 1.4vw,1.75rem);
  --measure:60ch;
  --shell:min(100% - 2*var(--edge),72rem);
  --nav-h:64px;
  --font-display:"Bricolage Grotesque",system-ui,sans-serif;
  --font-script:"Loved by the King",system-ui,cursive;
}

/* ---- VIEW TRANSITIONS (page to page) ---------------------- */
@view-transition{ navigation:auto; }
::view-transition-old(root){animation:vtFade .4s var(--ease-standard) both}
::view-transition-new(root){animation:vtWipe .62s var(--ease-expressive) both}
@keyframes vtFade{to{opacity:0}}
@keyframes vtWipe{
  from{clip-path:inset(100% 0 0 0);filter:brightness(1.6) saturate(1.3)}
  to{clip-path:inset(0 0 0 0);filter:none}
}
/* the brand lock-up persists seamlessly while content wipes in gold */

/* ---- RESET ------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  background:var(--ink); color:var(--ink-fg);
  font-family:"Inter",system-ui,sans-serif; font-weight:400; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,iframe,video{display:block;max-width:100%}
img{height:auto}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:var(--accent-ink)}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:var(--r-xs)}

/* ---- TYPE ROLES ------------------------------------------- */
.eyebrow{
  font-family:"Inter",sans-serif; font-size:var(--ms-dn1); font-weight:600;
  text-transform:uppercase; letter-spacing:.24em; color:var(--gold);
  text-align:center; margin-bottom:var(--space-5);
}
h1,h2,h3,.flagship__title{
  font-family:var(--font-display); font-weight:800;
  line-height:.95; letter-spacing:-.01em; text-transform:uppercase;
  text-wrap:balance;
}
p{text-wrap:pretty}
.script{font-family:var(--font-script);text-transform:none;letter-spacing:0;font-weight:400;line-height:1}

/* ---- SHELL / SECTION -------------------------------------- */
.shell{width:var(--shell);margin-inline:auto;padding-inline:var(--edge)}
.section{padding-block:var(--section-y)}
.section__head{font-size:clamp(1.8rem,4.5vw,2.8rem);text-align:center;color:var(--bone);margin-bottom:var(--space-4)}
.section__lead{max-width:var(--measure);margin:0 auto var(--space-8);text-align:center;color:var(--ink-muted);font-size:var(--ms-1)}

/* ---- THE CROWN MARK (his real embroidered crown, alive) ---- */
.crownmark{position:relative;display:inline-grid;isolation:isolate;line-height:0}
.crownmark__img{width:100%;height:auto;
  filter:drop-shadow(0 6px 22px color-mix(in srgb,var(--gold) 32%,transparent));
  animation:crownGlow 5s ease-in-out infinite}
.crownmark__sheen{position:absolute;inset:0;pointer-events:none;z-index:1;
  background:linear-gradient(108deg,transparent 42%,color-mix(in srgb,#fff 78%,transparent) 50%,transparent 58%);
  background-size:260% 100%;background-repeat:no-repeat;
  -webkit-mask:url("/assets/crown.webp") center/contain no-repeat;
  mask:url("/assets/crown.webp") center/contain no-repeat;
  mix-blend-mode:screen;opacity:0;
  animation:crownSheen 5.5s var(--ease-expressive) infinite}
@keyframes crownGlow{
  0%,100%{filter:drop-shadow(0 6px 18px color-mix(in srgb,var(--gold) 26%,transparent))}
  50%{filter:drop-shadow(0 8px 30px color-mix(in srgb,var(--gold-bright) 55%,transparent))}}
@keyframes crownSheen{
  0%{background-position:175% 0;opacity:0}
  8%{opacity:.95}
  34%{background-position:-85% 0;opacity:0}
  100%{background-position:-85% 0;opacity:0}}

/* the glow that comes off the TOP of the crown (the light-bloom) */
.bloom{position:relative;display:grid;place-items:center;isolation:isolate}
.bloom::before{content:"";position:absolute;z-index:-1;left:50%;top:-22%;
  width:128%;aspect-ratio:1/1;transform:translateX(-50%);
  background:radial-gradient(circle at 50% 50%,color-mix(in srgb,var(--gold-bright) 60%,transparent),color-mix(in srgb,var(--gold) 18%,transparent) 42%,transparent 66%);
  filter:blur(38px);opacity:.5;
  animation:bloomBreathe 5s var(--ease-expressive) infinite}
.bloom::after{content:"";position:absolute;z-index:-1;left:50%;top:-72%;
  width:46%;height:140%;transform:translateX(-50%);
  background:linear-gradient(to top,color-mix(in srgb,var(--gold-bright) 42%,transparent),transparent 72%);
  -webkit-mask:linear-gradient(to top,#000,transparent);mask:linear-gradient(to top,#000,transparent);
  filter:blur(26px);opacity:.4;
  animation:rayBreathe 6.5s ease-in-out infinite}
@keyframes bloomBreathe{0%,100%{opacity:.42;transform:translateX(-50%) scale(.92)}50%{opacity:.85;transform:translateX(-50%) scale(1.14)}}
@keyframes rayBreathe{0%,100%{opacity:.24;transform:translateX(-50%) scaleY(.92)}50%{opacity:.55;transform:translateX(-50%) scaleY(1.06)}}

/* ---- GRAIN / CURSOR / SCROLLBAR --------------------------- */
/* grain rides on body::before so it stays a pure decorative layer (no phantom element) */
body::before{content:"";position:fixed;inset:-50%;z-index:60;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 6s steps(6) infinite}
.grain{display:none}
@keyframes grain{0%{transform:translate(0,0)}20%{transform:translate(-6%,4%)}40%{transform:translate(4%,-6%)}60%{transform:translate(-4%,6%)}80%{transform:translate(6%,-4%)}100%{transform:translate(0,0)}}

.cursor{position:fixed;top:0;left:0;width:34px;height:34px;border:1.5px solid var(--gold);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:70;opacity:0;transition:opacity .3s,width .2s,height .2s,background .2s;mix-blend-mode:screen}
.cursor.is-on{opacity:.85}
.cursor.is-hot{width:54px;height:54px;background:color-mix(in srgb,var(--gold) 16%,transparent)}
@media (hover:none){.cursor{display:none}}

.scrollbar{position:fixed;top:0;left:0;right:0;height:2px;z-index:80;background:transparent}
.scrollbar span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold-deep),var(--gold-bright));box-shadow:var(--glow)}

/* ---- LOADER (first visit only) ---------------------------- */
.loader{position:fixed;inset:0;z-index:100;background:radial-gradient(120% 90% at 50% 36%,var(--ink-2),var(--ink-deep));display:grid;place-content:center;justify-items:center;gap:var(--space-5);transition:opacity .7s var(--ease-expressive)}
.loader.done{opacity:0;pointer-events:none}
.loader__mark{width:104px}
.loader__word{display:flex;gap:.04em;font-family:var(--font-display);font-weight:800;text-transform:uppercase;font-size:var(--ms-2);letter-spacing:.12em;color:var(--bone)}
.loader__word .sp{width:.4em}
.loader__word span{opacity:0;transform:translateY(14px);animation:wordIn .5s var(--ease-expressive) forwards}
.loader__word span:nth-child(1){animation-delay:.15s}.loader__word span:nth-child(2){animation-delay:.21s}.loader__word span:nth-child(3){animation-delay:.27s}.loader__word span:nth-child(5){animation-delay:.36s}.loader__word span:nth-child(6){animation-delay:.42s}.loader__word span:nth-child(7){animation-delay:.48s}.loader__word span:nth-child(8){animation-delay:.54s}.loader__word span:nth-child(9){animation-delay:.6s}
@keyframes wordIn{to{opacity:1;transform:translateY(0)}}

/* ---- GRAND INTRO (home, first visit): crown zooms in, site opens ----
   absolute (not fixed): a one-shot splash at the top that lifts away, never a persistent layer */
.intro-seq{position:absolute;inset:0;height:100svh;z-index:120;overflow:hidden;display:grid;place-items:center;background:radial-gradient(120% 100% at 50% 48%,var(--ink-2) 0%,#000 72%)}
body.intro-lock{overflow:hidden}
.intro-seq.done{opacity:0;visibility:hidden;transition:opacity .7s var(--ease-expressive),visibility .7s}
.intro-seq__stage{position:relative;display:grid;place-items:center}
.intro-seq__crown{width:clamp(120px,28vw,240px);transform-origin:center 46%;animation:introZoom 3s var(--ease-expressive) forwards}
.intro-seq__halo{position:absolute;width:130vmax;aspect-ratio:1;left:50%;top:48%;transform:translate(-50%,-50%);z-index:-1;background:radial-gradient(circle,color-mix(in srgb,var(--gold-bright) 55%,transparent),color-mix(in srgb,var(--gold) 14%,transparent) 28%,transparent 56%);filter:blur(50px);opacity:0;animation:introHalo 3s var(--ease-expressive) forwards}
.intro-seq__word{position:absolute;bottom:21%;left:0;right:0;text-align:center;font-family:var(--font-script);text-transform:none;letter-spacing:0;font-size:clamp(1.6rem,6vw,3rem);color:var(--gold-bright);opacity:0;animation:introWord 3s ease forwards}
@keyframes introZoom{0%{opacity:0;transform:scale(.35)}16%{opacity:1;transform:scale(.62)}46%{opacity:1;transform:scale(.86)}60%{transform:scale(.8)}100%{opacity:1;transform:scale(9)}}
@keyframes introHalo{0%{opacity:0}42%{opacity:.45}72%{opacity:.85}100%{opacity:0}}
@keyframes introWord{0%,28%{opacity:0;transform:translateY(14px)}48%{opacity:1;transform:none}72%{opacity:1}100%{opacity:0}}

/* ---- NAV (centered) --------------------------------------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  gap:var(--space-4);padding:var(--space-4) var(--edge);
  transition:background .4s,backdrop-filter .4s,padding .4s}
.nav.is-stuck{background:color-mix(in srgb,var(--ink) 84%,transparent);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding-block:var(--space-3)}
.nav__brand{grid-column:2;justify-self:center;display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:var(--ms-0);color:var(--bone)}
.nav__brand .crownmark{width:30px}
.nav__brand b{font-weight:700;view-transition-name:navword}
.nav__set{display:none;gap:var(--space-6);align-items:center}
.nav__set--l{grid-column:1;justify-content:flex-end}
.nav__set--r{grid-column:3;justify-content:flex-start}
.nav__set a{font-size:var(--ms-dn1);text-transform:uppercase;letter-spacing:.16em;color:var(--bone-mut);transition:color var(--dur-element) var(--ease-standard);position:relative}
.nav__set a::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:center;transition:transform var(--dur-element) var(--ease-standard)}
.nav__set a:hover,.nav__set a[aria-current="page"]{color:var(--gold)}
.nav__set a[aria-current="page"]::after,.nav__set a:hover::after{transform:scaleX(1)}
.nav__menu{grid-column:3;justify-self:end;display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;align-items:center;background:none;border:0;cursor:pointer}
.nav__menu i{display:block;width:24px;height:2px;background:var(--bone);transition:transform var(--dur-element) var(--ease-standard),opacity var(--dur-element)}
@media(min-width:54rem){
  .nav{grid-template-columns:1fr auto 1fr}
  .nav__set{display:inline-flex}
  .nav__menu{display:none}
}

/* mobile full-screen centered menu */
.menu{position:fixed;inset:0;z-index:55;display:none;place-content:center;justify-items:center;gap:var(--space-5);
  background:radial-gradient(120% 90% at 50% 30%,var(--ink-2),var(--ink-deep))}
.menu.open{display:grid;animation:menuIn .42s var(--ease-expressive) both}
@keyframes menuIn{from{opacity:0;transform:scale(1.04)}to{opacity:1;transform:scale(1)}}
.menu__crown{width:72px;margin-bottom:var(--space-3)}
.menu a{font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:var(--ms-3);color:var(--bone);transition:color var(--dur-element)}
.menu a[aria-current="page"],.menu a:hover{color:var(--gold)}
.menu__x{position:absolute;top:var(--space-4);right:var(--edge);width:46px;height:46px;border:1px solid var(--line);border-radius:50%;background:none;color:var(--bone);font-size:22px;cursor:pointer}
body.menu-open{overflow:hidden}

/* ---- BUTTONS ---------------------------------------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:var(--ms-1);padding:var(--space-3) var(--space-6);border-radius:var(--r-pill);min-height:52px;transition:transform var(--dur-element) var(--ease-standard),box-shadow var(--dur-element),background var(--dur-element),color var(--dur-element),border-color var(--dur-element)}
.btn--gold{background:var(--gold);color:var(--accent-ink);box-shadow:var(--glow)}
.btn--gold:hover{transform:translateY(-2px);background:var(--gold-bright);box-shadow:0 0 34px color-mix(in srgb,var(--gold) 60%,transparent)}
.btn--ghost{border:1px solid var(--line);color:var(--bone)}
.btn--ghost:hover{transform:translateY(-2px);border-color:var(--gold);color:var(--gold)}
.link-arrow{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--gold);font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:var(--ms-dn1)}
.link-arrow i{transition:transform var(--dur-element) var(--ease-standard)}
a:hover .link-arrow i,.link-arrow:hover i{transform:translateX(6px)}

/* ============================================================
   HERO (Home) - the arrival
   ============================================================ */
.hero{position:relative;min-height:100svh;display:grid;place-items:center;text-align:center;overflow:hidden;isolation:isolate}
.hero__sky{position:absolute;inset:0;z-index:-3;background:
  radial-gradient(120% 84% at 50% 118%, color-mix(in srgb,var(--gold) 44%,transparent) 0%, color-mix(in srgb,var(--w-autumn) 20%,transparent) 24%, transparent 60%),
  radial-gradient(90% 60% at 50% -12%, color-mix(in srgb,var(--gold-bright) 20%,transparent), transparent 60%),
  linear-gradient(180deg,#050403 0%, var(--ink) 44%, var(--ink-2) 100%)}
.hero__sky::after{content:"";position:absolute;inset:0;background:radial-gradient(60% 50% at 50% 46%,transparent,color-mix(in srgb,var(--ink-deep) 45%,transparent));animation:skyDrift 16s ease-in-out infinite alternate}
@keyframes skyDrift{from{transform:scale(1) translateY(0)}to{transform:scale(1.1) translateY(-2%)}}
.hero__rays{position:absolute;inset:0;z-index:-2;pointer-events:none;
  background:conic-gradient(from 0deg at 50% 40%, transparent 0deg, color-mix(in srgb,var(--gold) 12%,transparent) 7deg, transparent 15deg, transparent 30deg, color-mix(in srgb,var(--gold) 9%,transparent) 37deg, transparent 45deg, transparent 60deg, color-mix(in srgb,var(--gold) 11%,transparent) 67deg, transparent 75deg);
  -webkit-mask:radial-gradient(58% 58% at 50% 40%, #000 0%, transparent 72%);mask:radial-gradient(58% 58% at 50% 40%, #000 0%, transparent 72%);
  opacity:.4;animation:raysTurn 90s linear infinite}
@keyframes raysTurn{to{transform:rotate(360deg)}}
.embers{position:absolute;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.ember{position:absolute;bottom:-24px;width:var(--s,6px);height:var(--s,6px);border-radius:50%;
  background:radial-gradient(circle,var(--gold-bright),color-mix(in srgb,var(--gold) 35%,transparent) 60%,transparent);
  opacity:0;animation:emberRise var(--d,13s) ease-in var(--delay,0s) infinite}
@keyframes emberRise{0%{opacity:0;transform:translateY(0) scale(.5)}12%{opacity:.9}85%{opacity:.45}100%{opacity:0;transform:translateY(-94vh) translateX(var(--x,24px)) scale(1.15)}}
.hero__inner{display:grid;justify-items:center;width:100%;padding:calc(var(--nav-h) + var(--space-7)) var(--edge) 0;max-width:64rem}
.hero__crown{width:clamp(104px,16vw,164px);margin-bottom:var(--space-5)}
.hero__crown.bloom::before{width:182%}
.hero__eyebrow.script{font-size:clamp(1.5rem,5vw,2.4rem);color:var(--gold);margin-bottom:var(--space-2)}
.hero__name{font-family:var(--font-display);font-size:clamp(2.6rem,10vw,7.5rem);font-weight:800;line-height:.92;color:var(--bone);letter-spacing:-.02em;max-width:100%;text-transform:uppercase;text-shadow:0 0 60px color-mix(in srgb,var(--gold) 28%,transparent)}
.hero__name .ch,.hero__name .ln{display:inline-block}
.hero__line{font-family:var(--font-script);text-transform:none;font-size:clamp(2rem,7vw,3.6rem);letter-spacing:0;line-height:1;color:var(--gold-bright);margin-top:var(--space-5);max-width:100%;filter:drop-shadow(0 2px 18px color-mix(in srgb,var(--gold) 35%,transparent))}
.hero__cta{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center;margin-top:var(--space-8)}
/* center with auto-margins, not transform: the .reveal class resets transform on reveal and would knock it off-center */
.hero__scroll{position:absolute;bottom:calc(var(--space-5) + env(safe-area-inset-bottom));left:0;right:0;margin-inline:auto;width:max-content;display:grid;justify-items:center;gap:var(--space-2);font-size:var(--ms-dn2);text-transform:uppercase;letter-spacing:.24em;color:var(--bone-mut)}
.hero__scroll i{width:1px;height:34px;background:linear-gradient(var(--gold),transparent);animation:scrollLine 1.8s ease-in-out infinite}
@keyframes scrollLine{0%,100%{transform:scaleY(.4);transform-origin:top;opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* kinetic marquee band */
.marquee{position:relative;overflow:hidden;border-block:1px solid var(--line);background:var(--ink-deep);padding-block:var(--space-5);isolation:isolate}
.marquee__row{display:flex;align-items:center;gap:var(--space-7);width:max-content;animation:marq 32s linear infinite}
.marquee__row span{font-family:var(--font-display);font-weight:800;text-transform:uppercase;font-size:clamp(1.6rem,4.5vw,2.8rem);line-height:1;letter-spacing:.01em;color:transparent;-webkit-text-stroke:1px color-mix(in srgb,var(--bone) 42%,transparent);white-space:nowrap}
.marquee__row .star{color:var(--gold);-webkit-text-stroke:0;font-family:var(--font-script);font-size:.8em}
@keyframes marq{to{transform:translateX(-50%)}}
.marquee:hover .marquee__row{animation-play-state:paused}

/* centered grids: cap the column so long headings wrap instead of overflowing */
.hero,.hero__inner,.intro,.crownsec,.crownsec__copy,.chapter__inner,.chapter__copy,.door{grid-template-columns:minmax(0,1fr)}
.hero__name,.hero__line,.hero__cta,.intro h1,.crownsec__copy,.crownsec__head,.crownsec__cta,.chapter__head{justify-self:stretch}

/* home: the journey as an editorial index (no boxes) */
.gateway{background:linear-gradient(180deg,var(--ink-2),var(--ink));padding-bottom:0}
.index{margin-top:var(--space-8);border-top:1px solid var(--line)}
.index__row{position:relative;display:flex;align-items:center;justify-content:space-between;gap:var(--space-5);
  min-height:clamp(7.5rem,20vw,12rem);
  padding:clamp(var(--space-5),4.5vw,var(--space-8)) var(--edge);
  border-bottom:1px solid var(--line);overflow:hidden;isolation:isolate;color:var(--bone)}
/* his photo lives in every row on every device (mobile is the main stage), hover lifts it */
.index__media{position:absolute;inset:0;z-index:-2;background-size:cover;background-position:center 35%;opacity:.36;transform:scale(1.05);transition:opacity .55s var(--ease-expressive),transform .9s var(--ease-expressive)}
.index__row::before{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(90deg,color-mix(in srgb,var(--ink-deep) 88%,transparent) 0%,color-mix(in srgb,var(--ink-deep) 52%,transparent) 64%,color-mix(in srgb,var(--ink-deep) 22%,transparent) 100%);
  transition:opacity .55s var(--ease-expressive)}
.index__k{font-family:var(--font-display);font-weight:800;text-transform:uppercase;font-size:clamp(1.9rem,6.5vw,4rem);line-height:.92;letter-spacing:-.02em;text-shadow:0 2px 24px rgba(0,0,0,.7);transition:transform .45s var(--ease-expressive),color .4s}
.index__meta{display:flex;align-items:center;gap:var(--space-4);flex-shrink:0}
.index__d{font-family:var(--font-script);color:var(--gold-bright);font-size:clamp(1.1rem,3.5vw,1.8rem);white-space:nowrap;line-height:1;text-shadow:0 2px 16px rgba(0,0,0,.7)}
.index__arr{font-family:var(--font-display);color:var(--gold);font-size:var(--ms-3);transition:transform .4s var(--ease-expressive)}
@media(hover:hover){
  .index__media{opacity:.26}
  .index__row:hover .index__media{opacity:.7;transform:scale(1)}
  .index__row:hover .index__k{color:var(--gold-bright);transform:translateX(14px)}
  .index__row:hover .index__arr{transform:translateX(10px)}
}

/* page intro band (non-home pages) */
.intro{position:relative;min-height:62svh;display:grid;place-items:center;text-align:center;overflow:hidden;isolation:isolate;padding:calc(var(--nav-h) + var(--space-9)) var(--edge) var(--space-9)}
.intro__bg{position:absolute;inset:0;z-index:-1;background:
  radial-gradient(100% 80% at 50% 0%, color-mix(in srgb,var(--wash) 30%,transparent), transparent 60%),
  linear-gradient(180deg,var(--ink-deep),var(--ink) 70%);transition:background .8s var(--ease-expressive)}
.intro__crown{width:84px;margin-bottom:var(--space-5)}
.intro h1{font-size:clamp(2.2rem,7vw,4.6rem);color:var(--bone);letter-spacing:-.02em}
.intro p{max-width:46ch;margin:var(--space-4) auto 0;color:var(--ink-muted);font-size:var(--ms-1)}

/* ============================================================
   STORY - the worldly photo journey (his real worlds, color washes)
   ============================================================ */
.creed{padding-block:var(--section-y);text-align:center;background:linear-gradient(180deg,var(--ink),var(--ink-2))}
.creed p{max-width:24ch;margin-inline:auto;font-family:var(--font-display);font-weight:700;text-transform:none;font-size:var(--ms-3);line-height:1.1;color:var(--bone)}
.creed p .hl{color:var(--gold-bright);font-family:var(--font-script);font-weight:400;font-size:1.15em}
.creed__sub{max-width:var(--measure);margin:var(--space-6) auto 0;font-family:"Inter",sans-serif;font-weight:400;font-size:var(--ms-1);color:var(--ink-muted);text-transform:none;line-height:1.6}

.chapters{position:relative}
.chapter{position:relative;min-height:100svh;display:grid;align-items:end;justify-items:center;text-align:center;overflow:hidden;isolation:isolate}
.chapter__bleed{position:absolute;inset:0;z-index:-2}
.chapter__bleed img{position:absolute;left:0;top:-8%;width:100%;height:116%;object-fit:cover;filter:saturate(1.14) contrast(1.05);will-change:transform}
.chapter__scrim{position:absolute;inset:0;z-index:-1;background:
  radial-gradient(110% 80% at var(--wx,50%) 22%, color-mix(in srgb,var(--wash) 34%,transparent), transparent 58%),
  linear-gradient(180deg, color-mix(in srgb,var(--ink-deep) 52%,transparent) 0%, transparent 34%, color-mix(in srgb,var(--ink-deep) 32%,transparent) 62%, color-mix(in srgb,var(--ink-deep) 90%,transparent) 100%)}
.chapter__inner{position:relative;width:var(--shell);margin-inline:auto;padding:var(--space-9) var(--edge) var(--space-11);display:grid;justify-items:center;gap:var(--space-4);max-width:48rem}
.chapter__eyebrow.script{font-size:clamp(1.4rem,4.5vw,2.1rem);color:color-mix(in srgb,var(--wash) 55%,var(--gold-bright))}
.chapter__head{font-size:clamp(2rem,5.5vw,3.4rem);color:var(--bone);text-shadow:0 6px 34px rgba(0,0,0,.55)}
.chapter__inner p{max-width:42ch;color:color-mix(in srgb,var(--bone) 92%,transparent);font-size:var(--ms-1);text-shadow:0 2px 20px rgba(0,0,0,.7)}

/* ============================================================
   MUSIC - flagship + releases + players
   ============================================================ */
.music{background:linear-gradient(180deg,var(--ink),var(--ink-2))}
.flagship{display:grid;gap:var(--space-6);align-items:center;border:1px solid var(--line);border-radius:var(--r-xl);padding:var(--space-5);background:linear-gradient(160deg,color-mix(in srgb,var(--gold) 8%,transparent),transparent 60%);transition:border-color var(--dur-section),transform var(--dur-section),box-shadow var(--dur-section);position:relative;overflow:hidden}
.flagship::before{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(60% 80% at 18% 30%,color-mix(in srgb,var(--gold) 22%,transparent),transparent 60%);opacity:.5;animation:bloomBreathe 6s var(--ease-expressive) infinite}
.flagship>*{position:relative;z-index:1}
.flagship:hover{border-color:color-mix(in srgb,var(--gold) 50%,transparent);transform:translateY(-4px);box-shadow:var(--e3)}
.flagship__art{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--e3);max-width:30rem;margin-inline:auto;width:100%}
.flagship__art img{width:100%;transition:transform 1s var(--ease-expressive)}
.flagship:hover .flagship__art img{transform:scale(1.04)}
.flagship__meta{text-align:center;display:grid;justify-items:center;gap:var(--space-3)}
.flagship__meta .eyebrow{margin:0}
.flagship__title{font-size:var(--ms-3);color:var(--bone)}
.flagship__copy{max-width:42ch;color:var(--ink-muted);font-size:var(--ms-0)}
@media(min-width:56rem){.flagship{grid-template-columns:1fr 1fr;padding:var(--space-8)}.flagship__art{margin:0}}

.releases{margin-top:var(--space-8);display:grid;grid-template-columns:1fr;gap:var(--gutter)}
@media(min-width:34rem){.releases{grid-template-columns:repeat(2,1fr)}}
@media(min-width:56rem){.releases{grid-template-columns:repeat(3,1fr)}}
.release{display:grid;gap:var(--space-3);transition:transform var(--dur-section) var(--ease-standard)}
.release:hover{transform:translateY(-6px)}
.release__art{position:relative;border-radius:var(--r-md);overflow:hidden;box-shadow:var(--e2);aspect-ratio:1}
.release__art img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease-expressive)}
.release__art::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px var(--line);border-radius:var(--r-md);opacity:0;transition:opacity var(--dur-section)}
.release:hover .release__art img{transform:scale(1.06)}
.release:hover .release__art::after{opacity:1;box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--gold) 55%,transparent), var(--glow)}
.release__row{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-3)}
.release__title{font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.01em;font-size:var(--ms-1);color:var(--bone);line-height:1.05}
.release__title em{font-style:normal;font-weight:500;font-size:var(--ms-dn1);color:var(--ink-muted);display:block;letter-spacing:.04em}
.release__year{font-variant-numeric:tabular-nums lining-nums;font-size:var(--ms-dn1);color:var(--gold);font-weight:600}

.players{display:grid;grid-template-columns:1fr;gap:var(--gutter);max-width:62rem;margin:var(--space-8) auto 0}
@media(min-width:56rem){.players{grid-template-columns:1fr 1fr;align-items:start}}
.player{border-radius:var(--r-md);overflow:hidden;box-shadow:var(--e2)}
.player iframe{width:100%;border:0;display:block}
.platforms{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center;margin-top:var(--space-8)}
.plat{font-family:var(--font-display);font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:var(--ms-dn1);padding:var(--space-3) var(--space-5);border:1px solid var(--line);border-radius:var(--r-pill);color:var(--bone-mut);transition:color var(--dur-element),border-color var(--dur-element),transform var(--dur-element)}
.plat:hover{color:var(--gold);border-color:var(--gold);transform:translateY(-2px)}

/* ============================================================
   WATCH - the freestyle, staged like a premiere
   ============================================================ */
.watch{background:radial-gradient(120% 90% at 50% 0%,var(--ink-2),var(--ink-deep))}
.vstage{position:relative;max-width:64rem;margin-inline:auto;aspect-ratio:16/9;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--e3);background:#000}
.vstage__video{width:100%;height:100%;object-fit:cover;display:block;background:#000}
.vstage__play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:92px;height:92px;border-radius:50%;border:0;cursor:pointer;background:var(--gold);box-shadow:0 0 40px color-mix(in srgb,var(--gold) 55%,transparent);display:grid;place-items:center;transition:transform var(--dur-element) var(--ease-standard),background var(--dur-element)}
.vstage__play svg{width:34px;height:34px;fill:var(--accent-ink);transform:translateX(3px)}
.vstage__play:hover{transform:translate(-50%,-50%) scale(1.08);background:var(--gold-bright)}
.vstage__cap{position:absolute;left:0;right:0;bottom:0;padding:var(--space-6) var(--space-4) var(--space-3);text-align:center;font-family:var(--font-display);font-weight:600;text-transform:uppercase;letter-spacing:.12em;font-size:var(--ms-dn1);color:var(--bone);background:linear-gradient(transparent,color-mix(in srgb,var(--ink) 85%,transparent))}
.vstage.is-playing .vstage__play,.vstage.is-playing .vstage__cap{opacity:0;pointer-events:none;transition:opacity var(--dur-section)}
/* vertical freestyles */
.eyebrow.script{font-size:clamp(1.4rem,4.5vw,2rem);text-transform:none;letter-spacing:0;color:var(--gold-bright)}
.vstack{display:grid;grid-template-columns:1fr;gap:var(--gutter);max-width:62rem;margin:var(--space-7) auto 0;justify-items:center}
@media(min-width:56rem){.vstack{grid-template-columns:repeat(3,1fr)}}
.vstage--v{aspect-ratio:9/16;max-width:22rem;width:100%}
.vstage--v .vstage__play{width:72px;height:72px}

/* ============================================================
   CONNECT / CROWN CLIMAX - the crown is earned
   ============================================================ */
/* crown sits on top, the words stack beneath it (clean vertical hero) */
.crownsec{position:relative;min-height:92svh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;overflow:hidden;isolation:isolate;background:radial-gradient(120% 90% at 50% 26%,var(--ink-2),var(--ink-deep));padding:calc(var(--nav-h) + var(--space-7)) var(--edge) var(--space-9)}
.crownsec__stage{position:relative;z-index:0;display:grid;place-items:center;margin-bottom:var(--space-7)}
.crownsec__crown{width:clamp(124px,26vw,250px)}
.crownsec__copy{position:relative;z-index:1;align-self:stretch;display:grid;justify-items:center;gap:var(--space-5)}
.crownsec__head{font-size:clamp(2.2rem,7vw,4.8rem);font-weight:800;color:var(--bone);letter-spacing:-.02em;text-shadow:0 4px 40px rgba(6,5,4,.6)}
.crownsec__copy>p{max-width:44ch;color:var(--ink-muted);font-size:var(--ms-1)}
.crownsec__cta{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center;margin-top:var(--space-4)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{text-align:center;display:grid;justify-items:center;gap:var(--space-5);padding:var(--space-9) var(--edge) calc(var(--space-8) + env(safe-area-inset-bottom));background:var(--ink-deep);border-top:1px solid var(--line)}
.footer__crown{width:42px}
.footer__social{display:flex;flex-wrap:wrap;gap:var(--space-5);justify-content:center}
.footer__social a{font-size:var(--ms-dn1);text-transform:uppercase;letter-spacing:.14em;color:var(--bone-mut);transition:color var(--dur-element)}
.footer__social a:hover{color:var(--gold)}
.footer__credit{font-size:var(--ms-dn1);color:var(--ink-muted);letter-spacing:.04em}
.footer__credit a{color:var(--gold);font-weight:600}

/* ---- INSTALL CARD ----------------------------------------- */
.install{position:fixed;left:50%;bottom:calc(var(--space-4) + env(safe-area-inset-bottom));transform:translateX(-50%);z-index:90;display:flex;align-items:center;gap:var(--space-2);background:var(--ink-3);border:1px solid var(--line);border-radius:var(--r-pill);padding:var(--space-2) var(--space-2) var(--space-2) var(--space-4);box-shadow:var(--e3)}
.install[hidden]{display:none}
.install__btn{background:none;border:0;color:var(--gold);font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:var(--ms-dn1);cursor:pointer}
.install__x{width:30px;height:30px;border-radius:50%;border:1px solid var(--line);background:none;color:var(--bone-mut);cursor:pointer;font-size:18px;line-height:1}

/* ---- REVEAL (one verb: rise) - safe-visible without JS ------ */
.js .reveal,.js [data-split] .ln{opacity:0;transform:translateY(26px)}
.reveal.in,[data-split].in .ln{opacity:1;transform:none;transition:opacity var(--dur-cinematic) var(--ease-expressive),transform var(--dur-cinematic) var(--ease-expressive)}
[data-split] .ln{display:inline-block;transition-delay:var(--d,0ms)}
.js [data-chars] .ch{opacity:0;transform:translateY(46px) rotate(5deg)}
[data-chars].in .ch{opacity:1;transform:none;transition:opacity .55s var(--ease-expressive),transform .7s var(--ease-expressive);transition-delay:var(--d,0ms)}
[data-chars] .ch{display:inline-block}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .js .reveal,.js [data-split] .ln,.js [data-chars] .ch{opacity:1;transform:none}
  .crownmark__sheen,.bloom::before,.bloom::after,body::before,.hero__rays,.embers{display:none}
  .chapter__bleed img{top:0;height:100%;transform:none}
  .marquee__row{animation:none}
  ::view-transition-old(root),::view-transition-new(root){animation:none}
}
