/* ============================================================
   ESTAVO — Premium / Luxus-Edition
   Private Banking trifft Luxus-Hospitality trifft KI.
   Mitternachts-Navy · Champagner-Gold · Creme/Elfenbein
   ============================================================ */

:root{
  /* Navy-Tiefen */
  --navy-900:#070D1C;
  --navy-800:#0A1124;
  --navy-700:#0C1B33;
  --navy-600:#15294D;
  --navy-500:#1C3563;

  /* Gold / Champagner */
  --gold:#C8A24B;
  --gold-soft:#E6CB7E;
  --gold-deep:#A8853A;
  --gold-warm:#D9B968;
  --gold-line:rgba(200,162,75,.30);

  /* Creme / Taupe / Neutral */
  --cream:#F6F2E9;
  --cream-2:#EFE9DA;
  --ivory:#FBF9F3;
  --taupe:#8A93A8;
  --taupe-deep:#5E6880;
  --ink:#0C1B33;
  --line:#E5DECB;
  --white:#ffffff;

  /* System */
  --radius:18px;
  --radius-lg:26px;
  --radius-xl:34px;
  --maxw:1180px;
  --maxw-narrow:880px;

  --shadow-xs:0 6px 18px rgba(10,17,36,.06);
  --shadow-sm:0 14px 38px rgba(10,17,36,.09);
  --shadow:0 30px 80px rgba(10,17,36,.16);
  --shadow-gold:0 24px 60px rgba(200,162,75,.22);

  --ease:cubic-bezier(.16,.84,.34,1);
  --ease-slow:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  color:var(--ink);
  background:var(--ivory);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* ---- Film-Grain Overlay (gesamtseitig, dezent) ---- */
body::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

h1,h2,h3,h4{
  font-family:'Fraunces','Times New Roman',Georgia,serif;
  line-height:1.08;color:var(--navy-700);font-weight:500;
  font-optical-sizing:auto;letter-spacing:-.012em;
}
a{color:var(--navy-700);text-decoration:none}
img,svg{max-width:100%;display:block}
strong{font-weight:600}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 26px}
.container--narrow{max-width:var(--maxw-narrow)}

.skip-link{position:absolute;left:-999px;top:0;background:var(--navy-700);color:var(--cream);padding:12px 18px;border-radius:0 0 10px 0;z-index:10000}
.skip-link:focus{left:0}

