/* =========================================================
   PerPost.app – Homepage (DE)
   Plain CSS, no framework, no build step.
   ========================================================= */

:root{
  --ink:#313131;
  --ink-soft:#4a4a4a;
  --green:#1ca36f;
  --green-d:#15875c;
  --green-dark:#0f5740;
  --footer:#10362a;
  --yellow:#f5c84f;
  --yellow-d:#e9b734;
  --muted:#66738d;
  --bg:#ffffff;
  --bg-soft:#f4f7f6;
  --bg-mint:#e9f6f0;
  --line:#e7ece9;
  --shadow-sm:0 2px 10px rgba(20,40,30,.06);
  --shadow:0 14px 40px rgba(20,40,30,.10);
  --shadow-lg:0 30px 70px rgba(20,40,30,.16);
  --radius:18px;
  --radius-lg:26px;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{overflow-x:hidden}
body{
  margin:0;
  font-family:'Montserrat',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Josefin Sans',sans-serif;font-weight:700;line-height:1.12;margin:0;color:var(--ink);overflow-wrap:break-word}
p{margin:0;overflow-wrap:break-word}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:88px 0}
.section--soft{background:var(--bg-soft)}
.section--mint{background:var(--bg-mint)}
.eyebrow{
  font-family:'Josefin Sans',sans-serif;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;font-size:.78rem;color:var(--green);
}
.sec-head{text-align:center;max-width:720px;margin:0 auto 52px}
.sec-head h2{font-size:clamp(1.8rem,3.4vw,2.7rem)}
.sec-head p{color:var(--muted);margin-top:14px;font-size:1.05rem}
.text-green{color:var(--green)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;cursor:pointer;border:0;
  font-family:'Montserrat',sans-serif;font-weight:600;font-size:.98rem;
  padding:14px 26px;border-radius:999px;transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s;
}
.btn:hover{transform:translateY(-2px)}
.btn--green{background:var(--green);color:#fff;box-shadow:0 10px 24px rgba(28,163,111,.28)}
.btn--green:hover{background:var(--green-d)}
.btn--yellow{background:var(--yellow);color:var(--ink);box-shadow:0 10px 24px rgba(233,183,52,.32)}
.btn--yellow:hover{background:var(--yellow-d)}
.btn--ink{background:var(--ink);color:#fff}
.btn--ghost{background:transparent;color:var(--green);border:2px solid var(--green);padding:12px 24px}
.btn--ghost:hover{background:var(--green);color:#fff}

/* App store badges */
.stores{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.store-badge img{height:52px;width:auto;filter:drop-shadow(0 6px 14px rgba(20,40,30,.12));transition:transform .2s var(--ease)}
.store-badge:hover img{transform:translateY(-2px) scale(1.02)}

/* =========================================================
   HEADER
   ========================================================= */
.site-header{
  position:sticky;top:0;z-index:60;background:rgba(255,255,255,.86);
  backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;gap:24px;height:74px}
.brand img{height:38px}
.nav-links{display:flex;gap:22px;margin:0 auto;list-style:none;padding:0}
.nav-links a{font-size:.92rem;font-weight:500;color:var(--ink-soft);position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--green);transition:width .25s var(--ease)}
.nav-links a:hover{color:var(--green)}
.nav-links a:hover::after{width:100%}
.nav-actions{display:flex;align-items:center;gap:12px}
.lang{font-size:.85rem;font-weight:600;color:var(--muted);padding:6px 8px;border-radius:8px}
.lang:hover{background:var(--bg-soft)}
.pill{display:inline-flex;align-items:center;gap:7px;font-size:.84rem;font-weight:600;padding:9px 16px;border-radius:999px;white-space:nowrap}
.pill--green{background:var(--green);color:#fff}
.pill--yellow{background:var(--yellow);color:var(--ink)}
.pill:hover{transform:translateY(-1px)}
.pill svg{width:15px;height:15px;fill:currentColor}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.25s var(--ease)}

/* =========================================================
   HERO  (new – perpost.fr style, German)
   ========================================================= */
.hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(120% 120% at 85% -10%, rgba(28,163,111,.14), transparent 55%),
    radial-gradient(90% 90% at 10% 0%, rgba(245,200,79,.16), transparent 50%),
    linear-gradient(180deg,#f3faf6 0%, #ffffff 70%);
}
.hero::after{
  content:"";position:absolute;right:-6%;top:-12%;width:62%;height:120%;
  background:url("assets/app_fon.webp") right top/contain no-repeat;
  opacity:.28;pointer-events:none;mix-blend-mode:multiply;
}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:78px 0 88px}
.hero-badge{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);
  box-shadow:var(--shadow-sm);padding:8px 16px;border-radius:999px;font-size:.82rem;font-weight:600;color:var(--green-dark);margin-bottom:22px}
.hero-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(28,163,111,.18)}
.hero h1{font-size:clamp(2.5rem,5.4vw,4rem);letter-spacing:-.5px}
.hero h1 .ln{display:block}
.hero h1 .accent{color:var(--green)}
.hero .lede{color:var(--ink-soft);font-size:1.12rem;max-width:540px;margin:24px 0 32px}
.hero-cta{display:flex;flex-direction:column;gap:16px;align-items:flex-start}
.hero-trust{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:.86rem;margin-top:4px}
.hero-trust .stars{color:var(--yellow-d);letter-spacing:1px}

/* hero phone */
.hero-visual{position:relative;display:flex;justify-content:center}
.hero-phone{
  width:min(330px,80%);border-radius:38px;box-shadow:var(--shadow-lg);
  animation:floaty 6s ease-in-out infinite;
}
.hero-envelope{
  position:absolute;top:-26px;right:6%;width:118px;transform:rotate(-8deg);
  filter:drop-shadow(0 14px 22px rgba(20,40,30,.22));animation:floaty 5s ease-in-out infinite .4s;
}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

/* =========================================================
   SITUATIONS  (new – perpost.fr 6-card grid, German)
   ========================================================= */
.sit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.sit-card{
  border-radius:var(--radius);padding:30px 26px;background:#fff;border:1.5px solid var(--line);
  box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease);
  display:flex;flex-direction:column;gap:14px;min-height:178px;
}
.sit-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.sit-card .ic{width:46px;height:46px;display:flex;align-items:center;justify-content:center;border-radius:13px;background:var(--bg-mint)}
.sit-card .ic svg{width:24px;height:24px;stroke:var(--green);fill:none;stroke-width:1.9}
.sit-card h4{font-size:1.18rem;color:var(--green-dark)}
.sit-card.is-yellow{background:var(--yellow);border-color:var(--yellow)}
.sit-card.is-yellow .ic{background:rgba(255,255,255,.45)}
.sit-card.is-yellow .ic svg{stroke:var(--ink)}
.sit-card.is-yellow h4{color:var(--ink)}
.sit-foot{text-align:center;max-width:680px;margin:46px auto 0}
.sit-foot p{color:var(--muted)}
.sit-foot .stores{justify-content:center;margin-top:24px}
.sit-foot .btn{margin-top:6px}

