/* ===== LOCAL FONTS ===== */
@font-face {
  font-family: 'Fraunces';
  src: url('/assets/fonts/fraunces/fraunces-v38-latin-300.woff2') format('woff2');
  font-weight: 300; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Fraunces';
  src: url('/assets/fonts/fraunces/fraunces-v38-latin-300italic.woff2') format('woff2');
  font-weight: 300; font-style: italic; font-display: swap;
}
@font-face {
  font-family: 'Fraunces';
  src: url('/assets/fonts/fraunces/fraunces-v38-latin-regular.woff2') format('woff2');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Fraunces';
  src: url('/assets/fonts/fraunces/fraunces-v38-latin-italic.woff2') format('woff2');
  font-weight: 400; font-style: italic; font-display: swap;
}
@font-face {
  font-family: 'Fraunces';
  src: url('/assets/fonts/fraunces/fraunces-v38-latin-500.woff2') format('woff2');
  font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('/assets/fonts/inter/inter-v20-latin-regular.woff2') format('woff2');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('/assets/fonts/inter/inter-v20-latin-300.woff2') format('woff2');
  font-weight: 300; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('/assets/fonts/inter/inter-v20-latin-500.woff2') format('woff2');
  font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('/assets/fonts/inter/inter-v20-latin-600.woff2') format('woff2');
  font-weight: 600; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'JetBrains Mono';
  src: url('/assets/fonts/jetbrains-mono/jetbrains-mono-v24-latin-regular.woff2') format('woff2');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'JetBrains Mono';
  src: url('/assets/fonts/jetbrains-mono/jetbrains-mono-v24-latin-300.woff2') format('woff2');
  font-weight: 300; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'JetBrains Mono';
  src: url('/assets/fonts/jetbrains-mono/jetbrains-mono-v24-latin-500.woff2') format('woff2');
  font-weight: 500; font-style: normal; font-display: swap;
}

/* ===== EXTRACTED CSS FROM index.html ===== */
:root{
  --bg:#14120f; --bg-elev:#1b1815; --bg-panel:#221e1a;
  --fg:#f2ece1; --fg-dim:#b9b0a0; --fg-mute:#7d7466;
  --rule:#34302a; --rule-soft:#262320;
  --accent:#e6c28a; --accent-deep:#c69b5a; --hl:#d8c8a8;

  --f-display:"Fraunces", Georgia, serif;
  --f-body:"Inter", system-ui, sans-serif;
  --f-mono:"JetBrains Mono", ui-monospace, Menlo, monospace;

  --pad-section: 104px;
  --maxw: 1240px;
  --gutter: clamp(24px, 4vw, 56px);
}
html[data-palette="cool"]{
  --bg:#0e1114; --bg-elev:#141820; --bg-panel:#1a1f28;
  --fg:#eef1f5; --fg-dim:#a8b0bc; --fg-mute:#6b7382;
  --rule:#2a303a; --rule-soft:#1e222b;
  --accent:#9dc3e6; --accent-deep:#6a9dd0; --hl:#c5d9ec;
}
html[data-palette="mono"]{
  --bg:#0b0b0b; --bg-elev:#131313; --bg-panel:#1a1a1a;
  --fg:#f4f4f4; --fg-dim:#b2b2b2; --fg-mute:#777;
  --rule:#2a2a2a; --rule-soft:#1d1d1d;
  --accent:#f4f4f4; --accent-deep:#d9d9d9; --hl:#e6e6e6;
}
html[data-font="modern"]{ --f-display:"Inter", system-ui, sans-serif; }
html[data-font="editorial"]{ --f-display:"Fraunces", Georgia, serif; }
html[data-font="mono"]{ --f-display:"Fraunces", Georgia, serif; }
html[data-font="mono"] .eyebrow, html[data-font="mono"] .kicker, html[data-font="mono"] .num{ font-family:var(--f-mono); }
html[data-density="compact"]{ --pad-section:96px; }
html[data-density="airy"]{ --pad-section:148px; }

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:var(--f-body);font-weight:400;line-height:1.55;-webkit-font-smoothing:antialiased}
body{overflow-x:hidden}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}

.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.kicker{font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent)}
.num{font-family:var(--f-mono);color:var(--fg-mute);font-size:11px;letter-spacing:.18em}

h1,h2,h3{font-family:var(--f-display);font-weight:400;letter-spacing:-.02em;line-height:1.05;color:var(--fg);margin:0}
html[data-font="editorial"] h1, html[data-font="editorial"] h2, html[data-font="editorial"] h3{ font-weight:300; }
h1 em, h2 em, h3 em{ font-style:italic; color:var(--hl); font-weight:300; }
h2{font-size:clamp(30px, 3.6vw, 48px); max-width:22ch}
h3{font-size:clamp(20px, 1.9vw, 26px)}
p{margin:0}

