/* The Vitalist – Stylesheet
   Palette: deep navy blue, cream, brass-gold, steel
   Typo: Fraunces (display serif) + Inter (sans)
   Note: the historical class/variable names (--green, .bg-green) now carry
   the navy-blue brand colour. Names kept stable to avoid breaking markup. */

:root{
  --green:#102A47;       /* deep navy (primary) */
  --green-d:#0A1E33;     /* darker navy */
  --green-700:#1C5180;   /* link / mid blue */
  --gold:#C8A855;
  --gold-d:#9E8038;
  --cream:#F7F4ED;
  --cream-2:#ECE7DC;
  --sage:#8FA6BD;        /* steel blue accent */
  --ink:#1A2230;
  --muted:#566173;
  --line:#E1DBCE;
  --white:#ffffff;
  --maxw:1160px;
  --radius:16px;
  --shadow:0 18px 50px -28px rgba(10,30,51,.5);
  --shadow-sm:0 8px 26px -18px rgba(10,30,51,.42);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{
  font-family:"Fraunces","Georgia",serif;
  font-weight:500;
  line-height:1.12;
  letter-spacing:-.01em;
  color:var(--green-d);
  margin:0 0 .5em;
}
h1{font-size:clamp(2.2rem,5vw,3.6rem)}
h2{font-size:clamp(1.7rem,3.4vw,2.5rem)}
h3{font-size:clamp(1.2rem,2vw,1.45rem)}
p{margin:0 0 1.1rem}
a{color:var(--green-700);text-decoration:none}
a:hover{color:var(--gold-d)}
img{max-width:100%;display:block}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{
  font-family:"Inter",sans-serif;text-transform:uppercase;letter-spacing:.18em;
  font-size:.74rem;font-weight:600;color:var(--gold-d);margin:0 0 1rem;
}
.lead{font-size:1.18rem;color:var(--muted);max-width:60ch}
.section{padding:96px 0}
.section--tight{padding:64px 0}
.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}
.muted{color:var(--muted)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-weight:600;font-size:.98rem;line-height:1;
  padding:15px 26px;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:.18s ease;white-space:nowrap;
}
.btn--primary{background:var(--green);color:var(--cream)}
.btn--primary:hover{background:var(--green-d);color:var(--cream);transform:translateY(-1px)}
.btn--gold{background:var(--gold);color:var(--green-d)}
.btn--gold:hover{background:var(--gold-d);color:#fff;transform:translateY(-1px)}
.btn--ghost{background:transparent;border-color:var(--green);color:var(--green)}
.btn--ghost:hover{background:var(--green);color:var(--cream)}
.btn--light{background:var(--cream);color:var(--green-d)}
.btn--light:hover{background:var(--white)}
.btn--lg{padding:18px 32px;font-size:1.05rem}
.btn-row{display:flex;flex-wrap:wrap;gap:14px}
.btn-row--center{justify-content:center}

/* Header */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(247,244,237,.88);backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;gap:20px}
.brand{display:flex;align-items:center;gap:11px;color:var(--green-d)}
.brand:hover{color:var(--green-d)}
.brand img{width:36px;height:36px}
.wordmark{font-family:"Fraunces",serif;font-size:1.32rem;letter-spacing:-.01em;line-height:1;white-space:nowrap}
.wordmark b{font-weight:600;color:var(--green-d)}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none;margin:0;padding:0}
.nav-links a{font-size:.97rem;font-weight:500;color:var(--ink)}
.nav-links a:hover,.nav-links a.active{color:var(--gold-d)}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--green-d);margin:5px 0;transition:.2s}

/* Language switcher */
.lang{position:relative}
.lang-btn{
  display:inline-flex;align-items:center;gap:7px;cursor:pointer;
  font:inherit;font-size:.9rem;font-weight:600;color:var(--green-d);
  background:transparent;border:1.5px solid var(--line);border-radius:999px;
  padding:9px 14px;line-height:1;transition:.15s;
}
.lang-btn:hover{border-color:var(--gold)}
.lang-btn::before{content:"";width:16px;height:16px;display:inline-block;
  background:no-repeat center/contain url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23102A47' stroke-width='2'><circle cx='12' cy='12' r='9'/><path d='M3 12h18M12 3a15 15 0 0 1 0 18M12 3a15 15 0 0 0 0 18'/></svg>");}
.lang-btn::after{content:"";width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid var(--green-d)}
.lang-menu{
  position:absolute;right:0;top:calc(100% + 8px);min-width:190px;
  background:var(--white);border:1px solid var(--line);border-radius:12px;
  box-shadow:var(--shadow);padding:6px;display:none;z-index:80;
}
.lang.open .lang-menu{display:block}
.lang-menu a{display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:10px 12px;border-radius:8px;color:var(--ink);font-size:.92rem;font-weight:500}
.lang-menu a:hover{background:var(--cream-2);color:var(--green-d)}
.lang-menu a.active{color:var(--gold-d);font-weight:600}
.lang-menu a.soon{color:var(--muted);cursor:default}
.lang-menu a.soon:hover{background:transparent}
.lang-menu .tag{font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;
  color:var(--gold-d);border:1px solid var(--line);border-radius:99px;padding:2px 7px}

/* Hero */
.hero{position:relative;overflow:hidden;background:var(--green);color:var(--cream)}
.hero::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(900px 460px at 82% -10%,rgba(200,168,85,.20),transparent 60%),
    radial-gradient(700px 420px at 8% 110%,rgba(143,166,189,.20),transparent 60%);
}
.hero .container{position:relative;z-index:2}
.hero-inner{padding:96px 0 80px;max-width:820px}
.hero h1{color:var(--cream)}
.hero .eyebrow{color:var(--gold)}
.hero p{color:rgba(247,244,237,.88);font-size:1.2rem;max-width:56ch}
.hero .btn-row{margin-top:30px}

