/* ================================================================
   ONE TIME HOCKEY — stylesheet
   Mobile-first · Red #C8102E / White / Navy #0D1F3C
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,700;0,900;1,700&family=Barlow+Condensed:wght@400;600;700;800&family=Barlow:wght@400;500;600&display=swap');

/* ── TOKENS ─────────────────────────────────────── */
:root {
  --red:      #C8102E;
  --red-dk:   #9B0B22;
  --navy:     #0D1F3C;
  --navy-md:  #1A3A5C;
  --navy-lt:  #253F63;
  --white:    #FFFFFF;
  --off:      #F4F8FC;
  --ice:      #C8E6F5;
  --ice-dim:  #8BBCD4;
  --gold:     #E8A020;
  --ink:      #0F172A;
  --mid:      #374151;
  --muted:    #64748B;
  --border-d: rgba(255,255,255,.10);
  --border-l: rgba(0,0,0,.08);
  --r:        4px;
  --r-lg:     10px;
  --ease:     .2s ease;
  --shadow:   0 6px 32px rgba(0,0,0,.35);
  --shadow-s: 0 2px 12px rgba(0,0,0,.08);
  --fd: 'Playfair Display', Georgia, serif;
  --fc: 'Barlow Condensed', 'Arial Narrow', sans-serif;
  --fb: 'Barlow', 'Segoe UI', sans-serif;
}

/* ── RESET ──────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--fb);color:var(--ink);background:var(--white);line-height:1.65;overflow-x:hidden;padding-top:64px}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;border:none;font:inherit}
input,textarea,select{font:inherit}

/* ── TYPE ───────────────────────────────────────── */
h1,h2,h3{font-family:var(--fd);line-height:1.12}
h4,.label{font-family:var(--fc);letter-spacing:.08em}
.d-xl{font-size:clamp(2.8rem,8vw,5.5rem);font-family:var(--fd);font-weight:900;line-height:1.0}
.d-lg{font-size:clamp(2rem,5.5vw,3.8rem);font-family:var(--fd);font-weight:700;line-height:1.1}
.d-md{font-size:clamp(1.5rem,4vw,2.5rem);font-family:var(--fd);font-weight:700;line-height:1.15}
.tagline{font-family:var(--fd);font-style:italic;color:var(--gold);font-size:clamp(1rem,2.2vw,1.25rem);line-height:1.6}
.sec-label{font-family:var(--fc);font-weight:700;font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;color:var(--red);display:block;margin-bottom:.7rem}
.sec-label--lt{color:var(--ice)}
.sec-label--gold{color:var(--gold)}
p{margin-bottom:1rem}p:last-child{margin-bottom:0}

/* ── LAYOUT ─────────────────────────────────────── */
.wrap{width:100%;max-width:1200px;margin:0 auto;padding:0 1.25rem}
.sec{padding:5rem 0}.sec-sm{padding:3rem 0}.sec-lg{padding:7rem 0}
.bg-navy{background:var(--navy);color:var(--white)}
.bg-nmd{background:var(--navy-md);color:var(--white)}
.bg-red{background:var(--red);color:var(--white)}
.bg-off{background:var(--off);color:var(--ink)}
.bg-white{background:var(--white);color:var(--ink)}

