/* ─────────────────────────────────────────────────────────────
   Daniel Vesel · Referenzen & Entwicklung
   style.v13 · Editorial · Cormorant Garamond + DM Sans
   ───────────────────────────────────────────────────────────── */

:root{
  --bg:#0a0a0a;
  --bg-warm:#100e0a;      /* used in Heute section */
  --gold:#c9a560;
  --gold-soft:#dcb872;
  --gold-dim:rgba(201,165,96,.55);
  --gold-faint:rgba(201,165,96,.16);
  --hairline:rgba(201,165,96,.12);
  --hairline-2:rgba(255,255,255,.07);
  --ink:#f4f0e7;
  --ink-2:#e6e0d4;
  --muted:#8b857c;
  --faded:#5a554d;
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'DM Sans', system-ui, -apple-system, sans-serif;
  --max:980px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:300;
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit}

.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
@media(min-width:780px){ .wrap{padding:0 48px} }

/* ─────────── Topbar ─────────── */
.topbar{
  border-bottom:1px solid var(--hairline-2);
  padding:18px 0;
  position:sticky;
  top:0;
  z-index:20;
  background:rgba(10,10,10,.88);
  backdrop-filter:saturate(1.2) blur(10px);
  -webkit-backdrop-filter:saturate(1.2) blur(10px);
}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;gap:16px}
.topbar-brand{
  display:flex;align-items:center;gap:12px;
  font-family:var(--sans);font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--muted);text-decoration:none;
}
.topbar-brand .mark{
  width:30px;height:30px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--gold-faint);
  background:rgba(255,255,255,.02);
  color:var(--gold-soft);
  font-family:var(--serif);
  font-style:italic;
  font-size:14px;
  font-weight:500;
}
.topbar-brand b{color:var(--ink-2);font-weight:500;letter-spacing:.22em}
.topbar-nav{display:flex;gap:24px;font-family:var(--sans);font-size:10px;letter-spacing:.22em;text-transform:uppercase}
.topbar-nav a{color:var(--muted);text-decoration:none;padding-bottom:3px;border-bottom:1px solid transparent;transition:color .2s, border-color .2s}
.topbar-nav a:hover{color:var(--gold);border-color:var(--gold-faint)}
@media(max-width:720px){
  .topbar{padding:14px 0 12px}
  .topbar-inner{display:flex;flex-direction:column;align-items:stretch;gap:10px}
  .topbar-brand{align-self:flex-start}
  .topbar-nav{display:flex;justify-content:flex-end;flex-wrap:wrap;gap:14px}
  .topbar-nav a{font-size:9px;letter-spacing:.20em;padding-bottom:0}
}

/* ─────────── Hero ─────────── */
.hero{
  padding:110px 0 100px;
  border-bottom:1px solid var(--hairline-2);
  position:relative;
}
@media(max-width:720px){ .hero{padding:72px 0 70px} }

.hero-eyebrow{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
  margin-bottom:36px;
  display:flex;
  align-items:center;
  gap:14px;
}
.hero-eyebrow::before{
  content:"";width:32px;height:1px;background:var(--gold-dim);
}
.hero-name{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(48px, 8vw, 88px);
  line-height:.95;
  letter-spacing:-0.02em;
  margin:0 0 36px;
  color:var(--ink);
}
.hero-thesis{
  font-family:var(--serif);
  font-weight:400;
  font-style:italic;
  font-size:clamp(26px, 3.6vw, 40px);
  line-height:1.2;
  color:var(--gold-soft);
  margin:0 0 44px;
  max-width:680px;
  letter-spacing:-0.01em;
}
.hero-lead{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(18px, 1.9vw, 21px);
  line-height:1.6;
  color:var(--ink-2);
  max-width:620px;
  margin:0 0 48px;
}
.hero-meta{
  display:flex;
  flex-wrap:wrap;
  gap:18px 36px;
  padding-top:32px;
  border-top:1px solid var(--hairline-2);
  font-family:var(--sans);
  font-size:12px;
  letter-spacing:.06em;
  color:var(--muted);
}
.hero-meta div b{
  display:block;
  font-size:10px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--faded);
  font-weight:500;
  margin-bottom:6px;
}
.hero-meta a{color:var(--ink-2);text-decoration:none;border-bottom:1px solid transparent;transition:color .2s, border-color .2s}
.hero-meta a:hover{color:var(--gold);border-color:var(--gold-faint)}

