/* ============================================================
   Italo · Gelato&More — styles.css
   Direction: "Gelateria tricolore" — warm panna base, pistachio
   green as brand, amarena cherry as accent. Display: Fraunces.
   Body: Manrope. All fonts local (DSGVO-friendly, no CDN).
   ============================================================ */

/* ---------- Local fonts ---------- */
@font-face{font-family:'Fraunces';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/fraunces-400-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/fraunces-400-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:600;font-display:swap;src:url('assets/fonts/fraunces-600-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:600;font-display:swap;src:url('assets/fonts/fraunces-600-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:700;font-display:swap;src:url('assets/fonts/fraunces-700-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:700;font-display:swap;src:url('assets/fonts/fraunces-700-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:900;font-display:swap;src:url('assets/fonts/fraunces-900-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:900;font-display:swap;src:url('assets/fonts/fraunces-900-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Manrope';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/manrope-400-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Manrope';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/manrope-400-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Manrope';font-style:normal;font-weight:500;font-display:swap;src:url('assets/fonts/manrope-500-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Manrope';font-style:normal;font-weight:500;font-display:swap;src:url('assets/fonts/manrope-500-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Manrope';font-style:normal;font-weight:600;font-display:swap;src:url('assets/fonts/manrope-600-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Manrope';font-style:normal;font-weight:600;font-display:swap;src:url('assets/fonts/manrope-600-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Manrope';font-style:normal;font-weight:700;font-display:swap;src:url('assets/fonts/manrope-700-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Manrope';font-style:normal;font-weight:700;font-display:swap;src:url('assets/fonts/manrope-700-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Manrope';font-style:normal;font-weight:800;font-display:swap;src:url('assets/fonts/manrope-800-latin.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Manrope';font-style:normal;font-weight:800;font-display:swap;src:url('assets/fonts/manrope-800-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}

/* ---------- Tokens ---------- */
:root{
  --panna:#FBF5EC;        /* warm cream base */
  --panna-2:#F4E9D7;      /* alt section */
  --card:#FFFFFF;
  --ink:#2A201A;          /* warm near-black text */
  --ink-soft:#6A5C4F;     /* muted text */
  --pistacchio:#2E6B45;   /* brand primary (deep) */
  --pistacchio-d:#234f34; /* darker green for hover */
  --pistacchio-l:#7FB069; /* bright pistachio */
  --amarena:#C21F3A;      /* accent / CTA cherry */
  --amarena-d:#a3162e;
  --aperol:#E8703A;       /* warm spritz accent */
  --gold:#E7B45A;         /* cone gold */
  --line:#E7D7BF;         /* warm border */
  --line-soft:#EFE5D2;

  --shadow-sm:0 1px 2px rgba(42,32,26,.05),0 2px 8px rgba(42,32,26,.05);
  --shadow-md:0 8px 24px -8px rgba(42,32,26,.14),0 2px 8px rgba(42,32,26,.06);
  --shadow-lg:0 30px 60px -22px rgba(35,79,52,.30),0 10px 24px -12px rgba(42,32,26,.16);

  --r-sm:12px; --r-md:18px; --r-lg:28px; --r-xl:36px; --r-pill:999px;
  --container:1200px;
  --gap:clamp(1rem,3vw,2rem);
  --pad-x:clamp(1.1rem,5vw,2rem);
  --sp-section:clamp(4.5rem,9vw,8rem);

  --display:'Fraunces',Georgia,'Times New Roman',serif;
  --body:'Manrope',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;

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

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box;}
*{margin:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
body{
  font-family:var(--body);
  background:var(--panna);
  color:var(--ink);
  line-height:1.65;
  font-size:clamp(1rem,.97rem + .15vw,1.0625rem);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit;}
ul{list-style:none;padding:0;}
input,textarea{font:inherit;color:inherit;}
:focus-visible{outline:3px solid var(--pistacchio-l);outline-offset:3px;border-radius:6px;}

/* ---------- Headings / type scale ---------- */
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.08;letter-spacing:-.01em;color:var(--ink);}
h1{font-size:clamp(2.6rem,1.6rem + 4.6vw,5rem);font-weight:900;letter-spacing:-.025em;}
h2{font-size:clamp(2rem,1.4rem + 2.6vw,3.25rem);}
h3{font-size:clamp(1.3rem,1.15rem + .8vw,1.65rem);line-height:1.18;}
h4{font-size:1.15rem;font-weight:600;}
p{color:var(--ink-soft);}
.lead{font-size:clamp(1.08rem,1rem + .5vw,1.3rem);color:var(--ink-soft);line-height:1.6;}

/* ---------- Layout helpers ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--pad-x);}
.section{padding-block:var(--sp-section);}
.section--tint{background:var(--panna-2);}
.section--green{background:var(--pistacchio);color:#fff;}
.section__head{max-width:62ch;margin-bottom:clamp(2rem,4vw,3.5rem);}
.section__head.center{margin-inline:auto;text-align:center;}
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--body);font-weight:700;font-size:.78rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--pistacchio);
  margin-bottom:1rem;
}
.section--green .eyebrow{color:#cfe6c9;}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--amarena);border-radius:2px;}
.section__head.center .eyebrow::before{display:none;}
.muted{color:var(--ink-soft);}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-weight:700;font-size:1rem;line-height:1;
  padding:.95rem 1.5rem;border-radius:var(--r-pill);
  min-height:48px;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background-color .25s var(--ease),color .25s var(--ease);
  will-change:transform;
}
.btn svg{width:18px;height:18px;}
.btn--primary{background:var(--amarena);color:#fff;box-shadow:0 10px 22px -10px rgba(194,31,58,.7);}
.btn--primary:hover{background:var(--amarena-d);transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(194,31,58,.75);}
.btn--ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--line);}
.btn--ghost:hover{box-shadow:inset 0 0 0 1.5px var(--pistacchio);color:var(--pistacchio);transform:translateY(-2px);}
.btn--green{background:var(--pistacchio);color:#fff;box-shadow:0 10px 22px -12px rgba(46,107,69,.7);}
.btn--green:hover{background:var(--pistacchio-d);transform:translateY(-2px);}
.btn--light{background:#fff;color:var(--pistacchio);}
.btn--light:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);}

/* ============================================================
   Header / nav
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(251,245,236,.82);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color .3s var(--ease),box-shadow .3s var(--ease),background-color .3s var(--ease);
}
.site-header.scrolled{border-bottom-color:var(--line);box-shadow:0 6px 20px -16px rgba(42,32,26,.5);}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:74px;}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--display);font-weight:700;}
.brand img{width:42px;height:42px;}
.brand__name{font-size:1.18rem;line-height:1;letter-spacing:-.01em;}
.brand__name span{color:var(--pistacchio);}
.brand__sub{display:block;font-family:var(--body);font-size:.62rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);margin-top:3px;}

.nav__links{display:flex;align-items:center;gap:.35rem;}
.nav__links a{
  font-weight:600;font-size:.95rem;padding:.55rem .8rem;border-radius:var(--r-pill);
  color:var(--ink);transition:color .2s var(--ease),background-color .2s var(--ease);
}
.nav__links a:hover{color:var(--pistacchio);background:rgba(46,107,69,.08);}
.nav__cta{display:flex;align-items:center;gap:.6rem;}

.nav__toggle{
  display:none;width:48px;height:48px;border-radius:var(--r-sm);
  align-items:center;justify-content:center;
  box-shadow:inset 0 0 0 1.5px var(--line);background:var(--card);
}
.nav__toggle span{position:relative;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease),opacity .2s var(--ease);}
.nav__toggle span::before,.nav__toggle span::after{content:"";position:absolute;left:0;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease);}
.nav__toggle span::before{top:-7px;}
.nav__toggle span::after{top:7px;}
.nav__toggle[aria-expanded="true"] span{background:transparent;}
.nav__toggle[aria-expanded="true"] span::before{transform:translateY(7px) rotate(45deg);}
.nav__toggle[aria-expanded="true"] span::after{transform:translateY(-7px) rotate(-45deg);}

/* ============================================================
   Hero
   ============================================================ */
.hero{position:relative;padding-top:clamp(2.5rem,6vw,4.5rem);padding-bottom:clamp(3rem,7vw,6rem);overflow:hidden;}
.hero__bg{position:absolute;inset:0;z-index:-1;background:
  radial-gradient(60% 50% at 85% 5%,rgba(127,176,105,.22),transparent 60%),
  radial-gradient(55% 45% at 0% 95%,rgba(232,112,58,.14),transparent 60%);}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.5rem,4vw,4rem);align-items:center;}
.hero__badge{
  display:inline-flex;align-items:center;gap:.55rem;background:var(--card);
  box-shadow:var(--shadow-sm);border:1px solid var(--line-soft);
  padding:.5rem .9rem;border-radius:var(--r-pill);font-weight:700;font-size:.82rem;color:var(--ink);
  margin-bottom:1.4rem;
}
.hero__badge b{color:var(--pistacchio);}
.dot{width:8px;height:8px;border-radius:50%;background:var(--pistacchio-l);box-shadow:0 0 0 4px rgba(127,176,105,.22);}
.hero h1{margin-bottom:1.2rem;}
.hero h1 em{font-style:italic;color:var(--pistacchio);}
.hero__sub{max-width:46ch;margin-bottom:1.9rem;}
.hero__actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:2rem;}
.hero__facts{display:flex;flex-wrap:wrap;gap:1.6rem;border-top:1px solid var(--line);padding-top:1.4rem;}
.hero__fact{display:flex;flex-direction:column;}
.hero__fact b{font-family:var(--display);font-size:1.5rem;font-weight:700;color:var(--ink);line-height:1;}
.hero__fact span{font-size:.82rem;color:var(--ink-soft);font-weight:600;margin-top:.35rem;}

