*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --red:#c0392b; --red2:#e04535; --ink:#111317; --ink2:#1c2026;
  --white:#fff; --off:#f8f7f4; --slate:#f1f0ed; --gold:#f0b429;
  --text:#2c2c2c; --muted:#6b7280; --border:#e4e4e0; --green:#16a34a;
  --radius:12px;
  /* aliases so blog content styles resolve against the same tokens */
  --paper:var(--white); --line:var(--border); --tx:var(--text);
}
a{color:inherit;text-decoration:none}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--white);color:var(--text);-webkit-font-smoothing:antialiased}

/* ══════════════ TOP BAR ══════════════ */
.topbar{background:var(--ink);padding:0;display:flex;height:40px;align-items:stretch}
.topbar-left{display:flex;align-items:center;gap:24px;padding:0 40px;flex:1}
.topbar-item{display:flex;align-items:center;gap:6px;font-size:0.72rem;font-weight:600;color:rgba(255,255,255,0.55);letter-spacing:0.3px}
.topbar-item span{color:rgba(255,255,255,0.85)}
.topbar-cta{background:var(--red);color:white;padding:0 24px;display:flex;align-items:center;gap:7px;font-size:0.75rem;font-weight:700;letter-spacing:0.5px;text-decoration:none;white-space:nowrap;transition:background 0.15s}
.topbar-cta:hover{background:var(--red2)}

/* ══════════════ NAV ══════════════ */
nav{position:sticky;top:0;z-index:300;background:white;border-bottom:2px solid var(--red);display:flex;align-items:center;justify-content:space-between;padding:0 40px;height:62px;box-shadow:0 2px 16px rgba(0,0,0,0.06)}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none}
/* SVG logo mark - road through L plate */
.nav-logo svg{height:38px;width:auto}
.nav-links{display:flex;gap:0;list-style:none}
.nav-links a{color:var(--text);text-decoration:none;font-size:0.82rem;font-weight:600;padding:0 16px;height:62px;display:flex;align-items:center;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color 0.15s,border-color 0.15s}
.nav-links a:hover{color:var(--red);border-color:var(--red)}
.nav-right{display:flex;align-items:center;gap:10px}
.nav-tel{font-size:0.82rem;font-weight:700;color:var(--ink);text-decoration:none;padding:0 8px}
.nav-tel:hover{color:var(--red)}
.nav-btn{background:var(--red);color:white;padding:10px 20px;border-radius:6px;font-weight:700;font-size:0.8rem;text-decoration:none;transition:background 0.15s,transform 0.15s;letter-spacing:0.3px}
.nav-btn:hover{background:var(--red2);transform:translateY(-1px)}

