/* ============================================================
   WESTMERE PROPERTIES — CASH HOME BUYERS
   Shared stylesheet for index + location pages
   Palette: navy #1a2744 · white · gold #d4af37
   Type:    Playfair Display (display) + Manrope (UI)
   ============================================================ */

:root{
  --navy:#1a2744;
  --navy-2:#22325a;
  --navy-deep:#131c34;
  --navy-ink:#0e1729;
  --cream:#fafaf7;
  --paper:#ffffff;
  --ink:#0e1729;
  --muted:#5b6680;
  --line:#e6e3da;
  --line-soft:#f0eee6;
  --gold:#d4af37;
  --gold-light:#ecd16a;
  --gold-glow:#f4dc8e;
  --gold-dark:#a8842a;
  --shadow-soft:0 14px 40px -18px rgba(20,30,54,.25);
  --shadow-card:0 30px 60px -30px rgba(20,30,54,.35);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--paper);color:var(--ink);font-family:'Manrope',ui-sans-serif,system-ui,sans-serif;-webkit-font-smoothing:antialiased;line-height:1.6}
html{scroll-behavior:smooth}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font-family:inherit}
button{cursor:pointer;border:0;background:transparent;color:inherit}

/* ---------- TYPE ---------- */
/* ---------- TYPE ---------- */
.display{font-family:'Playfair Display',Georgia,serif;font-weight:500;letter-spacing:-.015em;line-height:1.18;padding-bottom:.04em}
.eyebrow{font-family:'Manrope',sans-serif;text-transform:uppercase;letter-spacing:.32em;font-size:11px;font-weight:600;color:var(--gold-dark)}
.navy .eyebrow,.navy-deep .eyebrow{color:var(--gold-light)}
.lede{font-size:18px;line-height:1.7;color:var(--muted);font-weight:400}
.navy .lede,.navy-deep .lede{color:rgba(255,255,255,.78)}

/* ---------- LAYOUT ---------- */
.navy{background:var(--navy);color:#fff}
.navy-deep{background:var(--navy-deep);color:#fff}
.white-sec{background:var(--cream);color:var(--ink)}
.wrap{max-width:1320px;margin:0 auto;padding:0 56px}
section{position:relative}
.pad-xl{padding:160px 0}
.pad-l{padding:120px 0}
.pad-m{padding:80px 0}
.rule{width:60px;height:2px;background:var(--gold);margin-bottom:18px}

/* ---------- ANGLED SECTION DIVIDERS ---------- */
.angle-top{position:relative}
.angle-top::before{
  content:"";position:absolute;left:0;right:0;top:-1px;height:60px;pointer-events:none;
  background:inherit;clip-path:polygon(0 100%, 100% 0, 100% 100%, 0 100%);
  transform:translateY(-58px);
}
.angle-bot{position:relative}
.angle-bot::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:60px;pointer-events:none;
  background:inherit;clip-path:polygon(0 0, 100% 0, 100% 100%, 0 0);
  transform:translateY(58px);
}

/* ---------- BUTTONS ---------- */
.btn-gold{
  display:inline-flex;align-items:center;gap:10px;
  background:linear-gradient(180deg,var(--gold-light) 0%, var(--gold) 55%, var(--gold-dark) 100%);
  color:var(--navy-deep);font-weight:700;font-size:13px;letter-spacing:.18em;text-transform:uppercase;
  padding:18px 30px;border-radius:6px;
  position:relative;overflow:hidden;isolation:isolate;
  box-shadow:0 16px 36px -14px rgba(212,175,55,.7), inset 0 1px 0 rgba(255,255,255,.5);
  transition:transform .25s ease, box-shadow .3s ease;
}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 22px 50px -14px rgba(212,175,55,.9), 0 0 0 4px rgba(212,175,55,.18), inset 0 1px 0 rgba(255,255,255,.55)}
.btn-gold::before{
  content:"";position:absolute;top:0;left:-120%;width:65%;height:100%;
  background:linear-gradient(110deg,transparent,rgba(255,255,255,.7),transparent);
  transition:left .9s ease;z-index:0;
}
.btn-gold:hover::before{left:140%}
.btn-gold span,.btn-gold svg{position:relative;z-index:1}
.btn-float{animation:floaty 4.2s ease-in-out infinite}
.btn-float.alt{animation-delay:.6s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

.btn-ghost{
  display:inline-flex;align-items:center;gap:10px;
  border:1.5px solid rgba(255,255,255,.55);color:#fff;
  padding:17px 28px;border-radius:6px;font-weight:600;font-size:13px;letter-spacing:.18em;text-transform:uppercase;
  transition:all .25s ease;
}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:var(--gold-light);color:var(--gold-light)}

