/* =====================================================================
   abbeo ag — Designsystem
   Schrift: ITC Avant Garde Std (Book + Demi, original, lokal eingebettet)
   Farben: Corporate Identity abbeo
   ===================================================================== */

/* ---------- Fonts ---------- */
@font-face{
  font-family:'Avant Garde abbeo';
  src:url('../fonts/abbeo-300.woff2') format('woff2'),url('../fonts/abbeo-300.ttf') format('truetype');
  font-weight:300 400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Avant Garde abbeo';
  src:url('../fonts/abbeo-600.woff2') format('woff2'),url('../fonts/abbeo-600.ttf') format('truetype');
  font-weight:600 700;font-style:normal;font-display:swap;
}

/* ---------- Tokens ---------- */
:root{
  /* CI */
  --teal:#7D9AA8;
  --teal-deep:#4d6c79;   /* WCAG: >=4.5:1 auf hellem Grund */
  --teal-mid:#A9BEC6;
  --teal-light:#CCE6F0;
  --blue:#005493;
  --red:#7D251A;
  --grey:#545554;

  /* Erweitert */
  --petrol:#0f2730;        /* tiefer Kontrastton */
  --petrol-2:#15333d;
  --ink:#13262d;           /* Überschriften */
  --text:#3c4a4d;          /* Fliesstext */
  --muted:#5c6c71;         /* sekundär, WCAG-konform */
  --line:#e4eaec;          /* Hairlines */
  --line-strong:#d2dce0;
  --bg:#f5f8f9;            /* Seitengrund */
  --bg-2:#eef3f5;
  --card:#ffffff;
  --white:#ffffff;

  /* Verläufe */
  --grad-ion:linear-gradient(120deg,var(--blue),var(--teal) 55%,var(--teal-light));
  --grad-petrol:linear-gradient(160deg,#13333d 0%,#0d242c 100%);
  --scrim:linear-gradient(90deg,rgba(8,24,30,.78) 0%,rgba(8,24,30,.5) 38%,rgba(8,24,30,.12) 70%,rgba(8,24,30,0) 100%);
  --scrim-bottom:linear-gradient(180deg,rgba(8,24,30,0) 35%,rgba(8,24,30,.55) 100%);

  /* Typo */
  --font:'Avant Garde abbeo','Century Gothic','Avant Garde',system-ui,sans-serif;
  --fs-display:clamp(2.25rem,1.3rem + 3.1vw,4rem);
  --fs-h1:clamp(2.3rem,1.4rem + 3.4vw,3.9rem);
  --fs-h2:clamp(1.85rem,1.2rem + 2.4vw,3rem);
  --fs-h3:clamp(1.3rem,1.05rem + 1vw,1.8rem);
  --fs-lead:clamp(1.12rem,1.02rem + .5vw,1.4rem);
  --fs-body:1.0625rem;
  --fs-small:.92rem;
  --fs-over:.78rem;

  /* Raum */
  --wrap:1240px;
  --wrap-narrow:880px;
  --gut:clamp(1.15rem,4vw,2.5rem);
  --sec:clamp(3.25rem,6vw,5.5rem);
  --radius:18px;
  --radius-s:11px;
  --radius-pill:999px;

  /* Schatten */
  --sh-1:0 1px 2px rgba(15,39,48,.04),0 4px 14px rgba(15,39,48,.05);
  --sh-2:0 2px 6px rgba(15,39,48,.06),0 18px 40px rgba(15,39,48,.10);
  --sh-3:0 30px 70px rgba(15,39,48,.16);

  /* Easing (Emil) */
  --ease-out:cubic-bezier(.23,1,.32,1);
  --ease-in-out:cubic-bezier(.77,0,.175,1);
  --ease-drawer:cubic-bezier(.32,.72,0,1);

  --header-h:78px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--font);font-weight:300;font-size:var(--fs-body);line-height:1.72;
  color:var(--text);background:var(--bg);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  font-synthesis:none;overflow-x:hidden;
}
img,svg,video,canvas{display:block;max-width:100%}
img,video{height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;border:none;background:none}
input,textarea,select{font:inherit}
ul{list-style:none;padding:0}
h1,h2,h3,h4{color:var(--ink);font-weight:600;line-height:1.08;letter-spacing:-.02em}
strong{font-weight:600;color:var(--ink)}
::selection{background:var(--teal-light);color:var(--ink)}

