/* ============================================================
   VANITY LIFE — Editorial Noir
   ============================================================ */

:root{
  /* ── Near-black base (matches the logo background) ───────── */
  --bg:        #050506;
  --bg-2:      #0a0a0d;
  --bg-3:      #131218;

  /* ── Text: warm ivory / silver ──────────────────────────── */
  --paper:     #efece3;
  --paper-2:   #c9c5b8;
  --paper-dim: #8c887b;
  --silver:    #d9d7d0;

  /* ── Hairlines (warm) ───────────────────────────────────── */
  --line:      rgba(232,222,196,0.10);
  --line-2:    rgba(232,222,196,0.20);

  /* ── Accent: gold (repurposes the old --blood vars so every
       existing accent reference becomes gold automatically) ── */
  --blood:     #d8b25e;   /* primary gold accent */
  --blood-2:   #b8923f;   /* deeper gold (hover/active) */

  /* ── Metallic gold scale ────────────────────────────────── */
  --gold:        #d4ad57;
  --gold-bright: #f6dd9b;
  --gold-mid:    #c9a24b;
  --gold-deep:   #8a6a2e;
  --gold-glow:   rgba(216,178,94,.45);

  /* ── Metallic gradients (for clipped text & shine) ──────── */
  --grad-gold:   linear-gradient(177deg,#f8e2a4 0%,#e2bd6c 30%,#b78a35 55%,#dcb863 78%,#f4d792 100%);
  --grad-silver: linear-gradient(177deg,#f6f5f1 0%,#d3d1ca 42%,#9d9b92 66%,#cbc9c1 82%,#edece7 100%);

  --display: "Fraunces", "Times New Roman", serif;
  --sans:    "Geist", system-ui, -apple-system, sans-serif;
  --mono:    "Geist Mono", ui-monospace, monospace;

  --container: 1320px;
  --radius: 2px;
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  background:var(--bg);
  color:var(--paper);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.55;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* film grain overlay */
body::before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none;
  z-index:1000;
  opacity:.06;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 1 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

a{ color:inherit; text-decoration:none; }
img,svg,video{ display:block; max-width:100%; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }

::selection{ background:var(--blood); color:var(--paper); }

.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:32px;
}
@media (max-width:720px){ .container{ padding-inline:20px; } }

.eyebrow{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--paper-dim);
}
.eyebrow .dot{
  display:inline-block; width:6px; height:6px; border-radius:50%;
  background:var(--blood);
  box-shadow:0 0 10px var(--blood);
  margin-right:10px;
  transform:translateY(-2px);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{ opacity:1; }
  50%{ opacity:.35; }
}

h1,h2,h3,h4{
  font-family:var(--display);
  font-weight:400;
  letter-spacing:-0.02em;
  line-height:1;
  font-variation-settings:"opsz" 144, "SOFT" 50;
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0;
  z-index:100;
  padding:18px 0;
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  background:rgba(8,7,10,.55);
  border-bottom:1px solid var(--line);
  transition:padding .3s ease, background .3s ease;
}
.nav--shrunk{
  padding:11px 0;
  background:rgba(8,7,10,.85);
}
.nav__row{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:24px;
}
.nav__row .brand{ justify-self:start; }
.nav__row .nav__links{ justify-self:center; }
.nav__row .nav__right{ justify-self:end; }

.nav__right{
  display:flex;
  align-items:center;
  gap:14px;
}

/* Modern UCP-Button */
.btn-ucp{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 18px;
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--paper);
  background:transparent;
  border:1px solid var(--line-2);
  transition:border-color .25s ease, background .25s ease, color .25s ease;
  white-space:nowrap;
  cursor:pointer;
}
.btn-ucp:hover{
  border-color:var(--blood);
  background:rgba(216,178,94,.09);
}
.btn-ucp svg{
  width:11px; height:11px;
  flex-shrink:0;
  transition:transform .3s cubic-bezier(.65,0,.35,1);
}
.btn-ucp:hover svg{
  transform:translate(2px,-2px);
  color:var(--blood);
}
.nav--shrunk .btn-ucp{
  padding:8px 16px;
}
@media (max-width:880px){
  .btn-ucp{ display:none; }
}
.brand{
  display:flex; align-items:center; gap:12px;
  font-family:var(--display);
  font-size:20px;
  letter-spacing:.04em;
  text-transform:uppercase;
  font-variation-settings:"opsz" 144, "wght" 500;
  color:var(--paper);
}
.brand__logo{
  height:40px;
  width:auto;
  display:block;
  transition:transform .3s ease, filter .3s ease;
  filter:drop-shadow(0 4px 14px rgba(216,178,94,.38));
}
.brand:hover .brand__logo{
  transform:scale(1.04);
  filter:drop-shadow(0 6px 20px rgba(216,178,94,.6));
}
.nav--shrunk .brand__logo{ height:34px; }
.foot__brand .brand__logo{ height:48px; }
.nav__links{
  display:flex; gap:38px;
  font-size:13px;
  letter-spacing:.04em;
}
.nav__links a{
  color:var(--paper-dim);
  transition:color .2s ease;
  position:relative;
  padding:6px 0;
}
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--blood); transition:width .3s ease;
}
.nav__links a:hover,
.nav__links a.active{ color:var(--paper); }
.nav__links a:hover::after,
.nav__links a.active::after{ width:100%; }

