/* =====================================================================
   KEDO STUDIO — Mietstudio Zell am See
   Design system & stylesheet
   Editorial photo-studio aesthetic · self-hosted fonts · no external CDNs
   ===================================================================== */

/* ---------- Fonts (self-hosted, DSGVO-safe) ---------- */
@font-face{font-family:"Roboto";src:url("../assets/fonts/Roboto-Light.woff2") format("woff2");font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:"Roboto";src:url("../assets/fonts/Roboto-Regular.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Roboto";src:url("../assets/fonts/Roboto-Medium.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Roboto";src:url("../assets/fonts/Roboto-Bold.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Roboto";src:url("../assets/fonts/Roboto-Black.woff2") format("woff2");font-weight:900;font-style:normal;font-display:swap}

/* ---------- Tokens ---------- */
:root{
  --ink:#0a0a0a;          /* near-black */
  --ink-soft:#161616;
  --paper:#f4f2ec;        /* warm off-white */
  --paper-2:#eae7dd;      /* warm gray, alt sections */
  --line:#d8d4c8;
  --accent:#e1fc21;       /* acid yellow-green */
  --muted:#646057;
  --muted-on-dark:#a8a59b;
  --white:#ffffff;

  --maxw:1320px;
  --gut:clamp(20px,5vw,72px);
  --radius:2px;

  --f-display:"Roboto",system-ui,sans-serif;
  --f-body:"Roboto",system-ui,sans-serif;

  --ease:cubic-bezier(.22,1,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --dur:.7s;

  --nav-h:74px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;font-family:var(--f-body);background:var(--paper);color:var(--ink);
  font-weight:400;line-height:1.6;font-size:clamp(16px,1.05vw,18px);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4,p{margin:0}
::selection{background:var(--accent);color:var(--ink)}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
.section{padding-block:clamp(72px,11vw,160px)}
.section--dark{background:var(--ink);color:var(--paper)}
.section--paper2{background:var(--paper-2)}
.eyebrow{
  font-size:.74rem;font-weight:700;letter-spacing:.32em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.7em;color:var(--muted);
}
.section--dark .eyebrow{color:var(--muted-on-dark)}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--accent)}
.display{
  font-family:var(--f-display);font-weight:900;line-height:.96;letter-spacing:-.02em;
  text-transform:uppercase;
}
.h-xl{font-size:clamp(2.6rem,8vw,7rem)}
.h-lg{font-size:clamp(2rem,5.4vw,4.4rem)}
.h-md{font-size:clamp(1.5rem,3vw,2.4rem)}
.lead{font-size:clamp(1.05rem,1.6vw,1.4rem);font-weight:300;line-height:1.55;max-width:46ch}
.muted{color:var(--muted)}
.section--dark .muted{color:var(--muted-on-dark)}
.accent-text{color:var(--accent)}

/* reveal */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--accent);--fg:var(--ink);
  display:inline-flex;align-items:center;gap:.7em;
  padding:1.05em 1.9em;background:var(--bg);color:var(--fg);
  font-weight:700;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;
  border-radius:100px;position:relative;overflow:hidden;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease);
  will-change:transform;
}
.btn span{position:relative;z-index:1}
.btn svg{position:relative;z-index:1;transition:transform .5s var(--ease)}
.btn::after{content:"";position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:transform .5s var(--ease);z-index:0}
.btn:hover{transform:translateY(-3px)}
.btn:hover svg{transform:translateX(5px)}
.btn:hover::after{transform:translateY(0)}
.btn:hover{color:var(--accent)}
.btn--ghost{--bg:transparent;--fg:currentColor;border:1px solid currentColor}
.btn--ghost::after{background:var(--accent)}
.btn--ghost:hover{color:var(--ink)}
.btn--lg{padding:1.2em 2.3em;font-size:.9rem}

.link-underline{position:relative;font-weight:500;letter-spacing:.02em;display:inline-block}
.link-underline::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .5s var(--ease)}
.link-underline:hover::after{transform:scaleX(1);transform-origin:left}

