/* ─── DESIGN TOKENS (INCL. REFINEMENTS) ──────────── */
:root {
  --void:   #100e0c;
  --deep:   #171411;
  --srf:    #1d1916;
  --lft:    #26211d;
  --stone:  #a9a297;
  --fog:    #cbc5bb;
  --mist:   #ddd7cd;
  --paper:  #f4f0e8;
  --gold:   #c9ad73;
  --gl:     rgba(201,173,115,.22);
  --gg:     rgba(201,173,115,.10);
  --ln:     rgba(255,255,255,.08);
  --dp: 'Playfair Display', Georgia, serif;
  --mn: 'DM Mono', 'Courier New', monospace;
  --bd: 'DM Sans', system-ui, sans-serif;
  --w: 1160px;
  --side: max(32px, calc((100vw - var(--w)) / 2));
}

/* ─── RESET & BASE ───────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; background: var(--void); }
body {
  background:
    radial-gradient(circle at top left, rgba(201,173,115,.08), transparent 32%),
    radial-gradient(circle at top right, rgba(255,255,255,.03), transparent 24%),
    linear-gradient(180deg, #120f0d 0%, #0f0d0b 100%);
  color: var(--mist); font-family: var(--bd); font-weight: 400; overflow-x: hidden; line-height: 1.6;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

/* grain overlay */
body::after {
  content: ''; position: fixed; inset: 0; pointer-events: none; z-index: 9999; opacity: .018;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ─── LANG SYSTEM ────────────────────────────────── */
[data-lang] { display: none; }
body.en [data-lang="en"], body.de [data-lang="de"] { display: block; }
.t-en, .t-de { display: none !important; }
body.en .t-en, body.de .t-de { display: inline !important; }
body.en span.t-en, body.de span.t-de { display: block !important; }

/* ─── COMPONENTS ─────────────────────────────────── */
.sh { width: min(calc(100% - 56px), var(--w)); margin: 0 auto; }
.lang-pill {
  position: fixed; top: 20px; right: 20px; z-index: 600;
  display: flex; border: 1px solid var(--gl);
  background: rgba(16,14,12,.82); backdrop-filter: blur(12px);
  box-shadow: 0 8px 30px rgba(0,0,0,.16);
}
.lang-pill button {
  font-family: var(--mn); font-size: 9px; letter-spacing: .2em; text-transform: uppercase;
  padding: 7px 13px; background: transparent; border: none; color: var(--stone); cursor: pointer; transition: all .3s;
}
.lang-pill button.on { color: var(--gold); background: var(--gg); }
.lang-pill button:hover { color: var(--mist); }

.bg { display: inline-flex; align-items: center; gap: 10px; padding: 14px 24px; background: var(--gold); color: var(--void); font-family: var(--mn); font-size: .71rem; letter-spacing: .14em; text-transform: uppercase; border: 1px solid var(--gold); transition: all .25s; cursor: pointer; box-shadow: 0 10px 24px rgba(201,173,115,.16); }
.bg:hover { background: #d4b97a; transform: translateY(-2px); }
.bo { display: inline-flex; align-items: center; gap: 10px; padding: 13px 22px; background: transparent; color: var(--mist); font-family: var(--mn); font-size: .71rem; letter-spacing: .13em; text-transform: uppercase; border: 1px solid rgba(196,169,106,.22); transition: all .25s; }
.bo:hover { border-color: rgba(196,169,106,.45); color: var(--paper); transform: translateY(-2px); }
.txt-link { font-family: var(--mn); font-size: .7rem; letter-spacing: .12em; text-transform: uppercase; color: var(--gold); opacity: .8; transition: opacity .2s; display: inline-flex; align-items: center; gap: 8px; }
.txt-link:hover { opacity: 1; }

/* ─── TOPBAR & NAV ───────────────────────────────── */
.bar { position: fixed; inset: 0 0 auto; z-index: 200; height: 64px; display: flex; align-items: center; background: rgba(16,14,12,.84); backdrop-filter: blur(18px); border-bottom: 1px solid rgba(201,173,115,.18); }
.bar-i { width: min(calc(100% - 56px), var(--w)); margin: 0 auto; display: flex; align-items: center; justify-content: space-between; }
.brand { display: flex; align-items: center; gap: 12px; }
.dots { display: grid; grid-template-columns: repeat(5, 4px); gap: 2.5px; flex-shrink: 0; }
.dots i { display: block; width: 4px; height: 4px; border-radius: 50%; background: var(--mist); opacity: .55; }
.dots i.g { background: var(--gold); opacity: .9; }
.bl strong { display: block; font-family: var(--mn); font-size: .68rem; letter-spacing: .15em; text-transform: uppercase; color: var(--paper); font-weight: 400; }
.bl em { display: block; font-family: var(--mn); font-size: .62rem; letter-spacing: .1em; text-transform: uppercase; color: var(--stone); font-style: normal; margin-top: 1px; }
nav { display: flex; gap: 0; align-items: center; }
nav a { font-family: var(--mn); font-size: .67rem; text-transform: uppercase; letter-spacing: .08em; color: var(--stone); padding: 7px 10px; transition: color .2s; white-space: nowrap; }
nav a:hover, nav a.active { color: var(--paper); }
nav a.active { color: var(--gold); }
.ncta { background: var(--gold) !important; color: var(--void) !important; padding: 8px 16px !important; transition: all .25s !important; margin-left: 10px !important; font-weight: 400 !important; }
.ncta:hover { background: #d4b97a !important; transform: translateY(-2px) !important; }

.ham { display: none; flex-direction: column; justify-content: space-between; width: 28px; height: 18px; background: none; border: none; cursor: pointer; padding: 0; flex-shrink: 0; margin-left: 12px; }
.ham span { display: block; height: 1.5px; width: 100%; background: var(--mist); transition: all .3s ease; }
.ham.open span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.ham.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.ham.open span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }
.mob-nav { display: none; position: fixed; inset: 0; z-index: 190; background: rgba(8,7,5,.97); backdrop-filter: blur(20px); opacity: 0; transition: opacity .35s ease; }
.mob-nav.open { opacity: 1; }
.mob-nav-inner { height: 100%; display: flex; flex-direction: column; justify-content: center; align-items: center; padding: 80px 40px 40px; }
.mob-close { position: absolute; top: 24px; right: 24px; background: none; border: none; color: var(--stone); font-size: 1.2rem; cursor: pointer; padding: 8px; transition: color .2s; }
.mob-close:hover { color: var(--paper); }
.mob-links { display: flex; flex-direction: column; align-items: center; width: 100%; }
.mob-links a { font-family: var(--dp); font-style: italic; font-size: clamp(1.8rem, 6vw, 2.8rem); font-weight: 400; color: var(--mist); padding: 16px 0; text-align: center; width: 100%; border-bottom: 1px solid var(--ln); transition: color .2s; }
.mob-links a:first-child { border-top: 1px solid var(--ln); }
.mob-links a:hover { color: var(--paper); }
.mob-cta { color: var(--gold) !important; font-style: normal !important; font-family: var(--mn) !important; font-size: 1rem !important; letter-spacing: .14em !important; text-transform: uppercase !important; padding: 20px 0 !important; }

/* ─── TYPOGRAPHY & SECTIONS ──────────────────────── */
.sec { padding: 112px 0; }
.sec.alt { background: transparent; }
.sec.mid { background: transparent; }
.sec.dark { background: var(--void); }
.slabel, .about-section-label { font-family: var(--mn); font-size: .67rem; text-transform: uppercase; letter-spacing: .2em; color: var(--gold); opacity: .8; margin-bottom: 14px; }
.stitle, .page-h1, .about-section-title { font-family: var(--dp); font-size: clamp(2.2rem, 4vw, 4rem); font-weight: 400; line-height: 1.02; letter-spacing: -.022em; color: var(--paper); }
.stitle em, .page-h1 em { font-style: italic; color: var(--gold); }
.sintro, .sbody, .about-p, .stance-cell-text, .testi-card p { font-size: 1.05rem; line-height: 1.85; color: var(--fog); max-width: 66ch; font-weight: 400; }
.sbody, .about-p { font-size: .97rem; line-height: 1.9; }
.sbody b, .sbody strong, .about-p strong { color: var(--paper); font-weight: 400; }
.split { display: grid; grid-template-columns: 1fr 1.5fr; gap: 88px; align-items: start; }
.page-header { background: linear-gradient(180deg, rgba(201,173,115,.05), rgba(0,0,0,0)); padding: 156px 0 104px; border-bottom: 1px solid var(--gl); }
.page-header-kicker { font-family: var(--mn); font-size: .67rem; letter-spacing: .22em; text-transform: uppercase; color: var(--gold); opacity: .8; margin-bottom: 18px; display: flex; align-items: center; gap: 12px; }
.page-header-kicker::before { content: ''; width: 22px; height: 1px; background: var(--gold); opacity: .35; }
.page-h1 { font-size: clamp(2.8rem, 5.5vw, 5.5rem); max-width: 16ch; line-height: .96; }
.page-intro { font-size: 1.08rem; line-height: 1.82; color: var(--fog); max-width: 52ch; margin-top: 28px; font-weight: 400; }

/* ─── MODALS & CARDS (ELEVATION) ─────────────────── */
.overlay { display: none; position: fixed; inset: 0; background: rgba(8,7,5,.88); backdrop-filter: blur(16px); z-index: 900; align-items: center; justify-content: center; }
.overlay.on { display: flex; }
.modal, .portrait-frame, .testi-block, .testi-card, .stance-cell, [class*="card"], [class*="panel"] {
  box-shadow: 0 18px 40px rgba(0,0,0,.14);
  background: linear-gradient(180deg, rgba(255,255,255,.018), rgba(255,255,255,.008));
}
.modal { background: var(--srf); border: 1px solid var(--gl); border-top: 2px solid var(--gold); max-width: 560px; width: calc(100% - 40px); max-height: 80vh; overflow-y: auto; padding: 40px; position: relative; }
.modal-close { position: absolute; top: 16px; right: 16px; background: none; border: none; color: var(--stone); font-size: 1.2rem; cursor: pointer; padding: 4px; transition: color .2s; }
.modal-close:hover { color: var(--paper); }
.modal h2 { font-family: var(--dp); font-size: 1.4rem; font-weight: 400; color: var(--paper); margin-bottom: 20px; }
.modal h3 { font-family: var(--mn); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); opacity: .6; margin-top: 20px; margin-bottom: 8px; }
.modal p { font-size: .9rem; color: var(--fog); line-height: 1.75; margin-bottom: 8px; }
.modal a { color: var(--gold); opacity: .7; }
.modal-note { font-family: var(--dp); font-style: italic; font-size: .82rem; color: var(--stone); opacity: .4; margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--ln); }