.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 20px;border:1px solid var(--rule);font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg);background:transparent;transition:all .25s;cursor:pointer}
.btn:hover{border-color:var(--accent);color:var(--accent)}
.btn .arrow{transition:transform .25s}
.btn:hover .arrow{transform:translateX(3px)}
.btn-primary{background:var(--accent);color:#14120f;border-color:var(--accent)}
.btn-primary:hover{background:var(--hl);color:#14120f;border-color:var(--hl)}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(20,18,15,.78);backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid var(--rule-soft)}
html[data-palette="cool"] .nav{background:rgba(14,17,20,.78)}
html[data-palette="mono"] .nav{background:rgba(11,11,11,.78)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:14px var(--gutter);display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:12px;color:var(--fg)}
.brand .mark{width:30px;height:30px;border:1px solid var(--rule);display:grid;place-items:center;font-family:var(--f-display);font-size:15px;font-style:italic;color:var(--accent)}
html[data-font="modern"] .brand .mark{font-style:normal;font-weight:500;font-family:var(--f-body)}
.brand .name{font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-dim)}
.brand .name b{color:var(--fg);font-weight:500}
.nav-links{display:flex;gap:24px}
.nav-links a{font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-dim)}
.nav-links a:hover{color:var(--fg)}
.nav-cta{font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;padding:9px 13px;border:1px solid var(--rule);color:var(--fg)}
.nav-cta:hover{border-color:var(--accent);color:var(--accent)}
@media(max-width:820px){.nav-links{display:none}}

/* NAV TOGGLE (hamburger) */
.nav-toggle{display:none;flex-direction:column;justify-content:space-between;width:36px;height:36px;padding:10px 9px;background:transparent;border:1px solid var(--rule);cursor:pointer;flex-shrink:0}
.nav-toggle span{display:block;width:18px;height:1px;background:var(--fg-dim);transform-origin:center;transition:transform .25s ease,opacity .2s ease,background .2s ease}
.nav-toggle.is-open span:nth-child(1){transform:translateY(7.5px) rotate(45deg);background:var(--fg)}
.nav-toggle.is-open span:nth-child(2){opacity:0}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);background:var(--fg)}
@media(max-width:820px){.nav-toggle{display:flex}}

/* MOBILE NAV PANEL */
.nav-mobile{position:absolute;top:100%;left:0;right:0;background:var(--bg-elev);border-top:1px solid var(--rule-soft);border-bottom:1px solid var(--rule);max-height:0;overflow:hidden;transition:max-height .38s cubic-bezier(.16,1,.3,1);display:none}
@media(max-width:820px){.nav-mobile{display:block}}
.nav-mobile.is-open{max-height:440px}
.nav-mobile a{display:block;padding:16px var(--gutter);font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-dim);border-bottom:1px solid var(--rule-soft);transition:color .2s ease}
.nav-mobile a:hover{color:var(--fg)}
.nav-mobile .nav-mobile-cta{color:var(--accent);border-bottom:none;border-top:1px solid var(--rule);margin-top:4px}
.nav-mobile .nav-mobile-cta:hover{color:var(--hl)}
@media(max-width:480px){.brand .name{display:none}}

/* ---------- HERO (smaller) ---------- */
.hero{position:relative;padding:128px 0 80px;border-bottom:1px solid var(--rule-soft);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center}
@media(max-width:960px){.hero-grid{grid-template-columns:1fr;gap:40px}}
.hero .meta-row{display:flex;gap:20px;align-items:center;margin-bottom:26px;flex-wrap:wrap}
.hero .meta-row .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(230,194,138,.12)}
.hero .meta-row .loc{font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;color:var(--fg-dim);text-transform:uppercase}
.hero h1{font-size:clamp(36px,5.2vw,68px);line-height:1.02;letter-spacing:-.025em;max-width:18ch;font-weight:400}
html[data-font="editorial"] .hero h1{font-weight:300}
.hero h1 .line{display:block}
.hero .hero-hook{font-family:var(--f-display);font-size:clamp(16px,1.8vw,22px);color:var(--fg-mute);margin-top:12px;font-style:italic;font-weight:300;max-width:36ch;line-height:1.4}
.hero .hero-hook em{color:var(--fg-dim);font-style:italic}
.hero .tagline{margin-top:22px;max-width:46ch;color:var(--fg-dim);font-size:15.5px;line-height:1.65}
.hero .cta-row{margin-top:32px;display:flex;gap:12px;flex-wrap:wrap}
.hero .proof{margin-top:36px;display:flex;gap:28px;flex-wrap:wrap;font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-mute)}
.hero .proof span b{color:var(--fg);font-weight:500;display:block;font-size:22px;font-family:var(--f-display);font-weight:400;letter-spacing:-.01em;margin-bottom:4px;text-transform:none}
html[data-font="editorial"] .hero .proof span b{font-weight:300;font-style:italic}

.portrait{aspect-ratio:4/5;border:1px solid var(--rule);position:relative;background:linear-gradient(180deg,var(--bg-elev),var(--bg-panel));display:grid;place-items:center;overflow:hidden}
.portrait::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(230,194,138,.045) 0 2px,transparent 2px 14px)}
.portrait::after{content:"FOTO · PHILIPP KAPPE";position:absolute;bottom:14px;left:14px;font-family:var(--f-mono);font-size:9px;letter-spacing:.22em;color:var(--fg-mute)}
.portrait .corners{position:absolute;inset:12px;border:1px solid var(--rule-soft);pointer-events:none}
.portrait svg.wm{width:70%;height:auto;opacity:.5;position:relative;z-index:1}

/* ---------- SECTION ---------- */
section{padding:var(--pad-section) 0;border-bottom:1px solid var(--rule-soft)}
.section-head{display:grid;grid-template-columns:170px 1fr;gap:40px;align-items:start;margin-bottom:56px}
.section-head .idx{font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;color:var(--fg-mute);text-transform:uppercase;padding-top:8px;border-top:1px solid var(--rule);max-width:140px}
.section-head h2{max-width:20ch}
@media(max-width:820px){.section-head{grid-template-columns:1fr;gap:16px}}