/* =====================================================================
   NAV
   ===================================================================== */
.nav{
  position:fixed;top:0;left:0;width:100%;height:var(--nav-h);z-index:60;
  display:flex;align-items:center;
  transition:background .5s var(--ease),box-shadow .5s var(--ease),height .4s var(--ease);
}
.nav__inner{max-width:1480px;margin:0 auto;padding-inline:clamp(18px,4vw,46px);width:100%;
  display:flex;align-items:center;justify-content:space-between;gap:2rem}
.nav__logo{display:flex;align-items:center}
.nav__logo img{height:26px;width:auto}
.nav__menu{display:flex;align-items:center;gap:clamp(1.1rem,2.2vw,2.4rem)}
.nav__menu a{font-size:.8rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--paper);position:relative;opacity:.85;transition:opacity .3s}
.nav__menu a::after{content:"";position:absolute;left:0;bottom:-6px;width:100%;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease)}
.nav__menu a:hover{opacity:1}
.nav__menu a:hover::after{transform:scaleX(1);transform-origin:left}
.nav__right{display:flex;align-items:center;gap:1.3rem}
.lang{display:flex;align-items:center;gap:.5rem;font-size:.78rem;font-weight:600;letter-spacing:.08em;color:var(--paper)}
.lang a{opacity:.5;transition:opacity .3s}
.lang a.is-active{opacity:1;color:var(--accent)}
.lang a:hover{opacity:1}
.lang__sep{opacity:.3}
.nav__cta{display:inline-flex;align-items:center;gap:.55em;padding:.72em 1.4em;background:var(--accent);color:var(--ink);border-radius:100px;font-size:.76rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;transition:transform .4s var(--ease)}
.nav__cta:hover{transform:translateY(-2px)}

/* scrolled state */
.nav.is-scrolled{background:rgba(10,10,10,.82);backdrop-filter:blur(14px);height:62px;box-shadow:0 1px 0 rgba(255,255,255,.06)}
.nav.is-hidden{transform:translateY(-100%);transition:transform .5s var(--ease)}

/* burger */
.burger{display:none;width:34px;height:34px;position:relative;z-index:80}
.burger span{position:absolute;left:4px;right:4px;height:2px;background:var(--paper);transition:transform .4s var(--ease),opacity .3s}
.burger span:nth-child(1){top:11px}
.burger span:nth-child(2){top:17px}
.burger span:nth-child(3){top:23px}
.nav.menu-open .burger span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav.menu-open .burger span:nth-child(2){opacity:0}
.nav.menu-open .burger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* mobile overlay */
.mobile-menu{position:fixed;inset:0;background:var(--ink);z-index:55;display:flex;flex-direction:column;justify-content:center;padding:0 var(--gut);
  clip-path:circle(0% at calc(100% - 40px) 40px);transition:clip-path .6s var(--ease);pointer-events:none}
.nav.menu-open + .mobile-menu,.mobile-menu.open{clip-path:circle(150% at calc(100% - 40px) 40px);pointer-events:auto}
.mobile-menu a.m-link{color:var(--paper);font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:clamp(2rem,9vw,3.4rem);line-height:1.08;letter-spacing:-.01em;padding:.12em 0;opacity:0;transform:translateY(20px);transition:opacity .5s var(--ease),transform .5s var(--ease),color .3s}
.mobile-menu.open a.m-link{opacity:1;transform:none}
.mobile-menu a.m-link:hover{color:var(--accent)}
.mobile-menu .m-foot{margin-top:2.4rem;display:flex;gap:1.4rem;align-items:center;color:var(--muted-on-dark);font-size:.85rem;opacity:0;transition:opacity .6s .3s}
.mobile-menu.open .m-foot{opacity:1}

/* =====================================================================
   HERO
   ===================================================================== */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;background:var(--ink);color:var(--paper)}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media video,.hero__media img{width:100%;height:100%;object-fit:cover}
