/* ============================================================
   COZII HOUSING — Shared Stylesheet (V2.1 mobile-first)
   Espresso/cream/gold palette · Cormorant + DM Sans

   Breakpoint cascade (mobile-first):
   - Base:     0-599px   (phones, default)
   - sm:       ≥600px    (large phones / small tablets)
   - md:       ≥768px    (tablets)
   - lg:       ≥1024px   (small desktops)
   - xl:       ≥1180px   (large desktops)
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  color-scheme: light only;
  --cream:        #F5EFE6;
  --cream-warm:   #EDE5D8;
  --bone:         #FDFAF6;
  --white:        #FDFAF6;
  --bone2:        #EDE5D8;
  --bone3:        #E2D8CB;
  --bone4:        #D6C8B5;

  --espresso:     #2C1810;
  --espresso2:    #3D2416;
  --espresso3:    #1A0E07;

  --gold:         #C1763A;
  --gold2:        #E8A878;
  --gold-dim:     rgba(193,118,58,0.10);
  --gold-border:  rgba(193,118,58,0.28);
  --gold-glow:    rgba(232,168,120,0.18);

  --terra:        #B85838;
  --sage:         #7A8870;

  --text:         #2C1810;
  --text-soft:    #3D2416;
  --text-dim:     #7A6558;
  --text-muted:   #A89A8A;

  --border:       rgba(44,24,16,0.12);
  --border2:      rgba(44,24,16,0.18);

  --serif:        'Cormorant Garamond', Georgia, serif;
  --sans:         'DM Sans', -apple-system, sans-serif;

  /* Mobile-first spacing scale (used in section padding, etc.) */
  --pad-x:        16px;     /* horizontal section padding on mobile */
  --pad-y:        64px;     /* vertical section padding on mobile */
}

html{
  scroll-behavior:smooth;
  background:#F5EFE6;
  color-scheme:light only;
  -webkit-text-size-adjust:100%; /* prevent iOS font size adjustment */
}
body{
  background:#F5EFE6 !important;
  color:var(--text);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  color-scheme:light only;
  min-width:320px;
}
::selection{background:var(--espresso);color:var(--bone)}
img{max-width:100%;display:block;height:auto}
a{color:inherit;-webkit-tap-highlight-color:transparent}
button{-webkit-tap-highlight-color:transparent}

/* Grid background */
.grid-bg{
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(42,29,20,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(42,29,20,0.025) 1px, transparent 1px);
  background-size:32px 32px;
  pointer-events:none;
  z-index:0;
}
@media (min-width:768px){ .grid-bg{ background-size:52px 52px; } }

