/* ============================================================
   Shepherd's Pasture — Stylesheet
   Brand: Sage #808D74 · Gold #C8A960 · Off-White #FDFDFE · Near-Black #0F0F0F
   Fonts: Cinzel (headings), Cardo (body) — self-hosted woff2
   ============================================================ */

/* ---- Self-hosted fonts ---- */
@font-face { font-family:'Cinzel'; font-style:normal; font-weight:400; font-display:swap; src:url('/assets/fonts/cinzel-400.woff2') format('woff2'); }
@font-face { font-family:'Cinzel'; font-style:normal; font-weight:500; font-display:swap; src:url('/assets/fonts/cinzel-500.woff2') format('woff2'); }
@font-face { font-family:'Cinzel'; font-style:normal; font-weight:600; font-display:swap; src:url('/assets/fonts/cinzel-600.woff2') format('woff2'); }
@font-face { font-family:'Cinzel'; font-style:normal; font-weight:700; font-display:swap; src:url('/assets/fonts/cinzel-700.woff2') format('woff2'); }
@font-face { font-family:'Cardo'; font-style:normal; font-weight:400; font-display:swap; src:url('/assets/fonts/cardo-400.woff2') format('woff2'); }
@font-face { font-family:'Cardo'; font-style:italic; font-weight:400; font-display:swap; src:url('/assets/fonts/cardo-400-italic.woff2') format('woff2'); }
@font-face { font-family:'Cardo'; font-style:normal; font-weight:700; font-display:swap; src:url('/assets/fonts/cardo-700.woff2') format('woff2'); }

/* ---- Tokens ---- */
:root{
  --sage:#808D74; --sage-dark:#5f6a55; --sage-light:#9aa68c; --sage-mist:#eef0ea;
  --gold:#C8A960; --gold-dark:#a8893f; --gold-light:#ddc58c;
  --off-white:#FDFDFE; --cream:#f6f4ee; --near-black:#0F0F0F; --ink:#23241f;
  --muted:#6b6f63; --line:#e2e0d6;
  --shadow-sm:0 2px 8px rgba(15,15,15,.06);
  --shadow:0 12px 32px rgba(15,15,15,.10);
  --shadow-lg:0 24px 60px rgba(15,15,15,.18);
  --radius:14px; --radius-lg:22px;
  --wrap:1180px; --serif:'Cardo',Georgia,'Times New Roman',serif; --display:'Cinzel',Georgia,serif;
}