/* ─────────── Werdegang Wrapper ─────────── */
.werdegang{
  padding:80px 0 60px;
}
.werdegang-intro{
  margin-bottom:72px;
}
.werdegang-intro .label{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--muted);
  margin:0 0 18px;
  display:flex;
  align-items:center;
  gap:14px;
}
.werdegang-intro .label::before{
  content:"";width:28px;height:1px;background:var(--gold-dim);
}
.werdegang-intro h2{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(34px, 5vw, 52px);
  line-height:1.05;
  letter-spacing:-0.01em;
  margin:0 0 16px;
  color:var(--ink);
}
.werdegang-intro h2 em{font-style:italic;color:var(--gold);font-weight:300}
.werdegang-intro p{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(17px, 1.8vw, 20px);
  color:var(--muted);
  max-width:560px;
  margin:0;
}

/* ─────────── Akt (compact narrative) ─────────── */
.akt{
  display:grid;
  grid-template-columns:1fr;
  gap:14px 56px;
  padding:54px 0;
  border-top:1px solid var(--hairline);
  position:relative;
}
.akt:last-of-type{border-bottom:1px solid var(--hairline)}
@media(min-width:880px){
  .akt{
    grid-template-columns:120px 1fr;
    gap:0 64px;
    padding:64px 0;
  }
}

.akt-marker{
  display:flex;
  flex-direction:column;
  gap:6px;
  align-items:flex-start;
}
@media(min-width:880px){ .akt-marker{padding-top:8px} }

.akt-num{
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  font-size:48px;
  line-height:1;
  color:var(--gold);
  letter-spacing:-0.02em;
}
.akt-icon{
  width:22px;
  height:22px;
  margin-top:14px;
  fill:none;
  stroke:var(--gold-dim);
  stroke-width:1;
  stroke-linecap:round;
  stroke-linejoin:round;
  opacity:.85;
}
.akt-years{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.18em;
  color:var(--muted);
  font-weight:500;
  text-transform:uppercase;
  margin-top:14px;
}

.akt-body h3{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(26px, 3.4vw, 36px);
  line-height:1.15;
  letter-spacing:-0.01em;
  margin:0 0 8px;
  color:var(--ink);
}
.akt-body h3 em{color:var(--gold);font-style:italic;font-weight:400}
.akt-body .akt-kicker{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
  margin:0 0 16px;
}
.akt-body p.prose{
  font-family:var(--serif);
  font-weight:400;
  font-size:18px;
  line-height:1.65;
  color:var(--ink-2);
  margin:0 0 16px;
  max-width:620px;
}
.akt-body p.prose + p.prose{margin-top:0}

/* Pull quote: used sparingly */
.pull{
  font-family:var(--serif);
  font-style:italic;
  font-weight:400;
  font-size:18px;
  line-height:1.55;
  color:var(--muted);
  margin:24px 0 4px;
  padding:0 0 0 22px;
  border-left:1px solid var(--gold-faint);
  max-width:580px;
}
.pull-source{
  display:block;
  font-family:var(--sans);
  font-style:normal;
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--faded);
  margin-top:12px;
}

/* Proof links */
.proofs{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:22px;
}
.proof{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
  text-decoration:none;
  padding:9px 14px;
  border:1px solid var(--gold-faint);
  transition:border-color .2s, background .2s, color .2s;
  white-space:nowrap;
}
.proof:hover{border-color:var(--gold);background:rgba(201,165,96,.05);color:var(--gold-soft)}
.proof .arrow{display:inline-block;transition:transform .25s}
.proof:hover .arrow{transform:translateX(3px)}

/* ─────────── Bridge to Heute ─────────── */
.bridge{
  padding:80px 0 30px;
  text-align:center;
}
.bridge-rule{
  width:1px;
  height:110px;
  background:linear-gradient(to bottom, transparent, var(--gold-dim) 50%, transparent);
  margin:0 auto;
}

