/* ============================================================
   Intercoiffure Heinz Grünberger — HERITAGE-LUXE
   Burgundy #6b2233 · Gold #c8a24a · Cream #f5eee2
   Cinzel (display) · Cormorant (serif) · Inter (body)
   Vanilla CSS · zero tracking · self-hosted fonts
   ============================================================ */

/* ---------- Fonts ---------- */
@font-face{font-family:'Cinzel';src:url('../fonts/cinzel-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Cinzel';src:url('../fonts/cinzel-600.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'Cinzel';src:url('../fonts/cinzel-700.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Cormorant';src:url('../fonts/cormorant-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Cormorant';src:url('../fonts/cormorant-400i.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Cormorant';src:url('../fonts/cormorant-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Cormorant';src:url('../fonts/cormorant-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Inter';src:url('../fonts/inter-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Inter';src:url('../fonts/inter-500.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Inter';src:url('../fonts/inter-600.woff2') format('woff2');font-weight:600;font-display:swap}

/* ---------- Tokens ---------- */
:root{
  --wine:#6b2233;
  --wine-dark:#4d1622;
  --wine-deep:#371019;
  --wine-soft:#8a3346;
  --gold:#c8a24a;
  --gold-soft:#d8b96e;
  --gold-deep:#a9842f;
  --cream:#f5eee2;
  --cream-2:#efe5d4;
  --paper:#fbf7f0;
  --ink:#241a1c;
  --ink-soft:#5a4a4d;
  --line:rgba(107,34,51,.16);
  --line-gold:rgba(200,162,74,.42);

  --f-display:'Cinzel',Georgia,serif;
  --f-serif:'Cormorant',Georgia,serif;
  --f-body:'Inter',system-ui,-apple-system,Segoe UI,sans-serif;

  --shell:1200px;
  --shell-wide:1480px;
  --gap-xs:.5rem; --gap-sm:1rem; --gap-md:1.6rem; --gap-lg:2.6rem; --gap-xl:4.4rem;
  --sec-y:clamp(4rem,8vw,7.5rem);
  --radius:3px;
  --shadow:0 24px 60px -34px rgba(55,16,25,.5);
  --shadow-soft:0 14px 34px -22px rgba(55,16,25,.42);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--f-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.7;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,h4{font-family:var(--f-display);font-weight:600;line-height:1.08;letter-spacing:.005em;color:var(--wine)}
.section-head h2{font-size:clamp(2rem,4vw,3.2rem)}
p{color:var(--ink-soft)}

/* ---------- Layout shells ---------- */
.shell{max-width:var(--shell);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.6rem)}
.shell-wide{max-width:var(--shell-wide);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.6rem)}
section{padding:var(--sec-y) 0}
section.tight{padding:clamp(2.2rem,4vw,3.4rem) 0}
.bg-cream{background:var(--cream)}
.bg-cream-2{background:var(--cream-2)}
.bg-wine{background:var(--wine);color:var(--cream)}
.bg-wine *{color:var(--cream)}

/* ---------- Eyebrow / kicker / ornament ---------- */
.eyebrow,.kicker{
  font-family:var(--f-body);font-size:.72rem;font-weight:600;
  letter-spacing:.28em;text-transform:uppercase;color:var(--gold-deep);
}
.dateline{
  font-family:var(--f-body);font-size:.68rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-soft);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:.5rem 0;display:flex;gap:1.2rem;flex-wrap:wrap;justify-content:center;
}
.ornament-rule{display:flex;align-items:center;gap:1rem;color:var(--gold-deep);
  font-family:var(--f-body);font-size:.72rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;margin-bottom:1.1rem}
.ornament-rule::before,.ornament-rule::after{content:"";flex:1;height:1px;background:var(--line-gold)}
.ornament-rule.left::before{display:none}
.section-head{max-width:720px;margin-bottom:var(--gap-lg)}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head.center .ornament-rule{justify-content:center}
.section-head p{font-family:var(--f-serif);font-size:1.34rem;line-height:1.5;margin-top:.7rem}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--f-body);font-weight:600;font-size:.82rem;letter-spacing:.06em;
  padding:.95rem 1.7rem;border-radius:var(--radius);cursor:pointer;
  transition:transform .4s var(--ease),background .35s,color .35s,box-shadow .4s,border-color .35s;
  border:1px solid transparent;text-transform:uppercase;
}
.btn .arrow{transition:transform .4s var(--ease)}
.btn:hover .arrow{transform:translateX(5px)}
.btn-primary{background:var(--wine);color:var(--cream);box-shadow:var(--shadow-soft)}
.btn-primary:hover{background:var(--wine-dark);transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:var(--wine-deep)}
.btn-gold:hover{background:var(--gold-soft);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--wine);border-color:var(--line-gold)}
.btn-ghost:hover{border-color:var(--gold);color:var(--wine-dark);background:rgba(200,162,74,.08)}
.btn-light{background:var(--cream);color:var(--wine);box-shadow:var(--shadow-soft)}
.btn-light:hover{transform:translateY(-2px);background:#fff}
.btn-outline{background:transparent;color:var(--cream);border-color:rgba(245,238,226,.5)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold-soft)}

