/* =========================================================================
   TINA FRÜHWIRTH — Design System
   Mobile-first, fluid type, system-tokens, no dead code.
   ========================================================================= */

/* ----- TOKENS ----- */
:root{
  /* color */
  --ink:#111A16;
  --ink-2:#3A4742;
  --muted:#6B7873;
  --bg:#FBF8F3;
  --bg-2:#F1ECE2;
  --bg-3:#E7DFCE;
  --line:rgba(17,26,22,.10);
  --line-2:rgba(17,26,22,.18);
  --moss:#2D4839;
  --moss-2:#1E3327;
  --terra:#C97B5C;
  --card:#FFFFFF;

  /* elevation */
  --shadow-1: 0 6px 24px rgba(17,26,22,.06);
  --shadow-2: 0 24px 60px rgba(17,26,22,.14);
  --shadow-3: 0 40px 80px rgba(17,26,22,.22);

  /* radii */
  --r-sm:14px; --r-md:20px; --r-lg:28px; --r-xl:36px;

  /* layout */
  --maxw:1180px;
  --gutter:20px;

  /* type scale — fluid clamp(min, preferred-vw, max) */
  --t-cap:  clamp(11px, 0.78vw, 12px);
  --t-body: clamp(15px, 1.05vw, 17px);
  --t-sub:  clamp(20px, 1.6vw, 24px);
  --t-h3:   clamp(22px, 2.2vw, 28px);
  --t-h2:   clamp(28px, 3.4vw, 44px);
  --t-h1:   clamp(40px, 6.4vw, 72px);

  /* motion */
  --ease-out: cubic-bezier(.2,.7,.2,1);
  --ease-in-out: cubic-bezier(.65,0,.35,1);

  /* hero sizes */
  --hero-h-index: 100svh;
  --hero-h-sub: 75svh;

  color-scheme: light;
}

/* ----- RESET ----- */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--bg)}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
}
body{
  background:var(--bg);
  color:var(--ink);
  font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
  font-size: var(--t-body);
  line-height: 1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit;padding:0}

/* skip link (a11y) */
.skip{position:absolute;left:-9999px;top:8px;background:var(--ink);color:#fff;padding:10px 16px;border-radius:8px;z-index:1000;font-weight:600}
.skip:focus{left:8px}

/* focus ring */
:focus-visible{outline:2px solid var(--moss);outline-offset:3px;border-radius:4px}

/* ----- TYPE ----- */
h1,h2,h3,h4{margin:0;font-weight:500;line-height:1.1;letter-spacing:-0.02em;font-family:'Fraunces',Georgia,serif}
h1{font-size:var(--t-h1);font-variation-settings:"SOFT" 80,"opsz" 144;letter-spacing:-0.025em}
h2{font-size:var(--t-h2)}
h3{font-size:var(--t-h3)}
.caption{font-family:'Inter',sans-serif;font-size:var(--t-cap);text-transform:uppercase;letter-spacing:.18em;font-weight:600;color:var(--moss)}
.lead{font-size:clamp(16px,1.2vw,19px);color:var(--ink-2);line-height:1.55;max-width:56ch}
.muted{color:var(--muted)}

/* ----- LAYOUT ----- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
section{padding:72px 0}
@media (max-width:760px){ section{padding:56px 0} }

/* =========================================================================
   NAV
   ========================================================================= */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:80;
  background:rgba(251,248,243,.78);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid transparent;
  transform:translateY(0);
  transition:transform .35s var(--ease-out), background .25s ease, border-color .25s ease;
}
.nav.scrolled{background:rgba(251,248,243,.92);border-bottom-color:var(--line)}
.nav.hide{transform:translateY(-110%)}

