/* ============================================================
   CHRISTOPH M. MEYER — christophmeyer.berlin
   Velvet Hour · Editorial system (Direction A)
   ============================================================ */
:root{
  --wine:#1C0E14; --oxblood:#6B2238; --amber:#D4924A;
  --blush:#C4908A; --charcoal:#3A2A2E; --ivory:#F5EDE3;
  --bg:#F5EDE3; --bg-2:#EEE3D3; --ink:#241419;
  --ink-70:rgba(36,20,25,.7); --ink-55:rgba(36,20,25,.55); --ink-14:rgba(36,20,25,.14);
  --head:"Newsreader",Georgia,serif;
  --body:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"Space Mono",ui-monospace,monospace;
  --maxw:1200px;
  --gut:clamp(22px,5vw,64px);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--body);
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4,p{margin:0;}
::selection{background:var(--amber);color:var(--wine);}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut);}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--oxblood);}
.serif{font-family:var(--head);}
.em{font-style:italic;color:var(--oxblood);}
.amber{color:var(--amber);}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:18px var(--gut);background:rgba(245,237,227,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--ink-14);}
.brand{font-family:var(--head);font-size:20px;font-weight:500;letter-spacing:-.01em;color:var(--oxblood);white-space:nowrap;}
.brand b{color:var(--ink);font-weight:500;}
.site-nav{display:flex;align-items:center;gap:30px;}
.site-nav a{font-size:14.5px;color:var(--ink-70);position:relative;padding:6px 0;transition:color .15s;}
.site-nav a:hover{color:var(--ink);}
.site-nav a.active{color:var(--ink);}
.site-nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1.5px;background:var(--amber);}
.site-nav a.nav-cta{color:var(--ink);border:1px solid var(--ink);border-radius:999px;padding:8px 18px;}
.site-nav a.nav-cta:hover{background:var(--ink);color:var(--ivory);}
.nav-burger{display:none;width:42px;height:42px;border:1px solid var(--ink-14);background:transparent;border-radius:8px;
  cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:4px;}
.nav-burger span{width:18px;height:1.6px;background:var(--ink);display:block;transition:.2s;}

/* ---------- buttons / links ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--body);font-size:15px;font-weight:600;
  padding:14px 24px;border-radius:3px;cursor:pointer;border:1.5px solid transparent;transition:.18s;white-space:nowrap;}
.btn-primary{background:var(--amber);color:var(--wine);}
.btn-primary:hover{background:#c4823c;transform:translateY(-1px);}
.btn-ghost{border-color:var(--ink);color:var(--ink);}
.btn-ghost:hover{background:var(--ink);color:var(--ivory);}
.btn-ghost.on-dark{border-color:rgba(245,237,227,.4);color:var(--ivory);}
.btn-ghost.on-dark:hover{background:var(--ivory);color:var(--wine);}
.btn-ico{width:18px;height:18px;flex:0 0 auto;}
.tlink{font-size:15px;color:var(--ink);border-bottom:1.5px solid var(--amber);padding-bottom:3px;transition:.15s;display:inline-block;}
.tlink:hover{color:var(--oxblood);border-color:var(--oxblood);}
.tlink.muted{border-color:transparent;color:var(--ink-55);}
.tlink.muted:hover{color:var(--ink);}

/* ---------- soft-float photo frame (the chosen treatment) ---------- */
.photo{overflow:hidden;border-radius:4px;background:#1a0f13;
  box-shadow:0 2px 6px rgba(28,14,20,.14), 0 38px 80px -34px rgba(28,14,20,.62);}
.photo img{width:100%;height:100%;object-fit:cover;display:block;filter:contrast(1.02) saturate(1.03);}