/* ---------- ICONS (reusable) ---------- */
.icon{width:36px;height:36px;stroke:var(--accent);fill:none;stroke-width:1.25;stroke-linecap:round;stroke-linejoin:round}
.icon-lg{width:44px;height:44px}

/* ---------- PROBLEM ---------- */
.problem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.problem-grid > div{padding:30px 28px;border-left:1px solid var(--rule)}
.problem-grid > div:first-child{border-left:none}
.problem-grid .icon-wrap{margin-bottom:22px}
.problem-grid .sym{font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;color:var(--accent);text-transform:uppercase;margin-bottom:10px}
.problem-grid h3{font-size:20px;margin-bottom:10px;color:var(--fg)}
.problem-grid p{color:var(--fg-dim);font-size:14.5px;line-height:1.6}
@media(max-width:820px){.problem-grid{grid-template-columns:1fr}.problem-grid > div{border-left:none;border-top:1px solid var(--rule);padding:28px 0}.problem-grid > div:first-child{border-top:none;padding-top:0}}

.problem-quote{margin-top:56px;padding:32px 0 0;border-top:1px solid var(--rule-soft);font-family:var(--f-display);font-weight:400;font-style:italic;font-size:clamp(20px,2vw,26px);line-height:1.4;color:var(--fg);max-width:36ch}
html[data-font="editorial"] .problem-quote{font-weight:300}
.problem-quote .attr{margin-top:16px;font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;color:var(--fg-mute);text-transform:uppercase;font-style:normal}

/* ---------- TRIGGERS ---------- */
.triggers{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
@media(max-width:820px){.triggers{grid-template-columns:1fr}}
.trigger{padding:24px 22px;border-top:1px solid var(--rule);border-left:1px solid var(--rule-soft);display:flex;align-items:flex-start;gap:16px}
.trigger:nth-child(3n+1){border-left:none}
.trigger:nth-child(-n+3){border-top:1px solid var(--rule)}
.trigger .ic{flex-shrink:0;width:36px;height:36px;border:1px solid var(--rule);display:grid;place-items:center;color:var(--accent)}
.trigger .ic svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.3}
.trigger p{color:var(--fg);font-size:14.5px;line-height:1.45;font-family:var(--f-display);font-weight:400}
html[data-font="editorial"] .trigger p{font-weight:300}
.trigger .n{font-family:var(--f-mono);font-size:9px;letter-spacing:.2em;color:var(--fg-mute);display:block;margin-bottom:6px}
@media(max-width:820px){.trigger{border-left:none}.trigger:not(:first-child){border-top:1px solid var(--rule-soft)}}

/* ---------- APPROACH / SYSTEM ---------- */
.approach-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
@media(max-width:820px){.approach-grid{grid-template-columns:1fr;gap:40px}}
.approach-lead h3{margin-bottom:18px;max-width:16ch}
.approach-lead p{color:var(--fg-dim);font-size:15px;line-height:1.7;max-width:42ch}
.approach-lead p + p{margin-top:14px}
.approach-quote{margin-top:26px;max-width:30ch;color:var(--hl);font-family:var(--f-display);font-weight:400;font-style:italic;font-size:19px;line-height:1.4;padding-left:18px;border-left:2px solid var(--accent)}
html[data-font="editorial"] .approach-quote{font-weight:300}

/* 6-node system diagram */
.sys-hex{position:relative;aspect-ratio:1/1;max-width:480px;margin:0 auto;width:100%}
.sys-hex .core{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:110px;height:110px;border-radius:50%;background:var(--bg);border:1px solid var(--accent);color:var(--accent);display:grid;place-items:center;text-align:center;font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;z-index:3}
.sys-hex svg.lines{position:absolute;inset:0;width:100%;height:100%;z-index:1}
.sys-hex .node{position:absolute;width:120px;transform:translate(-50%,-50%);text-align:center;z-index:2}
.sys-hex .node .ic{width:48px;height:48px;margin:0 auto 10px;border:1px solid var(--rule);background:var(--bg);display:grid;place-items:center;color:var(--accent)}
.sys-hex .node .ic svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.25}
.sys-hex .node .t{font-family:var(--f-display);font-size:14px;color:var(--fg);line-height:1.2;font-weight:400}
html[data-font="editorial"] .sys-hex .node .t{font-weight:300}
.sys-hex .node .n{font-family:var(--f-mono);font-size:9px;letter-spacing:.2em;color:var(--fg-mute);margin-top:4px}
/* positions: top, upper-right, lower-right, bottom, lower-left, upper-left */
.sys-hex .n1{left:50%;top:8%}
.sys-hex .n2{left:88%;top:30%}
.sys-hex .n3{left:88%;top:70%}
.sys-hex .n4{left:50%;top:92%}
.sys-hex .n5{left:12%;top:70%}
.sys-hex .n6{left:12%;top:30%}
@media(max-width:560px){
  .sys-hex{max-width:320px}
  .sys-hex .node{width:94px}
  .sys-hex .node .ic{width:40px;height:40px}
  .sys-hex .node .t{font-size:12px}
  .sys-hex .core{width:84px;height:84px;font-size:9px}
}