/* ─── FOOTER ─────────────────────────────────────── */
footer { background: linear-gradient(180deg, transparent, rgba(0,0,0,.12)); }
.fi-wrap { border-top: 1px solid var(--gl); padding: 28px 0 34px; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 14px; font-family: var(--mn); font-size: .65rem; letter-spacing: .11em; text-transform: uppercase; color: var(--stone); }
.flinks { display: flex; gap: 18px; flex-wrap: wrap; }
.flinks a { color: var(--stone); transition: color .2s; }
.flinks a:hover { color: var(--gold); }
.fplat a { color: var(--gold); opacity: .45; transition: opacity .2s; }
.fplat a:hover { opacity: 1; }

/* ─── ANIMATIONS & SCROLL REVEAL ─────────────────── */
@keyframes fadeUp { from { opacity: 0; transform: translateY(22px); } to { opacity: 1; transform: translateY(0); } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.fu { opacity: 0; animation: fadeUp 1s cubic-bezier(.16,1,.3,1) forwards; }
.fi { opacity: 0; animation: fadeIn 1.1s ease forwards; }
.d1{animation-delay:.12s} .d2{animation-delay:.28s} .d3{animation-delay:.44s} .d4{animation-delay:.60s} .d5{animation-delay:.76s}
.sr { opacity: 1; transition: opacity .7s ease, transform .7s cubic-bezier(.16,1,.3,1); }
.sr.hide { opacity: 0; transform: translateY(20px); }
.sr.on { opacity: 1; transform: translateY(0); }

/* ─── PAGE: INDEX ────────────────────────────────── */
.hero { position: relative; min-height: 100svh; display: flex; flex-direction: column; justify-content: flex-end; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; background: var(--deep); }
.hero-bg img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 38%; filter: brightness(.28) contrast(1.15) grayscale(.06); }
.hero-bg::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(8,7,5,.3) 0%, transparent 20%), linear-gradient(180deg, transparent 38%, rgba(8,7,5,.78) 65%, var(--void) 100%), radial-gradient(ellipse at 18% 60%, rgba(196,169,106,.06) 0%, transparent 48%); }
.hero-c { position: relative; z-index: 10; padding: 0 0 88px; }
.hero-kicker { font-family: var(--mn); font-size: .68rem; letter-spacing: .24em; text-transform: uppercase; color: var(--gold); opacity: .65; margin-bottom: 22px; display: flex; align-items: center; gap: 14px; }
.hero-kicker::before { content: ''; width: 26px; height: 1px; background: var(--gold); opacity: .4; flex-shrink: 0; }
.hero-h1 { font-family: var(--dp); font-size: clamp(3.8rem, 8vw, 9rem); font-weight: 400; line-height: .92; letter-spacing: -.04em; color: var(--paper); margin-bottom: 0; }
.hero-h1 em { font-style: italic; color: var(--gold); }
.hero-rule { width: 40px; height: 1px; background: var(--gold); opacity: .35; margin: 32px 0; }
.hero-sub { font-size: 1.12rem; line-height: 1.78; color: var(--mist); max-width: 44ch; margin-bottom: 44px; font-weight: 400; }
.hero-sub b { color: var(--paper); font-weight: 400; }
.hero-nav { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.doors { border-top: 1px solid var(--gl); }
.door-row { border-bottom: 1px solid var(--gl); display: grid; grid-template-columns: 80px 1fr auto; align-items: center; gap: 0; padding: 36px 0; cursor: pointer; transition: background .25s; text-decoration: none; position: relative; }
.door-row:hover { background: rgba(255,255,255,.015); }
.door-row::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 2px; background: var(--gold); transform: scaleY(0); transform-origin: top; transition: transform .4s cubic-bezier(.16,1,.3,1); }
.door-row:hover::before { transform: scaleY(1); }
.door-num { font-family: var(--dp); font-style: italic; font-size: 1.1rem; color: var(--gold); opacity: .3; padding-left: 0; width: 72px; flex-shrink: 0; }
.door-body { padding: 0 32px 0 0; }
.door-title { font-family: var(--dp); font-size: 1.4rem; font-weight: 400; color: var(--paper); line-height: 1.15; margin-bottom: 6px; }
.door-desc { font-size: .92rem; color: var(--stone); line-height: 1.65; font-weight: 400; }
.door-arrow { font-family: var(--mn); font-size: .68rem; letter-spacing: .12em; color: var(--gold); opacity: .4; flex-shrink: 0; padding-right: 4px; transition: opacity .2s, transform .2s; }
.door-row:hover .door-arrow { opacity: .9; transform: translateX(4px); }
.statement { padding: 128px 0; background: var(--deep); }
.statement-text { font-family: var(--dp); font-style: italic; font-size: clamp(1.6rem, 2.8vw, 2.8rem); font-weight: 400; line-height: 1.28; color: var(--mist); max-width: 22ch; }
.statement-text em { font-style: normal; color: var(--paper); }
.statement-attr { margin-top: 28px; font-family: var(--mn); font-size: .66rem; letter-spacing: .16em; text-transform: uppercase; color: var(--stone); display: flex; align-items: center; gap: 12px; }
.statement-attr::before { content: ''; width: 20px; height: 1px; background: var(--gold); opacity: .3; flex-shrink: 0; }