/* Grain overlay */
body::before{
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:1000;
  opacity:0.04;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* Keyframes */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes glowPulse{0%,100%{opacity:0.5}50%{opacity:0.85}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* ════════════════════════════════════════════════════════
   NAV (mobile-first)
   ════════════════════════════════════════════════════════ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:300;
  height:56px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;
  background:rgba(245,239,229,0.94);
  backdrop-filter:blur(20px) saturate(1.1);
  -webkit-backdrop-filter:blur(20px) saturate(1.1);
  border-bottom:1px solid var(--border);
  transition:height .3s ease, background .3s ease;
}
nav.scrolled{height:52px}
.nav-logo{
  display:inline-flex;align-items:baseline;gap:0;text-decoration:none;
  font-family:var(--serif);font-size:34px;font-weight:600;letter-spacing:-0.025em;
  color:var(--espresso);
  line-height:1;
}
.nav-logo i{font-style:normal;font-weight:600;color:var(--gold)}
.nav-logo .dot{display:none}

.nav-links{display:none;gap:36px;list-style:none}
.nav-links a{
  text-decoration:none;font-size:13px;font-weight:500;color:var(--text-soft);
  letter-spacing:0.01em;position:relative;transition:color .2s;
  padding:8px 0;
}
.nav-links a:hover, .nav-links a.active{color:var(--espresso)}
.nav-links a::after{content:'';position:absolute;bottom:-6px;left:0;width:0;height:1px;background:var(--gold);transition:width .25s ease}
.nav-links a:hover::after, .nav-links a.active::after{width:100%}

.nav-cta{
  display:none;
  background:var(--espresso);color:var(--bone);font-family:var(--sans);
  font-size:12px;font-weight:600;border:none;
  padding:10px 18px;border-radius:999px;cursor:pointer;
  letter-spacing:0.02em;text-decoration:none;transition:all .2s;
  min-height:40px;align-items:center;
}
.nav-cta:hover{background:var(--gold);transform:translateY(-1px)}

.nav-toggle{
  display:flex;align-items:center;justify-content:center;
  background:none;border:none;cursor:pointer;color:var(--espresso);
  width:40px;height:40px;
  padding:0;
  border-radius:8px;
  margin-right:-8px;
  transition:background .15s;
}
.nav-toggle:active{background:var(--cream-warm)}
.nav-toggle svg{width:22px;height:22px;display:block}

@media (min-width:600px){
  nav{padding:0 24px;height:64px}
  nav.scrolled{height:56px}
  .nav-logo{font-size:34px}
  .nav-cta{display:inline-flex}
}
@media (min-width:900px){
  nav{padding:0 32px;height:72px}
  nav.scrolled{height:60px}
  .nav-logo{font-size:36px}
  .nav-links{display:flex}
  .nav-toggle{display:none}
}
@media (min-width:1024px){
  nav{padding:0 40px}
}

/* Mobile nav drawer */
.nav-drawer{
  display:none;position:fixed;top:56px;left:0;right:0;
  background:var(--cream);border-bottom:1px solid var(--border);
  padding:16px 20px;z-index:299;
  flex-direction:column;gap:4px;
  max-height:calc(100dvh - 56px);
  overflow-y:auto;
  box-shadow:0 10px 30px -10px rgba(42,29,20,0.15);
}
.nav-drawer.open{display:flex}
.nav-drawer a{
  text-decoration:none;color:var(--espresso);
  font-size:15px;font-weight:500;
  padding:14px 12px;
  min-height:44px;
  display:flex;align-items:center;
  border-bottom:1px solid var(--border);
  border-radius:6px;
}
.nav-drawer a:last-child{border-bottom:none}
.nav-drawer a:active{background:var(--cream-warm)}
@media (min-width:600px){
  .nav-drawer{top:64px;max-height:calc(100dvh - 64px)}
}
@media (min-width:900px){
  .nav-drawer{display:none !important}
}

/* ════════════════════════════════════════════════════════
   AUDIENCE SWITCHER (mobile-first)
   ════════════════════════════════════════════════════════ */
.switcher-wrap{
  position:fixed;
  top:64px; /* below 56px nav + 8px gap on mobile */
  left:50%;
  transform:translateX(-50%);
  z-index:280;
  transition:top .3s ease;
  width:calc(100vw - 32px);
  max-width:340px;
}
nav.scrolled ~ .switcher-wrap{top:60px}
.switcher{
  background:var(--bone);
  border:1px solid var(--border2);
  border-radius:999px;
  padding:3px;
  display:flex;
  box-shadow:0 2px 12px rgba(42,29,20,0.08);
  position:relative;
}
.switcher a{
  flex:1;
  text-decoration:none;
  text-align:center;
  background:transparent;
  border:none;
  cursor:pointer;
  padding:8px 14px;
  font-family:var(--sans);
  font-size:12px;
  font-weight:600;
  color:var(--text-soft);
  border-radius:999px;
  position:relative;
  z-index:2;
  transition:color .3s,background .3s;
  letter-spacing:0.02em;
  white-space:nowrap;
  min-height:34px;
  display:flex;align-items:center;justify-content:center;
}
.switcher a.active{color:var(--bone);background:var(--espresso)}

@media (min-width:600px){
  .switcher-wrap{top:74px;width:auto;max-width:none}
  nav.scrolled ~ .switcher-wrap{top:66px}
  .switcher{padding:4px;box-shadow:0 4px 16px rgba(42,29,20,0.10)}
  .switcher a{padding:10px 22px;font-size:13px;min-height:36px}
}
@media (min-width:900px){
  .switcher-wrap{top:84px}
  nav.scrolled ~ .switcher-wrap{top:72px}
}

/* ════════════════════════════════════════════════════════
   SECTIONS (mobile-first)
   ════════════════════════════════════════════════════════ */
section{
  padding:64px 16px;
  position:relative;
  background:#F5EFE6;
}
.container{
  max-width:1180px;
  margin:0 auto;
  position:relative;
  z-index:1;
  width:100%;
}

.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--sans);font-size:10px;font-weight:700;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--gold);margin-bottom:18px;
  flex-wrap:wrap;
}
.eyebrow::before, .eyebrow::after{content:'';width:18px;height:1px;background:var(--gold);opacity:0.5}

.section-header{text-align:center;max-width:780px;margin:0 auto 44px}
.section-header.left{text-align:left;margin-left:0}

.section-title{
  font-family:var(--serif);
  font-size:clamp(32px, 7vw, 68px);
  font-weight:400;
  line-height:1.05;
  letter-spacing:-0.022em;
  color:var(--espresso);
  margin-bottom:16px;
}
.section-title .gold{color:var(--gold)}
.section-title .dim{color:var(--text-soft);opacity:0.78}
.section-title em{font-style:normal;color:var(--gold);font-weight:500}
.section-title .strike{
  text-decoration:line-through;
  text-decoration-color:var(--terra);
  text-decoration-thickness:2px;
  color:var(--text-soft);opacity:0.7;font-weight:300;
}

.section-sub{
  font-size:16px;line-height:1.6;color:var(--espresso2);
  max-width:640px;margin:0 auto;font-weight:400;
}
.section-header.left .section-sub{margin:0}

@media (min-width:600px){
  section{padding:80px 20px}
  .eyebrow{font-size:10px;gap:10px;margin-bottom:20px}
  .eyebrow::before, .eyebrow::after{width:24px}
  .section-header{margin:0 auto 56px}
  .section-sub{font-size:17px;line-height:1.65}
}
@media (min-width:768px){
  section{padding:100px 32px}
  .section-header{margin:0 auto 64px}
}
@media (min-width:1024px){
  section{padding:120px 40px}
}

/* Closing-section utility — used to be inline style="padding:160px 20px" */
.closing-section.pad-cta{padding:96px 16px}
@media (min-width:600px){ .closing-section.pad-cta{padding:120px 24px} }
@media (min-width:768px){ .closing-section.pad-cta{padding:140px 32px} }
@media (min-width:1024px){ .closing-section.pad-cta{padding:160px 40px} }

/* ════════════════════════════════════════════════════════
   BUTTONS (mobile-first)
   ════════════════════════════════════════════════════════ */