.hero__media .v-vertical{display:none}
.hero__media::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(10,10,10,.55) 0%,rgba(10,10,10,.15) 32%,rgba(10,10,10,.35) 62%,rgba(10,10,10,.92) 100%)}
.hero__inner{position:relative;z-index:2;width:100%;max-width:1480px;margin:0 auto;padding:0 clamp(18px,4vw,46px) clamp(40px,7vh,90px)}
.hero__tag{margin-bottom:1.6rem}
.hero__tag .eyebrow{color:var(--paper)}
.hero__tag .eyebrow::before{background:var(--accent)}
.hero__title{font-family:var(--f-display);font-weight:900;text-transform:uppercase;line-height:.92;letter-spacing:-.025em;
  font-size:clamp(3.4rem,13vw,11rem)}
.hero__sub{display:block;font-size:clamp(1rem,2.4vw,1.9rem);font-weight:300;letter-spacing:.02em;text-transform:none;margin-top:.5rem;color:var(--accent)}
.hero__row{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:2rem;margin-top:2.4rem}
.hero__claim{max-width:30ch;font-size:clamp(1rem,1.4vw,1.25rem);font-weight:300;color:var(--paper)}
.hero__cta{display:flex;gap:1rem;flex-wrap:wrap}
.hero__scroll{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted-on-dark)}
.hero__scroll .bar{width:1px;height:42px;background:linear-gradient(var(--accent),transparent);animation:scrolldown 2.2s var(--ease) infinite}
@keyframes scrolldown{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* marquee strip under hero */
.marquee{background:var(--accent);color:var(--ink);overflow:hidden;white-space:nowrap;border-block:1px solid var(--ink)}
.marquee__track{display:inline-flex;gap:2.5rem;padding-block:.85rem;animation:marquee 26s linear infinite;will-change:transform}
.marquee span{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:1rem;letter-spacing:.02em;display:inline-flex;align-items:center;gap:2.5rem}
.marquee span::after{content:"✳";font-size:.8em}
@keyframes marquee{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee__track{animation:none}}

/* =====================================================================
   VISION / INTRO split
   ===================================================================== */
.vision{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.vision__media{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:var(--radius)}
.vision__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.vision__media:hover img{transform:scale(1.05)}
.vision__media .badge{position:absolute;left:18px;bottom:18px;background:var(--accent);color:var(--ink);padding:.5em 1em;font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;border-radius:100px}
.vision__body p{margin-top:1.4rem;max-width:48ch}
.options{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2.4rem}
.option{border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem 1.4rem;transition:border-color .4s var(--ease),background .4s var(--ease),transform .4s var(--ease);background:var(--paper)}
.option:hover{border-color:var(--ink);transform:translateY(-4px)}
.option .num{font-size:.7rem;font-weight:700;letter-spacing:.2em;color:var(--accent);background:var(--ink);width:fit-content;padding:.35em .7em;border-radius:100px}
.option h3{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:1.45rem;margin-top:1rem;letter-spacing:-.01em}
.option p{margin-top:.5rem;font-size:.95rem;color:var(--muted)}
@media (max-width:860px){.vision{grid-template-columns:1fr}.options{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.options{grid-template-columns:1fr}}

/* =====================================================================
   SERVICES
   ===================================================================== */
.services__head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:clamp(2.5rem,6vw,4.5rem)}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1rem,2vw,1.6rem)}
.svc{position:relative;overflow:hidden;border-radius:var(--radius);min-height:clamp(340px,42vw,540px);display:flex;align-items:flex-end;color:var(--paper);isolation:isolate}
.svc img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform 1.5s var(--ease)}
.svc::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(10,10,10,.05) 30%,rgba(10,10,10,.9) 100%);transition:background .5s}
.svc:hover img{transform:scale(1.06)}
.svc__body{padding:clamp(1.5rem,3vw,2.4rem)}
.svc__num{font-size:.72rem;font-weight:700;letter-spacing:.24em;color:var(--accent)}
.svc h3{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:clamp(1.5rem,2.6vw,2.3rem);line-height:1;margin:.7rem 0 .6rem;letter-spacing:-.01em}
.svc p{font-size:.96rem;max-width:42ch;color:#e9e7df;max-height:0;opacity:0;overflow:hidden;transition:max-height .6s var(--ease),opacity .5s var(--ease),margin .5s}
.svc .tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem}
.svc .tags span{font-size:.66rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;border:1px solid rgba(255,255,255,.4);padding:.35em .8em;border-radius:100px}
.svc:hover p{max-height:200px;opacity:1}
@media (hover:none){.svc p{max-height:200px;opacity:1}}
@media (max-width:760px){.svc-grid{grid-template-columns:1fr}}

