/* =====================================================================
   Relax Spich · STATE-OF-THE-ART 2026 (self-contained)
   Consolidates: style.css (brand system) + nextlevel.css (3 features)
   + SOTA pass: fluid type scale, scroll-driven enhancements w/ fallback,
   container queries, AA contrast, :focus-visible, CLS-safe media.
   Colors from logo: pink #E3256A, cream #F7EFDC. Dark + pink-neon.
   ===================================================================== */

:root{
  /* --- brand palette --- */
  --pink:#E3256A;
  --pink-deep:#B81B57;
  --pink-soft:rgba(227,37,106,.18);
  --cream:#F7EFDC;
  --cream-dim:#d3c8af;          /* lifted from #cabfa6 for AA on dark */
  --bordeaux:#5a1224;
  --gold:#d2a85f;               /* lifted for AA */
  --bg:#0a0608;
  --bg-2:#120a0e;
  --bg-3:#1a1014;
  --ink:#f5ecd9;
  --ink-2:#c8bca2;              /* body text — lifted for AA on bg */
  --ink-3:#8a8071;              /* lifted from #7a7163 for AA on dark */
  --line:rgba(247,239,220,.10);
  --line-2:rgba(247,239,220,.18);
  --shadow:0 30px 80px -30px rgba(0,0,0,.7);
  --radius:14px;
  --radius-lg:22px;
  --max:1180px;
  --nav-h:96px;

  /* --- fluid type scale (SOTA: one coherent rhythm) --- */
  --fs-eyebrow:clamp(11px,.7vw + .4rem,12px);
  --fs-body:clamp(16px,.4vw + .9rem,17px);
  --fs-lead:clamp(16.5px,.5vw + .95rem,18px);
  --fs-h2:clamp(36px,5.2vw,66px);
  --fs-h1:clamp(52px,8.4vw,104px);

  /* --- consistent spacing rhythm --- */
  --space-sec:clamp(80px,10vw,140px);
  --gap:clamp(22px,3vw,32px);

  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Plus Jakarta Sans',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  font-weight:400;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{max-width:100%;display:block}
a{color:var(--cream);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--pink)}

::selection{background:var(--pink);color:#fff}

/* unified focus ring (SOTA a11y) — keyboard only */
:focus-visible{
  outline:2px solid var(--pink);
  outline-offset:3px;
  border-radius:6px;
}
:focus:not(:focus-visible){outline:none}

/* skip-to-content */
.skip-link{
  position:fixed;left:12px;top:-60px;z-index:120;
  background:var(--pink);color:#fff;
  padding:12px 18px;border-radius:0 0 12px 12px;
  font-weight:700;font-size:15px;
  transition:top .2s var(--ease);
}
.skip-link:focus{top:0;color:#fff}

/* ambient brand wash behind everything */
body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;
  background:
    radial-gradient(ellipse at 20% 0%, rgba(227,37,106,.10) 0%, transparent 50%),
    radial-gradient(ellipse at 90% 100%, rgba(199,154,85,.06) 0%, transparent 55%);
  z-index:0;
}

section[id]{scroll-margin-top:calc(var(--nav-h) + 16px)}
@media(max-width:880px){ :root{--nav-h:72px} }

/* =================== TOPBAR =================== */
.topbar{
  position:sticky;top:0;z-index:50;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;gap:18px;
  padding:12px clamp(16px,3vw,32px);
  background:rgba(10,6,8,.72);
  backdrop-filter:blur(14px) saturate(120%);
  -webkit-backdrop-filter:blur(14px) saturate(120%);
  border-bottom:1px solid var(--line);
  transition:background .25s var(--ease),border-color .25s var(--ease),box-shadow .25s var(--ease);
  min-height:var(--nav-h);
}
.topbar .brand{justify-self:center}
.topbar .nav{justify-self:start}
.topbar .phone-cta{justify-self:end}
.topbar .nav-toggle{justify-self:start}
.topbar.is-scrolled{
  background:rgba(10,6,8,.92);
  border-bottom-color:var(--line-2);
  box-shadow:0 14px 38px -22px rgba(0,0,0,.7);
}
.brand{display:flex;align-items:center;line-height:0}
.brand-logo{
  height:68px;width:auto;display:block;
  border-radius:6px;
  box-shadow:0 0 18px rgba(227,37,106,.28);
}

.nav{display:flex;gap:22px;margin-left:auto;flex-wrap:wrap;align-items:center}
.nav a{
  position:relative;
  font-size:14px;color:var(--ink-2);font-weight:500;letter-spacing:.2px;
  padding:8px 2px;
  transition:color .2s var(--ease);
}
.nav a::after{
  content:"";
  position:absolute;left:0;right:100%;bottom:2px;
  height:2px;background:var(--pink);border-radius:2px;
  transition:right .25s var(--ease);
}
.nav a:hover{color:var(--cream)}
.nav a:hover::after{right:0}
.nav a.is-active{color:var(--cream)}
.nav a.is-active::after{right:0;background:var(--pink);height:2px;box-shadow:0 0 8px rgba(227,37,106,.6)}

/* hamburger button (mobile) */
.nav-toggle{
  display:none;
  margin-left:auto;
  width:44px;height:44px;
  background:transparent;
  border:1px solid var(--line-2);
  border-radius:10px;
  cursor:pointer;
  position:relative;
  align-items:center;justify-content:center;
  flex-direction:column;gap:5px;
  transition:border-color .2s var(--ease),background .2s var(--ease);
}
.nav-toggle:hover{border-color:var(--pink);background:rgba(227,37,106,.08)}
.nav-toggle-bar{
  display:block;width:18px;height:2px;background:var(--cream);
  border-radius:2px;
  transition:transform .25s var(--ease),opacity .2s var(--ease);
  transform-origin:center;
}
.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.phone-cta{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 16px;border-radius:999px;
  min-height:44px;
  border:1px solid var(--pink);
  color:var(--cream);
  font-weight:600;font-size:14px;
  background:linear-gradient(180deg,rgba(227,37,106,.18),rgba(227,37,106,.06));
  transition:background .2s var(--ease),color .2s var(--ease),transform .2s var(--ease),box-shadow .2s var(--ease);
  will-change:transform,box-shadow;
}
.phone-cta:hover{background:var(--pink);color:#fff;transform:translateY(-1px);box-shadow:0 0 22px rgba(227,37,106,.45),inset 0 1px 0 rgba(255,255,255,.12)}

@media(max-width:880px){
  .nav-toggle{display:flex}
  .phone-cta span:last-child{display:none}
  .phone-cta{padding:10px;order:3;min-width:44px;justify-content:center}
  .topbar{padding:10px 14px;gap:10px}
  .brand-logo{height:48px}

  .nav{
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;gap:0;margin:0;
    padding:8px 8px 14px;
    background:rgba(10,6,8,.98);
    backdrop-filter:blur(16px) saturate(120%);
    -webkit-backdrop-filter:blur(16px) saturate(120%);
    border-bottom:1px solid var(--line-2);
    box-shadow:0 24px 50px -20px rgba(0,0,0,.65);
    transform:translateY(-8px);
    opacity:0;pointer-events:none;
    transition:opacity .22s var(--ease),transform .22s var(--ease);
    max-height:calc(100dvh - var(--nav-h));
    overflow-y:auto;
  }
  .nav.is-open{opacity:1;transform:translateY(0);pointer-events:auto}
  .nav a{
    width:100%;padding:15px 16px;font-size:16px;min-height:48px;
    display:flex;align-items:center;
    color:var(--cream);
    border-bottom:1px solid var(--line);border-radius:8px;
  }
  .nav a:last-child{border-bottom:none}
  .nav a::after{display:none}
  .nav a:hover{background:rgba(227,37,106,.10);color:var(--cream)}
  .nav a.is-active{color:var(--pink);background:var(--pink-soft)}
}

/* =================== HERO + ATMOSPHERE (Feature 1) =================== */
.hero{
  position:relative;
  isolation:isolate;
  min-height:calc(100dvh - var(--nav-h));
  padding:clamp(40px,7vh,90px) clamp(16px,3vw,32px) clamp(60px,9vh,120px);
  overflow:hidden;
  background:
    radial-gradient(ellipse 80% 60% at 78% 50%, rgba(227,37,106,.22) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 20% 100%, rgba(90,18,36,.45) 0%, transparent 60%),
    linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%);
}

/* darkened real photo, very slow Ken-Burns */
.hero-photo{
  position:absolute;inset:0;z-index:0;
  background:url("../assets/interior2.jpg") center/cover no-repeat;
  opacity:.22;
  filter:saturate(.85) contrast(1.05) brightness(.7);
  transform:scale(1.06);
  will-change:transform;
  animation:nlKenBurns 38s ease-in-out infinite alternate;
}
.hero-photo::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(90deg,rgba(10,6,8,.92) 0%,rgba(10,6,8,.62) 42%,rgba(10,6,8,.30) 100%),
    linear-gradient(180deg,rgba(10,6,8,.55) 0%,transparent 30%,rgba(10,6,8,.75) 100%);
}
@keyframes nlKenBurns{
  0%  {transform:scale(1.06) translate3d(0,0,0)}
  100%{transform:scale(1.14) translate3d(-1.5%,-1.5%,0)}
}

