/* ============================================================
   labelaccounting.de — Marketing-Theme "Ledger & Liner Notes"
   Light-First "Warm Swiss". Eigener --lam-* Namespace (getrennt
   vom App-White-Label --wl-*). Self-hosted Fonts (DSGVO, kein CDN).
   ============================================================ */

/* ---------- Fonts (self-hosted woff2, /static/fonts/) ---------- */
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:500;font-display:swap;src:url('/static/fonts/spacegrotesk-500.woff2') format('woff2')}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:600;font-display:swap;src:url('/static/fonts/spacegrotesk-600.woff2') format('woff2')}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url('/static/fonts/spacegrotesk-700.woff2') format('woff2')}
/* DIN Mittelschrift (DINish/OFL) — App-weiter Display-Font, hier für Editorial-Konsistenz mit der Operator-App */
@font-face{font-family:'DINish';font-style:normal;font-weight:400;font-display:swap;src:url('/static/fonts/dinish-400.woff2') format('woff2')}
@font-face{font-family:'DINish';font-style:normal;font-weight:500;font-display:swap;src:url('/static/fonts/dinish-500.woff2') format('woff2')}
@font-face{font-family:'DINish';font-style:normal;font-weight:700;font-display:swap;src:url('/static/fonts/dinish-700.woff2') format('woff2')}
@font-face{font-family:'Space Mono';font-style:normal;font-weight:400;font-display:swap;src:url('/static/fonts/spacemono-400.woff2') format('woff2')}
@font-face{font-family:'Space Mono';font-style:normal;font-weight:700;font-display:swap;src:url('/static/fonts/spacemono-700.woff2') format('woff2')}
@font-face{font-family:'InterWeb';font-style:normal;font-weight:400;font-display:swap;src:url('/static/fonts/inter-400.woff2') format('woff2')}
@font-face{font-family:'InterWeb';font-style:normal;font-weight:500;font-display:swap;src:url('/static/fonts/inter-500.woff2') format('woff2')}
@font-face{font-family:'InterWeb';font-style:normal;font-weight:600;font-display:swap;src:url('/static/fonts/inter-600.woff2') format('woff2')}

/* ---------- Tokens ---------- */
:root{
  --lam-bg:#FBFAF7; --lam-raised:#FFFFFF; --lam-sunken:#F0EEE8;
  --lam-text:#15171A; --lam-muted:#55585E; --lam-faint:#80848B;
  --lam-border:#E4E1D9; --lam-border-strong:#D2CEC4;
  --lam-acid:#E8FF3E; --lam-acid-dim:#D9F02A;
  --lam-success:#1E8E54; --lam-warning:#9A6A00; --lam-danger:#C2381E;
  --ff-display:'DINish','Space Grotesk',system-ui,sans-serif;
  --ff-mono:'Space Mono',ui-monospace,monospace;
  --ff-body:'InterWeb',system-ui,-apple-system,sans-serif;
  --maxw:1200px;
  /* Motion (Strang B / Single-Source, spiegelt base.html) */
  --ease-standard:cubic-bezier(0.2,0,0,1); --ease-emphasized:cubic-bezier(0.3,0.7,0,1); --ease-out:cubic-bezier(0,0,0.2,1);
  --dur-fast:120ms; --dur-base:200ms; --dur-slow:300ms;
}

@media (prefers-reduced-motion: reduce){
  .lam-site *,.lam-site *::before,.lam-site *::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;scroll-behavior:auto !important}
}