.btn-primary{
  background:var(--espresso);color:var(--bone);font-family:var(--sans);
  font-size:14px;font-weight:600;border:none;
  padding:14px 24px;border-radius:999px;cursor:pointer;
  letter-spacing:0.01em;text-decoration:none;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  transition:all .2s;
  min-height:48px; /* iOS tap target */
}
.btn-primary:hover{background:var(--gold);transform:translateY(-2px);box-shadow:0 12px 30px -10px rgba(184,145,84,0.5)}
.btn-primary svg{transition:transform .2s;flex-shrink:0}
.btn-primary:hover svg{transform:translateX(4px)}

.btn-ghost{
  background:transparent;color:var(--espresso);font-family:var(--sans);
  font-size:14px;font-weight:600;border:1px solid var(--border2);
  padding:13px 22px;border-radius:999px;cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  transition:all .2s;
  min-height:48px;
}
.btn-ghost:hover{border-color:var(--espresso);background:var(--bone)}

@media (min-width:600px){
  .btn-primary{padding:16px 28px}
  .btn-ghost{padding:15px 24px}
}

/* ════════════════════════════════════════════════════════
   HERO (mobile-first)
   ════════════════════════════════════════════════════════ */
.hero{
  background:var(--cream);
  position:relative;
  padding:116px 16px 56px;
  min-height:min(680px, 95dvh); /* dvh handles iOS Safari address bar */
  display:flex;
  align-items:center;
  overflow:hidden;
}
.hero-glow{
  position:absolute;
  width:700px;height:700px;
  background:radial-gradient(circle, rgba(184,145,84,0.18) 0%, transparent 60%);
  top:-200px;left:50%;transform:translateX(-50%);
  pointer-events:none;
  animation:glowPulse 8s ease-in-out infinite;
}
.hero-inner{max-width:980px;margin:0 auto;text-align:center;position:relative;z-index:2;width:100%}

.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center;
  font-size:10px;font-weight:700;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--gold);margin-bottom:22px;
  animation:fadeUp .5s ease .1s both;
}
.hero-eyebrow::before, .hero-eyebrow::after{content:'';width:18px;height:1px;background:var(--gold);opacity:0.6}

.hero-hook{
  font-family:var(--serif);font-size:14px;font-style:italic;color:var(--text-soft);
  max-width:560px;margin:0 auto 24px;line-height:1.55;font-weight:400;
  animation:fadeUp .5s ease .2s both;
}

.hero-title{
  font-family:var(--serif);
  font-size:clamp(40px, 11vw, 112px);
  font-weight:400;
  line-height:1;
  letter-spacing:-0.03em;
  color:var(--espresso);
  margin-bottom:22px;
  animation:fadeUp .6s ease .25s both;
}
.hero-title .gold{color:var(--gold)}
.hero-title .dim{color:var(--text-soft);opacity:0.75}
.hero-title em{font-style:normal;font-weight:500;color:var(--gold)}
.hero-title .strike{text-decoration:line-through;text-decoration-color:var(--terra);text-decoration-thickness:3px;color:var(--text-soft);opacity:0.65;font-weight:300}

.hero-sub{
  font-size:16px;color:var(--espresso2);max-width:620px;margin:0 auto 32px;
  line-height:1.55;font-weight:400;animation:fadeUp .6s ease .4s both;
}
.hero-sub strong{color:var(--espresso);font-weight:700}

.hero-actions{
  display:flex;gap:10px;flex-direction:column;align-items:stretch;
  margin-bottom:40px;
  animation:fadeUp .6s ease .55s both;
  max-width:340px;margin-left:auto;margin-right:auto;
}
.hero-actions .btn-primary, .hero-actions .btn-ghost{width:100%}

.hero-proof{
  display:grid;grid-template-columns:repeat(3, 1fr);gap:0;
  max-width:680px;margin:0 auto;
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:18px 0;
  animation:fadeUp .6s ease .7s both;
}
.proof-item{text-align:center;padding:0 8px;border-right:1px solid var(--border)}
.proof-item:last-child{border-right:none}
.proof-num{font-family:var(--serif);font-size:24px;font-weight:500;color:var(--espresso);line-height:1;margin-bottom:6px;white-space:nowrap}
.proof-num em{font-style:normal;color:var(--gold)}
.proof-label{font-size:9px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-dim);line-height:1.3}

@media (min-width:600px){
  .hero{padding:138px 24px 72px}
  .hero-eyebrow{font-size:10px;gap:10px;margin-bottom:28px}
  .hero-eyebrow::before, .hero-eyebrow::after{width:24px}
  .hero-hook{font-size:15px;margin:0 auto 32px}
  .hero-sub{font-size:18px;margin:0 auto 40px}
  .hero-actions{flex-direction:row;justify-content:center;max-width:none;gap:14px;margin-bottom:48px}
  .hero-actions .btn-primary, .hero-actions .btn-ghost{width:auto}
  .hero-proof{padding:22px 0}
  .proof-item{padding:0 12px}
  .proof-num{font-size:28px;margin-bottom:7px}
  .proof-label{font-size:10px;letter-spacing:0.16em}
}
@media (min-width:768px){
  .hero{padding:150px 32px 88px}
  .hero-hook{font-size:15px;margin:0 auto 36px}
  .hero-sub{font-size:19px;line-height:1.6;margin:0 auto 44px}
  .hero-proof{padding:24px 0}
  .proof-item{padding:0 16px}
  .proof-num{font-size:32px;margin-bottom:8px}
  .proof-label{font-size:10px;letter-spacing:0.18em}
  .hero-glow{width:1000px;height:1000px;top:-300px}
}
@media (min-width:1024px){
  .hero{padding:160px 40px 96px}
}

