*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Segoe UI',Arial,sans-serif;background:#F8F9F0;color:#1B4332;line-height:1.6}
:root{
  --green:#7BC67E;
  --forest:#1B4332;
  --forest-mid:#2D6A4F;
  --off-white:#F8F9F0;
  --cream:#EEF4EE;
  --accent:#D8EDDA;
  --white:#ffffff;
  --gray:#52796F;
  --gray-light:#f0f4f0;
  --border:#B7D8BB;
  --shadow:0 4px 24px rgba(27,67,50,0.10);
  --shadow-lg:0 8px 48px rgba(27,67,50,0.16);
  --radius:12px;
  --radius-lg:20px;
  --transition:0.3s ease;
}
a{color:var(--forest-mid);text-decoration:none}
a:hover{color:var(--forest)}
img{display:none}
ul{list-style:none}

#progress-bar{position:fixed;top:0;left:0;height:3px;width:0%;background:linear-gradient(90deg,var(--green),var(--forest-mid));z-index:9999;transition:width 0.1s linear}

header{position:sticky;top:0;z-index:900;background:rgba(248,249,240,0.96);backdrop-filter:blur(8px);border-bottom:1px solid transparent;transition:border-color var(--transition),box-shadow var(--transition)}
header.scrolled{border-color:var(--border);box-shadow:var(--shadow)}
.header-inner{max-width:1200px;margin:0 auto;padding:0 24px;height:68px;display:flex;align-items:center;justify-content:space-between}
.logo{font-size:1.4rem;font-weight:800;color:var(--forest);letter-spacing:-0.5px}
.logo span{color:var(--green)}
nav{display:flex;gap:32px;align-items:center}
nav a{font-size:0.95rem;font-weight:500;color:var(--forest);transition:color var(--transition)}
nav a:hover{color:var(--green)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.burger span{display:block;width:24px;height:2px;background:var(--forest);transition:all var(--transition)}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Hero — particles */
.hero{min-height:100vh;display:flex;align-items:center;padding:80px 24px;position:relative;overflow:hidden;background:var(--forest)}
.particles-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.particle{position:absolute;border-radius:50%;background:var(--green);opacity:0;animation:floatUp var(--dur,8s) var(--delay,0s) ease-in-out infinite}
@keyframes floatUp{0%{transform:translateY(0) scale(1);opacity:0}20%{opacity:var(--op,0.35)}80%{opacity:var(--op,0.35)}100%{transform:translateY(-100vh) scale(0.5);opacity:0}}
.hero-inner{position:relative;z-index:2;max-width:1200px;margin:0 auto;display:grid;grid-template-columns:3fr 2fr;gap:64px;align-items:center}
.hero-badge{display:inline-block;background:rgba(123,198,126,0.2);border:1px solid rgba(123,198,126,0.4);color:var(--green);padding:6px 18px;border-radius:50px;font-size:0.85rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;margin-bottom:24px}
.hero h1{font-size:clamp(2.2rem,5.5vw,3.8rem);font-weight:800;color:#fff;line-height:1.15;margin-bottom:20px;letter-spacing:-1px}
.hero h1 em{font-style:normal;color:var(--green)}
.hero-sub{font-size:1.1rem;color:rgba(255,255,255,0.78);max-width:520px;margin-bottom:36px;line-height:1.75}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:50px;font-size:1rem;font-weight:600;cursor:pointer;border:2px solid transparent;transition:all var(--transition)}
.btn-primary{background:var(--green);color:var(--forest);border-color:var(--green)}
.btn-primary:hover{background:#5ab05e;border-color:#5ab05e}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,0.5)}
.btn-outline:hover{background:rgba(255,255,255,0.1)}
.hero-side{display:flex;flex-direction:column;gap:16px}
.hero-stat-pill{background:rgba(255,255,255,0.07);border:1px solid rgba(123,198,126,0.25);border-radius:var(--radius);padding:20px 24px}
.hero-stat-pill .num{font-size:2rem;font-weight:800;color:var(--green);line-height:1}
.hero-stat-pill .lbl{font-size:0.85rem;color:rgba(255,255,255,0.6);margin-top:4px}

/* Sticky dots nav */
.dots-nav{position:fixed;right:24px;top:50%;transform:translateY(-50%);z-index:800;display:flex;flex-direction:column;gap:10px}
.dot-link{width:10px;height:10px;border-radius:50%;background:rgba(27,67,50,0.25);border:2px solid var(--forest-mid);transition:all var(--transition);cursor:pointer;display:block}
.dot-link.active{background:var(--green);border-color:var(--green);transform:scale(1.3)}

/* Stats */
.stats{background:var(--forest);padding:72px 24px}
.stats-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat-card{background:rgba(255,255,255,0.07);border:1px solid rgba(123,198,126,0.2);border-radius:var(--radius);padding:32px 20px;text-align:center}
.stat-num{font-size:2.6rem;font-weight:800;color:var(--green);letter-spacing:-1px;line-height:1}
.stat-suffix{font-size:1.6rem;font-weight:800;color:var(--green)}
.stat-label{margin-top:8px;font-size:0.88rem;color:rgba(255,255,255,0.55)}

/* Sections */
section{padding:96px 24px}
.section-tag{display:inline-block;background:var(--accent);color:var(--forest-mid);font-size:0.8rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;padding:6px 16px;border-radius:50px;margin-bottom:16px}
.section-title{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;color:var(--forest);line-height:1.2;margin-bottom:16px;letter-spacing:-0.5px}
.section-sub{font-size:1.05rem;color:var(--gray);line-height:1.75}
.centered{text-align:center;margin:0 auto}
.centered .section-sub{margin:0 auto 48px}

/* Asymmetric layout */
.asym-row{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr;gap:64px;align-items:center}
.asym-row.reverse{grid-template-columns:1fr 2fr}
.asym-row.reverse .asym-visual{order:-1}

/* About */
.about{background:var(--off-white)}
.about-text .section-sub{margin-top:16px;margin-bottom:24px}
.bar-chart-demo{width:100%;max-width:340px;padding:24px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.bar-chart-demo h4{font-size:0.8rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--gray);margin-bottom:18px}
.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.bar-label{font-size:0.82rem;color:var(--forest);min-width:80px;font-weight:600}
.bar-track{flex:1;height:10px;background:var(--accent);border-radius:5px;overflow:hidden}
.bar-fill{height:100%;border-radius:5px;background:linear-gradient(90deg,var(--green),var(--forest-mid));width:0%;transition:width 1.4s ease}
.bar-pct{font-size:0.8rem;color:var(--gray);min-width:34px;text-align:right}

/* Progress rings */
.prog-rings-wrap{max-width:1100px;margin:48px auto 0;display:grid;grid-template-columns:repeat(4,1fr);gap:28px;text-align:center}
.prog-ring-item{}
.prog-ring-svg{display:block;margin:0 auto 12px}
.prog-ring-bg{stroke:var(--accent)}
.prog-ring-circle{stroke:var(--green);fill:none;stroke-linecap:round;transform:rotate(-90deg);transform-origin:50% 50%;transition:stroke-dashoffset 1.4s ease}
.prog-ring-label{font-size:1rem;font-weight:700;color:var(--forest);margin-bottom:4px}
.prog-ring-pct{font-size:1.4rem;font-weight:800;color:var(--green);margin-bottom:6px}
.prog-ring-desc{font-size:0.85rem;color:var(--gray);line-height:1.5}

/* How */
.how{background:var(--cream)}
.steps-asym{max-width:1100px;margin:48px auto 0;display:grid;grid-template-columns:1fr 1fr;gap:28px}
.step{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:32px}
.step-num{width:48px;height:48px;background:var(--forest);color:var(--green);font-size:1.2rem;font-weight:800;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.step h3{font-size:1.05rem;font-weight:700;color:var(--forest);margin-bottom:10px}
.step p{font-size:0.92rem;color:var(--gray);line-height:1.7}

/* Cards */
.cards-grid{max-width:1100px;margin:48px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;transition:transform var(--transition),box-shadow var(--transition)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.card-icon{width:52px;height:52px;border-radius:12px;background:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.card h3{font-size:1.05rem;font-weight:700;color:var(--forest);margin-bottom:10px}
.card p{font-size:0.93rem;color:var(--gray);line-height:1.7}

/* Testimonials */
.testimonials{background:var(--forest)}
.testimonials .section-title{color:#fff}
.testimonials .section-sub{color:rgba(255,255,255,0.65)}
.testi-grid{max-width:1100px;margin:48px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testi-card{background:rgba(255,255,255,0.06);border:1px solid rgba(123,198,126,0.15);border-radius:var(--radius-lg);padding:32px;transition:background var(--transition)}
.testi-card:hover{background:rgba(255,255,255,0.09)}
.stars{color:#F5C842;font-size:1rem;letter-spacing:2px;margin-bottom:14px}
.testi-quote{font-size:0.93rem;color:rgba(255,255,255,0.82);line-height:1.8;font-style:italic;margin-bottom:22px}
.testi-author{display:flex;align-items:center;gap:12px}
.avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--forest-mid));display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:0.95rem;flex-shrink:0}
.testi-name{font-weight:700;color:#fff;font-size:0.92rem}
.testi-role{font-size:0.8rem;color:rgba(255,255,255,0.45)}

/* FAQ */
.faq{background:var(--off-white)}
.faq-list{max-width:760px;margin:48px auto 0;display:flex;flex-direction:column;gap:10px}
.faq-item{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.faq-q{width:100%;text-align:left;background:none;border:none;padding:18px 22px;font-size:0.98rem;font-weight:600;color:var(--forest);cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background var(--transition)}
.faq-q:hover{background:var(--cream)}
.faq-icon{font-size:1.3rem;color:var(--green);transition:transform var(--transition);flex-shrink:0}
.faq-q.open .faq-icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height 0.4s ease}
.faq-a.open{max-height:300px}
.faq-a p{padding:0 22px 18px;font-size:0.93rem;color:var(--gray);line-height:1.8}

/* Contact */
.contact{background:var(--cream)}
.contact-form-wrap{max-width:600px;margin:48px auto 0}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:0.88rem;font-weight:600;color:var(--forest);margin-bottom:6px}
.form-group input,.form-group textarea{width:100%;padding:12px 15px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:0.97rem;color:var(--forest);background:var(--white);outline:none;transition:border-color var(--transition),box-shadow var(--transition);font-family:inherit}
.form-group input:focus,.form-group textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(123,198,126,0.18)}
.form-group textarea{min-height:118px;resize:vertical}
.field-error{display:none;font-size:0.8rem;color:#c0392b;margin-top:4px}
.field-error.show{display:block}
.btn-submit{width:100%;padding:14px;font-size:1rem;font-weight:700;background:linear-gradient(135deg,var(--forest-mid),var(--forest));color:#fff;border:none;border-radius:50px;cursor:pointer;transition:opacity var(--transition),transform var(--transition)}
.btn-submit:hover{opacity:0.88;transform:translateY(-2px)}

/* CTA */
.cta-banner{background:linear-gradient(135deg,var(--green),var(--forest-mid));padding:80px 24px;text-align:center}
.cta-banner h2{font-size:clamp(1.8rem,4vw,2.5rem);font-weight:800;color:var(--forest);margin-bottom:14px}
.cta-banner p{font-size:1.05rem;color:rgba(27,67,50,0.75);margin-bottom:32px;max-width:540px;margin-left:auto;margin-right:auto}

/* Footer */
footer.full-footer{background:var(--forest);padding:64px 24px 0}
.footer-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(123,198,126,0.15)}
.footer-brand .logo{color:#fff;margin-bottom:14px;display:block;font-size:1.3rem}
.footer-brand p{font-size:0.88rem;color:rgba(255,255,255,0.5);line-height:1.7;margin-bottom:14px}
.footer-contact-info p{font-size:0.85rem;color:rgba(255,255,255,0.45);margin-bottom:5px}
.footer-contact-info a{color:rgba(255,255,255,0.45)}
.footer-col h4{font-size:0.82rem;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:rgba(255,255,255,0.35);margin-bottom:16px}
.footer-col ul li{margin-bottom:9px}
.footer-col ul li a{font-size:0.88rem;color:rgba(255,255,255,0.6);transition:color var(--transition)}
.footer-col ul li a:hover{color:var(--green)}
.footer-bottom{max-width:1200px;margin:0 auto;padding:18px 0;text-align:center;font-size:0.83rem;color:rgba(255,255,255,0.3)}
footer.min-footer{background:var(--forest);padding:26px 24px;text-align:center}
footer.min-footer p{font-size:0.83rem;color:rgba(255,255,255,0.4);margin-bottom:5px}
footer.min-footer a{color:rgba(255,255,255,0.5)}
footer.min-footer a:hover{color:var(--green)}

/* Cookie banner */
#cookie-banner{position:fixed;bottom:0;left:0;right:0;background:var(--forest);border-top:2px solid var(--green);padding:18px 24px;z-index:800;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
#cookie-banner p{font-size:0.88rem;color:rgba(255,255,255,0.82);flex:1;min-width:200px}
#cookie-banner a{color:var(--green)}
.cookie-btns{display:flex;gap:10px;flex-wrap:wrap}
.cookie-btns button{padding:8px 20px;border-radius:50px;font-size:0.88rem;font-weight:600;cursor:pointer;border:2px solid transparent;transition:all var(--transition)}
.btn-accept{background:var(--green);color:var(--forest);border-color:var(--green)}
.btn-accept:hover{background:#5ab05e}
.btn-decline{background:transparent;color:rgba(255,255,255,0.65);border-color:rgba(255,255,255,0.25)}
.btn-decline:hover{border-color:#fff;color:#fff}

/* Legal */
.legal-header{padding:26px 24px;background:var(--white);border-bottom:1px solid var(--border)}
.legal-header .logo{font-size:1.3rem;font-weight:800;color:var(--forest)}
.legal-header .logo span{color:var(--green)}
.legal-page{max-width:800px;margin:0 auto;padding:52px 24px}
.legal-page h1{font-size:1.9rem;font-weight:800;color:var(--forest);margin-bottom:8px}
.legal-page .lead{font-size:1.02rem;color:var(--gray);margin-bottom:32px;padding-bottom:22px;border-bottom:1px solid var(--border)}
.legal-page h2{font-size:1.15rem;font-weight:700;color:var(--forest);margin:28px 0 10px}
.legal-page p,.legal-page li{font-size:0.95rem;color:var(--gray);line-height:1.8;margin-bottom:10px}
.legal-page ul{padding-left:18px}
.legal-page ul li{list-style:disc}
.legal-page table{width:100%;border-collapse:collapse;margin:18px 0;font-size:0.88rem}
.legal-page table th{background:var(--accent);color:var(--forest);font-weight:700;padding:11px 13px;text-align:left;border:1px solid var(--border)}
.legal-page table td{padding:10px 13px;border:1px solid var(--border);color:var(--gray)}

/* Thank you */
.thankyou-page{min-height:100vh;display:flex;flex-direction:column}
.thankyou-content{flex:1;display:flex;align-items:center;justify-content:center;padding:60px 24px}
.thankyou-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:52px 44px;text-align:center;max-width:500px;width:100%;box-shadow:var(--shadow-lg)}
.thankyou-icon{width:76px;height:76px;background:linear-gradient(135deg,var(--green),var(--forest-mid));border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 22px}
.thankyou-card h1{font-size:1.75rem;font-weight:800;color:var(--forest);margin-bottom:12px}
.thankyou-card p{font-size:0.97rem;color:var(--gray);line-height:1.7;margin-bottom:26px}

/* Breadcrumb */
.breadcrumb{font-size:0.86rem;color:var(--gray);margin-bottom:24px}
.breadcrumb a{color:var(--green)}

/* About page */
.about-hero{padding:72px 24px 56px;background:var(--forest);text-align:center}
.about-hero .pill{display:inline-block;background:rgba(123,198,126,0.2);color:var(--green);font-size:0.8rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:6px 18px;border-radius:50px;margin-bottom:18px}
.about-hero h1{font-size:clamp(1.9rem,4.5vw,3rem);font-weight:800;color:#fff;line-height:1.2;margin-bottom:14px}
.about-hero p{font-size:1.05rem;color:rgba(255,255,255,0.72);max-width:560px;margin:0 auto}

/* Fade up */
.fade-up{opacity:0;transform:translateY(28px);transition:opacity 0.6s ease,transform 0.6s ease}
.fade-up.visible{opacity:1;transform:none}

/* Tabs */
.tabs-wrap{max-width:860px;margin:48px auto 0}
.tab-btns{display:flex;border-bottom:2px solid var(--border);position:relative;margin-bottom:0}
.tab-btn{padding:12px 24px;font-size:0.95rem;font-weight:600;color:var(--gray);background:none;border:none;cursor:pointer;transition:color var(--transition)}
.tab-btn.active{color:var(--forest)}
.tab-indicator{position:absolute;bottom:-2px;left:0;height:2px;background:var(--green);transition:left 0.3s ease,width 0.3s ease}
.tab-panel{display:none;padding:28px 0 0}
.tab-panel.active{display:block}
.tab-panel p{font-size:0.97rem;color:var(--gray);line-height:1.8}

@media(max-width:768px){
  nav{display:none;position:absolute;top:68px;left:0;right:0;background:var(--off-white);flex-direction:column;padding:18px 24px;gap:14px;border-bottom:1px solid var(--border);box-shadow:var(--shadow)}
  nav.open{display:flex}
  .burger{display:flex}
  .hero-inner{grid-template-columns:1fr}
  .hero-side{flex-direction:row;flex-wrap:wrap}
  .hero-stat-pill{flex:1;min-width:140px}
  .stats-inner{grid-template-columns:1fr 1fr}
  .asym-row,.asym-row.reverse{grid-template-columns:1fr}
  .asym-row.reverse .asym-visual{order:0}
  .steps-asym{grid-template-columns:1fr}
  .cards-grid{grid-template-columns:1fr}
  .testi-grid{grid-template-columns:1fr}
  .prog-rings-wrap{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .dots-nav{display:none}
  #cookie-banner{flex-direction:column;align-items:flex-start}
}
@media(max-width:480px){
  .stats-inner{grid-template-columns:1fr}
  .prog-rings-wrap{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}
