/* ═══════════════════════════════════════════════════
   WC-MOBIL.DE — LUXURY DESIGN SYSTEM
   Shared across all pages. No border-radius. No noise.
   Pure editorial darkness with warm gold.
   ═══════════════════════════════════════════════════ */

/* ── RESET ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px;font-size:16px;-webkit-text-size-adjust:100%}
img{display:block;max-width:100%;height:auto}
button{cursor:pointer;font-family:inherit}
a{color:var(--gold);text-decoration:none;transition:.25s ease}
a:hover{color:var(--gold2)}
::selection{background:rgba(200,151,90,.22);color:#fff}
::-webkit-scrollbar{width:2px}
::-webkit-scrollbar-track{background:var(--ink)}
::-webkit-scrollbar-thumb{background:var(--gold3)}

/* ── ROOT TOKENS ── */
:root{
  --ink:   #07090A;
  --ink1:  #0C0F0E;
  --ink2:  #131817;
  --ink3:  #1A2120;
  --ink4:  #212B29;
  --gold:  #C8975A;
  --gold2: #DEAD7A;
  --gold3: #8A6030;
  --gold-dim:  rgba(200,151,90,.07);
  --gold-line: rgba(200,151,90,.14);
  --cream: #F0EAE0;
  --cream2:#CEC5B4;
  --muted: #79756C;
  --red:   rgba(210,80,80,.85);
  --green: #7DC48A;
  --ff:'Fraunces',Georgia,serif;
  --fb:'DM Sans',system-ui,sans-serif;
  --ease:cubic-bezier(0.16,1,0.3,1);
  --ease2:cubic-bezier(0.34,1.56,0.64,1);
  --nav-h:80px;
}

/* ── BASE ── */
body{
  font-family:var(--fb);
  background:var(--ink);
  color:var(--cream);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-wrap:pretty;
}

/* ── CURSOR ── */
#cursor{position:fixed;top:0;left:0;z-index:99999;pointer-events:none}
#cursor-dot{width:5px;height:5px;border-radius:50%;background:var(--gold);position:absolute;transform:translate(-50%,-50%);transition:width .18s,height .18s}
#cursor-ring{width:26px;height:26px;border-radius:50%;border:1px solid rgba(200,151,90,.3);position:absolute;transform:translate(-50%,-50%);transition:width .4s var(--ease),height .4s var(--ease),opacity .3s}
@media(max-width:900px){#cursor{display:none}body{cursor:auto}}

/* ── KEYFRAMES ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes revealUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes shimmer{from{background-position:-200% center}to{background-position:200% center}}
@keyframes pulseGold{0%,100%{opacity:.5}50%{opacity:1}}

/* ════════════════════════════
   NAVIGATION
════════════════════════════ */
.nav{
  position:fixed;top:0;inset-inline:0;z-index:500;
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 clamp(20px,4vw,64px);
  transition:background .45s,box-shadow .45s;
}
.nav::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(7,9,10,.97) 0%,rgba(7,9,10,.0) 100%);
  pointer-events:none;transition:opacity .4s;
}
.nav.solid::before{background:rgba(7,9,10,.97);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px)}
.nav.solid{box-shadow:0 1px 0 var(--gold-line)}
/* Brand */
.nb{display:flex;align-items:center;gap:13px;text-decoration:none;position:relative;z-index:1}
.nb-logo{
  width:42px;height:42px;overflow:hidden;
  border:1px solid rgba(200,151,90,.2);flex-shrink:0;
}
.nb-logo img{width:100%;height:100%;object-fit:cover}
.nb-name{font-family:var(--ff);font-size:1rem;font-weight:700;color:#fff;letter-spacing:.01em;display:block;line-height:1.1}
.nb-sub{font-family:var(--fb);font-size:.42rem;font-weight:400;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);display:block;margin-top:2px}
/* Nav links */
.nl{display:flex;align-items:center;gap:2px;position:relative;z-index:1}
.nl a{
  font-family:var(--fb);font-size:.54rem;font-weight:400;letter-spacing:.14em;
  text-transform:uppercase;color:rgba(255,255,255,.42);
  padding:8px 13px;transition:.22s;
}
.nl a:hover{color:#fff;background:rgba(255,255,255,.04)}
/* CTA in nav */
.n-cta{
  display:inline-flex;align-items:center;gap:7px;
  padding:10px 22px;background:var(--gold);color:var(--ink);
  font-family:var(--fb);font-size:.54rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;
  transition:.32s var(--ease);margin-left:8px;position:relative;z-index:1;text-decoration:none;
  overflow:hidden;
}
.n-cta::before{content:'';position:absolute;inset:0;background:var(--gold2);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.n-cta:hover::before{transform:scaleX(1)}
.n-cta:hover{color:var(--ink);transform:translateY(-1px);box-shadow:0 6px 20px rgba(200,151,90,.28)}
.n-cta span,.n-cta svg{position:relative;z-index:1;color:var(--ink)}
.n-cta svg{width:11px;height:11px}
/* Hamburger */
.hbg{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:8px;z-index:600;position:relative}
.hbg i{width:22px;height:1px;background:var(--gold);display:block;transition:.38s var(--ease);transform-origin:center}
.hbg.open i:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.hbg.open i:nth-child(2){opacity:0;transform:scaleX(0)}
.hbg.open i:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}
@media(max-width:860px){
  .nl{
    position:fixed;inset:0 0 0 auto;width:min(300px,88vw);
    flex-direction:column;align-items:stretch;
    background:rgba(7,9,10,.99);backdrop-filter:blur(40px);
    padding:calc(var(--nav-h) + 20px) 28px 40px;gap:0;
    transform:translateX(100%);transition:.5s var(--ease);
    border-left:1px solid var(--gold-line);z-index:500;
  }
  .nl.open{transform:translateX(0)}
  .nl a{font-size:.78rem;padding:15px 0;border-bottom:1px solid rgba(200,151,90,.06)}
  .n-cta{margin:24px 0 0;justify-content:center}
  .hbg{display:flex}
  .nav-tel{display:none}
}

/* ════════════════════════════
   TRUST TICKER
════════════════════════════ */
.ticker{
  background:var(--gold);
  padding:10px 0;overflow:hidden;
}
.ticker-track{display:flex;width:max-content;animation:ticker 26s linear infinite}
.ti{
  display:flex;align-items:center;gap:18px;padding:0 26px;
  font-family:var(--fb);font-size:.5rem;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;color:var(--ink);white-space:nowrap;
}
.ti-sep{width:3px;height:3px;border-radius:50%;background:rgba(7,9,10,.28)}

/* ════════════════════════════
   BUTTONS
════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 28px;
  font-family:var(--fb);font-size:.58rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;
  border:none;transition:.34s var(--ease);text-decoration:none;
  white-space:nowrap;position:relative;overflow:hidden;cursor:pointer;
}
.btn svg{width:12px;height:12px;flex-shrink:0;position:relative;z-index:1}
.btn span{position:relative;z-index:1}
.btn-g{background:var(--gold);color:var(--ink)}
.btn-g::before{content:'';position:absolute;inset:0;background:var(--gold2);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.btn-g:hover::before{transform:scaleX(1)}
.btn-g:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(200,151,90,.32);color:var(--ink)}
.btn-o{background:transparent;color:var(--gold);border:1px solid rgba(200,151,90,.3)}
.btn-o:hover{border-color:rgba(200,151,90,.65);transform:translateY(-2px);background:rgba(200,151,90,.04)}
.btn-lg{padding:15px 34px;font-size:.6rem}
.btn-full{width:100%;justify-content:center}
button.btn:disabled{opacity:.4;pointer-events:none}

/* ════════════════════════════
   SECTION SYSTEM
════════════════════════════ */
.sec{padding:clamp(64px,8vw,120px) clamp(24px,5vw,72px)}
.sec-inner{max-width:1260px;margin:0 auto}
.alt{background:var(--ink1)}
.alt2{background:var(--ink2)}

/* Section label */
.lbl{
  display:flex;align-items:center;gap:10px;
  font-family:var(--fb);font-size:.44rem;font-weight:600;
  letter-spacing:.3em;text-transform:uppercase;color:var(--gold);
  margin-bottom:14px;
}
.lbl::after{content:'';flex:0 0 22px;height:1px;background:var(--gold)}

/* Section heading */
h2.sh{
  font-family:var(--ff);
  font-size:clamp(1.7rem,3.2vw,2.8rem);
  font-weight:900;line-height:1.0;letter-spacing:-.03em;
  color:#fff;margin-bottom:10px;
}
h2.sh em{font-style:italic;font-weight:300;color:var(--gold)}

/* Sub-paragraph */
.sp{
  font-size:clamp(.88rem,1.1vw,.97rem);
  color:rgba(240,234,224,.5);line-height:1.85;max-width:540px;
}

/* Gold rule divider */
.divr{width:22px;height:1px;background:var(--gold);margin:18px 0 38px;opacity:.8}
.center .divr{margin-left:auto;margin-right:auto}
.center{text-align:center}.center .lbl{justify-content:center}.center .sp{margin:0 auto}

/* TLDR box */
.tldr-b{
  background:rgba(200,151,90,.05);
  border-left:1px solid var(--gold);
  padding:16px 20px;
  margin-bottom:28px;
  font-size:.875rem;color:rgba(240,234,224,.65);line-height:1.88;
}
.tldr-b strong{color:var(--cream);font-weight:500}

/* ════════════════════════════
   PAGE HERO (Unterseiten)
════════════════════════════ */
.page-hero{
  padding:calc(var(--nav-h) + clamp(44px,6vh,88px)) clamp(24px,5vw,72px) clamp(44px,6vh,80px);
  position:relative;overflow:hidden;background:var(--ink);
}
.page-hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 65% 55% at 100% 50%, rgba(200,151,90,.07), transparent),
    radial-gradient(ellipse 40% 40% at 0% 0%, rgba(30,55,42,.14), transparent);
}
.page-hero-grid{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(200,151,90,.025) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(200,151,90,.025) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 75% 75% at 50% 0%,black 50%,transparent);
  -webkit-mask-image:radial-gradient(ellipse 75% 75% at 50% 0%,black 50%,transparent);
}
.page-hero-inner{position:relative;z-index:2;max-width:900px}
.ph-eyebrow{
  display:flex;align-items:center;gap:11px;
  font-family:var(--fb);font-size:.46rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);margin-bottom:20px;
  animation:fadeUp .6s var(--ease) both;
}
.ph-eyebrow::before{content:'';width:18px;height:1px;background:var(--gold)}
h1.ph-h1{
  font-family:var(--ff);
  font-size:clamp(2.4rem,5.5vw,4rem);font-weight:900;color:#fff;
  line-height:.94;letter-spacing:-.03em;margin-bottom:10px;
  animation:fadeUp .65s var(--ease) .07s both;
}
h1.ph-h1 em{font-style:italic;font-weight:300;color:var(--gold);display:block;font-size:.76em;line-height:1.2;margin-top:8px}
.ph-tldr{
  background:rgba(200,151,90,.06);border-left:1px solid var(--gold);
  padding:14px 20px;margin:20px 0 28px;
  font-size:.875rem;color:rgba(240,234,224,.68);line-height:1.85;
  animation:fadeUp .6s var(--ease) .15s both;
}
.ph-tldr strong{color:var(--cream);font-weight:500}
.ph-btns{display:flex;gap:10px;flex-wrap:wrap;animation:fadeUp .6s var(--ease) .22s both}
.ph-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:20px;animation:fadeUp .6s var(--ease) .28s both}
.chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 11px;
  border:1px solid rgba(200,151,90,.14);
  font-size:.64rem;color:var(--muted);letter-spacing:.04em;
}
.chip-dot{width:4px;height:4px;border-radius:50%;background:var(--gold);flex-shrink:0}