/* ---------- SERVICES (6 levers, visual cards) ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}
@media(max-width:900px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.svc-grid{grid-template-columns:1fr}}
.svc{background:var(--bg-elev);padding:32px 28px;display:flex;flex-direction:column;gap:16px;position:relative;min-height:260px}
.svc:hover{background:var(--bg-panel)}
.svc .top{display:flex;justify-content:space-between;align-items:flex-start}
.svc .ic{width:48px;height:48px;border:1px solid var(--rule);display:grid;place-items:center;color:var(--accent)}
.svc .ic svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.25}
.svc .n{font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;color:var(--fg-mute)}
.svc h3{font-size:22px;line-height:1.15;letter-spacing:-.01em}
.svc p{color:var(--fg-dim);font-size:14px;line-height:1.6;flex:1}
.svc .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}
.svc .tag{font-family:var(--f-mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-mute);border:1px solid var(--rule);padding:4px 7px}

/* ---------- WHY FAIL (lighter, visual) ---------- */
.fail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}
@media(max-width:820px){.fail-grid{grid-template-columns:1fr}}
.fail{background:var(--bg-elev);padding:28px 26px;display:flex;flex-direction:column;gap:14px;min-height:200px}
.fail .top{display:flex;align-items:center;gap:14px}
.fail .ic{width:40px;height:40px;border:1px solid var(--rule);display:grid;place-items:center;color:var(--accent);flex-shrink:0}
.fail .ic svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.25}
.fail .n{font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;color:var(--fg-mute)}
.fail h4{font-family:var(--f-display);font-weight:400;font-size:18px;margin:0;color:var(--fg);letter-spacing:-.01em;line-height:1.2}
html[data-font="editorial"] .fail h4{font-weight:300}
.fail p{color:var(--fg-dim);font-size:13.5px;line-height:1.6}

/* ---------- COMPARISON ---------- */
.cmp{border:1px solid var(--rule);display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr 1fr;overflow:hidden}
.cmp > div{padding:16px 18px;border-top:1px solid var(--rule);border-left:1px solid var(--rule);font-size:13.5px;color:var(--fg-dim);line-height:1.45;min-height:60px;display:flex;align-items:center}
.cmp > div:nth-child(-n+5){border-top:0}
.cmp > div:nth-child(5n+1){border-left:0}
.cmp .h{font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-mute);background:var(--bg-elev);min-height:52px}
.cmp .h.pk{color:var(--accent)}
.cmp .rlabel{font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg);background:var(--bg-elev)}
.cmp .yes{color:var(--accent)}
.cmp .no{color:var(--fg-mute)}
.cmp .cell-pk{background:rgba(230,194,138,.05);color:var(--fg)}
html[data-palette="cool"] .cmp .cell-pk{background:rgba(157,195,230,.06)}
html[data-palette="mono"] .cmp .cell-pk{background:rgba(244,244,244,.05)}
@media(max-width:900px){
  .cmp { grid-template-columns: 1.4fr 1fr; overflow: hidden; }
  .cmp > div { border-left: 1px solid var(--rule); border-top: 1px solid var(--rule); }
  .cmp > div:nth-child(-n+5) { border-top: 0; }
  .cmp > div:nth-child(5n+1) { border-left: 0; }
  .cmp .h:not(.pk):not(:first-child),
  .cmp .yes:not(.cell-pk),
  .cmp .no { display: none; }
  .cmp .h:first-child::after { content: 'Kriterium'; }
}

/* ---------- PROCESS ---------- */
.process{display:flex;flex-direction:column;border-top:1px solid var(--rule);border-bottom:none;position:relative;overflow:visible}
.process::before{content:'';position:absolute;left:19px;top:52px;bottom:52px;width:1px;background:var(--rule);pointer-events:none;z-index:0}
.process .step{display:grid;grid-template-columns:40px 1fr;grid-template-rows:min-content min-content min-content min-content;column-gap:28px;padding:28px 0 32px;border-left:0;border-bottom:1px solid var(--rule-soft);position:relative;min-height:auto;align-items:start}
.process .step:last-child{border-bottom:0}
.process .step .ic{grid-column:1;grid-row:1/5;width:40px;height:40px;border:1px solid var(--rule);display:grid;place-items:center;color:var(--accent);align-self:start;position:relative;z-index:2;background:var(--bg)}
.process .step .ic svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.3}
.process .step .n{grid-column:2;grid-row:1;font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;color:var(--fg-mute)}
.process .step h4{grid-column:2;grid-row:2;font-family:var(--f-display);font-weight:400;font-size:18px;line-height:1.2;color:var(--fg);margin:10px 0 0;letter-spacing:-.01em}
html[data-font="editorial"] .process .step h4{font-weight:300}
.process .step p{grid-column:2;grid-row:3;font-size:13px;color:var(--fg-dim);line-height:1.6;margin-top:8px}
.process .step .dur{grid-column:2;grid-row:4;font-family:var(--f-mono);font-size:9px;letter-spacing:.2em;color:var(--fg-mute);text-transform:uppercase;margin-top:10px}
@media(max-width:900px){.process::before{display:none}.process .step{border-top:1px solid var(--rule-soft)}.process .step:first-child{border-top:0}}

