/* ============================================================
   NADIIA — Hi-Fi · "Clean Modern"
   White · soft yellow accent · grotesk type
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Hanken+Grotesk:wght@300;400;500;600;700&family=Space+Mono:wght@400;700&display=swap');

:root{
  --ink:#16171c;
  --ink-2:#565b66;
  --ink-3:#9aa0ab;
  --paper:#ffffff;
  --paper-2:#f6f6f4;
  --card:#ffffff;
  --line:#e9e9e6;
  --line-2:#f1f1ee;

  --accent:#ffd21f;          /* clean yellow */
  --accent-2:#ffe066;        /* lighter yellow */
  --accent-ink:#a07e00;      /* readable yellow-ink on white */
  --accent-soft:#fff7cf;     /* pale yellow tint */
  --on-accent:#1a1b20;       /* text on yellow */

  --serif:'Space Grotesk', system-ui, sans-serif;   /* display */
  --sans:'Hanken Grotesk', system-ui, sans-serif;   /* body */
  --mono:'Space Mono', monospace;

  --maxw:1280px;
  --gut:clamp(20px, 5vw, 72px);
  --shadow:0 18px 44px -26px rgba(20,22,30,.28);
}

/* dark = clean night */
.theme-dark{
  --ink:#f3f4f6;
  --ink-2:#aeb3bd;
  --ink-3:#6f7480;
  --paper:#0e0f12;
  --paper-2:#16181c;
  --card:#16181c;
  --line:#26282e;
  --line-2:#1d1f24;
  --accent:#ffd84d;
  --accent-2:#ffe88a;
  --accent-ink:#ffd84d;
  --accent-soft:#2a2614;
  --on-accent:#16171c;
  --shadow:0 30px 60px -30px rgba(0,0,0,.7);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--sans); font-size:18px; line-height:1.6;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
  transition:background .4s ease, color .4s ease;
}
/* beat host-injected `html,body{background:transparent}` — keep paper theme-aware */
html body{ background:var(--paper); }

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding-left:var(--gut); padding-right:var(--gut); }

/* ---------- type helpers ---------- */
.kicker{
  font-family:var(--mono); font-size:12px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--accent-ink); font-weight:400;
}
.serif{ font-family:var(--serif); font-weight:600; line-height:.96; letter-spacing:-.02em; }
.display{ font-family:var(--serif); font-weight:700; line-height:.9; letter-spacing:-.03em; }
h2.sec{ font-family:var(--serif); font-weight:600; font-size:clamp(34px,5vw,58px); line-height:1; margin:0; letter-spacing:-.03em; text-wrap:balance; }
.sec-head > div:first-child{ min-width:0; }
.lead{ font-size:clamp(18px,2vw,22px); color:var(--ink-2); max-width:46ch; }
.muted{ color:var(--ink-3); }
em{ font-style:normal; }

/* ---------- buttons ---------- */
.btn{
  --bg:transparent; --fg:var(--ink); --bd:var(--ink);
  display:inline-flex; align-items:center; gap:.6em; cursor:pointer;
  font-family:var(--sans); font-weight:600; font-size:15px; letter-spacing:.01em;
  padding:14px 24px; border-radius:40px; border:1.5px solid var(--bd);
  background:var(--bg); color:var(--fg); transition:transform .25s, background .25s, color .25s, border-color .25s;
}
.btn:hover{ transform:translateY(-2px); }
.btn{ white-space:nowrap; }
.btn .ar{ transition:transform .25s; }
.btn:hover .ar{ transform:translate(3px,-1px); }
.btn--solid{ --bg:var(--accent); --fg:var(--on-accent); --bd:var(--accent); }
.btn--solid:hover{ --bg:var(--accent-2); }
.btn--ghost{ --bd:var(--line); --fg:var(--ink-2); }
.btn--ghost:hover{ --bd:var(--ink); --fg:var(--ink); }
.btn--sm{ padding:9px 16px; font-size:13px; }

/* ---------- nav ---------- */
.nav{
  position:sticky; top:0; z-index:40;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:18px var(--gut); backdrop-filter:blur(10px);
  background:color-mix(in srgb, var(--paper) 82%, transparent);
  border-bottom:1px solid transparent; transition:border-color .3s, padding .3s, background .3s;
}
.nav.scrolled{ border-color:var(--line); padding-top:12px; padding-bottom:12px; }
.brand{ font-family:var(--serif); font-weight:700; font-size:28px; line-height:1; letter-spacing:-.04em; white-space:nowrap; flex-shrink:0; display:inline-flex; align-items:center; }
.brand-logo{ height:1.7em; width:auto; flex-shrink:0; display:block; }
.brand-logo--dark{ display:none; }
.theme-dark .brand-logo--dark{ display:block; }
.theme-dark .brand-logo--light{ display:none; }
.brand-name{ margin-left:13px; padding-left:13px; line-height:1;
  border-left:1.5px solid color-mix(in srgb, currentColor 22%, transparent); }