/* Trenner nur einmal, vor dem ersten externen Link in der Sequenz */
.nav__links a:not([target="_blank"]) + a[target="_blank"]::before{
  content:"";
  position:absolute;
  right:calc(100% + 18px);
  top:50%;
  transform:translateY(-50%);
  width:1px;
  height:14px;
  background:var(--line-2);
}

/* Dropdown */
.nav__dropdown{
  position:relative;
  display:flex; align-items:center;
}
.nav__dropdown-trigger{
  display:inline-flex; align-items:center; gap:6px;
  font-family:inherit;
  font-size:13px;
  letter-spacing:.04em;
  color:var(--paper-dim);
  background:none;
  border:0;
  padding:6px 0;
  cursor:pointer;
  position:relative;
  transition:color .2s ease;
}
.nav__dropdown-trigger::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--blood); transition:width .3s ease;
}
.nav__dropdown:hover .nav__dropdown-trigger,
.nav__dropdown:focus-within .nav__dropdown-trigger{ color:var(--paper); }
.nav__dropdown:hover .nav__dropdown-trigger::after,
.nav__dropdown:focus-within .nav__dropdown-trigger::after{ width:100%; }

.nav__dropdown-trigger svg{
  width:10px; height:10px;
  transition:transform .25s ease;
  margin-top:1px;
}
.nav__dropdown:hover .nav__dropdown-trigger svg,
.nav__dropdown:focus-within .nav__dropdown-trigger svg{
  transform:rotate(180deg);
}

.nav__dropdown-menu{
  position:absolute;
  top:calc(100% + 14px);
  left:50%;
  min-width:220px;
  display:flex; flex-direction:column;
  background:rgba(8,7,10,.92);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border:1px solid var(--line-2);
  padding:8px 0;
  opacity:0;
  visibility:hidden;
  transform:translateX(-50%) translateY(-6px);
  transition:opacity .25s ease, transform .25s ease, visibility 0s linear .25s;
}
.nav__dropdown:hover .nav__dropdown-menu,
.nav__dropdown:focus-within .nav__dropdown-menu{
  opacity:1;
  visibility:visible;
  transform:translateX(-50%) translateY(0);
  transition:opacity .25s ease, transform .25s ease, visibility 0s linear 0s;
}
/* invisible bridge so hover doesn't drop when moving from trigger to menu */
.nav__dropdown-menu::before{
  content:"";
  position:absolute;
  left:0; right:0;
  top:-14px; height:14px;
}
.nav__dropdown-menu a{
  padding:11px 22px;
  font-size:13px;
  letter-spacing:.02em;
  color:var(--paper-dim);
  white-space:nowrap;
  transition:color .2s ease, background .2s ease, padding-left .2s ease;
  position:relative;
}
.nav__dropdown-menu a::after{ display:none; }
.nav__dropdown-menu a:hover{
  color:var(--paper);
  background:rgba(216,178,94,.09);
  padding-left:28px;
}
.nav__dropdown-menu a.is-current{
  color:var(--paper);
  background:rgba(216,178,94,.06);
  border-left:2px solid var(--blood);
}

.nav__toggle{
  display:none;
  width:38px; height:38px;
  border:1px solid var(--line-2);
  align-items:center; justify-content:center;
  flex-direction:column; gap:5px;
}
.nav__toggle{
  position:relative;
  z-index:200;                              /* über dem Mobile-Menü (150) */
}
.nav__toggle span{ display:block; width:16px; height:1px; background:var(--paper); transition:transform .25s ease; }
.nav__toggle.is-open span:first-child{ transform:translateY(3px) rotate(45deg); }
.nav__toggle.is-open span:last-child{ transform:translateY(-3px) rotate(-45deg); }

.mobile-menu{
  position:fixed;
  top:0; right:0; bottom:0;
  width:min(85vw, 340px);                   /* Slide-Panel rechts, max 340px breit */
  z-index:150;
  background:rgba(8,7,10,.98);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  display:flex;
  flex-direction:column;
  align-items:stretch;
  justify-content:flex-start;
  gap:0;
  padding:100px 28px 40px 28px;             /* oben unter der nav anfangen (Nav ist ~76px) */
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  border-left:1px solid var(--line);
  box-shadow:-16px 0 50px rgba(0,0,0,.5);
  /* Slide-Animation: standardmäßig nach rechts ausgeblendet */
  transform:translateX(100%);
  visibility:hidden;
  transition:transform 300ms cubic-bezier(.4,0,.2,1), visibility 0s linear 300ms;
}
.mobile-menu.is-open{
  transform:translateX(0);
  visibility:visible;
  transition:transform 300ms cubic-bezier(.4,0,.2,1), visibility 0s linear 0s;
}
.mobile-menu a{
  display:block;
  font-family:var(--display);
  font-size:24px;
  font-variation-settings:"opsz" 96, "wght" 400, "SOFT" 50;
  color:var(--paper);
  text-decoration:none;
  padding:14px 0;
  border-bottom:1px solid var(--line);
  letter-spacing:-0.005em;
  transition:color .2s ease, padding-left .2s ease;
}
.mobile-menu a:active,
.mobile-menu a:hover{
  color:var(--blood);
  padding-left:6px;
}
.mobile-menu a:last-child{ border-bottom:none; }
.mobile-menu em{ font-style:italic; color:var(--blood); }

