:root{
  --paper:#F4F1EA;          /* warm cream */
  --paper-2:#EDE8DC;        /* slightly darker paper */
  --paper-3:#E6E0D0;        /* section accent */
  --ink:#3D3A34;            /* warm charcoal */
  --ink-2:#6B6659;          /* muted warm gray */
  --ink-3:#9C968A;          /* light warm gray */
  --hairline:#D9D3C3;
  --hairline-2:#E8E2D4;

  /* one restrained accent — pulled from the pitch deck, muted */
  --accent:#6B8E7F;         /* muted sage/teal */
  --accent-2:#8DA79A;

  --serif:'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --container:1280px;
}

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  font-weight:400;
  line-height:1.6;
  overflow-x:hidden;
}

/* paper texture */
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 300 300' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='4'/%3E%3CfeColorMatrix values='0 0 0 0 0.24 0 0 0 0 0.23 0 0 0 0 0.2 0 0 0 0.5 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.28'/%3E%3C/svg%3E");
  opacity:.35;
  mix-blend-mode:multiply;
}
main, header, footer{position:relative; z-index:1}

img,svg{display:block; max-width:100%}
a{color:inherit; text-decoration:none}
button{font-family:inherit; cursor:pointer; border:0; background:none}
::selection{background:rgba(107,142,127,.25); color:var(--ink)}

.container{max-width:var(--container); margin:0 auto; padding:0 56px; position:relative}

/* ─────── MICRO LABELS (tracking) ─────── */
.micro{
  font-family:var(--sans);
  font-size:10px;
  font-weight:500;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--ink-2);
}
.micro-sm{font-size:9px; letter-spacing:.22em}

/* ─────── SERIF DISPLAY ─────── */
h1, h2, h3, .serif{
  font-family:var(--serif);
  font-weight:400;
  color:var(--ink);
  letter-spacing:.015em;
  line-height:1.1;
}

/* ─────── TOP BAR ─────── */
header.topbar{
  position:fixed; top:0; left:0; right:0;
  padding:32px 56px;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  z-index:40;
  transition:background .3s, padding .3s, border-color .3s;
  border-bottom:1px solid transparent;
}
header.topbar.scrolled{
  padding:20px 56px;
  background:rgba(244,241,234,.88);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom-color:var(--hairline-2);
}
.topbar-left{
  display:flex; align-items:center; gap:36px;
}
.topbar-wordmark{
  font-family:var(--serif);
  font-size:18px;
  font-weight:400;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--ink);
  white-space:nowrap;
}
.topbar-right{
  display:flex; align-items:center; justify-content:flex-end; gap:28px;
}
.menu-btn{
  width:36px; height:28px;
  display:flex; flex-direction:column; justify-content:center; gap:6px;
  padding:0;
}
.menu-btn span{
  display:block; width:100%; height:1px; background:var(--ink);
  transition:transform .25s, opacity .25s;
}
.menu-btn:hover span:nth-child(1){transform:translateX(-2px)}
.menu-btn:hover span:nth-child(2){transform:translateX(2px)}

/* ─────── NAV OVERLAY ─────── */
.nav-overlay{
  position:fixed; inset:0; z-index:60;
  background:rgba(244,241,234,.96);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  opacity:0; pointer-events:none;
  transition:opacity .4s cubic-bezier(.2,.8,.2,1);
  display:flex; align-items:center; justify-content:center;
}
.nav-overlay.open{opacity:1; pointer-events:auto}
.nav-overlay ul{
  list-style:none; text-align:center;
  display:flex; flex-direction:column; gap:28px;
}
.nav-overlay li{
  font-family:var(--serif); font-size:clamp(40px, 6vw, 68px);
  font-weight:400; font-style:italic;
  color:var(--ink);
  opacity:0; transform:translateY(20px);
  transition:opacity .5s, transform .5s;
}
.nav-overlay.open li{opacity:1; transform:none}
.nav-overlay li:nth-child(1){transition-delay:.1s}
.nav-overlay li:nth-child(2){transition-delay:.15s}
.nav-overlay li:nth-child(3){transition-delay:.2s}
.nav-overlay li:nth-child(4){transition-delay:.25s}
.nav-overlay li:nth-child(5){transition-delay:.3s}
.nav-overlay a{
  display:inline-block; cursor:pointer;
  transition:color .2s, transform .2s;
}
.nav-overlay a:hover{color:var(--accent); transform:translateX(4px)}
.nav-close{
  position:absolute; top:32px; right:56px;
  font-family:var(--sans); font-size:10px; font-weight:500;
  letter-spacing:.24em; text-transform:uppercase;
  color:var(--ink-2); cursor:pointer; padding:12px;
}