/* =====================================================================
   GALLERY / WORK
   ===================================================================== */
.gallery__head{margin-bottom:clamp(2rem,5vw,3.5rem)}
.masonry{columns:3;column-gap:14px}
.masonry .g-item{break-inside:avoid;margin-bottom:14px;position:relative;overflow:hidden;border-radius:var(--radius);cursor:pointer;background:var(--ink-soft)}
.masonry .g-item img{display:block;width:100%;height:auto;transition:transform 1.2s var(--ease)}
.masonry .g-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(10,10,10,.7));opacity:0;transition:opacity .5s}
.masonry .g-item .g-plus{position:absolute;right:14px;bottom:14px;width:38px;height:38px;border-radius:50%;background:var(--accent);color:var(--ink);display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(8px) scale(.8);transition:all .5s var(--ease);z-index:2}
.masonry .g-item:hover img{transform:scale(1.06)}
.masonry .g-item:hover::after{opacity:1}
.masonry .g-item:hover .g-plus{opacity:1;transform:none}
.g-item.is-hidden{display:none}
.gallery__more{text-align:center;margin-top:2.6rem}
@media (max-width:900px){.masonry{columns:2}}
@media (max-width:540px){.masonry{columns:2;column-gap:10px}.masonry .g-item{margin-bottom:10px}}

/* lightbox */
.lb{position:fixed;inset:0;z-index:120;background:rgba(8,8,8,.96);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s}
.lb.open{opacity:1;pointer-events:auto}
.lb img{max-width:90vw;max-height:86vh;border-radius:var(--radius);box-shadow:0 30px 90px rgba(0,0,0,.6);transform:scale(.96);transition:transform .5s var(--ease)}
.lb.open img{transform:none}
.lb__close,.lb__nav{position:absolute;color:var(--paper);width:54px;height:54px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.25);border-radius:50%;transition:background .3s,color .3s}
.lb__close:hover,.lb__nav:hover{background:var(--accent);color:var(--ink);border-color:var(--accent)}
.lb__close{top:24px;right:24px}
.lb__nav{top:50%;transform:translateY(-50%)}
.lb__nav.prev{left:24px}.lb__nav.next{right:24px}
.lb__count{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);color:var(--muted-on-dark);font-size:.8rem;letter-spacing:.2em}
@media (max-width:600px){.lb__nav{width:44px;height:44px}.lb__nav.prev{left:10px}.lb__nav.next{right:10px}.lb__close{top:14px;right:14px}}

/* =====================================================================
   EQUIPMENT
   ===================================================================== */