/* ══════════════ HERO ══════════════ */
.hero{min-height:calc(100vh - 102px);background:var(--ink);display:grid;grid-template-columns:54% 46%;overflow:hidden}
.hero-l{display:flex;flex-direction:column;justify-content:center;padding:64px 52px 64px 56px;position:relative}
/* Thin red left accent bar */
.hero-l::before{content:'';position:absolute;left:0;top:15%;bottom:15%;width:3px;background:var(--red);border-radius:0 2px 2px 0}
/* Credential strip */
.hero-strip{display:flex;align-items:center;gap:8px;margin-bottom:28px}
.strip-pill{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);padding:5px 11px;border-radius:4px;font-size:0.71rem;font-weight:700;color:rgba(255,255,255,0.72);letter-spacing:0.4px}
.strip-pill.hot{background:rgba(192,57,43,0.2);border-color:rgba(192,57,43,0.45);color:#ff8a7a}
.strip-dot{width:3px;height:3px;background:rgba(255,255,255,0.2);border-radius:50%}
/* Main headline */
.hero h1{font-family:'Syne',sans-serif;font-size:clamp(40px,4.6vw,68px);line-height:1.0;color:white;font-weight:800;letter-spacing:-1.5px;margin-bottom:18px}
.hero h1 .red{color:var(--red)}
.hero h1 .block{display:block}
/* Sub */
.hero-sub{color:rgba(255,255,255,0.55);font-size:1rem;line-height:1.75;max-width:420px;margin-bottom:32px;font-weight:400}
/* Stats row */
.hero-stats{display:flex;border:1px solid rgba(255,255,255,0.08);border-radius:10px;overflow:hidden;margin-bottom:32px;background:rgba(255,255,255,0.03)}
.hstat{flex:1;padding:14px 0;text-align:center;border-right:1px solid rgba(255,255,255,0.07)}
.hstat:last-child{border-right:none}
.hstat-val{font-family:'Syne',sans-serif;font-size:1.55rem;font-weight:800;color:var(--gold);display:block;line-height:1}
.hstat-lbl{font-size:0.6rem;font-weight:600;color:rgba(255,255,255,0.35);text-transform:uppercase;letter-spacing:0.8px;display:block;margin-top:3px}
/* CTA */
.hero-btns{display:flex;gap:10px;flex-wrap:wrap}
.btn-red{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:white;padding:15px 28px;border-radius:8px;font-weight:700;font-size:0.92rem;text-decoration:none;box-shadow:0 4px 20px rgba(192,57,43,0.4);transition:background 0.15s,transform 0.15s}
.btn-red:hover{background:var(--red2);transform:translateY(-2px)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;background:transparent;border:1.5px solid rgba(255,255,255,0.18);color:rgba(255,255,255,0.78);padding:14px 22px;border-radius:8px;font-weight:600;font-size:0.87rem;text-decoration:none;transition:border-color 0.15s,background 0.15s,transform 0.15s}
.btn-ghost:hover{border-color:rgba(255,255,255,0.4);background:rgba(255,255,255,0.05);transform:translateY(-2px)}
.hero-note{margin-top:16px;font-size:0.72rem;color:rgba(255,255,255,0.25)}
/* Hero photo */
.hero-r{position:relative;overflow:hidden}
.hero-r img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.hero-r::before{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(to right,rgba(17,19,23,0.45) 0%,transparent 30%),linear-gradient(to top,rgba(17,19,23,0.7) 0%,transparent 40%)}
/* Floating badge */
.hero-badge{position:absolute;bottom:28px;left:28px;z-index:5;background:rgba(17,19,23,0.88);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,0.1);border-radius:10px;padding:13px 16px;display:flex;gap:11px;align-items:center;max-width:200px}
.hb-icon{font-size:1.5rem;flex-shrink:0}
.hb-strong{display:block;font-size:0.8rem;font-weight:700;color:white}
.hb-sub{font-size:0.68rem;color:rgba(255,255,255,0.4);display:block}
.hb-stars{font-size:0.65rem;color:var(--gold);display:block;margin-top:2px}
.hero-dvsa{position:absolute;top:20px;right:20px;z-index:5;background:var(--red);border-radius:6px;padding:7px 12px;text-align:center}
.hero-dvsa span{display:block;color:white;font-size:0.58rem;font-weight:800;letter-spacing:1.5px}
.hero-dvsa strong{display:block;color:white;font-size:0.75rem;font-weight:700;margin-top:1px}

/* ══════════════ TRUST BAR ══════════════ */
.trust-bar{background:var(--ink2);padding:20px 40px;display:flex;align-items:center;justify-content:center;gap:0;border-bottom:1px solid rgba(255,255,255,0.05)}
.tbar-item{display:flex;align-items:center;gap:10px;padding:0 36px;border-right:1px solid rgba(255,255,255,0.08);flex:0 0 auto}
.tbar-item:last-child{border-right:none}
.tbar-icon{flex-shrink:0;color:var(--red);display:flex;align-items:center;justify-content:center}
.tbar-text strong{display:block;font-size:0.82rem;font-weight:700;color:white}
.tbar-text span{font-size:0.7rem;color:rgba(255,255,255,0.4)}

/* ══════════════ SECTIONS ══════════════ */
.sec{padding:88px 56px}
.sec-inner{max-width:1120px;margin:0 auto}
.tag{font-size:0.68rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--red);margin-bottom:8px;display:block}
.h2{font-family:'Syne',sans-serif;font-size:clamp(26px,2.8vw,40px);font-weight:800;line-height:1.1;letter-spacing:-0.5px;color:var(--ink)}
.h2 em{font-style:italic;font-family:'Georgia',serif;color:var(--red);font-weight:400}
.lead{font-size:0.97rem;line-height:1.78;color:var(--muted);max-width:540px;margin-top:10px}