/* ─────── BUTTONS ─────── */
.btn{
  font-family:var(--sans);
  font-size:11px;
  font-weight:500;
  letter-spacing:.18em;
  text-transform:uppercase;
  padding:18px 32px;
  border-radius:2px;
  display:inline-flex; align-items:center; gap:14px;
  transition:all .3s cubic-bezier(.2,.8,.2,1);
  position:relative;
}
.btn-ghost{
  color:var(--ink);
  border-bottom:1px solid var(--ink);
  padding:12px 0;
  border-radius:0;
}
.btn-ghost:hover{
  color:var(--accent);
  border-bottom-color:var(--accent);
}
.btn-ghost .arrow{
  display:inline-block;
  transition:transform .3s cubic-bezier(.2,.8,.2,1);
}
.btn-ghost:hover .arrow{transform:translateX(6px)}
.btn-solid{
  background:var(--ink);
  color:var(--paper);
  border-radius:0;
}
.btn-solid:hover{
  background:var(--accent);
  color:var(--paper);
  transform:translateY(-1px);
}

/* ─────── REVEAL (subtle) ─────── */
[data-reveal]{
  opacity:0; transform:translateY(26px);
  transition:opacity 1.2s cubic-bezier(.22,.61,.36,1),
             transform 1.2s cubic-bezier(.22,.61,.36,1);
  transition-delay:var(--delay, 0s);
}
[data-reveal="fade"]{transform:none}
[data-reveal].in{opacity:1; transform:none}

