/* =========================================================================
   COSMEDICA SPEZIAL LASER 2026 — Landing Page
   Design system: tech/laser-inspired, light base with dark hero,
   colors as accents. Tonality: fachlich-seriös, warm-einladend.
   ========================================================================= */

:root {
  /* Type — defaults; tweaks swap these */
  --ff-display: "Barlow Condensed", "Archivo Narrow", "Helvetica Neue", sans-serif;
  --ff-body: "Manrope", "Work Sans", "Helvetica Neue", sans-serif;
  --ff-mono: "JetBrains Mono", ui-monospace, "SF Mono", monospace;

  /* Color — light base, dark accent block, dual brand accents */
  --ink: #0d1b27;
  --ink-2: #1a2a38;
  --ink-muted: #4d5b69;
  --ink-quiet: #7b8794;
  --hairline: rgba(13, 27, 39, 0.08);
  --hairline-strong: rgba(13, 27, 39, 0.16);

  --bg: #f6f5f0;        /* warm warm-off-white */
  --bg-2: #ffffff;
  --bg-paper: #faf9f5;
  --bg-dark: #07111b;   /* near-black for hero / sections */
  --bg-dark-2: #0b1825;

  /* Brand — from event graphic */
  --brand-blue: #2a6788;     /* logo blue */
  --brand-blue-strong: #1f5779;
  --brand-lime: #c9d60e;     /* event-graphic yellow-green */
  --brand-lime-soft: #e2ec5e;
  --laser-blue: #4ba7e8;     /* hero laser beams */
  --laser-glow: #76cfff;

  /* Dynamic accent (driven by Tweaks) */
  --accent: var(--brand-blue);
  --accent-soft: rgba(42, 103, 136, 0.12);
  --accent-ink: #ffffff;     /* text on solid accent */

  /* Density */
  --sect-pad-y: 120px;
  --container: 1240px;
  --gutter: 32px;
  --radius-sm: 4px;
  --radius: 8px;
  --radius-lg: 16px;
}

[data-density="compact"] {
  --sect-pad-y: 72px;
  --gutter: 24px;
}
[data-density="airy"] {
  --sect-pad-y: 160px;
  --gutter: 40px;
}

[data-font="condensed"] {
  --ff-display: "Barlow Condensed", "Archivo Narrow", "Helvetica Neue", sans-serif;
  --ff-body: "Manrope", "Work Sans", "Helvetica Neue", sans-serif;
}
[data-font="editorial"] {
  --ff-display: "Instrument Serif", Georgia, serif;
  --ff-body: "DM Sans", "Helvetica Neue", sans-serif;
}
[data-font="tech"] {
  --ff-display: "Archivo", "Helvetica Neue", sans-serif;
  --ff-body: "IBM Plex Sans", "Helvetica Neue", sans-serif;
}
[data-font="tech"] h1, [data-font="tech"] h2, [data-font="tech"] h3 {
  font-weight: 800;
}
[data-font="editorial"] h1, [data-font="editorial"] h2 {
  font-style: italic;
  letter-spacing: -0.01em;
}

/* Accent variants */
[data-accent="blue"] {
  --accent: var(--brand-blue);
  --accent-soft: rgba(42, 103, 136, 0.10);
  --accent-ink: #ffffff;
}
[data-accent="lime"] {
  --accent: #8a9909;          /* darker lime for AA contrast on light */
  --accent-soft: rgba(201, 214, 14, 0.18);
  --accent-ink: #0d1b27;
}

/* ============================== RESET ============================== */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 88px; }
body {
  margin: 0;
  font-family: var(--ff-body);
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: "ss01", "cv11";
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; }
a { color: inherit; }