/* ══════════════ WHY ══════════════ */
.why{background:var(--off)}
.why-wrap{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;margin-top:52px}
.why-list{display:flex;flex-direction:column;gap:0}
.wi{display:flex;gap:16px;padding:20px 0;border-bottom:1px solid var(--border)}
.wi:last-child{border-bottom:none;padding-bottom:0}
.wi:first-child{padding-top:0}
.wi-num{font-family:'Syne',sans-serif;font-size:0.85rem;font-weight:800;color:var(--red);min-width:22px;margin-top:2px}
.wi-title{font-size:0.92rem;font-weight:700;color:var(--ink);margin-bottom:4px}
.wi-body{font-size:0.84rem;line-height:1.65;color:var(--muted)}
.why-card{background:var(--ink);border-radius:14px;padding:36px 32px;position:relative;overflow:hidden}
.why-card::after{content:'\201C';font-family:'Georgia',serif;font-size:140px;line-height:0.7;color:rgba(240,180,41,0.08);position:absolute;top:16px;left:16px}
.wc-q{font-family:'Georgia',serif;font-style:italic;font-size:1.15rem;line-height:1.65;color:rgba(255,255,255,0.87);margin-bottom:18px;position:relative;z-index:1}
.wc-cite{font-size:0.75rem;font-weight:600;color:var(--gold);position:relative;z-index:1}
.wc-stars{color:var(--gold);font-size:0.75rem;margin-bottom:8px;display:block;position:relative;z-index:1}
.wc-stats{display:flex;gap:0;margin-top:26px;padding-top:20px;border-top:1px solid rgba(255,255,255,0.07);position:relative;z-index:1}
.wcs{flex:1}
.wcs-n{font-family:'Syne',sans-serif;font-size:1.8rem;font-weight:800;color:var(--gold);line-height:1;display:block}
.wcs-l{font-size:0.62rem;color:rgba(255,255,255,0.35);text-transform:uppercase;letter-spacing:0.8px;display:block;margin-top:3px}
.wcs+.wcs{border-left:1px solid rgba(255,255,255,0.07);padding-left:20px;margin-left:8px}

/* ══════════════ PASS WALL ══════════════ */
.passes{background:var(--ink)}
.passes-head{text-align:center;margin-bottom:48px}
.passes-head .h2{color:white}
.passes-head .lead{margin:10px auto 0;color:rgba(255,255,255,0.4);text-align:center}
.passes-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.pc{border-radius:10px;overflow:hidden;aspect-ratio:3/4;position:relative;cursor:default;transition:transform 0.25s,box-shadow 0.25s}
.pc:hover{transform:translateY(-5px);box-shadow:0 16px 36px rgba(0,0,0,0.45)}
.pc img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.pc-foot{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(17,19,23,0.9) 0%,transparent 100%);padding:18px 10px 10px}
.pc-pill{display:inline-flex;align-items:center;gap:3px;background:var(--green);color:white;font-size:0.62rem;font-weight:800;padding:3px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:0.3px}
.passes-foot{text-align:center;margin-top:38px}
.passes-foot p{color:rgba(255,255,255,0.35);font-size:0.87rem;margin-bottom:14px}