.durations{margin-top:40px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.durations .d{border:1px solid var(--rule);padding:24px;background:var(--bg-elev);position:relative}
.durations .d.featured{border-color:var(--accent);background:rgba(230,194,138,.04)}
html[data-palette="cool"] .durations .d.featured{background:rgba(157,195,230,.05)}
html[data-palette="mono"] .durations .d.featured{background:rgba(244,244,244,.04)}
.durations .d .badge{position:absolute;top:-9px;left:20px;background:var(--accent);color:#14120f;font-family:var(--f-mono);font-size:9px;letter-spacing:.2em;padding:3px 8px;text-transform:uppercase}
.durations .d .m{font-family:var(--f-display);font-weight:400;font-size:36px;color:var(--fg);line-height:1}
html[data-font="editorial"] .durations .d .m{font-weight:300}
.durations .d .m em{color:var(--accent);font-style:italic}
.durations .d .l{font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;color:var(--fg-mute);text-transform:uppercase;margin-top:10px}
.durations .d .t{color:var(--fg-dim);font-size:13px;margin-top:12px;line-height:1.55}
@media(max-width:820px){.durations{grid-template-columns:1fr}}

/* ---------- ABOUT ---------- */
.about{display:grid;grid-template-columns:1fr 1.15fr;gap:60px;align-items:start}
@media(max-width:900px){.about{grid-template-columns:1fr;gap:40px}}
.about-img{aspect-ratio:4/5;border:1px solid var(--rule);position:relative;background:linear-gradient(180deg,var(--bg-elev),var(--bg-panel));overflow:hidden}
.about-img::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(230,194,138,.04) 0 2px,transparent 2px 14px)}
.about-img::after{content:"FOTO · PHILIPP";position:absolute;bottom:14px;left:14px;font-family:var(--f-mono);font-size:9px;letter-spacing:.22em;color:var(--fg-mute)}
.about p{color:var(--fg-dim);font-size:15.5px;line-height:1.7;max-width:50ch}
.about p + p{margin-top:14px}
.about .signature{margin-top:20px;font-family:var(--f-display);font-style:italic;font-size:22px;color:var(--hl);font-weight:400}
html[data-font="editorial"] .about .signature{font-weight:300}
.about .creds{margin-top:32px;display:grid;grid-template-columns:1fr 1fr;gap:20px 36px}
.about .creds .c{border-top:1px solid var(--rule);padding-top:12px}
.about .creds .c .k{font-family:var(--f-mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-mute)}
.about .creds .c .v{color:var(--fg);font-size:13.5px;margin-top:6px;line-height:1.45}

/* ---------- STORIES ---------- */
.stories{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.stories{grid-template-columns:1fr}}
.story{border:1px solid var(--rule);padding:28px;background:var(--bg-elev);display:flex;flex-direction:column;gap:14px;min-height:320px}
.story .tag{font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent)}
.story h4{font-family:var(--f-display);font-weight:400;font-size:22px;line-height:1.2;color:var(--fg);letter-spacing:-.01em;margin:0;max-width:20ch;font-style:italic}
html[data-font="editorial"] .story h4{font-weight:300}
.story p{color:var(--fg-dim);font-size:13.5px;line-height:1.65}
.story .outcome{margin-top:auto;padding-top:16px;border-top:1px solid var(--rule-soft);display:flex;gap:20px;flex-wrap:wrap}
.story .outcome .k{font-family:var(--f-mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-mute);display:block}
.story .outcome .v{font-family:var(--f-display);font-weight:400;font-size:17px;color:var(--hl);margin-top:2px}
html[data-font="editorial"] .story .outcome .v{font-weight:300}

/* ---------- EVIDENCE (message-only, no names) ---------- */
.evidence{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}
@media(max-width:820px){.evidence{grid-template-columns:1fr}}
.evidence .e{background:var(--bg-elev);padding:32px 28px;display:flex;flex-direction:column;gap:14px;min-height:220px}
.evidence .ic{width:44px;height:44px;border:1px solid var(--rule);display:grid;place-items:center;color:var(--accent)}
.evidence .ic svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.25}
.evidence h4{font-family:var(--f-display);font-weight:400;font-size:20px;line-height:1.2;color:var(--fg);margin:0;letter-spacing:-.01em}
html[data-font="editorial"] .evidence h4{font-weight:300}
.evidence p{color:var(--fg-dim);font-size:14px;line-height:1.6}

/* ---------- FAQ ---------- */
.faq-wrap{max-width:880px;margin:0 auto}
details.faq{border-top:1px solid var(--rule);padding:22px 0;cursor:pointer}
details.faq:last-of-type{border-bottom:1px solid var(--rule)}
details.faq summary{list-style:none;display:grid;grid-template-columns:40px 1fr 28px;gap:18px;align-items:center;font-family:var(--f-display);font-weight:400;font-size:clamp(17px,1.6vw,20px);color:var(--fg);letter-spacing:-.005em}
html[data-font="editorial"] details.faq summary{font-weight:300}
details.faq summary::-webkit-details-marker{display:none}
details.faq summary .n{font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;color:var(--fg-mute);font-weight:400}
details.faq summary .ic{width:22px;height:22px;border:1px solid var(--rule);display:grid;place-items:center;position:relative;justify-self:end}
details.faq summary .ic::before,details.faq summary .ic::after{content:"";position:absolute;background:var(--fg-dim);transition:opacity .2s,transform .3s}
details.faq summary .ic::before{width:9px;height:1px}
details.faq summary .ic::after{width:1px;height:9px}
details.faq[open] summary .ic::after{opacity:0}
details.faq .a{padding:16px 0 0 58px;color:var(--fg-dim);font-size:14.5px;line-height:1.7;max-width:58ch}

/* ---------- CTA ---------- */
.cta{padding:var(--pad-section) 0;text-align:center;border-bottom:1px solid var(--rule-soft);position:relative}
.cta::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%, rgba(230,194,138,.06), transparent 60%);pointer-events:none}
html[data-palette="cool"] .cta::before{background:radial-gradient(ellipse at 50% 0%, rgba(157,195,230,.07), transparent 60%)}
.cta h2{font-size:clamp(32px,4.4vw,58px);max-width:18ch;margin:0 auto 20px;position:relative}
.cta p{color:var(--fg-dim);max-width:46ch;margin:0 auto;font-size:15.5px;line-height:1.65;position:relative}
.cta .cta-row{margin-top:32px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative}
.cta .small{margin-top:22px;font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-mute);position:relative}