/* ============================== LAYOUT ============================== */
.container {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.container-wide {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 var(--gutter);
}
section {
  padding: var(--sect-pad-y) 0;
  position: relative;
}
section + section { padding-top: 0; }

/* ============================== TYPE ============================== */
.eyebrow {
  font-family: var(--ff-mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-quiet);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.eyebrow::before {
  content: "";
  width: 28px; height: 1px;
  background: currentColor;
  opacity: .6;
}
.eyebrow.no-line::before { display: none; }

h1, h2, h3, h4 {
  margin: 0;
  font-family: var(--ff-display);
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.01em;
  text-wrap: balance;
}
.h-accent { color: var(--accent); }

.h-display {
  font-family: var(--ff-display);
  font-size: clamp(56px, 9vw, 132px);
  line-height: 0.92;
  font-weight: 700;
  letter-spacing: -0.02em;
  text-transform: uppercase;
}
[data-font="editorial"] .h-display {
  font-weight: 400;
  font-size: clamp(60px, 9vw, 140px);
  text-transform: none;
  letter-spacing: -0.03em;
  line-height: 0.95;
}

.h-section {
  font-family: var(--ff-display);
  font-size: clamp(40px, 5.5vw, 76px);
  line-height: 0.96;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -0.015em;
}
[data-font="editorial"] .h-section {
  text-transform: none;
  font-weight: 400;
  letter-spacing: -0.02em;
}

.h-lede {
  font-family: var(--ff-display);
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.08;
  font-weight: 500;
  text-transform: none;
  letter-spacing: -0.01em;
}
[data-font="editorial"] .h-lede { font-style: italic; font-weight: 400; }

.h-card {
  font-family: var(--ff-display);
  font-size: 24px;
  line-height: 1.15;
  font-weight: 600;
  letter-spacing: -0.005em;
  text-transform: none;
}

.lede {
  font-size: clamp(18px, 1.4vw, 21px);
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 62ch;
}
p { margin: 0 0 1em; max-width: 68ch; color: var(--ink-2); }
p:last-child { margin-bottom: 0; }

/* Accent variants per requested colors */
.tone-blue { color: var(--brand-blue); }
.tone-lime { color: #8a9909; }

/* ============================== BUTTONS ============================== */
.btn {
  --b-bg: var(--ink);
  --b-fg: #ffffff;
  --b-bd: var(--ink);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 22px 14px 24px;
  background: var(--b-bg);
  color: var(--b-fg);
  border: 1px solid var(--b-bd);
  border-radius: 999px;
  font-family: var(--ff-body);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.01em;
  text-decoration: none;
  transition: transform .25s cubic-bezier(.2,.7,.2,1),
              background .2s ease, color .2s ease, border-color .2s ease,
              box-shadow .3s ease;
  white-space: nowrap;
  will-change: transform;
}
.btn:hover { transform: translateY(-1px); box-shadow: 0 12px 28px -16px rgba(0,0,0,.4); }
.btn:active { transform: translateY(0); }
.btn .arr { display: inline-block; transition: transform .25s; }
.btn:hover .arr { transform: translateX(3px); }

.btn-primary {
  --b-bg: var(--accent);
  --b-fg: var(--accent-ink);
  --b-bd: var(--accent);
}
.btn-ghost {
  --b-bg: transparent;
  --b-fg: var(--ink);
  --b-bd: var(--hairline-strong);
}
.btn-ghost:hover { --b-bd: var(--ink); }
.btn-light {
  --b-bg: rgba(255,255,255,.08);
  --b-fg: #ffffff;
  --b-bd: rgba(255,255,255,.22);
  backdrop-filter: blur(8px);
}
.btn-light:hover { --b-bg: rgba(255,255,255,.16); }
.btn-solid-light {
  --b-bg: #ffffff;
  --b-fg: var(--ink);
  --b-bd: #ffffff;
}

/* ============================== HEADER ============================== */
.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 100;
  background: rgba(246, 245, 240, 0.72);
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  border-bottom: 1px solid transparent;
  transition: background .3s, border-color .3s, padding .3s;
}
.site-header.scrolled {
  background: rgba(246, 245, 240, 0.92);
  border-bottom: 1px solid var(--hairline);
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 18px var(--gutter);
  max-width: 1440px;
  margin: 0 auto;
}
.brand { display: inline-flex; align-items: center; gap: 14px; text-decoration: none; }
.brand img { height: 38px; width: auto; }
.brand-meta {
  border-left: 1px solid var(--hairline-strong);
  padding-left: 14px;
  display: flex; flex-direction: column;
  font-family: var(--ff-mono);
  line-height: 1.1;
}
.brand-meta .e { font-size: 10px; letter-spacing: 0.16em; color: var(--ink-quiet); text-transform: uppercase; }
.brand-meta .d { font-size: 13px; font-weight: 600; color: var(--ink); margin-top: 2px; letter-spacing: 0.01em; }

.nav {
  display: flex; align-items: center; gap: 4px;
}
.nav a {
  position: relative;
  font-size: 13.5px;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--ink-2);
  padding: 8px 14px;
  border-radius: 999px;
  text-decoration: none;
  transition: color .2s, background .2s;
}
.nav a:hover { color: var(--ink); background: rgba(13,27,39,.04); }
.nav a.active {
  color: var(--ink);
  background: rgba(13,27,39,.06);
}
.nav a.active::before {
  content: "";
  position: absolute;
  left: 10px; top: 50%;
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--accent);
  transform: translateY(-50%);
}
.nav a.active { padding-left: 22px; }

.nav-cta {
  margin-left: 10px;
  padding: 9px 16px !important;
  background: var(--accent) !important;
  color: var(--accent-ink) !important;
  font-weight: 600 !important;
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
}
.nav-cta:hover { transform: translateY(-1px); }
.nav-cta::before { display: none !important; }

.social-links {
  display: flex; gap: 4px; margin-left: 4px;
  padding-left: 12px;
  border-left: 1px solid var(--hairline);
}
.social-links a {
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px;
  color: var(--ink-muted);
  padding: 0;
}
.social-links a:hover { color: var(--ink); background: rgba(13,27,39,.05); }

.mobile-toggle { display: none; }

@media (max-width: 1080px) {
  .nav a:not(.nav-cta) { display: none; }
  .nav .nav-cta { display: inline-flex; }
  .social-links { display: none; }
  .brand-meta { display: none; }
}

/* ============================== HERO ============================== */
.hero {
  padding: 140px 0 0;
  position: relative;
  overflow: hidden;
  background: var(--bg);
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 48px;
  align-items: stretch;
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.hero-left {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 32px 0 88px;
  min-height: 78vh;
}
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--ff-mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-muted);
  padding: 7px 12px 7px 8px;
  background: var(--bg-2);
  border: 1px solid var(--hairline);
  border-radius: 999px;
  width: fit-content;
}
.hero-eyebrow .dot {
  display: inline-block;
  flex-shrink: 0;
  width: 8px; height: 8px;
  min-width: 8px;
  border-radius: 50%;
  background: var(--brand-lime);
  box-shadow: 0 0 0 4px rgba(201, 214, 14, 0.18);
  animation: pulse 2.4s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(201, 214, 14, 0.18); }
  50% { box-shadow: 0 0 0 8px rgba(201, 214, 14, 0.06); }
}