/* Backdrop hinter dem Menü (verdunkelt den Rest) */
.mobile-menu-backdrop{
  position:fixed; inset:0;
  z-index:140;
  background:rgba(0,0,0,.5);
  opacity:0;
  visibility:hidden;
  transition:opacity 300ms ease, visibility 0s linear 300ms;
  cursor:pointer;
}
body.menu-open .mobile-menu-backdrop{
  opacity:1;
  visibility:visible;
  transition:opacity 300ms ease, visibility 0s linear 0s;
}

/* Scroll im Hintergrund unterbinden, wenn Menü offen */
body.menu-open{ overflow:hidden; }

/* Auf Desktop IMMER versteckt, egal welche Klassen gesetzt sind */
@media (min-width:881px){
  .mobile-menu,
  .mobile-menu.is-open,
  .mobile-menu-backdrop{ display:none !important; }
}

.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:11px 22px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  border:1px solid var(--paper);
  color:var(--paper);
  background:transparent;
  transition:background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
  white-space:nowrap;
}
.btn:hover{ background:var(--paper); color:var(--bg); }
.btn--primary{
  background:var(--blood); border-color:var(--blood); color:var(--paper);
}
.btn--primary:hover{
  background:var(--blood-2); border-color:var(--blood-2); color:var(--paper);
  transform:translateY(-1px);
  box-shadow:0 12px 30px -10px rgba(216,178,94,.55);
}
.btn--ghost{ border-color:var(--line-2); color:var(--paper-2); }
.btn--ghost:hover{ background:transparent; color:var(--paper); border-color:var(--paper); }

.live-dot{
  display:inline-block; width:7px; height:7px; border-radius:50%;
  background:var(--gold-bright);
  box-shadow:0 0 10px var(--gold-glow);
  animation:pulse 1.6s ease-in-out infinite;
}

