/* ════════════════════════════════════════════════════════════════════
   PORTFOLIO HOME REALTY — DESIGN SYSTEM  ·  "Editorial Coastal Luxury"
   One stylesheet that (a) powers the redesigned homepage natively and
   (b) re-skins every legacy page via design-token + font overrides.
   Loaded LAST in <head> so it wins the cascade.
   ════════════════════════════════════════════════════════════════════ */

/* ── New palette + legacy token remap ─────────────────────────────── */
:root{
  /* New semantic palette */
  --paper:#F7F3EC;          /* warm bone background        */
  --paper-2:#EFE9DC;        /* deeper sand (tinted bands)  */
  --paper-3:#E7DFCF;
  --ink:#211C17;            /* warm near-black             */
  --ink-soft:#41382F;       /* warm body text              */
  --night:#1B1814;          /* dark-section background     */
  --night-2:#13110E;
  --clay:#BC5B36;           /* primary terracotta accent   */
  --clay-dark:#9C4A2B;
  --clay-tint:#F3E0D5;
  --clay-mid:#E1B69F;
  --sage:#566F4F;           /* secondary green             */
  --sage-tint:#E7EDE1;
  --gold:#C2A06A;           /* luxury highlight            */
  --gold-soft:#E9DCC2;
  --line:#E3DBCC;           /* hairline on paper           */
  --line-2:#D6CBB6;

  /* ── Legacy tokens remapped onto new palette (cascade reskin) ── */
  --orange:var(--clay); --orange-dark:var(--clay-dark);
  --orange-light:var(--clay-tint); --orange-mid:var(--clay-mid);
  --charcoal:var(--ink);
  --body:var(--ink-soft); --muted:#8C8475; --subtle:#B4AB99;
  --white:#fff; --off-white:#FBF8F2;
  --gray-1:var(--paper-2); --gray-2:var(--line); --gray-3:var(--line-2);
  --green:var(--sage); --green-light:var(--sage-tint);
  --blue:#3C6076; --blue-light:#E9F0F1;

  /* Geometry + depth */
  --radius:7px; --radius-lg:13px; --radius-xl:20px;
  --shadow:0 2px 18px rgba(33,28,23,.07);
  --shadow-lg:0 18px 60px rgba(33,28,23,.13);

  /* Typography */
  --font-display:'Fraunces','Cormorant Garamond',Georgia,serif;
  --font-body:'Hanken Grotesk',system-ui,-apple-system,sans-serif;
  --nav-h:74px;
  --section-pad:84px;
}

/* ── Base ─────────────────────────────────────────────────────────── */
html{font-size:17px;scroll-behavior:smooth}
html body{
  font-family:var(--font-body)!important;
  color:var(--ink-soft)!important;
  background:var(--paper)!important;
  line-height:1.72;
  -webkit-font-smoothing:antialiased;
  letter-spacing:.002em;
}
/* faint paper grain for atmosphere */
html body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
}
body>*{position:relative;z-index:1}