/* ---------- Scroll progress ---------- */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:100%;
  background:linear-gradient(90deg,var(--gold),var(--gold-soft));
  transform:scaleX(0);transform-origin:0 50%;z-index:200;}

/* ---------- NAV ---------- */
.nav{position:sticky;top:0;z-index:120;
  background:rgba(251,247,240,.9);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);}
.nav-inner{max-width:var(--shell-wide);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:.85rem clamp(1.2rem,4vw,2.6rem);gap:1.5rem;}
.nav-brand{display:flex;align-items:center;gap:.7rem;flex-shrink:0}
.nav-mark{width:38px;height:38px;flex-shrink:0}
.nav-word{display:flex;flex-direction:column;line-height:1}
.nav-word b{font-family:var(--f-display);font-weight:700;font-size:1.02rem;color:var(--wine);letter-spacing:.04em}
.nav-word span{font-family:var(--f-body);font-size:.56rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-deep);margin-top:3px}
.nav-menu{display:flex;align-items:center;gap:1.6rem}
.nav-menu a{font-family:var(--f-body);font-size:.78rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft);position:relative;padding:.3rem 0;transition:color .3s;}
.nav-menu a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--gold);transition:width .35s var(--ease)}
.nav-menu a:hover,.nav-menu a.active{color:var(--wine)}
.nav-menu a:hover::after,.nav-menu a.active::after{width:100%}
.nav-cta{padding:.6rem 1.2rem !important;background:var(--wine);color:var(--cream) !important;border-radius:var(--radius);
  text-transform:uppercase;transition:background .3s,transform .3s !important;}
.nav-cta::after{display:none}
.nav-cta:hover{background:var(--wine-dark);transform:translateY(-1px)}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav-burger span{width:24px;height:2px;background:var(--wine);transition:.3s}
.nav-mobile{display:none;flex-direction:column;background:var(--paper);border-bottom:1px solid var(--line);
  padding:0 clamp(1.2rem,4vw,2.6rem);max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.nav-mobile.open{max-height:520px;padding:1rem clamp(1.2rem,4vw,2.6rem) 1.6rem}
.nav-mobile a{font-family:var(--f-body);font-size:.92rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-soft);padding:.85rem 0;border-bottom:1px solid var(--line)}
.nav-mobile a:last-child{border:none;color:var(--wine);font-weight:600}