@media (max-width:880px){
  .nav__links{ display:none; }
  .nav__toggle{ display:flex; }
  .nav .btn--primary span:not(.live-dot){ display:none; }

  /* Grid auf Mobile: 2 Spalten — Brand links, Burger rechts */
  .nav__row{
    grid-template-columns: 1fr auto;
    gap: 12px;
  }

  /* Container-Padding ausgleichen damit Burger etwas Abstand vom Rand hat */
  .nav .container{
    padding-left: 18px;
    padding-right: 18px;
  }
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  min-height:100vh;
  padding:130px 0 90px;
  display:flex; align-items:center;
  overflow:hidden;
  isolation:isolate;
}
.hero__bg{
  position:absolute; inset:0; z-index:-2;
  background:
    radial-gradient(ellipse 80% 60% at 70% 30%, rgba(216,178,94,.16), transparent 60%),
    radial-gradient(ellipse 60% 50% at 20% 80%, rgba(150,116,48,.18), transparent 60%),
    linear-gradient(180deg, #060507 0%, #0b0a0e 60%, #050406 100%);
}
.hero__bg::after{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, transparent 60%, var(--bg) 100%),
    repeating-linear-gradient(0deg, transparent 0, transparent 3px, rgba(0,0,0,.25) 3px, rgba(0,0,0,.25) 4px);
  pointer-events:none;
}
.hero__skyline{
  position:absolute; left:0; right:0; bottom:0;
  height:42%;
  z-index:-1;
  opacity:.55;
  mask-image:linear-gradient(180deg, transparent 0%, #000 40%, #000 100%);
}

.hero__grid{
  display:grid;
  grid-template-columns: 1fr;
  gap:48px;
  align-items:end;
}
.hero__lead{
  display:flex; flex-direction:column; gap:26px;
  max-width:1200px;
}
.hero__title{
  font-size: clamp(38px, 5.4vw, 76px);
  line-height:1;
  letter-spacing:-0.025em;
  font-variation-settings:"opsz" 144, "wght" 350, "SOFT" 30;
}
.hero__title em{
  font-style:italic;
  color:var(--paper);
  font-variation-settings:"opsz" 144, "wght" 300, "SOFT" 80;
}
.hero__title .accent{
  color:var(--blood);
  font-style:italic;
  font-variation-settings:"opsz" 144, "wght" 350, "SOFT" 100;
}
.hero__sub{
  max-width:520px;
  font-size:16px;
  line-height:1.65;
  color:var(--paper-2);
}
.hero__cta{ display:flex; gap:14px; flex-wrap:wrap; }

.hero__meta{
  position:absolute; right:32px; bottom:80px;
  display:flex; flex-direction:column; align-items:flex-end; gap:8px;
  font-family:var(--mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--paper-dim);
}
.hero__meta .vline{
  width:1px; height:60px; background:var(--line-2); margin-bottom:4px;
}
@media (max-width:880px){ .hero__meta{ display:none; } }

.hero__ticker{
  position:absolute; left:0; right:0; bottom:0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:rgba(0,0,0,.4);
  overflow:hidden;
  height:46px;
  display:flex; align-items:center;
}
.ticker-track{
  display:flex; gap:60px;
  animation:ticker 40s linear infinite;
  white-space:nowrap;
  font-family:var(--mono); font-size:12px; letter-spacing:.14em;
  color:var(--paper-2);
  text-transform:uppercase;
}
.ticker-track span{ display:inline-flex; align-items:center; gap:14px; }
.ticker-track span::before{
  content:"◆"; color:var(--blood); font-size:8px;
}
@keyframes ticker{
  0%{ transform:translateX(0); }
  100%{ transform:translateX(-50%); }
}

/* ============================================================
   SECTION BASE
   ============================================================ */
section{ padding:100px 0; position:relative; }
@media (max-width:720px){ section{ padding:70px 0; } }

.section-head{
  display:grid;
  grid-template-columns:1fr 2fr;
  gap:40px;
  margin-bottom:56px;
  align-items:end;
}
.section-head h2{
  font-size: clamp(32px, 4.4vw, 60px);
  line-height:.98;
  font-variation-settings:"opsz" 144, "wght" 350, "SOFT" 40;
  grid-column:1 / 2;
}
.section-head h2 em{ font-style:italic; color:var(--blood); }
.section-head__rail{
  grid-column:2 / 3;
  border-top:1px solid var(--line);
  padding-top:24px;
  display:flex; gap:40px; justify-content:space-between;
  color:var(--paper-2); font-size:14px;
}
.section-head__rail p{ max-width:36ch; }
@media (max-width:880px){
  .section-head{ grid-template-columns:1fr; gap:28px; }
  .section-head__rail{ flex-direction:column; gap:16px; }
}

/* ============================================================
   MANIFESTO
   ============================================================ */
.manifesto{ padding-top:80px; }
.manifesto__quote{
  font-family:var(--display);
  font-style:italic;
  font-size: clamp(22px, 2.6vw, 34px);
  line-height:1.22;
  font-variation-settings:"opsz" 144, "wght" 300, "SOFT" 70;
  color:var(--paper);
  max-width:24ch;
  letter-spacing:-0.012em;
}
.manifesto__row{
  display:grid; grid-template-columns:1fr 1.3fr; gap:60px; align-items:start;
}
.manifesto__body{
  display:flex; flex-direction:column; gap:18px;
  color:var(--paper-2);
  font-size:15px; line-height:1.7;
}
.manifesto__body p:first-child::first-letter{
  font-family:var(--display);
  font-size:3.6em;
  float:left;
  line-height:.9;
  padding-right:12px; padding-top:6px;
  color:var(--blood);
  font-variation-settings:"opsz" 144, "wght" 400, "SOFT" 100;
}
@media (max-width:880px){
  .manifesto__row{ grid-template-columns:1fr; gap:36px; }
}

/* ============================================================
   PILLARS
   ============================================================ */
.pillars{
  background:
    linear-gradient(180deg, transparent 0%, rgba(20,16,22,.6) 30%, rgba(20,16,22,.6) 70%, transparent 100%);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.pillars__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
  border-left:1px solid var(--line);
}
.pillar{
  border-right:1px solid var(--line);
  padding:38px 28px;
  display:flex; flex-direction:column; gap:22px;
  min-height:320px;
  transition:background .3s ease;
  position:relative;
}
.pillar:hover{ background:rgba(216,178,94,.05); }
.pillar__num{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.2em;
  color:var(--paper-dim);
}
.pillar h3{
  font-family:var(--display);
  font-size:24px;
  line-height:1.1;
  font-variation-settings:"opsz" 96, "wght" 400, "SOFT" 50;
}
.pillar h3 em{ font-style:italic; color:var(--blood); }
.pillar p{ color:var(--paper-2); font-size:14px; line-height:1.65; }
.pillar__icon{
  width:44px; height:44px;
  border:1px solid var(--line-2);
  display:grid; place-items:center;
  color:var(--paper);
}
.pillar__icon svg{ width:22px; height:22px; stroke:currentColor; fill:none; stroke-width:1.4; }
@media (max-width:880px){
  .pillars__grid{ grid-template-columns:1fr; border-left:0; }
  .pillar{ border-right:0; border-bottom:1px solid var(--line); }
}

/* ============================================================
   STATS
   ============================================================ */
.stats{ padding:70px 0; border-bottom:1px solid var(--line); }
.stats__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:32px;
}
.stat{ display:flex; flex-direction:column; gap:8px; }
.stat__num{
  font-family:var(--display);
  font-size: clamp(36px, 4.2vw, 56px);
  line-height:.92;
  font-variation-settings:"opsz" 144, "wght" 300, "SOFT" 60;
  letter-spacing:-0.035em;
  display:flex; align-items:baseline; gap:.05em;
}
.stat__num em{ font-style:italic; color:var(--blood); font-feature-settings:"tnum"; }
.stat__num .suffix{ font-size:.5em; color:var(--paper-dim); font-style:normal; }
.stat__label{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--paper-dim);
  border-top:1px solid var(--line);
  padding-top:12px;
}
@media (max-width:720px){
  .stats__grid{ grid-template-columns:repeat(2,1fr); gap:24px; }
}

