/* =========================================================
   Keep 100 Agents — Midlands estate agent network
   Brand: #0b2a4a (deep navy), #c79438 (warm gold),
          #04162c (near-black navy), #fbf8ee (warm ivory)
   Note: legacy variable names (--teal, --coral) retained
         but hold navy + gold values.
   ========================================================= */

:root{
  --teal: #0b2a4a;
  --teal-600: #071f38;
  --teal-400: #2e557d;
  --teal-100: #d3dfec;
  --teal-50:  #edf2f8;
  --ink: #04162c;
  --ink-700: #0d2441;
  --ink-500: #345778;
  --cream: #fbf8ee;
  --bone: #f0ead4;
  --sand: #e7dfc0;
  --coral: #c79438;
  --coral-600: #a07529;
  --line: rgba(4,22,44,0.12);
  --line-soft: rgba(4,22,44,0.06);
  --shadow-lg: 0 24px 60px -20px rgba(4,22,44,0.25);
  --shadow-sm: 0 6px 20px -8px rgba(4,22,44,0.18);

  --font-display: "Fraunces", "Times New Roman", serif;
  --font-body: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --radius: 18px;
  --radius-lg: 28px;
  --radius-xl: 40px;
}

/* ---------- BASE ---------- */
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img, svg{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
:focus-visible{outline:2px solid var(--teal);outline-offset:3px;border-radius:4px;}

.container{max-width:1200px;margin:0 auto;padding:0 28px;}

/* ---------- TYPOGRAPHY ---------- */
.h-display{
  font-family:var(--font-display);
  font-weight:500;
  font-size:clamp(2.2rem, 4.8vw, 4.6rem);
  line-height:1.02;
  letter-spacing:-0.025em;
  margin:0 0 22px;
  color:var(--ink);
  font-variation-settings:"opsz" 144;
}
.h-display em{
  font-style:italic;
  font-weight:400;
  color:var(--coral);
}
.h-display.light{color:var(--cream);}
.h-display.light em{color:var(--coral);}

.section-tag{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:0.78rem;
  font-weight:600;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--teal);
  padding:8px 14px;
  border:1px solid var(--teal);
  border-radius:999px;
  margin-bottom:22px;
  background:rgba(11,42,74,0.06);
}
.section-tag.light{color:var(--teal-100);border-color:rgba(11,42,74,0.5);background:rgba(11,42,74,0.1);}
.section-tag::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;}

.section-lede{
  font-size:clamp(1rem, 1.4vw, 1.2rem);
  color:var(--ink-500);
  max-width:680px;
  margin:0 0 40px;
  line-height:1.6;
}
.section-lede.light{color:rgba(251,248,238,0.8);}
/* Centered variant — use inside text-align:center containers */
.section-lede.center{margin:0 auto 40px;text-align:center;max-width:640px;}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 26px;
  border-radius:999px;
  font-weight:600;
  font-size:0.95rem;
  letter-spacing:-0.005em;
  transition:transform .2s ease, background .2s ease, color .2s ease, box-shadow .2s ease;
  white-space:nowrap;
  border:1.5px solid transparent;
}
.btn-lg{padding:18px 32px;font-size:1rem;}
.btn-primary{
  background:var(--ink);
  color:var(--cream);
  box-shadow:var(--shadow-sm);
}
.btn-primary:hover{background:var(--teal);transform:translateY(-2px);box-shadow:var(--shadow-lg);}
.btn-ghost{
  background:transparent;
  color:var(--ink);
  border-color:var(--ink);
}
.btn-ghost:hover{background:var(--ink);color:var(--cream);transform:translateY(-2px);}
.btn-accent{
  background:var(--coral);
  color:var(--cream);
  box-shadow:var(--shadow-sm);
}
.btn-accent:hover{background:var(--coral-600);transform:translateY(-2px);box-shadow:var(--shadow-lg);}

/* ---------- NAV ---------- */
.nav{
  position:sticky;
  top:0;
  z-index:100;
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  background:rgba(251,248,238,0.82);
  border-bottom:1px solid var(--line-soft);
  transition:background .2s ease;
}
.nav.scrolled{background:rgba(251,248,238,0.96);}
.nav-inner{
  max-width:1280px;
  margin:0 auto;
  padding:14px 28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:32px;
}
.brand{
  display:inline-flex;
  align-items:center;
  gap:12px;
}
.brand-mark{
  display:inline-block;
  flex-shrink:0;
  color:var(--coral);
  width:50px;
  height:25px;
  transition:transform .3s ease;
}
.brand:hover .brand-mark{
  transform:rotate(-8deg) scale(1.05);
}
.brand-text{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.brand-name{
  font-family:var(--font-display);
  font-weight:600;
  font-size:1rem;
  color:var(--ink);
  letter-spacing:-0.015em;
  font-variation-settings:"opsz" 144;
  line-height:1;
  display:block;
}
.brand-sub{
  font-family:var(--font-body);
  font-size:0.58rem;
  letter-spacing:0.28em;
  color:var(--teal);
  text-transform:uppercase;
  font-weight:600;
  padding-top:0;
}
.nav-links{
  display:flex;
  align-items:center;
  gap:34px;
}
.nav-links a{
  font-size:0.92rem;
  font-weight:500;
  color:var(--ink-500);
  position:relative;
  padding:6px 0;
  transition:color .2s ease;
}
.nav-links a:hover{color:var(--ink);}
.nav-links a::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:0;
  height:2px;
  background:var(--teal);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .25s ease;
}
.nav-links a:hover::after{transform:scaleX(1);}
.nav-quiz{color:var(--teal)!important;font-weight:600!important;}
.nav-cta{padding:10px 20px;font-size:0.9rem;}

.nav-toggle{display:none;flex-direction:column;gap:5px;padding:10px;}
.nav-toggle span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:all .2s ease;}

.mobile-menu{display:none;}

@media (max-width: 960px){
  .nav-links{display:none;}
  .nav-cta{display:none;}
  .nav-toggle{display:flex;}
  .brand-sub{display:none;}
  .mobile-menu{
    display:flex;
    flex-direction:column;
    gap:16px;
    padding:20px 28px 28px;
    border-top:1px solid var(--line-soft);
    background:var(--cream);
  }
  .mobile-menu[hidden]{display:none;}
  .mobile-menu a:not(.btn){padding:8px 0;color:var(--ink);font-weight:500;}
  .mobile-menu .btn{align-self:flex-start;margin-top:8px;}
  .mobile-menu .btn-primary{color:var(--cream);}
}

/* ================================================
   HERO
   ================================================ */
.hero{
  position:relative;
  padding:90px 0 80px;
  overflow:hidden;
  isolation:isolate;
}
.hero-bg{
  position:absolute;
  inset:0;
  z-index:-1;
}
.orb{
  position:absolute;
  border-radius:50%;
  filter:blur(60px);
  opacity:0.55;
  animation:float 14s ease-in-out infinite;
}
.orb-a{
  width:600px;height:600px;
  background:radial-gradient(circle at 30% 30%, var(--teal), transparent 70%);
  top:-200px;right:-150px;
}
.orb-b{
  width:480px;height:480px;
  background:radial-gradient(circle at 60% 60%, #e0ba78, transparent 70%);
  bottom:-180px;left:-100px;
  animation-delay:-6s;
}
@keyframes float{
  0%,100%{transform:translate(0,0) scale(1);}
  50%{transform:translate(40px,-20px) scale(1.05);}
}
.grain{
  position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 1px 1px, rgba(4,22,44,0.06) 1px, transparent 0);
  background-size:4px 4px;
  opacity:0.5;
  mix-blend-mode:multiply;
  pointer-events:none;
}

.hero-inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 28px;
  text-align:center;
}
.hero-badges{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
  margin-bottom:32px;
}
.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 16px;
  border-radius:999px;
  background:rgba(251,248,238,0.8);
  border:1px solid var(--line);
  font-size:0.85rem;
  font-weight:500;
  color:var(--ink-500);
  backdrop-filter:blur(6px);
}
.pill .dot{
  width:8px;height:8px;border-radius:50%;
  background:#1ecb92;
  box-shadow:0 0 0 4px rgba(30,203,146,0.25);
  animation:pulse 2s infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(30,203,146,0.45);}
  50%{box-shadow:0 0 0 6px rgba(30,203,146,0);}
}

.hero-title{
  font-family:var(--font-display);
  font-weight:500;
  font-variation-settings:"opsz" 144;
  font-size:clamp(2.6rem, 6.8vw, 6rem);
  line-height:0.96;
  letter-spacing:-0.03em;
  margin:0 auto 24px;
  max-width:1000px;
}
.hero-title em{
  font-style:italic;
  font-weight:400;
  color:var(--coral);
}
.hero-title .accent{
  font-style:italic;
  color:var(--coral);
  font-weight:400;
}
.hero-title .eyebrow{
  display:block;
  font-family:var(--font-body);
  font-size:0.78rem;
  font-weight:600;
  letter-spacing:0.25em;
  text-transform:uppercase;
  color:var(--teal);
  margin-bottom:22px;
}

.hero-lede{
  font-size:clamp(1.05rem, 1.5vw, 1.25rem);
  color:var(--ink-500);
  max-width:640px;
  margin:0 auto 38px;
}

.hero-ctas{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  justify-content:center;
  margin-bottom:80px;
}

.hero-stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
  max-width:900px;
  margin:0 auto;
  padding:32px;
  background:rgba(251,248,238,0.7);
  backdrop-filter:blur(8px);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
}
.hs-stat{text-align:center;}
.hs-num{
  font-family:var(--font-display);
  font-size:clamp(2.4rem, 4.2vw, 3.4rem);
  font-weight:500;
  color:var(--ink);
  font-variation-settings:"opsz" 144;
  line-height:1;
}
.hs-suf{
  font-family:var(--font-display);
  font-size:clamp(1.6rem, 2.8vw, 2rem);
  color:var(--teal);
  font-weight:500;
  font-style:italic;
}
.hs-stat p{
  margin:12px 0 0;
  font-size:0.92rem;
  color:var(--ink-500);
  line-height:1.5;
}
@media (max-width:720px){
  .hero-stats{grid-template-columns:1fr;padding:24px;}
}

.scroll-hint{
  display:block;
  width:40px;
  height:60px;
  border:2px solid var(--ink);
  border-radius:999px;
  margin:40px auto 0;
  position:relative;
}
.scroll-hint span{
  position:absolute;
  left:50%;top:10px;
  width:4px;height:8px;
  background:var(--ink);
  border-radius:2px;
  transform:translateX(-50%);
  animation:scrollHint 1.8s ease-in-out infinite;
}
@keyframes scrollHint{
  0%{opacity:0;transform:translate(-50%,0);}
  40%{opacity:1;}
  100%{opacity:0;transform:translate(-50%,20px);}
}

/* ================================================
   FEAR — stats marquee
   ================================================ */
.fear{
  padding:110px 0 100px;
  background:linear-gradient(180deg, var(--cream), var(--bone));
  position:relative;
}
.fear .container{text-align:center;}

.marquee{
  margin:56px 0 64px;
  overflow:hidden;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:22px 0;
  background:var(--ink);
  color:var(--cream);
}
.marquee-track{
  display:flex;
  width:max-content;
  white-space:nowrap;
  animation:marquee var(--mq-duration, 40s) linear infinite;
  font-family:var(--font-display);
  font-size:1.4rem;
  font-weight:500;
  font-variation-settings:"opsz" 144;
  will-change:transform;
}
.mq-copy{
  display:flex;
  flex-shrink:0;
}
.mq-copy > *{margin-right:32px;flex-shrink:0;}
.mq{color:var(--cream);}
.mq-dot{color:var(--teal);}
@keyframes marquee{
  from{transform:translate3d(0,0,0);}
  to{transform:translate3d(calc(-1 * var(--mq-distance, 50%)), 0, 0);}
}
@media (max-width:720px){
  .marquee-track{
    --mq-duration:22s;
    font-size:1.1rem;
  }
  .mq-copy > *{margin-right:22px;}
}