.hero-title {
  margin-top: 28px;
  font-family: var(--ff-display);
  font-size: clamp(64px, 8.6vw, 144px);
  line-height: 0.88;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.hero-title .line2 { color: var(--brand-blue); }
[data-font="editorial"] .hero-title {
  text-transform: none;
  font-weight: 400;
  letter-spacing: -0.03em;
  line-height: 0.95;
}
[data-font="editorial"] .hero-title .line2 { font-style: italic; }

.hero-sub {
  margin-top: 28px;
  font-size: clamp(17px, 1.3vw, 19px);
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 52ch;
}
.hero-cta-row {
  display: flex; gap: 12px; flex-wrap: wrap;
  margin-top: 36px;
}
.hero-meta {
  margin-top: auto;
  padding-top: 36px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  border-top: 1px solid var(--hairline);
  padding-bottom: 0;
}
.hero-meta-item .l {
  font-family: var(--ff-mono);
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-quiet);
}
.hero-meta-item .v {
  margin-top: 6px;
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.3;
}
.hero-meta-item .s {
  font-size: 13px;
  color: var(--ink-muted);
  margin-top: 2px;
}

/* Hero right — image panel w/ laser tile + meta strip */
.hero-right {
  position: relative;
  margin: 32px 0 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--bg-dark);
  min-height: 600px;
  isolation: isolate;
}
.hero-image {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  z-index: 0;
}
.hero-image::after {
  /* subtle dark vignette */
  content: "";
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(7,17,27,0) 50%, rgba(7,17,27,.7) 100%),
    radial-gradient(120% 80% at 50% 100%, rgba(76,167,232,.0) 60%, rgba(76,167,232,.18) 100%);
}
.hero-right-overlay {
  position: absolute;
  left: 24px; right: 24px; bottom: 24px;
  z-index: 2;
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 16px;
  color: #fff;
}
.hero-badge {
  background: var(--brand-lime);
  color: #0b1825;
  padding: 12px 18px;
  border-radius: 8px;
  font-family: var(--ff-display);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 14px;
  line-height: 1.2;
}
.hero-badge .b {
  display: block;
  font-family: var(--ff-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.18em;
  margin-bottom: 4px;
  color: rgba(11, 24, 37, 0.65);
  text-transform: uppercase;
}
.hero-locale {
  text-align: right;
  font-size: 13px;
  line-height: 1.5;
  color: rgba(255,255,255,.85);
}
.hero-locale b { display:block; color:#fff; font-size: 15px; }

.hero-marquee {
  margin-top: 88px;
  padding: 18px 0;
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
  overflow: hidden;
  background: var(--bg-paper);
}
.hero-marquee-track {
  display: flex;
  gap: 48px;
  animation: marquee 50s linear infinite;
  white-space: nowrap;
  width: max-content;
}
.hero-marquee-track span {
  font-family: var(--ff-display);
  font-size: 22px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--ink-muted);
  display: inline-flex; align-items: center; gap: 48px;
}
.hero-marquee-track span::after {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--brand-lime);
  display: inline-block;
}
@keyframes marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

@media (max-width: 980px) {
  .hero-grid { grid-template-columns: 1fr; }
  .hero-right { min-height: 360px; }
  .hero-meta { grid-template-columns: 1fr 1fr; }
  .hero-left { min-height: auto; padding-bottom: 24px; }
}

/* ============================== SECTION HEADERS ============================== */
.section-head {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 48px;
  align-items: end;
  margin-bottom: 56px;
}
.section-head .left .eyebrow { color: var(--ink-quiet); }
.section-head h2 { margin-top: 14px; }
.section-head .right { color: var(--ink-2); font-size: 17px; line-height: 1.55; max-width: 56ch; }
@media (max-width: 880px) {
  .section-head { grid-template-columns: 1fr; gap: 20px; margin-bottom: 36px; }
}

/* Anchor offset for sticky header */
[id] { scroll-margin-top: 88px; }

/* ============================== WILLKOMMEN ============================== */
.willkommen {
  padding-top: 100px;
}
.willkommen-grid {
  display: grid;
  grid-template-columns: 1fr 1.05fr;
  gap: 48px;
  align-items: start;
}
.willkommen-grid .col-text h2 .accent { color: var(--brand-blue); }
.willkommen-aside {
  position: sticky;
  top: 110px;
  padding: 28px;
  background: var(--bg-2);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
}
.willkommen-aside .pill {
  display: inline-block;
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--brand-blue);
  background: rgba(42, 103, 136, 0.08);
  padding: 5px 10px;
  border-radius: 999px;
  margin-bottom: 16px;
}
.willkommen-aside h3 {
  font-family: var(--ff-display);
  font-size: 22px;
  font-weight: 600;
  margin-bottom: 14px;
}
.kv-row {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 16px;
  padding: 14px 0;
  border-top: 1px solid var(--hairline);
  font-size: 14.5px;
}
.kv-row:last-of-type { border-bottom: 1px solid var(--hairline); }
.kv-row .k { color: var(--ink-quiet); font-family: var(--ff-mono); font-size: 11.5px; letter-spacing: 0.12em; text-transform: uppercase; padding-top: 2px; }
.kv-row .v { color: var(--ink); font-weight: 500; line-height: 1.4; }
@media (max-width: 880px) {
  .willkommen-grid { grid-template-columns: 1fr; gap: 32px; }
  .willkommen-aside { position: static; }
}