/* ─────── HERO ─────── */
.hero{
  min-height:100vh;
  display:flex; flex-direction:column;
  padding:140px 0 0;
  position:relative;
}
.hero-visual{
  flex:1;
  display:flex; align-items:center; justify-content:center;
  padding:20px 56px 60px;
  position:relative;
  min-height:50vh;
}
.hero-svg-wrap{
  width:100%;
  max-width:1100px;
  aspect-ratio:16/9;
  position:relative;
  filter:blur(.4px);
}
.hero-svg-wrap svg{
  width:100%; height:100%;
  overflow:visible;
}
.hero-svg-wrap svg path,
.hero-svg-wrap svg line,
.hero-svg-wrap svg circle,
.hero-svg-wrap svg rect{
  stroke:#6B665988;
  stroke-width:1.2;
  fill:none;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.hero-svg-wrap svg .faint{stroke-opacity:.35}
.hero-svg-wrap svg .lighter{stroke:#9C968A66}

/* sketch lines draw-in */
.hero-svg-wrap svg path,
.hero-svg-wrap svg line{
  stroke-dasharray:2000;
  stroke-dashoffset:2000;
  animation:draw 2.4s cubic-bezier(.2,.8,.2,1) forwards;
  animation-delay:.3s;
}
.hero-svg-wrap svg path:nth-child(2){animation-delay:.5s}
.hero-svg-wrap svg path:nth-child(3){animation-delay:.7s}
.hero-svg-wrap svg path:nth-child(4){animation-delay:.9s}
.hero-svg-wrap svg path:nth-child(5){animation-delay:1.1s}
@keyframes draw{
  to{stroke-dashoffset:0}
}

/* dust particles */
.dust{
  position:absolute; inset:0; pointer-events:none;
}
.dust i{
  position:absolute;
  width:2px; height:2px;
  background:#6B665988;
  border-radius:50%;
  animation:drift 8s linear infinite;
}
.dust i:nth-child(1){top:20%; left:15%; animation-delay:0s}
.dust i:nth-child(2){top:35%; left:80%; animation-delay:-2s}
.dust i:nth-child(3){top:60%; left:25%; animation-delay:-4s}
.dust i:nth-child(4){top:80%; left:70%; animation-delay:-1s}
.dust i:nth-child(5){top:15%; left:55%; animation-delay:-3s}
.dust i:nth-child(6){top:75%; left:40%; animation-delay:-5s}
@keyframes drift{
  0%,100%{transform:translate(0,0); opacity:0}
  10%,90%{opacity:.6}
  50%{transform:translate(20px,-30px); opacity:.8}
}

/* hero bottom plate */
.hero-plate{
  background:var(--paper-2);
  padding:80px 56px 100px;
  text-align:center;
  border-top:1px solid var(--hairline);
  position:relative;
}
.hero-plate::before{
  content:""; position:absolute; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  opacity:.06;
  mix-blend-mode:multiply;
  pointer-events:none;
}
.hero-plate > *{position:relative}
.hero-headline{
  font-family:var(--serif);
  font-size:clamp(22px, 2.6vw, 30px);
  font-weight:400;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink);
  margin-bottom:18px;
}
.hero-subhead{
  font-family:var(--serif);
  font-size:clamp(15px, 1.5vw, 18px);
  font-weight:400;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-2);
  margin-bottom:52px;
}
.hero-tag{
  margin-bottom:40px;
}
.hero-cta{
  display:inline-flex; gap:40px; align-items:center; flex-wrap:wrap; justify-content:center;
  margin-top:20px;
}

/* ─────── SECTIONS ─────── */
section{padding:160px 0; position:relative}
.section-label{
  text-align:center; margin-bottom:56px;
}
.section-label .micro{display:block; margin-bottom:22px}
.section-title{
  font-family:var(--serif);
  font-size:clamp(38px, 5vw, 72px);
  font-weight:400;
  line-height:1.1;
  text-align:center;
  max-width:900px;
  margin:0 auto 28px;
  letter-spacing:.005em;
}
.section-title .italic{font-style:italic; color:var(--accent)}
.section-intro{
  font-family:var(--serif);
  font-size:20px;
  font-weight:400;
  line-height:1.7;
  color:var(--ink-2);
  text-align:center;
  max-width:620px;
  margin:0 auto;
  font-style:italic;
}

/* hairline rules */
.hairline{
  width:60px; height:1px;
  background:var(--ink-3);
  margin:0 auto;
}
.hairline-lg{width:120px; margin:60px auto}

/* ─────── PHILOSOPHY (problem/solution) ─────── */
.philosophy{background:var(--paper)}
.numbers{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:60px;
  margin-top:80px;
  padding:0 40px;
}
.number{
  text-align:center;
  padding:40px 20px;
  border-right:1px solid var(--hairline);
}
.number:last-child{border-right:0}
.number .n{
  font-family:var(--serif);
  font-size:68px;
  font-weight:300;
  line-height:1;
  color:var(--ink);
  letter-spacing:-.02em;
}
.number .u{font-size:32px; color:var(--ink-2)}
.number .l{
  font-family:var(--sans);
  font-size:11px;
  font-weight:400;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--ink-2);
  margin-top:22px;
  line-height:1.7;
}