/* striped labelled placeholder */
.ph{position:relative;display:flex;align-items:center;justify-content:center;border-radius:4px;overflow:hidden;
  background-color:#cdbaa8;background-image:repeating-linear-gradient(135deg,rgba(36,20,25,.06) 0 14px,transparent 14px 28px);}
.ph span{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:rgba(36,20,25,.5);
  border:1px solid rgba(36,20,25,.32);padding:7px 12px;border-radius:2px;background:rgba(245,237,227,.5);}

/* ---------- hero (home) ---------- */
.hero{padding:clamp(48px,7vw,86px) 0 clamp(40px,5vw,64px);}
.hero-grid{display:grid;grid-template-columns:1fr 0.84fr;gap:clamp(32px,5vw,64px);align-items:end;}
.hero h1{font-family:var(--head);font-weight:430;font-size:clamp(40px,5.4vw,66px);line-height:1.04;
  letter-spacing:-.018em;text-wrap:balance;margin-top:24px;}
.hero .lead{font-size:clamp(17px,1.4vw,19px);color:var(--ink-70);max-width:30em;margin-top:26px;}
.hero .actions{display:flex;flex-wrap:wrap;gap:22px;align-items:center;margin-top:36px;}
.hero-photo{height:clamp(360px,46vw,500px);position:relative;}
.hero-photo .hp-layer{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;
  filter:contrast(1.02) saturate(1.03);opacity:0;transition:opacity .5s ease;}
.hero-photo .hp-layer.show{opacity:1;}
.mode-fade{animation:modefade .45s ease;}
@keyframes modefade{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}

/* home hero mode toggle */
.mode-row{display:flex;align-items:center;gap:14px;margin-bottom:6px;}
.mode-toggle{display:inline-flex;border:1px solid var(--ink-14);background:rgba(255,255,255,.45);border-radius:999px;padding:4px;}
.mode-toggle button{font:inherit;font-size:13px;letter-spacing:.02em;border:0;background:transparent;cursor:pointer;
  padding:8px 18px;border-radius:999px;color:var(--ink-55);display:flex;align-items:center;gap:8px;transition:.18s;}
.mode-toggle button .dot{width:7px;height:7px;border-radius:50%;background:currentColor;opacity:.5;}
.mode-toggle button[aria-pressed="true"]{background:var(--ink);color:var(--ivory);}
.mode-toggle button[aria-pressed="true"] .dot{opacity:1;background:var(--amber);}
.mode-hint{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-55);}

/* ---------- generic section ---------- */
.section{padding:clamp(54px,7vw,96px) 0;}
.section.alt{background:var(--bg-2);}
.section.dark{background:var(--wine);color:var(--ivory);}
/* dark timeline flows into the dark footer — trim its bottom so the gap isn't a doubled dark void */
.section.dark:has(.htimeline){padding-bottom:clamp(20px,2.5vw,34px);}
.section.dark .eyebrow{color:var(--amber);}
.sec-head{max-width:38em;}
.sec-head .eyebrow{display:block;margin-bottom:18px;}
.sec-head h2{font-family:var(--head);font-weight:430;font-size:clamp(30px,3.6vw,46px);line-height:1.08;letter-spacing:-.015em;text-wrap:balance;}
.sec-head p{color:var(--ink-70);margin-top:18px;font-size:18px;}
.section.dark .sec-head p{color:rgba(245,237,227,.74);}
.rule{height:1px;background:var(--ink-14);border:0;margin:0;}
.section.dark .rule{background:rgba(245,237,227,.16);}

/* ---------- stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;}
.stat .n{font-family:var(--head);font-size:clamp(38px,4vw,50px);font-weight:430;letter-spacing:-.02em;line-height:1;}
.stat .n i{font-style:normal;color:var(--amber);}
.stat .l{font-size:14px;color:var(--ink-55);margin-top:12px;line-height:1.45;}
.section.dark .stat .l{color:rgba(245,237,227,.6);}

/* ---------- two-worlds cards ---------- */
.worlds{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.5vw,32px);}
.world{background:var(--ivory);border:1px solid var(--ink-14);border-radius:6px;padding:clamp(28px,3vw,42px);
  display:flex;flex-direction:column;gap:16px;transition:.2s;position:relative;overflow:hidden;}
.world:hover{transform:translateY(-3px);box-shadow:0 30px 60px -38px rgba(28,14,20,.5);border-color:rgba(36,20,25,.24);}
.world .k{font-family:var(--mono);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--oxblood);}
.world h3{font-family:var(--head);font-weight:430;font-size:clamp(26px,2.6vw,34px);line-height:1.1;}
.world p{color:var(--ink-70);font-size:16px;flex:1;}
.world .go{font-size:14.5px;color:var(--ink);border-bottom:1.5px solid var(--amber);padding-bottom:3px;align-self:flex-start;}