/* Owner guarantee badge */
.own-guarantee{
  display:flex;align-items:flex-start;gap:12px;padding:16px 18px;
  background:var(--bone);border:1px solid var(--border);border-left:3px solid var(--gold);
  border-radius:8px;font-size:13px;text-align:left;
  max-width:580px;margin:0 auto;
  animation:fadeUp .6s ease .7s both;
  line-height:1.5;
}
.own-guarantee svg{flex-shrink:0;color:var(--gold);margin-top:1px}
.own-guarantee strong{color:var(--espresso);font-weight:700}
@media (min-width:600px){
  .own-guarantee{align-items:center;padding:18px 22px;font-size:14px;gap:14px}
}

/* ════════════════════════════════════════════════════════
   TICKER (mobile-first)
   ════════════════════════════════════════════════════════ */
.ticker-section{
  padding:0;background:var(--espresso);color:var(--bone);
  overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.ticker{
  display:flex;gap:0;padding:14px 0;white-space:nowrap;
  animation:ticker 40s linear infinite;width:max-content;
}
.ticker-item{
  display:flex;align-items:center;gap:14px;padding:0 20px;
  font-family:var(--serif);font-style:italic;font-size:15px;
  font-weight:400;color:var(--bone);
}
.ticker-item span.dot{width:5px;height:5px;border-radius:50%;background:var(--gold);flex-shrink:0}
.ticker-item .label{
  font-family:var(--sans);font-style:normal;font-size:10px;
  letter-spacing:0.16em;text-transform:uppercase;color:var(--gold2);font-weight:600;
}
@media (min-width:600px){
  .ticker{padding:16px 0}
  .ticker-item{gap:18px;padding:0 24px;font-size:16px}
  .ticker-item .label{font-size:11px;letter-spacing:0.18em}
}
@media (min-width:768px){
  .ticker{padding:18px 0}
  .ticker-item{gap:20px;padding:0 28px;font-size:18px}
}

/* ════════════════════════════════════════════════════════
   PROBLEM / FEATURE CARDS (mobile-first)
   ════════════════════════════════════════════════════════ */
.problem{background:var(--bone);border-bottom:1px solid var(--border)}
.prob-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:36px}
@media (min-width:600px){ .prob-grid{gap:18px;margin-top:44px} }
@media (min-width:768px){ .prob-grid{grid-template-columns:repeat(2,1fr);gap:20px;margin-top:48px} }
@media (min-width:1024px){ .prob-grid{grid-template-columns:repeat(3,1fr)} }

.prob-card{
  position:relative;padding:28px 22px;background:var(--cream);
  border:1px solid var(--border);border-radius:12px;
  transition:border-color .25s, transform .25s;overflow:hidden;
}
.prob-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
  transform:translateX(-100%);transition:transform .5s ease;
}
.prob-card:hover{border-color:var(--gold-border);transform:translateY(-4px)}
.prob-card:hover::before{transform:translateX(0)}
.prob-icon{font-size:28px;margin-bottom:16px;display:inline-block}
.prob-title{font-family:var(--serif);font-size:20px;font-weight:500;line-height:1.2;color:var(--espresso);margin-bottom:12px}
.prob-text{font-size:14px;line-height:1.55;color:var(--text-soft)}

@media (min-width:600px){
  .prob-card{padding:32px 26px}
  .prob-icon{font-size:30px;margin-bottom:18px}
  .prob-title{font-size:21px;margin-bottom:13px}
}
@media (min-width:768px){
  .prob-card{padding:36px 28px}
  .prob-icon{font-size:32px;margin-bottom:20px}
  .prob-title{font-size:22px;margin-bottom:14px;line-height:1.2}
  .prob-text{font-size:14px;line-height:1.6}
}

/* ════════════════════════════════════════════════════════
   HOOK / QUOTE (mobile-first)
   ════════════════════════════════════════════════════════ */
.hook-section{background:var(--cream-warm);text-align:center;border-bottom:1px solid var(--border)}
.hook-quote{
  font-family:var(--serif);
  font-size:clamp(22px, 5vw, 44px);
  font-weight:400;line-height:1.3;color:var(--espresso);font-style:italic;
  max-width:820px;margin:0 auto 18px;position:relative;
  padding:0 8px;
}
.hook-quote::before{
  content:'"';font-family:var(--serif);
  font-size:60px;color:var(--gold);
  position:absolute;top:-22px;left:-12px;opacity:0.3;line-height:1;
}
.hook-sub{font-size:15px;color:var(--espresso2);max-width:600px;margin:0 auto;line-height:1.55;font-weight:400;padding:0 8px}

@media (min-width:600px){
  .hook-quote{margin-bottom:20px;padding:0}
  .hook-quote::before{font-size:90px;top:-26px;left:-26px}
  .hook-sub{padding:0;font-size:16px;line-height:1.6}
}
@media (min-width:768px){
  .hook-quote{line-height:1.25;margin-bottom:24px}
  .hook-quote::before{font-size:120px;top:-30px;left:-40px}
}

/* ════════════════════════════════════════════════════════
   PHASES (mobile-first)
   ════════════════════════════════════════════════════════ */
.phases{background:var(--bone);border-top:1px solid var(--border)}
.phases-grid{
  display:grid;grid-template-columns:1fr;gap:1px;
  background:var(--border);border:1px solid var(--border);
  border-radius:12px;overflow:hidden;margin-top:36px;
}
@media (min-width:600px){ .phases-grid{margin-top:44px} }
@media (min-width:768px){ .phases-grid{margin-top:48px} }
@media (min-width:1024px){ .phases-grid{grid-template-columns:repeat(3,1fr)} }