/* Dual path cards */
.paths{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:54px}
.path{
  background:rgba(247,244,237,.06);border:1px solid rgba(247,244,237,.18);
  border-radius:var(--radius);padding:30px;transition:.2s;
}
.path:hover{background:rgba(247,244,237,.11);transform:translateY(-3px)}
.path h3{color:var(--cream);margin-bottom:.4rem}
.path .tag{font-size:.74rem;text-transform:uppercase;letter-spacing:.16em;color:var(--gold);font-weight:600}
.path p{font-size:1rem;color:rgba(247,244,237,.82);margin-bottom:1.2rem}
.path .go{display:inline-flex;align-items:center;gap:8px;color:var(--gold);font-weight:600}

/* Generic grid */
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px;box-shadow:var(--shadow-sm);
}
.card h3{margin-bottom:.5rem;color:var(--green-d)}
.card p{margin-bottom:0;color:var(--muted)}
.card .num{font-family:"Fraunces",serif;font-size:1.6rem;color:var(--gold-d);display:block;margin-bottom:.4rem}

.split{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.split--reverse .media{order:2}
.media img{border-radius:var(--radius);box-shadow:var(--shadow)}
.bg-cream2{background:var(--cream-2)}
.bg-green{background:var(--green);color:var(--cream)}
.bg-green h2,.bg-green>.container>.center h2{color:var(--cream)}
.bg-green>.container>div>p,.bg-green .lead{color:rgba(247,244,237,.85)}
.bg-green .eyebrow{color:var(--gold)}
/* Cards inside dark sections keep dark, legible text */
.bg-green .card h3,.bg-green .level h3{color:var(--green-d)}
.bg-green .card p,.bg-green .level p,.bg-green .card .muted,.bg-green .level .muted{color:var(--muted)}

/* Levels (Stufe 1-2-3) */
.levels{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:10px}
.level{border:1px solid var(--line);border-radius:var(--radius);padding:26px;background:var(--white)}
.level--3{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold) inset, var(--shadow-sm);background:#fffdf6}
.level .step{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-d);font-weight:600}
.level h3{margin:.4rem 0;color:var(--green-d)}
.level p{color:var(--muted)}

/* Feature list */
.flist{list-style:none;margin:0;padding:0;display:grid;gap:14px}
.flist li{display:flex;gap:13px;align-items:flex-start;color:var(--muted)}
.flist .ic{flex:0 0 auto;width:24px;height:24px;margin-top:2px;color:var(--gold-d)}
.flist b{color:var(--ink);font-weight:600}

/* Trust strip */
.trust{display:flex;flex-wrap:wrap;gap:14px 34px;justify-content:center;align-items:center}
.trust span{display:inline-flex;align-items:center;gap:9px;color:var(--muted);font-size:.95rem;font-weight:500}
.trust .ic{color:var(--gold-d);width:20px;height:20px}

/* Phases timeline */
.phases{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;counter-reset:ph}
.phase{position:relative;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px}
.phase::before{
  counter-increment:ph;content:counter(ph);
  font-family:"Fraunces",serif;font-size:1.05rem;color:var(--cream);
  width:38px;height:38px;border-radius:50%;background:var(--green);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px;
}
.phase h3{color:var(--green-d)}
.phase .amount{color:var(--gold-d);font-weight:600;margin-top:8px;display:block}
.phase .amount small{display:block;color:var(--muted);font-weight:500;font-size:.8rem;margin-top:2px}

/* Highlight / anchor banner */
.banner{background:linear-gradient(120deg,var(--green),var(--green-700));color:var(--cream);
  border-radius:24px;padding:40px 44px;display:flex;flex-wrap:wrap;align-items:center;
  justify-content:space-between;gap:24px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.banner::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(600px 300px at 90% -20%,rgba(200,168,85,.25),transparent 60%)}
.banner .b-txt{position:relative;z-index:2;max-width:62ch}
.banner h2{color:var(--cream);margin-bottom:.3rem}
.banner p{color:rgba(247,244,237,.85);margin:0}
.banner .b-cta{position:relative;z-index:2}