/* ─── PAGE: ABOUT ────────────────────────────────── */
.about-portrait-col { position: sticky; top: 100px; }
.portrait-frame { position: relative; aspect-ratio: 3/4; border: 1px solid var(--gl); overflow: hidden; max-width: 100%; }
.portrait-frame img { width: 100%; height: 100%; object-fit: cover; object-position: 55% 8%; }
.portrait-caption { margin-top: 16px; }
.portrait-caption strong { display: block; font-family: var(--mn); font-size: .7rem; letter-spacing: .14em; text-transform: uppercase; color: var(--paper); font-weight: 400; margin-bottom: 3px; }
.portrait-caption span { font-family: var(--mn); font-size: .63rem; letter-spacing: .1em; text-transform: uppercase; color: var(--stone); }
.about-section { margin-bottom: 72px; padding-bottom: 72px; border-bottom: 1px solid var(--ln); }
.about-section:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.stance-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--ln); margin-top: 28px; }
.stance-cell { padding: 28px 24px; }
.stance-cell-label { font-family: var(--mn); font-size: .62rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); opacity: .38; display: block; margin-bottom: 8px; }
.testi-block { border-top: 2px solid var(--gold); padding: 44px; margin-bottom: 1px; }
.testi-text { font-family: var(--dp); font-style: italic; font-size: clamp(1.05rem, 1.6vw, 1.4rem); line-height: 1.6; margin-bottom: 20px; }
.testi-text::before { content: '"'; display: block; font-family: var(--dp); font-size: 4.5rem; line-height: .6; color: var(--gold); opacity: .16; margin-bottom: 12px; }
.testi-attr { font-family: var(--mn); font-size: .65rem; letter-spacing: .14em; text-transform: uppercase; color: var(--stone); }
.testi-attr b { display: block; color: var(--gold); opacity: .55; font-weight: 400; margin-bottom: 2px; }
.testi-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--ln); }
.testi-card { padding: 32px 28px; }
.testi-note { font-family: var(--dp); font-style: italic; font-size: .82rem; color: var(--stone); opacity: .38; margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--ln); }

