/* ============================================================
   SunPath Solar — Lead funnel (DEMO) by Earvin Laureano
   Built on the Funnel Builder Master System.
   Brand: sky-blue + sun-amber + savings-green.
   ============================================================ */
:root{
  --sky:#0a6ce0; --sky-d:#0850ab; --night:#0a2540;
  --sun:#f5a623; --sun-d:#e08e0b; --green:#16a34a; --green-d:#15803d;
  --ink:#10243b; --slate:#56708a; --muted:#8aa0b6; --line:#dde7f0;
  --cloud:#f3f8fd; --sky-tint:#e7f2fe; --white:#fff;
  --r:18px; --shadow:0 22px 55px rgba(10,37,64,.16); --shadow-sm:0 10px 30px rgba(10,37,64,.08);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',sans-serif;color:var(--ink);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;line-height:1.08;letter-spacing:-.02em}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
.narrow{max-width:780px;margin:0 auto;padding:0 24px}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;background:var(--sun);color:var(--night);font-weight:800;font-size:1.04rem;padding:1.1rem 2.1rem;border-radius:12px;border:none;cursor:pointer;transition:.18s;box-shadow:0 12px 26px rgba(245,166,35,.36)}
.btn:hover{background:var(--sun-d);transform:translateY(-2px)}
.btn.full{width:100%}
.btn.lg{font-size:1.14rem;padding:1.25rem 2.6rem}
.btn-sky{background:var(--sky);color:#fff;box-shadow:0 12px 26px rgba(10,108,224,.3)}
.btn-sky:hover{background:var(--sky-d)}
.btn-ghost{background:transparent;color:var(--sky);border:1.5px solid var(--line);box-shadow:none}
.btn-ghost:hover{background:var(--sky-tint);border-color:var(--sky)}
.pill{display:inline-flex;align-items:center;gap:.5rem;background:var(--sky-tint);color:var(--sky-d);border:1px solid rgba(10,108,224,.2);font-size:.8rem;font-weight:700;letter-spacing:.02em;padding:.45rem 1.1rem;border-radius:100px}
.pill.green{background:rgba(22,163,74,.1);color:var(--green-d);border-color:rgba(22,163,74,.25)}
.eyebrow{display:inline-block;font-weight:800;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sky)}