.equip__head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:clamp(2.5rem,5vw,4rem)}
.equip-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:minmax(0,auto);gap:14px}
.eq{position:relative;overflow:hidden;border-radius:var(--radius);background:var(--ink-soft);color:var(--paper);display:flex;align-items:flex-end;min-height:240px;isolation:isolate}
.eq img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform 1.4s var(--ease)}
.eq::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(10,10,10,.1) 35%,rgba(10,10,10,.88))}
.eq:hover img{transform:scale(1.07)}
.eq__body{padding:1.3rem 1.4rem}
.eq__num{font-size:.7rem;font-weight:700;letter-spacing:.2em;color:var(--accent)}
.eq h3{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:1.25rem;margin-top:.5rem;letter-spacing:-.01em;line-height:1.02}
.eq p{font-size:.86rem;color:#d9d7cf;margin-top:.5rem;max-height:0;opacity:0;overflow:hidden;transition:max-height .6s var(--ease),opacity .5s,margin .5s}
.eq:hover p{max-height:160px;opacity:1}
@media (hover:none){.eq p{max-height:160px;opacity:1}}
/* bento spans */
.eq--wide{grid-column:span 3}
.eq--tall{grid-column:span 3}
.eq--std{grid-column:span 2}
@media (max-width:1000px){.equip-grid{grid-template-columns:repeat(4,1fr)}.eq--wide,.eq--tall{grid-column:span 2}.eq--std{grid-column:span 2}}
@media (max-width:620px){.equip-grid{grid-template-columns:1fr 1fr}.eq--wide,.eq--tall,.eq--std{grid-column:span 1}.eq{min-height:200px}}

/* =====================================================================
   TEAM
   ===================================================================== */
.team{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.team__media{position:relative}
.team__media .ph{aspect-ratio:3/4;overflow:hidden;border-radius:var(--radius)}
.team__media .ph img{width:100%;height:100%;object-fit:cover}
.team__media .ph.b{position:absolute;width:46%;right:-6%;bottom:-10%;aspect-ratio:3/4;box-shadow:0 24px 60px rgba(0,0,0,.4);border:4px solid var(--ink)}
.team__names{display:flex;gap:1.4rem;margin:1.8rem 0;flex-wrap:wrap}
.team__person{border-left:2px solid var(--accent);padding-left:1rem}
.team__person h4{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:1.2rem;color:var(--accent)}
.team__person span{font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-on-dark)}
.team__body p{margin-top:1.2rem;max-width:52ch}
@media (max-width:860px){.team{grid-template-columns:1fr}.team__media{max-width:440px}}

/* =====================================================================
   PRICING
   ===================================================================== */
.pricing__head{text-align:center;max-width:60ch;margin:0 auto clamp(2.5rem,5vw,4rem)}
.price-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(1rem,2.5vw,2rem)}
.pcard{background:var(--ink);color:var(--paper);border-radius:6px;padding:clamp(1.8rem,3vw,2.8rem);position:relative;overflow:hidden}
.pcard--accent{background:var(--accent);color:var(--ink)}
.pcard__label{display:flex;align-items:center;gap:.7rem;font-size:.75rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase}
.pcard--accent .pcard__label{color:var(--ink)}
.pcard h3{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:clamp(1.6rem,3vw,2.2rem);margin-top:.7rem;letter-spacing:-.01em}
.prow{display:flex;justify-content:space-between;align-items:baseline;padding:1.05rem 0;border-bottom:1px solid rgba(255,255,255,.12)}
.pcard--accent .prow{border-color:rgba(10,10,10,.16)}
.prow:last-of-type{border-bottom:none}
.prow .pd{font-weight:300;font-size:1.02rem}
.prow .pp{font-family:var(--f-display);font-weight:900;font-size:1.4rem;letter-spacing:-.01em}
.pcard__note{margin-top:1.2rem;font-size:.82rem;color:var(--muted-on-dark)}
.pcard--accent .pcard__note{color:rgba(10,10,10,.6)}
.pricing__foot{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.4rem}
.foot-card{border:1px solid var(--line);border-radius:6px;padding:1.5rem 1.6rem;background:var(--paper)}
.foot-card h4{font-size:.78rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;margin-bottom:.8rem;display:flex;align-items:center;gap:.6rem}
.foot-card h4::before{content:"";width:8px;height:8px;background:var(--accent);border-radius:50%}
.foot-card p{font-size:.92rem;color:var(--muted)}
.foot-card .sr{display:flex;justify-content:space-between;padding:.35rem 0;font-size:.92rem}
@media (max-width:820px){.price-grid{grid-template-columns:1fr}.pricing__foot{grid-template-columns:1fr}}