/* ============================== PROFESSIONALITÄT (lime accent) ============================== */
.prof {
  background: var(--bg-dark);
  color: #e9eef3;
  padding: var(--sect-pad-y) 0;
  position: relative;
  overflow: hidden;
}
.prof::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(60% 80% at 100% 0%, rgba(75, 167, 232, 0.18) 0%, transparent 60%),
    radial-gradient(50% 60% at 0% 100%, rgba(201, 214, 14, 0.10) 0%, transparent 60%);
  pointer-events: none;
}
/* Laser-beam decorative pattern */
.prof::after {
  content: "";
  position: absolute;
  right: -10%; top: -10%;
  width: 70%; height: 130%;
  background:
    conic-gradient(from 200deg at 50% 100%,
      transparent 0deg,
      rgba(75, 167, 232, 0.06) 6deg,
      transparent 12deg,
      rgba(75, 167, 232, 0.10) 18deg,
      transparent 24deg,
      rgba(75, 167, 232, 0.05) 32deg,
      transparent 40deg);
  filter: blur(2px);
  pointer-events: none;
  z-index: 0;
}
.prof .container { position: relative; z-index: 1; }
.prof .eyebrow { color: rgba(255,255,255,.55); }
.prof h2 { color: var(--brand-lime); }
.prof p { color: rgba(233, 238, 243, 0.78); }
.prof .lede { color: rgba(255,255,255,.92); }
.prof-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 64px;
  align-items: start;
}
.prof-points {
  display: grid;
  gap: 8px;
  align-content: start;
}
.prof-point {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 18px;
  padding: 20px 0;
  border-top: 1px solid rgba(255,255,255,.08);
}
.prof-point:last-child { border-bottom: 1px solid rgba(255,255,255,.08); }
.prof-point .num {
  font-family: var(--ff-mono);
  font-size: 12px;
  color: var(--brand-lime);
  letter-spacing: 0.16em;
}
.prof-point h4 {
  font-family: var(--ff-display);
  font-size: 18px;
  font-weight: 600;
  text-transform: none;
  letter-spacing: -0.005em;
  color: #fff;
  margin-bottom: 6px;
}
.prof-point p { margin: 0; font-size: 14.5px; color: rgba(233, 238, 243, 0.72); }
@media (max-width: 880px) {
  .prof-grid { grid-template-columns: 1fr; gap: 32px; }
}

/* ============================== EDITORIAL BLOCKS (Qualität, Zeit, Kommen, Unabhängig) ============================== */
.editorial {
  padding-top: 100px;
}
.editorial-grid {
  display: grid;
  grid-template-columns: 1fr 1.25fr;
  gap: 96px;
  align-items: start;
}
.editorial-grid .num {
  font-family: var(--ff-mono);
  font-size: 13px;
  letter-spacing: 0.18em;
  color: var(--ink-quiet);
  text-transform: uppercase;
}
.editorial-grid h2 {
  margin-top: 14px;
  font-family: var(--ff-display);
  font-size: clamp(36px, 4.4vw, 60px);
  line-height: 0.98;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -0.015em;
}
[data-font="editorial"] .editorial-grid h2 { text-transform: none; font-weight: 400; }
.editorial-grid .body p { font-size: 17px; line-height: 1.7; color: var(--ink-2); max-width: 60ch; }
.editorial-grid .body p + p { margin-top: 1em; }
.editorial-aside {
  margin-top: 32px;
  padding: 20px 24px;
  background: var(--bg-paper);
  border-left: 2px solid var(--accent);
  border-radius: 0 8px 8px 0;
  font-size: 15px;
  color: var(--ink-2);
}
@media (max-width: 880px) {
  .editorial-grid { grid-template-columns: 1fr; gap: 24px; }
}

