@font-face {
  font-family: "Norse";
  src: url("assets/fonts/Norse.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Norse";
  src: url("assets/fonts/Norse-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* ===== Self-hosted Google Fonts (Cormorant Garamond + Montserrat) ===== */
@font-face { font-family: "Cormorant Garamond"; font-style: normal; font-weight: 400; font-display: swap; src: url("assets/fonts/cormorant-400-lat.woff2") format("woff2"); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: "Cormorant Garamond"; font-style: normal; font-weight: 400; font-display: swap; src: url("assets/fonts/cormorant-400-latext.woff2") format("woff2"); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family: "Cormorant Garamond"; font-style: normal; font-weight: 500; font-display: swap; src: url("assets/fonts/cormorant-500-lat.woff2") format("woff2"); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: "Cormorant Garamond"; font-style: normal; font-weight: 500; font-display: swap; src: url("assets/fonts/cormorant-500-latext.woff2") format("woff2"); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family: "Cormorant Garamond"; font-style: normal; font-weight: 600; font-display: swap; src: url("assets/fonts/cormorant-600-lat.woff2") format("woff2"); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: "Cormorant Garamond"; font-style: normal; font-weight: 600; font-display: swap; src: url("assets/fonts/cormorant-600-latext.woff2") format("woff2"); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family: "Montserrat"; font-style: normal; font-weight: 300; font-display: swap; src: url("assets/fonts/montserrat-300-lat.woff2") format("woff2"); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: "Montserrat"; font-style: normal; font-weight: 300; font-display: swap; src: url("assets/fonts/montserrat-300-latext.woff2") format("woff2"); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family: "Montserrat"; font-style: normal; font-weight: 400; font-display: swap; src: url("assets/fonts/montserrat-400-lat.woff2") format("woff2"); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: "Montserrat"; font-style: normal; font-weight: 400; font-display: swap; src: url("assets/fonts/montserrat-400-latext.woff2") format("woff2"); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family: "Montserrat"; font-style: normal; font-weight: 500; font-display: swap; src: url("assets/fonts/montserrat-500-lat.woff2") format("woff2"); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: "Montserrat"; font-style: normal; font-weight: 500; font-display: swap; src: url("assets/fonts/montserrat-500-latext.woff2") format("woff2"); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
@font-face { font-family: "Montserrat"; font-style: normal; font-weight: 600; font-display: swap; src: url("assets/fonts/montserrat-600-lat.woff2") format("woff2"); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
@font-face { font-family: "Montserrat"; font-style: normal; font-weight: 600; font-display: swap; src: url("assets/fonts/montserrat-600-latext.woff2") format("woff2"); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }

:root {
  --black: #16120c;
  --black-2: #211b13;
  --gold: #cf9748;
  --gold-light: #e9bf76;
  --cream: #ece1cd;
  --muted: #b0a28d;
  --line: rgba(207, 151, 72, .28);
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }
html { scroll-behavior: smooth; }
html { overflow-x: hidden; }
body { margin: 0; max-width: 100%; background: var(--black); color: var(--cream); font-family: "Montserrat", sans-serif; }
body.landing-open { overflow: hidden; }
body.nl-open { overflow: hidden; }
img { max-width: 100%; }
section[id], main section { scroll-margin-top: 90px; }
a { color: inherit; text-decoration: none; }

/* ===== Micro-animations: scroll reveal ===== */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s cubic-bezier(.22,.61,.36,1), transform .7s cubic-bezier(.22,.61,.36,1); transition-delay: var(--reveal-delay, 0s); }
.reveal.in { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
  .reveal { opacity: 1 !important; transform: none !important; }
}
button, input { font: inherit; }
button { color: inherit; }
.icon-sprite { position: absolute; width: 0; height: 0; overflow: hidden; }
.brand-icon { width: 21px; height: 21px; overflow: visible; fill: currentColor; stroke: none; }
.brand-icon use[href="#icon-spotify"] { fill: none; stroke: currentColor; stroke-width: 1.55; stroke-linecap: round; }
.brand-icon use[href="#icon-instagram"] { fill: none; stroke: currentColor; stroke-width: 1.8; }
.brand-icon.brand-spotify { color: #1ed760; }
.brand-icon.brand-youtube { color: #ff0033; }
.brand-icon.brand-instagram { color: #e4405f; }
.brand-icon.brand-facebook { color: #1877f2; }
.brand-icon.brand-tiktok { color: #f4f4f4; }
.brand-icon.brand-applemusic { color: #fa243c; }
.brand-icon.brand-soundcloud { color: #ff5500; }
.brand-icon.brand-amazonmusic { color: #25d1da; }
.brand-icon.brand-deezer { color: #a238ff; }
.brand-icon.brand-youtubemusic { color: #ff0000; }
.youtube-play { fill: #fff; stroke: none; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ===== Landing / Choose your path ===== */
.landing {
  position: fixed; inset: 0; z-index: 100; overflow: hidden;
  display: flex; background: #050403;
  transition: opacity .55s ease, visibility .55s ease;
}
.landing.leaving { opacity: 0; visibility: hidden; pointer-events: none; }

.landing-choice {
  position: relative; flex: 1; min-width: 0;
  display: flex; align-items: flex-end; justify-content: center;
  border: 0; padding: 0; background: #050403; cursor: pointer;
  overflow: hidden; color: var(--cream);
  -webkit-tap-highlight-color: transparent;
}

.lc-bg {
  position: absolute; inset: 0;
  background-size: cover; background-repeat: no-repeat;
  transform: scale(1.04);
  transition: transform .9s ease, filter .6s ease;
}
.choice-ravnir .lc-bg {
  background-image: url("assets/ravnir-landing.jpg");
  background-position: 50% 24%;
  filter: saturate(.72) contrast(1.06) brightness(.7);
}
.choice-emma .lc-bg {
  background-image: url("assets/emma-landing.jpg");
  background-position: 50% 32%;
  filter: saturate(.82) contrast(1.04) brightness(.66);
}

.lc-scrim { position: absolute; inset: 0; transition: opacity .4s ease; }
.choice-ravnir .lc-scrim {
  background:
    linear-gradient(0deg, #04080a 4%, rgba(4,8,10,.35) 38%, rgba(4,8,10,.04) 64%),
    linear-gradient(90deg, rgba(60,86,102,.28), transparent 70%);
}
.choice-emma .lc-scrim {
  background:
    linear-gradient(0deg, #0b0703 4%, rgba(11,7,3,.35) 38%, rgba(11,7,3,.04) 64%),
    linear-gradient(270deg, rgba(150,104,52,.3), transparent 70%);
}

.lc-content {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: .9rem;
  padding: 0 6vw 14vh; text-align: center;
  transform: translateY(8px); transition: transform .5s ease;
}
.lc-kicker {
  font-size: .62rem; letter-spacing: .4em; text-transform: uppercase;
  color: var(--muted); padding-left: .4em;
}
.lc-name { line-height: 1; }
.lc-name-ravnir {
  font-family: "Norse", "Montserrat", sans-serif; font-weight: 700;
  font-size: clamp(2.6rem, 4.6vw, 4.4rem); letter-spacing: .08em;
  color: #d4dcdd;
}
.lc-name-emma {
  font-family: "Cormorant Garamond", serif; font-weight: 600;
  font-size: clamp(2.3rem, 4vw, 3.9rem); letter-spacing: .02em;
  color: #ecd9b6;
}
.lc-select {
  margin-top: .4rem;
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .7rem 1.9rem; border: 1px solid var(--line);
  font-size: .66rem; letter-spacing: .34em; text-transform: uppercase;
  color: var(--cream); background: rgba(8,7,5,.32);
  backdrop-filter: blur(2px);
  transition: border-color .3s ease, background .3s ease, letter-spacing .3s ease;
}
.ui-arrow { width: .9em; height: .9em; flex: none; fill: none; stroke: currentColor; stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round; vertical-align: -.05em; transition: transform .3s ease; }

@media (hover: hover) {
  .landing-choice:hover .lc-bg { transform: scale(1.09); filter: saturate(.95) contrast(1.06) brightness(.82); }
  .landing-choice:hover .lc-scrim { opacity: .78; }
  .landing-choice:hover .lc-content { transform: translateY(0); }
  .landing-choice:hover .lc-select { letter-spacing: .42em; background: rgba(8,7,5,.5); }
  .choice-ravnir:hover .lc-select { border-color: #91a3a6; }
  .choice-emma:hover .lc-select { border-color: var(--gold); }
  .landing-choice:hover .lc-select .ui-arrow { transform: translate(2px,-2px); }
}
.landing-choice:focus-visible { outline: none; }
.landing-choice:focus-visible .lc-select { border-color: var(--gold-light); background: rgba(8,7,5,.55); }

.landing::before {
  content: ""; position: absolute; top: 12%; bottom: 12%; left: 50%;
  width: 1px; transform: translateX(-.5px); z-index: 3; pointer-events: none;
  background: linear-gradient(180deg, transparent, var(--line) 18%, var(--line) 82%, transparent);
}
.landing-head {
  position: absolute; top: 8.5vh; left: 50%; transform: translateX(-50%);
  z-index: 4; pointer-events: none; text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: .5rem;
  text-shadow: 0 1px 3px rgba(0,0,0,.92), 0 3px 22px rgba(0,0,0,.92);
}
.landing-head::before {
  content: ""; position: absolute; z-index: -1; inset: -34% -46%;
  background: radial-gradient(58% 72% at 50% 44%, rgba(5,5,6,.74), rgba(5,5,6,.34) 52%, transparent 78%);
  filter: blur(7px);
}
.lh-kicker {
  font-size: .64rem; letter-spacing: .56em; text-transform: uppercase;
  color: #d8ccb5; padding-left: .56em;
}
.lh-title {
  font-family: "Norse", "Montserrat", sans-serif; font-weight: 700;
  font-size: clamp(2.6rem, 6vw, 5.2rem); letter-spacing: .14em;
  color: var(--gold-light); line-height: .9; padding-left: .14em;
}
.lh-path {
  font-size: .6rem; letter-spacing: .44em; text-transform: uppercase;
  color: #cabda4;
}
.lh-path::before, .lh-path::after { content: "—"; opacity: .55; margin: 0 .6em; }

.ravnir-site {
  --gold: #a0b3b6;
  --gold-light: #d8e0e1;
  --cream: #e2e8e8;
  --muted: #93a3a6;
  --line: rgba(160,179,182,.26);
  --black-2: #1d2c30;
  background: #111a1c;
  color: var(--cream);
}
.ravnir-site .tagline,
.ravnir-site .section-title h2 {
  font-family: "Norse", "Montserrat", sans-serif;
}
.ravnir-topbar { background: linear-gradient(#0c1416e8,transparent); border-color: rgba(160,179,182,.14); }
.ravnir-topbar nav a, .ravnir-cross { color: #c3ced0; }
.ravnir-hero-image { background-image: url("assets/ravnir-hero.jpg") !important; background-position: center !important; background-size: cover !important; background-repeat: no-repeat !important; background-color: #0f1719 !important; filter: saturate(.92) contrast(1.06) brightness(.9) !important; }
.ravnir-hero::after { background: linear-gradient(90deg,rgba(15,23,25,.88),rgba(15,23,25,.42) 44%,rgba(15,23,25,.04) 74%),linear-gradient(0deg,#111a1c,transparent 40%); }
.ravnir-site .ravnir-hero h1 { color: #d4dcdd; font-family: "Norse","Montserrat",sans-serif; font-size: clamp(4.5rem,12vw,11.5rem); font-weight: 700; letter-spacing: .04em; line-height: .9; }
.ravnir-hero .tagline { color: #aebcbe; }
.ravnir-hero .button.primary { background: #c8d1d2; color: #070a0b; }
.ravnir-site .ravnir-release { background: #131d1f; }
.ravnir-release .release-copy h2 { color: #ccd6d7; font-family: "Norse","Montserrat",sans-serif; font-weight: 700; letter-spacing: .1em; }
/* Timeline album covers (Saga / Journey) — small Spotify-linked thumbnails */
.timeline .tl-covers { grid-row: 4; display: flex; gap: .4rem; justify-content: center; align-items: flex-start; margin-top: .7rem; }
.tl-cover { display: block; width: 52px; flex: none; }
.tl-cover img { display: block; width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: 4px; border: 1px solid var(--line); filter: saturate(.82) contrast(1.05); transition: transform .3s cubic-bezier(.22,.61,.36,1), box-shadow .3s ease, filter .3s ease; }
@media (hover: hover) { .tl-cover:hover img { transform: translateY(-3px) scale(1.05); box-shadow: 0 10px 22px rgba(0,0,0,.55); filter: none; } }
.ravnir-site .ravnir-journey { background: radial-gradient(circle at 9% 48%,#3a5a5f3a,transparent 28%),#141e21; }
.ravnir-journey .timeline article::after { content: ""; }
.ravnir-stats { background: #111a1c; }
.ravnir-discography { padding: 9rem 8vw; border-bottom: 1px solid var(--line); background: #141e21; }
.ravnir-release-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 4rem 2.5vw; }
.ravnir-release-grid article { border-top: 1px solid var(--line); padding-top: 1rem; }
.ravnir-release-grid img { display: block; width: 100%; aspect-ratio: 1; object-fit: cover; filter: saturate(.62) contrast(1.12); }
.ravnir-release-grid p { margin: 1rem 0 .5rem; color: #7f9093; font-size: .55rem; letter-spacing: .13em; text-transform: uppercase; }
.ravnir-release-grid h3 { margin: 0; color: #c8d1d2; font-family: "Norse","Montserrat",sans-serif; font-size: 1.35rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.listen-link { display: inline-flex; align-items: center; gap: .55rem; margin-top: 1rem; color: #aebcbe; text-transform: uppercase; letter-spacing: .13em; font-size: .56rem; transition: color .2s ease; }
.listen-link:hover { color: #fff; }
.listen-link .brand-icon { width: 18px; height: 18px; }
.ravnir-footer { background: #0d1517; position: relative; }
.ravnir-footer .mountains { display: block; width: min(960px, 94%); height: auto; margin: 0 auto 2.6rem; opacity: .5; pointer-events: none; }
.footer-cta { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: .9rem; margin: 1.7rem auto 2.4rem; }
.join-btn { padding: .82rem 1.6rem; border: 1px solid var(--gold); border-radius: 40px; background: var(--gold-light); color: #0e1517; text-transform: uppercase; letter-spacing: .14em; font-size: .6rem; font-weight: 600; cursor: pointer; transition: transform .25s ease, box-shadow .25s ease; }
@media (hover: hover) { .join-btn:hover { transform: translateY(-1px); box-shadow: 0 10px 26px rgba(160,179,182,.22); } }
.follow-btn { display: flex; width: fit-content; align-items: center; gap: .6rem; padding: .82rem 1.5rem; border: 1px solid var(--line); border-radius: 40px; color: var(--cream); text-transform: uppercase; letter-spacing: .14em; font-size: .6rem; font-weight: 600; transition: border-color .25s ease, color .25s ease, transform .25s ease, box-shadow .25s ease; }
.follow-btn .brand-spotify { width: 18px; height: 18px; }
@media (hover: hover) { .follow-btn:hover { border-color: #1ed760; color: #fff; transform: translateY(-1px); box-shadow: 0 10px 26px rgba(30,215,96,.18); } }

/* ===== Newsletter "Join" modal ===== */
.nl-modal { position: fixed; inset: 0; z-index: 200; display: flex; align-items: flex-start; justify-content: center; padding: clamp(.85rem, 4vw, 1.4rem); overflow-y: auto; -webkit-overflow-scrolling: touch; }
.nl-backdrop { position: absolute; inset: 0; background: rgba(4,7,8,.74); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); }
.nl-card { position: relative; width: 100%; max-width: 440px; margin: auto; padding: clamp(1.5rem, 5.5vw, 2.8rem); background: linear-gradient(180deg, #162125, #101a1c); border: 1px solid var(--line); border-radius: 16px; box-shadow: 0 30px 80px rgba(0,0,0,.6); animation: nl-in .4s cubic-bezier(.22,.61,.36,1); }
@keyframes nl-in { from { opacity: 0; transform: translateY(16px) scale(.98); } to { opacity: 1; transform: none; } }
.nl-close { position: absolute; top: .9rem; right: .9rem; width: 36px; height: 36px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 50%; background: transparent; color: var(--gold-light); font-size: .9rem; cursor: pointer; transition: border-color .2s ease, background .2s ease; }
.nl-close:hover { border-color: var(--gold-light); background: rgba(255,255,255,.05); }
.nl-kicker { margin: 0 0 .5rem; color: var(--gold); text-transform: uppercase; letter-spacing: .26em; font-size: .56rem; }
.nl-card h2 { margin: 0 0 .7rem; color: var(--cream); font-family: "Norse","Montserrat",sans-serif; font-weight: 700; font-size: clamp(2rem, 6vw, 2.7rem); letter-spacing: .06em; line-height: 1; }
.nl-sub { margin: 0 0 1.6rem; color: var(--muted); font-size: .78rem; line-height: 1.7; max-width: 36ch; }
.nl-field { display: block; }
.nl-label { display: block; margin-bottom: .5rem; color: var(--muted); text-transform: uppercase; letter-spacing: .18em; font-size: .56rem; }
.nl-form input[type="email"] { width: 100%; padding: .85rem 1rem; background: rgba(0,0,0,.28); border: 1px solid var(--line); border-radius: 8px; color: var(--cream); font-size: .9rem; transition: border-color .2s ease, box-shadow .2s ease; }
.nl-form input[type="email"]::placeholder { color: #5f7174; }
.nl-form input[type="email"]:focus { outline: none; border-color: var(--gold-light); box-shadow: 0 0 0 3px rgba(160,179,182,.16); }
.nl-hp { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; }
.nl-consent { display: flex; align-items: flex-start; gap: .6rem; margin: 1.1rem 0 1.4rem; color: var(--muted); font-size: .68rem; line-height: 1.5; cursor: pointer; }
.nl-consent input { margin-top: .15rem; accent-color: var(--gold); flex: none; }
.nl-submit { width: 100%; padding: .9rem; border: 1px solid #c8d1d2; border-radius: 40px; background: #c8d1d2; color: #0e1517; text-transform: uppercase; letter-spacing: .16em; font-size: .64rem; font-weight: 600; cursor: pointer; transition: transform .2s ease, box-shadow .2s ease, opacity .2s ease; }
.nl-submit:hover { transform: translateY(-1px); box-shadow: 0 10px 26px rgba(160,179,182,.22); }
.nl-submit:disabled { opacity: .6; cursor: default; transform: none; box-shadow: none; }
.nl-msg { margin: .9rem 0 0; min-height: 1em; font-size: .68rem; letter-spacing: .04em; }
.nl-msg.is-error { color: #e58a8a; }
.nl-success-view { text-align: left; }
@media (max-width: 480px) {
  .nl-card { border-radius: 14px; }
  .nl-card h2 { font-size: clamp(1.7rem, 8.5vw, 2.4rem); }
  .nl-sub { margin-bottom: 1.3rem; }
  .nl-consent { margin: .9rem 0 1.2rem; }
  .nl-close { top: .7rem; right: .7rem; width: 32px; height: 32px; }
}

/* ===== Minimal Nordic decoration (prototype) ===== */
/* A) Film grain — global, barely-there filmic texture */
.grain { position: fixed; inset: 0; z-index: 3; pointer-events: none; opacity: .07;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

/* B) Topographic contour accent — RAVNIR stats section */
.ravnir-stats { position: relative; overflow: hidden; }
.ravnir-stats::before { content: ""; position: absolute; top: 50%; right: -6%; width: min(46vw, 560px); aspect-ratio: 1; transform: translateY(-50%); pointer-events: none; opacity: .05; background-repeat: no-repeat; background-position: center; background-size: contain;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 600 600' fill='none' stroke='%23a0b3b6' stroke-width='1.4'%3E%3Cpath d='M300 70C440 70 540 180 540 305 540 445 425 540 300 540 175 540 70 435 70 300 70 175 175 70 300 70Z'/%3E%3Cpath d='M305 120C415 116 480 205 482 300 484 405 395 478 300 480 200 482 122 400 120 305 118 210 205 124 305 120Z'/%3E%3Cpath d='M300 170C380 168 432 230 430 305 428 380 372 428 298 430 228 432 172 372 170 300 168 232 230 172 300 170Z'/%3E%3Cpath d='M302 220C355 222 384 258 382 305 380 350 345 382 300 380 258 378 222 348 220 302 218 260 252 218 302 220Z'/%3E%3Cpath d='M300 270C330 270 348 285 348 305 348 328 328 342 300 340 278 338 262 322 262 300 262 282 278 270 300 270Z'/%3E%3C/svg%3E"); }


.topbar { position: fixed; z-index: 30; inset: 0 0 auto; height: 74px; display: flex; align-items: center; gap: 1.4rem; padding: 0 3.4vw; border-bottom: 1px solid rgba(207,151,72,.14); background: linear-gradient(180deg, rgba(22,18,12,.92), rgba(22,18,12,.4) 65%, transparent); }

/* Artist switcher — minimal, with an active gold underline */
.artist-tabs { display: flex; align-items: center; }
.artist-tab { position: relative; padding: .5rem .9rem; border: 0; background: transparent; color: var(--muted); text-transform: uppercase; letter-spacing: .2em; font-size: .62rem; font-weight: 500; cursor: pointer; transition: color .25s ease; }
.artist-tab + .artist-tab { margin-left: .9rem; }
.artist-tab + .artist-tab::before { content: ""; position: absolute; left: -.45rem; top: 50%; transform: translateY(-50%); height: 13px; width: 1px; background: var(--line); }
.artist-tab::after { content: ""; position: absolute; left: .9rem; right: .9rem; bottom: .18rem; height: 1.5px; border-radius: 2px; background: var(--gold-light); transform: scaleX(0); transform-origin: center; transition: transform .35s cubic-bezier(.22,.61,.36,1); }
.artist-tab.active { color: var(--gold-light); }
.artist-tab.active::after { transform: scaleX(1); }
@media (hover: hover) { .artist-tab:hover { color: var(--cream); } }
.ravnir-site .artist-tab.active { color: #d6dddd; }
.ravnir-site .artist-tab.active::after { background: #c8d1d2; }

/* Section nav — grouped to the right with the actions */
.topbar nav { margin-left: auto; display: flex; gap: clamp(1.3rem, 2.4vw, 2.6rem); }
.topbar nav a { color: #c5a678; text-transform: uppercase; letter-spacing: .18em; font-size: .58rem; font-weight: 500; }
.ravnir-topbar nav a { color: #aebcbe; }

/* Header CTA (CTR) */
.nav-cta { display: inline-flex; align-items: center; gap: .45rem; padding: .58rem 1.15rem; border: 1px solid var(--gold); color: var(--gold-light); text-transform: uppercase; letter-spacing: .15em; font-size: .56rem; font-weight: 600; white-space: nowrap; transition: background .25s ease, color .25s ease, transform .25s ease, box-shadow .25s ease; }
.nav-cta .brand-icon { width: 15px; height: 15px; }
.ravnir-topbar .nav-cta { border-color: #8aa0a3; color: #d6dddd; }
@media (hover: hover) {
  .nav-cta:hover { background: var(--gold-light); color: var(--black); transform: translateY(-1px); box-shadow: 0 8px 22px rgba(197,141,67,.25); }
  .nav-cta:hover .brand-icon.brand-spotify { color: #111; }
  .ravnir-topbar .nav-cta:hover { background: #c8d1d2; color: #070a0b; box-shadow: 0 8px 22px rgba(145,163,166,.25); }
}

/* Close — refined circular button */
.cross-mark { width: 40px; height: 40px; flex: none; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 50%; background: transparent; color: var(--gold-light); font-size: .95rem; line-height: 1; cursor: pointer; }
.cross-mark:hover { border-color: var(--gold-light); background: rgba(255,255,255,.05); }

.hero { min-height: 100svh; position: relative; display: grid; align-items: center; padding: 120px 7vw 70px; overflow: hidden; isolation: isolate; }
.hero-image { position: absolute; inset: 0; z-index: -3; background: url("assets/emma-hero.png") center / cover no-repeat; filter: saturate(1) contrast(1.04) brightness(.92); }
.hero::after { content: ""; position: absolute; inset: 0; z-index: -2; background: linear-gradient(90deg, rgba(22,18,12,.9) 0%, rgba(22,18,12,.44) 46%, rgba(22,18,12,.04) 78%), linear-gradient(0deg,var(--black),transparent 40%); }
.hero-shape { position: absolute; z-index: -1; left: 12%; top: 21%; width: 28vw; aspect-ratio: 1; border-radius: 50%; background: #b17b3347; filter: blur(2px); }
.hero-copy { max-width: 680px; }
.kicker { color: var(--gold); text-transform: uppercase; letter-spacing: .28em; font-size: .6rem; }
.hero h1 { margin: 1.4rem 0; color: var(--gold-light); font-family: "Cormorant Garamond", serif; font-size: clamp(5rem,10vw,9rem); font-weight: 500; line-height: .7; letter-spacing: .02em; }
.tagline { text-transform: uppercase; letter-spacing: .26em; line-height: 1.9; font-size: .72rem; }
.actions { display: flex; gap: 1rem; margin-top: 2rem; }
.button { padding: 1rem 1.3rem; border: 1px solid var(--gold); text-transform: uppercase; letter-spacing: .13em; font-size: .55rem; }
.button.primary { background: var(--gold-light); color: var(--black); }
.down { position: absolute; bottom: 2rem; left: 50%; color: var(--gold); font-size: 1.6rem; }

.release { min-height: 72vh; display: grid; grid-template-columns: minmax(260px,400px) 1fr; align-items: center; gap: clamp(2.5rem,5vw,5.5rem); padding: 8rem 10vw; border-block: 1px solid var(--line); background: #1c160f; }
.release-cover img { width: 100%; display: block; }
.release-copy h2 { margin: .7rem 0 1.2rem; color: var(--gold-light); font-family: "Cormorant Garamond",serif; font-size: clamp(3.4rem,6vw,6rem); font-weight: 500; letter-spacing: .08em; }
.release-copy > p:not(.kicker) { max-width: 500px; color: var(--muted); line-height: 1.9; }
.release-date { text-transform: uppercase; letter-spacing: .18em; font-size: .6rem; }

/* ===== Release countdown ===== */
.countdown { display: inline-flex; gap: .35rem; margin-top: 1.4rem; padding: .85rem 1rem; border: 1px solid var(--line); border-radius: 12px; background: rgba(0,0,0,.28); }
.cd-unit { display: flex; flex-direction: column; align-items: center; min-width: 58px; padding: 0 .5rem; position: relative; }
.cd-unit + .cd-unit::before { content: ""; position: absolute; left: 0; top: 14%; height: 56%; width: 1px; background: var(--line); }
.cd-unit strong { font-family: "Norse","Montserrat",sans-serif; font-size: clamp(1.9rem,3.2vw,2.55rem); font-weight: 700; line-height: 1; color: var(--cream); font-variant-numeric: tabular-nums; letter-spacing: .02em; }
.cd-unit span { margin-top: .45rem; font-size: .5rem; letter-spacing: .16em; text-transform: uppercase; color: var(--muted); }
.countdown.is-released { font-family: "Norse","Montserrat",sans-serif; padding: .9rem 1.4rem; color: var(--gold-light); text-transform: uppercase; letter-spacing: .2em; font-size: 1.1rem; }

.platforms { display: flex; align-items: center; gap: 1.6rem; margin-top: 2rem; color: var(--gold-light); font-size: .67rem; }
.presave-cta { display: inline-flex; align-items: center; gap: .8rem; min-height: 54px; padding: 0 1.35rem; border: 1px solid var(--gold); background: var(--gold-light); color: var(--black); text-transform: uppercase; letter-spacing: .14em; font-size: .62rem; font-weight: 600; transition: transform .2s ease, box-shadow .2s ease; }
.presave-cta:hover { transform: translateY(-2px); box-shadow: 0 10px 30px rgba(197,141,67,.2); }
.presave-cta .brand-spotify { color: #111; width: 23px; height: 23px; }
.ravnir-site .presave-cta { background: #c8d1d2; border-color: #c8d1d2; color: #070a0b; }

.journey { padding: 6rem 7vw 5rem; background: radial-gradient(circle at 8% 50%,#6b3f1238,transparent 26%),#191309; border-bottom: 1px solid var(--line); }
.section-title { text-align: center; margin-bottom: 4rem; }
.section-title span { color: var(--gold-light); font-size: 1.6rem; }
.section-title h2 { margin: .5rem 0; font-family: "Cormorant Garamond",serif; color: var(--gold-light); text-transform: uppercase; letter-spacing: .25em; font-weight: 500; }
.timeline { display: grid; grid-template-columns: repeat(5,1fr); position: relative; }
.timeline article { position: relative; display: grid; grid-template-rows: 24px 22px minmax(30px,auto); gap: 7px; justify-items: center; text-align: center; }
.timeline article::before { content: ""; position: absolute; z-index: 0; top: 34px; left: 0; right: 0; border-top: 1px solid var(--gold); }
.timeline article:first-child::before { left: 50%; }
.timeline article:last-child::before { right: 50%; }
.timeline article::after { content: ""; z-index: 1; grid-row: 2; align-self: center; width: 12px; height: 12px; display: block; border: 1px solid var(--gold); border-radius: 50%; background: var(--black-2); box-shadow: 0 0 0 5px var(--black-2); }
.timeline strong { grid-row: 1; align-self: start; color: var(--gold-light); font-size: .65rem; letter-spacing: .15em; }
.timeline span { grid-row: 3; color: var(--muted); text-transform: uppercase; font-size: .48rem; line-height: 1.45; letter-spacing: .15em; }
.saga-shell { position: relative; display: grid; grid-template-columns: 42px minmax(0,1fr) 42px; align-items: center; gap: 1rem; }
.saga-track { display: flex; overflow-x: auto; scroll-snap-type: x mandatory; scrollbar-width: none; padding: .5rem 0 1.2rem; }
.saga-track::-webkit-scrollbar { display: none; }
.saga-track article { flex: 0 0 min(220px,38vw); scroll-snap-align: center; }
.saga-arrow { width: 42px; height: 42px; border: 1px solid var(--line); background: #162123; color: var(--gold-light); cursor: pointer; transition: .2s; }
.saga-arrow:hover { background: var(--gold-light); color: #162123; }

.stats { display: grid; grid-template-columns: repeat(auto-fit,minmax(180px,1fr)); padding: 4.5rem 6vw; border-bottom: 1px solid var(--line); }
.stats article { position: relative; display: grid; justify-items: center; gap: .7rem; padding: 0 2rem; text-align: center; border-right: 1px solid var(--line); }
.stats article:last-child { border: 0; }
.stat-link { position: absolute; inset: 0; z-index: 2; cursor: pointer; }
.stats strong { color: var(--gold-light); font-family: "Cormorant Garamond",serif; font-size: clamp(2.5rem,4vw,4rem); font-weight: 400; }
.stats span { color: var(--muted); text-transform: uppercase; font-size: .5rem; letter-spacing: .15em; }


.about-section { display: grid; grid-template-columns: minmax(320px,1.05fr) 1fr; align-items: center; gap: clamp(3rem,7vw,8rem); padding: 9rem 8vw; border-bottom: 1px solid var(--line); overflow: hidden; }
.about-image { position: relative; }
.about-image::before { content: ""; position: absolute; inset: -14px 14px 14px -14px; border: 1px solid var(--line); }
.about-image img { position: relative; display: block; width: 100%; object-fit: cover; }
.about-copy h2 { margin: .6rem 0 1.6rem; color: var(--gold-light); font-family: "Cormorant Garamond",serif; font-size: clamp(2.8rem,4.4vw,4.3rem); font-weight: 500; line-height: .92; }
.about-copy > p:not(.kicker) { max-width: 52ch; margin: 0 0 .95rem; color: var(--muted); font-size: .785rem; line-height: 1.72; }
.ravnir-about { background: #080c0d; }
.ravnir-about .about-image img { min-height: 470px; filter: saturate(.62) contrast(1.12) brightness(.78); }
.ravnir-about .about-copy h2 { font-family: "Norse","Montserrat",sans-serif; color: #d0d8d9; font-weight: 700; letter-spacing: .06em; }
.emma-about { background: radial-gradient(circle at 18% 48%,rgba(197,141,67,.12),transparent 32%),#0a0806; }
.emma-about .about-image img { aspect-ratio: 1.5 / 1; filter: saturate(.8) contrast(1.06) brightness(.8); }


.discography { padding: 9rem 10vw; border-bottom: 1px solid var(--line); }
.release-list { max-width: 1000px; margin: auto; display: grid; grid-template-columns: 1fr 1fr; gap: 5vw; }
.release-list article { display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 2rem; border-top: 1px solid var(--line); padding-top: 1.5rem; }
.release-list img { width: 100%; }
.release-list h3 { color: var(--gold-light); font-family: "Cormorant Garamond",serif; font-size: 2.2rem; font-weight: 500; }
.release-list a { display: inline-flex; align-items: center; gap: .45rem; color: var(--gold); text-transform: uppercase; letter-spacing: .14em; font-size: .55rem; transition: gap .25s ease, color .2s ease; }
@media (hover: hover) { .release-list a:hover { gap: .7rem; color: var(--gold-light); } }

footer { padding: 5rem 7vw 3rem; text-align: center; border-top: 1px solid var(--line); }
footer > p { color: var(--gold); text-transform: uppercase; letter-spacing: .35em; font-size: .65rem; }
footer > a { color: var(--gold-light); font-family: "Cormorant Garamond",serif; font-size: 2rem; }
.footer-links { margin: 2.5rem 0; display: flex; justify-content: center; gap: 2rem; color: var(--muted); font-size: .65rem; }
.footer-links a { display: inline-flex; align-items: center; gap: .55rem; }
.footer-links .brand-icon { width: 18px; height: 18px; }
footer small { color: #62594d; font-size: .55rem; }

/* ===== Premium micro-interactions ===== */
/* Topbar condenses on scroll */
.topbar { transition: background .35s ease, box-shadow .35s ease, height .35s ease; }
.topbar.scrolled { height: 64px; background: rgba(8,7,5,.82); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); box-shadow: 0 1px 0 var(--line), 0 14px 40px rgba(0,0,0,.45); }
.ravnir-topbar.scrolled { background: rgba(5,9,11,.82); }

/* Nav link underline sweep */
.topbar nav a { position: relative; transition: color .25s ease; }
.topbar nav a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -5px; height: 1px; background: currentColor; transition: right .3s cubic-bezier(.22,.61,.36,1); }
.topbar nav a:hover { color: var(--gold-light); }
.topbar nav a:hover::after { right: 0; }
.artist-tab { transition: color .25s ease, background .25s ease; }
.cross-mark { transition: transform .3s ease, color .25s ease; }
.cross-mark:hover { transform: rotate(90deg); color: #fff; }

/* Buttons: lift + light sheen */
.button { position: relative; overflow: hidden; transition: transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease; }
.button::after { content: ""; position: absolute; top: 0; left: -120%; width: 60%; height: 100%; background: linear-gradient(100deg, transparent, rgba(255,255,255,.35), transparent); transform: skewX(-18deg); transition: left .6s ease; }
.down { transform: translateX(-50%); animation: down-bob 2.4s ease-in-out infinite; }

@media (hover: hover) {
  .button:hover { transform: translateY(-2px); box-shadow: 0 12px 30px rgba(0,0,0,.4); }
  .button:hover::after { left: 130%; }
  .ravnir-release-grid article, .release-list article { transition: transform .4s cubic-bezier(.22,.61,.36,1); }
  .ravnir-release-grid img, .release-list img { transition: transform .6s cubic-bezier(.22,.61,.36,1), filter .4s ease; }
  .ravnir-release-grid article:hover { transform: translateY(-6px); }
  .release-list article:hover { transform: translateY(-4px); }
  .ravnir-release-grid article:hover img { transform: scale(1.045); filter: saturate(.82) contrast(1.14); }
  .release-list article:hover img { transform: scale(1.04); }
  .stats article { transition: transform .35s ease; }
  .stats article:hover { transform: translateY(-4px); }
  .stats article:hover strong { color: #fff; }
  .down:hover { color: var(--gold-light); }
}

/* Attention pulse on the main pre-save CTA (paused if reduced motion via global rule) */
.presave-cta { animation: cta-glow 3.2s ease-in-out infinite; }

@keyframes down-bob { 0%,100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(7px); } }
@keyframes cta-glow {
  0%, 100% { box-shadow: 0 0 0 0 rgba(197,141,67,0); }
  50% { box-shadow: 0 8px 30px rgba(197,141,67,.28); }
}
.ravnir-site .presave-cta { animation-name: cta-glow-cold; }
@keyframes cta-glow-cold {
  0%, 100% { box-shadow: 0 0 0 0 rgba(145,163,166,0); }
  50% { box-shadow: 0 8px 30px rgba(145,163,166,.3); }
}

/* ===== Scroll progress bar ===== */
.scroll-progress { position: fixed; top: 0; left: 0; right: 0; height: 2px; z-index: 40; pointer-events: none; }
.scroll-progress span { display: block; height: 100%; transform: scaleX(0); transform-origin: left; background: linear-gradient(90deg, rgba(197,141,67,0), var(--gold) 55%, var(--gold-light)); }

/* ===== Scrollspy: active section in nav ===== */
.topbar nav a.current { color: var(--gold-light); }
.ravnir-topbar nav a.current { color: #d6dddd; }
.topbar nav a.current::after { right: 0; }

/* ===== Hero: slow Ken-Burns drift ===== */
@keyframes kenburns { 0% { transform: scale(1.02); } 100% { transform: scale(1.1); } }
.ravnir-hero-image, .hero-image { animation: kenburns 26s ease-in-out infinite alternate; }

/* ===== Landing: cursor glow ===== */
.lc-glow { position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: 0; transition: opacity .45s ease; }
.choice-ravnir .lc-glow { background: radial-gradient(260px circle at var(--mx,50%) var(--my,50%), rgba(150,180,200,.13), transparent 62%); }
.choice-emma .lc-glow { background: radial-gradient(260px circle at var(--mx,50%) var(--my,50%), rgba(226,182,110,.15), transparent 62%); }
@media (hover: hover) and (pointer: fine) { .landing-choice:hover .lc-glow { opacity: 1; } }

/* ===== Hero atmosphere: snow (RAVNIR) / dust (Emma) ===== */
.hero-fx { position: absolute; inset: 0; z-index: -1; pointer-events: none; overflow: hidden; }
.hero-fx::before, .hero-fx::after {
  content: ""; position: absolute; left: 0; right: 0; top: -360px; height: calc(100% + 360px);
  background-repeat: repeat;
}
.fx-snow::before, .fx-snow::after {
  background-image:
    radial-gradient(1.6px 1.6px at 12% 10%, rgba(255,255,255,.7), transparent 60%),
    radial-gradient(1.4px 1.4px at 38% 24%, rgba(255,255,255,.55), transparent 60%),
    radial-gradient(1.8px 1.8px at 64% 12%, rgba(255,255,255,.65), transparent 60%),
    radial-gradient(1.3px 1.3px at 82% 30%, rgba(255,255,255,.5), transparent 60%),
    radial-gradient(1.5px 1.5px at 26% 42%, rgba(255,255,255,.6), transparent 60%),
    radial-gradient(1.4px 1.4px at 54% 56%, rgba(255,255,255,.5), transparent 60%);
  background-size: 320px 320px;
  animation: snowfall 15s linear infinite;
  opacity: .5;
}
.fx-snow::after { background-size: 220px 220px; opacity: .35; animation-duration: 24s; animation-delay: -7s; }
@keyframes snowfall { from { transform: translateY(0); } to { transform: translateY(360px); } }
.fx-dust::before, .fx-dust::after {
  background-image:
    radial-gradient(1.5px 1.5px at 16% 20%, rgba(226,182,110,.5), transparent 60%),
    radial-gradient(1.3px 1.3px at 44% 36%, rgba(223,211,189,.4), transparent 60%),
    radial-gradient(1.6px 1.6px at 70% 22%, rgba(226,182,110,.45), transparent 60%),
    radial-gradient(1.2px 1.2px at 86% 48%, rgba(223,211,189,.35), transparent 60%),
    radial-gradient(1.4px 1.4px at 30% 60%, rgba(226,182,110,.4), transparent 60%);
  background-size: 360px 360px;
  animation: dustdrift 30s linear infinite;
  opacity: .4;
}
.fx-dust::after { background-size: 260px 260px; opacity: .28; animation-duration: 44s; animation-delay: -10s; }
@keyframes dustdrift { from { transform: translateY(0); } to { transform: translateY(-360px); } }
@media (prefers-reduced-motion: reduce) { .hero-fx { display: none; } }

/* ===== Spotify embed ===== */
.spotify-embed { margin-top: 1.9rem; max-width: 460px; }
.embed-label { margin: 0 0 .7rem; color: var(--muted); text-transform: uppercase; letter-spacing: .18em; font-size: .55rem; }
.spotify-embed iframe { display: block; width: 100%; height: 152px; border: 0; border-radius: 12px; box-shadow: 0 14px 38px rgba(0,0,0,.4); }
.embed-open { display: inline-flex; align-items: center; gap: .5rem; margin-top: .85rem; color: var(--muted); text-transform: uppercase; letter-spacing: .16em; font-size: .55rem; transition: color .2s ease, gap .2s ease; }
.embed-open .brand-icon { width: 15px; height: 15px; }
.embed-open .ui-arrow { width: .85em; height: .85em; opacity: .8; }
@media (hover: hover) { .embed-open:hover { color: var(--cream); gap: .65rem; } }

@media (max-width: 850px) {
  .topbar { height: 62px; padding: 0 5vw; gap: .6rem; }
  .artist-tab { padding: .35rem .55rem; font-size: .56rem; letter-spacing: .14em; }
  .artist-tab + .artist-tab { margin-left: .7rem; }
  .artist-tab + .artist-tab::before { left: -.35rem; }
  .artist-tab::after { left: .55rem; right: .55rem; }
  .topbar nav { display: none; }
  .nav-cta { display: none; }
  .cross-mark { margin-left: auto; width: 36px; height: 36px; font-size: .85rem; }
  .hero { min-height: 100svh; align-items: end; padding: 96px 8vw 84px; }
  .hero-image { background-position: 62% center; }
  .hero-shape { display: none; }
  .hero::after { background: linear-gradient(0deg,var(--black) 5%,transparent 78%),linear-gradient(90deg,#16120ca8,transparent); }
  .hero h1 { font-size: clamp(3.7rem,17vw,5rem); line-height: .78; letter-spacing: -.015em; }
  .release { grid-template-columns: 1fr; padding: 4.5rem 8vw; min-height: 0; gap: 2rem; }
  .ravnir-hero-image { background-size: cover !important; background-position: center 18% !important; }
  .ravnir-site .ravnir-hero h1 { font-size: clamp(4.8rem,22vw,7rem); letter-spacing: .025em; }
  .timeline:not(.saga-track) { grid-template-columns: 1fr; gap: 2.5rem; }
  .timeline:not(.saga-track)::before { content: ""; position: absolute; left: 50%; top: 0; bottom: 0; border-left: 1px solid var(--line); }
  .timeline:not(.saga-track) article { grid-template-rows: auto; background: var(--black-2); padding: 1rem; z-index: 1; }
  .timeline:not(.saga-track) article::before { display: none; }
  .timeline:not(.saga-track) article::after, .timeline:not(.saga-track) strong, .timeline:not(.saga-track) span { grid-row: auto; }
  /* Saga → vertical timeline on mobile (like "The Journey"); horizontal slider stays on desktop */
  .saga-shell { display: block; }
  .saga-arrow { display: none; }
  .saga-track {
    display: grid; grid-template-columns: 1fr; gap: 2.5rem;
    position: relative; overflow: visible; scroll-snap-type: none; padding: 0;
  }
  .saga-track::before { content: ""; position: absolute; left: 50%; top: 0; bottom: 0; border-left: 1px solid var(--line); }
  .saga-track article { flex: initial; grid-template-rows: auto; background: var(--black-2); padding: 1rem; z-index: 1; }
  .saga-track article::before { display: none; }
  .saga-track article::after, .saga-track strong, .saga-track span { grid-row: auto; }
  .stats { grid-template-columns: 1fr 1fr; gap: 2.6rem 0; padding: 3.6rem 7vw; }
  .stats article { border: 0; padding: 0 1rem; }
  .stats article:nth-child(odd) { border-right: 1px solid var(--line); }
  .stats article:last-child:nth-child(odd) { grid-column: 1 / -1; border-right: 0; }
  .about-section { grid-template-columns: 1fr; padding: 4.5rem 8vw; gap: 2.4rem; }
  .about-image { order: 2; }
  .about-copy { order: 1; }
  .ravnir-about .about-image img { min-height: 0; aspect-ratio: 2 / 1; }
  .release-list { grid-template-columns: 1fr; }
  .ravnir-release-grid { grid-template-columns: 1fr 1fr; gap: 2.6rem 1.2rem; }
  .footer-links { flex-wrap: wrap; gap: 1.4rem 2rem; }

  /* tighter vertical rhythm so sections sit on-screen */
  .journey { padding: 4.2rem 7vw 3.4rem; }
  .section-title { margin-bottom: 2.4rem; }
  .stats { padding: 3.4rem 7vw; }
  .discography, .ravnir-discography { padding: 4.5rem 7vw; }
  footer { padding: 3.6rem 7vw 2.4rem; }
  footer > a { font-size: clamp(1.05rem, 5.6vw, 1.7rem); word-break: break-word; }
  .release-copy > p:not(.kicker), .about-copy > p:not(.kicker) { max-width: none; }
  /* anchor offset matches condensed mobile topbar */
  section[id], main section { scroll-margin-top: 72px; }

  /* landing → stack the two paths vertically */
  .landing { flex-direction: column; }
  .choice-ravnir .lc-bg { background-position: 50% 16%; }
  .choice-emma .lc-bg { background-position: 50% 26%; }
  .lc-content { padding: 0 8vw 6.5vh; gap: .65rem; }
  .lc-kicker { font-size: .54rem; letter-spacing: .32em; }
  .landing::before {
    top: auto; bottom: 50%; left: 12%; right: 12%; width: auto; height: 1px;
    transform: none;
    background: linear-gradient(90deg, transparent, var(--line) 18%, var(--line) 82%, transparent);
  }
  .landing-head { top: 3.5vh; gap: .35rem; }
  .lh-path { white-space: nowrap; letter-spacing: .3em; font-size: .54rem; }
}

@media (max-width: 480px) {
  .actions { flex-wrap: wrap; }
  .actions .button { flex: 1 1 auto; text-align: center; }
  .tagline { line-height: 1.7; }
  .release-cover { max-width: 320px; margin-inline: auto; }
  .presave-cta { width: 100%; justify-content: center; }
  .platforms { width: 100%; }
  .countdown { display: flex; width: 100%; gap: 0; padding: .95rem .35rem; }
  .cd-unit { flex: 1 1 0; min-width: 0; padding: 0 .25rem; }
  .cd-unit strong { font-size: clamp(1.75rem, 8vw, 2.3rem); }
  .ravnir-release-grid h3 { font-size: 1.1rem; }
  .release-list article { grid-template-columns: 88px 1fr; gap: 1.2rem; }
  .stats strong { font-size: 2.7rem; }
  .footer-links { gap: 1.1rem 1.6rem; }
}
