﻿:root{
  --ami-deep:#0B1620;
  --ami-ink:#0F2230;
  --ami-paper:#F7FAFB;
  --ami-mist:#E8F1F4;
  --ami-green:#4FA63B;
  --ami-green-bright:#7BD45E;
  --ami-citrus:#D7F26B;
  --ami-chrome:#C9D6DC;
  --line:rgba(11,22,32,.1);
  --shadow:0 22px 70px rgba(11,22,32,.14);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--ami-ink);
  background:var(--ami-paper);
  font-family:Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height:1.5;
}
body[data-city]{
  --city-accent:var(--ami-green);
  --city-accent-two:#7bd45e;
  --city-pattern:
    linear-gradient(120deg, rgba(79,166,59,.12), transparent 42%),
    repeating-linear-gradient(90deg, rgba(15,34,48,.08) 0 1px, transparent 1px 18px);
}
body[data-city="wilmington"]{
  --city-accent:#2f7db3;
  --city-accent-two:#7bd45e;
  --city-pattern:
    linear-gradient(90deg, rgba(47,125,179,.16) 0 16%, transparent 16% 26%, rgba(79,166,59,.13) 26% 33%, transparent 33%),
    repeating-linear-gradient(0deg, rgba(15,34,48,.08) 0 1px, transparent 1px 16px);
}
body[data-city="newark"]{
  --city-accent:#226f54;
  --city-accent-two:#6fb7ff;
  --city-pattern:
    radial-gradient(circle at 20% 22%, rgba(34,111,84,.2) 0 8px, transparent 9px),
    linear-gradient(90deg, rgba(111,183,255,.12) 0 2px, transparent 2px 22px),
    linear-gradient(0deg, rgba(34,111,84,.12) 0 2px, transparent 2px 22px);
}
body[data-city="new-castle"]{
  --city-accent:#9b483b;
  --city-accent-two:#70b8d8;
  --city-pattern:
    repeating-linear-gradient(90deg, rgba(155,72,59,.14) 0 16px, transparent 16px 24px),
    linear-gradient(135deg, rgba(112,184,216,.16), transparent 48%);
}
body[data-city="bear"]{
  --city-accent:#3b7d31;
  --city-accent-two:#f0c84a;
  --city-pattern:
    linear-gradient(135deg, rgba(240,200,74,.2) 0 8%, transparent 8% 18%, rgba(59,125,49,.14) 18% 28%, transparent 28%),
    repeating-linear-gradient(0deg, rgba(15,34,48,.08) 0 1px, transparent 1px 20px);
}
body[data-city="middletown"]{
  --city-accent:#3268b2;
  --city-accent-two:#a7d74f;
  --city-pattern:
    linear-gradient(90deg, rgba(50,104,178,.18) 0 2px, transparent 2px 34px),
    linear-gradient(0deg, rgba(167,215,79,.2) 0 2px, transparent 2px 34px);
}
body[data-city="lewes"]{
  --city-accent:#247e8a;
  --city-accent-two:#74d1be;
  --city-pattern:
    radial-gradient(ellipse at 18% 24%, rgba(116,209,190,.24), transparent 32%),
    repeating-linear-gradient(135deg, rgba(36,126,138,.14) 0 3px, transparent 3px 18px);
}
body[data-city="rehoboth-beach"]{
  --city-accent:#1f8ca3;
  --city-accent-two:#ffb35c;
  --city-pattern:
    repeating-linear-gradient(90deg, rgba(255,179,92,.18) 0 8px, transparent 8px 18px),
    radial-gradient(ellipse at 74% 20%, rgba(31,140,163,.22), transparent 38%);
}
body[data-city="milford"]{
  --city-accent:#2f8f7f;
  --city-accent-two:#6fb7ff;
  --city-pattern:
    linear-gradient(115deg, transparent 0 38%, rgba(111,183,255,.22) 38% 42%, transparent 42%),
    radial-gradient(circle at 18% 28%, rgba(47,143,127,.18), transparent 30%);
}
body[data-city="millsboro"]{
  --city-accent:#476a35;
  --city-accent-two:#5fb7d6;
  --city-pattern:
    linear-gradient(35deg, transparent 0 45%, rgba(95,183,214,.22) 45% 48%, transparent 48%),
    linear-gradient(-35deg, transparent 0 43%, rgba(71,106,53,.18) 43% 47%, transparent 47%);
}
body[data-city="milton"]{
  --city-accent:#587538;
  --city-accent-two:#d9b24c;
  --city-pattern:
    radial-gradient(circle at 20% 24%, rgba(217,178,76,.22) 0 12px, transparent 13px),
    repeating-linear-gradient(90deg, rgba(88,117,56,.12) 0 2px, transparent 2px 24px);
}
body[data-city="west-chester"]{
  --city-accent:#8f3f34;
  --city-accent-two:#4fa63b;
  --city-pattern:
    repeating-linear-gradient(0deg, rgba(143,63,52,.15) 0 10px, transparent 10px 18px),
    linear-gradient(90deg, rgba(79,166,59,.16) 0 2px, transparent 2px 26px);
}
body[data-city="exton"]{
  --city-accent:#315f97;
  --city-accent-two:#6fbf5a;
  --city-pattern:
    linear-gradient(90deg, rgba(49,95,151,.16) 0 2px, transparent 2px 30px),
    linear-gradient(0deg, rgba(111,191,90,.16) 0 2px, transparent 2px 30px),
    radial-gradient(circle at 78% 20%, rgba(49,95,151,.18), transparent 28%);
}
a{color:inherit;text-decoration:none}
.nav{
  position:relative;
  top:auto;
  z-index:50;
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:1.25rem;
  align-items:center;
  padding:.7rem clamp(1.25rem,3vw,2.5rem);
  background:#fff;
  border-bottom:1px solid rgba(11,22,32,.06);
}
.brand-logo{
  display:grid;
  place-items:center;
  width:clamp(150px,14vw,220px);
  height:auto;
  aspect-ratio:597 / 401;
  overflow:visible;
}
.brand-logo-img{display:block;width:100%;height:100%;object-fit:contain}
.nav-links{display:flex;gap:1.1rem;justify-content:center;font-weight:850}
.nav-links a{color:rgba(11,22,32,.84)}
.nav-links a:hover{color:var(--ami-green)}
.btn{
  display:inline-flex;align-items:center;gap:.55rem;justify-content:center;
  border-radius:999px;border:1px solid transparent;
  padding:.78rem 1.08rem;font-weight:900;
  min-height:48px;
  line-height:1.15;
  text-align:center;
  box-shadow:0 14px 30px rgba(79,166,59,.2);
}
.btn-primary{background:var(--ami-green);color:#fff}
.btn-ghost{border-color:rgba(11,22,32,.16);background:#fff;color:var(--ami-ink);box-shadow:none}
main{overflow:hidden}
.hero{
  min-height:calc(100vh - 120px);
  display:grid;
  grid-template-columns:minmax(0,1.02fr) minmax(360px,.98fr);
  gap:clamp(2rem,5vw,5rem);
  align-items:center;
  padding:clamp(3rem,6vw,6rem) clamp(1.25rem,5vw,5rem);
}
.hero-copy{max-width:720px}
.eyebrow{
  display:inline-flex;align-items:center;gap:.65rem;
  margin-bottom:1rem;color:var(--ami-green);font-weight:900;
  text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;
}
.eyebrow:before{content:"";width:30px;height:1px;background:var(--ami-green)}
h1,h2,h3{font-family:Fraunces, Georgia, serif;color:var(--ami-deep);line-height:1.05;letter-spacing:0}
h1{font-size:clamp(2.45rem,6vw,5.9rem);margin:0 0 1.1rem;font-weight:420}
h2{font-size:clamp(1.9rem,3.4vw,3.35rem);margin:0 0 1rem;font-weight:430}
h3{font-size:1.35rem;margin:.15rem 0 .5rem}
p{font-weight:740;color:rgba(11,22,32,.76);margin:0}
.lede{font-size:clamp(1.05rem,1vw + .8rem,1.3rem);max-width:58ch}
.hero-actions{
  display:grid;
  grid-template-columns:minmax(0,1.25fr) minmax(180px,.75fr);
  gap:.8rem;
  width:min(100%,640px);
  margin-top:2rem;
  align-items:stretch;
}
.hero-actions .btn{
  width:100%;
  min-height:54px;
  padding-inline:1.15rem;
  white-space:nowrap;
}
.area-art{
  position:relative;
  min-height:560px;
  border-radius:22px;
  overflow:hidden;
  background:
    radial-gradient(70% 60% at 72% 16%, color-mix(in srgb, var(--accent2) 28%, transparent), transparent 64%),
    linear-gradient(135deg, #071620, #122a3a);
  box-shadow:var(--shadow);
  isolation:isolate;
  perspective:900px;
}
.city-aerial-card{
  position:relative;
  min-height:560px;
  border-radius:22px;
  overflow:hidden;
  background:#071620;
  box-shadow:var(--shadow);
  isolation:isolate;
  transform-style:preserve-3d;
}
.city-aerial-card:before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background:
    linear-gradient(180deg, rgba(7,22,32,0) 45%, rgba(7,22,32,.72) 100%),
    radial-gradient(70% 55% at 72% 18%, rgba(123,212,94,.18), transparent 62%);
}
.city-aerial-card:after{
  content:"";
  position:absolute;
  inset:14px;
  z-index:2;
  border:1px solid rgba(255,255,255,.24);
  border-radius:18px;
  pointer-events:none;
}
.city-aerial-img{
  width:100%;
  height:100%;
  min-height:560px;
  object-fit:cover;
  display:block;
  transform:scale(1.01);
}
.regional-pin{
  position:absolute;
  z-index:4;
  display:block;
  left:var(--x);
  top:var(--y);
  width:3rem;
  height:3rem;
  border-radius:999px;
  transform:translate(-50%, -50%);
  cursor:pointer;
}
.regional-pin:before,
.regional-pin:after{
  content:"";
  position:absolute;
  inset:.42rem;
  border-radius:999px;
  opacity:0;
  pointer-events:none;
  transition:opacity 220ms cubic-bezier(.2,.75,.2,1), transform 220ms cubic-bezier(.2,.75,.2,1);
}
.regional-pin:before{
  border:2px solid var(--ami-green-bright);
  box-shadow:0 0 0 11px rgba(123,212,94,.18), 0 0 34px rgba(79,166,59,.38);
  transform:scale(.6);
}
.regional-pin:after{
  inset:1.14rem;
  background:rgba(255,255,255,.9);
  transform:scale(.42);
}
.regional-pin:hover:before,
.regional-pin:hover:after,
.regional-pin:focus-visible:before,
.regional-pin:focus-visible:after{
  opacity:1;
  transform:scale(1);
}
.regional-pin:focus-visible{outline:3px solid var(--ami-green-bright);outline-offset:5px}
.city-aerial-caption{
  position:absolute;
  left:1.2rem;
  right:1.2rem;
  bottom:1.2rem;
  z-index:3;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:1rem;
}
.city-aerial-title{
  display:grid;
  gap:.25rem;
  color:#fff;
}
.city-aerial-title span{
  font-size:.72rem;
  font-weight:950;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(255,255,255,.72);
}
.city-aerial-title strong{
  font-family:Fraunces, Georgia, serif;
  font-size:clamp(1.35rem,2vw,2rem);
  font-weight:460;
  line-height:1.05;
  text-shadow:0 12px 32px rgba(0,0,0,.32);
}
.city-aerial-card .badge-stack{
  position:static;
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  max-width:58%;
}
.city-map-interactive{
  --map-shift-x:0px;
  --map-shift-y:0px;
  --map-zoom:1.025;
  --map-brightness:1.03;
  will-change:transform;
  transition:transform 360ms cubic-bezier(.2,.75,.2,1), box-shadow 360ms ease, filter 360ms ease;
}
.city-map-interactive.is-tilting{
  box-shadow:0 34px 94px rgba(11,22,32,.28), 0 0 0 1px rgba(255,255,255,.5) inset;
  filter:saturate(1.08);
}
.city-map-interactive:before{
  background:
    linear-gradient(180deg, rgba(7,22,32,0) 36%, rgba(7,22,32,.78) 100%),
    radial-gradient(62% 48% at 72% 18%, rgba(123,212,94,.28), transparent 66%),
    linear-gradient(112deg, transparent 0 34%, rgba(255,255,255,.34) 45%, transparent 58% 100%);
  background-size:100% 100%, 100% 100%, 230% 100%;
  background-position:center, center, 118% 0;
  animation:cityGlassSheen 8.5s ease-in-out infinite;
}
.city-map-interactive .city-aerial-img{
  transform:translate3d(var(--map-shift-x), var(--map-shift-y), 0) scale(var(--map-zoom));
  filter:saturate(1.18) contrast(1.08) brightness(var(--map-brightness));
  transition:transform 620ms cubic-bezier(.16,1,.3,1), filter 620ms cubic-bezier(.16,1,.3,1);
  will-change:transform, filter;
}
.city-map-interactive:hover .city-aerial-img,
.city-map-interactive:focus-within .city-aerial-img,
.city-map-interactive.is-tilting .city-aerial-img{
  --map-zoom:1.065;
  --map-brightness:1.07;
  filter:saturate(1.28) contrast(1.11) brightness(var(--map-brightness));
}
.hotspot-layer{
  position:absolute;
  inset:0;
  z-index:4;
  pointer-events:none;
}
.map-hotspot{
  position:absolute;
  left:var(--x);
  top:var(--y);
  width:2.55rem;
  height:2.55rem;
  border:0;
  border-radius:999px;
  padding:0;
  color:#fff;
  background:radial-gradient(circle at 36% 30%, #fff 0 10%, var(--ami-green-bright) 11% 34%, var(--ami-green) 35% 70%, #1f6f1e 71%);
  box-shadow:0 13px 28px rgba(11,22,32,.24), 0 0 0 7px rgba(123,212,94,.22);
  cursor:pointer;
  pointer-events:auto;
  transform:translate(-50%, -50%) translateZ(0);
  transition:transform 260ms cubic-bezier(.2,.75,.2,1), box-shadow 260ms ease, filter 260ms ease;
}
.map-hotspot:before{
  content:"";
  position:absolute;
  inset:-12px;
  border-radius:inherit;
  border:1px solid rgba(123,212,94,.42);
  animation:hotspotPulse 2.6s ease-in-out infinite;
}
.map-hotspot:after{
  content:attr(data-index);
  position:absolute;
  inset:8px;
  display:grid;
  place-items:center;
  border-radius:999px;
  font-size:.78rem;
  font-weight:950;
  background:rgba(11,22,32,.22);
}
.map-hotspot:hover,
.map-hotspot:focus-visible,
.map-hotspot.is-active{
  z-index:8;
  transform:translate(-50%, -50%) translateY(-18px) scale(1.18);
  filter:saturate(1.26) brightness(1.05);
  box-shadow:0 28px 48px rgba(11,22,32,.38), 0 0 0 12px rgba(123,212,94,.32), 0 0 44px rgba(123,212,94,.62);
}
.map-hotspot:focus-visible{outline:3px solid #fff;outline-offset:5px}
.hotspot-popover{
  position:absolute;
  left:50%;
  bottom:calc(100% + 14px);
  width:min(250px, 42vw);
  padding:.82rem .9rem .9rem;
  border:1px solid rgba(255,255,255,.22);
  border-radius:16px;
  background:rgba(7,22,32,.88);
  color:#fff;
  box-shadow:0 24px 50px rgba(0,0,0,.36);
  backdrop-filter:blur(14px);
  text-align:left;
  opacity:0;
  transform:translateX(-50%) translateY(10px) scale(.96);
  pointer-events:none;
  transition:opacity 190ms ease, transform 250ms cubic-bezier(.2,.75,.2,1);
}
.map-hotspot:hover .hotspot-popover,
.map-hotspot:focus-visible .hotspot-popover,
.map-hotspot.is-active .hotspot-popover{
  opacity:1;
  transform:translateX(-50%) translateY(0) scale(1);
}
.hotspot-popover strong{
  display:block;
  font-family:Fraunces, Georgia, serif;
  font-size:1.12rem;
  font-weight:500;
  line-height:1.05;
  margin-bottom:.28rem;
}
.hotspot-popover span{
  display:block;
  color:rgba(255,255,255,.74);
  font-size:.78rem;
  font-weight:900;
  letter-spacing:.13em;
  text-transform:uppercase;
  margin-bottom:.35rem;
}
.hotspot-popover p{
  color:rgba(255,255,255,.84);
  font-size:.9rem;
  font-weight:720;
  line-height:1.36;
}
.clean-route{
  position:absolute;
  z-index:3;
  left:10%;
  right:10%;
  top:54%;
  height:5px;
  pointer-events:none;
  border-radius:999px;
  opacity:.86;
  transform:rotate(var(--route-angle, -6deg));
  background:linear-gradient(90deg, transparent, rgba(123,212,94,.12), rgba(255,255,255,.94), rgba(123,212,94,.28), transparent);
  box-shadow:0 0 30px rgba(123,212,94,.58), 0 0 10px rgba(255,255,255,.32);
  animation:cleanRoute 3.1s ease-in-out infinite;
}
@keyframes hotspotPulse{
  0%,100%{transform:scale(.86);opacity:.16}
  45%{transform:scale(1.28);opacity:.56}
}
@keyframes cleanRoute{
  0%,100%{clip-path:inset(0 100% 0 0);opacity:.2}
  45%,65%{clip-path:inset(0 0 0 0);opacity:.9}
}
@keyframes cityGlassSheen{
  0%,100%{background-position:center, center, 118% 0}
  48%{background-position:center, center, -42% 0}
}
@media (prefers-reduced-motion: reduce){
  .city-map-interactive,
  .map-hotspot,
  .hotspot-popover{transition:none}
  .map-hotspot:before,
  .clean-route{animation:none}
  .city-map-interactive:before{animation:none}
  .city-map-interactive .city-aerial-img{transform:scale(1.02)}
}
.area-art:before{
  content:"";
  position:absolute;inset:0;
  background:
    linear-gradient(transparent 94%, rgba(255,255,255,.06) 94%) 0 0/38px 38px,
    linear-gradient(90deg, transparent 94%, rgba(255,255,255,.06) 94%) 0 0/38px 38px;
  mask-image:linear-gradient(180deg,#000,transparent 76%);
}
.sky-label{
  position:absolute;left:1.3rem;top:1.3rem;z-index:5;
  font-weight:950;color:rgba(255,255,255,.82);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
}
.map-plane{
  position:absolute;
  left:8%;right:8%;bottom:7%;
  height:50%;
  transform:rotateX(62deg) rotateZ(-8deg);
  transform-origin:center bottom;
  border:1px solid rgba(255,255,255,.18);
  border-radius:26px;
  background:
    linear-gradient(90deg, transparent 49%, rgba(255,255,255,.12) 50%, transparent 51%) 0 0/78px 78px,
    linear-gradient(0deg, transparent 49%, rgba(255,255,255,.1) 50%, transparent 51%) 0 0/78px 78px,
    linear-gradient(135deg, rgba(79,166,59,.25), rgba(0,117,191,.16), rgba(255,255,255,.06));
  box-shadow:0 42px 80px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.28);
}
.route{
  position:absolute;height:3px;border-radius:999px;background:linear-gradient(90deg, transparent, var(--accent), #fff, transparent);
  box-shadow:0 0 18px color-mix(in srgb, var(--accent) 70%, transparent);
}
.route.r1{left:12%;right:14%;top:42%;transform:rotate(-8deg)}
.route.r2{left:28%;right:22%;top:64%;transform:rotate(15deg);opacity:.75}
.pin{
  position:absolute;width:18px;height:18px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%, #fff, var(--accent) 62%, rgba(11,22,32,.38));
  border:2px solid rgba(255,255,255,.7);
  box-shadow:0 0 24px color-mix(in srgb, var(--accent) 72%, transparent);
}
.pin.p1{left:20%;top:38%}.pin.p2{left:52%;top:55%}.pin.p3{left:76%;top:32%}
.objects{position:absolute;inset:0;z-index:3;transform-style:preserve-3d}
.block,.house,.tower,.store,.clinic,.school,.glass,.tree,.water,.dune{
  position:absolute;bottom:34%;transform-style:preserve-3d;
  display:none;
}
.block,.tower,.store,.clinic,.school{
  width:70px;height:110px;border-radius:8px 8px 3px 3px;
  background:linear-gradient(145deg, rgba(255,255,255,.2), rgba(255,255,255,.04)), linear-gradient(160deg, color-mix(in srgb, var(--accent) 40%, #0b1620), #0b1620);
  border:1px solid rgba(255,255,255,.2);
  box-shadow:0 24px 44px rgba(0,0,0,.32), inset 0 1px 0 rgba(255,255,255,.2);
}
.tower:before,.block:before,.store:before,.clinic:before,.school:before{
  content:"";position:absolute;inset:14px 12px;
  background:repeating-linear-gradient(0deg, rgba(255,255,255,.24) 0 2px, transparent 2px 14px), repeating-linear-gradient(90deg, rgba(255,255,255,.18) 0 2px, transparent 2px 16px);
  opacity:.72;
}
.tower{height:190px;width:84px;left:58%;bottom:35%;transform:skewY(-2deg)}
.tower.t2{height:145px;left:70%;bottom:34%;opacity:.85}
.block{left:44%;height:132px}
.store{height:78px;width:150px;left:22%;bottom:31%}
.clinic{height:92px;width:122px;left:58%;bottom:30%}
.school{height:86px;width:150px;left:18%;bottom:31%}
.house{
  width:88px;height:54px;border-radius:8px;background:linear-gradient(145deg,#f7fafb,#c9d6dc);
  border:1px solid rgba(255,255,255,.6);box-shadow:0 18px 34px rgba(0,0,0,.25);
}
.house:before{content:"";position:absolute;left:8px;right:8px;top:-28px;height:34px;clip-path:polygon(0 100%,50% 0,100% 100%);background:linear-gradient(135deg,var(--accent),#0f2230)}
.house.h1{left:18%;bottom:32%}.house.h2{left:30%;bottom:29%;transform:scale(.82)}.house.h3{left:72%;bottom:31%;transform:scale(.9)}
.glass{
  width:126px;height:74px;left:64%;bottom:30%;
  border:1px solid rgba(255,255,255,.34);border-radius:16px;
  background:linear-gradient(135deg, rgba(255,255,255,.28), rgba(119,221,231,.08));
  box-shadow:0 22px 42px rgba(0,0,0,.22);
}
.tree{width:18px;height:60px;background:#17301f;border-radius:999px;box-shadow:0 0 0 18px rgba(123,212,94,.25);bottom:31%}
.tree.t1{left:14%}.tree.t2{left:82%;transform:scale(.8)}.tree.t3{left:50%;transform:scale(.65)}
.water{
  left:5%;right:5%;bottom:20%;height:50px;border-radius:50%;
  background:linear-gradient(90deg, transparent, rgba(119,221,231,.38), transparent);
  transform:rotateX(70deg);
}
.dune{
  left:12%;right:12%;bottom:28%;height:42px;border-radius:50%;
  background:linear-gradient(90deg, transparent, rgba(215,242,107,.28), rgba(255,255,255,.22), transparent);
  transform:rotateX(66deg);
}
.badge-stack{position:absolute;right:1.2rem;bottom:1.2rem;z-index:6;display:grid;gap:.45rem}
.scene-badge{padding:.55rem .75rem;border-radius:999px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.08);color:#fff;font-size:.78rem;font-weight:900;backdrop-filter:blur(8px)}
.city-downtown .tower,.city-downtown .block,.city-downtown .store,.city-downtown .glass,.city-downtown .tree{display:block}
.city-downtown .store{left:20%}
.city-campus .school,.city-campus .store,.city-campus .block,.city-campus .glass,.city-campus .tree{display:block}
.city-historic .house,.city-historic .store,.city-historic .block,.city-historic .water,.city-historic .tree{display:block}
.city-retail .store,.city-retail .clinic,.city-retail .block,.city-retail .house,.city-retail .tree{display:block}
.city-retail .store{width:170px}
.city-coastal .water,.city-coastal .dune,.city-coastal .store,.city-coastal .clinic,.city-coastal .glass,.city-coastal .tree{display:block}
.city-growth .clinic,.city-growth .store,.city-growth .school,.city-growth .block,.city-growth .house,.city-growth .tree{display:block}
.city-smalltown .house,.city-smalltown .school,.city-smalltown .store,.city-smalltown .tree{display:block}
.city-resort .water,.city-resort .dune,.city-resort .store,.city-resort .clinic,.city-resort .glass,.city-resort .tree{display:block}
.city-borough .store,.city-borough .clinic,.city-borough .block,.city-borough .house,.city-borough .tree{display:block}
.city-officepark .block,.city-officepark .clinic,.city-officepark .store,.city-officepark .glass,.city-officepark .tree{display:block}
.section{padding:clamp(3rem,6vw,6rem) clamp(1.25rem,5vw,5rem);border-top:1px solid var(--line)}
.section-head{max-width:860px;margin-bottom:2rem}
.section-head.copy-motion-head{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  max-width:min(1120px, 100%);
  padding:clamp(1.2rem,2.5vw,1.9rem);
  border:1px solid color-mix(in srgb, var(--city-accent) 24%, rgba(255,255,255,.72));
  border-radius:22px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.76), rgba(255,255,255,.38) 48%, color-mix(in srgb, var(--city-accent-two) 12%, rgba(255,255,255,.18))),
    radial-gradient(80% 110% at 0% 0%, rgba(255,255,255,.68), transparent 55%);
  box-shadow:
    0 24px 62px rgba(11,22,32,.09),
    inset 0 1px 0 rgba(255,255,255,.82),
    inset 0 -24px 54px rgba(11,22,32,.035);
  backdrop-filter:blur(18px) saturate(1.22);
  -webkit-backdrop-filter:blur(18px) saturate(1.22);
  opacity:0;
  transform:translateY(18px);
  transition:opacity 520ms ease, transform 620ms cubic-bezier(.2,.75,.2,1), border-color 280ms ease, box-shadow 280ms ease;
}
.section-head.copy-motion-head:before{
  content:"";
  position:absolute;
  inset:-42%;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 18% 22%, color-mix(in srgb, var(--city-accent-two) 32%, transparent), transparent 26%),
    radial-gradient(circle at 78% 18%, color-mix(in srgb, var(--city-accent) 24%, transparent), transparent 25%),
    radial-gradient(circle at 54% 90%, rgba(255,255,255,.72), transparent 22%),
    conic-gradient(from 140deg at 50% 50%, color-mix(in srgb, var(--city-accent) 16%, transparent), transparent, color-mix(in srgb, var(--city-accent-two) 16%, transparent), transparent);
  opacity:.2;
  filter:saturate(1.1);
  animation:liquidPanelFlow 10s ease-in-out infinite alternate;
}
.section-head.copy-motion-head > *{
  position:relative;
  z-index:1;
}
.section-head.copy-motion-head h2{
  max-width:25ch;
  font-size:clamp(2.05rem,3.7vw,3.75rem);
  line-height:.98;
}
.section-head.copy-motion-head p:not(.eyebrow){
  max-width:74ch;
  color:rgba(11,22,32,.72);
  font-size:clamp(1rem,.62vw + .88rem,1.18rem);
  line-height:1.46;
}
.section-head.copy-motion-head:after{
  content:"";
  position:relative;
  z-index:1;
  display:block;
  width:min(380px, 72%);
  height:3px;
  margin-top:1.15rem;
  border-radius:999px;
  background:linear-gradient(90deg, var(--city-accent), var(--city-accent-two), transparent);
  transform:scaleX(.18);
  transform-origin:left center;
  opacity:.42;
  transition:transform 780ms cubic-bezier(.2,.75,.2,1), opacity 520ms ease;
}
.section-head.copy-motion-head.is-visible{
  opacity:1;
  transform:translateY(0);
}
.section-head.copy-motion-head:hover,
.section-head.copy-motion-head:focus-within{
  border-color:color-mix(in srgb, var(--city-accent) 46%, rgba(255,255,255,.72));
  box-shadow:
    0 30px 72px rgba(11,22,32,.13),
    inset 0 1px 0 rgba(255,255,255,.9),
    inset 0 -24px 54px rgba(11,22,32,.045);
}
.section-head.copy-motion-head:hover:before,
.section-head.copy-motion-head:focus-within:before{
  opacity:.32;
  animation-duration:6s;
}
.section-head.copy-motion-head.is-visible:after{
  transform:scaleX(1);
  opacity:1;
}
.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;perspective:1200px}
.card{
  position:relative;overflow:hidden;isolation:isolate;
  background:#fff;border:1px solid var(--line);border-radius:18px;padding:1.2rem;
  box-shadow:0 12px 32px rgba(11,22,32,.06);
}
.card p,.card li{font-weight:720;color:rgba(11,22,32,.72)}
.card.motion-card{
  min-height:100%;
  cursor:default;
  opacity:0;
  transform:translateY(22px) scale(.975) rotateX(0) rotateY(0);
  transform-style:preserve-3d;
  border-color:color-mix(in srgb, var(--city-accent) 22%, rgba(255,255,255,.68));
  background:
    linear-gradient(135deg, rgba(255,255,255,.74), rgba(255,255,255,.42) 50%, color-mix(in srgb, var(--city-accent-two) 10%, rgba(255,255,255,.2))),
    radial-gradient(95% 120% at 0% 0%, rgba(255,255,255,.7), transparent 58%);
  box-shadow:
    0 20px 48px rgba(11,22,32,.08),
    inset 0 1px 0 rgba(255,255,255,.82),
    inset 0 -18px 40px rgba(11,22,32,.035);
  backdrop-filter:blur(17px) saturate(1.2);
  -webkit-backdrop-filter:blur(17px) saturate(1.2);
  transition:
    opacity 520ms ease,
    transform 560ms cubic-bezier(.2,.75,.2,1),
    border-color 240ms ease,
    box-shadow 280ms ease,
    background 280ms ease;
  will-change:transform, opacity;
}
.card.motion-card.is-visible{
  opacity:1;
  transform:translateY(0) scale(1) rotateX(0) rotateY(0);
  transition-delay:calc(var(--motion-index, 0) * 70ms);
}
.card.motion-card:before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(circle at var(--spot-x, 74%) var(--spot-y, 16%), color-mix(in srgb, var(--city-accent-two) 34%, transparent), transparent 28%),
    radial-gradient(ellipse at 8% 18%, color-mix(in srgb, var(--city-accent) 22%, transparent), transparent 32%),
    radial-gradient(ellipse at 92% 18%, color-mix(in srgb, var(--city-accent-two) 24%, transparent), transparent 30%),
    radial-gradient(ellipse at 42% 112%, rgba(255,255,255,.78), transparent 34%),
    var(--city-pattern);
  opacity:.16;
  transform:translate3d(-7%, -5%, 0) scale(1.08);
  filter:saturate(1.12);
  animation:liquidPanelFlow 9s ease-in-out infinite alternate;
  transition:opacity 260ms ease, transform 360ms cubic-bezier(.2,.75,.2,1);
}
.card.motion-card:after{
  content:"";
  position:absolute;
  inset:-30% -58%;
  z-index:1;
  pointer-events:none;
  background:linear-gradient(105deg, transparent 38%, rgba(255,255,255,.76) 50%, transparent 62%);
  opacity:0;
  transform:translateX(-46%) rotate(8deg);
}
.card.motion-card > *{
  position:relative;
  z-index:2;
}
.card.motion-card .card-liquid-blob{
  position:absolute;
  left:var(--liquid-x, 72%);
  top:var(--liquid-y, 18%);
  z-index:1;
  width:150px;
  height:150px;
  border-radius:43% 57% 58% 42% / 42% 38% 62% 58%;
  pointer-events:none;
  background:
    radial-gradient(circle at 35% 28%, rgba(255,255,255,.76), transparent 22%),
    radial-gradient(circle at 62% 66%, color-mix(in srgb, var(--city-accent-two) 56%, transparent), transparent 36%),
    color-mix(in srgb, var(--city-accent) 38%, transparent);
  filter:blur(9px) saturate(1.18);
  opacity:.22;
  mix-blend-mode:multiply;
  transform:translate(-50%, -50%) scale(.78) rotate(0deg);
  animation:liquidBlob 7s ease-in-out infinite alternate;
  transition:opacity 260ms ease, transform 320ms cubic-bezier(.2,.75,.2,1);
}
.card.motion-card h3{
  padding-right:2.4rem;
  font-size:clamp(1.35rem,1vw + 1rem,1.72rem);
  line-height:1.06;
  margin-bottom:.65rem;
}
.card.motion-card p,
.card.motion-card li{
  color:rgba(11,22,32,.7);
  font-size:clamp(.98rem,.38vw + .9rem,1.08rem);
  line-height:1.48;
}
.card-motion-kicker{
  display:inline-flex;
  align-items:center;
  gap:.42rem;
  margin:0 0 .7rem;
  color:color-mix(in srgb, var(--city-accent) 84%, var(--ami-deep));
  font-size:.72rem;
  font-weight:950;
  letter-spacing:.14em;
  line-height:1;
  text-transform:uppercase;
}
.card-motion-kicker:before{
  content:"";
  width:.55rem;
  height:.55rem;
  border-radius:999px;
  background:var(--city-accent);
  box-shadow:0 0 0 7px color-mix(in srgb, var(--city-accent) 14%, transparent), 0 0 22px color-mix(in srgb, var(--city-accent-two) 50%, transparent);
}
.card.motion-card .card-motion-mark{
  position:absolute;
  right:.95rem;
  top:.95rem;
  z-index:2;
  display:grid;
  place-items:center;
  min-width:2.05rem;
  height:2.05rem;
  padding:0 .42rem;
  border-radius:999px;
  background:linear-gradient(135deg, color-mix(in srgb, var(--city-accent) 84%, #fff), color-mix(in srgb, var(--city-accent-two) 72%, #fff));
  color:#fff;
  box-shadow:0 12px 26px color-mix(in srgb, var(--city-accent) 28%, transparent);
  font-size:.68rem;
  font-weight:950;
  letter-spacing:.04em;
  transform:translateZ(28px) scale(.92);
  transition:transform 260ms cubic-bezier(.2,.75,.2,1), box-shadow 260ms ease;
}
.card.motion-card:hover,
.card.motion-card:focus-within,
.card.motion-card.is-card-active{
  transform:translateY(-14px) scale(1.028) rotateX(var(--card-rx, 0deg)) rotateY(var(--card-ry, 0deg));
  border-color:color-mix(in srgb, var(--city-accent) 58%, rgba(255,255,255,.72));
  box-shadow:
    0 32px 68px rgba(11,22,32,.16),
    0 0 0 1px color-mix(in srgb, var(--city-accent) 24%, transparent),
    inset 0 1px 0 rgba(255,255,255,.9);
  transition-delay:0ms;
}
.card.motion-card:hover:before,
.card.motion-card:focus-within:before,
.card.motion-card.is-card-active:before{
  opacity:.32;
  transform:translate3d(0, 0, 0) scale(1.02);
}
.card.motion-card:hover .card-liquid-blob,
.card.motion-card:focus-within .card-liquid-blob,
.card.motion-card.is-card-active .card-liquid-blob{
  opacity:.42;
  transform:translate(-50%, -50%) scale(1.04) rotate(14deg);
  animation-duration:4.6s;
}
.card.motion-card:hover:after,
.card.motion-card:focus-within:after,
.card.motion-card.is-card-active:after{
  animation:cardCleanPass 980ms cubic-bezier(.2,.75,.2,1) both;
}
.card.motion-card:hover .card-motion-mark,
.card.motion-card:focus-within .card-motion-mark,
.card.motion-card.is-card-active .card-motion-mark{
  transform:translateZ(40px) translateY(-3px) scale(1.05);
  box-shadow:0 18px 34px color-mix(in srgb, var(--city-accent) 36%, transparent);
}
.tag.motion-tag{
  opacity:0;
  transform:translateY(12px) scale(.94);
  transition:opacity 420ms ease, transform 460ms cubic-bezier(.2,.75,.2,1), border-color 220ms ease, box-shadow 220ms ease;
}
.tag.motion-tag.is-visible{
  opacity:1;
  transform:translateY(0) scale(1);
  transition-delay:calc(var(--motion-index, 0) * 45ms);
}
.tag.motion-tag:hover{
  transform:translateY(-4px) scale(1.045);
  border-color:color-mix(in srgb, var(--city-accent) 52%, var(--line));
  box-shadow:0 12px 24px color-mix(in srgb, var(--city-accent) 18%, transparent);
}
@keyframes cardCleanPass{
  0%{opacity:0;transform:translateX(-50%) rotate(8deg)}
  18%{opacity:.65}
  100%{opacity:0;transform:translateX(52%) rotate(8deg)}
}
@keyframes liquidPanelFlow{
  0%{transform:translate3d(-7%, -5%, 0) rotate(0deg) scale(1.06);border-radius:42% 58% 64% 36% / 48% 42% 58% 52%}
  45%{transform:translate3d(4%, 3%, 0) rotate(7deg) scale(1.12);border-radius:58% 42% 48% 52% / 42% 62% 38% 58%}
  100%{transform:translate3d(-2%, 5%, 0) rotate(-5deg) scale(1.08);border-radius:46% 54% 38% 62% / 58% 42% 58% 42%}
}
@keyframes liquidBlob{
  0%{border-radius:43% 57% 58% 42% / 42% 38% 62% 58%;transform:translate(-50%, -50%) scale(.78) rotate(0deg)}
  50%{border-radius:58% 42% 45% 55% / 56% 48% 52% 44%;transform:translate(-48%, -52%) scale(.96) rotate(12deg)}
  100%{border-radius:39% 61% 62% 38% / 49% 56% 44% 51%;transform:translate(-52%, -48%) scale(.84) rotate(-10deg)}
}
.tagline{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem}
.tag{display:inline-flex;border:1px solid var(--line);background:var(--ami-paper);padding:.45rem .65rem;border-radius:999px;font-size:.78rem;font-weight:900}
.city-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}
.city-card{
  min-height:250px;position:relative;overflow:hidden;border-radius:18px;background:#fff;border:1px solid var(--line);
  box-shadow:0 12px 34px rgba(11,22,32,.08);
}
.city-card-art{height:118px;background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 22%, #0b1620), #0b1620);position:relative;overflow:hidden}
.city-card-art:before{
  content:"";position:absolute;left:12%;right:12%;bottom:18px;height:44px;
  background:linear-gradient(90deg, rgba(255,255,255,.18), rgba(123,212,94,.14));
  transform:skewX(-18deg);border-radius:10px;box-shadow:0 0 28px color-mix(in srgb, var(--accent) 50%, transparent);
}
.city-card-photo{height:132px;background:#071620}
.city-card-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform:scale(1.02);
  transition:transform 620ms cubic-bezier(.16,1,.3,1), filter 620ms cubic-bezier(.16,1,.3,1);
}
.city-card:hover .city-card-photo img,
.city-card:focus-within .city-card-photo img{
  transform:scale(1.075) translateY(-3px);
  filter:saturate(1.2) contrast(1.08) brightness(1.04);
}
.city-card-photo:before{
  left:0;
  right:0;
  top:0;
  bottom:0;
  height:auto;
  z-index:1;
  border-radius:0;
  transform:none;
  box-shadow:none;
  background:linear-gradient(180deg, rgba(7,22,32,.04), rgba(7,22,32,.34));
}
.city-card-body{padding:1rem}
.city-card-body strong{font-family:Fraunces, Georgia, serif;font-size:1.35rem;color:var(--ami-deep)}
.city-card-body span{display:block;margin-top:.35rem;font-weight:800;color:rgba(11,22,32,.72)}
.footer{padding:2rem clamp(1.25rem,5vw,5rem);background:#fff;border-top:1px solid var(--line)}
.foot-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-weight:850}
@media (max-width:1000px){
  .hero{grid-template-columns:1fr}
  .city-grid,.grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:700px){
  .nav{grid-template-columns:auto 1fr;gap:.7rem 1rem}
  .nav-links{justify-content:flex-end;overflow:visible;flex-wrap:wrap;gap:.75rem}
  .nav > .btn{grid-column:1 / -1;width:100%}
  .brand-logo{width:142px;height:auto}
  .hero{padding-top:2rem}
  .area-art{min-height:430px}
  .city-aerial-card{min-height:430px}
  .city-aerial-img{min-height:430px}
  .city-aerial-caption{align-items:flex-start;flex-direction:column}
  .city-aerial-card .badge-stack{max-width:none;justify-content:flex-start}
  .hotspot-popover{width:220px}
  .map-hotspot{width:2.25rem;height:2.25rem}
  .city-grid,.grid{grid-template-columns:1fr}
}
@media (max-width:620px){
  .hero-actions{grid-template-columns:1fr}
  .hero-actions .btn{white-space:normal}
}
@media (prefers-reduced-motion: reduce){
  .section-head.copy-motion-head,
  .tag.motion-tag,
  .card.motion-card{
    opacity:1;
    transform:none;
    transition:none;
  }
  .section-head.copy-motion-head:after{
    transform:scaleX(1);
  }
  .section-head.copy-motion-head:before,
  .card.motion-card .card-liquid-blob,
  .card.motion-card:before,
  .card.motion-card:after{
    animation:none;
    transition:none;
  }
}