/* ============================================================
   CINEMA
   ============================================================ */
.cinema{ overflow:hidden; }
.cinema__row{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:64px;
  align-items:center;
}
.cinema__media{
  aspect-ratio:3/4;
  position:relative;
  overflow:hidden;
  background:#000;
  border:1px solid var(--line);
  cursor:pointer;
}
.cinema__media::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 70% 80% at 50% 100%, rgba(216,178,94,.40), transparent 70%),
    radial-gradient(ellipse 100% 70% at 50% 30%, rgba(60,30,80,.3), transparent 60%),
    linear-gradient(180deg, #1a0808 0%, #0a0508 60%, #000 100%);
  transition:transform .8s ease;
}
.cinema__media:hover::before{ transform:scale(1.04); }
.cinema__media::after{
  content:"";
  position:absolute; inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.6' numOctaves='2'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .35 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:.7;
  mix-blend-mode:overlay;
}
.cinema__inner{
  position:absolute; inset:0; z-index:1;
  display:flex; flex-direction:column; justify-content:space-between;
  padding:32px;
  color:var(--paper);
}
.cinema__inner .top{
  display:flex; justify-content:space-between;
  font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--paper-2);
}
.cinema__inner .center{
  display:flex; align-items:center; justify-content:center;
  flex:1;
}
.play{
  width:72px; height:72px; border-radius:50%;
  border:1px solid var(--paper);
  display:grid; place-items:center;
  color:var(--paper);
  transition:transform .3s ease, background .3s ease;
}
.cinema__media:hover .play{ background:var(--paper); color:var(--bg); transform:scale(1.05); }
.play svg{ width:20px; height:20px; margin-left:3px; }
.cinema__inner .bottom{
  display:flex; justify-content:space-between; align-items:end;
}
.cinema__inner .bottom .ttl{
  font-family:var(--display); font-style:italic;
  font-size:22px; line-height:1.05; max-width:18ch;
  font-variation-settings:"opsz" 144, "wght" 300, "SOFT" 80;
}
.cinema__inner .bottom .meta{
  font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--paper-2); text-align:right;
}
.corner{
  position:absolute; width:18px; height:18px;
  border:1px solid var(--paper);
  z-index:2;
}
.corner.tl{ top:14px; left:14px; border-right:0; border-bottom:0; }
.corner.tr{ top:14px; right:14px; border-left:0; border-bottom:0; }
.corner.bl{ bottom:14px; left:14px; border-right:0; border-top:0; }
.corner.br{ bottom:14px; right:14px; border-left:0; border-top:0; }

.cinema__copy{ display:flex; flex-direction:column; gap:26px; }
.cinema__copy h2{
  font-size:clamp(30px, 4vw, 54px);
  line-height:1;
  font-variation-settings:"opsz" 144, "wght" 350, "SOFT" 50;
}
.cinema__copy h2 em{ font-style:italic; color:var(--blood); }
.cinema__copy p{ color:var(--paper-2); font-size:15px; line-height:1.7; max-width:50ch; }
.cinema__points{
  list-style:none;
  display:flex; flex-direction:column; gap:14px;
  border-top:1px solid var(--line); padding-top:24px;
}
.cinema__points li{
  display:grid; grid-template-columns:auto 1fr; gap:18px;
  font-size:14px; color:var(--paper-2);
  padding-bottom:14px; border-bottom:1px solid var(--line);
}
.cinema__points li:last-child{ border-bottom:0; padding-bottom:0; }
.cinema__points .k{
  font-family:var(--mono); font-size:11px; letter-spacing:.18em;
  color:var(--blood); text-transform:uppercase;
  padding-top:3px;
}
@media (max-width:980px){
  .cinema__row{ grid-template-columns:1fr; gap:60px; }
}

/* ============================================================
   STORY
   ============================================================ */