/* demo bar */
.demo-bar{background:var(--night);color:#bcd6f0;font-size:.82rem;text-align:center;padding:.6rem 1rem;font-weight:600}
.demo-bar strong{color:#fff}
.demo-bar a{color:var(--sun);text-decoration:underline;text-underline-offset:2px;font-weight:700}

/* header / nav */
header.nav{background:#fff;border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;padding:1rem 24px;max-width:1140px;margin:0 auto}
.logo{display:flex;align-items:center;gap:.55rem;font-weight:800;font-size:1.3rem;color:var(--night)}
.logo .m{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--sun),var(--sky));color:#fff;display:grid;place-items:center;font-size:1.05rem}
.logo span{color:var(--sky)}
.nav-phone{font-weight:700;color:var(--slate);font-size:.92rem}
.nav-phone b{color:var(--ink)}
@media(max-width:680px){.nav-phone{display:none}}

/* hero / opt-in */
.hero{background:linear-gradient(165deg,#eaf4ff 0%,#f3f8fd 55%,#fff 100%);overflow:hidden;position:relative}
.hero-grid{display:grid;grid-template-columns:1.06fr .94fr;gap:3rem;align-items:center;padding:3.5rem 0 4rem}
.hero h1{font-size:clamp(2.3rem,5vw,3.7rem);color:var(--night)}
.hero h1 em{font-style:normal;color:var(--sky);position:relative;white-space:nowrap}
.hero h1 .hl{background:linear-gradient(180deg,transparent 62%,rgba(245,166,35,.4) 0);padding:0 .1em}
.hero .lede{font-size:1.16rem;color:var(--slate);margin:1.3rem 0 1.6rem;max-width:30rem}
.hero ul.ticks{list-style:none;display:grid;gap:.6rem;margin-bottom:1.6rem}
.hero ul.ticks li{display:flex;gap:.6rem;align-items:center;font-weight:600;color:var(--ink)}
.hero ul.ticks .c{flex:none;width:24px;height:24px;border-radius:50%;background:rgba(22,163,74,.13);color:var(--green-d);display:grid;place-items:center;font-weight:800;font-size:.78rem}
.trust-row{display:flex;gap:1.6rem;flex-wrap:wrap;align-items:center;margin-top:1.4rem}
.trust-row .stars{color:var(--sun);letter-spacing:.08em}
.trust-row div{font-size:.86rem;color:var(--slate)}
.trust-row strong{color:var(--ink)}

/* form card */
.form-card{background:#fff;border-radius:22px;box-shadow:var(--shadow);border:1px solid var(--line);padding:2rem;position:relative}
.form-card .fc-top{background:var(--sky);color:#fff;margin:-2rem -2rem 1.4rem;padding:1.1rem 2rem;border-radius:22px 22px 0 0;text-align:center}
.form-card .fc-top b{font-size:1.12rem;font-weight:800;display:block}
.form-card .fc-top span{font-size:.86rem;opacity:.9}
label{display:block;font-size:.82rem;font-weight:700;color:var(--slate);margin:.85rem 0 .35rem}
input,select{width:100%;padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:11px;font-size:1rem;font-family:inherit;color:var(--ink);background:#fff;transition:.15s}
input:focus,select:focus{outline:none;border-color:var(--sky);box-shadow:0 0 0 3px rgba(10,108,224,.13)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.form-card .btn{margin-top:1.2rem}
.fine{font-size:.76rem;color:var(--muted);text-align:center;margin-top:.85rem}
@media(max-width:860px){.hero-grid{grid-template-columns:1fr;padding:2.5rem 0}}

/* logos / as-seen */
.asseen{padding:1.8rem 0;border-bottom:1px solid var(--line);background:#fff}
.asseen-in{display:flex;align-items:center;justify-content:center;gap:2.4rem;flex-wrap:wrap}
.asseen-in span:first-child{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.asseen-in span{font-weight:800;color:#b8c8d8;font-size:1.05rem}

/* sections */
section{padding:4.5rem 0}
.sec-head{text-align:center;max-width:42rem;margin:0 auto 2.8rem}
.sec-head h2{font-size:clamp(1.9rem,3.8vw,2.7rem);color:var(--night)}
.sec-head h2 em{font-style:normal;color:var(--sky)}
.sec-head p{color:var(--slate);margin-top:.9rem;font-size:1.06rem}
.cloud{background:var(--cloud)}
.night-sec{background:var(--night);color:#dbe8f5}
.night-sec .sec-head h2{color:#fff}
.night-sec .sec-head h2 em{color:var(--sun)}
.night-sec .sec-head p{color:#a9c2db}

/* steps / how it works */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
@media(max-width:820px){.steps{grid-template-columns:1fr}}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.8rem;box-shadow:var(--shadow-sm)}
.step .n{width:44px;height:44px;border-radius:12px;background:var(--sky-tint);color:var(--sky);font-weight:800;font-size:1.1rem;display:grid;place-items:center;margin-bottom:1rem}
.step h3{font-size:1.2rem;color:var(--night);margin-bottom:.35rem}
.step p{color:var(--slate);font-size:.94rem}

/* stat band */
.stats{display:flex;justify-content:center;gap:3.4rem;flex-wrap:wrap}
.stats .s{text-align:center}
.stats .s b{display:block;font-size:2.6rem;font-weight:800;color:var(--sun)}
.stats .s span{font-size:.92rem;color:#a9c2db}

/* feature split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:3.2rem;align-items:center}
.split img{width:100%;border-radius:20px;box-shadow:var(--shadow);aspect-ratio:5/4;object-fit:cover}
.split h2{font-size:clamp(1.8rem,3.6vw,2.5rem);color:var(--night)}
.split h2 em{font-style:normal;color:var(--sky)}
.split p{color:var(--slate);margin-top:1rem}
.split ul{list-style:none;margin-top:1.3rem;display:grid;gap:.85rem}
.split li{display:flex;gap:.7rem;align-items:flex-start;color:var(--ink)}
.split li b{color:var(--night)}
.split .c{flex:none;width:26px;height:26px;border-radius:50%;background:rgba(22,163,74,.13);color:var(--green-d);display:grid;place-items:center;font-weight:800;font-size:.82rem;margin-top:.15rem}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:2rem}.split.rev .img-col{order:-1}}

/* testimonials */
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
@media(max-width:820px){.t-grid{grid-template-columns:1fr}}
.t{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.7rem;box-shadow:var(--shadow-sm)}
.t .stars{color:var(--sun);margin-bottom:.6rem}
.t p{font-size:.96rem;color:var(--ink)}
.t .who{display:flex;align-items:center;gap:.75rem;margin-top:1.1rem}
.t .who img{width:46px;height:46px;border-radius:50%;object-fit:cover}
.t .who b{font-size:.92rem;display:block}
.t .who span{font-size:.82rem;color:var(--muted)}

/* fit report card */
.fit{max-width:560px;margin:0 auto;background:#fff;border:2px solid var(--sky);border-radius:24px;box-shadow:var(--shadow);overflow:hidden}
.fit .fit-top{background:linear-gradient(135deg,var(--sky),var(--sky-d));color:#fff;padding:1.6rem;text-align:center}
.fit .fit-top b{font-size:1.4rem}
.fit .fit-body{padding:1.8rem}
.fit .fit-row{display:flex;align-items:center;gap:.9rem;padding:.8rem 0;border-bottom:1px solid var(--line)}
.fit .fit-row:last-child{border-bottom:none}
.fit .fit-row .ic{flex:none;width:40px;height:40px;border-radius:11px;background:rgba(22,163,74,.12);color:var(--green-d);display:grid;place-items:center;font-weight:800}
.fit .fit-row b{display:block;color:var(--night)}
.fit .fit-row span{font-size:.88rem;color:var(--slate)}

/* urgency */
.why-now{background:rgba(245,166,35,.1);border:1px solid rgba(245,166,35,.35);border-radius:var(--r);padding:1.4rem 1.6rem;display:flex;gap:1rem;align-items:flex-start;max-width:48rem;margin:0 auto}
.why-now .ic{flex:none;font-size:1.6rem}
.why-now b{color:var(--sun-d)}
.why-now p{color:var(--ink);font-size:.96rem}

/* faq */
.faq{max-width:760px;margin:0 auto}
.q{background:#fff;border:1px solid var(--line);border-radius:14px;margin-bottom:.8rem;overflow:hidden}
.q button{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:1.15rem 1.4rem;font-weight:700;font-size:1rem;color:var(--ink);display:flex;justify-content:space-between;gap:1rem;align-items:center;font-family:inherit}
.q .ans{max-height:0;overflow:hidden;transition:max-height .3s ease;color:var(--slate)}
.q .ans p{padding:0 1.4rem 1.2rem}
.q.open .ans{max-height:260px}
.q .plus{color:var(--sky);font-size:1.3rem;transition:transform .25s}
.q.open .plus{transform:rotate(45deg)}

/* cta band */
.cta-band{background:linear-gradient(135deg,var(--sky),var(--sky-d));color:#fff;text-align:center;padding:4.5rem 0}
.cta-band h2{font-size:clamp(2rem,4vw,2.9rem);color:#fff}
.cta-band h2 em{font-style:normal;color:var(--sun)}
.cta-band p{color:#d3e6fb;max-width:34rem;margin:1rem auto 2rem;font-size:1.08rem}
.cta-band .btn{background:var(--sun);color:var(--night)}

/* footer */
footer.ft{background:var(--night);color:#8fabc7;text-align:center;padding:2.6rem 0;font-size:.85rem}
footer.ft a{color:#fff;text-decoration:underline}

/* ===== two-pane layout (booking / confirmation) ===== */
.lp{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}
@media(max-width:860px){.lp{grid-template-columns:1fr}}
.lp .aside{position:relative;color:#fff;padding:3rem;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}
.lp .aside img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.lp .aside:after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(10,108,224,.85),rgba(10,37,64,.92));z-index:1}
.lp .aside>*{position:relative;z-index:2}
.lp .panel{background:var(--cloud);padding:3rem;display:flex;align-items:center;justify-content:center}
.bk{width:100%;max-width:32rem}
.alist{list-style:none;display:grid;gap:.85rem;margin-top:1.5rem}
.alist li{display:flex;gap:.7rem;align-items:flex-start}
.alist .c{flex:none;width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.2);display:grid;place-items:center;font-weight:800;font-size:.8rem;margin-top:.1rem}
.astat{display:flex;gap:2rem;border-top:1px solid rgba(255,255,255,.22);padding-top:1.4rem}
.astat strong{font-size:1.7rem;display:block}
.astat span{font-size:.82rem;color:#cfe0f3}
.steps-mini{display:flex;gap:.5rem;margin-bottom:1.3rem;font-size:.78rem;font-weight:700;color:var(--muted)}
.steps-mini .on{color:var(--sky)}

/* slot picker */
.slots{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem;margin:.5rem 0 1rem}
.slot{border:1.5px solid var(--line);background:#fff;border-radius:10px;padding:.7rem;text-align:center;cursor:pointer;font-weight:700;font-size:.88rem;transition:.15s}
.slot:hover{border-color:var(--sky)}
.slot.sel{background:var(--sky);color:#fff;border-color:var(--sky)}
.day-label{font-weight:800;color:var(--night);margin:.8rem 0 .3rem}

/* reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