.btn-pulse{position:relative}
.btn-pulse::after{
  content:"";position:absolute;inset:0;border-radius:6px;
  box-shadow:0 0 0 0 rgba(212,175,55,.55);animation:pulseGlow 2.4s ease-out infinite;pointer-events:none;
}
@keyframes pulseGlow{
  0%{box-shadow:0 0 0 0 rgba(212,175,55,.55)}
  70%{box-shadow:0 0 0 16px rgba(212,175,55,0)}
  100%{box-shadow:0 0 0 0 rgba(212,175,55,0)}
}

/* ---------- GOLD SHIMMER TEXT ---------- */
.shimmer{
  background:linear-gradient(100deg, var(--gold-dark) 0%, var(--gold) 28%, var(--gold-glow) 50%, var(--gold) 72%, var(--gold-dark) 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:shimmer 5s linear infinite;
  padding:.1em .12em .14em .04em;
  margin:-.1em -.12em -.14em -.04em;
}
.shimmer-white{
  background:linear-gradient(100deg,#fff 0%, var(--gold-glow) 38%, #fff 58%, var(--gold-glow) 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:shimmer 6s linear infinite;
  padding:.1em .12em .14em .04em;
  margin:-.1em -.12em -.14em -.04em;
}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ---------- GOLD ANIMATED UNDERLINE (used on headings) ---------- */
.gold-under{position:relative;display:inline-block;padding-bottom:18px}
.gold-under::after{
  content:"";position:absolute;left:50%;transform:translateX(-50%);bottom:0;
  width:120px;height:3px;background:linear-gradient(90deg,transparent,var(--gold-light),var(--gold),var(--gold-dark),var(--gold),var(--gold-light),transparent);
  background-size:200% 100%;animation:underlineSlide 4s linear infinite;border-radius:2px;
}
@keyframes underlineSlide{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ---------- REVEAL ON SCROLL ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease, transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal-l{opacity:0;transform:translateX(-70px);transition:opacity 1s ease, transform 1.05s cubic-bezier(.2,.7,.2,1)}
.reveal-r{opacity:0;transform:translateX(70px);transition:opacity 1s ease, transform 1.05s cubic-bezier(.2,.7,.2,1)}
.reveal.in,.reveal-l.in,.reveal-r.in{opacity:1;transform:none}
.delay-100{transition-delay:.1s}.delay-200{transition-delay:.2s}.delay-300{transition-delay:.3s}
.delay-400{transition-delay:.4s}.delay-500{transition-delay:.5s}.delay-600{transition-delay:.6s}
.delay-700{transition-delay:.7s}.delay-800{transition-delay:.8s}

/* ---------- NAV ---------- */
nav.top{
  position:fixed;top:0;left:0;right:0;z-index:60;
  padding:20px 56px;color:#fff;
  display:flex;align-items:center;justify-content:space-between;gap:36px;
  transition:background .35s ease, padding .35s ease, border-color .35s ease, box-shadow .35s ease;
  border-bottom:1px solid transparent;
}
nav.top.scrolled{
  background:rgba(19,28,52,.72);backdrop-filter:blur(18px) saturate(1.2);-webkit-backdrop-filter:blur(18px) saturate(1.2);
  padding:14px 56px;border-color:rgba(255,255,255,.08);
  box-shadow:0 12px 40px -20px rgba(0,0,0,.5);
}
.brand{display:flex;align-items:center;gap:14px;font-family:'Playfair Display',serif;font-size:20px;letter-spacing:.04em;color:#fff}
.brand .mark{
  width:38px;height:38px;border:1.5px solid var(--gold);
  display:flex;align-items:center;justify-content:center;color:var(--gold);
  font-family:'Playfair Display',serif;font-size:18px;letter-spacing:0;
  background:rgba(212,175,55,.07);
}
.brand .name{display:flex;flex-direction:column;line-height:1}
.brand .name strong{font-weight:600;color:var(--gold);letter-spacing:.14em;font-family:'Manrope';font-size:14px;text-transform:uppercase}
.brand .name small{font-family:'Manrope';font-size:9px;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:5px;font-weight:500}
nav ul{display:flex;gap:32px;list-style:none;flex:1;justify-content:center}
nav ul a{font-size:12px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;opacity:.88;position:relative;padding:8px 0}
nav ul a:hover{opacity:1;color:var(--gold-light)}
nav ul a::after{
  content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;
  background:linear-gradient(90deg,var(--gold-light),var(--gold),var(--gold-dark));
  transition:right .35s ease;
}
nav ul a:hover::after{right:0}
.nav-right{display:flex;align-items:center;gap:18px}
.nav-phone{font-family:'Playfair Display',serif;font-size:18px;color:var(--gold-light);font-weight:500;display:flex;align-items:center;gap:8px;letter-spacing:.02em}
.nav-phone .ico{width:14px;height:14px;color:var(--gold-light)}
.nav-cta{
  background:linear-gradient(180deg,var(--gold-light),var(--gold) 60%,var(--gold-dark));color:var(--navy-deep);
  font-weight:700;font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  padding:12px 22px;border-radius:6px;position:relative;
  box-shadow:0 8px 24px -10px rgba(212,175,55,.7), inset 0 1px 0 rgba(255,255,255,.5);
}
.nav-cta::after{
  content:"";position:absolute;inset:0;border-radius:6px;
  box-shadow:0 0 0 0 rgba(212,175,55,.55);animation:pulseGlow 2.4s ease-out infinite;pointer-events:none;
}

/* ---------- HERO ---------- */
.hero{
  min-height:100vh;position:relative;overflow:hidden;color:#fff;
  display:flex;align-items:center;justify-content:center;text-align:center;
  padding:170px 56px 0;
}
.hero-bg{
  position:absolute;inset:0;
  background-image:var(--hero-img, url('https://images.unsplash.com/photo-1570129477492-45c003edd2be?w=2400&q=80&auto=format&fit=crop'));
  background-size:cover;background-position:center 60%;
  background-color:#7ea9c9;
  transform:scale(1.05);
  will-change:transform;
  animation:slowZoom 24s ease-in-out infinite alternate;
}
@keyframes slowZoom{from{transform:scale(1.03)}to{transform:scale(1.12)}}
.hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(19,28,52,.15) 0%, rgba(19,28,52,.25) 55%, rgba(19,28,52,.55) 100%);
}
.hero-inner{position:relative;z-index:2;max-width:1100px;width:100%;display:flex;flex-direction:column;align-items:center;gap:32px}
.hero h1{font-size:clamp(54px, 7.6vw, 116px);letter-spacing:-.02em;font-weight:600;text-shadow:0 4px 30px rgba(0,0,0,.35);line-height:1.12;padding-bottom:.08em}
.hero h1 em{font-style:italic;font-weight:500}
.hero .lede{font-size:clamp(18px,1.6vw,22px);max-width:780px;color:rgba(255,255,255,.92);text-shadow:0 2px 16px rgba(0,0,0,.35)}
.hero-actions{display:flex;gap:18px;align-items:center;flex-wrap:wrap;justify-content:center;margin-top:8px}
.hero-trust{display:flex;gap:30px;justify-content:center;align-items:center;color:rgba(255,255,255,.85);font-size:13px;font-weight:500;letter-spacing:.05em;margin-top:10px}
.hero-trust span{display:inline-flex;align-items:center;gap:8px}
.hero-trust .star{color:var(--gold-light)}

/* page-load cascade */
.cascade>*{opacity:0;transform:translateY(20px);animation:cascadeUp .9s cubic-bezier(.2,.7,.2,1) forwards}
.cascade>*:nth-child(1){animation-delay:.15s}
.cascade>*:nth-child(2){animation-delay:.30s}
.cascade>*:nth-child(3){animation-delay:.45s}
.cascade>*:nth-child(4){animation-delay:.60s}
.cascade>*:nth-child(5){animation-delay:.75s}
.cascade>*:nth-child(6){animation-delay:.90s}
@keyframes cascadeUp{to{opacity:1;transform:none}}

/* ---------- HERO STATS BAR ---------- */
.hero-stats{
  position:absolute;bottom:0;left:0;right:0;z-index:3;
  background:rgba(19,28,52,.78);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-top:1px solid rgba(212,175,55,.4);
  color:#fff;
}
.hero-stats-inner{max-width:1320px;margin:0 auto;padding:28px 56px;display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.hstat{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;position:relative}
.hstat:not(:last-child)::after{content:"";position:absolute;right:-15px;top:8px;bottom:8px;width:1px;background:rgba(255,255,255,.16)}
.hstat .num{font-family:'Playfair Display',serif;font-size:46px;font-weight:600;line-height:1;color:var(--gold-light);letter-spacing:-.01em}
.hstat .num .unit{font-size:20px;color:var(--gold-light);margin-left:2px}
.hstat .lbl{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.75);font-weight:600}

/* ---------- SECTION HEAD ---------- */
.sec-head{text-align:center;max-width:820px;margin:0 auto 72px}
.sec-head .eyebrow{display:inline-block;margin-bottom:18px}
.sec-head h2{font-size:clamp(42px,5vw,68px);font-weight:600;line-height:1.18;text-wrap:balance;padding-bottom:.06em}
.sec-head .lede{margin-top:22px}

/* ---------- PROCESS (3 cards on white) ---------- */
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;position:relative}
.process-card{
  background:#fff;border:1px solid var(--line);border-top:3px solid var(--gold);
  padding:50px 38px 44px;border-radius:8px;position:relative;overflow:hidden;
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.process-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-card)}
.process-card .step-num{
  font-family:'Playfair Display',serif;font-size:120px;font-weight:600;line-height:.8;color:var(--gold);
  opacity:.18;position:absolute;right:24px;top:18px;
}
.process-card .ico{
  width:56px;height:56px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,rgba(212,175,55,.16),rgba(212,175,55,.04));
  border:1px solid rgba(212,175,55,.45);color:var(--gold-dark);border-radius:10px;margin-bottom:24px;
}
.process-card .ico svg{width:26px;height:26px}
.process-card h3{font-family:'Playfair Display',serif;font-size:30px;font-weight:600;margin-bottom:14px;line-height:1.2}
.process-card p{font-size:15px;color:var(--muted);line-height:1.7}
.process-card .step-tag{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-dark);font-weight:700;margin-bottom:18px}