/* =====================================================================
   FAQ
   ===================================================================== */
.faq{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.faq__list{border-top:1px solid var(--line)}
.faq__item{border-bottom:1px solid var(--line)}
.faq__q{width:100%;text-align:left;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;padding:1.5rem 0;font-size:clamp(1rem,1.5vw,1.18rem);font-weight:500;color:var(--ink)}
.faq__q .ic{flex:none;width:30px;height:30px;border-radius:50%;border:1px solid var(--line);position:relative;transition:background .4s,border-color .4s}
.faq__q .ic::before,.faq__q .ic::after{content:"";position:absolute;background:var(--ink);transition:transform .4s var(--ease),background .3s}
.faq__q .ic::before{left:50%;top:9px;bottom:9px;width:2px;transform:translateX(-50%)}
.faq__q .ic::after{top:50%;left:9px;right:9px;height:2px;transform:translateY(-50%)}
.faq__item.open .faq__q .ic{background:var(--accent);border-color:var(--accent)}
.faq__item.open .faq__q .ic::before{transform:translateX(-50%) scaleY(0)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .55s var(--ease)}
.faq__a p{padding-bottom:1.5rem;color:var(--muted);max-width:60ch;font-size:.98rem}
.faq__intro h2{margin-bottom:1.2rem}
@media (max-width:820px){.faq{grid-template-columns:1fr}}

/* =====================================================================
   CONTACT / BOOKING
   ===================================================================== */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem)}
.contact__intro .lead{margin-top:1.4rem}
.contact__meta{margin-top:2.4rem;display:grid;gap:1.2rem}
.cmeta{display:flex;gap:1rem;align-items:flex-start}
.cmeta .ic{flex:none;width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:var(--accent)}
.cmeta .t{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-on-dark)}
.cmeta .v{font-size:1.02rem;font-weight:500}
.cmeta a:hover .v{color:var(--accent)}
.form{display:grid;gap:1.1rem}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{position:relative;display:flex;flex-direction:column}
.field label{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-on-dark);margin-bottom:.5rem}
.field input,.field select,.field textarea{
  background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.22);
  color:var(--paper);padding:.7rem 0;font-family:inherit;font-size:1rem;border-radius:0;transition:border-color .4s}
