/* R&M Automobile — Design System V2
   Single source of truth for: tokens, typography, buttons, nav, footer, cookie banner, reveal */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --page:#0f0f0e;
  --c1:#161614;
  --c2:#1c1c1a;
  --c3:#222220;
  --c4:#2a2a26;
  --c5:#33332e;
  --tx:#f4eee0;
  --tx2:rgba(244,238,224,.74);
  --tx3:rgba(244,238,224,.5);
  --tx4:rgba(244,238,224,.32);
  --tx5:rgba(244,238,224,.18);
  --bo:rgba(244,238,224,.07);
  --bo2:rgba(244,238,224,.14);
  --bo3:rgba(244,238,224,.28);
  --grn:#7ad99e;
  --grn2:#9ee2b5;
  --grn-soft:rgba(122,217,158,.12);
  --grn-bd:rgba(122,217,158,.32);
  --grn-glow:rgba(122,217,158,.42);
  --gold:#d9b86d;
  --red:#f87171;
  --fh:'Plus Jakarta Sans',sans-serif;
  --fb:'DM Sans',sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
  --bounce:cubic-bezier(.175,.885,.32,1.275);
  --r-sm:8px;
  --r-md:14px;
  --r-lg:20px;
  --r-xl:32px;
  --nav-h:88px;
  --nav-h-mob:72px;
  --container:1280px;
  --pad-sec:128px;
  --pad-sec-mob:72px;
  /* KKM-Pattern Tokens (Spec 2026-05-05-index-redesign) */
  --page-deep:#0a0908;
  --tx-mute:#988f7a;
  --tx-soft:#c8c0ad;
  --tx-faint:#7a7261;
  --bord-soft:rgba(255,255,255,.06);
  --bord:#2a2a26;
}
html,body{overflow-x:hidden;max-width:100vw}
html{scroll-behavior:smooth;scroll-padding-top:108px}
body{font-family:var(--fb);background:var(--page);color:var(--tx);-webkit-font-smoothing:antialiased;line-height:1.55;font-size:16px;position:relative;isolation:isolate}

/* Site-wide background — clean dark, kein Rauschen */
/* (frühere body::before Mesh + body::after Noise entfernt — wirkten wie TV-Static) */
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%;height:auto}
button{font-family:inherit}
::selection{background:var(--grn);color:#0d1410}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;animation-iteration-count:1!important}
  .reveal,.word,.h1-w{opacity:1!important;transform:none!important}
}