.stat-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:20px;
  margin-bottom:60px;
}
.stat-card{
  padding:36px 28px;
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  text-align:left;
  transition:transform .3s ease, box-shadow .3s ease;
}
.stat-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}
.stat-card.accent-card{
  background:var(--ink);color:var(--cream);border-color:var(--ink);
}
.stat-card.accent-card p strong{color:var(--coral);}
.stat-card.accent-card .stat-num{color:var(--coral);}
.stat-num{
  font-family:var(--font-display);
  font-size:clamp(2.6rem, 4.8vw, 3.8rem);
  font-weight:500;
  color:var(--teal);
  line-height:1;
  margin-bottom:16px;
  font-variation-settings:"opsz" 144;
}
.stat-num .small{
  font-size:0.5em;
  color:var(--ink-500);
  font-style:italic;
}
.stat-card.accent-card .stat-num .small{color:var(--teal-100);}
.stat-card p{margin:0;font-size:0.95rem;line-height:1.55;color:inherit;}
.stat-card.accent-card p{color:rgba(251,248,238,0.9);}

@media (max-width:980px){.stat-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:520px){.stat-grid{grid-template-columns:1fr;}}

.fear-cta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:36px 40px;
  border-radius:var(--radius-lg);
  background:linear-gradient(135deg, var(--teal), var(--ink));
  color:var(--cream);
  text-align:left;
  box-shadow:var(--shadow-lg);
}
.fear-cta h3{
  margin:0 0 6px;
  font-family:var(--font-display);
  font-size:clamp(1.4rem, 2.4vw, 1.9rem);
  font-weight:500;
  line-height:1.1;
  font-variation-settings:"opsz" 144;
}
.fear-cta h3 em{font-style:italic;color:var(--coral);}
.fear-cta p{margin:0;color:rgba(251,248,238,0.8);}

/* ================================================
   ONE SINGLE DAY
   ================================================ */
.day{
  padding:110px 0 120px;
  background:var(--ink);
  color:var(--cream);
  position:relative;
  overflow:hidden;
}
.day::before{
  content:"";
  position:absolute;
  top:-200px;left:50%;
  width:700px;height:700px;
  background:radial-gradient(circle, rgba(11,42,74,0.25), transparent 60%);
  transform:translateX(-50%);
  filter:blur(60px);
  pointer-events:none;
}
.day .container{position:relative;text-align:center;}

.quote{
  max-width:780px;
  margin:50px auto 64px;
  padding:40px;
  border:1px solid rgba(251,248,238,0.15);
  border-radius:var(--radius-lg);
  background:rgba(11,42,74,0.08);
  backdrop-filter:blur(6px);
}
.quote blockquote{
  font-family:var(--font-display);
  font-style:italic;
  font-size:clamp(1.3rem, 2.4vw, 1.9rem);
  line-height:1.35;
  font-weight:400;
  margin:0 0 20px;
  font-variation-settings:"opsz" 144;
}
.quote figcaption{
  font-size:0.9rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--teal-100);
  font-weight:500;
}

.day-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.day-card{
  padding:40px 30px;
  border:1px solid rgba(251,248,238,0.15);
  border-radius:var(--radius-lg);
  text-align:left;
  transition:transform .3s ease, border-color .3s ease;
}
.day-card:hover{transform:translateY(-6px);border-color:var(--teal);}
.day-num{
  font-family:var(--font-display);
  font-size:clamp(3rem, 5.5vw, 4.4rem);
  font-weight:500;
  color:var(--coral);
  line-height:1;
  display:block;
  margin-bottom:16px;
  font-variation-settings:"opsz" 144;
}
.day-num small{font-size:0.4em;color:rgba(199,148,56,0.55);font-style:italic;}
.day-card p{margin:0;color:rgba(251,248,238,0.8);}

@media (max-width:820px){.day-grid{grid-template-columns:1fr;}}

/* ================================================
   SOLUTION — Pillars with animated glass icons
   ================================================ */
.solution{padding:120px 0 60px;background:var(--cream);}
.solution .container{text-align:center;}

.solution-stats{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:60px;
  margin:30px 0 70px;
  padding:34px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.solution-stats div{display:flex;flex-direction:column;align-items:center;gap:6px;}
.sol-num{
  font-family:var(--font-display);
  font-size:clamp(2.4rem, 4vw, 3.2rem);
  font-weight:500;
  color:var(--teal);
  line-height:1;
  font-variation-settings:"opsz" 144;
}
.sol-lbl{
  font-size:0.8rem;
  font-weight:600;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--ink-500);
}

.pillars{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:20px;
  text-align:left;
}
.pillar{
  padding:40px;
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
  position:relative;
  overflow:hidden;
}
.pillar:hover{transform:translateY(-4px);border-color:var(--teal);box-shadow:var(--shadow-lg);}

/* Glass blurry icon container */
.pillar-ico{
  width:72px;height:72px;
  display:grid;place-items:center;
  border-radius:20px;
  color:var(--teal);
  margin-bottom:24px;
  position:relative;
  overflow:hidden;
  isolation:isolate;
  background:linear-gradient(135deg, rgba(11,42,74,0.12), rgba(11,42,74,0.04));
  border:1px solid rgba(11,42,74,0.2);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.6),
    0 8px 24px -8px rgba(11,42,74,0.3);
}
/* Animated blur blob inside the icon */
.ico-blur{
  position:absolute;
  inset:-20%;
  background:radial-gradient(circle at 30% 30%, var(--teal-400), transparent 60%);
  filter:blur(14px);
  opacity:0.5;
  animation:icoBlur 6s ease-in-out infinite;
  z-index:-1;
}
@keyframes icoBlur{
  0%,100%{transform:translate(0,0) scale(1);opacity:0.45;}
  50%{transform:translate(30%,20%) scale(1.25);opacity:0.7;}
}
.ico-svg{
  width:36px;height:36px;
  position:relative;
  z-index:1;
}
.pillar:hover .pillar-ico{
  border-color:var(--teal);
  background:linear-gradient(135deg, rgba(11,42,74,0.22), rgba(11,42,74,0.08));
}

/* Per-icon animations */
/* pulse — real-time protection rings */
.pillar-ico-pulse .ico-ring{
  transform-origin:center;
  animation:icoPulseRing 2.2s ease-out infinite;
}
.pillar-ico-pulse .ico-ring-2{animation-delay:.6s;}
@keyframes icoPulseRing{
  0%{transform:scale(.6);opacity:1;}
  70%{transform:scale(1.1);opacity:0;}
  100%{transform:scale(1.1);opacity:0;}
}
.pillar-ico-pulse .ico-dot{
  animation:icoDotPulse 1.5s ease-in-out infinite;
  transform-origin:center;
  fill:var(--coral);
}
@keyframes icoDotPulse{
  0%,100%{transform:scale(1);}
  50%{transform:scale(1.25);}
}

/* slide — smart controls */
.pillar-ico-slide .ico-toggle{
  animation:icoToggle 3s ease-in-out infinite;
  fill:var(--coral);
}
@keyframes icoToggle{
  0%,45%{transform:translateX(0);}
  55%,100%{transform:translateX(-14px);}
}
.pillar-ico-slide .ico-bar{
  stroke-dasharray:30;
  stroke-dashoffset:30;
  animation:icoBarDraw 1.6s ease-out infinite alternate;
}
.pillar-ico-slide .ico-bar-2{animation-delay:.2s;}
.pillar-ico-slide .ico-bar-3{animation-delay:.4s;}
@keyframes icoBarDraw{
  0%{stroke-dashoffset:30;}
  100%{stroke-dashoffset:0;}
}

/* check — privacy first shield */
.pillar-ico-check .ico-shield{
  transform-origin:center;
  animation:icoShield 3.5s ease-in-out infinite;
}
@keyframes icoShield{
  0%,100%{transform:scale(1);}
  50%{transform:scale(1.04);}
}
.pillar-ico-check .ico-check{
  stroke-dasharray:20;
  stroke-dashoffset:20;
  animation:icoCheck 2.4s ease-in-out infinite;
  stroke:var(--coral);
}
@keyframes icoCheck{
  0%,20%{stroke-dashoffset:20;}
  50%,80%{stroke-dashoffset:0;}
  100%{stroke-dashoffset:20;}
}

/* chart — deep insights */
.pillar-ico-chart .ico-line{
  stroke-dasharray:40;
  stroke-dashoffset:40;
  animation:icoLine 2.5s ease-in-out infinite;
}
@keyframes icoLine{
  0%{stroke-dashoffset:40;}
  50%,100%{stroke-dashoffset:0;}
}
.pillar-ico-chart .ico-spark{
  opacity:0;
  animation:icoSpark 2.5s ease-in-out infinite;
  fill:var(--coral);
}
.pillar-ico-chart .ico-spark-1{animation-delay:.3s;}
.pillar-ico-chart .ico-spark-2{animation-delay:.7s;}
.pillar-ico-chart .ico-spark-3{animation-delay:1.1s;}
.pillar-ico-chart .ico-spark-4{animation-delay:1.5s;}
@keyframes icoSpark{
  0%,30%{opacity:0;transform:scale(.5);transform-origin:center;}
  50%{opacity:1;transform:scale(1.3);}
  70%,100%{opacity:0.8;transform:scale(1);}
}

.pillar h3{
  font-family:var(--font-display);
  font-weight:500;
  font-size:1.7rem;
  line-height:1.1;
  margin:0 0 12px;
  font-variation-settings:"opsz" 144;
}
.pillar p{margin:0 0 20px;color:var(--ink-500);}
.pillar ul{margin:0;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:8px;}
.pillar li{
  font-size:0.82rem;
  font-weight:500;
  padding:6px 12px;
  background:var(--teal-50);
  color:var(--teal);
  border-radius:999px;
}
@media (max-width:820px){.pillars{grid-template-columns:1fr;}}

/* ================================================
   FEATURES
   ================================================ */
.features{
  padding:80px 0 120px;
  background:linear-gradient(180deg, var(--cream), var(--sand));
}
.features .container{text-align:center;}

.feat-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:16px;
  margin-top:56px;
  text-align:left;
}
.feat-card{
  padding:32px 26px;
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:var(--radius);
  position:relative;
  transition:transform .3s ease, border-color .3s ease, background .3s ease;
  min-height:220px;
  display:flex;
  flex-direction:column;
}
.feat-card:hover{
  transform:translateY(-6px);
  border-color:var(--teal);
  background:var(--teal-50);
}
.feat-num{
  font-family:var(--font-display);
  font-size:1rem;
  color:var(--teal);
  font-weight:500;
  letter-spacing:0.1em;
  margin-bottom:14px;
  display:inline-block;
  font-style:italic;
}
.feat-card h3{
  font-family:var(--font-display);
  font-weight:500;
  font-size:1.35rem;
  margin:0 0 10px;
  line-height:1.15;
  font-variation-settings:"opsz" 144;
}
.feat-card p{margin:0;font-size:0.92rem;color:var(--ink-500);}