/* ---------- page hero (interior pages) ---------- */
.page-hero{padding:clamp(46px,6vw,84px) 0 clamp(30px,4vw,48px);}
.page-hero .eyebrow{display:block;margin-bottom:20px;}
.page-hero h1{font-family:var(--head);font-weight:430;font-size:clamp(40px,6vw,76px);line-height:1.02;letter-spacing:-.02em;text-wrap:balance;}
.page-hero .lead{font-size:clamp(18px,1.5vw,21px);color:var(--ink-70);max-width:34em;margin-top:26px;}
.section:has(.bigmail){padding-top:0;}

/* contact: text + portrait */
.contact-layout{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,84px);align-items:center;}
.contact-portrait{margin:0;}
.cp-frame{position:relative;aspect-ratio:4/5;}
.cp-frame img{width:100%;height:100%;object-fit:cover;object-position:center 12%;display:block;
  filter:contrast(1.05) brightness(1.01);}
@media (max-width:760px){
  .contact-layout{grid-template-columns:1fr;}
  .contact-portrait{order:-1;max-width:420px;}
}

/* ---------- timeline ---------- */
.timeline{display:flex;flex-direction:column;}
.tl-item{display:grid;grid-template-columns:200px 1fr;gap:clamp(20px,3vw,48px);padding:34px 0;border-top:1px solid var(--ink-14);}
.tl-item:last-child{border-bottom:1px solid var(--ink-14);}
.tl-when{font-family:var(--mono);font-size:12.5px;letter-spacing:.06em;color:var(--ink-55);padding-top:7px;}
.tl-role{font-family:var(--head);font-size:clamp(22px,2.4vw,28px);font-weight:430;line-height:1.15;}
/* career filter (Events / Music worlds) */
.cv-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.cv-toggle{align-self:flex-end;}
.tl-item{transition:opacity .4s ease;}
.tl-item[data-hidden]{display:none;}
/* "available for bookings" tag on the DJ role */
.book-tag{display:inline-flex;align-items:center;gap:9px;margin-top:18px;
  font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  color:#6b3a3f;background:rgba(196,144,138,.16);border:1px solid rgba(196,144,138,.5);
  border-radius:999px;padding:8px 15px;transition:background .18s,border-color .18s,transform .18s;}
.book-tag:hover{background:var(--oxblood);border-color:var(--oxblood);color:var(--ivory);transform:translateY(-1px);}
.book-dot{width:7px;height:7px;border-radius:50%;background:#3fa56a;box-shadow:0 0 0 0 rgba(63,165,106,.5);
  animation:bookpulse 2.2s ease-out infinite;}
.book-arrow{transition:transform .18s;}
.book-tag:hover .book-arrow{transform:translateX(3px);}
@keyframes bookpulse{0%{box-shadow:0 0 0 0 rgba(63,165,106,.5);}70%{box-shadow:0 0 0 6px rgba(63,165,106,0);}100%{box-shadow:0 0 0 0 rgba(63,165,106,0);}}
@media (prefers-reduced-motion:reduce){.book-dot{animation:none;}}

/* ---------- long-form prose article ---------- */
.prose{max-width:64ch;margin-top:clamp(32px,4vw,48px);}
.prose p{color:var(--ink-70);font-size:17px;line-height:1.8;margin:0 0 1.35em;text-wrap:pretty;}
.prose p:last-child{margin-bottom:0;}
.prose a{color:var(--oxblood);border-bottom:1px solid rgba(107,34,56,.35);transition:.15s;}
.prose a:hover{color:var(--wine);border-color:var(--wine);}
.prose .prose-lead{font-size:clamp(20px,2vw,23px);line-height:1.6;color:var(--ink);margin-bottom:1.1em;}
.prose .prose-sub{font-family:var(--head);font-weight:430;font-size:clamp(21px,1.9vw,26px);line-height:1.2;
  letter-spacing:-.01em;color:var(--oxblood);margin:2.2em 0 .65em;}