.story{
  padding:90px 0;
  background:
    linear-gradient(180deg, transparent 0%, rgba(20,8,8,.5) 40%, rgba(20,8,8,.5) 60%, transparent 100%);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.story__row{
  display:grid; grid-template-columns:1fr 1.4fr; gap:64px;
  align-items:start;
}
.story__row .label{ position:sticky; top:120px; }
.story__row h2{
  font-size:clamp(28px, 3.4vw, 46px);
  line-height:1.08;
  font-variation-settings:"opsz" 144, "wght" 350, "SOFT" 50;
  margin-bottom:28px;
}
.story__row h2 em{ font-style:italic; color:var(--blood); }
.story__row p{ color:var(--paper-2); font-size:15px; line-height:1.75; margin-bottom:16px; }
.story__row p:last-child{ margin-bottom:0; }
.story__sign{
  color:var(--paper); font-style:italic; font-family:var(--display);
  font-size:18px; margin-top:24px;
  font-variation-settings:"opsz" 96, "wght" 400, "SOFT" 80;
}
@media (max-width:880px){
  .story__row{ grid-template-columns:1fr; gap:32px; }
  .story__row .label{ position:static; }
}

/* ============================================================
   JOIN
   ============================================================ */
.join{ padding:120px 0; }
.join__inner{
  border:1px solid var(--line-2);
  padding:60px 48px;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(ellipse 60% 80% at 100% 100%, rgba(216,178,94,.14), transparent 70%),
    linear-gradient(180deg, var(--bg-2) 0%, var(--bg) 100%);
}
.join__inner::before{
  content:""; position:absolute; inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.4' numOctaves='2'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .25 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:.5; mix-blend-mode:overlay; pointer-events:none;
}
.join__grid{
  display:grid; grid-template-columns:1.4fr 1fr; gap:60px; align-items:end;
  position:relative; z-index:1;
}
.join h2{
  font-size:clamp(36px, 5vw, 72px);
  line-height:.96;
  font-variation-settings:"opsz" 144, "wght" 350, "SOFT" 50;
}
.join h2 em{ font-style:italic; color:var(--blood); }
.join__sub{ color:var(--paper-2); margin-top:20px; max-width:50ch; font-size:15px; }
.join__cards{
  display:flex; flex-direction:column; gap:14px;
}
.join-card{
  border:1px solid var(--line);
  padding:20px 22px;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  transition:background .25s ease, border-color .25s ease, transform .25s ease;
  background:rgba(0,0,0,.3);
  cursor:pointer;
}
.join-card:hover{ border-color:var(--paper); background:rgba(255,255,255,.02); transform:translateX(-4px); }
.join-card__main{ display:flex; flex-direction:column; gap:4px; }
.join-card__main strong{
  font-family:var(--display); font-size:20px; font-weight:400;
  font-variation-settings:"opsz" 96, "wght" 500, "SOFT" 30;
  letter-spacing:-.01em;
}
.join-card__main span{
  font-family:var(--mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--paper-dim);
}
.join-card__arrow{
  width:38px; height:38px; border:1px solid var(--line-2);
  display:grid; place-items:center; transition:background .25s ease, color .25s ease, border-color .25s ease;
  color:var(--paper);
}
.join-card:hover .join-card__arrow{ background:var(--blood); border-color:var(--blood); }
.join-card svg{ width:14px; height:14px; }
@media (max-width:880px){
  .join__inner{ padding:48px 28px; }
  .join__grid{ grid-template-columns:1fr; gap:40px; }
}

/* ============================================================
   FOOTER
   ============================================================ */
footer{
  border-top:1px solid var(--line);
  padding:60px 0 36px;
  color:var(--paper-dim);
  font-size:13px;
}
.foot__row{
  display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:40px;
  margin-bottom:60px;
}
.foot__brand{ display:flex; flex-direction:column; gap:16px; max-width:60ch; }
.foot__brand p{ font-size:13px; color:var(--paper-dim); line-height:1.6; }
.foot__col h4{
  font-family:var(--mono); font-size:11px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--paper-2); margin-bottom:18px;
}
.foot__col ul{ list-style:none; display:flex; flex-direction:column; gap:10px; }
.foot__col a{ color:var(--paper-dim); transition:color .2s ease; }
.foot__col a:hover{ color:var(--paper); }
.foot__bottom{
  display:flex; justify-content:space-between; align-items:center;
  padding-top:24px; border-top:1px solid var(--line);
  font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
}
@media (max-width:720px){
  .foot__row{ grid-template-columns:1fr; gap:32px; }
  .foot__bottom{ flex-direction:column; gap:14px; align-items:flex-start; }
}

/* ============================================================
   TRAILER MODAL
   ============================================================ */
.modal{
  position:fixed; inset:0; z-index:200;
  display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,.85);
  backdrop-filter:blur(8px);
  padding:24px;
}
.modal__frame{
  width:100%; max-width:1100px;
  aspect-ratio:16/9;
  background:#000;
  border:1px solid var(--line-2);
  position:relative;
}
.modal__frame iframe{ width:100%; height:100%; border:0; }
.modal__close{
  position:absolute; top:-44px; right:0;
  font-family:var(--mono); font-size:11px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--paper-2);
  display:flex; align-items:center; gap:8px;
}
.modal__close:hover{ color:var(--paper); }

/* ============================================================
   REVEAL ON SCROLL
   ============================================================ */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .9s ease, transform .9s ease; }
.reveal.in{ opacity:1; transform:none; }

/* ============================================================
   SUB-PAGES (Regelwerk, Fraktionsregelwerk, etc.)
   ============================================================ */