/* ---------- Base ---------- */
.lam-site,.lam-site *{box-sizing:border-box}
.lam-site{background:var(--lam-bg);color:var(--lam-text);font-family:var(--ff-body);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;margin:0;display:flex;flex-direction:column;min-height:100vh}
.lam-site a{text-decoration:none}
.lam-site a:not(.btn){color:inherit}
.lam-site main{flex:1 0 auto}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;width:100%}
.eyebrow{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--lam-muted);display:inline-flex;gap:.6em;align-items:center}
.eyebrow .idx{color:var(--lam-text)}
.eyebrow.warn{color:var(--lam-warning)}
.num{font-family:var(--ff-mono);font-variant-numeric:tabular-nums}
.lam-site h1,.lam-site h2,.lam-site h3{font-family:var(--ff-display);font-weight:600;letter-spacing:-.02em;line-height:1.08;margin:0}
.lam-site h1{font-size:clamp(2.6rem,6vw,4.6rem);letter-spacing:-.03em}
.lam-site h2{font-size:clamp(1.7rem,3.2vw,2.6rem)}
.lam-site h3{font-size:1.18rem;font-weight:500;letter-spacing:-.01em}
.lead{font-size:1.15rem;color:var(--lam-muted);max-width:42ch}
.mark{background:linear-gradient(transparent 60%,var(--lam-acid) 60%);padding:0 .04em}
section{border-top:1px solid var(--lam-border)}
.pad{padding:clamp(56px,9vw,116px) 0}
.sechead{max-width:60ch;margin-bottom:48px}
.sechead h2{margin:.4em 0 .35em}

/* ---------- Buttons (CTA = near-black + acid hairline) ---------- */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--ff-display);font-weight:500;font-size:.96rem;padding:.85em 1.4em;border-radius:6px;border:1px solid var(--lam-text);transition:transform var(--dur-fast) var(--ease-standard),background var(--dur-fast) var(--ease-standard);cursor:pointer;line-height:1}
.btn-primary{background:var(--lam-text);color:var(--lam-bg);box-shadow:inset 0 -3px 0 var(--lam-acid)}
.btn-primary:hover{transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--lam-text);border-color:var(--lam-border-strong)}
.btn-ghost:hover{border-color:var(--lam-text)}
.btn .arw{font-family:var(--ff-mono)}