.nav-links{ display:flex; gap:30px; align-items:center; }
.nav-close{ display:none; }
.nav-links .nav-cta{ display:none; }
.nav-links a{
  font-family:var(--mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-2);
  position:relative; padding:4px 0;
}
.nav-links a::after{ content:''; position:absolute; left:0; bottom:-2px; width:0; height:1.5px; background:var(--accent); transition:width .25s; }
.nav-links a:hover{ color:var(--ink); }
.nav-links a:hover::after{ width:100%; }
.nav-links a.active{ color:var(--ink); }
.nav-links a.active::after{ width:100%; }
.nav-right{ display:flex; align-items:center; gap:14px; }
.lang{ display:flex; font-family:var(--mono); font-size:12px; border:1.5px solid var(--line); border-radius:30px; overflow:hidden; }
.lang button{ background:transparent; border:none; cursor:pointer; padding:6px 11px; color:var(--ink-3); font-family:var(--mono); font-size:12px; letter-spacing:.05em; }
.lang button.on{ background:var(--ink); color:var(--paper); }
.theme-btn{
  display:grid; place-items:center; width:34px; height:34px; flex:0 0 auto;
  border:1.5px solid var(--line); border-radius:50%; background:transparent;
  color:var(--ink-2); cursor:pointer; padding:0; transition:color .25s, border-color .25s, background .25s;
}
.theme-btn:hover{ color:var(--ink); border-color:var(--ink); }
.theme-btn svg{ width:16px; height:16px; }
.theme-btn .i-moon{ display:block; }
.theme-btn .i-sun{ display:none; }
.theme-dark .theme-btn .i-moon{ display:none; }
.theme-dark .theme-btn .i-sun{ display:block; }

/* hamburger (mobile only) */
.menu-btn{
  display:none; width:40px; height:40px; flex:0 0 auto;
  background:transparent; border:none; cursor:pointer; padding:0; position:relative;
}
.menu-btn .bars{
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
}
.menu-btn .bars, .menu-btn .bars::before, .menu-btn .bars::after{
  content:''; display:block; width:22px; height:2px; background:var(--ink); border-radius:2px;
  transition:transform .3s ease, opacity .2s ease, background .2s ease;
}
.menu-btn .bars::before{ position:absolute; top:-7px; left:0; }
.menu-btn .bars::after{ position:absolute; top:7px; left:0; }
.nav.open .menu-btn .bars{ background:transparent; }
.nav.open .menu-btn .bars::before{ transform:translateY(7px) rotate(45deg); }
.nav.open .menu-btn .bars::after{ transform:translateY(-7px) rotate(-45deg); }

/* ---------- hero ---------- */
.hero{ position:relative; padding-block:clamp(30px,6vw,70px) clamp(50px,7vw,90px); }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(24px,4vw,60px); align-items:center; }
.hero-copy{ position:relative; z-index:3; }
.hero-copy .kicker{ margin-bottom:22px; display:flex; align-items:center; gap:12px; }
.hero-copy .kicker::before{ content:''; width:42px; height:1.5px; background:var(--accent); display:inline-block; }
.hero h1{ margin:0; font-family:var(--serif); font-weight:700; font-size:clamp(60px,9.5vw,124px); line-height:.88; letter-spacing:-.045em; }
.hero h1 em{ display:block; font-weight:400; font-style:normal; color:var(--ink-2); font-size:.32em; line-height:1.1; margin-top:.38em; letter-spacing:-.01em; }
.hero .lead{ margin:26px 0 32px; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.hero-meta{ display:flex; gap:34px; margin-top:38px; padding-top:24px; border-top:1px solid var(--line); flex-wrap:wrap; }
.hero-meta .m .k{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); margin-bottom:4px; }
.hero-meta .m .v{ font-family:var(--serif); font-weight:600; letter-spacing:-.02em; font-size:20px; line-height:1.05; white-space:nowrap; letter-spacing:-.02em; }

