/*
Theme Name: Metrowala Properties
Theme URI: https://metrowalaproperties.online
Author: Metrowala Properties
Description: India's First Metro-Centric Real Estate Platform
Version: 7.0
Text Domain: metrowala
*/
/* Fonts loaded via wp_enqueue_style in functions.php (non-render-blocking,
   Plus Jakarta Sans only). The old @import that pulled serif Fraunces was
   removed — it caused serif headings and blocked render. */

:root{
  --red:#E23744;--red-d:#C42D39;--red-l:#FFF0F1;--red-m:#FFDDE0;
  --gold:#D4AF37;--gold-l:#FDF8E7;
  --ink:#0F172A;--ink-2:#334155;--ink-3:#475569;--ink-4:#64748B;
  --bg:#F8FAFC;--bg-2:#F1F5F9;--bg-3:#E2E8F0;
  --white:#FFFFFF;--success:#059669;--warning:#D97706;
  --shadow-xs:0 1px 2px rgba(0,0,0,.06);
  --shadow-sm:0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);
  --shadow:0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.06);
  --shadow-md:0 10px 25px rgba(0,0,0,.08),0 4px 10px rgba(0,0,0,.05);
  --shadow-lg:0 20px 40px rgba(0,0,0,.1),0 8px 16px rgba(0,0,0,.06);
  --shadow-xl:0 32px 64px rgba(0,0,0,.12),0 16px 32px rgba(0,0,0,.08);
  --shadow-red:0 8px 24px rgba(226,55,68,.3);
  --r:12px;--r-sm:8px;--r-lg:16px;--r-xl:20px;--r-full:9999px;
  --ff:  'Plus Jakarta Sans',system-ui,-apple-system,'Segoe UI',sans-serif;
  --ff-d:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;
  --ff-m:'Plus Jakarta Sans',ui-monospace,monospace;
  --transition:.2s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--ff);background:var(--bg);color:var(--ink);line-height:1.6;overflow-x:hidden}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font-family:inherit}
ul{list-style:none}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* ── TYPOGRAPHY ── */
.eyebrow{font-family:var(--ff-m);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);font-weight:500}
h1,h2,h3,h4{line-height:1.15;color:var(--ink);letter-spacing:-.02em}
h1{font-family:var(--ff-d);font-size:clamp(34px,5vw,60px);font-weight:700}
h2{font-family:var(--ff-d);font-size:clamp(26px,3.5vw,40px);font-weight:600}
h3{font-family:var(--ff);font-size:clamp(18px,2vw,22px);font-weight:700}
h4{font-family:var(--ff);font-size:16px;font-weight:600}
p{color:var(--ink-3);line-height:1.75;font-size:16px}
.text-lg{font-size:17px;line-height:1.7}
.text-sm{font-size:13px}
.text-xs{font-size:11px}
.fw-700{font-weight:700}
.text-ink{color:var(--ink)}
.text-red{color:var(--red)}
.text-gold{color:var(--gold)}
.text-center{text-align:center}
.text-muted{color:var(--ink-3)}