.prose .prose-sub:first-child{margin-top:0;}
.prose-fig{margin:2.4em 0;}
.prose-fig .photo{max-width:430px;}
.prose-fig img{width:100%;height:auto;display:block;transition:transform .4s ease;}
.prose-fig-link{display:block;position:relative;max-width:430px;border-radius:4px;overflow:hidden;}
.prose-fig-link::after{content:"";position:absolute;inset:0;background:rgba(28,14,20,.18);opacity:0;transition:opacity .25s;}
.prose-fig-link:hover::after{opacity:1;}
.prose-fig-link:hover img{transform:scale(1.03);}
.fig-play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2;
  width:62px;height:62px;border-radius:50%;background:rgba(245,237,227,.92);color:var(--wine);
  display:flex;align-items:center;justify-content:center;transition:transform .25s,background .25s;
  box-shadow:0 8px 30px -8px rgba(28,14,20,.5);}
.fig-play svg{width:26px;height:26px;margin-left:3px;}
.prose-fig-link:hover .fig-play{transform:translate(-50%,-50%) scale(1.08);background:var(--amber);}
.prose-fig figcaption{margin-top:12px;font-family:var(--mono);font-size:12px;letter-spacing:.04em;
  color:var(--ink-55);text-transform:uppercase;}
.tl-org{color:var(--oxblood);font-weight:600;font-size:15px;margin-top:6px;}
.tl-desc{color:var(--ink-70);margin-top:14px;font-size:16px;max-width:46em;}
.tl-desc ul{margin:14px 0 0;padding-left:18px;}
.tl-desc li{margin:7px 0;}

/* ---------- tag chips ---------- */
.chips{display:flex;flex-wrap:wrap;gap:10px;}
.chip{font-size:14px;color:var(--ink);background:var(--ivory);border:1px solid var(--ink-14);border-radius:999px;padding:9px 16px;}
.chip.blush{background:rgba(196,144,138,.16);border-color:rgba(196,144,138,.45);color:#6b3a3f;}

/* two-col text block */
.cols2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,64px);}
.defs{display:flex;flex-direction:column;}
.def{display:grid;grid-template-columns:auto 1fr;gap:24px;padding:16px 0;border-top:1px solid var(--ink-14);}
.def:last-child{border-bottom:1px solid var(--ink-14);}
.def dt{font-weight:600;font-size:15.5px;}
.def dd{margin:0;color:var(--ink-70);font-size:15.5px;text-align:right;}
/* stacked variant: long titles + meta read vertically, left-aligned */
.defs-stacked .def{grid-template-columns:1fr;gap:5px;}
.defs-stacked .def dt{font-size:16px;}
.defs-stacked .def dd{text-align:left;font-size:14px;letter-spacing:.01em;}

/* ---------- events by region ---------- */
.regions{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.5vw,36px);}
.region .k{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--oxblood);
  padding-bottom:14px;border-bottom:1px solid var(--ink-14);margin-bottom:8px;}
.region ul{list-style:none;margin:0;padding:0;}
.region li{font-family:var(--head);font-size:19px;padding:11px 0;border-bottom:1px solid var(--ink-14);color:var(--ink);}
.region li span{font-family:var(--body);font-size:12px;color:var(--ink-55);display:block;margin-top:2px;letter-spacing:.02em;}

/* ---------- music ---------- */
.mix{background:var(--charcoal);border-radius:8px;padding:clamp(22px,2.5vw,30px);box-shadow:0 30px 70px -40px rgba(0,0,0,.6);}
.mix .k{font-family:var(--mono);font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--blush);}
.mix h3{font-family:var(--head);color:var(--ivory);font-weight:430;font-size:clamp(24px,2.6vw,32px);margin:10px 0 18px;}
.mix iframe{border-radius:6px;display:block;}
.alias{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.5vw,32px);}
.alias .card{border:1px solid var(--ink-14);border-radius:6px;padding:clamp(24px,3vw,36px);background:var(--ivory);}
.alias .card .k{font-family:var(--mono);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--oxblood);}
.alias .card h3{font-family:var(--head);font-weight:430;font-size:28px;margin:10px 0 12px;}
.alias .card p{color:var(--ink-70);font-size:16px;}
.alias .card .links{display:flex;gap:18px;margin-top:20px;flex-wrap:wrap;}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(32px,5vw,72px);align-items:start;}
.bigmail{font-family:var(--head);font-weight:430;font-size:clamp(22px,2.3vw,30px);letter-spacing:-.01em;
  border-bottom:2px solid var(--amber);padding-bottom:6px;display:inline-block;line-height:1.15;word-break:break-word;}
.bigmail:hover{color:var(--oxblood);border-color:var(--oxblood);}