.page-hero{
  position:relative;
  padding:170px 0 70px;
  border-bottom:1px solid var(--line);
  overflow:hidden;
  isolation:isolate;
}
.page-hero::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(ellipse 60% 80% at 80% 50%, rgba(216,178,94,.10), transparent 60%),
    linear-gradient(180deg, #07060a 0%, #0c0a10 100%);
}
.page-hero__title{
  font-family:var(--display);
  font-size:clamp(38px, 5.4vw, 76px);
  line-height:1;
  font-variation-settings:"opsz" 144, "wght" 350, "SOFT" 30;
  letter-spacing:-0.025em;
  margin-top:18px;
}
.page-hero__title em,
.page-hero__title .accent{
  font-style:italic;
  color:var(--blood);
  font-variation-settings:"opsz" 144, "wght" 350, "SOFT" 100;
}
.page-hero__sub{
  margin-top:28px;
  max-width:62ch;
  font-size:16px;
  line-height:1.7;
  color:var(--paper-2);
}

.rules{ padding:90px 0 140px; }
.rules__grid{
  display:grid;
  grid-template-columns:240px 1fr;
  gap:80px;
  align-items:start;
}
.rules__toc{
  position:sticky;
  top:120px;
  font-size:13px;
}
.rules__toc h4{
  font-family:var(--mono); font-size:11px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--paper-dim); margin-bottom:18px;
  border-top:1px solid var(--line);
  padding-top:18px;
}
.rules__toc ul{ list-style:none; display:flex; flex-direction:column; gap:10px; }
.rules__toc a{
  color:var(--paper-dim);
  transition:color .25s ease, padding-left .25s ease, border-color .25s ease;
  display:block;
  padding:2px 0 2px 0;
  border-left:2px solid transparent;
  padding-left:0;
}
.rules__toc a:hover{
  color:var(--paper);
  padding-left:8px;
  border-left-color:var(--blood);
}
.rules__toc a.is-active{
  color:var(--paper);
  padding-left:12px;
  border-left-color:var(--blood);
  font-weight:500;
}

/* Scroll-Offset für Anker-Sprünge, damit überschriften nicht unter der Nav landen */
.rule[id]{ scroll-margin-top:110px; }

.rules__body{
  display:flex; flex-direction:column;
  gap:64px;
}
.rule{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:32px;
  padding-bottom:64px;
  border-bottom:1px solid var(--line);
}
.rule:last-child{ border-bottom:0; padding-bottom:0; }
.rule__num{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--blood);
  padding-top:10px;
  white-space:nowrap;
}
.rule__content h2{
  font-family:var(--display);
  font-size:clamp(24px, 2.8vw, 36px);
  line-height:1.1;
  font-variation-settings:"opsz" 96, "wght" 400, "SOFT" 50;
  margin-bottom:20px;
}
.rule__content h2 em{ font-style:italic; color:var(--blood); }
.rule__content p{
  color:var(--paper-2);
  font-size:15px;
  line-height:1.75;
  margin-bottom:14px;
}
.rule__content p:last-child{ margin-bottom:0; }
.rule__content ul{
  list-style:none;
  display:flex; flex-direction:column;
  gap:10px;
  margin-top:6px;
  padding-left:0;
}
.rule__content ul li{
  color:var(--paper-2);
  font-size:15px;
  line-height:1.6;
  padding-left:22px;
  position:relative;
}
.rule__content ul li::before{
  content:"—";
  position:absolute;
  left:0;
  color:var(--blood);
}
.rule__content strong{
  color:var(--paper);
  font-weight:500;
}