/* soft haze drifting across the room */
.hero-haze{
  position:absolute;inset:-10% -10% 0 -10%;z-index:0;pointer-events:none;
  background:
    radial-gradient(40% 55% at 30% 80%, rgba(227,37,106,.10) 0%, transparent 60%),
    radial-gradient(45% 50% at 75% 25%, rgba(199,154,85,.06) 0%, transparent 60%);
  filter:blur(8px);
  will-change:transform,opacity;
  animation:nlHaze 22s ease-in-out infinite alternate;
}
@keyframes nlHaze{
  0%  {opacity:.9; transform:translate3d(-2%,0,0)}
  100%{opacity:.6; transform:translate3d(2%,-1.5%,0)}
}

/* slow-drifting neon light blobs (depth) */
.hero-blobs{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.hero-blobs .blob{
  position:absolute;display:block;border-radius:50%;
  filter:blur(48px);will-change:transform,opacity;mix-blend-mode:screen;
}
.blob-1{
  width:46vw;height:46vw;max-width:560px;max-height:560px;left:58%;top:8%;
  background:radial-gradient(circle at 50% 50%, rgba(227,37,106,.58) 0%, rgba(227,37,106,0) 70%);
  animation:nlBlob1 26s ease-in-out infinite alternate;
}
.blob-2{
  width:34vw;height:34vw;max-width:420px;max-height:420px;left:6%;top:46%;
  background:radial-gradient(circle at 50% 50%, rgba(184,27,87,.52) 0%, rgba(184,27,87,0) 70%);
  animation:nlBlob2 32s ease-in-out infinite alternate;
}
.blob-3{
  width:28vw;height:28vw;max-width:360px;max-height:360px;left:40%;top:70%;
  background:radial-gradient(circle at 50% 50%, rgba(199,154,85,.30) 0%, rgba(199,154,85,0) 70%);
  animation:nlBlob3 38s ease-in-out infinite alternate;
}
@keyframes nlBlob1{0%{transform:translate3d(0,0,0) scale(1)}100%{transform:translate3d(-6%,7%,0) scale(1.12)}}
@keyframes nlBlob2{0%{transform:translate3d(0,0,0) scale(1.05)}100%{transform:translate3d(8%,-5%,0) scale(.92)}}
@keyframes nlBlob3{0%{transform:translate3d(0,0,0) scale(.95)}100%{transform:translate3d(-5%,-8%,0) scale(1.1)}}

/* canvas bokeh sits above blobs, below grain/content */
.hero-bokeh{position:absolute;inset:0;z-index:0;width:100%;height:100%;pointer-events:none;opacity:.7}

.hero-grain{
  position:absolute;inset:0;z-index:1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .06 0'/></filter><rect width='180' height='180' filter='url(%23n)'/></svg>");
  opacity:.55;mix-blend-mode:overlay;pointer-events:none;
}
.hero-inner{
  position:relative;z-index:2;
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(28px,5vw,60px);
  align-items:center;
}
.hero-left{position:relative}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:var(--fs-eyebrow);font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:var(--cream-dim);
  margin-bottom:18px;
}
.dot-live{
  width:8px;height:8px;border-radius:50%;background:var(--pink);
  box-shadow:0 0 8px var(--pink),0 0 16px rgba(227,37,106,.4);
  will-change:opacity,transform,box-shadow;
  animation:liveDot 1.5s ease-in-out infinite;
}
@keyframes liveDot{
  0%,100%{opacity:1;transform:scale(1);box-shadow:0 0 8px var(--pink),0 0 16px rgba(227,37,106,.4)}
  50%    {opacity:.55;transform:scale(.85);box-shadow:0 0 4px var(--pink),0 0 8px rgba(227,37,106,.25)}
}