/* ---------- footer ---------- */
.site-footer{background:var(--wine);color:var(--ivory);padding:clamp(56px,7vw,90px) 0 36px;}
.foot-cta{font-family:var(--head);font-weight:430;font-size:clamp(34px,5vw,64px);line-height:1.03;letter-spacing:-.02em;
  max-width:14ch;text-wrap:balance;}
.foot-cta a{border-bottom:2px solid var(--amber);}
.foot-cta a:hover{color:var(--amber);}
.foot-cta .typer{color:var(--amber);}
.foot-cta .typer::after{content:"";display:inline-block;width:3px;height:.82em;background:var(--amber);
  margin-left:5px;vertical-align:-0.04em;animation:typcaret 1s steps(1) infinite;}
@keyframes typcaret{0%,49%{opacity:1;}50%,100%{opacity:0;}}
@media (prefers-reduced-motion:reduce){.foot-cta .typer::after{animation:none;}}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:32px;margin-top:clamp(40px,5vw,64px);
  padding-top:40px;border-top:1px solid rgba(245,237,227,.16);}
.foot-grid h4{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--blush);margin-bottom:16px;font-weight:400;}
.foot-grid a,.foot-grid p{color:rgba(245,237,227,.74);font-size:15px;display:block;margin:9px 0;transition:color .15s;}
.foot-grid a:hover{color:var(--amber);}
.foot-brand{font-family:var(--head);font-size:22px;color:var(--ivory);}
.foot-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:48px;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(245,237,227,.5);}
.foot-legal{display:flex;gap:22px;}
.foot-legal a{color:rgba(245,237,227,.5);transition:color .15s;}
.foot-legal a:hover{color:var(--amber);}

/* ---------- timeline (dark, horizontal) ---------- */
.htimeline{margin-top:clamp(36px,4.4vw,58px);}
.htl-viewport{overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none;
  cursor:grab;-webkit-overflow-scrolling:touch;
  margin-inline:calc(-1*var(--gut));padding-inline:var(--gut);}
.htl-viewport::-webkit-scrollbar{display:none;}
.htl-viewport.dragging{cursor:grabbing;}
.htl-viewport.dragging *{user-select:none;}
.htl-track{position:relative;display:flex;gap:clamp(20px,2.4vw,34px);list-style:none;margin:0;padding:0;
  width:max-content;}
.htl-track::before{content:"";position:absolute;left:0;right:0;top:33px;height:1px;
  background:rgba(245,237,227,.18);}
.htl-item{position:relative;flex:0 0 auto;width:clamp(230px,24vw,288px);}
.htl-year{display:block;height:24px;line-height:24px;font-family:var(--mono);font-size:13px;
  letter-spacing:.06em;color:var(--amber);}
.htl-node{display:block;height:18px;position:relative;}
.htl-node::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:11px;height:11px;border-radius:50%;background:var(--amber);box-shadow:0 0 0 5px var(--wine);}
.htl-item.now .htl-node::before{background:var(--wine);border:1.5px solid var(--amber);}
.htl-item.now .htl-year{color:var(--blush);}
.htl-body{margin-top:14px;}
.htl-body h3{font-family:var(--head);font-weight:480;font-size:clamp(19px,1.6vw,23px);
  line-height:1.16;letter-spacing:-.01em;color:var(--ivory);}
.htl-body p{margin-top:8px;color:rgba(245,237,227,.7);font-size:15px;line-height:1.55;}

.htl-controls{display:flex;align-items:center;gap:20px;margin-top:clamp(28px,3vw,40px);}
.htl-arrow{flex:0 0 auto;width:46px;height:46px;border-radius:50%;cursor:pointer;
  background:transparent;color:var(--ivory);border:1px solid rgba(245,237,227,.3);
  font-size:17px;line-height:1;transition:.18s;display:flex;align-items:center;justify-content:center;}
.htl-arrow:hover{background:var(--amber);border-color:var(--amber);color:var(--wine);}
.htl-arrow:disabled{opacity:.3;cursor:default;}
.htl-arrow:disabled:hover{background:transparent;border-color:rgba(245,237,227,.3);color:var(--ivory);}
.htl-progress{flex:1;height:2px;background:rgba(245,237,227,.16);border-radius:2px;position:relative;}
.htl-progress-bar{position:absolute;left:0;top:0;height:100%;width:30%;background:var(--amber);
  border-radius:2px;transition:width .12s linear,left .12s linear;}
