/* ============================================================
   Anni — Produktseiten Design-System
   Warmes Editorial · Terracotta auf Cream · Bricolage + Hanken
   ============================================================ */
:root{
  --terra:#C75639; --terra-deep:#A4421F; --terra-soft:rgba(199,86,57,.10);
  --ink:#2A211C; --ink-soft:#5A4D44;
  --cream:#FAF4EC; --cream-deep:#F3E9DA; --sand:#EFE3D3;
  --green:#2E7A67; --green-soft:rgba(46,122,103,.12);
  --spark:#E8A23D; --spark-soft:rgba(232,162,61,.16);
  --card:#FFFFFF; --muted:#7A6A5C; --faint:#A89A8C;
  --hair:#E7DAC8; --hair-strong:#D8C7B0;
  --display:'Bricolage Grotesque',Georgia,serif;
  --body:'Hanken Grotesk',-apple-system,sans-serif;
  --maxw:1140px; --r:0; --shadow:0 24px 60px -28px rgba(80,40,20,.32);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--body);color:var(--ink);background:var(--cream);
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","cv01";overflow-x:hidden;
}
/* feines Papier-Korn als Atmosphäre */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative;z-index:1}
a{color:inherit}
img{max-width:100%}
h1,h2,h3{font-family:var(--display);font-weight:800;line-height:1.04;letter-spacing:-.02em;margin:0}
p{margin:0}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--terra)}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--spark);
  box-shadow:0 0 0 4px var(--spark-soft)}
.accent{color:var(--terra)}
.lead{font-size:clamp(18px,2.2vw,21px);color:var(--ink-soft);max-width:60ch;text-wrap:pretty}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--body);font-weight:700;
  font-size:15.5px;padding:13px 24px;border-radius:0;background:var(--terra);color:var(--cream);
  text-decoration:none;border:none;cursor:pointer;transition:transform .18s,box-shadow .18s,background .18s;
  box-shadow:0 10px 24px -10px rgba(199,86,57,.6)}
.btn:hover{background:var(--terra-deep);transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(199,86,57,.7)}
.btn svg{width:17px;height:17px}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--hair-strong);box-shadow:none}
.btn-ghost:hover{background:rgba(42,33,28,.04);border-color:var(--ink);transform:translateY(-2px)}
.btn-lg{font-size:16.5px;padding:16px 30px}
.btn-sm{font-size:14px;padding:9px 16px}

/* ---------- Brand mark ---------- */
.mark{border-radius:0;background:var(--terra);position:relative;display:inline-flex;
  align-items:center;justify-content:center;flex-shrink:0;width:34px;height:34px}
.mark .a{font-family:var(--display);font-weight:800;color:var(--cream);font-size:20px;line-height:1}
.mark .dot{position:absolute;top:6px;right:6px;width:6px;height:6px;border-radius:50%;background:var(--spark)}

/* ---------- Nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(250,244,236,.82);
  backdrop-filter:saturate(1.4) blur(14px);border-bottom:1px solid var(--hair)}
.nav-inner{display:flex;align-items:center;gap:20px;height:68px}
.nav-brand{display:flex;align-items:center;gap:10px;text-decoration:none;font-family:var(--display);
  font-weight:800;font-size:19px;color:var(--ink)}
.nav-links{display:flex;gap:26px;margin-left:14px}
.nav-links a{font-size:14.5px;font-weight:600;color:var(--muted);text-decoration:none;position:relative}
.nav-links a:hover{color:var(--ink)}
.nav-links a.on{color:var(--terra)}
.nav-cta{margin-left:auto}
.nav-toggle{display:none}
.nav-burger{display:none;align-items:center;justify-content:center;width:44px;height:44px;margin-left:auto;
  border:1px solid var(--hair-strong);border-radius:0;background:var(--card);cursor:pointer;flex:none}
.nav-burger span,.nav-burger span::before,.nav-burger span::after{display:block;width:19px;height:2px;
  background:var(--ink);border-radius:2px;content:""}
.nav-burger span{position:relative}
.nav-burger span::before{position:absolute;top:-6px}
.nav-burger span::after{position:absolute;top:6px}
.nav-menu-cta{display:none}

/* ---------- Hero ---------- */
.hero{padding:78px 0 56px;position:relative}
.hero h1{font-size:clamp(40px,6.4vw,76px);max-width:14ch}
.hero .lead{margin-top:22px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.hero-meta{display:flex;gap:22px;flex-wrap:wrap;margin-top:30px;color:var(--muted);font-size:14.5px}
.hero-meta span{display:inline-flex;align-items:center;gap:7px}
.hero-meta b{color:var(--ink)}
.tick{color:var(--green);font-weight:800}

/* ---------- Sections ---------- */
.sec{padding:72px 0}
.sec-tight{padding:52px 0}
.sec-head{max-width:62ch}
.sec h2{font-size:clamp(28px,4vw,44px);margin-top:12px}
.sec .lead{margin-top:16px}
.band{background:var(--ink);color:var(--cream)}
.band .lead{color:rgba(250,244,236,.78)}
.band .eyebrow{color:var(--spark)}
.soft{background:var(--cream-deep)}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:20px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--card);border:1px solid var(--hair);border-radius:var(--r);padding:26px;
  transition:transform .2s,box-shadow .2s,border-color .2s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--hair-strong)}