.hero-claim{
  font-family:'Caveat',cursive;font-weight:700;
  font-size:var(--fs-h1);line-height:.95;
  color:var(--cream);margin-bottom:18px;letter-spacing:-.5px;
}
.hero-claim .claim-since{
  display:block;
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:400;
  font-size:clamp(15px,1.6vw,19px);
  color:var(--ink-2);letter-spacing:0;margin-top:14px;line-height:1.45;
}
.hero-sub{
  max-width:520px;font-size:var(--fs-body);
  color:var(--ink-2);margin-bottom:28px;line-height:1.6;
}
.hero-ctas{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:28px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 22px;border-radius:999px;
  min-height:48px;
  font-weight:600;font-size:15px;letter-spacing:.2px;
  cursor:pointer;border:1px solid transparent;
  transition:background .22s var(--ease),color .22s var(--ease),transform .22s var(--ease),box-shadow .22s var(--ease),border-color .22s var(--ease);
}
.btn.primary{
  background:var(--pink);color:#fff;
  box-shadow:0 12px 28px -10px rgba(227,37,106,.5),inset 0 1px 0 rgba(255,255,255,.18);
  will-change:transform,box-shadow;
}
.btn.primary:hover{
  background:var(--pink-deep);transform:translateY(-2px);
  box-shadow:0 18px 36px -10px rgba(227,37,106,.6),0 0 28px rgba(227,37,106,.45),inset 0 1px 0 rgba(255,255,255,.18);
}
.btn.primary:active{transform:translateY(0)}
.btn.ghost{background:transparent;color:var(--cream);border-color:var(--line-2)}
.btn.ghost:hover{border-color:var(--pink);background:rgba(227,37,106,.06);box-shadow:0 0 18px rgba(227,37,106,.22)}
.btn.big{padding:16px 26px;font-size:16px;min-height:52px}

.hero-pills{display:flex;flex-wrap:wrap;gap:10px}
.pill{
  display:inline-flex;align-items:center;
  padding:8px 14px;border-radius:999px;
  background:rgba(247,239,220,.05);
  border:1px solid var(--line-2);
  font-size:13px;color:var(--cream);font-weight:500;letter-spacing:.3px;
}
.pill::before{content:"";display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--pink);margin-right:9px}

/* logo stage right side */
.hero-right{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center}
.logo-stage{
  position:relative;isolation:isolate;
  width:100%;max-width:560px;padding:38px 28px;
  background:linear-gradient(180deg,rgba(8,4,6,.86) 0%,rgba(16,7,9,.9) 100%);
  border:1px solid rgba(227,37,106,.18);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
  transform:rotate(-1.2deg);
  backdrop-filter:blur(2px);
  -webkit-backdrop-filter:blur(2px);
}
.logo-real{
  width:100%;height:auto;position:relative;z-index:2;
  filter:drop-shadow(0 0 18px rgba(227,37,106,.35));
}
/* Variante F: Flicker-On + Steady-Glow (NO laser-sweep) */
.logo-real.logo-vf{
  will-change:filter,opacity;
  animation:vfLoad 1.6s steps(1,end) 1 forwards, vfGlow 5s ease-in-out 1.6s infinite;
}
@keyframes vfLoad{
  0%   {opacity:0;  filter:drop-shadow(0 0 0 rgba(227,37,106,0))}
  20%  {opacity:.85;filter:drop-shadow(0 0 8px rgba(227,37,106,.55))}
  25%  {opacity:.2; filter:drop-shadow(0 0 0 rgba(227,37,106,0))}
  35%  {opacity:.95;filter:drop-shadow(0 0 10px rgba(227,37,106,.65))}
  42%  {opacity:.4; filter:drop-shadow(0 0 2px rgba(227,37,106,.2))}
  55%  {opacity:1;  filter:drop-shadow(0 0 12px rgba(227,37,106,.8))}
  65%  {opacity:.7; filter:drop-shadow(0 0 6px rgba(227,37,106,.45))}
  100% {opacity:1;  filter:drop-shadow(0 0 14px rgba(227,37,106,.85)) drop-shadow(0 0 36px rgba(227,37,106,.55))}
}
@keyframes vfGlow{
  0%,100%{filter:drop-shadow(0 0 10px rgba(227,37,106,.7))  drop-shadow(0 0 28px rgba(227,37,106,.4))}
  50%    {filter:drop-shadow(0 0 14px rgba(227,37,106,.9))  drop-shadow(0 0 42px rgba(227,37,106,.55)) drop-shadow(0 0 78px rgba(227,37,106,.28))}
}
.logo-glow{
  position:absolute;inset:-30px;
  background:radial-gradient(ellipse 60% 40% at 50% 50%,rgba(227,37,106,.32) 0%,transparent 70%);
  filter:blur(20px);z-index:1;
  will-change:opacity,transform;
  animation:heroBgBreath 6s ease-in-out infinite;
}
@keyframes heroBgBreath{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.78;transform:scale(1.04)}}
.logo-address{
  margin-top:14px;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:14px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:var(--cream-dim);text-align:center;max-width:560px;width:100%;padding:0 8px;
}

@media(max-width:880px){
  .hero-inner{grid-template-columns:1fr;text-align:left}
  .hero-right{order:-1;margin-bottom:8px}
  .logo-stage{max-width:440px;padding:24px 20px;transform:rotate(-1deg)}
  .logo-address{font-size:12.5px;letter-spacing:.1em;margin-top:10px}
}

.scroll-cue{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  z-index:3;display:block;
  width:24px;height:38px;border:1.5px solid rgba(227,37,106,.4);border-radius:14px;opacity:.7;
  box-shadow:0 0 10px rgba(227,37,106,.18);
}
.scroll-cue span{
  position:absolute;top:8px;left:50%;transform:translateX(-50%);
  width:3px;height:8px;background:var(--pink);border-radius:2px;
  box-shadow:0 0 6px rgba(255,91,148,.6);
  animation:cue 1.8s ease-in-out infinite;
}
@keyframes cue{0%,100%{opacity:1;top:8px}50%{opacity:.2;top:18px}}
@media(max-width:880px){.scroll-cue{display:none}}

/* =================== SECTION BASE =================== */
.block{position:relative;z-index:1;padding:var(--space-sec) clamp(16px,3vw,32px)}
.block-inner{max-width:var(--max);margin:0 auto;position:relative}