/* REVEAL */
.reveal{opacity:0;transform:translateY(36px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}
.reveal.on{opacity:1;transform:none}

/* TYPOGRAPHY */
.eyebrow{font-family:var(--fh);font-size:11px;font-weight:600;letter-spacing:.32em;text-transform:uppercase;color:var(--tx3);display:inline-flex;align-items:center;gap:14px}
.eyebrow::before{content:'';display:block;width:40px;height:1px;background:linear-gradient(to right,var(--grn-bd) 0%,transparent 100%)}
.eyebrow.center{justify-content:center}
.eyebrow.center::before{background:linear-gradient(to right,transparent 0%,var(--grn-bd) 50%,transparent 100%)}
.eyebrow.green{color:var(--grn)}

h2.display{font-family:var(--fh);font-size:clamp(36px,4.4vw,64px);font-weight:800;line-height:1;letter-spacing:-.035em;color:var(--tx)}
h2.display em{font-style:italic;font-weight:700;color:var(--grn)}
h2.display .muted{color:var(--tx3)}
h2.display .grad{background:linear-gradient(135deg,var(--grn) 0%,var(--gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
h3.section-h3{font-family:var(--fh);font-size:clamp(22px,2.4vw,32px);font-weight:700;line-height:1.15;letter-spacing:-.022em;color:var(--tx)}

.lede{font-size:clamp(17px,1.4vw,22px);font-weight:300;color:var(--tx2);line-height:1.7;max-width:680px}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-family:var(--fh);font-weight:700;letter-spacing:.16em;text-transform:uppercase;border-radius:999px;cursor:pointer;white-space:nowrap;transition:all .35s var(--ease);border:none}
.btn svg{transition:transform .3s var(--ease);flex-shrink:0}
.btn:hover svg{transform:translateX(4px)}
.btn-prime{padding:18px 32px;background:var(--grn);color:#0d1410;font-size:12px;box-shadow:0 0 32px rgba(122,217,158,.3),inset 0 1px 0 rgba(255,255,255,.22)}
.btn-prime:hover{transform:translateY(-2px);box-shadow:0 0 64px rgba(122,217,158,.55),inset 0 1px 0 rgba(255,255,255,.32)}
.btn-glass{padding:17px 30px;background:rgba(244,238,224,.04);backdrop-filter:blur(14px);color:var(--tx);font-size:12px;font-weight:600;border:1px solid var(--bo2)}
.btn-glass:hover{background:rgba(244,238,224,.09);border-color:var(--bo3);transform:translateY(-2px)}
.btn-mini{padding:12px 22px;background:transparent;color:var(--tx2);font-size:11px;font-weight:600;border:1px solid var(--bo2)}
.btn-mini:hover{border-color:var(--grn-bd);color:var(--grn);background:var(--grn-soft)}
.btn-shimmer{position:relative;overflow:hidden}
.btn-shimmer::after{content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.4),transparent);transition:none}
.btn-shimmer:hover::after{left:140%;transition:left 1.1s ease}

/* NAV */
nav.topbar{position:fixed;top:0;left:0;right:0;z-index:300;padding:0 60px;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;background:rgba(15,15,14,.6);backdrop-filter:blur(28px) saturate(150%);border-bottom:1px solid var(--bo);transition:background .3s,padding .3s}
nav.topbar.scrolled{background:rgba(15,15,14,.86);box-shadow:0 8px 32px rgba(0,0,0,.4)}
.nav-logo{display:flex;align-items:center;flex-shrink:0;transition:transform .3s var(--ease)}
.nav-logo:hover{transform:scale(1.04)}
.nav-logo img{height:46px;width:auto}
.nav-links{display:flex;align-items:center;gap:38px;list-style:none}
.nav-links a{font-family:var(--fh);font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--tx3);transition:color .3s;position:relative;padding-bottom:5px}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--grn);border-radius:2px;transition:width .35s var(--ease)}
.nav-links a:hover{color:var(--tx)}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{width:100%}
.nav-links a[aria-current="page"]{color:var(--tx)}
.nav-cta{padding:13px 26px;background:var(--grn);color:#0d1410!important;font-weight:700!important;border-radius:999px;letter-spacing:.13em!important;font-size:11px!important;box-shadow:0 0 24px rgba(122,217,158,.32);transition:all .3s var(--ease)!important}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 0 40px rgba(122,217,158,.55)}
.nav-cta::after{display:none!important}
.nav-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:12px;background:none;border:none;z-index:400;border-radius:8px;transition:background .25s}
.nav-burger:hover{background:rgba(244,238,224,.05)}
.nav-burger span{display:block;width:24px;height:2px;background:var(--tx);border-radius:1px;transition:all .35s var(--ease)}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mob-menu{display:none;position:fixed;inset:0;background:rgba(15,15,14,.97);backdrop-filter:blur(24px);z-index:250;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:80px 24px}
.mob-menu.open{display:flex}
.mob-menu a{font-family:var(--fh);font-size:clamp(32px,7vw,52px);font-weight:800;letter-spacing:-.025em;color:var(--tx2);padding:10px 0;transition:color .25s,transform .25s}
.mob-menu a:hover,.mob-menu a:active{color:var(--grn);transform:translateX(6px)}
.mob-menu a em{font-style:italic;color:var(--grn);font-weight:700}
.mob-menu .mob-cta{margin-top:32px}

/* SECTIONS — KKM-style: clear container, alternating backgrounds */
section,.sec{position:relative}
.sec{padding:var(--pad-sec) 40px}
.sec>*{max-width:var(--container);margin-left:auto;margin-right:auto}
.sec-tight{padding:80px 40px}
.sec-tight>*{max-width:var(--container);margin-left:auto;margin-right:auto}
.sec-alt{background:var(--c1)}


.container{max-width:var(--container);margin:0 auto;width:100%}
.container-narrow{max-width:920px;margin:0 auto;width:100%}