h1,h2,h3,h4,h5,h6{
  font-family:var(--font-display)!important;
  color:var(--ink);
  line-height:1.08;
  letter-spacing:-.018em;
  font-weight:430;
  font-optical-sizing:auto;
}
h1{font-size:clamp(2.5rem,5.4vw,4.5rem)}
h2{font-size:clamp(1.85rem,3.4vw,2.95rem);font-weight:440}
h3{font-size:clamp(1.1rem,1.8vw,1.35rem);font-weight:500}
p{line-height:1.78}
strong,b{color:var(--ink);font-weight:600}
em{font-style:italic}
a{transition:color .2s,background .2s,border-color .2s}
::selection{background:var(--clay);color:#fff}
*:focus-visible{outline:2px solid var(--clay);outline-offset:3px}
img{max-width:100%}

/* ── Layout helpers (shared with legacy) ──────────────────────────── */
.container{max-width:1180px;margin:0 auto;padding:0 2rem}
.section{padding:var(--section-pad) 0}
.section-tinted{background:var(--paper-2)!important}
.section-dark{background:var(--night)!important}
.section-orange{background:var(--clay)!important}
.text-center{text-align:center}
/* reveal is opt-in: only hidden once JS confirms it can reveal them */
html.reveal-on .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
html.reveal-on .reveal.visible{opacity:1;transform:none}

/* Eyebrow / tag */
.tag,.eyebrow{
  display:inline-flex;align-items:center;gap:7px;
  font-family:var(--font-body)!important;
  font-size:.7rem!important;font-weight:600!important;text-transform:uppercase;
  letter-spacing:.18em!important;padding:5px 13px;border-radius:100px;
}
.eyebrow{padding:0;letter-spacing:.24em;color:var(--clay);background:none}
.tag-orange{background:var(--clay-tint)!important;color:var(--clay-dark)!important}
.tag-green{background:var(--sage-tint)!important;color:var(--sage)!important}
.tag-gray{background:var(--paper-3)!important;color:var(--muted)!important}
.tag-white{background:rgba(255,255,255,.1)!important;color:rgba(255,255,255,.82)!important;border:1px solid rgba(255,255,255,.22)!important}

/* ── Buttons (force new font + shape) ─────────────────────────────── */
.btn-primary,.btn-secondary,.btn-white,.btn-ghost-white,.hero-card-cta,.nav-cta,.form-submit{
  font-family:var(--font-body)!important;font-weight:600!important;letter-spacing:.01em;text-decoration:none!important;
}
.btn-primary{
  background:var(--clay)!important;color:#fff!important;border:none!important;
  padding:14px 30px!important;border-radius:100px!important;font-size:.9rem!important;
  box-shadow:0 10px 26px -10px rgba(188,91,54,.7)!important;
  display:inline-flex;align-items:center;gap:9px;cursor:pointer;transition:all .25s!important;
}
.btn-primary:hover{background:var(--clay-dark)!important;transform:translateY(-2px)!important;box-shadow:0 16px 34px -12px rgba(188,91,54,.8)!important}
.btn-secondary{
  background:transparent!important;color:var(--ink)!important;
  border:1.5px solid var(--line-2)!important;padding:13px 26px!important;border-radius:100px!important;font-size:.9rem!important;
  display:inline-flex;align-items:center;gap:8px;transition:all .25s!important;
}
.btn-secondary:hover{border-color:var(--clay)!important;color:var(--clay)!important;background:var(--clay-tint)!important}
.btn-white{background:var(--paper)!important;color:var(--clay-dark)!important;padding:14px 30px!important;border-radius:100px!important;font-size:.9rem!important;display:inline-flex;align-items:center;gap:9px;transition:all .25s!important}
.btn-white:hover{background:#fff!important;transform:translateY(-2px)!important}
.btn-ghost-white{background:transparent!important;color:rgba(255,255,255,.8)!important;border:1.5px solid rgba(255,255,255,.28)!important;padding:13px 26px!important;border-radius:100px!important;font-size:.88rem!important;display:inline-flex;align-items:center;gap:8px;transition:all .25s!important}
.btn-ghost-white:hover{color:#fff!important;border-color:rgba(255,255,255,.6)!important;background:rgba(255,255,255,.06)!important}

/* ════════════════════════════════════════════════════════════════════
   NAVIGATION  (new markup uses .site-nav; also hardens legacy <nav>)
   ════════════════════════════════════════════════════════════════════ */
.announce{
  background:var(--night)!important;color:rgba(255,255,255,.74)!important;
  font-family:var(--font-body)!important;font-size:.76rem!important;font-weight:500!important;
  letter-spacing:.01em;padding:10px 1rem!important;text-align:center;
  border-bottom:1px solid rgba(255,255,255,.07)!important;
}
.announce a{color:var(--gold)!important;font-weight:600!important;text-decoration:none}
.announce a:hover{color:#fff!important}

nav,.site-nav{
  position:sticky;top:0;z-index:200;height:var(--nav-h);
  display:flex;align-items:center;gap:1rem;padding:0 2rem!important;
  background:rgba(247,243,236,.82)!important;backdrop-filter:blur(16px) saturate(1.2);
  -webkit-backdrop-filter:blur(16px) saturate(1.2);
  border-bottom:1px solid var(--line)!important;
}
.nav-logo{flex-shrink:0;line-height:0;display:flex;align-items:center}
.nav-logo img{height:46px!important;width:auto}
.nav-links{display:flex;align-items:center;gap:.1rem;list-style:none;margin:0 0 0 auto!important;padding:0}
.nav-links a{
  font-family:var(--font-body)!important;color:var(--ink-soft)!important;
  font-size:.82rem!important;font-weight:500!important;letter-spacing:.01em;
  padding:8px 13px!important;border-radius:8px;text-decoration:none;position:relative;
}
.nav-links a::after{content:"";position:absolute;left:13px;right:13px;bottom:4px;height:1.5px;background:var(--clay);transform:scaleX(0);transform-origin:left;transition:transform .25s}
.nav-links a:hover{color:var(--ink)!important;background:transparent!important}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-phone{
  display:flex;align-items:center;gap:6px;color:var(--ink)!important;
  font-family:var(--font-body)!important;font-size:.82rem!important;font-weight:600!important;
  padding:8px 14px!important;border:1.5px solid var(--line-2)!important;border-radius:100px;text-decoration:none;white-space:nowrap;
}
.nav-phone:hover{border-color:var(--sage)!important;color:var(--sage)!important;background:none!important}
.nav-cta{
  background:var(--clay)!important;color:#fff!important;padding:9px 20px!important;
  border-radius:100px;font-size:.82rem!important;text-decoration:none;white-space:nowrap;
  box-shadow:0 8px 20px -8px rgba(188,91,54,.7)!important;transition:all .25s!important;
}
.nav-cta:hover{background:var(--clay-dark)!important;transform:translateY(-1px)!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:6px;margin-left:auto}
.hamburger span{display:block;width:23px;height:2px;background:var(--ink);border-radius:2px;transition:all .2s}
.mobile-menu{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:var(--paper);padding:1rem 1.5rem 1.6rem;border-bottom:1px solid var(--line);z-index:199;flex-direction:column;gap:.4rem;box-shadow:var(--shadow-lg)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--font-body)!important;color:var(--ink)!important;font-weight:500;font-size:1rem;padding:11px 0;border-bottom:1px solid var(--line);text-decoration:none}
.mobile-menu a:last-child{border:none;background:var(--clay);color:#fff!important;text-align:center;padding:13px;border-radius:100px;margin-top:.6rem}

/* ════════════════════════════════════════════════════════════════════
   FOOTER  (new markup uses .site-footer)
   ════════════════════════════════════════════════════════════════════ */
footer,.site-footer{background:var(--night)!important;padding:3.5rem 0 0!important;color:rgba(255,255,255,.6)}
.site-footer .container{max-width:1180px}
.ftr-top{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.09)}
.ftr-brand-logo{display:inline-block;background:var(--paper);border-radius:9px;padding:7px 12px;line-height:0;margin-bottom:1rem}
.ftr-brand-logo img{height:44px;width:auto;display:block}
.ftr-desc{font-family:var(--font-body);color:rgba(255,255,255,.5);font-size:.86rem;font-weight:300;line-height:1.75;max-width:30ch;margin-bottom:1.1rem}
.ftr-contact a{display:block;color:rgba(255,255,255,.72);font-size:.88rem;font-weight:400;text-decoration:none;margin-bottom:.4rem}
.ftr-contact a:hover{color:#fff}
.ftr-contact span{display:block;color:rgba(255,255,255,.4);font-size:.78rem;margin-top:.5rem;line-height:1.8}
.ftr-col h4{font-family:var(--font-body)!important;color:rgba(255,255,255,.92)!important;font-size:.7rem!important;font-weight:600!important;letter-spacing:.16em!important;text-transform:uppercase;margin-bottom:1rem!important}
.ftr-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem}
.ftr-col a{font-family:var(--font-body);color:rgba(255,255,255,.55);font-size:.86rem;font-weight:300;text-decoration:none;transition:color .2s,padding-left .2s}
.ftr-col a:hover{color:var(--gold);padding-left:3px}
.ftr-cities{border-top:1px solid rgba(255,255,255,.09);padding-top:1.4rem;margin-top:2rem;font-size:.82rem;line-height:2.1}
.ftr-cities strong{color:rgba(255,255,255,.45);font-family:var(--font-body);font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-right:.6rem}
.ftr-cities a{color:rgba(255,255,255,.5);font-family:var(--font-body);font-size:.82rem;font-weight:300;text-decoration:none;margin-right:.7rem}
.ftr-cities a:hover{color:#fff}
.ftr-disclose{text-align:center;padding:1.3rem 0 .2rem;font-size:.8rem;color:rgba(255,255,255,.5);font-family:var(--font-body);line-height:1.9}
.ftr-disclose strong{color:rgba(255,255,255,.74);font-weight:600}
.ftr-disclose a{color:rgba(255,255,255,.6);text-decoration:underline;text-decoration-color:rgba(255,255,255,.2)}
.ftr-disclose a:hover{color:#fff}
.ftr-bottom{border-top:1px solid rgba(255,255,255,.09);padding:1.3rem 0;margin-top:1.5rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem}
.ftr-bottom span,.ftr-bottom a{color:rgba(255,255,255,.4);font-family:var(--font-body);font-size:.76rem;font-weight:300;text-decoration:none}
.ftr-bottom a:hover{color:rgba(255,255,255,.8)}

/* ════════════════════════════════════════════════════════════════════
   LEGACY COMPONENT REFINEMENTS (recolor + re-font shared widgets)
   ════════════════════════════════════════════════════════════════════ */
.stat-num{font-family:var(--font-display)!important;color:var(--ink)!important;font-weight:480}
.stat-label{font-family:var(--font-body)!important;color:var(--muted)!important;font-weight:600}
.how-step,.rcard,.blog-card-hp,.faq-item{border-color:var(--line)!important;background:#fff!important}
.how-step{border-radius:var(--radius-xl)!important}
.how-num{font-family:var(--font-display)!important;background:var(--ink)!important}
.how-step:hover .how-num{background:var(--clay)!important}
.how-step h3,.rcard .r-name,.blog-card-hp h3,.city-card-name{font-family:var(--font-display)!important}
.compare-table th{background:var(--ink)!important;font-family:var(--font-body)!important;letter-spacing:.1em}
.compare-table th:last-child{background:var(--clay)!important}
.compare-highlight{font-family:var(--font-display)!important;color:var(--clay)!important;font-weight:600}
.compare-table td:last-child{color:var(--clay-dark)!important;background:var(--clay-tint)!important}
.rcard-text{font-family:var(--font-display)!important;font-style:italic;font-size:1.02rem!important;color:var(--ink-soft)!important;line-height:1.6}
.rcard-stars{color:var(--clay)!important}
.faq-q{font-family:var(--font-display)!important;color:var(--ink)!important;font-weight:520}
.faq-item.open,.faq-item:hover{border-color:var(--clay)!important}
.faq-item.open .faq-icon{background:var(--clay)!important}
.city-card{border-color:var(--line)!important;border-radius:var(--radius)!important;background:#fff!important}
.city-card:hover{border-color:var(--clay-mid)!important}
.city-card::after{background:var(--clay)!important}
.city-card-rebate{color:var(--sage)!important;font-family:var(--font-display)!important}
.cta-banner{background:var(--night)!important}
.cta-banner::before{background:radial-gradient(ellipse at 50% 0%,rgba(194,160,106,.16),transparent 60%)!important}
.hero-overlay{background:linear-gradient(105deg,rgba(27,24,20,.95) 42%,rgba(27,24,20,.62))!important}
.hero h1 em{color:var(--gold)!important;font-style:italic}
.calc-result{background:var(--clay)!important}
.float-call{background:var(--sage)!important;box-shadow:0 6px 20px -6px rgba(86,111,79,.8)!important}
.float-call:hover{background:#445a3e!important}
.lifestyle-tag{font-family:var(--font-display)!important;color:var(--gold)!important}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--clay)!important;box-shadow:0 0 0 3px rgba(188,91,54,.12)!important}
.form-group label{font-family:var(--font-body)!important;letter-spacing:.08em}
#formOk h3{color:var(--sage)!important}

/* Underlined contextual links inside prose */
.city-prose a:not(.btn-primary):not(.btn-secondary),
.post-body a:not(.btn-primary):not(.btn-secondary),
article a:not(.btn-primary):not(.btn-secondary),
.learn-content a:not(.btn-primary):not(.btn-secondary){
  color:var(--clay-dark)!important;text-decoration-color:rgba(188,91,54,.4)!important;
}

/* ════════════════════════════════════════════════════════════════════
   HOMEPAGE-ONLY MODULES  (new flagship markup)
   ════════════════════════════════════════════════════════════════════ */
.hx{background:var(--night);position:relative;overflow:hidden}
.hx-bg{position:absolute;inset:0}
.hx-bg img{width:100%;height:100%;object-fit:cover;opacity:.32}
.hx-veil{position:absolute;inset:0;background:linear-gradient(110deg,rgba(20,17,14,.95) 38%,rgba(20,17,14,.55) 100%)}
.hx-grain{position:absolute;inset:0;opacity:.4;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hx-inner{position:relative;z-index:3;display:grid;grid-template-columns:1.15fr .85fr;gap:4.5rem;align-items:center;padding:5.5rem 0 5rem}
.hx-eyebrow{display:flex;align-items:center;gap:.85rem;margin-bottom:1.6rem}
.hx-eyebrow i{display:block;width:34px;height:1.5px;background:var(--gold)}
.hx-eyebrow span{font-family:var(--font-body);font-size:.74rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.65)}
.hx h1{color:#fff;font-size:clamp(2.7rem,5.6vw,4.9rem);line-height:1.02;font-weight:380;letter-spacing:-.02em;margin-bottom:1.4rem}
.hx h1 em{font-style:italic;color:var(--gold)}
.hx-sub{color:rgba(255,255,255,.66);font-size:1.08rem;line-height:1.7;max-width:46ch;margin-bottom:2.1rem;font-weight:300}
.hx-actions{display:flex;gap:.9rem;flex-wrap:wrap;margin-bottom:2.4rem}
.hx-trust{display:flex;gap:1.6rem;flex-wrap:wrap}
.hx-trust div{display:flex;align-items:center;gap:7px;font-size:.8rem;color:rgba(255,255,255,.55);font-weight:400}
.hx-trust svg{color:var(--gold);flex-shrink:0}

/* hero rebate card */
.hx-card{background:rgba(247,243,236,.04);border:1px solid rgba(255,255,255,.13);border-radius:var(--radius-xl);padding:2rem;backdrop-filter:blur(10px);box-shadow:0 30px 80px -30px rgba(0,0,0,.7)}
.hx-card-tag{display:flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:.7rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.hx-card h3{color:#fff!important;font-size:1.2rem;font-weight:440;margin-bottom:1.3rem;letter-spacing:0}
.hx-field{position:relative;margin-bottom:1rem}
.hx-field span{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--muted);font-weight:600;font-size:1.1rem;font-family:var(--font-display)}
.hx-field input{width:100%;background:var(--paper);border:none;border-radius:var(--radius);padding:15px 16px 15px 30px;font-size:1.15rem;font-weight:600;font-family:var(--font-display);color:var(--ink);outline:none}
.hx-slider{width:100%;margin:.3rem 0 1.2rem;accent-color:var(--gold);cursor:pointer}
.hx-result{background:var(--clay);border-radius:var(--radius);padding:1.15rem 1.3rem;display:flex;justify-content:space-between;align-items:center;margin-bottom:1.1rem}
.hx-result-label{font-family:var(--font-body);font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.78)}
.hx-result-note{font-family:var(--font-body);font-size:.72rem;color:rgba(255,255,255,.6)}
.hx-result-amt{font-family:var(--font-display);font-size:2rem;font-weight:480;color:#fff;line-height:1}
.hx-card-cta{display:block;text-align:center;background:var(--paper);color:var(--clay-dark);padding:13px;border-radius:100px;font-weight:600;font-family:var(--font-body);text-decoration:none;transition:all .2s}
.hx-card-cta:hover{background:#fff}

/* marquee strip */
.marq{background:var(--ink);overflow:hidden;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}
.marq-track{display:flex;gap:3.5rem;padding:14px 0;white-space:nowrap;animation:marq 38s linear infinite;width:max-content}
.marq-track span{font-family:var(--font-display);font-style:italic;font-size:1.05rem;color:rgba(255,255,255,.55);display:flex;align-items:center;gap:3.5rem}
.marq-track span::after{content:"✦";color:var(--gold);font-style:normal;font-size:.7rem}
@keyframes marq{to{transform:translateX(-50%)}}

/* stat band */
.statband{background:var(--paper);border-bottom:1px solid var(--line)}
.statband-inner{display:flex;justify-content:center;flex-wrap:wrap}
.statband .s{padding:30px 2.6rem;text-align:center;position:relative}
.statband .s:not(:last-child)::after{content:"";position:absolute;right:0;top:26%;height:48%;width:1px;background:var(--line)}
.statband .n{font-family:var(--font-display);font-size:2.5rem;font-weight:440;color:var(--ink);line-height:1}
.statband .l{font-family:var(--font-body);font-size:.74rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:.4rem}

/* section heading kit */
.shead{max-width:680px}
.shead.center{margin:0 auto;text-align:center}
.shead h2{margin:.7rem 0 .6rem}
.shead p{color:var(--muted);font-size:1.02rem;line-height:1.7}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius-xl);padding:2.1rem 1.8rem;transition:all .3s cubic-bezier(.16,1,.3,1)}
.step:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--clay-mid)}
.step-n{font-family:var(--font-display);font-size:.9rem;font-weight:500;color:#fff;background:var(--ink);width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.3rem;transition:background .3s}
.step:hover .step-n{background:var(--clay)}
.step h3{font-size:1.22rem;margin-bottom:.5rem}
.step p{font-size:.93rem;color:var(--muted);margin:0;line-height:1.7}

/* value split */
.vsplit{display:grid;grid-template-columns:.95fr 1.05fr;gap:4rem;align-items:center}
.vsplit-media{position:relative;border-radius:var(--radius-xl);overflow:hidden;aspect-ratio:4/5}
.vsplit-media img{width:100%;height:100%;object-fit:cover}
.vsplit-badge{position:absolute;left:1.4rem;bottom:1.4rem;background:rgba(247,243,236,.94);backdrop-filter:blur(8px);border-radius:var(--radius-lg);padding:1rem 1.3rem;box-shadow:var(--shadow-lg)}
.vsplit-badge .big{font-family:var(--font-display);font-size:1.7rem;color:var(--clay);font-weight:480;line-height:1}
.vsplit-badge .sm{font-size:.74rem;color:var(--muted);font-weight:600;letter-spacing:.04em;text-transform:uppercase;margin-top:.25rem}
.vlist{display:flex;flex-direction:column;gap:1.5rem;margin:1.8rem 0}
.vitem{display:flex;gap:1.1rem}
.vicon{flex-shrink:0;width:44px;height:44px;border-radius:12px;background:var(--clay-tint);color:var(--clay-dark);display:flex;align-items:center;justify-content:center}
.vitem h4{font-family:var(--font-display);font-size:1.08rem;color:var(--ink);margin-bottom:.2rem;font-weight:520}
.vitem p{font-size:.9rem;color:var(--muted);margin:0;line-height:1.65}

/* math / compare */
.mtable{width:100%;border-collapse:separate;border-spacing:0;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.mtable th{font-family:var(--font-body);font-size:.74rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;text-align:left;padding:1rem 1.4rem;background:var(--ink);color:#fff}
.mtable th:last-child{background:var(--clay)}
.mtable td{padding:1rem 1.4rem;border-bottom:1px solid var(--line);font-size:.95rem;background:#fff}
.mtable tr:last-child td{border-bottom:none}
.mtable td.dim{color:var(--subtle)}
.mtable td:last-child{background:var(--clay-tint);font-family:var(--font-display);font-weight:600;color:var(--clay-dark);font-size:1.05rem}

/* cities */
.citygrid{display:grid;grid-template-columns:repeat(5,1fr);gap:.7rem;margin-top:2.4rem}
.citycard{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1.1rem;text-decoration:none;transition:all .25s;position:relative;overflow:hidden}
.citycard::after{content:"";position:absolute;left:0;bottom:0;right:0;height:2px;background:var(--clay);transform:scaleX(0);transform-origin:left;transition:transform .25s}
.citycard:hover{transform:translateY(-3px);border-color:var(--clay-mid);box-shadow:var(--shadow)}
.citycard:hover::after{transform:scaleX(1)}
.citycard .cn{font-family:var(--font-display);font-size:.96rem;font-weight:520;color:var(--ink);line-height:1.25}
.citycard .cp{font-size:.72rem;color:var(--muted);font-weight:500;margin:2px 0 4px}
.citycard .cr{font-family:var(--font-display);font-size:.78rem;font-weight:600;color:var(--sage)}

/* reviews */
.revgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.rev{background:#fff;border:1px solid var(--line);border-radius:var(--radius-xl);padding:1.7rem;transition:all .3s}
.rev:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.rev-stars{color:var(--clay);letter-spacing:2px;margin-bottom:.8rem}
.rev-q{font-family:var(--font-display);font-style:italic;font-size:1.04rem;line-height:1.55;color:var(--ink-soft);margin-bottom:1.2rem}
.rev-who{display:flex;align-items:center;gap:.8rem}
.rev-av{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--font-display);font-weight:600;font-size:.85rem;flex-shrink:0}
.rev-name{font-family:var(--font-display);font-size:.92rem;font-weight:560;color:var(--ink)}
.rev-meta{font-size:.74rem;color:var(--muted)}

/* faq */
.faqx{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.fq{border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:#fff;transition:border-color .25s}
.fq:hover,.fq.open{border-color:var(--clay)}
.fq-q{display:flex;justify-content:space-between;gap:1rem;align-items:center;padding:1.15rem 1.3rem;cursor:pointer;font-family:var(--font-display);font-weight:520;font-size:1rem;color:var(--ink);user-select:none}
.fq-ic{flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--paper-2);display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--muted);transition:all .25s}
.fq.open .fq-ic{background:var(--clay);color:#fff;transform:rotate(45deg)}
.fq-a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease;padding:0 1.3rem;font-size:.93rem;color:var(--muted);line-height:1.75}
.fq.open .fq-a{max-height:340px;padding:0 1.3rem 1.2rem}

/* contact */
.cwrap{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:start}
.cinfo h2{color:#fff!important}
.cinfo p{color:rgba(255,255,255,.62)}
.cdetail{display:flex;align-items:center;gap:.9rem;margin-bottom:.7rem;color:rgba(255,255,255,.78);font-size:.92rem}
.cdetail a{color:rgba(255,255,255,.78);text-decoration:none}
.cdetail a:hover{color:#fff}
.cdetail-ic{flex-shrink:0;width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;color:var(--gold)}
.cform{background:var(--paper);border-radius:var(--radius-xl);padding:2rem;box-shadow:var(--shadow-lg)}
.cform .row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.cgrp{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.85rem}
.cgrp label{font-family:var(--font-body);font-size:.74rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink)}
.cgrp input,.cgrp select,.cgrp textarea{border:1.5px solid var(--line);border-radius:var(--radius);padding:12px 14px;font-family:var(--font-body);font-size:.94rem;color:var(--ink);background:#fff;outline:none;transition:all .2s;width:100%}
.cgrp input:focus,.cgrp select:focus,.cgrp textarea:focus{border-color:var(--clay);box-shadow:0 0 0 3px rgba(188,91,54,.12)}
.cgrp textarea{resize:vertical;min-height:90px}

/* blog cards */
.blogrow{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.bcard{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius-xl);overflow:hidden;text-decoration:none;transition:all .3s cubic-bezier(.16,1,.3,1)}
.bcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--clay-mid)}
.bcard-img{height:180px;background:var(--paper-2) center/cover no-repeat}
.bcard-bd{padding:1.3rem;flex:1;display:flex;flex-direction:column}
.bcard-meta{display:flex;gap:.5rem;align-items:center;margin-bottom:.7rem;flex-wrap:wrap}
.bcard h3{font-size:1.08rem;margin-bottom:.4rem;line-height:1.25}
.bcard p{font-size:.86rem;color:var(--muted);line-height:1.6;flex:1;margin-bottom:.9rem}
.bcard-link{font-family:var(--font-body);font-size:.82rem;font-weight:600;color:var(--clay-dark);margin-top:auto}

/* tools strip */
.toolrow{display:grid;grid-template-columns:repeat(5,1fr);gap:.8rem;margin-top:1.6rem}
.toolcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.3rem 1rem;text-align:center;text-decoration:none;transition:all .25s}
.toolcard:hover{border-color:var(--clay-mid);transform:translateY(-3px);box-shadow:var(--shadow)}
.toolcard .ti{color:var(--clay);margin-bottom:.6rem;display:flex;justify-content:center}
.toolcard .tt{font-family:var(--font-display);font-size:.95rem;font-weight:520;color:var(--ink)}
.toolcard .td{font-size:.74rem;color:var(--muted);margin-top:.15rem}

/* big closing CTA */
.bigcta{background:var(--night);text-align:center;position:relative;overflow:hidden}
.bigcta::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 120%,rgba(194,160,106,.18),transparent 55%)}
.bigcta .inner{position:relative;z-index:1;padding:5rem 0}
.bigcta h2{color:#fff;font-size:clamp(2rem,4vw,3.2rem);font-weight:380;margin-bottom:.7rem}
.bigcta p{color:rgba(255,255,255,.6);max-width:48ch;margin:0 auto 2rem;font-size:1.05rem;font-weight:300}
.bigcta .acts{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* float + popup recolor reuse legacy ids */
.float-cta{position:fixed;bottom:24px;right:24px;z-index:500;display:flex;flex-direction:column;align-items:flex-end;gap:8px}

/* ── Responsive ───────────────────────────────────────────────────── */
@media(max-width:1080px){
  .hx-inner{grid-template-columns:1fr;gap:3rem;padding:4rem 0}
  .hx-card{max-width:440px}
  .citygrid{grid-template-columns:repeat(4,1fr)}
  .toolrow{grid-template-columns:repeat(3,1fr)}
  .ftr-top{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  :root{--section-pad:60px}
  .steps{grid-template-columns:1fr}
  .vsplit{grid-template-columns:1fr;gap:2.2rem}
  .vsplit-media{aspect-ratio:16/10;max-height:420px}
  .revgrid,.blogrow{grid-template-columns:1fr 1fr}
  .faqx,.cwrap{grid-template-columns:1fr}
  .citygrid{grid-template-columns:repeat(3,1fr)}
  .nav-links,.nav-phone{display:none}
  .hamburger{display:flex}
}
@media(max-width:560px){
  html{font-size:16px}
  .container{padding:0 1.3rem}
  .revgrid,.blogrow{grid-template-columns:1fr}
  .citygrid{grid-template-columns:repeat(2,1fr)}
  .toolrow{grid-template-columns:repeat(2,1fr)}
  .ftr-top{grid-template-columns:1fr}
  .cform .row{grid-template-columns:1fr}
  .statband .s{padding:22px 1.3rem}
  .statband .n{font-size:2rem}
  .float-cta{bottom:16px;right:16px}
}