.h2-script{
  font-family:'Caveat',cursive;font-weight:700;
  font-size:var(--fs-h2);line-height:1.02;
  color:var(--cream);letter-spacing:-.4px;margin-bottom:22px;
  text-shadow:0 0 14px rgba(227,37,106,.16),0 0 28px rgba(227,37,106,.06);
}
.sec-head{margin-bottom:44px;max-width:680px}
.sec-head .eyebrow{margin-bottom:10px}
.sec-sub{color:var(--ink-2);font-size:var(--fs-body);margin-top:6px;max-width:54ch;line-height:1.6}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:var(--fs-eyebrow);font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--pink);
}

/* =================== ABOUT =================== */
.about-block{background:linear-gradient(180deg,var(--bg-2),var(--bg) 100%);border-top:1px solid var(--line)}
.about-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(28px,4vw,56px);align-items:start}
.about-text p{color:var(--ink-2);font-size:var(--fs-body);margin-bottom:14px;max-width:54ch;line-height:1.6}
.about-card{
  background:rgba(247,239,220,.03);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;display:flex;flex-direction:column;gap:18px;
  box-shadow:0 20px 50px -30px rgba(0,0,0,.5);transform:rotate(.4deg);
}
.card-row{display:grid;grid-template-columns:96px 1fr;gap:14px;padding-bottom:14px;border-bottom:1px solid var(--line);font-size:14px}
.card-row:last-child{border:0;padding-bottom:0}
.card-key{font-size:var(--fs-eyebrow);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);font-weight:600;padding-top:2px}
.card-val{color:var(--cream);line-height:1.45}
.card-val a{color:var(--pink);font-weight:600}
.card-val a:hover{color:var(--cream)}
@media(max-width:760px){.about-grid{grid-template-columns:1fr}.about-card{transform:none}}

/* =================== BENTO GALERIE =================== */
.galerie-block{background:var(--bg)}
.bento{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:160px;gap:14px}
.bento-cell{
  position:relative;display:block;border-radius:var(--radius);overflow:hidden;
  background:#0e0509;border:1px solid var(--line);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease);
}
.bento-cell img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);filter:saturate(.96) contrast(1.02)}
.bento-cell::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.4) 100%);pointer-events:none;transition:opacity .3s var(--ease)}
.bento-cell:hover{border-color:rgba(227,37,106,.4);box-shadow:0 24px 50px -20px rgba(227,37,106,.35);transform:translateY(-3px)}
.bento-cell:hover img{transform:scale(1.06)}
.c1{grid-column:1 / span 7;grid-row:1 / span 2}
.c2{grid-column:8 / span 5;grid-row:1 / span 2}
.c3{grid-column:1 / span 4;grid-row:3 / span 2}
.c4{grid-column:5 / span 4;grid-row:3 / span 1}
.c5{grid-column:5 / span 4;grid-row:4 / span 1}
.c6{grid-column:9 / span 4;grid-row:3 / span 2}
@media(max-width:860px){
  .bento{grid-template-columns:repeat(6,1fr);grid-auto-rows:140px}
  .c1{grid-column:1 / span 6;grid-row:1 / span 2}
  .c2{grid-column:1 / span 3;grid-row:3 / span 2}
  .c3{grid-column:4 / span 3;grid-row:3 / span 2}
  .c4{grid-column:1 / span 3;grid-row:5 / span 1}
  .c5{grid-column:4 / span 3;grid-row:5 / span 1}
  .c6{grid-column:1 / span 6;grid-row:6 / span 2}
}
@media(max-width:520px){
  .bento{grid-template-columns:repeat(2,1fr);grid-auto-rows:130px}
  .c1,.c2,.c3,.c4,.c5,.c6{grid-column:span 2;grid-row:span 1}
}

/* =================== HIGHLIGHTS =================== */
.highlights-block{
  background:
    radial-gradient(ellipse 50% 35% at 0% 100%,rgba(227,37,106,.08) 0%,transparent 55%),
    linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%);
  border-top:1px solid var(--line);
}
.hl-permanents{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:36px}
.hl-permanent{
  display:flex;flex-direction:column;
  background:linear-gradient(180deg,rgba(227,37,106,.06) 0%,rgba(227,37,106,.02) 100%);
  border:1px solid rgba(227,37,106,.28);border-radius:var(--radius);overflow:hidden;
  box-shadow:0 18px 44px -22px rgba(227,37,106,.32);color:var(--cream);text-decoration:none;
  transition:transform .3s var(--ease),border-color .3s var(--ease),box-shadow .35s var(--ease);
  will-change:transform,box-shadow,border-color;
}
.hl-permanent:nth-child(1){transform:rotate(-.3deg)}
.hl-permanent:nth-child(2){transform:rotate(.25deg)}
.hl-permanent:nth-child(3){transform:rotate(-.2deg)}
.hl-permanent:hover{
  border-color:rgba(227,37,106,.5);
  box-shadow:0 22px 48px -20px rgba(227,37,106,.38),0 0 22px rgba(227,37,106,.18);
  transform:translateY(-3px) rotate(0deg);color:var(--cream);
}
.hl-permanent-img{position:relative;aspect-ratio:16/10;overflow:hidden;background:#0e0509}
.hl-permanent-img img{width:100%;height:100%;object-fit:cover;filter:saturate(1.02) contrast(1.04);transition:transform .6s var(--ease)}
.hl-permanent:hover .hl-permanent-img img{transform:scale(1.04)}
.hl-permanent-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(10,6,8,.45) 100%);pointer-events:none}
.hl-permanent-body{padding:18px 20px 22px;display:flex;flex-direction:column;gap:8px}
.hl-permanent-tag{font-size:var(--fs-eyebrow);letter-spacing:.22em;text-transform:uppercase;color:var(--pink);font-weight:700}
.hl-permanent-title{font-family:'Caveat',cursive;font-weight:700;font-size:clamp(24px,2.4vw,30px);color:var(--cream);letter-spacing:-.2px;line-height:1.05}
.hl-permanent-desc{color:var(--ink-2);font-size:14.5px;line-height:1.55}
@media(max-width:980px){.hl-permanents{grid-template-columns:1fr 1fr;gap:18px}.hl-permanent:nth-child(3){grid-column:1 / -1}}
@media(max-width:700px){
  .hl-permanents{grid-template-columns:1fr;gap:16px}
  .hl-permanent,.hl-permanent:nth-child(n){transform:none}
  .hl-permanent:nth-child(3){grid-column:auto}
}