/* ── NAV ────────────────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--red);height:64px;display:flex;align-items:center;transition:box-shadow var(--ease)}
.nav.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.4)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:1200px;margin:0 auto;padding:0 1.25rem}
.nav-logo{font-family:var(--fc);font-weight:800;font-size:1.3rem;letter-spacing:.06em;color:var(--white);text-transform:uppercase;line-height:1}
.nav-logo span{display:block;font-weight:400;font-size:.65em;letter-spacing:.14em;color:rgba(255,255,255,.65);margin-top:1px}
.nav-links{display:none;align-items:center;gap:.2rem}
.nav-links a{font-family:var(--fc);font-weight:600;font-size:.88rem;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.85);padding:.4rem .7rem;border-radius:var(--r);transition:color var(--ease),background var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--white);background:rgba(255,255,255,.12)}
.nav-links .nav-cta{background:var(--white);color:var(--red)!important;font-weight:700;padding:.4rem 1rem;margin-left:.5rem}
.nav-links .nav-cta:hover{background:var(--off)}
.burger{display:flex;flex-direction:column;gap:5px;padding:8px;background:transparent}
.burger span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:all .3s}

/* Mobile overlay */
.nav-overlay{display:none;position:fixed;inset:0;background:var(--navy);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;padding-top:64px}
.nav-overlay.open{display:flex}
.nav-overlay a{font-family:var(--fc);font-weight:700;font-size:2.2rem;letter-spacing:.04em;text-transform:uppercase;color:var(--white);padding:.5rem 2rem;transition:color var(--ease)}
.nav-overlay a:hover{color:var(--gold)}
.nav-overlay .mob-cta{margin-top:1.25rem;background:var(--red);color:var(--white)!important;border-radius:var(--r);padding:.7rem 2.5rem!important}
.nav-close{position:absolute;top:18px;right:1.25rem;background:transparent;color:var(--white);font-size:2rem;line-height:1;padding:.5rem}

/* ── BUTTONS ────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;font-family:var(--fc);font-weight:700;font-size:1rem;letter-spacing:.06em;text-transform:uppercase;padding:.75rem 1.75rem;border-radius:var(--r);transition:all var(--ease);min-height:48px;white-space:nowrap;border:2px solid transparent}
.btn-red{background:var(--red);color:var(--white);border-color:var(--red)}
.btn-red:hover{background:var(--red-dk);border-color:var(--red-dk);transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--white);border-color:var(--white)}
.btn-outline:hover{background:var(--white);color:var(--red)}
.btn-outline-red{background:transparent;color:var(--red);border-color:var(--red)}
.btn-outline-red:hover{background:var(--red);color:var(--white)}
.btn-gold{background:var(--gold);color:var(--navy);border-color:var(--gold)}
.btn-gold:hover{background:#c8880e;border-color:#c8880e}
.btn-full{width:100%}
.btn-row{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}

/* ── HERO ───────────────────────────────────────── */
.hero{min-height:88vh;display:flex;align-items:center;background:var(--navy);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 75% 50%, rgba(200,16,46,.14) 0%, transparent 55%), radial-gradient(ellipse 50% 80% at 5% 90%, rgba(26,58,92,.7) 0%, transparent 60%);pointer-events:none}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--red),transparent)}

/* Grid System for side-by-side */
.hero-grid { display: flex; flex-direction: column; gap: 3rem; width: 100%; position: relative; z-index: 1; padding: 4rem 0; }
.hero-text-col, .hero-video-col { width: 100%; }

@media(min-width: 992px) {
  .hero-grid { flex-direction: row; align-items: center; justify-content: space-between; }
  .hero-text-col { flex: 0 0 55%; }
  .hero-video-col { flex: 0 0 42%; }
}

/* Video Aspect Ratio Box */
.vid-wrap {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 Aspect Ratio */
  height: 0;
  overflow: hidden;
  border-radius: var(--r-lg);
  box-shadow: var(--shadow);
  border: 1px solid var(--border-d);
}
.vid-wrap iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--fc);font-weight:600;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ice-dim);margin-bottom:1.5rem}
.eyebrow::before{content:'';display:block;width:24px;height:2px;background:var(--red);flex-shrink:0}

/* Page hero */
.pg-hero{padding:3.5rem 0 3rem;background:var(--navy);position:relative;overflow:hidden}
.pg-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--red) 20%,var(--red) 80%,transparent)}
.pg-hero .wrap{position:relative;z-index:1}

/* ── STAT BAR ───────────────────────────────────── */
.stat-bar{background:var(--red);padding:1.5rem 0}
.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;text-align:center}
.stat-val{font-family:var(--fc);font-weight:800;font-size:1.6rem;color:var(--white);line-height:1;letter-spacing:.02em}
.stat-lbl{font-family:var(--fc);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.75);margin-top:.25rem}