.phase-panel{background:var(--cream);padding:32px 24px;position:relative;transition:background .3s}
.phase-panel:hover{background:var(--bone)}
.phase-num{
  font-family:var(--serif);font-size:11px;font-weight:500;
  letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);
  margin-bottom:18px;display:flex;align-items:center;gap:10px;
}
.phase-num::before{content:'';width:24px;height:1px;background:var(--gold)}
.phase-title{font-family:var(--serif);font-size:24px;font-weight:500;line-height:1.18;color:var(--espresso);margin-bottom:14px}
.phase-title em{font-style:normal;color:var(--gold);font-weight:500}
.phase-text{font-size:14px;line-height:1.6;color:var(--text-soft);margin-bottom:20px}
.phase-detail{font-size:12px;color:var(--text-dim);letter-spacing:0.04em;padding-top:18px;border-top:1px solid var(--border);line-height:1.4}

@media (min-width:600px){
  .phase-panel{padding:40px 30px}
  .phase-title{font-size:26px;margin-bottom:15px}
}
@media (min-width:768px){
  .phase-panel{padding:48px 36px}
  .phase-num{margin-bottom:24px}
  .phase-num::before{width:30px}
  .phase-title{font-size:28px;line-height:1.15;margin-bottom:16px}
  .phase-text{line-height:1.65;margin-bottom:24px}
  .phase-detail{font-size:12px;letter-spacing:0.05em;padding-top:20px}
}

/* ════════════════════════════════════════════════════════
   AUDIENCE LIST (mobile-first)
   ════════════════════════════════════════════════════════ */
.for-who{border-bottom:1px solid var(--border)}
.audience-rows{
  display:grid;gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:12px;
  overflow:hidden;margin-top:36px;
}
@media (min-width:600px){ .audience-rows{margin-top:44px} }
@media (min-width:768px){ .audience-rows{margin-top:48px} }

.audience-row{
  background:var(--bone);padding:20px 18px;
  display:grid;grid-template-columns:44px 1fr;gap:14px;
  align-items:flex-start;transition:background .25s;
}
.audience-row:hover{background:var(--cream-warm)}
.audience-num{
  font-family:var(--serif);font-size:24px;font-weight:500;
  color:var(--gold);line-height:1;
}
.audience-row h4{font-family:var(--serif);font-size:18px;font-weight:500;line-height:1.2;color:var(--espresso);margin-bottom:5px}
.audience-row p{font-size:13px;color:var(--text-soft);line-height:1.5}
.audience-tag{
  display:none;
  font-size:10px;font-weight:600;padding:6px 12px;
  background:var(--cream-warm);color:var(--espresso2);
  border-radius:999px;text-transform:uppercase;
  letter-spacing:0.12em;white-space:nowrap;
  margin-top:8px;justify-self:start;
}

@media (min-width:600px){
  .audience-row{padding:24px 24px;grid-template-columns:50px 1fr;gap:18px;align-items:center}
  .audience-num{font-size:28px}
  .audience-row h4{font-size:20px;margin-bottom:6px}
  .audience-tag{display:inline-block;grid-column:2;margin-top:6px}
}
@media (min-width:768px){
  .audience-row{padding:28px 32px;grid-template-columns:60px 1fr auto;gap:24px}
  .audience-num{font-size:32px}
  .audience-row h4{font-size:21px}
  .audience-tag{grid-column:3;margin-top:0;align-self:center}
}

/* ════════════════════════════════════════════════════════
   REVIEWS (mobile-first)
   ════════════════════════════════════════════════════════ */
.reviews{background:var(--cream-warm);border-bottom:1px solid var(--border)}
.reviews-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:36px}
@media (min-width:600px){ .reviews-grid{gap:18px;margin-top:44px} }
@media (min-width:768px){ .reviews-grid{gap:20px;margin-top:48px;grid-template-columns:repeat(2,1fr)} }
@media (min-width:1024px){ .reviews-grid{grid-template-columns:repeat(3,1fr)} }

.review-card{
  background:var(--bone);padding:28px 24px;
  border:1px solid var(--border);border-radius:12px;
  display:flex;flex-direction:column;gap:18px;
  transition:transform .3s, box-shadow .3s, border-color .3s;
}
.review-card:hover{transform:translateY(-4px);border-color:var(--gold-border);box-shadow:0 24px 50px -25px rgba(42,29,20,0.18)}
.review-stars{color:var(--gold);letter-spacing:3px;font-size:15px}
.review-quote{font-family:var(--serif);font-size:17px;line-height:1.5;font-style:italic;color:var(--espresso);flex:1}
.review-author{display:flex;align-items:center;gap:12px;padding-top:16px;border-top:1px solid var(--border)}
.review-avatar{
  width:38px;height:38px;border-radius:50%;
  background:var(--cream-warm);display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);color:var(--gold);font-weight:500;font-size:16px;flex-shrink:0;
}
.review-name{font-weight:600;font-size:13px;color:var(--espresso)}
.review-source{font-size:11px;color:var(--text-dim);margin-top:2px}

@media (min-width:768px){
  .review-card{padding:36px 32px;gap:20px}
  .review-quote{font-size:18px}
}

/* ════════════════════════════════════════════════════════
   CLOSING / CTA SECTION (mobile-first)
   ════════════════════════════════════════════════════════ */