/* ─────── PROCESS ─────── */
.process{
  background:var(--paper-2);
  border-top:1px solid var(--hairline);
  border-bottom:1px solid var(--hairline);
}
.steps{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  margin-top:80px;
}
.step{
  padding:50px 38px;
  border-right:1px solid var(--hairline);
  text-align:center;
  transition:background .4s;
}
.step:last-child{border-right:0}
.step:hover{background:rgba(61,58,52,.02)}
.step .num{
  font-family:var(--serif);
  font-size:14px;
  font-style:italic;
  color:var(--accent);
  margin-bottom:18px;
}
.step h3{
  font-size:26px;
  font-weight:400;
  margin-bottom:16px;
}
.step p{
  font-family:var(--serif);
  font-size:16px;
  line-height:1.65;
  color:var(--ink-2);
  font-style:italic;
}

/* ─────── PRINCIPLES (why) ─────── */
.principles-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:80px 60px;
  margin-top:80px;
}
.principle{text-align:center}
.principle .micro{margin-bottom:18px}
.principle h3{
  font-size:26px;
  font-weight:400;
  margin-bottom:14px;
  font-style:italic;
}
.principle p{
  font-family:var(--serif);
  font-size:17px;
  line-height:1.65;
  color:var(--ink-2);
  max-width:300px;
  margin:0 auto;
}

/* ─────── DEMO SHOWCASE ─────── */
.demo-showcase{
  background:var(--paper);
  text-align:center;
}
.demo-visual{
  margin:80px auto 60px;
  max-width:320px;
  position:relative;
}
.phone-mock{
  width:100%;
  background:#1a1713;
  border-radius:38px;
  padding:10px;
  box-shadow:
    0 40px 100px rgba(61,58,52,.18),
    0 0 0 1px rgba(61,58,52,.06);
  position:relative;
}
.phone-mock::before{
  content:""; position:absolute; top:14px; left:50%; transform:translateX(-50%);
  width:90px; height:22px; background:#1a1713; border-radius:20px; z-index:2;
}
.phone-screen{
  background:var(--paper);
  border-radius:30px;
  padding:42px 18px 18px;
  min-height:520px;
  display:flex; flex-direction:column;
  overflow:hidden;
}
.phone-screen .pg{
  font-family:var(--sans); font-size:9px;
  letter-spacing:.2em; text-transform:uppercase; color:var(--ink-3);
}
.phone-screen .pname{
  font-family:var(--serif); font-size:26px;
  color:var(--ink); margin-top:4px; letter-spacing:.01em;
}
.phone-screen .pm-hero{
  margin-top:18px;
  padding:18px;
  background:var(--paper-2);
  border:1px solid var(--hairline);
  border-radius:4px;
}
.phone-screen .pm-hero .lbl{
  font-family:var(--sans); font-size:8px;
  letter-spacing:.2em; text-transform:uppercase; color:var(--accent);
}
.phone-screen .pm-hero h4{
  font-family:var(--serif); font-size:19px; margin-top:6px; font-weight:400;
}
.phone-screen .pm-hero p{
  font-family:var(--serif); font-size:11px; color:var(--ink-2); margin-top:4px; font-style:italic;
}
.phone-screen .pm-hero .go{
  margin-top:14px; font-family:var(--sans); font-size:9px;
  letter-spacing:.2em; text-transform:uppercase; color:var(--ink);
  border-bottom:1px solid var(--ink); padding-bottom:3px; display:inline-block;
}
.phone-screen .divider{
  margin:22px 0 14px;
  font-family:var(--sans); font-size:8px;
  letter-spacing:.2em; text-transform:uppercase; color:var(--ink-3);
}
.phone-screen .pjob{
  padding:12px 0;
  border-top:1px solid var(--hairline);
  display:flex; align-items:center; gap:10px;
}
.phone-screen .pjob .dot{
  width:5px; height:5px; border-radius:50%; background:var(--accent);
}
.phone-screen .pjob .info{flex:1}
.phone-screen .pjob .name{
  font-family:var(--serif); font-size:13px; color:var(--ink);
}
.phone-screen .pjob .meta{
  font-family:var(--sans); font-size:9px;
  letter-spacing:.08em; color:var(--ink-3); margin-top:1px;
}
.phone-screen .pjob .badge{
  font-family:var(--sans); font-size:8px;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--accent);
}