/* ---- Eyebrow / Akzente ---- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.7em;
  font-size:.74rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;
  color:var(--gold-deep);margin:0 0 1.1em;font-family:'Inter',sans-serif;
}
.eyebrow::before{content:"";width:30px;height:1px;background:linear-gradient(90deg,transparent,var(--gold))}
.eyebrow--center{justify-content:center}
.eyebrow--center::after{content:"";width:30px;height:1px;background:linear-gradient(90deg,var(--gold),transparent)}
.eyebrow--light{color:var(--gold-soft)}
.eyebrow--light::before{background:linear-gradient(90deg,transparent,var(--gold-soft))}
.eyebrow--light.eyebrow--center::after{background:linear-gradient(90deg,var(--gold-soft),transparent)}
.accent{color:var(--gold-deep)}

/* Gold-Hairline divider */
.hairline{height:1px;border:0;background:linear-gradient(90deg,transparent,var(--gold-line) 18%,var(--gold-line) 82%,transparent);margin:0}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:'Inter',sans-serif;font-weight:600;font-size:1rem;letter-spacing:.005em;
  padding:15px 30px;border-radius:999px;text-decoration:none;border:1px solid transparent;
  cursor:pointer;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s,color .35s,border-color .35s;
  overflow:hidden;isolation:isolate;
}
.btn--solid{background:linear-gradient(135deg,var(--gold-soft),var(--gold) 55%,var(--gold-deep));color:var(--navy-800);box-shadow:0 14px 34px rgba(200,162,75,.26)}
.btn--solid::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.55) 50%,transparent 70%);transform:translateX(-130%);transition:transform .7s var(--ease)}
.btn--solid:hover{transform:translateY(-3px);box-shadow:0 22px 48px rgba(200,162,75,.4)}
.btn--solid:hover::after{transform:translateX(130%)}
.btn--ghost{background:transparent;color:var(--navy-700);border-color:var(--navy-700)}
.btn--ghost:hover{background:var(--navy-700);color:var(--cream);transform:translateY(-3px)}
.btn--light{background:transparent;color:var(--cream);border-color:rgba(246,242,233,.45)}
.btn--light:hover{background:var(--cream);color:var(--navy-800);transform:translateY(-3px)}
.btn--sm{padding:11px 22px;font-size:.9rem}
.btn--lg{padding:18px 38px;font-size:1.06rem}
.btn .arrow{transition:transform .35s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

/* ============================================================
   HEADER / NAV — transparent, scroll-aware
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background .4s var(--ease),box-shadow .4s,border-color .4s,backdrop-filter .4s;
  border-bottom:1px solid transparent;
}
.site-header.is-scrolled{
  background:rgba(8,13,28,.72);backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid rgba(200,162,75,.16);
  box-shadow:0 12px 40px rgba(0,0,0,.28);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:84px}
.nav__brand{display:flex;align-items:center;transition:opacity .3s}
.nav__brand:hover{opacity:.82}
.nav__brand img{height:34px;width:auto}
/* Logo on dark hero = mono/white; swap handled by two imgs */
.nav__brand .logo--dark{display:none}
.site-header.is-scrolled .nav__brand .logo--light{display:none}
.site-header.is-scrolled .nav__brand .logo--dark{display:block}

.nav__menu{display:flex;align-items:center;gap:34px}
.nav__menu a:not(.btn){
  position:relative;color:var(--cream);font-weight:500;font-size:.95rem;letter-spacing:.01em;
  padding:4px 0;transition:color .3s;
}
.nav__menu a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--gold-soft);transition:width .4s var(--ease)}
.nav__menu a:not(.btn):hover{color:var(--gold-soft)}
.nav__menu a:not(.btn):hover::after{width:100%}
.nav__toggle{display:none;flex-direction:column;gap:6px;background:none;border:0;cursor:pointer;padding:10px;z-index:60}
.nav__toggle span{width:26px;height:2px;background:var(--cream);border-radius:2px;transition:.35s var(--ease)}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;color:var(--cream);
  padding:190px 0 130px;overflow:hidden;
  background:
    radial-gradient(120% 90% at 78% 6%, rgba(200,162,75,.16), transparent 52%),
    radial-gradient(90% 80% at 6% 92%, rgba(28,53,99,.7), transparent 60%),
    linear-gradient(165deg,var(--navy-900) 0%,var(--navy-700) 46%,var(--navy-600) 100%);
}
.hero::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(70% 55% at 50% 0%, rgba(255,255,255,.05), transparent 70%);
}
.hero__grid{position:relative;display:grid;grid-template-columns:1.06fr .94fr;gap:64px;align-items:center}
.hero .eyebrow{color:var(--gold-soft)}
.hero h1{
  font-size:clamp(2.6rem,6vw,4.7rem);letter-spacing:-.02em;color:#fff;font-weight:400;
  line-height:1.02;
}
.hero h1 .accent{
  color:transparent;background:linear-gradient(120deg,var(--gold-soft),var(--gold-warm) 60%,var(--gold-deep));
  -webkit-background-clip:text;background-clip:text;font-style:italic;
}
.hero .lead{font-size:1.18rem;color:#c8d0e0;max-width:33em;margin-top:1.4rem;font-weight:400}
.hero__cta{display:flex;flex-wrap:wrap;gap:16px;margin:38px 0 22px}
.hero__note{display:flex;flex-wrap:wrap;gap:10px 20px;font-size:.82rem;color:#9aa4ba;align-items:center}
.hero__note span{display:inline-flex;align-items:center;gap:7px}
.hero__note span::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--gold)}