/* Section with dual-tone bg variation */
.bg-paper { background: var(--bg-paper); }
.divider {
  height: 1px;
  background: var(--hairline);
  margin: 0;
}
.section-rule {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.section-rule .line {
  height: 1px;
  background: var(--hairline);
}

/* ============================== PROGRAMM CTA ============================== */
.programm {
  padding: var(--sect-pad-y) 0;
  background: var(--bg);
}
.programm-card {
  background: var(--ink);
  color: #fff;
  border-radius: var(--radius-lg);
  padding: 64px 64px;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 48px;
  align-items: center;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.programm-card::before {
  /* Laser sweep decoration */
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(70% 100% at 100% 50%, rgba(75, 167, 232, 0.25) 0%, transparent 60%),
    linear-gradient(90deg, transparent 60%, rgba(201, 214, 14, 0.05) 100%);
  z-index: -1;
}
.programm-card h2 {
  font-family: var(--ff-display);
  font-size: clamp(36px, 4vw, 56px);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  line-height: 0.98;
  color: #fff;
}
.programm-card p { color: rgba(255,255,255,.75); margin-top: 18px; }
.programm-card .num {
  font-family: var(--ff-mono);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
}
.programm-card .file {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 12px;
  padding: 24px;
  display: flex; flex-direction: column; gap: 14px;
}
.programm-card .file .doc-row {
  display: flex; align-items: center; gap: 14px;
  padding: 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
}
.programm-card .file .doc-row .ico {
  width: 40px; height: 48px;
  background: var(--brand-lime);
  color: #0b1825;
  border-radius: 4px;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--ff-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.05em;
}
.programm-card .file .doc-row .meta {
  flex: 1;
}
.programm-card .file .doc-row .meta b {
  display: block;
  font-family: var(--ff-body);
  font-size: 14.5px;
  font-weight: 600;
  color: #fff;
}
.programm-card .file .doc-row .meta span {
  display: block;
  font-size: 12.5px;
  color: rgba(255,255,255,.55);
  margin-top: 2px;
  font-family: var(--ff-mono);
  letter-spacing: 0.05em;
}
.programm-card .file .pending {
  font-size: 12px;
  color: rgba(255,255,255,.55);
  font-style: italic;
}
@media (max-width: 880px) {
  .programm-card { grid-template-columns: 1fr; padding: 36px 28px; gap: 28px; }
}

/* ============================== REFERENTEN (editorial) ============================== */
.referenten {
  padding: var(--sect-pad-y) 0;
}
.speaker {
  display: grid;
  grid-template-columns: 0.45fr 1.55fr;
  gap: 56px;
  align-items: start;
  padding: 64px 0;
  border-top: 1px solid var(--hairline);
}
.speaker:last-of-type { border-bottom: 1px solid var(--hairline); }
.speaker-portrait {
  position: relative;
  background: var(--bg-paper);
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 4/5;
  cursor: pointer;
  transition: transform .4s cubic-bezier(.2,.7,.2,1);
}
.speaker-portrait img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .8s cubic-bezier(.2,.7,.2,1);
}
.speaker-portrait:hover img { transform: scale(1.04); }
.speaker-portrait .badge {
  position: absolute;
  top: 16px; left: 16px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(8px);
  padding: 5px 10px;
  border-radius: 999px;
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.speaker-portrait .more {
  position: absolute;
  bottom: 16px; right: 16px;
  background: var(--ink);
  color: #fff;
  border-radius: 999px;
  padding: 9px 16px;
  font-size: 12.5px;
  font-weight: 500;
  display: inline-flex; align-items: center; gap: 6px;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .25s, transform .25s;
}
.speaker-portrait:hover .more { opacity: 1; transform: translateY(0); }

[data-speaker-style="card"] .speaker-portrait {
  box-shadow: 0 24px 48px -28px rgba(0,0,0,.3);
  border: 1px solid var(--hairline);
}
[data-speaker-style="frame"] .speaker-portrait {
  background: var(--brand-lime);
  padding: 18px;
}
[data-speaker-style="frame"] .speaker-portrait img {
  border-radius: 8px;
}
[data-speaker-style="frame"] .speaker-portrait .badge {
  top: 30px; left: 30px;
}

.speaker-info .name {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-quiet);
  margin-bottom: 12px;
}
.speaker-info h3 {
  font-family: var(--ff-display);
  font-size: clamp(32px, 3.4vw, 48px);
  line-height: 1.02;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -0.015em;
  margin-bottom: 8px;
}
[data-font="editorial"] .speaker-info h3 { text-transform: none; font-weight: 400; }
.speaker-info .role {
  font-size: 17px;
  color: var(--ink-muted);
  margin-bottom: 24px;
  line-height: 1.45;
  max-width: 44ch;
}
.speaker-info .bio-bullets {
  list-style: none;
  padding: 0; margin: 0 0 28px;
  display: grid; gap: 4px;
  font-size: 15px;
  color: var(--ink-2);
}
.speaker-info .bio-bullets li {
  position: relative;
  padding: 6px 0 6px 20px;
}
.speaker-info .bio-bullets li::before {
  content: "";
  position: absolute;
  left: 0; top: 14px;
  width: 8px; height: 1px;
  background: var(--accent);
}
.speaker-info .tags {
  display: flex; flex-wrap: wrap; gap: 6px;
}
.speaker-info .tag {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  padding: 5px 10px;
  background: var(--bg-2);
  border: 1px solid var(--hairline);
  border-radius: 999px;
  color: var(--ink-muted);
}

.speaker-ghost {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 48px;
}
.speaker-ghost .g {
  aspect-ratio: 1/1;
  background:
    repeating-linear-gradient(45deg,
      rgba(13,27,39,.025) 0,
      rgba(13,27,39,.025) 8px,
      rgba(13,27,39,.05) 8px,
      rgba(13,27,39,.05) 16px);
  border: 1px dashed var(--hairline-strong);
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-mono);
  font-size: 11.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-quiet);
  text-align: center;
  padding: 16px;
}

@media (max-width: 880px) {
  .speaker { grid-template-columns: 1fr; gap: 28px; padding: 36px 0; }
  .speaker-ghost { grid-template-columns: 1fr; }
}