/* portrait */
.portrait{ position:relative; }
.portrait .frame{
  position:relative; aspect-ratio:3/3.7; border-radius:24px; overflow:hidden;
  background:var(--paper-2); border:1px solid var(--line); box-shadow:var(--shadow);
}
.ph{
  position:relative; width:100%; height:100%;
  background:var(--paper-2);
  display:flex; align-items:center; justify-content:center; padding:18px;
}
.ph::before{
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at 50% 42%, color-mix(in srgb,var(--accent) 9%, transparent), transparent 60%);
}
.ph .cap{ position:relative; font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); background:var(--card); padding:6px 12px; border-radius:30px; border:1px solid var(--line); }
.portrait .badge{
  position:absolute; left:-18px; bottom:46px; z-index:4;
  background:var(--accent); color:var(--on-accent); font-family:var(--mono); font-size:12px; letter-spacing:.06em;
  padding:11px 16px; border-radius:30px; box-shadow:var(--shadow);
}
.portrait .disc{
  position:absolute; right:-26px; top:-26px; width:120px; height:120px; border-radius:50%;
  border:1.5px solid var(--accent); z-index:4; display:grid; place-items:center;
  animation:spin 18s linear infinite;
}
.portrait .disc span{ font-family:var(--mono); font-size:10px; letter-spacing:.3em; text-transform:uppercase; color:var(--accent-ink); }
@keyframes spin{ to{ transform:rotate(360deg); } }

/* ---------- section frame ---------- */
.section{ padding-block:clamp(54px,8vw,110px); position:relative; z-index:2; }
.sec-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:46px; flex-wrap:wrap; }
.sec-head .kicker{ margin-bottom:14px; }

/* ---------- concerts tracklist ---------- */
.tracklist{ border-top:1px solid var(--line); }
.track{
  display:grid; grid-template-columns:54px 1fr auto auto; gap:22px; align-items:center;
  padding:22px 8px; border-bottom:1px solid var(--line); position:relative; transition:padding .3s;
}
.track:hover{ padding-left:18px; }
.track::after{ content:''; position:absolute; left:0; top:0; height:100%; width:0; background:var(--accent-soft); z-index:-1; transition:width .35s; opacity:.6; }
.track:hover::after{ width:100%; }
.track .no{ font-family:var(--mono); font-size:14px; color:var(--accent-ink); }
.track .where{ font-family:var(--serif); font-size:clamp(24px,3vw,34px); line-height:1.04; }
.track .where .city{ display:block; font-family:var(--sans); font-size:14px; letter-spacing:.04em; color:var(--ink-3); margin-top:4px; }
.track .date{ font-family:var(--mono); font-size:14px; color:var(--ink-2); text-align:right; }
.track .date b{ display:block; font-size:22px; color:var(--ink); font-weight:700; }
.track .go{ font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); white-space:nowrap; }
.track:hover .go{ color:var(--accent-ink); }
.track.tba{ opacity:.55; }

/* ---------- projects ---------- */
.proj-grid{ display:grid; grid-template-columns:1fr 1fr; gap:28px; }
.proj{
  background:var(--card); border:1px solid var(--line); border-radius:20px; overflow:hidden;
  display:flex; flex-direction:column; transition:transform .3s, box-shadow .3s;
}
.proj:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.proj .img{ aspect-ratio:16/10; }
.proj .body{ padding:26px 28px 30px; }
.proj .tags{ display:flex; gap:8px; margin-bottom:14px; flex-wrap:wrap; }
.tag{ font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; padding:5px 11px; border-radius:30px; border:1px solid var(--line); color:var(--ink-2); }
.tag.live{ background:var(--accent); border-color:var(--accent); color:var(--on-accent); }
.proj h3{ font-family:var(--serif); font-weight:600; font-size:30px; margin:0 0 10px; line-height:1.02; letter-spacing:-.03em; }
.proj p{ margin:0 0 18px; color:var(--ink-2); font-size:16px; }