.field textarea{resize:vertical;min-height:90px}
.field select option{color:#111}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent)}
.field input::placeholder,.field textarea::placeholder{color:rgba(255,255,255,.32)}
.consent{display:flex;gap:.7rem;align-items:flex-start;font-size:.82rem;color:var(--muted-on-dark)}
.consent input{margin-top:.2rem;accent-color:var(--accent);width:16px;height:16px;flex:none}
.consent a{color:var(--accent)}
.form__note{font-size:.78rem;color:var(--muted-on-dark)}
.form__ok{display:none;padding:1.4rem;border:1px solid var(--accent);border-radius:6px;color:var(--paper);background:rgba(225,252,33,.06)}
.form__ok.show{display:block}
.hp{position:absolute!important;left:-9999px;width:1px;height:1px;opacity:0;overflow:hidden;pointer-events:none}
@media (max-width:820px){.contact{grid-template-columns:1fr}.form .row{grid-template-columns:1fr}}

/* =====================================================================
   LOCATION
   ===================================================================== */
.location{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:6px;overflow:hidden;border:1px solid var(--line)}
.location__info{padding:clamp(2rem,4vw,3.4rem);background:var(--paper)}
.location__info h3{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:clamp(1.6rem,3vw,2.4rem);letter-spacing:-.01em}
.location__info p{color:var(--muted);margin-top:1rem;max-width:40ch}
.loc-points{margin-top:1.8rem;display:grid;gap:1rem}
.loc-points li{display:flex;gap:.8rem;align-items:center;font-size:.96rem}
.loc-points .d{width:8px;height:8px;border-radius:50%;background:var(--accent);flex:none}
.location__map{min-height:340px;position:relative;filter:grayscale(1) contrast(1.05);transition:filter .6s}
.location:hover .location__map{filter:grayscale(0)}
.location__map iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.map-consent{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;text-align:center;padding:2rem;background:var(--ink);color:var(--paper)}
.map-consent svg{color:var(--accent)}
.map-consent p{font-size:.86rem;color:var(--muted-on-dark);max-width:34ch}
.map-consent a{font-size:.8rem;color:var(--accent)}
@media (max-width:760px){.location{grid-template-columns:1fr}}

/* =====================================================================
   FOOTER
   ===================================================================== */
.footer{background:var(--ink);color:var(--paper);padding-top:clamp(3.5rem,7vw,6rem)}
.footer__cta{text-align:center;padding-bottom:clamp(3rem,6vw,5rem);border-bottom:1px solid rgba(255,255,255,.1)}
.footer__cta h2{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:clamp(2.2rem,7vw,5.5rem);line-height:.98;letter-spacing:-.02em}
.footer__cta p{color:var(--muted-on-dark);margin:1.2rem auto 2rem;max-width:46ch}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2rem;padding-block:clamp(2.5rem,5vw,4rem)}
.footer__brand img{height:30px;margin-bottom:1.2rem}
.footer__brand p{color:var(--muted-on-dark);max-width:34ch;font-size:.92rem}
.footer__col h5{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-on-dark);margin-bottom:1.1rem}
.footer__col a{display:block;padding:.35rem 0;font-size:.95rem;color:var(--paper);opacity:.85;transition:opacity .3s,color .3s}
.footer__col a:hover{opacity:1;color:var(--accent)}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;padding-block:1.8rem;border-top:1px solid rgba(255,255,255,.1);font-size:.8rem;color:var(--muted-on-dark)}
.footer__bottom a:hover{color:var(--accent)}
.socials{display:flex;gap:.8rem}
.socials a{width:38px;height:38px;border:1px solid rgba(255,255,255,.18);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .3s,color .3s,border-color .3s}
.socials a:hover{background:var(--accent);color:var(--ink);border-color:var(--accent)}
@media (max-width:760px){.footer__grid{grid-template-columns:1fr;gap:2.4rem}}

/* =====================================================================
   COOKIE
   ===================================================================== */
.cookie{position:fixed;left:20px;bottom:20px;max-width:380px;background:var(--ink);color:var(--paper);padding:1.6rem;border-radius:8px;z-index:130;box-shadow:0 24px 60px rgba(0,0,0,.4);transform:translateY(140%);transition:transform .6s var(--ease)}
.cookie.show{transform:none}
.cookie h4{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:1.1rem;margin-bottom:.6rem}
.cookie p{font-size:.85rem;color:var(--muted-on-dark);margin-bottom:1.1rem}
.cookie p a{color:var(--accent)}
.cookie__btns{display:flex;gap:.7rem;flex-wrap:wrap}
.cookie__btns .btn{padding:.8em 1.3em;font-size:.72rem}
.cookie .btn--mini{background:transparent;color:var(--paper);border:1px solid rgba(255,255,255,.3)}
.cookie .btn--mini::after{background:var(--accent)}
@media (max-width:480px){.cookie{left:12px;right:12px;bottom:12px;max-width:none}}

/* =====================================================================
   LEGAL pages
   ===================================================================== */