/* ── LAYOUT ── */
.container{max-width:1280px;margin:0 auto;padding:0 24px}
@media(min-width:768px){.container{padding:0 40px}}
@media(min-width:1280px){.container{padding:0 48px}}
.section{padding:96px 0}
.section--sm{padding:64px 0}
.section--lg{padding:120px 0}
.section--alt{background:var(--bg-2)}
.section--dark{background:var(--ink)}
.section--red{background:linear-gradient(135deg,#C42D39,var(--red))}
.grid-2{display:grid;grid-template-columns:1fr;gap:32px}
.grid-3{display:grid;grid-template-columns:1fr;gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
@media(min-width:640px){.grid-2{grid-template-columns:1fr 1fr}}
@media(min-width:768px){.grid-3{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.grid-4{grid-template-columns:repeat(4,1fr)}}
.gap-4{gap:16px}.gap-6{gap:24px}.gap-8{gap:32px}
.flex{display:flex}.flex-col{flex-direction:column}
.items-center{align-items:center}.items-start{align-items:flex-start}
.justify-between{justify-content:space-between}.justify-center{justify-content:center}
.flex-wrap{flex-wrap:wrap}
.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mt-8{margin-top:32px}.mt-12{margin-top:48px}
.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mb-8{margin-bottom:32px}
.w-full{width:100%}

/* ── NAV ── */
.site-header{position:sticky;top:0;z-index:999;background:rgba(255,255,255,.97);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--bg-3);transition:box-shadow var(--transition)}
.site-header.shadow{box-shadow:var(--shadow-md)}
.nav-inner{display:flex;align-items:center;height:72px;gap:8px}
.nav-logo{display:flex;align-items:center;margin-right:auto}
.nav-logo img{height:44px;width:auto}
.nav-links{display:none;align-items:center;gap:2px}
@media(min-width:1024px){.nav-links{display:flex}}
.nav-links a{display:flex;align-items:center;padding:8px 14px;border-radius:8px;font-size:14px;font-weight:500;color:var(--ink-2);transition:all var(--transition);white-space:nowrap}
.nav-links a:hover{color:var(--ink);background:var(--bg-2)}
.nav-links a.active{color:var(--red);background:var(--red-l);font-weight:600}
.nav-actions{display:flex;align-items:center;gap:8px;margin-left:16px}
.btn-wa-nav{display:flex;align-items:center;gap:7px;padding:9px 18px;background:#25D366;color:#fff;border:none;border-radius:9px;font-size:13.5px;font-weight:700;cursor:pointer;transition:all var(--transition);text-decoration:none;white-space:nowrap;letter-spacing:-.01em}
.btn-wa-nav:hover{background:#20BA5A;color:#fff;transform:translateY(-1px);box-shadow:0 4px 14px rgba(37,211,102,.4)}
.btn-list{padding:9px 18px;border:2px solid var(--red);color:var(--red);background:transparent;border-radius:9px;font-size:13.5px;font-weight:700;cursor:pointer;transition:all var(--transition);white-space:nowrap;text-decoration:none}
.btn-list:hover,.btn-list:focus{background:var(--red);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-red)}
.hamburger{display:flex;flex-direction:column;justify-content:space-between;width:24px;height:18px;cursor:pointer;background:none;border:none;padding:0;margin-left:8px}
@media(min-width:1024px){.hamburger{display:none}}
.hamburger span{display:block;width:100%;height:2px;background:var(--ink);border-radius:2px;transition:all .3s}
.mobile-menu{display:none;flex-direction:column;background:#fff;border-bottom:1px solid var(--bg-3);padding:8px 0}
.mobile-menu.open{display:flex}
.mobile-menu a{padding:13px 24px;font-size:15px;font-weight:500;color:var(--ink-2);border-bottom:1px solid var(--bg-2);transition:color var(--transition)}
.mobile-menu a:hover{color:var(--red)}
.mobile-menu a:last-child{border:none;color:#25D366;font-weight:700}

/* ── WHATSAPP FLOAT ── */
.wa-float{position:fixed;bottom:28px;right:28px;z-index:9998;width:62px;height:62px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(37,211,102,.5);transition:transform var(--transition);text-decoration:none}
.wa-float:hover{transform:scale(1.1)}
.wa-float-pulse{position:absolute;inset:-4px;border-radius:50%;background:rgba(37,211,102,.25);animation:wa-pulse 2.5s ease-in-out infinite}
@keyframes wa-pulse{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.2);opacity:0}}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 28px;border-radius:10px;font-weight:700;font-size:14.5px;cursor:pointer;transition:all var(--transition);border:none;letter-spacing:-.01em;text-decoration:none;white-space:nowrap;line-height:1}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-d);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-red)}
.btn-secondary{background:var(--ink);color:#fff}
.btn-secondary:hover{background:#1f2937;color:#fff;transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--ink);border:2px solid var(--bg-3)}
.btn-outline:hover{border-color:var(--red);color:var(--red);background:var(--red-l)}
.btn-ghost{background:transparent;color:var(--ink-2);padding:11px 20px}
.btn-ghost:hover{background:var(--bg-2);color:var(--ink)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:#B8960C;color:#fff;transform:translateY(-2px)}
.btn-whatsapp{background:#25D366;color:#fff}
.btn-whatsapp:hover{background:#20BA5A;color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px rgba(37,211,102,.4)}
.btn-sm{padding:9px 18px;font-size:13px}
.btn-lg{padding:16px 36px;font-size:16px;border-radius:12px}
.btn-icon{width:40px;height:40px;padding:0;border-radius:8px}

/* ── HERO ── */
.hero{position:relative;overflow:hidden;background:#F8FAFC;padding:0}
.hero-inner{display:grid;grid-template-columns:1fr;min-height:580px;align-items:center}
@media(min-width:900px){.hero-inner{grid-template-columns:1fr 1fr;min-height:640px}}
.hero-content{padding:80px 0 60px;position:relative;z-index:2}
.hero-visual{display:none;position:relative}
@media(min-width:900px){.hero-visual{display:flex;align-items:center;justify-content:center}}
.hero-bg-orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}
.hero-bg-orb-1{width:500px;height:500px;background:radial-gradient(circle,rgba(226,55,68,.15),transparent 70%);top:-100px;right:-100px}
.hero-bg-orb-2{width:400px;height:400px;background:radial-gradient(circle,rgba(212,175,55,.06),transparent 70%);bottom:-80px;left:20%}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(226,55,68,.12);border:1px solid rgba(226,55,68,.25);padding:7px 16px;border-radius:var(--r-full);margin-bottom:24px}
.hero-tag span{font-family:var(--ff-m);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,180,160,.95)}
.hero h1{color:#fff;margin-bottom:20px;max-width:640px}
.hero h1 em{font-style:italic;color:rgba(255,120,80,.95)}
.hero-sub{color:rgba(255,255,255,.6);font-size:17px;max-width:480px;margin-bottom:36px;line-height:1.7}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:44px}
.hero-stats{display:flex;flex-wrap:wrap;gap:24px 36px;padding-top:36px;border-top:1px solid rgba(255,255,255,.1)}
.hero-stat strong{display:block;font-family:var(--ff-d);font-size:32px;font-weight:700;color:#fff;line-height:1;letter-spacing:-.03em}
.hero-stat span{font-family:var(--ff-m);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-top:4px;display:block}
.hero-line-bar{height:4px;display:flex;gap:1px;overflow:hidden;border-radius:4px;margin-bottom:0}
.hero-line-seg{flex:1;opacity:.85}

/* ── TRUST BAR ── */
.trust-bar{background:var(--red);padding:12px 0}
.trust-inner{display:flex;flex-wrap:wrap;gap:8px 28px;align-items:center;justify-content:center}
.trust-item{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.92);font-size:13px;font-weight:600}

/* ── SEARCH WIDGET ── */
.search-widget{background:#fff;border-radius:var(--r-xl);padding:28px 32px;box-shadow:var(--shadow-xl);border:1px solid rgba(0,0,0,.04)}
.search-mode{display:flex;gap:4px;margin-bottom:22px;background:var(--bg-2);padding:4px;border-radius:10px;width:fit-content}
.smode-tab{padding:8px 22px;border-radius:8px;font-family:var(--ff-m);font-size:11px;letter-spacing:.06em;text-transform:uppercase;border:none;background:transparent;color:var(--ink-3);cursor:pointer;transition:all var(--transition);font-weight:600}
.smode-tab.on{background:#fff;color:var(--red);box-shadow:var(--shadow-sm)}
.search-fields{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(min-width:960px){.search-fields{grid-template-columns:repeat(5,1fr) auto;align-items:end}}
.sf-group label{font-family:var(--ff-m);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);display:block;margin-bottom:7px;font-weight:500}
.sf-group select,.sf-group input{width:100%;padding:12px 14px;border:1.5px solid var(--bg-3);border-radius:9px;font-size:14px;color:var(--ink);background:#fff;appearance:none;-webkit-appearance:none;transition:border-color var(--transition);font-weight:500}
.sf-group select:focus,.sf-group input:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(226,55,68,.1)}
.btn-search{padding:12px 26px;background:var(--red);color:#fff;border:none;border-radius:9px;font-weight:700;font-size:14px;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;gap:8px;white-space:nowrap;align-self:flex-end;letter-spacing:-.01em}
.btn-search:hover{background:var(--red-d);transform:translateY(-2px);box-shadow:var(--shadow-red)}

/* ── SECTION HEADS ── */
.sh{margin-bottom:52px}
.sh .eyebrow{display:block;margin-bottom:12px}
.sh h2{margin-bottom:12px}
.sh p{max-width:560px;font-size:16px}
.sh--center{text-align:center}
.sh--center p{margin:12px auto 0}
.shr{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:44px}

/* ── PROPERTY CARDS ── */
.card{background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);transition:all var(--transition);cursor:pointer;display:flex;flex-direction:column;border:1.5px solid transparent}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px);border-color:rgba(226,55,68,.12)}
.card-img{height:210px;position:relative;overflow:hidden;background:linear-gradient(135deg,#EEF2F6,#E2E8F0)}
.card-img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .5s cubic-bezier(.25,.46,.45,.94)}
.card:hover .card-img img{transform:scale(1.07)}
.card-img-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:52px;opacity:.15}
.card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.6) 0%,transparent 60%)}
.card-badges{position:absolute;top:14px;left:14px;right:14px;display:flex;justify-content:space-between;align-items:flex-start;gap:8px;z-index:2}
.lp{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);padding:5px 11px;border-radius:var(--r-full);font-family:var(--ff-m);font-size:10px;color:var(--ink);box-shadow:var(--shadow-xs);font-weight:600}
.ld{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.mb{padding:5px 11px;border-radius:var(--r-full);font-family:var(--ff-m);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:#fff;font-weight:600}
.mb.buy{background:rgba(226,55,68,.9)}
.mb.rent{background:rgba(17,24,39,.85)}
.card-price-strip{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:28px 16px 14px}
.card-price-strip .price{font-family:var(--ff-d);font-size:22px;font-weight:700;color:#fff;letter-spacing:-.02em}
.card-body{padding:16px 18px 20px;flex:1;display:flex;flex-direction:column}
.card-title{font-family:var(--ff);font-size:15.5px;font-weight:700;color:var(--ink);margin-bottom:6px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-loc{font-size:13px;color:var(--ink-3);display:flex;align-items:center;gap:4px;margin-bottom:12px}
.card-meta{display:flex;gap:10px;flex-wrap:wrap;padding-top:12px;border-top:1px solid var(--bg-2);margin-top:auto}
.card-meta span{font-family:var(--ff-m);font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);display:flex;align-items:center;gap:4px;font-weight:500}
.card-trust{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}
.mw-badge{display:inline-flex;align-items:center;gap:4px;font-family:var(--ff-m);font-size:9px;letter-spacing:.04em;text-transform:uppercase;padding:3px 8px;border-radius:var(--r-full);font-weight:600}

/* ── FEATURE CARDS ── */
.feat-card{padding:28px;background:#fff;border-radius:var(--r-lg);border:1.5px solid var(--bg-3);transition:all var(--transition)}
.feat-card:hover{border-color:var(--red);box-shadow:var(--shadow-md);transform:translateY(-3px)}
.feat-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:18px}
.feat-icon--red{background:var(--red-l)}
.feat-icon--gold{background:var(--gold-l)}

/* ── LINE TRACKS ── */
.lt-wrap{margin-bottom:32px}
.lt-head{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.lt-name{font-family:var(--ff-m);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);font-weight:600}
.lt-count{font-family:var(--ff-m);font-size:10px;color:var(--ink-3);margin-left:auto}
.lt-rail{overflow-x:auto;padding-bottom:10px;cursor:grab}
.lt-rail:active{cursor:grabbing}
.lt-rail::-webkit-scrollbar{height:4px}
.lt-rail::-webkit-scrollbar-thumb{background:var(--bg-3);border-radius:2px}
.lt-row{display:flex;align-items:center;height:52px;position:relative}
.lt-bar{position:absolute;left:0;right:0;height:3px;top:50%;transform:translateY(-50%)}
.lt-nodes{display:flex;align-items:center;position:relative;z-index:1;min-width:max-content;gap:88px;padding:0 8px}
.stn{display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;user-select:none}
.sdot{width:12px;height:12px;border-radius:50%;background:#fff;border:2.5px solid currentColor;transition:transform .18s,box-shadow .18s}
.stn:hover .sdot{transform:scale(1.5);box-shadow:0 0 0 5px rgba(226,55,68,.15)}
.sname{font-family:var(--ff-m);font-size:9px;letter-spacing:.03em;color:var(--ink);white-space:nowrap;font-weight:500}

/* ── TOOLS (EMI CALC etc) ── */
.calc-card{background:#fff;border:1.5px solid var(--bg-3);border-radius:var(--r-xl);padding:32px;box-shadow:var(--shadow)}
.calc-result{background:linear-gradient(135deg,var(--red),var(--red-d));border-radius:var(--r-lg);padding:28px;text-align:center;margin-top:20px}
.calc-result .amount{font-family:var(--ff-d);font-size:42px;font-weight:700;color:#fff;letter-spacing:-.03em}
.calc-result p{color:rgba(255,255,255,.75);font-size:13px;margin-top:4px}
.range-track{-webkit-appearance:none;width:100%;height:6px;border-radius:3px;background:var(--bg-3);outline:none;cursor:pointer}
.range-track::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--red);cursor:pointer;box-shadow:var(--shadow-sm)}

/* ── CALCULATORS PAGE ── */
.calc-tabs{display:flex;gap:4px;background:var(--bg-2);padding:4px;border-radius:10px;margin-bottom:28px;flex-wrap:wrap}
.calc-tab{padding:9px 18px;border-radius:8px;font-family:var(--ff-m);font-size:11px;letter-spacing:.06em;text-transform:uppercase;border:none;background:transparent;color:var(--ink-3);cursor:pointer;transition:all var(--transition);font-weight:600}
.calc-tab.on{background:#fff;color:var(--red);box-shadow:var(--shadow-sm)}
.calc-panel{display:none}
.calc-panel.on{display:block}

/* ── LISTINGS ── */
.lst-layout{display:grid;grid-template-columns:1fr;gap:28px}
@media(min-width:960px){.lst-layout{grid-template-columns:280px 1fr}}
.fsb{background:#fff;border:1.5px solid var(--bg-3);border-radius:var(--r-xl);padding:24px;position:sticky;top:86px;align-self:flex-start;box-shadow:var(--shadow-sm)}
.fsb-title{font-family:var(--ff-m);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--bg-2);display:flex;align-items:center;gap:8px;font-weight:600}
.fgrp{margin-bottom:16px}
.fgrp label{font-family:var(--ff-m);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);display:block;margin-bottom:7px;font-weight:500}
.fgrp select{width:100%;padding:11px 13px;border:1.5px solid var(--bg-3);border-radius:9px;font-size:14px;appearance:none;-webkit-appearance:none;color:var(--ink);transition:border-color var(--transition);font-weight:500}
.fgrp select:focus{outline:none;border-color:var(--red)}
.results-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:10px}
.results-count{font-family:var(--ff-m);font-size:11px;letter-spacing:.06em;color:var(--ink-3);font-weight:500}
.no-results{text-align:center;padding:72px 24px;background:#fff;border:1.5px solid var(--bg-3);border-radius:var(--r-xl)}
.pagination{display:flex;gap:6px;margin-top:48px;flex-wrap:wrap}
.pagination a,.pagination span{padding:9px 16px;border:1.5px solid var(--bg-3);border-radius:8px;font-family:var(--ff-m);font-size:11px;color:var(--ink-3);transition:all var(--transition)}
.pagination a:hover,.pagination .current{background:var(--red);color:#fff;border-color:var(--red)}

/* ── PROPERTY DETAIL ── */
.property-gallery{height:440px;border-radius:var(--r-xl);overflow:hidden;position:relative;background:linear-gradient(135deg,#EEF2F6,#E2E8F0);margin-bottom:32px}
@media(min-width:768px){.property-gallery{height:520px}}
.property-gallery img{width:100%;height:100%;object-fit:cover}
.pdl{display:grid;grid-template-columns:1fr;gap:40px}
@media(min-width:1024px){.pdl{grid-template-columns:1fr 380px}}
.pspecs{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:28px 0}
@media(min-width:540px){.pspecs{grid-template-columns:repeat(3,1fr)}}
.spec-box{border:1.5px solid var(--bg-3);border-radius:12px;padding:16px;transition:all var(--transition)}
.spec-box:hover{border-color:var(--red);background:var(--red-l)}
.spec-l{font-family:var(--ff-m);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);display:block;margin-bottom:5px;font-weight:500}
.spec-v{font-size:15px;font-weight:700;color:var(--ink)}
.metro-box{background:linear-gradient(135deg,var(--red-l),#fff5f3);border:1.5px solid rgba(226,55,68,.15);border-radius:12px;padding:20px;margin-top:24px}
.ccard{background:#fff;border:1.5px solid var(--bg-3);border-radius:var(--r-xl);padding:28px;position:sticky;top:90px;box-shadow:var(--shadow-md)}
.ccard .price{font-family:var(--ff-d);font-size:34px;font-weight:700;color:var(--red);letter-spacing:-.03em}
.ccard .pnote{font-family:var(--ff-m);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:24px;display:block;margin-top:4px}
.enq-label{font-family:var(--ff-m);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);display:block;margin-bottom:6px;font-weight:500}
.enq-input{width:100%;padding:11px 14px;border:1.5px solid var(--bg-3);border-radius:9px;font-size:14px;font-family:var(--ff);color:var(--ink);transition:border-color var(--transition);margin-bottom:12px;font-weight:500}
.enq-input:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(226,55,68,.1)}

/* ── TESTIMONIALS ── */
.testi{background:#fff;border:1.5px solid var(--bg-3);border-radius:var(--r-xl);padding:28px;box-shadow:var(--shadow-sm)}
.testi-stars{color:#F59E0B;font-size:16px;letter-spacing:2px;margin-bottom:12px}
.testi-text{font-family:var(--ff-d);font-size:17px;font-style:italic;color:var(--ink);line-height:1.65;margin-bottom:18px}
.testi-author{display:flex;align-items:center;gap:12px}
.tav{width:44px;height:44px;border-radius:50%;background:var(--red-l);display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:800;color:var(--red);font-family:var(--ff-d);flex-shrink:0}
.tname{font-weight:700;font-size:14px;color:var(--ink)}
.tloc{font-size:12px;color:var(--ink-3)}

/* ── CONTACT ── */
.ci-item{display:flex;align-items:flex-start;gap:14px;padding:18px;background:var(--bg-2);border-radius:12px;margin-bottom:12px}
.ci-icon{width:44px;height:44px;background:var(--red-l);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fcard{background:#fff;border:1.5px solid var(--bg-3);border-radius:var(--r-xl);padding:32px;box-shadow:var(--shadow-sm)}
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.fg label{font-family:var(--ff-m);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.fg input,.fg select,.fg textarea{padding:12px 15px;border:1.5px solid var(--bg-3);border-radius:9px;font-size:14px;color:var(--ink);background:#fff;transition:border-color var(--transition);appearance:none;-webkit-appearance:none;width:100%;font-weight:500}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(226,55,68,.1)}
.frow2{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* ── METRO & LOCALITIES ── */
.mlcard{background:#fff;border:1.5px solid var(--bg-3);border-radius:var(--r-lg);padding:26px;margin-bottom:20px;transition:all var(--transition)}
.mlcard:hover{border-color:var(--red);box-shadow:var(--shadow-md)}
.mlh{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.station-chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{padding:5px 12px;background:var(--bg-2);border-radius:var(--r-full);font-family:var(--ff-m);font-size:10px;letter-spacing:.03em;color:var(--ink-2);border:1.5px solid var(--bg-3);cursor:pointer;transition:all var(--transition);font-weight:500}
.chip:hover{background:var(--red);color:#fff;border-color:var(--red);transform:translateY(-1px)}
.loc-card{background:#fff;border:1.5px solid var(--bg-3);border-radius:var(--r-lg);padding:22px;transition:all var(--transition)}
.loc-card:hover{border-color:var(--red);box-shadow:var(--shadow-md);transform:translateY(-3px)}

/* ── BUILDERS ── */
.bldr-card{background:#fff;border:1.5px solid var(--bg-3);border-radius:var(--r-xl);padding:28px;position:relative;transition:all var(--transition)}
.bldr-card:hover{border-color:var(--red);box-shadow:var(--shadow-lg)}
.verified-badge{position:absolute;top:18px;right:18px;background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:1px solid #6ee7b7;color:#065f46;font-family:var(--ff-m);font-size:9px;letter-spacing:.06em;text-transform:uppercase;padding:5px 12px;border-radius:var(--r-full);display:inline-flex;align-items:center;gap:5px;font-weight:600}

/* ── CTA DARK ── */
.cta-dark{background:#fff;border:1px solid #E2E8F0;border-radius:32px;padding:64px 48px;text-align:center;position:relative;overflow:hidden;box-shadow:0 20px 40px -15px rgba(0,0,0,.03)}
.cta-dark::after{content:'';position:absolute;top:-40%;right:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(153,27,27,.04),transparent 70%);pointer-events:none}
.cta-dark h2{color:#0F172A}
.cta-dark p{color:#475569;max-width:520px;margin:16px auto 30px;font-size:16px;line-height:1.6}

/* ── EXIT INTENT ── */
.exit-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity var(--transition)}
.exit-overlay.show{opacity:1;pointer-events:all}
.exit-popup{background:#fff;border-radius:var(--r-xl);padding:40px;max-width:480px;width:100%;position:relative;box-shadow:var(--shadow-xl);transform:scale(.95);transition:transform var(--transition)}
.exit-overlay.show .exit-popup{transform:scale(1)}
.exit-close{position:absolute;top:16px;right:16px;background:var(--bg-2);border:none;border-radius:var(--r-full);width:32px;height:32px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;color:var(--ink-3)}

/* ── SCROLL CTA ── */
.scroll-cta{position:fixed;bottom:0;left:0;right:0;z-index:997;background:#fff;border-top:1px solid var(--bg-3);padding:12px 20px;display:none;align-items:center;justify-content:space-between;gap:12px;box-shadow:0 -4px 20px rgba(0,0,0,.08)}
.scroll-cta.visible{display:flex}
@media(min-width:768px){.scroll-cta{display:none!important}}

/* ── ALERTS ── */
.alert{padding:14px 18px;border-radius:10px;font-size:14px;margin-bottom:16px;font-weight:500}
.alert-success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}
.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}
.alert-info{background:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}

/* ── FOOTER ── */
.site-footer{background:var(--ink);padding:72px 0 28px}
.footer-grid{display:grid;grid-template-columns:1fr;gap:44px;margin-bottom:56px}
@media(min-width:640px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.footer-grid{grid-template-columns:2.2fr 1fr 1fr 1fr}}
.footer-logo img{height:38px;width:auto;filter:brightness(0) invert(1);margin-bottom:14px}
.footer-brand p{color:#6b7a90;font-size:14px;line-height:1.8}
.fcol-title{font-family:var(--ff-m);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:#3d4f66;margin-bottom:18px;display:block;font-weight:600}
.footer-col a,.footer-col button{display:block;font-size:14px;color:#8a9ab5;margin-bottom:10px;background:none;border:none;text-align:left;cursor:pointer;transition:color var(--transition);padding:0;width:100%;font-weight:500}
.footer-col a:hover,.footer-col button:hover{color:#fff}
.fci{display:flex;align-items:center;gap:10px;font-size:14px;color:#8a9ab5;margin-bottom:10px}
.fci a{color:#8a9ab5;transition:color var(--transition)}
.fci a:hover{color:#fff}
.footer-qr{background:#1a2535;border-radius:12px;padding:16px 18px;display:inline-block;margin-top:20px}
.footer-qr p{font-family:var(--ff-m);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:#3d4f66;margin-bottom:10px}
.footer-qr img{width:88px;height:88px;border-radius:8px;background:#fff;padding:4px}
.footer-bar{border-top:1px solid #1a2535;padding-top:28px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-bar p{font-family:var(--ff-m);font-size:11px;color:#2d3d52}

/* ── 404 ── */
.e404{min-height:65vh;display:flex;align-items:center;justify-content:center;text-align:center}
.e404-code{font-family:var(--ff-d);font-size:120px;font-weight:700;color:var(--bg-3);line-height:1;margin-bottom:12px;letter-spacing:-.06em}

/* ── UTILITIES ── */
.hidden{display:none!important}
.show{display:block}
.rounded{border-radius:var(--r)}
.rounded-lg{border-radius:var(--r-lg)}
.rounded-xl{border-radius:var(--r-xl)}
.rounded-full{border-radius:var(--r-full)}
.shadow{box-shadow:var(--shadow)}
.shadow-lg{box-shadow:var(--shadow-lg)}
.bg-white{background:#fff}
.bg-alt{background:var(--bg-2)}
.border{border:1.5px solid var(--bg-3)}
.p-6{padding:24px}
.p-8{padding:32px}

/* ── RESPONSIVE ── */
@media(max-width:640px){
  .section,.section--sm{padding:60px 0}
  .hero-content{padding:60px 0 40px}
  .cta-dark{padding:44px 24px}
  .search-widget{padding:20px}
  .fcard,.calc-card{padding:22px}
  .pdl,.fsb,.ccard{position:static!important}
  .frow2{grid-template-columns:1fr}
  .property-gallery{height:260px}
  .hero-stats{gap:18px 28px}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
}

/* ═══════════════════════════════════════════════
   METROWALA v5 — NEW FEATURE STYLES
   Compare · AI Search · Reviews · Metro Map · 
   Investment Score · Compare Tray
═══════════════════════════════════════════════ */

/* ── COMPARE TABLE ── */
.compare-wrap { overflow-x: auto; }
.compare-header-row { display: flex; gap: 1px; min-width: 700px; }
.compare-label-col { width: 180px; flex-shrink: 0; }
.compare-prop-col { flex: 1; min-width: 180px; background: var(--bg); border-radius: 12px; padding: 20px; text-align: center; }
.compare-prop-col img { width: 100%; height: 120px; object-fit: cover; border-radius: 8px; margin-bottom: 12px; }
.compare-prop-col h3 { font-size: 15px; margin-bottom: 6px; }
.compare-prop-col h3 a { color: var(--ink); text-decoration: none; }
.compare-prop-col h3 a:hover { color: var(--red); }
.cmp-price { font-size: 20px; font-weight: 800; color: var(--red); font-family: var(--ff-d); }
.compare-table { min-width: 700px; margin-top: 16px; }
.compare-row { display: flex; gap: 1px; border-bottom: 1px solid var(--bg-3); }
.compare-row:nth-child(odd) { background: var(--bg-2); }
.compare-label { width: 180px; flex-shrink: 0; padding: 12px 16px; font-size: 13px; font-weight: 600; color: var(--ink-3); font-family: var(--ff-m); text-transform: uppercase; letter-spacing: .04em; display: flex; align-items: center; }
.compare-val { flex: 1; min-width: 180px; padding: 12px 16px; font-size: 14px; text-align: center; color: var(--ink); }
.cmp-score { padding: 4px 10px; border-radius: 20px; font-weight: 700; font-size: 13px; color: #fff; }
.compare-actions { display: flex; gap: 12px; justify-content: center; margin-top: 24px; }
.compare-empty { text-align: center; padding: 60px 20px; color: var(--ink-3); }
.compare-empty p { font-size: 18px; margin-bottom: 20px; }
.compare-remove { font-size: 11px; margin-top: 8px; }

/* ── COMPARE TRAY (sticky) ── */
.compare-tray { position: fixed; bottom: 0; left: 0; right: 0; z-index: 1000; background: var(--ink-dark, #111827); color: #fff; padding: 14px 24px; box-shadow: 0 -4px 20px rgba(0,0,0,.3); }
.ct-inner { max-width: 1200px; margin: 0 auto; display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.ct-count { font-size: 14px; font-weight: 600; margin-right: auto; }
.ct-thumbs { display: flex; gap: 6px; }
.ct-thumb { background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2); border-radius: 4px; padding: 4px 8px; font-size: 11px; }
.ct-clear { background: transparent; border: 1px solid rgba(255,255,255,.3); color: rgba(255,255,255,.7); padding: 6px 14px; border-radius: 6px; cursor: pointer; font-size: 12px; }
.ct-clear:hover { color: #fff; border-color: #fff; }

/* ── AI SEARCH ── */
.ai-loading, .ai-empty { text-align: center; padding: 24px; color: rgba(255,255,255,.7); font-size: 15px; }
.ai-summary { font-size: 14px; color: rgba(255,255,255,.8); margin-bottom: 16px; }
.ai-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 16px; }
.ai-card { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); border-radius: 12px; overflow: hidden; color: #fff; transition: transform .2s; }
.ai-card:hover { transform: translateY(-3px); }
.ai-card-img { height: 140px; overflow: hidden; position: relative; background: rgba(255,255,255,.05); }
.ai-card-img img { width: 100%; height: 100%; object-fit: cover; }
.ai-card-ph { display: flex; align-items: center; justify-content: center; height: 100%; font-size: 40px; opacity: .3; }
.ai-card-body { padding: 14px; }
.ai-card-body h4 { font-size: 14px; margin: 0 0 6px; color: #fff; }
.ai-price { font-size: 18px; font-weight: 800; color: #E23744; font-family: var(--ff-d); margin-bottom: 6px; }
.ai-card-body p { font-size: 12px; color: rgba(255,255,255,.6); margin: 0 0 8px; }
.ai-examples .ai-example:hover { background: rgba(255,255,255,.15); color: #fff; }

/* ── REVIEWS ── */
.mw-reviews { margin-top: 40px; padding-top: 40px; border-top: 1.5px solid var(--bg-3); }
.reviews-header { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; margin-bottom: 24px; }
.reviews-header h2 { font-size: 22px; margin: 0; }
.reviews-summary { display: flex; align-items: center; gap: 8px; }
.mw-stars { color: #E3A800; font-size: 18px; letter-spacing: 2px; }
.reviews-empty { color: var(--ink-3); font-size: 15px; margin-bottom: 24px; }
.reviews-list { display: grid; gap: 16px; margin-bottom: 32px; }
.review-card { background: var(--bg); border: 1.5px solid var(--bg-3); border-radius: 12px; padding: 20px; }
.review-top { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.reviewer-avatar { width: 40px; height: 40px; border-radius: 50%; background: var(--red-l); color: var(--red); font-weight: 700; font-size: 18px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.review-date { margin-left: auto; font-size: 12px; color: var(--ink-3); }
.review-card h4 { font-size: 15px; margin: 0 0 8px; }
.review-card p { font-size: 14px; color: var(--ink-2); line-height: 1.7; margin: 0; }
.review-form-wrap { background: var(--bg-2); border-radius: 12px; padding: 24px; }
.review-form-wrap h3 { font-size: 18px; margin: 0 0 16px; }
.mw-review-form { display: grid; gap: 12px; }
.mw-review-form input, .mw-review-form textarea { padding: 10px 14px; border: 1.5px solid var(--bg-3); border-radius: 8px; font-size: 14px; font-family: var(--ff-s); background: var(--bg); color: var(--ink); width: 100%; box-sizing: border-box; }
.mw-review-form input:focus, .mw-review-form textarea:focus { outline: none; border-color: var(--red); }
.review-note { font-size: 12px; color: var(--ink-3); margin: 0; }
.star-picker { display: flex; align-items: center; gap: 6px; flex-direction: row-reverse; justify-content: flex-end; }
.star-picker span { font-size: 13px; color: var(--ink-3); margin-right: 8px; }
.star-picker input[type=radio] { display: none; }
.star-picker label { font-size: 26px; color: #d1d5db; cursor: pointer; transition: color .15s; }
.star-picker input:checked ~ label, .star-picker label:hover, .star-picker label:hover ~ label { color: #E3A800; }

/* ── INTERACTIVE METRO MAP ── */
.metro-line-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 24px; }
.mlt-btn { background: var(--bg); border: 1.5px solid var(--bg-3); border-radius: 8px; padding: 8px 16px; font-family: var(--ff-m); font-size: 12px; cursor: pointer; display: flex; align-items: center; gap: 6px; color: var(--ink-2); transition: all .2s; letter-spacing: .03em; }
.mlt-btn:hover, .mlt-btn.active { background: var(--lc); color: #fff; border-color: var(--lc); }
.mlt-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--lc); flex-shrink: 0; }
.mlt-count { background: rgba(255,255,255,.2); border-radius: 10px; padding: 1px 6px; font-size: 10px; }
.metro-map-layout { display: grid; grid-template-columns: 280px 1fr; gap: 20px; min-height: 500px; margin-bottom: 40px; }
@media(max-width:768px){ .metro-map-layout { grid-template-columns: 1fr; } }
.metro-station-ribbon { background: var(--bg); border: 1.5px solid var(--bg-3); border-radius: 12px; overflow-y: auto; max-height: 500px; padding: 16px; }
.msri-placeholder, .mpp-placeholder { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100%; color: var(--ink-3); text-align: center; gap: 12px; padding: 40px 20px; }
.msri-stations { display: flex; flex-direction: column; gap: 2px; }
.msri-st { background: transparent; border: none; text-align: left; padding: 8px 12px; border-radius: 6px; cursor: pointer; font-size: 13px; display: flex; align-items: center; gap: 8px; color: var(--ink-2); transition: background .15s; }
.msri-st:hover, .msri-st.active { background: rgba(var(--lc-rgb, 226,55,68),.1); color: var(--ink); }
.msri-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; background: var(--lc); }
.metro-prop-panel { background: var(--bg); border: 1.5px solid var(--bg-3); border-radius: 12px; overflow-y: auto; max-height: 500px; padding: 16px; }
.mpp-loading { text-align: center; padding: 40px; color: var(--ink-3); }
.mpp-empty { text-align: center; padding: 40px 20px; color: var(--ink-3); }
.mpp-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.mpp-header h3 { font-size: 16px; margin: 0; }
.mpp-header span { font-size: 12px; color: var(--ink-3); }
.mpp-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; }
.mpp-card { background: var(--bg-2); border-radius: 10px; overflow: hidden; border: 1px solid var(--bg-3); transition: transform .2s; display: block; }
.mpp-card:hover { transform: translateY(-2px); }
.mpp-card-img { height: 100px; overflow: hidden; background: var(--bg-3); }
.mpp-card-img img { width: 100%; height: 100%; object-fit: cover; }
.mpp-card-ph { display: flex; align-items: center; justify-content: center; height: 100%; font-size: 30px; opacity: .3; }
.mpp-card-body { padding: 10px; }
.mpp-card-body h4 { font-size: 13px; margin: 0 0 4px; color: var(--ink); }
.mpp-price { font-size: 15px; font-weight: 700; color: var(--red); font-family: var(--ff-d); margin-bottom: 4px; }
.mpp-card-body p { font-size: 11px; color: var(--ink-3); margin: 0 0 6px; }

/* ── METRO SCHEMATIC ── */
.metro-schematic-wrap { margin: 40px 0; }
.metro-schematic { background: var(--bg); border: 1.5px solid var(--bg-3); border-radius: 16px; padding: 20px; overflow: auto; text-align: center; }
.metro-schematic svg { max-width: 100%; height: auto; }

/* ── ALL LINES GRID ── */
.all-lines-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; margin-top: 40px; }
.alg-card { background: var(--bg); border: 1.5px solid var(--bg-3); border-radius: 12px; padding: 20px; }
.alg-head { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.alg-dot { width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0; }
.alg-head h3 { font-size: 16px; margin: 0; flex: 1; }
.alg-len { font-size: 12px; color: var(--ink-3); }
.alg-stations { font-size: 13px; color: var(--ink-3); margin: 0 0 12px; }
.alg-key-stations { display: flex; gap: 6px; flex-wrap: wrap; }
.metro-st-chip { padding: 4px 10px; border-radius: 20px; font-size: 11px; cursor: pointer; font-family: var(--ff-m); text-decoration: none; background: color-mix(in srgb, var(--lc) 12%, transparent); color: var(--lc); border: 1px solid color-mix(in srgb, var(--lc) 30%, transparent); }
.metro-st-chip:hover { background: var(--lc); color: #fff; }

/* ── INVESTMENT SCORE TABLE ── */
.invest-score-table { background: var(--bg); border: 1.5px solid var(--bg-3); border-radius: 12px; overflow: hidden; }
.ist-row { display: flex; align-items: center; gap: 16px; padding: 14px 20px; border-bottom: 1px solid var(--bg-3); flex-wrap: wrap; }
.ist-row:last-child { border-bottom: none; }
.ist-row:hover { background: var(--bg-2); }
.ist-rank { width: 28px; height: 28px; border-radius: 50%; background: var(--red-l); color: var(--red); font-weight: 700; font-size: 13px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ist-station { flex: 1; min-width: 160px; }
.ist-station strong { display: block; font-size: 15px; margin-bottom: 3px; }
.ist-station span { font-size: 12px; color: var(--ink-3); display: flex; align-items: center; }
.ist-insight { flex: 2; font-size: 13px; color: var(--ink-3); min-width: 180px; }
.ist-score { font-size: 20px; font-weight: 800; font-family: var(--ff-d); min-width: 60px; text-align: center; }
.ist-bar { flex: 1; min-width: 80px; height: 6px; background: var(--bg-3); border-radius: 3px; overflow: hidden; }
.ist-bar-fill { height: 100%; border-radius: 3px; transition: width .5s; }

/* ── INVEST SCORE BANNER (single property) ── */
.invest-score-banner { background: linear-gradient(135deg, #111827, #1f2937); border-radius: 16px; padding: 28px 32px; }
@media(max-width:640px){ .invest-score-banner { padding: 20px; } }

/* ── TESTIMONIALS ── */
.testimonials-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }
.testi-card { background: var(--bg); border: 1.5px solid var(--bg-3); border-radius: 12px; padding: 24px; }
.testi-stars { font-size: 20px; color: #E3A800; margin-bottom: 12px; }
.testi-text { font-size: 15px; line-height: 1.7; color: var(--ink-2); margin: 0 0 16px; font-style: italic; }
.testi-author strong { display: block; font-size: 15px; color: var(--ink); }
.testi-author span { font-size: 13px; color: var(--ink-3); }

/* ── COMPARE BUTTON on cards ── */
.mw-compare-btn { transition: all .2s; }
.mw-compare-btn:hover { opacity: .85; }

/* ── PILL TAGS ── */
.pill { display: inline-block; padding: 3px 8px; border-radius: 20px; font-size: 11px; background: var(--bg-2); color: var(--ink-2); font-family: var(--ff-m); margin-right: 4px; }

/* ── ALERT ── */
.alert { padding: 14px 18px; border-radius: 8px; font-size: 14px; font-weight: 600; }
.alert-success { background: #d1fae5; color: #065f46; }

/* ── BREADCRUMB ── */
.mw-breadcrumb { font-family: var(--ff-m); font-size: 11px; color: var(--ink-3); margin-bottom: 20px; letter-spacing: .04em; }
.mw-breadcrumb a { color: var(--ink-3); text-decoration: none; }
.mw-breadcrumb a:hover { color: var(--red); }
.mw-breadcrumb span { color: var(--ink); }

/* ═══════════════════════════════════════════════
   METROWALA v6 — LIFE DECISION PLATFORM STYLES
═══════════════════════════════════════════════ */

/* ── SINGLE PROPERTY v6 ── */
.sp-gallery-wrap { margin-bottom: 0; }
.gallery-badges  { position:absolute;top:20px;left:20px;display:flex;gap:8px;flex-wrap:wrap;z-index:2; }
.sp-left  { min-width: 0; }
.sp-right { min-width: 0; }
.sp-h1    { font-size: clamp(20px,3vw,30px); margin-bottom: 6px; }
.sp-loc   { font-size: 15px; color: var(--ink-3); margin: 0; }
.sp-title-row { display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:16px; }

/* Quick decision chips */
.sp-decision-chips { display:flex;gap:10px;flex-wrap:wrap;margin:16px 0; }
.sp-chip { background:var(--bg-2);border:1.5px solid var(--bg-3);border-radius:10px;padding:10px 14px;display:flex;flex-direction:column;gap:2px;min-width:110px; }
.sp-chip span  { font-size:10px;color:var(--ink-3);font-family:var(--ff-m);text-transform:uppercase;letter-spacing:.05em; }
.sp-chip strong{ font-size:15px;font-weight:700;color:var(--ink);font-family:var(--ff-d); }
.sp-chip--score { border-color:var(--red);background:var(--red-l); }
.sp-chip--score strong { color:var(--red); }
.sp-chip--green strong { color:#059669; }
.sp-chip--gold  strong { color:#D97706; }
.sp-chip--red   strong { color:#E23744; }
.sp-chip:hover  { border-color:var(--red); }

/* Section dividers */
.sp-section { margin-top:28px;padding-top:28px;border-top:1.5px solid var(--bg-3); }
.sp-section h2 { font-size:20px;margin-bottom:14px; }
.sp-content { font-size:15px;line-height:1.85;color:var(--ink-2); }

/* RERA box */
.rera-box { margin-top:20px;background:var(--bg-2);border-radius:10px;padding:14px 16px;display:flex;align-items:center;gap:12px; }
.rera-label { font-family:var(--ff-m);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:2px; }
.rera-num   { font-family:var(--ff-m);font-size:14px;font-weight:600;color:var(--ink); }

/* Share row */
.sp-share { margin-top:24px;padding:16px 18px;background:var(--bg-2);border-radius:12px;display:flex;align-items:center;gap:10px;flex-wrap:wrap; }
.sp-share span { font-size:12px;color:var(--ink-3);font-family:var(--ff-m); }

/* Contact card extras */
.emi-estimate { background:var(--red-l);border-radius:8px;padding:10px 14px;margin-bottom:16px; }
.emi-label    { font-family:var(--ff-m);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--red);margin-bottom:2px; }
.emi-val      { font-weight:700;font-size:17px;color:var(--ink); }
.emi-val span { font-size:11px;font-weight:400;color:var(--ink-3); }
.ccard-more-link { display:block;font-size:12px;color:var(--ink-3);margin-top:8px;text-align:center;text-decoration:none; }
.ccard-more-link:hover { color:var(--red); }
.agent-row    { border-top:1.5px solid var(--bg-3);padding-top:14px;margin-top:14px;display:flex;align-items:center;gap:10px; }
.agent-avatar { width:38px;height:38px;border-radius:50%;background:var(--red-l);color:var(--red);font-weight:700;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.agent-name   { font-weight:700;font-size:14px;color:var(--ink); }
.agent-tag    { font-size:11px;color:var(--ink-3); }

/* Quick Decision Box */
.quick-decision-box { background:var(--bg);border:1.5px solid var(--bg-3);border-radius:14px;padding:18px;margin-top:16px; }
.quick-decision-box h4 { font-size:14px;margin:0 0 12px;font-family:var(--ff-m);text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3); }
.qd-item { display:flex;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid var(--bg-3);font-size:13px; }
.qd-item:last-child { border-bottom:none; }
.qd-item.fail { color:var(--ink-3); }

/* ── DECISION DASHBOARD ── */
.decision-dashboard { max-width:100%; }

/* Verdict Banner */
.dd-verdict-banner { color:#fff; }
.dd-eyebrow { font-family:var(--ff-m);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#D4AF37;display:block;margin-bottom:8px; }
.dd-verdict-title { font-size:clamp(20px,3vw,28px);margin:0 0 12px;color:#fff; }
.dd-verdict-top { display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:12px; }
.dd-verdict-badge { padding:8px 18px;border-radius:30px;font-weight:700;font-size:14px;font-family:var(--ff-m);white-space:nowrap;text-align:center; }
.dd-verdict-note { font-size:14px;color:rgba(255,255,255,.7);margin:0 0 24px; }

/* Composite score ring */
.dd-composite-row { display:flex;align-items:center;gap:28px;flex-wrap:wrap; }
.dd-score-ring { display:flex;flex-direction:column;align-items:center;gap:8px;flex-shrink:0; }
.dd-score-label { font-size:11px;color:rgba(255,255,255,.5);font-family:var(--ff-m);text-transform:uppercase;letter-spacing:.06em; }
.dd-score-pillars { display:grid;grid-template-columns:repeat(3,1fr);gap:12px;flex:1;min-width:260px; }
@media(max-width:520px){ .dd-score-pillars { grid-template-columns:repeat(2,1fr); } }
.dd-pillar { background:rgba(255,255,255,.06);border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:4px; }
.dd-pillar-icon  { font-size:20px; }
.dd-pillar-label { font-size:10px;color:rgba(255,255,255,.5);font-family:var(--ff-m);text-transform:uppercase;letter-spacing:.04em; }
.dd-pillar-value { font-size:13px;font-weight:700; }

/* Buyer profiles */
.dd-profiles { margin-top:20px;display:flex;align-items:center;gap:10px;flex-wrap:wrap; }
.dd-profiles-label { font-size:12px;color:rgba(255,255,255,.5);font-family:var(--ff-m); }
.dd-profile-chip { background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.85);padding:5px 12px;border-radius:20px;font-size:12px;font-family:var(--ff-m); }

/* Tabs */
.dd-tabs { display:flex;gap:6px;flex-wrap:wrap;margin:24px 0 0;border-bottom:2px solid var(--bg-3);padding-bottom:0; }
.dd-tab { padding:10px 16px;border:none;background:transparent;font-family:var(--ff-m);font-size:12px;color:var(--ink-3);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;letter-spacing:.03em;transition:all .2s;border-radius:6px 6px 0 0; }
.dd-tab:hover  { color:var(--ink);background:var(--bg-2); }
.dd-tab.active { color:var(--red);border-bottom-color:var(--red);font-weight:700; }

/* Panels */
.dd-panel { display:none;padding:28px 0; }
.dd-panel.active { display:block; }
.dd-panel-head { margin-bottom:24px; }
.dd-panel-head h3 { font-size:22px;margin:0 0 8px; }
.dd-panel-head p  { font-size:15px;color:var(--ink-2);margin:0; }

/* Stat cards */
.dd-grid-3 { display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:20px; }
.dd-stat-card { background:var(--bg);border:1.5px solid var(--bg-3);border-radius:14px;padding:20px;text-align:center; }
.dd-stat-card--green { border-color:#059669;background:#059669;background:linear-gradient(135deg,#064e3b,#065f46);color:#fff; }
.dd-stat-card--green .dd-stat-val,.dd-stat-card--green .dd-stat-label,.dd-stat-card--green .dd-stat-note { color:#fff; }
.dd-stat-card--green .dd-stat-note { opacity:.7; }
.dd-stat-icon  { font-size:28px;margin-bottom:10px; }
.dd-stat-val   { font-size:24px;font-weight:800;font-family:var(--ff-d);color:var(--ink);line-height:1;margin-bottom:6px; }
.dd-stat-label { font-size:12px;font-weight:600;color:var(--ink-2);margin-bottom:4px; }
.dd-stat-note  { font-size:11px;color:var(--ink-3);line-height:1.4; }

/* Insight box */
.dd-insight-box { background:var(--bg-2);border-left:4px solid var(--red);border-radius:0 12px 12px 0;padding:18px 20px;display:flex;gap:14px;align-items:flex-start;margin-top:8px; }
.dd-insight-icon { font-size:22px;flex-shrink:0;margin-top:2px; }
.dd-insight-box strong { display:block;font-size:15px;margin-bottom:6px; }
.dd-insight-box p { font-size:14px;color:var(--ink-2);margin:0 0 8px;line-height:1.7; }
.dd-insight-box p:last-child { margin:0; }
.dd-warning { color:#D97706;font-size:13px;background:#FEF3C7;border-radius:6px;padding:8px 12px;margin-top:8px!important; }

/* Commute line strip */
.dd-metro-line-strip { display:flex;align-items:center;gap:12px;flex-wrap:wrap; }

/* Disclaimer */
.dd-disclaimer { font-size:11px;color:var(--ink-3);font-style:italic;margin-top:16px;line-height:1.6; }

/* Value verdict */
.dd-value-verdict { display:flex;align-items:center;gap:12px; }

/* Family scores */
.dd-family-scores { display:flex;flex-direction:column;gap:14px; }
.dd-family-row    { display:flex;align-items:center;gap:12px; }
.dd-family-icon   { font-size:22px;width:32px;text-align:center;flex-shrink:0; }
.dd-family-info   { min-width:140px;flex-shrink:0; }
.dd-family-name   { font-size:13px;font-weight:600;color:var(--ink); }
.dd-family-note   { font-size:11px;color:var(--ink-3); }
.dd-family-bar-wrap { flex:1;height:8px;background:var(--bg-3);border-radius:4px;overflow:hidden;min-width:80px; }
.dd-family-bar    { height:100%;border-radius:4px;transition:width .6s ease; }
.dd-family-score  { font-weight:700;font-size:14px;min-width:40px;text-align:right;font-family:var(--ff-d); }

/* Risk header */
.dd-risk-header { display:flex;align-items:flex-start;gap:16px;flex-wrap:wrap; }

/* Checklist */
.dd-checklist { display:flex;flex-direction:column;gap:10px;margin-bottom:20px; }
.dd-check-row { display:flex;gap:12px;align-items:flex-start;padding:12px 16px;border-radius:10px;background:var(--bg); }
.dd-check-row.pass { border-left:3px solid #059669; }
.dd-check-row.fail { border-left:3px solid #E23744;background:#FEF2F2; }
.dd-check-icon { font-size:18px;flex-shrink:0;margin-top:1px; }
.dd-check-row strong { display:block;font-size:14px;margin-bottom:2px; }
.dd-check-row p { font-size:12px;color:var(--ink-3);margin:0; }

/* Red flags */
.dd-red-flags { background:#FEF2F2;border:1.5px solid #FECACA;border-radius:12px;padding:16px 18px;margin-bottom:20px; }
.dd-red-flags h4 { font-size:14px;color:#991B1B;margin:0 0 10px; }
.dd-red-flag { font-size:13px;color:#DC2626;padding:6px 0;border-bottom:1px solid #FECACA; }
.dd-red-flag:last-child { border-bottom:none;padding-bottom:0; }

/* RERA box */
.dd-rera-box { background:#EFF6FF;border:1.5px solid #BFDBFE;border-radius:12px;padding:16px 18px;display:flex;gap:12px;align-items:flex-start; }
.dd-rera-box strong { display:block;font-size:14px;margin-bottom:4px; }
.dd-rera-box p { font-size:12px;color:var(--ink-3);margin:0; }
.dd-rera-box a { color:#2563EB; }

/* Legal sections */
.dd-legal-section { margin-bottom:20px; }
.dd-legal-section h4 { font-size:14px;margin:0 0 10px; }
.dd-legal-clear,.dd-legal-risk { font-size:14px;padding:8px 0;border-bottom:1px solid var(--bg-3);line-height:1.5; }
.dd-legal-clear { color:var(--ink-2); }
.dd-legal-risk  { color:var(--ink-2); }

/* Documents */
.dd-docs { background:var(--bg-2);border-radius:12px;padding:20px;margin-top:16px; }
.dd-docs h4 { font-size:15px;margin:0 0 14px; }
.dd-docs-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;margin-bottom:12px; }
.dd-doc-item { font-size:13px;padding:8px 10px;background:var(--bg);border-radius:7px;border:1px solid var(--bg-3); }

/* Infrastructure */
.dd-infra-impact { margin-bottom:20px; }
.dd-infra-list   { display:flex;flex-direction:column;gap:14px; }
.dd-infra-item   { display:flex;gap:14px;align-items:flex-start;padding:16px;background:var(--bg);border-radius:12px;border:1.5px solid var(--bg-3); }
.dd-infra-icon   { font-size:24px;flex-shrink:0; }
.dd-infra-body   { flex:1; }
.dd-infra-body strong { display:block;font-size:15px;margin-bottom:4px; }
.dd-infra-body p { font-size:13px;color:var(--ink-3);margin:0; }
.dd-infra-meta   { display:flex;flex-direction:column;gap:6px;align-items:flex-end;flex-shrink:0; }
.dd-infra-timeline { font-size:12px;color:var(--ink-3);font-family:var(--ff-m); }
.dd-infra-impact-badge,.dd-infra-impact { font-size:11px;font-weight:700;font-family:var(--ff-m);padding:3px 10px;border-radius:20px;white-space:nowrap; }

/* ── DECISION PILLARS GRID (homepage) ── */
.decision-pillars-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px; }
.dp-card  { background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:22px;transition:transform .2s,background .2s; }
.dp-card:hover { transform:translateY(-4px);background:rgba(255,255,255,.08); }
.dp-icon  { font-size:28px;margin-bottom:12px; }
.dp-title { font-size:15px;font-weight:700;color:#fff;margin:0 0 8px; }
.dp-desc  { font-size:13px;color:rgba(255,255,255,.55);line-height:1.65;margin:0; }

/* ── PROPERTY CARD v6: score badge ── */
.card-score-badge { position:absolute;top:10px;right:10px;background:#111827;color:#D4AF37;font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;font-family:var(--ff-m);letter-spacing:.04em;z-index:3; }

/* ═══════════════════════════════════════════════
   v7 — PROGRAMMATIC ENTITY PAGES
   Locality / Station / Line landing pages
═══════════════════════════════════════════════ */
.entity-hero { padding: 28px 0 36px; }
.entity-hero-grid { display:grid; grid-template-columns: 1fr 320px; gap:32px; align-items:start; }
@media(max-width:820px){ .entity-hero-grid { grid-template-columns:1fr; } }
.entity-h1 { font-size:clamp(24px,4vw,38px); line-height:1.15; letter-spacing:-0.02em; color:#0F172A; margin:0 0 14px; }
.entity-h1 strong { color:#991B1B; font-weight:800; }
.entity-sub { font-size:16px; line-height:1.7; color:#475569; margin:0 0 22px; max-width:640px; }
.entity-hero-actions { display:flex; gap:12px; flex-wrap:wrap; }

.entity-metro-card { background:#fff; border:1px solid #E2E8F0; border-radius:16px; padding:22px; box-shadow:0 4px 16px rgba(15,23,42,.04); }
.emc-eyebrow { font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:#94A3B8; }
.entity-metro-card h3 { font-size:20px; margin:6px 0 10px; color:#0F172A; }
.emc-line { display:inline-flex; align-items:center; gap:8px; font-size:13px; font-weight:600; color:#475569; margin-bottom:10px; }
.emc-line span { width:12px; height:12px; border-radius:50%; }
.entity-metro-card p { font-size:13px; color:#64748B; margin:4px 0; }
.emc-score { display:flex; justify-content:space-between; padding:6px 0; border-bottom:1px solid #F1F5F9; font-size:13px; }
.emc-score strong { color:#0F172A; }

.entity-station-lines { display:flex; gap:8px; flex-wrap:wrap; align-items:center; }
.esl-pill { display:inline-flex; align-items:center; gap:6px; background:#fff; border:1px solid #E2E8F0; border-radius:30px; padding:5px 12px; font-size:12px; font-weight:600; color:#334155; }
.esl-pill span { width:9px; height:9px; border-radius:50%; background:var(--lc); }
.esl-interchange { background:#FEF3C7; color:#92400E; border-radius:30px; padding:5px 12px; font-size:12px; font-weight:700; }

/* Decision score cards */
.loc-scores-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px; }
.loc-score-card { background:#fff; border:1px solid #E2E8F0; border-radius:12px; padding:18px; }
.lsc-top { display:flex; justify-content:space-between; align-items:baseline; margin-bottom:10px; }
.lsc-label { font-size:14px; font-weight:600; color:#334155; }
.lsc-val { font-size:22px; font-weight:800; font-family:var(--ff-d); }
.lsc-val small { font-size:12px; color:#94A3B8; font-weight:400; }
.lsc-bar { height:8px; background:#F1F5F9; border-radius:4px; overflow:hidden; }
.lsc-fill { height:100%; border-radius:4px; transition:width .6s ease; }

.loc-market-strip { display:flex; gap:16px; flex-wrap:wrap; margin-top:24px; }
.loc-market-strip > div { flex:1; min-width:140px; background:#F8FAFC; border:1px solid #E2E8F0; border-radius:12px; padding:16px; text-align:center; }
.loc-market-strip span { display:block; font-size:11px; text-transform:uppercase; letter-spacing:.06em; color:#94A3B8; margin-bottom:4px; }
.loc-market-strip strong { font-size:20px; color:#0F172A; font-family:var(--ff-d); }

/* Zero-data fallback */
.entity-fallback { text-align:center; max-width:520px; margin:0 auto; padding:48px 24px; background:#fff; border:1px dashed #CBD5E1; border-radius:18px; }
.ef-icon { font-size:48px; margin-bottom:16px; }
.entity-fallback h3 { font-size:22px; color:#0F172A; margin:0 0 10px; }
.entity-fallback p { font-size:15px; color:#64748B; line-height:1.7; margin:0 0 24px; }
.ef-actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

/* Internal links */
.entity-links-grid { display:grid; grid-template-columns:1fr 1fr; gap:32px; }
@media(max-width:640px){ .entity-links-grid { grid-template-columns:1fr; } }
.entity-links-col h3 { font-size:16px; color:#0F172A; margin:0 0 14px; }
.entity-link-chips { display:flex; gap:8px; flex-wrap:wrap; }
.entity-chip { background:#fff; border:1px solid #E2E8F0; border-radius:30px; padding:7px 14px; font-size:13px; color:#334155; text-decoration:none; transition:all .15s; }
.entity-chip:hover { border-color:#991B1B; color:#991B1B; background:#FEF2F2; }

/* Line stations strip */
.line-stations-strip { display:flex; flex-wrap:wrap; gap:4px; padding:8px 0; }
.line-station-node { display:inline-flex; align-items:center; gap:8px; padding:8px 14px; background:#fff; border:1px solid #E2E8F0; border-radius:10px; text-decoration:none; color:#334155; font-size:13px; transition:all .15s; }
.line-station-node:hover { border-color:var(--lc); color:#0F172A; transform:translateY(-1px); }
.lsn-dot { width:9px; height:9px; border-radius:50%; background:var(--lc); flex-shrink:0; }

/* FAQ */
.entity-faqs { display:flex; flex-direction:column; gap:12px; }
.entity-faq { background:#fff; border:1px solid #E2E8F0; border-radius:12px; padding:0; overflow:hidden; }
.entity-faq summary { padding:16px 20px; font-size:15px; font-weight:600; color:#0F172A; cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center; }
.entity-faq summary::after { content:'+'; font-size:22px; color:#991B1B; font-weight:300; }
.entity-faq[open] summary::after { content:'−'; }
.entity-faq p { padding:0 20px 18px; margin:0; font-size:14px; line-height:1.7; color:#475569; }

/* ═══════════════════════════════════════════════
   v7 — ICE-WHITE HERO COMMAND CENTER
═══════════════════════════════════════════════ */
.hero-v7 { position:relative; background:#F8FAFC; padding:56px 0 0; overflow:hidden; border-bottom:1px solid #E2E8F0; }
.hero-v7-lines { position:absolute; inset:0; width:100%; height:100%; z-index:0; opacity:.7; }
.hero-v7-inner { position:relative; z-index:2; text-align:center; max-width:960px; margin:0 auto; }
.hero-v7-tag { display:inline-block; background:#fff; border:1px solid #E2E8F0; border-radius:30px; padding:8px 18px; font-size:13px; font-weight:600; color:#475569; margin-bottom:26px; box-shadow:0 2px 8px rgba(15,23,42,.04); }
.hero-v7-h1 { font-size:clamp(32px,5.5vw,60px); line-height:1.08; letter-spacing:-0.03em; font-weight:800; color:#0F172A; margin:0 0 20px; }
.hero-v7-h1 span { color:#991B1B; }
.hero-v7-sub { font-size:clamp(15px,2vw,19px); line-height:1.6; color:#475569; max-width:680px; margin:0 auto 36px; }

/* Widget */
.hero-v7-widget { background:#fff; border:1px solid #F1F5F9; border-radius:24px; box-shadow:0 20px 60px rgba(15,23,42,.10); max-width:900px; margin:0 auto; overflow:hidden; text-align:left; }
.hv7-tabs { display:flex; gap:0; border-bottom:1px solid #F1F5F9; }
.hv7-tab { flex:1; background:#fff; border:none; padding:18px; font-size:15px; font-weight:700; color:#94A3B8; cursor:pointer; transition:all .15s; border-bottom:3px solid transparent; }
.hv7-tab.on { color:#991B1B; border-bottom-color:#991B1B; background:#FEFCFC; }
.hv7-panel { display:none; padding:28px; }
.hv7-panel.on { display:block; }

/* Metro search box */
.hv7-search-box { display:flex; align-items:center; gap:12px; background:#F8FAFC; border:2px solid #E2E8F0; border-radius:14px; padding:6px 6px 6px 18px; transition:border-color .15s; }
.hv7-search-box:focus-within { border-color:#991B1B; background:#fff; }
.hv7-search-box input[type=text] { flex:1; border:none; background:transparent; font-size:16px; padding:14px 0; outline:none; color:#0F172A; }
.hv7-go { background:#991B1B; color:#fff; border:none; border-radius:10px; padding:14px 28px; font-size:15px; font-weight:700; cursor:pointer; transition:background .15s; }
.hv7-go:hover { background:#7f1414; }
.hv7-dropdown { display:none; margin-top:10px; background:#fff; border:1px solid #E2E8F0; border-radius:14px; box-shadow:0 12px 32px rgba(15,23,42,.12); max-height:340px; overflow-y:auto; padding:8px; }
.hv7-dropdown.show { display:block; }
.hv7-dd-line { display:flex; align-items:center; gap:8px; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:#94A3B8; padding:10px 12px 6px; }
.hv7-dd-line span { width:10px; height:10px; border-radius:50%; }
.hv7-dd-item { display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:8px; font-size:14px; color:#334155; text-decoration:none; }
.hv7-dd-item:hover { background:#F8FAFC; color:#991B1B; }
.hv7-dd-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.hv7-dd-hint { padding:18px; text-align:center; color:#94A3B8; font-size:14px; }

/* Commute calculator */
.hv7-commute-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:18px; }
@media(max-width:560px){ .hv7-commute-row { grid-template-columns:1fr; } }
.hv7-field label { display:block; font-size:12px; font-weight:700; color:#64748B; margin-bottom:8px; text-transform:uppercase; letter-spacing:.04em; }
.hv7-field select { width:100%; padding:14px; border:2px solid #E2E8F0; border-radius:12px; font-size:15px; background:#F8FAFC; color:#0F172A; cursor:pointer; }
.hv7-field select:focus { border-color:#991B1B; outline:none; background:#fff; }
.hv7-calc-btn { width:100%; background:#0F172A; color:#fff; border:none; border-radius:12px; padding:16px; font-size:15px; font-weight:700; cursor:pointer; transition:background .15s; }
.hv7-calc-btn:hover { background:#991B1B; }
.hv7-result { margin-top:20px; background:#F8FAFC; border:1px solid #E2E8F0; border-radius:14px; padding:22px; }
.hv7-result-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; text-align:center; }
@media(max-width:560px){ .hv7-result-grid { grid-template-columns:1fr; gap:12px; } }
.hv7-result-grid span { display:block; font-size:11px; text-transform:uppercase; letter-spacing:.05em; color:#94A3B8; margin-bottom:6px; }
.hv7-result-grid strong { font-size:24px; color:#0F172A; font-weight:800; }
.hv7-result-grid > div:last-child strong { color:#059669; }
.hv7-result-note { font-size:12px; color:#94A3B8; line-height:1.6; margin:16px 0 0; }

/* Quick pills */
.hero-v7-pills { display:flex; gap:10px; flex-wrap:wrap; justify-content:center; margin:28px auto 0; max-width:760px; }
.hv7-pill { background:#fff; border:1px solid #E2E8F0; border-radius:30px; padding:10px 18px; font-size:14px; font-weight:600; color:#334155; text-decoration:none; transition:all .15s; box-shadow:0 1px 3px rgba(15,23,42,.04); }
.hv7-pill:hover { border-color:#991B1B; color:#991B1B; transform:translateY(-2px); box-shadow:0 6px 16px rgba(153,27,27,.12); }

/* Stats */
.hero-v7-stats { display:flex; gap:40px; justify-content:center; flex-wrap:wrap; margin:44px 0 40px; }
.hero-v7-stats strong { display:block; font-size:30px; font-weight:800; color:#0F172A; letter-spacing:-0.02em; }
.hero-v7-stats span { font-size:13px; color:#64748B; }

/* Spine */
.hero-v7-spine { display:flex; height:6px; width:100%; }

/* ═══════════════════════════════════════════════
   v7.2 — HERO UPGRADE, DECISION SCORE, TRUST, MOBILE UX
═══════════════════════════════════════════════ */

/* Trust indicator row under subhead */
.hero-v7-trustrow{display:flex;gap:10px 22px;flex-wrap:wrap;justify-content:center;margin:0 auto 30px;max-width:680px}
.hero-v7-trustrow span{font-size:13.5px;font-weight:600;color:#475569;white-space:nowrap}

/* Widget radius consistency = 24px */
.hero-v7-widget{border-radius:24px}

/* LAYER 1: intent pills */
.hv7-intent{display:flex;gap:8px;padding:18px 18px 0;flex-wrap:wrap;justify-content:center}
.hv7-intent-pill{flex:0 0 auto;min-height:44px;padding:10px 22px;border:2px solid #E2E8F0;background:#fff;border-radius:30px;font-size:14px;font-weight:700;color:#475569;cursor:pointer;transition:all .15s}
.hv7-intent-pill.on{border-color:#991B1B;background:#991B1B;color:#fff;box-shadow:0 4px 12px rgba(153,27,27,.2)}

/* LAYER 2: mode pills */
.hv7-mode{display:flex;gap:6px;padding:16px 18px 4px;flex-wrap:wrap;justify-content:center;border-bottom:1px solid #F1F5F9}
.hv7-mode-pill{flex:0 0 auto;min-height:42px;padding:9px 16px;border:none;background:transparent;border-radius:10px;font-size:13.5px;font-weight:600;color:#94A3B8;cursor:pointer;transition:all .15s}
.hv7-mode-pill:hover{background:#F8FAFC;color:#475569}
.hv7-mode-pill.on{background:#FEF2F2;color:#991B1B}

/* panels */
.hv7-panel{display:none;padding:24px 26px 26px}
.hv7-panel.on{display:block}
.hv7-panel-hint{font-size:13px;color:#64748B;margin:14px 4px 0;text-align:center}
.hv7-panel-hint a{color:#991B1B;font-weight:600;text-decoration:none}

/* search box: input + button never overlap (flex, button flex-shrink:0) */
.hv7-search-box{display:flex;align-items:center;gap:10px;background:#F8FAFC;border:2px solid #E2E8F0;border-radius:16px;padding:6px 6px 6px 16px;transition:border-color .15s}
.hv7-search-box:focus-within{border-color:#991B1B;background:#fff}
.hv7-search-ico{flex:0 0 auto}
.hv7-search-box input[type=text]{flex:1 1 auto;min-width:0;border:none;background:transparent;font-size:16px;padding:14px 0;outline:none;color:#0F172A}
.hv7-go{flex:0 0 auto;min-height:48px;background:#991B1B;color:#fff;border:none;border-radius:11px;padding:0 26px;font-size:15px;font-weight:700;cursor:pointer;transition:background .15s}
.hv7-go:hover{background:#7f1414}

/* LAYER 4: chips */
.hv7-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px;align-items:center}
.hv7-chip{min-height:40px;padding:8px 15px;border:1.5px solid #E2E8F0;background:#fff;border-radius:30px;font-size:13px;font-weight:600;color:#475569;cursor:pointer;transition:all .15s}
.hv7-chip:hover{border-color:#CBD5E1;background:#F8FAFC}
.hv7-chip.on{border-color:#991B1B;background:#FEF2F2;color:#991B1B}
.hv7-chip-div{width:1px;height:22px;background:#E2E8F0;margin:0 4px}

/* DECISION SCORE PREVIEW */
.hv7-scorepreview{background:#fff;padding:56px 0;border-bottom:1px solid #E2E8F0}
.hv7-score-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;max-width:920px;margin:0 auto}
.hv7-score-card{background:#F8FAFC;border:1px solid #E2E8F0;border-radius:24px;padding:26px 16px;text-align:center;transition:transform .2s,box-shadow .2s}
.hv7-score-card:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(15,23,42,.06)}
.hv7-score-num{font-size:40px;font-weight:800;color:#991B1B;line-height:1;letter-spacing:-.03em}
.hv7-score-lab{font-size:13px;font-weight:700;color:#0F172A;margin-top:10px}
.hv7-score-sub{font-size:12px;color:#94A3B8;margin-top:2px}
.hv7-score-verified .hv7-score-check{font-size:38px;color:#059669;font-weight:800;line-height:1}
.hv7-score-verified .hv7-score-sub{color:#059669;font-weight:700}
.hv7-score-note{text-align:center;font-size:12px;color:#94A3B8;margin:24px auto 0;max-width:560px}

/* WHY TRUST cards */
.hv7-trust{background:#F8FAFC}
.hv7-trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.hv7-trust-card{background:#fff;border:1px solid #E2E8F0;border-radius:24px;padding:28px 24px;transition:transform .2s,box-shadow .2s}
.hv7-trust-card:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(15,23,42,.07)}
.hv7-trust-ico{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.hv7-trust-card h3{font-size:17px;font-weight:700;color:#0F172A;margin:0 0 8px}
.hv7-trust-card p{font-size:14px;line-height:1.6;color:#64748B;margin:0}

/* ── DESKTOP HEADER touch targets (≥48px) ── */
.btn-wa-nav,.btn-list{min-height:44px}

/* ═══════════ MOBILE UX FIXES (≤768px) ═══════════ */
@media(max-width:768px){
  /* Fix 1: logo always visible, prioritised */
  .nav-inner{gap:8px}
  .nav-logo{margin-right:auto;flex:1 1 auto;min-width:0}
  .nav-logo img{height:38px;max-width:160px;width:auto}
  /* Fix 1: hide List Property on mobile; shrink WhatsApp to icon */
  .btn-list{display:none}
  .btn-wa-nav{padding:0;width:44px;height:44px;justify-content:center;border-radius:12px;gap:0}
  .btn-wa-nav .btn-wa-nav-label{display:none}
  .nav-actions{gap:6px;margin-left:8px}
  /* Fix 6: hamburger ≥44px tap target */
  .hamburger{width:44px;height:44px;justify-content:center;align-items:center;gap:5px;padding:10px;margin-left:2px}
  .hamburger span{width:22px}

  /* Fix 5: hero container full width + 16-20px padding */
  .hero-v7{padding-top:36px}
  .hero-v7-inner{padding-left:16px;padding-right:16px}
  .hero-v7-widget{border-radius:20px}
  .hero-v7-h1{font-size:clamp(30px,8vw,40px)}

  /* Fix 2+3: search input/button stack full width, no overlap */
  .hv7-search-box{flex-wrap:wrap;padding:10px}
  .hv7-search-box input[type=text]{flex:1 1 100%;order:1;padding:10px 4px;font-size:16px}
  .hv7-go{flex:1 1 100%;order:2;width:100%;min-height:50px}
  .hv7-search-ico{display:none}

  /* tabs/chips spacing + scroll instead of cram */
  .hv7-intent{padding:16px 14px 0}
  .hv7-mode{gap:6px;padding:14px 10px 4px;flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .hv7-mode::-webkit-scrollbar{display:none}
  .hv7-mode-pill{flex:0 0 auto;white-space:nowrap}
  .hv7-panel{padding:18px 16px 20px}
  .hv7-chips{gap:8px}
  .hv7-chip{min-height:44px}
  .hv7-intent-pill{min-height:46px;flex:1 1 calc(50% - 8px)}

  /* score preview: 2-up grid on phones */
  .hv7-score-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .hv7-score-card{padding:22px 12px;border-radius:20px}
  .hv7-score-num{font-size:34px}
  .hv7-trust-grid{grid-template-columns:1fr 1fr;gap:12px}
  .hv7-trust-card{padding:22px 18px;border-radius:20px}

  /* Fix 4: floating WhatsApp ~56px + safe margins, clear of scroll-cta */
  .wa-float{width:56px;height:56px;bottom:84px;right:16px}
  .wa-float svg{width:24px;height:24px}
  /* when bottom scroll-cta is visible, lift the float further */
  body.mw-cta-visible .wa-float{bottom:140px}
}

@media(max-width:420px){
  .hv7-trust-grid{grid-template-columns:1fr}
  .hero-v7-trustrow{gap:8px 16px}
  .hero-v7-trustrow span{font-size:12.5px}
}

/* iPhone SE / very narrow: keep logo readable */
@media(max-width:360px){
  .nav-logo img{max-width:140px;height:34px}
  .hero-v7-h1{font-size:27px}
}

/* ═══════════════════════════════════════════════
   v7.3 — PHASE 3: LIGHT CANVAS + PREMIUM WHATSAPP CTA
═══════════════════════════════════════════════ */

/* Phase 3.4 — premium emerald WhatsApp CTA (replaces neon #25D366) */
.btn-whatsapp{background:#16A34A;color:#fff;padding:14px 28px;border-radius:12px;font-weight:700}
.btn-whatsapp:hover{background:#15803D;color:#fff;transform:translateY(-2px);box-shadow:0 8px 22px rgba(22,163,74,.28)}
.btn-wa-nav{background:#16A34A}
.btn-wa-nav:hover{background:#15803D;box-shadow:0 4px 14px rgba(22,163,74,.32)}
.wa-float{background:#16A34A;box-shadow:0 6px 24px rgba(22,163,74,.4)}
.wa-float-pulse{background:rgba(22,163,74,.22)}
.mobile-menu a:last-child{color:#16A34A}
.btn-whatsapp.btn-sm{padding:9px 16px;border-radius:10px}
.btn-whatsapp.btn-lg{padding:16px 32px}

/* Phase 3 — light treatment for the section--red dark band */
.section--red{background:#F8FAFC !important;border-top:1px solid #E2E8F0;border-bottom:1px solid #E2E8F0}
.section--red h2,.section--red h3{color:#0F172A}
.section--red p{color:#475569}
.section--red .eyebrow{color:#991B1B}

/* Phase 3 — calc result card: light premium instead of crimson gradient */
.calc-result{background:#fff !important;border:1px solid #E2E8F0;box-shadow:0 20px 40px -15px rgba(0,0,0,.04)}
.calc-result *{color:#0F172A !important}
.calc-result .calc-result-label,.calc-result small{color:#64748B !important}

/* Consistent premium card radius site-wide on the expanding CTA */
.cta-dark .btn-whatsapp,.cta-dark .btn{margin-top:4px}

/* v7.3 — hero property-type dropdown */
.hv7-ptype{flex:0 0 auto;border:none;background:transparent;font-size:14px;font-weight:600;color:#475569;padding:10px 8px;outline:none;cursor:pointer;border-left:1px solid #E2E8F0}
@media(max-width:768px){
  .hv7-ptype{flex:1 1 100%;order:1;border-left:none;border-top:1px solid #E2E8F0;padding:12px 4px;margin-top:4px}
}

/* ═══════════════════════════════════════════════
   v7.4 — READABILITY & CROSS-DEVICE COMFORT PASS
   Goal: comfortable, strain-free reading phone → laptop
═══════════════════════════════════════════════ */

/* Tablet step: 2-up property/trust grids (was jumping 1→4) */
@media(min-width:640px) and (max-width:1023px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .hv7-trust-grid{grid-template-columns:repeat(2,1fr)}
  .hv7-score-grid{grid-template-columns:repeat(3,1fr)}
}

/* Comfortable measure: cap long paragraph line-length so eyes don't travel
   across the full 1280px on laptops (ideal ~65-75 chars) */
.entity-sub,.hero-v7-sub,.cta-dark p,.hv7-trust-card p,.section p:not(.no-measure){max-width:68ch}
.hero-v7-sub,.cta-dark p{margin-left:auto;margin-right:auto}

/* Never let a heading overflow on tiny screens */
h1,h2,h3{overflow-wrap:break-word;word-break:normal;hyphens:none}

/* Larger, comfortable tap + text on small phones */
@media(max-width:480px){
  html{font-size:16px}
  p{font-size:15.5px;line-height:1.7}
  .btn{padding:13px 22px;font-size:15px;min-height:48px}
  .entity-h1{font-size:clamp(26px,7vw,34px)}
  /* tighten section padding so content isn't lost in whitespace on phones */
  .section,.section--sm{padding:44px 0}
  .container{padding:0 18px}
}

/* Mid-laptop: keep hero from feeling oversized on 13" screens */
@media(min-width:1024px) and (max-width:1366px){
  .hero-v7-h1{font-size:clamp(40px,4.4vw,54px)}
}

/* Respect users who set larger system text (accessibility) */
@media(prefers-reduced-motion:no-preference){
  html{scroll-behavior:smooth}
}

/* Focus-visible outlines for keyboard users (accessibility, no visual cost for mouse) */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid #991B1B;outline-offset:2px;border-radius:4px
}

/* Ensure form controls are always tall enough to tap and read */
input,select,textarea{font-size:16px}/* 16px prevents iOS auto-zoom */

/* ═══════════════════════════════════════════════
   v7.5 — DECISIVE LIGHT-CANVAS OVERHAUL
   Kills every remaining dark/red gradient site-wide and
   forces the sans-serif brand font (beats any stale cache).
   This block is LAST in the file so it wins the cascade.
═══════════════════════════════════════════════ */

/* ---- FORCE SANS-SERIF EVERYWHERE (no serif can survive) ---- */
:root{
  --ff:'Plus Jakarta Sans',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --ff-d:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;
  --ff-m:'Plus Jakarta Sans',ui-monospace,monospace;
}
body,h1,h2,h3,h4,h5,h6,.hero-v7-h1,.entity-h1,.testi-text,
.card-price-strip .price,.calc-result .amount,.ccard .price,
.hv7-score-num,.dd-stat-val,.lsc-val,.stat-num,.e404-code{
  font-family:'Plus Jakarta Sans',system-ui,-apple-system,'Segoe UI',sans-serif !important;
}
.testi-text{font-style:normal !important;}

/* ---- KILL ALL DARK / RED GRADIENTS ---- */

/* The new final CTA — clean light premium card */
.cta-final{
  background:#fff;border:1px solid #E2E8F0;border-radius:32px;
  padding:60px 48px;text-align:center;position:relative;overflow:hidden;
  box-shadow:0 20px 50px -20px rgba(15,23,42,.08);
}
.cta-final-eyebrow{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:#991B1B;
}
.cta-final h2{color:#0F172A;margin:14px 0 12px;font-size:clamp(24px,3.4vw,36px)}
.cta-final p{color:#475569;max-width:520px;margin:0 auto 28px;font-size:16px;line-height:1.6}
.cta-final-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}

/* Legacy .cta-dark (still used on 3 inner pages) → same light card */
.cta-dark{
  background:#fff !important;border:1px solid #E2E8F0 !important;
  border-radius:32px !important;
  box-shadow:0 20px 50px -20px rgba(15,23,42,.08) !important;
}
.cta-dark::after{display:none !important}
.cta-dark h2{color:#0F172A !important}
.cta-dark p{color:#475569 !important}
.cta-dark .eyebrow{color:#991B1B !important}

/* Crimson section band → light */
.section--red{background:#F8FAFC !important;border-top:1px solid #E2E8F0;border-bottom:1px solid #E2E8F0}
.section--red h2,.section--red h3{color:#0F172A !important}
.section--red p,.section--red .eyebrow{color:#475569 !important}
.section--red .eyebrow{color:#991B1B !important}

/* Dark section → light */
.section--dark{background:#F8FAFC !important}
.section--dark h2,.section--dark h3{color:#0F172A !important}
.section--dark p{color:#475569 !important}

/* Calculator result card → clean white */
.calc-result{background:#fff !important;border:1px solid #E2E8F0;box-shadow:0 12px 30px -12px rgba(15,23,42,.06)}
.calc-result *{color:#0F172A !important}
.calc-result .amount{color:#991B1B !important}
.calc-result small,.calc-result .calc-result-label{color:#64748B !important}

/* Property card image placeholder → soft neutral, not dark crimson */
.card-img{background:linear-gradient(135deg,#EEF2F6,#E2E8F0) !important}
.card-img-ph{color:#94A3B8 !important}

/* The OLD dark hero (inner pages still using .hero) → light ice canvas */
.hero{background:#F8FAFC !important}
.hero h1,.hero h2{color:#0F172A !important}
.hero .hero-sub,.hero p{color:#475569 !important}
.hero-stat strong{color:#0F172A !important}

/* ---- PREMIUM POLISH (WhatsApp-clean feel) ---- */

/* Consistent emerald WhatsApp everywhere */
.btn-whatsapp{background:#16A34A !important;color:#fff !important;border-radius:12px}
.btn-whatsapp:hover{background:#15803D !important;box-shadow:0 8px 22px rgba(22,163,74,.28)}

/* Primary buttons: crimson, comfortable, rounded */
.btn-primary{background:#991B1B !important;color:#fff !important;border-radius:12px}
.btn-primary:hover{background:#7f1414 !important;transform:translateY(-1px);box-shadow:0 8px 22px rgba(153,27,27,.22)}

/* Softer, more consistent card shadows globally */
.card,.fcard,.calc-card,.ccard,.testi-card,.dd-card{
  border-radius:20px;box-shadow:0 8px 24px -12px rgba(15,23,42,.06);border:1px solid #E2E8F0;
}

/* Generous, breathable section rhythm */
.section{padding:72px 0}
@media(max-width:640px){.section{padding:48px 0}}

/* v7.5 — simplified search hint */
.hv7-search-hint{font-size:12.5px;color:#94A3B8;text-align:center;margin:14px 0 0}

/* ═══════════════════════════════════════════════
   v7.6 — UNIFIED SEARCH WIDGET (Zillow/Compass-grade)
   This block is LAST so it is authoritative over earlier
   widget styles. Implements: single horizontal tab row,
   pixel-aligned input capsule, divider before dropdown,
   matched button radius, breathing room above the card.
═══════════════════════════════════════════════ */

/* Breathing room: push the card away from the trust ticks (req 3) */
.hero-v7-trustrow{margin-bottom:40px !important}

/* The white card */
.hero-v7-widget{
  background:#fff;border:1px solid #EEF1F5;border-radius:24px;
  box-shadow:0 24px 60px -20px rgba(15,23,42,.18);
  max-width:860px;margin:0 auto;overflow:hidden;text-align:left;
}

/* ---- REQ 1: ONE clean horizontal tab line (pill states, no harsh borders) ---- */
.hv7-tabs{
  display:flex;gap:6px;padding:14px 16px 0;border-bottom:1px solid #F1F5F9;
  flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;
}
.hv7-tabs::-webkit-scrollbar{display:none}
.hv7-tab{
  flex:0 0 auto;display:inline-flex;align-items:center;gap:7px;
  min-height:46px;padding:10px 20px;margin-bottom:14px;
  border:none;background:transparent;border-radius:12px;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:14.5px;font-weight:700;
  color:#64748B;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap;
}
.hv7-tab:hover{background:#F8FAFC;color:#334155}
.hv7-tab.on{background:#FEF2F2;color:#991B1B}   /* subtle pill state, not a hard border */

/* ---- REQ 2: pixel-perfect input capsule ---- */
.hv7-panel{display:none;padding:22px}
.hv7-panel.on{display:block}

.hv7-search-box{
  display:flex;align-items:stretch;gap:0;
  background:#F8FAFC;border:1.5px solid #E2E8F0;border-radius:16px;
  padding:6px;transition:border-color .15s,background .15s;
}
.hv7-search-box:focus-within{border-color:#991B1B;background:#fff}

/* search icon: fixed gutter so text starts at a consistent x */
.hv7-search-ico{flex:0 0 auto;align-self:center;margin:0 10px 0 12px}

/* the text input fills the middle, vertically centered */
.hv7-search-box input[type=text]{
  flex:1 1 auto;min-width:0;border:none;background:transparent;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;color:#0F172A;
  padding:0;outline:none;align-self:center;
}

/* divider + dropdowns (req 2 + req 4): a vertical rule to the LEFT of each
   selector (BHK, then type), so neither floats mid-air. */
.hv7-select-wrap{
  display:flex;align-items:center;flex:0 0 auto;
  border-left:1.5px solid #E2E8F0;margin-left:10px;padding-left:4px;
}
.hv7-select{
  border:none;background:transparent;cursor:pointer;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:14.5px;font-weight:600;
  color:#475569;padding:0 30px 0 12px;outline:none;align-self:center;
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%2394A3B8' stroke-width='2.5' viewBox='0 0 24 24'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;
}
.hv7-select:hover{color:#0F172A}

/* button radius matches inner capsule (req 2): parent r=16, pad=6 → inner r=10 */
.hv7-go{
  flex:0 0 auto;min-height:48px;margin-left:10px;
  background:#991B1B;color:#fff;border:none;border-radius:10px;
  padding:0 28px;font-family:'Plus Jakarta Sans',sans-serif;
  font-size:15px;font-weight:700;cursor:pointer;transition:background .15s;
}
.hv7-go:hover{background:#7f1414}

.hv7-search-hint{font-size:12.5px;color:#94A3B8;text-align:center;margin:14px 0 0}

/* ---- MOBILE: stack cleanly, no overlap ---- */
@media(max-width:640px){
  .hv7-tabs{padding:12px 12px 0;gap:4px}
  .hv7-tab{padding:9px 14px;font-size:13.5px;margin-bottom:12px}
  .hv7-panel{padding:16px}
  .hv7-search-box{flex-wrap:wrap;padding:8px;gap:6px}
  .hv7-search-ico{display:none}
  .hv7-search-box input[type=text]{flex:1 1 100%;order:1;padding:12px 6px;min-height:44px}
  /* both selects sit side-by-side on their own row */
  .hv7-select-wrap{flex:1 1 calc(50% - 3px);order:2;border-left:none;border-top:1.5px solid #E2E8F0;margin-left:0;padding-left:0;padding-top:4px}
  .hv7-select-wrap:last-of-type{border-left:1.5px solid #E2E8F0;padding-left:8px}
  .hv7-select{width:100%;padding:12px;min-height:44px}
  .hv7-go{flex:1 1 100%;order:3;width:100%;margin-left:0;min-height:50px}
}

/* ═══════════════════════════════════════════════
   v7.9 — PHASE 8: COMMUTE INTELLIGENCE DATA CARDS
═══════════════════════════════════════════════ */
.mw-datacards{margin:8px 0}
.mw-datacards-head{margin-bottom:18px}
.mw-dc-eyebrow{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#991B1B}
.mw-datacards-head h3{font-size:20px;color:#0F172A;margin:6px 0 0;font-weight:700}
.mw-dc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:680px){.mw-dc-grid{grid-template-columns:1fr}}
.mw-dc-card{background:#fff;border:1px solid #E2E8F0;border-radius:18px;padding:20px;box-shadow:0 8px 24px -14px rgba(15,23,42,.08);transition:transform .2s,box-shadow .2s}
.mw-dc-card:hover{transform:translateY(-3px);box-shadow:0 14px 30px -14px rgba(15,23,42,.12)}
.mw-dc-card--good{border-color:#A7F3D0;background:linear-gradient(180deg,#F0FDF4,#fff)}
.mw-dc-hub{font-size:14px;font-weight:700;color:#0F172A;margin-bottom:10px}
.mw-dc-time{font-size:34px;font-weight:800;color:#991B1B;line-height:1;letter-spacing:-.02em}
.mw-dc-time span{font-size:14px;font-weight:600;color:#94A3B8;margin-left:4px}
.mw-dc-meta{display:flex;gap:14px;margin-top:12px;font-size:13px;color:#64748B;flex-wrap:wrap}
.mw-dc-badge{margin-top:12px;display:inline-block;background:#ECFDF5;color:#059669;font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px}
.mw-dc-note{font-size:12px;color:#94A3B8;line-height:1.6;margin:16px 0 0}

/* Transit proximity card */
.mw-proximity-card{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid #E2E8F0;border-left:4px solid var(--lc);border-radius:16px;padding:18px 22px;box-shadow:0 8px 24px -16px rgba(15,23,42,.08)}
.mw-prox-ico{font-size:28px}
.mw-prox-eyebrow{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#94A3B8;margin-bottom:4px}
.mw-prox-main{font-size:16px;color:#0F172A}
.mw-prox-main strong{font-weight:700}
.mw-prox-line{display:inline-flex;align-items:center;gap:6px;margin-left:8px;font-size:13px;font-weight:600;color:#475569}
.mw-prox-dot{width:10px;height:10px;border-radius:50%;background:var(--lc)}

/* Price velocity card */
.mw-velocity-card{background:#fff;border:1px solid #E2E8F0;border-radius:18px;padding:22px;margin-top:16px;box-shadow:0 8px 24px -16px rgba(15,23,42,.08)}
.mw-vel-eyebrow{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#991B1B;margin-bottom:14px}
.mw-vel-grid{display:flex;gap:32px;flex-wrap:wrap}
.mw-vel-num{font-size:26px;font-weight:800;letter-spacing:-.02em}
.mw-vel-lab{font-size:12px;color:#64748B;margin-top:2px}

/* Sticky mobile action bar (property pages) */
.mw-prop-sticky{position:fixed;left:0;right:0;bottom:0;z-index:60;display:none;gap:10px;padding:12px 14px calc(12px + env(safe-area-inset-bottom));background:#fff;border-top:1px solid #E2E8F0;box-shadow:0 -8px 28px -12px rgba(15,23,42,.18)}
.mw-prop-sticky.show{display:flex}
.mw-sticky-btn{flex:1;min-height:50px;display:flex;align-items:center;justify-content:center;border-radius:12px;font-size:15px;font-weight:700;text-decoration:none;transition:background .15s}
.mw-sticky-call{background:#0F172A;color:#fff}
.mw-sticky-call:active{background:#1e293b}
.mw-sticky-wa{background:#16A34A;color:#fff}
.mw-sticky-wa:active{background:#15803D}
/* lift float WhatsApp above sticky bar when shown */
@media(max-width:768px){body:has(.mw-prop-sticky.show) .wa-float{bottom:86px}}

/* ═══════════════════════════════════════════════
   v7.10 — READABILITY + HERO CLEANUP (user feedback)
═══════════════════════════════════════════════ */

/* Clean dot-grid hero texture (replaces busy crossing curves) */
.hero-v7-grid{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:radial-gradient(#E2E8F0 1.2px, transparent 1.2px);
  background-size:28px 28px;
  -webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 35%, #000 30%, transparent 75%);
  mask-image:radial-gradient(ellipse 70% 60% at 50% 35%, #000 30%, transparent 75%);
  opacity:.6;
}

/* ---- WORLD-CLASS READABLE TYPE SCALE ---- */
/* Body copy: larger, more line-height, stronger contrast */
body{font-size:17px;line-height:1.7;color:#334155}
p{font-size:17px;line-height:1.75;color:#475569}
.hero-v7-sub{font-size:clamp(17px,2vw,20px);line-height:1.65;color:#475569}

/* Section headings: clearer hierarchy */
h2{font-size:clamp(24px,3.2vw,34px);line-height:1.2}
h3{font-size:clamp(18px,2.2vw,22px);line-height:1.3}

/* Cards: bump the small text that was hard to read */
.card-title{font-size:17px;line-height:1.4}
.card-loc{font-size:14.5px}
.card-meta span{font-size:14px}
.fcard p,.ccard p,.dd-card p,.hv7-trust-card p{font-size:15px;line-height:1.65}
.entity-sub{font-size:17px;line-height:1.7}
.entity-faq summary{font-size:16px}
.entity-faq p{font-size:15.5px;line-height:1.75}
.entity-chip,.hv7-pill{font-size:14.5px}

/* Data cards (commute) — ensure legible on small screens */
.mw-dc-hub{font-size:15px}
.mw-dc-meta{font-size:14px}
.mw-dc-note,.mw-dc-eyebrow{font-size:13px}

/* Trust ticks: a touch larger so they read at a glance */
.hero-v7-trustrow span{font-size:14.5px}

/* MOBILE: enforce comfortable minimums (no sub-15px reading text) */
@media(max-width:768px){
  body,p{font-size:16px;line-height:1.7}
  .hero-v7-h1{font-size:clamp(32px,8.5vw,42px);line-height:1.12}
  .hero-v7-sub{font-size:16.5px}
  .card-title{font-size:16.5px}
  .card-loc,.card-meta span{font-size:14px}
  .entity-h1{font-size:clamp(26px,7vw,32px)}
  .mw-dc-time{font-size:30px}
  .hv7-tab{font-size:14px}
  .hv7-select{font-size:15px}
  .hv7-search-box input[type=text]{font-size:16px}/* never below 16 (stops iOS zoom) */
  /* tighten the giant hero on small screens so it doesn't dominate */
  .hero-v7{padding-top:28px}
}

/* Small phones */
@media(max-width:380px){
  .hero-v7-h1{font-size:29px}
  .hero-v7-trustrow span{font-size:13px}
}
