/* ─── HERO ────────────────────────── */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:linear-gradient(105deg,var(--dark) 0%,#3a1820 40%,rgba(40,32,26,.85) 100%)}
.hero-img{position:absolute;inset:0;object-fit:cover;width:100%;height:100%;opacity:.35;object-position:center 30%}
.hero-pattern{position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 48px,rgba(255,255,255,.025) 48px,rgba(255,255,255,.025) 49px),repeating-linear-gradient(90deg,transparent,transparent 48px,rgba(255,255,255,.025) 48px,rgba(255,255,255,.025) 49px)}
.hero-inner{max-width:1260px;margin:0 auto;padding:6rem 5% 5rem;position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
@media(max-width:900px){.hero-inner{grid-template-columns:1fr;padding:4rem 5%}}
.hero-eyebrow{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.45);display:flex;align-items:center;gap:10px;margin-bottom:1.2rem}
.hero-eyebrow::before{content:"";width:24px;height:1px;background:rgba(255,255,255,.3)}
.hero h1{font-family:var(--serif);font-size:clamp(2.8rem,5vw,4.2rem);font-weight:300;color:#fff;line-height:1.08;margin-bottom:1.4rem}
.hero h1 em{font-style:italic;color:rgba(255,255,255,.5)}
.hero-sub{font-size:1rem;color:rgba(255,255,255,.6);line-height:1.75;max-width:480px;margin-bottom:2.5rem}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}
.btn-primary{padding:.9rem 2.2rem;background:var(--red);color:#fff;border:none;border-radius:2px;font-family:var(--sans);font-size:.78rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:background .2s}
.btn-primary:hover{background:var(--red2)}
.btn-outline{padding:.9rem 2rem;background:transparent;color:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.3);border-radius:2px;font-family:var(--sans);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px;transition:all .2s}
.btn-outline:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.55);color:#fff}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);border-radius:2px;overflow:hidden}
.hero-stat{padding:1.4rem 1.2rem;background:rgba(0,0,0,.25);text-align:center}
.hero-stat-num{font-family:var(--serif);font-size:2.4rem;font-weight:300;color:#fff;display:block;line-height:1;margin-bottom:.3rem}
.hero-stat-lbl{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4)}

/* ─── CLAIM STRIPE ────────────────── */
.claim-stripe{background:var(--red2);padding:1.4rem 5%}
.claim-inner{max-width:1260px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:3rem;flex-wrap:wrap}
.claim-item{display:flex;align-items:center;gap:10px;font-size:.8rem;color:rgba(255,255,255,.7);white-space:nowrap}
.claim-icon{font-size:1rem;flex-shrink:0}

/* ─── SECTION SHARED ──────────────── */
section{padding:5rem 5%}
.sec-inner{max-width:1260px;margin:0 auto}
.sec-eyebrow{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--red);display:flex;align-items:center;gap:8px;margin-bottom:.8rem}
.sec-eyebrow::before{content:"";width:16px;height:1px;background:var(--red)}
.sec-title{font-family:var(--serif);font-size:clamp(2rem,3.5vw,2.8rem);font-weight:300;color:var(--dark);line-height:1.15;margin-bottom:1.2rem}
.sec-title em{font-style:italic;color:var(--red)}
.sec-lead{font-size:.95rem;color:var(--muted);line-height:1.8;max-width:640px}