/* Inline-Marker für Regelwerk-Hervorhebungen */
.mark-warning{ color:#e8a93b; }
.mark-danger { color:var(--blood); font-weight:500; }
.mark-success{ color:#3ecf6b; }
.mark-info   { color:var(--paper-2); }

/* Sub-Paragraph-Layout: jede (x.y)-Klausel als eigene Zeile */
.rule__list{
  list-style:none;
  display:flex; flex-direction:column;
  gap:18px;
  padding:0;
}
.rule__list > li{
  display:grid;
  grid-template-columns:54px 1fr;
  gap:18px;
  font-size:15px;
  color:var(--paper-2);
  line-height:1.7;
  padding:0;
  position:static;
}
.rule__list > li::before{ content:none; }
.rule__list > li > .clause{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.12em;
  color:var(--paper-dim);
  padding-top:5px;
  white-space:nowrap;
}
.rule__list ul{
  list-style:none;
  margin-top:10px;
  padding-left:0;
  display:flex; flex-direction:column;
  gap:6px;
}
.rule__list ul li{
  padding-left:18px;
  position:relative;
  font-size:14px;
  line-height:1.6;
}
.rule__list ul li::before{
  content:"—";
  position:absolute;
  left:0;
  color:var(--blood);
}
.rule__list .example{
  display:block;
  margin-top:8px;
  padding:14px 16px;
  border-left:2px solid var(--line-2);
  background:rgba(255,255,255,.015);
  font-size:14px;
  color:var(--paper-dim);
  font-style:italic;
}

@media (max-width:720px){
  .rule__list > li{ grid-template-columns:1fr; gap:6px; }
  .rule__list > li > .clause{ padding-top:0; }
}

@media (max-width:880px){
  .rules__grid{ grid-template-columns:1fr; gap:48px; }
  .rules__toc{ position:static; }
  .rule{ grid-template-columns:1fr; gap:14px; padding-bottom:48px; }
  .rule__num{ padding-top:0; }
}

/* ============================================================
   VUE TRANSITIONS
   ============================================================ */
.fade-enter-active, .fade-leave-active{ transition:opacity .3s ease; }
.fade-enter-from, .fade-leave-to{ opacity:0; }

.menu-enter-active, .menu-leave-active{ transition:opacity .25s ease, transform .25s ease; }
.menu-enter-from, .menu-leave-to{ opacity:0; transform:translateY(-8px); }

/* ============================================================
   GOLD & SILVER — Metallic Refinement (Logo-inspired)
   ============================================================ */

/* Brushed metallic helpers */
.metal-gold,
.section-head h2 em,
.pillar h3 em,
.cinema__copy h2 em,
.story__row h2 em,
.join h2 em,
.rule__content h2 em,
.mobile-menu em,
.stat__num em,
.manifesto__quote{
  background:var(--grad-gold);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
  font-style:italic;
}

/* The hero word-mark: "Vanity" ivory, "Life" brushed silver — like the logo */
.hero__title .accent{
  background:var(--grad-silver);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
  filter:drop-shadow(0 1px 0 rgba(0,0,0,.5));
}

/* Brand word-mark in metallic gold */
.brand span{
  background:var(--grad-gold);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
}
.foot__brand .brand span{ filter:drop-shadow(0 1px 1px rgba(0,0,0,.4)); }

/* Primary CTA — solid polished gold with deep text */
.btn.btn--primary{
  background:var(--grad-gold);
  border:1px solid rgba(246,221,155,.55);
  color:#1a1408;
  font-weight:600;
  box-shadow:0 1px 0 rgba(255,243,210,.45) inset, 0 10px 26px -14px var(--gold-glow);
}
.btn.btn--primary:hover{
  background:var(--grad-gold);
  border-color:rgba(246,221,155,.8);
  color:#140f06;
  transform:translateY(-1px);
  box-shadow:0 1px 0 rgba(255,243,210,.6) inset, 0 16px 34px -12px var(--gold-glow);
}
.btn.btn--primary svg{ stroke:#1a1408; }

/* Outline buttons / UCP — warm gold edge on hover */
.btn{ border-color:var(--line-2); color:var(--paper); }
.btn:hover{ background:var(--gold-bright); color:#161106; border-color:var(--gold-bright); }
.btn-ucp:hover{ border-color:var(--gold) !important; color:var(--gold-bright) !important; }

/* Nav: a faint gold hairline at the base */
.nav{ border-bottom:1px solid var(--line); box-shadow:0 1px 0 rgba(216,178,94,.07); }
.nav--shrunk{ box-shadow:0 1px 0 rgba(216,178,94,.12); }

/* Eyebrow / live dots — warm gold, not red */
.eyebrow .dot{
  background:var(--gold-bright);
  box-shadow:0 0 12px var(--gold-glow);
}

/* Refined gold text selection */
::selection{ background:rgba(216,178,94,.85); color:#120d04; }

/* Section divider rails & quote bars pick up the gold */
.section-head__rail p::before{ color:var(--gold) !important; }
.story__sign{
  background:var(--grad-gold);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
}

/* Stat numbers: a touch of gold glow for the metallic read */
/* Stat numbers: metallic gold needs breathing room or background-clip:text
   cuts the tall italic glyph at the tight line-height. */
.stat__num{ line-height:1; align-items:flex-end; }
.stat__num em{
  display:inline-block;
  line-height:1.18;
  padding:.06em .04em .02em;
  filter:drop-shadow(0 1px 6px rgba(216,178,94,.25));
}

/* Hero CTA arrow inherits dark on gold */
.btn.btn--primary:hover svg path{ stroke:#140f06; }

/* Film-grain a hair softer so gold stays clean */
body::before{ opacity:.045; }

/* ============================================================
   COPY / SELECTION PROTECTION
   ============================================================ */
html, body, *{
  -webkit-user-select:none;
  -moz-user-select:none;
  -ms-user-select:none;
  user-select:none;
  -webkit-touch-callout:none;          /* iOS long-press menu */
}
/* Inhalte trotzdem normal benutzbar lassen */
input, textarea, [contenteditable="true"]{
  -webkit-user-select:text;
  -moz-user-select:text;
  -ms-user-select:text;
  user-select:text;
}
img, svg, .brand__logo{
  -webkit-user-drag:none;
  -khtml-user-drag:none;
  -moz-user-drag:none;
  user-drag:none;
}
::selection{ background:transparent; color:inherit; }
::-moz-selection{ background:transparent; color:inherit; }