/* arrows between process cards — placed in the gap so they're visible */
.process-grid{isolation:isolate}
.process-grid::before,.process-grid::after{
  content:"";position:absolute;top:50%;width:14px;height:14px;
  border-top:2px solid var(--gold);border-right:2px solid var(--gold);
  transform:translateY(-50%) rotate(45deg);
  opacity:.8;z-index:0;pointer-events:none;
}
/* grid is 3 equal cols + 2 gaps of 30px. Center of each gap is at (cellW + 15) and (2*cellW + 45) */
.process-grid::before{left:calc(33.33% - 8px)}
.process-grid::after{left:calc(66.66% - 8px)}
.process-card{z-index:1;background:#fff}
@media (max-width:1100px){.process-grid::before,.process-grid::after{display:none}}

/* ---------- SITUATIONS (8 cards on navy) ---------- */
.sit-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.sit{
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.1);
  padding:34px 26px;border-radius:8px;position:relative;overflow:hidden;
  transition:transform .35s ease, border-color .35s ease, box-shadow .35s ease, background .35s ease;
}
.sit::before{
  content:"";position:absolute;inset:0;border-radius:8px;pointer-events:none;
  box-shadow:inset 0 0 0 1px transparent;transition:box-shadow .35s ease;
}
.sit:hover{
  transform:translateY(-6px);
  border-color:rgba(212,175,55,.55);
  background:linear-gradient(180deg,rgba(212,175,55,.07),rgba(212,175,55,.01));
  box-shadow:0 22px 50px -22px rgba(212,175,55,.45);
}
.sit .ico{
  width:48px;height:48px;display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(212,175,55,.5);color:var(--gold-light);border-radius:10px;
  background:rgba(212,175,55,.08);margin-bottom:20px;
}
.sit .ico svg{width:22px;height:22px}
.sit h4{font-family:'Playfair Display',serif;font-size:22px;font-weight:600;margin-bottom:8px;line-height:1.2}
.sit p{font-size:13px;color:rgba(255,255,255,.7);line-height:1.6}