/* ── LANE CARDS ─────────────────────────────────── */
.lane-grid{display:grid;grid-template-columns:1fr;gap:1rem}
.lane-card{background:var(--navy-md);border:1px solid var(--border-d);border-radius:var(--r-lg);overflow:hidden;transition:transform var(--ease),box-shadow var(--ease),border-color var(--ease)}
.lane-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:rgba(255,255,255,.22)}
.lane-card-hd{padding:.85rem 1.2rem;display:flex;align-items:center;justify-content:space-between}
.lane-card-team{font-family:var(--fc);font-weight:800;font-size:1.08rem;letter-spacing:.04em;color:var(--white);line-height:1.25}
.lane-card-price{font-family:var(--fc);font-weight:700;font-size:.88rem;color:var(--white);text-align:right;line-height:1.25}
.lane-card-bd{padding:.9rem 1.2rem 1.25rem}
.lane-card-type{font-family:var(--fc);font-weight:700;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:.4rem}
.lane-card-desc{font-size:.88rem;color:var(--ice-dim);line-height:1.55}
.lane-card-link{display:inline-flex;align-items:center;gap:.3rem;font-family:var(--fc);font-weight:700;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);margin-top:.75rem;transition:gap var(--ease)}
.lane-card-link:hover{gap:.55rem}

/* ── LANE DETAIL PAGE ───────────────────────────── */
.lane-sec{padding:3.5rem 0}
.lane-sec:nth-child(odd){background:var(--white)}
.lane-sec:nth-child(even){background:var(--off)}
.lane-det-hd{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.25rem}
.lane-bar{width:6px;border-radius:3px;flex-shrink:0;margin-top:.25rem;min-height:56px}
.lane-det-name{font-family:var(--fd);font-size:clamp(1.8rem,5vw,3rem);font-weight:900;line-height:1.0}
.lane-det-type{font-family:var(--fc);font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;margin-top:.3rem}
.equip-list{display:flex;flex-direction:column;gap:.5rem;margin:1.25rem 0}
.equip-item{display:flex;align-items:center;gap:.65rem;font-size:.94rem;color:var(--mid)}
.equip-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.lane-callout{background:var(--navy);color:var(--white);border-radius:var(--r-lg);padding:1.5rem;border-left:4px solid var(--gold);margin-top:1.5rem}
.lane-callout p{color:var(--ice-dim);font-size:.93rem;line-height:1.65}
.lane-callout strong{color:var(--gold)}
.lane-price-box{background:var(--off);border:1px solid var(--border-l);border-radius:var(--r-lg);padding:1.5rem;margin-top:1.5rem}
.lane-price-box.dark{background:var(--navy-md);border-color:var(--border-d)}
.price-row{display:flex;justify-content:space-between;align-items:baseline;padding:.5rem 0;border-bottom:1px solid var(--border-l)}
.price-row:last-child{border-bottom:none}
.price-lbl{font-size:.92rem;color:var(--mid)}
.dark .price-lbl{color:var(--ice-dim)}
.price-val{font-family:var(--fc);font-weight:700;font-size:1.05rem;color:var(--navy)}
.dark .price-val{color:var(--white)}

/* ── PRICING PAGE ───────────────────────────────── */
.pricing-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
.p-card{background:var(--white);border:1px solid var(--border-l);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-s)}
.p-card-hd{padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between}
.p-card-title{font-family:var(--fc);font-weight:800;font-size:.95rem;letter-spacing:.06em;text-transform:uppercase;color:var(--white)}
.p-card-bd{padding:1.25rem 1.5rem}
.p-row{display:flex;justify-content:space-between;align-items:baseline;padding:.55rem 0;border-bottom:1px solid var(--border-l);font-size:.94rem}
.p-row:last-child{border-bottom:none}
.p-row-lbl{color:var(--mid)}
.p-row-val{font-family:var(--fc);font-weight:700;font-size:1rem;color:var(--navy)}
.p-note{font-size:.81rem;color:var(--muted);font-style:italic;margin-top:.75rem;padding-top:.75rem;border-top:1px dashed var(--border-l)}