/* ---------- Nav ---------- */
.lam-nav{position:sticky;top:0;z-index:50;background:rgba(251,250,247,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--lam-border)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{font-family:var(--ff-display);font-weight:700;letter-spacing:-.02em;font-size:1.18rem;display:flex;align-items:center;gap:.5em}
.brand .dot{width:9px;height:9px;background:var(--lam-acid);border:1px solid var(--lam-text);display:inline-block}
.brand img{height:26px}
.nav-links{display:flex;gap:26px;align-items:center;font-size:.92rem;color:var(--lam-muted)}
.nav-links a:hover{color:var(--lam-text)}
.nav-links a.active{color:var(--lam-text)}
.nav-cta{display:flex;gap:12px;align-items:center}
.nav-cta .btn{padding:.55em 1em;font-size:.86rem}
.nav-burger{display:none;background:none;border:none;cursor:pointer;color:var(--lam-text);padding:6px}
.nav-mobile{display:none;border-top:1px solid var(--lam-border);background:var(--lam-bg)}
.nav-mobile.open{display:block}
.nav-mobile a{display:block;padding:12px 0;font-size:1rem;color:var(--lam-muted);border-bottom:1px solid var(--lam-border)}
@media(max-width:860px){.nav-links,.nav-cta .btn-ghost{display:none}.nav-burger{display:block}}

/* ---------- Footer ---------- */
.lam-footer{background:var(--lam-text);color:#c9cac2;margin-top:0}
.foot{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;padding:56px 0 36px}
.lam-footer .brand{color:var(--lam-bg)}
.foot h5{font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:#7d7e76;margin:0 0 14px}
.foot a{display:block;color:#c9cac2;font-size:.9rem;padding:4px 0}
.foot a:hover{color:var(--lam-acid)}
.foot p{font-size:.86rem;color:#9a9b92;margin-top:10px}
.foot-bot{border-top:1px solid #2b2d27;padding:18px 0;font-family:var(--ff-mono);font-size:.7rem;color:#7d7e76;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
@media(max-width:760px){.foot{grid-template-columns:1fr 1fr}}

/* ---------- Hero ---------- */
.hero{padding:clamp(48px,8vw,92px) 0 clamp(40px,6vw,72px)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{margin:.35em 0 .5em}
.hero-cta{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}
.hero-sub{font-family:var(--ff-mono);font-size:.74rem;color:var(--lam-faint);margin-top:18px;letter-spacing:.02em}
@media(max-width:860px){.hero-grid{grid-template-columns:1fr;gap:36px}}

/* ---------- Page hero (Sub-Seiten) ---------- */
.page-hero{padding:clamp(56px,8vw,96px) 0 clamp(32px,4vw,48px)}
.page-hero h1{margin:.3em 0 .4em;max-width:18ch}
.page-hero .lead{max-width:54ch}

/* ---------- Beleg-Artefakt ---------- */
.beleg{background:var(--lam-raised);border:1px solid var(--lam-border-strong);border-radius:8px;overflow:hidden;box-shadow:0 1px 0 var(--lam-border),0 24px 48px -28px rgba(20,20,18,.22)}
.beleg-bar{display:flex;align-items:center;gap:6px;padding:11px 14px;border-bottom:1px solid var(--lam-border);background:var(--lam-sunken)}
.beleg-bar i{width:9px;height:9px;border-radius:50%;background:var(--lam-border-strong);display:inline-block}
.beleg-bar .ttl{font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.08em;color:var(--lam-faint);margin-left:8px;text-transform:uppercase}
.beleg-body{padding:20px 22px}
.beleg h4{font-family:var(--ff-display);font-size:1.05rem;font-weight:600;margin:0}
.beleg .meta{font-family:var(--ff-mono);font-size:.7rem;color:var(--lam-muted);margin:2px 0 16px;letter-spacing:.03em}
.row{display:flex;justify-content:space-between;align-items:baseline;padding:9px 0;border-bottom:1px solid var(--lam-border);font-size:.9rem}
.row .lbl{color:var(--lam-muted)}
.row .val{font-family:var(--ff-mono);font-variant-numeric:tabular-nums}
.row.neg .val{color:var(--lam-danger)}
.row.tax .lbl,.row.tax .val{color:var(--lam-warning)}
.row.total{border-bottom:none;padding-top:14px;margin-top:4px;border-top:2px solid var(--lam-text)}
.row.total .lbl{color:var(--lam-text);font-weight:600;font-family:var(--ff-display)}
.row.total .val{font-size:1.25rem;font-weight:700;background:linear-gradient(transparent 62%,var(--lam-acid) 62%)}
.callout{font-family:var(--ff-mono);font-size:.66rem;color:var(--lam-muted);margin-top:14px;display:flex;gap:.5em}
.callout .ar{color:var(--lam-text)}

/* ---------- Metrik-Band ---------- */
.metrics{background:var(--lam-sunken);border-top:1px solid var(--lam-border);border-bottom:1px solid var(--lam-border)}
.metrics-in{display:grid;grid-template-columns:repeat(4,1fr)}
.metric{padding:30px 26px;border-right:1px solid var(--lam-border)}
.metric:last-child{border-right:none}
.metric .mv{font-family:var(--ff-display);font-weight:700;font-size:clamp(1.9rem,3vw,2.5rem);letter-spacing:-.02em;font-variant-numeric:tabular-nums;line-height:1}
.metric .ml{font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.05em;color:var(--lam-muted);margin-top:11px;line-height:1.55;text-transform:uppercase}
@media(max-width:860px){.metrics-in{grid-template-columns:1fr 1fr}.metric{border-bottom:1px solid var(--lam-border)}.metric:nth-child(2){border-right:none}}

/* ---------- Pillars ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--lam-border)}
.pillar{padding:32px 28px;border-right:1px solid var(--lam-border)}
.pillar:last-child{border-right:none}
.pillar .idx{font-family:var(--ff-mono);font-size:1.5rem;color:var(--lam-text)}
.pillar h3{margin:18px 0 10px}
.pillar p{color:var(--lam-muted);font-size:.95rem;margin:0}
@media(max-width:860px){.pillars{grid-template-columns:1fr}.pillar{border-right:none;border-bottom:1px solid var(--lam-border)}.pillar:last-child{border-bottom:none}}

/* ---------- Vertriebe / Dist-Grid ---------- */
.dist-grid{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--lam-border);border-bottom:none}
.dist-grid span{font-family:var(--ff-mono);font-size:.8rem;letter-spacing:.06em;padding:22px 16px;border-bottom:1px solid var(--lam-border);border-right:1px solid var(--lam-border);color:var(--lam-muted);text-align:center;display:flex;align-items:center;justify-content:center}
.dist-grid span:nth-child(4n){border-right:none}
.dist-grid span.out{font-weight:700;background:var(--lam-text);color:var(--lam-bg)}
.dist-note{font-family:var(--ff-mono);font-size:.72rem;color:var(--lam-muted);margin-top:18px;letter-spacing:.05em;text-transform:uppercase}
@media(max-width:860px){.dist-grid{grid-template-columns:1fr 1fr}.dist-grid span:nth-child(4n){border-right:1px solid var(--lam-border)}.dist-grid span:nth-child(2n){border-right:none}}

/* ---------- Ledger ---------- */
.ledger-wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:start}
.ledger{background:var(--lam-raised);border:1px solid var(--lam-border-strong);border-radius:8px;overflow:hidden}
.ledger-head{padding:14px 20px;border-bottom:1px solid var(--lam-border);background:var(--lam-sunken);font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--lam-muted);display:flex;justify-content:space-between}
.lrow{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:baseline;padding:14px 20px;border-bottom:1px solid var(--lam-border)}
.lrow .step{font-family:var(--ff-mono);font-size:.66rem;color:var(--lam-faint)}
.lrow .desc{font-size:.92rem}
.lrow .desc small{display:block;color:var(--lam-muted);font-size:.76rem}
.lrow .amt{font-family:var(--ff-mono);font-variant-numeric:tabular-nums;font-size:1rem}
.lrow.minus .amt{color:var(--lam-danger)}
.lrow.tax .step,.lrow.tax .amt{color:var(--lam-warning)}
.lrow.out{background:var(--lam-bg)}
.lrow.out .desc{font-family:var(--ff-display);font-weight:600}
.lrow.out .amt{font-size:1.4rem;font-weight:700;background:linear-gradient(transparent 60%,var(--lam-acid) 60%)}
@media(max-width:860px){.ledger-wrap{grid-template-columns:1fr;gap:28px}}

/* ---------- Precision ---------- */
.prec{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--lam-border)}
.prec > div{padding:34px 32px;border-right:1px solid var(--lam-border)}
.prec > div:last-child{border-right:none;background:var(--lam-raised)}
.prec .tag{font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--lam-faint)}
.prec .big{font-family:var(--ff-mono);font-size:clamp(1.4rem,3vw,2.1rem);margin:12px 0 6px;font-variant-numeric:tabular-nums}
.prec .strike{color:var(--lam-danger)}
.prec .good span{background:linear-gradient(transparent 62%,var(--lam-acid) 62%)}
.prec p{font-size:.86rem;color:var(--lam-muted);margin:0}
@media(max-width:560px){.prec{grid-template-columns:1fr}.prec>div{border-right:none;border-bottom:1px solid var(--lam-border)}}

/* ---------- Pricing ---------- */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--lam-border)}
.price-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.pcard{padding:30px 26px;border-right:1px solid var(--lam-border)}
.pcard:last-child{border-right:none}
.pcard.hl{background:var(--lam-text);color:var(--lam-bg)}
.pcard.hl .pp,.pcard.hl .pf{color:var(--lam-bg)}
.pcard .pn{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--lam-faint)}
.pcard.hl .pn{color:var(--lam-acid)}
.pcard .pp{font-family:var(--ff-display);font-size:2.1rem;font-weight:700;margin:14px 0 2px;font-variant-numeric:tabular-nums}
.pcard .pf{font-size:.86rem;color:var(--lam-muted);margin-bottom:16px}
.pcard ul{list-style:none;font-size:.86rem;color:var(--lam-muted);padding:0;margin:0 0 18px}
.pcard.hl ul{color:#d9dad2}
.pcard li{padding:5px 0;border-bottom:1px solid var(--lam-border)}
.pcard.hl li{border-color:#33352f}
.pcard .btn{width:100%;justify-content:center}
.pcard.hl .btn-ghost{color:var(--lam-bg);border-color:#44463f}
@media(max-width:860px){.price-grid,.price-grid.cols-4{grid-template-columns:1fr}.pcard{border-right:none;border-bottom:1px solid var(--lam-border)}}

/* ---------- Add-on band ---------- */
.addon{margin-top:22px;border:1px solid var(--lam-border);border-left:3px solid var(--lam-warning);border-radius:6px;padding:18px 22px;display:flex;align-items:center;gap:14px 18px;flex-wrap:wrap;background:var(--lam-raised)}
.addon .ax{font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--lam-warning);border:1px solid var(--lam-warning);padding:.25em .55em;border-radius:3px}
.addon strong{font-family:var(--ff-display);font-weight:600}
.addon .txt{color:var(--lam-muted);font-size:.92rem}
.addon .num{margin-left:auto;font-family:var(--ff-mono);font-weight:700;font-variant-numeric:tabular-nums;background:linear-gradient(transparent 58%,var(--lam-acid) 58%);padding:0 .2em;white-space:nowrap}
@media(max-width:600px){.addon .num{margin-left:0}}

/* ---------- Compare-Table (Preise) ---------- */
.cmp{width:100%;border-collapse:collapse;font-size:.9rem;margin-top:8px}
.cmp th,.cmp td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--lam-border)}
.cmp thead th{font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--lam-muted);font-weight:400}
.cmp td:not(:first-child),.cmp th:not(:first-child){text-align:center;font-family:var(--ff-mono);font-variant-numeric:tabular-nums}
.cmp tbody td:first-child{color:var(--lam-muted)}
.cmp .yes{color:var(--lam-success);font-weight:700}
.cmp .no{color:var(--lam-faint)}