/* ─────── PRICING ─────── */
.pricing{background:var(--paper-2); border-top:1px solid var(--hairline); border-bottom:1px solid var(--hairline)}
.plans{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:0;
  margin-top:80px;
  border-left:1px solid var(--hairline);
  border-right:1px solid var(--hairline);
  background:var(--paper);
}
.plan{
  padding:60px 44px;
  text-align:center;
  border-right:1px solid var(--hairline);
  position:relative;
  transition:background .4s;
}
.plan:last-child{border-right:0}
.plan.featured{
  background:var(--paper-2);
}
.plan.featured::before{
  content:""; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--accent);
}
.plan .micro{display:block; margin-bottom:20px}
.plan .pname{
  font-family:var(--serif); font-size:32px; font-weight:400;
  margin-bottom:8px; font-style:italic;
}
.plan .pdesc{
  font-family:var(--serif); font-size:14px; color:var(--ink-2);
  margin-bottom:36px; font-style:italic;
}
.plan .price{
  display:flex; align-items:baseline; justify-content:center; gap:4px;
  margin-bottom:36px;
}
.plan .price .n{
  font-family:var(--serif); font-size:72px; font-weight:300;
  color:var(--ink); letter-spacing:-.03em; line-height:1;
}
.plan .price .u{
  font-family:var(--sans); font-size:11px; font-weight:500;
  letter-spacing:.14em; text-transform:uppercase; color:var(--ink-2);
}
.plan ul{
  list-style:none;
  margin-bottom:36px;
  padding-top:30px;
  border-top:1px solid var(--hairline);
}
.plan li{
  font-family:var(--serif);
  font-size:15px;
  padding:10px 0;
  color:var(--ink);
  line-height:1.6;
}
.plan .btn{width:100%; justify-content:center}

/* ─────── FOUNDER ─────── */
.founder{
  background:var(--paper);
  text-align:center;
}
.founder-quote{
  font-family:var(--serif);
  font-size:clamp(32px, 4.2vw, 56px);
  font-weight:400;
  font-style:italic;
  line-height:1.2;
  color:var(--ink);
  max-width:900px;
  margin:60px auto 50px;
}
.founder-byline{
  display:flex; align-items:center; justify-content:center; gap:20px;
  margin-top:40px;
}
.founder-initials{
  width:56px; height:56px; border-radius:50%;
  border:1px solid var(--hairline);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--serif); font-size:15px;
  letter-spacing:.15em; color:var(--ink);
}
.founder-name{
  text-align:left;
}
.founder-name .name{
  font-family:var(--serif); font-size:17px; color:var(--ink);
}
.founder-name .title{
  font-family:var(--sans); font-size:10px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--ink-3); margin-top:3px;
}

/* ─────── LOCATIONS ─────── */
.locations{
  background:var(--paper-2);
  border-top:1px solid var(--hairline);
  text-align:center;
}
.cities-list{
  display:flex; flex-wrap:wrap; justify-content:center; gap:0;
  margin-top:60px;
}
.city-name{
  font-family:var(--serif);
  font-size:clamp(22px, 2.5vw, 32px);
  font-weight:400;
  padding:14px 36px;
  border-right:1px solid var(--hairline);
  color:var(--ink);
  transition:color .3s;
}
.city-name:hover{color:var(--accent); font-style:italic}
.city-name:last-child{border-right:0}

/* ─────── CTA ─────── */
.cta-section{
  background:var(--paper);
  text-align:center;
  padding:180px 0;
}
.cta-headline{
  font-family:var(--serif);
  font-size:clamp(44px, 6vw, 96px);
  font-weight:400;
  line-height:1.05;
  color:var(--ink);
  margin-bottom:40px;
}
.cta-headline em{color:var(--accent)}