/* ---------- HERO — cinematic crossfade ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden;background:var(--wine-deep)}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-layer{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;
  animation:heroFade 24s infinite;will-change:opacity,transform}
.hero-layer.l1{animation-delay:0s}
.hero-layer.l2{animation-delay:8s}
.hero-layer.l3{animation-delay:16s}
@keyframes heroFade{
  0%{opacity:0;transform:scale(1.06)}
  6%{opacity:1}
  28%{opacity:1;transform:scale(1.13)}
  36%{opacity:0;transform:scale(1.14)}
  100%{opacity:0}
}
.hero-veil{position:absolute;inset:0;z-index:1;
  background:linear-gradient(105deg,rgba(55,16,25,.86) 0%,rgba(77,22,34,.66) 46%,rgba(55,16,25,.34) 100%);}
.hero-veil::after{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 90% at 18% 28%,transparent 40%,rgba(55,16,25,.5) 100%)}
.hero-grain{position:absolute;inset:0;z-index:2;pointer-events:none;opacity:.4;mix-blend-mode:screen;
  background:radial-gradient(1px 1px at 20% 30%,rgba(200,162,74,.5),transparent),
            radial-gradient(1px 1px at 70% 60%,rgba(245,238,226,.4),transparent),
            radial-gradient(1px 1px at 45% 80%,rgba(200,162,74,.3),transparent);
  background-size:240px 240px;animation:grainDrift 26s linear infinite}
@keyframes grainDrift{from{transform:translate(0,0)}to{transform:translate(-30px,-40px)}}
.hero-bars{position:absolute;left:0;right:0;height:46px;z-index:3;background:var(--wine-deep);opacity:0;transition:opacity 1.2s ease .3s}
.hero-bars.top{top:0}.hero-bars.bot{bottom:0}
.hero.lit .hero-bars{opacity:.9}
.hero-inner{position:relative;z-index:4;max-width:var(--shell);margin:0 auto;width:100%;
  padding:5rem clamp(1.2rem,4vw,2.6rem)}
.hero-crest{display:flex;align-items:center;gap:.7rem;margin-bottom:1.6rem;color:var(--gold-soft);
  font-family:var(--f-body);font-size:.72rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase}
.hero-crest .star{width:16px;height:16px;color:var(--gold)}
.hero-crest::after{content:"";width:60px;height:1px;background:var(--line-gold)}
.hero h1{color:var(--cream);font-size:clamp(2.7rem,6.4vw,5.6rem);font-weight:700;line-height:1.02;max-width:16ch;
  text-shadow:0 2px 30px rgba(0,0,0,.4)}
.hero h1 em{font-style:normal;color:var(--gold);font-family:var(--f-serif);font-weight:600}
.hero-sub{font-family:var(--f-serif);font-size:clamp(1.2rem,2.2vw,1.7rem);color:var(--cream);
  max-width:50ch;margin:1.6rem 0 2.2rem;line-height:1.5;opacity:.94}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.6rem}
.hero-trust{display:flex;gap:1.6rem;flex-wrap:wrap}
.hero-trust .chip{display:flex;align-items:center;gap:.55rem;color:var(--cream);
  font-family:var(--f-body);font-size:.8rem;letter-spacing:.04em}
.hero-trust .chip b{font-weight:600}
.hero-trust .chip .ic{color:var(--gold);font-size:1rem}
.hero-trust .chip + .chip{padding-left:1.6rem;border-left:1px solid rgba(245,238,226,.22)}
.scroll-cue{position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);z-index:5;
  font-family:var(--f-body);font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:var(--cream);
  opacity:.7;animation:cueBob 2.4s ease-in-out infinite}
@keyframes cueBob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(7px)}}

/* char-reveal */
.hero h1 .word{display:inline-block;will-change:transform}
.hero h1 .char{display:inline-block;opacity:0;transform:translateY(38px) rotateX(-32deg);filter:blur(8px);
  animation:charIn .9s var(--ease) forwards}
@keyframes charIn{to{opacity:1;transform:none;filter:blur(0)}}

/* ---------- PAGE HERO (sub-pages) ---------- */
.page-hero{position:relative;background:var(--wine-deep);overflow:hidden;
  padding:clamp(5rem,11vw,8.5rem) 0 clamp(3.4rem,6vw,5rem)}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.26;
  filter:saturate(.85);transform:scale(1.08)}
