/* R&M Automobile — Cookie-Consent + A11y-Shared CSS
   Standalone-File mit Fallback-Tokens, damit es auf allen Pages funktioniert,
   unabhängig davon ob v2.css mit eingebunden ist.

   Token-Fallback-Syntax: var(--name, #fallback) — Page-Token gewinnt wenn definiert.
*/

/* === A11y: Skip-Link =================================== */
.skip-link{
  position:fixed;top:-100px;left:0;
  background:var(--grn, #6fcf97);color:#0d1410;
  padding:14px 22px;
  font-family:var(--fh, 'Plus Jakarta Sans', sans-serif);
  font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  text-decoration:none;
  z-index:1000;border-radius:0 0 8px 0;
  transition:top .2s var(--ease, cubic-bezier(.22,1,.36,1));
}
.skip-link:focus{top:0;outline:2px solid #fff;outline-offset:-3px}
.skip-link-anchor{display:block;height:0;width:0;overflow:hidden}


.cookie-banner{
  position:fixed;bottom:24px;left:24px;right:24px;z-index:500;
  background:var(--c2, rgba(28,28,26,.97));
  backdrop-filter:blur(28px) saturate(150%);
  -webkit-backdrop-filter:blur(28px) saturate(150%);
  border:1px solid var(--bo2, rgba(250,250,249,.18));
  border-radius:var(--r-md, 14px);
  padding:22px 26px;
  display:flex;align-items:center;gap:22px;flex-wrap:wrap;
  transform:translateY(calc(100% + 36px));opacity:0;pointer-events:none;
  transition:transform .55s var(--ease, cubic-bezier(.22,1,.36,1)),opacity .55s var(--ease, cubic-bezier(.22,1,.36,1));
  box-shadow:0 32px 80px rgba(0,0,0,.55);
  max-width:1080px;margin:0 auto;
  color:var(--tx, #fafaf9);
  font-family:var(--fb, 'DM Sans', sans-serif);
}
.cookie-banner.show{transform:none;opacity:1;pointer-events:auto}
.cookie-banner__head{display:flex;align-items:center;gap:12px;flex-shrink:0}
.cookie-banner__head svg{width:20px;height:20px;color:var(--grn, #6fcf97);flex-shrink:0}
.cookie-banner__head strong{
  font-family:var(--fh, 'Plus Jakarta Sans', sans-serif);
  font-size:12.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--tx, #fafaf9);
}
.cookie-banner__body{flex:1 1 320px;min-width:0}
.cookie-banner__txt{
  font-size:13.5px;font-weight:400;line-height:1.6;margin:0;
  color:var(--tx2, rgba(250,250,249,.72));
}
.cookie-banner__txt a{
  color:var(--tx, #fafaf9);text-decoration:underline;
  text-decoration-color:var(--bo3, rgba(250,250,249,.32));text-underline-offset:3px;
}
.cookie-banner__btns{display:flex;gap:10px;flex-shrink:0;flex-wrap:wrap}

.cookie-btn{
  padding:12px 20px;
  font-family:var(--fh, 'Plus Jakarta Sans', sans-serif);
  font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  border-radius:999px;cursor:pointer;
  transition:all .3s var(--ease, cubic-bezier(.22,1,.36,1));
  border:1px solid var(--bo2, rgba(250,250,249,.18));
  background:transparent;
  color:var(--tx2, rgba(250,250,249,.72));
  min-height:44px;white-space:nowrap;
}
.cookie-btn:hover{
  border-color:var(--bo3, rgba(250,250,249,.32));
  color:var(--tx, #fafaf9);
}
.cookie-btn:focus-visible{outline:2px solid var(--grn, #6fcf97);outline-offset:2px}
.cookie-btn--prime{
  background:var(--grn, #6fcf97);color:#0d1410;
  border-color:var(--grn, #6fcf97);
  box-shadow:0 0 22px rgba(122,217,158,.28);
}
.cookie-btn--prime:hover{
  transform:translateY(-1px);
  box-shadow:0 0 40px rgba(122,217,158,.5);
  color:#0d1410;
}

.cookie-modal{
  position:fixed;inset:0;z-index:600;display:none;
  align-items:center;justify-content:center;padding:24px;
  background:rgba(8,8,7,.78);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  font-family:var(--fb, 'DM Sans', sans-serif);
}
.cookie-modal.show{display:flex}
.cookie-modal__panel{
  width:100%;max-width:560px;max-height:90vh;overflow-y:auto;
  background:var(--c1, #161614);
  border:1px solid var(--bo2, rgba(250,250,249,.18));
  border-radius:var(--r-lg, 20px);
  box-shadow:0 40px 80px rgba(0,0,0,.7);position:relative;
  color:var(--tx, #fafaf9);
}
.cookie-modal__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 26px 16px;border-bottom:1px solid var(--bo, rgba(250,250,249,.13));
  position:sticky;top:0;background:var(--c1, #161614);z-index:1;
}
.cookie-modal__title{
  font-family:var(--fh, 'Plus Jakarta Sans', sans-serif);
  font-size:13px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--tx, #fafaf9);margin:0;
}
.cookie-modal__close{
  width:36px;height:36px;border-radius:999px;
  border:1px solid var(--bo2, rgba(250,250,249,.18));
  background:transparent;color:var(--tx3, rgba(250,250,249,.62));
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all .3s var(--ease, cubic-bezier(.22,1,.36,1));flex-shrink:0;
}
.cookie-modal__close:hover{
  border-color:var(--bo3, rgba(250,250,249,.32));
  color:var(--tx, #fafaf9);
}
.cookie-modal__close:focus-visible{outline:2px solid var(--grn, #6fcf97);outline-offset:2px}
.cookie-modal__close svg{width:16px;height:16px}
.cookie-modal__body{padding:8px 26px}
.cookie-modal__intro{
  font-size:13.5px;font-weight:400;line-height:1.65;margin:16px 0 6px;
  color:var(--tx2, rgba(250,250,249,.72));
}
.cookie-modal__intro a{
  color:var(--tx, #fafaf9);text-decoration:underline;
  text-decoration-color:var(--bo3, rgba(250,250,249,.32));text-underline-offset:3px;
}
.cookie-cat{
  display:grid;grid-template-columns:1fr auto;gap:6px 18px;
  padding:20px 0;border-bottom:1px solid var(--bo, rgba(250,250,249,.13));
  align-items:start;
}
.cookie-cat:last-of-type{border-bottom:none}
.cookie-cat__name{
  font-family:var(--fh, 'Plus Jakarta Sans', sans-serif);
  font-size:13.5px;font-weight:700;letter-spacing:-.01em;align-self:center;
  color:var(--tx, #fafaf9);
}
.cookie-cat__desc{
  font-size:12.5px;font-weight:400;line-height:1.55;
  grid-column:1/-1;margin-top:2px;
  color:var(--tx3, rgba(250,250,249,.62));
}
.cookie-cat__static{
  font-family:var(--fh, 'Plus Jakarta Sans', sans-serif);
  font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--grn, #6fcf97);align-self:center;padding:6px 12px;
  background:rgba(122,217,158,.12);
  border:1px solid var(--grn-bd, rgba(111,207,151,.32));
  border-radius:999px;white-space:nowrap;
}
.cookie-toggle{
  position:relative;width:44px;height:24px;border-radius:999px;
  background:rgba(250,250,249,.13);
  border:1px solid var(--bo2, rgba(250,250,249,.18));
  cursor:pointer;
  transition:background .3s var(--ease, cubic-bezier(.22,1,.36,1)),border-color .3s;
  align-self:center;padding:0;flex-shrink:0;
}
.cookie-toggle::after{
  content:'';position:absolute;top:1px;left:2px;width:18px;height:18px;
  background:var(--tx3, rgba(250,250,249,.62));border-radius:50%;
  transition:transform .3s var(--ease, cubic-bezier(.22,1,.36,1)),background .3s;
}
.cookie-toggle[aria-checked="true"]{
  background:var(--grn, #6fcf97);
  border-color:var(--grn, #6fcf97);
}
.cookie-toggle[aria-checked="true"]::after{
  transform:translateX(20px);background:#0d1410;
}
.cookie-toggle:focus-visible{outline:2px solid var(--grn, #6fcf97);outline-offset:2px}
.cookie-modal__foot{
  display:flex;gap:10px;padding:20px 26px 24px;
  border-top:1px solid var(--bo, rgba(250,250,249,.13));
  flex-wrap:wrap;position:sticky;bottom:0;
  background:var(--c1, #161614);
}
.cookie-modal__foot .cookie-btn{flex:1;min-width:180px}

/* Media-Fallback für gegating'te Insta/TikTok-Videos */
.social-video-fallback{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  text-align:center;
  background:linear-gradient(180deg,rgba(15,15,14,.88) 0%,rgba(15,15,14,.94) 100%);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  color:var(--tx2, rgba(250,250,249,.72));
  font-family:var(--fh, 'Plus Jakarta Sans', sans-serif);
  font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  cursor:pointer;border:none;border-radius:inherit;padding:18px;z-index:2;
  transition:background .3s var(--ease, cubic-bezier(.22,1,.36,1)),color .3s;
}
.social-video-fallback:hover,.social-video-fallback:focus-visible{
  background:linear-gradient(180deg,rgba(15,15,14,.78) 0%,rgba(15,15,14,.88) 100%);
  color:var(--grn, #6fcf97);outline:none;
}
.social-video-fallback:focus-visible{
  box-shadow:inset 0 0 0 2px var(--grn-bd, rgba(111,207,151,.32));
}
.social-video-fallback__sub{
  display:block;margin-top:8px;font-size:9.5px;font-weight:500;letter-spacing:.18em;
  color:var(--tx3, rgba(250,250,249,.62));
}
body.consent-ext .social-video-fallback{display:none}

@media(max-width:768px){
  /* === BANNER Mobile === */
  .cookie-banner{
    left:10px;right:10px;
    bottom:calc(10px + env(safe-area-inset-bottom));
    padding:18px 18px 16px;flex-direction:column;align-items:stretch;gap:14px;
    border-radius:14px;
  }
  .cookie-banner__head{justify-content:flex-start;gap:10px}
  .cookie-banner__head svg{width:18px;height:18px}
  .cookie-banner__head strong{font-size:11px;letter-spacing:.16em}
  .cookie-banner__body{flex:none}
  .cookie-banner__txt{font-size:13px;line-height:1.55}
  /* Buttons Mobile: Prime full-width oben, decline+settings 2-col darunter */
  .cookie-banner__btns{
    display:grid;width:100%;gap:8px;
    grid-template-columns:1fr 1fr;
    grid-template-areas:
      "prime prime"
      "decline settings";
  }
  .cookie-banner__btns .cookie-btn{
    flex:none;width:auto;min-width:0;
    padding:14px 12px;font-size:10.5px;letter-spacing:.1em;
    min-height:48px;
  }
  .cookie-banner__btns .cookie-btn--prime,
  .cookie-banner__btns [data-cookie-action="accept-all"]{grid-area:prime}
  .cookie-banner__btns [data-cookie-action="decline"]{grid-area:decline}
  .cookie-banner__btns [data-cookie-action="settings"]{grid-area:settings}

  /* === MODAL Mobile === */
  .cookie-modal{padding:10px}
  .cookie-modal__panel{max-height:92vh;border-radius:14px}
  .cookie-modal__head{padding:18px 20px 14px}
  .cookie-modal__title{font-size:12px}
  .cookie-modal__body{padding:6px 20px}
  .cookie-modal__intro{font-size:13px;line-height:1.6;margin:14px 0 4px}
  .cookie-cat{padding:18px 0;gap:8px 14px}
  .cookie-cat__name{font-size:13px}
  .cookie-cat__desc{font-size:12px;line-height:1.55}
  .cookie-cat__static{font-size:9px;padding:5px 10px;letter-spacing:.14em}
  /* Modal-Foot: vertikal gestackt, Prime oben */
  .cookie-modal__foot{
    padding:16px 20px calc(16px + env(safe-area-inset-bottom));
    flex-direction:column-reverse;gap:8px;
  }
  .cookie-modal__foot .cookie-btn{
    flex:none;width:100%;min-width:0;min-height:48px;
    padding:14px 16px;font-size:10.5px;letter-spacing:.12em;
  }
}
@media(max-width:380px){
  .cookie-banner__btns{grid-template-columns:1fr;grid-template-areas:"prime" "decline" "settings"}
  .cookie-banner__btns .cookie-btn{padding:13px 12px}
}

/* === A11y Phase 2: Globaler Focus-Visible (Pre-Live Pkt 9) ===
   Klar sichtbarer Focus-Indikator auf dunklem Design fuer Keyboard-User.
   Mausklick-Focus bleibt unsichtbar (UX-Standard via :focus-visible).
   Tokens mit Fallback fuer Pages ohne v2-Tokens. */
:focus{outline:none}
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible,
summary:focus-visible{
  outline:2px solid var(--grn, #6fcf97);
  outline-offset:3px;
  border-radius:3px;
  box-shadow:0 0 0 4px rgba(111,207,151,.18);
  transition:outline-color .15s ease, box-shadow .15s ease;
}
/* Input/Select/Textarea: outline-offset enger damit Border-Box-Layout sauber bleibt */
input:focus-visible,
select:focus-visible,
textarea:focus-visible{
  outline-offset:1px;
}
/* Primary-Buttons bekommen etwas mehr Glow */
.btn-d:focus-visible,
.btn-g:focus-visible,
.bd:focus-visible,
.bg2:focus-visible,
.nav-pill:focus-visible,
.cookie-btn--prime:focus-visible{
  outline-offset:3px;
  box-shadow:0 0 0 4px rgba(111,207,151,.22);
}
/* Windows-Forced-Colors-Mode: nutzt OS-Farben */
@media (forced-colors: active){
  a:focus-visible,
  button:focus-visible,
  input:focus-visible,
  select:focus-visible,
  textarea:focus-visible,
  [tabindex]:focus-visible{
    outline:3px solid CanvasText;
    outline-offset:2px;
    box-shadow:none;
  }
}
