:root{
  --green-deep:#232c18;--green:#333d24;--green-2:#3f4a2d;--olive:#5a6844;--sage:#8a9670;
  --terra:#a45b34;--terra-bright:#bb6c42;--terra-deep:#864825;--terra-soft:#f3e6da;
  --sun:#e0a06a;--sand:#cbb79a;--stone:#b8a684;
  --ink:#2b2820;--slate:#7c7160;--slate-2:#544c3f;
  --cream:#f7f2e9;--cream-2:#efe7d7;--cream-3:#e9dfcb;--card:#fffdf8;
  --line:#e7dcc7;--line-2:#dccdb2;--ok:#5c7d3a;
  --shadow:0 30px 70px -34px rgba(45,35,18,.42);--shadow-sm:0 12px 30px -16px rgba(45,35,18,.28);
  --shadow-terra:0 18px 42px -16px rgba(134,72,37,.5);--shadow-green:0 18px 42px -16px rgba(35,44,24,.5);
  --radius:16px;--radius-lg:24px;--maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);background:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
h1,h2,h3,h4,.display{font-family:'Fraunces','Georgia',serif;line-height:1.08;letter-spacing:-.015em;font-weight:600}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.wrap.narrow{max-width:900px}
section{padding:clamp(58px,7.4vw,104px) 0}
.soft{background:var(--cream-2)}
.warm{background:linear-gradient(180deg,#f4ebda,var(--cream))}
.muted{color:var(--slate)}
.center{text-align:center;margin-top:32px}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:.72rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--terra-deep);background:var(--terra-soft);padding:8px 17px;border-radius:100px;border:1px solid rgba(164,91,52,.16);font-family:'Inter'}
.eyebrow.light{color:#e9c9ac;background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.15)}
.eyebrow svg{color:var(--terra)}

/* icons */
.ic-svg{width:24px;height:24px;flex:0 0 auto}
.ic-sm{width:18px;height:18px;flex:0 0 auto}
.ic-card{width:26px;height:26px;stroke-width:1.7}
.ic-chk{width:18px;height:18px;color:var(--ok);flex:0 0 auto}

/* reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.16,.84,.44,1),transform .8s cubic-bezier(.16,.84,.44,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important}}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-18px)}}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(164,91,52,.5)}70%{box-shadow:0 0 0 15px rgba(164,91,52,0)}}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-weight:600;font-family:'Inter',sans-serif;font-size:1rem;padding:14px 27px;border-radius:100px;cursor:pointer;border:0;transition:transform .18s,box-shadow .18s,filter .18s;will-change:transform}
.btn-call{background:linear-gradient(135deg,var(--terra-bright),var(--terra-deep));color:#fff;box-shadow:var(--shadow-terra);padding-left:8px}
.btn-call:hover{filter:brightness(1.06)}
.btn-call svg{width:34px;height:34px;padding:8px;background:rgba(255,255,255,.22);border-radius:50%;box-sizing:border-box}
.btn:hover{transform:translateY(-3px)}
.btn-cta{background:linear-gradient(135deg,var(--terra-bright),var(--terra-deep));color:#fff;box-shadow:var(--shadow-terra)}
.btn-cta:hover{filter:brightness(1.06)}
.btn-primary{background:linear-gradient(135deg,var(--green-2),var(--green-deep));color:#fff;box-shadow:var(--shadow-green)}
.btn-primary:hover{filter:brightness(1.08)}
.btn-light{background:#fff;color:var(--terra-deep);box-shadow:0 14px 30px -14px rgba(0,0,0,.3)}
.btn-light:hover{background:var(--terra-soft)}
.btn-dark{background:var(--green-deep);color:#fff}
.btn-dark:hover{background:var(--green)}
.btn-block{width:100%}
.btn.pulse{animation:pulse 2.6s infinite}
.cta-row{display:flex;flex-wrap:wrap;gap:13px;margin-top:28px}

/* nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(247,242,233,.86);backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid transparent;transition:box-shadow .25s,border-color .25s}
.nav.scrolled{box-shadow:0 6px 26px -18px rgba(45,35,18,.5);border-color:var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:104px}
.brandlink{display:flex;align-items:center}
.brand-logo{height:88px;width:auto}
.brand-fallback{display:none;align-items:center;gap:11px;font-family:'Fraunces';font-weight:700;font-size:1.15rem;color:var(--green)}
.brand-fallback .mark{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:var(--green);color:#fff;font-size:.95rem}
.brand-fallback small{display:block;font-family:'Inter';font-weight:500;font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--terra);margin-top:-1px}
.nav-links{display:flex;align-items:center;gap:26px}
.nav-links a.link{font-weight:500;color:var(--slate-2);font-size:.95rem;position:relative;padding:4px 0}
.nav-links a.link::after{content:'';position:absolute;left:0;bottom:-3px;width:0;height:2px;background:var(--terra);transition:width .25s}
.nav-links a.link:hover,.nav-links a.link.active{color:var(--green)}
.nav-links a.link:hover::after,.nav-links a.link.active::after{width:100%}
.navcall{padding:11px 21px}
.nav-toggle{display:none;background:none;border:0;color:var(--green);cursor:pointer;padding:6px}
@media(max-width:900px){
  .nav-toggle{display:inline-flex}
  .nav-links{position:absolute;top:100%;left:0;right:0;background:var(--cream);flex-direction:column;align-items:stretch;gap:0;padding:8px 24px 18px;border-bottom:1px solid var(--line);box-shadow:var(--shadow-sm);display:none}
  .nav.open .nav-links{display:flex}
  .nav-links a.link{padding:14px 0;border-bottom:1px solid var(--line)}
  .navcall{margin-top:12px;justify-content:center}
  .brand-logo{height:66px}
  .nav-inner{height:86px}
}

/* hero — desert gradient, no external image */
.hero{position:relative;color:#fff;overflow:hidden;
  background:
   radial-gradient(1100px 620px at 78% -8%, rgba(224,160,106,.4), transparent 55%),
   radial-gradient(760px 520px at 10% 118%, rgba(90,104,68,.5), transparent 60%),
   linear-gradient(158deg,#2b3419 0%,#232c18 46%,#2c2a1c 100%)}
.hero::before{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.5;
  background:radial-gradient(circle at 78% 16%, rgba(224,160,106,.5), transparent 34%)}
.hero::after{content:'';position:absolute;left:0;right:0;bottom:0;height:120px;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,transparent,rgba(35,44,24,.0)),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'%3E%3Cpath d='M0 90 L120 60 L260 96 L420 40 L560 88 L720 30 L880 84 L1040 44 L1200 82 L1200 120 L0 120 Z' fill='%23232c18' opacity='.5'/%3E%3C/svg%3E") bottom/cover no-repeat}
.herogrid{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center;padding-top:clamp(48px,5vw,78px);padding-bottom:clamp(80px,8vw,124px)}
.hero h1{font-size:clamp(2.3rem,5.2vw,3.7rem);font-weight:600;margin:20px 0 18px;letter-spacing:-.02em}
.hero h1 .hl{color:var(--sun);font-style:italic}
.hero .sub{font-size:clamp(1.04rem,1.6vw,1.22rem);color:#e5dcc9;max-width:44ch}
.trust-row{display:flex;flex-wrap:wrap;gap:16px 26px;margin-top:34px}
.trust-row .t{display:flex;align-items:center;gap:9px;font-size:.92rem;color:#e5dcc9;font-weight:500}
.trust-row .t svg{color:var(--sun)}
@media(max-width:940px){.herogrid{grid-template-columns:1fr}.hero-card{order:-1;max-width:560px}}
.hero-badge{position:absolute;right:-40px;top:-30px;width:340px;opacity:.08;z-index:0;pointer-events:none}
.hero-card{background:var(--card);color:var(--ink);border-radius:20px;overflow:hidden;box-shadow:var(--shadow);position:relative;border:1px solid rgba(255,255,255,.5)}
.hc-head{position:relative;background:linear-gradient(140deg,var(--green),var(--green-2));color:#fff;padding:24px 28px 20px}
.hc-head::after{content:'';position:absolute;left:0;right:0;bottom:0;height:3px;background:linear-gradient(90deg,var(--terra-bright),var(--terra-deep))}
.hc-head .tag{display:inline-block;font-family:'Inter';font-weight:700;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:#3a1c00;background:linear-gradient(135deg,var(--sun),var(--terra));padding:5px 13px;border-radius:100px;margin-bottom:10px}
.hc-head h3{font-size:1.42rem;font-weight:600}
.hc-head p{color:#d9e0cc;font-size:.9rem;margin-top:4px}
.hero-card form{padding:20px 28px 26px}

/* form fields */
.field{margin-top:13px}
.field label{font-size:.8rem;font-weight:600;color:var(--slate);display:block;margin-bottom:5px}
.field input,.field select{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:11px;font-family:inherit;font-size:.98rem;background:var(--cream);transition:border .15s,box-shadow .15s}
.field input:focus,.field select:focus{outline:none;border-color:var(--terra);box-shadow:0 0 0 3px rgba(164,91,52,.15);background:#fff}
.form-fine{font-size:.72rem;color:var(--slate);margin-top:10px;text-align:center}

/* trust strip */
.strip{background:var(--green-deep);color:#d8dcc6;margin-top:-1px}
.strip .wrap{display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;padding:22px 0}
.strip .s{display:flex;align-items:center;gap:10px;font-weight:500;font-size:.94rem}
.strip .s svg{color:var(--sun)}

/* section heads */
.head{text-align:center;max-width:780px;margin:0 auto 50px}
.head h2{font-size:clamp(1.9rem,4vw,2.7rem);margin:14px 0 12px;font-weight:600}
.head p{color:var(--slate);font-size:1.07rem}

/* cards */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:900px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid{grid-template-columns:1fr}}
.card{position:relative;display:block;border:1px solid var(--line);border-radius:var(--radius);padding:32px 28px;background:var(--card);overflow:hidden;transition:transform .2s,box-shadow .2s,border-color .2s;color:inherit}
.card::before{content:'';position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--terra-bright),var(--terra-deep));transform:scaleX(0);transform-origin:left;transition:transform .3s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--line-2)}
.card:hover::before{transform:scaleX(1)}
.card .ic{position:relative;width:60px;height:60px;border-radius:16px;display:grid;place-items:center;color:#fff;background:linear-gradient(140deg,var(--olive),var(--green));margin-bottom:17px;box-shadow:0 14px 26px -12px rgba(35,44,24,.55);transition:transform .25s}
.card:nth-child(3n+2) .ic{background:linear-gradient(140deg,var(--terra-bright),var(--terra-deep));box-shadow:0 14px 26px -12px rgba(134,72,37,.5)}
.card:nth-child(3n) .ic{background:linear-gradient(140deg,var(--sage),var(--olive));box-shadow:0 14px 26px -12px rgba(90,104,68,.5)}
.card:hover .ic{transform:scale(1.06) rotate(-4deg)}
.card h3{font-size:1.24rem;margin-bottom:8px;font-weight:600}
.card p{color:var(--slate);font-size:.95rem}
.cardlink{display:inline-flex;align-items:center;gap:6px;margin-top:15px;color:var(--terra-deep);font-weight:600;font-family:'Inter';font-size:.9rem}
.cardlink svg{transition:transform .2s}
.card:hover .cardlink svg{transform:translateX(4px)}

/* sub-page hero */
.subhero{position:relative;color:#fff;overflow:hidden;background:
  radial-gradient(880px 480px at 86% -14%, rgba(224,160,106,.34), transparent 56%),
  radial-gradient(680px 440px at 4% 122%, rgba(90,104,68,.5), transparent 60%),
  linear-gradient(158deg,#2b3419,#232c18)}
.subhero .wrap{padding-top:clamp(36px,4vw,58px);padding-bottom:clamp(48px,6vw,76px)}
.subhero h1{font-size:clamp(2rem,4.4vw,3.1rem);font-weight:600;margin:14px 0 14px;max-width:20ch}
.subhero h1 .hl{color:var(--sun);font-style:italic}
.subhero .lead{color:#e3dac7;font-size:clamp(1.02rem,1.5vw,1.2rem);max-width:64ch}
.crumbs{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:.85rem;color:#b9c2a3;margin-bottom:6px}
.crumbs a{color:#b9c2a3}.crumbs a:hover{color:#fff}
.crumbs i{opacity:.5;font-style:normal}
.crumbs span{color:#e6ecd6}

/* prose + lists */
.prose p{margin-bottom:17px;color:var(--slate-2);font-size:1.06rem}
.h2sm{font-size:clamp(1.4rem,2.7vw,1.85rem);margin:36px 0 16px;font-weight:600}
.checks{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:12px 24px;margin:6px 0}
@media(max-width:600px){.checks{grid-template-columns:1fr}}
.checks li{display:flex;align-items:flex-start;gap:10px;color:var(--slate-2)}
.chips{display:flex;flex-wrap:wrap;gap:11px;margin-top:6px}
.chips.center{justify-content:center}
.chip{display:inline-flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:100px;padding:10px 17px;font-weight:500;font-size:.9rem;color:var(--green);box-shadow:var(--shadow-sm);transition:transform .16s,border-color .16s,color .16s}
.chip:hover{transform:translateY(-3px);border-color:var(--terra);color:var(--terra-deep)}
.chip svg{color:var(--terra)}
.pins{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}
.pinrow{display:inline-flex;align-items:center;gap:8px;color:var(--slate);font-weight:500;font-size:.95rem;background:var(--cream-2);border-radius:10px;padding:9px 15px}
.pinrow svg{color:var(--terra)}

/* faq */
.faq{margin-top:6px}
.faq .q{border:1px solid var(--line);border-radius:13px;padding:2px 22px;margin-bottom:12px;background:var(--card);transition:border-color .2s,box-shadow .2s}
.faq .q[open]{border-color:var(--line-2);box-shadow:var(--shadow-sm)}
.faq summary{font-family:'Fraunces';font-weight:600;font-size:1.08rem;cursor:pointer;padding:17px 0;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-size:1.5rem;color:var(--terra);transition:transform .25s;font-family:'Inter'}
.faq .q[open] summary::after{transform:rotate(45deg)}
.faq .q p{color:var(--slate);padding-bottom:19px}

/* how-it-works steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:780px){.steps{grid-template-columns:1fr}}
.step{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:34px 30px;box-shadow:var(--shadow-sm);overflow:hidden}
.step .num{position:absolute;top:16px;right:22px;font-family:'Fraunces';font-weight:600;font-size:2.7rem;color:var(--cream-3);line-height:1}
.step .ic{position:relative;width:56px;height:56px;border-radius:15px;display:grid;place-items:center;color:#fff;background:linear-gradient(140deg,var(--olive),var(--green));box-shadow:0 12px 24px -12px rgba(35,44,24,.5);margin-bottom:16px}
.step:nth-child(2) .ic{background:linear-gradient(140deg,var(--terra-bright),var(--terra-deep))}
.step:nth-child(3) .ic{background:linear-gradient(140deg,var(--sage),var(--olive))}
.step h3{font-size:1.2rem;margin-bottom:8px;font-weight:600}
.step p{color:var(--slate);font-size:.96rem}

/* why split + stats panel */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
@media(max-width:880px){.split{grid-template-columns:1fr;gap:38px}}
.why-list{display:grid;gap:18px;margin-top:24px}
.why-item{display:flex;gap:14px}
.why-item .chk{flex:0 0 auto;width:34px;height:34px;border-radius:10px;background:var(--terra-soft);color:var(--terra-deep);display:grid;place-items:center}
.why-item h4{font-size:1.1rem;margin-bottom:2px;font-weight:600}
.why-item p{color:var(--slate);font-size:.95rem}
.why-visual{position:relative;background:linear-gradient(158deg,var(--green),var(--green-deep));border-radius:24px;padding:44px 38px 38px;color:#fff;box-shadow:var(--shadow);overflow:hidden}
.why-visual::after{content:'';position:absolute;top:-90px;right:-90px;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(224,160,106,.42),transparent 70%);filter:blur(18px)}
.why-visual .ring{position:absolute;border:1px solid rgba(255,255,255,.09);border-radius:50%}
.why-visual .r1{width:240px;height:240px;top:-80px;right:-80px}.why-visual .r2{width:160px;height:160px;bottom:-50px;left:-40px}
.why-visual .big{position:relative;font-family:'Fraunces';font-size:clamp(2.1rem,5vw,3rem);font-weight:600;font-style:italic;color:var(--sun)}
.why-visual .divider{height:1px;background:rgba(255,255,255,.14);margin:22px 0}
.why-visual .row{position:relative;display:flex;justify-content:space-between;align-items:baseline;padding:9px 0}
.why-visual .row b{font-family:'Fraunces';font-size:1.6rem;font-weight:600}.why-visual .row span{color:#c9d1b4;font-size:.92rem}
.why-visual .ftag{position:relative;margin-top:22px;font-family:'Fraunces';font-weight:600;font-size:1.05rem;font-style:italic;color:#fff}
.why-visual .ftag span{color:var(--sun)}

/* cta band */
.ctaband-wrap{padding:clamp(42px,6vw,76px) 0}
.cta-band{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--terra-deep),var(--terra-bright));color:#fff;text-align:center;border-radius:26px;padding:60px 26px;box-shadow:var(--shadow-terra)}
.cta-band::before{content:'';position:absolute;inset:0;background:radial-gradient(600px 300px at 18% 8%,rgba(255,255,255,.2),transparent 60%);pointer-events:none}
.cta-band h2{position:relative;font-size:clamp(1.8rem,3.8vw,2.6rem);font-weight:600}
.cta-band p{position:relative;color:#f6e8dc;margin:12px auto 26px;max-width:54ch;font-size:1.06rem}
.cta-band .cta-row{position:relative;justify-content:center}

/* contact */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:start}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}}
.contact-card{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:30px 28px;box-shadow:var(--shadow-sm)}
.contact-card h3{font-size:1.36rem;margin-bottom:6px;font-weight:600}
.contact-info{display:grid;gap:14px}
.info{display:flex;align-items:center;gap:14px;background:var(--cream-2);border:1px solid var(--line);border-radius:14px;padding:16px 18px;color:inherit}
.info .ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--olive),var(--green));flex:0 0 auto}
.info:nth-child(2) .ic{background:linear-gradient(135deg,var(--terra-bright),var(--terra-deep))}
.info:nth-child(3) .ic{background:linear-gradient(135deg,var(--sage),var(--olive))}
.info b{font-family:'Fraunces';display:block;font-size:1rem;font-weight:600}
.info span{color:var(--slate);font-size:.92rem}

/* footer */
.footer{background:var(--green-deep);color:#b3bb9d;padding:60px 0 26px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:38px}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr;gap:30px}}
.footer h5{color:#fff;font-family:'Fraunces';font-size:1rem;margin-bottom:14px;font-weight:600}
.footer a{color:#b3bb9d;display:block;padding:4px 0;font-size:.93rem;transition:color .15s}
.footer a:hover{color:var(--sun)}
.foot-brand{display:flex;align-items:center;gap:12px;color:#fff;font-family:'Fraunces';font-weight:600;font-size:1.15rem;margin-bottom:14px}
.foot-brand .fmark{width:44px;height:44px;border-radius:50%;background:#fff;display:grid;place-items:center;overflow:hidden;flex:0 0 auto}
.foot-brand .fmark img{width:44px;height:44px;object-fit:contain}
.foot-brand .fmark .fb{display:none;font-size:.85rem;color:var(--green);font-weight:700}
.foot-about{max-width:38ch;line-height:1.7}
.foot-call{color:#fff!important;font-weight:600;display:inline-flex!important;align-items:center;gap:8px;margin-top:12px}
.foot-call svg{color:var(--sun)}
.foot-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;border-top:1px solid rgba(255,255,255,.1);margin-top:38px;padding-top:22px;font-size:.85rem}
.foot-fine{font-size:.76rem;color:#8b9373;margin-top:14px;max-width:78ch;line-height:1.6}

/* lead-form inline success */
.form-done{display:none;text-align:center;padding:18px 6px}
.form-done .tick{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;margin:0 auto 12px;color:#fff;background:linear-gradient(135deg,#6fa03f,#4d7a2a)}
.form-done h4{font-size:1.24rem;margin-bottom:6px;font-weight:600}
.form-done p{color:var(--slate);font-size:.95rem}
form.sent{display:none}
.form-done.show{display:block;animation:riseIn .4s ease}
@keyframes riseIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* quiz popup */
.quiz-overlay{position:fixed;inset:0;z-index:120;display:none;align-items:center;justify-content:center;padding:18px;
  background:rgba(30,26,14,.6);backdrop-filter:blur(6px);opacity:0;transition:opacity .25s}
.quiz-overlay.open{display:flex;opacity:1}
.quiz-modal{position:relative;width:100%;max-width:520px;background:var(--card);border-radius:24px;overflow:hidden;
  box-shadow:0 40px 90px -30px rgba(30,26,14,.7);transform:translateY(18px) scale(.98);transition:transform .3s cubic-bezier(.16,.84,.44,1)}
.quiz-overlay.open .quiz-modal{transform:none}
.quiz-head{position:relative;background:linear-gradient(150deg,var(--green),var(--green-2));color:#fff;padding:24px 26px 18px}
.quiz-head .kicker{font-size:.72rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--sun);display:flex;align-items:center;gap:7px}
.quiz-head h3{font-family:'Fraunces';font-size:1.4rem;margin-top:6px;font-weight:600}
.quiz-head p{color:#d9e0cc;font-size:.9rem;margin-top:3px}
.quiz-close{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;border:0;cursor:pointer;
  background:rgba(255,255,255,.14);color:#fff;display:grid;place-items:center;transition:background .15s}
.quiz-close:hover{background:rgba(255,255,255,.26)}
.quiz-prog{height:4px;background:rgba(255,255,255,.16);border-radius:4px;margin-top:16px;overflow:hidden}
.quiz-prog span{display:block;height:100%;width:25%;background:linear-gradient(90deg,var(--sun),var(--terra));border-radius:4px;transition:width .35s}
.quiz-body{padding:24px 26px 28px}
.quiz-step{display:none}.quiz-step.active{display:block;animation:riseIn .35s ease}
.quiz-step h4{font-family:'Fraunces';font-size:1.18rem;margin-bottom:15px;font-weight:600}
.quiz-opts{display:grid;gap:10px}
.quiz-opts.two{grid-template-columns:1fr 1fr}
@media(max-width:440px){.quiz-opts.two{grid-template-columns:1fr}}
.qopt{display:flex;align-items:center;gap:11px;width:100%;text-align:left;border:1.5px solid var(--line);background:var(--cream);
  border-radius:13px;padding:14px 15px;cursor:pointer;font-family:inherit;font-size:.98rem;font-weight:500;color:var(--ink);transition:border .15s,background .15s,transform .12s}
.qopt:hover{border-color:var(--terra);background:#fff;transform:translateY(-2px)}
.qopt .qic{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;color:#fff;background:linear-gradient(140deg,var(--olive),var(--green));flex:0 0 auto}
.qopt.sel{border-color:var(--terra);background:var(--terra-soft);box-shadow:0 0 0 3px rgba(164,91,52,.14)}
.quiz-field{margin-top:12px}
.quiz-field label{font-size:.8rem;font-weight:600;color:var(--slate);display:block;margin-bottom:5px}
.quiz-field input,.quiz-field select{width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:11px;font-family:inherit;font-size:1rem;background:var(--cream)}
.quiz-field input:focus,.quiz-field select:focus{outline:none;border-color:var(--terra);box-shadow:0 0 0 3px rgba(164,91,52,.15);background:#fff}
.quiz-actions{display:flex;gap:10px;margin-top:18px}
.quiz-back{background:none;border:0;color:var(--slate);font-weight:600;font-family:'Inter';cursor:pointer;padding:13px 6px}
.quiz-next{flex:1}
.quiz-trust{display:flex;align-items:center;justify-content:center;gap:7px;margin-top:14px;color:var(--slate);font-size:.8rem}
.quiz-trust svg{color:var(--ok)}
.quiz-done{display:none;text-align:center;padding:8px 4px 6px}
.quiz-done.show{display:block;animation:riseIn .4s ease}
.quiz-done .tick{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;margin:4px auto 14px;color:#fff;background:linear-gradient(135deg,#6fa03f,#4d7a2a);box-shadow:0 14px 30px -10px rgba(77,122,42,.55)}
.quiz-done h3{font-family:'Fraunces';font-size:1.46rem;margin-bottom:8px;font-weight:600}
.quiz-done p{color:var(--slate);font-size:1rem;max-width:36ch;margin:0 auto 18px}
.quiz-tab{position:fixed;right:-1px;top:50%;transform:translateY(-50%);writing-mode:vertical-rl;z-index:90;
  background:linear-gradient(135deg,var(--terra-bright),var(--terra-deep));color:#fff;border:0;cursor:pointer;
  font-family:'Inter';font-weight:600;font-size:.84rem;letter-spacing:.05em;padding:16px 9px;border-radius:12px 0 0 12px;box-shadow:-6px 0 20px -8px rgba(134,72,37,.55)}
@media(max-width:720px){.quiz-tab{display:none}}

/* sticky mobile call */
.mobile-call{display:none}
@media(max-width:720px){
  .mobile-call{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:60;box-shadow:0 -8px 30px -10px rgba(0,0,0,.35)}
  .mobile-call a{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:15px;font-family:'Inter';font-weight:600;color:#fff}
  .mobile-call .c{background:var(--green)}.mobile-call .q{background:linear-gradient(135deg,var(--terra-bright),var(--terra-deep))}
  body{padding-bottom:56px}
}