.page-hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(55,16,25,.7),rgba(55,16,25,.92))}
.page-hero .shell{position:relative;z-index:2}
.page-hero .hero-crest{color:var(--gold-soft)}
.page-hero h1{color:var(--cream);font-size:clamp(2.3rem,5.4vw,4.2rem);max-width:18ch}
.page-hero .lede{font-family:var(--f-serif);font-size:clamp(1.15rem,2vw,1.5rem);color:var(--cream);
  opacity:.92;max-width:54ch;margin-top:1.2rem;line-height:1.5}

/* ---------- Reveals ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in-view{opacity:1;transform:none}
.reveal[data-delay]{transition-delay:var(--d,0ms)}

/* ---------- Estate-gazette cards ---------- */
.gazette-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line)}
.gaz-card{background:var(--paper);padding:2rem 1.8rem;position:relative;transition:background .4s}
.gaz-card .num{font-family:var(--f-display);font-size:.8rem;color:var(--gold-deep);letter-spacing:.18em}
.gaz-card h3{font-size:1.55rem;margin:.6rem 0 .7rem;line-height:1.12}
.gaz-card p{font-size:.96rem}
.gaz-card .more{display:inline-flex;align-items:center;gap:.4rem;margin-top:1rem;
  font-family:var(--f-body);font-size:.74rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--wine);opacity:0;transform:translateY(6px);transition:.4s}
.gaz-card::before{content:"";position:absolute;left:0;top:0;width:0;height:2px;background:var(--gold);transition:width .5s var(--ease)}
.gaz-card:hover{background:var(--cream)}
.gaz-card:hover::before{width:100%}
.gaz-card:hover .more{opacity:1;transform:none}

/* ---------- Image figure with warm treatment + hover ---------- */
.fig{position:relative;overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow)}
.fig img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease),filter .9s}
.fig.warm img{filter:saturate(1.04) contrast(1.02) sepia(.05)}
.fig:hover img{transform:scale(1.05)}
.fig.bw img{filter:grayscale(1) contrast(1.04)}
.fig.bw:hover img{filter:grayscale(0) contrast(1.04)}
.fig::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(55,16,25,.28));pointer-events:none}

/* ---------- Split / portrait sections ---------- */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2rem,5vw,4.4rem);align-items:center}
.split.flip .split-media{order:-1}
.split-text .ornament-rule{margin-bottom:1rem}
.split-text h2{font-size:clamp(1.9rem,3.6vw,2.9rem);margin-bottom:1rem}
.split-text p + p{margin-top:1rem}
.split-media{position:relative}
.split-media .frame{position:relative;border:1px solid var(--line-gold);padding:14px;background:var(--paper)}
.split-media .frame .fig{box-shadow:none}
.portrait-badges{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.5rem}
.badge{display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--line-gold);
  border-radius:40px;padding:.45rem 1rem;font-family:var(--f-body);font-size:.74rem;font-weight:500;letter-spacing:.04em;color:var(--wine)}
.badge .star{width:13px;height:13px;color:var(--gold-deep)}

/* ---------- Bleed strip ---------- */
.bleed{position:relative;min-height:clamp(360px,52vw,560px);display:flex;align-items:center;overflow:hidden;background:var(--wine-deep)}
.bleed > img{position:absolute;inset:0;width:100%;height:118%;top:-9%;object-fit:cover;opacity:.32;filter:saturate(.85)}
.bleed::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(55,16,25,.82),rgba(77,22,34,.5))}
.bleed-inner{position:relative;z-index:2;max-width:860px;margin:0 auto;text-align:center;padding:3rem clamp(1.2rem,4vw,2.6rem)}
.bleed-inner .ornament-rule{justify-content:center;color:var(--gold-soft)}
.bleed-inner .ornament-rule::before,.bleed-inner .ornament-rule::after{background:var(--line-gold)}
.bleed-inner h2{color:var(--cream);font-size:clamp(1.8rem,4vw,3rem);margin-bottom:1.1rem}
.bleed-inner p{font-family:var(--f-serif);font-size:clamp(1.15rem,2vw,1.55rem);color:var(--cream);opacity:.94;line-height:1.5}