.feat-card.feat-quiz{
  background:var(--ink);
  color:var(--cream);
  border-color:var(--ink);
}
.feat-card.feat-quiz:hover{background:var(--teal);border-color:var(--teal);}
.feat-card.feat-quiz .feat-num{color:var(--teal);font-size:1.4rem;}
.feat-card.feat-quiz:hover .feat-num{color:var(--cream);}
.feat-card.feat-quiz p{color:rgba(251,248,238,0.85);margin-bottom:18px;}
.feat-card.feat-quiz .btn{
  background:var(--teal);color:var(--cream);margin-top:auto;align-self:flex-start;
  padding:10px 18px;font-size:0.88rem;
}
.feat-card.feat-quiz:hover .btn{background:var(--ink);}

@media (max-width:1100px){.feat-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.feat-grid{grid-template-columns:1fr;}}

/* ================================================
   STEPS
   ================================================ */
.steps{
  padding:120px 0;
  background:var(--ink);
  color:var(--cream);
  position:relative;
  overflow:hidden;
}
.steps::before{
  content:"";
  position:absolute;
  bottom:-200px;right:-100px;
  width:500px;height:500px;
  background:radial-gradient(circle, rgba(11,42,74,0.25), transparent 60%);
  filter:blur(60px);pointer-events:none;
}
.steps .container{position:relative;text-align:center;}

.step-list{
  list-style:none;
  counter-reset:step;
  padding:0;
  margin:60px 0 40px;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  text-align:left;
}
.step{
  padding:32px 26px;
  background:rgba(251,248,238,0.04);
  border:1px solid rgba(251,248,238,0.12);
  border-radius:var(--radius);
  transition:transform .3s ease, border-color .3s ease, background .3s ease;
  position:relative;
}
.step:hover{transform:translateY(-4px);border-color:var(--teal);background:rgba(11,42,74,0.08);}
.step-num{
  font-family:var(--font-display);
  font-size:3rem;
  font-weight:500;
  color:var(--coral);
  line-height:1;
  margin-bottom:18px;
  display:inline-block;
  font-variation-settings:"opsz" 144;
  font-style:italic;
}
.step h3{
  font-family:var(--font-display);
  font-weight:500;
  font-size:1.45rem;
  margin:0 0 10px;
  font-variation-settings:"opsz" 144;
}
.step p{margin:0 0 18px;font-size:0.92rem;color:rgba(251,248,238,0.8);}
.step ul{margin:0;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:6px;}
.step li{
  font-size:0.75rem;padding:5px 10px;
  background:rgba(11,42,74,0.18);color:var(--teal-100);
  border-radius:999px;font-weight:500;
}
.steps-cta{margin-top:24px;}
@media (max-width:960px){.step-list{grid-template-columns:repeat(2,1fr);}}
@media (max-width:520px){.step-list{grid-template-columns:1fr;}}

/* ================================================
   PRICING
   ================================================ */
.pricing{padding:120px 0;background:var(--cream);}
.pricing .container{text-align:center;}

.billing-toggle{
  display:inline-flex;
  padding:6px;
  background:var(--bone);
  border-radius:999px;
  margin:10px 0 44px;
  border:1px solid var(--line);
}
.bt-btn{
  padding:10px 22px;
  border-radius:999px;
  font-weight:600;
  font-size:0.9rem;
  color:var(--ink-500);
  transition:all .25s ease;
  display:inline-flex;align-items:center;gap:8px;
}
.bt-btn.is-active{background:var(--ink);color:var(--cream);}
.bt-save{
  background:var(--teal);color:var(--cream);
  padding:3px 10px;border-radius:999px;font-size:0.7rem;
}

.price-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  text-align:left;
}
.price-card{
  padding:40px;
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  position:relative;
  display:flex;flex-direction:column;
  transition:transform .3s ease, box-shadow .3s ease;
}
.price-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}
.price-card.featured{
  background:var(--ink);
  color:var(--cream);
  border-color:var(--ink);
  transform:scale(1.03);
}
.price-card.featured:hover{transform:scale(1.03) translateY(-6px);}
.badge-featured{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  padding:6px 14px;
  background:var(--coral);color:var(--cream);
  border-radius:999px;font-size:0.75rem;font-weight:600;
  letter-spacing:0.08em;text-transform:uppercase;
}
.price-card h3{
  font-family:var(--font-display);
  font-weight:500;
  font-size:1.8rem;
  margin:0 0 6px;
  font-variation-settings:"opsz" 144;
}
.price-sub{
  font-size:0.88rem;color:var(--ink-500);margin:0 0 26px;
}
.price-card.featured .price-sub{color:rgba(251,248,238,0.7);}
.price{
  display:flex;align-items:baseline;gap:4px;
  font-family:var(--font-display);
  margin-bottom:26px;
}
.price .currency{font-size:1.4rem;color:var(--teal);}
.price-card.featured .price .currency{color:var(--teal-100);}
.price .amount{
  font-size:3.4rem;
  font-weight:500;
  line-height:1;
  font-variation-settings:"opsz" 144;
}
.price .per{
  font-family:var(--font-body);
  font-size:0.9rem;color:var(--ink-500);font-weight:400;
}
.price-card.featured .price .per{color:rgba(251,248,238,0.7);}

.price-list{
  list-style:none;padding:0;margin:0 0 30px;
  display:flex;flex-direction:column;gap:10px;
}
.price-list li{
  padding-left:28px;position:relative;font-size:0.94rem;
}
.price-list li::before{
  content:"";
  position:absolute;left:0;top:7px;
  width:16px;height:9px;
  border-left:2px solid var(--teal);
  border-bottom:2px solid var(--teal);
  transform:rotate(-45deg);
}
.price-card .btn{align-self:stretch;margin-top:auto;}
.price-card.featured .price-list li::before{
  border-left-color:var(--coral);
  border-bottom-color:var(--coral);
}
.price-card.featured .price .currency{color:var(--coral);}
.price-note{
  margin-top:30px;font-size:0.85rem;color:var(--ink-500);
}
@media (max-width:960px){
  .price-grid{grid-template-columns:1fr;max-width:440px;margin:0 auto;}
  .price-card.featured{transform:none;}
  .price-card.featured:hover{transform:translateY(-6px);}
}

/* ================================================
   QUIZ BANNER
   ================================================ */
.quiz-banner{
  padding:120px 0;
  background:linear-gradient(135deg, var(--ink), var(--teal-600) 120%);
  color:var(--cream);
  position:relative;
  overflow:hidden;
}
.quiz-banner::before{
  content:"";
  position:absolute;top:-100px;right:-100px;
  width:400px;height:400px;
  background:radial-gradient(circle, rgba(199,148,56,0.3), transparent 60%);
  filter:blur(60px);pointer-events:none;
}
.qb-inner{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:60px;
  align-items:center;
  position:relative;
}
.qb-stats{
  display:flex;flex-wrap:wrap;gap:30px;
  margin:30px 0 36px;
}
.qb-stats div{display:flex;flex-direction:column;gap:4px;}
.qb-stats strong{
  font-family:var(--font-display);
  font-size:2rem;color:var(--coral);
  font-variation-settings:"opsz" 144;
  font-weight:500;
}
.qb-stats span{font-size:0.85rem;color:rgba(251,248,238,0.7);max-width:180px;}

.qb-card{
  background:var(--cream);
  color:var(--ink);
  border-radius:var(--radius-lg);
  box-shadow:0 30px 70px -20px rgba(0,0,0,0.4);
  overflow:hidden;
  transform:rotate(1.5deg);
  transition:transform .4s ease;
}
.qb-card:hover{transform:rotate(0) scale(1.02);}
.qb-card-head{
  display:flex;align-items:center;gap:6px;
  padding:14px 20px;
  background:var(--bone);
  border-bottom:1px solid var(--line);
}
.qb-dot{width:10px;height:10px;border-radius:50%;background:var(--line);}
.qb-dot:nth-child(1){background:#ff5f56;}
.qb-dot:nth-child(2){background:#ffbd2e;}
.qb-dot:nth-child(3){background:#27c93f;}
.qb-title{
  margin-left:auto;font-size:0.78rem;
  font-weight:600;letter-spacing:0.04em;color:var(--ink-500);
}
.qb-body{padding:28px;}
.qb-q{
  font-family:var(--font-display);
  font-size:1.3rem;font-weight:500;line-height:1.3;
  margin:0 0 22px;font-variation-settings:"opsz" 144;
}
.qb-opt{
  display:block;width:100%;text-align:left;
  padding:14px 18px;
  margin-bottom:10px;
  background:var(--bone);
  border:1.5px solid transparent;
  border-radius:12px;
  font-weight:500;font-size:0.95rem;
  transition:all .2s ease;
}
.qb-opt:hover{background:var(--teal-50);border-color:var(--teal);}
.qb-opt-active{background:var(--teal-50);border-color:var(--teal);color:var(--teal-600);}

@media (max-width:960px){.qb-inner{grid-template-columns:1fr;}}

/* ================================================
   TESTIMONIALS (with slider)
   ================================================ */
.testimonials{padding:120px 0 60px;background:var(--cream);}
.testimonials-head{text-align:center;margin-bottom:20px;}

.slider{
  position:relative;
  padding:20px 0 40px;
  margin:0 -10px;
}
.slider-viewport{
  overflow:hidden;
  padding:10px 10px 20px;
}
.slider-track{
  display:flex;
  gap:20px;
  transition:transform .55s cubic-bezier(.2,.7,.2,1);
  will-change:transform;
}
.t-card{
  flex:0 0 calc((100% - 40px) / 3);
  padding:36px 32px;
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  margin:0;
  transition:transform .3s ease, box-shadow .3s ease;
  display:flex;flex-direction:column;
}
.t-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}
.t-rating{color:var(--teal);font-size:1.1rem;letter-spacing:0.1em;margin-bottom:16px;}
.t-card blockquote{
  margin:0 0 24px;
  font-family:var(--font-display);
  font-size:1.15rem;line-height:1.45;font-weight:400;
  font-variation-settings:"opsz" 144;
  flex:1;
}
.t-card figcaption{
  display:flex;align-items:center;gap:14px;
  padding-top:20px;border-top:1px solid var(--line);
}
.t-avatar{
  width:44px;height:44px;
  border-radius:50%;
  background:var(--teal);color:var(--cream);
  display:grid;place-items:center;
  font-weight:700;font-size:0.9rem;flex-shrink:0;
}
.t-card figcaption strong{display:block;font-size:0.95rem;}
.t-card figcaption em{
  font-style:normal;font-size:0.8rem;color:var(--ink-500);
}

.slider-nav{
  position:absolute;
  top:50%;transform:translateY(-50%);
  width:50px;height:50px;
  border-radius:50%;
  background:var(--cream);
  border:1.5px solid var(--line);
  color:var(--ink);
  font-size:1.4rem;font-weight:500;
  display:grid;place-items:center;
  box-shadow:var(--shadow-sm);
  transition:all .25s ease;
  z-index:3;
}
.slider-nav:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);transform:translateY(-50%) scale(1.05);}
.slider-nav:disabled{opacity:0.35;cursor:not-allowed;}
.slider-nav:disabled:hover{background:var(--cream);color:var(--ink);transform:translateY(-50%);}
.slider-prev{left:-10px;}
.slider-next{right:-10px;}

.slider-dots{
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:20px;
}
.slider-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--line);
  transition:all .3s ease;
  cursor:pointer;
}
.slider-dot.is-active{
  background:var(--teal);
  width:26px;border-radius:4px;
}

@media (max-width:960px){
  .t-card{flex:0 0 calc((100% - 20px) / 2);}
  .slider-prev{left:0;}
  .slider-next{right:0;}
}
@media (max-width:640px){
  .t-card{flex:0 0 100%;}
}