/* ─── PAGE: APPROACH ─────────────────────────────── */
.cond-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--ln); }
.cond-cell-new { background: var(--deep); padding: 52px 44px; position: relative; }
.cond-cell-new.alt { background: var(--srf); }
.cond-bignum { font-family: var(--dp); font-style: italic; font-size: clamp(6rem, 10vw, 11rem); line-height: .88; color: var(--gold); opacity: .07; position: absolute; top: 24px; right: 28px; pointer-events: none; user-select: none; }
.cond-label { font-family: var(--mn); font-size: .65rem; letter-spacing: .18em; text-transform: uppercase; color: var(--gold); opacity: .5; margin-bottom: 16px; display: block; }
.cond-title { font-family: var(--dp); font-size: clamp(1.4rem, 2vw, 1.9rem); font-weight: 400; color: var(--paper); line-height: 1.18; margin-bottom: 18px; }
.cond-body { font-size: .97rem; color: var(--fog); line-height: 1.88; font-weight: 400; margin-bottom: 14px; }
.cond-facts { margin-top: 20px; display: flex; flex-direction: column; gap: 10px; }
.cond-fact { display: flex; gap: 12px; font-size: .92rem; color: var(--fog); line-height: 1.6; }
.cond-fact::before { content: '→'; color: var(--gold); opacity: .45; font-size: .78em; flex-shrink: 0; margin-top: 2px; }
.phil-block { padding: 112px 0; background: var(--void); }
.phil-layout { display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px; align-items: start; }
.phil-quote { font-family: var(--dp); font-style: italic; font-size: clamp(1.5rem, 2.5vw, 2.2rem); font-weight: 400; line-height: 1.22; color: var(--paper); margin-bottom: 20px; }
.phil-quote em { font-style: normal; color: var(--gold); }
.phil-attr { font-family: var(--mn); font-size: .65rem; letter-spacing: .14em; text-transform: uppercase; color: var(--stone); }
.phil-statement { border-left: 1px solid var(--gl); padding: 28px 32px; margin-bottom: 36px; }
.phil-stmt-text { font-family: var(--dp); font-style: italic; font-size: clamp(.97rem, 1.3vw, 1.1rem); line-height: 1.72; color: var(--mist); margin-bottom: 10px; }
.phil-stmt-sub { font-family: var(--dp); font-style: italic; font-size: .95rem; line-height: 1.72; color: var(--stone); }
.phil-body { font-size: .97rem; color: var(--fog); line-height: 1.9; font-weight: 400; margin-bottom: 14px; }
.phil-body strong { color: var(--paper); font-weight: 400; }
.lens-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--ln); margin-top: 52px; }
.lens-card { background: var(--srf); padding: 32px 26px; transition: background .3s; }
.lens-card:hover { background: var(--lft); }
.lens-n { font-family: var(--mn); font-size: .62rem; letter-spacing: .15em; color: var(--gold); opacity: .35; display: block; margin-bottom: 12px; }
.lens-title { font-family: var(--dp); font-size: 1rem; font-weight: 400; color: var(--paper); margin-bottom: 8px; line-height: 1.2; }
.lens-desc { font-size: .88rem; color: var(--fog); line-height: 1.7; font-weight: 400; }