/* ---------- Gallery rail / grid ---------- */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.gallery .fig{aspect-ratio:3/4}

/* ---------- Counter row ---------- */
.counters{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-gold);border:1px solid var(--line-gold)}
.counter-cell{background:var(--paper);text-align:center;padding:2.2rem 1rem}
.counter-cell .n{font-family:var(--f-display);font-size:clamp(2.2rem,4.5vw,3.4rem);font-weight:700;color:var(--wine);font-variant-numeric:tabular-nums}
.counter-cell .n .suf{font-size:.55em;color:var(--gold-deep)}
.counter-cell .lbl{font-family:var(--f-body);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-top:.4rem}

/* ---------- CTA banner ---------- */
.cta-banner{background:var(--wine);color:var(--cream);border-radius:var(--radius);
  padding:clamp(2.6rem,5vw,4rem);text-align:center;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.cta-banner::before{content:"";position:absolute;inset:0;
  background:radial-gradient(80% 120% at 80% -20%,rgba(200,162,74,.22),transparent 60%)}
.cta-banner > *{position:relative}
.cta-banner h2{color:var(--cream);font-size:clamp(1.8rem,3.6vw,2.8rem);margin-bottom:.8rem}
.cta-banner p{color:var(--cream);opacity:.9;font-family:var(--f-serif);font-size:1.3rem;max-width:52ch;margin:0 auto 1.8rem}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ---------- Price tables ---------- */
.price-block{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius)}
.price-block-head{background:var(--wine);color:var(--cream);padding:1.1rem 1.6rem;display:flex;align-items:center;gap:.7rem}
.price-block-head h3{color:var(--cream);font-size:1.3rem}
.price-block-head .star{width:16px;height:16px;color:var(--gold)}
.price-row{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;
  padding:.85rem 1.6rem;border-bottom:1px solid var(--line)}
.price-row:last-child{border-bottom:none}
.price-row .svc{font-family:var(--f-serif);font-size:1.18rem;color:var(--ink)}
.price-row .svc small{display:block;font-family:var(--f-body);font-size:.74rem;color:var(--ink-soft);letter-spacing:.02em}
.price-row .pr{font-family:var(--f-body);font-weight:600;color:var(--wine);white-space:nowrap;font-variant-numeric:tabular-nums}
.price-row.head{background:var(--cream-2)}
.price-row.head .svc,.price-row.head .pr{font-family:var(--f-body);font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep)}
.price-row.note-row{background:var(--cream);justify-content:flex-start}
.price-row.note-row .svc{font-size:.96rem;font-style:italic;color:var(--ink-soft)}
.price-cols{display:grid;grid-template-columns:1.6fr repeat(3,.8fr);gap:0;align-items:baseline;
  padding:.8rem 1.6rem;border-bottom:1px solid var(--line)}
.price-cols:last-child{border-bottom:none}
.price-cols span{font-family:var(--f-body);font-size:.92rem;color:var(--ink)}
.price-cols .svc{font-family:var(--f-serif);font-size:1.12rem}
.price-cols .pr{text-align:right;font-weight:600;color:var(--wine);font-variant-numeric:tabular-nums}
.price-cols.head span{font-size:.66rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-deep)}
.price-cols.head{background:var(--cream-2)}
.price-cols .pr{text-align:right}

/* ---------- Hours table ---------- */
.hours-table{width:100%;border-collapse:collapse}
.hours-table td{padding:.7rem 0;border-bottom:1px solid var(--line);font-family:var(--f-body);font-size:.95rem}
.hours-table td:first-child{color:var(--ink);font-weight:500}
.hours-table td:last-child{text-align:right;color:var(--ink-soft);font-variant-numeric:tabular-nums}
.hours-table tr.closed td{color:var(--ink-soft);opacity:.6}
.hours-table tr.today td{color:var(--wine);font-weight:600}
.hours-table tr.today td:first-child::after{content:" · heute";font-size:.7rem;color:var(--gold-deep);letter-spacing:.08em}