/* hero visual */
.hero__visual{position:relative;}
.hero__photo{
  position:relative;border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--shadow-lg);border:6px solid #fff;aspect-ratio:11/13;
}
.hero__photo img{width:100%;height:100%;object-fit:cover;}
.hero__chip{
  position:absolute;background:var(--card);border-radius:var(--r-md);
  box-shadow:var(--shadow-md);padding:.7rem .95rem;display:flex;align-items:center;gap:.6rem;
  font-weight:700;font-size:.9rem;
}
.hero__chip small{display:block;font-weight:600;font-size:.72rem;color:var(--ink-soft);}
.hero__chip .scoop{width:34px;height:34px;border-radius:50%;flex:none;box-shadow:inset 0 -6px 10px rgba(0,0,0,.08);}
.hero__chip--tl{top:8%;left:-6%;animation:float 6s ease-in-out infinite;}
.hero__chip--br{bottom:9%;right:-5%;animation:float 7s ease-in-out infinite .8s;}
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}

/* ============================================================
   Trust strip
   ============================================================ */
.trust{background:var(--ink);color:#fff;}
.trust__row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;padding-block:1.6rem;}
.trust__item{display:flex;align-items:center;gap:.75rem;font-weight:600;font-size:.95rem;color:#f3ece2;}
.trust__item svg{width:24px;height:24px;flex:none;color:var(--pistacchio-l);}

/* ============================================================
   Cards grid (Leistungen)
   ============================================================ */
.grid{display:grid;gap:var(--gap);}
.grid--3{grid-template-columns:repeat(3,1fr);}
.grid--4{grid-template-columns:repeat(4,1fr);}
.grid--2{grid-template-columns:repeat(2,1fr);}

.card{
  background:var(--card);border:1px solid var(--line-soft);border-radius:var(--r-lg);
  overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
  display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}
.card__media{aspect-ratio:4/3;overflow:hidden;background:var(--panna-2);}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);}
.card:hover .card__media img{transform:scale(1.05);}
.card__body{padding:1.4rem 1.4rem 1.6rem;display:flex;flex-direction:column;gap:.55rem;flex:1;}
.card__tag{font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--amarena);}
.card p{font-size:.95rem;}
.card__price{margin-top:auto;padding-top:.6rem;font-weight:700;color:var(--pistacchio);font-size:.92rem;}