.closing-section{
  text-align:center;background:var(--espresso);color:var(--bone);
  position:relative;overflow:hidden;
  padding:80px 16px;
}
.closing-section::before{
  content:'';position:absolute;top:-50%;right:-20%;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle, rgba(184,145,84,0.15), transparent 70%);
  pointer-events:none;
}
.closing-title{
  font-family:var(--serif);
  font-size:clamp(32px, 8vw, 80px);
  font-weight:400;line-height:1.04;letter-spacing:-0.022em;
  color:var(--bone);margin-bottom:20px;
}
.closing-title .gold{color:var(--gold2)}
.closing-title em{font-style:normal;color:var(--gold2);font-weight:500}
.closing-section .section-sub{color:rgba(251,247,240,0.75);max-width:580px}
.closing-section .btn-primary{background:var(--gold);color:var(--espresso);margin-top:24px}
.closing-section .btn-primary:hover{background:var(--bone)}
/* When btn-primary is inside .hero-actions (paired with ghost button), kill the margin
   and let the flex parent handle alignment. Also force equal heights. */
.closing-section .hero-actions .btn-primary,
.closing-section .hero-actions .btn-ghost{margin-top:0}
.closing-section .hero-actions{align-items:stretch}
.closing-section .container{position:relative;z-index:2}
.closing-verse{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--gold2);letter-spacing:0.05em;margin-bottom:18px}
.closing-sub{font-size:16px;color:rgba(251,247,240,0.75);max-width:580px;margin:0 auto 28px;line-height:1.55}
.closing-note{margin-top:20px;font-size:12px;color:rgba(251,247,240,0.5);line-height:1.5}

.closing-section .hero-actions{margin-bottom:0;max-width:340px}

@media (min-width:600px){
  .closing-section{padding:96px 24px}
  .closing-title{margin-bottom:22px}
  .closing-verse{font-size:14px;margin-bottom:22px}
  .closing-sub{font-size:17px;margin:0 auto 32px}
  .closing-section .btn-primary{margin-top:28px}
  .closing-section .hero-actions{max-width:none}
}
@media (min-width:768px){
  .closing-section{padding:120px 32px}
  .closing-title{margin-bottom:24px}
  .closing-verse{margin-bottom:24px}
  .closing-sub{font-size:18px;line-height:1.6;margin:0 auto 36px}
  .closing-section .btn-primary{margin-top:36px}
}

/* ════════════════════════════════════════════════════════
   OWNER PAIN (mobile-first)
   ════════════════════════════════════════════════════════ */
.own-pain{background:var(--bone);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.pain-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:36px}
@media (min-width:600px){ .pain-grid{gap:14px;margin-top:44px} }
@media (min-width:768px){ .pain-grid{grid-template-columns:repeat(2,1fr);margin-top:48px} }

.pain-card{
  background:var(--cream);padding:22px 22px;
  border:1px solid var(--border);border-left:3px solid var(--terra);
  border-radius:8px;
  display:flex;align-items:flex-start;gap:12px;
  transition:transform .25s, border-color .25s;
}
.pain-card:hover{transform:translateX(4px);border-color:var(--terra)}
.pain-x{
  flex-shrink:0;width:22px;height:22px;border-radius:50%;
  background:rgba(184,103,74,0.15);color:var(--terra);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:13px;line-height:1;margin-top:1px;
}
.pain-text{font-size:14px;line-height:1.55;color:var(--text-soft)}
.pain-text strong{color:var(--espresso);font-weight:600}

@media (min-width:600px){
  .pain-card{padding:24px 26px;gap:14px}
  .pain-x{width:24px;height:24px;font-size:14px}
}

/* ════════════════════════════════════════════════════════
   TIERS (mobile-first)
   ════════════════════════════════════════════════════════ */
.tiers{background:var(--bone);border-top:1px solid var(--border)}
.tiers-grid{display:grid;grid-template-columns:1fr;gap:20px;margin-top:36px}
@media (min-width:600px){ .tiers-grid{margin-top:44px} }
@media (min-width:768px){ .tiers-grid{gap:24px;margin-top:48px} }

.tier-card{
  background:var(--cream);border:1px solid var(--border);
  border-radius:14px;padding:32px 24px;position:relative;
  transition:transform .3s, box-shadow .3s, border-color .3s;
}
.tier-card:hover{transform:translateY(-6px);border-color:var(--gold-border);box-shadow:0 30px 60px -30px rgba(42,29,20,0.2)}
.tier-popular{background:var(--espresso);border-color:var(--espresso);color:var(--bone)}
.tier-popular:hover{border-color:var(--gold)}
.tier-popular .tier-name, .tier-popular .tier-feat, .tier-popular .tier-tag, .tier-popular .tier-price-amt{color:var(--bone)}
.tier-popular .tier-feat svg{color:var(--gold2)}
.tier-popular .tier-price-period{color:rgba(251,247,240,0.55)}
.tier-popular .tier-price{border-color:rgba(251,247,240,0.15)}
.tier-badge{
  position:absolute;top:-13px;right:22px;
  background:var(--gold);color:var(--espresso);
  font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;
  padding:6px 12px;border-radius:999px;
}
.tier-name{font-family:var(--serif);font-size:26px;font-weight:500;color:var(--espresso);margin-bottom:6px;line-height:1.15}
.tier-name em{font-style:normal;color:var(--gold);font-weight:500}
.tier-tag{font-size:13px;color:var(--text-soft);margin-bottom:24px}
.tier-price{
  display:flex;align-items:baseline;gap:10px;
  padding-bottom:24px;margin-bottom:24px;
  border-bottom:1px solid var(--border);
  flex-wrap:wrap;
}
.tier-price-amt{font-family:var(--serif);font-size:46px;font-weight:500;color:var(--espresso);line-height:1;letter-spacing:-0.02em}
.tier-price-amt em{font-style:normal;color:var(--gold);font-weight:600}
.tier-price-period{font-size:12px;color:var(--text-dim);line-height:1.4}
.tier-feats{list-style:none;display:grid;gap:12px;margin-bottom:24px}
.tier-feat{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:1.55;color:var(--text-soft)}
.tier-feat svg{width:16px;height:16px;color:var(--gold);flex-shrink:0;margin-top:4px}
.tier-feat > span{flex:1 1 auto;min-width:0}
.tier-feat strong{color:var(--espresso);font-weight:700}
.tier-popular .tier-feat strong{color:var(--bone)}
.tier-cta{
  display:flex;align-items:center;justify-content:center;
  width:100%;text-align:center;
  background:var(--espresso);color:var(--bone);text-decoration:none;
  padding:14px 24px;border-radius:999px;font-size:14px;font-weight:600;
  transition:all .2s;min-height:48px;
}
.tier-cta:hover{background:var(--gold)}
.tier-popular .tier-cta{background:var(--gold);color:var(--espresso)}
.tier-popular .tier-cta:hover{background:var(--bone)}