/* ─── PAGE: OFFERS ───────────────────────────────── */
.pathway { display: grid; grid-template-columns: repeat(5, 1fr); gap: 1px; background: var(--ln); }
.pw-step { background: var(--srf); padding: 28px 22px; position: relative; transition: background .3s; }
.pw-step:hover { background: var(--lft); }
.pw-step::after { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--gold); transform: scaleX(0); transform-origin: left; transition: transform .4s cubic-bezier(.16,1,.3,1); }
.pw-step:hover::after { transform: scaleX(1); }
.pw-n { font-family: var(--mn); font-size: .6rem; letter-spacing: .15em; color: var(--gold); opacity: .35; display: block; margin-bottom: 10px; }
.pw-big { font-family: var(--dp); font-style: italic; font-size: 4rem; color: var(--paper); opacity: .06; line-height: 1; display: block; margin-bottom: 12px; }
.pw-name { font-family: var(--dp); font-size: .97rem; font-weight: 400; color: var(--paper); line-height: 1.2; margin-bottom: 6px; }
.pw-verb { font-size: .82rem; color: var(--stone); font-weight: 400; }
.offers-list { border-top: 1px solid var(--ln); }
.offer-row { border-bottom: 1px solid var(--ln); padding: 56px 0; display: grid; grid-template-columns: 56px 1fr auto; align-items: start; position: relative; transition: background .25s; }
.offer-row::before { content: ''; position: absolute; top: -1px; left: 0; right: 0; height: 1px; background: var(--gold); transform: scaleX(0); transform-origin: left; transition: transform .45s cubic-bezier(.16,1,.3,1); }
.offer-row:hover::before { transform: scaleX(1); }
.offer-row:hover { background: rgba(255,255,255,.012); }
.o-num { font-family: var(--dp); font-style: italic; font-size: 1.1rem; color: var(--gold); opacity: .28; padding-top: 6px; }
.o-body { padding: 0 48px 0 0; }
.o-tag { font-family: var(--mn); font-size: .62rem; text-transform: uppercase; letter-spacing: .16em; color: var(--gold); opacity: .48; margin-bottom: 8px; }
.o-name { font-family: var(--dp); font-size: 1.55rem; font-weight: 400; color: var(--paper); margin-bottom: 10px; line-height: 1.1; }
.o-liner { font-family: var(--dp); font-style: italic; font-size: 1rem; color: var(--mist); margin-bottom: 16px; line-height: 1.58; max-width: 58ch; }
.o-desc { font-size: .93rem; color: var(--fog); line-height: 1.82; margin-bottom: 28px; font-weight: 400; max-width: 64ch; }
.o-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; border-top: 1px solid var(--ln); padding-top: 20px; }
.o-col-h { font-family: var(--mn); font-size: .62rem; text-transform: uppercase; letter-spacing: .14em; color: var(--gold); opacity: .38; margin-bottom: 12px; }
.o-list { list-style: none; padding: 0; }
.o-list li { font-size: .9rem; color: var(--fog); line-height: 1.65; padding-left: 16px; position: relative; margin-bottom: 6px; font-weight: 400; }
.o-list li::before { content: '—'; position: absolute; left: 0; color: var(--gold); opacity: .35; font-size: .75em; top: 2px; }
.o-counter { font-family: var(--mn); font-size: .62rem; letter-spacing: .1em; text-transform: uppercase; color: var(--stone); opacity: .22; white-space: nowrap; padding-top: 8px; }
.entry-g { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--ln); margin-top: 52px; }
.entry-c { background: var(--srf); padding: 44px 32px; position: relative; }
.entry-c::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, var(--gold), rgba(196,169,106,.15), transparent); }
.entry-tag { font-family: var(--mn); font-size: .62rem; text-transform: uppercase; letter-spacing: .15em; color: var(--gold); opacity: .42; margin-bottom: 14px; }
.entry-title { font-family: var(--dp); font-size: 1.12rem; font-weight: 400; color: var(--paper); margin-bottom: 12px; line-height: 1.2; }
.entry-body { font-size: .91rem; color: var(--fog); line-height: 1.75; margin-bottom: 16px; font-weight: 400; }
.entry-list { list-style: none; padding: 0; }
.entry-list li { font-size: .87rem; color: var(--fog); padding-left: 18px; position: relative; margin-bottom: 6px; line-height: 1.6; font-weight: 400; }
.entry-list li::before { content: '→'; position: absolute; left: 0; color: var(--gold); opacity: .38; font-size: .78em; top: 2px; }
.cta-band { background: var(--srf); border: 1px solid var(--gl); border-top: 2px solid var(--gold); padding: 52px 56px; display: grid; grid-template-columns: 1fr auto; gap: 48px; align-items: center; }
.cta-band h2 { font-family: var(--dp); font-size: clamp(1.5rem, 2.2vw, 2.2rem); font-weight: 400; color: var(--paper); line-height: 1.18; margin-bottom: 10px; }
.cta-band p { font-size: .96rem; color: var(--fog); max-width: 44ch; line-height: 1.78; }
.cta-acts { display: flex; flex-direction: column; gap: 12px; align-items: flex-start; flex-shrink: 0; }

