/* ============================================================
   ZAUBERER LIAR — Design v2 „Salon Parisien"
   Helles französisches Editorial: Elfenbein & Tinte,
   Champagner-Gold als Glanz-Akzent. Dunkle Bühnen-Panels
   für Hero, Band, Finale & Footer.
   ============================================================ */

:root{
  /* Grundfarben */
  --paper:#f7f3ea;          /* Elfenbein-Grund */
  --porcelain:#fffdf7;      /* Karten-Weiß */
  --ink:#171a24;            /* Tinten-Blauschwarz */
  --ink-2:#202432;
  --ink-3:#2a2f42;
  /* Gold */
  --or:#b08d3f;             /* dekorativ */
  --or-text:#7d6526;        /* Gold für kleinen Text auf hell (Kontrast) */
  --or-bright:#e3c47c;      /* Glanz auf dunkel */
  --or-deep:#8a6c2c;
  /* Kontext-Tokens (hell = Standard) */
  --bg:var(--paper);
  --surface:var(--porcelain);
  --surface-2:#f1ece0;
  --text:#3b3f4d;
  --text-strong:var(--ink);
  --text-muted:#6e7280;
  --accent:var(--or-text);
  --accent-deco:var(--or);
  --line-c:rgba(125,101,38,.22);
  --line-strong:rgba(125,101,38,.45);
  --ease:cubic-bezier(.16,1,.3,1);
  --maxw:1200px;
}
/* dunkle Bühnen-Panels überschreiben die Kontext-Tokens */
.hero,.page-hero,.band,.cta-final,footer,.cookie,.mobile-nav{
  --bg:var(--ink);
  --surface:var(--ink-2);
  --surface-2:var(--ink-3);
  --text:#c9c5ba;
  --text-strong:#f4efe3;
  --text-muted:#9a9daa;
  --accent:var(--or-bright);
  --accent-deco:var(--or-bright);
  --line-c:rgba(227,196,124,.18);
  --line-strong:rgba(227,196,124,.42);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--paper); color:var(--text);
  font-family:'Inter',sans-serif; font-weight:400; font-size:16px;
  line-height:1.75; letter-spacing:.005em; overflow-x:hidden;
}
/* feines Papierkorn */
body::before{ content:""; position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.03;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
h1,h2,h3,.display{font-family:'Playfair Display',serif;font-weight:500;line-height:1.12;letter-spacing:.005em;text-wrap:balance;color:var(--text-strong)}
h4,h5{color:var(--text-strong)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
p{text-wrap:pretty}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.gold{color:var(--accent)}
.gold-text{color:var(--accent)}
.eyebrow{font-size:.72rem;letter-spacing:.38em;text-transform:uppercase;color:var(--accent);font-weight:500;display:inline-flex;align-items:center;gap:14px}
.eyebrow::before{content:"";width:34px;height:1px;background:linear-gradient(90deg,transparent,var(--accent-deco))}
.kicker{font-family:'Playfair Display',serif;font-style:italic;font-size:1.15rem;color:var(--accent);display:block;margin-bottom:6px}
.ic{width:26px;height:26px;stroke:var(--accent-deco);fill:none;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round}

.divider{height:1px;background:linear-gradient(90deg,transparent,var(--line-strong),transparent);margin:0 auto;max-width:var(--maxw)}

/* ---------- Topbar (immer dunkel-transluzent über dunklem Hero) ---------- */
.topbar{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:22px 32px;transition:.5s cubic-bezier(.2,.7,.2,1);
  background:linear-gradient(180deg,rgba(23,26,36,.85),transparent)}
.topbar.scrolled{background:rgba(23,26,36,.94);backdrop-filter:blur(16px);padding:14px 32px;border-bottom:1px solid rgba(227,196,124,.18)}
.brand{font-family:'Playfair Display',serif;font-size:1.5rem;letter-spacing:.26em;font-weight:500;color:#f4efe3}
.brand b{font-weight:600;color:var(--or-bright)}
.nav{display:flex;gap:36px;align-items:center}
.nav a{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:#b9bcc7;transition:.3s;position:relative}
.nav a:hover,.nav a.active{color:#f4efe3}
.nav a::after{content:"";position:absolute;left:0;bottom:-7px;width:0;height:1px;background:var(--or-bright);transition:.35s}
.nav a:hover::after,.nav a.active::after{width:100%}
.cta-mini{border:1px solid rgba(227,196,124,.45);color:var(--or-bright)!important;padding:11px 22px;border-radius:2px;font-size:.72rem;transition:.4s;position:relative;overflow:hidden}
.cta-mini:hover{color:var(--ink)!important}
.cta-mini::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,var(--or),var(--or-bright));transform:translateY(101%);transition:.4s;z-index:-1}
.cta-mini:hover::before{transform:translateY(0)}
.cta-mini span{position:relative;z-index:1}
.burger{display:none;flex-direction:column;gap:6px;cursor:pointer;z-index:60;padding:8px}
.burger span{width:26px;height:1.5px;background:#f4efe3;transition:.3s}
.mobile-nav{position:fixed;inset:0;z-index:55;background:rgba(23,26,36,.98);backdrop-filter:blur(12px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;opacity:0;pointer-events:none;transition:.4s}
.mobile-nav.open{opacity:1;pointer-events:all}
.mobile-nav a{font-family:'Playfair Display',serif;font-size:1.8rem;color:#f4efe3}
.mobile-nav a:hover{color:var(--or-bright)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:11px;padding:16px 34px;border-radius:2px;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500;transition:.45s cubic-bezier(.2,.7,.2,1);cursor:pointer;border:1px solid transparent;position:relative;overflow:hidden;font-family:'Inter',sans-serif}
.btn-gold{color:#1d1605;background:linear-gradient(120deg,var(--or-deep),var(--or-bright) 50%,var(--or));background-size:200% auto;box-shadow:0 14px 38px -14px rgba(138,108,44,.55)}
.btn-gold:hover{background-position:right center;transform:translateY(-3px);box-shadow:0 20px 48px -14px rgba(176,141,63,.55)}
.btn-ghost{border-color:var(--line-strong);color:var(--text-strong)}
.btn-ghost:hover{border-color:var(--accent-deco);color:var(--accent);background:rgba(176,141,63,.06)}

/* ---------- Hero (Start) — dunkle Bühne mit Goldlicht ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:130px 0 90px;overflow:hidden;background:var(--ink)}
.hero-bg{position:absolute;inset:0;z-index:0;
  background:
   radial-gradient(130% 100% at 80% 8%,rgba(176,141,63,.22),transparent 50%),
   radial-gradient(90% 90% at 8% 100%,rgba(138,108,44,.12),transparent 55%),
   linear-gradient(165deg,#171a24 0%,#1c2030 50%,#14161f 100%)}
.hero-rays{position:absolute;inset:0;z-index:0;opacity:.55;pointer-events:none;
  background:repeating-conic-gradient(from 90deg at 82% 14%,rgba(227,196,124,.06) 0deg,transparent 2deg 9deg);mask:radial-gradient(60% 60% at 82% 14%,#000,transparent 70%)}
.hero-glow{position:absolute;width:560px;height:560px;border-radius:50%;z-index:0;right:-60px;top:46%;transform:translateY(-50%);
  background:radial-gradient(circle,rgba(227,196,124,.16),transparent 68%);filter:blur(30px);animation:breathe 10s ease-in-out infinite}
@keyframes breathe{0%,100%{transform:translateY(-52%) scale(1)}50%{transform:translateY(-46%) scale(1.06)}}
.hero .wrap{position:relative;z-index:2}
.hero-grid{display:grid;grid-template-columns:1.12fr .88fr;gap:60px;align-items:center}
.hero h1{font-size:clamp(2.9rem,6.2vw,5.4rem);margin:24px 0 26px}
.hero h1 i{font-style:italic;font-weight:500}
.hero p.lead{font-size:1.15rem;color:#c9c5ba;max-width:520px;margin-bottom:40px}
.hero p.lead .em{font-family:'Playfair Display',serif;font-style:italic;font-size:1.32rem;color:#f4efe3}
.hero-actions{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.hero-card{position:relative}
.hero-frame{position:relative;padding:12px}
.hero-frame::before{content:"";position:absolute;inset:0;border:1px solid var(--line-strong);border-radius:3px;background:linear-gradient(160deg,rgba(227,196,124,.07),transparent 40%)}
.hero-frame::after{content:"";position:absolute;top:-1px;left:24px;right:24px;height:1px;background:linear-gradient(90deg,transparent,var(--or-bright),transparent)}
.hero-portrait{aspect-ratio:3/4;border-radius:2px;overflow:hidden;position:relative;background:#202432;box-shadow:0 50px 90px -34px rgba(0,0,0,.7)}
.hero-portrait img{width:100%;height:100%;object-fit:cover;filter:saturate(.94) contrast(1.02)}
.hero-portrait::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(23,26,36,.5))}
.hero-badge{position:absolute;left:-26px;bottom:46px;background:rgba(32,36,50,.95);backdrop-filter:blur(8px);
  border:1px solid var(--line-strong);border-radius:2px;padding:18px 24px;box-shadow:0 24px 50px -18px rgba(0,0,0,.6)}
.hero-badge .num{font-family:'Playfair Display',serif;font-size:2.4rem;line-height:1;font-weight:600;color:var(--or-bright)}
.hero-badge .lbl{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:#9a9daa;margin-top:4px}
.stars{color:var(--accent);letter-spacing:4px;font-size:.8rem}

/* ---------- Page-Hero (Unterseiten) ---------- */
.page-hero{position:relative;padding:180px 0 90px;overflow:hidden;text-align:center;background:var(--ink)}
.page-hero .hero-bg{background:radial-gradient(120% 90% at 50% 0%,rgba(176,141,63,.20),transparent 55%),linear-gradient(165deg,#171a24,#1c2030 60%,#14161f)}
.page-hero .wrap{position:relative;z-index:2;max-width:880px}
.page-hero h1{font-size:clamp(2.5rem,5.4vw,4.4rem);margin:22px 0 22px}
.page-hero h1 i{font-style:italic}
.page-hero p{font-size:1.14rem;color:#c9c5ba;max-width:640px;margin:0 auto 36px}
.breadcrumb{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#9a9daa}
.breadcrumb a:hover{color:var(--or-bright)}

/* ---------- Sektionen ---------- */
section{position:relative;z-index:2;padding:110px 0}
section.tight{padding:84px 0}
.sec-head{max-width:700px;margin-bottom:60px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.center .eyebrow::after{content:"";width:34px;height:1px;background:linear-gradient(90deg,var(--accent-deco),transparent)}
.sec-head h2{font-size:clamp(2.2rem,4.2vw,3.4rem);margin:18px 0 18px}
.sec-head p{color:var(--text-muted);font-size:1.05rem}

/* ---------- Prosa + Split ---------- */
.prose p{color:var(--text);font-size:1.05rem;line-height:1.85;margin-bottom:18px;max-width:62ch}
.prose p strong,.prose strong{color:var(--text-strong);font-weight:600}
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.split.rev{direction:rtl}.split.rev>*{direction:ltr}
.media-frame{position:relative;padding:12px}
.media-frame::before{content:"";position:absolute;inset:0;border:1px solid var(--line-strong);border-radius:3px}
.media-frame img{border-radius:2px;width:100%;aspect-ratio:4/3;object-fit:cover;box-shadow:0 36px 70px -34px rgba(23,26,36,.45)}

/* ---------- Karten (allgemein) ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-c);border:1px solid var(--line-c);border-radius:3px;overflow:hidden}
.card{background:var(--surface);padding:40px 34px;transition:.5s;position:relative}
.card:hover{background:var(--surface-2)}
.card .icwrap{width:58px;height:58px;border:1px solid var(--line-strong);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:22px;transition:.5s;background:radial-gradient(circle at 50% 40%,rgba(176,141,63,.08),transparent)}
.card:hover .icwrap{border-color:var(--accent-deco);box-shadow:0 0 0 6px rgba(176,141,63,.06)}
.card h3{font-size:1.5rem;margin-bottom:12px}
.card p{color:var(--text-muted);font-size:.95rem}
.card .meta{margin-top:16px;font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}

/* ---------- Angebote (Start) ---------- */
.offers{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-c);border:1px solid var(--line-c);border-radius:3px;overflow:hidden}
.offer{background:var(--surface);padding:48px 38px;transition:.5s;position:relative}
.offer::after{content:"";position:absolute;left:38px;right:38px;top:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-deco),transparent);transform:scaleX(0);transition:.55s}
.offer:hover{background:var(--surface-2)}
.offer:hover::after{transform:scaleX(1)}
.offer .icwrap{width:62px;height:62px;border:1px solid var(--line-strong);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:26px;transition:.5s;background:radial-gradient(circle at 50% 40%,rgba(176,141,63,.08),transparent)}
.offer:hover .icwrap{border-color:var(--accent-deco);box-shadow:0 0 0 6px rgba(176,141,63,.06)}
.offer h3{font-size:1.85rem;margin-bottom:14px}
.offer p{color:var(--text-muted);font-size:.96rem;margin-bottom:22px}
.offer ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.offer li{font-size:.9rem;color:var(--text);padding-left:22px;position:relative}
.offer li::before{content:"";position:absolute;left:0;top:.62em;width:8px;height:8px;border:1px solid var(--accent-deco);transform:rotate(45deg)}
.offer .more{display:inline-flex;align-items:center;gap:8px;margin-top:26px;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);transition:.3s}
.offer .more:hover{gap:14px}

/* ---------- Checkliste ---------- */
.checklist{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:14px 32px;margin-top:8px}
.checklist li{font-size:.98rem;color:var(--text);padding-left:30px;position:relative}
.checklist li::before{content:"";position:absolute;left:0;top:.2em;width:16px;height:16px;border:1px solid var(--accent-deco);border-radius:50%;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23b08d3f' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='M5 13l4 4L19 7'/%3E%3C/svg%3E") center/10px no-repeat}

/* ---------- Preise ---------- */
.prices{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-c);border:1px solid var(--line-c);border-radius:3px;overflow:hidden}
.price{background:var(--surface);padding:30px 32px;display:flex;justify-content:space-between;align-items:baseline;gap:20px}
.price .name{font-family:'Playfair Display',serif;font-size:1.35rem;color:var(--text-strong)}
.price .name span{display:block;font-family:'Inter';font-size:.8rem;color:var(--text-muted);letter-spacing:.02em}
.price .amt{font-family:'Playfair Display',serif;font-size:1.7rem;white-space:nowrap;color:var(--accent)}

/* ---------- Band (dunkles Panel) ---------- */
.band{background:linear-gradient(160deg,#1c2030,#171a24);border-top:1px solid rgba(227,196,124,.14);border-bottom:1px solid rgba(227,196,124,.14)}
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;margin-top:12px}
.feat{padding:34px 26px;text-align:center;position:relative}
.feat:not(:last-child)::after{content:"";position:absolute;right:-14px;top:20%;bottom:20%;width:1px;background:var(--line-c)}
.feat .icwrap{width:54px;height:54px;margin:0 auto 18px;border:1px solid var(--line-strong);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.4s}
.feat:hover .icwrap{border-color:var(--accent-deco);transform:translateY(-4px)}
.feat h4{font-family:'Playfair Display',serif;font-weight:600;font-size:1.3rem;margin-bottom:9px}
.feat p{font-size:.86rem;color:var(--text-muted)}

/* ---------- Anlässe ---------- */
.occ{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-c);border:1px solid var(--line-c);border-radius:3px;overflow:hidden}
.occ-item{background:var(--surface);padding:42px 44px;transition:.45s;position:relative}
.occ-item:hover{background:var(--surface-2)}
.occ-item .no{font-family:'Playfair Display',serif;font-style:italic;font-size:1.1rem;color:var(--accent);display:block;margin-bottom:10px}
.occ-item h3{font-size:1.65rem;margin-bottom:12px}
.occ-item p{color:var(--text-muted);font-size:.95rem}
.occ-item .tag{display:inline-block;margin-top:18px;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);border:1px solid var(--line-c);padding:7px 15px;border-radius:2px}

/* ---------- Bewertungen ---------- */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.rev{background:var(--surface);border:1px solid var(--line-c);border-radius:3px;padding:40px 34px;position:relative;transition:.45s}
.rev:hover{border-color:var(--line-strong);transform:translateY(-5px)}
.rev .q{font-family:'Playfair Display',serif;font-size:5rem;color:var(--accent-deco);opacity:.18;line-height:.5;position:absolute;top:30px;right:30px;font-style:italic}
.rev .stars{margin-bottom:18px}
.rev p{color:var(--text);margin-bottom:22px;font-family:'Playfair Display',serif;font-size:1.22rem;line-height:1.55;font-style:italic}
.rev .who{font-size:.76rem;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase}
.rev .who b{color:var(--accent);font-weight:600}

/* ---------- FAQ ---------- */
.faq-item{border-bottom:1px solid var(--line-c);padding:26px 0;cursor:pointer;transition:.3s}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:24px;font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--text-strong)}
.faq-q .pl{color:var(--accent-deco);font-size:1.4rem;transition:.4s;flex-shrink:0;font-weight:300}
.faq-item.open .pl{transform:rotate(135deg);color:var(--accent)}
.faq-item.open .faq-q{color:var(--accent)}
.faq-a{max-height:0;overflow:hidden;transition:.45s ease;color:var(--text-muted);font-size:1rem}
.faq-item.open .faq-a{max-height:360px;padding-top:16px}

/* ---------- Finale CTA (dunkel) ---------- */
.cta-final{text-align:center;position:relative;background:linear-gradient(170deg,#1c2030,#14161f);border-top:1px solid rgba(227,196,124,.14);overflow:hidden}
.cta-final::before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:680px;height:680px;border-radius:50%;
  background:radial-gradient(circle,rgba(176,141,63,.14),transparent 65%);z-index:0}
.cta-final .wrap{position:relative;z-index:1}
.cta-final h2{font-size:clamp(2.5rem,5.2vw,4.2rem);margin-bottom:20px}
.cta-final p{color:#b9b5aa;font-size:1.12rem;max-width:560px;margin:0 auto 38px}
.phone-big{font-family:'Playfair Display',serif;font-size:2.3rem;letter-spacing:.04em;display:inline-block;margin-top:18px;color:var(--or-bright)}

/* ---------- Formular ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:720px;margin:0 auto}
.field{display:flex;flex-direction:column;gap:8px;text-align:left}
.field.full{grid-column:1/-1}
.field label{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:600}
.field input,.field textarea,.field select{background:var(--porcelain);border:1px solid var(--line-c);border-radius:2px;padding:14px 16px;color:var(--ink);font-family:'Inter';font-size:1rem;transition:.3s}
.field input:focus,.field textarea:focus,.field select:focus{outline:2px solid var(--or);outline-offset:1px;border-color:var(--or)}
.field textarea{resize:vertical;min-height:130px}
.form-note{font-size:.8rem;color:var(--text-muted);margin-top:14px}

/* ---------- Kontakt-Infokarten ---------- */
.info-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-c);border:1px solid var(--line-c);border-radius:3px;overflow:hidden;margin-bottom:54px}
.info{background:var(--surface);padding:34px;text-align:center}
.info .icwrap{width:52px;height:52px;margin:0 auto 16px;border:1px solid var(--line-strong);border-radius:50%;display:flex;align-items:center;justify-content:center}
.info h4{font-family:'Playfair Display';font-size:1.3rem;margin-bottom:6px}
.info a,.info p{color:var(--text-muted);font-size:.95rem}
.info a:hover{color:var(--accent)}

/* ---------- Rechtsseiten ---------- */
.legal{padding:160px 0 90px}
.legal .wrap{max-width:820px}
.legal h1{font-size:clamp(2.2rem,4vw,3.2rem);margin-bottom:30px}
.legal h2{font-size:1.5rem;color:var(--accent);margin:38px 0 12px}
.legal p,.legal li{color:var(--text);font-size:.98rem;margin-bottom:12px}
.legal ul{padding-left:22px;margin-bottom:16px}
.legal a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}

/* ---------- Footer (dunkel) ---------- */
footer{background:var(--ink);border-top:1px solid rgba(227,196,124,.16);padding:72px 0 34px;position:relative;z-index:2;color:var(--text)}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:50px}
footer h5{font-family:'Inter',sans-serif;font-weight:600;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--or-bright);margin-bottom:22px}
footer a,footer .foot-grid p{display:block;color:#a8abb6;font-size:.9rem;margin-bottom:11px;transition:.3s}
footer a:hover{color:var(--or-bright)}
footer .brand{font-size:1.6rem;margin-bottom:18px}
.foot-bottom{border-top:1px solid rgba(227,196,124,.14);padding-top:28px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.78rem;color:#9a9daa;letter-spacing:.06em}

/* ---------- Cookie-Consent ---------- */
.cookie{position:fixed;left:24px;right:24px;bottom:24px;z-index:80;max-width:560px;margin:0 auto;
  background:rgba(32,36,50,.97);backdrop-filter:blur(14px);border:1px solid rgba(227,196,124,.4);border-radius:4px;
  padding:26px 28px;box-shadow:0 30px 70px -20px rgba(0,0,0,.7);transform:translateY(160%);transition:.6s cubic-bezier(.2,.7,.2,1)}
.cookie.show{transform:translateY(0)}
.cookie h4{font-family:'Playfair Display';font-size:1.4rem;margin-bottom:8px}
.cookie p{font-size:.88rem;color:#b9bcc7;margin-bottom:18px}
.cookie p a{color:var(--or-bright);text-decoration:underline;text-underline-offset:3px}
.cookie-actions{display:flex;gap:12px;flex-wrap:wrap}
.cookie .btn{padding:12px 24px;font-size:.74rem}
.cookie .btn-text{background:none;border:1px solid rgba(227,196,124,.25);color:#b9bcc7}
.cookie .btn-text:hover{border-color:var(--or-bright);color:var(--or-bright)}

/* ---------- Reveal-Animation ---------- */
.reveal{opacity:1;transform:none}
.js-anim .reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.js-anim .reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media(prefers-reduced-motion:reduce){.js-anim .reveal{transition:opacity .4s ease;transform:none;opacity:0}.js-anim .reveal.in{opacity:1}.hero-glow{animation:none}}

/* ---------- Responsive ---------- */
@media(max-width:920px){
  .nav{display:none}.burger{display:flex}
  .hero-grid,.offers,.cards,.feat-grid,.occ,.rev-grid,.foot-grid,.split,.prices,.info-row,.form-grid,.checklist{grid-template-columns:1fr}
  .split.rev{direction:ltr}
  .feat:not(:last-child)::after{display:none}
  .hero-card{max-width:380px;margin:0 auto}.hero-badge{left:auto;right:18px}
  section{padding:80px 0}.foot-grid{grid-template-columns:1fr 1fr}
  .price{flex-direction:column;gap:6px}
}