/* ============================== SPONSOREN ============================== */
.sponsoren {
  background: var(--bg-paper);
  padding: var(--sect-pad-y) 0;
}
.sponsor-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 64px;
  align-items: center;
}
.sponsor-slots {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-top: 32px;
}
.sponsor-slot {
  aspect-ratio: 3/2;
  background: var(--bg-2);
  border: 1px dashed var(--hairline-strong);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-quiet);
}
.sponsor-counter {
  margin-top: 28px;
  display: flex; align-items: center; gap: 20px;
  padding: 18px 24px;
  background: var(--ink);
  color: #fff;
  border-radius: 12px;
}
.sponsor-counter .big {
  font-family: var(--ff-display);
  font-size: 44px;
  font-weight: 700;
  line-height: 1;
  color: var(--brand-lime);
}
.sponsor-counter .lbl {
  font-size: 13px;
  color: rgba(255,255,255,.8);
  line-height: 1.4;
}
.sponsor-counter .lbl b { display: block; color: #fff; font-size: 14.5px; }
@media (max-width: 880px) {
  .sponsor-grid { grid-template-columns: 1fr; gap: 32px; }
  .sponsor-slots { grid-template-columns: repeat(3, 1fr); }
}

/* ============================== REGISTRIERUNG ============================== */
.registrierung {
  padding: var(--sect-pad-y) 0;
}
.reg-card {
  background: var(--ink);
  color: #fff;
  border-radius: var(--radius-lg);
  padding: 80px 64px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.reg-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(70% 100% at 50% 100%, rgba(75, 167, 232, 0.22) 0%, transparent 60%),
    conic-gradient(from 180deg at 50% 130%,
      transparent 0deg,
      rgba(75, 167, 232, 0.08) 8deg,
      transparent 16deg,
      rgba(75, 167, 232, 0.05) 24deg,
      transparent 32deg);
  pointer-events: none;
}
.reg-card > * { position: relative; z-index: 1; }
.reg-card h2 {
  color: #fff;
  font-family: var(--ff-display);
  font-size: clamp(40px, 4.4vw, 64px);
  font-weight: 700;
  text-transform: uppercase;
  line-height: 0.98;
  letter-spacing: -0.015em;
}
.reg-card p { color: rgba(255,255,255,.75); margin-top: 16px; }
.reg-stats {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}
.reg-stat {
  padding: 22px 24px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 12px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 16px;
  align-items: center;
}
.reg-stat .lbl { font-size: 13.5px; color: rgba(255,255,255,.75); line-height: 1.45; }
.reg-stat .lbl b { color: #fff; }
.reg-stat .big {
  font-family: var(--ff-display);
  font-size: 38px;
  line-height: 1;
  font-weight: 700;
  color: var(--brand-lime);
}
@media (max-width: 880px) {
  .reg-card { grid-template-columns: 1fr; padding: 40px 28px; }
}

/* ============================== FAQ (tabbed) ============================== */
.faq {
  padding: var(--sect-pad-y) 0;
  background: var(--bg-paper);
}
.faq-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 32px;
  padding: 6px;
  background: var(--bg-2);
  border: 1px solid var(--hairline);
  border-radius: 999px;
  width: fit-content;
}
.faq-tabs button {
  appearance: none;
  background: transparent;
  border: 0;
  padding: 10px 18px;
  border-radius: 999px;
  font-family: var(--ff-body);
  font-size: 13.5px;
  font-weight: 500;
  color: var(--ink-muted);
  letter-spacing: 0.01em;
  transition: background .2s, color .2s;
  display: inline-flex; align-items: center; gap: 8px;
}
.faq-tabs button:hover { color: var(--ink); }
.faq-tabs button.active {
  background: var(--ink);
  color: #fff;
}
.faq-tabs button .count {
  font-family: var(--ff-mono);
  font-size: 11px;
  opacity: .6;
  font-weight: 400;
}

.faq-body {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 56px;
  align-items: start;
}
.faq-list {
  display: flex; flex-direction: column;
  border-top: 1px solid var(--hairline);
}
.faq-item {
  border-bottom: 1px solid var(--hairline);
}
.faq-q {
  appearance: none;
  background: transparent;
  border: 0;
  padding: 22px 0;
  width: 100%;
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
  text-align: left;
  font-family: var(--ff-display);
  font-size: 19px;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -0.005em;
  text-transform: none;
}
.faq-q .plus {
  flex-shrink: 0;
  width: 30px; height: 30px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px;
  background: var(--bg-2);
  border: 1px solid var(--hairline);
  transition: background .2s, transform .3s;
  color: var(--ink);
}
.faq-q .plus svg { transition: transform .3s; }
.faq-item.open .faq-q .plus { background: var(--ink); color: #fff; border-color: var(--ink); }
.faq-item.open .faq-q .plus svg { transform: rotate(45deg); }
.faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height .35s ease;
}
.faq-item.open .faq-a { max-height: 800px; }
.faq-a-inner {
  padding: 0 0 24px;
  color: var(--ink-2);
  font-size: 15.5px;
  line-height: 1.65;
}
.faq-a-inner a { color: var(--brand-blue); text-decoration: underline; text-underline-offset: 3px; }

.faq-side {
  position: sticky;
  top: 110px;
}
.faq-map {
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--hairline);
  background: var(--bg-2);
  position: relative;
}
.faq-map iframe {
  display: block;
  width: 100%;
  height: 320px;
  border: 0;
  filter: grayscale(.15) contrast(1.02);
}
.faq-map .map-meta {
  padding: 18px 22px;
  border-top: 1px solid var(--hairline);
  display: flex; justify-content: space-between; align-items: flex-start; gap: 16px;
}
.faq-map .map-meta b {
  font-family: var(--ff-display);
  font-size: 17px;
  font-weight: 600;
  color: var(--ink);
}
.faq-map .map-meta div { font-size: 13px; color: var(--ink-muted); line-height: 1.5; margin-top: 4px; }
.faq-map .map-meta a {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brand-blue);
  text-decoration: none;
  white-space: nowrap;
  padding-top: 4px;
}
.faq-side .hotels {
  margin-top: 18px;
  padding: 22px;
  background: var(--bg-2);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
}
.faq-side .hotels h4 {
  font-family: var(--ff-display);
  font-size: 17px;
  font-weight: 600;
  margin-bottom: 12px;
}
.hotel-list {
  display: grid; gap: 6px;
}
.hotel-list a {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 0;
  border-top: 1px solid var(--hairline);
  text-decoration: none;
  color: var(--ink);
  font-size: 14px;
  font-weight: 500;
  transition: color .2s;
}
.hotel-list a:hover { color: var(--brand-blue); }
.hotel-list a span { font-family: var(--ff-mono); font-size: 11px; color: var(--ink-quiet); letter-spacing: 0.06em; }
.hotel-list a:last-child { border-bottom: 1px solid var(--hairline); }