/* ─── PAGE: CONTACT ──────────────────────────────── */
.contact-hero { padding: 144px 0 0; }
.contact-split { display: grid; grid-template-columns: 1fr 1fr; gap: 96px; align-items: start; padding-bottom: 112px; }
.c-kicker { font-family: var(--mn); font-size: .67rem; letter-spacing: .22em; text-transform: uppercase; color: var(--gold); opacity: .55; margin-bottom: 18px; display: flex; align-items: center; gap: 12px; }
.c-kicker::before { content: ''; width: 22px; height: 1px; background: var(--gold); opacity: .35; }
.c-title { font-family: var(--dp); font-size: clamp(2rem, 4vw, 3.8rem); font-weight: 400; line-height: 1.05; letter-spacing: -.025em; color: var(--paper); margin-bottom: 22px; }
.c-title em { font-style: italic; color: var(--gold); }
.c-body { font-size: 1rem; color: var(--fog); line-height: 1.85; margin-bottom: 14px; font-weight: 400; }
.c-email-direct { margin-top: 28px; padding-top: 28px; border-top: 1px solid var(--ln); }
.c-email-label { font-family: var(--mn); font-size: .62rem; letter-spacing: .16em; text-transform: uppercase; color: var(--stone); opacity: .5; display: block; margin-bottom: 6px; }
.c-email-addr { font-family: var(--mn); font-size: .82rem; letter-spacing: .06em; color: var(--gold); opacity: .65; transition: opacity .2s; }
.c-email-addr:hover { opacity: 1; }
.cform { display: flex; flex-direction: column; gap: 18px; }
.cform-field { display: flex; flex-direction: column; gap: 7px; }
.cform-field label { font-family: var(--mn); font-size: .63rem; text-transform: uppercase; letter-spacing: .14em; color: var(--gold); opacity: .52; }
.cform-field input, .cform-field select, .cform-field textarea { background: var(--srf); border: 1px solid var(--ln); color: var(--mist); font-family: var(--bd); font-size: .93rem; font-weight: 400; padding: 13px 16px; outline: none; transition: border-color .25s; width: 100%; }
.cform-field input::placeholder, .cform-field textarea::placeholder { color: var(--stone); opacity: .75; }
.cform-field input:hover, .cform-field select:hover, .cform-field textarea:hover { border-color: rgba(196,169,106,.4); }
.cform-field input:focus, .cform-field select:focus, .cform-field textarea:focus { border-color: var(--gold); }
.cform-field select { cursor: pointer; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23c4a96a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; background-color: var(--srf); padding-right: 36px; }
.cform-field select option { background: var(--srf); color: var(--mist); }
.cform-field textarea { resize: vertical; min-height: 120px; }
.form-note { font-family: var(--dp); font-style: italic; font-size: .82rem; color: var(--stone); opacity: .35; margin-top: 4px; }
.form-note a { color: var(--gold); opacity: .55; }
.form-note a:hover { opacity: 1; }
#cf-confirm { display: none; font-family: var(--dp); font-style: italic; font-size: .97rem; color: var(--gold); margin-top: 10px; }