.hl-events{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.hl-event{
  display:flex;flex-direction:column;
  background:linear-gradient(180deg,rgba(247,239,220,.04) 0%,rgba(247,239,220,.01) 100%);
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;color:var(--cream);
  transition:transform .3s var(--ease),border-color .3s var(--ease),box-shadow .35s var(--ease);
  will-change:transform,box-shadow,border-color;
}
.hl-event:nth-child(1){transform:rotate(-.35deg)}
.hl-event:nth-child(2){transform:rotate(.3deg)}
.hl-event:nth-child(3){transform:rotate(-.25deg)}
.hl-event:nth-child(4){transform:rotate(.4deg)}
.hl-event:nth-child(5){transform:rotate(-.3deg)}
.hl-event:hover{
  border-color:rgba(227,37,106,.4);
  box-shadow:0 22px 48px -20px rgba(227,37,106,.32),0 0 20px rgba(227,37,106,.16);
  transform:translateY(-3px) rotate(0deg);color:var(--cream);
}
.hl-event-img{position:relative;aspect-ratio:16/9;overflow:hidden;background:#0e0509}
.hl-event-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.98) contrast(1.03);transition:transform .6s var(--ease)}
.hl-event:hover .hl-event-img img{transform:scale(1.05)}
.hl-event-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.4) 100%);pointer-events:none}
.hl-event-body{padding:18px 20px 22px}
.hl-event-title{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:clamp(18px,1.7vw,21px);color:var(--cream);letter-spacing:-.2px;margin-bottom:8px;display:flex;align-items:center;gap:10px}
.hl-event-title::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--pink-soft),transparent)}
.hl-event-desc{color:var(--ink-2);font-size:14.5px;line-height:1.55}
@media(max-width:980px){.hl-events{grid-template-columns:1fr 1fr;gap:18px}}
@media(max-width:760px){.hl-events{grid-template-columns:1fr;gap:18px}.hl-event,.hl-event:nth-child(n){transform:none}}

/* =================== EVENT SPOTLIGHT + COUNTDOWN (Feature 2b) =================== */
.spotlight{
  display:grid;grid-template-columns:minmax(260px,40%) 1fr;gap:0;margin-bottom:36px;
  border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid rgba(227,37,106,.30);
  background:linear-gradient(180deg,rgba(227,37,106,.07) 0%,rgba(227,37,106,.02) 100%);
  box-shadow:0 24px 56px -22px rgba(227,37,106,.4),0 0 28px rgba(227,37,106,.12);
}
.spotlight-img{position:relative;min-height:260px;overflow:hidden;background:#0e0509}
.spotlight-img img{width:100%;height:100%;object-fit:cover;filter:saturate(1.02) contrast(1.04)}
.spotlight-img::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 50%,rgba(10,6,8,.5) 100%),linear-gradient(180deg,transparent 60%,rgba(10,6,8,.4) 100%)}
.spotlight-badge{
  position:absolute;top:14px;left:14px;z-index:2;
  display:inline-flex;align-items:center;gap:7px;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:#fff;
  padding:7px 12px;border-radius:999px;
  background:linear-gradient(180deg,rgba(227,37,106,.95),rgba(184,27,87,.95));
  box-shadow:0 8px 22px -10px rgba(227,37,106,.7);
}
.spotlight-badge::before{content:"";width:7px;height:7px;border-radius:50%;background:#fff;box-shadow:0 0 8px #fff;animation:nlLiveBlink 1.6s ease-in-out infinite}
@keyframes nlLiveBlink{0%,100%{opacity:1}50%{opacity:.35}}
.spotlight-body{padding:clamp(22px,3vw,34px);display:flex;flex-direction:column;justify-content:center;gap:10px}
.spotlight-tag{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--pink);font-weight:700}
.spotlight-title{font-family:'Caveat',cursive;font-weight:700;font-size:clamp(30px,3.6vw,46px);line-height:1.02;color:var(--cream);margin:0}
.spotlight-date{font-family:'JetBrains Mono',monospace;font-size:14px;color:var(--cream-dim);letter-spacing:.02em;margin:0}
.spotlight-desc{color:var(--ink-2);font-size:15px;line-height:1.55;max-width:46ch;margin:2px 0 0}
.countdown{display:flex;align-items:flex-start;gap:8px;margin:6px 0 2px}
.cd-unit{
  display:flex;flex-direction:column;align-items:center;gap:4px;min-width:62px;padding:12px 10px;border-radius:14px;
  background:linear-gradient(180deg,rgba(247,239,220,.06),rgba(247,239,220,.02));border:1px solid var(--line-2);
}
.cd-num{font-family:'JetBrains Mono',monospace;font-size:clamp(22px,2.6vw,30px);font-weight:500;color:var(--cream);font-variant-numeric:tabular-nums;line-height:1;text-shadow:0 0 14px rgba(227,37,106,.35)}
.cd-lbl{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);font-weight:600}
.cd-sep{font-family:'JetBrains Mono',monospace;font-size:24px;color:var(--pink);line-height:1;padding-top:14px;opacity:.7}
@media(max-width:760px){
  .spotlight{grid-template-columns:1fr}
  .spotlight-img{aspect-ratio:16/9;min-height:0}
  .cd-unit{min-width:0;flex:1;padding:10px 4px}
  .cd-sep{display:none}
  .countdown{gap:6px}
}