/* ---------- USA MAP ---------- */
.map-section .sec-head h2 span{display:inline-block;position:relative}
.map-wrap{
  position:relative;max-width:1180px;margin:0 auto;
  border:1px solid rgba(255,255,255,.08);
  background:radial-gradient(ellipse at center,rgba(212,175,55,.04),transparent 60%);
  border-radius:10px;padding:30px 30px 50px;
}
.map-canvas{
  position:relative;width:100%;aspect-ratio:960/600;
}
.map-canvas > svg.usa-svg{
  position:absolute;inset:0;width:100%;height:100%;
}
.usa-svg{display:block;filter:drop-shadow(0 20px 40px rgba(0,0,0,.3))}
.usa-svg .state{fill:rgba(255,255,255,.06);stroke:rgba(212,175,55,.75);stroke-width:.8;stroke-linejoin:round;transition:fill .3s ease;cursor:pointer}
.usa-svg .state:hover{fill:rgba(212,175,55,.18);stroke:var(--gold-light);stroke-width:1.4}
.dot{position:absolute;transform:translate(-50%,-50%);z-index:3}
.dot .core{
  width:12px;height:12px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%,var(--gold-glow),var(--gold) 60%,var(--gold-dark));
  box-shadow:0 0 14px 3px rgba(212,175,55,.55), inset 0 0 6px rgba(255,255,255,.4);
  position:relative;z-index:2;cursor:pointer;
  transition:transform .25s ease;
}
.dot:hover .core{transform:scale(1.4)}
.dot .ring{
  position:absolute;top:50%;left:50%;width:12px;height:12px;border-radius:50%;
  border:1.5px solid var(--gold-light);transform:translate(-50%,-50%);
  animation:ripple 2.8s ease-out infinite;
}
.dot .ring.delay{animation-delay:1.4s}
@keyframes ripple{
  0%{width:12px;height:12px;opacity:.9}
  100%{width:80px;height:80px;opacity:0}
}
.dot .tip{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%) translateY(6px);
  background:linear-gradient(180deg,var(--gold-light),var(--gold));
  color:var(--navy-deep);
  padding:7px 14px;border-radius:4px;
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;white-space:nowrap;
  opacity:0;pointer-events:none;
  transition:opacity .25s ease, transform .25s ease;
  box-shadow:0 8px 20px -6px rgba(0,0,0,.4);
}
.dot .tip::after{
  content:"";position:absolute;left:50%;bottom:-5px;transform:translateX(-50%) rotate(45deg);
  width:10px;height:10px;background:var(--gold);
}
.dot:hover .tip{opacity:1;transform:translateX(-50%) translateY(0)}