/* feature/benefit cards */
.feature{background:var(--card);border:1px solid var(--line-soft);border-radius:var(--r-lg);padding:1.7rem;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease);}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.feature__icon{width:54px;height:54px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:rgba(46,107,69,.1);color:var(--pistacchio);margin-bottom:1.1rem;}
.feature__icon svg{width:26px;height:26px;}
.feature h3{margin-bottom:.5rem;}
.feature p{font-size:.95rem;}

/* ============================================================
   Vetrina — signature flavour strip
   ============================================================ */
.vetrina__scroll{
  display:flex;gap:1rem;overflow-x:auto;padding:.5rem .25rem 1.5rem;
  scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
  scrollbar-width:thin;scrollbar-color:var(--pistacchio-l) transparent;
}
.vetrina__scroll::-webkit-scrollbar{height:8px;}
.vetrina__scroll::-webkit-scrollbar-thumb{background:var(--line);border-radius:99px;}
.flavour{
  scroll-snap-align:start;flex:0 0 auto;width:148px;
  background:var(--card);border:1px solid var(--line-soft);border-radius:var(--r-md);
  padding:1.1rem;text-align:center;box-shadow:var(--shadow-sm);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.flavour:hover{transform:translateY(-6px) rotate(-1.5deg);box-shadow:var(--shadow-md);}
.flavour__scoop{
  width:78px;height:78px;border-radius:50%;margin:0 auto .8rem;
  box-shadow:inset 0 -10px 16px rgba(0,0,0,.12),inset 0 6px 10px rgba(255,255,255,.4);
}
.flavour b{display:block;font-family:var(--display);font-size:1.05rem;}
.flavour span{font-size:.78rem;color:var(--ink-soft);}

/* ============================================================
   About / story
   ============================================================ */
.about__grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(1.8rem,5vw,4.5rem);align-items:center;}
.about__media{position:relative;}
.about__media img{border-radius:var(--r-xl);box-shadow:var(--shadow-lg);border:6px solid #fff;width:100%;}
.about__stamp{
  position:absolute;bottom:-22px;right:-12px;background:var(--amarena);color:#fff;
  width:128px;height:128px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;box-shadow:var(--shadow-md);transform:rotate(-8deg);padding:1rem;border:3px dashed rgba(255,255,255,.5);
}
.about__stamp b{font-family:var(--display);font-size:1.5rem;line-height:1;}
.about__stamp span{font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-top:.3rem;}
.about__lead{margin:1.2rem 0 1.4rem;}
.about p + p{margin-top:1rem;}

/* Accordion (mobile-friendly long text) */
.accordion{margin-top:1.6rem;border-top:1px solid var(--line);}
.acc__item{border-bottom:1px solid var(--line);}
.acc__trigger{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1.1rem .25rem;text-align:left;font-family:var(--display);font-weight:600;font-size:1.1rem;color:var(--ink);
}
.acc__trigger .acc__icon{flex:none;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(46,107,69,.1);color:var(--pistacchio);transition:transform .3s var(--ease),background-color .3s var(--ease);}
.acc__trigger[aria-expanded="true"] .acc__icon{transform:rotate(45deg);background:var(--pistacchio);color:#fff;}
.acc__panel{overflow:hidden;height:0;transition:height .35s var(--ease);}
.acc__panel-inner{padding:0 .25rem 1.2rem;}
.acc__panel-inner p{font-size:.96rem;}

/* ============================================================
   Press / featured
   ============================================================ */
.press__row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1rem 2.2rem;}
.press__item{display:flex;align-items:center;gap:.6rem;font-family:var(--display);font-weight:600;font-size:1.1rem;color:var(--ink);opacity:.8;}
.press__item svg{width:22px;height:22px;color:var(--amarena);flex:none;}

/* ============================================================
   Standort
   ============================================================ */
.standort__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(1.5rem,4vw,3rem);align-items:stretch;}
.standort__map{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--line);}
.standort__map img{width:100%;height:100%;object-fit:cover;min-height:320px;}
.standort__map .route-cta{position:absolute;left:50%;bottom:1.2rem;transform:translateX(-50%);white-space:nowrap;}
.standort__info{background:var(--card);border:1px solid var(--line-soft);border-radius:var(--r-lg);padding:clamp(1.5rem,3vw,2.2rem);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1.3rem;}
.info-row{display:flex;gap:.9rem;}
.info-row svg{width:22px;height:22px;color:var(--pistacchio);flex:none;margin-top:3px;}
.info-row h3{font-size:1.05rem;margin-bottom:.2rem;}
.info-row p,.info-row a{font-size:.95rem;color:var(--ink-soft);}
.info-row a:hover{color:var(--pistacchio);}
.hours{display:grid;grid-template-columns:auto 1fr;gap:.35rem 1.2rem;font-size:.95rem;}
.hours dt{color:var(--ink-soft);font-weight:600;}
.hours dd{color:var(--ink);font-weight:600;text-align:right;}
.badge-soft{display:inline-block;font-size:.74rem;font-weight:700;color:var(--aperol);background:rgba(232,112,58,.12);padding:.2rem .6rem;border-radius:var(--r-pill);}

