/* ==========================================================================
   DAS FOLIENWERK · consolidated stylesheet
   Tokens, base, layout, nav, page-transition, sections, components, utilities.
   ========================================================================== */

:root{
  --bg:#f4f3f0;
  --surface:#ffffff;
  --surface-2:#f5f4f1;
  --surface-3:#ebeae6;
  --hairline:#e7e6e3;
  --hairline-2:#d9d8d3;
  --text:#0a0a0a;
  --text-dim:#6b6b6b;
  --text-mute:#9a9a9a;
  --red:#D7263D;
  --red-soft:rgba(215,38,61,0.08);
  --display:'Geist', system-ui, -apple-system, sans-serif;
  --ui:'Geist', system-ui, -apple-system, sans-serif;
  --mono:'Geist Mono', ui-monospace, monospace;
}

*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; background:var(--bg); color:var(--text); font-family:var(--ui); -webkit-font-smoothing:antialiased; }
html{ scroll-behavior:smooth; scroll-padding-top:90px; }
body{ overflow-x:hidden; }
body.nav-locked{ overflow:hidden; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background:var(--text); color:#fff; }
img{ max-width:100%; height:auto; }

.container{ width:100%; max-width:1280px; margin:0 auto; padding:0 24px; }
@media (max-width:720px){ .container{ padding:0 16px; } }

/* ---------- TYPOGRAPHY ---------- */
.eyebrow{ font-family:var(--mono); font-size:11px; letter-spacing:0.04em; text-transform:uppercase; color:var(--text-dim); display:inline-flex; align-items:center; gap:10px; }
.eyebrow .dot{ width:6px; height:6px; border-radius:50%; background:var(--red); display:inline-block; }
h1,h2,h3,h4{ font-family:var(--display); font-weight:600; letter-spacing:-0.025em; margin:0; line-height:1.05; color:var(--text); }
h1{ font-size:clamp(40px, 6vw, 76px); letter-spacing:-0.035em; }
h2{ font-size:clamp(32px, 4.2vw, 54px); letter-spacing:-0.03em; }
h3{ font-size:clamp(20px, 1.8vw, 26px); letter-spacing:-0.02em; }
p{ line-height:1.55; color:var(--text-dim); margin:0; }
.serif-italic{ font-family:inherit; font-style:normal; font-weight:400; color:var(--text-dim); }

/* ---------- BUTTONS ---------- */
.btn{ display:inline-flex; align-items:center; gap:8px; padding:12px 20px; border-radius:999px; font-weight:500; font-size:14px; border:1px solid transparent; transition:transform .25s cubic-bezier(.2,.8,.2,1), background-color .2s, border-color .2s, color .2s, box-shadow .25s; white-space:nowrap; line-height:1; }
.btn:hover{ transform:translateY(-2px); }
.btn-dark{ background:var(--text); color:#fff; }
.btn-dark:hover{ background:#222; box-shadow:0 12px 24px -12px rgba(10,10,10,0.4); }
.btn-ghost{ background:transparent; color:var(--text); border-color:var(--hairline-2); }
.btn-ghost:hover{ border-color:var(--text); background:#fff; }
.btn-white{ background:#fff; color:var(--text); border:1px solid var(--hairline); }
.btn-white:hover{ background:#fafaf8; }

/* ---------- SECTIONS ---------- */
section{ position:relative; }
.section{ padding:96px 0; }
@media (max-width:720px){ .section{ padding:64px 0; } }
.section-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:40px; margin-bottom:40px; flex-wrap:wrap; }
.section-head .lead{ max-width:520px; color:var(--text-dim); }

.panel{ background:var(--surface); border:1px solid var(--hairline); border-radius:24px; }
.panel-soft{ background:var(--surface-2); border:1px solid var(--hairline); border-radius:20px; }

/* striped fallback for broken images */
.stripes-soft{
  background-color:#f0efeb;
  background-image:repeating-linear-gradient(135deg, #ebeae6 0 16px, #f0efeb 16px 32px);
  border:1px solid var(--hairline);
}

/* card lift */
.card-lift{ transition:transform .35s cubic-bezier(.2,.8,.2,1), border-color .25s, box-shadow .35s, background .25s; }
.card-lift:hover{ transform:translateY(-4px); box-shadow:0 18px 40px -18px rgba(0,0,0,0.18); }

/* form fields */
.field{ display:flex; flex-direction:column; gap:8px; }
.field label{ font-family:var(--mono); font-size:10px; letter-spacing:0.06em; text-transform:uppercase; color:var(--text-mute); }
.input,.textarea,.select{ width:100%; background:#fff; border:1px solid var(--hairline); color:var(--text); padding:13px 16px; border-radius:10px; font-family:var(--ui); font-size:14px; outline:none; transition:border-color .15s, box-shadow .15s; }
.input:focus,.textarea:focus,.select:focus{ border-color:var(--text); }
.textarea{ resize:vertical; min-height:120px; }

.hide-scrollbar{ scrollbar-width:none; }
.hide-scrollbar::-webkit-scrollbar{ display:none; }
.hr-soft{ height:1px; background:var(--hairline); border:none; margin:0; }

/* ---------- TOP NAV ---------- */
.full-nav{
  position:sticky; top:0; z-index:50; padding:14px 0 0;
  background:rgba(244,243,240,0.92);
  backdrop-filter:blur(14px) saturate(140%); -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid var(--hairline);
}
.full-nav .row{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.brand{ display:inline-flex; align-items:center; text-decoration:none; }
.brand-logo{ height:42px; width:auto; display:block; }
@media (max-width:720px){ .brand-logo{ height:34px; } }

.nav-pill{
  display:flex; gap:4px; padding:5px; background:#fff;
  border:1px solid var(--hairline); border-radius:999px;
  box-shadow:0 1px 0 rgba(0,0,0,0.02); position:relative;
}
.nav-pill > a, .nav-pill .dd-trigger{
  padding:8px 14px; border-radius:999px; font-size:13px; color:var(--text-dim);
  background:transparent; font-weight:500; transition:color .15s, background .15s;
  display:inline-flex; align-items:center; gap:6px; text-decoration:none; position:relative;
}
.nav-pill > a:hover, .nav-pill .dd-trigger:hover{ color:var(--text); }
.nav-pill > a.active{ background:var(--text); color:#fff; }
.nav-pill > a.active:hover{ color:#fff; }
.nav-pill .dd-wrap{ position:relative; }
.nav-pill .dd-trigger svg{ transition:transform .2s; }
.nav-pill .dd-wrap.open .dd-trigger svg{ transform:rotate(180deg); }

/* nav-pill underline on hover (non-active links) */
.nav-pill > a:not(.active)::after, .nav-pill .dd-trigger:not(.active)::after{
  content:""; position:absolute; left:14px; right:14px; bottom:4px;
  height:1.5px; background:currentColor;
  transform:scaleX(0); transform-origin:center;
  transition:transform .25s cubic-bezier(.2,.8,.2,1);
}
.nav-pill > a:hover:not(.active)::after, .nav-pill .dd-trigger:hover:not(.active)::after{ transform:scaleX(0.5); }

/* dropdown panel */
.nav-dropdown{
  display:none;
  position:absolute; left:50%; top:calc(100% + 12px);
  width:min(720px, 92vw); padding:10px;
  background:#fff; border:1px solid var(--hairline); border-radius:20px;
  box-shadow:0 24px 60px -20px rgba(0,0,0,0.18); z-index:60;
  transform:translateX(-50%);
}
.nav-pill .dd-wrap.open .nav-dropdown{ display:block; }
.dd-grid{ display:grid; grid-template-columns:1fr 1fr; gap:6px; }
.dd-grid > a{
  display:flex; align-items:center; gap:14px; padding:14px; border-radius:14px;
  color:var(--text); transition:background .15s; text-decoration:none;
}
.dd-grid > a:hover{ background:var(--surface-2); }
.dd-grid > a > svg:last-child{ transition:transform .25s cubic-bezier(.2,.8,.2,1); }
.dd-grid > a:hover > svg:last-child{ transform:translateX(4px); }
.dd-code{ font-family:var(--mono); font-size:11px; color:var(--text-mute); min-width:24px; }
.dd-body{ flex:1; display:flex; flex-direction:column; }
.dd-name{ font-size:14px; font-weight:500; color:var(--text); }
.dd-desc{ font-size:11.5px; color:var(--text-mute); margin-top:2px; font-family:var(--mono); letter-spacing:0.02em; }
.dd-foot{ border-top:1px solid var(--hairline); margin-top:8px; padding:10px 14px; display:flex; justify-content:space-between; align-items:center; }
.dd-foot-lbl{ font-family:var(--mono); font-size:10.5px; color:var(--text-mute); letter-spacing:0.06em; text-transform:uppercase; }

.nav-right{ display:flex; align-items:center; gap:10px; }
.nav-burger{
  display:none; width:40px; height:40px; border-radius:50%;
  background:var(--text); border:none; color:#fff;
  place-items:center; cursor:pointer; padding:0;
}

/* breadcrumb strip */
.crumbs-row{
  display:flex; align-items:center; gap:8px; padding:10px 24px 12px; margin-top:12px;
  border-top:1px solid var(--hairline);
  font-family:var(--mono); font-size:11px; color:var(--text-mute);
  letter-spacing:0.04em; overflow-x:auto; white-space:nowrap;
}
.crumbs-row a{ color:var(--text-dim); }
.crumbs-row a:hover{ color:var(--text); }
.crumbs-row .sep{ opacity:.5; }
.crumbs-row [aria-current]{ color:var(--text); }
@media (max-width:720px){ .crumbs-row{ padding:10px 16px 12px; } }

/* mobile overlay */
.nav-mobile{
  position:fixed; top:74px; left:0; right:0; bottom:0; z-index:55;
  background:rgba(244,243,240,0.98); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  overflow-y:auto; padding:24px 0 60px;
  display:none;
}
.nav-mobile.open{ display:block; }
.nav-mobile .m-lbl{ font-family:var(--mono); font-size:10.5px; color:var(--text-mute); letter-spacing:0.08em; text-transform:uppercase; margin-bottom:14px; }
.nav-mobile .m-services{ display:flex; flex-direction:column; gap:8px; }
.nav-mobile .m-services > a{ display:flex; align-items:center; gap:14px; padding:16px 18px; border-radius:16px; background:#fff; border:1px solid var(--hairline); color:var(--text); text-decoration:none; }
.nav-mobile .m-services .dd-name{ font-size:15px; }
.nav-mobile .m-nav-grid{ display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.nav-mobile .m-nav-grid > a{ padding:14px 16px; border-radius:14px; background:#fff; border:1px solid var(--hairline); font-size:14px; font-weight:500; color:var(--text); text-decoration:none; display:flex; justify-content:space-between; align-items:center; }
.nav-mobile .m-wa{
  margin-top:20px; display:flex; align-items:center; justify-content:center; gap:10px;
  padding:14px 18px; border-radius:999px; background:#25D366; color:#fff;
  font-weight:500; font-size:14px; text-decoration:none;
}

@media (max-width:1080px){
  .nav-pill, .nav-kontakt{ display:none !important; }
  .nav-burger{ display:grid !important; }
}
@media (max-width:560px){
  .dd-grid{ grid-template-columns:1fr; }
  .nav-mobile .m-nav-grid{ grid-template-columns:1fr; }
}

/* ---------- PAGE TRANSITION (preloader) ---------- */
.page-transition{
  position:fixed; inset:0; z-index:9999;
  background:#f4f3f0;
  display:flex; align-items:center; justify-content:center; flex-direction:column; gap:26px;
  opacity:1; visibility:visible;
}
.page-transition.hidden{ animation:pt-hide .55s cubic-bezier(.4,0,.2,1) forwards; }
.page-transition.leaving{ animation:pt-show .35s cubic-bezier(.4,0,.2,1) forwards; pointer-events:auto; }
@keyframes pt-hide{ to{ opacity:0; visibility:hidden; transform:translateY(-12px); } }
@keyframes pt-show{ from{ opacity:0; } to{ opacity:1; } }

.pt-logo{ height:56px; animation:pt-logo-in .9s cubic-bezier(.2,.7,.2,1) both; }
.pt-logo img{ height:100%; width:auto; display:block; }
@keyframes pt-logo-in{
  from{ opacity:0; transform:translateY(12px) scale(0.97); filter:blur(4px); }
  to  { opacity:1; transform:translateY(0)   scale(1);    filter:blur(0); }
}
.pt-line{ height:1.5px; background:var(--red); width:0; animation:pt-line-draw 1.1s cubic-bezier(.4,0,.2,1) .35s both; }
@keyframes pt-line-draw{ from{ width:0; opacity:0; } to{ width:200px; opacity:1; } }
.pt-eyebrow{
  font-family:var(--mono); font-size:10.5px; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--text-mute); opacity:0; animation:pt-fade-in .6s ease-out .85s both;
}
@keyframes pt-fade-in{ to{ opacity:1; } }

/* ---------- REVEAL (blur-in) ---------- */
.reveal{ opacity:0; transform:translateY(22px); filter:blur(10px); will-change:opacity, transform, filter; }
.reveal.in{ animation:reveal-in .9s cubic-bezier(.2,.7,.2,1) forwards; }
@keyframes reveal-in{ to{ opacity:1; transform:translateY(0); filter:blur(0); } }
.reveal-word{ display:inline-block; opacity:0; transform:translateY(0.4em); filter:blur(8px); }
.reveal-word.in{ animation:reveal-word-in .8s cubic-bezier(.2,.7,.2,1) forwards; }
@keyframes reveal-word-in{ to{ opacity:1; transform:translateY(0); filter:blur(0); } }

/* hero entrance scale */
.hero-entry{ animation:hero-enter 1.2s cubic-bezier(.2,.7,.2,1) both; }
@keyframes hero-enter{ from{ opacity:0; transform:scale(0.96); filter:blur(6px); } to{ opacity:1; transform:scale(1); filter:blur(0); } }

/* pulse */
@keyframes pulse{ 0%,100%{ opacity:1; transform:scale(1); } 50%{ opacity:.4; transform:scale(1.5); } }
.pulse{ animation:pulse 2s ease-in-out infinite; }

/* marquee */
@keyframes marquee{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
.marquee{ display:flex; gap:80px; width:max-content; animation:marquee 50s linear infinite; align-items:center; }

/* Brand logo cells inside the marquee — self-hosted SVG/PNG/JPG with text fallback */
.brand-logo-cell{
  height:64px; min-width:160px;
  display:inline-flex; align-items:center; justify-content:center;
  position:relative;
}
.brand-logo-img{
  max-height:48px; max-width:180px; object-fit:contain; display:block;
  filter:grayscale(100%) opacity(0.55) brightness(1.05);
  transition:filter .35s ease, transform .35s ease;
}
.brand-logo-cell:hover .brand-logo-img{ filter:grayscale(0%) opacity(1) brightness(1); transform:scale(1.04); }
.brand-logo-text{
  display:none;
  font-family:var(--display); font-weight:600; font-size:22px;
  color:#bcbab4; letter-spacing:-0.02em; white-space:nowrap;
  transition:color .3s ease;
}
.brand-logo-cell.no-logo .brand-logo-text{ display:inline-block; }
.brand-logo-cell.no-logo:hover .brand-logo-text{ color:#0a0a0a; }

/* ---------- SUB-PAGE LAYOUT (Service detail pages) ---------- */
.sub-hero{ padding:64px 0 48px; }
.sub-hero h1{ max-width:920px; margin-top:14px; font-size:clamp(36px, 5.4vw, 64px); }
.sub-hero .lead{ max-width:680px; margin-top:24px; font-size:17px; color:var(--text-dim); line-height:1.65; }
.sub-hero .ctas{ margin-top:32px; display:flex; gap:10px; flex-wrap:wrap; }

.content-grid{ display:grid; grid-template-columns:1fr 1.2fr; gap:64px; align-items:start; }
@media (max-width:880px){ .content-grid{ grid-template-columns:1fr; gap:24px; } }

.features{ display:grid; grid-template-columns:repeat(2,1fr); gap:12px; margin-top:24px; }
.feature{ background:var(--surface-2); border:1px solid var(--hairline); border-radius:18px; padding:20px; }
.feature .lbl{ font-family:var(--mono); font-size:10px; color:var(--text-mute); letter-spacing:0.08em; text-transform:uppercase; }
.feature .val{ margin-top:8px; font-family:var(--display); font-size:22px; font-weight:600; letter-spacing:-0.02em; }
.feature .sub{ margin-top:4px; font-size:12.5px; color:var(--text-dim); line-height:1.5; }
@media (max-width:560px){ .features{ grid-template-columns:1fr; } }

.chips{ display:flex; gap:8px; flex-wrap:wrap; margin-top:18px; }
.chip{ font-family:var(--mono); font-size:11px; padding:6px 12px; border-radius:999px; background:#fff; border:1px solid var(--hairline); color:var(--text-dim); letter-spacing:0.04em; }

.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.step{ background:var(--surface-2); border:1px solid var(--hairline); border-radius:18px; padding:22px; }
.step .n{ font-family:var(--mono); font-size:11px; color:var(--text-mute); letter-spacing:0.08em; }
.step h3{ margin-top:14px; font-size:17px; font-weight:600; }
.step p{ margin-top:8px; font-size:13.5px; }
@media (max-width:880px){ .steps{ grid-template-columns:1fr 1fr; } }
@media (max-width:540px){ .steps{ grid-template-columns:1fr; } }

.dark-strip{ background:var(--text); color:#fff; padding:72px 0; }
.dark-strip h2{ color:#fff; }
.dark-strip p{ color:rgba(255,255,255,0.7); margin-top:14px; max-width:520px; }
.dark-strip .btn-white{ background:#fff; color:var(--text); border-color:transparent; }
.dark-strip .btn-ghost-dark{ background:transparent; color:#fff; border:1px solid rgba(255,255,255,0.2); padding:12px 20px; border-radius:999px; font-weight:500; font-size:14px; }

.faq{ border-top:1px solid var(--hairline); }
.faq details{ border-bottom:1px solid var(--hairline); padding:20px 0; }
.faq summary{ cursor:pointer; list-style:none; display:flex; justify-content:space-between; gap:24px; align-items:center; font-size:17px; font-weight:500; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; font-family:var(--mono); font-size:22px; color:var(--text-mute); transition:transform .2s; }
.faq details[open] summary::after{ content:"–"; }
.faq details p{ margin-top:14px; max-width:740px; font-size:14.5px; }

.related{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:24px; }
.related a{ background:var(--surface-2); border:1px solid var(--hairline); border-radius:18px; padding:22px; transition:transform .25s, border-color .25s, box-shadow .25s; display:block; }
.related a:hover{ transform:translateY(-2px); border-color:var(--hairline-2); box-shadow:0 12px 28px -16px rgba(0,0,0,0.1); }
.related .lbl{ font-family:var(--mono); font-size:10.5px; color:var(--text-mute); letter-spacing:0.08em; text-transform:uppercase; }
.related h3{ margin-top:10px; font-size:18px; font-weight:600; }
.related p{ margin-top:8px; font-size:13px; }
.related .arrow{ margin-top:14px; display:inline-flex; align-items:center; gap:6px; font-size:12.5px; font-weight:500; color:var(--text); }
@media (max-width:880px){ .related{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .related{ grid-template-columns:1fr; } }

.sub-footer{ padding:40px 0 28px; border-top:1px solid var(--hairline); margin-top:24px; }
.sub-footer .row{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px; }
.sub-footer p{ font-size:12.5px; color:var(--text-mute); margin:0; }
.sub-footer nav{ display:flex; gap:18px; font-size:12.5px; color:var(--text-mute); flex-wrap:wrap; }

.status{ display:inline-flex; align-items:center; gap:10px; padding:7px 14px; border-radius:999px; background:#fff; border:1px solid var(--hairline); font-size:12px; color:var(--text-dim); }
.status .dot{ position:relative; display:inline-flex; }
.status .dot span{ width:6px; height:6px; border-radius:50%; background:#22c55e; display:inline-block; }
.status .dot .ring{ position:absolute; inset:0; border-radius:50%; background:#22c55e; }

/* ---------- SITE FOOTER (homepage) ---------- */
.site-footer{ background:var(--bg); padding:48px 0 28px; border-top:1px solid var(--hairline); }
.site-footer .ft-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:48px; }
@media (max-width:900px){ .site-footer .ft-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:540px){ .site-footer .ft-grid{ grid-template-columns:1fr; } }
.ft-lbl{ font-family:var(--mono); font-size:10px; color:var(--text-mute); letter-spacing:0.1em; margin-bottom:18px; }
.ft-link{ padding:6px 0; }
.ft-link a{ font-size:13px; color:var(--text-dim); }
.ft-link a:hover{ color:var(--text); }
.ft-seo{
  margin-top:48px; padding-top:24px; border-top:1px solid var(--hairline);
  font-family:var(--mono); font-size:10.5px; color:var(--text-mute);
  letter-spacing:0.04em; line-height:1.8;
}
.ft-legal{
  margin-top:24px; padding-top:20px; border-top:1px solid var(--hairline);
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:16px; font-size:12px; color:var(--text-mute);
}
.ft-legal nav{ display:flex; gap:20px; }

/* ---------- WHATSAPP FAB ---------- */
.wa-fab{
  position:fixed; right:20px; bottom:20px; z-index:60;
  display:flex; align-items:center; gap:10px;
  padding:12px 16px 12px 14px; border-radius:999px;
  background:#25D366; color:#fff;
  box-shadow:0 12px 28px -10px rgba(37,211,102,0.55);
  font-weight:500; font-size:13px;
  animation:wa-in .5s cubic-bezier(.2,.8,.2,1) 1s both;
}
@keyframes wa-in{ from{ opacity:0; transform:translateY(80px); } to{ opacity:1; transform:translateY(0); } }
@media (max-width:540px){ .wa-fab .wa-label{ display:none; } }

/* ---------- COOKIE BANNER (DSGVO) ---------- */
.cookie-banner{
  position:fixed; left:16px; right:16px; bottom:16px; z-index:200;
  max-width:560px;
  background:#fff; border:1px solid var(--hairline);
  border-radius:18px; padding:20px 22px;
  box-shadow:0 24px 60px -20px rgba(0,0,0,0.22);
  display:none; flex-direction:column; gap:14px;
}
.cookie-banner.show{ display:flex; opacity:1; animation:cookie-in .35s cubic-bezier(.2,.7,.2,1) both; }
@keyframes cookie-in{ from{ opacity:0; } to{ opacity:1; } }
.cookie-banner h4{ font-family:var(--display); font-weight:600; font-size:16px; letter-spacing:-0.02em; margin:0; color:#0a0a0a; display:flex; align-items:center; gap:10px; }
.cookie-banner h4 .dot{ width:6px; height:6px; border-radius:50%; background:#D7263D; display:inline-block; }
.cookie-banner p{ font-size:13px; line-height:1.55; color:#6b6b6b; margin:0; }
.cookie-banner p a{ color:#0a0a0a; text-decoration:underline; }
.cookie-banner .ck-actions{ display:flex; gap:8px; flex-wrap:wrap; margin-top:4px; }
.cookie-banner .ck-btn{
  padding:10px 16px; border-radius:999px; font-size:13px; font-weight:500;
  border:1px solid var(--hairline); cursor:pointer;
  font-family:inherit; line-height:1; background:#fff; color:#0a0a0a;
  transition:transform .2s, background .2s, border-color .2s;
}
.cookie-banner .ck-btn:hover{ transform:translateY(-1px); border-color:#0a0a0a; }
.cookie-banner .ck-btn.primary{ background:#0a0a0a; color:#fff; border-color:#0a0a0a; }
.cookie-banner .ck-btn.primary:hover{ background:#222; }
.cookie-banner details summary{
  font-family:var(--mono); font-size:11px; letter-spacing:0.06em; text-transform:uppercase;
  color:#9a9a9a; cursor:pointer; padding:8px 0; list-style:none;
}
.cookie-banner details summary::-webkit-details-marker{ display:none; }
.cookie-banner details summary::after{ content:" ▾"; }
.cookie-banner details[open] summary::after{ content:" ▴"; }
.cookie-banner .ck-cats{ display:flex; flex-direction:column; gap:8px; margin-top:6px; }
.cookie-banner .ck-cat{ display:flex; justify-content:space-between; align-items:center; padding:10px 12px; background:#f5f4f1; border-radius:10px; font-size:12.5px; }
.cookie-banner .ck-cat label{ display:flex; align-items:center; gap:10px; cursor:pointer; }
.cookie-banner .ck-cat input{ accent-color:#0a0a0a; }
.cookie-banner .ck-cat .req{ font-family:var(--mono); font-size:10px; color:#9a9a9a; text-transform:uppercase; letter-spacing:0.06em; }
@media (max-width:560px){
  .cookie-banner{ left:8px; right:8px; bottom:8px; padding:14px 16px; gap:10px; max-height:78dvh; overflow-y:auto; }
  .cookie-banner h4{ font-size:14.5px; }
  .cookie-banner p{ font-size:12.5px; line-height:1.5; }
  .cookie-banner .ck-actions{ flex-direction:column-reverse; gap:6px; }
  .cookie-banner .ck-btn{ width:100%; padding:11px 14px; justify-content:center; text-align:center; }
}

/* ---------- VIEW TRANSITIONS (cross-document morph) ----------
   Chrome 126+, Edge 126+, Safari 18.2+. Browsers without support fall
   back gracefully to the manual page-transition overlay. Elements with
   the same `view-transition-name` morph between their positions on the
   old and new pages. */
@view-transition { navigation: auto; }
::view-transition-old(root), ::view-transition-new(root){ animation-duration:.35s; }
::view-transition-group(*){ animation-duration:.45s; animation-timing-function:cubic-bezier(.2,.7,.2,1); }

.brand-logo   { view-transition-name: brand-logo; }
.full-nav     { view-transition-name: site-nav; }
.wa-fab       { view-transition-name: wa-fab; }
/* Skip the preloader from cross-page morphs — it should appear on each
   page independently as its own thing. */
.page-transition{ view-transition-name: none; }

/* ---------- KLARNA — cycling pulse on monthly-rate pills ---------- */
.klarna-strip{ background:#FFA8CD; }
.klarna-pills{ display:flex; gap:8px; flex-wrap:wrap; }
.klarna-pill{
  padding:8px 14px; border-radius:999px;
  background:#fff; color:#0a0a0a;
  font-family:var(--mono); font-size:11px; letter-spacing:0.06em;
  transition:transform .3s cubic-bezier(.2,.7,.2,1), background .3s, color .3s;
  animation:klarna-glow 5s cubic-bezier(.4,0,.6,1) infinite;
}
.klarna-pill:nth-child(1){ animation-delay:0s; }
.klarna-pill:nth-child(2){ animation-delay:1.25s; }
.klarna-pill:nth-child(3){ animation-delay:2.5s; }
.klarna-pill:nth-child(4){ animation-delay:3.75s; }
@keyframes klarna-glow{
  0%, 22%, 100%   { background:#fff; color:#0a0a0a; transform:scale(1); }
  8%, 14%         { background:#0a0a0a; color:#fff; transform:scale(1.08); }
}

/* ---------- 3D CONFIGURATOR ---------- */
.cfg-grid{
  display:grid; grid-template-columns:1.6fr 1fr; gap:24px;
}
@media (max-width:1080px){ .cfg-grid{ grid-template-columns:1fr; } }

/* Grid items default to min-width:auto which lets inner overflow-x:auto
   children (the long car list / swatch row) push the column out beyond
   its track. Forcing min-width:0 keeps the grid tracks honest. */
.cfg-grid > *{ min-width:0; }

.cfg-stage{ display:flex; flex-direction:column; gap:14px; min-width:0; }
.cfg-stage-toolbar{
  display:flex; justify-content:space-between; align-items:center; gap:14px; flex-wrap:wrap;
  padding:0 4px;
}
.cfg-stage-meta{ display:flex; flex-direction:column; gap:2px; }
.cfg-stage-brand{ font-family:var(--mono); font-size:10px; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-mute); }
.cfg-stage-model{ font-family:var(--display); font-size:18px; font-weight:600; letter-spacing:-0.02em; }
.cfg-stage-actions{ display:flex; gap:6px; }

.cfg-viewer{
  position:relative; width:100%; height:clamp(360px, 56vw, 620px);
  background:var(--surface-2); border:1px solid var(--hairline); border-radius:20px;
  overflow:hidden;
}
.cfg-viewer model-viewer{ width:100%; height:100%; display:block; }
.cfg-placeholder{
  position:absolute; inset:0; display:none; align-items:center; justify-content:center;
  background:var(--surface-2); padding:24px;
}
.cfg-placeholder.show{ display:flex; }
.cfg-placeholder-inner{
  text-align:center; max-width:380px; color:var(--text-mute);
}
.cfg-placeholder svg{ color:var(--hairline-2); margin-bottom:20px; }
.cfg-placeholder-text strong{
  font-family:var(--display); font-weight:600; font-size:18px;
  letter-spacing:-0.02em; color:var(--text);
  display:block; margin-bottom:8px;
}
.cfg-placeholder-text span{ font-size:13.5px; color:var(--text-dim); line-height:1.55; }

/* Car picker — horizontal scrollable strip */
.cfg-cars{
  display:flex; gap:8px;
  overflow-x:auto; padding:6px 4px 14px;
  scroll-snap-type:x proximity; -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.cfg-cars::-webkit-scrollbar{ display:none; }
.cfg-car{
  flex:0 0 auto; scroll-snap-align:start;
  padding:12px 16px; min-width:160px; text-align:left;
  background:#fff; border:1px solid var(--hairline); border-radius:14px;
  cursor:pointer; transition:border-color .2s, transform .2s, background .2s;
  display:flex; flex-direction:column; gap:3px;
}
.cfg-car:hover{ border-color:var(--text); transform:translateY(-1px); }
.cfg-car.active{ background:var(--text); color:#fff; border-color:var(--text); }
.cfg-car-brand{ font-family:var(--mono); font-size:9.5px; letter-spacing:0.1em; color:var(--text-mute); text-transform:uppercase; }
.cfg-car.active .cfg-car-brand{ color:rgba(255,255,255,0.6); }
.cfg-car-name{ font-family:var(--display); font-size:14px; font-weight:600; letter-spacing:-0.01em; }
.cfg-car-cat{ font-size:10.5px; color:var(--text-mute); margin-top:2px; font-family:var(--mono); }
.cfg-car.active .cfg-car-cat{ color:rgba(255,255,255,0.55); }

/* Right side panel */
.cfg-side{ display:flex; flex-direction:column; gap:14px; }
.cfg-tabs{
  display:flex; gap:4px; padding:4px;
  background:#fff; border:1px solid var(--hairline); border-radius:12px;
  overflow-x:auto; scrollbar-width:none;
}
.cfg-tabs::-webkit-scrollbar{ display:none; }
.cfg-tabs button{
  flex:1; min-width:fit-content; white-space:nowrap;
  padding:8px 14px; border-radius:8px; border:none; background:transparent;
  font-family:var(--ui); font-size:12.5px; font-weight:500;
  color:var(--text-dim); cursor:pointer; transition:background .15s, color .15s;
}
.cfg-tabs button.active{ background:var(--text); color:#fff; }

/* Swatch grid */
.cfg-swatches{
  display:grid; grid-template-columns:repeat(3,1fr); gap:8px;
  max-height:480px; overflow-y:auto;
  padding:4px; scrollbar-width:thin;
}
.cfg-swatch{
  display:flex; flex-direction:column; align-items:stretch; gap:6px;
  padding:8px; background:#fff;
  border:1px solid var(--hairline); border-radius:12px;
  cursor:pointer; transition:border-color .15s, transform .15s, box-shadow .15s;
  text-align:left;
}
.cfg-swatch:hover{ transform:translateY(-1px); border-color:var(--hairline-2); box-shadow:0 4px 12px -6px rgba(0,0,0,0.1); }
.cfg-swatch.active{ border-color:var(--text); box-shadow:0 0 0 2px var(--text); }
.cfg-swatch-color{
  display:block; width:100%; aspect-ratio:1/1;
  border-radius:8px; border:1px solid rgba(0,0,0,0.08);
}
.cfg-swatch-label{ font-size:11px; font-weight:500; color:var(--text); line-height:1.3; }
.cfg-swatch-brand{ font-family:var(--mono); font-size:9px; color:var(--text-mute); letter-spacing:0.04em; }
.cfg-swatch[data-cat-active="0"]{ display:none; }

@media (max-width:560px){
  .cfg-swatches{ grid-template-columns:repeat(2,1fr); }
}

/* Quote / config summary */
.cfg-quote{ padding:18px; }
.cfg-quote-summary{ margin-top:12px; display:grid; gap:8px; }
.cfg-quote-row{
  display:flex; justify-content:space-between; align-items:center;
  padding:6px 10px; background:var(--surface-2); border-radius:8px;
  font-size:12.5px;
}
.cfg-quote-lbl{ font-family:var(--mono); color:var(--text-mute); letter-spacing:0.04em; text-transform:uppercase; font-size:10px; }
.cfg-quote-val{ font-weight:500; color:var(--text); text-align:right; max-width:60%; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

.cfg-wa{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 14px; border-radius:999px;
  background:#25D366; color:#fff; font-size:12.5px; font-weight:500;
  text-decoration:none; align-self:flex-start;
}
.cfg-wa:hover{ transform:translateY(-1px); }

/* ---------- TESTIMONIALS SLIDER ---------- */
.test-nav{ display:flex; gap:8px; }
.test-prev, .test-next{
  width:44px; height:44px; border-radius:50%;
  background:transparent; color:#fff;
  border:1px solid rgba(255,255,255,0.18);
  cursor:pointer; display:grid; place-items:center;
  transition:background .2s, transform .2s, border-color .2s, opacity .2s;
}
.test-prev:hover, .test-next:hover{ background:#fff; color:#0a0a0a; border-color:#fff; transform:translateY(-1px); }
.test-prev:disabled, .test-next:disabled{ opacity:.35; cursor:not-allowed; }
.test-slider{
  margin-top:36px; position:relative;
  /* fade edges so cards slide cleanly under the container border */
  mask-image:linear-gradient(90deg, transparent 0, #000 32px, #000 calc(100% - 32px), transparent 100%);
  -webkit-mask-image:linear-gradient(90deg, transparent 0, #000 32px, #000 calc(100% - 32px), transparent 100%);
}
.test-track{
  display:flex; gap:14px;
  overflow-x:auto; overscroll-behavior-x:contain;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  padding:4px 32px 16px;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.test-track::-webkit-scrollbar{ display:none; }
.test-card{
  flex:0 0 340px; scroll-snap-align:start;
  padding:24px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:18px;
  display:flex; flex-direction:column;
  transition:background .25s, border-color .25s, transform .25s;
}
.test-card:hover{ background:rgba(255,255,255,0.07); border-color:rgba(255,255,255,0.16); transform:translateY(-2px); }
.test-stars{ display:flex; gap:2px; color:#FFB400; }
.test-quote{
  margin-top:14px; color:rgba(255,255,255,0.85);
  font-size:14px; line-height:1.6; flex:1;
}
.test-meta{
  margin-top:18px; padding-top:14px;
  border-top:1px solid rgba(255,255,255,0.08);
}
.test-author{ font-weight:500; font-size:13px; }
.test-context{
  font-family:var(--mono); font-size:11px;
  color:rgba(255,255,255,0.5); margin-top:3px; letter-spacing:0.04em;
}
.test-dots{
  display:flex; justify-content:center; gap:6px; margin-top:18px;
}
.test-dots > button{
  width:6px; height:6px; padding:0; border-radius:50%;
  background:rgba(255,255,255,0.2); border:none; cursor:pointer;
  transition:background .2s, width .2s;
}
.test-dots > button.active{ background:#fff; width:20px; border-radius:3px; }

@media (max-width:640px){
  .test-nav{ display:none; }
  .test-card{ flex:0 0 85vw; }
  .test-track{ padding-left:16px; padding-right:16px; }
  .test-slider{ mask-image:none; -webkit-mask-image:none; }
}

/* ---------- LEAFLET MAP (brand-styled) ---------- */
.leaflet-container{
  background:#f4f3f0 !important;
  font-family:var(--ui);
  outline:none;
}
/* slight desaturation so the tiles fit the cream/black/red palette */
.leaflet-tile{
  filter:saturate(0.6) contrast(1.02);
}
/* zoom buttons */
.leaflet-bar a, .leaflet-bar a:hover{
  background:#fff !important;
  color:var(--text) !important;
  border:1px solid var(--hairline) !important;
  width:32px !important; height:32px !important;
  line-height:30px !important; font-size:18px !important;
  font-family:var(--display) !important;
  transition:background .15s, color .15s, border-color .15s;
}
.leaflet-bar a:hover{
  background:var(--text) !important;
  color:#fff !important;
  border-color:var(--text) !important;
}
.leaflet-bar a:first-child{ border-top-left-radius:10px !important; border-top-right-radius:10px !important; }
.leaflet-bar a:last-child{  border-bottom-left-radius:10px !important; border-bottom-right-radius:10px !important; }
.leaflet-control-zoom{ border:none !important; box-shadow:0 8px 24px -12px rgba(0,0,0,0.12); }
/* attribution */
.leaflet-control-attribution{
  background:rgba(255,255,255,0.85) !important;
  font-family:var(--mono) !important;
  font-size:9.5px !important;
  color:var(--text-mute) !important;
  padding:4px 8px !important;
  border-top-left-radius:8px;
}
.leaflet-control-attribution a{ color:var(--text-dim) !important; }
/* brand marker (red dot + pulsing ring + white border) */
.fw-marker{ background:transparent !important; border:none !important; }
.fw-marker-dot{ position:relative; width:28px; height:28px; }
.fw-marker-ring{
  position:absolute; inset:-10px; border-radius:50%;
  background:rgba(215,38,61,0.22);
  animation:pulse 2s ease-in-out infinite;
}
.fw-marker-core{
  position:absolute; inset:0; border-radius:50%;
  background:var(--red);
  border:4px solid #fff;
  box-shadow:0 6px 16px -4px rgba(0,0,0,0.25);
}
/* popup */
.leaflet-popup-content-wrapper{
  background:#fff !important;
  border:1px solid var(--hairline) !important;
  border-radius:14px !important;
  box-shadow:0 18px 40px -18px rgba(0,0,0,0.18) !important;
  padding:4px 8px !important;
}
.leaflet-popup-content{ margin:12px 14px !important; font-size:13px !important; color:var(--text) !important; line-height:1.5 !important; }
.leaflet-popup-tip{ background:#fff !important; box-shadow:none !important; }
.leaflet-popup-close-button{ color:var(--text-mute) !important; font-size:18px !important; padding:8px 8px 0 0 !important; }

/* ---------- PREMIUM-SERVICE SLIDER (dark section above gallery) ---------- */
.premium-tabs{
  display:flex; justify-content:center; gap:6px; margin-top:32px; flex-wrap:wrap;
}
.premium-tabs button{
  padding:8px 16px; border-radius:999px; font-size:13px; font-family:var(--ui);
  background:rgba(255,255,255,0.04); color:rgba(255,255,255,0.7);
  border:1px solid rgba(255,255,255,0.12); font-weight:500; cursor:pointer;
  transition:all .25s ease;
}
.premium-tabs button:hover{ color:#fff; border-color:rgba(255,255,255,0.35); }
.premium-tabs button.active{ background:#fff; color:#0a0a0a; border-color:#fff; }

.premium-slider-wrap{
  position:relative; margin-top:48px; padding:0 56px;
}
.premium-arc{
  position:absolute; left:0; top:40px; width:100%; height:80%;
  pointer-events:none; z-index:0;
}
.premium-slider{
  position:relative; z-index:1;
  width:min(440px, 100%); margin:0 auto;
  overflow:hidden; border-radius:24px;
}
.premium-track{
  display:flex;
  transition:transform .65s cubic-bezier(.2,.7,.2,1);
  will-change:transform;
}
.premium-card{
  flex:0 0 100%; min-width:0;
  padding:8px;
  background:#fff; color:var(--text);
  border-radius:24px;
  box-shadow:0 24px 60px -20px rgba(0,0,0,0.6);
}
.premium-card-img{
  width:100%; height:240px; border-radius:16px; overflow:hidden;
  background:#fafaf8; position:relative;
}
.premium-card-img img{ width:100%; height:100%; object-fit:cover; display:block; }
.premium-card-body{ padding:20px 16px 12px; text-align:center; }
.premium-card-body h3{ font-size:22px; font-weight:600; color:var(--text); }
.premium-card-body p{ font-size:14px; margin-top:8px; color:var(--text-dim); }
.premium-card-foot{
  border-top:1px solid var(--hairline);
  padding:14px 16px; display:flex; justify-content:space-between; align-items:center;
}
.premium-card-stat{
  font-family:var(--display); font-size:24px; font-weight:600;
  letter-spacing:-0.02em; line-height:1;
}
.premium-card-statlbl{
  font-family:var(--mono); font-size:10px; color:var(--text-mute);
  margin-top:4px; letter-spacing:0.06em; text-transform:uppercase;
}

.premium-nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:42px; height:42px; border-radius:50%;
  background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.18);
  color:#fff; cursor:pointer; z-index:2;
  display:grid; place-items:center;
  transition:all .2s ease;
  backdrop-filter:blur(8px);
}
.premium-nav:hover{ background:#fff; color:#0a0a0a; border-color:#fff; }
.premium-nav.prev{ left:0; }
.premium-nav.next{ right:0; }

.premium-dots{
  display:flex; justify-content:center; gap:6px; margin-top:24px;
}
.premium-dots button{
  width:22px; height:3px; border-radius:2px;
  background:rgba(255,255,255,0.2); border:0; padding:0; cursor:pointer;
  transition:all .25s ease;
}
.premium-dots button:hover{ background:rgba(255,255,255,0.5); }
.premium-dots button.active{ background:#fff; width:36px; }

@media (max-width:680px){
  .premium-slider-wrap{ padding:0 12px; }
  .premium-nav{ width:36px; height:36px; }
  .premium-nav.prev{ left:-6px; }
  .premium-nav.next{ right:-6px; }
}

/* ---------- DESIGN-VORSCHAU upload card ---------- */
.dp-photo-preview{
  flex:1; min-height:320px; position:relative; overflow:hidden;
  background:#fafaf8;
  border-bottom:1px solid var(--hairline);
  display:flex; align-items:center; justify-content:center;
}
.dp-photo-preview.is-dragover{ background:#f0eee8; }
.dp-photo-preview.is-dragover::after{
  content:''; position:absolute; inset:14px; border-radius:14px;
  border:2px dashed var(--text); pointer-events:none;
}
.dp-photo-label{
  cursor:pointer; display:inline-flex; flex-direction:column;
  align-items:center; gap:8px; color:var(--text-dim);
  text-align:center; padding:24px;
  transition:transform .25s ease, color .2s ease;
}
.dp-photo-preview:hover .dp-photo-label{ color:var(--text); transform:translateY(-2px); }
.dp-photo-icon{ transition:transform .35s cubic-bezier(.2,.7,.2,1); }
.dp-photo-preview:hover .dp-photo-icon{ transform:translateY(-3px); }
.dp-photo-text{
  font-family:var(--mono); font-size:11px; letter-spacing:0.08em;
  text-transform:uppercase; margin-top:6px;
}
.dp-photo-hint{
  font-family:var(--mono); font-size:10px; letter-spacing:0.04em;
  color:var(--text-mute);
}
.dp-photo-img{
  position:absolute; inset:0; margin:auto;
  max-width:92%; max-height:92%;
  width:auto; height:auto;
  object-fit:contain;
  border-radius:10px;
  opacity:0; transform:scale(0.96);
  transition:opacity .45s ease, transform .55s cubic-bezier(.2,.7,.2,1);
}
.dp-photo-img[hidden]{ display:none; }
.dp-photo-img.in{ opacity:1; transform:scale(1); }
.dp-photo-preview.has-photo .dp-photo-label{ display:none; }

/* upload spinner */
.dp-photo-loader{
  position:absolute; inset:0; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:12px;
  background:rgba(255,255,255,0.72); backdrop-filter:blur(6px);
  font-family:var(--mono); font-size:11px; letter-spacing:0.06em;
  text-transform:uppercase; color:var(--text-dim);
  animation:dp-loader-in .2s ease both;
}
.dp-photo-loader[hidden]{ display:none; }
@keyframes dp-loader-in{ from{opacity:0} to{opacity:1} }
.dp-spinner{
  width:34px; height:34px; border-radius:50%;
  border:2px solid var(--hairline); border-top-color:var(--text);
  animation:dp-spin .9s linear infinite;
}
@keyframes dp-spin{ to{ transform:rotate(360deg); } }

.dp-photo-clear{
  position:absolute; top:10px; right:10px;
  width:30px; height:30px; border-radius:50%;
  border:1px solid var(--hairline); background:#fff;
  display:grid; place-items:center; cursor:pointer;
  color:var(--text); z-index:2;
  transition:transform .2s ease, background .2s ease;
}
.dp-photo-clear[hidden]{ display:none; }
.dp-photo-clear:hover{ background:var(--text); color:#fff; }

/* Design-Vorschau funnel — only the active step is rendered. Wrapped here in
   CSS (rather than inline) so JS class-toggle alone controls visibility. */
.dp-step{ display:none; }
.dp-step.active{ display:flex; flex-direction:column; gap:14px; animation:dp-step-in .35s cubic-bezier(.2,.7,.2,1) both; }
@keyframes dp-step-in{ from{ opacity:0; transform:translateY(8px); } to{ opacity:1; transform:translateY(0); } }

.dp-finish-row{
  display:flex; gap:6px; flex-wrap:wrap; align-items:center;
  margin-top:8px; padding-top:14px;
  border-top:1px solid var(--hairline);
}
.dp-finish-lbl{
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:0.06em; text-transform:uppercase;
  color:var(--text-mute); margin-right:4px;
}
.dp-finish{
  padding:7px 12px; border-radius:999px; font-size:12px;
  background:#fff; border:1px solid var(--hairline); cursor:pointer;
}

/* ---------- BOOKING WIDGET (#termin on home) ---------- */
.book-grid{
  display:grid; grid-template-columns:1.45fr 1fr; gap:36px;
}
@media (max-width:880px){ .book-grid{ grid-template-columns:1fr; gap:20px; } }

.book-dates-head{
  display:flex; align-items:center; gap:12px; margin-bottom:14px;
}
.book-week-label{ flex:1; display:flex; flex-direction:column; gap:4px; align-items:flex-start; }
.book-week-range{
  font-family:var(--mono); font-size:11px; letter-spacing:0.04em;
  color:var(--text); font-weight:500;
}
.book-week-nav{
  width:32px; height:32px; border-radius:50%;
  background:#fff; border:1px solid var(--hairline); cursor:pointer;
  display:grid; place-items:center; color:var(--text);
  transition:all .15s ease;
}
.book-week-nav:hover:not(:disabled){ border-color:var(--text); transform:translateY(-1px); }
.book-week-nav:disabled{ opacity:0.3; cursor:not-allowed; }

.book-dates{
  display:grid; grid-template-columns:repeat(7, minmax(0,1fr)); gap:6px;
}
.book-dates .book-date[data-page]{ display:none; }
.book-dates .book-date[data-page].show{ display:flex; }
@media (max-width:560px){ .book-dates{ grid-template-columns:repeat(7, minmax(0,1fr)); gap:4px; } }

.book-dots{
  display:flex; justify-content:center; gap:5px; margin-top:14px;
}
.book-dots button{
  width:18px; height:3px; border-radius:2px;
  background:var(--hairline); border:0; padding:0; cursor:pointer;
  transition:all .2s ease;
}
.book-dots button:hover{ background:var(--text-dim); }
.book-dots button.active{ background:var(--text); width:28px; }
.book-date{
  display:flex; flex-direction:column; align-items:center; gap:2px;
  padding:10px 4px; border-radius:10px;
  background:#fff; border:1px solid var(--hairline); cursor:pointer;
  font-family:var(--mono); font-size:11px; color:var(--text);
  transition:all .15s ease;
}
.book-date:hover{ border-color:var(--text); transform:translateY(-1px); }
.book-date.active{ background:var(--text); color:#fff; border-color:var(--text); }
.book-date.soft{ background:#faf8f4; opacity:0.7; }
.book-date.soft::after{
  content:'§'; position:absolute; margin-top:34px; font-size:9px; color:var(--text-mute);
}
.book-date .d-dow{ font-size:9.5px; color:var(--text-mute); text-transform:uppercase; letter-spacing:0.05em; }
.book-date.active .d-dow{ color:rgba(255,255,255,0.55); }
.book-date .d-day{ font-weight:600; font-size:15px; line-height:1; margin:2px 0; }
.book-date .d-mon{ font-size:9px; color:var(--text-mute); text-transform:uppercase; }
.book-date.active .d-mon{ color:rgba(255,255,255,0.55); }

.book-times{
  display:grid; grid-template-columns:repeat(6, minmax(0,1fr)); gap:6px;
}
@media (max-width:560px){ .book-times{ grid-template-columns:repeat(4, minmax(0,1fr)); } }
.book-time{
  padding:9px 4px; border-radius:8px;
  background:#fff; border:1px solid var(--hairline); cursor:pointer;
  font-family:var(--mono); font-size:12px; color:var(--text);
  transition:all .15s ease;
}
.book-time:hover{ border-color:var(--text); }
.book-time.active{ background:var(--text); color:#fff; border-color:var(--text); }

.book-side{ display:flex; flex-direction:column; gap:10px; }
.book-svc-pill{
  display:inline-flex; align-items:center; gap:8px; align-self:flex-start;
  padding:8px 14px; border-radius:999px;
  background:#0a0a0a; color:#fff;
  font-family:var(--mono); font-size:11px; letter-spacing:0.03em;
}
.book-svc-pill svg{ stroke:#fff; opacity:0.8; }
#book-status.ok{ color:#15803d; font-weight:500; }
#book-status.err{ color:#b91c1c; }

#booking-form.sent .book-side{ opacity:0.55; pointer-events:none; }
#booking-form.sent #book-status{ font-size:14px; }

/* ---------- LEGAL PAGES (impressum / datenschutz / agb) ---------- */
.legal-section{ padding-top:24px; padding-bottom:80px; }
.legal-section .container{ max-width:780px; }
.legal-section h2{
  font-family:var(--display); font-weight:500; font-size:clamp(20px,2vw,26px);
  letter-spacing:-0.02em; margin:40px 0 14px;
}
.legal-section h2:first-of-type{ margin-top:8px; }
.legal-section h3{
  font-family:var(--display); font-weight:500; font-size:16px;
  margin:22px 0 8px; color:var(--text);
}
.legal-section p, .legal-section li{
  font-size:14.5px; line-height:1.65; color:var(--text-dim);
}
.legal-section ul{ margin:6px 0 14px 22px; padding:0; }
.legal-section li{ margin-bottom:6px; }
.legal-section a{ color:var(--text); text-decoration:underline; text-underline-offset:3px; }
.legal-section a:hover{ color:var(--red); }
.legal-section code{
  font-family:var(--mono); font-size:12.5px;
  background:#faf8f4; padding:1px 6px; border-radius:4px;
  border:1px solid var(--hairline);
}
.legal-todo{
  display:inline-block;
  padding:0 6px; border-radius:4px;
  background:#fef3c7; color:#92400e;
  font-family:var(--mono); font-size:12px;
}
.legal-updated{
  margin-top:48px; padding-top:20px;
  border-top:1px solid var(--hairline);
  font-family:var(--mono); font-size:11px; letter-spacing:0.05em;
  color:var(--text-mute);
}

/* ---------- ADMIN AREA (admin.php) ---------- */
.admin-shell{ max-width:1180px; margin:0 auto; padding:40px 24px 80px; }
.admin-shell h1{ font-family:var(--display); font-weight:500; font-size:34px; letter-spacing:-0.02em; margin-bottom:8px; }
.admin-shell .sub{ color:var(--text-dim); font-size:14px; margin-bottom:32px; }
.admin-filters{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:18px; }
.admin-filters a{
  padding:7px 12px; border-radius:999px; background:#fff; border:1px solid var(--hairline);
  font-size:12.5px; color:var(--text); text-decoration:none;
  font-family:var(--mono); letter-spacing:0.03em;
}
.admin-filters a.active{ background:var(--text); color:#fff; border-color:var(--text); }
.admin-table{ width:100%; border-collapse:collapse; background:#fff; border:1px solid var(--hairline); border-radius:14px; overflow:hidden; }
.admin-table th, .admin-table td{ padding:12px 14px; text-align:left; font-size:13.5px; vertical-align:top; }
.admin-table th{ background:#faf8f4; font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:0.05em; color:var(--text-mute); border-bottom:1px solid var(--hairline); }
.admin-table tr:not(:last-child) td{ border-bottom:1px solid var(--hairline); }
.admin-table .ref{ font-family:var(--mono); font-weight:600; }
.admin-table .when{ font-family:var(--mono); color:var(--text-dim); white-space:nowrap; }
.admin-table .status{ display:inline-flex; align-items:center; gap:6px; padding:3px 9px; border-radius:999px; font-size:11.5px; font-weight:500; }
.admin-table .status.new      { background:#fffbeb; color:#92400e; }
.admin-table .status.confirmed{ background:#ecfdf5; color:#065f46; }
.admin-table .status.cancelled{ background:#fef2f2; color:#991b1b; text-decoration:line-through; }
.admin-table .status.done     { background:#f3f4f6; color:#374151; }
.admin-table .actions{ display:flex; gap:6px; flex-wrap:wrap; }
.admin-table .actions button{ font-family:var(--mono); font-size:11px; padding:6px 10px; border-radius:6px; border:1px solid var(--hairline); background:#fff; cursor:pointer; }
.admin-table .actions button:hover{ border-color:var(--text); }
.admin-table .actions button.danger{ color:#b91c1c; }
.admin-empty{ padding:60px 20px; text-align:center; color:var(--text-mute); font-size:14px; }

.admin-tabs{
  display:flex; gap:8px; margin-bottom:24px;
  border-bottom:1px solid var(--hairline);
}
.admin-tabs a{
  padding:11px 18px; font-size:13px; font-weight:500;
  color:var(--text-mute); text-decoration:none;
  border-bottom:2px solid transparent; margin-bottom:-1px;
}
.admin-tabs a:hover{ color:var(--text); }
.admin-tabs a.active{ color:var(--text); border-bottom-color:var(--text); }

.admin-job-form{
  background:#fff; border:1px solid var(--hairline); border-radius:14px;
  padding:24px; margin-bottom:16px;
}
.admin-job-form .field{ margin-bottom:12px; }
.admin-job-form .field:last-of-type{ margin-bottom:0; }

.admin-table .status.draft  { background:#f3f4f6; color:#374151; }
.admin-table .status.open   { background:#ecfdf5; color:#065f46; }
.admin-table .status.closed { background:#fef2f2; color:#991b1b; }
.admin-table .btn-link{
  font-family:var(--mono); font-size:11px;
  color:var(--text); text-decoration:underline;
  padding:6px 10px;
}
.admin-table .btn-link:hover{ color:var(--red); }

/* ---- Media grid (admin) ---- */
.admin-media-grid{
  display:grid; grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
  gap:14px; margin-top:8px;
}
.admin-media-card{
  background:#fff; border:1px solid var(--hairline); border-radius:14px;
  overflow:hidden; display:flex; flex-direction:column;
}
.admin-media-preview{
  height:160px; background:#faf8f4; display:grid; place-items:center;
  border-bottom:1px solid var(--hairline); overflow:hidden;
}
.admin-media-preview img{ width:100%; height:100%; object-fit:cover; display:block; }
.admin-media-glb{
  font-family:var(--mono); font-size:11px; text-align:center;
  color:var(--text-dim); line-height:1.6;
}
.admin-media-glb span{ font-size:10px; color:var(--text-mute); }
.admin-media-body{ padding:14px; display:flex; flex-direction:column; gap:6px; }
.admin-media-label{ font-weight:600; font-size:14px; }
.admin-media-slot{
  font-family:var(--mono); font-size:10.5px; color:var(--text-mute);
  letter-spacing:0.04em;
}
.admin-media-hint{
  font-size:12px; color:var(--text-dim); line-height:1.45;
}
.admin-media-status{
  font-family:var(--mono); font-size:10.5px; color:#15803d;
  letter-spacing:0.04em; text-transform:uppercase; margin-top:4px;
}
.admin-media-form{
  display:flex; gap:6px; align-items:center; margin-top:8px;
  padding-top:10px; border-top:1px solid var(--hairline);
}
.admin-media-form input[type=file]{
  flex:1; font-size:11px; min-width:0;
}

/* ---------- KARRIERE page ---------- */
.karriere-empty{
  background:#fff; border:1px solid var(--hairline); border-radius:18px;
  padding:48px 32px; text-align:center;
  display:flex; flex-direction:column; align-items:center; gap:14px;
}
.karriere-empty svg{ color:var(--text-mute); }
.karriere-empty h3{ font-family:var(--display); font-weight:500; font-size:22px; }
.karriere-empty p{ max-width:480px; color:var(--text-dim); font-size:14.5px; line-height:1.55; }
.karriere-empty .btn{ margin-top:8px; }

.karriere-list{ display:grid; gap:14px; }
.karriere-card{ padding:24px; display:flex; flex-direction:column; gap:14px; }
.karriere-card-head{
  display:flex; justify-content:space-between; align-items:flex-start;
  gap:16px; flex-wrap:wrap;
}
.karriere-card h3{ font-family:var(--display); font-weight:500; font-size:22px; letter-spacing:-0.02em; }
.karriere-meta{ display:flex; gap:6px; flex-wrap:wrap; }
.karriere-chip{
  padding:4px 10px; border-radius:999px;
  background:var(--text); color:#fff;
  font-family:var(--mono); font-size:10.5px; letter-spacing:0.04em;
  text-transform:uppercase;
}
.karriere-chip.soft{ background:#fff; color:var(--text); border:1px solid var(--hairline); }
.karriere-summary{ font-size:15px; color:var(--text-dim); line-height:1.55; margin:0; }
.karriere-detail summary{
  cursor:pointer; font-family:var(--mono); font-size:11px;
  letter-spacing:0.06em; text-transform:uppercase; color:var(--text-mute);
  padding:8px 0; list-style:none;
}
.karriere-detail summary::-webkit-details-marker{ display:none; }
.karriere-detail summary::after{ content:' ▾'; }
.karriere-detail[open] summary::after{ content:' ▴'; }
.karriere-body{
  padding-top:8px; font-size:14px; line-height:1.65; color:var(--text);
}
.karriere-card .btn{ align-self:flex-start; }

.admin-login{
  max-width:380px; margin:120px auto 0; padding:32px;
  background:#fff; border:1px solid var(--hairline); border-radius:18px;
  box-shadow:0 12px 40px -16px rgba(0,0,0,0.08);
}
@media (max-width:420px){
  .admin-login{ margin:60px 16px 0; padding:24px; }
}
.admin-login h1{ font-size:24px; margin-bottom:6px; }
.admin-login p{ color:var(--text-dim); font-size:13.5px; margin-bottom:20px; }
.admin-login .field{ margin-bottom:12px; }

/* ---------- REDUCED MOTION ---------- */
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  .reveal, .reveal-word{ opacity:1 !important; transform:none !important; filter:none !important; animation:none !important; }
  .page-transition{ display:none !important; }
  .hero-entry{ animation:none !important; }
  *{ animation:none !important; transition:none !important; }
}