.city-pills{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;max-width:1080px;margin:60px auto 0}
.city-pill{
  padding:10px 20px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  color:var(--gold-light);border:1px solid rgba(212,175,55,.45);border-radius:999px;
  background:rgba(212,175,55,.05);transition:all .25s ease;cursor:pointer;
}
.city-pill:hover{background:var(--gold);color:var(--navy-deep);border-color:var(--gold);transform:translateY(-2px)}

/* ---------- WHY US (4 feature cards) ---------- */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.why{
  background:#fff;border:1px solid var(--line);padding:42px 30px;border-radius:10px;text-align:center;position:relative;
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.why:hover{transform:translateY(-8px);border-color:rgba(212,175,55,.6);box-shadow:0 28px 60px -28px rgba(212,175,55,.4)}
.why .ico{
  width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,rgba(212,175,55,.16),rgba(212,175,55,.04));
  border:1.5px solid rgba(212,175,55,.5);color:var(--gold-dark);margin:0 auto 22px;
}
.why .ico svg{width:34px;height:34px}
.why h4{font-family:'Playfair Display',serif;font-size:24px;font-weight:600;margin-bottom:12px}
.why p{font-size:14px;color:var(--muted);line-height:1.7}

/* ---------- LEAD FORM ---------- */
.form-shell{
  position:relative;max-width:920px;margin:0 auto;
  background:rgba(255,255,255,.07);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(212,175,55,.55);border-radius:14px;padding:48px 48px 44px;
  box-shadow:0 40px 100px -40px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.06);
  color:#fff;
}
.form-shell::before{
  content:"";position:absolute;inset:-1px;border-radius:15px;pointer-events:none;
  background:linear-gradient(135deg,rgba(212,175,55,.4),transparent 30%,transparent 70%,rgba(212,175,55,.4));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;padding:1px;
}
.form-shell.on-white{
  background:#fff;color:var(--ink);
  border-color:rgba(212,175,55,.7);
  box-shadow:0 40px 100px -40px rgba(20,30,54,.35), inset 0 1px 0 rgba(255,255,255,.5);
}
.form-shell .head{text-align:center;margin-bottom:30px}
.form-shell .head .eyebrow{color:var(--gold-light)}
.form-shell.on-white .head .eyebrow{color:var(--gold-dark)}
.form-shell .head h3{font-family:'Playfair Display',serif;font-size:36px;font-weight:600;margin:12px 0 10px;line-height:1.15}
.form-shell .head p{font-size:14px;opacity:.78;max-width:560px;margin:0 auto}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.fld{display:flex;flex-direction:column;gap:8px}
.fld.full{grid-column:span 2}
.fld label{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.7);font-weight:600}
.form-shell.on-white .fld label{color:var(--muted)}
.fld input,.fld select,.fld textarea{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.18);
  color:#fff;padding:14px 16px;font-size:15px;font-weight:400;outline:none;border-radius:6px;
  transition:border-color .25s ease, background .25s ease;
}
.form-shell.on-white .fld input,
.form-shell.on-white .fld select,
.form-shell.on-white .fld textarea{
  background:#fff;border:1px solid var(--line);color:var(--ink);
}
.fld input::placeholder,.fld textarea::placeholder{color:rgba(255,255,255,.4)}
.form-shell.on-white .fld input::placeholder,.form-shell.on-white .fld textarea::placeholder{color:#9aa1b0}
.fld input:focus,.fld select:focus,.fld textarea:focus{border-color:var(--gold-light);background:rgba(255,255,255,.08)}
.form-shell.on-white .fld input:focus,.form-shell.on-white .fld select:focus,.form-shell.on-white .fld textarea:focus{border-color:var(--gold);background:#fff;box-shadow:0 0 0 3px rgba(212,175,55,.18)}
.fld select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,currentColor 50%),linear-gradient(135deg,currentColor 50%,transparent 50%);background-position:calc(100% - 20px) calc(50% - 2px),calc(100% - 15px) calc(50% - 2px);background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:36px}
.form-shell.on-white .fld select option{background:#fff;color:var(--ink)}
.fld select option{background:var(--navy-deep);color:#fff}
.form-submit{margin-top:22px;display:flex;flex-direction:column;align-items:center;gap:14px}
.form-submit .btn-gold{width:100%;max-width:520px;justify-content:center;padding:20px 30px;font-size:14px}
.form-submit .micro{font-size:12px;color:rgba(255,255,255,.65);text-align:center}
.form-shell.on-white .form-submit .micro{color:var(--muted)}
.form-trust{display:flex;justify-content:center;gap:24px;margin-top:24px;flex-wrap:wrap}
.form-trust span{display:inline-flex;align-items:center;gap:8px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:rgba(255,255,255,.75)}
.form-shell.on-white .form-trust span{color:var(--muted)}
.form-trust svg{width:14px;height:14px;color:var(--gold-light)}
.form-shell.on-white .form-trust svg{color:var(--gold)}

/* ---------- UPLOAD ZONE ---------- */
.upload-zone{margin:22px 0 4px}
.upload-label{
  display:flex;align-items:center;gap:18px;
  padding:16px 20px;
  border:1.5px dashed rgba(212,175,55,.5);border-radius:8px;
  background:rgba(212,175,55,.04);
  cursor:pointer;transition:all .25s ease;
  color:inherit;
}
.form-shell.on-white .upload-label{background:rgba(212,175,55,.06);border-color:rgba(212,175,55,.55)}
.upload-label:hover{background:rgba(212,175,55,.1);border-color:var(--gold-light)}
.form-shell.on-white .upload-label:hover{border-color:var(--gold)}
.upload-ico{
  width:42px;height:42px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  border-radius:8px;background:rgba(212,175,55,.15);color:var(--gold-light)
}
.form-shell.on-white .upload-ico{background:rgba(212,175,55,.15);color:var(--gold-dark)}
.upload-ico svg{width:22px;height:22px}
.upload-text{flex:1;min-width:0}
.upload-title{font-size:14px;font-weight:700;letter-spacing:.02em;display:flex;align-items:center;flex-wrap:wrap;gap:8px}
.upload-opt{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-light);font-weight:700;padding:3px 8px;border-radius:3px;background:rgba(212,175,55,.18);border:1px solid rgba(212,175,55,.4)}
.form-shell.on-white .upload-opt{color:var(--gold-dark)}
.upload-hint{font-size:12px;opacity:.72;margin-top:6px;line-height:1.5;font-weight:400}
.upload-btn{
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;
  padding:10px 18px;border-radius:5px;
  background:rgba(212,175,55,.18);color:var(--gold-light);border:1px solid rgba(212,175,55,.5);
  flex-shrink:0;white-space:nowrap;transition:all .2s ease;
}
.upload-label:hover .upload-btn{background:var(--gold);color:var(--navy-deep);border-color:var(--gold)}
.form-shell.on-white .upload-btn{color:var(--gold-dark)}
.upload-files{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.upload-files .chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 11px;border-radius:4px;
  background:rgba(212,175,55,.12);border:1px solid rgba(212,175,55,.35);
  font-size:11px;font-weight:600;color:var(--gold-light);
  max-width:240px;
}
.form-shell.on-white .upload-files .chip{color:var(--gold-dark);background:rgba(212,175,55,.14)}
.upload-files .chip svg{width:11px;height:11px;flex-shrink:0}
.upload-files .chip .name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media (max-width:640px){
  .upload-label{flex-direction:column;align-items:flex-start;text-align:left}
  .upload-btn{align-self:stretch;text-align:center}
}

/* ---------- TESTIMONIALS ---------- */
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.test{
  background:#fff;border:1px solid var(--line);border-radius:10px;padding:36px 32px;
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
  position:relative;
}
.test:hover{transform:translateY(-5px);border-color:rgba(212,175,55,.5);box-shadow:var(--shadow-soft)}
.test .stars{color:var(--gold);font-size:16px;letter-spacing:.15em;margin-bottom:16px}
.test blockquote{font-family:'Playfair Display',serif;font-size:19px;line-height:1.5;color:var(--ink);font-weight:500;font-style:italic;margin-bottom:22px}
.test .who{display:flex;align-items:center;gap:14px;padding-top:18px;border-top:1px solid var(--line)}
.test .who .av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#d4af37,#a8842a);display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Playfair Display';font-weight:600;font-size:18px}
.test .who strong{display:block;font-weight:700;font-size:14px;color:var(--ink)}
.test .who span{display:block;font-size:12px;color:var(--muted)}

/* ---------- LOCATIONS GRID ---------- */
.loc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.loc-card{
  display:block;position:relative;padding:30px 26px;border-radius:8px;
  background:#fff;border:1px solid var(--line);
  transition:all .3s ease;
  overflow:hidden;
}
.loc-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent);
  transform:scaleX(0);transform-origin:left;transition:transform .4s ease;
}
.loc-card:hover{transform:translateY(-4px);border-color:rgba(212,175,55,.6);box-shadow:var(--shadow-soft)}
.loc-card:hover::before{transform:scaleX(1)}
.loc-card .city{font-family:'Playfair Display',serif;font-size:24px;font-weight:600;color:var(--ink);margin-bottom:6px}
.loc-card .st{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:14px}
.loc-card .arrow{display:inline-flex;align-items:center;gap:8px;color:var(--gold-dark);font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;transition:gap .25s ease}
.loc-card:hover .arrow{gap:14px;color:var(--gold)}