/* ---------- Toggle (Monat/Jahr) ---------- */
.toggle{display:inline-flex;border:1px solid var(--lam-border-strong);border-radius:6px;overflow:hidden;font-family:var(--ff-mono);font-size:.8rem}
.toggle button{padding:.5em 1.1em;background:transparent;border:none;cursor:pointer;color:var(--lam-muted)}
.toggle button.on{background:var(--lam-text);color:var(--lam-bg)}
.toggle .save{color:var(--lam-warning)}

/* ---------- Origin / DESSERT ---------- */
.origin{background:var(--lam-sunken)}
.origin .wrap{display:grid;grid-template-columns:auto 1fr;gap:40px;align-items:center}
.origin .lab{font-family:var(--ff-display);font-weight:700;font-size:clamp(2.2rem,5vw,3.4rem);letter-spacing:-.03em;line-height:1}
.origin .lab small{display:block;font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.14em;color:var(--lam-faint);font-weight:400;margin-top:8px}
.origin p{font-size:1.1rem;max-width:46ch;margin:0}
@media(max-width:700px){.origin .wrap{grid-template-columns:1fr;gap:18px}}

/* ---------- Final CTA ---------- */
.final{text-align:center}
.final h2{font-size:clamp(2rem,5vw,3.4rem);max-width:18ch;margin:0 auto .3em}
.final .lead{margin:0 auto 30px;text-align:center}
.final .hero-cta{justify-content:center}