/* ---------- videos filmstrip ---------- */
.films{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.film{ position:relative; border-radius:16px; overflow:hidden; border:1px solid var(--line); cursor:pointer; }
.film .img{ aspect-ratio:16/9; }
.film .play{
  position:absolute; inset:0; display:grid; place-items:center; background:rgba(20,15,8,.18); transition:background .3s;
}
.film:hover .play{ background:rgba(20,15,8,.32); }
.film .play .disc2{ width:64px; height:64px; border-radius:50%; background:var(--accent); display:grid; place-items:center; box-shadow:var(--shadow); transition:transform .3s; }
.film:hover .play .disc2{ transform:scale(1.08); }
.film .play .disc2::after{ content:''; border-style:solid; border-width:11px 0 11px 18px; border-color:transparent transparent transparent var(--on-accent); margin-left:4px; }
.film .label{ position:absolute; left:14px; bottom:12px; color:#fff; font-family:var(--mono); font-size:12px; letter-spacing:.06em; text-shadow:0 1px 6px rgba(0,0,0,.6); }

/* ---------- about teaser ---------- */
.about{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,70px); align-items:center; }
.about .big{ font-family:var(--serif); font-weight:600; font-style:normal; font-size:clamp(26px,3.4vw,40px); line-height:1.14; letter-spacing:-.03em; }
.about .big b{ font-style:normal; font-weight:700; color:var(--accent-ink); }
.pull{ border-left:2px solid var(--accent); padding-left:20px; }

/* ---------- newsletter band ---------- */
.band{ background:var(--ink); color:var(--paper); border-radius:28px; padding:clamp(36px,5vw,64px); position:relative; overflow:hidden; }
.theme-dark .band{ background:var(--card); border:1px solid var(--line); }
.band h2{ color:var(--paper); }
.theme-dark .band h2{ color:var(--ink); }
.band .row{ display:flex; gap:30px; align-items:center; justify-content:space-between; flex-wrap:wrap; }
.band .form{ display:flex; gap:10px; flex-wrap:wrap; }
.input{
  background:transparent; border:1.5px solid color-mix(in srgb, var(--paper) 40%, transparent);
  color:var(--paper); border-radius:40px; padding:13px 20px; font-family:var(--sans); font-size:15px; min-width:240px;
}
.theme-dark .input{ color:var(--ink); border-color:var(--line); }
.input::placeholder{ color:color-mix(in srgb, var(--paper) 55%, transparent); }
.band .disc-bg{ position:absolute; right:-80px; top:-80px; width:280px; height:280px; border-radius:50%; border:1px solid color-mix(in srgb,var(--accent) 60%, transparent); }
.band .disc-bg::after{ content:''; position:absolute; inset:40px; border-radius:50%; border:1px solid color-mix(in srgb,var(--accent) 35%, transparent); }

/* ---------- footer ---------- */
.foot{ padding-block:clamp(50px,7vw,90px) 30px; border-top:1px solid var(--line); position:relative; z-index:2; }
.foot-grid{ display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:34px; padding-bottom:46px; }
.foot .brand{ font-size:40px; margin-bottom:16px; }
.foot h5{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); margin:0 0 16px; }
.foot a.fl{ display:block; padding:6px 0; color:var(--ink-2); font-size:16px; transition:color .2s, padding-left .2s; }
.foot a.fl:hover{ color:var(--accent-ink); padding-left:6px; }
.social{ display:flex; gap:10px; margin-top:6px; }
.social a{ width:42px; height:42px; border:1.5px solid var(--line); border-radius:12px; display:grid; place-items:center; font-family:var(--mono); font-size:12px; color:var(--ink-2); transition:all .25s; }
.social a:hover{ background:var(--accent); border-color:var(--accent); color:var(--on-accent); transform:translateY(-3px); }
.social a svg{ width:19px; height:19px; }
.foot-bottom{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; padding-top:24px; border-top:1px solid var(--line); font-family:var(--mono); font-size:12px; color:var(--ink-3); letter-spacing:.04em; }
.foot-bottom .lg{ display:flex; gap:20px; }
.foot-bottom a:hover{ color:var(--accent-ink); }

/* ---------- reveal ---------- */
.reveal{ opacity:0; transform:translateY(24px); }
.reveal.anim{ transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
.no-js .reveal{ opacity:1; transform:none; }

/* lang visibility */
[data-en]{ display:none; }
body.lang-en [data-de]{ display:none; }
body.lang-en [data-en]{ display:revert; }

/* ---------- two-up strip (concerts + current project) ---------- */
.duo{ display:grid; grid-template-columns:1fr 1fr; gap:26px; }
.panel{ background:var(--card); border:1px solid var(--line); border-radius:22px; padding:30px 32px 34px; display:flex; flex-direction:column; }
.panel .phead{ display:flex; align-items:baseline; justify-content:space-between; gap:14px; margin-bottom:20px; }
.panel .phead h3{ font-family:var(--serif); font-weight:600; letter-spacing:-.02em; font-size:25px; margin:0; line-height:1.05; white-space:nowrap; }
.panel .more{ font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); white-space:nowrap; }
.panel .more:hover{ color:var(--accent-ink); }

/* compact concert list */
.mini{ border-top:1px solid var(--line); margin-top:2px; }
.mini .ev{ display:grid; grid-template-columns:62px 1fr auto; gap:16px; align-items:center; padding:15px 4px; border-bottom:1px solid var(--line); transition:padding-left .25s; }
.mini .ev:hover{ padding-left:12px; }
.mini .ev .d{ font-family:var(--mono); font-size:12px; color:var(--accent-ink); line-height:1.2; }
.mini .ev .d b{ display:block; font-size:21px; color:var(--ink); font-weight:700; }
.mini .ev .w{ font-family:var(--serif); font-size:22px; line-height:1.05; }
.mini .ev .w small{ display:block; font-family:var(--sans); font-size:13px; color:var(--ink-3); margin-top:2px; }
.mini .ev .go{ font-family:var(--mono); font-size:12px; color:var(--ink-3); }
.mini .ev:hover .go{ color:var(--accent-ink); }
.mini .ev.tba{ opacity:.5; }
.panel .panel-cta{ margin-top:auto; padding-top:22px; }