/* ─────── FOOTER ─────── */
footer{
  background:var(--paper-3);
  padding:80px 0 50px;
  border-top:1px solid var(--hairline);
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:60px;
  margin-bottom:80px;
}
.footer-brand h4{
  font-family:var(--serif); font-size:26px; font-weight:400;
  letter-spacing:.25em; text-transform:uppercase;
  margin-bottom:16px;
}
.footer-brand p{
  font-family:var(--serif); font-size:16px; color:var(--ink-2);
  font-style:italic; line-height:1.6; max-width:320px;
}
.footer-col h5{
  font-family:var(--sans); font-size:10px; font-weight:500;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--ink-2); margin-bottom:22px;
}
.footer-col ul{list-style:none; display:flex; flex-direction:column; gap:14px}
.footer-col li a{
  font-family:var(--serif); font-size:15px; color:var(--ink);
  transition:color .2s;
}
.footer-col li a:hover{color:var(--accent); font-style:italic}
.footer-bottom{
  padding-top:40px;
  border-top:1px solid var(--hairline);
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px;
  font-family:var(--sans); font-size:10px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ink-3);
}

/* ─────── RESPONSIVE ─────── */
@media (max-width:1024px){
  .container{padding:0 36px}
  header.topbar, header.topbar.scrolled{padding-left:36px; padding-right:36px}
  .hero-visual{padding:20px 36px 40px}
  .numbers{grid-template-columns:repeat(2,1fr); gap:0}
  .number{border-right:none; border-bottom:1px solid var(--hairline); padding:48px 20px}
  .number:nth-child(2){border-right:1px solid var(--hairline)}
  .number:nth-child(2n){border-right:none}
  .number:last-child{border-bottom:none}
  .steps{grid-template-columns:repeat(2,1fr)}
  .step{border-bottom:1px solid var(--hairline)}
  .step:nth-child(2n){border-right:none}
  .step:nth-child(3), .step:nth-child(4){border-bottom:none}
  .principles-grid{grid-template-columns:repeat(2,1fr); gap:60px 40px}
  .plans{grid-template-columns:1fr; border-left:none; border-right:none}
  .plan{border-right:none; border-bottom:1px solid var(--hairline)}
  .plan:last-child{border-bottom:none}
  .footer-grid{grid-template-columns:1fr 1fr; gap:40px}
}
@media (max-width:640px){
  .container{padding:0 24px}
  header.topbar, header.topbar.scrolled{padding:24px; grid-template-columns:1fr auto}
  .topbar-left .topbar-micro{display:none}
  .topbar-wordmark{font-size:14px}
  .nav-close{top:24px; right:24px}
  section{padding:100px 0}
  .hero{padding-top:120px}
  .hero-plate{padding:60px 24px 80px}
  .hero-visual{padding:20px 24px}
  .numbers{grid-template-columns:1fr; padding:0}
  .number{border-right:none !important}
  .number .n{font-size:56px}
  .steps{grid-template-columns:1fr}
  .step{border-right:none}
  .principles-grid{grid-template-columns:1fr; gap:50px}
  .cities-list{flex-direction:column; gap:0}
  .city-name{border-right:none; border-bottom:1px solid var(--hairline); width:100%}
  .city-name:last-child{border-bottom:none}
  .footer-grid{grid-template-columns:1fr; gap:50px}
  .hero-cta{flex-direction:column; gap:20px}
}
@media (prefers-reduced-motion:reduce){
  *, *::before, *::after{animation-duration:.01s !important; transition-duration:.1s !important}
  [data-reveal]{opacity:1 !important; transform:none !important}
  .hero-svg-wrap svg path, .hero-svg-wrap svg line{stroke-dashoffset:0 !important; animation:none !important}
}