/* =================== COCKTAILS (Feature 2a) =================== */
.cocktails-block{
  background:
    radial-gradient(ellipse 60% 40% at 100% 0%,rgba(227,37,106,.10) 0%,transparent 55%),
    linear-gradient(180deg,var(--bg-2),var(--bg) 100%);
  border-top:1px solid var(--line);
}
.ck-filter{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:28px}
.ck-tab{
  appearance:none;cursor:pointer;min-height:44px;padding:11px 20px;border-radius:999px;
  border:1px solid var(--line-2);background:rgba(247,239,220,.04);color:var(--ink-2);
  font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:600;letter-spacing:.2px;
  transition:color .2s var(--ease),border-color .2s var(--ease),background .2s var(--ease),box-shadow .2s var(--ease),transform .2s var(--ease);
}
.ck-tab:hover{color:var(--cream);border-color:var(--pink);background:rgba(227,37,106,.08)}
.ck-tab.is-active{
  color:#fff;border-color:var(--pink);
  background:linear-gradient(180deg,rgba(227,37,106,.95),rgba(184,27,87,.95));
  box-shadow:0 10px 26px -12px rgba(227,37,106,.6),0 0 18px rgba(227,37,106,.35);
}
.cocktails{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.cocktail-card{
  background:linear-gradient(180deg,rgba(247,239,220,.04) 0%,rgba(247,239,220,.01) 100%);
  border:1px solid var(--line);border-radius:var(--radius);padding:14px;
  display:flex;flex-direction:column;height:100%;
  transition:transform .28s var(--ease),border-color .28s var(--ease),box-shadow .28s var(--ease);
  will-change:transform,box-shadow,border-color;
}
.cocktail-card:nth-child(2){transform:rotate(.4deg)}
.cocktail-card:nth-child(3){transform:rotate(-.35deg)}
.cocktail-card:nth-child(5){transform:rotate(-.45deg)}
.cocktail-card:nth-child(6){transform:rotate(.3deg)}
.cocktail-card:hover{
  border-color:rgba(227,37,106,.40);
  box-shadow:0 20px 44px -22px rgba(227,37,106,.3),0 0 18px rgba(227,37,106,.14);
  transform:translateY(-3px) rotate(0deg);
}
.cocktail-img{position:relative;aspect-ratio:4/3;border-radius:10px;overflow:hidden;margin-bottom:14px;background:#0e0509;cursor:pointer}
.cocktail-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.98) contrast(1.03);transition:transform .55s var(--ease)}
.cocktail-card:hover .cocktail-img img{transform:scale(1.045)}
.cocktail-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.35) 100%);pointer-events:none}
.cocktail-name{
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:clamp(17px,1.6vw,19px);
  color:var(--cream);letter-spacing:-.2px;margin:4px 4px 8px;line-height:1.1;display:flex;align-items:center;gap:10px;
}
.cocktail-name::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--pink-soft),transparent)}
.cocktail-desc{color:var(--ink-2);font-size:14.5px;line-height:1.55;margin:0 4px 4px}
.cocktail-note{margin-top:28px;text-align:center;font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--cream-dim);letter-spacing:.04em}

/* card filtering animation */
.cocktail-card.is-hidden{display:none}
.cocktail-card.is-enter{animation:nlCardIn .35s var(--ease) both}
@keyframes nlCardIn{0%{opacity:0;transform:translate3d(0,10px,0)}100%{opacity:1;transform:translate3d(0,0,0)}}

/* ingredient reveal overlay */
.ck-ingredients{
  position:absolute;inset:0;z-index:3;
  display:flex;flex-direction:column;justify-content:flex-end;gap:8px;padding:16px 16px 14px;
  background:linear-gradient(180deg,rgba(10,6,8,.30) 0%,rgba(10,6,8,.86) 70%,rgba(10,6,8,.94) 100%);
  opacity:0;transform:translate3d(0,6px,0);
  transition:opacity .28s var(--ease),transform .28s var(--ease);pointer-events:none;
}
.cocktail-card:hover .ck-ingredients,
.cocktail-card:focus-within .ck-ingredients,
.cocktail-card.is-open .ck-ingredients{opacity:1;transform:translate3d(0,0,0)}
.ck-ingredients .ck-ing-label{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--pink);font-weight:700}
.ck-ingredients ul{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:6px}
.ck-ingredients li{font-size:12.5px;line-height:1.2;color:var(--cream);padding:5px 10px;border-radius:999px;background:rgba(247,239,220,.10);border:1px solid rgba(247,239,220,.16)}
.ck-badge{
  position:absolute;top:10px;left:10px;z-index:4;
  font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--cream);
  padding:5px 10px;border-radius:999px;background:rgba(10,6,8,.62);border:1px solid var(--line-2);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.ck-badge.is-free{color:#1a0e06;background:rgba(210,168,95,.95);border-color:rgba(210,168,95,.95);font-weight:800}
.ck-tap-hint{
  display:none;position:absolute;bottom:10px;right:10px;z-index:4;
  font-size:11px;color:var(--cream-dim);padding:4px 9px;border-radius:999px;
  background:rgba(10,6,8,.6);border:1px solid var(--line);
}
@media (hover:none){.ck-tap-hint{display:inline-block}.cocktail-card.is-open .ck-tap-hint{display:none}}
@media(max-width:860px){.cocktails{grid-template-columns:repeat(2,1fr);gap:18px}}
@media(max-width:520px){.cocktails{grid-template-columns:1fr;gap:16px}.cocktail-card,.cocktail-card:nth-child(n){transform:none}}

/* =================== ZEITEN + ADRESSE + MAP (Feature 3a) =================== */
.hours-block{
  background:linear-gradient(180deg,var(--bg),var(--bg-2) 100%);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.hours-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,56px);align-items:start}
.hours{width:100%;border-collapse:collapse;font-family:'JetBrains Mono',ui-monospace,monospace;font-size:15px}
.hours tr{border-bottom:1px solid var(--line)}
.hours th,.hours td{padding:12px 0;text-align:left;font-weight:500}
.hours th{color:var(--cream-dim);font-weight:500}
.hours td{color:var(--cream);text-align:right;font-variant-numeric:tabular-nums}
.hours tr.today{background:linear-gradient(90deg,rgba(227,37,106,.14),rgba(227,37,106,.02) 70%,transparent);border-radius:8px;box-shadow:inset 2px 0 0 var(--pink)}
.hours tr.today th,.hours tr.today td{padding-left:10px;padding-right:10px}
.hours tr.today th{color:var(--pink);font-weight:700}
.hours tr.today td{color:var(--pink);font-weight:700}
.hours tr.today th::before{content:"\2192  ";color:var(--pink);font-weight:700}
.addr-col{position:relative}
.addr-line{color:var(--ink-2);font-size:16px;margin-bottom:24px;line-height:1.55}
.addr-ctas{display:flex;flex-wrap:wrap;gap:10px}
.map-embed{
  position:relative;margin:4px 0 22px;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line-2);
  box-shadow:0 20px 50px -28px rgba(0,0,0,.6),0 0 18px rgba(227,37,106,.10);
  aspect-ratio:16/10;background:#0e0509;
}
.map-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(.25) contrast(1.05) brightness(.92) saturate(1.05)}
@media(max-width:760px){.hours-grid{grid-template-columns:1fr}.map-embed{aspect-ratio:4/3}}