/* featured current project */
.feat .img{ aspect-ratio:16/10; border-radius:14px; overflow:hidden; margin-bottom:18px; }
.feat .tags{ display:flex; gap:8px; margin-bottom:12px; }
.feat h4{ font-family:var(--serif); font-weight:600; letter-spacing:-.02em; font-size:27px; margin:0 0 8px; line-height:1.02; }
.feat p{ margin:0 0 18px; color:var(--ink-2); font-size:16px; }

/* footer newsletter strip */
.foot-news{ display:flex; align-items:center; justify-content:space-between; gap:26px; flex-wrap:wrap;
  padding-bottom:38px; margin-bottom:40px; border-bottom:1px solid var(--line); }

/* ---------- home news preview window ---------- */
.news-window{ background:var(--card); border:1px solid var(--line); border-radius:24px; overflow:hidden; box-shadow:var(--shadow); }
.nw-bar{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding:18px 26px; border-bottom:1px solid var(--line); }
.nw-bar .ttl{ display:flex; align-items:baseline; gap:14px; }
.nw-bar h3{ font-family:var(--serif); font-weight:600; letter-spacing:-.02em; font-size:26px; margin:0; line-height:1; }
.nw-bar .live-dot{ display:inline-flex; align-items:center; gap:7px; font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent-ink); }
.nw-bar .live-dot::before{ content:''; width:8px; height:8px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 0 var(--accent); animation:pulse 2.2s infinite; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 color-mix(in srgb,var(--accent) 70%, transparent); } 70%{ box-shadow:0 0 0 7px transparent; } 100%{ box-shadow:0 0 0 0 transparent; } }
.nw-body{ display:grid; grid-template-columns:1.15fr .85fr; gap:0; align-items:stretch; }
.nw-feature{ padding:26px 28px; border-right:1px solid var(--line); display:flex; flex-direction:column; }
.nw-feature .img{ aspect-ratio:16/7; border-radius:14px; overflow:hidden; margin-bottom:18px; max-height:240px; }
.nw-feature .meta{ display:flex; align-items:center; gap:12px; margin-bottom:12px; }
.nw-feature h4{ font-family:var(--serif); font-weight:600; letter-spacing:-.02em; font-size:clamp(24px,2.6vw,32px); line-height:1.04; margin:0 0 10px; letter-spacing:-.01em; }
.nw-feature p{ color:var(--ink-2); font-size:16px; margin:0 0 18px; }
.nw-feature .read{ margin-top:4px; align-self:flex-start; }
.nw-side{ display:flex; flex-direction:column; }
.nw-side .item{ display:grid; grid-template-columns:64px 1fr; gap:15px; align-items:center; padding:18px 26px; border-bottom:1px solid var(--line); transition:background .2s, padding-left .25s; }
.nw-side .item:hover{ background:var(--paper-2); padding-left:32px; }
.nw-side .item .thumb{ aspect-ratio:1; border-radius:10px; overflow:hidden; }
.nw-side .item .date{ font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); margin-bottom:3px; }
.nw-side .item h5{ font-family:var(--serif); font-weight:600; letter-spacing:-.02em; font-size:19px; line-height:1.08; margin:0; }
.nw-foot{ display:flex; align-items:center; justify-content:center; padding:22px; }
.nw-foot .btn{ min-width:220px; justify-content:center; }
.nw-side .item.tba{ opacity:.5; }
.nw-side .item.tba:hover{ background:none; padding-left:26px; }

.date{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }
.foot-news h4{ font-family:var(--serif); font-weight:600; letter-spacing:-.02em; font-size:clamp(26px,3vw,38px); margin:0 0 4px; line-height:1; }
.foot-news .sub{ color:var(--ink-3); font-size:15px; }
.foot-news .form{ display:flex; gap:10px; flex-wrap:wrap; }
.foot-news .input{ background:transparent; border:1.5px solid var(--line); color:var(--ink);
  border-radius:40px; padding:13px 20px; font-family:var(--sans); font-size:15px; min-width:240px; }
.foot-news .input::placeholder{ color:var(--ink-3); }

/* ============================================================
   INNER PAGES
   ============================================================ */
.page-head{ padding-block:clamp(40px,6vw,80px) clamp(28px,4vw,46px); border-bottom:1px solid var(--line); }
.page-head .kicker{ margin-bottom:18px; display:flex; align-items:center; gap:12px; }
.page-head .kicker::before{ content:''; width:42px; height:1.5px; background:var(--accent); }
.page-head h1{ font-family:var(--serif); font-weight:700; font-size:clamp(46px,8vw,100px); line-height:.92; letter-spacing:-.045em; margin:0; }
.page-head .lead{ margin-top:22px; }
.crumbs{ font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); margin-bottom:20px; }
.crumbs a:hover{ color:var(--accent-ink); }

/* generic content section */
.psection{ padding-block:clamp(44px,6vw,86px); }
.psection.tight{ padding-block:clamp(30px,4vw,54px); }