.benefits-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  padding-top:60px;
  margin-top:60px;
  border-top:1px solid var(--line);
  text-align:left;
}
.benefit{
  position:relative;
  padding:32px 28px;
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
  isolation:isolate;
}
.benefit::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(145deg, rgba(11,42,74,0.08), transparent 60%);
  opacity:0;
  transition:opacity .35s ease;
  z-index:-1;
}
.benefit:hover{
  transform:translateY(-6px);
  border-color:var(--teal);
  box-shadow:var(--shadow-lg);
}
.benefit:hover::before{opacity:1;}
.benefit-ico{
  width:48px;height:48px;
  border-radius:14px;
  display:grid;place-items:center;
  margin-bottom:18px;
  background:linear-gradient(135deg, rgba(11,42,74,0.18), rgba(11,42,74,0.06));
  border:1px solid rgba(11,42,74,0.2);
  color:var(--teal);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.6);
  transition:transform .35s ease, background .35s ease;
}
.benefit:hover .benefit-ico{
  transform:scale(1.08) rotate(-4deg);
  background:linear-gradient(135deg, rgba(11,42,74,0.28), rgba(11,42,74,0.12));
}
.benefit-num{
  position:absolute;
  top:22px;right:26px;
  font-family:var(--font-display);
  font-style:italic;
  font-size:1.1rem;
  color:var(--teal);
  opacity:0.55;
  font-variation-settings:"opsz" 144;
}
.benefit h4{
  font-family:var(--font-display);
  font-weight:500;font-size:1.35rem;margin:0 0 10px;
  font-variation-settings:"opsz" 144;
  line-height:1.15;
}
.benefit p{margin:0;color:var(--ink-500);font-size:0.93rem;line-height:1.55;}
@media (max-width:960px){.benefits-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:520px){.benefits-grid{grid-template-columns:1fr;}}

/* ---------- PILLAR CTA ---------- */
.pillar-cta{
  margin-top:40px;
  padding:34px 40px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:30px;
  flex-wrap:wrap;
  background:linear-gradient(135deg, var(--ink) 0%, var(--teal-600) 140%);
  border-radius:var(--radius-lg);
  color:var(--cream);
  box-shadow:var(--shadow-lg);
  position:relative;
  overflow:hidden;
  text-align:left;
}
.pillar-cta::before{
  content:"";
  position:absolute;
  top:-100px;right:-60px;
  width:320px;height:320px;
  background:radial-gradient(circle, rgba(199,148,56,0.35), transparent 60%);
  filter:blur(50px);
  pointer-events:none;
}
.pc-left{
  display:flex;align-items:center;gap:22px;
  position:relative;flex:1;min-width:280px;
}
.pc-glyph{
  flex-shrink:0;
  width:58px;height:58px;
  display:grid;place-items:center;
  border-radius:18px;
  background:linear-gradient(135deg, rgba(11,42,74,0.3), rgba(11,42,74,0.1));
  border:1px solid rgba(46,85,125,0.4);
  color:var(--teal-100);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.2),
    0 10px 30px -10px rgba(11,42,74,0.5);
  position:relative;
  overflow:visible;
}
.pc-glyph::before{
  content:"";
  position:absolute;
  inset:-6px;
  border-radius:22px;
  background:radial-gradient(circle, rgba(46,85,125,0.25), transparent 70%);
  filter:blur(8px);
  z-index:-1;
  animation:pcGlow 3s ease-in-out infinite;
}
@keyframes pcGlow{
  0%,100%{opacity:0.5;transform:scale(1);}
  50%{opacity:1;transform:scale(1.15);}
}
.pc-glyph-svg{
  width:44px;height:44px;
  overflow:visible;
}
/* Rotating dashed orbit */
.pc-ring-rotate{
  transform-origin:22px 22px;
  animation:pcRingRotate 12s linear infinite;
}
@keyframes pcRingRotate{
  from{transform:rotate(0deg);}
  to{transform:rotate(360deg);}
}
/* Pulsing concentric rings */
.pc-pulse{
  transform-origin:22px 22px;
  opacity:0;
  animation:pcPulseRing 2.6s ease-out infinite;
}
.pc-pulse-2{animation-delay:1.3s;}
@keyframes pcPulseRing{
  0%{transform:scale(.55);opacity:.9;}
  80%{transform:scale(1.4);opacity:0;}
  100%{transform:scale(1.4);opacity:0;}
}
/* Floating question mark */
.pc-q{
  transform-origin:22px 22px;
  animation:pcQFloat 3.2s ease-in-out infinite;
}
@keyframes pcQFloat{
  0%,100%{transform:translateY(0) scale(1);}
  50%{transform:translateY(-1px) scale(1.04);}
}
/* Twinkling sparkles */
.pc-spark{
  opacity:0;
  animation:pcSparkTwinkle 2.4s ease-in-out infinite;
  transform-origin:center;
}
.pc-spark-1{animation-delay:0s;transform-origin:5px 10.5px;}
.pc-spark-2{animation-delay:.8s;transform-origin:39px 6.5px;}
.pc-spark-3{animation-delay:1.6s;transform-origin:38px 36.5px;}
@keyframes pcSparkTwinkle{
  0%,40%{opacity:0;transform:scale(.3);}
  55%{opacity:1;transform:scale(1.3);}
  70%,100%{opacity:0;transform:scale(.3);}
}

.pillar-cta h3{
  font-family:var(--font-display);
  font-weight:500;
  font-size:clamp(1.3rem, 2.2vw, 1.7rem);
  line-height:1.2;
  margin:0 0 4px;
  font-variation-settings:"opsz" 144;
}
.pillar-cta p{
  margin:0;
  color:rgba(251,248,238,0.8);
  font-size:0.95rem;
  max-width:520px;
}
.pillar-cta .btn{position:relative;z-index:1;}
@media (max-width:720px){
  .pillar-cta{
    flex-direction:column;
    align-items:center;
    text-align:center;
    gap:22px;
    padding:36px 24px;
  }
  .pc-left{
    flex-direction:column;
    align-items:center;
    text-align:center;
    gap:18px;
    min-width:0;
  }
  .pc-glyph{width:64px;height:64px;}
  .pc-glyph-svg{width:48px;height:48px;}
  .pillar-cta h3{font-size:1.4rem;}
  .pillar-cta p{margin:0 auto;max-width:440px;}
  .pillar-cta .btn{width:100%;justify-content:center;}
}

/* ================================================
   ABOUT
   ================================================ */
.about{
  padding:80px 0 120px;
  background:linear-gradient(180deg, var(--cream), var(--sand));
}
.about-inner{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:80px;
  align-items:center;
}
.values{display:flex;flex-direction:column;gap:24px;}
.value{
  padding:28px 30px;
  background:var(--cream);
  border:1px solid var(--line);
  border-left:4px solid var(--teal);
  border-radius:var(--radius);
  transition:transform .3s ease;
}
.value:hover{transform:translateX(6px);}
.value h4{
  font-family:var(--font-display);
  font-weight:500;font-size:1.35rem;
  margin:0 0 8px;
  font-variation-settings:"opsz" 144;
}
.value p{margin:0;color:var(--ink-500);}
@media (max-width:960px){.about-inner{grid-template-columns:1fr;gap:50px;}}

/* ================================================
   CONTACT
   ================================================ */
.contact{padding:120px 0;background:var(--cream);}
.contact-inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
}
.contact-blocks{display:flex;flex-direction:column;gap:28px;margin-top:30px;}
.contact-blocks h4{
  font-family:var(--font-display);font-weight:500;font-size:1.2rem;
  margin:0 0 6px;font-variation-settings:"opsz" 144;
}
.contact-blocks a{color:var(--teal);font-weight:500;}
.contact-blocks p{margin:2px 0;color:var(--ink-500);font-size:0.93rem;}
.muted{color:var(--ink-500);opacity:0.7;font-size:0.85rem;}

.contact-form{
  padding:40px;
  background:var(--bone);
  border-radius:var(--radius-lg);
  display:flex;flex-direction:column;gap:16px;
}
.contact-form h3{
  font-family:var(--font-display);
  font-weight:500;font-size:1.8rem;
  margin:0;font-variation-settings:"opsz" 144;
}
.contact-form label{
  display:flex;flex-direction:column;gap:6px;
  font-size:0.85rem;font-weight:600;color:var(--ink-500);
  letter-spacing:0.04em;text-transform:uppercase;
}
.contact-form input,
.contact-form textarea{
  padding:14px 16px;
  border:1.5px solid var(--line);
  border-radius:12px;
  background:var(--cream);
  font-family:inherit;font-size:1rem;
  color:var(--ink);
  transition:border-color .2s ease;
  font-weight:400;
  text-transform:none;
  letter-spacing:normal;
}
.contact-form input:focus,
.contact-form textarea:focus{
  outline:none;border-color:var(--teal);
}
.contact-form textarea{resize:vertical;min-height:120px;font-family:inherit;}
.contact-form .btn{align-self:flex-start;}
.form-status{margin:0;font-size:0.88rem;color:var(--teal-600);font-weight:500;}

@media (max-width:860px){.contact-inner{grid-template-columns:1fr;gap:50px;}}

/* ================================================
   NEWSLETTER (IMPROVED)
   ================================================ */
.newsletter{
  padding:100px 0;
  background:var(--ink);
  color:var(--cream);
  position:relative;
  overflow:hidden;
}
.ns-bg{
  position:absolute;inset:0;pointer-events:none;z-index:0;
}
.ns-orb{
  position:absolute;
  top:-150px;right:-100px;
  width:500px;height:500px;
  background:radial-gradient(circle, rgba(11,42,74,0.35), transparent 60%);
  filter:blur(60px);
  animation:float 14s ease-in-out infinite;
}
.ns-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(11,42,74,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(11,42,74,0.06) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse at center, black 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse at center, black 30%, transparent 80%);
  opacity:0.5;
}
.newsletter-inner{
  position:relative;z-index:1;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
}
.ns-content h3{
  font-family:var(--font-display);
  font-weight:500;
  font-size:clamp(2rem, 3.5vw, 2.8rem);
  margin:14px 0 12px;
  line-height:1.05;
  letter-spacing:-0.02em;
  font-variation-settings:"opsz" 144;
}
.ns-content p{margin:0 0 24px;color:rgba(251,248,238,0.75);max-width:460px;}
.ns-perks{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:10px;
}
.ns-perks li{
  display:flex;align-items:center;gap:12px;
  font-size:0.95rem;color:rgba(251,248,238,0.85);
}
.ns-check{
  display:grid;place-items:center;
  width:22px;height:22px;border-radius:50%;
  background:rgba(11,42,74,0.2);color:var(--teal-100);
  font-weight:700;font-size:0.75rem;
  flex-shrink:0;
}