/* ---- Hero Visual: edles Call-Transcript-Panel (animiert) ---- */
.hero__visual{position:relative}
.glass-panel{
  position:relative;
  background:linear-gradient(155deg,rgba(255,255,255,.09),rgba(255,255,255,.03));
  border:1px solid rgba(230,203,126,.22);
  border-radius:var(--radius-xl);
  box-shadow:0 40px 90px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter:blur(14px);
  padding:30px 30px 26px;
  overflow:hidden;
}
.glass-panel::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold-soft),transparent)}
.glass-panel--float{animation:float 7s var(--ease-slow) infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

.callbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.callbar__live{display:inline-flex;align-items:center;gap:9px;font-size:.76rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-soft)}
.pulse{position:relative;width:9px;height:9px;border-radius:50%;background:var(--gold-soft)}
.pulse::after{content:"";position:absolute;inset:0;border-radius:50%;background:var(--gold-soft);animation:pulse 2s var(--ease) infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.7}70%{transform:scale(3.4);opacity:0}100%{opacity:0}}
.callbar__time{font-size:.76rem;color:#9aa4ba}

/* animated transcript lines */
.transcript{display:flex;flex-direction:column;gap:12px;min-height:188px}
.t-line{display:flex;gap:11px;align-items:flex-start;opacity:0;transform:translateY(8px)}
.js .t-line{animation:tIn .6s var(--ease) forwards}
.js .t-line:nth-child(1){animation-delay:.5s}
.js .t-line:nth-child(2){animation-delay:1.8s}
.js .t-line:nth-child(3){animation-delay:3.1s}
.js .t-line:nth-child(4){animation-delay:4.4s}
@keyframes tIn{to{opacity:1;transform:none}}
/* Replay: Animationen erneut auslösen (Hero-Schleife) */
.glass-panel.replay .t-line,.glass-panel.replay .booked-strip{animation:none}
.glass-panel.replay .t-line{animation:tIn .6s var(--ease) forwards}
.glass-panel.replay .t-line:nth-child(1){animation-delay:.3s}
.glass-panel.replay .t-line:nth-child(2){animation-delay:1.6s}
.glass-panel.replay .t-line:nth-child(3){animation-delay:2.9s}
.glass-panel.replay .t-line:nth-child(4){animation-delay:4.2s}
.glass-panel.replay .booked-strip{animation:tIn .7s var(--ease) 5.5s forwards}
.t-line__who{flex:0 0 auto;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;font-family:'Inter',sans-serif}
.t-line--caller .t-line__who{background:rgba(255,255,255,.1);color:#c8d0e0}
.t-line--ai .t-line__who{background:linear-gradient(135deg,var(--gold-soft),var(--gold-deep));color:var(--navy-800)}
.t-line__txt{font-size:.92rem;line-height:1.5;color:#dfe4ee;padding-top:4px}
.t-line--ai .t-line__txt{color:#fff}

.booked-strip{
  margin-top:18px;display:flex;align-items:center;gap:12px;
  background:linear-gradient(120deg,rgba(200,162,75,.18),rgba(200,162,75,.06));
  border:1px solid rgba(230,203,126,.32);border-radius:14px;padding:14px 16px;
  opacity:0;transform:translateY(8px);
}
.js .booked-strip{animation:tIn .7s var(--ease) 5.7s forwards}
.booked-strip .chk{flex:0 0 auto;width:26px;height:26px;border-radius:50%;background:var(--gold);color:var(--navy-800);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem}
.booked-strip__txt{font-size:.86rem;color:#fff;font-weight:500}
.booked-strip__txt strong{color:var(--gold-soft)}

/* floating mini-meta cards around panel */
.hero__chip{
  position:absolute;z-index:3;background:rgba(8,13,28,.78);backdrop-filter:blur(10px);
  border:1px solid rgba(230,203,126,.28);border-radius:14px;padding:11px 15px;
  box-shadow:0 20px 40px rgba(0,0,0,.4);font-size:.78rem;color:#dfe4ee;
}
.hero__chip strong{display:block;font-family:'Fraunces',serif;color:var(--gold-soft);font-size:1.05rem;font-weight:500}
.hero__chip--a{top:-54px;left:-34px;animation:floatChip 6s var(--ease-slow) infinite}
.hero__chip--b{bottom:24px;right:-30px;animation:floatChip 6s var(--ease-slow) .8s infinite reverse}
@keyframes floatChip{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* ============================================================
   KENNZAHLEN-BAND
   ============================================================ */
.metricbar{background:var(--navy-700);position:relative;border-top:1px solid rgba(200,162,75,.14)}
.metricbar__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:48px 0}
.metric{text-align:center;padding:8px 18px;position:relative}
.metric+.metric::before{content:"";position:absolute;left:0;top:14%;bottom:14%;width:1px;background:linear-gradient(180deg,transparent,rgba(200,162,75,.28),transparent)}
.metric__num{font-family:'Fraunces',serif;font-size:clamp(2.1rem,4vw,2.9rem);font-weight:400;color:var(--gold-soft);line-height:1;letter-spacing:-.01em}
.metric__num .suf{font-size:.55em;color:var(--gold)}
.metric__label{display:block;margin-top:12px;font-size:.84rem;color:#aeb7cc;letter-spacing:.01em}

/* ============================================================
   SECTIONS (light)
   ============================================================ */
.section{padding:120px 0;position:relative}
.section--tint{background:var(--cream)}
.section--ivory{background:var(--ivory)}
.section--narrow-pad{padding:96px 0}
.section__head{max-width:46em;margin:0 auto 60px}
.section__head--center{text-align:center}
.section__head h2{font-size:clamp(2rem,4.2vw,3.1rem);font-weight:400;letter-spacing:-.018em}
.section__head h2 em{font-style:italic;color:var(--gold-deep)}
.section__intro{color:var(--taupe-deep);font-size:1.12rem;margin-top:1.1rem;line-height:1.7}

/* ============================================================
   PROBLEM — Daten-Visualisierung
   ============================================================ */
.problem__grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:60px;align-items:center}
.problem__viz{
  position:relative;background:linear-gradient(160deg,var(--navy-700),var(--navy-600));
  border-radius:var(--radius-xl);padding:42px 40px;color:var(--cream);
  box-shadow:var(--shadow);border:1px solid rgba(200,162,75,.16);overflow:hidden;
}
.problem__viz::before{content:"";position:absolute;top:-40%;right:-20%;width:60%;height:120%;background:radial-gradient(circle,rgba(200,162,75,.18),transparent 70%)}
.problem__viz h3{color:#fff;font-size:1.3rem;margin-bottom:6px;font-weight:500}
.problem__viz .vsub{color:#9aa4ba;font-size:.86rem;margin-bottom:28px}
.bar-row{position:relative;margin-bottom:22px}
.bar-row__top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:9px}
.bar-row__label{font-size:.9rem;color:#dfe4ee}
.bar-row__val{font-family:'Fraunces',serif;font-size:1.15rem;color:var(--gold-soft)}
.bar{height:9px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}
.bar__fill{height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,var(--gold-deep),var(--gold-soft));transition:width 1.4s var(--ease-slow)}
.bar__fill--miss{background:linear-gradient(90deg,#8A93A8,#c0c8d8)}
.is-visible .bar__fill{width:var(--w)}
.problem__viz .vnote{margin-top:24px;padding-top:18px;border-top:1px solid rgba(255,255,255,.1);font-size:.8rem;color:#8a93a8;line-height:1.6}

.problem__list{list-style:none;display:grid;gap:2px}
.problem__list li{position:relative;padding:18px 0 18px 40px;border-bottom:1px solid var(--line)}
.problem__list li:last-child{border-bottom:0}
.problem__list li::before{content:"";position:absolute;left:6px;top:23px;width:11px;height:11px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 5px rgba(200,162,75,.14)}
.problem__list strong{display:block;color:var(--navy-700);font-weight:600;margin-bottom:2px;font-size:1.02rem}
.problem__list span{color:var(--taupe-deep);font-size:.95rem}

/* ============================================================
   STEPS — So funktioniert Estavo
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;counter-reset:step}
.step{
  position:relative;background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:38px 32px 34px;box-shadow:var(--shadow-xs);transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s;
  overflow:hidden;
}
.step::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold-soft),var(--gold-deep));transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease)}
.step:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:var(--gold-line)}
.step:hover::before{transform:scaleX(1)}
.step__n{
  display:flex;align-items:center;justify-content:center;width:58px;height:58px;border-radius:50%;
  background:linear-gradient(155deg,var(--navy-700),var(--navy-500));color:var(--gold-soft);
  font-family:'Fraunces',serif;font-weight:400;font-size:1.5rem;margin-bottom:22px;
  box-shadow:0 12px 26px rgba(12,27,51,.22),inset 0 1px 0 rgba(255,255,255,.12);
  border:1px solid rgba(200,162,75,.24);
}
.step h3{font-size:1.32rem;margin-bottom:12px;font-weight:500}
.step p{margin:0;font-size:.98rem;color:var(--taupe-deep);line-height:1.65}
.step__line{display:none}

/* ============================================================
   FEATURES
   ============================================================ */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.feature{
  position:relative;background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:36px 32px;box-shadow:var(--shadow-xs);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s;
}
.feature:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--gold-line)}
.feature__icon{
  width:54px;height:54px;border-radius:15px;display:flex;align-items:center;justify-content:center;
  margin-bottom:22px;background:linear-gradient(155deg,var(--cream),var(--cream-2));
  border:1px solid var(--gold-line);box-shadow:inset 0 1px 0 rgba(255,255,255,.7);
}
.feature__icon svg{width:26px;height:26px;stroke:var(--gold-deep);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.feature h3{font-size:1.22rem;margin-bottom:10px;font-weight:500}
.feature p{margin:0;color:var(--taupe-deep);font-size:.97rem;line-height:1.65}

/* ============================================================
   IM GESPRÄCH — Transcript-Beispiel (light, editorial)
   ============================================================ */
.dialog__grid{display:grid;grid-template-columns:1fr 1.12fr;gap:56px;align-items:center}
.dialog__copy h2{margin-bottom:16px}
.dialog__copy p{color:var(--taupe-deep);font-size:1.06rem}
.dialog__tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.dialog__tag{font-size:.82rem;font-weight:500;color:var(--navy-700);background:var(--white);border:1px solid var(--gold-line);border-radius:999px;padding:8px 16px;box-shadow:var(--shadow-xs)}

.chat{
  background:linear-gradient(170deg,var(--white),var(--ivory));
  border:1px solid var(--line);border-radius:var(--radius-xl);
  box-shadow:var(--shadow);padding:30px;position:relative;overflow:hidden;
}
.chat::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold-soft),var(--gold-deep))}
.chat__head{display:flex;align-items:center;justify-content:space-between;padding-bottom:20px;margin-bottom:22px;border-bottom:1px solid var(--line)}
.chat__id{display:flex;align-items:center;gap:12px}
.chat__avatar{width:42px;height:42px;border-radius:13px;background:var(--navy-700);display:flex;align-items:center;justify-content:center}
.chat__avatar img{width:24px;height:24px}
.chat__id b{display:block;font-family:'Fraunces',serif;color:var(--navy-700);font-weight:500;font-size:1.02rem}
.chat__id span{font-size:.78rem;color:var(--taupe)}
.chat__time{font-size:.78rem;color:var(--gold-deep);font-weight:600;display:inline-flex;align-items:center;gap:7px}
.chat__bubbles{display:flex;flex-direction:column;gap:14px}
.bubble{max-width:84%;padding:13px 17px;font-size:.95rem;line-height:1.55;border-radius:16px}
.bubble--caller{align-self:flex-start;background:var(--cream);color:var(--navy-700);border-bottom-left-radius:5px}
.bubble--ai{align-self:flex-end;background:linear-gradient(135deg,var(--navy-700),var(--navy-600));color:#fff;border-bottom-right-radius:5px;box-shadow:0 14px 30px rgba(12,27,51,.2)}
.bubble small{display:block;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;opacity:.6;margin-bottom:3px;font-weight:600}
.chat__result{margin-top:22px;display:flex;align-items:center;gap:13px;background:linear-gradient(120deg,rgba(200,162,75,.16),rgba(200,162,75,.05));border:1px solid var(--gold-line);border-radius:16px;padding:16px 18px}
.chat__result .chk{flex:0 0 auto;width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--gold-soft),var(--gold-deep));color:var(--navy-800);display:flex;align-items:center;justify-content:center;font-weight:700}
.chat__result b{color:var(--navy-700);font-weight:600}
.chat__result span{display:block;font-size:.84rem;color:var(--taupe-deep)}

/* ============================================================
   NUTZEN / BENEFITS
   ============================================================ */
.benefits{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.benefit{
  position:relative;padding:34px 32px;border-radius:var(--radius-lg);
  background:var(--white);border:1px solid var(--line);box-shadow:var(--shadow-xs);
  transition:transform .5s var(--ease),box-shadow .5s;overflow:hidden;
}
.benefit:hover{transform:translateY(-5px);box-shadow:var(--shadow-sm)}
.benefit__no{font-family:'Fraunces',serif;font-size:1rem;color:var(--gold-deep);letter-spacing:.04em}
.benefit h3{font-size:1.28rem;margin:10px 0 10px;font-weight:500}
.benefit p{margin:0;color:var(--taupe-deep);font-size:.98rem;line-height:1.65}

/* ============================================================
   TIMELINE / Einführung
   ============================================================ */
.timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;position:relative}
.tl{position:relative;background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px 26px;box-shadow:var(--shadow-xs);transition:transform .5s var(--ease),box-shadow .5s}
.tl:hover{transform:translateY(-5px);box-shadow:var(--shadow-sm)}
.tl__day{display:inline-block;font-family:'Inter',sans-serif;font-weight:600;font-size:.76rem;letter-spacing:.06em;color:var(--gold-deep);background:rgba(200,162,75,.12);border:1px solid var(--gold-line);padding:6px 14px;border-radius:999px;margin-bottom:16px}
.tl h3{font-size:1.14rem;margin-bottom:8px;font-weight:500}
.tl p{margin:0;color:var(--taupe-deep);font-size:.93rem;line-height:1.6}

/* ============================================================
   REFERENZ / VERTRAUEN
   ============================================================ */
.refbox{
  position:relative;background:linear-gradient(160deg,var(--white),var(--ivory));
  border:1px solid var(--line);border-radius:var(--radius-xl);
  padding:54px 56px;max-width:880px;margin:0 auto;box-shadow:var(--shadow);overflow:hidden;
}
.refbox::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold-soft),var(--gold-deep))}
.refbox__mark{font-family:'Fraunces',serif;font-size:5rem;line-height:.6;color:var(--gold);opacity:.4;margin-bottom:8px}
.refbox .quote{font-family:'Fraunces',serif;font-size:clamp(1.4rem,2.6vw,1.9rem);line-height:1.42;color:var(--navy-700);margin-bottom:26px;font-weight:400}
.refbox .meta{display:flex;align-items:center;gap:14px;color:var(--taupe-deep);font-size:.96rem}
.refbox .meta .av{width:46px;height:46px;border-radius:50%;background:linear-gradient(155deg,var(--cream),var(--cream-2));border:1px solid var(--gold-line)}
.refbox .meta strong{color:var(--navy-700);display:block}
.refnote{text-align:center;color:var(--taupe);font-size:.86rem;margin-top:24px;font-style:italic}

/* WAS ESTAVO NICHT IST */
.notbox{
  position:relative;background:var(--navy-700);color:var(--cream);
  border-radius:var(--radius-xl);padding:48px 52px;max-width:920px;margin:0 auto;
  box-shadow:var(--shadow);border:1px solid rgba(200,162,75,.16);overflow:hidden;
}
.notbox::before{content:"";position:absolute;top:-30%;left:-10%;width:50%;height:140%;background:radial-gradient(circle,rgba(200,162,75,.14),transparent 70%)}
.notbox h3{position:relative;color:#fff;font-size:1.6rem;margin-bottom:22px;font-weight:500}
.notbox h3 em{color:var(--gold-soft);font-style:italic}
.notbox__items{position:relative;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:22px}
.notbox__items span{font-size:.88rem;color:#dfe4ee;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:999px;padding:9px 17px}
.notbox p{position:relative;margin:0;color:#aeb7cc;font-size:1rem;line-height:1.7;max-width:60em}

/* ============================================================
   FAQ
   ============================================================ */
.faq{max-width:880px;margin:0 auto;display:grid;gap:14px}
.faq__item{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:6px 28px;box-shadow:var(--shadow-xs);transition:box-shadow .4s,border-color .4s}
.faq__item[open]{box-shadow:var(--shadow-sm);border-color:var(--gold-line)}
.faq__item summary{cursor:pointer;font-weight:500;font-family:'Fraunces',serif;font-size:1.16rem;color:var(--navy-700);padding:20px 0;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary .ic{flex:0 0 auto;width:28px;height:28px;border-radius:50%;border:1px solid var(--gold-line);position:relative;transition:transform .35s var(--ease),background .35s}
.faq__item summary .ic::before,.faq__item summary .ic::after{content:"";position:absolute;top:50%;left:50%;background:var(--gold-deep);transition:.35s}
.faq__item summary .ic::before{width:11px;height:1.6px;transform:translate(-50%,-50%)}
.faq__item summary .ic::after{width:1.6px;height:11px;transform:translate(-50%,-50%)}
.faq__item[open] summary .ic{transform:rotate(135deg);background:rgba(200,162,75,.12)}
.faq__item p{margin:0 0 22px;color:var(--taupe-deep);line-height:1.7;max-width:62em}

/* ============================================================
   CTA / KONTAKT
   ============================================================ */
.cta{
  position:relative;color:var(--cream);padding:130px 0;overflow:hidden;
  background:
    radial-gradient(90% 70% at 50% 0%, rgba(200,162,75,.16), transparent 55%),
    radial-gradient(70% 60% at 12% 100%, rgba(28,53,99,.6), transparent 60%),
    linear-gradient(165deg,var(--navy-900),var(--navy-700) 55%,var(--navy-600));
}
.cta__inner{max-width:760px;margin:0 auto;text-align:center;position:relative}
.cta h2{color:#fff;font-size:clamp(2.1rem,4.2vw,3.2rem);font-weight:400;letter-spacing:-.02em}
.cta h2 em{font-style:italic;color:var(--gold-soft)}
.cta>.cta__inner>p{color:#c8d0e0;margin-top:1rem;font-size:1.12rem}
.demo-form{max-width:660px;margin:42px auto 0;text-align:left}
.demo-form__grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.demo-field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.demo-field--full{grid-column:1 / -1}
.demo-field>span{font-size:.8rem;font-weight:600;color:#dfe4ee;letter-spacing:.02em}
.demo-form input,.demo-form textarea{
  font:inherit;font-size:1rem;color:#fff;background:rgba(255,255,255,.05);
  border:1px solid rgba(246,242,233,.18);border-radius:12px;padding:14px 16px;width:100%;
  transition:border-color .3s,box-shadow .3s,background .3s;
}
.demo-form input::placeholder,.demo-form textarea::placeholder{color:#7c869c}
.demo-form input:focus,.demo-form textarea:focus{outline:none;border-color:var(--gold);background:rgba(255,255,255,.08);box-shadow:0 0 0 3px rgba(200,162,75,.28)}
.demo-form textarea{resize:vertical;min-height:92px}
.demo-form .btn{margin-top:8px;width:100%}
.demo-form__hp{position:absolute;left:-9999px}
.demo-form__note{font-size:.78rem;color:#9aa4ba;margin-top:14px;text-align:center}
.demo-thanks{max-width:580px;margin:42px auto 0;text-align:center;background:rgba(246,242,233,.06);border:1px solid var(--gold-line);border-radius:var(--radius-lg);padding:40px 34px}
.demo-thanks .chk{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--gold-soft),var(--gold-deep));color:var(--navy-800);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.4rem;margin:0 auto 16px}
.demo-thanks h3{color:#fff;margin:0 0 8px;font-size:1.5rem;font-weight:500}
.demo-thanks p{color:#c8d0e0;margin:0}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--navy-900);color:#aeb7cc;padding:80px 0 32px;position:relative;border-top:1px solid rgba(200,162,75,.14)}
.footer__grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:40px}
.footer__brand img{height:34px;width:auto;margin-bottom:18px}
.footer__brand p{max-width:27em;color:#9aa4ba;font-size:.94rem;line-height:1.7}
.footer__tag{font-family:'Fraunces',serif;color:var(--cream);font-size:1.05rem;font-style:italic;margin-bottom:10px!important}
.footer__col h4{color:#fff;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:16px;font-family:'Inter',sans-serif;font-weight:600}
.footer__col a{display:block;color:#aeb7cc;text-decoration:none;font-size:.95rem;padding:5px 0;transition:color .3s,transform .3s var(--ease)}
.footer__col a:hover{color:var(--gold-soft);transform:translateX(3px)}
.footer__base{margin-top:54px;padding-top:24px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.82rem;color:#6c7690}
.footer__base a{color:#8a93a8}
.footer__base a:hover{color:var(--gold-soft)}

/* ============================================================
   LEGAL PAGES
   ============================================================ */
.legal-wrap{padding-top:84px}
.legal{max-width:800px;margin:0 auto;padding:80px 26px 100px}
.legal__back{display:inline-flex;align-items:center;gap:7px;margin-bottom:30px;color:var(--gold-deep);text-decoration:none;font-weight:600;font-size:.92rem}
.legal__back:hover{color:var(--gold)}
.legal h1{font-size:clamp(2rem,4vw,2.7rem);margin-bottom:14px;font-weight:400}
.legal__lead{color:var(--taupe-deep);font-size:1.06rem;margin-bottom:10px}
.legal h2{font-size:1.28rem;margin:40px 0 12px;font-weight:500;color:var(--navy-700)}
.legal p,.legal address{color:var(--taupe-deep);font-style:normal;margin-bottom:12px;line-height:1.8}
.legal a{color:var(--gold-deep);text-decoration:underline;text-decoration-color:var(--gold-line)}
.legal a:hover{color:var(--gold)}
.legal address strong,.legal p strong{color:var(--navy-700)}
.legal .hairline{margin:8px 0 0}

/* ============================================================
   SCROLL-REVEAL (nur mit JS)
   ============================================================ */
.js .reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease-slow),transform .9s var(--ease-slow)}
.js .reveal.is-visible{opacity:1;transform:none}
.js .reveal-stagger>*{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease-slow),transform .8s var(--ease-slow)}
.js .reveal-stagger.is-visible>*{opacity:1;transform:none}
.js .reveal-stagger.is-visible>*:nth-child(2){transition-delay:.1s}
.js .reveal-stagger.is-visible>*:nth-child(3){transition-delay:.2s}
.js .reveal-stagger.is-visible>*:nth-child(4){transition-delay:.3s}
.js .reveal-stagger.is-visible>*:nth-child(5){transition-delay:.4s}
.js .reveal-stagger.is-visible>*:nth-child(6){transition-delay:.5s}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .features{grid-template-columns:1fr 1fr}
  .timeline{grid-template-columns:1fr 1fr}
  .metricbar__grid{grid-template-columns:1fr 1fr;gap:36px 0}
  .metric:nth-child(3)::before,.metric:nth-child(odd)::before{display:none}
  .metric:nth-child(even)::before{display:block}
}
@media (max-width:900px){
  .hero{padding:150px 0 100px}
  .hero__grid{grid-template-columns:1fr;gap:56px}
  .hero__chip{display:none}
  .problem__grid{grid-template-columns:1fr;gap:40px}
  .dialog__grid{grid-template-columns:1fr;gap:40px}
  .steps{grid-template-columns:1fr}
  .benefits{grid-template-columns:1fr}
  .section{padding:88px 0}
  .nav__menu{
    position:fixed;inset:0 0 0 auto;width:min(86vw,360px);flex-direction:column;align-items:flex-start;
    justify-content:center;gap:24px;background:linear-gradient(160deg,var(--navy-800),var(--navy-700));
    padding:40px;transform:translateX(105%);transition:transform .45s var(--ease);
    box-shadow:-30px 0 80px rgba(0,0,0,.5);border-left:1px solid rgba(200,162,75,.2);
  }
  .nav__menu.is-open{transform:translateX(0)}
  .nav__menu a:not(.btn){font-size:1.2rem;font-family:'Fraunces',serif}
  .nav__menu .btn{width:100%;margin-top:8px}
  .nav__toggle{display:flex}
}
@media (max-width:620px){
  .features{grid-template-columns:1fr}
  .timeline{grid-template-columns:1fr}
  .demo-form__grid{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr 1fr}
  .footer__brand{grid-column:1 / -1}
  .metricbar__grid{grid-template-columns:1fr 1fr}
  .refbox,.notbox{padding:36px 26px}
  .problem__viz{padding:32px 26px}
  .container{padding:0 20px}
}
@media (max-width:430px){
  .footer__grid{grid-template-columns:1fr}
  .hero__cta .btn{width:100%}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  .glass-panel--float,.hero__chip{animation:none!important}
  .js .reveal,.js .reveal-stagger>*{opacity:1!important;transform:none!important;transition:none!important}
  .t-line,.booked-strip{opacity:1!important;transform:none!important}
  .bar__fill{transition:none!important;width:var(--w)!important}
}