/* bio layout */
.bio-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(30px,5vw,68px); align-items:start; }
.bio-portrait .frame{ position:relative; aspect-ratio:3/3.7; border-radius:24px; overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow); }
.bio-body p{ font-size:18px; color:var(--ink-2); margin:0 0 18px; max-width:60ch; }
.bio-body .big{ font-family:var(--serif); font-weight:600; letter-spacing:-.03em; font-size:clamp(24px,3vw,34px); color:var(--ink); line-height:1.18; margin:0 0 26px; }
.factlist{ display:grid; grid-template-columns:1fr 1fr; gap:18px 30px; margin-top:30px; padding-top:26px; border-top:1px solid var(--line); }
.factlist .f .k{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); margin-bottom:4px; }
.factlist .f .v{ font-family:var(--serif); font-weight:500; font-size:20px; letter-spacing:-.02em; }

/* press kit callout */
.callout{ background:var(--card); border:1px solid var(--line); border-radius:22px; padding:clamp(26px,4vw,42px); display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.callout h3{ font-family:var(--serif); font-weight:600; letter-spacing:-.02em; font-size:clamp(26px,3vw,36px); margin:0 0 6px; }

/* media photo grid */
.photo-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.photo-grid .ph{ aspect-ratio:4/3; border-radius:14px; }
.photo-grid .ph.tall{ grid-row:span 2; aspect-ratio:auto; }
.filter-row{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:30px; }
.pill{ font-family:var(--sans); font-weight:500; font-size:14px; padding:8px 18px; border-radius:30px; border:1.5px solid var(--line); color:var(--ink-2); cursor:pointer; background:var(--card); transition:all .2s; }
.pill.on{ background:var(--accent); border-color:var(--accent); color:var(--on-accent); }
.pill:hover{ border-color:var(--ink); }

/* news list */
.news-feature{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(24px,4vw,48px); align-items:center; margin-bottom:clamp(40px,5vw,64px); }
.news-feature .ph{ aspect-ratio:4/3; border-radius:18px; }
.news-feature .meta{ display:flex; gap:12px; align-items:center; margin-bottom:16px; }
.news-feature h2{ font-family:var(--serif); font-weight:600; letter-spacing:-.02em; font-size:clamp(30px,4vw,50px); line-height:1.02; margin:0 0 16px; letter-spacing:-.01em; }
.news-list{ display:grid; grid-template-columns:1fr 1fr; gap:30px; }
.news-item{ display:grid; grid-template-columns:130px 1fr; gap:20px; padding-bottom:26px; border-bottom:1px solid var(--line); }
.news-item .ph{ aspect-ratio:1; border-radius:12px; }
.news-item h3{ font-family:var(--serif); font-weight:600; letter-spacing:-.02em; font-size:23px; margin:8px 0 8px; line-height:1.05; }
.news-item .date{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); }

/* forms (light) */
.form-card{ background:var(--card); border:1px solid var(--line); border-radius:24px; padding:clamp(26px,4vw,44px); }
.fstep{ font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent-ink); margin:8px 0 18px; padding-top:22px; border-top:1px solid var(--line); }
.fstep:first-child{ padding-top:0; border-top:none; margin-top:0; }
.fgrid{ display:grid; grid-template-columns:1fr 1fr; gap:18px 22px; }
.ffield{ display:flex; flex-direction:column; gap:7px; }
.ffield.full{ grid-column:1 / -1; }
.ffield label{ font-size:14px; color:var(--ink-2); font-weight:500; }
.ffield label .req{ color:var(--accent-ink); }
.f-input{ height:48px; border:1.5px solid var(--line); background:var(--paper); border-radius:12px; padding:0 15px;
  font-family:var(--sans); font-size:15px; color:var(--ink); transition:border-color .2s; width:100%; }
.f-input::placeholder{ color:var(--ink-3); }
.f-input:focus{ outline:none; border-color:var(--accent); }
textarea.f-input{ height:auto; min-height:120px; padding:13px 15px; resize:vertical; }
.choices{ display:flex; gap:10px; flex-wrap:wrap; }
.choice{ font-family:var(--sans); font-size:14px; padding:9px 16px; border-radius:30px; border:1.5px solid var(--line);
  background:var(--paper); color:var(--ink-2); cursor:pointer; transition:all .2s; }
.choice.on{ background:var(--accent-soft); border-color:var(--accent); color:var(--accent-ink); }
.choice:hover{ border-color:var(--ink); }

/* form submit status (Formspree) */
.form-status{ display:none; margin-top:20px; font-size:15px; line-height:1.55;
  border-radius:14px; padding:16px 20px; }