/* ---------- FOOTER ---------- */
footer{background:var(--navy-deep);color:#fff;padding:90px 56px 32px;border-top:1px solid rgba(212,175,55,.18);position:relative}
.foot-cta{
  max-width:1320px;margin:-160px auto 70px;
  background:linear-gradient(135deg,var(--navy) 0%, var(--navy-deep) 100%);
  border:1px solid rgba(212,175,55,.4);
  border-radius:14px;padding:60px 70px;
  display:grid;grid-template-columns:1.4fr auto;gap:50px;align-items:center;
  position:relative;overflow:hidden;
}
.foot-cta::before,.foot-cta::after{
  content:"";position:absolute;width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(212,175,55,.2),transparent 60%);filter:blur(20px);
}
.foot-cta::before{top:-200px;right:-100px}
.foot-cta::after{bottom:-200px;left:-100px}
.foot-cta > *{position:relative;z-index:1}
.foot-cta h3{font-family:'Playfair Display',serif;font-size:42px;font-weight:600;line-height:1.15}
.foot-cta p{color:rgba(255,255,255,.78);margin-top:14px;font-size:16px}
.foot-cta .actions{display:flex;flex-direction:column;gap:12px;align-items:center;text-align:center}
.foot-cta .actions .phone{font-family:'Playfair Display',serif;font-size:30px;color:var(--gold-light);font-weight:600}
.foot-grid{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:60px;padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-grid h5{font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-light);margin-bottom:22px;font-weight:700}
.foot-grid ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.foot-grid ul a{font-size:14px;color:rgba(255,255,255,.78);font-weight:400;transition:color .25s}
.foot-grid ul a:hover{color:var(--gold-light)}
.foot-about p{font-size:14px;color:rgba(255,255,255,.7);line-height:1.7;margin:18px 0;max-width:340px}
.foot-contact{display:flex;flex-direction:column;gap:10px;font-size:14px;color:rgba(255,255,255,.85)}
.foot-contact a{color:var(--gold-light);font-weight:600}
.foot-social{display:flex;gap:12px;margin-top:20px}
.foot-social a{
  width:42px;height:42px;border-radius:50%;border:1px solid rgba(212,175,55,.4);
  display:flex;align-items:center;justify-content:center;color:var(--gold-light);transition:all .25s ease;
}
.foot-social a:hover{background:var(--gold);color:var(--navy-deep);transform:translateY(-2px)}
.foot-bot{max-width:1320px;margin:24px auto 0;display:flex;justify-content:space-between;align-items:center;font-size:12px;letter-spacing:.1em;color:rgba(255,255,255,.5);flex-wrap:wrap;gap:14px}
.foot-bot a{color:rgba(255,255,255,.65)}
.foot-bot a:hover{color:var(--gold-light)}