.card h3{font-size:20px;margin-bottom:8px}
.card p{color:var(--ink-soft);font-size:15.5px}
.ico{width:46px;height:46px;border-radius:0;background:var(--terra-soft);color:var(--terra);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.ico svg{width:23px;height:23px}

/* ---------- Steps ---------- */
.steps{counter-reset:s;display:grid;gap:18px}
.step{display:flex;gap:18px;align-items:flex-start;background:var(--card);border:1px solid var(--hair);
  border-radius:var(--r);padding:22px 24px}
.step::before{counter-increment:s;content:counter(s);font-family:var(--display);font-weight:800;
  font-size:20px;width:42px;height:42px;flex:none;border-radius:0;background:var(--ink);color:var(--cream);
  display:flex;align-items:center;justify-content:center}
.step h3{font-size:18px;margin-bottom:4px}
.step p{color:var(--ink-soft);font-size:15px}

/* ---------- Feature list ---------- */
.flist{list-style:none;padding:0;margin:0;display:grid;gap:13px}
.flist li{display:flex;gap:12px;align-items:flex-start;font-size:16px}
.flist li::before{content:"";flex:none;width:22px;height:22px;border-radius:50%;margin-top:1px;
  background:var(--green-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232E7A67' stroke-width='3'%3E%3Cpath d='M5 13l4 4L19 7'/%3E%3C/svg%3E") center/13px no-repeat}

/* ---------- Pill / badge ---------- */
.pill{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:700;
  padding:6px 13px;border-radius:0;background:var(--card);border:1px solid var(--hair);color:var(--muted)}
.pill-on{background:var(--terra);color:var(--cream);border-color:var(--terra)}
.pill-soft{background:var(--green-soft);color:var(--green);border:none}
.pill-lock{background:var(--sand);color:var(--faint);border:none}

/* ---------- Package cards (overview) ---------- */
.pkg{position:relative;display:flex;flex-direction:column;background:var(--card);border:1px solid var(--hair);
  border-radius:var(--r);padding:28px;transition:transform .2s,box-shadow .2s,border-color .2s}
.pkg:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.pkg.feat{border-color:var(--terra);box-shadow:0 24px 60px -30px rgba(199,86,57,.45)}
.pkg .tag{position:absolute;top:-12px;left:24px;background:var(--terra);color:var(--cream);
  font-size:11.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 12px;border-radius:0}
.pkg .pk-name{font-family:var(--display);font-weight:800;font-size:23px}
.pkg .pk-for{color:var(--muted);font-size:14px;margin-top:4px}
.pkg .flist{margin:18px 0 22px}
.pkg .flist li{font-size:14.5px}
.pkg .pk-cta{margin-top:auto}
.pkg .pk-cta .btn{width:100%;justify-content:center}

/* ---------- FAQ ---------- */
.faq details{border-bottom:1px solid var(--hair);padding:6px 0}
.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:16px;
  align-items:center;padding:18px 2px;font-family:var(--display);font-weight:700;font-size:18px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:24px;color:var(--terra);transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .fa-body{padding:0 2px 18px;color:var(--ink-soft);font-size:16px;max-width:72ch}

/* ---------- CTA band ---------- */
.cta-band{text-align:center;padding:84px 0}
.cta-band h2{font-size:clamp(30px,5vw,52px);max-width:18ch;margin:0 auto}
.cta-band .lead{margin:18px auto 0}
.cta-band .hero-ctas{justify-content:center}

/* ---------- App mock (hero visual) ---------- */
.mock{background:var(--card);border:1px solid var(--hair-strong);border-radius:0;overflow:hidden;
  box-shadow:var(--shadow)}
.mock-bar{display:flex;align-items:center;gap:7px;padding:11px 14px;border-bottom:1px solid var(--hair);background:var(--cream)}
.mock-bar i{width:10px;height:10px;border-radius:50%;background:var(--hair-strong)}
.mock-bar .url{margin-left:8px;font-size:12px;color:var(--faint)}
.mock-body{padding:20px}
.mrow{display:flex;align-items:center;gap:12px;padding:13px 14px;border:1px solid var(--hair);
  border-radius:0;margin-bottom:10px;background:var(--cream)}
.mrow .mt{font-weight:600;font-size:14px}
.mrow .ms{margin-left:auto;font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:0}
.ms-wait{background:var(--spark-soft);color:#9a6a18}
.ms-live{background:var(--green-soft);color:var(--green)}
.mrow .mok{width:26px;height:26px;border-radius:0;background:var(--terra);color:#fff;display:flex;
  align-items:center;justify-content:center;font-weight:800;font-family:var(--display)}

/* ---------- Footer ---------- */
.footer{padding:44px 0;border-top:1px solid var(--hair)}
.footer-inner{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.f-brand{display:flex;align-items:center;gap:9px;font-family:var(--display);font-weight:800;font-size:18px}
.f-links{display:flex;gap:20px;flex-wrap:wrap}
.f-links a{font-size:14px;color:var(--muted);text-decoration:none}
.f-links a:hover{color:var(--ink)}
.f-meta{margin-left:auto;font-size:13px;color:var(--faint)}
.f-meta a{color:var(--muted);text-decoration:none}

/* ---------- Reveal animation ---------- */
.rv{opacity:0;transform:translateY(18px);animation:rv .7s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes rv{to{opacity:1;transform:none}}
.d1{animation-delay:.06s}.d2{animation-delay:.14s}.d3{animation-delay:.22s}
.d4{animation-delay:.3s}.d5{animation-delay:.38s}.d6{animation-delay:.46s}
@media (prefers-reduced-motion:reduce){.rv{animation:none;opacity:1;transform:none}}

/* ---------- Responsive ---------- */
@media (max-width:920px){
  .g-3,.g-4{grid-template-columns:repeat(2,1fr)}
  .hero-split{grid-template-columns:1fr!important}
  .hero-visual-col{display:none}
}
@media (max-width:680px){
  body{font-size:16px}
  .wrap{padding:0 20px}
  /* Mobiles Menü (Hamburger, CSS-only) */
  .nav-burger{display:flex}
  .nav-cta{display:none}
  .nav-links{position:absolute;top:67px;left:0;right:0;margin:0;display:none;flex-direction:column;gap:0;
    padding:6px 20px 18px;background:var(--cream);border-bottom:1px solid var(--hair);
    box-shadow:0 20px 42px -22px rgba(80,40,20,.42)}
  .nav-toggle:checked ~ .nav-links{display:flex}
  .nav-links a:not(.nav-menu-cta){padding:15px 2px;font-size:16.5px;color:var(--ink);
    border-bottom:1px solid var(--hair)}
  .nav-menu-cta{display:flex!important;justify-content:center;margin-top:14px}
  .g-2,.g-3,.g-4{grid-template-columns:1fr}
  .sec{padding:52px 0}
  .hero{padding:46px 0 36px}
  .hero h1{font-size:clamp(34px,8.6vw,46px)}
  .cta-band h2{font-size:clamp(27px,7.6vw,36px)}
  .lead{font-size:16.5px}
  .btn-lg{padding:15px 26px}
  .hero-ctas .btn{flex:1 1 auto;justify-content:center}
}
