/* =====================================================================
   Virto Lawyers — Real Estate Lawyers in Estepona
   Design system: deep navy + gold, cream content surfaces
   ===================================================================== */

/* ---------- Tokens ---------- */
:root{
  --navy:        #14283e;
  --navy-2:      #1b3552;
  --navy-soft:   #21405f;
  --navy-line:   rgba(255,255,255,.12);
  --gold:        #c9aa63;
  --gold-2:      #b8964e;
  --gold-soft:   #e7d9b4;
  --cream:       #f5f1e8;
  --cream-2:     #faf7f0;
  --paper:       #ffffff;
  --ink:         #1f2733;
  --ink-soft:    #3a4654;
  --muted:       #5f6b78;
  --line:        #e7e0d2;
  --shadow-sm:   0 6px 20px rgba(20,40,62,.08);
  --shadow-md:   0 18px 50px rgba(20,40,62,.16);
  --radius:      14px;
  --radius-sm:   10px;
  --container:   1200px;
  --serif: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --sans:  'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.7;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ font-family:var(--serif); font-weight:700; line-height:1.15; color:var(--ink); margin:0 0 .5em; }
h1{ font-size:clamp(2.1rem,5vw,3.4rem); }
h2{ font-size:clamp(1.8rem,3.6vw,2.6rem); }
h3{ font-size:1.35rem; }
p{ margin:0 0 1.1rem; }
strong{ color:var(--ink); font-weight:600; }
:focus-visible{ outline:3px solid var(--gold); outline-offset:2px; }

/* ---------- Layout helpers ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:24px; }
.section{ padding:88px 0; }
.section--tight{ padding:64px 0; }
.section--cream{ background:var(--cream-2); }
.section--navy{ background:var(--navy); color:#fff; }
.section--navy h1,.section--navy h2,.section--navy h3{ color:#fff; }
.center{ text-align:center; }
.lead{ font-size:1.12rem; color:var(--muted); }
.section--navy .lead{ color:rgba(255,255,255,.78); }
.maxw-760{ max-width:760px; }
.mx-auto{ margin-inline:auto; }

/* ---------- Eyebrow / section heads ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--sans); font-weight:600; font-size:.78rem;
  letter-spacing:.22em; text-transform:uppercase; color:var(--gold-2);
  margin:0 0 .9rem;
}
.eyebrow::before{ content:""; width:30px; height:2px; background:var(--gold); display:inline-block; }
.eyebrow--center::after{ content:""; width:30px; height:2px; background:var(--gold); display:inline-block; }
.eyebrow--center{ justify-content:center; }
.rotator{ display:inline-block; min-width:2.6em; transition:opacity .3s ease, transform .3s ease; }
.rotator.swap{ opacity:0; transform:translateY(-5px); }
.section--navy .eyebrow{ color:var(--gold); }
.section-head{ max-width:720px; margin-bottom:48px; }
.section-head.center{ margin-inline:auto; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  font-family:var(--sans); font-weight:600; font-size:.92rem; letter-spacing:.04em;
  padding:.95rem 1.7rem; border-radius:8px; cursor:pointer; border:2px solid transparent;
  transition:transform .18s ease, background .2s ease, color .2s ease, box-shadow .2s ease;
  white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); }
.btn-gold{ background:var(--gold); color:#15293f; }
.btn-gold:hover{ background:var(--gold-2); color:#10202f; box-shadow:0 12px 30px rgba(201,170,99,.35); }
.btn-navy{ background:var(--navy); color:#fff; }
.btn-navy:hover{ background:var(--navy-2); }
.btn-outline{ background:transparent; color:#fff; border-color:rgba(255,255,255,.55); }
.btn-outline:hover{ background:#fff; color:var(--navy); border-color:#fff; }
.btn-outline-ink{ background:transparent; color:var(--navy); border-color:var(--navy); }
.btn-outline-ink:hover{ background:var(--navy); color:#fff; }
.btn-lg{ padding:1.05rem 2.1rem; font-size:1rem; }
.btn-arrow::after{ content:"→"; font-size:1.05em; transition:transform .2s ease; }
.btn-arrow:hover::after{ transform:translateX(4px); }

/* ---------- Header ---------- */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:60;
  padding:18px 0;
  transition:background .3s ease, padding .3s ease, box-shadow .3s ease;
}
.site-header__inner{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.brand{ display:flex; align-items:center; gap:.6rem; flex:0 0 auto; }
.brand img{ height:46px; width:auto; transition:height .3s ease; }
.nav{ display:flex; align-items:center; gap:6px; margin-left:auto; }
.nav a{
  font-family:var(--sans); font-weight:500; font-size:.92rem; letter-spacing:.02em;
  color:#fff; padding:.6rem .85rem; border-radius:7px; position:relative;
  transition:color .2s ease, background .2s ease;
}
.nav a:hover{ color:var(--gold-soft); }
.nav a.active{ color:var(--gold); }
.nav a.btn-gold{ color:#15293f; }   /* keep dark text on gold CTA inside nav */
.nav a.btn-gold:hover{ color:#10202f; }
.header-cta{ margin-left:10px; }
.header-cta.in-drawer{ display:none; }   /* only shown inside the mobile drawer */

/* dropdown */
.has-dropdown{ position:relative; }
.dropdown{
  position:absolute; top:calc(100% + 10px); left:0; min-width:250px;
  background:#fff; border-radius:12px; box-shadow:var(--shadow-md);
  padding:10px; opacity:0; visibility:hidden; transform:translateY(8px);
  transition:opacity .2s ease, transform .2s ease, visibility .2s; border:1px solid var(--line);
}
.has-dropdown:hover .dropdown,.has-dropdown:focus-within .dropdown{ opacity:1; visibility:visible; transform:translateY(0); }
.dropdown a{ color:var(--ink); display:block; padding:.65rem .8rem; border-radius:8px; font-size:.9rem; }
.dropdown a:hover{ background:var(--cream); color:var(--navy); }

/* scrolled state */
.site-header.scrolled{ background:rgba(18,32,49,.96); backdrop-filter:saturate(140%) blur(8px); box-shadow:0 8px 30px rgba(0,0,0,.25); padding:10px 0; }
.site-header.scrolled .brand img{ height:40px; }

/* light header variant (inner pages with light hero) */
.site-header.on-light .nav a{ color:#eef1f4; }

/* mobile toggle */
.nav-toggle{
  display:none; width:46px; height:46px; border:none; background:transparent; cursor:pointer;
  flex-direction:column; gap:5px; align-items:center; justify-content:center; margin-left:auto;
}
.nav-toggle span{ width:24px; height:2px; background:#fff; transition:.3s; }
.nav-open .nav-toggle span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-open .nav-toggle span:nth-child(2){ opacity:0; }
.nav-open .nav-toggle span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- Hero ---------- */
.hero{ position:relative; color:#fff; padding:160px 0 84px; overflow:hidden; }
.hero__bg{ position:absolute; inset:0; z-index:0; }
.hero__bg img{ width:100%; height:100%; object-fit:cover; }
.hero__bg::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(100deg, rgba(13,24,38,.94) 0%, rgba(15,28,45,.86) 42%, rgba(16,30,48,.55) 100%);
}
.hero__inner{ position:relative; z-index:2; display:grid; grid-template-columns:1.12fr .88fr; gap:40px; align-items:center; }
.hero__title{ font-size:clamp(2.3rem,4.6vw,3.7rem); text-transform:uppercase; letter-spacing:.01em; line-height:1.08; color:#fff; margin-bottom:1.1rem; }
.hero__title .gold{ color:var(--gold); }
.hero__text{ font-size:1.13rem; color:rgba(255,255,255,.82); max-width:540px; margin-bottom:1.9rem; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; }
.hero__media{ position:relative; display:flex; justify-content:center; align-items:flex-end; align-self:end; }
.hero__media img{ height:clamp(430px,46vw,560px); width:auto; max-width:none; margin-bottom:-84px; filter:drop-shadow(0 24px 44px rgba(0,0,0,.5)); }

/* ---------- Feature / value cards ---------- */
.features{ position:relative; z-index:5; margin-top:-88px; }
.features__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.feature{
  background:var(--navy); color:#fff; border-radius:var(--radius); padding:34px 30px;
  box-shadow:var(--shadow-md); border:1px solid var(--navy-line);
  transition:transform .25s ease, border-color .25s ease;
}
.feature:hover{ transform:translateY(-6px); border-color:var(--gold); }
.feature__icon{
  width:54px; height:54px; border-radius:12px; display:grid; place-items:center;
  background:rgba(201,170,99,.16); color:var(--gold); margin-bottom:18px;
}
.feature__icon svg{ width:26px; height:26px; }
.feature h3{ color:#fff; font-size:1.18rem; letter-spacing:.06em; text-transform:uppercase; }
.feature p{ color:rgba(255,255,255,.72); font-size:.96rem; margin:0; }

/* ---------- Split / media-text rows ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.split--reverse .split__media{ order:2; }
.split__media{ position:relative; }
.split__media img{ border-radius:var(--radius); box-shadow:var(--shadow-md); width:100%; object-fit:cover; }
.split__media .frame-accent{ position:absolute; inset:auto -18px -18px auto; width:60%; height:60%; border:3px solid var(--gold); border-radius:var(--radius); z-index:-1; }

/* badge card (specialist) */
.badge-card{
  background:var(--navy); color:#fff; border-radius:var(--radius); padding:30px 28px;
  text-align:center; box-shadow:var(--shadow-md); max-width:300px;
}
.badge-card .eyebrow{ color:var(--gold); justify-content:center; }
.badge-card h3{ color:#fff; margin:0; }

/* ---------- Check list ---------- */
.check-list{ display:grid; gap:14px; margin:0 0 1.6rem; }
.check-list li{ position:relative; padding-left:38px; line-height:1.55; }
.check-list li::before{
  content:""; position:absolute; left:0; top:2px; width:24px; height:24px; border-radius:50%;
  background:var(--gold);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/16px no-repeat;
          mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/16px no-repeat;
}
.section--navy .check-list li,.benefits .check-list li{ color:rgba(255,255,255,.85); }

/* ---------- Benefits (why choose) ---------- */
.benefits{ position:relative; background:var(--navy); color:#fff; overflow:hidden; }
.benefits__bg{ position:absolute; inset:0; z-index:0; }
.benefits__bg img{ width:100%; height:100%; object-fit:cover; }
.benefits__bg::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(100deg, rgba(11,21,34,.96) 0%, rgba(13,25,40,.88) 40%, rgba(15,28,46,.55) 78%, rgba(15,28,46,.35) 100%); }
.benefits > .container{ position:relative; z-index:2; }
.benefits .split{ align-items:center; }
.benefits h2, .benefits h3{ color:#fff; }
.benefits .lead{ color:rgba(255,255,255,.85); }
.benefits .check-list{ grid-template-columns:1fr; }
.benefits__media{ position:relative; display:flex; justify-content:center; align-items:flex-end; align-self:stretch; }
.benefits__media img{ max-height:520px; width:auto; filter:drop-shadow(0 26px 46px rgba(0,0,0,.55)); }
@media(min-width:760px){ .benefits .check-list{ grid-template-columns:1fr 1fr; gap:14px 34px; } }

/* ---------- Stats ---------- */
.stats{ background:var(--navy-2); }
.stats__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.stat{
  background:var(--navy); border:1px solid var(--navy-line); border-radius:var(--radius);
  padding:34px 18px; text-align:center; color:#fff;
}
.stat:first-child{ background:linear-gradient(160deg,var(--gold),var(--gold-2)); color:#15293f; border:none; }
.stat__num{ font-family:var(--serif); font-size:2.7rem; font-weight:800; line-height:1; }
.stat__num .plus{ color:var(--gold); }
.stat:first-child .stat__num .plus{ color:#15293f; }
.stat__label{ margin-top:.5rem; font-size:.86rem; letter-spacing:.08em; text-transform:uppercase; color:rgba(255,255,255,.7); }
.stat:first-child .stat__label{ color:rgba(21,41,63,.75); }

/* ---------- Contact panel ---------- */
.contact-panel{
  background:linear-gradient(155deg,var(--gold),#b8954a);
  border-radius:20px; padding:48px clamp(24px,4vw,56px); color:#1d2c1a;
  box-shadow:0 30px 60px rgba(160,120,40,.25);
}
.contact-panel h2{ color:#1f2a14; }
.contact-panel .lead{ color:rgba(31,42,20,.8); }
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-field{ display:flex; flex-direction:column; gap:.35rem; }
.form-field.full{ grid-column:1 / -1; }
.form-field label{ font-size:.82rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:rgba(28,38,18,.85); }
.form-field input,.form-field select,.form-field textarea{
  font-family:var(--sans); font-size:1rem; padding:.85rem 1rem; border-radius:9px;
  border:1px solid rgba(20,30,10,.18); background:rgba(255,255,255,.92); color:#1c2733; width:100%;
}
.form-field textarea{ min-height:120px; resize:vertical; }
.form-field select{
  appearance:none; -webkit-appearance:none; cursor:pointer; padding-right:38px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2315293f' stroke-width='2.4'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat:no-repeat; background-position:right 14px center;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{ outline:2px solid #15293f; background-color:#fff; }
.form-note{ font-size:.82rem; color:rgba(28,38,18,.7); margin:.6rem 0 0; }
.form-consent .consent-label{ display:flex; align-items:flex-start; gap:.6rem; font-size:.86rem; line-height:1.45; font-weight:500; color:#3a2e12; cursor:pointer; }
.form-consent input[type="checkbox"]{ margin-top:.15rem; width:18px; height:18px; flex:0 0 auto; accent-color:#15293f; cursor:pointer; }
.form-consent a{ color:#15293f; font-weight:700; text-decoration:underline; }
.form-status{ margin-top:1rem; font-weight:600; }
#contact{ scroll-margin-top:90px; }   /* offset the sticky header when jumping to the form */

/* contact details list (contact page) */
.contact-cards{ display:grid; gap:18px; }
.contact-card{ display:flex; gap:16px; align-items:flex-start; background:var(--cream-2); border:1px solid var(--line); border-radius:var(--radius); padding:22px; }
.contact-card .ic{ width:46px; height:46px; flex:0 0 auto; border-radius:10px; background:var(--navy); color:var(--gold); display:grid; place-items:center; }
.contact-card .ic svg{ width:22px; height:22px; }
.contact-card h4{ margin:0 0 .2rem; font-family:var(--sans); font-size:.8rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }
.contact-card p,.contact-card a{ margin:0; font-size:1.05rem; color:var(--ink); }
.map-embed{ border:0; width:100%; height:100%; min-height:320px; border-radius:var(--radius); }

/* ---------- Services grid ---------- */
.services-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.service-card{
  background:rgba(255,255,255,.04); border:1px solid var(--navy-line); border-radius:var(--radius);
  padding:34px 30px; transition:transform .25s ease, background .25s ease, border-color .25s;
}
.service-card:hover{ transform:translateY(-6px); background:rgba(255,255,255,.07); border-color:var(--gold); }
.service-card__icon{ width:56px; height:56px; border-radius:12px; background:rgba(201,170,99,.16); color:var(--gold); display:grid; place-items:center; margin-bottom:18px; }
.service-card__icon svg{ width:28px; height:28px; }
.service-card h3{ color:#fff; }
.service-card p{ color:rgba(255,255,255,.72); font-size:.96rem; }
.service-card .more{ color:var(--gold); font-weight:600; font-size:.9rem; display:inline-flex; gap:.4rem; align-items:center; }
.service-card .more::after{ content:"→"; transition:transform .2s; }
.service-card:hover .more::after{ transform:translateX(4px); }

/* ---------- Team ---------- */
.team-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:30px; max-width:760px; margin-inline:auto; }
.team-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); transition:transform .25s ease, box-shadow .25s; }
.team-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.team-card__photo{ aspect-ratio:1/1; background:#ffffff; }
.team-card__photo img{ width:100%; height:100%; object-fit:cover; }
.team-card__body{ padding:22px 24px; text-align:center; }
.team-card__body h3{ margin:0 0 .15rem; }
.team-card__role{ color:var(--gold-2); font-weight:600; font-size:.85rem; letter-spacing:.1em; text-transform:uppercase; }

/* ---------- Page hero (inner pages) ---------- */
.page-hero{ position:relative; color:#fff; padding:160px 0 70px; overflow:hidden; }
.page-hero__bg{ position:absolute; inset:0; z-index:0; }
.page-hero__bg img{ width:100%; height:100%; object-fit:cover; }
.page-hero__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(13,24,38,.93), rgba(15,28,45,.74)); }
.page-hero__inner{ position:relative; z-index:2; max-width:760px; }
.page-hero h1{ color:#fff; }
.breadcrumb{ font-size:.85rem; color:rgba(255,255,255,.7); margin-bottom:1rem; display:flex; gap:.5rem; flex-wrap:wrap; }
.breadcrumb a:hover{ color:var(--gold); }
.breadcrumb span{ color:var(--gold); }

/* ---------- Process steps ---------- */
.steps{ display:grid; gap:22px; counter-reset:step; }
.step{ display:grid; grid-template-columns:auto 1fr; gap:20px; align-items:start; background:var(--cream-2); border:1px solid var(--line); border-radius:var(--radius); padding:24px 26px; }
.step__num{ counter-increment:step; width:48px; height:48px; border-radius:50%; background:var(--navy); color:var(--gold); font-family:var(--serif); font-size:1.3rem; font-weight:700; display:grid; place-items:center; }
.step__num::before{ content:counter(step,decimal-leading-zero); }
.step h3{ font-size:1.15rem; margin-bottom:.3rem; }
.step p{ margin:0; color:var(--muted); font-size:.97rem; }

/* ---------- FAQ ---------- */
.faq{ display:grid; gap:14px; max-width:840px; margin-inline:auto; }
.faq details{ border:1px solid var(--line); border-radius:var(--radius-sm); background:var(--paper); overflow:hidden; }
.faq summary{ cursor:pointer; padding:20px 24px; font-weight:600; font-size:1.05rem; color:var(--navy); display:flex; justify-content:space-between; gap:1rem; align-items:center; list-style:none; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; color:var(--gold); font-size:1.5rem; line-height:1; transition:transform .2s; }
.faq details[open] summary::after{ transform:rotate(45deg); }
.faq details p{ padding:0 24px 20px; margin:0; color:var(--muted); }

/* ---------- CTA band ---------- */
.cta-band{ background:linear-gradient(120deg,var(--navy),var(--navy-2)); color:#fff; border-radius:20px; padding:clamp(36px,5vw,64px); text-align:center; }
.cta-band h2{ color:#fff; }
.cta-band .lead{ color:rgba(255,255,255,.78); max-width:620px; margin-inline:auto; }

/* ---------- Footer ---------- */
.site-footer{ background:#0f2034; color:rgba(255,255,255,.74); padding:72px 0 0; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:40px; }
.footer-brand img{ height:54px; margin-bottom:18px; }
.footer-brand p{ font-size:.95rem; color:rgba(255,255,255,.6); }
.site-footer h4{ color:#fff; font-family:var(--sans); font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; margin:0 0 18px; }
.footer-links li{ margin-bottom:10px; }
.footer-links a{ font-size:.95rem; color:rgba(255,255,255,.66); transition:color .2s, padding .2s; }
.footer-links a:hover{ color:var(--gold); padding-left:5px; }
.footer-contact li{ display:flex; gap:12px; margin-bottom:16px; font-size:.95rem; align-items:flex-start; }
.footer-contact .ic{ color:var(--gold); flex:0 0 auto; margin-top:3px; }
.footer-contact .ic svg{ width:18px; height:18px; }
.footer-contact a:hover{ color:var(--gold); }
.footer-bottom{ margin-top:56px; border-top:1px solid rgba(255,255,255,.1); padding:22px 0; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:.85rem; color:rgba(255,255,255,.5); }
.footer-bottom a:hover{ color:var(--gold); }

/* ---------- Legal / prose ---------- */
.prose{ max-width:820px; margin-inline:auto; }
.prose h2{ margin-top:2.2rem; font-size:1.5rem; }
.prose h3{ margin-top:1.6rem; font-size:1.12rem; }
.prose p,.prose li{ color:var(--ink-soft); }
.prose ul{ list-style:disc; padding-left:1.3rem; margin:0 0 1.2rem; }
.prose ul li{ margin-bottom:.5rem; }
.prose a{ color:var(--gold-2); text-decoration:underline; }
.prose .muted-note{ background:var(--cream); border-left:3px solid var(--gold); padding:14px 18px; border-radius:6px; font-size:.92rem; color:var(--muted); }

/* ---------- Footer areas bar ---------- */
.footer-areas{ margin-top:42px; padding-top:26px; border-top:1px solid rgba(255,255,255,.1); }
.footer-areas h4{ margin-bottom:12px; }
.footer-areas .area-row{ display:flex; flex-wrap:wrap; font-size:.92rem; row-gap:6px; }
.footer-areas .area-row a{ color:rgba(255,255,255,.66); padding:0 14px; border-right:1px solid rgba(255,255,255,.18); }
.footer-areas .area-row a:first-child{ padding-left:0; }
.footer-areas .area-row a:last-child{ border-right:none; }
.footer-areas .area-row a:hover{ color:var(--gold); }

/* ---------- Area chips (location cross-links) ---------- */
.area-chips{ display:flex; flex-wrap:wrap; gap:12px; justify-content:center; }
.area-chips a{ display:inline-flex; align-items:center; gap:.5rem; padding:.7rem 1.35rem; border:1px solid var(--line); border-radius:40px; background:#fff; font-weight:600; font-size:.95rem; color:var(--navy); transition:transform .2s ease, background .2s ease, color .2s ease; }
.area-chips a:hover{ background:var(--navy); color:#fff; border-color:var(--navy); transform:translateY(-2px); }
.area-chips a.current{ background:var(--gold); border-color:var(--gold); color:#15293f; }

/* ---------- Local areas grid (neighbourhoods) ---------- */
.local-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:14px; }
.local-grid li{ background:var(--cream-2); border:1px solid var(--line); border-radius:10px; padding:14px 16px; font-weight:600; color:var(--navy); display:flex; align-items:center; gap:.6rem; }
.local-grid li::before{ content:""; width:8px; height:8px; border-radius:50%; background:var(--gold); flex:0 0 auto; }

/* ---------- Reveal animation ---------- */
[data-reveal]{ opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s ease; }
[data-reveal].in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ [data-reveal]{ opacity:1; transform:none; transition:none; } html{ scroll-behavior:auto; } }

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .hero__inner{ grid-template-columns:1fr; }
  .hero__media{ display:none; }
  .hero{ padding:150px 0 80px; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:32px; }
  .stats__grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:860px){
  .nav, .header-cta{ display:none; }
  .nav-toggle{ display:flex; }
  /* mobile drawer */
  .nav.open{
    display:flex; position:fixed; inset:0 0 0 auto; width:min(86vw,360px);
    background:var(--navy); flex-direction:column; align-items:stretch; gap:4px;
    padding:96px 22px 30px; z-index:55; box-shadow:-20px 0 60px rgba(0,0,0,.4);
    overflow-y:auto;
  }
  .nav.open a{ color:#fff; padding:.9rem .4rem; border-bottom:1px solid var(--navy-line); }
  .nav.open .has-dropdown{ display:flex; flex-direction:column; }
  .nav.open .dropdown{ position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; background:transparent; border:none; padding:0 0 0 14px; }
  .nav.open .dropdown a{ color:rgba(255,255,255,.75); }
  .nav.open .header-cta.in-drawer{ display:inline-flex; margin:14px 0 0; justify-content:center; }
  .nav-backdrop{ position:fixed; inset:0; background:rgba(8,16,26,.55); z-index:54; opacity:0; visibility:hidden; transition:.25s; }
  .nav-open .nav-backdrop{ opacity:1; visibility:visible; }
  .features{ margin-top:0; }
  .features__grid{ grid-template-columns:1fr; }
  .split{ grid-template-columns:1fr; gap:34px; }
  .split--reverse .split__media{ order:0; }
  .services-grid{ grid-template-columns:1fr; }
  .section{ padding:64px 0; }
}
@media (max-width:560px){
  body{ font-size:16px; }
  .form-grid{ grid-template-columns:1fr; }
  .stats__grid{ grid-template-columns:1fr 1fr; }
  .team-grid{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .hero{ padding:130px 0 64px; }
}