/* ══════════════ REVIEWS ══════════════ */
.reviews{background:var(--slate)}
.reviews-head{text-align:center;margin-bottom:48px}
.reviews-head .lead{margin:10px auto 0;text-align:center}
.rg{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.rc{background:white;border-radius:10px;padding:24px 22px;border:1.5px solid var(--border);transition:transform 0.2s,box-shadow 0.2s,border-color 0.2s}
.rc:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(0,0,0,0.07);border-color:var(--gold)}
.rc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.rc-name{font-weight:700;font-size:0.88rem;color:var(--ink)}
.rc-loc{font-size:0.7rem;color:var(--muted);margin-top:2px}
.rc-stars{color:var(--gold);font-size:0.8rem;letter-spacing:1px}
.rc-body{font-size:0.855rem;line-height:1.72;color:#475569}
.rc-body::before{content:'\201C';font-family:'Georgia',serif;font-size:2rem;line-height:0;vertical-align:-0.4rem;color:var(--gold);opacity:0.28;margin-right:2px}
.rc-ok{display:inline-flex;align-items:center;gap:4px;margin-top:12px;font-size:0.68rem;color:var(--green);font-weight:700}

/* ══════════════ BLOG PREVIEW ══════════════ */
.bp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.bp-card{display:flex;flex-direction:column;background:white;border-radius:10px;padding:26px 24px;border:1.5px solid var(--border);text-decoration:none;transition:transform 0.2s,box-shadow 0.2s,border-color 0.2s}
.bp-card:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(0,0,0,0.07);border-color:var(--red)}
.bp-tag{align-self:flex-start;background:#fbece9;color:var(--red);font-weight:700;font-size:0.68rem;letter-spacing:0.5px;text-transform:uppercase;padding:5px 11px;border-radius:999px;margin-bottom:14px}
.bp-card h3{font-family:'Syne',sans-serif;font-size:1.05rem;line-height:1.3;color:var(--ink);margin-bottom:8px}
.bp-card p{font-size:0.86rem;line-height:1.65;color:var(--muted);flex:1}
.bp-read{margin-top:16px;font-size:0.82rem;font-weight:700;color:var(--red)}
.bp-card:hover .bp-read{color:var(--red2)}
.bp-more{display:inline-flex;align-items:center;gap:8px;text-decoration:none;background:var(--ink);color:white;padding:14px 28px;border-radius:8px;font-weight:700;font-size:0.9rem;transition:background 0.15s,transform 0.15s}
.bp-more:hover{background:var(--ink2);transform:translateY(-1px)}
.blog-preview{background:var(--off)}
@media (max-width:860px){.bp-grid{grid-template-columns:1fr}}

/* ══════════════ PRICING ══════════════ */
.pricing{background:var(--off)}
.pricing-head{text-align:center;margin-bottom:48px}
.pricing-head .lead{margin:10px auto 0;text-align:center}
.pg{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.pcard{background:white;border-radius:12px;border:2px solid var(--border);padding:32px 26px;position:relative;transition:border-color 0.2s,transform 0.2s,box-shadow 0.2s}
.pcard:hover{border-color:var(--red);transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,0.07)}
.pcard.feat{background:var(--ink);border-color:var(--gold)}
.ptop-tag{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--red);color:white;font-size:0.61rem;font-weight:800;letter-spacing:1px;text-transform:uppercase;padding:3px 12px;border-radius:4px;white-space:nowrap}
.p-icon{font-size:1.7rem;margin-bottom:14px}
.pcard h3{font-family:'Syne',sans-serif;font-size:1.12rem;font-weight:800;color:var(--ink);margin-bottom:8px}
.pcard.feat h3{color:white}
.pcard p{font-size:0.83rem;line-height:1.7;color:var(--muted);margin-bottom:18px}
.pcard.feat p{color:rgba(255,255,255,0.48)}
.p-val{font-family:'Syne',sans-serif;font-size:2rem;font-weight:800;color:var(--ink)}
.pcard.feat .p-val{color:var(--gold)}
.p-val small{font-family:'Inter',sans-serif;font-size:0.72rem;color:var(--muted);font-weight:400}
.pcard.feat .p-val small{color:rgba(255,255,255,0.3)}
.p-features{margin-top:18px;display:flex;flex-direction:column;gap:7px}
.pf{display:flex;align-items:center;gap:8px;font-size:0.8rem;color:var(--text)}
.pcard.feat .pf{color:rgba(255,255,255,0.65)}
.pf-check{color:var(--green);font-weight:700;flex-shrink:0}
.pcard.feat .pf-check{color:var(--gold)}

/* ══════════════ BOOK FORM ══════════════ */
.book-sec{background:var(--ink);padding:88px 56px}
.book-inner{max-width:900px;margin:0 auto}
.book-head{text-align:center;margin-bottom:48px}
.book-head .h2{color:white}
.book-head .lead{margin:10px auto 0;text-align:center;color:rgba(255,255,255,0.45)}
.form-wrap{background:white;border-radius:16px;padding:44px 40px;box-shadow:0 24px 64px rgba(0,0,0,0.3)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.fg-full{grid-column:1/-1}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:0.78rem;font-weight:700;color:var(--ink);letter-spacing:0.2px}
.form-group input,.form-group select,.form-group textarea{padding:12px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:0.88rem;font-family:'Inter',sans-serif;color:var(--text);outline:none;transition:border-color 0.15s,box-shadow 0.15s;background:white}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(192,57,43,0.1)}
.form-group textarea{resize:vertical;min-height:90px}
.form-choices{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px}
.choice-btn{padding:11px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:0.82rem;font-weight:600;color:var(--text);background:white;cursor:pointer;transition:border-color 0.15s,background 0.15s,color 0.15s;text-align:center}
.choice-btn:hover,.choice-btn.selected{border-color:var(--red);background:rgba(192,57,43,0.06);color:var(--red)}
.form-submit{width:100%;padding:16px;background:var(--red);color:white;border:none;border-radius:8px;font-family:'Inter',sans-serif;font-size:1rem;font-weight:700;cursor:pointer;margin-top:20px;transition:background 0.15s,transform 0.15s;letter-spacing:0.3px}
.form-submit:hover{background:var(--red2);transform:translateY(-1px)}
.form-note{text-align:center;font-size:0.72rem;color:var(--muted);margin-top:12px}
/* Success message */
.form-success{display:none;text-align:center;padding:40px 20px}
.fs-icon{font-size:3rem;margin-bottom:16px;display:block}
.fs-title{font-family:'Syne',sans-serif;font-size:1.5rem;font-weight:800;color:var(--ink);margin-bottom:8px}
.fs-sub{color:var(--muted);font-size:0.95rem;line-height:1.6}