.legal{padding-top:calc(var(--nav-h) + 40px);padding-bottom:80px;min-height:70vh}
.legal h1{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:clamp(2rem,5vw,3.4rem);margin-bottom:2rem;letter-spacing:-.01em}
.legal h2{font-size:1.3rem;font-weight:700;margin:2.2rem 0 .8rem}
.legal h3{font-size:1.05rem;font-weight:700;margin:1.4rem 0 .5rem}
.legal p,.legal li{color:var(--ink-soft);max-width:75ch;margin-bottom:.8rem}
.legal ul{list-style:disc;padding-left:1.3rem;margin-bottom:1rem}
.legal a{color:#3b6b1f;text-decoration:underline}
.legal .back{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:2rem;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600}
.legal .muted-note{background:var(--paper-2);border-left:3px solid var(--accent);padding:1rem 1.2rem;font-size:.9rem;border-radius:0 4px 4px 0}

/* ---------- Hero price anchor ---------- */
.hero__price{display:inline-flex;align-items:baseline;gap:.5em;margin-top:1rem;color:var(--paper);font-size:.8rem;letter-spacing:.06em;text-transform:uppercase}
.hero__price strong{font-family:var(--f-display);font-weight:900;color:var(--accent);font-size:1.15rem;letter-spacing:0}

/* ---------- Steps (Ablauf) ---------- */
.steps{display:grid;gap:1.1rem;margin-top:2.2rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.12)}
.steps__title{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-on-dark);margin-bottom:.4rem}
.step{display:flex;gap:1rem;align-items:flex-start}
.step__n{flex:none;width:42px;height:42px;border-radius:50%;background:var(--accent);color:var(--ink);font-family:var(--f-display);font-weight:900;display:flex;align-items:center;justify-content:center;font-size:1.05rem}
.step h4{font-size:1rem;font-weight:700;color:var(--paper)}
.step p{font-size:.88rem;color:var(--muted-on-dark);margin-top:.15rem;max-width:42ch}

/* ---------- Reviews band ---------- */
.section--accent{background:var(--accent);color:var(--ink)}
.reviews{text-align:center;padding-block:clamp(48px,7vw,84px)}
.reviews .stars{font-size:1.7rem;letter-spacing:.18em;color:var(--ink);margin-bottom:.6rem}
.reviews h3{font-family:var(--f-display);font-weight:900;text-transform:uppercase;font-size:clamp(1.5rem,3.4vw,2.6rem);letter-spacing:-.01em;line-height:1.02}
.reviews p{max-width:48ch;margin:.9rem auto 1.6rem;color:rgba(10,10,10,.72);font-size:1rem}
.btn--dark{--bg:var(--ink);--fg:var(--accent)}
.btn--dark::after{background:var(--paper)}
.btn--dark:hover{color:var(--ink)}
.reviews-widget{margin-top:2.6rem}
.reviews-consent{background:var(--ink);color:var(--paper);border-radius:12px;padding:clamp(1.8rem,4vw,2.8rem) 1.6rem;display:flex;flex-direction:column;align-items:center;gap:1.1rem;max-width:560px;margin:0 auto}
.reviews-consent p{color:var(--muted-on-dark);font-size:.88rem;max-width:42ch;margin:0}
.reviews-consent a{color:var(--accent);font-size:.82rem}
.reviews-mount{margin-top:2rem;min-height:60px}
.reviews-mount iframe{max-width:100%}

/* ---------- Mobile booking bar ---------- */
.bookbar{position:fixed;left:0;right:0;bottom:0;z-index:70;display:none;align-items:center;justify-content:space-between;gap:1rem;
  padding:.7rem 1rem calc(.7rem + env(safe-area-inset-bottom,0));background:rgba(10,10,10,.94);backdrop-filter:blur(12px);
  border-top:1px solid rgba(255,255,255,.12);transform:translateY(120%);transition:transform .5s var(--ease)}
.bookbar.show{transform:none}
.bookbar__price{color:var(--paper);font-size:.72rem;line-height:1.15;letter-spacing:.04em;text-transform:uppercase}
.bookbar__price strong{display:block;font-family:var(--f-display);font-weight:900;color:var(--accent);font-size:1.05rem;letter-spacing:0;text-transform:none}
.bookbar .btn{padding:.9em 1.5em;font-size:.76rem;white-space:nowrap}
@media (max-width:760px){.bookbar{display:flex}}

/* utility */
.center{text-align:center}
.mt-2{margin-top:2rem}
.nowrap{white-space:nowrap}