/* ---------- Info card grid (contact) ---------- */
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.4rem}
.info-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem}
.info-card h3{font-size:1.2rem;margin-bottom:.7rem;display:flex;align-items:center;gap:.55rem}
.info-card h3 .ic{color:var(--gold-deep)}
.info-card a{color:var(--wine);font-weight:500;border-bottom:1px solid var(--line-gold);transition:border-color .3s}
.info-card a:hover{border-color:var(--gold)}
.info-card p{font-size:.95rem}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.4rem;counter-reset:step}
.step{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;position:relative}
.step::before{counter-increment:step;content:"0" counter(step);position:absolute;top:1.2rem;right:1.4rem;
  font-family:var(--f-display);font-size:1.7rem;color:var(--line-gold);font-weight:700}
.step h3{font-size:1.2rem;margin-bottom:.5rem}
.step p{font-size:.94rem}

/* ---------- BonusCard visual ---------- */
.bonus-card-vis{background:linear-gradient(135deg,var(--wine),var(--wine-deep));border-radius:10px;
  padding:2rem;color:var(--cream);box-shadow:var(--shadow);position:relative;overflow:hidden;max-width:420px}
.bonus-card-vis::after{content:"";position:absolute;right:-30px;top:-30px;width:160px;height:160px;
  border:1px solid var(--line-gold);border-radius:50%}
.bonus-card-vis .bc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2.4rem}
.bonus-card-vis .bc-name{font-family:var(--f-display);font-weight:700;letter-spacing:.04em}
.bonus-card-vis .bc-name span{display:block;font-family:var(--f-body);font-size:.58rem;letter-spacing:.24em;color:var(--gold-soft);margin-top:4px}
.bonus-card-vis .bc-label{font-family:var(--f-serif);font-size:1.6rem;color:var(--gold-soft)}
.bonus-card-vis .stamps{display:flex;gap:.6rem;flex-wrap:wrap}
.bonus-card-vis .stamp{width:30px;height:30px;border-radius:50%;border:1px solid rgba(245,238,226,.35);
  display:flex;align-items:center;justify-content:center;font-size:.7rem}
.bonus-card-vis .stamp.on{background:var(--gold);border-color:var(--gold);color:var(--wine-deep)}

/* ---------- Aktions cards ---------- */
.aktion-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s}
.aktion-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.aktion-card .fig{border-radius:0;aspect-ratio:16/10;box-shadow:none}
.aktion-card .ak-body{padding:1.7rem;flex:1;display:flex;flex-direction:column}
.aktion-card .ak-tag{font-family:var(--f-body);font-size:.66rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:.6rem}
.aktion-card h3{font-size:1.45rem;margin-bottom:.6rem}
.aktion-card p{font-size:.95rem;flex:1}
.aktion-card .ak-foot{margin-top:1.2rem;padding-top:1rem;border-top:1px solid var(--line);font-family:var(--f-serif);font-style:italic;color:var(--wine)}

/* ---------- Legal prose ---------- */
.prose{max-width:780px}
.prose h2{font-size:1.5rem;margin:2rem 0 .8rem;color:var(--wine)}
.prose h3{font-size:1.15rem;margin:1.4rem 0 .5rem}
.prose p,.prose li{font-size:.98rem;line-height:1.75;color:var(--ink-soft)}
.prose ul{margin:.6rem 0 .6rem 1.4rem}
.prose a{color:var(--wine);border-bottom:1px solid var(--line-gold)}
.prose .meta{font-family:var(--f-body);font-size:.92rem;color:var(--ink);background:var(--cream);
  border-left:3px solid var(--gold);padding:1rem 1.4rem;border-radius:0 var(--radius) var(--radius) 0;margin-bottom:1.5rem}