.form-status.ok, .form-status.err{ display:block; }
.form-status.ok{ background:var(--accent-soft); border:1px solid var(--accent); color:var(--ink-2); }
.form-status.ok strong{ display:block; font-family:var(--serif); font-weight:600; letter-spacing:-.01em;
  font-size:21px; line-height:1.1; color:var(--accent-ink); margin-bottom:5px; }
.form-status.err{ color:var(--ink-2);
  background:color-mix(in srgb, #e0533a 12%, var(--card));
  border:1px solid color-mix(in srgb, #e0533a 45%, var(--line)); }
.form-card.sent > *:not(.form-status){ display:none !important; }

/* real photos in placeholder frames */
.frame{ position:relative; }
.realphoto{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center 22%; display:block; }
.ph.realphoto-wrap{ position:relative; overflow:hidden; }
.photo-credit{ position:absolute; right:9px; bottom:8px; z-index:2; font-family:var(--mono);
  font-size:10px; letter-spacing:.04em; color:#fff; background:rgba(0,0,0,.42);
  padding:3px 7px; border-radius:6px; backdrop-filter:blur(2px); }

/* CV / Stationen list */
.cv-head{ font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-2); margin:0 0 6px; }
.cv{ display:grid; gap:0; }
.cv .row{ display:grid; grid-template-columns:140px 1fr; gap:24px; align-items:baseline;
  padding:17px 0; border-top:1px solid var(--line-2); }
.cv .row:last-child{ border-bottom:1px solid var(--line-2); }
.cv .yr{ font-family:var(--mono); font-size:13px; color:var(--accent-ink); letter-spacing:.02em; }
.cv .tx{ font-size:17px; line-height:1.4; color:var(--ink); }
@media (max-width:680px){ .cv .row{ grid-template-columns:84px 1fr; gap:14px; } .cv .tx{ font-size:15px; } }

/* video embed + DSGVO click-to-load */
.video-embed{ position:relative; width:100%; aspect-ratio:16/9; border-radius:18px;
  overflow:hidden; background:#0a0a0c; border:1px solid var(--line); }
.video-embed iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.yt-consent{ position:absolute; inset:0; width:100%; height:100%; display:flex;
  flex-direction:column; align-items:center; justify-content:center; gap:14px;
  text-align:center; padding:28px; cursor:pointer; border:0; color:#f3f4f6;
  background:linear-gradient(160deg,#1a1b1f,#0c0c0e); font-family:var(--sans);
  transition:background .3s; }
.yt-consent:hover{ background:linear-gradient(160deg,#222329,#101012); }
.yt-play{ width:62px; height:62px; border-radius:50%; display:grid; place-items:center;
  background:var(--accent); color:#16171c; font-size:22px; padding-left:4px;
  box-shadow:0 14px 30px -12px rgba(0,0,0,.6); transition:transform .25s; }
.yt-consent:hover .yt-play{ transform:scale(1.08); }
.yt-title{ font-family:var(--serif); font-weight:600; font-size:18px; letter-spacing:-.01em; }
.yt-note{ font-size:13px; line-height:1.5; color:#aeb3bd; max-width:40ch; margin:0; }
.yt-note a{ color:var(--accent-2); text-decoration:underline; }

/* featured project */
.feature-proj{ display:grid; grid-template-columns:1.25fr .75fr; gap:44px; align-items:center; margin-bottom:60px; }
.feature-proj .fp-body h2{ margin:0 0 14px; }
@media (max-width:820px){ .feature-proj{ grid-template-columns:1fr; gap:26px; } }

/* aside info card */
.aside-card{ background:var(--card); border:1px solid var(--line); border-radius:20px; padding:24px 26px; }
.aside-card .kicker{ margin-bottom:10px; }

/* legal page */
.legal-wrap{ display:grid; grid-template-columns:220px 1fr; gap:clamp(28px,5vw,64px); align-items:start; }
.legal-toc{ position:sticky; top:90px; font-size:14px; }
.legal-toc a{ display:block; padding:7px 0; color:var(--ink-3); border-bottom:1px solid var(--line-2); }
.legal-toc a:hover{ color:var(--accent-ink); }
.legal-body{ max-width:70ch; }
.legal-body h2{ font-family:var(--serif); font-weight:600; letter-spacing:-.02em; font-size:clamp(24px,3vw,32px); margin:38px 0 12px; }
.legal-body h2:first-child{ margin-top:0; }
.legal-body p{ color:var(--ink-2); margin:0 0 14px; font-size:16px; }
.legal-note{ border-left:3px solid var(--accent); padding-left:18px; color:var(--ink-2); margin:16px 0; }

/* newsletter page */
.nl-grid{ display:grid; grid-template-columns:1.3fr .7fr; gap:30px; align-items:start; }
.success{ background:var(--accent-soft); border:1px solid var(--accent); border-radius:18px; padding:22px 24px; }
.success h4{ font-family:var(--serif); font-weight:600; letter-spacing:-.02em; font-size:22px; margin:0 0 6px; color:var(--accent-ink); }
.check{ display:inline-flex; align-items:center; gap:9px; cursor:pointer; }
.check .box{ width:22px; height:22px; border:1.5px solid var(--ink); border-radius:6px; background:var(--accent-soft); flex:0 0 auto; }

/* ---------- responsive ---------- */
@media (max-width:980px){
  .hero-grid{ grid-template-columns:1fr; }
  .portrait{ max-width:440px; margin:0 auto; order:-1; }
  .proj-grid, .about, .films{ grid-template-columns:1fr; }
  .duo{ grid-template-columns:1fr; }
  .bio-grid, .news-feature, .news-list, .nl-grid, .legal-wrap, .fgrid, .bk-grid, .kt-grid{ grid-template-columns:1fr; }
  .bk-grid, .kt-grid{ grid-template-columns:1fr !important; }
  .nw-body{ grid-template-columns:1fr; }
  .nw-feature{ border-right:none; border-bottom:1px solid var(--line); }
  .photo-grid{ grid-template-columns:1fr 1fr; }
  .legal-toc{ position:static; }
  .bio-portrait{ max-width:380px; }
  .foot-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:680px){
  .menu-btn{ display:grid; }
  .nav .brand{ font-size:22px; }
  /* backdrop-filter on .nav would make the fixed overlay relative to the
     header instead of the viewport — disable it so the menu covers fullscreen */
  .nav{ backdrop-filter:none; -webkit-backdrop-filter:none; background:var(--paper); }
  .nav-right .btn--solid{ display:none; }
  .nav-right{ gap:8px; }
  .nav-links{
    position:fixed; inset:0; z-index:60;
    flex-direction:column; align-items:flex-start; justify-content:center; gap:0;
    background:var(--paper); padding:96px var(--gut) 40px; overflow-y:auto;
    transform:translateX(8%); opacity:0; visibility:hidden; pointer-events:none;
    transition:transform .42s cubic-bezier(.16,.84,.28,1), opacity .3s ease, visibility 0s linear .42s;
  }
  .nav.open .nav-links{
    transform:translateX(0); opacity:1; visibility:visible; pointer-events:auto;
    transition:transform .42s cubic-bezier(.16,.84,.28,1), opacity .3s ease, visibility 0s;
  }
  .nav-links a{
    font-family:var(--serif); font-weight:600; font-size:clamp(28px,9vw,40px);
    letter-spacing:-.02em; line-height:1.1; color:var(--ink);
    padding:13px 0; width:100%; border-bottom:1px solid var(--line-2);
    opacity:0; transform:translateY(16px);
    transition:opacity .4s ease, transform .45s cubic-bezier(.16,.84,.28,1), color .2s;
  }
  .nav.open .nav-links a{ opacity:1; transform:none; }
  .nav-links a::after{ display:none; }
  /* staggered reveal (child 1 = close button) */
  .nav.open .nav-links a:nth-child(2){ transition-delay:.08s; }
  .nav.open .nav-links a:nth-child(3){ transition-delay:.13s; }
  .nav.open .nav-links a:nth-child(4){ transition-delay:.18s; }
  .nav.open .nav-links a:nth-child(5){ transition-delay:.23s; }
  .nav.open .nav-links a:nth-child(6){ transition-delay:.28s; }
  .nav.open .nav-links a:nth-child(7){ transition-delay:.33s; }
  .nav.open .nav-links a:nth-child(8){ transition-delay:.38s; }
  .nav-links .nav-cta{
    display:block; margin-top:28px; border-bottom:none; text-align:center; align-self:stretch;
    font-family:var(--sans); font-size:16px; font-weight:600; opacity:0; transform:translateY(16px);
  }
  .nav-close{
    display:block;
    position:absolute; top:20px; right:calc(var(--gut) - 8px);
    width:46px; height:46px; padding:0; border:none; background:transparent;
    cursor:pointer; border-radius:50%; transition:background .2s;
  }
  .nav-close:hover{ background:var(--paper-2); }
  .nav-close::before, .nav-close::after{
    content:''; position:absolute; top:50%; left:50%;
    width:24px; height:2px; background:var(--ink); border-radius:2px;
  }
  .nav-close::before{ transform:translate(-50%,-50%) rotate(45deg); }
  .nav-close::after{ transform:translate(-50%,-50%) rotate(-45deg); }
  body.menu-open{ overflow:hidden; }
  .films{ grid-template-columns:1fr; }
  .track{ grid-template-columns:34px 1fr auto; gap:14px; }
  .track .go{ display:none; }
  .foot-grid{ grid-template-columns:1fr; }
  .hero-meta{ flex-wrap:wrap; gap:18px; }
}