.ns-form{
  display:flex;flex-direction:column;gap:14px;
  padding:36px;
  background:rgba(251,248,238,0.05);
  border:1px solid rgba(251,248,238,0.1);
  border-radius:var(--radius-lg);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.ns-field{
  display:flex;
  gap:8px;
  padding:6px;
  background:var(--cream);
  border-radius:999px;
  align-items:center;
}
.ns-field input{
  flex:1;
  padding:12px 20px;
  border:none;background:transparent;
  font-family:inherit;font-size:0.95rem;color:var(--ink);
  outline:none;
}
.ns-field input::placeholder{color:rgba(4,22,44,0.5);}
.ns-field .btn{padding:12px 22px;white-space:nowrap;}

.ns-mini{
  margin:0;
  font-size:0.8rem;
  color:rgba(251,248,238,0.5);
}
.ns-mini a{color:var(--teal-100);text-decoration:underline;}
.ns-status{
  margin:0;
  color:var(--teal-400);
  font-size:0.9rem;
  font-weight:500;
}

@media (max-width:820px){
  .newsletter-inner{grid-template-columns:1fr;gap:40px;}
  .ns-field{flex-wrap:wrap;padding:10px;border-radius:var(--radius);}
  .ns-field input{min-width:100%;padding:10px 14px;}
  .ns-field .btn{width:100%;}
}

/* ================================================
   FOOTER (IMPROVED)
   ================================================ */
.footer{
  background:var(--ink);
  color:var(--cream);
  padding:80px 0 0;
  position:relative;
  border-top:1px solid rgba(251,248,238,0.08);
  overflow:hidden;
}
.footer-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 600px 300px at 10% 0%, rgba(11,42,74,0.15), transparent 60%),
    radial-gradient(ellipse 500px 250px at 90% 100%, rgba(11,42,74,0.1), transparent 60%);
  pointer-events:none;
}
.footer-inner{
  position:relative;
  display:grid;
  grid-template-columns:1.8fr 1fr 1fr 1fr;
  gap:60px;
  padding-bottom:50px;
  border-bottom:1px solid rgba(251,248,238,0.1);
}
.foot-brand .brand-mark{
  color:var(--coral);
  background:transparent;
  border:none;
}
.foot-brand .brand-name{color:var(--cream);}
.foot-brand .brand-sub{color:var(--coral);opacity:0.85;}
.foot-brand > p{
  margin:20px 0 24px;
  color:rgba(251,248,238,0.7);
  max-width:380px;
  line-height:1.6;
  font-size:0.95rem;
}
.socials{display:flex;gap:10px;margin-bottom:24px;}
.soc{
  width:40px;height:40px;
  display:grid;place-items:center;
  border-radius:50%;
  background:rgba(11,42,74,0.15);
  color:var(--teal-100);
  transition:background .2s ease, color .2s ease, transform .2s ease;
  border:1px solid rgba(11,42,74,0.2);
}
.soc:hover{background:var(--teal);color:var(--cream);transform:translateY(-2px);border-color:var(--teal);}
.soc svg{width:16px;height:16px;}

.foot-trust{
  display:flex;flex-wrap:wrap;gap:10px;
}
.trust-badge{
  padding:6px 14px;
  border-radius:999px;
  background:rgba(11,42,74,0.12);
  border:1px solid rgba(11,42,74,0.25);
  color:var(--teal-100);
  font-size:0.78rem;
  font-weight:500;
  letter-spacing:0.02em;
}

.foot-col{display:flex;flex-direction:column;gap:14px;}
.foot-col h4{
  font-size:0.78rem;
  font-weight:700;letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--teal-100);
  margin:0 0 8px;
}
.foot-col a{
  color:rgba(251,248,238,0.8);
  font-size:0.94rem;
  transition:color .2s ease, padding-left .2s ease;
}
.foot-col a:hover{color:var(--coral);padding-left:4px;}

.foot-bottom{
  position:relative;
  padding:26px 0 30px;
}
.foot-bottom-inner{
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:12px;
  font-size:0.85rem;
  color:rgba(251,248,238,0.65);
}
.foot-bottom p{margin:0;}
.foot-bottom .heart{color:var(--coral);animation:heartBeat 1.6s ease-in-out infinite;display:inline-block;transform-origin:50% 50%;}
.foot-bottom .muted{color:rgba(251,248,238,0.5);}
.foot-bottom .made-by{
  flex-basis:100%;
  text-align:center;
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid rgba(251,248,238,0.08);
  font-size:0.82rem;
  color:rgba(251,248,238,0.55);
  letter-spacing:0.01em;
}
.foot-bottom .made-by a{
  color:var(--coral);
  font-weight:600;
  position:relative;
  transition:color .2s ease;
}
.foot-bottom .made-by a::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:-2px;
  height:1px;
  background:var(--coral);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .3s ease;
}
.foot-bottom .made-by a:hover{color:var(--coral-600);}
.foot-bottom .made-by a:hover::after{transform:scaleX(1);}

@keyframes heartBeat{
  0%, 40%, 100% { transform:scale(1); }
  15% { transform:scale(1.25); }
  25% { transform:scale(1.1); }
}

@media (max-width:960px){
  .footer-inner{grid-template-columns:1fr 1fr;gap:40px 30px;}
  .foot-brand{grid-column:1 / -1;}
}
@media (max-width:560px){
  .footer-inner{grid-template-columns:1fr;}
  .foot-brand{grid-column:auto;}
}

/* ---------- TO-TOP ---------- */
.to-top{
  position:fixed;
  bottom:28px;right:28px;
  width:50px;height:50px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--teal), #c79438);
  color:var(--cream);
  font-size:1.3rem;font-weight:700;
  box-shadow:var(--shadow-lg);
  z-index:50;
  opacity:0;transform:translateY(20px);pointer-events:none;
  transition:all .3s ease;
}
.to-top.visible{opacity:1;transform:translateY(0);pointer-events:auto;}
.to-top:hover{transform:translateY(-4px);}

/* ---------- REVEAL ANIMATION ---------- */
[data-reveal]{
  opacity:0;
  transform:translateY(30px);
  transition:opacity .8s ease, transform .8s ease;
}
[data-reveal].in{
  opacity:1;transform:translateY(0);
}

/* ---------- REDUCED MOTION ---------- */
@media (prefers-reduced-motion: reduce){
  *,::before,::after{
    animation-duration:0.01ms!important;
    transition-duration:0.01ms!important;
  }
  [data-reveal]{opacity:1;transform:none;}
}

/* =========================================================
   LEGAL PAGES (shared styles)
   ========================================================= */
.legal-hero{
  padding:130px 0 60px;
  background:linear-gradient(135deg, var(--ink), var(--teal-600) 150%);
  color:var(--cream);
  position:relative;
  overflow:hidden;
}
.legal-hero::before{
  content:"";
  position:absolute;top:-120px;right:-80px;
  width:400px;height:400px;
  background:radial-gradient(circle, rgba(11,42,74,0.35), transparent 60%);
  filter:blur(60px);pointer-events:none;
}
.legal-hero .container{position:relative;}
.legal-hero a.back{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--teal-100);font-weight:500;font-size:0.9rem;
  margin-bottom:28px;
  transition:color .2s ease;
}
.legal-hero a.back:hover{color:var(--cream);}
.legal-hero h1{
  font-family:var(--font-display);
  font-weight:500;
  font-size:clamp(2.2rem, 4.5vw, 4rem);
  line-height:1.05;
  letter-spacing:-0.02em;
  margin:0 0 16px;
  font-variation-settings:"opsz" 144;
}
.legal-hero p.last-updated{
  color:rgba(251,248,238,0.7);
  font-size:0.9rem;
  margin:0;
}

.legal-body{
  padding:80px 0 120px;
  background:var(--cream);
}
.legal-body .container{max-width:820px;}
.legal-body h2{
  font-family:var(--font-display);
  font-weight:500;
  font-size:clamp(1.5rem, 2.6vw, 2rem);
  margin:50px 0 16px;
  color:var(--ink);
  font-variation-settings:"opsz" 144;
  letter-spacing:-0.01em;
}
.legal-body h2:first-child{margin-top:0;}
.legal-body h3{
  font-family:var(--font-display);
  font-weight:500;
  font-size:1.25rem;
  margin:30px 0 10px;
  color:var(--ink);
  font-variation-settings:"opsz" 144;
}
.legal-body p,
.legal-body li{
  color:var(--ink-500);
  font-size:1rem;
  line-height:1.7;
}
.legal-body p{margin:0 0 16px;}
.legal-body ul{padding-left:24px;margin:0 0 20px;}
.legal-body li{margin-bottom:8px;}
.legal-body strong{color:var(--ink);}
.legal-body a{color:var(--teal);text-decoration:underline;}
.legal-body a:hover{color:var(--ink);}
.legal-callout{
  padding:20px 24px;
  border-left:4px solid var(--teal);
  background:var(--teal-50);
  border-radius:0 var(--radius) var(--radius) 0;
  margin:24px 0;
}
.legal-callout p:last-child{margin-bottom:0;}

/* =========================================================
   KEEP 100 AGENTS — additional component styles
   ========================================================= */

