:root{--green:#2f7d12;--lime:#61b900;--dark:#071019;--muted:#5f6873;--warm:#f5f3ee}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--dark);background:#fff}a{text-decoration:none;color:inherit}
.topbar{height:28px;background:#050505;color:#fff;display:flex;justify-content:center;align-items:center;gap:42px;font-size:12px;font-weight:700;overflow:hidden;white-space:nowrap}
.nav{height:52px;background:#fff;border-bottom:1px solid #e7eaee;display:flex;align-items:center;justify-content:space-between;padding:0 54px;position:sticky;top:0;z-index:10}
.brand{display:flex;align-items:center;gap:10px}.brand b{font-size:22px;display:block}.brand small{font-size:12px;color:var(--muted)}
.logo{width:42px;height:42px;border:3px solid var(--green);border-radius:12px;display:grid;place-items:center;position:relative;overflow:hidden}.mesh{position:absolute;inset:-2px;background:repeating-linear-gradient(90deg,rgba(0,0,0,.2) 0 1px,transparent 1px 6px),repeating-linear-gradient(0deg,rgba(0,0,0,.16) 0 1px,transparent 1px 6px);clip-path:polygon(42% 0,100% 0,100% 100%,15% 100%)}.tick{position:relative;color:var(--green);font-size:24px;font-weight:900}
.links{display:flex;align-items:center;gap:24px;font-weight:900;font-size:14px}.btn{background:linear-gradient(135deg,var(--green),var(--lime));color:#fff!important;border:0;border-radius:10px;padding:14px 24px;text-transform:uppercase;font-weight:900;display:inline-block}.small{padding:14px 22px}
.hero{position:relative;min-height:calc(100vh - 80px);overflow:hidden;background:#f8f4ee}.photo{position:absolute;inset:0;background:url('assets/hero.jpg') center/cover no-repeat}.fade{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.38) 0%,rgba(0,0,0,.22) 28%,rgba(0,0,0,.04) 52%,transparent 65%)}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:minmax(390px,610px) 360px;gap:54px;align-items:start;padding:30px 58px 92px;min-height:610px}.copy{padding-top:18px}
.pill,.badge{display:inline-block;background:#edf7e8;color:var(--green);border-radius:999px;padding:8px 14px;font-size:13px;text-transform:uppercase;font-weight:900}
h1{font-size:56px;line-height:.98;margin:28px 0 12px;letter-spacing:-2px}h2{font-size:28px;color:var(--green);margin:0 0 28px}
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:620px}.features span{display:block;color:var(--green);font-size:34px}.features b{display:block;font-size:14px}.features small{font-size:12px}
.calc{background:#fff;border-radius:18px;padding:22px;box-shadow:0 18px 48px rgba(0,0,0,.2);width:360px;justify-self:end}.calc h3{font-size:21px;line-height:1.2;margin:0 0 18px}.calc label{display:block;font-weight:900;margin:13px 0 6px;font-size:14px}.calc input,.contact input,.contact textarea{width:100%;border:1px solid #ccd3db;border-radius:9px;padding:12px 14px;font-size:15px;background:#fff}.unit{position:relative}.unit span{position:absolute;right:13px;top:50%;transform:translateY(-50%);font-weight:900}.notice{margin-top:12px;background:#edf7e8;border:1px solid #cfe8c3;color:#255d0d;border-radius:10px;padding:10px;font-weight:700;font-size:13px}.hidden{display:none}.calc hr{border:0;border-top:1px solid #e6e9ed;margin:18px 0 0}.price-label{font-weight:900;margin:16px 0 6px}.price{font-size:38px;color:var(--green);font-weight:900}.checks{list-style:none;padding:0;margin:0 0 18px}.checks li{margin:7px 0}.checks li:before{content:'✓';color:var(--green);font-weight:900;margin-right:9px}.calc .btn{width:100%;text-align:center}.lock{text-align:center;color:var(--muted);font-size:12px;font-weight:700}
.trust{position:absolute;z-index:3;left:58px;right:58px;bottom:22px;background:rgba(255,255,255,.94);border-radius:14px;padding:19px 22px;display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:16px;box-shadow:0 12px 32px rgba(0,0,0,.12);font-weight:800}
.section{padding:80px 58px}.kicker{color:var(--green);font-weight:900;text-transform:uppercase;letter-spacing:2px}.section h2{font-size:44px;line-height:1;margin:10px 0 12px}.sub{color:var(--muted);font-size:18px}.products{background:var(--warm)}
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;margin-top:34px}.cards article{background:#fff;border:1px solid #d8e7d2;border-radius:22px;padding:24px;box-shadow:0 16px 36px rgba(0,0,0,.08)}.cards img{width:100%;height:270px;object-fit:cover;border-radius:16px;display:block;margin-bottom:18px}.cards h3{font-size:30px;margin:13px 0 2px}.cards strong{display:block;color:var(--green);font-size:34px;font-weight:900;margin-top:15px}
.dark{background:#06111b;color:#fff}.about p{max-width:900px;font-size:20px;line-height:1.6}.contact{background:var(--warm)}.contact form{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;max-width:900px}.contact textarea{grid-column:span 2;min-height:120px}
@media(max-width:950px){.topbar{height:auto;flex-direction:column;gap:6px;padding:8px 12px;font-size:12px}.nav{height:auto;padding:10px 20px}.links{display:none}.hero{min-height:auto}.hero-grid{grid-template-columns:1fr;padding:28px 20px}.calc{width:100%;justify-self:auto;margin-top:0}h1{font-size:42px}.features{grid-template-columns:repeat(2,1fr)}.trust{position:relative;left:auto;right:auto;bottom:auto;margin:0 20px 24px;grid-template-columns:1fr}.section{padding:52px 20px}.cards,.contact form{grid-template-columns:1fr}.contact textarea{grid-column:span 1}}
/* Final layout polish */
.photo{
  background-image:url('assets/hero-new.png') !important;
  background-position:center center;
}
.hero-grid{
  grid-template-columns:minmax(390px, 1fr) 288px;
  padding:12px 42px 88px;
  gap:40px;
  align-items:start;
}
.calc{
  width:288px;
  padding:18px;
  justify-self:end;
  margin-top:-45px;
}
.calc h3{font-size:18px;}
.calc label{font-size:13px;margin:10px 0 5px;}
.calc input{padding:10px 12px;font-size:14px;}
.price{font-size:32px;}
.checks li{font-size:13px;margin:5px 0;}
.calc .btn{padding:11px 14px;font-size:13px;}
.lock{margin-bottom:0;}
.hero .copy{padding-top:6px;}
.hero .pill{
  background:rgba(47,125,18,.85);
  color:#fff!important;
  padding:7px 16px;
  font-size:12px;
  letter-spacing:1.2px;
  border:1px solid rgba(97,185,0,.3);
}
.hero h1{
  font-size:52px;
  line-height:1;
  margin-top:16px;
  margin-bottom:8px;
  letter-spacing:-1.5px;
  color:#fff;
  text-shadow:0 2px 12px rgba(0,0,0,.3);
}
.hero h2{
  font-size:24px;
  margin-bottom:16px;
  font-weight:700;
  letter-spacing:-0.3px;
  color:#b4f068;
  text-shadow:0 1px 6px rgba(0,0,0,.2);
}
.hero .beratung-line{
  color:rgba(255,255,255,.85);
  text-shadow:0 1px 4px rgba(0,0,0,.2);
}
.hero .features b{color:rgba(255,255,255,.95);}
.hero .features small{color:rgba(255,255,255,.7);}
.hero .features span{color:#b4f068;}
.features span{font-size:28px;}
.features b{font-size:13px;}
.features small{font-size:11px;}
.cards img{
  height:315px;
  object-fit:cover;
}
.products{
  background:#f5f3ee;
}

/* Abgeschlossene Projekte */
.projects{
  background:#fff;
}
.projects-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:24px;
  margin-top:34px;
}
.project-card{
  background:#fff;
  border:1px solid #e3e7df;
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 14px 34px rgba(0,0,0,.07);
  cursor:pointer;
  transition:transform .25s ease, box-shadow .25s ease;
}
.project-card:hover{
  transform:translateY(-5px);
  box-shadow:0 18px 44px rgba(0,0,0,.12);
}
.project-card img,
.project-card video{
  width:100%;
  height:240px;
  object-fit:cover;
  display:block;
}
.project-info{
  padding:18px 20px 22px;
}
.project-info h3{
  margin:0 0 6px;
  font-size:20px;
}
.project-info p{
  margin:0;
  color:#66705f;
  font-size:14px;
}
.video-placeholder .video-tile{
  height:240px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,#eef4e8,#dfe9d6);
  color:#2f7d12;
  text-align:center;
}
.video-placeholder .play{
  width:58px;
  height:58px;
  border-radius:50%;
  background:#2f7d12;
  color:#fff;
  display:grid;
  place-items:center;
  font-weight:900;
  margin:auto auto 10px;
}
.upload-box{
  margin-top:34px;
  background:#f5f3ee;
  border:2px dashed #c8d9b6;
  border-radius:22px;
  padding:28px;
  text-align:center;
}
.upload-box h3{
  margin:0 0 8px;
  font-size:24px;
}
.upload-box p{
  max-width:760px;
  margin:0 auto 18px;
  color:#5f6873;
}
.upload-box input{
  background:#fff;
  padding:14px;
  border-radius:12px;
  border:1px solid #dfe4da;
  max-width:100%;
}
.upload-box small{
  display:block;
  margin-top:10px;
  color:#6a7465;
}
.lightbox{
  position:fixed;
  inset:0;
  z-index:1000;
  background:rgba(0,0,0,.82);
  display:none;
  align-items:center;
  justify-content:center;
  padding:30px;
}
.lightbox.active{
  display:flex;
}
.lightbox-content img,
.lightbox-content video{
  max-width:min(1100px,92vw);
  max-height:86vh;
  border-radius:18px;
  box-shadow:0 20px 70px rgba(0,0,0,.45);
  background:#000;
}
.lightbox-close{
  position:absolute;
  top:20px;
  right:26px;
  background:#fff;
  color:#111;
  border:0;
  width:46px;
  height:46px;
  border-radius:50%;
  font-size:30px;
  cursor:pointer;
}
@media(max-width:950px){
  .hero-grid{
    grid-template-columns:1fr;
    padding:24px 20px;
  }
  .calc{
    width:100%;
    margin-top:0;
  }
  .projects-grid{
    grid-template-columns:1fr;
  }
}

/* Product image update */
.product-card,
.cards article{
  overflow:hidden;
}
.product-card img,
.cards img{
  transition:transform .35s ease;
}
.product-card:hover img,
.cards article:hover img{
  transform:scale(1.035);
}

/* Final: Abgeschlossene Projekte with 2 folders */
.projects{background:#fff;}
.project-tabs{display:flex;gap:12px;flex-wrap:wrap;margin:30px 0 24px;}
.tab-button{border:1px solid #cfe2c6;background:#f2f8ee;color:#2f7d12;border-radius:999px;padding:12px 22px;font-weight:900;cursor:pointer;}
.tab-button.active{background:#2f7d12;color:#fff;}
.tab-content{display:none;}
.tab-content.active{display:block;}
.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin-top:22px;}
.project-card{background:#fff;border:1px solid #e3e7df;border-radius:22px;overflow:hidden;box-shadow:0 14px 34px rgba(0,0,0,.07);cursor:pointer;transition:.25s;}
.project-card:hover{transform:translateY(-5px);box-shadow:0 18px 44px rgba(0,0,0,.12);}
.project-card img,.project-card video{width:100%;height:250px;object-fit:cover;display:block;}
.video-wrap{position:relative;background:#111;}
.play-badge{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:58px;height:58px;border-radius:50%;background:rgba(47,125,18,.92);color:#fff;display:grid;place-items:center;font-weight:900;box-shadow:0 12px 30px rgba(0,0,0,.25);}
.project-info{padding:18px 20px 22px;}
.project-info h3{margin:0 0 6px;font-size:20px;}
.project-info p{margin:0;color:#66705f;font-size:14px;}
.upload-note{margin-top:30px;background:#f5f3ee;border-radius:20px;padding:24px;}
.upload-note h3{margin:0 0 8px;}
.upload-note code{background:#fff;padding:4px 8px;border-radius:8px;}
.lightbox{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.86);display:none;align-items:center;justify-content:center;padding:30px;}
.lightbox.active{display:flex;}
.lightbox-content img,.lightbox-content video{max-width:min(1120px,86vw);max-height:86vh;border-radius:18px;background:#000;box-shadow:0 20px 70px rgba(0,0,0,.45);}
.lightbox-close{position:absolute;top:20px;right:26px;background:#fff;color:#111;border:0;width:46px;height:46px;border-radius:50%;font-size:30px;cursor:pointer;}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:56px;height:56px;border-radius:50%;border:0;background:#fff;color:#2f7d12;font-size:44px;line-height:1;cursor:pointer;}
.lightbox-prev{left:28px;}
.lightbox-next{right:28px;}
@media(max-width:950px){.projects-grid{grid-template-columns:1fr}.lightbox{padding:10px;}.lightbox-nav{width:44px;height:44px;font-size:32px;background:rgba(255,255,255,.85);z-index:1002;}.lightbox-prev{left:6px;}.lightbox-next{right:6px;}}

/* Final fixes: product photos, Netlify contact form, WhatsApp */
.hidden{display:none!important;}
.cards img,
.product-card img{
  object-fit:cover;
  object-position:center;
}
.contact-form-section{
  background:#f5f3ee;
}
.contact-form{
  max-width:920px;
  margin:30px auto 0;
  background:#fff;
  border-radius:24px;
  padding:32px;
  box-shadow:0 14px 40px rgba(0,0,0,.08);
}
.form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}
.contact-form label{
  display:flex;
  flex-direction:column;
  gap:8px;
  font-weight:800;
  color:#111827;
  margin-bottom:18px;
}
.contact-form input,
.contact-form textarea{
  border:1px solid #d5dbe3;
  border-radius:14px;
  padding:14px 16px;
  font:inherit;
  background:#fff;
}
.contact-form textarea{
  resize:vertical;
}
.whatsapp-float{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:1200;
  background:#25D366;
  color:white;
  text-decoration:none;
  border-radius:999px;
  padding:15px 20px;
  font-weight:900;
  box-shadow:0 14px 35px rgba(0,0,0,.25);
  display:flex;
  align-items:center;
  gap:10px;
}
.whatsapp-float::before{
  content:"☎";
  width:24px;
  height:24px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.22);
}
.whatsapp-float:hover{
  transform:translateY(-2px);
}
.thanks-page{
  min-height:100vh;
  display:grid;
  place-items:center;
  background:#f5f3ee;
  padding:24px;
}
.thanks-card{
  background:white;
  max-width:620px;
  border-radius:28px;
  padding:42px;
  box-shadow:0 20px 60px rgba(0,0,0,.10);
  text-align:center;
}
.thanks-card h1{
  font-size:42px;
  margin-bottom:16px;
}
.thanks-card p{
  color:#5f6873;
  font-size:18px;
  margin-bottom:28px;
}
.whatsapp-inline{
  margin-left:10px;
  background:#25D366!important;
}
@media(max-width:760px){
  .form-grid{grid-template-columns:1fr;}
  .contact-form{padding:22px;}
  .whatsapp-float{
    right:16px;
    bottom:16px;
    padding:14px 16px;
  }
  .whatsapp-float span{display:none;}
  .whatsapp-float::before{
    background:transparent;
    font-size:24px;
  }
}

/* Anfrage modal + success modal */
.anfrage-modal,
.success-modal{
  position:fixed;
  inset:0;
  z-index:2000;
  display:none;
  align-items:center;
  justify-content:center;
  padding:22px;
}
.anfrage-modal.active,
.success-modal.active{
  display:flex;
}
.anfrage-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.58);
  backdrop-filter:blur(4px);
}
.anfrage-modal-card,
.success-card{
  position:relative;
  z-index:2;
  width:min(620px, 96vw);
  max-height:92vh;
  overflow:auto;
  background:#fff;
  border-radius:26px;
  padding:30px;
  box-shadow:0 24px 80px rgba(0,0,0,.28);
}
.modal-close{
  position:absolute;
  top:14px;
  right:16px;
  border:0;
  background:#f2f4f1;
  color:#111;
  width:38px;
  height:38px;
  border-radius:50%;
  font-size:25px;
  cursor:pointer;
}
.modal-kicker{
  color:#2f7d12;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:1.5px;
  margin:0 0 8px;
}
.anfrage-modal-card h2,
.success-card h2{
  margin:0 0 10px;
  font-size:32px;
  line-height:1.1;
}
.modal-sub{
  color:#5f6873;
  margin:0 0 18px;
  line-height:1.5;
}
.calc-summary{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  background:#f5f3ee;
  border-radius:18px;
  padding:14px;
  margin:16px 0 20px;
}
.calc-summary div{
  background:#fff;
  border-radius:14px;
  padding:12px;
}
.calc-summary span{
  display:block;
  color:#6a7465;
  font-size:12px;
  font-weight:800;
  margin-bottom:4px;
}
.calc-summary strong{
  color:#2f7d12;
  font-size:17px;
}
.modal-form label{
  display:flex;
  flex-direction:column;
  gap:7px;
  font-weight:900;
  margin-bottom:14px;
}
.modal-form label span{
  font-weight:700;
  color:#7b837a;
  font-size:12px;
}
.modal-form input,
.modal-form textarea{
  border:1px solid #d5dbe3;
  border-radius:13px;
  padding:13px 15px;
  font:inherit;
  background:#fff;
}
.modal-submit{
  width:100%;
  text-align:center;
  border:0;
  cursor:pointer;
}
.success-card{
  max-width:520px;
  text-align:center;
}
.success-icon{
  width:62px;
  height:62px;
  border-radius:50%;
  display:grid;
  place-items:center;
  margin:0 auto 16px;
  background:#2f7d12;
  color:#fff;
  font-size:34px;
  font-weight:900;
}
.success-card p{
  color:#5f6873;
  margin:0 0 10px;
}
.success-card strong{
  display:block;
  margin-bottom:22px;
}
@media(max-width:640px){
  .anfrage-modal-card,
  .success-card{
    padding:24px 18px;
    border-radius:22px;
  }
  .calc-summary{
    grid-template-columns:1fr;
  }
  .anfrage-modal-card h2,
  .success-card h2{
    font-size:27px;
  }
}

/* FINAL CLEANUP: compact hero, no endless first-screen image */
.hero,
.hero-section{
  min-height:auto!important;
}
.hero-grid{
  min-height:auto!important;
  padding-top:24px!important;
  padding-bottom:42px!important;
}
.photo{
  max-height:816px!important;
  background-size:cover!important;
  background-position:center!important;
}
@media(min-width:900px){
  .hero,
  .hero-section{
    max-height:912px!important;
    overflow:hidden!important;
  }
}
@media(max-width:760px){
  .hero,
  .hero-section{
    min-height:auto!important;
    max-height:none!important;
  }
  .hero-grid{
    padding-top:20px!important;
    padding-bottom:28px!important;
  }
  .hero h1{
    font-size:clamp(40px, 12vw, 62px)!important;
    line-height:.96!important;
  }
}

/* FINAL CLEANUP: booking buttons clickable */
[data-open-anfrage]{
  cursor:pointer;
}

/* FINAL STABLE FIX: private + B2B modals */
.b2b-modal{
  position:fixed;
  inset:0;
  z-index:2000;
  display:none;
  align-items:center;
  justify-content:center;
  padding:22px;
}
.b2b-modal.active{
  display:flex;
}
.anfrage-modal.active,
.success-modal.active{
  display:flex!important;
}
.modal-close{
  z-index:5;
}
.modal-submit:disabled{
  opacity:.65;
  cursor:not-allowed;
}

/* FINAL POLISH ONLY: desktop 100%, calculator, modal, WhatsApp */
html, body{
  overflow-x:hidden;
}
.hero,
.hero-section{
  min-height:auto!important;
}
.hero-grid{
  min-height:744px!important;
  max-height:864px!important;
  padding-top:24px!important;
  padding-bottom:32px!important;
  align-items:center!important;
}
.hero h1{
  font-size:clamp(44px, 5vw, 76px)!important;
  line-height:.96!important;
}
.photo{
  min-height:672px!important;
  max-height:840px!important;
  background-size:cover!important;
  background-position:center!important;
}
.calculator,
.calc-card,
.price-card,
.hero-card{
  max-width:288px!important;
}
@media(min-width:900px){
  .hero,
  .hero-section{
    max-height:912px!important;
    overflow:hidden!important;
  }
}
@media(max-width:760px){
  .hero-grid{
    min-height:auto!important;
    max-height:none!important;
    padding-top:18px!important;
    padding-bottom:28px!important;
  }
  .hero h1{
    font-size:clamp(40px, 12vw, 62px)!important;
  }
  .calculator,
  .calc-card,
  .price-card,
  .hero-card{
    max-width:100%!important;
  }
}
.whatsapp-float{
  right:24px!important;
  bottom:24px!important;
  z-index:2100!important;
}
@media(min-width:900px){
  .whatsapp-float{
    bottom:18px!important;
  }
}
.anfrage-modal,
.b2b-modal,
.success-modal{
  position:fixed;
  inset:0;
  z-index:2000;
  display:none;
  align-items:center;
  justify-content:center;
  padding:22px;
}
.anfrage-modal.active,
.b2b-modal.active,
.success-modal.active{
  display:flex!important;
}
.anfrage-modal-card,
.success-card{
  max-height:88vh!important;
  overflow:auto!important;
}
.modal-close{
  z-index:5!important;
  cursor:pointer!important;
}
.modal-submit:disabled{
  opacity:.65;
  cursor:not-allowed;
}
[data-open-private],
[data-open-b2b]{
  cursor:pointer;
}


/* === FINAL MANUAL POLISH 2026-05-18 === */
.topbar{
  height:auto !important;
  min-height:30px !important;
  padding:6px 22px !important;
  display:flex !important;
  flex-wrap:wrap !important;
  justify-content:center !important;
  gap:12px 28px !important;
  line-height:1.25 !important;
  font-size:13px !important;
}
.nav .links .btn.small{display:none!important;}
.beratung-line{
  color:var(--muted);
  font-weight:700;
  margin:0 0 22px;
  font-size:16px;
  letter-spacing:0.3px;
}
.service-list{
  list-style:none;
  margin:10px 0 28px;
  padding:0;
  color:var(--muted);
  font-size:18px;
  line-height:1.55;
}
.service-list li{margin:4px 0;}
.service-list li:before{
  content:'✓';
  color:var(--green);
  font-weight:900;
  margin-right:10px;
}
.sub-intro{margin-bottom:0!important;}
.showcase-video{
  position:relative;
  z-index:4;
  max-width:720px;
  margin:0 auto 34px;
}
.showcase-video video{
  height:320px!important;
  object-fit:cover;
}
.upload-note{display:none!important;}
.whatsapp-float{
  right:22px!important;
  bottom:22px!important;
}
@media(max-width:950px){
  .topbar{
    flex-direction:row!important;
    align-items:center!important;
    justify-content:center!important;
    font-size:11px!important;
    gap:5px 12px!important;
    padding:6px 8px!important;
    white-space:normal!important;
  }
  .beratung-line{font-size:15px;margin-bottom:18px;}
  .service-list{font-size:16px;line-height:1.45;margin-bottom:20px;}
  .showcase-video{
    margin:0 20px 24px!important;
    border-radius:18px!important;
  }
  .showcase-video video{
    height:210px!important;
  }
  .whatsapp-float{
    right:12px!important;
    bottom:12px!important;
    width:48px!important;
    height:48px!important;
    padding:0!important;
    font-size:13px!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
  }
  .contact h2{font-size:42px!important;}
}

/* TEST 1: featured video fixed, no hero overlay */
.featured-video-section{
  background:#fff;
  padding-top:54px!important;
  padding-bottom:58px!important;
}
.featured-video-section .showcase-video{
  max-width:680px;
  margin:24px 0 0;
  cursor:default;
}
.featured-video-section .showcase-video:hover{
  transform:none;
}
.featured-video-section .showcase-video video{
  width:100%;
  height:300px!important;
  object-fit:cover;
  display:block;
  background:#111;
}
@media(max-width:950px){
  .featured-video-section{
    padding:38px 20px 42px!important;
  }
  .featured-video-section h2{
    font-size:34px!important;
  }
  .featured-video-section .showcase-video{
    margin:18px 0 0!important;
    max-width:100%;
  }
  .featured-video-section .showcase-video video{
    height:190px!important;
  }
}


/* TEST 2: move Trustpilot proof bar below hero onto white area */
.trust-strip{
  background:#fff;
  padding:22px 58px 10px;
}
.trust-strip .trust{
  position:relative!important;
  left:auto!important;
  right:auto!important;
  bottom:auto!important;
  max-width:1180px;
  margin:0 auto!important;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(15,23,42,.08);
  border-radius:14px;
  padding:16px 20px;
  display:grid;
  grid-template-columns:1.35fr repeat(4,1fr);
  gap:14px;
  box-shadow:0 10px 28px rgba(0,0,0,.10);
  font-weight:800;
}
.featured-video-section{
  padding-top:34px!important;
}
@media(max-width:950px){
  .trust-strip{
    padding:18px 20px 6px;
  }
  .trust-strip .trust{
    grid-template-columns:1fr;
    gap:12px;
    padding:18px 18px;
  }
  .featured-video-section{
    padding-top:30px!important;
  }
}

/* TEST 3: extended proof bar, all items in one line on desktop */
.trust-strip{
  padding:18px 38px 12px!important;
}
.trust-strip .trust{
  max-width:1280px!important;
  width:calc(100% - 12px);
  display:flex!important;
  align-items:center;
  justify-content:space-between;
  gap:18px!important;
  padding:14px 18px!important;
  white-space:nowrap;
  font-size:14px;
  line-height:1.15;
}
.trust-strip .trust div{
  min-width:0;
  flex:0 1 auto;
  white-space:nowrap;
}
.trust-strip .trust div:first-child{
  flex:1.05 0 auto;
}
.hero{
  min-height:768px;
}
.hero-grid{
  padding-bottom:58px;
}
@media(max-width:1200px){
  .trust-strip .trust{
    gap:12px!important;
    font-size:13px;
    padding:13px 14px!important;
  }
}
@media(max-width:950px){
  .trust-strip{
    padding:16px 20px 8px!important;
  }
  .trust-strip .trust{
    display:grid!important;
    grid-template-columns:1fr;
    white-space:normal;
    font-size:15px;
    gap:12px!important;
    width:auto;
    padding:18px 18px!important;
  }
  .trust-strip .trust div,
  .trust-strip .trust div:first-child{
    white-space:normal;
    flex:auto;
  }
  .hero{
    min-height:auto;
  }
  .hero-grid{
    padding-bottom:28px;
  }
}

/* Stepper buttons for calculator inputs */
.stepper-wrap{
  display:flex;
  align-items:stretch;
}
.stepper-wrap input[type="number"]{
  -moz-appearance:textfield;
  flex:1;
  border-radius:0;
  border-left:0;
  border-right:0;
  text-align:center;
  min-width:0;
}
.stepper-wrap input[type="number"]::-webkit-inner-spin-button,
.stepper-wrap input[type="number"]::-webkit-outer-spin-button{
  -webkit-appearance:none;
  margin:0;
}
.stepper-btn{
  width:40px;
  min-width:40px;
  border:1px solid #ccd3db;
  background:#f5f3ee;
  font-size:20px;
  font-weight:900;
  cursor:pointer;
  color:#2f7d12;
  display:grid;
  place-items:center;
  padding:0;
  line-height:1;
  user-select:none;
  transition:background .15s;
}
.stepper-minus{
  border-radius:9px 0 0 9px;
}
.stepper-plus{
  border-radius:0 9px 9px 0;
}
.stepper-btn:hover{
  background:#e8f0df;
}
.stepper-btn:active{
  background:#d9e8cc;
}
.stepper-wrap>.unit-suffix{
  position:absolute;
  right:52px;
  top:50%;
  transform:translateY(-50%);
}

/* Orange state for outside service area */
.notice.notice-outside{
  background:#fff7ed;
  border-color:#f0b87a;
  color:#92400e;
}
.calc.outside-area .price{
  color:#c2610c;
}
.calc.outside-area .price-label{
  color:#92400e;
  font-weight:900;
}
.calc.outside-area .checks{
  display:none;
}
.outside-hint{
  margin:8px 0 14px;
  font-size:13px;
  color:#92400e;
  font-weight:700;
  font-style:italic;
}

/* Technik & Details section */
.technik-section{
  background:#f5f3ee;
  text-align:center;
  padding-top:56px;
  padding-bottom:56px;
}
.technik-section .sub{
  max-width:480px;
  margin-left:auto;
  margin-right:auto;
}
.technik-grid{
  display:grid;
  grid-template-columns:1fr;
  max-width:540px;
  margin:28px auto 0;
}
.technik-card{
  background:#fff;
  border:1px solid #d8e7d2;
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 14px 34px rgba(0,0,0,.07);
  transition:transform .25s ease, box-shadow .25s ease;
}
.technik-card:hover{
  transform:translateY(-5px);
  box-shadow:0 18px 44px rgba(0,0,0,.12);
}
.technik-card img{
  width:100%;
  height:300px;
  object-fit:cover;
  display:block;
}
.technik-info{
  padding:20px 24px 24px;
  text-align:left;
}
.technik-info h3{
  margin:0 0 8px;
  font-size:22px;
}
.technik-info p{
  margin:0;
  color:#5f6873;
  font-size:15px;
  line-height:1.5;
}
@media(max-width:950px){
  .technik-grid{
    max-width:100%;
  }
  .technik-card img{
    height:240px;
  }
}

/* Nav: lesbar und schön */
.nav{
  height:54px!important;
  padding:0 54px!important;
  background:#fff;
  box-shadow:0 2px 12px rgba(0,0,0,.06);
  border-bottom:none!important;
}
.logo{
  width:36px!important;
  height:36px!important;
  border-width:2.5px!important;
  border-radius:10px!important;
  border-color:var(--green)!important;
  background:linear-gradient(135deg,#f0f9eb,#fff);
  flex-shrink:0;
}
.tick{
  font-size:20px!important;
}
.brand{
  gap:10px!important;
}
.brand b{
  font-size:20px!important;
  letter-spacing:-.3px;
  color:var(--dark);
  line-height:1.15;
}
.brand small{
  font-size:11.5px!important;
  color:#6b7c65!important;
  letter-spacing:.3px;
  line-height:1.2;
  display:block;
  margin-top:1px;
}
.links{
  gap:20px!important;
  font-size:13.5px!important;
}
.links a{
  color:var(--dark);
  transition:color .2s;
}
.links a:hover{
  color:var(--green);
}
@media(max-width:950px){
  .nav{
    height:auto!important;
    padding:10px 20px!important;
  }
  .brand b{
    font-size:18px!important;
  }
  .brand small{
    font-size:10.5px!important;
  }
}

/* === MOBILE HERO: premium, image-forward === */
@media(max-width:950px){
  .fade{
    background:linear-gradient(
      90deg,
      rgba(0,0,0,.52) 0%,
      rgba(0,0,0,.32) 35%,
      rgba(0,0,0,.08) 65%,
      transparent 100%
    )!important;
  }
  .hero .copy{
    position:relative;
    z-index:2;
    padding:14px 12px 16px!important;
    background:none!important;
    backdrop-filter:none!important;
    -webkit-backdrop-filter:none!important;
  }
  .hero h1{
    color:#fff!important;
    font-size:38px!important;
    text-shadow:
      0 2px 16px rgba(0,0,0,.55),
      0 1px 3px rgba(0,0,0,.4);
  }
  .hero h2{
    color:#b4f068!important;
    font-weight:700!important;
    text-shadow:
      0 2px 12px rgba(0,0,0,.45),
      0 1px 3px rgba(0,0,0,.3);
  }
  .hero .beratung-line{
    color:rgba(255,255,255,.92)!important;
    font-weight:700!important;
    text-shadow:
      0 1px 8px rgba(0,0,0,.4),
      0 1px 2px rgba(0,0,0,.25);
  }
  .hero .pill{
    background:rgba(47,125,18,.85)!important;
    color:#fff!important;
    border-color:rgba(97,185,0,.3)!important;
    box-shadow:0 2px 8px rgba(0,0,0,.25);
  }
  .features{
    margin-top:10px!important;
    padding:0;
    border:none;
    background:transparent!important;
  }
  .features > div{
    background:rgba(0,0,0,.28);
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
    border-radius:10px;
    padding:8px 10px;
    border:1px solid rgba(255,255,255,.08);
  }
  .features span{
    color:#b4f068!important;
    text-shadow:0 1px 6px rgba(0,0,0,.35);
  }
  .features b{
    color:#fff!important;
    font-size:14px!important;
    font-weight:900!important;
    text-shadow:
      0 1px 8px rgba(0,0,0,.4),
      0 1px 2px rgba(0,0,0,.3);
  }
  .features small{
    color:rgba(255,255,255,.8)!important;
    font-size:12px!important;
    text-shadow:0 1px 4px rgba(0,0,0,.25);
  }
  .hero-grid{
    padding-top:12px!important;
    padding-bottom:14px!important;
  }
  .calc{
    margin-top:18px!important;
  }
}

/* === REFINEMENTS 2026-05-20 === */

/* 1. Top bar: shorter, tighter */
.topbar{
  min-height:24px!important;
  padding:4px 22px!important;
  gap:8px 22px!important;
  font-size:12px!important;
  font-weight:600!important;
  letter-spacing:.2px;
}

/* 2. WhatsApp: real SVG icon instead of phone emoji */
.whatsapp-float::before{
  content:none!important;
  display:none!important;
}
.wa-icon{
  width:22px;
  height:22px;
  flex-shrink:0;
}

/* 3. Nav/brand: better vertical alignment */
.nav{
  height:56px!important;
}
.brand{
  display:flex!important;
  align-items:center!important;
  gap:11px!important;
}
.brand > span{
  display:flex;
  flex-direction:column;
  justify-content:center;
  line-height:1;
}
.brand b{
  font-size:19px!important;
  line-height:1.15!important;
  letter-spacing:-.2px;
  margin-bottom:1px;
}
.brand small{
  font-size:11px!important;
  line-height:1.15!important;
  margin-top:2px!important;
  color:#6b7c65!important;
  letter-spacing:.2px;
}
.logo{
  width:38px!important;
  height:38px!important;
  flex-shrink:0;
  display:grid!important;
  place-items:center!important;
}

/* 4. Hero: subtle contrast, no heavy white overlays */
.fade{
  background:linear-gradient(
    90deg,
    rgba(0,0,0,.42) 0%,
    rgba(0,0,0,.24) 30%,
    rgba(0,0,0,.06) 55%,
    transparent 70%
  )!important;
}

/* 5. Typography: increase readability */
.beratung-line{
  font-size:17px!important;
  font-weight:700!important;
  letter-spacing:.2px;
}
.features b{
  font-size:15px!important;
}
.features small{
  font-size:12.5px!important;
}
.features span{
  font-size:30px!important;
}

/* 6. Calculator: slightly larger text */
.calc h3{
  font-size:19px!important;
  line-height:1.25!important;
}
.calc label{
  font-size:14px!important;
}
.calc input{
  font-size:15px!important;
  padding:11px 13px!important;
}
.price{
  font-size:34px!important;
}
.price-label{
  font-size:15px!important;
}
.checks li{
  font-size:14px!important;
}
.calc .btn{
  font-size:14px!important;
  padding:13px 18px!important;
}
.lock{
  font-size:12.5px!important;
}

/* Mobile refinements */
@media(max-width:950px){
  .topbar{
    font-size:11px!important;
    gap:3px 10px!important;
    padding:4px 10px!important;
    min-height:auto!important;
  }
  .nav{
    height:auto!important;
    min-height:48px;
    padding:8px 16px!important;
  }
  .brand b{
    font-size:17px!important;
  }
  .brand small{
    font-size:10px!important;
  }
  .beratung-line{
    font-size:16px!important;
  }
  .features b{
    font-size:14px!important;
  }
  .features small{
    font-size:12px!important;
  }
  .whatsapp-float{
    width:50px!important;
    height:50px!important;
    padding:0!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
  }
  .whatsapp-float .wa-icon{
    width:26px;
    height:26px;
  }
  .whatsapp-float span{
    display:none!important;
  }
}

@media(max-width:760px){
  .whatsapp-float{
    width:48px!important;
    height:48px!important;
    right:14px!important;
    bottom:14px!important;
  }
  .whatsapp-float .wa-icon{
    width:24px;
    height:24px;
  }
}

/* === REFINEMENTS BATCH 2026-05-20 === */

/* 1. Hamburger button – hidden on desktop, visible on mobile */
.hamburger{
  display:none;
  background:none;
  border:none;
  cursor:pointer;
  padding:6px;
  flex-direction:column;
  gap:5px;
  z-index:20;
}
.hamburger span{
  display:block;
  width:24px;
  height:2.5px;
  background:var(--dark);
  border-radius:2px;
  transition:transform .25s, opacity .2s;
}
.hamburger.active span:nth-child(1){
  transform:translateY(7.5px) rotate(45deg);
}
.hamburger.active span:nth-child(2){
  opacity:0;
}
.hamburger.active span:nth-child(3){
  transform:translateY(-7.5px) rotate(-45deg);
}

/* Mobile menu overlay */
.mobile-menu{
  position:fixed;
  inset:0;
  z-index:1500;
  display:none;
}
.mobile-menu.active{
  display:block;
}
.mobile-menu-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.45);
  backdrop-filter:blur(3px);
  -webkit-backdrop-filter:blur(3px);
}
.mobile-menu-panel{
  position:absolute;
  top:0;
  right:0;
  width:min(320px, 82vw);
  height:100%;
  background:#fff;
  box-shadow:-8px 0 40px rgba(0,0,0,.18);
  padding:68px 28px 40px;
  overflow-y:auto;
  transform:translateX(100%);
  transition:transform .3s ease;
}
.mobile-menu.active .mobile-menu-panel{
  transform:translateX(0);
}
.mobile-menu-close{
  position:absolute;
  top:16px;
  right:16px;
  width:38px;
  height:38px;
  border:none;
  background:#f2f4f1;
  border-radius:50%;
  font-size:24px;
  color:#111;
  cursor:pointer;
  display:grid;
  place-items:center;
}
.mobile-menu-links{
  display:flex;
  flex-direction:column;
  gap:0;
}
.mobile-menu-links a{
  display:block;
  padding:16px 4px;
  font-size:17px;
  font-weight:800;
  color:var(--dark);
  border-bottom:1px solid #eef0ec;
  transition:color .2s;
}
.mobile-menu-links a:last-child{
  border-bottom:none;
}
.mobile-menu-links a:hover,
.mobile-menu-links a:active{
  color:var(--green);
}

@media(max-width:950px){
  .hamburger{
    display:flex;
  }
  .links{
    display:none!important;
  }
}

/* 2. Top bar: slightly reduced */
.topbar{
  min-height:22px!important;
  padding:3px 22px!important;
  gap:6px 20px!important;
  font-size:11.5px!important;
}
@media(max-width:950px){
  .topbar{
    padding:3px 8px!important;
    font-size:10.5px!important;
    gap:2px 8px!important;
  }
}

/* 3. WhatsApp – already SVG, ensure ::before hidden */
.whatsapp-float::before{
  content:none!important;
  display:none!important;
}

/* 4. Logo/brand area: cleaner, more modern alignment */
.brand{
  gap:12px!important;
}
.brand > span{
  display:flex!important;
  flex-direction:column!important;
  justify-content:center!important;
  gap:2px;
}
.brand b{
  font-size:19px!important;
  font-weight:900!important;
  letter-spacing:-.3px;
  line-height:1.1!important;
}
.brand small{
  font-size:11.5px!important;
  font-weight:500!important;
  color:#7a8d73!important;
  letter-spacing:.4px;
  line-height:1.15!important;
  margin-top:0!important;
}
.logo{
  width:38px!important;
  height:38px!important;
  border-width:2.5px!important;
  border-radius:10px!important;
}

/* 5. Hero: subtle contrast only, no heavy overlays */
.fade{
  background:linear-gradient(
    90deg,
    rgba(0,0,0,.40) 0%,
    rgba(0,0,0,.22) 28%,
    rgba(0,0,0,.05) 55%,
    transparent 68%
  )!important;
}

/* 6. Typography: better readability */
.beratung-line{
  font-size:18px!important;
  font-weight:700!important;
}
.hero .features b{
  font-size:16px!important;
}
.hero .features small{
  font-size:13px!important;
}

/* 7. Calculator: "Fixpreis Kalkulator" title, compact mobile, readable */
.calc h3{
  font-size:19px!important;
  font-weight:900!important;
  letter-spacing:-.2px;
}
@media(max-width:950px){
  .calc{
    padding:16px!important;
  }
  .calc h3{
    font-size:17px!important;
    margin-bottom:14px!important;
  }
  .calc label{
    font-size:13px!important;
    margin:8px 0 4px!important;
  }
  .calc input{
    padding:9px 11px!important;
    font-size:14px!important;
  }
  .price{
    font-size:30px!important;
  }
  .price-label{
    font-size:14px!important;
  }
  .checks li{
    font-size:13px!important;
  }
  .calc .btn{
    padding:12px 14px!important;
    font-size:13px!important;
  }
  .stepper-btn{
    width:36px;
    min-width:36px;
    font-size:18px;
  }
}

/* 8. Video poster: ensure video covers like image when poster shown */
.video-wrap video{
  object-fit:cover;
  background:#111;
}
.video-wrap video[poster]{
  object-fit:cover;
}

/* Mobile typography refinements */
@media(max-width:950px){
  .beratung-line{
    font-size:16px!important;
  }
  .hero .features b{
    font-size:14px!important;
  }
  .hero .features small{
    font-size:12px!important;
  }
  .brand b{
    font-size:17px!important;
  }
  .brand small{
    font-size:10.5px!important;
  }

  /* Gallery tabs: larger, more prominent on mobile */
  .project-tabs{
    gap:10px;
    margin:26px 0 20px;
  }
  .tab-button{
    flex:1;
    text-align:center;
    padding:15px 24px;
    font-size:16px;
    font-weight:900;
    letter-spacing:.3px;
    border-width:2px;
    border-color:#b8d4a8;
    box-shadow:0 2px 8px rgba(47,125,18,.08);
    transition:background .2s,color .2s,box-shadow .2s,border-color .2s;
  }
  .tab-button.active{
    border-color:#2f7d12;
    box-shadow:0 4px 16px rgba(47,125,18,.28);
    transform:scale(1.03);
  }
}

/* === FINAL READABILITY & PREMIUM POLISH 2026-05-20 === */

/* DESKTOP: Badge "INSEKTENSCHUTZ NACH MASS" ~15% bigger */
.hero .pill{
  font-size:14px!important;
  padding:9px 18px!important;
  letter-spacing:1.4px!important;
}

/* DESKTOP: Green subtitle "Insektenschutz, der passt." ~20% bigger */
.hero h2{
  font-size:29px!important;
  letter-spacing:-.3px!important;
}

/* DESKTOP: Beratung line ~15% bigger + bolder */
.beratung-line{
  font-size:21px!important;
  font-weight:800!important;
  letter-spacing:.2px!important;
}

/* DESKTOP: Four features 20-30% bigger */
.hero .features span{
  font-size:38px!important;
}
.hero .features b{
  font-size:20px!important;
  letter-spacing:-.1px;
}
.hero .features small{
  font-size:16px!important;
  line-height:1.3!important;
}

/* MOBILE: Fixpreis Kalkulator adjustments */
@media(max-width:950px){
  /* Calc title ~30% bigger */
  .calc h3{
    font-size:22px!important;
    margin-bottom:16px!important;
  }
  /* Field labels ~15% bigger */
  .calc label{
    font-size:15px!important;
    margin:10px 0 5px!important;
  }
  /* Price display ~15% bigger */
  .price{
    font-size:35px!important;
  }
  .price-label{
    font-size:16px!important;
  }
  /* Plus/Minus icons slightly larger */
  .stepper-btn{
    width:42px!important;
    min-width:42px!important;
    font-size:22px!important;
  }
  /* Input fields ~10% taller */
  .calc input{
    padding:12px 13px!important;
    font-size:15px!important;
  }
  /* Checks list readable */
  .checks li{
    font-size:14px!important;
  }
  /* GTT Bilder / GTT Video buttons: bigger and easier to tap */
  .tab-button{
    padding:18px 28px!important;
    font-size:18px!important;
    min-height:56px;
    border-radius:999px;
  }
  /* Hero text adjustments for mobile */
  .hero .pill{
    font-size:12px!important;
    padding:7px 14px!important;
  }
  .hero h2{
    font-size:22px!important;
  }
  .beratung-line{
    font-size:16px!important;
    font-weight:700!important;
  }
  .hero .features b{
    font-size:15px!important;
  }
  .hero .features small{
    font-size:13px!important;
  }
  .hero .features span{
    font-size:28px!important;
  }
}

/* Mobile menu: Fixpreis Kalkulator as sub-item under Privatkunden */
.mobile-menu-links .mobile-sub-item{
  padding-left:24px!important;
  font-size:15px!important;
  font-weight:700!important;
  color:var(--green)!important;
  border-bottom:1px solid #eef0ec;
}
.mobile-menu-links .mobile-sub-item::before{
  content:'↳ ';
  opacity:.5;
}

/* === FINAL HEADER/LOGO V3 & DESKTOP ADJUSTMENTS === */

/* 1a. Logo V3: Modern, Minimalistic – remove mesh, clean checkmark (both platforms) */
.mesh{
  display:none!important;
}
.logo{
  width:42px!important;
  height:42px!important;
  border-width:2.5px!important;
  border-radius:11px!important;
  background:linear-gradient(145deg,#f4faf0,#fff)!important;
}
.tick{
  font-size:23px!important;
}

/* 1b. Brand name bolder */
.brand b{
  font-size:22px!important;
  font-weight:900!important;
  letter-spacing:-.3px!important;
}

/* 1c. Subtitle smaller and lighter gray */
.brand small{
  font-size:10px!important;
  color:#adb7a8!important;
  font-weight:400!important;
  letter-spacing:.3px!important;
}

/* 1d. Hamburger menu thicker/stronger */
.hamburger span{
  width:27px!important;
  height:3px!important;
}
.hamburger{
  gap:5.5px!important;
}
.hamburger.active span:nth-child(1){
  transform:translateY(8.5px) rotate(45deg)!important;
}
.hamburger.active span:nth-child(3){
  transform:translateY(-8.5px) rotate(-45deg)!important;
}

/* 1e. Mobile header: apply logo V3 style, keep layout close to current */
@media(max-width:950px){
  .logo{
    width:40px!important;
    height:40px!important;
    border-radius:10px!important;
  }
  .tick{
    font-size:22px!important;
  }
  .brand b{
    font-size:18px!important;
  }
  .brand small{
    font-size:9.5px!important;
    color:#adb7a8!important;
    font-weight:400!important;
  }
}

/* 2. Hero Desktop: text ~15-20% larger */
@media(min-width:951px){
  .hero .pill{
    font-size:16px!important;
    padding:10px 20px!important;
    letter-spacing:1.5px!important;
  }
  .hero h2{
    font-size:35px!important;
    letter-spacing:-.4px!important;
  }
  .beratung-line{
    font-size:24px!important;
    font-weight:900!important;
  }
}

/* 3. Features Desktop: ~25% bigger icons and text */
@media(min-width:951px){
  .hero .features{
    max-width:none!important;
    gap:20px!important;
  }
  .hero .features span{
    font-size:48px!important;
  }
  .hero .features b{
    font-size:24px!important;
    line-height:1.2!important;
  }
  .hero .features small{
    font-size:19px!important;
    line-height:1.3!important;
  }
}

/* 4. Calculator Desktop: ~30% larger fonts, proportional buttons/inputs */
@media(min-width:951px){
  .hero-grid{
    grid-template-columns:minmax(390px,1fr) 350px!important;
    max-height:none!important;
  }
  .hero,.hero-section{
    max-height:none!important;
  }
  .calc{
    width:350px!important;
    padding:24px!important;
  }
  .calc h3{
    font-size:25px!important;
    margin-bottom:20px!important;
  }
  .calc label{
    font-size:18px!important;
    margin:14px 0 7px!important;
  }
  .calc input{
    font-size:19px!important;
    padding:14px 16px!important;
  }
  .calc .price{
    font-size:39px!important;
  }
  .calc .price-label{
    font-size:19px!important;
    margin:18px 0 8px!important;
  }
  .calc .checks li{
    font-size:18px!important;
    margin:8px 0!important;
  }
  .calc .btn{
    font-size:18px!important;
    padding:16px 22px!important;
  }
  .calc .lock{
    font-size:16px!important;
    margin-top:8px!important;
  }
  .stepper-btn{
    width:48px!important;
    min-width:48px!important;
    font-size:24px!important;
  }
  .calc hr{
    margin:20px 0 0!important;
  }
  .calc .notice{
    font-size:16px!important;
    padding:13px!important;
  }
}

/* === FOOTER === */
.site-footer{
  background:#06111b;
  color:#fff;
  padding:0;
}
.footer-inner{
  max-width:1280px;
  margin:0 auto;
  padding:42px 58px 28px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:32px;
  flex-wrap:wrap;
}
.footer-brand{
  display:flex;
  align-items:center;
  gap:12px;
}
.footer-brand .logo{
  width:36px!important;
  height:36px!important;
  border-color:rgba(97,185,0,.6)!important;
  background:linear-gradient(145deg,rgba(47,125,18,.15),rgba(255,255,255,.06))!important;
  flex-shrink:0;
}
.footer-brand .tick{
  color:#61b900!important;
  font-size:19px!important;
}
.footer-brand b{
  font-size:18px;
  display:block;
  color:#fff;
  letter-spacing:-.2px;
}
.footer-brand small{
  font-size:11px;
  display:block;
  color:rgba(255,255,255,.45);
  margin-top:2px;
}
.footer-links{
  display:flex;
  gap:28px;
  align-items:center;
}
.footer-links a{
  color:rgba(255,255,255,.7);
  font-size:14px;
  font-weight:700;
  transition:color .2s;
  letter-spacing:.2px;
}
.footer-links a:hover{
  color:#61b900;
}
.footer-contact{
  display:flex;
  flex-direction:column;
  gap:6px;
  font-size:13px;
  color:rgba(255,255,255,.55);
  font-weight:600;
}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding:16px 58px;
  text-align:center;
}
.footer-bottom p{
  margin:0;
  font-size:12px;
  color:rgba(255,255,255,.35);
  letter-spacing:.3px;
}
@media(max-width:950px){
  .footer-inner{
    flex-direction:column;
    align-items:center;
    text-align:center;
    padding:34px 24px 22px;
    gap:24px;
  }
  .footer-links{
    gap:22px;
    flex-wrap:wrap;
    justify-content:center;
  }
  .footer-contact{
    align-items:center;
  }
  .footer-bottom{
    padding:14px 20px;
  }
}

/* === LEGAL PAGES === */
.legal-page{
  padding-top:48px!important;
  padding-bottom:60px!important;
}
.legal-page h1{
  font-size:42px;
  line-height:1.05;
  margin:10px 0 32px;
  color:var(--dark);
  letter-spacing:-1px;
}
.legal-content{
  max-width:820px;
}
.legal-content h2{
  font-size:24px;
  color:var(--green);
  margin:38px 0 14px;
  line-height:1.2;
}
.legal-content h3{
  font-size:18px;
  color:var(--dark);
  margin:24px 0 10px;
  font-weight:900;
}
.legal-content p{
  font-size:16px;
  line-height:1.7;
  color:#374151;
  margin:0 0 14px;
}
.legal-content ul{
  margin:0 0 16px;
  padding-left:24px;
}
.legal-content li{
  font-size:16px;
  line-height:1.7;
  color:#374151;
  margin:6px 0;
}
.legal-content a{
  color:var(--green);
  text-decoration:underline;
  font-weight:700;
}
.legal-content a:hover{
  color:var(--lime);
}
.legal-date{
  margin-top:42px!important;
  font-size:14px!important;
  color:var(--muted)!important;
  font-style:italic;
}
@media(max-width:950px){
  .legal-page{
    padding:36px 20px 48px!important;
  }
  .legal-page h1{
    font-size:32px;
    margin-bottom:24px;
  }
  .legal-content h2{
    font-size:21px;
    margin:30px 0 12px;
  }
  .legal-content h3{
    font-size:17px;
  }
  .legal-content p,
  .legal-content li{
    font-size:15px;
    line-height:1.65;
  }
}

/* === COOKIE CONSENT BANNER === */
.cookie-banner{
  position:fixed;
  bottom:0;
  left:0;
  right:0;
  z-index:3000;
  background:rgba(6,17,27,.96);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  padding:0;
  transform:translateY(100%);
  transition:transform .4s ease;
}
.cookie-banner.active{
  transform:translateY(0);
}
.cookie-inner{
  max-width:1280px;
  margin:0 auto;
  padding:20px 58px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.cookie-inner p{
  margin:0;
  font-size:14px;
  color:rgba(255,255,255,.82);
  line-height:1.5;
  flex:1;
}
.cookie-inner a{
  color:#61b900;
  text-decoration:underline;
  font-weight:700;
}
.cookie-actions{
  display:flex;
  gap:12px;
  flex-shrink:0;
}
.cookie-accept{
  padding:11px 22px!important;
  font-size:13px!important;
  border-radius:10px;
  white-space:nowrap;
}
.cookie-decline{
  background:transparent;
  border:1px solid rgba(255,255,255,.25);
  color:rgba(255,255,255,.7);
  border-radius:10px;
  padding:11px 18px;
  font-size:13px;
  font-weight:700;
  cursor:pointer;
  white-space:nowrap;
  transition:border-color .2s, color .2s;
}
.cookie-decline:hover{
  border-color:rgba(255,255,255,.5);
  color:#fff;
}
@media(max-width:950px){
  .cookie-inner{
    flex-direction:column;
    padding:18px 20px;
    gap:14px;
    text-align:center;
  }
  .cookie-inner p{
    font-size:13px;
  }
  .cookie-actions{
    width:100%;
    justify-content:center;
  }
}
/* Cookie banner active: shift WhatsApp button up */
.cookie-banner.active ~ .whatsapp-float{
  bottom:90px!important;
  transition:bottom .4s ease;
}