/* ---- Reset / base ---- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--serif);font-size:1.075rem;line-height:1.7;color:var(--ink);background:var(--off-white);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block;height:auto}
a{color:var(--sage-dark);text-decoration:none;transition:color .2s}
a:hover{color:var(--gold-dark)}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.18;color:var(--near-black);margin:0 0 .5em;letter-spacing:.01em}
h1{font-size:clamp(2.1rem,5vw,3.5rem)}
h2{font-size:clamp(1.7rem,3.6vw,2.6rem)}
h3{font-size:1.3rem}
p{margin:0 0 1.1em}
.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 22px}
.muted{color:var(--muted)}
.center{text-align:center}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--gold);color:#000;padding:10px 16px;z-index:200}
.skip-link:focus{left:8px;top:8px}
section{padding:clamp(3rem,7vw,6rem) 0}

/* ---- Buttons ---- */
.btn{display:inline-block;font-family:var(--display);font-weight:600;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;padding:.95em 1.9em;border-radius:50px;cursor:pointer;border:2px solid transparent;transition:all .22s ease;text-align:center}
.btn-gold{background:var(--gold);color:#1a1405;border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-dark);border-color:var(--gold-dark);color:#fff;transform:translateY(-2px)}
.btn-sage{background:var(--sage);color:#fff;border-color:var(--sage)}
.btn-sage:hover{background:var(--sage-dark);border-color:var(--sage-dark);color:#fff;transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--sage-dark);border-color:var(--sage)}
.btn-outline:hover{background:var(--sage);color:#fff}
.btn-outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn-outline-light:hover{background:#fff;color:var(--near-black);border-color:#fff}
.btn-lg{padding:1.1em 2.4em;font-size:.9rem}

/* ---- Top bar ---- */
.topbar{background:var(--near-black);color:#d9d6cb;font-size:.85rem}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;height:40px}
.topbar a{color:#d9d6cb;letter-spacing:.04em}
.topbar a:hover{color:var(--gold-light)}
.topbar-social{display:flex;gap:18px}

/* ---- Header / nav ---- */
.site-header{position:sticky;top:0;z-index:120;background:rgba(253,253,254,.96);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);transition:box-shadow .3s}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:104px}
.brand-mark{width:104px;height:104px;object-fit:contain;display:block}
.primary-nav ul{display:flex;align-items:center;gap:24px;list-style:none;margin:0;padding:0}
.primary-nav a{font-family:var(--display);font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);font-weight:500}
.primary-nav a:hover,.primary-nav a.active{color:var(--gold-dark)}
.primary-nav a.active{border-bottom:2px solid var(--gold)}
.nav-cta a{color:#1a1405 !important}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:26px;height:2px;background:var(--near-black);transition:.3s}

/* ---- Hero ---- */
.hero{position:relative;min-height:78vh;display:flex;align-items:center;color:#fff;text-align:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05)}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,15,15,.45),rgba(15,15,15,.30) 40%,rgba(95,106,85,.55))}
.hero-content{position:relative;z-index:2;max-width:880px;margin:0 auto;padding:6rem 22px}
.hero .eyebrow{color:var(--gold-light)}
.hero h1{color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.4)}
.hero p.lead{font-size:1.3rem;color:#f3f1ea;margin:1rem auto 2rem;max-width:640px}
.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ---- Eyebrow / section heads ---- */
.eyebrow{font-family:var(--display);text-transform:uppercase;letter-spacing:.26em;font-size:.8rem;font-weight:600;color:var(--gold-dark);margin-bottom:.7rem;display:block}
.section-head{max-width:720px;margin:0 auto 3rem;text-align:center}
.section-head.left{margin-left:0;text-align:left}
.divider{width:64px;height:3px;background:var(--gold);margin:1.2rem auto;border-radius:2px}
.section-head.left .divider{margin-left:0}

/* ---- Layout helpers ---- */
.bg-sage-mist{background:var(--sage-mist)}
.bg-cream{background:var(--cream)}
.bg-dark{background:var(--near-black);color:#e9e7dd}
.bg-dark h2,.bg-dark h3{color:#fff}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split.reverse .split-media{order:2}
.split-media img{border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.grid{display:grid;gap:28px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}

/* ---- Cards ---- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .25s,box-shadow .25s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card-media{position:relative;aspect-ratio:4/3;overflow:hidden}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.card:hover .card-media img{transform:scale(1.06)}
.card-badge{position:absolute;top:14px;right:14px;background:var(--gold);color:#1a1405;font-family:var(--display);font-size:.72rem;font-weight:700;letter-spacing:.08em;padding:.4em .9em;border-radius:50px;text-transform:uppercase}
.card-body{padding:1.5rem 1.6rem 1.7rem;display:flex;flex-direction:column;flex:1}
.card-body h3{margin-bottom:.3rem}
.card-eyebrow{font-size:.78rem;color:var(--gold-dark);letter-spacing:.1em;text-transform:uppercase;font-family:var(--display);margin-bottom:.6rem}
.card-body .btn{margin-top:auto;align-self:flex-start}

/* ---- Feature list ---- */
.feature-list{list-style:none;margin:0;padding:0;columns:2;column-gap:2.5rem}
.feature-list li{padding:.5rem 0 .5rem 1.9rem;position:relative;break-inside:avoid;border-bottom:1px solid var(--line)}
.feature-list li::before{content:"✦";position:absolute;left:0;color:var(--gold-dark)}

/* ---- Stat strip ---- */
.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stat .num{font-family:var(--display);font-size:2.6rem;color:var(--gold-dark);font-weight:700;line-height:1}
.stat .label{font-size:.95rem;color:var(--muted);letter-spacing:.04em}

/* ---- Reviews ---- */
.review-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-sm);height:100%}
.stars{color:var(--gold);letter-spacing:2px;font-size:1.05rem}
.review-text{font-style:italic;color:var(--ink);margin:1rem 0}
.review-name{font-family:var(--display);font-weight:600;color:var(--near-black)}

/* ---- Distances / pills ---- */
.pill-row{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.pill{background:#fff;border:1px solid var(--line);border-radius:50px;padding:.6em 1.3em;font-size:.95rem;box-shadow:var(--shadow-sm)}

/* ---- Facility detail ---- */
.page-hero{position:relative;min-height:46vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.page-hero .hero-bg{transform:none}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,15,15,.15),rgba(15,15,15,.7))}
.page-hero-content{position:relative;z-index:2;padding:2.5rem 0 3rem}
.page-hero h1{color:#fff}
.breadcrumbs{font-size:.85rem;color:var(--muted);margin-bottom:1rem}
.breadcrumbs a{color:var(--sage-dark)}
.breadcrumbs span{color:var(--gold-dark)}

/* ---- Video ---- */
.video-frame{position:relative;aspect-ratio:16/9;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);background:#000}
.video-frame iframe,.video-frame video{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-placeholder{position:relative;aspect-ratio:16/9;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;background-size:cover;background-position:center}
.video-placeholder::after{content:"";position:absolute;inset:0;background:rgba(15,15,15,.5)}
.video-placeholder .vp-inner{position:relative;z-index:2;padding:1.5rem}
.play-badge{width:74px;height:74px;border-radius:50%;background:rgba(255,255,255,.18);border:2px solid #fff;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;backdrop-filter:blur(2px)}
.play-badge::before{content:"";border-style:solid;border-width:12px 0 12px 20px;border-color:transparent transparent transparent #fff;margin-left:4px}

/* ---- Interactive map ---- */
.map-stage{position:relative;max-width:1000px;margin:0 auto;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);background:var(--sage-mist)}
.map-stage img{width:100%;display:block}
.hotspot{position:absolute;transform:translate(-50%,-50%);width:38px;height:38px;border-radius:50%;background:var(--gold);border:3px solid #fff;box-shadow:0 4px 14px rgba(0,0,0,.35);cursor:pointer;display:flex;align-items:center;justify-content:center;color:#1a1405;font-family:var(--display);font-weight:700;animation:pulse 2.4s infinite}
.hotspot:hover,.hotspot:focus{background:var(--sage);color:#fff;outline:none;transform:translate(-50%,-50%) scale(1.12)}
.hotspot .tip{position:absolute;bottom:130%;left:50%;transform:translateX(-50%);background:var(--near-black);color:#fff;font-family:var(--serif);font-size:.8rem;letter-spacing:0;text-transform:none;padding:.35em .7em;border-radius:8px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s}
.hotspot:hover .tip,.hotspot:focus .tip{opacity:1}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(200,169,96,.6)}70%{box-shadow:0 0 0 16px rgba(200,169,96,0)}100%{box-shadow:0 0 0 0 rgba(200,169,96,0)}}
.map-legend{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:1.8rem}
.map-legend button{background:#fff;border:1px solid var(--line);border-radius:50px;padding:.5em 1.1em;font-family:var(--serif);cursor:pointer;font-size:.95rem;transition:.2s}
.map-legend button:hover{background:var(--sage);color:#fff;border-color:var(--sage)}

/* ---- Modal ---- */
.modal{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(15,15,15,.8)}
.modal.open{display:flex}
.modal-box{background:#fff;border-radius:var(--radius-lg);max-width:880px;width:100%;overflow:hidden;box-shadow:var(--shadow-lg);animation:pop .25s ease}
@keyframes pop{from{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:1.1rem 1.5rem;border-bottom:1px solid var(--line)}
.modal-head h3{margin:0}
.modal-close{background:none;border:0;font-size:1.6rem;line-height:1;cursor:pointer;color:var(--muted)}
.modal-body{padding:1.5rem}

/* ---- Forms ---- */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.5rem,4vw,2.6rem);box-shadow:var(--shadow)}
.field{margin-bottom:1.3rem}
.field label{display:block;font-family:var(--display);font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);margin-bottom:.5rem;font-weight:600}
.field .req{color:var(--gold-dark)}
.field input,.field textarea,.field select{width:100%;font-family:var(--serif);font-size:1rem;padding:.85em 1em;border:1px solid var(--line);border-radius:10px;background:var(--off-white);color:var(--ink);transition:border .2s,box-shadow .2s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--sage);box-shadow:0 0 0 3px rgba(128,141,116,.2)}
.field textarea{min-height:130px;resize:vertical}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}
.checks{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.check{display:flex;align-items:center;gap:.6rem;background:var(--off-white);border:1px solid var(--line);border-radius:10px;padding:.7em .9em;cursor:pointer;font-size:.97rem}
.check input{width:auto}
.check:hover{border-color:var(--sage)}
.form-note{font-size:.85rem;color:var(--muted)}
.alert{padding:1em 1.2em;border-radius:10px;margin-bottom:1.3rem;font-size:.97rem}
.alert-success{background:#eef5e9;border:1px solid #bcd9a8;color:#3a5a2a}
.alert-error{background:#fbecea;border:1px solid #e6b5ad;color:#8a2c1d}

/* ---- Calendar ---- */
.cal-controls{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:1.4rem;flex-wrap:wrap}
.cal-controls h3{margin:0}
.cal-nav button{background:#fff;border:1px solid var(--line);border-radius:8px;width:42px;height:42px;font-size:1.2rem;cursor:pointer}
.cal-nav button:hover{background:var(--sage);color:#fff}
.calendar{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.calendar th{background:var(--sage);color:#fff;font-family:var(--display);font-weight:500;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;padding:.7em}
.calendar td{border:1px solid var(--line);height:84px;vertical-align:top;padding:.4em;position:relative;font-size:.85rem}
.calendar td.empty{background:var(--cream)}
.calendar td .daynum{font-family:var(--display);color:var(--muted)}
.calendar td.today{outline:2px solid var(--gold)}
.cal-tag{display:block;font-size:.68rem;border-radius:5px;padding:.15em .4em;margin-top:.25em;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal-tag.reserved{background:#f2dede;color:#9b3127}
.cal-tag.unavailable{background:#ece9e2;color:#6b6f63}
.legend-dots{display:flex;gap:18px;flex-wrap:wrap;margin-top:1.2rem;font-size:.9rem}
.legend-dots span{display:inline-flex;align-items:center;gap:.5em}
.dot{width:14px;height:14px;border-radius:4px;display:inline-block}
.dot.reserved{background:#e0a59c}.dot.unavailable{background:#cfccc2}.dot.available{background:#bcd9a8}

/* ---- Attractions ---- */
.attraction-group{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem 1.6rem;box-shadow:var(--shadow-sm);break-inside:avoid;margin-bottom:1.5rem}
.attraction-group h3{color:var(--sage-dark);margin-bottom:.6rem}
.attraction-group ul{margin:0;padding-left:1.1rem}
.attraction-group li{margin-bottom:.3rem}
.masonry{columns:3;column-gap:1.5rem}
@media(max-width:900px){.masonry{columns:2}}
@media(max-width:600px){.masonry{columns:1}}

/* ---- FAQ ---- */
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:1rem;overflow:hidden}
.faq summary{cursor:pointer;padding:1.1em 1.3em;font-family:var(--display);font-weight:600;font-size:1.05rem;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--gold-dark);font-size:1.4rem}
.faq details[open] summary::after{content:"–"}
.faq details[open] summary{background:var(--sage-mist)}
.faq .faq-a{padding:0 1.3em 1.2em}

/* ---- CTA bar (persistent) ---- */
.cta-bar{position:sticky;bottom:0;z-index:90;background:linear-gradient(135deg,var(--sage-dark),var(--sage));color:#fff;box-shadow:0 -6px 24px rgba(15,15,15,.18);transform:translateY(100%);transition:transform .4s ease}
.cta-bar.show{transform:translateY(0)}
.cta-bar-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:.9rem 22px}
.cta-bar-text{margin:0;font-size:1.05rem}
.cta-bar-actions{display:flex;gap:12px;flex-shrink:0}

/* ---- Footer ---- */
.site-footer{background:var(--near-black);color:#c7c4ba;padding-top:4rem}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2.5rem;padding-bottom:3rem}
.footer-logo{width:90px;height:90px;border-radius:50%;object-fit:cover;margin-bottom:1rem}
.footer-tag{font-size:.95rem;line-height:1.7}
.footer-col h3{color:#fff;font-size:1rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:1rem}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{margin-bottom:.5rem}
.footer-col a{color:#c7c4ba}
.footer-col a:hover{color:var(--gold-light)}
.footer-social{display:flex;gap:16px;margin-top:1rem}
.footer-bottom{border-top:1px solid #2a2a26;padding:1.3rem 0}
.footer-bottom-inner{display:flex;justify-content:space-between;font-size:.85rem;color:#8d897e}
.footer-bottom a{color:#8d897e}

/* ---- Admin ---- */
.admin-body{background:var(--sage-mist);min-height:100vh}
.admin-login{max-width:420px;margin:6vh auto;padding:0 20px}
.admin-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:2.4rem}
.admin-top{background:var(--near-black);color:#fff;padding:1rem 0}
.admin-top-inner{display:flex;justify-content:space-between;align-items:center}
.admin-top a{color:#d9d6cb}
.admin-wrap{max-width:1100px;margin:2rem auto;padding:0 20px}
.admin-tabs{display:flex;gap:10px;margin-bottom:1.5rem;flex-wrap:wrap}
.admin-tabs a{background:#fff;border:1px solid var(--line);padding:.6em 1.2em;border-radius:50px;font-family:var(--display);font-size:.85rem;letter-spacing:.04em}
.admin-tabs a.active{background:var(--sage);color:#fff;border-color:var(--sage)}
.table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.table th{background:var(--sage);color:#fff;text-align:left;padding:.8em 1em;font-family:var(--display);font-weight:500;font-size:.82rem;letter-spacing:.04em}
.table td{padding:.8em 1em;border-top:1px solid var(--line);font-size:.95rem;vertical-align:middle}
.table tr:hover td{background:var(--cream)}
.badge{display:inline-block;padding:.25em .7em;border-radius:50px;font-size:.75rem;font-weight:700}
.badge.reserved{background:#f2dede;color:#9b3127}
.badge.unavailable{background:#ece9e2;color:#6b6f63}
.inline-form{display:inline}
.btn-sm{padding:.45em 1em;font-size:.72rem}
.btn-danger{background:#b5392b;border-color:#b5392b;color:#fff}
.btn-danger:hover{background:#8a2c1d;border-color:#8a2c1d}

/* ---- Misc ---- */
.prose p{max-width:68ch}
.lead{font-size:1.2rem}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.tag-row{display:flex;gap:10px;flex-wrap:wrap;margin:.5rem 0 1.5rem}
.tag{background:var(--sage-mist);color:var(--sage-dark);border-radius:50px;padding:.35em 1em;font-size:.85rem;font-family:var(--display);letter-spacing:.04em}

/* ---- Responsive ---- */
@media(max-width:980px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .grid-3{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:820px){
  .nav-toggle{display:flex}
  .primary-nav{position:fixed;inset:0 0 0 auto;width:min(320px,82vw);background:var(--off-white);transform:translateX(100%);transition:transform .3s ease;box-shadow:var(--shadow-lg);padding:90px 28px 28px;overflow-y:auto}
  .primary-nav.open{transform:translateX(0)}
  .primary-nav ul{flex-direction:column;align-items:flex-start;gap:6px}
  .primary-nav li{width:100%;border-bottom:1px solid var(--line)}
  .primary-nav a{display:block;padding:.8em 0}
  .primary-nav a.active{border-bottom:2px solid transparent}
  .nav-cta{margin-top:1rem;border-bottom:0 !important}
  .nav-cta a{display:inline-block !important}
  .split{grid-template-columns:1fr}
  .split.reverse .split-media{order:0}
  .stat-strip{grid-template-columns:1fr 1fr}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .cta-bar-inner{flex-direction:column;text-align:center}
  .cta-bar-text{font-size:.95rem}
  .feature-list{columns:1}
  .footer-bottom-inner{flex-direction:column;gap:.4rem;text-align:center}
}
@media(max-width:520px){
  .checks{grid-template-columns:1fr}
  .calendar td{height:62px;font-size:.75rem}
  .hero{min-height:70vh}
}
@media(prefers-reduced-motion:reduce){*{animation:none !important;transition:none !important}}