@media (min-width:600px){
  .tier-card{padding:38px 30px}
  .tier-badge{right:28px}
  .tier-name{font-size:28px;margin-bottom:7px}
  .tier-price-amt{font-size:54px}
  .tier-price-period{font-size:13px}
  .tier-feats{gap:13px;margin-bottom:28px}
  .tier-cta{padding:16px 24px}
}
@media (min-width:768px){
  .tier-card{padding:44px 38px}
  .tier-badge{right:32px;letter-spacing:0.15em;padding:7px 14px}
  .tier-name{font-size:30px;margin-bottom:8px}
  .tier-tag{font-size:14px;margin-bottom:32px}
  .tier-price{gap:10px;padding-bottom:28px;margin-bottom:28px}
  .tier-price-amt{font-size:60px}
  .tier-feats{gap:14px;margin-bottom:32px}
}

/* ════════════════════════════════════════════════════════
   FOR-WHO (Good/Bad lists) (mobile-first)
   ════════════════════════════════════════════════════════ */
.for-who-own{background:var(--cream-warm);border-bottom:1px solid var(--border)}
.fw-grid{display:grid;grid-template-columns:1fr;gap:20px;margin-top:36px}
@media (min-width:600px){ .fw-grid{margin-top:44px} }
@media (min-width:768px){ .fw-grid{gap:24px;margin-top:48px} }
@media (min-width:1024px){ .fw-grid{grid-template-columns:1fr 1fr} }

.fw-card{background:var(--bone);border:1px solid var(--border);border-radius:14px;padding:28px 24px}
.fw-card.bad{background:var(--cream)}
@media (min-width:600px){ .fw-card{padding:32px 28px} }
@media (min-width:768px){ .fw-card{padding:36px 32px} }