/* hero pages: transparent nav until scrolled */
.nav.over-hero:not(.scrolled){
  background:transparent;
  backdrop-filter:none;-webkit-backdrop-filter:none;
}
.nav.over-hero:not(.scrolled) .brand-text,
.nav.over-hero:not(.scrolled) .nav-links a{color:rgba(255,255,255,.95)}
.nav.over-hero:not(.scrolled) .burger{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.25)}
.nav.over-hero:not(.scrolled) .burger span,
.nav.over-hero:not(.scrolled) .burger span::before,
.nav.over-hero:not(.scrolled) .burger span::after{background:#fff}

.nav-inner{
  max-width:var(--maxw);margin:0 auto;padding:14px var(--gutter);
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.brand img{height:30px;width:auto}
.brand-text{font-family:'Fraunces',Georgia,serif;font-weight:500;font-size:18px;letter-spacing:-0.01em;color:var(--ink);transition:color .25s}

.nav-links{display:none;align-items:center;gap:28px}
.nav-links a{font-size:14px;font-weight:500;color:rgba(17,26,22,.78);transition:color .15s;padding:6px 0;position:relative}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:1.5px;background:currentColor;
}

.nav-cta{
  display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:999px;
  background:var(--moss);color:#fff !important;font-weight:600;font-size:14px;
  transition:background .2s, transform .15s;
}
.nav-cta:hover{background:var(--moss-2)}
.nav-cta:active{transform:translateY(1px)}
.nav.over-hero:not(.scrolled) .nav-cta{background:#fff;color:var(--ink) !important}
.nav.over-hero:not(.scrolled) .nav-cta:hover{background:#f4f4f4}

.burger{
  width:44px;height:44px;border-radius:999px;background:rgba(255,255,255,.6);
  border:1px solid var(--line);display:flex;align-items:center;justify-content:center;
  transition:background .25s, border-color .25s;
}
.burger span{display:block;width:18px;height:1.5px;background:var(--ink);position:relative;transition:background .2s}
.burger span::before, .burger span::after{
  content:"";position:absolute;left:0;width:18px;height:1.5px;background:var(--ink);
  transition:transform .25s var(--ease-out), top .25s var(--ease-out);
}
.burger span::before{top:-6px}
.burger span::after{top:6px}
body.menu-open .burger span{background:transparent}
body.menu-open .burger span::before{top:0;transform:rotate(45deg)}
body.menu-open .burger span::after{top:0;transform:rotate(-45deg)}

@media (min-width:860px){
  .nav-links{display:flex}
  .burger{display:none}
}

/* full-screen menu overlay */
.menu{
  position:fixed;inset:0;z-index:70;background:var(--bg);
  opacity:0;pointer-events:none;transform:translateY(-8px);
  transition:opacity .25s ease, transform .3s var(--ease-out);
  display:flex;flex-direction:column;justify-content:center;padding:90px 28px 40px;
  overflow-y:auto;
}
body.menu-open{overflow:hidden}
body.menu-open .menu{opacity:1;pointer-events:auto;transform:none}
.menu nav{display:flex;flex-direction:column;gap:6px}
.menu nav a{
  font-family:'Fraunces',Georgia,serif;font-size:clamp(32px, 8vw, 44px);
  letter-spacing:-0.02em;color:var(--ink);
  padding:14px 0;border-bottom:1px solid var(--line);
}
.menu nav a.active{color:var(--moss)}
.menu .menu-foot{margin-top:32px;display:flex;flex-direction:column;gap:12px;color:var(--muted);font-size:14px}
.menu .menu-foot a{color:var(--moss);font-weight:500}

/* =========================================================================
   HERO — universal component
   Mobile: 100svh on index, 75svh on subpages
   Desktop: same. Image full-bleed with picture + responsive sources.
   ========================================================================= */
.hero{
  position:relative;
  height:var(--hero-h-sub);
  background:#1a201d;color:#fff;
  overflow:hidden;
  display:flex;align-items:flex-end;
  isolation:isolate;
}
.hero.hero-index{height:var(--hero-h-index)}

.hero-media{
  position:absolute;inset:0;z-index:1;
}
.hero-media img{
  width:100%;height:100%;object-fit:cover;
  object-position:center 35%;
  /* subtle ken-burns on load */
  animation: heroIn 1.4s var(--ease-out) both;
}
@keyframes heroIn{
  from{transform:scale(1.06);opacity:.0}
  to{transform:scale(1);opacity:1}
}

.hero-media::after{
  content:"";position:absolute;inset:0;z-index:2;
  background:linear-gradient(
    180deg,
    rgba(0,0,0,.45) 0%,
    rgba(0,0,0,.08) 22%,
    rgba(0,0,0,.05) 45%,
    rgba(17,26,22,.55) 80%,
    rgba(17,26,22,.85) 100%
  );
}

.hero-inner{
  position:relative;z-index:3;
  width:100%;max-width:var(--maxw);
  margin:0 auto;
  padding:0 var(--gutter) 48px;
}
.hero .caption{color:rgba(255,255,255,.92);display:inline-block;margin-bottom:14px}
.hero h1{color:#fff;margin:0 0 18px;max-width:18ch;text-wrap:balance}
.hero p.lead{color:rgba(255,255,255,.88);max-width:42ch}
.hero-cta{
  margin-top:28px;display:inline-flex;align-items:center;gap:10px;
  padding:16px 26px;border-radius:999px;background:#fff;color:var(--ink);
  font-weight:600;font-size:15px;box-shadow:var(--shadow-2);
  transition:transform .15s, background .2s;
}
.hero-cta:hover{background:#f4f4f4;transform:translateY(-2px)}
.hero-cta:active{transform:translateY(0)}
.hero-cta .arrow{display:inline-block;transition:transform .2s}
.hero-cta:hover .arrow{transform:translateX(4px)}

.hero-crumbs{
  position:absolute;top:90px;left:50%;transform:translateX(-50%);
  z-index:3;width:100%;max-width:var(--maxw);padding:0 var(--gutter);
  font-size:12px;color:rgba(255,255,255,.75);letter-spacing:.04em;
}
.hero-crumbs a{color:rgba(255,255,255,.85);border-bottom:1px solid rgba(255,255,255,.3)}
.hero-crumbs a:hover{color:#fff;border-color:#fff}
.hero-crumbs .sep{margin:0 8px;color:rgba(255,255,255,.4)}

.hero-scroll{
  position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:3;
  color:rgba(255,255,255,.7);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:6px;pointer-events:none;
}
.hero-scroll::after{
  content:"";width:1px;height:24px;background:rgba(255,255,255,.5);
  animation:scrollPulse 1.8s ease-in-out infinite;
}
@keyframes scrollPulse{
  0%,100%{opacity:.3;transform:scaleY(.6)}
  50%{opacity:1;transform:scaleY(1)}
}

@media (min-width:860px){
  .hero-inner{padding-bottom:72px}
}

/* =========================================================================
   STICKY BOTTOM CTA (mobile)
   ========================================================================= */
.bottom-cta{
  position:fixed;left:12px;right:12px;bottom:12px;z-index:60;
  display:flex;gap:8px;padding:10px;
  background:rgba(17,26,22,.94);color:#fff;
  border-radius:999px;backdrop-filter:blur(12px);
  box-shadow:0 10px 30px rgba(0,0,0,.25);
  opacity:0;pointer-events:none;transform:translateY(20px);
  transition:opacity .3s ease, transform .3s var(--ease-out);
}
.bottom-cta.show{opacity:1;pointer-events:auto;transform:none}
body.menu-open .bottom-cta{opacity:0;pointer-events:none}
.bottom-cta a{
  flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 14px;border-radius:999px;font-size:14px;font-weight:600;
  transition:background .2s;
}
.bottom-cta a.primary{background:#fff;color:var(--ink)}
.bottom-cta a.primary:hover{background:#f4f4f4}
.bottom-cta a.ghost{background:rgba(255,255,255,.10);color:#fff}
.bottom-cta a.ghost:hover{background:rgba(255,255,255,.18)}
@media (min-width:860px){ .bottom-cta{display:none} }

/* =========================================================================
   SECTIONS — common patterns
   ========================================================================= */
.section-head{margin-bottom:36px;max-width:720px}
.section-head .caption{display:inline-block;margin-bottom:14px}
.section-head h2{margin-bottom:14px;text-wrap:balance}

.bg-cream{background:var(--bg)}
.bg-sand{background:var(--bg-2)}

/* ----- ANGEBOTE TEASER ----- */
.offers{display:flex;flex-direction:column;gap:14px}
.offer{
  position:relative;background:var(--card);border-radius:var(--r-lg);
  padding:28px 26px;box-shadow:var(--shadow-1);
  display:flex;flex-direction:column;gap:10px;
  transition:transform .3s var(--ease-out), box-shadow .3s var(--ease-out);
}
.offer:hover{transform:translateY(-4px);box-shadow:var(--shadow-2)}
.offer .num{font-family:'Fraunces',Georgia,serif;font-size:14px;color:var(--terra);letter-spacing:.05em}
.offer h3{margin:2px 0 4px}
.offer p{color:var(--ink-2);margin:0}
.offer .meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.offer .meta span{font-size:12px;background:var(--bg-2);color:var(--ink-2);padding:5px 10px;border-radius:999px}
.offer .more{margin-top:14px;display:inline-flex;align-items:center;gap:6px;color:var(--moss);font-weight:600;font-size:14px}
.offer .more .arrow{transition:transform .2s}
.offer:hover .more .arrow{transform:translateX(4px)}
@media (min-width:860px){
  .offers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
}

/* ----- EDITORIAL SPLIT (image + text) ----- */
.split{display:flex;flex-direction:column;gap:28px}
.split .ph{aspect-ratio:4/5;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-2);position:relative;background:var(--bg-2)}
.split .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease-out)}
.split:hover .ph img{transform:scale(1.03)}
.split .body{display:flex;flex-direction:column;gap:14px}
.split .body .more{
  align-self:flex-start;display:inline-flex;align-items:center;gap:8px;
  padding:14px 22px;border-radius:999px;border:1px solid var(--ink);color:var(--ink);
  font-weight:600;font-size:14px;transition:background .2s, color .2s;
  margin-top:6px;
}
.split .body .more:hover{background:var(--ink);color:#fff}
.split .body .more .arrow{transition:transform .2s}
.split .body .more:hover .arrow{transform:translateX(4px)}
@media (min-width:860px){
  .split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
  .split.reverse .ph{order:2}
}

/* ----- BIG STATEMENT ----- */
.statement{padding:120px 0;background:var(--moss);color:#fff;text-align:center;position:relative;overflow:hidden}
.statement::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.06), transparent 50%);
  pointer-events:none;
}
.statement blockquote{
  font-family:'Fraunces',Georgia,serif;font-weight:400;
  font-size:clamp(28px,4vw,52px);line-height:1.15;letter-spacing:-0.02em;
  max-width:18ch;margin:0 auto;text-wrap:balance;
  position:relative;
}
.statement blockquote::before,
.statement blockquote::after{
  content:'"';font-size:1.2em;opacity:.4;line-height:0;
  vertical-align:-0.1em;
}
.statement cite{
  display:block;margin-top:28px;font-style:normal;
  font-family:'Inter',sans-serif;font-size:13px;letter-spacing:.18em;
  text-transform:uppercase;color:rgba(255,255,255,.6);
}

/* ----- CONTACT TEASER ----- */
.contact-teaser{
  background:var(--bg-2);border-radius:var(--r-xl);padding:48px 28px;text-align:left;
  display:flex;flex-direction:column;gap:18px;position:relative;overflow:hidden;
}
.contact-teaser::before{
  content:"";position:absolute;top:-40%;right:-20%;width:60%;height:160%;
  background:radial-gradient(circle, var(--bg-3), transparent 70%);
  opacity:.6;pointer-events:none;
}
.contact-teaser > *{position:relative;z-index:1}
.contact-teaser h2{max-width:16ch;text-wrap:balance}
.contact-teaser .actions{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.contact-teaser .actions a{
  display:inline-flex;align-items:center;gap:10px;padding:14px 22px;
  border-radius:999px;font-weight:600;font-size:15px;justify-content:center;
  transition:transform .15s, background .2s;
}
.contact-teaser .actions a:hover{transform:translateY(-2px)}
.contact-teaser a.primary{background:var(--ink);color:#fff}
.contact-teaser a.primary:hover{background:#000}
.contact-teaser a.ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.contact-teaser a.ghost:hover{background:var(--bg)}
@media (min-width:760px){
  .contact-teaser{padding:64px;text-align:left}
  .contact-teaser .actions{flex-direction:row}
  .contact-teaser .actions a{justify-content:flex-start}
}

/* ----- FAQ TEASER (proper styled now) ----- */
.faq-teaser{background:var(--bg)}
.faq-teaser .faq-teaser-card{
  background:var(--moss);color:#fff;
  border-radius:var(--r-xl);padding:48px 28px;
  display:flex;flex-direction:column;gap:18px;
  position:relative;overflow:hidden;
}
.faq-teaser .faq-teaser-card::before{
  content:"?";position:absolute;font-family:'Fraunces',serif;
  font-size:clamp(180px,22vw,300px);line-height:1;
  right:-20px;bottom:-60px;color:rgba(255,255,255,.06);
  pointer-events:none;font-weight:400;
}
.faq-teaser .faq-teaser-card > *{position:relative;z-index:1}
.faq-teaser .caption{color:rgba(255,255,255,.7)}
.faq-teaser h2{color:#fff;max-width:18ch;text-wrap:balance}
.faq-teaser p{color:rgba(255,255,255,.78);max-width:48ch}
.faq-teaser .actions{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.faq-teaser .actions a{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 22px;border-radius:999px;font-weight:600;font-size:15px;
  background:#fff;color:var(--moss);transition:transform .15s, background .2s;
}
.faq-teaser .actions a:hover{background:#f4f4f4;transform:translateY(-2px)}
.faq-teaser .actions .arrow{transition:transform .2s}
.faq-teaser .actions a:hover .arrow{transform:translateX(4px)}
@media (min-width:760px){
  .faq-teaser .faq-teaser-card{padding:64px;flex-direction:row;align-items:center;justify-content:space-between;gap:48px}
  .faq-teaser .faq-teaser-card .text{max-width:60%}
  .faq-teaser .actions{flex-direction:row;margin-top:0;flex-shrink:0}
}

/* =========================================================================
   FOOTER
   ========================================================================= */
footer{padding:56px 0 32px;background:var(--ink);color:rgba(255,255,255,.7)}
footer .wrap{display:flex;flex-direction:column;gap:32px}
.foot-top{display:flex;flex-direction:column;gap:24px}
.foot-top .brand-text{color:#fff;font-size:22px;display:block}
.foot-cols{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.foot-cols h4{color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.16em;font-weight:600;margin-bottom:12px;font-family:'Inter',sans-serif}
.foot-cols a{display:block;padding:4px 0;font-size:14px;color:rgba(255,255,255,.65);transition:color .2s}
.foot-cols a:hover{color:#fff}
.foot-bottom{
  display:flex;flex-direction:column;gap:6px;font-size:12px;color:rgba(255,255,255,.4);
  border-top:1px solid rgba(255,255,255,.10);padding-top:20px;
}
.foot-bottom a:hover{color:rgba(255,255,255,.75)}
@media (min-width:760px){
  .foot-top{flex-direction:row;justify-content:space-between;align-items:flex-start;gap:48px}
  .foot-cols{grid-template-columns:repeat(3,1fr);min-width:60%}
  .foot-bottom{flex-direction:row;justify-content:space-between}
}

/* =========================================================================
   REVEAL ANIMATION — opt-in via .js class (no-JS fallback shows content)
   ========================================================================= */
.js .reveal{opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease-out), transform .8s var(--ease-out)}
.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none;transition:none}}

/* =========================================================================
   POSTS / WISSEN
   ========================================================================= */
.posts{display:flex;flex-direction:column;gap:22px}
.post{
  background:#fff;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-1);display:block;
  transition:transform .3s var(--ease-out), box-shadow .3s var(--ease-out);
}
.post:hover{transform:translateY(-4px);box-shadow:var(--shadow-2)}
.post .ph{aspect-ratio:16/10;overflow:hidden;background:var(--bg-2)}
.post .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease-out)}
.post:hover .ph img{transform:scale(1.04)}
.post .body{padding:24px}
.post .cat{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--moss);font-weight:600;margin-bottom:10px;display:block}
.post h3{margin-bottom:8px;line-height:1.2}
.post p{color:var(--ink-2);font-size:15px;margin:0}
@media (min-width:760px){
  .posts{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
}

/* =========================================================================
   DETAIL CARDS (Angebote, Impressum)
   ========================================================================= */
.detail-card{
  background:#fff;border-radius:var(--r-lg);padding:32px 26px;
  box-shadow:var(--shadow-1);display:flex;flex-direction:column;gap:14px;
  margin-bottom:18px;
}
.detail-card h3{font-family:'Fraunces',Georgia,serif;font-weight:500}
.detail-card .row{display:flex;gap:18px;flex-wrap:wrap;margin-top:6px}
.detail-card .row > div{flex:1;min-width:140px}
.detail-card .row .lbl{font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-bottom:4px}
.detail-card .row .val{font-weight:600}
.detail-card ul{margin:6px 0 0 0;padding-left:18px;color:var(--ink-2)}
.detail-card ul li{margin:6px 0}
.detail-card a{color:var(--moss);border-bottom:1px solid rgba(45,72,57,.3)}
.detail-card a:hover{border-color:var(--moss)}

@media (min-width:760px){
  .detail-card{padding:40px 36px}
}

/* =========================================================================
   FAQ ACCORDION
   ========================================================================= */
.faq{display:flex;flex-direction:column}
.faq details{border-bottom:1px solid var(--line);padding:18px 4px}
.faq details[open]{padding-bottom:22px}
.faq summary{
  list-style:none;display:flex;justify-content:space-between;align-items:center;
  gap:16px;cursor:pointer;font-family:'Fraunces',Georgia,serif;font-size:19px;font-weight:500;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-size:24px;color:var(--moss);transition:transform .25s var(--ease-out);
  flex-shrink:0;
}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin:12px 0 0;color:var(--ink-2)}
.faq details a{color:var(--moss);border-bottom:1px solid rgba(45,72,57,.3)}

/* =========================================================================
   CONTACT FORM
   ========================================================================= */
.contact-grid{display:flex;flex-direction:column;gap:28px}
.contact-list{display:flex;flex-direction:column;gap:10px}
.contact-row{
  display:flex;align-items:center;gap:14px;padding:16px 18px;
  background:#fff;border-radius:var(--r-md);box-shadow:var(--shadow-1);
  transition:transform .2s, box-shadow .2s;
}
a.contact-row:hover{transform:translateY(-2px);box-shadow:var(--shadow-2)}
.contact-row .ico{
  width:40px;height:40px;border-radius:999px;background:var(--moss);color:#fff;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.contact-row .t{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.contact-row .v{font-weight:600;margin-top:2px}

form .field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
form label{font-size:13px;font-weight:600;color:var(--ink)}
form input, form textarea, form select{
  font:inherit;font-size:15px;padding:14px 16px;border-radius:14px;
  border:1px solid var(--line);background:#fff;color:var(--ink);outline:none;
  transition:border-color .2s, box-shadow .2s;width:100%;
}
form input:focus, form textarea:focus, form select:focus{
  border-color:var(--moss);box-shadow:0 0 0 3px rgba(45,72,57,.15);
}
form input:user-invalid, form textarea:user-invalid{
  border-color:var(--terra);
}
form textarea{min-height:140px;resize:vertical;font-family:inherit}
.consent{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--muted);margin:6px 0 18px;line-height:1.5}
.consent input{margin-top:3px;width:auto;flex-shrink:0;accent-color:var(--moss)}
.consent a{color:var(--moss);border-bottom:1px solid rgba(45,72,57,.3)}
form .btn-submit{
  width:100%;padding:16px 22px;border-radius:999px;
  background:var(--ink);color:#fff;font-weight:600;font-size:15px;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  transition:background .2s, transform .15s;
}
form .btn-submit:hover{background:#000;transform:translateY(-2px)}
form .btn-submit:active{transform:translateY(0)}
form .form-status{margin-top:14px;font-size:14px;min-height:1.5em}
form .form-status.ok{color:var(--moss)}
form .form-status.err{color:var(--terra)}

@media (min-width:860px){
  .contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:start}
}

/* =========================================================================
   BACK TO TOP
   ========================================================================= */
.totop{
  position:fixed;right:16px;bottom:80px;z-index:55;
  width:44px;height:44px;border-radius:999px;background:#fff;
  border:1px solid var(--line);box-shadow:var(--shadow-1);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transform:translateY(10px);
  transition:opacity .25s, transform .25s, background .2s;
}
.totop:hover{background:var(--bg)}
.totop.show{opacity:1;pointer-events:auto;transform:none}
@media (min-width:860px){ .totop{bottom:24px} }

/* =========================================================================
   ICONS
   ========================================================================= */
.icon{width:18px;height:18px;display:inline-block;vertical-align:-3px;fill:currentColor}
.icon-lg{width:20px;height:20px}

/* =========================================================================
   RUDEL CAROUSEL — proper, accessible, no vertical scroll
   ========================================================================= */
.rudel{position:relative}
.rudel-track{
  display:flex;gap:16px;
  overflow-x:auto;overflow-y:hidden;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  padding:8px 4px 12px;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  scroll-padding:0 var(--gutter);
}
.rudel-track::-webkit-scrollbar{display:none;height:0}

.rudel-card{
  flex:0 0 82%;max-width:82%;
  scroll-snap-align:start;
  background:#fff;border-radius:var(--r-lg);
  overflow:hidden;box-shadow:var(--shadow-1);
  display:flex;flex-direction:column;
  transition:transform .3s var(--ease-out), box-shadow .3s var(--ease-out);
}
.rudel-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-2)}
.rudel-card .ph{aspect-ratio:4/3;overflow:hidden;background:var(--bg-2)}
.rudel-card .ph img{width:100%;height:100%;object-fit:cover}
.rudel-card .body{padding:22px}
.rudel-card .meta{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--terra);margin-bottom:8px;font-weight:600}
.rudel-card h3{margin-bottom:8px}
.rudel-card p{color:var(--ink-2);font-size:15px;margin:0}

@media (min-width:760px){
  .rudel-card{flex-basis:46%;max-width:46%}
}
@media (min-width:1060px){
  .rudel-card{flex-basis:30%;max-width:30%}
}

/* arrows — desktop only */
.rudel-arrow{
  position:absolute;top:calc(50% - 30px);transform:translateY(-50%);
  width:48px;height:48px;border-radius:999px;
  border:1px solid var(--line-2);
  background:rgba(255,255,255,.95);backdrop-filter:blur(8px);
  display:grid;place-items:center;
  box-shadow:var(--shadow-1);cursor:pointer;
  font-size:22px;line-height:1;color:var(--ink);
  transition:background .2s, transform .15s, opacity .2s;
  z-index:2;
}
.rudel-arrow:hover{background:#fff;transform:translateY(-50%) scale(1.05)}
.rudel-arrow:active{transform:translateY(-50%) scale(.98)}
.rudel-arrow:disabled{opacity:.35;cursor:not-allowed}
.rudel-arrow.prev{left:-8px}
.rudel-arrow.next{right:-8px}
@media (max-width:900px){
  .rudel-arrow{display:none}
}

/* dots — mobile-friendly indicator */
.rudel-dots{
  display:flex;justify-content:center;gap:8px;
  margin-top:18px;
}
.rudel-dots button{
  width:8px;height:8px;border-radius:999px;
  background:var(--line-2);
  transition:background .2s, width .2s;
}
.rudel-dots button[aria-current="true"]{
  background:var(--moss);width:24px;
}

/* =========================================================================
   SCROLL PROGRESS BAR (subtle, top of page)
   ========================================================================= */
.scroll-progress{
  position:fixed;top:0;left:0;right:0;height:2px;z-index:90;
  pointer-events:none;
  background:linear-gradient(90deg, var(--moss), var(--terra));
  transform-origin:0 0;transform:scaleX(0);
  transition:transform .1s linear;
}

/* =========================================================================
   PAGE HEAD (for legal pages without hero)
   ========================================================================= */
.page-head{padding:140px 0 56px;background:var(--bg)}
.page-head .caption{margin-bottom:18px;display:inline-block}
.page-head h1{font-size:clamp(34px,5.5vw,64px);margin-bottom:18px;text-wrap:balance}
.page-head p{max-width:60ch}
.crumbs{font-size:12px;color:var(--muted);letter-spacing:.04em;margin-bottom:18px}
.crumbs a{color:var(--muted);border-bottom:1px solid transparent;transition:color .2s, border-color .2s}
.crumbs a:hover{color:var(--ink);border-color:var(--line-2)}
.crumbs .sep{margin:0 8px;color:var(--line-2)}

/* =========================================================================
   VIEW TRANSITIONS (progressive enhancement)
   ========================================================================= */
@supports (view-transition-name: hero) {
  .hero-media img{view-transition-name:hero-image}
}
::view-transition-old(hero-image),
::view-transition-new(hero-image){
  animation-duration:.5s;
}