/* ════════════════════════════
   FEATURE GRID
════════════════════════════ */
.feat-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(215px,1fr));
  gap:1px;margin-top:36px;background:var(--ink);
}
.feat{
  background:var(--ink2);padding:28px 24px;
  border:1px solid transparent;transition:.3s;position:relative;
}
.feat:hover{border-color:var(--gold-line);background:var(--ink3)}
.feat-num{
  font-family:var(--ff);font-size:3rem;font-weight:900;
  color:rgba(200,151,90,.06);position:absolute;top:10px;right:14px;line-height:1;
}
.feat-icon{
  width:36px;height:36px;
  background:rgba(200,151,90,.09);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px;
}
.feat-icon svg{width:16px;height:16px;color:var(--gold)}
.feat-title{font-family:var(--ff);font-size:1rem;font-weight:700;color:#fff;margin-bottom:5px}
.feat-desc{font-size:.82rem;color:rgba(240,234,224,.5);line-height:1.78}

/* ════════════════════════════
   PRICE CARDS (Unterseiten — .pc)
════════════════════════════ */
.price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1px;margin-top:32px}
.pc{background:var(--ink2);padding:26px 22px;border:1px solid transparent;transition:.3s;position:relative;display:flex;flex-direction:column}
.pc:hover{border-color:var(--gold-line)}
.pc.pop{background:var(--ink3);border-color:rgba(200,151,90,.24)}
.pc-hot{position:absolute;top:-1px;right:14px;background:var(--gold);font-family:var(--fb);font-size:.38rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);padding:3px 9px}
.pc-period{font-family:var(--fb);font-size:.44rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:7px}
.pc-name{font-family:var(--ff);font-size:1rem;font-weight:700;color:#fff;margin-bottom:2px}
.pc-slot{font-size:.7rem;color:var(--muted);margin-bottom:14px}
.pc-price{font-family:var(--ff);font-size:2.4rem;font-weight:900;color:#fff;line-height:1;letter-spacing:-.03em}
.pc-price sup{font-size:.62rem;vertical-align:super;font-weight:300;color:var(--gold)}
.pc-vat{font-size:.62rem;color:var(--muted);margin:4px 0 18px}
.pc-list{list-style:none;margin-bottom:20px;flex:1}
.pc-list li{display:flex;align-items:center;gap:8px;font-size:.8rem;color:rgba(240,234,224,.55);padding:5px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.pc-list li:last-child{border-bottom:none}
.pc-list li svg{width:10px;height:10px;color:var(--gold);flex-shrink:0}
/* transport sub-strip */
.transport-strip{margin-top:16px;display:grid;grid-template-columns:repeat(3,1fr);gap:1px}
.ts{background:var(--ink2);padding:14px 16px}
.ts-lbl{font-family:var(--fb);font-size:.42rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:4px}
.ts-val{font-size:.8rem;color:rgba(240,234,224,.5)}
@media(max-width:580px){.transport-strip{grid-template-columns:1fr}}

/* ════════════════════════════
   PRICE GRID (Index — .pf)
════════════════════════════ */
.price-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin-top:38px}
@media(max-width:760px){.price-grid-4{grid-template-columns:1fr 1fr}}
@media(max-width:440px){.price-grid-4{grid-template-columns:1fr}}
.pf{background:var(--ink2);padding:28px 24px;border:1px solid transparent;transition:.35s;position:relative;display:flex;flex-direction:column}
.pf:hover{border-color:var(--gold-line);background:var(--ink3)}
.pf.pop{background:var(--ink3);border-color:rgba(200,151,90,.24)}
.pf-hot{position:absolute;top:-1px;right:14px;background:var(--gold);color:var(--ink);font-family:var(--fb);font-size:.38rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;padding:3px 9px}
.pf-period{font-family:var(--fb);font-size:.44rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:7px}
.pf-name{font-family:var(--ff);font-size:1.05rem;font-weight:700;color:#fff;margin-bottom:2px}
.pf-slot{font-size:.7rem;color:var(--muted);margin-bottom:16px}
.pf-price{font-family:var(--ff);font-size:2.6rem;font-weight:900;color:#fff;line-height:1;letter-spacing:-.04em}
.pf-price sup{font-size:.64rem;vertical-align:super;font-weight:300;color:var(--gold)}
.pf-vat{font-size:.62rem;color:var(--muted);margin:4px 0 18px}
.pf-list{list-style:none;margin-bottom:22px;flex:1}
.pf-list li{display:flex;align-items:center;gap:8px;font-size:.8rem;color:rgba(240,234,224,.55);padding:5px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.pf-list li:last-child{border-bottom:none}
.pf-list li svg{width:10px;height:10px;color:var(--gold);flex-shrink:0}

/* vor-ort beneath prices */
.vor-ort{margin-top:2px;border:1px solid var(--gold-line);background:rgba(200,151,90,.025)}
.vor-ort-head{padding:16px 24px;border-bottom:1px solid rgba(200,151,90,.1);display:flex;align-items:center;gap:10px}
.vor-ort-head svg{width:15px;height:15px;color:var(--gold);flex-shrink:0}
.vor-ort-head span{font-family:var(--fb);font-size:.62rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.vor-ort-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px}
.vor-item{padding:20px 24px;background:var(--ink2)}
.vor-icon-row{display:flex;align-items:center;gap:9px;margin-bottom:10px}
.vor-icon-row svg{width:18px;height:18px;color:var(--gold);flex-shrink:0}
.vor-icon-row span{font-family:var(--fb);font-size:.58rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.vor-val{font-size:1rem;color:var(--cream);margin-bottom:5px;font-weight:500;line-height:1.3}
.vor-note{font-size:.72rem;color:var(--gold);line-height:1.5}
.vor-sub{font-size:.82rem;color:rgba(240,234,224,.45);line-height:1.55}
@media(max-width:580px){.vor-ort-grid{grid-template-columns:1fr}}

/* transport strip (index) */
.ts-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:2px}
.ts-col{background:var(--ink2);padding:14px 18px}
.ts-lbl{font-family:var(--fb);font-size:.48rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:5px}
.ts-val{font-size:.78rem;color:rgba(240,234,224,.62);line-height:1.55;white-space:nowrap}
@media(max-width:500px){.ts-strip{grid-template-columns:1fr}}

/* ════════════════════════════
   COMPARE TABLE
════════════════════════════ */
.cmp-wrap{overflow-x:auto;margin-top:28px}
.cmp{width:100%;border-collapse:collapse;min-width:460px}
.cmp th{
  font-family:var(--fb);font-size:.46rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold);padding:12px 18px;text-align:left;
  border-bottom:1px solid rgba(200,151,90,.2);background:rgba(200,151,90,.04);
}
.cmp td{font-size:.84rem;color:rgba(240,234,224,.56);padding:11px 18px;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:top}
.cmp tr:last-child td{border-bottom:none}
.cmp tr:hover td{background:rgba(200,151,90,.025)}
.yes{color:#7DC48A;font-weight:500}
.no{color:rgba(200,151,90,.28)}

/* ════════════════════════════
   STATS ROW
════════════════════════════ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin:44px 0}
.stat{background:var(--ink2);padding:30px 26px;border:1px solid transparent;transition:.3s}
.stat:hover{border-color:var(--gold-line)}
.stat-num{
  font-family:var(--ff);font-size:3rem;font-weight:900;color:#fff;
  line-height:1;letter-spacing:-.04em;margin-bottom:7px;
  background:linear-gradient(135deg,#fff 30%,var(--gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.stat-label{font-family:var(--fb);font-size:.8rem;color:var(--muted)}
@media(max-width:640px){.stats{grid-template-columns:1fr 1fr}}

/* ════════════════════════════
   PHOTO STRIP / PHOTO DUO
════════════════════════════ */
.photo-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.photo-strip figure{position:relative;overflow:hidden;margin:0;aspect-ratio:4/3}
.photo-strip img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .75s var(--ease)}
.photo-strip figure:hover img{transform:scale(1.05)}
.photo-label{
  position:absolute;top:14px;left:14px;
  background:rgba(7,9,10,.78);backdrop-filter:blur(10px);
  border:1px solid rgba(200,151,90,.22);
  padding:4px 12px;
  font-family:var(--fb);font-size:.48rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);
}
.photo-strip figcaption{
  position:absolute;bottom:0;left:0;right:0;padding:14px 18px;
  background:linear-gradient(transparent,rgba(7,9,10,.9));
  font-family:var(--fb);font-size:.6rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(240,234,224,.7);
}
@media(max-width:640px){.photo-strip{grid-template-columns:1fr}.photo-strip figure{aspect-ratio:16/9}}
.photo-duo{display:grid;grid-template-columns:1fr 1fr;gap:2px;margin-top:28px}
.photo-duo figure{position:relative;overflow:hidden}
.photo-duo img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:.65s var(--ease)}
.photo-duo figure:hover img{transform:scale(1.04)}
.photo-duo figcaption{position:absolute;bottom:0;left:0;right:0;padding:12px 14px;background:linear-gradient(transparent,rgba(7,9,10,.9));font-family:var(--fb);font-size:.56rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:rgba(240,234,224,.62)}
@media(max-width:500px){.photo-duo{grid-template-columns:1fr}}

/* ════════════════════════════
   TRANSPORT CALCULATOR
════════════════════════════ */
.calc-box{background:var(--ink2);border:1px solid var(--gold-line);padding:30px;margin-bottom:2px}
.calc-label{font-family:var(--fb);font-size:.44rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.calc-row{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:end;max-width:560px}
.calc-result{padding:12px 20px;background:rgba(200,151,90,.07);border:1px solid rgba(200,151,90,.22);text-align:center;white-space:nowrap;display:none;min-width:100px}
.calc-result-label{font-family:var(--fb);font-size:.4rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:3px}
.calc-result-val{font-family:var(--ff);font-size:1.7rem;font-weight:900;color:#fff;line-height:1}
.calc-detail{margin-top:12px;font-size:.8rem;color:rgba(240,234,224,.42);display:none}
.calc-total{margin-top:10px;padding:12px 18px;background:rgba(200,151,90,.05);border-left:1px solid var(--gold);display:none}
.calc-total-label{font-family:var(--fb);font-size:.44rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.calc-total-val{font-family:var(--ff);font-size:1.4rem;font-weight:900;color:#fff;margin-left:10px}
/* custom dropdown */
.cd-wrap{position:relative;user-select:none}
.cd-trigger{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  background:rgba(255,255,255,.025);border:1px solid rgba(200,151,90,.16);
  color:var(--cream);font-family:var(--fb);font-size:.87rem;
  padding:11px 14px;cursor:pointer;transition:.22s;width:100%;
}
.cd-trigger:hover{border-color:rgba(200,151,90,.36)}
.cd-trigger.open{border-color:rgba(200,151,90,.48)}
.cd-trigger svg{width:13px;height:13px;color:var(--gold);flex-shrink:0;transition:transform .25s}
.cd-trigger.open svg{transform:rotate(180deg)}
.cd-trigger .cd-val{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cd-trigger .cd-ph{color:var(--muted)}
.cd-list{position:absolute;top:calc(100% + 3px);left:0;right:0;z-index:300;background:var(--ink2);border:1px solid rgba(200,151,90,.22);max-height:260px;overflow-y:auto;box-shadow:0 16px 48px rgba(0,0,0,.7);display:none}
.cd-opt{padding:10px 14px;font-family:var(--fb);font-size:.85rem;color:rgba(240,234,224,.62);cursor:pointer;border-bottom:1px solid rgba(200,151,90,.05);transition:.18s}
.cd-opt:last-child{border-bottom:none}
.cd-opt:hover{background:rgba(200,151,90,.07);color:var(--cream)}
.cd-opt.selected{background:rgba(200,151,90,.1);color:var(--gold)}
.cd-opt.ph{color:var(--muted);font-style:italic}

/* ════════════════════════════
   CITIES
════════════════════════════ */
.city-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1px;margin-top:34px}
.city-a,.city{
  background:var(--ink2);padding:18px 16px;
  border:1px solid transparent;transition:.28s;text-decoration:none;display:block;
}
.city-a:hover,.city:hover{border-color:var(--gold-line);background:var(--ink3)}
.city-name{font-family:var(--ff);font-size:.95rem;font-weight:700;color:#fff;margin-bottom:2px}
.city-dist{font-size:.66rem;color:var(--muted)}
.city-arr{font-size:.62rem;color:var(--gold);display:block;margin-top:7px;transition:.22s}
.city-a:hover .city-arr,.city:hover .city-arr{transform:translateX(5px)}

/* ════════════════════════════
   REVIEWS
════════════════════════════ */
.rv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(275px,1fr));gap:1px;margin-top:34px}
.rv{background:var(--ink2);padding:28px 26px;border:1px solid transparent;transition:.28s;position:relative}
.rv:hover{border-color:var(--gold-line)}
.rv-quote{position:absolute;top:16px;right:20px;font-family:var(--ff);font-size:4rem;font-weight:900;color:rgba(200,151,90,.07);line-height:1}
.rv-stars{display:flex;gap:3px;margin-bottom:12px}
.rv-stars svg{width:11px;height:11px;color:var(--gold)}
.rv-text{font-family:var(--ff);font-weight:300;font-style:italic;font-size:.9rem;color:rgba(240,234,224,.65);line-height:1.82;margin-bottom:14px}
.rv-who{font-family:var(--fb);font-size:.48rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}

/* ════════════════════════════
   FAQ
════════════════════════════ */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;margin-top:34px}
.fq{background:var(--ink2);padding:24px 26px;border:1px solid transparent;transition:.28s}
.fq:hover{border-color:var(--gold-line)}
.fq-q{font-family:var(--ff);font-size:.94rem;font-weight:700;color:#fff;margin-bottom:8px;line-height:1.35}
.fq-a{font-size:.83rem;color:rgba(240,234,224,.5);line-height:1.82}
@media(max-width:640px){.faq-grid{grid-template-columns:1fr}}

/* ════════════════════════════
   CONTACT FORM (LUXURY)
════════════════════════════ */
.contact-split{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px,5vw,88px);align-items:start;margin-top:44px}
.ci h3{font-family:var(--ff);font-size:1.6rem;font-weight:700;color:#fff;margin-bottom:12px;letter-spacing:-.02em}
.ci p{font-size:.88rem;color:rgba(240,234,224,.48);line-height:1.88;margin-bottom:24px}
.clist{list-style:none}
.clist li{display:flex;align-items:center;gap:13px;font-size:.86rem;color:rgba(240,234,224,.52);padding:11px 0;border-bottom:1px solid rgba(200,151,90,.07)}
.clist li:last-child{border-bottom:none}
.clist li svg{width:13px;height:13px;color:var(--gold);flex-shrink:0}
.clist a{color:rgba(240,234,224,.52)}.clist a:hover{color:var(--gold)}
.cta-tel{
  display:inline-flex;align-items:center;gap:10px;margin-top:26px;
  font-family:var(--ff);font-size:1.65rem;font-weight:700;
  color:var(--gold);text-decoration:none;letter-spacing:-.02em;transition:.25s;
}
.cta-tel:hover{color:var(--gold2)}
.cta-tel svg{width:18px;height:18px}
/* Form box */
.form-box{background:var(--ink2);padding:38px;border:1px solid var(--gold-line)}
.fi{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.fi label{
  font-family:var(--fb);font-size:.44rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);
}
.fi input,.fi textarea,.fi select{
  background:rgba(255,255,255,.022);
  border:none;border-bottom:1px solid rgba(200,151,90,.18);
  color:var(--cream);font-family:var(--fb);font-size:.88rem;
  padding:11px 2px;outline:none;transition:.22s;width:100%;
  color-scheme:dark;
}
.fi input::placeholder,.fi textarea::placeholder{color:var(--muted)}
.fi input:focus,.fi textarea:focus,.fi select:focus{
  border-bottom-color:rgba(200,151,90,.55);
  background:rgba(200,151,90,.02);
}
.fi select option{background:var(--ink2);color:var(--cream)}
.fi textarea{min-height:90px;resize:vertical;line-height:1.65;padding:11px 2px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:460px){.frow{grid-template-columns:1fr}}
.form-note{font-size:.7rem;color:var(--muted);margin-top:10px;line-height:1.65}
.al{padding:12px 16px;font-size:.84rem;margin-bottom:12px;display:none}
.al-ok{background:rgba(74,130,90,.1);border:1px solid rgba(74,130,90,.2);color:#7DC48A}
.al-err{background:rgba(180,60,60,.09);border:1px solid rgba(180,60,60,.18);color:#E08080}
@media(max-width:720px){.contact-split{grid-template-columns:1fr}}

/* ════════════════════════════
   AI / GEMINI BADGE
════════════════════════════ */
.ai-badge{
  background:rgba(200,151,90,.05);border:1px solid var(--gold-line);
  padding:22px 28px;display:flex;align-items:center;gap:20px;
  margin-top:2px;text-decoration:none;transition:.25s;
}
.ai-badge:hover{border-color:rgba(200,151,90,.35);background:rgba(200,151,90,.08)}
.ai-badge-icon{
  flex-shrink:0;width:44px;height:44px;
  background:rgba(200,151,90,.1);border:1px solid rgba(200,151,90,.22);
  display:flex;align-items:center;justify-content:center;font-size:22px;
}
.ai-badge-label{font-family:var(--fb);font-size:.46rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:3px}
.ai-badge-copy{font-family:var(--ff);font-size:.96rem;font-weight:700;color:#fff;line-height:1.25}
.ai-badge-sub{font-family:var(--fb);font-size:.78rem;color:rgba(240,234,224,.42);margin-top:3px;line-height:1.55}

/* ════════════════════════════
   SEO TEXT
════════════════════════════ */
.seo-sec{padding:clamp(40px,5vw,76px) clamp(24px,5vw,72px)}
.seo-inner{max-width:820px;margin:0 auto}
.seo-inner h2{font-family:var(--ff);font-size:1.04rem;font-weight:700;color:#fff;margin:30px 0 10px;border-top:1px solid rgba(200,151,90,.07);padding-top:26px}
.seo-inner h2:first-child{border-top:none;margin-top:0;padding-top:0}
.seo-inner p{font-size:.875rem;color:rgba(240,234,224,.42);line-height:1.9;margin-bottom:10px;text-wrap:pretty}
.seo-inner strong{color:rgba(240,234,224,.78);font-weight:500}
.seo-inner a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}

/* ════════════════════════════
   BIERZELT PARTNER SECTION
════════════════════════════ */
.bierzelt-sec{background:var(--ink2);padding:clamp(60px,8vw,110px) clamp(24px,5vw,72px)}
.bierzelt-inner{max-width:1260px;margin:0 auto}
.bierzelt-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(44px,6vw,96px);align-items:center;margin-top:44px}
.bierzelt-imgs{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.bierzelt-imgs img{width:100%;aspect-ratio:3/4;object-fit:cover;display:block;transition:.6s var(--ease)}
.bierzelt-imgs img:hover{transform:scale(1.03)}
.bierzelt-text p{font-size:.92rem;color:rgba(240,234,224,.58);line-height:1.88;margin-bottom:16px}
.bierzelt-text strong{color:var(--cream);font-weight:500}
.bierzelt-meta{font-size:.78rem;color:var(--muted);margin-top:22px;line-height:1.7}
@media(max-width:720px){.bierzelt-grid{grid-template-columns:1fr}.bierzelt-imgs{grid-template-columns:1fr 1fr}}

/* ════════════════════════════
   REQUIREMENTS BLOCK
════════════════════════════ */
.req-sec{background:var(--ink1);padding:clamp(52px,6vw,90px) clamp(24px,5vw,72px)}
.req-inner{max-width:1260px;margin:0 auto}
.req-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:36px}
@media(max-width:700px){.req-grid{grid-template-columns:1fr}}
.req-item{background:var(--ink2);padding:30px 28px;border:1px solid transparent;transition:.3s}
.req-item:hover{border-color:var(--gold-line)}
.req-icon{width:56px;height:56px;background:rgba(200,151,90,.07);border:1px solid rgba(200,151,90,.15);display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.req-icon svg{width:26px;height:26px;color:var(--gold)}
.req-label{font-family:var(--fb);font-size:.52rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.req-val{font-family:var(--ff);font-size:1.2rem;font-weight:700;color:#fff;line-height:1.25;margin-bottom:6px}
.req-note{font-size:.78rem;color:var(--gold);line-height:1.55}
.req-sub{font-size:.82rem;color:rgba(240,234,224,.42);line-height:1.55}
.req-warn{background:rgba(200,151,90,.05);border-color:rgba(200,151,90,.18)}

/* ════════════════════════════
   HERO (INDEX)
════════════════════════════ */
.hero{min-height:auto;position:relative;overflow:hidden;display:grid}
.hero-bg{
  position:absolute;inset:0;
  background-image:url('aussen.jpg');
  background-size:cover;background-position:22% center;
  background-color:#1a2a1e;will-change:transform;
}
.hero-bg::after{
  content:'';position:absolute;inset:0;
  background:
    linear-gradient(to right,
      rgba(7,9,10,.0) 0%,
      rgba(7,9,10,.12) 28%,
      rgba(7,9,10,.72) 50%,
      rgba(7,9,10,.97) 62%,
      rgba(7,9,10,1) 100%
    ),
    linear-gradient(to bottom,
      rgba(7,9,10,.3) 0%,
      transparent 14%,
      rgba(7,9,10,.44) 72%,
      var(--ink) 100%
    );
}
.hero-inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns:minmax(300px,680px);
  align-items:flex-start;
  padding:calc(var(--nav-h) + 24px) clamp(24px,4vw,64px) 52px;
  gap:0;
}
.hero-kicker{
  font-family:var(--ff);font-size:clamp(1.05rem,1.5vw,1.4rem);
  font-weight:300;font-style:italic;color:#fff;
  margin-bottom:clamp(12px,2vh,20px);
  opacity:0;animation:revealUp .8s var(--ease) .2s forwards;
  padding-bottom:7px;border-bottom:1px solid var(--gold);display:inline-block;
  text-shadow:0 2px 24px rgba(0,0,0,.9);
}
h1.hero-h{
  font-family:var(--ff);
  font-size:clamp(3rem,5.4vw,5.4rem);
  font-weight:900;line-height:.9;letter-spacing:-.034em;color:#fff;
  margin-bottom:clamp(10px,1.5vh,18px);
  opacity:0;animation:revealUp .9s var(--ease) .28s forwards;
}
h1.hero-h .ital{
  font-style:italic;font-weight:300;color:var(--gold);
  display:block;line-height:1;margin-top:5px;font-size:.72em;
}
.hero-lead{
  font-size:clamp(.9rem,1.1vw,1.02rem);color:rgba(240,234,224,.7);
  line-height:1.78;max-width:480px;
  margin-bottom:clamp(20px,3vh,36px);
  opacity:0;animation:revealUp .8s var(--ease) .38s forwards;
}
.hero-lead strong{color:var(--cream);font-weight:500}
.hero-cta-row{
  display:flex;gap:12px;flex-wrap:wrap;
  margin-bottom:clamp(22px,3vh,38px);
  opacity:0;animation:revealUp .8s var(--ease) .48s forwards;
}
.hero-tags{
  display:flex;flex-wrap:wrap;gap:6px;
  opacity:0;animation:revealUp .7s var(--ease) .58s forwards;
}
.tag{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 12px;
  border:1px solid rgba(200,151,90,.14);
  font-family:var(--fb);font-size:.64rem;color:rgba(240,234,224,.5);
  transition:.25s;
}
.tag:hover{border-color:rgba(200,151,90,.35);color:var(--cream)}
.tag-dot{width:4px;height:4px;border-radius:50%;background:var(--gold);flex-shrink:0}
/* HERO RIGHT — PRICE TABLE */
.hero-right{
  display:flex;flex-direction:column;
  opacity:0;animation:revealUp .9s var(--ease) .42s forwards;
  width:480px;flex-shrink:0;
  background:rgba(7,9,10,.88);
  backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
  border:1px solid rgba(200,151,90,.16);
}
.pt-header{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:18px 24px 14px;border-bottom:1px solid rgba(200,151,90,.1);
}
.pt-title{font-family:var(--ff);font-size:1.05rem;font-weight:700;color:#fff;letter-spacing:-.01em}
.pt-sub{font-size:.68rem;color:var(--gold);opacity:.7}
.pt-body{display:flex;flex-direction:column}
.pt-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;border-bottom:1px solid rgba(200,151,90,.07);
  position:relative;transition:.25s;cursor:default;
}
.pt-row:last-of-type{border-bottom:none}
.pt-row:hover{background:rgba(200,151,90,.04)}
.pt-row.pt-hot{background:rgba(200,151,90,.07);border-bottom-color:rgba(200,151,90,.16)}
.pt-badge{
  position:absolute;top:8px;right:80px;
  background:var(--gold);color:var(--ink);
  font-family:var(--fb);font-size:.4rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  padding:2px 8px;
}
.pt-left{display:flex;flex-direction:column;gap:1px}
.pt-period{font-family:var(--fb);font-size:.52rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.pt-name{font-family:var(--ff);font-size:1.05rem;font-weight:700;color:#fff;line-height:1.1}
.pt-slot{font-size:.72rem;color:var(--muted)}
.pt-price{font-family:var(--ff);font-size:2.6rem;font-weight:900;color:#fff;letter-spacing:-.04em;line-height:1;display:flex;align-items:flex-start}
.pt-eur{font-size:.85rem;font-weight:300;margin-right:1px;margin-top:5px;color:var(--gold)}
/* HERO RIGHT — REQUIREMENTS */
.pt-req{border-top:1px solid rgba(200,151,90,.16)}
.pt-req-title{
  display:flex;align-items:center;gap:8px;padding:12px 24px;
  font-family:var(--fb);font-size:.54rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);border-bottom:1px solid rgba(200,151,90,.08);
}
.pt-req-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px}
.pt-req-item{padding:14px 18px;background:rgba(0,0,0,.2)}
.pt-req-item.pt-req-warn{background:rgba(200,151,90,.08)}
.pt-req-label{font-family:var(--fb);font-size:.5rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:5px}
.pt-req-val{font-size:.9rem;color:var(--cream);line-height:1.3;margin-bottom:2px;font-weight:500}
.pt-req-sub{font-size:.74rem;color:rgba(240,234,224,.38);line-height:1.5;margin-top:2px}
@media(max-width:920px){
  .hero-inner{grid-template-columns:1fr;gap:24px;padding:calc(var(--nav-h) + 26px) clamp(20px,4vw,48px) clamp(34px,5vh,56px)}
  .hero-right{width:100%}
  h1.hero-h{font-size:clamp(2.6rem,8vw,4rem)}
  .pt-req-grid{grid-template-columns:1fr}
}

/* ════════════════════════════
   CONTACT (index inline section)
════════════════════════════ */
.quick-form-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(44px,6vw,88px);
  align-items:start;margin-top:44px;
}
@media(max-width:720px){.quick-form-grid{grid-template-columns:1fr}}

/* ════════════════════════════
   FOOTER
════════════════════════════ */
.foot{
  background:var(--ink1);
  border-top:1px solid rgba(200,151,90,.08);
  padding:clamp(44px,6vw,80px) clamp(24px,5vw,72px) 28px;
}
.foot-grid{max-width:1260px;margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:clamp(28px,4vw,60px)}
.fb-name{font-family:var(--ff);font-size:1.08rem;font-weight:700;color:#fff;letter-spacing:-.01em;margin-bottom:2px}
.fb-sub{font-family:var(--fb);font-size:.44rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:14px}
.fb-desc{font-size:.78rem;color:var(--muted);line-height:1.82;margin-bottom:14px}
.fb-tel{display:inline-flex;align-items:center;gap:8px;font-family:var(--ff);font-size:1rem;font-weight:700;color:var(--gold);text-decoration:none;transition:.22s}
.fb-tel:hover{color:var(--gold2)}
.fb-tel svg{width:13px;height:13px}
.fc h4{font-family:var(--fb);font-size:.44rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.fc ul{list-style:none}
.fc li{padding:3px 0}
.fc a{font-size:.78rem;color:var(--muted);transition:.22s}
.fc a:hover{color:var(--cream)}
.foot-btm{
  max-width:1260px;margin:30px auto 0;padding-top:20px;
  border-top:1px solid rgba(200,151,90,.06);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;
}
.foot-btm p,.foot-btm a{font-size:.7rem;color:var(--muted)}
.foot-btm a:hover{color:var(--gold)}
.flinks{display:flex;gap:18px}
@media(max-width:640px){.foot-grid{grid-template-columns:1fr}.foot-btm{flex-direction:column;text-align:center}}

/* ════════════════════════════
   NOTICE / WARNING BLOCKS
════════════════════════════ */
.notice{
  display:flex;align-items:flex-start;gap:16px;
  padding:18px 24px;
  background:var(--ink2);border:1px solid var(--gold-line);
  margin-top:1px;
}
.notice-icon{color:var(--gold);font-size:1rem;font-weight:700;flex-shrink:0;margin-top:1px;font-family:var(--ff)}
.notice-title{font-family:var(--fb);font-size:.84rem;font-weight:700;color:var(--cream);margin-bottom:5px}
.notice-text{font-size:.8rem;color:rgba(240,234,224,.48);line-height:1.7}
.notice-danger{background:rgba(28,12,12,.8);border-color:rgba(180,60,60,.28)}
.notice-danger .notice-icon{color:rgba(210,80,80,.8)}
.notice-danger .notice-title{color:rgba(240,180,180,.85)}
.notice-danger .notice-text{color:rgba(230,160,160,.44)}

/* ════════════════════════════
   DATE INPUT
════════════════════════════ */
input[type="date"]{color-scheme:dark;cursor:pointer}
input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(72%) sepia(40%) saturate(400%) hue-rotate(5deg) brightness(95%);cursor:pointer;opacity:.8}

/* ════════════════════════════
   FEAT SPLIT (two-col with image)
════════════════════════════ */
.feat-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(48px,6vw,96px);align-items:center}
.feat-img-wrap{position:relative;overflow:hidden}
.feat-img-wrap img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;transition:transform .8s var(--ease)}
.feat-img-wrap:hover img{transform:scale(1.04)}
.feat-img-wrap::before{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(135deg,rgba(200,151,90,.07),transparent 60%);pointer-events:none}
.feat-cap{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:14px 18px;background:linear-gradient(transparent,rgba(7,9,10,.88));font-family:var(--fb);font-size:.56rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(240,234,224,.6)}
.feat-list{list-style:none;margin:28px 0}
.feat-list li{display:flex;align-items:flex-start;gap:14px;padding:16px 0;border-bottom:1px solid rgba(200,151,90,.07)}
.feat-list li:last-child{border-bottom:none}
.feat-list li svg{width:16px;height:16px;color:var(--gold);flex-shrink:0;margin-top:3px}
.feat-list-title{font-family:var(--ff);font-size:.93rem;font-weight:700;color:#fff;margin-bottom:4px}
.feat-list-desc{font-size:.82rem;color:rgba(240,234,224,.5);line-height:1.75}
@media(max-width:760px){.feat-split{grid-template-columns:1fr}}

/* ════════════════════════════
   PREREQUISITES STRIP
════════════════════════════ */
.prereq-strip{
  background:var(--ink1);
  border-top:1px solid var(--gold-line);
  border-bottom:2px solid rgba(200,151,90,.3);
  padding:clamp(52px,7vw,96px) clamp(18px,4vw,64px);
}
.prereq-inner{max-width:1320px;margin:0 auto}
.prereq-head{
  display:flex;align-items:center;gap:14px;
  font-family:var(--fb);font-size:clamp(.82rem,1.3vw,1rem);
  font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:var(--gold);margin-bottom:32px;
}
.prereq-head em{font-style:normal;color:rgba(240,234,224,.55);font-weight:400;text-transform:none;letter-spacing:0}
.prereq-head svg{flex-shrink:0;color:var(--gold)}
.prereq-cards{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--gold-line);
  margin-bottom:1px;
}
.prereq-card{
  background:var(--ink2);
  padding:32px 28px;
  display:flex;align-items:flex-start;gap:20px;
  transition:.28s;
}
.prereq-card:hover{background:var(--ink3)}
.prereq-icon{
  width:60px;height:60px;flex-shrink:0;
  background:rgba(200,151,90,.1);
  border:1px solid rgba(200,151,90,.2);
  display:flex;align-items:center;justify-content:center;
}
.prereq-icon svg{width:26px;height:26px;color:var(--gold)}
.prereq-text{display:flex;flex-direction:column;gap:3px}
.prereq-label{
  font-family:var(--fb);font-size:.58rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--gold);
}
.prereq-val{
  font-family:var(--ff);font-size:clamp(1rem,1.6vw,1.2rem);font-weight:700;
  color:#fff;line-height:1.2;white-space:nowrap;
}
.prereq-note{font-size:.84rem;color:var(--muted);line-height:1.55}
.prereq-warning{
  background:rgba(180,60,60,.08);
  border:1px solid rgba(180,60,60,.25);
  padding:20px 28px;
  display:flex;align-items:center;gap:16px;
  color:rgba(230,160,160,.85);
}
.prereq-warning svg{flex-shrink:0;stroke:rgba(210,80,80,.7)}
@media(max-width:700px){
  .prereq-cards{grid-template-columns:1fr}
  .prereq-card{padding:18px 16px}
}

/* ════════════════════════════
   HORIZONTAL PRICE STRIP
════════════════════════════ */
.pstrip{
  background:var(--ink);
  border-bottom:1px solid var(--gold-line);
  padding:0 clamp(18px,4vw,64px);
}
.pstrip-inner{max-width:1320px;margin:0 auto}
.pstrip-meta{
  display:flex;align-items:baseline;gap:16px;
  padding:20px 0 14px;
  border-bottom:1px solid rgba(200,151,90,.08);
}
.pstrip-title{
  font-family:var(--ff);font-size:1.1rem;font-weight:700;color:#fff;letter-spacing:-.01em;
}
.pstrip-sub{font-family:var(--fb);font-size:.58rem;color:var(--muted);letter-spacing:.04em}
.pstrip-cards{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--gold-line);
  margin-bottom:0;
}
.pstrip-card{
  background:var(--ink1);
  padding:22px 22px 20px;
  position:relative;display:flex;flex-direction:column;
  transition:.28s;border-bottom:2px solid transparent;
}
.pstrip-card:hover{background:var(--ink2);border-bottom-color:var(--gold)}
.pstrip-card--hot{
  background:var(--ink2);
  border-bottom:2px solid var(--gold);
}
.pstrip-card--hot:hover{background:var(--ink3)}
.pstrip-badge{
  position:absolute;top:0;right:16px;
  background:var(--gold);color:var(--ink);
  font-family:var(--fb);font-size:.38rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  padding:3px 9px;
}
.pstrip-period{
  font-family:var(--fb);font-size:.44rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:4px;
}
.pstrip-name{
  font-family:var(--ff);font-size:1.15rem;font-weight:700;color:#fff;
  line-height:1.1;margin-bottom:2px;
}
.pstrip-slot{font-size:.7rem;color:var(--muted);margin-bottom:14px}
.pstrip-price{
  font-family:var(--ff);font-size:2.8rem;font-weight:900;color:#fff;
  line-height:1;letter-spacing:-.04em;margin-bottom:16px;flex:1;
  display:flex;align-items:flex-start;
}
.pstrip-price sup{
  font-size:.58rem;font-weight:300;color:var(--gold);
  margin-top:6px;margin-right:1px;
}
.pstrip-btn{
  display:flex;align-items:center;justify-content:center;
  padding:9px 16px;
  border:1px solid rgba(200,151,90,.25);
  font-family:var(--fb);font-size:.52rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);text-decoration:none;transition:.28s;
}
.pstrip-btn:hover{border-color:rgba(200,151,90,.6);background:rgba(200,151,90,.06);color:var(--gold)}
.pstrip-btn--gold{
  background:var(--gold);color:var(--ink);border-color:var(--gold);
}
.pstrip-btn--gold:hover{background:var(--gold2);border-color:var(--gold2);color:var(--ink)}
/* Responsive */
@media(max-width:720px){
  .pstrip-cards{grid-template-columns:1fr 1fr}
  .pstrip-price{font-size:2.2rem}
}
@media(max-width:420px){
  .pstrip-cards{grid-template-columns:1fr}
  .pstrip-card{flex-direction:row;align-items:center;flex-wrap:wrap;gap:8px;padding:16px}
  .pstrip-period,.pstrip-slot{display:none}
  .pstrip-name{flex:1;font-size:1rem}
  .pstrip-price{font-size:1.8rem;margin-bottom:0;flex:none}
  .pstrip-btn{flex:none;padding:8px 14px}
}

/* ════════════════════════════
   TRANSPORT CALCULATOR STRIP
════════════════════════════ */
.tcalc-strip{
  background:var(--ink2);
  border-top:1px solid var(--gold-line);
  border-bottom:1px solid var(--gold-line);
  padding:clamp(40px,5vw,72px) clamp(18px,4vw,64px);
}
.tcalc-inner{max-width:1320px;margin:0 auto}

/* Header */
.tcalc-head{margin-bottom:32px}
.tcalc-title{
  font-family:var(--ff);font-size:clamp(1.8rem,3.5vw,2.8rem);
  font-weight:900;color:#fff;line-height:1;letter-spacing:-.03em;
  margin-bottom:10px;
}
.tcalc-rule{
  display:inline-flex;flex-wrap:wrap;align-items:center;gap:10px;
  margin-top:14px;
  padding:12px 20px;
  background:rgba(200,151,90,.08);
  border:1px solid rgba(200,151,90,.28);
  border-left:3px solid var(--gold);
  font-size:clamp(.8rem,1vw,.92rem);
  color:rgba(240,234,224,.75);line-height:1.65;
}
.tcalc-rule strong{color:var(--gold);font-weight:600}

/* Body — stacked layout: inputs top, results bottom */
.tcalc-body{
  display:flex;
  flex-direction:column;
  gap:24px;
}
.tcalc-field-group{
  display:flex;gap:16px;align-items:flex-end;flex-wrap:wrap;
}
.tcalc-results{
  display:flex;align-items:center;gap:clamp(10px,2vw,24px);
  flex-wrap:wrap;
}
.tcalc-field{display:flex;flex-direction:column;gap:6px}
.tcalc-field label{
  font-family:var(--fb);font-size:.72rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--gold);
}
.tcalc-field input,
.tcalc-field select{
  background:rgba(255,255,255,.03);
  border:none;border-bottom:2px solid rgba(200,151,90,.28);
  color:var(--cream);font-family:var(--ff);font-size:1.3rem;font-weight:700;
  padding:8px 4px;outline:none;transition:.22s;
  color-scheme:dark;
}
.tcalc-field input{width:130px}
.tcalc-field select{
  width:260px;
  font-family:var(--fb);font-size:.95rem;font-weight:400;
}
.tcalc-field input:focus,
.tcalc-field select:focus{
  border-bottom-color:var(--gold);
  background:rgba(200,151,90,.03);
}
.tcalc-field select option{background:var(--ink2)}

/* Results */
.tcalc-results{
  display:flex;align-items:center;gap:clamp(14px,2vw,28px);
  flex-wrap:wrap;
}
.tcalc-sub-results{
  display:flex;align-items:center;gap:clamp(8px,1.5vw,18px);
}
.tcalc-result-box{
  display:flex;flex-direction:column;gap:4px;
  padding:14px 20px;
  background:rgba(255,255,255,.025);
  border:1px solid rgba(200,151,90,.12);
  min-width:110px;text-align:center;
  transition:.25s;
}
.tcalc-result-total{
  display:flex;flex-direction:column;gap:4px;
  padding:18px 32px;
  background:rgba(200,151,90,.1);
  border:2px solid var(--gold);
  text-align:center;
  transition:.3s;
}
.tcalc-result-total .tcalc-result-label{color:var(--gold)}
.tcalc-result-total .tcalc-result-val{
  font-size:clamp(2rem,3.5vw,2.8rem);
  color:var(--gold);
  font-weight:900;letter-spacing:-.04em;
}
.tcalc-result-label{
  font-family:var(--fb);font-size:.42rem;font-weight:600;
  letter-spacing:.24em;text-transform:uppercase;color:rgba(200,151,90,.7);
}
.tcalc-result-val{
  font-family:var(--ff);font-size:1.5rem;font-weight:900;
  color:#fff;line-height:1;letter-spacing:-.03em;
  transition:.3s;
}
.tcalc-result-plus,
.tcalc-result-equals{
  font-family:var(--ff);font-size:1.4rem;font-weight:300;
  color:rgba(200,151,90,.4);flex-shrink:0;
}
.tcalc-anfragen{flex-shrink:0;align-self:stretch;display:flex;align-items:center}

/* Hide number input spinners */
.tcalc-field input[type=number]::-webkit-inner-spin-button,
.tcalc-field input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.tcalc-field input[type=number]{-moz-appearance:textfield}
/* Checkbox extra option */
.tcalc-check-field{justify-content:flex-end}
.tcalc-check-label{
  display:flex;align-items:flex-start;gap:12px;cursor:pointer;
  padding:12px 16px;
  border:1px solid rgba(200,151,90,.18);
  background:rgba(255,255,255,.02);
  transition:.22s;
}
.tcalc-check-label:hover{border-color:rgba(200,151,90,.42);background:rgba(200,151,90,.04)}
.tcalc-check-label input[type="checkbox"]{display:none}
.tcalc-check-box{
  width:18px;height:18px;flex-shrink:0;margin-top:2px;
  border:1px solid rgba(200,151,90,.4);
  background:transparent;transition:.22s;position:relative;
}
.tcalc-check-label input:checked + .tcalc-check-box{
  background:var(--gold);border-color:var(--gold);
}
.tcalc-check-label input:checked + .tcalc-check-box::after{
  content:'';position:absolute;left:4px;top:1px;
  width:6px;height:10px;
  border:2px solid var(--ink);border-top:none;border-left:none;
  transform:rotate(45deg);
}
.tcalc-check-title{display:block;font-family:var(--fb);font-size:.72rem;font-weight:600;color:var(--cream);margin-bottom:3px}
.tcalc-check-sub{display:block;font-size:.64rem;color:var(--muted)}
.tcalc-check-sub strong{color:var(--gold);font-weight:600}


.tcalc-hint{
  margin-top:14px;
  font-size:.54rem;color:var(--muted);letter-spacing:.03em;line-height:1.6;
}

/* Responsive */
@media(max-width:900px){
  .tcalc-field-group{flex-wrap:wrap;gap:12px}
  .tcalc-field input{width:100%}
  .tcalc-field select{width:100%}
  .tcalc-field{flex:1;min-width:140px}
  .tcalc-results{gap:10px}
  .tcalc-result-box{flex:1;min-width:90px;padding:12px 14px}
  .tcalc-anfragen{width:100%;justify-content:center;margin-left:0;margin-top:4px}
  .tcalc-check-field{width:100%}
}
@media(max-width:500px){
  .tcalc-result-plus,.tcalc-result-equals{font-size:1rem}
  .tcalc-result-val{font-size:1.3rem}
  .tcalc-result-box--total .tcalc-result-val{font-size:1.5rem}
}



/* ── Tablet (≤ 920px) ── */
@media(max-width:920px){
  :root{--nav-h:68px}

  /* Hero */
  .hero-inner{
    grid-template-columns:1fr;
    justify-content:stretch;
    margin-left:0;
    padding:calc(var(--nav-h) + 24px) clamp(18px,4vw,40px) 36px;
    gap:20px;
  }
  .hero-right{width:100%}
  h1.hero-h{font-size:clamp(2.4rem,7.5vw,3.8rem)}
  .pt-req-grid{grid-template-columns:1fr 1fr}
  .pt-req-grid .pt-req-item:first-child{grid-column:1/-1}

  /* Price grid */
  .price-grid-4{grid-template-columns:1fr 1fr}

  /* Sections */
  .sec{padding:clamp(44px,6vw,80px) clamp(18px,4vw,40px)}
  .req-sec,.bierzelt-sec{padding:clamp(44px,6vw,80px) clamp(18px,4vw,40px)}

  /* Bierzelt */
  .bierzelt-grid{grid-template-columns:1fr;gap:36px}

  /* Contact */
  .contact-split{grid-template-columns:1fr;gap:36px}

  /* Stats */
  .stats{grid-template-columns:1fr 1fr}

  /* Footer */
  .foot-grid{grid-template-columns:1fr 1fr}
}

/* ── Mobile (≤ 600px) ── */
@media(max-width:600px){
  :root{--nav-h:60px}

  /* Hero image — show more on narrow screens */
  .hero-bg{background-position:35% center}
  .hero-bg::after{
    background:
      linear-gradient(to bottom,
        rgba(7,9,10,.5) 0%,
        rgba(7,9,10,.7) 38%,
        rgba(7,9,10,.93) 72%,
        var(--ink) 100%
      );
  }

  /* Typography */
  h1.hero-h{font-size:clamp(2.2rem,10vw,3.2rem);line-height:.92}
  .hero-kicker{font-size:.95rem}
  .hero-lead{font-size:.88rem}
  h2.sh{font-size:clamp(1.5rem,6vw,2.2rem)}

  /* Hero buttons */
  .hero-cta-row{flex-direction:column;gap:10px}
  .hero-cta-row .btn{width:100%;justify-content:center}

  /* Hero tags */
  .hero-tags{gap:5px}
  .tag{font-size:.62rem;padding:5px 10px}

  /* Price table in hero */
  .pt-price{font-size:2rem}
  .pt-name{font-size:.9rem}
  .pt-req-grid{grid-template-columns:1fr}

  /* Photo strip */
  .photo-strip{grid-template-columns:1fr}
  .photo-strip figure{aspect-ratio:16/9}

  /* Requirements grid */
  .req-grid{grid-template-columns:1fr}

  /* Vor-ort grid */
  .vor-ort-grid{grid-template-columns:1fr}

  /* Prices */
  .price-grid-4{grid-template-columns:1fr}
  .price-grid{grid-template-columns:1fr}
  .pc{padding:22px 18px}
  .pf{padding:22px 18px}

  /* Transport table */
  .ts-strip{grid-template-columns:1fr}
  .cmp{min-width:380px}

  /* Stats */
  .stats{grid-template-columns:1fr 1fr}
  .stat{padding:20px 16px}
  .stat-num{font-size:2.2rem}

  /* City grid */
  .city-grid{grid-template-columns:1fr 1fr}

  /* Reviews */
  .rv-grid{grid-template-columns:1fr}

  /* FAQ */
  .faq-grid{grid-template-columns:1fr}

  /* Bierzelt images */
  .bierzelt-imgs{grid-template-columns:1fr 1fr}

  /* Contact form */
  .frow{grid-template-columns:1fr}
  .form-box{padding:24px 18px}

  /* CTA tel */
  .cta-tel{font-size:1.3rem}

  /* Footer */
  .foot-grid{grid-template-columns:1fr}
  .foot-btm{flex-direction:column;text-align:center}

  /* Calc */
  .calc-row{grid-template-columns:1fr}
  .calc-result{display:none!important}

  /* Page hero (subpages) */
  h1.ph-h1{font-size:clamp(2rem,8vw,3rem)}
  .page-hero{padding:calc(var(--nav-h) + 28px) 18px 36px}

  /* Sections padding */
  .sec{padding:36px 18px}
  .seo-sec{padding:32px 18px}
  .req-sec,.bierzelt-sec{padding:36px 18px}
  .foot{padding:36px 18px 22px}

  /* Ticker */
  .ti{font-size:.48rem;gap:14px;padding:0 18px}

  /* Buttons */
  .btn{padding:12px 20px;font-size:.56rem}
  .btn-lg{padding:13px 24px;font-size:.58rem}

  /* Nav CTA — hide text label on very small screens */
  .nav-tel .nav-tel-text{display:none}
}

/* ── Small mobile (≤ 380px) ── */
@media(max-width:380px){
  h1.hero-h{font-size:2rem}
  .pt-price{font-size:1.8rem}
  .city-grid{grid-template-columns:1fr}
}

/* ── Touch targets — all interactive elements min 44px ── */
@media(hover:none){
  .btn{min-height:44px}
  .n-cta,.nc{min-height:44px}
  .nl a{padding:14px 13px;min-height:44px;display:flex;align-items:center}
  .city-a,.city{padding:16px 14px;min-height:44px}
  .cd-trigger{min-height:44px}
  .fi input,.fi select,.fi textarea{padding:13px 4px;font-size:16px!important} /* prevent iOS zoom */
  select{font-size:16px!important}
}

/* ════════════════════════════
   BACKWARD-COMPAT ALIASES
   (subpages use these class names)
════════════════════════════ */
/* Nav CTA — subpages use .nc */
.nc{
  display:inline-flex;align-items:center;gap:7px;
  padding:10px 22px;background:var(--gold);color:var(--ink);
  font-family:var(--fb);font-size:.54rem;font-weight:600;letter-spacing:.13em;
  text-transform:uppercase;transition:.32s var(--ease);text-decoration:none;
  position:relative;overflow:hidden;
}
.nc::before{content:'';position:absolute;inset:0;background:var(--gold2);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.nc:hover::before{transform:scaleX(1)}
.nc:hover{color:var(--ink);transform:translateY(-1px);box-shadow:0 6px 20px rgba(200,151,90,.28)}
.nc span,.nc svg{position:relative;z-index:1;color:var(--ink)}
.nc svg{width:11px;height:11px}
/* Section alt backgrounds */
.sec-alt{background:var(--ink2)}
/* Divider — subpages use .div */
.div{width:22px;height:1px;background:var(--gold);margin:18px 0 38px;opacity:.8}
.center .div{margin-left:auto;margin-right:auto}
/* Button aliases */
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{background:var(--gold2);transform:translateY(-2px);box-shadow:0 8px 28px rgba(200,151,90,.32);color:var(--ink)}
.btn-ghost{background:transparent;color:var(--gold);border:1px solid rgba(200,151,90,.3)}
.btn-ghost:hover{border-color:rgba(200,151,90,.65);transform:translateY(-2px)}

/* ════════════════════════════
   MISC / UTILITY
════════════════════════════ */
.gold{color:var(--gold)}
.dim{color:rgba(240,234,224,.45)}
.mt-0{margin-top:0!important}
.mb-0{margin-bottom:0!important}
.text-center{text-align:center}
.w100{width:100%}
.gap-1{gap:1px}