/* =================== STIMMEN =================== */
.voices-block{background:var(--bg)}
.voices{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.voice{
  background:linear-gradient(180deg,rgba(247,239,220,.04) 0%,rgba(247,239,220,.01) 100%);
  border:1px solid var(--line);border-radius:var(--radius);padding:22px;position:relative;
  transition:border-color .25s var(--ease),transform .25s var(--ease);
}
.voice:hover{border-color:rgba(227,37,106,.35);transform:translateY(-2px)}
.voice.v2{transform:rotate(.6deg)}
.voice.v2:hover{transform:rotate(.6deg) translateY(-2px)}
.voice.v3{transform:rotate(-.5deg)}
.voice.v3:hover{transform:rotate(-.5deg) translateY(-2px)}
.stars{color:var(--gold);font-size:14px;letter-spacing:3px;margin-bottom:12px}
.voice blockquote{font-family:'Caveat',cursive;font-size:22px;line-height:1.3;color:var(--cream);margin-bottom:14px;font-weight:500}
.voice figcaption{font-size:12px;color:var(--ink-3);letter-spacing:.18em;text-transform:uppercase;font-weight:600}
.rating-line{text-align:center;margin-top:28px;color:var(--cream-dim);font-size:14px;font-family:'JetBrains Mono',monospace}
@media(max-width:760px){.voices{grid-template-columns:1fr}.voice.v2,.voice.v3{transform:none}.voice.v2:hover,.voice.v3:hover{transform:translateY(-2px)}}

/* =================== MIETEN + FORM (Feature 3b) =================== */
.mieten-block{
  background:
    radial-gradient(ellipse 50% 35% at 100% 0%,rgba(227,37,106,.08) 0%,transparent 55%),
    linear-gradient(180deg,var(--bg-2) 0%,var(--bg) 100%);
  border-top:1px solid var(--line);
}
.mieten-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:36px;align-items:center}
.mieten-text .h2-script{margin-top:6px;margin-bottom:14px}
.mieten-lead{color:var(--ink-2);font-size:var(--fs-lead);line-height:1.6;max-width:48ch;margin-bottom:22px}
.mieten-facts{list-style:none;padding:0;margin:0 0 26px;display:flex;flex-direction:column;gap:12px}
.mieten-facts li{display:flex;align-items:center;gap:12px;padding:12px 16px;background:rgba(247,239,220,.03);border:1px solid var(--line-2);border-radius:var(--radius);color:var(--cream);font-size:15px;line-height:1.45}
.mf-icon{font-size:20px;line-height:1;filter:drop-shadow(0 0 6px rgba(227,37,106,.3))}
.mieten-ctas{display:flex;flex-wrap:wrap;gap:12px}
.mieten-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line-2);box-shadow:var(--shadow);transform:rotate(.4deg);transition:transform .35s var(--ease)}
.mieten-card:hover{transform:rotate(0deg) translateY(-2px)}
.mieten-card-img{aspect-ratio:4/3;overflow:hidden;background:#0e0509}
.mieten-card-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.98) contrast(1.03)}
.mieten-card-cap{position:absolute;left:0;right:0;bottom:0;padding:14px 18px;background:linear-gradient(180deg,transparent 0%,rgba(10,6,8,.85) 100%);color:var(--cream);font-size:13.5px;letter-spacing:.1px}
@media(max-width:880px){.mieten-grid{grid-template-columns:1fr;gap:26px}.mieten-card{transform:none}}