/* Membership */
.mem-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
.mem-card{background:var(--navy-md);border:1px solid var(--border-d);border-radius:var(--r-lg);padding:1.75rem;position:relative}
.mem-card.featured{border-color:var(--gold)}
.mem-badge{position:absolute;top:-.6rem;right:1.25rem;background:var(--gold);color:var(--navy);font-family:var(--fc);font-weight:800;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;padding:.2rem .6rem;border-radius:2px}
.mem-price{font-family:var(--fd);font-weight:900;font-size:2.6rem;color:var(--white);line-height:1;margin-bottom:.2rem}
.mem-period{font-family:var(--fc);font-size:.84rem;color:var(--ice-dim);margin-bottom:1.25rem}
.mem-features{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.5rem}
.mem-feat{display:flex;align-items:flex-start;gap:.6rem;font-size:.91rem;color:var(--ice);line-height:1.45}
.mem-feat::before{content:'✓';color:var(--gold);font-weight:700;flex-shrink:0;margin-top:.05em}
.mem-feat.perk{color:var(--gold);font-weight:600}

/* ── FAQ ────────────────────────────────────────── */
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--border-l)}
.faq-q{width:100%;background:transparent;text-align:left;padding:1.2rem 0;display:flex;justify-content:space-between;align-items:center;gap:1rem;font-family:var(--fc);font-weight:700;font-size:1.05rem;color:var(--navy);transition:color var(--ease)}
.faq-q:hover{color:var(--red)}
.faq-icon{font-size:1.5rem;color:var(--red);transition:transform var(--ease);flex-shrink:0;line-height:1}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding var(--ease);font-size:.93rem;color:var(--mid);line-height:1.72}
.faq-item.open .faq-a{max-height:300px;padding-bottom:1.2rem}
/* FAQ on dark bg */
.bg-navy .faq-q,.bg-nmd .faq-q{color:var(--white)}
.bg-navy .faq-a,.bg-nmd .faq-a{color:var(--ice-dim)}
.bg-navy .faq-item,.bg-nmd .faq-item{border-color:var(--border-d)}

/* ── COACHES ────────────────────────────────────── */
.check-list{display:flex;flex-direction:column;gap:.75rem}
.check-item{display:flex;align-items:flex-start;gap:.75rem;font-size:.96rem;line-height:1.5;color:var(--ice)}
.check-icon{width:20px;height:20px;background:var(--red);border-radius:50%;flex-shrink:0;margin-top:.12em;display:flex;align-items:center;justify-content:center}
.check-icon svg{width:11px;height:11px;fill:var(--white)}
.coaches-deal{background:var(--navy-lt);border-radius:var(--r-lg);padding:2rem;border-left:4px solid var(--red)}
.coaches-deal p{color:var(--ice-dim);font-size:.95rem;line-height:1.7}

/* ── FORMS ──────────────────────────────────────── */
.form-group{margin-bottom:1.25rem}
.form-label{display:block;font-family:var(--fc);font-weight:700;font-size:.83rem;letter-spacing:.08em;text-transform:uppercase;color:var(--navy-md);margin-bottom:.4rem}
.bg-navy .form-label,.bg-nmd .form-label{color:var(--ice)}
.form-input,.form-select,.form-textarea{width:100%;padding:.75rem 1rem;background:var(--white);border:2px solid var(--border-l);border-radius:var(--r);font-size:.97rem;color:var(--ink);transition:border-color var(--ease);min-height:48px}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--red)}
.form-textarea{min-height:130px;resize:vertical}

/* ── FOOTER ─────────────────────────────────────── */
.footer{background:var(--navy);padding:4rem 0 0;border-top:3px solid var(--red)}
.foot-grid{display:grid;grid-template-columns:1fr;gap:3rem;padding-bottom:3rem}
.foot-logo{font-family:var(--fc);font-weight:800;font-size:1.45rem;letter-spacing:.06em;text-transform:uppercase;color:var(--white);margin-bottom:.75rem}
.foot-tagline{font-family:var(--fd);font-style:italic;color:var(--gold);font-size:.93rem;margin-bottom:1.25rem;line-height:1.55}
.foot-hdg{font-family:var(--fc);font-weight:700;font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ice-dim);margin-bottom:1rem}
.foot-links{display:flex;flex-direction:column;gap:.45rem}
.foot-links a{font-size:.91rem;color:rgba(255,255,255,.6);transition:color var(--ease)}
.foot-links a:hover{color:var(--white)}
.foot-hours{font-size:.89rem;color:rgba(255,255,255,.6);line-height:1.85}
.foot-hours strong{color:var(--white)}
.foot-bar{border-top:1px solid rgba(255,255,255,.08);padding:1.2rem 0;display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center;font-size:.81rem;color:rgba(255,255,255,.3)}