@media (max-width: 980px) {
  .faq-body { grid-template-columns: 1fr; }
  .faq-side { position: static; }
}
@media (max-width: 600px) {
  .faq-tabs {
    border-radius: 16px;
    width: 100%;
  }
  .faq-tabs button {
    flex: 1;
    justify-content: center;
  }
}

/* ============================== KONTAKT ============================== */
.kontakt {
  padding: var(--sect-pad-y) 0;
}
.kontakt-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: stretch;
}
.kontakt-card {
  padding: 40px;
  background: var(--bg-2);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-lg);
  display: flex; flex-direction: column;
}
.kontakt-card .eyebrow { margin-bottom: 22px; }
.kontakt-card h3 {
  font-family: var(--ff-display);
  font-size: clamp(28px, 2.6vw, 38px);
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.05;
  margin-bottom: 12px;
}
.kontakt-card .role { color: var(--ink-muted); font-size: 15px; margin-bottom: 28px; }
.kontakt-row {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 0;
  border-top: 1px solid var(--hairline);
  text-decoration: none;
  color: var(--ink);
}
.kontakt-row:last-child { border-bottom: 1px solid var(--hairline); }
.kontakt-row .ico {
  width: 36px; height: 36px;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent);
  display: inline-flex; align-items: center; justify-content: center;
}
.kontakt-row .meta .l { font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-quiet); }
.kontakt-row .meta .v { font-size: 15.5px; font-weight: 500; color: var(--ink); margin-top: 2px; }

/* Newsletter */
.newsletter-card {
  padding: 40px;
  background: var(--ink);
  color: #fff;
  border-radius: var(--radius-lg);
  display: flex; flex-direction: column;
  position: relative;
  overflow: hidden;
}
.newsletter-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(80% 80% at 100% 0%, rgba(75, 167, 232, 0.22) 0%, transparent 60%);
  pointer-events: none;
}
.newsletter-card > * { position: relative; z-index: 1; }
.newsletter-card h3 {
  font-family: var(--ff-display);
  font-size: clamp(28px, 2.6vw, 38px);
  font-weight: 600;
  color: #fff;
  letter-spacing: -0.01em;
  margin-bottom: 12px;
}
.newsletter-card p { color: rgba(255,255,255,.7); margin-bottom: 24px; }
.nl-form { display: flex; flex-direction: column; gap: 10px; margin-top: auto; }
.nl-field {
  display: flex; flex-direction: column; gap: 6px;
}
.nl-field label {
  font-family: var(--ff-mono);
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
}
.nl-field input {
  appearance: none;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 8px;
  padding: 13px 16px;
  font-family: var(--ff-body);
  font-size: 15px;
  color: #fff;
  outline: none;
  transition: border-color .2s, background .2s;
}
.nl-field input:focus { border-color: var(--brand-lime); background: rgba(255,255,255,.10); }
.nl-field input::placeholder { color: rgba(255,255,255,.4); }
.nl-consent {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 12.5px;
  color: rgba(255,255,255,.65);
  line-height: 1.4;
  margin: 8px 0 14px;
}
.nl-consent input { margin-top: 3px; accent-color: var(--brand-lime); }
.nl-submit {
  background: var(--brand-lime);
  color: #0b1825;
  border: 0;
  border-radius: 999px;
  padding: 14px 22px;
  font-family: var(--ff-body);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.01em;
  transition: transform .2s, background .2s;
  cursor: pointer;
  align-self: flex-start;
}
.nl-submit:hover { transform: translateY(-1px); }
.nl-success {
  margin-top: 14px;
  padding: 14px 16px;
  background: rgba(201, 214, 14, 0.15);
  border: 1px solid rgba(201, 214, 14, 0.4);
  color: var(--brand-lime);
  border-radius: 8px;
  font-size: 13.5px;
}
.nl-error {
  margin-top: 8px;
  padding: 10px 14px;
  background: rgba(220, 60, 60, 0.15);
  border: 1px solid rgba(220, 60, 60, 0.35);
  color: #f87171;
  border-radius: 6px;
  font-size: 13px;
}
.nl-doi-hint {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin-top: -8px;
  margin-bottom: 20px;
  padding: 10px 14px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 8px;
  font-size: 12.5px;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.75);
}
.nl-doi-hint > svg {
  flex-shrink: 0;
  margin-top: 2px;
}