/* ─── MEDIA QUERIES ──────────────────────────────── */
@media (max-width: 1100px) {
  .pathway { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 900px) {
  .about-portrait-col { position: static; }
  .portrait-frame { max-width: 280px; aspect-ratio: 4/5; }
  .stance-grid, .testi-grid, .cond-grid { grid-template-columns: 1fr; }
  .phil-layout { grid-template-columns: 1fr; gap: 44px; }
  .offer-row { grid-template-columns: 40px 1fr; }
  .o-counter { display: none; }
  .o-cols, .entry-g { grid-template-columns: 1fr; }
  .cta-band { grid-template-columns: 1fr; padding: 40px 28px; }
  .contact-split { grid-template-columns: 1fr; gap: 52px; padding-bottom: 72px; }
}
@media (max-width: 800px) {
  nav { display: none; }
  .ham { display: flex; }
  .lang-pill { right: 60px; }
  .split { grid-template-columns: 1fr; gap: 44px; }
  .sh { width: calc(100% - 36px); }
  .sec { padding: 72px 0; }
  .hero-h1 { font-size: clamp(3rem, 11vw, 5rem); }
  .door-row { grid-template-columns: 52px 1fr 24px; }
  .page-header { padding: 132px 0 84px; }
}
@media (max-width: 600px) {
  .lens-grid { grid-template-columns: 1fr; }
  .pathway { grid-template-columns: 1fr 1fr; }
}
