/* ==========================================================================
   DV Communities — homepage
   Shares the type system + motion of the RV-park pages (assets/park.css) but
   carries the corporate brand: deep teal + leaf green + navy, pulled from the
   shield logo. Light, editorial, confident. Reuses assets/park.js.
   ========================================================================== */

:root{
  --bg:#eef2f2;
  --bg-2:#e3eaea;
  --paper:#ffffff;
  --ink:#0a2730;        /* deep teal-navy */
  --ink-soft:#496670;
  --line:rgba(10,39,48,.14);
  --line-soft:rgba(10,39,48,.07);
  --primary:#0f7d77;    /* shield teal */
  --primary-d:#0a5b56;
  --accent:#5ea63f;     /* shield green */
  --radius:16px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:"Hanken Grotesk", system-ui, sans-serif;
  font-size:clamp(1rem,.96rem + .2vw,1.085rem); line-height:1.7; font-weight:400;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{ margin:0; font-weight:400; }
::selection{ background:var(--primary); color:#fff; }
@media (pointer:fine){
  *{ scrollbar-width:thin; scrollbar-color:var(--primary) transparent; }
  *::-webkit-scrollbar{ width:11px; height:11px; }
  *::-webkit-scrollbar-thumb{ background:var(--primary); border:3px solid var(--bg); border-radius:99px; }
}

/* ---- Layout ---- */
.container{ width:min(1180px,92vw); margin-inline:auto; }
.section{ padding-block:clamp(4.5rem,9vw,8rem); position:relative; }
.section--alt{ background:var(--bg-2); }
.section--paper{ background:var(--paper); }
section[id]{ scroll-margin-top:84px; }

.display{ font-family:"Fraunces",Georgia,serif; font-optical-sizing:auto; font-weight:430; line-height:1.03; letter-spacing:-.012em; }
.eyebrow{ font-family:"Space Mono",ui-monospace,monospace; font-size:.72rem; text-transform:uppercase; letter-spacing:.24em; color:var(--primary); margin:0 0 1.4rem; display:flex; align-items:center; gap:.7rem; }
.eyebrow i{ font-style:normal; color:var(--accent); }
.eyebrow::before{ content:""; width:26px; height:1px; background:currentColor; opacity:.5; }
.section-head{ max-width:46rem; margin-bottom:clamp(2.5rem,5vw,3.6rem); }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head.center .eyebrow{ justify-content:center; }
.section-head h2{ font-size:clamp(2rem,1.3rem + 3vw,3.5rem); }
.prose{ color:var(--ink-soft); max-width:42rem; }
.prose.lg{ font-size:clamp(1.1rem,1rem + .6vw,1.4rem); line-height:1.6; color:var(--ink); }

/* ---- Buttons ---- */
.btn{ display:inline-flex; align-items:center; gap:.6em; padding:.92em 1.6em; font-family:"Hanken Grotesk",sans-serif; font-weight:600; font-size:.97rem; border-radius:100px; border:1px solid transparent; cursor:pointer; transition:transform .25s,background .25s,box-shadow .25s,color .25s,border-color .25s; }
.btn svg{ width:1.05em; height:1.05em; }
.btn--solid{ background:var(--primary); color:#fff; box-shadow:0 12px 26px -14px var(--primary); }
.btn--solid:hover{ background:var(--primary-d); transform:translateY(-2px); box-shadow:0 18px 32px -14px var(--primary); }
.btn--ghost{ border-color:var(--line); color:var(--ink); }
.btn--ghost:hover{ border-color:var(--ink); transform:translateY(-2px); }

/* ---- Texture ---- */
.grain{ position:fixed; inset:0; z-index:200; pointer-events:none; opacity:.045; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
.contours{ position:absolute; inset:0; width:100%; height:100%; color:var(--primary); opacity:.10; pointer-events:none; stroke:currentColor; fill:none; stroke-width:1.4; }

/* ---- Nav (light) ---- */
.nav{ position:fixed; top:0; left:0; right:0; z-index:100; transition:background .35s,box-shadow .35s,border-color .35s; border-bottom:1px solid transparent; }
.nav__inner{ display:flex; align-items:center; justify-content:space-between; height:76px; }
.brand{ display:flex; align-items:center; }
/* logo.svg has ~23% transparent padding top & bottom; render large and pull the
   transparent overflow back with negative margins so the mark looks right
   without forcing a taller nav. */
.brand img{ height:104px; width:auto; display:block; margin-block:-26px; }
.nav__links{ display:flex; gap:2rem; }
.nav__links a{ font-size:.9rem; font-weight:500; color:var(--ink-soft); position:relative; padding:.2rem 0; transition:color .25s; }
.nav__links a:hover{ color:var(--ink); }
.nav__links a::after{ content:""; position:absolute; left:0; bottom:-2px; width:100%; height:1.5px; background:var(--primary); transform:scaleX(0); transform-origin:left; transition:transform .3s; }
.nav__links a:hover::after{ transform:scaleX(1); }
.nav__cta{ display:flex; align-items:center; gap:1rem; }
.nav__apply{ padding:.58em 1.3em; font-size:.88rem; }
.nav__toggle{ display:none; }
.nav--solid{ background:color-mix(in srgb,var(--paper) 88%,transparent); backdrop-filter:blur(12px); border-color:var(--line-soft); box-shadow:0 1px 24px -14px rgba(0,0,0,.4); }

/* ---- Hero (light, brand mesh) ---- */
.hero{ position:relative; overflow:hidden; padding-top:clamp(8rem,16vh,11rem); padding-bottom:clamp(4rem,8vw,7rem); }
.hero::before{ content:""; position:absolute; inset:0; z-index:0; background:
   radial-gradient(60% 55% at 8% -5%, rgba(15,125,119,.20), transparent 60%),
   radial-gradient(48% 45% at 102% 12%, rgba(94,166,63,.18), transparent 60%),
   radial-gradient(42% 50% at 88% 108%, rgba(15,125,119,.12), transparent 60%); }
.hero .contours{ z-index:0; opacity:.08; }
.hero__grid{ position:relative; z-index:1; display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.hero__eyebrow{ color:var(--primary); }
.hero__title{ font-family:"Fraunces",serif; font-optical-sizing:auto; font-weight:450; font-size:clamp(2.7rem,1.6rem + 5.4vw,5.4rem); line-height:1.0; letter-spacing:-.018em; margin:0 0 1.4rem; text-wrap:balance; }
.hero__title em{ font-style:italic; color:var(--primary); }
.hero__lede{ font-size:clamp(1.1rem,1rem + .6vw,1.4rem); line-height:1.55; color:var(--ink-soft); max-width:34rem; margin:0 0 2.2rem; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:1rem; }

/* brand card (echoes the shield gradient) */
.hero__card{ position:relative; overflow:hidden; border-radius:24px; padding:clamp(1.8rem,3vw,2.6rem); color:#fff;
  background:linear-gradient(150deg,var(--primary) 0%, #169a8f 48%, var(--accent) 120%);
  box-shadow:0 40px 70px -36px rgba(10,90,86,.7); }
.hero__card .contours{ color:#fff; opacity:.18; }
.hero__card-label{ font-family:"Space Mono",monospace; font-size:.7rem; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.85); margin:0 0 1rem; position:relative; }
.hero__card h3{ font-family:"Fraunces",serif; font-weight:450; font-size:clamp(1.4rem,1rem + 1.4vw,1.95rem); line-height:1.1; margin:0 0 1.4rem; position:relative; }
.chips{ display:flex; flex-wrap:wrap; gap:.5rem; position:relative; }
.chip{ font-family:"Space Mono",monospace; font-size:.78rem; letter-spacing:.08em; padding:.42em .8em; border:1px solid rgba(255,255,255,.45); border-radius:99px; }
.hero__card-foot{ position:relative; margin-top:1.6rem; padding-top:1.2rem; border-top:1px solid rgba(255,255,255,.25); display:flex; align-items:center; gap:.6rem; font-weight:600; font-size:.95rem; }

/* ---- Stat strip ---- */
.stats{ background:var(--paper); border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft); }
.stats__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:2rem; padding-block:2.4rem; text-align:center; }
.stats__grid b{ display:block; font-family:"Fraunces",serif; font-weight:500; font-size:clamp(1.5rem,1rem + 1.6vw,2.1rem); color:var(--primary); }
.stats__grid span{ color:var(--ink-soft); font-size:.95rem; }

/* ---- Value cards ---- */
.vcards{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.vcard{ background:var(--paper); padding:clamp(1.8rem,2.6vw,2.6rem); position:relative; transition:background .3s; }
.section--alt .vcard{ background:var(--bg); }
.vcard:hover{ background:var(--bg-2); }
.vcard__no{ font-family:"Space Mono",monospace; font-size:.74rem; color:var(--accent); letter-spacing:.1em; }
.vcard__icon{ width:34px; height:34px; stroke:var(--primary); fill:none; stroke-width:1.6; margin:.7rem 0 1.1rem; }
.vcard h3{ font-family:"Fraunces",serif; font-weight:500; font-size:1.4rem; margin:0 0 .6rem; }
.vcard p{ margin:0; color:var(--ink-soft); font-size:.97rem; }

/* ---- Portal ---- */
.portal__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2.5rem,5vw,5rem); align-items:center; }
.feats{ list-style:none; margin:1.8rem 0 0; padding:0; }
.feats li{ display:flex; gap:1rem; padding:1.05rem 0; border-top:1px solid var(--line); }
.feats li:last-child{ border-bottom:1px solid var(--line); }
.feats svg{ width:26px; height:26px; flex-shrink:0; color:var(--accent); margin-top:.1rem; }
.feats b{ display:block; font-weight:600; }
.feats p{ margin:.15rem 0 0; color:var(--ink-soft); font-size:.94rem; }
.portal__cta{ margin-top:2rem; display:flex; flex-wrap:wrap; gap:.9rem; }
.portal__note{ margin-top:1.1rem; font-size:.88rem; color:var(--ink-soft); }
.portal__note a{ color:var(--primary); text-decoration:underline; text-underline-offset:2px; }

/* portal CSS mockup (no stock photo) */
.mock{ background:var(--paper); border:1px solid var(--line); border-radius:18px; box-shadow:0 40px 70px -44px rgba(10,39,48,.5); overflow:hidden; }
.mock__bar{ display:flex; gap:.4rem; padding:.9rem 1.1rem; border-bottom:1px solid var(--line-soft); background:var(--bg-2); }
.mock__bar i{ width:11px; height:11px; border-radius:50%; background:var(--line); display:block; }
.mock__body{ padding:1.4rem; display:grid; gap:1rem; }
.mock__pay{ background:linear-gradient(135deg,var(--primary),#169a8f); color:#fff; border-radius:12px; padding:1.2rem 1.3rem; display:flex; justify-content:space-between; align-items:center; }
.mock__pay small{ display:block; font-family:"Space Mono",monospace; font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; opacity:.85; }
.mock__pay b{ font-family:"Fraunces",serif; font-weight:500; font-size:1.7rem; }
.mock__pay span{ background:rgba(255,255,255,.2); border:1px solid rgba(255,255,255,.4); border-radius:99px; padding:.5em 1.1em; font-size:.85rem; font-weight:600; }
.mock__row{ display:flex; align-items:center; gap:.9rem; padding:.9rem 1rem; border:1px solid var(--line); border-radius:12px; }
.mock__row svg{ width:22px; height:22px; color:var(--primary); flex-shrink:0; }
.mock__row b{ font-weight:600; font-size:.95rem; } .mock__row p{ margin:0; font-size:.82rem; color:var(--ink-soft); }
.mock__row .tag{ margin-left:auto; font-family:"Space Mono",monospace; font-size:.66rem; letter-spacing:.08em; color:var(--accent); }

/* ---- Steps ---- */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; position:relative; counter-reset:step; }
.steps::before{ content:""; position:absolute; top:34px; left:8%; right:8%; height:1px; background:repeating-linear-gradient(90deg,var(--line) 0 8px, transparent 8px 16px); }
.step{ position:relative; }
.step__n{ width:68px; height:68px; border-radius:50%; background:var(--paper); border:1px solid var(--line); display:flex; align-items:center; justify-content:center; font-family:"Fraunces",serif; font-size:1.5rem; color:var(--primary); margin-bottom:1.4rem; position:relative; z-index:1; }
.section--alt .step__n{ background:var(--bg); }
.step h3{ font-family:"Fraunces",serif; font-weight:500; font-size:1.25rem; margin:0 0 .5rem; }
.step p{ margin:0; color:var(--ink-soft); font-size:.94rem; }

/* ---- States ---- */
.states{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.state{ background:var(--paper); border:1px solid var(--line); border-radius:14px; padding:1.4rem .6rem; text-align:center; transition:transform .3s,border-color .3s,background .3s; }
.state:hover{ transform:translateY(-4px); border-color:var(--primary); background:var(--bg); }
.state b{ display:block; font-family:"Fraunces",serif; font-weight:500; font-size:1.7rem; color:var(--primary); }
.state span{ font-size:.82rem; color:var(--ink-soft); }

/* ---- Testimonials ---- */
.quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.quote{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:2rem; display:flex; flex-direction:column; gap:1.2rem; }
.quote__stars{ color:var(--accent); letter-spacing:.15em; font-size:.9rem; }
.quote p{ margin:0; font-family:"Fraunces",serif; font-size:1.18rem; line-height:1.45; color:var(--ink); flex:1; }
.quote__who{ display:flex; align-items:center; gap:.8rem; }
.quote__mono{ width:44px; height:44px; border-radius:50%; background:linear-gradient(140deg,var(--primary),var(--accent)); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:.95rem; }
.quote__who b{ display:block; font-weight:600; }
.quote__who span{ font-size:.85rem; color:var(--ink-soft); }

/* ---- Owners band ---- */
.owners{ position:relative; overflow:hidden; color:#fff; background:linear-gradient(155deg,#0a2730 0%, #0d4a48 55%, var(--primary) 130%); }
.owners .contours{ color:#fff; opacity:.12; }
.owners__in{ position:relative; z-index:1; display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.owners h2{ font-family:"Fraunces",serif; font-weight:450; font-size:clamp(2rem,1.4rem + 2.6vw,3.2rem); line-height:1.05; margin:0 0 1.2rem; }
.owners p{ color:rgba(255,255,255,.88); font-size:1.1rem; margin:0 0 2rem; max-width:34rem; }
.owners .btn--solid{ background:#fff; color:var(--primary); }
.owners .btn--solid:hover{ background:var(--bg); }
.owners .btn--ghost{ color:#fff; border-color:rgba(255,255,255,.5); }
.owners .btn--ghost:hover{ border-color:#fff; background:rgba(255,255,255,.1); }
.owners__checks{ list-style:none; margin:0; padding:0; display:grid; gap:1rem; }
.owners__checks li{ display:flex; align-items:center; gap:.8rem; font-weight:500; }
.owners__checks svg{ width:24px; height:24px; color:#fff; opacity:.9; }

/* ---- Closing ---- */
.closing{ text-align:center; }
.closing h2{ font-family:"Fraunces",serif; font-weight:450; font-size:clamp(2rem,1.4rem + 3vw,3.6rem); margin:0 0 1.6rem; text-wrap:balance; }
.closing .hero__cta{ justify-content:center; }

/* ---- Footer (dark) ---- */
.foot{ background:var(--ink); color:rgba(255,255,255,.66); padding-block:clamp(3.5rem,6vw,5rem) 2rem; }
.foot__grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr 1.1fr; gap:2.2rem; }
/* logo on a white chip — inverting it to white flattens the shield into a blob */
.foot__logo-chip{ display:inline-flex; align-items:center; height:46px; padding:0 14px; background:#fff; border-radius:11px; overflow:hidden; margin-bottom:1.1rem; }
.foot__logo{ height:88px; width:auto; display:block; margin-block:-21px; }
.foot__brand p{ margin:.3rem 0; font-size:.92rem; max-width:26rem; }
.foot h4{ font-family:"Space Mono",monospace; font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.5); margin:0 0 1.1rem; font-weight:400; }
.foot ul{ list-style:none; margin:0; padding:0; display:grid; gap:.7rem; }
.foot ul a{ color:rgba(255,255,255,.78); font-size:.92rem; transition:color .25s; }
.foot ul a:hover{ color:#fff; }
.foot .lbl{ font-family:"Space Mono",monospace; font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.45); display:block; }
.foot__base{ margin-top:3rem; padding-top:1.6rem; border-top:1px solid rgba(255,255,255,.12); display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-family:"Space Mono",monospace; font-size:.72rem; letter-spacing:.06em; color:rgba(255,255,255,.5); }

/* ---- Reveals ---- */
[data-reveal]{ opacity:0; transform:translateY(22px); transition:opacity .85s cubic-bezier(.2,.7,.2,1),transform .85s cubic-bezier(.2,.7,.2,1); transition-delay:calc(var(--d,0) * 80ms); }
[data-reveal].is-in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } *{ animation:none !important; } [data-reveal]{ opacity:1; transform:none; transition:none; } .btn{ transition:none; } }

/* ---- Responsive ---- */
@media (max-width:980px){
  .hero__grid{ grid-template-columns:1fr; }
  .hero__card{ order:-1; }
  .vcards{ grid-template-columns:1fr 1fr; }
  .portal__grid,.owners__in{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr 1fr; } .steps::before{ display:none; }
  .states{ grid-template-columns:repeat(4,1fr); }
  .quotes{ grid-template-columns:1fr; }
  .stats__grid{ grid-template-columns:1fr 1fr; gap:1.6rem; }
  .foot__grid{ grid-template-columns:1fr 1fr; } .foot__brand{ grid-column:1 / -1; }
}
@media (max-width:620px){
  .nav__links{ position:fixed; inset:76px 0 auto 0; flex-direction:column; gap:0; background:var(--paper); border-bottom:1px solid var(--line); padding:.5rem 6vw 1.2rem; transform:translateY(-130%); transition:transform .4s cubic-bezier(.2,.7,.2,1); box-shadow:0 20px 40px -30px rgba(0,0,0,.5); }
  .nav__links.open{ transform:translateY(0); }
  .nav__links a{ padding:.9rem 0; border-bottom:1px solid var(--line-soft); width:100%; }
  .nav__apply{ display:none; }
  .nav__toggle{ display:inline-flex; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; }
  .nav__toggle span{ width:24px; height:2px; background:var(--ink); transition:transform .3s,opacity .3s; }
  .nav__toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .nav__toggle.open span:nth-child(2){ opacity:0; }
  .nav__toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
  .vcards{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr; }
  .states{ grid-template-columns:repeat(2,1fr); }
  .stats__grid{ grid-template-columns:1fr 1fr; }
  .foot__grid{ grid-template-columns:1fr; }
  .foot__base{ justify-content:flex-start; }
}