/* ---------- Comparison pricing (2-column) ---------- */
.price-grid.compare-grid{
  grid-template-columns:repeat(2,1fr);
  max-width:900px;
  margin:0 auto;
}
.price-card.is-traditional{
  background:var(--bone);
  border-color:var(--line);
  position:relative;
}
.price-card.is-traditional h3,
.price-card.is-traditional .price-sub{opacity:0.78;}
.price-card.is-traditional .price .amount{color:var(--ink-500);}
.price-card.is-traditional .price-list li{color:var(--ink-500);}
.price-card.is-traditional .price-list li::before{
  border-left-color:#b96c6c;
  border-bottom-color:#b96c6c;
  width:12px;height:12px;
  border-bottom:none;
  border-left:none;
  top:9px;
  background:
    linear-gradient(45deg, transparent 45%, #b96c6c 45%, #b96c6c 55%, transparent 55%),
    linear-gradient(-45deg, transparent 45%, #b96c6c 45%, #b96c6c 55%, transparent 55%);
  transform:none;
}
.badge-pro{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  padding:6px 14px;
  background:var(--coral);color:var(--ink);
  border-radius:999px;font-size:0.75rem;font-weight:700;
  letter-spacing:0.08em;text-transform:uppercase;
  box-shadow:0 8px 24px -8px rgba(199,148,56,0.6);
}
.price-card.featured .badge-pro{background:var(--coral);color:var(--ink);}
@media (max-width:760px){
  .price-grid.compare-grid{grid-template-columns:1fr;max-width:440px;}
}

/* ---------- Locations perks as 2-col grid ---------- */
.ns-perks.locations-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px 24px;
}
.ns-perks.locations-grid li{
  font-size:0.95rem;
}

/* ---------- Contact CTA card (used inside newsletter-like block) ---------- */
.contact-cta-form{
  display:flex;flex-direction:column;gap:18px;
  padding:34px;
  background:rgba(251,248,238,0.05);
  border:1px solid rgba(251,248,238,0.12);
  border-radius:var(--radius-lg);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.contact-cta-form h4{
  font-family:var(--font-display);
  font-weight:500;
  font-size:1.4rem;
  margin:0;
  color:var(--cream);
  font-variation-settings:"opsz" 144;
  line-height:1.2;
}
.contact-cta-form p{margin:0;color:rgba(251,248,238,0.72);font-size:0.95rem;line-height:1.55;}
.contact-cta-row{display:flex;flex-direction:column;gap:12px;}
.contact-cta-row .btn{justify-content:center;width:100%;}
.contact-cta-line{
  display:flex;align-items:center;gap:12px;
  padding:14px 18px;
  background:rgba(11,42,74,0.4);
  border:1px solid rgba(199,148,56,0.3);
  border-radius:14px;
  color:var(--cream);
  font-family:var(--font-display);
  font-size:1.05rem;
  font-weight:500;
  letter-spacing:-0.01em;
  transition:border-color .2s ease, transform .2s ease;
}
.contact-cta-line:hover{border-color:var(--coral);transform:translateY(-2px);}
.contact-cta-line svg{flex-shrink:0;color:var(--coral);}
.contact-cta-line small{
  display:block;
  font-family:var(--font-body);
  font-size:0.72rem;font-weight:600;
  letter-spacing:0.14em;text-transform:uppercase;
  color:rgba(251,248,238,0.5);
  margin-bottom:2px;
}

/* ---------- Hero badges w/ checkmarks ---------- */
.pill.pill-check{padding-left:12px;}
.pill.pill-check .check{
  display:grid;place-items:center;
  width:16px;height:16px;border-radius:50%;
  background:var(--teal);color:var(--cream);
  font-size:0.62rem;font-weight:800;
  flex-shrink:0;
}

/* ---------- Phone icon styling for buttons ---------- */
.btn .btn-ico{
  width:16px;height:16px;
  display:inline-block;
  flex-shrink:0;
}

/* ================================================
   ANIMATED CALL & EMAIL BUTTONS
   — Ringing phone, bobbing envelope, shine sweep
   ================================================ */

/* Common: both call + email get relative positioning and a shine sweep */
a[href^="tel:"].btn,
a[href^="mailto:"].btn{
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
a[href^="tel:"].btn > *,
a[href^="mailto:"].btn > *{
  position:relative;
  z-index:1;
}
a[href^="tel:"].btn::after,
a[href^="mailto:"].btn::after{
  content:"";
  position:absolute;
  top:0;left:-75%;
  width:55%;height:100%;
  background:linear-gradient(110deg, transparent 0%, rgba(255,255,255,0.3) 50%, transparent 100%);
  transform:skewX(-18deg);
  transition:left .75s cubic-bezier(.4,.1,.25,1);
  pointer-events:none;
  z-index:0;
}
a[href^="tel:"].btn:hover::after,
a[href^="mailto:"].btn:hover::after{
  left:130%;
}

/* ---------- PHONE: continuous ring-pulse + wobble ---------- */
a[href^="tel:"].btn .btn-ico{
  transform-origin:50% 50%;
  animation:phonePulse 1.4s ease-in-out infinite;
  filter:drop-shadow(0 0 0 transparent);
  will-change:transform, filter;
}
a[href^="tel:"].btn:hover .btn-ico{
  animation:phonePulseFast 0.7s ease-in-out infinite;
}

@keyframes phonePulse{
  0%, 100% { transform:scale(1) rotate(0deg);    filter:drop-shadow(0 0 0 rgba(199,148,56,0)); }
  20%      { transform:scale(1.1) rotate(-10deg); filter:drop-shadow(0 0 3px rgba(199,148,56,0.55)); }
  40%      { transform:scale(1.12) rotate(0deg);  filter:drop-shadow(0 0 6px rgba(199,148,56,0.7)); }
  60%      { transform:scale(1.1) rotate(10deg);  filter:drop-shadow(0 0 3px rgba(199,148,56,0.55)); }
  80%      { transform:scale(1.05) rotate(0deg);  filter:drop-shadow(0 0 1px rgba(199,148,56,0.2)); }
}

@keyframes phonePulseFast{
  0%, 100% { transform:scale(1) rotate(0deg);     filter:drop-shadow(0 0 0 rgba(199,148,56,0)); }
  25%      { transform:scale(1.22) rotate(-16deg); filter:drop-shadow(0 0 6px rgba(199,148,56,0.85)); }
  50%      { transform:scale(1.28) rotate(0deg);   filter:drop-shadow(0 0 10px rgba(199,148,56,0.95)); }
  75%      { transform:scale(1.22) rotate(16deg);  filter:drop-shadow(0 0 6px rgba(199,148,56,0.85)); }
}

/* ---------- EMAIL: continuous float-pulse + wiggle on hover ---------- */
a[href^="mailto:"].btn .btn-ico{
  transform-origin:50% 55%;
  animation:envelopePulse 1.6s ease-in-out infinite;
  filter:drop-shadow(0 0 0 transparent);
  will-change:transform, filter;
}
a[href^="mailto:"].btn:hover .btn-ico{
  animation:envelopeWiggle 0.7s ease-in-out infinite;
}

@keyframes envelopePulse{
  0%, 100% { transform:translateY(0) scale(1);          filter:drop-shadow(0 0 0 rgba(199,148,56,0)); }
  30%      { transform:translateY(-2px) scale(1.08);    filter:drop-shadow(0 0 3px rgba(199,148,56,0.45)); }
  50%      { transform:translateY(-3px) scale(1.12);    filter:drop-shadow(0 0 6px rgba(199,148,56,0.7)); }
  70%      { transform:translateY(-2px) scale(1.08);    filter:drop-shadow(0 0 3px rgba(199,148,56,0.45)); }
}

@keyframes envelopeWiggle{
  0%, 100% { transform:translateY(0) rotate(0) scale(1.1);      filter:drop-shadow(0 0 4px rgba(199,148,56,0.7)); }
  25%      { transform:translate(2px,-4px) rotate(-14deg) scale(1.2); filter:drop-shadow(0 0 8px rgba(199,148,56,0.9)); }
  75%      { transform:translate(-2px,-4px) rotate(12deg) scale(1.2); filter:drop-shadow(0 0 8px rgba(199,148,56,0.9)); }
}

/* ---------- contact-cta-line icons also animated ---------- */
.contact-cta-line[href^="tel:"] svg{
  animation:phonePulse 1.4s ease-in-out infinite;
  transform-origin:50% 50%;
}
.contact-cta-line[href^="tel:"]:hover svg{
  animation:phonePulseFast 0.7s ease-in-out infinite;
}
.contact-cta-line[href^="mailto:"] svg{
  animation:envelopePulse 1.6s ease-in-out infinite;
  transform-origin:50% 55%;
}
.contact-cta-line[href^="mailto:"]:hover svg{
  animation:envelopeWiggle 0.7s ease-in-out infinite;
}

/* Respect users who prefer less motion */
@media (prefers-reduced-motion: reduce){
  a[href^="tel:"].btn .btn-ico,
  a[href^="mailto:"].btn .btn-ico,
  .contact-cta-line[href^="tel:"] svg,
  .contact-cta-line[href^="mailto:"] svg{
    animation:none !important;
  }
  a[href^="tel:"].btn:hover,
  a[href^="mailto:"].btn:hover{
    animation:none !important;
  }
  a[href^="tel:"].btn::after,
  a[href^="mailto:"].btn::after{
    display:none;
  }
}

/* ---------- "Or call us" small inline text ---------- */
.or-call{
  margin:18px auto 0;
  font-size:0.92rem;
  color:var(--ink-500);
  text-align:center;
}
.or-call a{color:var(--teal);font-weight:600;}
.or-call.light{color:rgba(251,248,238,0.7);}
.or-call.light a{color:var(--coral);}

/* ---------- QB-card field styles (application form mock) ---------- */
.qb-field-label{
  display:block;
  font-size:0.7rem;
  font-weight:700;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-500);
  margin:14px 0 6px;
}
.qb-field-label:first-of-type{margin-top:0;}

/* ---------- Small tweaks ---------- */
.hero-title .accent{color:var(--coral);}
.accent-text{color:var(--coral);}

/* ensure to-top uses only brand colors */
.to-top{
  background:linear-gradient(135deg, var(--ink), var(--teal));
}

/* Billed-toggle tweak for comparison */
.billing-toggle.compare-toggle .bt-btn.is-active{
  background:var(--teal);color:var(--cream);
}

/* ---------- Location/cities mini grid (SEO-friendly) ---------- */
.cities-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(140px, 1fr));
  gap:10px;
  margin-top:24px;
}
.city-chip{
  padding:14px 16px;
  background:rgba(251,248,238,0.05);
  border:1px solid rgba(251,248,238,0.12);
  border-radius:12px;
  color:var(--cream);
  font-weight:600;
  font-size:0.92rem;
  display:flex;
  align-items:center;
  gap:10px;
  transition:border-color .2s ease, transform .2s ease, background .2s ease;
}
.city-chip:hover{
  border-color:var(--coral);
  transform:translateY(-2px);
  background:rgba(199,148,56,0.08);
}
.city-chip .pin{
  width:8px;height:8px;border-radius:50%;
  background:var(--coral);
  box-shadow:0 0 0 3px rgba(199,148,56,0.25);
  flex-shrink:0;
}

/* ---------- Requirement checklist (about section) ---------- */
.value .value-num{
  font-family:var(--font-display);
  font-style:italic;
  font-size:0.95rem;
  color:var(--teal);
  font-weight:500;
  margin-right:10px;
  font-variation-settings:"opsz" 144;
}

/* ---------- Trust strip under hero CTAs ---------- */
.trust-strip{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:6px 18px;
  margin:22px 0 46px;
  font-size:0.82rem;
  color:var(--ink-500);
  font-weight:500;
}
.trust-strip .ts-dot{
  width:4px;height:4px;border-radius:50%;
  background:var(--coral);
  opacity:0.6;
}

/* ---------- Force social colors to navy + gold ---------- */
.orb-b{
  background:radial-gradient(circle at 60% 60%, #e0ba78, transparent 70%);
}

/* ================================================

/* ================================================
   CITY LANDING PAGES — v2
   ================================================ */

/* ---------- Nav tweaks: make Apply Now fit better in nav ---------- */
.nav-inner .btn.nav-btn{
  padding:10px 20px;
  font-size:0.88rem;
  box-shadow:0 4px 14px -5px rgba(199,148,56,0.45);
}
.nav-inner .btn.nav-btn:hover{
  box-shadow:0 6px 20px -6px rgba(199,148,56,0.7);
}

/* ---------- City hero ---------- */
.city-hero{
  position:relative;
  padding:100px 0 80px;
  overflow:hidden;
  isolation:isolate;
}
.city-hero .container{text-align:center;position:relative;z-index:1;}

.city-badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:9px 20px;
  background:rgba(11,42,74,0.05);
  border:1px solid rgba(11,42,74,0.12);
  border-radius:999px;
  font-size:0.86rem;color:var(--ink);font-weight:500;
  letter-spacing:0.005em;
  margin-bottom:30px;
}
.city-badge strong{font-weight:700;color:var(--ink);}
.city-pin{
  display:inline-block;width:9px;height:9px;border-radius:50%;
  background:var(--coral);
  box-shadow:0 0 0 4px rgba(199,148,56,0.2);
  animation:cityPinPulse 2s ease-in-out infinite;
}
@keyframes cityPinPulse{
  0%,100%{box-shadow:0 0 0 4px rgba(199,148,56,0.2);}
  50%{box-shadow:0 0 0 8px rgba(199,148,56,0.08);}
}

.city-hero-title{max-width:920px;margin-left:auto;margin-right:auto;}

.city-hero-stats{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:40px 60px;
  margin-top:58px;
  padding:32px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.city-hero-stats div{display:flex;flex-direction:column;gap:4px;align-items:center;}
.city-hero-stats strong{
  font-family:var(--font-display);
  font-size:clamp(2rem, 3vw, 2.6rem);
  font-weight:500;color:var(--coral);
  font-variation-settings:"opsz" 144;line-height:1;
}
.city-hero-stats span{
  font-size:0.85rem;color:var(--ink-500);
  max-width:180px;text-align:center;
}

/* ---------- Why {city} — centered, with animated glass icons ---------- */
.city-why{
  padding:110px 0 90px;
  background:linear-gradient(180deg, var(--cream), var(--bone));
  text-align:center;
}
.city-why .container{text-align:center;}
.city-why .section-lede{margin-left:auto;margin-right:auto;max-width:620px;text-align:center;}

.city-why-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
  margin-top:56px;
}
.city-why-card{
  padding:38px 30px 34px;
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  text-align:left;
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
  position:relative;
}
.city-why-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg);
  border-color:var(--coral);
}
.city-why-card .pillar-ico{margin-bottom:22px;}
.city-why-card h3{
  font-family:var(--font-display);
  font-size:1.38rem;font-weight:500;
  color:var(--ink);
  margin:0 0 10px;line-height:1.2;
  font-variation-settings:"opsz" 144;
}
.city-why-card p{
  margin:0;font-size:0.94rem;line-height:1.6;
  color:var(--ink-500);
}
@media(max-width:900px){.city-why-grid{grid-template-columns:1fr;max-width:520px;margin-left:auto;margin-right:auto;}}