/* Social icons */
.social-row{display:flex;gap:.65rem;align-items:center;margin-top:1rem}
.soc-link{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);color:var(--white);transition:background var(--ease),color var(--ease)}
.soc-link:hover{background:var(--gold);color:var(--navy)}
.soc-link svg{width:17px;height:17px;fill:currentColor}

/* ── MISC ───────────────────────────────────────── */
.divider{height:3px;background:linear-gradient(90deg,transparent,var(--red) 30%,var(--red) 70%,transparent);border:none;margin:0}
.two-col{display:grid;grid-template-columns:1fr;gap:3rem;align-items:start}
.info-card{background:var(--navy-md);border-radius:var(--r-lg);padding:2rem;border-left:4px solid var(--red)}
.info-card h3{font-family:var(--fc);font-weight:800;font-size:1.25rem;letter-spacing:.04em;color:var(--white);margin-bottom:.75rem}
.info-card p{color:var(--ice-dim);font-size:.93rem}
.cta-band{padding:5rem 0;text-align:center}
.cta-band h2{margin-bottom:.75rem;color:var(--white)}
.cta-band p{color:var(--ice-dim);margin-bottom:2rem;max-width:500px;margin-left:auto;margin-right:auto}
.booking-ph{background:var(--navy-md);border:2px dashed rgba(255,255,255,.14);border-radius:var(--r-lg);padding:3.5rem 2rem;text-align:center}
.booking-ph h3{color:var(--white);margin-bottom:.5rem}
.booking-ph p{color:var(--ice-dim);margin-bottom:1.5rem}
.booking-ph .ph-phone{font-family:var(--fc);font-size:1.9rem;font-weight:700;color:var(--gold);letter-spacing:.04em;display:block;margin-bottom:1rem}
.map-ph{background:var(--navy-md);border-radius:var(--r-lg);height:260px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.75rem;border:1px solid var(--border-d);color:var(--ice-dim);font-family:var(--fc);font-size:.95rem;letter-spacing:.06em;text-align:center;padding:2rem}
.email-row{display:flex;flex-direction:column;gap:.75rem;max-width:420px}
.email-row .form-input{background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.15);color:var(--white)}
.email-row .form-input::placeholder{color:rgba(255,255,255,.4)}
.email-row .form-input:focus{border-color:var(--red)}
.tag-pill{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--fc);font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:.3rem .75rem;border-radius:20px;background:rgba(200,16,46,.15);color:var(--red);margin-bottom:.75rem}
.bg-navy .tag-pill,.bg-nmd .tag-pill{background:rgba(200,16,46,.25);color:#f08090}

/* ── ANIMATIONS ─────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
.fu{animation:fadeUp .6s ease both}
.fu-1{animation-delay:.1s}.fu-2{animation-delay:.2s}.fu-3{animation-delay:.3s}.fu-4{animation-delay:.4s}.fu-5{animation-delay:.5s}

/* ── RESPONSIVE ─────────────────────────────────── */
@media(min-width:768px){
  .nav-links{display:flex}
  .burger{display:none}
  .stat-grid{grid-template-columns:repeat(4,1fr)}
  .lane-grid{grid-template-columns:repeat(2,1fr)}
  .pricing-grid{grid-template-columns:repeat(2,1fr)}
  .mem-grid{grid-template-columns:repeat(3,1fr)}
  .two-col{grid-template-columns:1fr 1fr;align-items:center}
  .foot-grid{grid-template-columns:2fr 1fr 1fr}
  .foot-bar{flex-direction:row;justify-content:space-between}
  .email-row{flex-direction:row}
}
@media(min-width:1024px){
  .lane-grid{grid-template-columns:repeat(3,1fr)}
  .hero{min-height:88vh}
  .sec{padding:6rem 0}
  .sec-lg{padding:8rem 0}
}