.anfrage{
  margin-top:clamp(36px,5vw,56px);padding:clamp(24px,3.5vw,40px);border-radius:var(--radius-lg);border:1px solid var(--line-2);
  background:
    radial-gradient(ellipse 60% 50% at 100% 0%,rgba(227,37,106,.08) 0%,transparent 55%),
    linear-gradient(180deg,rgba(247,239,220,.04),rgba(247,239,220,.01));
  box-shadow:0 24px 60px -30px rgba(0,0,0,.6);
}
.anfrage-head{margin-bottom:24px;max-width:620px}
.anfrage-head .h2-script{margin:6px 0 8px;font-size:clamp(30px,4vw,46px)}
.anfrage-form{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.field{display:flex;flex-direction:column;gap:7px}
.field-wide{grid-column:1 / -1}
.field label{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--cream-dim);font-weight:600}
.field input,.field select,.field textarea{
  width:100%;min-height:48px;padding:13px 14px;border-radius:var(--radius);
  border:1px solid var(--line-2);background:rgba(10,6,8,.55);color:var(--ink);
  font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;line-height:1.4;
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease);
}
.field textarea{min-height:96px;resize:vertical}
.field select{
  appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='%23d3c8af'><path d='M7 10l5 5 5-5z'/></svg>");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;
}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-3)}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--pink);background:rgba(10,6,8,.7);
  box-shadow:0 0 0 3px rgba(227,37,106,.18),0 0 18px rgba(227,37,106,.18);
}
.field input[type="date"]::-webkit-calendar-picker-indicator,
.field input[type="time"]::-webkit-calendar-picker-indicator{filter:invert(.85) sepia(.4) saturate(4) hue-rotate(300deg);cursor:pointer}
.form-error{grid-column:1 / -1;margin:0;color:#ff8aae;font-size:14px;font-weight:600}
.anfrage-ctas{grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:12px;margin-top:4px}
.anfrage-ctas .btn{min-height:48px}
.form-hint{grid-column:1 / -1;margin:6px 0 0;font-size:13.5px;color:var(--ink-3);line-height:1.5}
@media(max-width:680px){.anfrage-form{grid-template-columns:1fr}.anfrage-ctas .btn{width:100%;justify-content:center}}

/* toast */
.nl-toast{
  position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(12px);z-index:200;
  max-width:min(92vw,420px);padding:13px 18px;border-radius:999px;
  background:rgba(16,7,9,.96);border:1px solid rgba(227,37,106,.45);color:var(--cream);
  font-size:14px;font-weight:500;
  box-shadow:0 18px 44px -18px rgba(0,0,0,.7),0 0 22px rgba(227,37,106,.3);
  opacity:0;pointer-events:none;transition:opacity .25s var(--ease),transform .25s var(--ease);text-align:center;
}
.nl-toast.is-show{opacity:1;transform:translateX(-50%) translateY(0)}

/* =================== KONTAKT =================== */
.kontakt-block{
  background:
    radial-gradient(ellipse 70% 50% at 50% 0%,rgba(227,37,106,.15) 0%,transparent 60%),
    linear-gradient(180deg,var(--bg-2),var(--bg) 100%);
  border-top:1px solid var(--line);
}
.kontakt-card{
  max-width:680px;margin:0 auto;text-align:center;
  background:rgba(247,239,220,.03);border:1px solid var(--line-2);border-radius:var(--radius-lg);
  padding:clamp(34px,5vw,60px) clamp(24px,4vw,48px);
}
.kontakt-card p{color:var(--ink-2);font-size:var(--fs-lead);margin:8px auto 26px;max-width:48ch}
.kontakt-ctas{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.fb-btn svg{vertical-align:middle;margin-right:8px;color:#3b89ff}
.fb-btn:hover svg{color:#5ba0ff}

/* =================== FOOTER =================== */
.foot{background:#070406;border-top:1px solid var(--line);padding:clamp(40px,6vw,72px) clamp(16px,3vw,32px) 30px}
.foot-inner{max-width:var(--max);margin:0 auto}
.foot-cols{display:grid;grid-template-columns:1.4fr 1fr 2fr;gap:36px;margin-bottom:32px}
.foot-logo{display:block;height:80px;width:auto;margin-bottom:14px;filter:drop-shadow(0 0 14px rgba(227,37,106,.32))}
.foot-tag{color:var(--ink-3);font-size:14px;max-width:30ch}
.foot h4{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--cream-dim);margin-bottom:10px;font-weight:600}
.foot p{color:var(--ink-2);font-size:14px;margin-bottom:6px;line-height:1.5}
.foot a{color:var(--cream)}
.foot a:hover{color:var(--pink)}
.muted{color:var(--ink-3)}
.small{font-size:12px;line-height:1.55}
.foot-social{margin-top:14px}
.foot-social a{display:inline-flex;align-items:center;gap:10px;color:var(--ink-2);text-decoration:none;transition:color .2s var(--ease);font-size:14px}
.foot-social a svg{color:#3b89ff}
.foot-social a:hover{color:var(--cream)}
.foot-social a:hover svg{color:#5ba0ff}
.foot-bottom{border-top:1px solid var(--line);padding-top:18px;font-size:12px;color:var(--ink-3);text-align:center}
@media(max-width:760px){.foot-cols{grid-template-columns:1fr;gap:24px}}
@media(max-width:580px){.foot-logo{height:64px}}

/* =================== LIGHTBOX =================== */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(8,4,6,.95);display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .25s var(--ease);padding:24px}
.lightbox.open{display:flex;opacity:1}
.lightbox-img{max-width:min(1400px,92vw);max-height:88vh;width:auto;height:auto;display:block;border-radius:10px;box-shadow:0 0 60px rgba(227,37,106,.3)}
.lightbox-btn{position:absolute;width:54px;height:54px;background:rgba(20,12,16,.85);color:var(--cream);border:1px solid var(--line-2);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s var(--ease),transform .15s var(--ease),color .15s var(--ease)}
.lightbox-btn:hover{background:var(--pink);color:#fff}
.lightbox-prev{left:max(16px,2vw);top:50%;transform:translateY(-50%)}
.lightbox-prev:hover{transform:translateY(-50%) scale(1.08)}
.lightbox-next{right:max(16px,2vw);top:50%;transform:translateY(-50%)}
.lightbox-next:hover{transform:translateY(-50%) scale(1.08)}
.lightbox-close{top:max(16px,2vw);right:max(16px,2vw);width:48px;height:48px}
.lightbox-close:hover{transform:scale(1.1)}
.lightbox-counter{position:absolute;bottom:max(16px,2vw);left:50%;transform:translateX(-50%);color:var(--cream-dim);font-size:13px;background:rgba(20,12,16,.7);padding:6px 14px;border-radius:30px;font-family:'JetBrains Mono',monospace;letter-spacing:.05em}
@media (max-width:580px){.lightbox{padding:12px}.lightbox-btn{width:44px;height:44px}.lightbox-prev{left:8px}.lightbox-next{right:8px}.lightbox-close{width:44px;height:44px;top:10px;right:10px}.lightbox-counter{bottom:14px;font-size:12px}}

/* =================== REVEAL-ON-SCROLL (JS fallback path) =================== */
.reveal{opacity:0;transform:translate3d(0,8px,0);transition:opacity .55s var(--ease),transform .55s var(--ease);will-change:opacity,transform}
.reveal.is-in{opacity:1;transform:translate3d(0,0,0)}

/* =====================================================================
   SOTA progressive enhancement: scroll-driven reveals.
   Browsers WITH animation-timeline get native, jank-free, main-thread-
   free reveals. The .no-csat class (set by JS when unsupported) keeps
   the IntersectionObserver path above. reduced-motion neutralises both.
   ===================================================================== */
@supports (animation-timeline: view()){
  html:not(.no-csat) .reveal{
    opacity:1;transform:none;transition:none;
  }
  html:not(.no-csat) .hl-permanent,
  html:not(.no-csat) .hl-event,
  html:not(.no-csat) .bento-cell,
  html:not(.no-csat) .voice,
  html:not(.no-csat) .about-card,
  html:not(.no-csat) .mieten-card,
  html:not(.no-csat) .spotlight{
    animation:csatReveal linear both;
    animation-timeline:view();
    animation-range:entry 0% cover 22%;
    will-change:opacity,transform;
  }
  @keyframes csatReveal{
    from{opacity:0;transform:translate3d(0,26px,0)}
    to{opacity:1;transform:translate3d(0,0,0)}
  }
}

/* small touch polish */
@media(max-width:580px){
  .hours{font-size:16px}
  .hours th,.hours td{padding:14px 4px}
  .addr-line{font-size:16.5px}
  .mieten-lead{font-size:16.5px}
  .kontakt-card p{font-size:16.5px}
}

/* =================== REDUCED MOTION (full static fallback) =================== */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none !important;transition:none !important;scroll-behavior:auto !important}
  .hero-photo{transform:scale(1.04)}
  .hero-haze{opacity:.7}
  .hero-bokeh{display:none}
  .logo-real.logo-vf{opacity:1 !important;filter:drop-shadow(0 0 12px rgba(227,37,106,.75)) drop-shadow(0 0 30px rgba(227,37,106,.45)) !important}
  .reveal{opacity:1 !important;transform:none !important}
  /* neutralise scroll-driven keyframes too */
  .hl-permanent,.hl-event,.bento-cell,.voice,.about-card,.mieten-card,.spotlight{animation:none !important;opacity:1 !important;transform:none !important}
}