.fw-badge{
  display:inline-flex;align-items:center;gap:8px;
  font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;
  padding:7px 14px;border-radius:999px;margin-bottom:20px;
}
.fw-card.good .fw-badge{background:rgba(122,136,112,0.18);color:#5a6850}
.fw-card.bad .fw-badge{background:rgba(184,103,74,0.18);color:var(--terra)}
.fw-items{display:grid;gap:16px}
.fw-item{display:grid;grid-template-columns:24px 1fr;gap:12px;align-items:flex-start}
.fw-dot{
  width:24px;height:24px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-weight:700;font-size:13px;margin-top:1px;
}
.fw-card.good .fw-dot{background:rgba(122,136,112,0.18);color:#5a6850}
.fw-card.bad .fw-dot{background:rgba(184,103,74,0.18);color:var(--terra)}
.fw-item-title{font-family:var(--serif);font-size:16px;font-weight:500;color:var(--espresso);margin-bottom:4px;line-height:1.25}
.fw-item-text{font-size:13px;color:var(--text-soft);line-height:1.55}
@media (min-width:600px){
  .fw-badge{font-size:11px;letter-spacing:0.16em;margin-bottom:22px}
  .fw-items{gap:18px}
  .fw-item{gap:14px}
  .fw-item-title{font-size:17px}
}

/* ════════════════════════════════════════════════════════
   FAQ (mobile-first)
   ════════════════════════════════════════════════════════ */
.faq{background:var(--bone);border-bottom:1px solid var(--border)}
.faq-list{
  max-width:820px;margin:36px auto 0;display:grid;gap:1px;
  background:var(--border);border:1px solid var(--border);
  border-radius:12px;overflow:hidden;
}
@media (min-width:600px){ .faq-list{margin:44px auto 0} }
@media (min-width:768px){ .faq-list{margin:48px auto 0} }

.faq-item{background:var(--cream)}
.faq-q{
  width:100%;background:transparent;border:none;text-align:left;
  padding:18px 20px;
  font-family:var(--serif);font-size:16px;font-weight:500;color:var(--espresso);
  cursor:pointer;display:flex;justify-content:space-between;align-items:center;
  gap:16px;transition:background .2s;line-height:1.3;
  min-height:60px;
}
.faq-q:hover{background:var(--bone)}
.faq-toggle{
  flex-shrink:0;width:28px;height:28px;
  border:1px solid var(--border2);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--espresso);
  transition:transform .3s, background .25s, color .25s;
  font-size:16px;font-weight:400;
}
.faq-item.open .faq-toggle{background:var(--gold);color:var(--bone);border-color:var(--gold);transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item.open .faq-a{max-height:800px}
.faq-a-inner{padding:0 20px 22px;font-size:14px;line-height:1.65;color:var(--text-soft)}

@media (min-width:600px){
  .faq-q{padding:22px 24px;font-size:17px;gap:20px}
  .faq-toggle{width:30px;height:30px}
  .faq-a-inner{padding:0 24px 26px;font-size:15px;line-height:1.7}
}
@media (min-width:768px){
  .faq-q{padding:24px 28px;font-size:18px;gap:24px}
  .faq-a-inner{padding:0 28px 28px}
}

/* ════════════════════════════════════════════════════════
   FOOTER (mobile-first)
   ════════════════════════════════════════════════════════ */
footer{background:var(--cream);padding:56px 20px 28px;border-top:1px solid var(--border);position:relative}
.footer-inner{
  max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:1fr;gap:36px;
  margin-bottom:36px;
}
.footer-brand{font-family:var(--serif);font-size:28px;font-weight:500;color:var(--espresso)}
.footer-brand i{font-style:normal;font-weight:500;color:var(--gold)}
.footer-brand .dot{color:var(--terra)}
.footer-tag{color:var(--text-soft);font-size:13px;line-height:1.6;margin-top:14px;max-width:340px}
.footer-col h5{
  font-family:var(--sans);font-size:11px;text-transform:uppercase;
  letter-spacing:0.16em;color:var(--gold);margin-bottom:14px;font-weight:700;
}
.footer-col a{
  display:block;color:var(--text-soft);text-decoration:none;
  font-size:14px;padding:8px 0;transition:color .2s;
  min-height:36px;
}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{
  max-width:1180px;margin:0 auto;padding-top:24px;
  border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;
  font-size:11px;color:var(--text-dim);flex-wrap:wrap;gap:10px;
  line-height:1.4;
}

@media (min-width:600px){
  footer{padding:64px 24px 32px}
  .footer-inner{grid-template-columns:repeat(2, 1fr);gap:40px;margin-bottom:44px}
  .footer-tag{font-size:14px}
  .footer-col a{font-size:14px}
  .footer-bottom{font-size:12px}
}
@media (min-width:768px){
  footer{padding:80px 32px 36px}
  .footer-inner{grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
  .footer-brand{font-size:32px}
  .footer-col h5{font-size:11px;letter-spacing:0.18em;margin-bottom:20px}
  .footer-col a{padding:6px 0;min-height:32px}
}
@media (min-width:1024px){
  footer{padding:80px 40px 36px}
  .footer-inner{gap:60px}
}

/* ════════════════════════════════════════════════════════
   REVEAL ON SCROLL
   ════════════════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal.delay-1{transition-delay:.1s}
.reveal.delay-2{transition-delay:.2s}
.reveal.delay-3{transition-delay:.3s}

/* ════════════════════════════════════════════════════════
   UTILITY HELPERS
   ════════════════════════════════════════════════════════ */
/* Hero variant used on contact.html — shorter, no min-height */
.hero-compact{
  min-height:auto;
  padding:108px 16px 48px;
}
@media (min-width:600px){ .hero-compact{padding:128px 24px 64px} }
@media (min-width:768px){ .hero-compact{padding:148px 32px 72px} }

/* Problem section variant — tighter top padding (used when stacked under hero-compact) */
.problem-tight{padding-top:40px}
@media (min-width:600px){ .problem-tight{padding-top:48px} }
@media (min-width:768px){ .problem-tight{padding-top:60px} }

/* "Versus property management" section — uses cream background instead of cream-bone */
.vs-pm-section{
  background:var(--cream);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:64px 16px;
}
@media (min-width:600px){ .vs-pm-section{padding:80px 20px} }
@media (min-width:768px){ .vs-pm-section{padding:100px 32px} }
@media (min-width:1024px){ .vs-pm-section{padding:120px 40px} }

/* Center actions in hero-actions row when used as nav-pair */
.hero-actions.center{justify-content:center}

/* Inverted ghost button — used on dark closing-section backgrounds */
.btn-ghost.btn-ghost-inverse{
  border-color:rgba(251,247,240,0.3);
  color:var(--bone);
}
.btn-ghost.btn-ghost-inverse:hover{
  border-color:var(--bone);
  background:rgba(251,247,240,0.1);
}

/* Center single tier-card */
.tiers-grid.tiers-single{
  grid-template-columns:1fr;
  max-width:780px;
  margin-left:auto;
  margin-right:auto;
}

/* Pull quote — used below comparison table */
.pull-quote{
  margin-top:28px;
  padding:20px 22px;
  background:var(--bone);
  border-left:3px solid var(--gold);
  border-radius:8px;
  max-width:780px;
  margin-left:auto;
  margin-right:auto;
}
.pull-quote-text{
  font-family:var(--serif);
  font-size:15px;
  line-height:1.5;
  color:var(--espresso);
  font-style:italic;
  margin:0;
}
@media (min-width:600px){
  .pull-quote{margin-top:32px;padding:22px 26px}
  .pull-quote-text{font-size:16px;line-height:1.55}
}
@media (min-width:768px){
  .pull-quote{margin-top:36px;padding:24px 28px}
  .pull-quote-text{font-size:17px}
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;scroll-behavior:auto !important}
  .ticker{animation:none}
  .hero-glow{animation:none}
}