/* ---------- FOOTER ---------- */
.footer{background:var(--wine-deep);color:var(--cream);padding:clamp(3.4rem,6vw,5rem) 0 0}
.footer-grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:2.4rem}
.footer-brand{max-width:320px}
.footer-brand .fb-mark{display:flex;align-items:center;gap:.7rem;margin-bottom:1.1rem}
.footer-brand .fb-mark img{width:44px;height:44px}
.footer-brand .fb-mark b{font-family:var(--f-display);font-weight:700;font-size:1.1rem;color:var(--cream)}
.footer-brand p{color:rgba(245,238,226,.72);font-size:.92rem;line-height:1.65}
.footer-col h4{font-family:var(--f-body);font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:1rem}
.footer-col a,.footer-col p{display:block;color:rgba(245,238,226,.78);font-size:.9rem;padding:.28rem 0;transition:color .3s}
.footer-col a:hover{color:var(--gold-soft)}
.footer-bottom{max-width:var(--shell);margin:3rem auto 0;padding:1.4rem clamp(1.2rem,4vw,2.6rem);
  border-top:1px solid rgba(245,238,226,.14);display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  font-size:.78rem;color:rgba(245,238,226,.6)}
.footer-bottom a{color:rgba(245,238,226,.72)}
.footer-bottom a:hover{color:var(--gold-soft)}

/* ---------- Sticky mobile booking ---------- */
.sticky-book{position:fixed;left:0;right:0;bottom:0;z-index:130;display:none;
  gap:.6rem;padding:.7rem .9rem;background:rgba(55,16,25,.96);backdrop-filter:blur(10px);
  border-top:1px solid var(--line-gold)}
.sticky-book .btn{flex:1;justify-content:center;padding:.85rem 1rem;font-size:.78rem}

/* ---------- Demo notice ---------- */
.demo-notice{position:fixed;left:1rem;bottom:1rem;z-index:140;max-width:340px;
  background:var(--wine);color:var(--cream);border:1px solid var(--line-gold);border-radius:var(--radius);
  padding:.7rem 1rem;display:flex;align-items:center;gap:.8rem;box-shadow:var(--shadow);
  font-family:var(--f-body);font-size:.74rem;line-height:1.4}
.demo-notice b{color:var(--gold-soft)}
.demo-notice .close{cursor:pointer;opacity:.7;font-size:.9rem;flex-shrink:0}
.demo-notice .close:hover{opacity:1}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1 !important;transform:none !important;transition:none !important}
  .hero-layer{animation:none !important;opacity:1}
  .hero-layer.l2,.hero-layer.l3{opacity:0}
  .hero h1 .char{animation:none !important;opacity:1 !important;transform:none !important;filter:none !important}
  .hero-grain,.scroll-cue{animation:none !important}
  *{transition:none !important}
}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
  .gazette-grid{grid-template-columns:repeat(2,1fr)}
  .counters{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .nav-menu{display:none}
  .nav-burger{display:flex}
  .nav-mobile{display:flex}
  .split{grid-template-columns:1fr;gap:2rem}
  .split.flip .split-media{order:0}
  .sticky-book{display:flex}
  body{padding-bottom:64px}
  .demo-notice{left:.6rem;right:.6rem;bottom:72px;max-width:none}
  .hero-trust .chip + .chip{padding-left:0;border-left:none}
  .hero-trust{gap:.9rem}
  .price-cols{grid-template-columns:1.4fr repeat(3,.7fr)}
}
@media (max-width:560px){
  .gazette-grid{grid-template-columns:1fr}
  .counters{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero{min-height:88vh}
  .price-cols{grid-template-columns:1fr;gap:.2rem}
  .price-cols .pr{text-align:left}
  .price-cols.head{display:none}
  .price-cols span.svc{font-weight:600;margin-bottom:.2rem}
}