/* ---------- FAQ Accordion ---------- */
.faq-list{max-width:760px;border-top:1px solid var(--lam-border)}
.faq-item{border-bottom:1px solid var(--lam-border)}
.faq-item summary{list-style:none;cursor:pointer;padding:20px 0;display:flex;justify-content:space-between;gap:16px;font-family:var(--ff-display);font-weight:500;font-size:1.05rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary .chev{font-family:var(--ff-mono);color:var(--lam-faint);transition:transform .15s}
.faq-item[open] summary .chev{transform:rotate(45deg)}
.faq-item .ans{padding:0 0 20px;color:var(--lam-muted);max-width:64ch}

/* ---------- Formulare (Kontakt / Login) ---------- */
.lam-form{max-width:520px}
.lam-form .field{margin-bottom:18px}
.lam-form label{display:block;font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--lam-muted);margin-bottom:7px}
.lam-form input,.lam-form textarea,.lam-form select{width:100%;font-family:var(--ff-body);font-size:1rem;padding:.7em .8em;border:1px solid var(--lam-border-strong);border-radius:6px;background:var(--lam-raised);color:var(--lam-text)}
.lam-form input:focus,.lam-form textarea:focus,.lam-form select:focus{outline:none;border-color:var(--lam-text)}
.lam-form textarea{min-height:140px;resize:vertical}
.lam-form .btn{margin-top:6px}
.lam-alert{border:1px solid var(--lam-border);border-left:3px solid var(--lam-warning);border-radius:6px;padding:14px 18px;margin-bottom:22px;font-size:.92rem;background:var(--lam-raised)}
.lam-alert.ok{border-left-color:var(--lam-success)}
.lam-alert.err{border-left-color:var(--lam-danger)}