/* ---------- Market snapshot — centered, premium ---------- */
.market-snapshot{
  padding:110px 0;
  background:var(--ink);
  color:var(--cream);
  position:relative;overflow:hidden;
}
.market-snapshot::before{
  content:"";
  position:absolute;top:-250px;right:-150px;
  width:600px;height:600px;
  background:radial-gradient(circle, rgba(199,148,56,0.14), transparent 60%);
  filter:blur(70px);pointer-events:none;
}
.market-snapshot::after{
  content:"";
  position:absolute;bottom:-200px;left:-100px;
  width:420px;height:420px;
  background:radial-gradient(circle, rgba(199,148,56,0.08), transparent 60%);
  filter:blur(60px);pointer-events:none;
}
.market-snapshot .container{position:relative;z-index:1;text-align:center;}
.ms-head{text-align:center;margin-bottom:48px;}
.ms-head .section-lede{margin-left:auto;margin-right:auto;}

/* Stat cards row */
.ms-stats{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:14px;
  margin-bottom:56px;
  text-align:left;
}
.ms-stat{
  padding:26px 24px;
  background:rgba(251,248,238,0.04);
  border:1px solid rgba(251,248,238,0.1);
  border-radius:var(--radius-lg);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  transition:border-color .3s ease, transform .3s ease;
}
.ms-stat:hover{border-color:rgba(199,148,56,0.5);transform:translateY(-3px);}
.ms-stat-featured{
  background:rgba(199,148,56,0.08);
  border-color:rgba(199,148,56,0.4);
}
.ms-stat-val{
  display:block;
  font-family:var(--font-display);
  font-size:clamp(1.6rem, 2.4vw, 2.1rem);
  font-weight:500;
  color:var(--cream);
  line-height:1;
  margin-bottom:8px;
  font-variation-settings:"opsz" 144;
}
.ms-stat-gold{color:var(--coral);}
.ms-stat-lbl{
  display:block;
  font-size:0.72rem;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:rgba(251,248,238,0.6);
  font-weight:600;
}
@media(max-width:820px){.ms-stats{grid-template-columns:repeat(2, 1fr);}}
@media(max-width:440px){.ms-stats{grid-template-columns:1fr;}}

/* Market prose + nearby */
.ms-body{
  max-width:780px;margin:0 auto;
  text-align:center;
}
.ms-prose{
  font-size:1.08rem;line-height:1.78;
  color:rgba(251,248,238,0.88);
  margin:0 0 42px;
  text-align:left;
}
.ms-nearby{margin-bottom:42px;}
.ms-nearby h4{
  font-size:0.72rem;font-weight:700;
  letter-spacing:0.22em;text-transform:uppercase;
  color:var(--coral);
  margin:0 0 16px;
  text-align:center;
}
.ms-nearby .nearby-chips{
  display:flex;flex-wrap:wrap;gap:8px;
  justify-content:center;
}
.nearby-chip{
  padding:9px 18px;
  background:rgba(251,248,238,0.06);
  border:1px solid rgba(251,248,238,0.14);
  border-radius:999px;
  font-size:0.88rem;font-weight:500;
  color:rgba(251,248,238,0.9);
  transition:border-color .2s ease, background .2s ease;
}
.nearby-chip:hover{border-color:var(--coral);background:rgba(199,148,56,0.1);}
.ms-apply{margin-top:10px;}

/* ---------- How it works — centered, with animated glass icons ---------- */
.city-how{
  padding:110px 0;
  background:var(--cream);
  text-align:center;
}
.city-how .container{text-align:center;}
.city-how .section-lede{margin-left:auto;margin-right:auto;max-width:620px;text-align:center;}
.city-how-steps{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:20px;
  margin-top:56px;
  text-align:left;
}
.city-how-step{
  padding:32px 26px;
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  transition:border-color .3s ease, transform .3s ease, box-shadow .3s ease;
  position:relative;
}
.city-how-step:hover{
  transform:translateY(-4px);
  border-color:var(--coral);
  box-shadow:0 12px 32px -14px rgba(11,42,74,0.22);
}
.city-how-step .pillar-ico{margin-bottom:20px;}
.city-how-num{
  display:inline-block;
  font-family:var(--font-display);
  font-size:0.95rem;font-weight:500;
  color:var(--coral);
  font-style:italic;
  line-height:1;
  margin-bottom:8px;
  letter-spacing:0.02em;
  font-variation-settings:"opsz" 144;
}
.city-how-step h3{
  font-family:var(--font-display);
  font-size:1.2rem;font-weight:500;
  margin:0 0 8px;
  color:var(--ink);
  font-variation-settings:"opsz" 144;
}
.city-how-step p{margin:0;font-size:0.9rem;line-height:1.55;color:var(--ink-500);}
@media(max-width:960px){.city-how-steps{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.city-how-steps{grid-template-columns:1fr;}}

/* ---------- Testimonial carousel ---------- */
.city-quote{
  padding:110px 0;
  background:linear-gradient(180deg, var(--cream), var(--bone));
  text-align:center;
}
.city-quote .container{text-align:center;}

.t-carousel{
  max-width:760px;
  margin:52px auto 0;
  position:relative;
}
.t-viewport{
  overflow:hidden;
  border-radius:var(--radius-lg);
}
.t-track{
  display:flex;
  transition:transform .6s cubic-bezier(.4,.2,.2,1);
  will-change:transform;
}
.t-slide{
  flex:0 0 100%;
  padding:56px 48px;
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  text-align:center;
  margin:0;
  box-sizing:border-box;
}
.t-quote-mark{
  width:38px;height:38px;
  color:var(--coral);
  margin-bottom:14px;
}
.t-slide blockquote{
  font-family:var(--font-display);
  font-size:clamp(1.15rem, 1.9vw, 1.5rem);
  font-weight:400;font-style:italic;
  color:var(--ink);
  line-height:1.4;
  margin:0 0 28px;
  font-variation-settings:"opsz" 144;
}
.t-slide figcaption{
  display:flex;flex-direction:column;gap:3px;
}
.t-slide figcaption strong{
  font-family:var(--font-display);
  font-size:1rem;font-weight:500;
  color:var(--ink);
  font-variation-settings:"opsz" 144;
}
.t-slide figcaption span{
  font-size:0.78rem;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--coral);font-weight:600;
}

.t-controls{
  display:flex;justify-content:center;align-items:center;gap:18px;
  margin-top:26px;
}
.t-nav{
  width:40px;height:40px;border-radius:50%;
  background:var(--cream);
  border:1px solid var(--line);
  color:var(--ink);
  display:grid;place-items:center;
  cursor:pointer;
  transition:all .2s ease;
}
.t-nav:hover{
  border-color:var(--coral);
  background:var(--coral);
  color:var(--cream);
  transform:scale(1.08);
}
.t-dots{display:flex;gap:8px;}
.t-dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(11,42,74,0.2);
  border:none;cursor:pointer;padding:0;
  transition:all .3s ease;
}
.t-dot.active{
  background:var(--coral);
  width:24px;border-radius:999px;
}

@media(max-width:600px){
  .t-slide{padding:40px 26px;}
}

/* ---------- Final CTA with animated illustration ---------- */
.city-cta{
  padding:110px 0;
  background:var(--ink);
  color:var(--cream);
  position:relative;overflow:hidden;
}
.city-cta::before{
  content:"";
  position:absolute;bottom:-200px;left:-100px;
  width:500px;height:500px;
  background:radial-gradient(circle, rgba(199,148,56,0.16), transparent 60%);
  filter:blur(60px);pointer-events:none;
}
.city-cta::after{
  content:"";
  position:absolute;top:-150px;right:-150px;
  width:400px;height:400px;
  background:radial-gradient(circle, rgba(199,148,56,0.08), transparent 60%);
  filter:blur(60px);pointer-events:none;
}
.city-cta-inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.1fr 1fr;
  gap:60px;align-items:center;
}
.city-cta-copy .section-lede.light{margin-bottom:32px;max-width:520px;}
.city-cta-buttons{display:flex;gap:12px;flex-wrap:wrap;}

/* Illustration on the right */
.city-cta-art{
  position:relative;
  height:420px;
  min-width:380px;
}

/* Main deal confirmation card */
.art-card{
  position:absolute;
  background:rgba(251,248,238,0.06);
  border:1px solid rgba(251,248,238,0.14);
  border-radius:18px;
  padding:22px 24px;
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  box-shadow:0 24px 60px -12px rgba(0,0,0,0.5);
}
.art-card-main{
  top:40px;left:30px;right:30px;
  min-height:240px;
  background:linear-gradient(135deg, rgba(251,248,238,0.12), rgba(251,248,238,0.04));
  border:1px solid rgba(199,148,56,0.35);
  animation:artFloat 5s ease-in-out infinite;
}
.art-card-behind{
  top:280px;right:0;
  width:240px;
  background:linear-gradient(135deg, rgba(199,148,56,0.15), rgba(199,148,56,0.04));
  border:1px solid rgba(199,148,56,0.28);
  animation:artFloat 5s ease-in-out infinite;
  animation-delay:-2s;
}
@keyframes artFloat{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-10px);}
}