/* Self-check */
.check{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow-sm);max-width:720px;margin:0 auto}
.check .q{font-family:"Fraunces",serif;font-size:1.35rem;color:var(--green-d);margin-bottom:18px}
.check .opts{display:grid;gap:10px}
.check .opt{display:block;width:100%;text-align:left;padding:14px 18px;border:1.5px solid var(--line);border-radius:12px;background:var(--cream);cursor:pointer;font:inherit;color:var(--ink);transition:.15s}
.check .opt:hover{border-color:var(--gold);background:#fffdf6}
.check .bar{height:6px;background:var(--cream-2);border-radius:99px;overflow:hidden;margin-bottom:22px}
.check .bar i{display:block;height:100%;background:var(--gold);width:0;transition:width .3s}
.check .result{text-align:center}
.check .result h3{margin-bottom:.4rem}

/* Quote / experience */
.quote{font-family:"Fraunces",serif;font-size:clamp(1.4rem,2.6vw,1.9rem);line-height:1.4;color:var(--green-d);max-width:24ch}

/* CTA band */
.cta-band{background:var(--green);color:var(--cream);border-radius:24px;padding:56px;text-align:center}
.cta-band h2{color:var(--cream)}
.cta-band p{color:rgba(247,244,237,.85);max-width:54ch;margin-left:auto;margin-right:auto}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.contact-card{display:flex;gap:14px;align-items:flex-start;padding:20px 0;border-bottom:1px solid var(--line)}
.contact-card .ic{color:var(--gold-d);width:24px;height:24px;flex:0 0 auto;margin-top:3px}
.contact-card b{display:block;color:var(--ink)}
.contact-card a{color:var(--green-700)}
form .field{margin-bottom:16px}
form label{display:block;font-size:.9rem;font-weight:600;margin-bottom:6px;color:var(--ink)}
form input,form textarea,form select{
  width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:12px;
  font:inherit;background:var(--white);color:var(--ink);
}
form input:focus,form textarea:focus,form select:focus{outline:none;border-color:var(--gold)}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:.86rem;color:var(--muted)}
.consent input{width:auto;margin-top:4px}
#cal-inline{min-height:640px;width:100%;border:1px solid var(--line);border-radius:var(--radius);overflow:auto;background:var(--white)}

/* Compliance note */
.note{background:var(--cream-2);border-left:3px solid var(--gold);border-radius:8px;padding:16px 20px;font-size:.92rem;color:var(--muted)}

/* Floating WhatsApp */
.wa-float{
  position:fixed;right:20px;bottom:20px;z-index:60;
  display:inline-flex;align-items:center;gap:10px;
  background:#25D366;color:#073b22;font-weight:600;
  padding:13px 18px;border-radius:999px;box-shadow:var(--shadow);
}
.wa-float:hover{transform:translateY(-2px);color:#073b22}
.wa-float svg{width:22px;height:22px}

/* Footer */
.site-footer{background:var(--green-d);color:rgba(247,244,237,.8);padding:64px 0 30px}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px}
.site-footer h4{color:var(--cream);font-family:"Inter",sans-serif;font-size:.85rem;text-transform:uppercase;letter-spacing:.14em;margin-bottom:14px}
.site-footer a{color:rgba(247,244,237,.8)}
.site-footer a:hover{color:var(--gold)}
.footer-links{list-style:none;margin:0;padding:0;display:grid;gap:10px;font-size:.95rem}
.footer-brand{display:flex;align-items:center;gap:11px;font-family:"Fraunces",serif;font-size:1.25rem;color:var(--cream);margin-bottom:14px}
.footer-brand b{font-weight:600}
.footer-brand img{width:32px;height:32px}
.footer-bottom{margin-top:40px;padding-top:22px;border-top:1px solid rgba(247,244,237,.16);display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;font-size:.85rem;color:rgba(247,244,237,.6)}
.disclaimer{font-size:.82rem;color:rgba(247,244,237,.55);max-width:90ch;margin-top:18px;line-height:1.6}

/* Legal pages */
.legal{max-width:820px}
.legal h2{margin-top:2em}
.legal h3{margin-top:1.4em}
.legal p,.legal li{color:var(--muted)}
.legal ul{padding-left:20px}

/* Responsive */
@media(max-width:880px){
  .nav-links{
    position:fixed;inset:74px 0 auto 0;background:var(--cream);
    flex-direction:column;gap:0;padding:8px 24px 18px;border-bottom:1px solid var(--line);
    display:none;
  }
  .nav-links.open{display:flex}
  .nav-links li{width:100%;border-bottom:1px solid var(--line)}
  .nav-links a{display:block;padding:14px 0}
  .nav-toggle{display:block}
  .nav-cta .btn{display:none}
  .lang-btn{padding:8px 12px}
  .paths,.grid-2,.grid-3,.levels,.phases,.split,.contact-grid,.footer-top{grid-template-columns:1fr}
  .split{gap:32px}
  .split--reverse .media{order:0}
  .section{padding:68px 0}
  .cta-band{padding:40px 24px}
  .banner{padding:32px 26px}
}