/* ============================================================
   Kontakt
   ============================================================ */
.contact__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(1.8rem,4vw,3.5rem);align-items:start;}
.contact__aside .feature{margin-bottom:1rem;}
.form{background:var(--card);border:1px solid var(--line-soft);border-radius:var(--r-lg);padding:clamp(1.5rem,3vw,2.4rem);box-shadow:var(--shadow-md);}
.field{margin-bottom:1.15rem;}
.field label{display:block;font-weight:700;font-size:.9rem;margin-bottom:.45rem;}
.field label .req{color:var(--amarena);}
.field input,.field textarea{
  width:100%;padding:.85rem 1rem;border-radius:var(--r-sm);
  background:var(--panna);border:1.5px solid var(--line);
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease),background-color .2s var(--ease);min-height:48px;
}
.field textarea{min-height:130px;resize:vertical;line-height:1.55;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--pistacchio);background:#fff;box-shadow:0 0 0 4px rgba(46,107,69,.12);}
.field input:user-invalid,.field textarea:user-invalid{border-color:var(--amarena);}
.field__hint{font-size:.8rem;color:var(--ink-soft);margin-top:.4rem;}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:1.15rem;}

.consent{display:flex;gap:.8rem;align-items:flex-start;background:var(--panna);border:1.5px solid var(--line);border-radius:var(--r-sm);padding:.95rem 1.05rem;margin-bottom:1.3rem;}
.consent input{flex:none;width:22px;height:22px;margin-top:2px;accent-color:var(--pistacchio);cursor:pointer;}
.consent label{font-size:.88rem;color:var(--ink-soft);line-height:1.5;}
.consent a{color:var(--pistacchio);font-weight:700;text-decoration:underline;text-underline-offset:2px;}
.form__note{margin-top:1rem;font-size:.82rem;color:var(--ink-soft);text-align:center;}
.form__status{margin-top:1rem;padding:.9rem 1rem;border-radius:var(--r-sm);font-weight:600;font-size:.92rem;display:none;}
.form__status.is-ok{display:block;background:rgba(46,107,69,.12);color:var(--pistacchio-d);border:1px solid rgba(46,107,69,.3);}