/* FOOTER — KKM-style clean */
footer{background:var(--c1);padding:96px 40px 36px;border-top:1px solid var(--bo);position:relative}
footer>*{max-width:var(--container);margin-left:auto;margin-right:auto}
.ft-pre{display:grid;grid-template-columns:1.5fr 1fr;gap:64px;align-items:center;padding-bottom:48px;border-bottom:1px solid var(--bo);margin-bottom:48px;position:relative}
.ft-pre h3{font-family:var(--fh);font-size:clamp(28px,3vw,42px);font-weight:800;line-height:1.05;letter-spacing:-.025em;color:var(--tx)}
.ft-pre h3 em{font-style:italic;color:var(--grn);font-weight:700}
.ft-pre p{font-size:15px;color:var(--tx2);line-height:1.7;margin-top:16px;max-width:480px}
.ft-pre-r{display:flex;flex-direction:column;gap:10px}
.ft-inner{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:64px;padding-bottom:56px;border-bottom:1px solid var(--bo);position:relative}
.ft-brand .fl img{height:50px;width:auto;margin-bottom:24px;display:block}
.ft-brand p{font-size:14px;font-weight:400;color:var(--tx3);line-height:1.85;margin-bottom:28px;max-width:300px}
.ft-social{display:flex;gap:10px}
.fsoc{width:44px;height:44px;border:1px solid var(--bo2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--tx3);transition:all .35s var(--ease)}
.fsoc:hover{border-color:var(--grn-bd);color:var(--grn);background:var(--grn-soft);transform:translateY(-3px)}
.ft-col h4,.ft-col .ft-head{font-family:var(--fh);font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--tx4);margin-bottom:24px;display:block}
.ft-col ul{list-style:none;display:flex;flex-direction:column;gap:14px}
.ft-col a{font-size:14px;font-weight:400;color:var(--tx3);transition:color .3s,padding-left .3s}
.ft-col a:hover{color:var(--grn);padding-left:4px}
.fci{display:flex;flex-direction:column;gap:3px}
.fci-l{font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--tx4)}
.fci-v{font-size:14px;font-weight:400;color:var(--tx3);transition:color .3s;line-height:1.5}
a.fci-v:hover{color:var(--grn)}
.ft-bot{display:flex;justify-content:space-between;align-items:center;padding-top:32px;flex-wrap:wrap;gap:14px;position:relative}
.ft-copy{font-size:12px;font-weight:400;color:var(--tx4)}
.ft-legal{display:flex;gap:24px}
.ft-legal a{font-size:12px;font-weight:400;color:var(--tx4);transition:color .3s}
.ft-legal a:hover{color:var(--grn)}