/* ---------- DIVIDER (decorative) ---------- */
.gold-divider{display:flex;align-items:center;justify-content:center;gap:14px;margin:0 auto 18px;max-width:200px;color:var(--gold)}
.gold-divider .line{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.gold-divider .dot{width:6px;height:6px;background:var(--gold);border-radius:50%}

/* ---------- LOCATION PAGE HERO ---------- */
.loc-hero{min-height:72vh;padding:170px 56px 220px;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;position:relative;overflow:hidden}
.loc-hero .hero-overlay{background:linear-gradient(180deg,rgba(19,28,52,.45),rgba(19,28,52,.75))}
.loc-hero .breadcrumb{font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-light);margin-bottom:18px;font-weight:600}
.loc-hero h1{font-size:clamp(46px,6vw,86px);font-weight:600;letter-spacing:-.015em;line-height:1.14;padding-bottom:.08em}
.loc-hero p{max-width:760px;margin:22px auto 30px;font-size:18px;color:rgba(255,255,255,.85);line-height:1.7}

/* ---------- MOBILE ---------- */
@media (max-width: 1100px){
  .wrap{padding:0 28px}
  nav.top{padding:14px 24px}
  nav.top.scrolled{padding:10px 24px}
  nav ul{display:none}
  .hero{padding:140px 24px 200px}
  .hero-stats-inner{grid-template-columns:1fr 1fr;padding:22px 24px;gap:18px}
  .hstat .num{font-size:32px}
  .hstat:not(:last-child)::after{display:none}
  .process-grid{grid-template-columns:1fr}
  .process-grid::before,.process-grid::after{display:none}
  .sit-grid{grid-template-columns:1fr 1fr}
  .why-grid{grid-template-columns:1fr 1fr}
  .test-grid{grid-template-columns:1fr}
  .loc-grid{grid-template-columns:1fr 1fr}
  .form-shell{padding:32px 24px}
  .form-grid{grid-template-columns:1fr}
  .fld.full{grid-column:span 1}
  .foot-grid{grid-template-columns:1fr 1fr;gap:36px}
  .foot-cta{grid-template-columns:1fr;padding:42px 28px;margin:-120px 16px 50px}
  .foot-cta .actions{align-items:flex-start}
  footer{padding:80px 24px 32px}
  .nav-phone{display:none}
  .pad-l{padding:80px 0}
  .pad-xl{padding:100px 0}
}
@media (max-width: 640px){
  .sit-grid,.why-grid,.loc-grid{grid-template-columns:1fr}
}

/* ---------- SCROLLBAR ---------- */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--cream)}
::-webkit-scrollbar-thumb{background:var(--navy);border-radius:6px}
::-webkit-scrollbar-thumb:hover{background:var(--gold-dark)}