/* ---------- NEWSLETTER ---------- */
.news{padding:72px 0;border-bottom:1px solid var(--rule-soft)}
.news-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:center}
@media(max-width:820px){.news-grid{grid-template-columns:1fr;gap:24px}}
.news h3{font-size:clamp(22px,2.2vw,28px);max-width:22ch}
.news p{color:var(--fg-dim);font-size:14px;margin-top:12px;max-width:42ch;line-height:1.6}
.news form{display:grid;grid-template-columns:1fr auto;gap:8px;border:1px solid var(--rule);padding:6px;background:var(--bg-elev)}
.news input{background:transparent;border:0;outline:0;color:var(--fg);padding:12px 14px;font-family:var(--f-body);font-size:14px;width:100%}
.news input::placeholder{color:var(--fg-mute)}
.news button{cursor:pointer;background:var(--accent);color:#14120f;border:0;padding:12px 20px;font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase}
.news button:hover{background:var(--hl)}

/* ---------- BLOG ---------- */
.blog{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:820px){.blog{grid-template-columns:1fr}}
.post{display:flex;flex-direction:column;gap:12px;padding-top:18px;border-top:1px solid var(--rule)}
.post .thumb{aspect-ratio:16/10;border:1px solid var(--rule);background:linear-gradient(180deg,var(--bg-elev),var(--bg-panel));position:relative;overflow:hidden;margin-bottom:4px}
.post .thumb::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(230,194,138,.04) 0 2px,transparent 2px 14px)}
.post .thumb svg{position:absolute;inset:0;margin:auto;width:40%;height:auto;stroke:var(--accent);fill:none;stroke-width:1;opacity:.6}
.post .meta{display:flex;gap:14px;align-items:center;font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-mute)}
.post .meta .cat{color:var(--accent)}
.post h4{font-family:var(--f-display);font-weight:400;font-size:19px;line-height:1.25;color:var(--fg);margin:0;letter-spacing:-.005em;max-width:24ch}
html[data-font="editorial"] .post h4{font-weight:300}
.post h4:hover{color:var(--hl)}
.post .ex{color:var(--fg-dim);font-size:13.5px;line-height:1.6;max-width:40ch}
.post .read{font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg);margin-top:auto;padding-top:12px}

/* ---------- FOOTER ---------- */
footer{padding:64px 0 32px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr;gap:28px}}
.foot-brand .logo{font-family:var(--f-display);font-size:28px;color:var(--fg);letter-spacing:-.01em;font-weight:400}
html[data-font="editorial"] .foot-brand .logo{font-weight:300}
.foot-brand .sub{font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;color:var(--fg-mute);text-transform:uppercase;margin-top:10px}
.foot-col h5{font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;color:var(--fg-mute);text-transform:uppercase;margin:0 0 14px;font-weight:400}
.foot-col a{display:block;color:var(--fg-dim);font-size:13.5px;padding:5px 0}
.foot-col a:hover{color:var(--fg)}
.foot-bar{margin-top:56px;padding-top:20px;border-top:1px solid var(--rule-soft);display:flex;justify-content:space-between;gap:20px;font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-mute)}

/* ---------- Back to top ---------- */
#back-to-top{position:fixed;bottom:24px;right:24px;width:40px;height:40px;background:var(--bg-panel);border:1px solid var(--rule);color:var(--fg-mute);cursor:pointer;display:grid;place-items:center;z-index:99;opacity:0;transition:opacity .3s ease,color .2s ease,border-color .2s ease;pointer-events:none}
#back-to-top.visible{opacity:1;pointer-events:auto}
#back-to-top:hover{color:var(--accent);border-color:var(--accent)}

/* Legal pages */
.legal-content h2 { font-size: 18px; margin: 36px 0 12px; color: var(--fg); font-family: var(--f-display); font-weight: 400; }
.legal-content h3 { font-size: 15px; margin: 24px 0 8px; color: var(--fg); font-family: var(--f-body); font-weight: 500; }
.legal-content p { margin-bottom: 14px; }
.legal-content a { color: var(--accent); }
.legal-content strong { color: var(--fg); font-weight: 500; }
.legal-content ul { padding-left: 20px; margin-bottom: 14px; }

/* Blog listing */
.blog-list { display: grid; gap: 32px; margin-top: 40px; }
.blog-post { border-bottom: 1px solid var(--rule-soft); padding-bottom: 32px; }
.blog-meta { display: flex; gap: 16px; margin-bottom: 10px; }
.blog-cat { font-family: var(--f-mono); font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: var(--accent); }
.blog-date { font-family: var(--f-mono); font-size: 10px; letter-spacing: .2em; color: var(--fg-mute); }
.blog-title { font-size: clamp(18px, 2.5vw, 24px); margin: 0 0 10px; font-weight: 400; }
.blog-title a { color: var(--fg); text-decoration: none; }
.blog-title a:hover { color: var(--accent); }
.blog-excerpt { color: var(--fg-dim); font-size: 15px; line-height: 1.7; margin-bottom: 14px; }
.blog-read { font-family: var(--f-mono); font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: var(--fg-mute); text-decoration: none; }
.blog-read:hover { color: var(--accent); }
.legal-content ul li { margin-bottom: 6px; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; max-width: 900px; }
@media(max-width:820px) { .contact-grid { grid-template-columns: 1fr; gap: 40px; } }