.skip-link{position:absolute;left:-999px;top:0;z-index:200;background:var(--ink);color:#fff;padding:.7rem 1.1rem;border-radius:0 0 8px 0}
.skip-link:focus{left:0}
:focus-visible{outline:2.5px solid var(--blue);outline-offset:3px;border-radius:4px}
[id]{scroll-margin-top:calc(var(--header-h) + 1rem)}

/* ---------- Layout ---------- */
.wrap{width:min(100% - var(--gut)*2,var(--wrap));margin-inline:auto}
.wrap-narrow{width:min(100% - var(--gut)*2,var(--wrap-narrow));margin-inline:auto}
.section{padding-block:var(--sec)}
.section--tight{padding-block:clamp(3rem,6vw,5rem)}
.section--petrol{background:var(--grad-petrol);color:#cfdde2}
.section--petrol h1,.section--petrol h2,.section--petrol h3,.section--petrol strong{color:#fff}
.section--soft{background:var(--bg-2)}
.bleed-top{margin-top:calc(var(--header-h) * -1)}

.eyebrow{display:inline-flex;align-items:center;font-size:var(--fs-over);font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;color:var(--teal-deep)}
.section--petrol .eyebrow{color:var(--teal-mid)}
.center{text-align:center}
.center .eyebrow{justify-content:center}
.lead{font-size:var(--fs-lead);line-height:1.55;color:var(--text);font-weight:300}
.section--petrol .lead{color:#bccdd3}
.measure{max-width:62ch}
.center .measure{margin-inline:auto}

h2.title{font-size:var(--fs-h2);margin-top:.7rem}
h1.title{font-size:var(--fs-h1);margin-top:.7rem}
.title + .lead{margin-top:1.4rem}

/* ---------- Header ---------- */
.site-header{position:fixed;inset:0 0 auto 0;height:var(--header-h);z-index:100;
  display:flex;align-items:center;
  background:#fff;border-bottom:1px solid var(--line);
  transition:box-shadow .3s var(--ease-out)}
.site-header.scrolled{background:rgba(255,255,255,.82);backdrop-filter:saturate(1.3) blur(12px);-webkit-backdrop-filter:saturate(1.3) blur(12px);box-shadow:0 6px 24px rgba(15,39,48,.08)}
.header-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1.2rem;width:100%}
.logo{display:inline-flex;align-items:center;flex:none;grid-column:3;justify-self:end;margin-right:clamp(.8rem,2.6vw,2.4rem)}
.logo img{height:48px;width:auto;display:block;mix-blend-mode:multiply}
.nav{display:flex;align-items:center;grid-column:2;justify-self:center;gap:.5rem}
.nav-link{position:relative;display:inline-flex;align-items:center;gap:.34rem;padding:.6rem .95rem;border-radius:10px;
  font-size:1rem;color:var(--ink);font-weight:300;transition:color .2s var(--ease-out),background .2s var(--ease-out)}
.nav-link:hover{background:rgba(125,154,168,.12)}
.nav-link.is-active{color:var(--teal-deep);font-weight:600}
.nav-link .caret{width:9px;height:9px;border-right:1.6px solid currentColor;border-bottom:1.6px solid currentColor;
  transform:rotate(45deg) translateY(-2px);transition:transform .25s var(--ease-out);opacity:.6}
.nav-item{position:relative}
.nav-item:hover .nav-link .caret,.nav-item:focus-within .nav-link .caret{transform:rotate(225deg) translateY(-2px)}

/* Dropdown */
.dropdown{position:absolute;top:calc(100% + 12px);left:50%;translate:-50% 0;min-width:296px;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius-s);box-shadow:var(--sh-2);
  padding:.5rem;opacity:0;visibility:hidden;transform:scale(.97) translateY(-6px);transform-origin:top center;
  transition:opacity .2s var(--ease-out),transform .2s var(--ease-out),visibility .2s}
.dropdown::before{content:"";position:absolute;top:-12px;left:0;right:0;height:12px}
.nav-item:hover .dropdown,.nav-item:focus-within .dropdown{opacity:1;visibility:visible;transform:scale(1) translateY(0)}
.dropdown a{display:flex;flex-direction:column;gap:.12rem;padding:.7rem .85rem;border-radius:9px;color:var(--ink);
  transition:background .16s var(--ease-out),transform .16s var(--ease-out)}
.dropdown a:hover{background:var(--bg-2)}
.dropdown a small{color:var(--muted);font-size:.82rem;line-height:1.35}
.dropdown a span{font-weight:600;font-size:.97rem;display:inline-flex;align-items:center;gap:.4rem}

.header-cta{display:inline-flex;flex:none;justify-self:start}
.nav-cta-mobile{display:none}
.burger{display:none}
.nav-toggle{display:none}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  padding:.92rem 1.6rem;border-radius:var(--radius-pill);font-weight:600;font-size:.93rem;letter-spacing:.01em;
  transition:transform .16s var(--ease-out),box-shadow .25s var(--ease-out),background .25s var(--ease-out),color .25s var(--ease-out)}
.btn svg{width:17px;height:17px}
.btn:active{transform:scale(.97)}
.btn--primary{background:#496775;color:#fff;box-shadow:0 10px 24px rgba(73,103,117,.34)}
.btn--primary:hover{background:#3c5762;box-shadow:0 14px 30px rgba(73,103,117,.44)}
.btn--ink{background:var(--ink);color:#fff}
.btn--ink:hover{background:#0c1c22}
.btn--ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--line-strong)}
.btn--ghost:hover{box-shadow:inset 0 0 0 1.5px var(--teal);color:var(--teal-deep);background:rgba(125,154,168,.07)}
.btn--light{background:#fff;color:var(--ink);box-shadow:var(--sh-1)}
.btn--light:hover{box-shadow:var(--sh-2)}
.btn--on-dark{background:#fff;color:var(--petrol)}
.btn--on-dark:hover{background:var(--teal-light)}
.btn--lg{padding:1.05rem 2rem;font-size:1rem}
.btn .arr{transition:transform .22s var(--ease-out)}
.btn:hover .arr{transform:translateX(4px)}
.btn-row{display:flex;flex-wrap:wrap;gap:.85rem;align-items:center}
.center .btn-row{justify-content:center}

.textlink{display:inline-flex;align-items:center;gap:.45rem;font-weight:600;color:var(--teal-deep);
  border-bottom:1.5px solid transparent;padding-bottom:2px;transition:border-color .2s var(--ease-out),color .2s var(--ease-out)}
.textlink .arr{transition:transform .22s var(--ease-out)}
.textlink:hover{border-color:var(--teal);color:var(--blue)}
.textlink:hover .arr{transform:translateX(4px)}

/* ---------- Hero (breites, schlankes Cineastik-Band) ---------- */
.hero{position:relative;min-height:clamp(440px,72vh,560px);display:grid;align-content:stretch;
  padding:calc(var(--header-h) + 3rem) 0 clamp(3rem,6vh,5rem);
  overflow:hidden;isolation:isolate;
  background:
    radial-gradient(70% 95% at 22% 12%, rgba(0,84,147,.4), transparent 60%),
    radial-gradient(60% 85% at 88% 96%, rgba(125,154,168,.26), transparent 60%),
    linear-gradient(150deg,#143542 0%,#0b1f26 100%)}
.hero--short{min-height:clamp(360px,52vh,460px)}
/* Cineastik 21:9 ab Desktop, mit Höhen-Untergrenze damit Text immer passt */
@media (min-width:1024px){.hero,.hero--short{aspect-ratio:21/9;min-height:520px}}
.hero__media,.hero__media img,.hero__media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero__media{z-index:-3}
.hero__media img,.hero__media video{animation:kenburns 24s var(--ease-in-out) infinite alternate}
@keyframes kenburns{from{transform:scale(1.02)}to{transform:scale(1.12)}}
.hero__canvas{position:absolute;inset:0;width:100%;height:100%;z-index:-2;opacity:.9}
.hero__scrim{position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(9,26,33,.34) 0%,rgba(9,26,33,.12) 45%,rgba(9,26,33,.5) 100%)}
.hero__scrim::after{content:none}
/* Bild-Hero: Titel links, Beschreibung + zwei CTAs rechts, Bild als Hintergrund */
.hero--image .hero__scrim{background:linear-gradient(90deg,rgba(9,26,33,.66) 0%,rgba(9,26,33,.42) 44%,rgba(9,26,33,.46) 60%,rgba(9,26,33,.62) 100%),linear-gradient(180deg,rgba(9,26,33,0) 46%,rgba(9,26,33,.46) 100%)}
.hero--image .hero__inner{display:grid;grid-template-columns:1.05fr .95fr;grid-template-rows:auto auto;column-gap:clamp(2.5rem,6vw,5.5rem);row-gap:0;align-content:center;text-align:left}
.hero__lead{min-width:0;align-self:start}
.hero--image h1{font-size:clamp(2.6rem,1.6rem + 3vw,4.3rem);line-height:1.06;margin-top:1rem;text-wrap:balance}
.hero__lead .btn-row{margin-top:1.8rem;justify-content:flex-start}
.hero__aside{display:flex;flex-direction:column;align-items:flex-end;align-self:end;margin-left:auto;max-width:72ch;text-align:left}
.hero__aside .hero__sub{margin:0;max-width:none;text-align:left;align-self:flex-end}
@media (max-width:860px){
  .hero--image .hero__inner{grid-template-columns:1fr;grid-template-rows:none;row-gap:1.4rem;min-height:0}
  .hero__lead,.hero__aside{align-self:auto}
  .hero__aside{max-width:60ch;align-items:flex-start;margin-left:0;text-align:left}
  .hero__aside .hero__sub{text-align:left;align-self:flex-start}
  .hero__aside .hero__sub br{display:none}
  .hero--image .hero__scrim{background:linear-gradient(180deg,rgba(9,26,33,.5),rgba(9,26,33,.7))}
}
/* Foto-Hero (Unterseiten): Verlauf links + unten fuer Lesbarkeit von Titel und Beschreibung */
.hero--photo .hero__scrim{background:linear-gradient(100deg,rgba(9,26,33,.66) 0%,rgba(9,26,33,.4) 40%,rgba(9,26,33,.32) 62%,rgba(9,26,33,.52) 100%),linear-gradient(180deg,rgba(9,26,33,.22) 0%,rgba(9,26,33,0) 42%,rgba(9,26,33,.55) 100%)}
@media (max-width:860px){.hero--photo .hero__scrim{background:linear-gradient(180deg,rgba(9,26,33,.45),rgba(9,26,33,.72))}}
.hero__inner{display:grid;grid-template-columns:1.05fr .95fr;grid-template-rows:1.35fr auto auto auto 1fr;column-gap:clamp(2.5rem,6vw,5.5rem);align-items:center;text-align:left}
.hero .eyebrow{grid-column:1;grid-row:2;color:var(--teal-light)}
.hero h1{grid-column:1;grid-row:3;color:#fff;font-size:var(--fs-display);text-wrap:balance;margin-top:.9rem;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.hero .btn-row{grid-column:1;grid-row:4;margin-top:1.6rem;justify-content:flex-start}
.hero__sub{grid-column:2;grid-row:1 / -1;align-self:end;justify-self:end;color:#dceaef;font-size:var(--fs-lead);font-weight:300;margin:0;max-width:44ch;text-align:left;text-wrap:pretty}
@media (max-width:860px){
  .hero{align-content:center}
  .hero__inner{grid-template-columns:1fr;grid-template-rows:none;column-gap:0;min-height:0}
  .hero .eyebrow,.hero h1,.hero__sub,.hero .btn-row{grid-column:1;grid-row:auto}
  .hero__sub{align-self:auto;justify-self:start;margin-top:1.3rem;max-width:56ch;padding-bottom:0}
  .hero .btn-row{margin-top:1.9rem}
}
.hero__scroll{position:absolute;left:50%;bottom:1.3rem;translate:-50% 0;z-index:1;color:#cfe0e6;font-size:.72rem;
  letter-spacing:.22em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:.8}
.hero__scroll span{width:1px;height:34px;background:linear-gradient(#cfe0e6,transparent);animation:scrolldrop 2.1s var(--ease-in-out) infinite}
@keyframes scrolldrop{0%{transform:scaleY(.2);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(.05);transform-origin:bottom}}

/* Floating product chips inside hero (home) */
.hero__chips{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1.7rem}
.hero__chip{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .95rem;border-radius:var(--radius-pill);
  background:rgba(255,255,255,.1);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.18);color:#eaf3f6;font-size:.86rem}
.hero__chip b{color:#fff;font-weight:600}

/* ---------- Breadcrumb ---------- */
.crumb{font-size:.85rem;color:var(--muted);padding-top:1.4rem}
.crumb a{color:var(--teal-deep)}
.crumb a:hover{text-decoration:underline}
.crumb span{margin:0 .45rem;opacity:.5}

/* ---------- Grids ---------- */
.grid{display:grid;gap:clamp(1rem,2.2vw,1.7rem)}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.split--wide{grid-template-columns:1.05fr .95fr}
@media (max-width:920px){.g-3,.g-4{grid-template-columns:repeat(2,1fr)}.split{grid-template-columns:1fr;gap:2.5rem}}
@media (max-width:600px){.g-2,.g-3,.g-4{grid-template-columns:1fr}}

/* ---------- Cards ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--sh-1);
  transition:transform .28s var(--ease-out),box-shadow .28s var(--ease-out),border-color .28s var(--ease-out)}
@media (hover:hover) and (pointer:fine){
  .card.lift:hover{transform:translateY(-6px);box-shadow:var(--sh-3);border-color:var(--line-strong)}
}
.card__body{padding:clamp(1.4rem,2.4vw,2rem)}

/* Vorteils-Kachel */
.feature{padding:clamp(1.5rem,2.4vw,2.1rem);background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--sh-1);transition:transform .28s var(--ease-out),box-shadow .28s var(--ease-out)}
@media (hover:hover){.feature:hover{transform:translateY(-5px);box-shadow:var(--sh-2)}}
.feature .ico{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;margin-bottom:1.1rem;
  background:linear-gradient(150deg,var(--teal-light),#eaf5fb);color:var(--teal-deep)}
.feature .ico svg{width:26px;height:26px}
.feature h3{font-size:1.18rem;margin-bottom:.5rem}
.feature p{font-size:.97rem;color:var(--text)}

/* Vorteile als Bento-Raster (Intro-Kachel + 5 Vorteile = 6 Zellen) */
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(.8rem,1.5vw,1.2rem)}
.bento__intro{background:var(--grad-petrol);color:#fff;border-radius:var(--radius);padding:clamp(1.6rem,2.6vw,2.2rem);
  display:flex;flex-direction:column;justify-content:center;box-shadow:var(--sh-2)}
.bento__intro .eyebrow{color:var(--teal-mid)}
.bento__intro h2{color:#fff;font-size:clamp(1.45rem,1.1rem + 1.1vw,2rem);margin-top:.6rem;line-height:1.12}
.bento__card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.3rem,2vw,1.7rem);
  box-shadow:var(--sh-1);transition:transform .28s var(--ease-out),box-shadow .28s var(--ease-out)}
@media (hover:hover){.bento__card:hover{transform:translateY(-4px);box-shadow:var(--sh-2)}}
.bento__card .ico{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;margin-bottom:.9rem;
  background:linear-gradient(150deg,var(--teal-light),#eaf5fb);color:var(--teal-deep)}
.bento__card .ico svg{width:23px;height:23px}
.bento__card h3{font-size:1.1rem;margin-bottom:.35rem}
.bento__card p{font-size:.92rem;color:var(--text);line-height:1.55}
@media (max-width:860px){.bento{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.bento{grid-template-columns:1fr}}

/* Duft-Palette (Gegenstück zum Vorher/Nachher-Regler) */
.scentbars{display:grid;grid-template-columns:repeat(5,1fr);gap:.4rem;border-radius:var(--radius);overflow:hidden;box-shadow:var(--sh-2);aspect-ratio:16/10}
.scentbars span{display:flex;align-items:flex-end;justify-content:center;padding:.7rem .2rem;color:#fff;font-size:.66rem;
  letter-spacing:.08em;text-transform:uppercase;font-weight:600;transition:transform .35s var(--ease-out)}
@media (hover:hover){.scentbars span:hover{transform:scaleY(1.05)}}

/* Produktwelt-Karten (Home) */
.world{position:relative;overflow:hidden;border-radius:var(--radius);min-height:430px;display:flex;flex-direction:column;
  justify-content:flex-end;color:#fff;isolation:isolate;box-shadow:var(--sh-2)}
.world__bg{position:absolute;inset:0;z-index:-2;background-size:cover;background-position:center;transition:transform .5s var(--ease-out);transform:translateZ(0)}
.world::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(10,28,34,.05),rgba(10,28,34,.78))}
@media (hover:hover){.world:hover .world__bg{transform:scale(1.06) translateZ(0)}}
.world__body{position:relative;z-index:1;padding:clamp(1.6rem,3vw,2.5rem)}
.world h3{color:#fff;font-size:clamp(1.5rem,2.5vw,2.1rem)}
.world p{color:#e7f0f3;margin:.7rem 0 1.3rem;max-width:42ch}
.world .tag{position:absolute;top:1.3rem;left:1.3rem;z-index:1;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.25);backdrop-filter:blur(6px);padding:.4rem .8rem;border-radius:var(--radius-pill)}

/* Geräte-Karte */
.device{display:flex;flex-direction:column;overflow:hidden}
.device__media{position:relative;aspect-ratio:4/3;background:linear-gradient(150deg,#e8f1f5,#f5fafc);overflow:hidden}
.device__media .ph{position:absolute;inset:0;display:grid;place-items:center;color:var(--teal-deep)}
.device__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.device__badge{position:absolute;top:1rem;left:1rem;background:var(--ink);color:#fff;font-size:.72rem;letter-spacing:.1em;
  text-transform:uppercase;padding:.35rem .7rem;border-radius:var(--radius-pill)}
.device__body{padding:clamp(1.3rem,2vw,1.7rem);display:flex;flex-direction:column;gap:.7rem;flex:1}
.device__body h3{font-size:1.3rem}
.device__tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.2rem}
.chip{font-size:.78rem;color:var(--teal-deep);background:rgba(125,154,168,.13);padding:.3rem .65rem;border-radius:var(--radius-pill)}
.device__foot{margin-top:auto;padding-top:.4rem}

/* ---------- Checklist ---------- */
.checks{display:grid;gap:.85rem}
.checks li{display:flex;gap:.8rem;align-items:flex-start;font-size:1rem}
.checks li svg{flex:none;width:23px;height:23px;margin-top:1px;color:var(--teal-deep)}
.section--petrol .checks li svg{color:var(--teal-mid)}
.checks--2{grid-template-columns:1fr 1fr}
@media (max-width:680px){.checks--2{grid-template-columns:1fr}}

/* ---------- Accordion ---------- */
.acc{border-top:1px solid var(--line)}
.acc__item{border-bottom:1px solid var(--line)}
.acc__head{width:100%;display:flex;align-items:center;gap:1.2rem;padding:1.5rem .25rem;text-align:left}
.acc__head .idx{font-size:.82rem;color:var(--teal-deep);font-weight:600;width:2.2rem;flex:none}
.acc__head h3{font-size:clamp(1.12rem,1.6vw,1.45rem);flex:1;transition:color .2s var(--ease-out)}
.acc__head:hover h3{color:var(--teal-deep)}
.acc__sign{flex:none;width:34px;height:34px;border-radius:50%;border:1.5px solid var(--line-strong);position:relative;transition:border-color .25s var(--ease-out),background .25s var(--ease-out)}
.acc__sign::before,.acc__sign::after{content:"";position:absolute;inset:50% 9px auto 9px;height:1.6px;background:var(--ink);transition:transform .3s var(--ease-out),background .25s}
.acc__sign::after{transform:rotate(90deg)}
.acc__item.open .acc__sign{background:var(--teal-deep);border-color:var(--teal-deep)}
.acc__item.open .acc__sign::before,.acc__item.open .acc__sign::after{background:#fff}
.acc__item.open .acc__sign::after{transform:rotate(0)}
.acc__panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows .4s var(--ease-drawer)}
.acc__item.open .acc__panel{grid-template-rows:1fr}
.acc__panelin{overflow:hidden}
.acc__content{padding:0 .25rem 1.8rem;display:grid;grid-template-columns:1.3fr 1fr;gap:2rem;align-items:start}
.acc__content .media{aspect-ratio:16/10;border-radius:var(--radius-s);background:linear-gradient(150deg,#e3eef2,#f3f9fb);overflow:hidden;position:relative}
.acc__content .media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.acc__content .media .ph{position:absolute;inset:0;display:grid;place-items:center;color:var(--teal-deep);gap:.4rem;text-align:center;padding:1rem}
@media (max-width:760px){.acc__content{grid-template-columns:1fr}}

/* ---------- Funktionsweise Steps ---------- */
.steps{counter-reset:step;display:grid;gap:clamp(1rem,2vw,1.5rem)}
.step{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem clamp(1.4rem,2.2vw,2rem) 1.8rem 4.6rem;box-shadow:var(--sh-1)}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);position:absolute;left:1.4rem;top:1.7rem;
  font-weight:600;color:var(--teal-deep);font-size:1rem}
.step h3{font-size:1.18rem;margin-bottom:.5rem}
.step--dark{background:transparent;border-color:rgba(255,255,255,.14)}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.stat .num{font-size:clamp(1.7rem,1.1rem + 1.5vw,2.5rem);font-weight:600;color:var(--ink);line-height:1;letter-spacing:-.02em}
.section--petrol .stat .num{color:#fff}
.stat .lbl{margin-top:.45rem;font-size:.85rem;color:var(--muted);letter-spacing:.01em}
.section--petrol .stat .lbl{color:#a9bfc6}
.stats--bar .stat{text-align:center;padding-inline:.4rem}
@media (min-width:761px){.stats--bar .stat + .stat{border-left:1px solid var(--line)}}
@media (max-width:760px){.stats{grid-template-columns:repeat(2,1fr);gap:1.8rem 1rem}}

/* ---------- Before / After Slider ---------- */
.compare{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--sh-2);aspect-ratio:16/9;
  user-select:none;touch-action:none;background:var(--petrol)}
.compare__side{position:absolute;inset:0;display:grid;place-items:center;text-align:center;padding:2rem}
.compare__before{background:linear-gradient(135deg,#6b6f70,#4a4d4e)}
.compare__after{background:linear-gradient(135deg,#3f7d92,#23586c);clip-path:inset(0 0 0 50%)}
.compare__label{position:absolute;bottom:1rem;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;
  background:rgba(0,0,0,.3);padding:.35rem .8rem;border-radius:var(--radius-pill);backdrop-filter:blur(4px)}
.compare__before .compare__label{left:1rem}
.compare__after .compare__label{right:1rem}
.compare__txt{color:#fff;max-width:24ch}
.compare__txt b{display:block;font-size:1.3rem;margin-bottom:.3rem}
.compare__handle{position:absolute;top:0;bottom:0;left:50%;width:2px;background:#fff;z-index:3;translate:-50% 0}
.compare__grip{position:absolute;top:50%;left:50%;translate:-50% -50%;width:48px;height:48px;border-radius:50%;background:#fff;
  box-shadow:var(--sh-2);display:grid;place-items:center;color:var(--teal-deep)}
.compare__grip svg{width:24px;height:24px}
.compare input[type=range]{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:ew-resize;z-index:4;margin:0}

/* ---------- Duftwelten ---------- */
.scent{position:relative;overflow:hidden;border-radius:var(--radius);min-height:300px;display:flex;flex-direction:column;
  justify-content:flex-end;color:#fff;isolation:isolate;box-shadow:var(--sh-1);
  transition:transform .28s var(--ease-out),box-shadow .28s var(--ease-out)}
@media (hover:hover){.scent:hover{transform:translateY(-5px);box-shadow:var(--sh-3)}}
.scent__bg{position:absolute;inset:0;z-index:-2;transition:transform .5s var(--ease-out)}
@media (hover:hover){.scent:hover .scent__bg{transform:scale(1.07)}}
.scent::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.6))}
.scent__body{padding:clamp(1.4rem,2.5vw,2rem)}
.scent h3{color:#fff;font-size:1.5rem}
.scent .kw{font-size:.84rem;letter-spacing:.16em;text-transform:uppercase;opacity:.92;margin-bottom:.5rem}
.scent p{color:#eef4f6;font-size:.95rem;margin-top:.6rem;max-width:40ch;
  max-height:0;opacity:0;overflow:hidden;transition:max-height .45s var(--ease-drawer),opacity .35s var(--ease-out),margin .4s}
.scent.open p{max-height:200px;opacity:1}
.scent__toggle{margin-top:1rem;align-self:flex-start;font-size:.82rem;letter-spacing:.06em;color:#fff;
  display:inline-flex;align-items:center;gap:.45rem;border-bottom:1.5px solid rgba(255,255,255,.5);padding-bottom:2px}
.scent__toggle .arr{transition:transform .3s var(--ease-out)}
.scent.open .scent__toggle .arr{transform:rotate(180deg)}

/* ---------- Pricing / Abo ---------- */
.plan{display:flex;flex-direction:column;padding:clamp(1.6rem,2.6vw,2.3rem);background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--sh-1);position:relative;transition:transform .28s var(--ease-out),box-shadow .28s var(--ease-out)}
.plan.featured{border-color:var(--teal);box-shadow:0 24px 60px rgba(85,119,133,.2);background:linear-gradient(180deg,#fff,#fbfdfe)}
@media (hover:hover){.plan:hover{transform:translateY(-6px);box-shadow:var(--sh-3)}}
.plan__flag{position:absolute;top:-13px;left:clamp(1.6rem,2.6vw,2.3rem);background:var(--grad-ion);color:#fff;font-size:.74rem;
  letter-spacing:.1em;text-transform:uppercase;padding:.4rem .85rem;border-radius:var(--radius-pill);font-weight:600;box-shadow:var(--sh-1)}
.plan h3{font-size:1.5rem}
.plan .tagline{color:var(--muted);margin:.5rem 0 1.3rem;font-size:.95rem;min-height:2.6em}
.plan__list{display:grid;gap:.7rem;margin:0 0 1.6rem;padding-top:1.3rem;border-top:1px solid var(--line)}
.plan__list li{display:flex;gap:.6rem;align-items:flex-start;font-size:.95rem}
.plan__list li svg{flex:none;width:20px;height:20px;color:var(--teal-deep);margin-top:2px}
.plan__cta{margin-top:auto}
.plan .ideal{font-size:.86rem;color:var(--muted);margin-bottom:1.2rem}
.plan .ideal b{color:var(--ink);font-weight:600}

/* ---------- Split media block ---------- */
.media-block{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:5/4;background:linear-gradient(150deg,#e3eef2,#f3f9fb);box-shadow:var(--sh-2)}
.media-block img,.media-block video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.media-block .ph{position:absolute;inset:0;display:grid;place-content:center;justify-items:center;gap:.6rem;color:var(--teal-deep);text-align:center;padding:2rem}
.media-block .ph svg{width:42px;height:42px;opacity:.7}
.media-block .ph small{font-size:.82rem;color:var(--muted);max-width:30ch}
.media-block--tall{aspect-ratio:3/4}
.media-block--fill{aspect-ratio:auto;align-self:stretch}
@media (max-width:920px){.media-block--fill{aspect-ratio:5/4;align-self:auto}}
.media-tag{position:absolute;left:1rem;bottom:1rem;z-index:2;background:rgba(255,255,255,.85);backdrop-filter:blur(6px);
  color:var(--ink);font-size:.78rem;padding:.4rem .8rem;border-radius:var(--radius-pill);box-shadow:var(--sh-1)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;border-radius:clamp(20px,3vw,30px);background:var(--grad-petrol);color:#fff;
  padding:clamp(2.6rem,6vw,5rem);isolation:isolate}
.cta-band canvas{position:absolute;inset:0;z-index:-1;opacity:.6}
.cta-band h2{color:#fff;font-size:var(--fs-h2)}
.cta-band p{color:#c6d6db;margin:1rem 0 2rem;max-width:52ch}
.cta-band.center p{margin-inline:auto}

/* ---------- Quiz teaser ---------- */
.quizteaser{position:relative;overflow:hidden;border-radius:var(--radius);background:var(--card);border:1px solid var(--line);
  display:grid;grid-template-columns:1.1fr .9fr;box-shadow:var(--sh-2)}
.quizteaser__body{padding:clamp(1.8rem,3.5vw,3rem)}
.quizteaser__visual{position:relative;background:var(--grad-petrol);min-height:280px;overflow:hidden;isolation:isolate}
.quizteaser__visual canvas{position:absolute;inset:0}
.quizteaser__visual .badge{position:absolute;top:50%;left:50%;translate:-50% -50%;text-align:center;color:#fff;z-index:1}
.quizteaser__visual .badge b{font-size:3rem;display:block;font-weight:600}
@media (max-width:760px){.quizteaser{grid-template-columns:1fr}.quizteaser__visual{min-height:180px;order:-1}}

/* ---------- Team ---------- */
.team-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;box-shadow:var(--sh-1);
  transition:transform .3s var(--ease-out),box-shadow .3s var(--ease-out)}
@media (hover:hover){.team-card:hover{transform:translateY(-4px);box-shadow:var(--sh-2)}}
.team-card .avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(150deg,var(--teal-light),#eaf5fb);
  display:grid;place-items:center;color:var(--teal-deep);font-weight:600;font-size:1.3rem;margin-bottom:1rem}
.team-card h3{font-size:1.18rem}
.team-card .role{color:var(--teal-deep);font-size:.9rem;font-weight:600;margin-top:.2rem}
.team-card .contacts{margin-top:1rem;display:grid;gap:.6rem;font-size:.92rem}
.team-card .contacts a{padding:.15rem 0}
.team-card .contacts a{display:inline-flex;align-items:center;gap:.5rem;color:var(--text)}
.team-card .contacts a:hover{color:var(--teal-deep)}
.team-card .contacts svg{width:17px;height:17px;color:var(--teal-deep);flex:none}

/* ---------- Form ---------- */
.form{display:grid;gap:1.1rem}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
@media (max-width:560px){.form .row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:.4rem}
.field label{font-size:.85rem;font-weight:600;color:var(--ink)}
.field input,.field textarea{background:var(--white);border:1.5px solid var(--line-strong);border-radius:11px;padding:.85rem 1rem;
  color:var(--ink);transition:border-color .2s var(--ease-out),box-shadow .2s var(--ease-out)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,84,147,.28)}
.field textarea{resize:vertical;min-height:130px}
.form__note{font-size:.82rem;color:var(--muted)}

/* ---------- Partner logos ---------- */
.partners{display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.partners .cell{background:var(--card);aspect-ratio:3/2;display:grid;place-items:center;color:var(--muted);font-size:.82rem;
  transition:background .25s var(--ease-out),color .25s}
.partners .cell:hover{background:var(--bg-2);color:var(--teal-deep)}
@media (max-width:900px){.partners{grid-template-columns:repeat(3,1fr)}}
@media (max-width:520px){.partners{grid-template-columns:repeat(2,1fr)}}

/* ---------- Marquee ---------- */
.marquee{overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__track{display:flex;gap:3rem;width:max-content;animation:marquee 32s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__track span{color:var(--muted);font-size:1rem;white-space:nowrap;display:inline-flex;align-items:center;gap:3rem}
.marquee__track span::after{content:"";width:5px;height:5px;border-radius:50%;background:var(--teal)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- Trust row (statisch, zentriert) ---------- */
.trustrow{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:.7rem 1.4rem;
  color:var(--muted);font-size:.95rem;letter-spacing:.01em}
.trustrow span{display:inline-flex;align-items:center;gap:1.4rem}
.trustrow span:not(:last-child)::after{content:"";width:4px;height:4px;border-radius:50%;background:var(--teal);opacity:.7}

/* ---------- Pills / tag row ---------- */
.pillrow{display:flex;flex-wrap:wrap;gap:.55rem}
.pillrow .p{font-size:.86rem;background:var(--bg-2);border:1px solid var(--line);color:var(--text);padding:.45rem .9rem;border-radius:var(--radius-pill)}

/* ---------- Footer ---------- */
.site-footer{background:var(--bg-2);color:var(--text);padding-top:clamp(3.5rem,6vw,5.5rem);border-top:1px solid var(--line)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2.5rem;padding-bottom:3rem}
.site-footer h4{color:var(--ink);font-size:.95rem;letter-spacing:.04em;margin-bottom:1.1rem}
.footer-col a,.footer-col p{display:block;color:var(--text);font-size:.92rem;padding:.28rem 0;transition:color .2s var(--ease-out)}
.footer-col a:hover{color:var(--teal-deep)}
.footer-logo{display:inline-flex;margin-bottom:1.2rem}
.footer-logo img{height:44px;width:auto;display:block;mix-blend-mode:multiply}
.footer-brand p{max-width:34ch;font-size:.92rem;line-height:1.6}
.socials{display:flex;gap:.6rem;margin-top:1.3rem}
.socials a{width:44px;height:44px;border-radius:50%;border:1px solid var(--line-strong);display:grid;place-items:center;
  color:var(--teal-deep);transition:background .22s var(--ease-out),color .22s,transform .22s var(--ease-out)}
@media (hover:hover){.socials a:hover{background:var(--teal-deep);color:#fff;transform:translateY(-3px)}}
.socials svg{width:18px;height:18px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  padding:1.6rem 0;border-top:1px solid var(--line);font-size:.85rem;color:var(--muted)}
.footer-bottom .legal{display:flex;gap:1.4rem;flex-wrap:wrap}
.footer-bottom a:hover{color:var(--ink)}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr}}

/* ---------- Floating contact ---------- */
.fab{position:fixed;right:clamp(1rem,3vw,1.8rem);bottom:clamp(1rem,3vw,1.8rem);z-index:90;display:inline-flex;align-items:center;gap:.6rem;
  background:var(--teal-deep);color:#fff;padding:.9rem 1.3rem;border-radius:var(--radius-pill);box-shadow:0 14px 34px rgba(85,119,133,.45);
  font-weight:600;font-size:.92rem;transform:translateY(0);transition:transform .25s var(--ease-out),box-shadow .25s,background .25s}
@media (hover:hover){.fab:hover{transform:translateY(-3px);background:#3f5b66}}
.fab svg{width:19px;height:19px}
@media (max-width:560px){.fab span{display:none}.fab{padding:1rem;border-radius:50%}}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.07s}
.reveal[data-d="2"]{transition-delay:.14s}
.reveal[data-d="3"]{transition-delay:.21s}
.reveal[data-d="4"]{transition-delay:.28s}
.reveal[data-d="5"]{transition-delay:.35s}

/* ---------- Utility ---------- */
.mt-0{margin-top:0}.mt-1{margin-top:.6rem}.mt-2{margin-top:1.2rem}.mt-3{margin-top:2rem}.mt-4{margin-top:3rem}
.mb-3{margin-bottom:2rem}
.maxw-head{max-width:46ch}
.center .maxw-head{margin-inline:auto}
.divider{height:1px;background:var(--line);border:none;margin-block:var(--sec)}
.rule-accent{width:64px;height:3px;border-radius:3px;background:var(--grad-ion);margin:1.4rem 0}
.center .rule-accent{margin-inline:auto}

/* ---------- Prose (Rechtsseiten) ---------- */
.prose h2{font-size:var(--fs-h3);margin:2.4rem 0 .8rem}
.prose h3{font-size:1.15rem;margin:1.6rem 0 .5rem}
.prose p{margin-bottom:1rem}
.prose ul{list-style:disc;padding-left:1.3rem;margin-bottom:1rem;display:grid;gap:.4rem}
.prose a{color:var(--teal-deep);border-bottom:1px solid var(--line-strong)}
.prose a:hover{border-color:var(--teal)}
.prose .addr{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-s);padding:1.2rem 1.4rem;margin-bottom:1.4rem}

/* ---------- Mobile nav ---------- */
@media (max-width:1040px){
  .header-inner{display:flex;justify-content:space-between;align-items:center}
  .header-cta{display:none}
  .burger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;flex:none;z-index:120;cursor:pointer}
  .burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease-out),opacity .2s}
  .nav-toggle:checked ~ .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle:checked ~ .burger span:nth-child(2){opacity:0}
  .nav-toggle:checked ~ .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav{position:fixed;inset:var(--header-h) 0 0 0;background:var(--bg);flex-direction:column;align-items:stretch;
    gap:.15rem;padding:1.4rem var(--gut);overflow-y:auto;
    transform:translateX(100%);transition:transform .4s var(--ease-drawer);box-shadow:var(--sh-3)}
  .nav-toggle:checked ~ .nav{transform:translateX(0)}
  .nav-link{font-size:1.1rem;padding:.85rem .5rem;border-radius:10px}
  .nav-item{border-bottom:1px solid var(--line)}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;background:transparent;
    min-width:0;padding:0 0 .6rem 1rem}
  .dropdown a{padding:.55rem .5rem}
  .nav-cta-mobile{display:inline-flex;width:100%;justify-content:center;margin-top:1.2rem}
  .nav-link .caret{margin-left:auto}
}
@media (max-width:1040px){body.nav-open{overflow:hidden}}

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

/* ================= Top-Level Politur (Test, reversibel) ================= */
/* Hero-Eingang: gestaffeltes Auftauchen */
.hero .eyebrow{animation:heroUp .75s var(--ease-out) both}
.hero h1{animation:heroUp .75s var(--ease-out) .08s both}
.hero__sub{animation:heroUp .75s var(--ease-out) .16s both}
.hero .btn-row{animation:heroUp .75s var(--ease-out) .24s both}
@keyframes heroUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}

/* 3D-Tilt der Produktkacheln (Rotation per JS) */
.world{transition:transform .6s var(--ease-out)}

/* Feiner Glanz-Sweep auf Primaer-Buttons beim Hover */
.btn--primary{position:relative;overflow:hidden}
.btn--primary::after{content:"";position:absolute;top:0;bottom:0;left:-130%;width:55%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.28),transparent);transform:skewX(-18deg);pointer-events:none}
@media (hover:hover) and (pointer:fine){.btn--primary:hover::after{left:140%;transition:left .7s var(--ease-out)}}

/* Cursor-Spotlight auf dunklen Abschnitten */
.section--petrol.has-spot,.cta-band.has-spot{position:relative;overflow:hidden}
.has-spot::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:0;transition:opacity .45s var(--ease-out);background:radial-gradient(340px circle at var(--mx,50%) var(--my,40%),rgba(169,190,198,.20),transparent 62%)}
@media (hover:hover) and (pointer:fine){.has-spot:hover::before{opacity:1}}
.section--petrol.has-spot>*,.cta-band.has-spot>*{position:relative;z-index:1}

/* Klickbarkeit deutlich machen: CTA-Pfeil + Link reagieren auf Hover der ganzen Karte */
@media (hover:hover) and (pointer:fine){
  .card.lift:hover .textlink{border-color:var(--teal);color:var(--blue)}
  .card.lift:hover .textlink .arr{transform:translateX(6px)}
  .world:hover .textlink{border-color:rgba(255,255,255,.95);color:#fff}
  .world:hover .textlink .arr{transform:translateX(6px)}
}

/* Hero-Bild klaert sich beim Laden (frische, klare Luft) */
@keyframes heroClear{from{filter:blur(12px) saturate(.8);opacity:.55;transform:scale(1.1)}to{filter:blur(0) saturate(1);opacity:1;transform:scale(1.04)}}
.hero--image .hero__media img,.hero--photo .hero__media img{animation:heroClear 1.3s var(--ease-out) both}

/* Lebendige Luft: Stroemungsfeld-Canvas im Hero */
.hero .airflow{position:absolute;inset:0;width:100%;height:100%;z-index:-2;pointer-events:none}

/* Perfektes Handwerk: sichtbarer Tastatur-Fokus */
a:focus-visible,button:focus-visible,.btn:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,summary:focus-visible,label.choice:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--teal-deep);outline-offset:3px;border-radius:6px}

/* Nav-Link: animierte Unterstreichung */
.nav-link{position:relative}
.nav-link::after{content:"";position:absolute;left:.1rem;right:.1rem;bottom:-3px;height:2px;border-radius:2px;background:var(--teal-deep);transform:scaleX(0);transform-origin:center;transition:transform .28s var(--ease-out)}
@media (hover:hover) and (pointer:fine){.nav-link:hover::after{transform:scaleX(1)}}
.nav-link.is-active::after{transform:scaleX(1);background:var(--teal)}

/* Duft-Diffusion: warmes, atmendes Bloom in Raumbeduftungs-Abschnitten */
.page-scent .section--petrol{position:relative;overflow:hidden}
.page-scent .section--petrol::after{content:"";position:absolute;z-index:0;left:50%;top:50%;width:min(70vw,640px);height:min(70vw,640px);translate:-50% -50%;border-radius:50%;background:radial-gradient(circle,rgba(214,178,138,.16),transparent 64%);animation:scentBloom 9s ease-in-out infinite;pointer-events:none}
.page-scent .section--petrol>*{position:relative;z-index:1}
@keyframes scentBloom{0%,100%{transform:scale(.82);opacity:.45}50%{transform:scale(1.15);opacity:.9}}
.page-home,.page-ion,.page-company,.page-contact{--page-scope:1}

/* Immersiver Startseiten-Hero: hebt die Startseite klar von den Unterseiten ab */
.hero--image{min-height:92vh}
@media (min-width:1024px){.hero--image{aspect-ratio:auto;min-height:100vh}}
@media (max-width:860px){.hero--image{min-height:88vh}}
.hero--image .hero__media img{object-position:center 35%}
/* Textfeld im hohen Hero auf Augenhoehe zentrieren */
/* Startseite-Hero: Titel oben links, Beschreibung beginnt rechts auf Hoehe der Button-Unterkante */
.hero--image .hero__lead{grid-column:1;grid-row:1;align-self:start}
.hero--image .hero__aside{grid-column:2;grid-row:2;align-self:start;justify-self:end}
@media (max-width:860px){.hero--image .hero__lead,.hero--image .hero__aside{grid-column:1;grid-row:auto;justify-self:start;align-self:auto}}