/* ─────────── Heute · Ready4nexxt (the climax) ─────────── */
.heute{
  position:relative;
  padding:60px 0 140px;
  text-align:center;
  background:
    radial-gradient(circle at 50% 30%, rgba(201,165,96,.05), transparent 55%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg-warm) 40%, var(--bg) 100%);
  border-top:1px solid var(--hairline);
  border-bottom:1px solid var(--hairline);
}
.heute-kicker{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
  margin-bottom:32px;
}
.heute-icon{
  display:block;
  width:32px;
  height:32px;
  margin:0 auto 22px;
  fill:none;
  stroke:var(--gold);
  stroke-width:1;
  stroke-linecap:round;
  stroke-linejoin:round;
  opacity:.9;
}
.heute-logo{
  display:block;
  width:clamp(88px, 11vw, 112px);
  height:auto;
  margin:0 auto 32px;
  user-select:none;
  -webkit-user-drag:none;
  filter:drop-shadow(0 8px 28px rgba(201,165,96,.18));
}
@media(max-width:480px){ .heute-logo{margin-bottom:26px} }
.heute-thesis{
  font-family:var(--serif);
  font-weight:400;
  font-style:italic;
  font-size:clamp(24px, 3.4vw, 38px);
  line-height:1.2;
  color:var(--gold-soft);
  margin:0 auto 36px;
  max-width:680px;
  letter-spacing:-0.005em;
}
.heute-name{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(56px, 10vw, 110px);
  line-height:.95;
  letter-spacing:-0.025em;
  margin:0 0 36px;
  color:var(--ink);
}
.heute-body{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(18px, 2vw, 22px);
  line-height:1.6;
  color:var(--ink-2);
  max-width:640px;
  margin:0 auto 24px;
}
.heute-note{
  font-family:var(--serif);
  font-style:italic;
  font-size:17px;
  color:var(--muted);
  max-width:560px;
  margin:32px auto 0;
}
.cta-row{
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:48px;
}
.cta{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:500;
  text-decoration:none;
  padding:16px 30px;
  border:1px solid var(--gold);
  color:var(--gold);
  background:transparent;
  transition:background .25s, color .25s;
}
.cta:hover{background:var(--gold);color:var(--bg)}
.cta-secondary{border-color:var(--hairline);color:var(--muted)}
.cta-secondary:hover{background:transparent;color:var(--ink);border-color:var(--ink-2)}

/* ─────────── Zertifikate ─────────── */
.zertifikate{padding:90px 0 80px}
.zertifikate-head{margin-bottom:48px}
.zertifikate-head .label{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--muted);
  margin:0 0 16px;
  display:flex;
  align-items:center;
  gap:14px;
}
.zertifikate-head .label::before{
  content:"";width:28px;height:1px;background:var(--gold-dim);
}
.zertifikate-head h2{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(34px, 5vw, 52px);
  line-height:1.05;
  margin:0 0 16px;
  color:var(--ink);
}
.zertifikate-head h2 em{color:var(--gold);font-style:italic;font-weight:300}
.zertifikate-head p{
  font-family:var(--serif);
  font-style:italic;
  font-size:17px;
  color:var(--muted);
  max-width:560px;
  margin:0;
}
.zert-groups{
  display:grid;
  grid-template-columns:1fr;
  gap:48px;
}
@media(min-width:780px){
  .zert-groups{grid-template-columns:repeat(3,1fr);gap:48px}
}
.zert-group h3{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
  margin:0 0 20px;
  padding-bottom:14px;
  border-bottom:1px solid var(--hairline);
}
.zert-list{list-style:none;margin:0;padding:0}
.zert-item{
  display:block;
  padding:14px 0;
  border-bottom:1px solid var(--hairline-2);
  text-decoration:none;
  color:inherit;
  transition:border-color .2s;
  position:relative;
}
.zert-item:hover{border-color:var(--gold-faint)}
.zert-name{
  font-family:var(--serif);
  font-weight:400;
  font-size:17px;
  line-height:1.3;
  color:var(--ink-2);
  margin:0 0 4px;
  padding-right:24px;
}
.zert-item:hover .zert-name{color:var(--gold-soft)}
.zert-meta{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.06em;
  color:var(--muted);
}
.zert-item::after{
  content:"→";
  position:absolute;
  right:0;
  top:14px;
  color:var(--gold-faint);
  font-family:var(--sans);
  font-size:14px;
  transition:transform .25s, color .25s;
}
.zert-item:hover::after{color:var(--gold);transform:translateX(3px)}