/* ===== ANIMATIONS ===== */
@keyframes heroIn {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: none; }
}
.meta-row      { opacity: 0; animation: heroIn .5s ease both .10s; }
#hero-headline    { opacity: 0; animation: heroIn .6s ease both .25s; }
.hero .hero-hook  { opacity: 0; animation: heroIn .5s ease both .42s; }
#hero-tagline     { opacity: 0; animation: heroIn .5s ease both .55s; }
.hero .cta-row    { opacity: 0; animation: heroIn .5s ease both .68s; }
.hero .proof      { opacity: 0; animation: heroIn .5s ease both .80s; }
.hero aside       { opacity: 0; animation: heroIn .7s ease both .35s; }

/* Scroll reveal */
.reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .65s cubic-bezier(.16,1,.3,1), transform .65s cubic-bezier(.16,1,.3,1);
}
.reveal.is-visible { opacity: 1; transform: none; }
.reveal-d1 { transition-delay: .08s; }
.reveal-d2 { transition-delay: .16s; }
.reveal-d3 { transition-delay: .24s; }
.reveal-d4 { transition-delay: .32s; }
.reveal-d5 { transition-delay: .40s; }

@media (prefers-reduced-motion: reduce) {
  .meta-row, #hero-headline, .hero .hero-hook, #hero-tagline,
  .hero .cta-row, .hero .proof, .hero aside { animation: none; opacity: 1; }
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* Nav active section */
.nav-links a.is-active { color: var(--accent); }

/* FAQ smooth toggle */
details.faq .a {
  overflow: hidden;
  transition: height .38s cubic-bezier(.16,1,.3,1);
}

/* ===== HEX DIAGRAM ANIMATION ===== */

/* Transitions always present so they fire when class changes */
.sys-hex .core {
  transition: opacity .55s ease, transform .7s cubic-bezier(.16,1,.3,1), box-shadow .3s ease;
}
.sys-hex .node { opacity: 1; }
#sys-hex-svg line {
  stroke-dasharray: 185;
  stroke-dashoffset: 185;
  transition: stroke-dashoffset .75s cubic-bezier(.4,0,.2,1);
}
#sys-hex-svg polygon { transition: opacity .6s ease; }

/* Initial hidden state (before hex-go) */
.sys-hex:not(.hex-go) .core {
  opacity: 0;
  transform: translate(-50%,-50%) scale(.78);
}
.sys-hex:not(.hex-go) #sys-hex-svg polygon { opacity: 0; }

/* Animated state */
.sys-hex.hex-go #sys-hex-svg line { stroke-dashoffset: 0; }
.sys-hex.hex-go #sys-hex-svg g:first-child line:nth-child(1) { transition-delay: .00s; }
.sys-hex.hex-go #sys-hex-svg g:first-child line:nth-child(2) { transition-delay: .08s; }
.sys-hex.hex-go #sys-hex-svg g:first-child line:nth-child(3) { transition-delay: .16s; }
.sys-hex.hex-go #sys-hex-svg g:first-child line:nth-child(4) { transition-delay: .24s; }
.sys-hex.hex-go #sys-hex-svg g:first-child line:nth-child(5) { transition-delay: .32s; }
.sys-hex.hex-go #sys-hex-svg g:first-child line:nth-child(6) { transition-delay: .40s; }
.sys-hex.hex-go #sys-hex-svg polygon { opacity: 1; transition-delay: .58s; }

/* Core pulse after appearing */
@keyframes corePulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(230,194,138,0); }
  50%      { box-shadow: 0 0 0 10px rgba(230,194,138,.10); }
}
.sys-hex.hex-go .core { animation: corePulse 3.5s ease 1.3s infinite; }

/* Node icon subtle blink (staggered, after diagram appears) */
@keyframes nodeIconBlink {
  0%, 100% { border-color: var(--rule); }
  50%       { border-color: rgba(230,194,138,.5); box-shadow: 0 0 7px rgba(230,194,138,.14); }
}
.sys-hex.hex-go .n1 .ic { animation: nodeIconBlink 5s ease-in-out 1.4s infinite; }
.sys-hex.hex-go .n2 .ic { animation: nodeIconBlink 5s ease-in-out 2.0s infinite; }
.sys-hex.hex-go .n3 .ic { animation: nodeIconBlink 5s ease-in-out 2.6s infinite; }
.sys-hex.hex-go .n4 .ic { animation: nodeIconBlink 5s ease-in-out 3.2s infinite; }
.sys-hex.hex-go .n5 .ic { animation: nodeIconBlink 5s ease-in-out 3.8s infinite; }
.sys-hex.hex-go .n6 .ic { animation: nodeIconBlink 5s ease-in-out 4.4s infinite; }

/* Reduced motion overrides */
@media (prefers-reduced-motion: reduce) {
  #sys-hex-svg line { stroke-dasharray: none; stroke-dashoffset: 0; transition: none; }
  .sys-hex:not(.hex-go) .core { transform: translate(-50%,-50%); opacity: 1; }
  .sys-hex.hex-go .core { animation: none; }
  .sys-hex.hex-go .n1 .ic, .sys-hex.hex-go .n2 .ic, .sys-hex.hex-go .n3 .ic,
  .sys-hex.hex-go .n4 .ic, .sys-hex.hex-go .n5 .ic, .sys-hex.hex-go .n6 .ic { animation: none; }
}