.art-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;}
.art-status{
  display:inline-flex;align-items:center;gap:6px;
  font-size:0.7rem;letter-spacing:0.14em;text-transform:uppercase;
  color:rgba(251,248,238,0.85);font-weight:600;
}
.art-status-dot{
  width:7px;height:7px;border-radius:50%;
  background:#4ade80;
  box-shadow:0 0 0 3px rgba(74,222,128,0.25);
  animation:artStatusPulse 1.6s ease-in-out infinite;
}
@keyframes artStatusPulse{
  0%,100%{box-shadow:0 0 0 3px rgba(74,222,128,0.25);}
  50%{box-shadow:0 0 0 6px rgba(74,222,128,0.1);}
}
.art-chip{
  font-size:0.68rem;letter-spacing:0.12em;text-transform:uppercase;
  padding:3px 10px;
  background:rgba(199,148,56,0.16);
  color:var(--coral);
  border-radius:999px;
  font-weight:700;
}
.art-addr{
  font-size:0.78rem;color:rgba(251,248,238,0.6);
  margin-bottom:10px;
}
.art-amount-row{
  display:flex;align-items:baseline;gap:4px;
  margin-bottom:6px;
  font-family:var(--font-display);
  color:var(--coral);
}
.art-currency{
  font-size:1.3rem;font-weight:500;
  opacity:0.8;
}
.art-amount{
  font-size:2.4rem;font-weight:500;
  letter-spacing:-0.02em;line-height:1;
  font-variation-settings:"opsz" 144;
  animation:artAmountGlow 3s ease-in-out infinite;
}
@keyframes artAmountGlow{
  0%,100%{filter:drop-shadow(0 0 0 rgba(199,148,56,0));}
  50%{filter:drop-shadow(0 0 8px rgba(199,148,56,0.5));}
}
.art-label{
  display:block;
  font-size:0.78rem;color:rgba(251,248,238,0.7);
  margin-bottom:18px;
}
.art-bar{
  height:6px;
  background:rgba(251,248,238,0.1);
  border-radius:3px;
  overflow:hidden;
  margin-bottom:10px;
}
.art-bar-fill{
  height:100%;
  background:linear-gradient(90deg, var(--coral), #e0ba78);
  border-radius:3px;
  width:0%;
  animation:artBarFill 3.6s cubic-bezier(.4,.2,.2,1) infinite;
}
@keyframes artBarFill{
  0%{width:65%;}
  30%,75%{width:100%;}
  100%{width:65%;}
}
.art-bar-labels{
  display:flex;justify-content:space-between;
  font-size:0.7rem;color:rgba(251,248,238,0.5);
  font-weight:500;
}
.art-bar-now{color:var(--coral);font-weight:700;}

.art-mini-label{
  display:block;
  font-size:0.66rem;letter-spacing:0.16em;text-transform:uppercase;
  color:rgba(251,248,238,0.7);font-weight:600;
  margin-bottom:6px;
}
.art-mini-value{
  display:block;
  font-family:var(--font-display);
  font-size:1.05rem;font-weight:500;
  color:var(--cream);
  line-height:1.2;
  font-variation-settings:"opsz" 144;
}
.art-mini-meta{
  display:block;
  font-size:0.72rem;color:var(--coral);
  margin-top:6px;font-weight:600;
}

/* Floating decorative orbs */
.art-floater{
  position:absolute;border-radius:50%;
  background:var(--coral);
  opacity:0.5;
  pointer-events:none;
  animation:artFloaterMove 8s ease-in-out infinite;
}
.art-floater-1{width:6px;height:6px;top:10px;left:80px;animation-delay:0s;}
.art-floater-2{width:4px;height:4px;top:50%;right:20px;animation-delay:-2s;opacity:0.35;}
.art-floater-3{width:8px;height:8px;bottom:40px;left:15%;animation-delay:-4s;opacity:0.4;}
.art-floater-4{width:5px;height:5px;top:30%;left:-5px;animation-delay:-6s;opacity:0.45;}
@keyframes artFloaterMove{
  0%,100%{transform:translate(0,0) scale(1);opacity:0.3;}
  33%{transform:translate(15px,-20px) scale(1.3);opacity:0.6;}
  66%{transform:translate(-10px,10px) scale(0.8);opacity:0.5;}
}

@media(max-width:980px){
  .city-cta-inner{grid-template-columns:1fr;gap:60px;}
  .city-cta-art{margin:0 auto;max-width:440px;min-width:0;width:100%;}
}
@media(max-width:480px){
  .city-cta-art{height:380px;}
  .art-card-main{left:10px;right:10px;padding:18px 20px;}
  .art-card-behind{right:10px;width:200px;}
}

/* ---------- Other cities ---------- */
.other-cities{
  padding:110px 0;
  background:var(--cream);
  text-align:center;
}
.other-cities .container{text-align:center;}
.other-cities .section-lede{margin-left:auto;margin-right:auto;max-width:640px;text-align:center;}
.other-cities-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
  margin-top:52px;
  text-align:left;
}
.other-city-card{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 24px;
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:var(--radius);
  transition:transform .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.other-city-card:hover{
  transform:translateY(-3px);
  border-color:var(--coral);
  box-shadow:0 10px 28px -12px rgba(11,42,74,0.25);
}
.other-city-name{
  display:block;
  font-family:var(--font-display);
  font-size:1.2rem;font-weight:500;
  color:var(--ink);line-height:1;
  font-variation-settings:"opsz" 144;
}
.other-city-county{
  display:block;
  font-size:0.72rem;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--ink-500);font-weight:600;margin-top:4px;
}
.other-city-arrow{
  font-size:1.1rem;color:var(--coral);font-weight:600;
  transition:transform .3s ease;
}
.other-city-card:hover .other-city-arrow{transform:translateX(4px);}
@media(max-width:820px){.other-cities-grid{grid-template-columns:repeat(2,1fr);}}

/* ================================================
   CITY-PAGE CONTEXT-SPECIFIC ICONS (v2 — bolder, reliable)
   Uses SVG-unit transform-origin to avoid Safari transform-box bugs
   ================================================ */

/* -- 1. Apply online: document lines fill in sequentially -- */
.pillar-ico.city-ico-apply .city-line{
  stroke-dasharray:12;
  stroke-dashoffset:12;
  animation:cityLineFill 2.6s ease-in-out infinite;
}
.pillar-ico.city-ico-apply .city-line-2{animation-delay:.3s;}
.pillar-ico.city-ico-apply .city-line-3{animation-delay:.6s;stroke:var(--coral);}
@keyframes cityLineFill{
  0%, 8%   { stroke-dashoffset:12; }
  40%, 80% { stroke-dashoffset:0; }
  92%, 100%{ stroke-dashoffset:12; }
}

/* -- 2. Discovery call: phone ringing + expanding signal waves -- */
.pillar-ico.city-ico-call .city-phone{
  transform-origin:16px 22px;
  animation:cityPhoneRing 2.4s ease-in-out infinite;
}
@keyframes cityPhoneRing{
  0%, 65%, 100% { transform:rotate(0); }
  72% { transform:rotate(-16deg); }
  79% { transform:rotate(14deg); }
  86% { transform:rotate(-10deg); }
  93% { transform:rotate(5deg); }
}
.pillar-ico.city-ico-call .city-call-ring{
  stroke:var(--coral);
  animation:cityRingWave 1.8s ease-out infinite;
  opacity:0;
}
.pillar-ico.city-ico-call .city-call-ring-1{animation-delay:0s;}
.pillar-ico.city-ico-call .city-call-ring-2{animation-delay:.6s;}
@keyframes cityRingWave{
  0%   { opacity:0; }
  30%  { opacity:0.9; }
  70%  { opacity:0.5; }
  100% { opacity:0; }
}

/* -- 3. Rocket: floats + flame flicker + smoke rise -- */
.pillar-ico.city-ico-launch .city-rocket{
  animation:cityRocketFloat 2.4s ease-in-out infinite;
}
@keyframes cityRocketFloat{
  0%, 100% { transform:translateY(0); }
  50%      { transform:translateY(-2.5px); }
}
.pillar-ico.city-ico-launch .city-rocket-window{
  fill:var(--coral);
}
.pillar-ico.city-ico-launch .city-flame{
  transform-origin:20px 25px;
  fill:var(--coral);
  animation:cityFlameFlicker 0.35s ease-in-out infinite;
}
@keyframes cityFlameFlicker{
  0%, 100% { transform:scaleY(1) scaleX(1);    opacity:1; }
  50%      { transform:scaleY(1.25) scaleX(0.82); opacity:0.85; }
}
.pillar-ico.city-ico-launch .city-smoke{
  animation:citySmokeRise 1.6s ease-out infinite;
}
.pillar-ico.city-ico-launch .city-smoke-2{animation-delay:.8s;}
@keyframes citySmokeRise{
  0%   { transform:translateY(0) scale(0.7); opacity:0.5; }
  100% { transform:translateY(4px) scale(1.6); opacity:0; }
}

/* -- 4. Pound coin: dashed ring rotates, £ pulses gold -- */
.pillar-ico.city-ico-coin .city-coin-dash{
  transform-origin:20px 20px;
  animation:cityCoinSpin 14s linear infinite;
}
@keyframes cityCoinSpin{
  0%   { transform:rotate(0); }
  100% { transform:rotate(360deg); }
}
.pillar-ico.city-ico-coin .city-pound-sym{
  transform-origin:20px 20px;
  animation:cityPoundPulse 2s ease-in-out infinite;
}
.pillar-ico.city-ico-coin .city-pound-sym path{stroke:var(--coral);}
@keyframes cityPoundPulse{
  0%, 100% { transform:scale(1);    filter:drop-shadow(0 0 0 rgba(199,148,56,0)); }
  50%      { transform:scale(1.08); filter:drop-shadow(0 0 6px rgba(199,148,56,0.75)); }
}

/* -- 5. House with £ (Why card 1) — house breathes, £ pulses gold -- */
.pillar-ico.city-ico-house .city-house{
  transform-origin:20px 33px;
  animation:cityHouseBreathe 3s ease-in-out infinite;
}
@keyframes cityHouseBreathe{
  0%, 100% { transform:translateY(0) scale(1); }
  50%      { transform:translateY(-1px) scale(1.02); }
}
.pillar-ico.city-ico-house .city-house-pound{
  transform-origin:19px 25px;
  animation:cityPoundPulse 2.2s ease-in-out infinite;
}
.pillar-ico.city-ico-house .city-house-pound path{stroke:var(--coral);}

/* -- 6. Network (Why card 2) — outer nodes pulse in sequence, center glows gold -- */
.pillar-ico.city-ico-network .city-net-node{
  animation:cityNetNode 2.4s ease-in-out infinite;
}
.pillar-ico.city-ico-network .city-net-node-1{transform-origin:10px 10px; animation-delay:0s;}
.pillar-ico.city-ico-network .city-net-node-2{transform-origin:30px 10px; animation-delay:.3s;}
.pillar-ico.city-ico-network .city-net-node-3{transform-origin:10px 30px; animation-delay:.6s;}
.pillar-ico.city-ico-network .city-net-node-4{transform-origin:30px 30px; animation-delay:.9s;}
@keyframes cityNetNode{
  0%, 100% { transform:scale(1);   opacity:.85; }
  50%      { transform:scale(1.35); opacity:1;   }
}
.pillar-ico.city-ico-network .city-net-center{
  fill:var(--coral);
  transform-origin:20px 20px;
  animation:cityNetCenter 2.4s ease-in-out infinite;
}
@keyframes cityNetCenter{
  0%, 100% { transform:scale(1);    filter:drop-shadow(0 0 0 rgba(199,148,56,0)); }
  50%      { transform:scale(1.2);  filter:drop-shadow(0 0 7px rgba(199,148,56,0.85)); }
}
.pillar-ico.city-ico-network .city-net-lines{
  stroke-dasharray:4 3;
  animation:cityNetFlow 2.4s linear infinite;
}
@keyframes cityNetFlow{
  0%   { stroke-dashoffset:0; }
  100% { stroke-dashoffset:-14; }
}

/* -- 7. Map pins (Why card 3) — main gold pin bounces + glows, side pins bob gently -- */
.pillar-ico.city-ico-pins .city-pin-main{
  transform-origin:20px 28px;
  animation:cityPinMain 2.2s ease-in-out infinite;
}
.pillar-ico.city-ico-pins .city-pin-main circle:first-of-type,
.pillar-ico.city-ico-pins .city-pin-main path{
  fill:var(--coral);
}
@keyframes cityPinMain{
  0%, 100% { transform:translateY(0)    scale(1);    filter:drop-shadow(0 0 0 rgba(199,148,56,0)); }
  50%      { transform:translateY(-3px) scale(1.08); filter:drop-shadow(0 0 6px rgba(199,148,56,0.75)); }
}
.pillar-ico.city-ico-pins .city-pin-left{
  animation:cityPinSide 2.2s ease-in-out infinite;
  animation-delay:.25s;
}
.pillar-ico.city-ico-pins .city-pin-right{
  animation:cityPinSide 2.2s ease-in-out infinite;
  animation-delay:.5s;
}
@keyframes cityPinSide{
  0%, 100% { transform:translateY(0); }
  50%      { transform:translateY(-2px); }
}
.pillar-ico.city-ico-pins .city-pins-ground{
  animation:cityPinsGround 2.2s ease-in-out infinite;
}
@keyframes cityPinsGround{
  0%, 100% { opacity:0.2; }
  50%      { opacity:0.45; }
}