/* ---------- Legal-Content (Quill-HTML) ---------- */
.lam-legal-content{color:var(--lam-muted);line-height:1.75;font-size:1rem;max-width:760px}
.lam-legal-content h1{font-family:var(--ff-display);font-size:1.75rem;font-weight:600;color:var(--lam-text);margin:2rem 0 .75rem}
.lam-legal-content h2{font-family:var(--ff-display);font-size:1.35rem;font-weight:600;color:var(--lam-text);margin:1.75rem 0 .6rem}
.lam-legal-content h3{font-family:var(--ff-display);font-size:1.125rem;font-weight:500;color:var(--lam-text);margin:1.5rem 0 .5rem}
.lam-legal-content p{margin-bottom:.85rem}
.lam-legal-content ul{list-style:disc;padding-left:1.5rem;margin-bottom:1rem}
.lam-legal-content ol{list-style:decimal;padding-left:1.5rem;margin-bottom:1rem}
.lam-legal-content li{margin-bottom:.35rem}
.lam-legal-content strong,.lam-legal-content b{font-weight:600;color:var(--lam-text)}
.lam-legal-content a{color:var(--lam-text);text-decoration:underline;text-decoration-color:var(--lam-acid-dim);text-underline-offset:2px}
.lam-legal-content blockquote{border-left:3px solid var(--lam-border-strong);padding-left:1rem;margin:1rem 0;color:var(--lam-muted);font-style:italic}
.lam-legal-content hr{border:none;border-top:1px solid var(--lam-border);margin:1.5rem 0}

/* ---------- Utilities ---------- */
.mono-note{font-family:var(--ff-mono);font-size:.74rem;color:var(--lam-faint);letter-spacing:.03em}
.stack-list{list-style:none;padding:0;margin:0}
.stack-list li{padding:14px 0;border-bottom:1px solid var(--lam-border);display:flex;gap:14px;align-items:baseline}
.stack-list .k{font-family:var(--ff-mono);font-size:.7rem;color:var(--lam-faint);min-width:2.5em}
.prefers-reduced{}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ---------- Backward-Compat: checkout.html (noch nicht portiert) ----------
   checkout.html erbt website/base.html + nutzt diese Vars (eigene .co-*-Klassen,
   keine geteilten). Alte Werte hier wiederherstellen → checkout bleibt 1:1 wie
   vorher + voll funktional. Marketing-Seiten nutzen --lam-* (kein Konflikt). */
:root{
  --bg-primary:#FFFFFF; --bg-secondary:#F3F3F3; --bg-sidebar:#F8F8F8;
  --text-primary:#1E1E1E; --text-secondary:#6B6B6B;
  --accent:#007ACC; --accent-hover:#005F9E; --border:#E5E5E5;
}