/* ══════════════ RED CTA BAND ══════════════ */
.cta-band{background:var(--red);padding:72px 56px;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'L';position:absolute;font-family:'Syne',sans-serif;font-size:260px;font-weight:800;color:rgba(255,255,255,0.04);left:40px;top:50%;transform:translateY(-50%);line-height:1;user-select:none}
.cta-band::after{content:'PASS';position:absolute;font-family:'Syne',sans-serif;font-size:100px;font-weight:800;color:rgba(255,255,255,0.04);right:40px;top:50%;transform:translateY(-50%);user-select:none}
.cb-inner{position:relative;z-index:1;max-width:560px;margin:0 auto}
.cb-inner h2{font-family:'Syne',sans-serif;font-size:clamp(26px,3.2vw,44px);font-weight:800;color:white;margin-bottom:10px;letter-spacing:-0.5px}
.cb-inner p{color:rgba(255,255,255,0.62);font-size:0.97rem;margin-bottom:28px;line-height:1.7}
.cb-btns{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.btn-white{background:white;color:var(--red);padding:14px 30px;border-radius:8px;font-weight:800;font-size:0.92rem;text-decoration:none;display:inline-flex;align-items:center;gap:7px;transition:transform 0.15s,box-shadow 0.15s}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.18)}
.btn-outline-w{background:rgba(255,255,255,0.1);border:1.5px solid rgba(255,255,255,0.25);color:white;padding:14px 24px;border-radius:8px;font-weight:600;font-size:0.87rem;text-decoration:none;display:inline-flex;align-items:center;gap:7px;transition:background 0.15s,transform 0.15s}
.btn-outline-w:hover{background:rgba(255,255,255,0.18);transform:translateY(-2px)}
.cb-tel{margin-top:14px;font-size:0.78rem;color:rgba(255,255,255,0.42)}
.cb-tel a{color:rgba(255,255,255,0.7);text-decoration:none;font-weight:600}