/* ─────────── Kontakt ─────────── */
.kontakt{
  padding:90px 0 90px;
  border-top:1px solid var(--hairline-2);
  text-align:center;
}
.kontakt .label{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold);
  margin:0 0 22px;
}
.kontakt h2{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(30px, 4.5vw, 44px);
  line-height:1.1;
  margin:0 0 18px;
  color:var(--ink);
}
.kontakt h2 em{color:var(--gold);font-style:italic;font-weight:300}
.kontakt-lead{
  font-family:var(--serif);
  font-style:italic;
  font-size:17px;
  color:var(--muted);
  max-width:540px;
  margin:0 auto 44px;
}
.kontakt-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:24px;
  max-width:640px;
  margin:0 auto;
  text-align:left;
}
@media(min-width:660px){ .kontakt-grid{grid-template-columns:1fr 1fr;gap:28px 64px} }
.kontakt-item b{
  display:block;
  font-family:var(--sans);
  font-size:10px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--faded);
  font-weight:500;
  margin-bottom:8px;
}
.kontakt-item a, .kontakt-item span{
  font-family:var(--serif);
  font-size:18px;
  color:var(--ink-2);
  text-decoration:none;
  border-bottom:1px solid transparent;
  transition:border-color .2s, color .2s;
}
.kontakt-item a:hover{color:var(--gold);border-color:var(--gold-faint)}

/* ─────────── Footer ─────────── */
.footer{
  border-top:1px solid var(--hairline-2);
  padding:36px 0 48px;
  text-align:center;
}
.footer p{
  font-family:var(--sans);
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--faded);
  margin:0 0 10px;
}
.footer a{
  color:var(--muted);
  text-decoration:none;
  margin:0 6px;
  transition:color .2s;
}
.footer a:hover{color:var(--gold)}
.footer .note{
  text-transform:none;
  letter-spacing:.02em;
  font-size:11px;
  color:var(--faded);
  font-style:italic;
}

/* ─────────── To Top ─────────── */
.toTop{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:30;
  display:none;
  width:42px;
  height:42px;
  border-radius:50%;
  background:rgba(10,10,10,.85);
  backdrop-filter:blur(8px);
  color:var(--gold);
  border:1px solid var(--gold-faint);
  align-items:center;
  justify-content:center;
  font-size:16px;
  line-height:1;
  cursor:pointer;
  transition:background .2s, border-color .2s;
}
.toTop:hover{background:rgba(201,165,96,.08);border-color:var(--gold)}
.toTop.show{display:inline-flex}

/* ─────────── Reveal ─────────── */
.reveal{
  opacity:0;
  transform:translateY(14px);
  transition:opacity .85s ease, transform .85s ease;
}
.reveal.in{opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ─────────── Print ─────────── */
@media print{
  body{background:#fff;color:#000}
  .topbar, .toTop, .cta-row{display:none}
  .akt-num{color:#888}
  .heute{background:#fff}
  .proof{display:none}
}


/* v14 refinements: centered logo + book feature */
.heute-mark{display:flex;justify-content:center;align-items:center;margin:0 auto 34px;max-width:100%;}
.heute-logo{display:block;width:clamp(140px,17vw,208px);height:auto;margin:0 auto;filter:drop-shadow(0 10px 30px rgba(201,165,96,.18));}
@media(max-width:480px){ .heute-mark{margin-bottom:26px} .heute-logo{width:132px} }
.book-feature{
  margin:38px auto 0;
  max-width:760px;
  display:grid;
  grid-template-columns:132px minmax(0,1fr);
  gap:28px;
  align-items:center;
  text-align:left;
  padding:26px 28px;
  border:1px solid var(--hairline);
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(201,165,96,.03));
}
.book-feature-art{display:flex;justify-content:center;align-items:center}
.book-cover{width:112px;height:auto;filter:drop-shadow(0 10px 26px rgba(0,0,0,.35));}
.book-feature-kicker{
  margin:0 0 8px;
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
}
.book-feature h3{
  margin:0 0 10px;
  font-family:var(--serif);
  font-size:clamp(30px,3.8vw,42px);
  line-height:1;
  font-weight:400;
  color:var(--ink);
}
.book-feature p{
  margin:0;
  font-family:var(--serif);
  font-size:clamp(18px,1.95vw,21px);
  line-height:1.55;
  color:var(--ink-2);
}
.book-feature p em{font-style:italic;color:var(--gold-soft)}
@media(max-width:720px){
  .book-feature{grid-template-columns:1fr;gap:20px;padding:22px 20px;text-align:center}
  .book-feature-copy{text-align:center}
}