/* ─── WHY SECTION ─────────────────── */
.why-section{background:#fff}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;margin-top:3.5rem}
@media(max-width:860px){.why-grid{grid-template-columns:1fr}}
.why-img-wrap{position:relative}
.why-img-wrap img{width:100%;height:480px;object-fit:cover;object-position:center top;border-radius:2px}
.why-img-badge{position:absolute;bottom:-20px;right:-20px;background:var(--red);color:#fff;padding:1.5rem;border-radius:2px;text-align:center;min-width:140px;box-shadow:var(--shadow)}
.why-img-badge strong{font-family:var(--serif);font-size:2.2rem;font-weight:300;display:block;line-height:1}
.why-img-badge span{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.7);display:block;margin-top:4px}
.benefit-list{list-style:none;margin-top:2rem}
.benefit-list li{display:flex;align-items:flex-start;gap:14px;padding:1.1rem 0;border-bottom:1px solid var(--bdr)}
.benefit-list li:last-child{border-bottom:none}
.benefit-num{font-family:var(--serif);font-size:1.5rem;font-weight:300;color:rgba(109,26,52,.2);width:32px;flex-shrink:0;line-height:1.2}
.benefit-content h3{font-family:var(--serif);font-size:1.05rem;font-weight:400;color:var(--dark);margin-bottom:.2rem}
.benefit-content p{font-size:.83rem;color:var(--muted);line-height:1.6}

/* ─── PILLARS ─────────────────────── */
.pillars-section{background:var(--cream)}
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
@media(max-width:900px){.pillars-grid{grid-template-columns:1fr}}
.pillar-card{background:#fff;border:1px solid var(--bdr);border-radius:2px;overflow:hidden;position:relative;transition:transform .2s,box-shadow .2s}
.pillar-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.pillar-icon-wrap{padding:2rem 2rem 0;font-size:2.2rem;line-height:1}
.pillar-body{padding:1.3rem 2rem 2rem}
.pillar-body h3{font-family:var(--serif);font-size:1.25rem;font-weight:400;color:var(--dark);margin-bottom:.6rem}
.pillar-body p{font-size:.83rem;color:var(--muted);line-height:1.65}
.pillar-tag{display:inline-block;margin-top:1rem;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--red);padding:3px 10px;border:1px solid rgba(109,26,52,.2);border-radius:1px}
.pillar-accent{position:absolute;top:0;left:0;right:0;height:3px;background:var(--red)}

/* ─── METHODS ─────────────────────── */
.methods-section{background:var(--navy);position:relative;overflow:hidden}
.methods-section::before{content:"Fasten";font-family:var(--serif);font-size:22vw;font-weight:600;color:rgba(255,255,255,.02);position:absolute;right:-2%;bottom:-4%;pointer-events:none;line-height:1;user-select:none}
.methods-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.07);margin-top:3rem}
@media(max-width:820px){.methods-grid{grid-template-columns:1fr}}
.method-card{background:rgba(255,255,255,.03);padding:2.5rem 2rem;transition:background .2s;position:relative}
.method-card:hover{background:rgba(255,255,255,.07)}
.method-card::before{content:attr(data-num);font-family:var(--serif);font-size:5rem;font-weight:300;color:rgba(255,255,255,.05);position:absolute;top:1rem;right:1.5rem;line-height:1}
.method-tag{font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;padding:3px 10px;border-radius:1px;display:inline-block;margin-bottom:1rem}
.tag-red{background:rgba(109,26,52,.3);color:rgba(255,180,180,.8);border:1px solid rgba(109,26,52,.4)}
.tag-sage{background:rgba(90,122,58,.2);color:rgba(160,200,120,.8);border:1px solid rgba(90,122,58,.3)}
.tag-amber{background:rgba(122,92,58,.2);color:rgba(200,160,100,.8);border:1px solid rgba(122,92,58,.3)}
.method-card h3{font-family:var(--serif);font-size:1.5rem;font-weight:300;color:#fff;margin-bottom:.5rem}
.method-card p{font-size:.82rem;color:rgba(255,255,255,.45);line-height:1.7}
.method-kcal{font-size:.72rem;color:rgba(255,255,255,.3);margin-top:1rem;padding-top:.8rem;border-top:1px solid rgba(255,255,255,.06)}

/* ─── PROCESS ─────────────────────── */
.process-section{background:#fff}
.process-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-top:3rem;position:relative}
@media(max-width:900px){.process-steps{grid-template-columns:1fr;gap:0}}
.process-steps::before{content:"";position:absolute;top:28px;left:10%;right:10%;height:1px;background:var(--bdr);z-index:0}
@media(max-width:900px){.process-steps::before{display:none}}
.process-step{text-align:center;padding:0 1rem;position:relative;z-index:1}
.process-num{width:56px;height:56px;border-radius:50%;background:var(--cream2);border:2px solid var(--bdr);display:flex;align-items:center;justify-content:center;margin:0 auto 1.2rem;font-family:var(--serif);font-size:1.1rem;color:var(--dark);font-weight:300;position:relative;transition:all .2s}
.process-step:hover .process-num{background:var(--red);border-color:var(--red);color:#fff}
.process-step h4{font-family:var(--serif);font-size:.98rem;font-weight:400;color:var(--dark);margin-bottom:.4rem;line-height:1.3}
.process-step p{font-size:.76rem;color:var(--muted);line-height:1.6}

/* ─── TESTIMONIALS ────────────────── */
.testi-section{background:var(--cream2)}
.testi-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.5rem;margin-top:3rem}
@media(max-width:860px){.testi-grid{grid-template-columns:1fr}}
.testi-card{background:#fff;border:1px solid var(--bdr);border-radius:2px;padding:2rem;position:relative}
.testi-card::before{content:"\201C";font-family:var(--serif);font-size:4rem;color:rgba(109,26,52,.12);position:absolute;top:.5rem;right:1.5rem;line-height:1}
.testi-text{font-family:var(--serif);font-size:1rem;font-style:italic;color:var(--dark);line-height:1.7;margin-bottom:1.2rem}
.testi-author{font-size:.73rem;color:var(--muted);letter-spacing:.06em}
.testi-author strong{color:var(--dark);font-weight:400;display:block;margin-bottom:1px}
.testi-stars{color:var(--red);font-size:.75rem;margin-bottom:.5rem;letter-spacing:1px}

/* ─── PACKAGE ─────────────────────── */
.package-section{background:var(--navy);color:#fff}
.package-inner{max-width:1260px;margin:0 auto}
.package-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;margin-top:3rem}
@media(max-width:860px){.package-grid{grid-template-columns:1fr}}
.package-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:2px;overflow:hidden}
.package-card-header{background:var(--red);padding:1.5rem 2rem;display:flex;align-items:center;justify-content:space-between}
.package-card-header h3{font-family:var(--serif);font-size:1.5rem;font-weight:300;color:#fff}
.package-card-header .price{font-family:var(--serif);font-size:1.2rem;font-weight:300;color:rgba(255,255,255,.75)}
.package-card-body{padding:2rem}
.inc-list{list-style:none}
.inc-list li{display:flex;align-items:flex-start;gap:10px;padding:.55rem 0;border-bottom:1px solid rgba(255,255,255,.06);font-size:.83rem;color:rgba(255,255,255,.55)}
.inc-list li:last-child{border-bottom:none}
.inc-tick{width:18px;height:18px;border-radius:50%;background:rgba(90,122,58,.15);border:1px solid rgba(90,122,58,.3);display:flex;align-items:center;justify-content:center;font-size:.6rem;flex-shrink:0;color:#9cc975;margin-top:1px}
.package-note{font-size:.75rem;color:rgba(255,255,255,.3);line-height:1.65;margin-top:1.5rem;padding:.9rem;background:rgba(255,255,255,.03);border-radius:2px;border-left:3px solid rgba(109,26,52,.4)}
.sidebar-info{display:flex;flex-direction:column;gap:1.5rem}
.info-box{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:2px;padding:1.5rem}
.info-box-ttl{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.3);display:flex;align-items:center;gap:7px;margin-bottom:1rem}
.info-box-ttl::before{content:"";width:12px;height:1px;background:rgba(255,255,255,.3)}
.info-box p{font-size:.83rem;color:rgba(255,255,255,.5);line-height:1.7}
.info-box a{color:rgba(255,180,130,.7);transition:color .15s}
.info-box a:hover{color:rgba(255,200,160,.9)}

/* ─── CTA ─────────────────────────── */
.cta-section{background:var(--red);padding:5rem 5%;text-align:center;position:relative;overflow:hidden}
.cta-section::before{content:"Jetzt anfragen";font-family:var(--serif);font-size:16vw;font-weight:600;color:rgba(255,255,255,.04);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;white-space:nowrap;user-select:none}
.cta-inner{max-width:700px;margin:0 auto;position:relative;z-index:1}
.cta-eyebrow{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:1rem}
.cta-inner h2{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);font-weight:300;color:#fff;margin-bottom:1rem;line-height:1.15}
.cta-inner p{font-size:.9rem;color:rgba(255,255,255,.6);line-height:1.75;margin-bottom:2.5rem}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn-cta-white{padding:1rem 2.5rem;background:#fff;color:var(--red);font-family:var(--sans);font-size:.78rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;border-radius:2px;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:background .2s}
.btn-cta-white:hover{background:var(--cream)}
.btn-cta-ghost{padding:1rem 2rem;background:transparent;color:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.3);border-radius:2px;font-family:var(--sans);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px;transition:all .2s}
.btn-cta-ghost:hover{background:rgba(255,255,255,.08);color:#fff}

/* ─── FOOTER ──────────────────────── */
footer{background:var(--dark);padding:3.5rem 5% 2rem}
.fgrid{max-width:1260px;margin:0 auto 2.5rem;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem}
@media(max-width:800px){.fgrid{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.fgrid{grid-template-columns:1fr}}
.fbrand p{font-size:.82rem;color:rgba(255,255,255,.4);line-height:1.75;max-width:280px;margin-top:.7rem}
.fcol h4{font-size:.63rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:1rem}
.fcol ul{list-style:none}
.fcol ul li{margin-bottom:.5rem}
.fcol ul li a{font-size:.83rem;color:rgba(255,255,255,.5);transition:color .15s}
.fcol ul li a:hover{color:#fff}
.fbot{max-width:1260px;margin:0 auto;padding-top:2rem;border-top:1px solid rgba(255,255,255,.07);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.fcopy{font-size:.76rem;color:rgba(255,255,255,.25)}
.flinks{display:flex;gap:1.5rem}
.flinks a{font-size:.73rem;color:rgba(255,255,255,.3);transition:color .15s}
.flinks a:hover{color:rgba(255,255,255,.7)}

/* ─── TAX BANNER ──────────────────── */
.tax-banner{background:linear-gradient(135deg,#2a5c2a 0%,#3d7a3d 50%,#2a5c2a 100%);border-top:3px solid #9cc975;border-bottom:3px solid rgba(90,122,58,.5)}
.tax-inner{max-width:1260px;margin:0 auto;padding:1.8rem 5%;display:flex;align-items:center;gap:2rem;flex-wrap:wrap}
.tax-icon{font-family:var(--serif);font-size:3rem;font-weight:600;color:rgba(255,255,255,.25);flex-shrink:0;line-height:1;width:56px;text-align:center}
.tax-text{flex:1;min-width:260px}
.tax-text strong{display:block;font-size:.95rem;font-weight:500;color:#fff;margin-bottom:.35rem;letter-spacing:.01em}
.tax-text p{font-size:.82rem;color:rgba(255,255,255,.7);line-height:1.6}
.tax-text strong strong{color:#d4f5a0}
.tax-cta{flex-shrink:0;padding:.8rem 1.8rem;background:#fff;color:#2a5c2a;font-family:var(--sans);font-size:.75rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;border-radius:2px;white-space:nowrap;transition:background .15s}
.tax-cta:hover{background:var(--cream)}

/* ─── SCROLL ANIMATION ────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}

/* ─── DIVIDER ─────────────────────── */
.ornament{text-align:center;padding:2rem 0;color:rgba(109,26,52,.2);letter-spacing:.4em;font-size:.7rem}