:root{
  --ocean:#0b3d52;      /* deep ocean blue */
  --ocean-2:#11536e;
  --teal:#1b9aaa;       /* island teal accent */
  --sand:#f4ece0;       /* warm sand */
  --sand-2:#efe4d3;
  --char:#23282d;       /* volcanic charcoal */
  --gray:#5b6670;
  --concrete:#d9d6d0;
  --sun:#e87a3e;        /* sunset orange CTA */
  --sun-2:#d96828;
  --white:#ffffff;
  --maxw:1280px;
  --radius:14px;
  --shadow:0 10px 30px rgba(11,61,82,.12);
  --font:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  --display:"Sora","Inter",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--char);background:var(--white);line-height:1.6;font-size:17px}
img{max-width:100%;display:block}
a{color:var(--teal);text-decoration:none}
h1,h2,h3{font-family:var(--display);line-height:1.12;color:var(--ocean);font-weight:700;letter-spacing:-.02em}
h1{font-size:clamp(2.1rem,5vw,3.4rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.4rem)}
h3{font-size:1.25rem}
p{margin:0 0 1rem}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:72px 0}
.section--sand{background:var(--sand)}
.section--ocean{background:linear-gradient(135deg,var(--ocean),var(--ocean-2));color:#eaf3f6}
.section--ocean h2,.section--ocean h3{color:#fff}
.eyebrow{text-transform:uppercase;letter-spacing:.14em;font-size:.8rem;font-weight:700;color:var(--teal);margin-bottom:.6rem}
.lead{font-size:1.15rem;color:var(--gray);max-width:60ch}
.section--ocean .lead{color:#cfe3ea}

/* buttons */
.btn{display:inline-block;padding:14px 26px;border-radius:50px;font-weight:700;font-size:1rem;transition:.18s;cursor:pointer;border:0}
.btn--primary{background:var(--sun);color:#fff;box-shadow:0 8px 20px rgba(232,122,62,.35)}
.btn--primary:hover{background:var(--sun-2);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.7)}
.btn--ghost:hover{background:#fff;color:var(--ocean)}
.btn--dark{background:var(--ocean);color:#fff}
.btn--dark:hover{background:var(--ocean-2)}

/* header */
.topbar{background:var(--char);color:#cdd4da;font-size:.85rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;padding-top:7px;padding-bottom:7px;flex-wrap:wrap;gap:6px}
.topbar a{color:#fff;font-weight:600}
header.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border-bottom:1px solid #eee}
.nav .container{display:flex;align-items:center;justify-content:space-between;padding-top:14px;padding-bottom:14px;gap:16px}
.brand{display:flex;align-items:center;gap:12px;font-weight:900;color:var(--ocean);font-size:1.15rem;letter-spacing:-.02em}
.brand .mark{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,var(--ocean),var(--teal));color:#fff;display:grid;place-items:center;font-weight:900;font-size:1.1rem}
.brand small{display:block;font-size:.62rem;letter-spacing:.18em;color:var(--teal);font-weight:700}
.logo-img{height:56px;width:auto}
.menu{display:flex;gap:22px;align-items:center;list-style:none}
.menu>li{position:relative}
.menu>li>a{color:var(--char);font-weight:600;font-size:.97rem;padding:8px 0}
.menu>li>a:hover{color:var(--teal)}
.menu .has>a::after{content:"▾";font-size:.7rem;margin-left:4px;color:var(--gray)}
.submenu{position:absolute;top:100%;left:-12px;min-width:230px;background:#fff;border:1px solid #eee;border-radius:12px;box-shadow:var(--shadow);padding:8px;display:none}
.menu .has:hover .submenu{display:block}
.submenu a{display:block;padding:9px 12px;border-radius:8px;color:var(--char);font-size:.92rem}
.submenu a:hover{background:var(--sand);color:var(--ocean)}
.nav-cta{display:flex;align-items:center;gap:12px}
.nav-call{font-weight:800;color:var(--ocean);white-space:nowrap}
.hamb{display:none;font-size:1.6rem;background:none;border:0;color:var(--ocean)}

/* hero */
.hero{position:relative;color:#fff;background:var(--char);overflow:hidden}
.hero .imgslot{position:absolute;inset:0;z-index:0}
.hero .container{position:relative;z-index:1;padding-top:90px;padding-bottom:90px}
.hero h1{color:#fff;margin-bottom:18px}
.hero p{font-size:1.18rem;color:#eef3f5;margin-bottom:28px;max-width:60ch}
.hero--full{min-height:80vh;display:flex;align-items:center}
.hero--full h1{font-size:clamp(2.5rem,5.5vw,4rem)}
.hero-copy{max-width:760px}
.eyebrow--sun{color:var(--sun)}
.btn--white{background:#fff;color:var(--ocean)}
.btn--white:hover{background:var(--sand)}
.estimate-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:start}
.cbox input{width:auto;flex:none;margin:0}
@media(max-width:880px){.estimate-grid{grid-template-columns:1fr}.hero--full{min-height:auto}}
.hero .actions{display:flex;gap:14px;flex-wrap:wrap}
.trust{display:flex;gap:26px;flex-wrap:wrap;margin-top:34px;color:#cfe3ea;font-weight:600;font-size:.95rem}
.trust span{display:flex;align-items:center;gap:8px}
.trust b{color:var(--sun);font-size:1.05rem}

/* grid + cards */
.grid{display:grid;gap:22px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.card{background:#fff;border:1px solid #eee;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.18s}
.card:hover{transform:translateY(-4px)}
.card .imgslot{aspect-ratio:16/10;background:linear-gradient(135deg,var(--concrete),#c4c0b8);display:grid;place-items:center;color:#7d8893;font-weight:700;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase}
.card .body{padding:20px}
.card h3{margin-bottom:8px}
.card p{color:var(--gray);font-size:.96rem;margin-bottom:14px}
.card a.more{font-weight:700}

/* feature split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split .imgslot{aspect-ratio:4/3;border-radius:var(--radius);background:linear-gradient(135deg,var(--concrete),#bdb9b1);display:grid;place-items:center;color:#7d8893;font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.85rem}
.card .ph{aspect-ratio:16/10;width:100%;object-fit:cover;display:block}
.split .ph{aspect-ratio:4/3;width:100%;object-fit:cover;border-radius:var(--radius);display:block;box-shadow:var(--shadow)}
.checks{list-style:none;display:grid;gap:10px;margin:18px 0}
.checks li{display:flex;gap:10px;align-items:flex-start}
.checks li::before{content:"✔";color:var(--teal);font-weight:900}

/* form */
.formwrap{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:28px;border:1px solid #eee}
.formwrap h3{font-size:1.55rem;text-align:center;margin-bottom:4px}
.formwrap .formsub{text-align:center}
.estimate-grid .ph{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow);margin-top:10px;display:block}
.field{margin-bottom:14px}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:5px}
.field input,.field textarea{width:100%;padding:12px 14px;border:1px solid #d6d6d6;border-radius:10px;font-size:1rem;font-family:inherit}
.field textarea{min-height:110px;resize:vertical}
.checkrow{display:flex;gap:24px;flex-wrap:wrap}
.checkrow label{display:inline-flex;align-items:center;gap:7px;font-weight:500;cursor:pointer}
.checkrow input{width:auto;flex:none;margin:0}
.cbox{flex:1;min-width:92px;display:flex;gap:8px;align-items:center;justify-content:center;border:1px solid #d6d6d6;border-radius:10px;padding:11px 10px;font-weight:600;font-size:.9rem;cursor:pointer}
.cbox:hover{border-color:var(--teal)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.formsub{color:#52606b;font-size:.93rem;margin:2px 0 18px;font-weight:500}
.opt{color:#9aa3ab;font-weight:500;font-size:.8rem}
.formdisc{font-size:.76rem;color:#9aa3ab;text-align:center;margin-top:14px;line-height:1.5}
.hp{position:absolute;left:-9999px}
@media(max-width:560px){.frow{grid-template-columns:1fr}}

/* faq */
.faq details{background:#fff;border:1px solid #eee;border-radius:12px;padding:16px 20px;margin-bottom:12px}
.faq summary{font-weight:700;color:var(--ocean);cursor:pointer;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--teal);font-weight:900}
.faq details[open] summary::after{content:"–"}
.faq p{margin-top:12px;color:var(--gray)}

/* footer */
footer.foot{background:var(--char);color:#aeb7bf;padding:56px 0 26px;font-size:.93rem}
footer.foot h4{color:#fff;margin-bottom:14px;font-size:1rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px}
.foot-grid a{color:#aeb7bf;display:block;padding:3px 0}
.foot-grid a:hover{color:#fff}
.foot-bottom{border-top:1px solid #3a4046;margin-top:34px;padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:#7e8890}

/* misc */
.center{text-align:center}
.mt{margin-top:24px}
.areas-list{columns:3;column-gap:24px}
.areas-list a{padding:6px 0;display:block}

@media(max-width:880px){
  .menu{display:none}
  .hamb{display:block}
  .grid-3,.grid-2{grid-template-columns:1fr}
  .split{grid-template-columns:1fr;gap:26px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .areas-list{columns:2}
}

/* ===== v2 redesign ===== */
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}
.chip{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.3);color:#fff;padding:7px 14px;border-radius:50px;font-size:.84rem;font-weight:600}
.chip b{color:var(--sun)}
.hero .formwrap{color:var(--char)}
.section--stats{padding:36px 0;background:#fff;border-bottom:1px solid #eee}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat b{display:block;font-family:var(--display);font-weight:800;font-size:clamp(1.7rem,4vw,2.5rem);color:var(--ocean);line-height:1}
.stat span{display:block;margin-top:7px;font-size:.82rem;color:var(--gray);font-weight:600;text-transform:uppercase;letter-spacing:.07em}
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.quote{background:#fff;border:1px solid #eee;border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}
.quote .stars{color:#f5a623;letter-spacing:2px}
.quote p{font-size:1.02rem;margin:12px 0 16px;color:var(--char)}
.quote .who{display:flex;align-items:center;gap:12px;font-weight:700;color:var(--ocean)}
.quote .av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--ocean),var(--teal));color:#fff;display:grid;place-items:center;font-weight:800;flex:none}
.quote small{display:block;color:var(--gray);font-weight:500;font-size:.78rem}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:1fr;gap:12px}
.gallery img{width:100%;height:100%;aspect-ratio:1/1;object-fit:cover;border-radius:12px;display:block}
.gallery img:first-child{grid-column:span 2;grid-row:span 2}
@media(max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:26px}
  .stats{grid-template-columns:repeat(2,1fr);gap:20px}
  .quotes{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .gallery img:first-child{grid-column:span 2;grid-row:auto}
}