/* =========================================================
   RADIO band
   ========================================================= */
.radio-band{display:flex;align-items:center;gap:40px;justify-content:center;flex-wrap:wrap;text-align:left}
.radio-band img{width:150px;border-radius:16px;box-shadow:var(--shadow-sm);background:#fff;padding:10px}
.radio-band .rb-text{max-width:560px}
.radio-band h2{font-size:clamp(1.6rem,3vw,2.2rem)}
.radio-band h2 .head{color:var(--green)}
.radio-band p{color:var(--muted);margin-top:12px}

/* =========================================================
   BEHÖRDEN dark band
   ========================================================= */
.gov{
  position:relative;color:#fff;text-align:center;overflow:hidden;
  background:linear-gradient(125deg,#0f5740 0%, #10362a 60%, #0b2a20 100%);
}
.gov::before{
  content:"";position:absolute;inset:0;opacity:.16;
  background:radial-gradient(60% 80% at 80% 20%,rgba(245,200,79,.5),transparent 60%);
}
.gov .wrap{position:relative;z-index:2;max-width:760px}
.gov h2{color:#fff;font-size:clamp(1.8rem,3.6vw,2.7rem)}
.gov p{color:rgba(255,255,255,.82);font-size:1.1rem;margin:18px 0 30px}

/* =========================================================
   WARUM ANDERS – compare cards
   ========================================================= */
.cmp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cmp-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.cmp-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.cmp-card .ic{width:54px;height:54px;border-radius:15px;background:var(--bg-mint);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.cmp-card .ic svg{width:28px;height:28px;stroke:var(--green);fill:none;stroke-width:1.8}
.cmp-card h4{font-size:1.25rem;margin-bottom:14px}
.cmp-line{display:flex;gap:10px;align-items:flex-start;margin-bottom:10px;font-size:.95rem;color:var(--ink-soft)}
.cmp-line .mk{flex:none;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem;color:#fff;margin-top:3px}
.cmp-line.ok .mk{background:var(--green)}
.cmp-line.no .mk{background:#d96b6b}
.cmp-line.no{color:var(--muted)}

/* =========================================================
   STEPS (3 Schritte)
   ========================================================= */
.steps-wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:56px;align-items:center}
.steps-visual{position:relative;display:flex;justify-content:center}
.steps-visual img{width:min(360px,90%)}
.steps-list{display:flex;flex-direction:column;gap:14px}
.step{display:flex;gap:20px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px 26px;box-shadow:var(--shadow-sm);transition:transform .2s var(--ease)}
.step:hover{transform:translateX(4px)}
.step .num{flex:none;width:44px;height:44px;border-radius:50%;background:var(--yellow);color:var(--ink);font-family:'Josefin Sans';font-weight:700;font-size:1.25rem;display:flex;align-items:center;justify-content:center}
.step h4{font-size:1.2rem;margin-bottom:6px}
.step p{color:var(--muted);font-size:.96rem}
.steps-list .stores{margin-top:10px}

/* =========================================================
   PARTNERS
   ========================================================= */
.partners{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.partner{background:#fff;border:1px solid var(--line);border-radius:var(--radius);height:118px;display:flex;align-items:center;justify-content:center;padding:24px;box-shadow:var(--shadow-sm);transition:transform .2s var(--ease)}
.partner:hover{transform:translateY(-4px)}
.partner img{max-height:46px;width:auto;opacity:.92}

/* =========================================================
   TESTIMONIALS
   ========================================================= */
.tst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tst-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px}
.tst-card .stars{color:var(--yellow-d);letter-spacing:2px}
.tst-card .quote{color:var(--ink-soft);font-size:.98rem}
.tst-meta{display:flex;align-items:center;gap:12px;margin-top:auto}
.tst-meta .av{width:42px;height:42px;border-radius:50%;background:var(--green);color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:'Josefin Sans'}
.tst-meta b{display:block;font-size:.95rem}
.tst-meta span{color:var(--muted);font-size:.85rem}

/* =========================================================
   CTA band (Startklar)
   ========================================================= */
.cta-band{background:linear-gradient(120deg,var(--yellow) 0%, #f7d36e 100%);border-radius:var(--radius-lg);padding:54px 48px;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;box-shadow:var(--shadow)}
.cta-band h2{font-size:clamp(1.8rem,3.4vw,2.5rem);max-width:560px}
.cta-band p{color:#5a4a18;margin-top:12px;max-width:520px;font-weight:500}
.cta-band .stores{margin-top:22px}

/* =========================================================
   PERSONAS
   ========================================================= */
.persona-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.persona{display:flex;gap:22px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.persona:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.persona .pic{flex:none;width:84px;height:84px;border-radius:50%;border:3px solid var(--yellow);overflow:hidden;background:var(--bg-mint);display:flex;align-items:center;justify-content:center}
.persona .pic img{width:100%;height:100%;object-fit:cover}
.persona .pic svg{width:38px;height:38px;stroke:var(--green);fill:none;stroke-width:1.7}
.persona h4{font-size:1.18rem;margin-bottom:10px;color:var(--green-dark)}
.persona .prob{color:var(--ink-soft);font-size:.93rem;margin-bottom:10px}
.persona .sol{font-size:.93rem;color:var(--ink)}
.persona .sol b{color:var(--green)}

/* =========================================================
   FEATURES grid
   ========================================================= */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px 26px;box-shadow:var(--shadow-sm);transition:transform .2s var(--ease)}
.feat:hover{transform:translateY(-4px)}
.feat .ic{width:48px;height:48px;border-radius:13px;background:var(--bg-mint);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.feat .ic svg{width:25px;height:25px;stroke:var(--green);fill:none;stroke-width:1.8}
.feat h4{font-size:1.1rem;margin-bottom:8px}
.feat p{color:var(--muted);font-size:.92rem}

/* =========================================================
   PRICING
   ========================================================= */
.price-intro{text-align:center;max-width:640px;margin:0 auto 44px;color:var(--muted)}
.price-intro .big{color:var(--ink);font-weight:700;font-size:1.1rem}
.price-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;max-width:920px;margin:0 auto}
.price-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:34px 32px;box-shadow:var(--shadow-sm)}
.price-card h3{font-size:1.4rem;margin-bottom:22px;display:flex;align-items:center;gap:10px}
.price-row{display:flex;justify-content:space-between;align-items:flex-start;padding:18px 0;border-top:1px solid var(--line);gap:16px}
.price-row:first-of-type{border-top:0}
.price-row .lbl b{display:block;font-size:1.02rem;margin-bottom:3px}
.price-row .lbl span{color:var(--muted);font-size:.84rem}
.price-row .amt{font-family:'Josefin Sans';font-weight:700;font-size:1.5rem;color:var(--green);white-space:nowrap}
.price-note{text-align:center;color:var(--muted);font-size:.86rem;margin:30px auto 0;max-width:680px}

/* =========================================================
   STATS
   ========================================================= */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat .n{font-family:'Josefin Sans';font-weight:700;font-size:clamp(2rem,4vw,2.8rem);color:var(--green)}
.stat .l{color:var(--muted);font-weight:600;margin-top:6px;font-family:'Josefin Sans'}

/* =========================================================
   FAQ
   ========================================================= */
.faq{max-width:840px;margin:0 auto}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:14px;margin-bottom:14px;overflow:hidden;box-shadow:var(--shadow-sm)}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:22px 24px;display:flex;justify-content:space-between;align-items:center;gap:18px;font-family:'Josefin Sans';font-weight:700;font-size:1.08rem;color:var(--ink)}
.faq-q .chev{flex:none;width:26px;height:26px;border-radius:50%;background:var(--bg-mint);display:flex;align-items:center;justify-content:center;transition:transform .25s var(--ease)}
.faq-q .chev svg{width:14px;height:14px;stroke:var(--green);stroke-width:2.4;fill:none}
.faq-item.open .chev{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .32s var(--ease)}
.faq-a p{padding:0 24px 22px;color:var(--muted);font-size:.97rem}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{background:var(--footer);color:rgba(255,255,255,.78);padding:60px 0 30px}
.foot-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;align-items:flex-start}
.foot-brand img{height:44px;margin-bottom:16px;filter:brightness(0) invert(1)}
.foot-brand p{max-width:320px;font-size:.92rem}
.foot-links{display:flex;gap:60px;flex-wrap:wrap}
.foot-col h5{font-family:'Josefin Sans';color:#fff;font-size:1rem;margin:0 0 14px}
.foot-col a{display:block;font-size:.9rem;margin-bottom:9px;color:rgba(255,255,255,.72)}
.foot-col a:hover{color:var(--yellow)}
.foot-stores{display:flex;gap:12px;margin-top:6px}
.foot-stores img{height:44px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:44px;padding-top:24px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.84rem;color:rgba(255,255,255,.6)}
.foot-bottom a:hover{color:var(--yellow)}

/* =========================================================
   Reveal animation
   ========================================================= */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:980px){
  .nav-links{display:none}
  .nav-actions .pill{display:none}
  .burger{display:flex}
  .nav{height:64px}
  .hero-inner{grid-template-columns:1fr;gap:30px;padding:48px 0 60px;text-align:center}
  .hero .lede{margin-left:auto;margin-right:auto}
  .hero-cta{align-items:center}
  .hero-trust{justify-content:center}
  .hero::after{display:none}
  .hero-visual{order:-1}
  .steps-wrap{grid-template-columns:1fr;gap:36px}
  .steps-visual{order:-1}
  .partners{grid-template-columns:repeat(2,1fr)}
  .sit-grid,.cmp-grid,.tst-grid,.feat-grid{grid-template-columns:repeat(2,1fr)}
  .persona-grid,.price-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:36px}
  .section{padding:64px 0}

  /* mobile nav drawer */
  .nav-links.open{
    display:flex;flex-direction:column;position:absolute;top:64px;left:0;right:0;
    background:#fff;padding:18px 22px;gap:6px;border-bottom:1px solid var(--line);box-shadow:var(--shadow);margin:0;
  }
  .nav-links.open a{padding:12px 4px;border-bottom:1px solid var(--line)}
  .nav-links.open a:last-child{border-bottom:0}
}
@media (max-width:620px){
  .sit-grid,.cmp-grid,.tst-grid,.feat-grid{grid-template-columns:1fr}
  .hero h1{font-size:2.3rem}
  .cta-band{padding:36px 26px;text-align:center;justify-content:center}
  .cta-band .stores{justify-content:center}
  .radio-band{text-align:center}
  .price-card{padding:26px 22px}
  .persona{flex-direction:column;text-align:center;align-items:center}
  .store-badge img{height:46px}
}