/* ══════════════ HOURS ══════════════ */
.hours{background:white;padding:88px 56px}
.hours-wrap{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;margin-top:48px}
.htable{}
.hr{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-radius:7px;font-size:0.88rem}
.hr:nth-child(even){background:var(--slate)}
.hr.today{background:var(--ink)}
.hr.today .hd{color:white;font-weight:700}
.hr.today .ht{color:var(--gold);font-weight:700}
.hd{font-weight:600;color:var(--text)}
.ht{color:var(--green);font-weight:600;letter-spacing:0.3px}
.contact-cards{display:flex;flex-direction:column;gap:12px;margin-top:32px}
.cc{display:flex;align-items:flex-start;gap:14px;background:var(--slate);border-radius:10px;padding:16px 18px;transition:background 0.15s}
.cc:hover{background:#eaeae6}
.cc-icon{font-size:1.2rem;flex-shrink:0;margin-top:1px}
.cc-lbl{font-size:0.65rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:2px}
.cc-val{font-size:0.9rem;font-weight:700;color:var(--ink)}
.cc-val a{color:var(--ink);text-decoration:none}
.cc-val a:hover{color:var(--red)}

/* ══════════════ FOOTER ══════════════ */
footer{background:var(--ink2);padding:44px 24px 36px;display:flex;flex-direction:column;align-items:center;gap:0;border-top:3px solid var(--red);text-align:center}
.fl-wrap{display:flex;align-items:center;gap:11px;margin-bottom:12px}
.fl-info{color:rgba(255,255,255,0.3);font-size:0.76rem;line-height:1.8}
.fl-info a{color:rgba(240,180,41,0.65);text-decoration:none}
.fc{color:rgba(255,255,255,0.17);font-size:0.7rem;text-align:right;align-self:flex-end}

/* ══════════════ ANIMATIONS ══════════════ */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.anim{opacity:0;animation:fadeUp 0.65s ease both}
.hero-strip{animation-delay:0.05s}
.hero h1{animation-delay:0.18s}
.hero-sub{animation-delay:0.3s}
.hero-stats{animation-delay:0.42s}
.hero-btns{animation-delay:0.52s}
.hero-note{animation-delay:0.6s}
.hero-badge{animation-delay:0.85s}
.reveal{opacity:0;transform:translateY(20px);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal.on{opacity:1;transform:translateY(0)}
.d1{transition-delay:0.1s}.d2{transition-delay:0.2s}.d3{transition-delay:0.3s}.d4{transition-delay:0.4s}

/* ══════════════ RESPONSIVE ══════════════ */
@media(max-width:1024px){
  .topbar{display:none}
  nav{padding:0 20px}
  .nav-links{display:none}
  .nav-tel{display:none}
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-l{padding:44px 24px;order:2}
  .hero-l::before{display:none}
  .hero-r{height:65vw;min-height:280px;order:1}
  .sec,.book-sec,.hours,.cta-band{padding:64px 24px}
  .why-wrap{grid-template-columns:1fr;gap:40px}
  .passes-grid{grid-template-columns:repeat(3,1fr)}
  .passes-grid .pc:nth-child(4),.passes-grid .pc:nth-child(5){display:none}
  .rg{grid-template-columns:1fr}
  .pg{grid-template-columns:1fr}
  .hours-wrap{grid-template-columns:1fr;gap:36px}
  .form-grid{grid-template-columns:1fr}
  .fg-full{grid-column:auto}
  .trust-bar{flex-wrap:wrap;gap:16px;padding:20px 24px}
  .tbar-item{border-right:none;padding:0 16px}
  footer{padding:38px 24px 24px;flex-direction:column}
  .fc{text-align:left}
}
@media(max-width:600px){
  .hero-stats{flex-wrap:wrap}
  .hstat{min-width:50%;border-bottom:1px solid rgba(255,255,255,0.07)}
  .passes-grid{grid-template-columns:1fr 1fr}
  .passes-grid .pc:nth-child(4){display:block}
  .passes-grid .pc:nth-child(5){display:none}
  .form-choices{grid-template-columns:1fr}
}

/* ══ OVERFLOW & MOBILE TEXT FIX ══ */
*{max-width:100%}
img,input,select,textarea,table{max-width:100%}
input,select,textarea{width:100%;min-width:0}
.form-grid{width:100%}
.form-wrap{padding:32px 20px;overflow:hidden}
.hero h1{word-break:break-word;overflow-wrap:break-word}
.h2{word-break:break-word;overflow-wrap:break-word}
.hero-stats{flex-wrap:wrap}
.topbar-left{flex-wrap:wrap;gap:8px}
.trust-bar{overflow-x:hidden}
@media(max-width:480px){
  .form-wrap{padding:24px 16px}
  .form-grid{grid-template-columns:1fr!important}
  .fg-full{grid-column:auto!important}
  .form-choices{grid-template-columns:1fr 1fr!important}
  .hero h1{font-size:clamp(34px,9vw,54px)!important}
  .h2{font-size:clamp(24px,7vw,36px)!important}
  .hstat-val{font-size:1.3rem!important}
  .nav-tel{display:none!important}
  .tbar-item{padding:0 10px!important}
  .sec,.book-sec,.hours,.cta-band{padding:52px 20px!important}
}




/* ══════════════ HAMBURGER MENU ══════════════ */

/* On mobile: hide existing nav links, show hamburger in nav */
@media(max-width:768px){
  .nav-links{display:none}
  .nav-tel{display:none}
  .nav-btn{display:none}
  .topbar{display:none}
  nav{padding:0 16px;height:56px}
}

/* Hamburger button: sits inside the nav on the right */
.ham-btn{
  display:none;
  width:40px;height:40px;
  background:var(--ink);border:none;border-radius:8px;
  cursor:pointer;
  flex-direction:column;align-items:center;justify-content:center;gap:5px;
  flex-shrink:0;
  transition:background 0.2s;
}
.ham-btn:hover{background:#2a2f36}
.ham-line{
  width:18px;height:2px;background:white;border-radius:2px;
  transition:transform 0.3s,opacity 0.2s;
  display:block;
}
.ham-btn.open .ham-line:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ham-btn.open .ham-line:nth-child(2){opacity:0}
.ham-btn.open .ham-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:768px){
  .ham-btn{display:flex}
}

/* Full screen overlay */
.mob-menu{
  position:fixed;inset:0;z-index:500;
  background:var(--off);
  display:flex;flex-direction:column;
  padding:0;
  opacity:0;visibility:hidden;
  transition:opacity 0.3s ease, visibility 0.3s;
  overflow-y:auto;
}
.mob-menu.open{opacity:1;visibility:visible}

/* Menu top bar with close button */
.mob-menu-top{
  height:56px;
  display:flex;align-items:center;justify-content:flex-end;
  padding:0 16px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.mob-close-btn{
  width:40px;height:40px;
  background:var(--ink);border:none;border-radius:8px;
  cursor:pointer;color:white;font-size:1.2rem;
  display:flex;align-items:center;justify-content:center;
}

/* Nav links list */
.mob-links{
  flex:1;display:flex;flex-direction:column;
  padding:16px 0;
}
.mob-link{
  font-family:'Syne',sans-serif;
  font-size:1.3rem;font-weight:700;
  color:var(--ink);text-decoration:none;
  padding:14px 28px;
  border-bottom:1px solid var(--border);
  display:block;
  opacity:0;transform:translateX(-16px);
  transition:opacity 0.3s ease, transform 0.3s ease, color 0.15s, background 0.15s;
}
.mob-menu.open .mob-link{opacity:1;transform:translateX(0)}
.mob-menu.open .mob-link:nth-child(1){transition-delay:0.05s}
.mob-menu.open .mob-link:nth-child(2){transition-delay:0.1s}
.mob-menu.open .mob-link:nth-child(3){transition-delay:0.15s}
.mob-menu.open .mob-link:nth-child(4){transition-delay:0.2s}
.mob-menu.open .mob-link:nth-child(5){transition-delay:0.25s}
.mob-menu.open .mob-link:nth-child(6){transition-delay:0.3s}
.mob-link:first-child{border-top:1px solid var(--border)}
.mob-link:hover{color:var(--red);background:rgba(192,57,43,0.04)}

/* Bottom actions */
.mob-menu-foot{
  padding:24px 32px 40px;
  display:flex;flex-direction:column;gap:12px;
  opacity:0;transform:translateY(10px);
  transition:opacity 0.3s ease 0.35s, transform 0.3s ease 0.35s;
}
.mob-menu.open .mob-menu-foot{opacity:1;transform:translateY(0)}
.mob-book{
  background:var(--red);color:white;
  padding:16px;border-radius:8px;
  font-family:'Syne',sans-serif;font-size:1rem;font-weight:800;
  letter-spacing:0.5px;text-transform:uppercase;
  text-align:center;text-decoration:none;
  display:block;
  transition:background 0.15s;
}
.mob-book:hover{background:var(--red2)}
.mob-tel{
  text-align:center;font-size:0.9rem;font-weight:600;
  color:var(--muted);text-decoration:none;
}
.mob-tel:hover{color:var(--red)}

#pricing a[href^="tel"]:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(192,57,43,0.4)}
#pricing a[href="#book"]:hover{border-color:var(--red);color:var(--red);transform:translateY(-2px)}

.skip-link{position:absolute;top:-60px;left:0;background:var(--red);color:white;padding:10px 18px;z-index:9999;text-decoration:none;font-weight:700;border-radius:0 0 8px 0;transition:top 0.2s}
.skip-link:focus{top:0}

/* ══════════════ BLOG CONTENT (shared header/nav/footer above, this is blog-only) ══════════════ */
.wrap{max-width:700px;margin:0 auto;padding:0 24px}
.wrap-wide{max-width:1080px;margin:0 auto;padding:0 24px}
/* ══════════════ BLOG INDEX HERO ══════════════ */
.bhero{background:var(--ink);color:#fff;padding:64px 22px 56px;text-align:center}
.bhero h1{font-family:'Syne',sans-serif;font-size:2.6rem;font-weight:800;line-height:1.1;letter-spacing:-.5px}
.bhero p{color:#b8bcc2;max-width:560px;margin:16px auto 0;font-size:1.08rem}
.bhero .kicker{color:var(--gold);font-weight:700;letter-spacing:2px;text-transform:uppercase;font-size:.78rem;margin-bottom:14px}

/* ══════════════ CARD GRID ══════════════ */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px;padding:52px 0 70px}
.card{
  background:var(--paper);border:1px solid var(--line);border-radius:16px;overflow:hidden;
  display:flex;flex-direction:column;transition:transform .18s,box-shadow .18s;
  min-width:0;
}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 34px rgba(0,0,0,.10)}
.card-top{height:8px;background:linear-gradient(90deg,var(--red),var(--gold))}
.card-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.tag{align-self:flex-start;background:#fbece9;color:var(--red);font-weight:700;font-size:.72rem;letter-spacing:.5px;text-transform:uppercase;padding:5px 11px;border-radius:999px;margin-bottom:14px}
.card h2{font-family:'Syne',sans-serif;font-size:1.32rem;line-height:1.25;color:var(--ink);margin-bottom:10px}
.card p{color:var(--muted);font-size:.96rem;flex:1}
.card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:18px;font-size:.85rem;flex-wrap:wrap;gap:8px}
.read-time{color:var(--muted)}
.read-link{color:var(--red);font-weight:700}
.card:hover .read-link{color:var(--red2)}

/* ══════════════ ARTICLE ══════════════ */
.article{background:var(--paper)}
.art-head{background:var(--ink);color:#fff;padding:48px 24px 40px}
.art-head .tag{background:rgba(255,255,255,.1);color:#fff;margin-bottom:18px}
.art-head h1{font-family:'Syne',sans-serif;font-size:2rem;line-height:1.2;font-weight:800;letter-spacing:-.3px;max-width:720px;margin-bottom:20px}
.art-meta{display:flex;flex-wrap:wrap;gap:8px 16px;align-items:center;color:#b8bcc2;font-size:.88rem}
.art-meta strong{color:#fff;font-weight:600}
.art-dot{width:4px;height:4px;border-radius:50%;background:#6b7280}
.art-body{padding:40px 0 20px;font-size:1.05rem;line-height:1.75;color:var(--tx)}
.art-body p{margin:0 0 22px}
.art-body h2{font-family:'Syne',sans-serif;font-size:1.45rem;color:var(--ink);margin:36px 0 16px;line-height:1.3}
.art-body h3{font-size:1.15rem;color:var(--ink);margin:26px 0 12px;font-weight:700}
.art-body ul,.art-body ol{margin:0 0 22px;padding-left:22px}
.art-body li{margin-bottom:10px;line-height:1.65}
.art-body strong{color:var(--ink)}
.art-body a.inline{color:var(--red);font-weight:600;border-bottom:1px solid rgba(192,57,43,.3)}

.art-body .lead{font-size:1.15rem;line-height:1.65;color:var(--ink);font-weight:500;margin-bottom:26px}

.keybox{
  background:linear-gradient(180deg,#fbece9,#fdf5f2);
  border:1px solid #f2cfc8;border-left:4px solid var(--red);
  border-radius:12px;padding:20px 22px;margin:0 0 30px;
}
.keybox .kb-label{color:var(--red);font-weight:800;font-size:.76rem;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:8px}
.keybox p{margin:0;font-size:1.02rem;line-height:1.65;color:var(--ink)}

.tip{background:#fdf9ec;border:1px solid #efdca8;border-left:4px solid var(--gold);border-radius:12px;padding:18px 20px;margin:0 0 26px}
.tip .tip-label{color:#a67c07;font-weight:800;font-size:.76rem;letter-spacing:1.2px;text-transform:uppercase;margin-bottom:6px}
.tip p{margin:0;color:#5c4a12}

.pquote{border-left:4px solid var(--gold);padding:6px 0 6px 22px;margin:26px 0;font-family:'Syne',sans-serif;font-size:1.35rem;line-height:1.35;color:var(--ink);font-weight:700}

.faq{margin:44px 0 10px}
.faq h2{font-family:'Syne',sans-serif;font-size:1.5rem;color:var(--ink);margin-bottom:18px}
.faq-q{font-family:'Syne',sans-serif;font-weight:700;color:var(--ink);font-size:1.05rem;margin:0;padding:18px 20px;background:var(--off);border:1px solid var(--line);border-bottom:none;border-radius:10px 10px 0 0;position:relative;padding-left:44px}
.faq-q::before{content:"Q";position:absolute;left:16px;top:50%;transform:translateY(-50%);width:22px;height:22px;background:var(--red);color:#fff;border-radius:50%;font-size:.72rem;font-weight:800;display:flex;align-items:center;justify-content:center;font-family:'Inter',sans-serif}
.faq-a{color:var(--tx);margin:0 0 18px;padding:16px 20px 18px 44px;background:#fff;border:1px solid var(--line);border-radius:0 0 10px 10px;line-height:1.65}

.ctabox{background:var(--ink);border-radius:18px;padding:34px 24px;text-align:center;margin:44px 0}
.ctabox h3{color:#fff;font-family:'Syne',sans-serif;font-size:1.55rem;margin-bottom:8px}
.ctabox p{color:#b8bcc2;margin-bottom:22px;max-width:440px;margin-left:auto;margin-right:auto}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn{padding:13px 24px;border-radius:10px;font-weight:700;font-size:.98rem;display:inline-flex;align-items:center;gap:8px;transition:.15s}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:var(--red2)}
.btn-out{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.3)}
.btn-out:hover{border-color:#fff}

.related{padding:20px 22px 60px;max-width:1080px;margin:0 auto}
.related h3{font-family:'Syne',sans-serif;font-size:1.35rem;color:var(--ink);margin-bottom:20px}
.rel-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.rel{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:18px 20px;transition:.15s;min-width:0}
.rel:hover{border-color:var(--red);transform:translateY(-2px)}
.rel .tag{margin-bottom:10px}
.rel strong{display:block;font-family:'Syne',sans-serif;color:var(--ink);font-size:1.05rem;line-height:1.3}

.backlink{display:inline-flex;align-items:center;gap:7px;color:var(--muted);font-weight:600;font-size:.9rem;margin:30px 22px 0;padding-bottom:30px}
.backlink:hover{color:var(--red)}

@media(max-width:768px){
  .bhero{padding:48px 20px 40px}
  .bhero h1{font-size:2rem}
  .art-head h1{font-size:1.72rem}
  .related{padding:20px 20px 60px}
}