@media (max-width: 880px) {
  .kontakt-grid { grid-template-columns: 1fr; }
}

/* ============================== FOOTER ============================== */
.site-footer {
  background: var(--bg-dark);
  color: rgba(255,255,255,.7);
  padding: 72px 0 32px;
  position: relative;
  overflow: hidden;
}
.site-footer::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(60% 80% at 20% 0%, rgba(75, 167, 232, 0.12) 0%, transparent 60%);
  pointer-events: none;
}
.site-footer .container { position: relative; }
.footer-top {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 48px;
  padding-bottom: 56px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.footer-brand img {
  height: 56px;
  filter: brightness(0) invert(1);
  margin-bottom: 20px;
}
.footer-brand p { color: rgba(255,255,255,.6); font-size: 14.5px; max-width: 40ch; }
.footer-col h5 {
  font-family: var(--ff-mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.5);
  margin: 0 0 14px;
  font-weight: 500;
}
.footer-col a {
  display: block;
  padding: 6px 0;
  font-size: 14.5px;
  color: rgba(255,255,255,.78);
  text-decoration: none;
  transition: color .2s;
}
.footer-col a:hover { color: #fff; }
.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 32px;
  gap: 24px;
  flex-wrap: wrap;
  font-family: var(--ff-mono);
  font-size: 11.5px;
  letter-spacing: 0.06em;
  color: rgba(255,255,255,.5);
  text-transform: uppercase;
}
.footer-bottom .social { display: flex; gap: 8px; }
.footer-bottom .social a {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.85);
  transition: background .2s, transform .2s;
}
.footer-bottom .social a:hover { background: rgba(255,255,255,.12); transform: translateY(-1px); }
.footer-bottom .social a svg { width: 18px; height: 18px; display: block; flex-shrink: 0; }

@media (max-width: 880px) {
  .footer-top { grid-template-columns: 1fr; gap: 32px; }
}

/* ============================== MODAL ============================== */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(7, 17, 27, 0.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 1000;
  display: flex; align-items: center; justify-content: center;
  padding: 32px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s;
}
.modal-overlay.open { opacity: 1; pointer-events: auto; }
.modal {
  background: var(--bg);
  border-radius: var(--radius-lg);
  max-width: 920px;
  width: 100%;
  max-height: calc(100vh - 64px);
  overflow: auto;
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  transform: translateY(20px) scale(.98);
  transition: transform .3s;
  overflow-x: hidden;
}
.modal-overlay.open .modal { transform: translateY(0) scale(1); }
.modal-img {
  background: var(--bg-paper);
  position: relative;
  min-height: 100%;
}
.modal-img img { width: 100%; height: 100%; object-fit: cover; min-height: 400px; }
.modal-body { padding: 40px 36px; position: relative; }
.modal-close {
  position: absolute;
  top: 16px; right: 16px;
  width: 36px; height: 36px;
  border-radius: 999px;
  background: var(--bg-2);
  border: 1px solid var(--hairline);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--ink);
}
.modal-body .name {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-quiet);
  margin-bottom: 10px;
}
.modal-body h3 {
  font-family: var(--ff-display);
  font-size: 32px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  margin-bottom: 8px;
}
[data-font="editorial"] .modal-body h3 { text-transform: none; font-weight: 400; }
.modal-body .role { color: var(--ink-muted); font-size: 15px; margin-bottom: 24px; }
.modal-body .full-bio {
  display: grid; gap: 8px;
  font-size: 14.5px; color: var(--ink-2);
}
.modal-body .full-bio div {
  padding: 10px 0;
  border-top: 1px solid var(--hairline);
}
.modal-body .full-bio div:last-child { border-bottom: 1px solid var(--hairline); }

@media (max-width: 720px) {
  .modal { grid-template-columns: 1fr; }
  .modal-img img { min-height: 240px; }
}

/* ============================== FADE-IN ON SCROLL ============================== */
.fade-up {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1);
}
.fade-up.in {
  opacity: 1;
  transform: translateY(0);
}
.fade-up.d1 { transition-delay: .08s; }
.fade-up.d2 { transition-delay: .16s; }
.fade-up.d3 { transition-delay: .24s; }

/* ============================== ICONS ============================== */
.ico-sm { width: 16px; height: 16px; }
.ico-md { width: 20px; height: 20px; }

/* ============================== MOBILE NAV ============================== */
@media (max-width: 1080px) {
  .mobile-toggle { display: inline-flex; }
  .nav.open {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 100%; left: 0; right: 0;
    background: rgba(246,245,240,.96);
    backdrop-filter: blur(16px);
    border-top: 1px solid var(--hairline);
    padding: 12px 0 20px;
    z-index: 99;
  }
  .nav.open a:not(.nav-cta) { display: flex; padding: 12px var(--gutter); }
  .nav.open .nav-cta { margin: 8px var(--gutter) 0; }
}