/* ===== DIRECTIONAL REVEAL VARIANTS ===== */
.reveal-left {
  opacity: 0;
  transform: translateX(-28px);
  transition: opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1);
}
.reveal-left.is-visible { opacity: 1; transform: none; }

.reveal-right {
  opacity: 0;
  transform: translateX(28px);
  transition: opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1);
}
.reveal-right.is-visible { opacity: 1; transform: none; }

/* ===== PROCESS TIMELINE LINE ANIMATION ===== */
.process::after {
  content: '';
  position: absolute;
  left: 19px;
  top: 52px;
  height: 0;
  width: 1px;
  background: linear-gradient(to bottom, var(--accent), rgba(230,194,138,.15));
  opacity: .8;
  transition: height 1.8s cubic-bezier(.4,0,.2,1) .1s;
  pointer-events: none;
  z-index: 1;
}
.process.hex-go::after { height: calc(100% - 104px); }

/* ===== SERVICE CARD HOVER ACCENT LINE ===== */
.svc::before {
  content: '';
  position: absolute;
  left: 0; bottom: 0;
  width: 2px; height: 0;
  background: var(--accent);
  transition: height .4s cubic-bezier(.16,1,.3,1);
  opacity: .8;
  z-index: 1;
}
.svc:hover::before { height: 100%; }
.svc:hover .ic { border-color: var(--accent-deep); transition: border-color .2s ease; }

/* ===== SECTION HEAD BORDER DRAW ===== */
.section-head .idx {
  position: relative;
  border-top: none;
}
.section-head .idx::before {
  content: '';
  position: absolute;
  top: -1px; left: 0;
  height: 1px;
  background: var(--rule);
  width: 0;
  transition: width .55s cubic-bezier(.16,1,.3,1);
}
.section-head.is-visible .idx::before { width: 100%; }

/* ===== HEX ORBIT RING ===== */
.hex-orbit {
  transform-origin: 200px 200px;
  opacity: 0;
  transition: opacity 1s ease 1.4s;
}
.sys-hex.hex-go .hex-orbit {
  opacity: 1;
  animation: hexOrbit 40s linear 2.4s infinite;
}
@keyframes hexOrbit {
  from { transform: rotate(0deg); }
  to   { transform: rotate(60deg); }
}

/* ===== HEX LINE PULSE (after draw completes) ===== */
@keyframes hexLinePulse {
  0%, 100% { stroke: #34302a; }
  50%       { stroke: rgba(230,194,138,.38); }
}
.sys-hex.hex-pulse #sys-hex-svg g:first-child line {
  animation: hexLinePulse 7s ease infinite;
}
.sys-hex.hex-pulse #sys-hex-svg g:first-child line:nth-child(1) { animation-delay: 0s;   }
.sys-hex.hex-pulse #sys-hex-svg g:first-child line:nth-child(2) { animation-delay: 1.1s; }
.sys-hex.hex-pulse #sys-hex-svg g:first-child line:nth-child(3) { animation-delay: 2.3s; }
.sys-hex.hex-pulse #sys-hex-svg g:first-child line:nth-child(4) { animation-delay: 3.5s; }
.sys-hex.hex-pulse #sys-hex-svg g:first-child line:nth-child(5) { animation-delay: 4.7s; }
.sys-hex.hex-pulse #sys-hex-svg g:first-child line:nth-child(6) { animation-delay: 5.9s; }

/* ===== CTA SECTION AMBIENT GLOW ===== */
.cta { position: relative; overflow: hidden; }
.cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 60% at 50% -10%, var(--accent), transparent 65%);
  opacity: .045;
  animation: ctaBreath 7s ease-in-out infinite;
  pointer-events: none;
}
@keyframes ctaBreath {
  0%, 100% { opacity: .03; transform: scaleY(1); }
  50%       { opacity: .07; transform: scaleY(1.12); }
}

/* ===== SERVICE CARD: number accent on hover ===== */
.svc:hover .top .n { color: var(--accent); }
.svc .top .n { transition: color .25s ease; }

/* ===== PROBLEM GRID: icon lift on hover ===== */
.problem-grid > div .icon-wrap { transition: transform .35s cubic-bezier(.16,1,.3,1); }
.problem-grid > div:hover .icon-wrap { transform: translateY(-4px); }

/* ===== REDUCED MOTION: extra overrides ===== */
@media (prefers-reduced-motion: reduce) {
  .hex-orbit { animation: none !important; }
  .sys-hex.hex-pulse #sys-hex-svg g:first-child line { animation: none !important; }
  .cta::before { animation: none !important; }
}

/* ===== DURATION PRICE HOVER ===== */
.d { position: relative; }
.d .price {
  font-family: var(--f-mono);
  font-size: 14px;
  letter-spacing: .06em;
  color: var(--accent);
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--rule);
  opacity: 0;
  transform: translateY(6px);
  transition: opacity .25s ease, transform .25s ease;
}
.d:hover .price { opacity: 1; transform: none; }

/* ===== FOOTER SOCIAL ICONS ===== */
.foot-social { display: flex; gap: 12px; margin-top: 20px; }
.foot-social a {
  display: grid; place-items: center;
  width: 34px; height: 34px;
  border: 1px solid var(--rule);
  color: var(--fg-mute);
  transition: color .2s ease, border-color .2s ease;
}
.foot-social a:hover { color: var(--accent); border-color: var(--accent); }
.foot-social svg { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 1.5; }
