/* Reset & tokens */
*{box-sizing:border-box} html,body{margin:0;padding:0}
img{max-width:100%;display:block}
:root{
  --bg:#fff8f5;
  --surface:#ffffff;
  --muted:#f7f9fc;
  --text:#263245;
  --text-soft:#4c5a73;
  --accent:#ffb703;
  --brand:#e76f51;
  --good:#2a9d8f;
  --line:#e9edf5;
  --shadow:0 18px 50px rgba(20, 20, 40, .08);
}
body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,sans-serif;line-height:1.65;color:var(--text);background:radial-gradient(1200px 600px at 80% -10%,#fff3e0,transparent 60%) ,linear-gradient(180deg,var(--bg),#fff)}
.container{width:min(1100px,92%);margin:0 auto}

/* Header */
.site-header{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);animation:fadeDown .6s ease both}
.header-wrap{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0}
.logo{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:var(--text);font-weight:900}
.logo-mark{font-size:1.35rem}
.logo-text{letter-spacing:.2px}
.main-nav{display:flex;gap:1rem;align-items:center}
.main-nav a{color:var(--text-soft);text-decoration:none;font-weight:700}
.main-nav a:hover{color:var(--text)}

/* Buttons */
.btn{display:inline-block;padding:.9rem 1.15rem;border:1px solid transparent;border-radius:1rem;text-decoration:none;font-weight:900;transition:transform .15s ease, box-shadow .15s ease}
.btn--small{padding:.5rem .8rem;font-size:.9rem;border-color:#d9e2ec}
.btn--primary{background:linear-gradient(180deg,var(--accent),#ffa726);color:#1d1300;box-shadow:var(--shadow)}
.btn--outline{border-color:#d9e2ec;color:var(--text);background:var(--surface)}
.btn:hover{transform:translateY(-1px)}
.btn--full{width:100%;text-align:center}
.btn--shine{position:relative;overflow:hidden}
.btn--shine::after{content:"";position:absolute;inset:0;transform:translateX(-120%);background:linear-gradient(100deg,transparent 0,rgba(255,255,255,.7) 50%,transparent 100%);}
.btn--shine:hover::after{animation:shine 1.1s ease}

.microcopy{font-size:.95rem;color:var(--text-soft);margin-top:.5rem}

/* Hero */
.hero{padding:2.6rem 0 1.8rem;position:relative;overflow:hidden}
.hero-wrap{display:grid;grid-template-columns:1.08fr .92fr;gap:2rem;align-items:center}
.eyebrow{font-weight:900;color:#7a8baa;letter-spacing:.08em;text-transform:uppercase;font-size:.8rem;margin-bottom:.5rem}
.glow{filter:drop-shadow(0 5px 20px rgba(231,111,81,.25))}
.title-balance{font-size:clamp(2rem,2.7vw,3rem);line-height:1.2;margin:0 0 .75rem}
.underline{background:linear-gradient(180deg,rgba(255,183,3,.3),rgba(255,183,3,.3));box-decoration-break:clone}
.lead{font-size:1.08rem;color:#314e6e;animation:fadeUp .6s .15s both}
.hero-bullets{margin:1rem 0;padding-left:1.2rem}
.hero-cta{margin-top:1rem}
.trust{display:flex;flex-wrap:wrap;gap:.5rem 1rem;margin-top:1rem}
.trust-item{font-size:.95rem;color:#5c7a99;border:1px dashed #d9e2ec;padding:.45rem .7rem;border-radius:.8rem;background:#fff}

.hero-media{min-height:320px;position:relative}
.hero-photo{width:100%;height:380px;border-radius:1.2rem;background:
  radial-gradient(100% 60% at 70% 0%, rgba(255,183,3,.25), transparent 60%),
  url('hero.jpg') center/cover, linear-gradient(180deg,#eee,#ddd);
  border:1px solid #e6edf6;box-shadow:var(--shadow);transform:translateZ(0);}
.parallax{transition:transform .6s cubic-bezier(.2,.6,.2,1)}
.hero-badges{position:absolute;left:-10px;bottom:-10px;display:flex;gap:.5rem;flex-wrap:wrap}
.badge{background:#fff;border:1px solid var(--line);border-radius:.7rem;padding:.35rem .6rem;font-weight:800;color:#344d67;box-shadow:var(--shadow)}

/* Floating blobs */
.float{position:absolute;border-radius:50%;filter:blur(30px);opacity:.45;animation:float 12s ease-in-out infinite;z-index:-1}
.float--1{width:220px;height:220px;background:#ffe0b2;top:-40px;right:-60px;animation-delay:0s}
.float--2{width:180px;height:180px;background:#ffd3c7;bottom:-40px;left:-40px;animation-delay:1.5s}
.float--3{width:160px;height:160px;background:#d7fff6;top:40%;left:45%;animation-delay:3s}

/* Sections */
section{padding:2.6rem 0}
h2{font-size:clamp(1.6rem,2.1vw,2rem);margin:.2rem 0 1rem}
.grid{display:grid;gap:1rem}
.grid-2{grid-template-columns:1fr 1fr}
.grid-3{grid-template-columns:repeat(3,1fr)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:1rem;padding:1rem;box-shadow:var(--shadow);transition:transform .2s ease, box-shadow .2s ease}
.card.lift:hover{transform:translateY(-2px);box-shadow:0 24px 60px rgba(20,20,40,.12)}
.card .subtitle{color:var(--text-soft);font-weight:700;margin:.2rem 0}

/* Checklists & steps */
.checklist{list-style:none;padding-left:0}
.checklist li{padding-left:1.3rem;position:relative;margin:.35rem 0}
.checklist li::before{content:'✓';position:absolute;left:0;top:0;color:#2a9d8f;font-weight:900}
.steps ol{margin:.5rem 0;padding-left:1.2rem}

/* Tabs */
.tabs{display:flex;gap:.5rem;margin-bottom:.8rem;flex-wrap:wrap}
.tab{padding:.55rem .9rem;border:1px solid var(--line);background:#fff;border-radius:.7rem;font-weight:800;color:#425a77;cursor:pointer;transition:background .2s}
.tab:hover{background:var(--muted)}
.tab.is-active{background:linear-gradient(180deg,#fff,#fff8f5);border-color:#ffd58a}
.panes .pane{display:none}
.panes .pane.is-active{display:block;animation:fadeUp .35s ease both}

/* Map placeholder */
.map .map-placeholder{height:340px;display:flex;flex-direction:column;align-items:center;justify-content:center;border:1px dashed #d7dfeb;border-radius:.9rem;color:#5c7a99;background:#fff}

/* FAQ */
.faq details{background:var(--surface);border:1px solid var(--line);border-radius:.8rem;padding:.75rem 1rem;margin:.6rem 0;box-shadow:var(--shadow)}
.faq summary{cursor:pointer;font-weight:900}

/* Lead form */
.lead .lead-card{background:linear-gradient(180deg,#fff,#fff8f5);border:1px solid var(--line);border-radius:1.2rem;padding:1rem;box-shadow:var(--shadow)}
.form-grid{display:grid;gap:.75rem;grid-template-columns:1fr 1fr}
label span{display:block;font-size:.95rem;color:#5c6f86;margin-bottom:.25rem}
input[type=text], input[type=tel], select{width:100%;padding:.9rem 1rem;border-radius:1rem;border:1px solid #d9e2ec;background:#ffffff;color:#102a43;transition:border-color .15s}
input[type=text]:focus, input[type=tel]:focus, select:focus{border-color:#ffc65c;outline:none}
input[type=checkbox]{transform:scale(1.2);margin-right:.5rem}
.consent{display:flex;align-items:center;gap:.5rem;margin:.75rem 0}
.form-note{color:#5c7a99;font-size:.95rem}
.form-success{margin-top:.75rem;padding:.85rem;background:#e6fff7;border:1px solid #c1f5e3;border-radius:.9rem;color:#0b6b57;animation:fadeUp .3s ease both}

/* Sticky CTA */
.sticky-cta{position:fixed;bottom:12px;left:0;right:0;display:none;justify-content:center;z-index:50}
.sticky-cta__btn{display:inline-block;padding:.9rem 1.2rem;border-radius:999px;background:linear-gradient(180deg,var(--brand),#f2846b);color:#fff;font-weight:900;text-decoration:none;box-shadow:0 12px 34px rgba(231,111,81,.35)}

/* Footer */
.site-footer{border-top:1px solid var(--line);padding:2rem 0;background:#fff}
.footer-wrap{display:grid;grid-template-columns:1.1fr .9fr .9fr;gap:1rem}
.footer-col a{color:#1f5f8b;text-decoration:none}
.footer-col a:hover{text-decoration:underline}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(14px);}
.reveal.is-visible{opacity:1;transform:none;transition:opacity .6s ease, transform .6s ease}
.parallax{transition:transform .6s cubic-bezier(.2,.6,.2,1)}

/* Animations */
@keyframes shine{from{transform:translateX(-120%)}to{transform:translateX(120%)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes fadeDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
@keyframes float{0%,100%{transform:translateY(0) translateX(0)}50%{transform:translateY(-10px) translateX(6px)}}

/* Responsive */
@media (max-width: 960px){
  .hero-wrap{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr 1fr}
}
@media (max-width: 640px){
  .main-nav{display:none}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .hero{padding-top:1.2rem}
  .sticky-cta{display:flex}
}