/* COOKIE BANNER */
.cookie-banner{position:fixed;bottom:24px;left:24px;right:24px;z-index:500;background:rgba(28,28,26,.96);backdrop-filter:blur(28px) saturate(150%);border:1px solid var(--bo2);border-radius:var(--r-md);padding:22px 26px;display:flex;align-items:center;justify-content:space-between;gap:22px;flex-wrap:wrap;transform:translateY(calc(100% + 36px));transition:transform .55s var(--ease);box-shadow:0 32px 80px rgba(0,0,0,.55);max-width:1080px;margin:0 auto}
.cookie-banner.show{transform:none}
.cookie-txt{font-size:13px;font-weight:400;color:var(--tx2);line-height:1.6;max-width:680px}
.cookie-txt a{color:var(--tx);text-decoration:underline;text-decoration-color:var(--bo3);text-underline-offset:3px}
.cookie-btns{display:flex;gap:12px;flex-shrink:0}
.cookie-accept{padding:12px 24px;background:var(--grn);color:#0d1410;font-family:var(--fh);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;border:none;border-radius:999px;cursor:pointer;transition:all .3s var(--ease);box-shadow:0 0 22px rgba(122,217,158,.28)}
.cookie-accept:hover{transform:translateY(-1px);box-shadow:0 0 40px rgba(122,217,158,.5)}
.cookie-decline{padding:12px 22px;background:transparent;color:var(--tx3);font-family:var(--fh);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;border:1px solid var(--bo2);border-radius:999px;cursor:pointer;transition:all .3s var(--ease)}
.cookie-decline:hover{border-color:var(--bo3);color:var(--tx)}

/* MOBILE NAV / FOOTER */
@media(max-width:1180px){
  nav.topbar{padding:0 32px}
  .nav-links{gap:30px}
}
@media(max-width:1100px){
  footer{padding:96px 32px 40px}
  .ft-inner{grid-template-columns:1fr 1fr;gap:48px}
  .ft-pre{grid-template-columns:1fr;gap:36px}
  .sec{padding:var(--pad-sec-mob) 32px}
}
@media(max-width:1180px){
  /* Burger früher rein damit Kontakt-Button nicht zerquetscht wird */
  nav.topbar{padding:0 24px;height:var(--nav-h-mob)}
  .nav-logo img{height:42px}
  .nav-links{display:none}
  .nav-burger{display:flex}
  .nav-cta{display:none}
}
@media(max-width:768px){
  nav.topbar{padding:0 20px}
  .nav-logo img{height:38px}
  .sec,.sec-tight{padding:64px 20px}
  footer{padding:64px 20px 32px}
  .ft-inner{grid-template-columns:1fr 1fr;gap:32px;padding-bottom:40px}
  .cookie-banner{left:12px;right:12px;bottom:12px;padding:18px 20px;flex-direction:column;align-items:flex-start;gap:14px}
  .cookie-btns{width:100%}
  .cookie-accept,.cookie-decline{flex:1}
}
@media(max-width:480px){
  .ft-inner{grid-template-columns:1fr}
}

/* === KKM-PATTERN — neue Index-Sektionen (Spec 2026-05-05) === */

/* Section-Wrapper auf Pure-Dark + Sternen-BG */
.kkm-sec{
  background-color:var(--page-deep);
  background-image:
    radial-gradient(35% 25% at 80% 30%,rgba(122,217,158,.05) 0%,transparent 70%),
    radial-gradient(circle at 12% 20%,rgba(255,255,255,.5) 1px,transparent 2px),
    radial-gradient(circle at 28% 75%,rgba(255,255,255,.4) 1px,transparent 2px),
    radial-gradient(circle at 50% 40%,rgba(255,255,255,.3) 1px,transparent 2px),
    radial-gradient(circle at 70% 80%,rgba(255,255,255,.4) 1px,transparent 2px),
    radial-gradient(circle at 88% 18%,rgba(255,255,255,.5) 1px,transparent 2px),
    radial-gradient(circle at 8% 60%,rgba(255,255,255,.35) 1px,transparent 2px);
  position:relative;
  padding:var(--pad-sec) 56px;
  color:var(--tx);
}
.kkm-sec>*{max-width:1180px;margin-left:auto;margin-right:auto}
.kkm-sec.deep{background-color:#0c0a08}
@media(max-width:880px){.kkm-sec{padding:80px 24px}}

/* Section-Head (zentriert, Eyebrow-Pill + Two-Tone H2 + Lead) */
.kkm-head{text-align:center;max-width:780px;margin:0 auto 56px}
.kkm-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--fh);font-size:11px;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--grn);
  background:var(--grn-soft);
  border:1px solid var(--grn-bd);
  padding:6px 14px;border-radius:999px;
  margin-bottom:18px;
}
.kkm-h2{
  font-family:var(--fh);
  font-size:clamp(32px,4.4vw,52px);
  line-height:1.06;font-weight:800;letter-spacing:-.025em;
  color:var(--tx);text-wrap:balance;margin:0 0 18px;
}
.kkm-h2 .accent{color:var(--grn)}
.kkm-lead{
  font-family:var(--fb);
  font-size:16px;line-height:1.55;
  color:var(--tx-mute);
  max-width:520px;margin:0 auto;
}

/* Pill-CTAs */
.pill-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--grn);color:var(--page-deep);
  font-family:var(--fh);font-weight:700;font-size:14px;
  padding:14px 28px;border-radius:999px;
  border:none;cursor:pointer;text-decoration:none;
  box-shadow:0 0 30px rgba(122,217,158,.18);
  transition:transform .3s var(--ease),box-shadow .3s;
}
.pill-cta:hover{transform:translateY(-2px);box-shadow:0 0 50px rgba(122,217,158,.35)}
.pill-ghost{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--tx);
  font-family:var(--fh);font-weight:600;font-size:14px;
  padding:14px 28px;border-radius:999px;
  border:1px solid var(--bord);text-decoration:none;
  transition:border-color .3s,background .3s;
}
.pill-ghost:hover{border-color:var(--grn-bd);background:var(--grn-soft)}

/* Service-Pill (Pill-Row im Hero) */
.svc-pill{
  font-family:var(--fh);font-size:11px;font-weight:600;
  letter-spacing:.05em;text-transform:uppercase;
  color:var(--tx-mute);
  border:1px solid var(--bord);border-radius:999px;
  padding:6px 14px;
}
.svc-pill.lead{
  background:var(--grn-soft);
  border-color:rgba(122,217,158,.25);
  color:var(--grn);
}

/* Section-CTA-Wrap */
.sec-cta{display:flex;justify-content:center;margin-top:48px;gap:14px;flex-wrap:wrap}