/* ============================================================
   Footer
   ============================================================ */
.footer{background:var(--ink);color:#e9ddcf;}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.2rem;padding-block:clamp(3rem,6vw,4.5rem);}
.footer__brand .brand__name{color:#fff;}
.footer__brand .brand__name span{color:var(--pistacchio-l);}
.footer__brand .brand__sub{color:#b6a895;}
.footer__brand p{color:#bdaf9d;margin-top:1rem;max-width:34ch;font-size:.95rem;}
.footer h4{color:#fff;font-family:var(--body);font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1.1rem;}
.footer__links a{display:block;padding:.3rem 0;color:#cfc1af;font-size:.95rem;transition:color .2s var(--ease);}
.footer__links a:hover{color:#fff;}
.socials{display:flex;gap:.7rem;margin-top:1.2rem;}
.socials a{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.07);color:#e9ddcf;transition:background-color .25s var(--ease),transform .25s var(--ease),color .25s var(--ease);}
.socials a:hover{background:var(--pistacchio);color:#fff;transform:translateY(-3px);}
.socials svg{width:20px;height:20px;}

.footer__bottom{border-top:1px solid rgba(255,255,255,.12);padding-block:1.4rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;}
.footer__bottom small{color:#a99b89;font-size:.85rem;}
.powered{font-size:.9rem;color:#cfc1af;display:inline-flex;align-items:center;gap:.4rem;}
.powered a{color:#22b8e0;font-weight:700;}
.powered a:hover{text-decoration:underline;}

/* ============================================================
   Scroll reveal
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal[data-delay="1"]{transition-delay:.08s;}
.reveal[data-delay="2"]{transition-delay:.16s;}
.reveal[data-delay="3"]{transition-delay:.24s;}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:1024px){
  .hero__grid{grid-template-columns:1fr;}
  .hero__visual{max-width:520px;margin-inline:auto;order:-1;}
  .grid--4{grid-template-columns:repeat(2,1fr);}
  .about__grid,.standort__grid,.contact__grid{grid-template-columns:1fr;}
  .about__media{max-width:520px;}
  .footer__top{grid-template-columns:1fr 1fr;}
  .footer__brand{grid-column:1 / -1;}
}
@media (max-width:760px){
  .nav__links,.nav__cta .btn--ghost{display:none;}
  .nav__toggle{display:flex;}
  /* Mobile menu panel */
  .nav__links{
    position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;gap:.2rem;
    background:var(--panna);padding:1rem var(--pad-x) 1.6rem;
    box-shadow:0 24px 40px -20px rgba(42,32,26,.4);border-bottom:1px solid var(--line);
    transform:translateY(-12px);opacity:0;pointer-events:none;
    transition:transform .3s var(--ease),opacity .3s var(--ease);max-height:calc(100dvh - 74px);overflow-y:auto;
  }
  .nav__links.open{display:flex;transform:none;opacity:1;pointer-events:auto;}
  .nav__links a{padding:.95rem 1rem;font-size:1.05rem;border-radius:var(--r-sm);}
  .nav__links a:last-child{margin-top:.5rem;background:var(--amarena);color:#fff;text-align:center;font-weight:700;}
  .trust__row{grid-template-columns:1fr 1fr;gap:1rem;}
  .grid--3,.grid--4,.grid--2{grid-template-columns:1fr;}
  .row-2{grid-template-columns:1fr;}
  .hero__facts{gap:1.1rem 1.6rem;}
  .about__stamp{width:104px;height:104px;right:6px;}
  .hero__chip--tl{left:0;}
  .hero__chip--br{right:0;}
}
@media (max-width:430px){
  .hero__chip{display:none;}
  .footer__top{grid-template-columns:1fr;}
  .footer__bottom{flex-direction:column;text-align:center;}
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;}
  .reveal{opacity:1;transform:none;}
}