@media (max-width:620px){
  .htl-item{width:78vw;}
}

/* ---------- SoundCloud consent gate ---------- */
.sc-embed{position:relative;min-height:240px;border-radius:6px;overflow:hidden;}
.sc-consent{background:rgba(245,237,227,.04);border:1px solid rgba(245,237,227,.16);border-radius:6px;
  padding:clamp(26px,4vw,40px);display:flex;flex-direction:column;gap:12px;align-items:flex-start;}
.sc-consent-lead{font-family:var(--head);font-size:clamp(20px,2.2vw,26px);color:var(--ivory);}
.sc-consent-body{color:rgba(245,237,227,.66);font-size:14.5px;max-width:52ch;line-height:1.55;}
.sc-consent-body a{color:var(--amber);border-bottom:1px solid rgba(212,146,74,.5);}
.sc-consent-actions{display:flex;flex-wrap:wrap;gap:18px;align-items:center;margin-top:8px;}
.sc-consent-actions .tlink.muted{color:rgba(245,237,227,.6);}
.sc-consent-actions .tlink.muted:hover{color:var(--ivory);}

/* ---------- legal / prose pages ---------- */
.section:has(.legal){padding-top:0;}
.legal{max-width:760px;}
.legal h2{font-family:var(--head);font-weight:430;font-size:clamp(22px,2.4vw,28px);letter-spacing:-.01em;
  margin:44px 0 14px;line-height:1.2;}
.legal h2:first-child{margin-top:0;}
.legal h3{font-family:var(--body);font-weight:600;font-size:16px;margin:26px 0 8px;}
.legal p{color:var(--ink-70);margin:10px 0;font-size:16px;line-height:1.65;}
.legal a{color:var(--oxblood);border-bottom:1px solid rgba(107,34,56,.35);}
.legal a:hover{color:var(--ink);}
.legal address{font-style:normal;color:var(--ink);line-height:1.7;font-size:16px;margin:8px 0;}
.legal ul{margin:10px 0;padding-left:20px;color:var(--ink-70);}
.legal li{margin:7px 0;line-height:1.6;}
.legal .todo{background:rgba(212,146,74,.13);border:1px dashed rgba(107,34,56,.5);border-radius:4px;
  padding:2px 7px;font-family:var(--mono);font-size:.82em;letter-spacing:.02em;color:#7a3a26;white-space:nowrap;}
.legal-note{background:var(--bg-2);border:1px solid var(--ink-14);border-left:3px solid var(--amber);
  border-radius:4px;padding:18px 22px;margin:0 0 36px;font-size:14.5px;color:var(--ink-70);line-height:1.6;max-width:760px;}
.legal-note strong{color:var(--ink);}

/* ---------- reveal on scroll ---------- */.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease;}
.reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;}.mode-fade{animation:none;}}

/* ---------- responsive ---------- */
@media (max-width:920px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-photo{height:clamp(320px,80vw,460px);order:-1;}
  .stats{grid-template-columns:1fr 1fr;gap:28px;}
  .worlds,.cols2,.regions,.alias,.contact-grid{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr 1fr;}
  .tl-item{grid-template-columns:1fr;gap:6px;}
  .tl-when{padding-top:0;}
}
@media (max-width:680px){
  .site-nav{position:fixed;inset:0 0 auto 0;top:0;flex-direction:column;align-items:flex-start;gap:4px;
    background:var(--ivory);padding:88px var(--gut) 32px;transform:translateY(-110%);transition:transform .28s ease;
    border-bottom:1px solid var(--ink-14);box-shadow:0 30px 60px -30px rgba(28,14,20,.4);z-index:40;}
  .site-nav.open{transform:none;}
  .site-nav a{font-size:20px;font-family:var(--head);padding:10px 0;}
  .site-nav a.nav-cta{border:0;padding:10px 0;color:var(--oxblood);}
  .site-nav a.active::after{display:none;}
  .nav-burger{display:flex;z-index:60;}
  .foot-grid{grid-template-columns:1fr;}
  .stats{grid-template-columns:1fr 1fr;}
  .def{grid-template-columns:1fr;gap:4px;}
  .def dd{text-align:left;}
}
