:root{
  --ink-navy:#0A1F33;
  --ink-deep:#071727;
  --court-blue:#123C64;
  --court-blue-soft:#17456f;
  --line-white:#F3F6FA;
  --cork-red:#FF4438;
  --champion-gold:#FFB627;
  --court-green:#046307;
  --slate-mist:#93A8BD;
  --glass:rgba(255,255,255,.07);
  --glass-border:rgba(255,255,255,.12);
  --radius:18px;
  --shadow:0 22px 70px rgba(0,0,0,.32);
  --maxw:1220px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:82px}
body{font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--ink-navy);color:var(--line-white);line-height:1.65;overflow-x:hidden}
a{color:inherit}img{max-width:100%;display:block}button,input,textarea{font:inherit}.mono{font-family:'Space Mono',monospace}.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}.skip-link{position:absolute;left:-999px;top:0;background:#fff;color:#000;padding:10px 14px;z-index:9999}.skip-link:focus{left:12px;top:12px}h1,h2,.display{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.035em;line-height:1.05}h3{line-height:1.25}.section{padding:86px 0}.section-tag{display:inline-flex;align-items:center;gap:10px;font-family:'Space Mono',monospace;color:var(--champion-gold);font-size:.76rem;text-transform:uppercase;letter-spacing:.15em;margin-bottom:12px}.section-tag:before{content:"";width:24px;height:2px;background:var(--champion-gold)}.section-head{max-width:720px;margin:0 auto 46px;text-align:center}.section-head .section-tag{justify-content:center}.section-head h2,.about-grid h2,.booking-grid h2,.contact-grid h2{font-size:clamp(1.8rem,2.6vw,2.50rem);color:var(--line-white);margin-bottom:14px}.section-head p,.about-grid p,.booking-grid p,.contact-grid p{color:#C8D6E4;font-size:1.02rem; text-align:justify;}.dark-panel{background:linear-gradient(180deg,rgba(18,60,100,.82),rgba(10,31,51,.96));border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06)}
.site-nav{position:sticky;top:0;z-index:300;background:#0f1e72;backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.08)}.nav-inner{max-width:var(--maxw);margin:0 auto;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;gap:18px}.brand{display:flex;align-items:center;gap:11px;text-decoration:none;flex-shrink:0}.brand-logo{width:46px;height:46px;border-radius:14px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;overflow:hidden;border:1px solid rgba(255,182,39,.22)}.brand-logo img{width:100%;height:100%;object-fit:contain}.brand-text{font-family:'Oswald',sans-serif;text-transform:uppercase;font-weight:700;font-size:1.08rem;letter-spacing:.05em}.brand-text strong{color:var(--cork-red);font-weight:700}.nav-links{display:flex;align-items:center;gap:26px}.nav-links a{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.055em;text-decoration:none;font-size:.84rem;color:#F3F6FA;position:relative;padding:7px 0;transition:color .2s ease}.nav-links a:after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--champion-gold);transition:width .22s ease}.nav-links a:hover,.nav-links a.is-active{color:var(--champion-gold)}.nav-links a:hover:after,.nav-links a.is-active:after{width:100%}.nav-actions{display:flex;align-items:center;gap:12px}.login-icon{display:inline-flex;align-items:center;gap:8px;text-decoration:none;background:var(--cork-red);color:#fff;padding:10px 18px;border-radius:999px;font-family:'Oswald',sans-serif;letter-spacing:.05em;text-transform:uppercase;font-size:.82rem;box-shadow:0 10px 26px rgba(255,68,56,.28);transition:transform .2s ease,box-shadow .2s ease}.login-icon svg{width:18px;height:18px;fill:currentColor}.login-icon:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(255,68,56,.4)}.nav-toggle{display:none;width:42px;height:42px;border:1px solid rgba(255,255,255,.12);border-radius:12px;background:rgba(255,255,255,.05);cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:5px}.nav-toggle span{width:22px;height:2px;border-radius:4px;background:#fff;transition:transform .25s ease,opacity .25s ease}.nav-toggle.is-active span:nth-child(1){transform:translateY(7px) rotate(45deg)}.nav-toggle.is-active span:nth-child(2){opacity:0}.nav-toggle.is-active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.hero-slideshow{position:relative;min-height:560px;height:88vh;max-height:790px;overflow:hidden;padding:0;background:var(--ink-navy)}.slide{position:absolute;inset:0;opacity:0;transition:opacity 1s ease}.slide:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,23,39,.86),rgba(10,31,51,.58),rgba(10,31,51,.42)),linear-gradient(180deg,rgba(10,31,51,.18),var(--ink-navy) 96%)}.slide.is-active{opacity:1;z-index:1}.slide img{width:100%;height:100%;object-fit:cover}.hero-content{position:relative;z-index:5;max-width:var(--maxw);height:100%;margin:0 auto;padding:0 24px;display:flex;flex-direction:column;justify-content:center;align-items:flex-start}.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'Space Mono',monospace;color:var(--champion-gold);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px}.hero-eyebrow:before{content:"";width:28px;height:2px;background:var(--champion-gold)}.hero-content h1{font-size:clamp(2.7rem,7vw,5.4rem);max-width:12ch}.hero-content h1 span{color:var(--cork-red)}.hero-content p{margin-top:22px;max-width:56ch;color:#D9E5F0; text-align: justify; font-size:1.1rem}.hero-cta-row{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}.btn{appearance:none;border:none;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:14px 27px;font-weight:800;text-decoration:none;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease,border-color .2s ease}.btn-primary{background:var(--cork-red);color:#fff;box-shadow:0 12px 32px rgba(255,68,56,.34)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(255,68,56,.42)}.btn-outline{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.36);color:#fff}.btn-outline:hover{transform:translateY(-2px);border-color:var(--champion-gold);background:rgba(255,182,39,.1)}.btn-light{background:#fff;color:var(--ink-navy)}.text-link{font-weight:800;color:var(--champion-gold);text-decoration:none}.hero-badges{margin-top:28px;display:flex;gap:10px;flex-wrap:wrap}.hero-badges span{font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.05em;color:#C7D7E5;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);padding:7px 12px;border-radius:999px}.slide-arrows{position:absolute;left:18px;right:18px;top:50%;transform:translateY(-50%);z-index:8;display:flex;justify-content:space-between;pointer-events:none}.slide-arrow{pointer-events:auto;width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.26);background:rgba(10,31,51,.52);color:#fff;font-size:1.7rem;line-height:1;cursor:pointer;backdrop-filter:blur(4px);transition:background .2s ease,border-color .2s ease}.slide-arrow:hover{background:var(--cork-red);border-color:var(--cork-red)}.slide-dots{position:absolute;z-index:8;left:0;right:0;bottom:24px;display:flex;justify-content:center;gap:10px}.slide-dot{width:10px;height:10px;border-radius:50%;border:0;background:rgba(255,255,255,.38);cursor:pointer;transition:background .2s ease,transform .2s ease}.slide-dot.is-active{background:var(--champion-gold);transform:scale(1.25)}
.stats-strip{background:var(--court-blue);border-bottom:1px solid rgba(255,255,255,.08);padding:34px 0}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}.stat-card{border-right:1px solid rgba(255,255,255,.12);padding:0 12px}.stat-card:last-child{border-right:0}.stat-card strong{display:block;font-size:clamp(1.75rem,3.4vw,2.5rem);color:var(--champion-gold);line-height:1}.stat-card span{display:block;margin-top:8px;color:var(--slate-mist);font-size:.78rem;text-transform:uppercase;letter-spacing:.07em}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}.about-actions{margin-top:26px;display:flex;gap:16px;flex-wrap:wrap;align-items:center}.about-panel{display:grid;gap:16px}.mini-card,.info-card,.program-card,.booking-card,blockquote{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.09);border-radius:var(--radius); text-align:justify; padding:24px}.mini-card span,.service-item span{font-family:'Space Mono',monospace;color:var(--champion-gold);  font-size:.8rem}.mini-card h3,.info-card h3,.program-card h3,.service-item h3{margin:8px 0; color:#fff}.mini-card p,.info-card p,.program-card p,.service-item p{color:var(--slate-mist)}.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.info-card{transition:transform .22s ease,border-color .22s ease,background .22s ease}.info-card:hover{transform:translateY(-5px);border-color:rgba(255,182,39,.34);background:rgba(255,255,255,.065)}.info-card .icon{width:54px;height:54px;border-radius:16px;background:rgba(255,68,56,.16);display:flex;align-items:center;justify-content:center;font-size:1.45rem;margin-bottom:18px}.service-list{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.service-item{padding:24px; text-align:justify;border-left:3px solid var(--cork-red);background:rgba(255,255,255,.035);border-radius:var(--radius)}.program-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.program-card{position:relative;overflow:hidden}.program-card.featured{border-color:rgba(255,182,39,.45);box-shadow:0 18px 60px rgba(0,0,0,.22)}.program-card .level{display:inline-flex;background:rgba(255,182,39,.14);color:var(--champion-gold);border:1px solid rgba(255,182,39,.28);padding:5px 10px;border-radius:999px;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.program-card ul{margin:18px 0 0 20px;color:#C8D6E4}.program-card li{margin-bottom:8px}.booking-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:32px;align-items:center}.booking-features{margin:22px 0;display:flex;gap:10px;flex-wrap:wrap}.booking-features span{background:rgba(255,182,39,.12);border:1px solid rgba(255,182,39,.24);color:var(--champion-gold);padding:8px 12px;border-radius:999px;font-weight:700;font-size:.86rem}.booking-card{background:linear-gradient(150deg,rgba(18,60,100,.9),rgba(10,31,51,.86));box-shadow:var(--shadow)}.booking-card a{display:block;margin-top:12px;color:var(--champion-gold);font-weight:800;text-decoration:none}.facility-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.facility-grid div{padding:18px 20px;border-radius:14px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);font-weight:800}.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.gallery-grid img{width:100%;border-radius:18px;border:1px solid rgba(255,255,255,.08);box-shadow:0 18px 46px rgba(0,0,0,.18)}.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}blockquote p{font-size:1.02rem;color:#DCE8F4}blockquote cite{display:block;margin-top:16px;color:var(--champion-gold);font-style:normal;font-weight:800}.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:34px;align-items:stretch}.contact-cards{margin-top:24px;display:grid;grid-template-columns:1fr 1fr;gap:14px}.contact-cards a,.contact-cards div{display:block;text-decoration:none;padding:18px;border-radius:16px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09)}.contact-cards strong{display:block;color:var(--champion-gold);font-size:.82rem;text-transform:uppercase;letter-spacing:.08em}.contact-cards span{display:block;margin-top:5px;color:#E1ECF7}.map-card{border-radius:22px;overflow:hidden;border:1px solid rgba(255,255,255,.11);min-height:380px;box-shadow:var(--shadow)}.map-card iframe{width:100%;height:100%;min-height:380px;border:0;display:block}.site-footer{background:#071727;border-top:1px solid rgba(255,255,255,.08);padding:58px 0 0}.footer-grid{display:grid;grid-template-columns:1.4fr .8fr .9fr 1.2fr;gap:34px}.footer-brand{margin-bottom:14px}.site-footer p,.site-footer a{color:var(--slate-mist);font-size:.92rem}.site-footer a{display:block;text-decoration:none;margin:8px 0}.site-footer a:hover{color:#fff}.site-footer h3{font-family:'Oswald',sans-serif;color:var(--champion-gold);text-transform:uppercase;letter-spacing:.08em;font-size:.9rem;margin-bottom:14px}.footer-bottom{margin-top:42px;border-top:1px solid rgba(255,255,255,.08);padding:18px 0}.footer-bottom .wrap{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}.footer-bottom a{margin:0;color:var(--champion-gold);font-weight:800}
.modal-overlay{position:fixed;inset:0;background:rgba(5,15,26,.72);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;padding:20px;z-index:1000;opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease}.modal-overlay.is-open{opacity:1;visibility:visible}.modal-card{position:relative;width:100%;max-width:460px;background:linear-gradient(155deg,var(--court-blue),var(--ink-deep));border:1px solid rgba(255,182,39,.28);border-radius:24px;text-align:center;padding:38px 30px 30px;box-shadow:0 28px 80px rgba(0,0,0,.46);transform:translateY(18px) scale(.98);transition:transform .25s ease}.modal-overlay.is-open .modal-card{transform:translateY(0) scale(1)}.modal-close{position:absolute;right:14px;top:14px;width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);color:#fff;font-size:1.5rem;cursor:pointer}.modal-icon{display:flex;width:62px;height:62px;border-radius:50%;align-items:center;justify-content:center;background:rgba(255,182,39,.14);margin:0 auto 16px;font-size:1.7rem}.modal-card h2{font-family:'Oswald',sans-serif;text-transform:uppercase;margin-bottom:10px}.modal-card p{color:#C9D8E6}.modal-actions{margin-top:24px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.reveal{opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s ease}.reveal.in{opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.reveal{opacity:1;transform:none}}
@media (max-width:1060px){.nav-links{position:fixed;left:0;right:0;top:71px;background:rgba(10,31,51,.98);border-bottom:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;align-items:flex-start;gap:0;padding:0 24px;max-height:0;overflow:hidden;transition:max-height .3s ease}.nav-links.is-open{max-height:460px;padding-top:10px;padding-bottom:18px}.nav-links a{width:100%;padding:12px 0}.nav-toggle{display:flex}.card-grid,.program-grid,.facility-grid,.testimonial-grid{grid-template-columns:1fr 1fr}.service-list{grid-template-columns:1fr 1fr}.gallery-grid{grid-template-columns:1fr 1fr}.about-grid,.booking-grid,.contact-grid{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr 1fr}.map-card{min-height:320px}.map-card iframe{min-height:320px}}
@media (max-width:680px){.wrap,.nav-inner,.hero-content{padding-left:18px;padding-right:18px}.brand-text{font-size:.96rem}.brand-logo{width:42px;height:42px}.login-icon{padding:10px 13px}.login-icon span{display:none}.hero-slideshow{min-height:520px;height:82vh}.hero-cta-row,.modal-actions{flex-direction:column;align-items:stretch}.btn{text-align:center;width:100%}.slide-arrows{display:none}.stats-grid{grid-template-columns:1fr 1fr;gap:18px}.stat-card{border-right:0;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:16px}.section{padding:58px 0}.card-grid,.program-grid,.facility-grid,.testimonial-grid,.service-list,.gallery-grid,.contact-cards{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr}.footer-bottom .wrap{display:block;text-align:center}.footer-bottom a{margin-top:8px}.modal-card{padding:34px 20px 26px;border-radius:20px}}

/* ===================== 2026-07-01 public website refinements ===================== */
.brand-logo{padding:3px;flex:0 0 auto;}
.brand-logo img{width:auto;height:auto;max-width:100%;max-height:100%;object-fit:contain;object-position:center;}
.map-card{position:relative;}
.map-open-link{position:absolute;left:18px;right:18px;bottom:18px;display:flex;align-items:center;justify-content:center;min-height:44px;padding:10px 14px;border-radius:999px;background:rgba(255,68,56,.94);color:#fff;text-decoration:none;font-weight:800;box-shadow:0 14px 28px rgba(0,0,0,.28);transition:transform .2s ease,background .2s ease;}
.map-open-link:hover{background:var(--cork-red);transform:translateY(-2px);color:#fff;}

.coach-page .nav-links a[href="about-coach.php"]{color:var(--champion-gold);}
.coach-page .nav-links a[href="about-coach.php"]:after{width:100%;}
.coach-hero{position:relative;overflow:hidden;padding:84px 0 64px;background:radial-gradient(circle at 78% 18%,rgba(255,68,56,.15),transparent 34%),radial-gradient(circle at 12% 88%,rgba(255,182,39,.10),transparent 34%),linear-gradient(145deg,#08192a,var(--ink-navy));}
.coach-hero:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.055) 1px,transparent 1px);background-size:220px 120px;opacity:.35;pointer-events:none;}
.coach-hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;}
.coach-kicker{display:inline-flex;gap:10px;align-items:center;font-family:'Space Mono',monospace;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--champion-gold);margin-bottom:18px;}
.coach-kicker:before{content:"";width:28px;height:2px;background:var(--champion-gold);}
.coach-hero h1{font-size:clamp(3rem,7vw,5.2rem);line-height:.98;color:#fff;}
.coach-hero h1 span{color:var(--cork-red);display:block;}
.coach-role{margin-top:12px;font-family:'Oswald',sans-serif;letter-spacing:.08em;text-transform:uppercase;color:#BFD0E1;font-size:1.08rem;}
.coach-lede{margin-top:20px;color:#D5E2EF;max-width:58ch;font-size:1.06rem;}
.coach-actions{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap;}
.coach-badges{margin-top:24px;display:flex;gap:10px;flex-wrap:wrap;}
.coach-badges span{font-family:'Space Mono',monospace;font-size:.72rem;color:#C7D7E5;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);padding:7px 12px;border-radius:999px;}
.coach-photo-panel{display:flex;justify-content:center;}
.coach-photo-frame-large{position:relative;width:min(360px,82vw);aspect-ratio:1/1;border-radius:50%;background:linear-gradient(155deg,var(--court-blue),#071727);border:2px solid rgba(255,182,39,.32);box-shadow:0 28px 80px rgba(0,0,0,.32);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.coach-photo-frame-large:before{content:"";position:absolute;inset:20px;border-radius:50%;border:1px dashed rgba(255,182,39,.35);}
.coach-photo-frame-large img{position:relative;z-index:1;width:100%;height:100%;object-fit:cover;object-position:center top;}
.coach-photo-fallback{position:absolute;z-index:0;font-family:'Oswald',sans-serif;font-size:6rem;color:#fff;}
.coach-stat-strip{background:var(--court-blue);padding:34px 0;}
.coach-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center;}
.coach-stat-card{border-right:1px solid rgba(255,255,255,.1);padding:4px 12px;}
.coach-stat-card:last-child{border-right:0;}
.coach-stat-card strong{display:block;font-size:clamp(1.8rem,3.8vw,2.4rem);color:var(--champion-gold);}
.coach-stat-card span{display:block;margin-top:6px;color:var(--slate-mist);font-size:.76rem;text-transform:uppercase;letter-spacing:.06em;}
.coach-two-col{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:start;}
.coach-copy p{color:#D6E3F0;margin-bottom:16px;font-size:1rem;}
.coach-quote{background:var(--court-blue);border-left:4px solid var(--champion-gold);border-radius:0 18px 18px 0;padding:28px;font-family:'Oswald',sans-serif;font-size:1.18rem;color:#fff;line-height:1.55;}
.coach-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.coach-info-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:18px;padding:26px 22px;}
.coach-info-card .icon{width:44px;height:44px;border-radius:12px;background:rgba(255,68,56,.15);display:flex;align-items:center;justify-content:center;margin-bottom:16px;font-size:1.2rem;}
.coach-info-card small{display:block;color:var(--champion-gold);font-family:'Space Mono',monospace;margin-bottom:8px;text-transform:uppercase;}
.coach-info-card h3{font-family:'Inter',sans-serif;text-transform:none;letter-spacing:0;font-size:1.05rem;color:#fff;margin-bottom:8px;}
.coach-info-card p{color:var(--slate-mist);font-size:.92rem;}
.coach-timeline{border-left:2px solid rgba(255,182,39,.32);padding-left:28px;}
.coach-timeline-item{position:relative;padding-bottom:26px;}
.coach-timeline-item:last-child{padding-bottom:0;}
.coach-timeline-item:before{content:"";position:absolute;left:-35px;top:5px;width:12px;height:12px;border-radius:50%;background:var(--champion-gold);box-shadow:0 0 0 4px rgba(255,182,39,.14);}
.coach-timeline-item small{font-family:'Space Mono',monospace;color:var(--champion-gold);}
.coach-timeline-item h3{margin-top:4px;font-family:'Inter',sans-serif;text-transform:none;letter-spacing:0;font-size:1rem;color:#fff;}
.champion-spotlight{background:linear-gradient(120deg,var(--court-blue),#0e2f4f);border:1px solid rgba(255,182,39,.25);border-radius:22px;padding:32px;display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:center;margin-bottom:28px;}
.champion-medal{width:66px;height:66px;border-radius:50%;background:var(--champion-gold);display:flex;align-items:center;justify-content:center;font-size:1.8rem;}
.champion-spotlight p{color:var(--slate-mist);}
.coach-mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.coach-mini-card{background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.08);border-left:4px solid var(--court-blue-soft);border-radius:12px;padding:18px;}
.coach-mini-card strong{display:block;color:#fff;margin-bottom:5px;}
.coach-mini-card span{display:inline-block;color:var(--champion-gold);font-size:.78rem;font-family:'Space Mono',monospace;text-transform:uppercase;}
.coach-cta{background:radial-gradient(circle at 18% 28%,rgba(255,68,56,.18),transparent 40%),var(--court-blue);text-align:center;}
.coach-cta p{max-width:56ch;margin:10px auto 28px;color:var(--slate-mist);}

@media (max-width:1060px){.coach-hero-grid,.coach-two-col{grid-template-columns:1fr;}.coach-photo-panel{order:-1}.coach-card-grid,.coach-mini-grid{grid-template-columns:1fr 1fr}.coach-stat-grid{grid-template-columns:1fr 1fr}.coach-stat-card{border-right:0;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:16px}}
@media (max-width:680px){.site-nav .nav-inner{display:grid;grid-template-columns:48px minmax(0,1fr) 48px;align-items:center;gap:8px;padding-left:14px;padding-right:14px;min-height:70px}.site-nav .nav-actions{display:contents}.site-nav .nav-toggle{grid-column:1;grid-row:1;justify-self:start;display:flex}.site-nav .brand{grid-column:2;grid-row:1;justify-self:start;margin-left:3px;min-width:0;gap:8px}.site-nav .login-icon{grid-column:3;grid-row:1;justify-self:end;width:44px;height:44px;padding:0;border-radius:50%}.brand-logo{width:44px;height:44px;padding:0;background:transparent!important;border:0!important;box-shadow:none!important;border-radius:0;overflow:visible}.brand-logo img{max-width:44px;max-height:44px}.brand-text{font-size:.78rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-links{top:70px}.coach-hero{padding:54px 0 48px}.coach-actions{flex-direction:column}.coach-actions .btn{width:100%}.coach-card-grid,.coach-mini-grid{grid-template-columns:1fr}.champion-spotlight{grid-template-columns:1fr;text-align:center}.champion-medal{margin:0 auto}.map-open-link{position:static;border-radius:0;min-height:46px}.coach-stat-grid{grid-template-columns:1fr 1fr}}

/* =========================================================
   Clean Responsive System - 2026-07-01
   Ordered media queries:
   Large Desktop >=1600px
   Desktop 1200px-1599px
   Small Desktop 992px-1199px
   Laptop 768px-991px
   Tablet 576px-767px
   Mobile <576px
   ========================================================= */

/* Base responsive normalisation */
html,body{max-width:100%;overflow-x:hidden}
body{min-width:0}
.wrap{width:min(100% - 48px,var(--maxw));max-width:var(--maxw);padding-left:0!important;padding-right:0!important}
.site-nav{--nav-h:68px;min-height:var(--nav-h)}
.site-nav .nav-inner{
  width:100%;
  max-width:none;
  min-height:var(--nav-h);
  padding:10px clamp(22px,2.2vw,48px);
  display:grid;
  grid-template-columns:minmax(210px,1fr) auto minmax(110px,1fr);
  align-items:center;
  gap:clamp(14px,1.8vw,38px);
}
.site-nav .brand{justify-self:start;min-width:0}
.site-nav .brand-logo{
  width:40px!important;
  height:40px!important;
  min-width:40px!important;
  min-height:40px!important;
  padding:3px!important;
  border-radius:10px!important;
  background:#fff!important;
  border:0!important;
  overflow:hidden!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  box-shadow:0 4px 12px rgba(0,0,0,.18),0 0 0 1px rgba(255,255,255,.88)!important;
}
.site-nav .brand-logo img{
  display:block!important;
  width:auto!important;
  height:auto!important;
  max-width:100%!important;
  max-height:100%!important;
  min-width:0!important;
  min-height:0!important;
  object-fit:contain!important;
  object-position:center!important;
  border-radius:6px!important;
  background:#fff!important;
  transform:none!important;
}
.site-nav .nav-links{justify-self:center}
.site-nav .nav-actions{justify-self:end}
.site-nav .login-icon{align-items:center;justify-content:center}
.hero-slideshow{height:calc(100svh - 68px);min-height:560px;max-height:790px}
.hero-content{width:min(100% - 48px,var(--maxw));max-width:var(--maxw);padding-left:0!important;padding-right:0!important}
.map-card{position:relative}
.map-open-link{position:absolute;left:18px;right:18px;bottom:18px;display:flex;align-items:center;justify-content:center;min-height:44px;padding:10px 14px;border-radius:999px;background:rgba(255,68,56,.94);color:#fff!important;text-decoration:none;font-weight:800;box-shadow:0 14px 28px rgba(0,0,0,.28);transition:transform .2s ease,background .2s ease}
.map-open-link:hover{background:var(--cork-red);transform:translateY(-2px)}
.btn-demo{background:#006600!important;color:#fff;box-shadow:0 8px 24px rgba(0,102,0,.30)}
.btn-demo:hover{background:#007a00!important;transform:translateY(-2px);box-shadow:0 12px 28px rgba(0,102,0,.42)}
.site-footer .footer-brand{gap:0!important;align-items:flex-start!important}
.site-footer .footer-brand .brand-logo{display:none!important}
.site-footer .footer-brand .brand-text{display:inline-block!important}
.site-footer .footer-bottom .wrap,
.site-footer .footer-bottom-centered .wrap{display:flex!important;justify-content:center!important;align-items:center!important;text-align:center!important;gap:0!important}
.site-footer .footer-bottom span,
.site-footer .footer-bottom-centered span{display:block!important;width:100%;text-align:center!important}
.site-footer .footer-bottom a{display:none!important}

/* Login page base */
.landing-login-page{background:var(--ink-navy);color:var(--line-white)}
.public-login-section{
  position:relative;
  min-height:calc(100svh - 68px);
  display:flex;
  align-items:center;
  padding:clamp(28px,5vh,56px) 0;
  overflow:hidden;
  background:
    radial-gradient(circle at 12% 18%,rgba(255,68,56,.14),transparent 38%),
    radial-gradient(circle at 86% 74%,rgba(255,182,39,.12),transparent 42%),
    linear-gradient(135deg,var(--ink-deep),var(--ink-navy) 58%,#0c2a45);
}
.public-login-bg{position:absolute;inset:0;opacity:.18;pointer-events:none;background:linear-gradient(90deg,transparent 0 12%,rgba(255,255,255,.18) 12.2% 12.5%,transparent 12.7% 50%,rgba(255,255,255,.16) 50.2% 50.5%,transparent 50.8%),linear-gradient(0deg,transparent 0 28%,rgba(255,255,255,.16) 28.2% 28.5%,transparent 28.7% 62%,rgba(255,255,255,.14) 62.2% 62.5%,transparent 62.7%)}
.public-login-wrap{
  position:relative;
  z-index:1;
  width:min(100% - 48px,var(--maxw));
  max-width:var(--maxw);
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(350px,520px);
  gap:clamp(28px,5vw,70px);
  align-items:center;
  padding-left:0!important;
  padding-right:0!important;
}
.public-login-intro h1{
  font-size:2rem!important;
  line-height:1.12!important;
  max-width:none!important;
  white-space:nowrap!important;
  margin-bottom:20px!important;
}
.public-login-intro p{
  color:#D7E4F1;
  max-width:62ch;
  font-size:1.02rem;
  text-align:justify!important;
  text-justify:inter-word;
}
.public-login-highlights,.login-card-chip{display:none!important}
.public-login-card{
  width:100%;
  background:rgba(255,255,255,.96);
  color:#132235;
  border-radius:24px;
  padding:clamp(22px,3vw,34px);
  box-shadow:0 28px 80px rgba(0,0,0,.34);
  border:1px solid rgba(255,255,255,.65);
}
.public-login-card-head{text-align:center;margin-bottom:22px}
.public-login-card h2{text-align:center!important;font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:clamp(1.9rem,3vw,2.4rem);color:#101a2c;margin-bottom:5px}
.public-login-card p{color:#5d6d82;margin:0}
.login-alert{border-radius:14px;padding:12px 14px;margin-bottom:16px;font-weight:700;font-size:.94rem}
.login-alert-warning{background:#fff4d7;color:#7a4a00;border:1px solid #ffd580}
.login-alert-danger{background:#ffe2e2;color:#a10f0f;border:1px solid #ffb3b3}
.public-login-form{display:grid;gap:16px}
.public-form-group label{display:inline-flex;align-items:center;font-weight:800;color:#152033;margin-bottom:8px}
.public-form-group label.required:after{content:"*";color:var(--cork-red);margin-left:4px}
.public-input-wrap{position:relative;display:flex;align-items:center;width:100%;min-width:0}
.public-input-wrap>svg{position:absolute;left:14px;width:20px;height:20px;fill:#6f8197;pointer-events:none}
.public-input-wrap input{width:100%;min-width:0;height:52px;border:1px solid #d7e0ea;background:#f7faff;color:#132235;border-radius:16px;padding:0 16px 0 46px;outline:none;font-weight:700;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}
.public-password-wrap input{padding-right:54px}
.public-input-wrap input:focus{border-color:var(--cork-red);background:#fff;box-shadow:0 0 0 4px rgba(255,68,56,.12)}
.public-password-toggle{position:absolute;right:10px;width:38px;height:38px;border-radius:12px;background:rgba(18,60,100,.08);display:flex;align-items:center;justify-content:center;cursor:pointer;color:#50657d;transition:background .2s ease,color .2s ease}
.public-password-toggle:hover{background:rgba(255,68,56,.12);color:var(--cork-red)}
.public-password-toggle svg{width:21px;height:21px;fill:currentColor}
.public-login-options{display:flex;align-items:center;justify-content:space-between;gap:12px}
.public-check{display:flex;align-items:center;gap:8px;color:#5d6d82;font-weight:700;font-size:.92rem;cursor:pointer}
.public-check input{width:16px;height:16px;accent-color:var(--cork-red)}
.public-login-submit{width:100%;min-height:52px;gap:8px;margin-top:4px}
.public-login-submit svg{width:20px;height:20px;fill:currentColor}

/* Large Desktop ≥1600px */
@media (min-width:1600px){
  :root{--maxw:1440px}
  .hero-slideshow{max-height:860px}
  .hero-content h1{font-size:clamp(4.2rem,5.2vw,6.2rem)}
  .hero-content p{font-size:1.16rem}
  .public-login-wrap{grid-template-columns:minmax(0,1fr) minmax(420px,540px)}
}

/* Desktop 1200–1599px */
@media (min-width:1200px) and (max-width:1599px){
  :root{--maxw:1220px}
  .hero-slideshow{max-height:790px}
  .public-login-section{padding:clamp(24px,4.2vh,52px) 0}
  .public-login-wrap{grid-template-columns:minmax(0,1fr) minmax(380px,500px)}
  .public-login-card{padding:28px 34px}
}

/* Small Desktop 992–1199px */
@media (min-width:992px) and (max-width:1199px){
  :root{--maxw:1040px}
  .site-nav .nav-inner{grid-template-columns:minmax(190px,.7fr) auto minmax(90px,.7fr);gap:18px;padding-left:22px;padding-right:22px}
  .nav-links{gap:18px}
  .nav-links a{font-size:.78rem}
  .brand-text{font-size:1rem}
  .hero-content h1{font-size:clamp(3.2rem,6vw,4.6rem)}
  .card-grid,.program-grid,.facility-grid,.testimonial-grid{grid-template-columns:repeat(2,1fr)}
  .service-list{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .about-grid,.booking-grid,.contact-grid,.coach-hero-grid,.coach-two-col{grid-template-columns:1fr}
  .public-login-section{padding:24px 0}
  .public-login-wrap{grid-template-columns:minmax(0,1fr) minmax(350px,440px);gap:30px}
  .public-login-card{padding:24px 28px}
}

/* Laptop 768–991px */
@media (min-width:768px) and (max-width:991px){
  .site-nav{--nav-h:70px}
  .site-nav .nav-inner{grid-template-columns:52px minmax(0,1fr) 52px;min-height:var(--nav-h);padding-left:16px;padding-right:16px;gap:10px}
  .site-nav .nav-actions{display:contents}
  .site-nav .nav-toggle{grid-column:1;grid-row:1;display:flex;justify-self:start}
  .site-nav .brand{grid-column:2;grid-row:1;justify-self:center;gap:0;text-align:center}
  .site-nav .brand-logo{display:none!important}
  .site-nav .brand-text{display:block;font-size:clamp(1.05rem,2.4vw,1.28rem);line-height:1;letter-spacing:.045em}
  .site-nav .login-icon{grid-column:3;grid-row:1;justify-self:end;width:46px;height:46px;padding:0;border-radius:50%}
  .site-nav .login-icon span{display:none}
  .site-nav .login-icon svg{width:22px;height:22px}
  .nav-links{position:fixed;left:0;right:0;top:var(--nav-h);background:rgba(10,31,51,.98);border-bottom:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;align-items:flex-start;gap:0;padding:0 24px;max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease}
  .nav-links.is-open{max-height:460px;padding-top:10px;padding-bottom:18px}
  .nav-links a{width:100%;padding:12px 0}
  .hero-slideshow{height:auto;min-height:620px}
  .hero-content{padding-top:58px!important;padding-bottom:58px!important}
  .slide-arrows{display:none}
  .about-grid,.booking-grid,.contact-grid,.coach-hero-grid,.coach-two-col{grid-template-columns:1fr}
  .card-grid,.program-grid,.facility-grid,.testimonial-grid,.service-list,.gallery-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .coach-photo-panel{order:-1}
  .coach-card-grid,.coach-mini-grid,.coach-stat-grid{grid-template-columns:1fr 1fr}
  .coach-stat-card{border-right:0;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:16px}
  .public-login-section{min-height:auto;padding:44px 0}
  .public-login-wrap{grid-template-columns:1fr;max-width:640px}
  .public-login-intro{text-align:center}
  .public-login-intro .section-tag{justify-content:center}
  .public-login-intro h1{margin-left:auto;margin-right:auto}
  .public-login-intro p{margin-left:auto;margin-right:auto}
  .public-login-card{max-width:540px;margin:0 auto}
}

/* Tablet 576–767px */
@media (min-width:576px) and (max-width:767px){
  .site-nav{--nav-h:70px}
  .wrap,.hero-content,.public-login-wrap{width:min(100% - 36px,var(--maxw))}
  .section{padding:62px 0}
  .site-nav .nav-inner{grid-template-columns:52px minmax(0,1fr) 52px;min-height:var(--nav-h);padding-left:14px;padding-right:14px;gap:8px}
  .site-nav .nav-actions{display:contents}
  .site-nav .nav-toggle{grid-column:1;grid-row:1;display:flex;justify-self:start}
  .site-nav .brand{grid-column:2;grid-row:1;justify-self:center;gap:0;text-align:center}
  .site-nav .brand-logo{display:none!important}
  .site-nav .brand-text{font-size:clamp(1.05rem,4vw,1.28rem);line-height:1;letter-spacing:.045em}
  .site-nav .login-icon{grid-column:3;grid-row:1;justify-self:end;width:46px;height:46px;padding:0;border-radius:50%}
  .site-nav .login-icon span{display:none}
  .site-nav .login-icon svg{width:22px;height:22px}
  .nav-links{position:fixed;left:0;right:0;top:var(--nav-h);background:rgba(10,31,51,.98);border-bottom:1px solid rgba(255,255,255,.08);flex-direction:column;align-items:flex-start;gap:0;padding:0 24px;max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease}
  .nav-links.is-open{max-height:460px;padding-top:10px;padding-bottom:18px}
  .nav-links a{width:100%;padding:12px 0}
  .hero-slideshow{height:auto;min-height:580px}
  .hero-content{padding-top:52px!important;padding-bottom:52px!important}
  .hero-content h1{font-size:clamp(2.5rem,9vw,3.8rem)}
  .slide-arrows{display:none}
  .hero-cta-row,.modal-actions{flex-direction:column;align-items:stretch}
  .btn{width:100%;text-align:center}
  .stats-grid,.card-grid,.program-grid,.facility-grid,.testimonial-grid,.service-list,.gallery-grid,.contact-cards{grid-template-columns:1fr 1fr}
  .about-grid,.booking-grid,.contact-grid,.coach-hero-grid,.coach-two-col{grid-template-columns:1fr}
  .map-open-link{position:static;border-radius:0;min-height:46px}
  .footer-grid{grid-template-columns:1fr 1fr!important;gap:26px 18px!important}
  .footer-grid>div:first-child{grid-column:1/-1;text-align:left}
  .footer-grid>div:nth-child(4){grid-column:1/-1;text-align:left}
  .footer-bottom span{font-size:.8rem;line-height:1.35}
  .coach-card-grid,.coach-mini-grid,.coach-stat-grid{grid-template-columns:1fr 1fr}
  .public-login-section{min-height:auto;padding:38px 0 48px}
  .public-login-wrap{display:block}
  .public-login-intro{margin:0 auto 24px;text-align:center}
  .public-login-intro h1{display:none!important}
  .public-login-intro .section-tag{justify-content:center}
  .public-login-intro p{text-align:justify;font-size:1rem;max-width:100%}
  .public-login-card{max-width:540px;margin:0 auto}
}

/* Mobile <576px */
@media (max-width:575px){
  .site-nav{--nav-h:70px}
  html,body{overflow-x:hidden}
  .wrap,.hero-content,.public-login-wrap{width:100%;max-width:100%;padding-left:18px!important;padding-right:18px!important}
  .section{padding:56px 0}
  .section-head{margin-bottom:34px}
  .section-head h2,.about-grid h2,.booking-grid h2,.contact-grid h2{font-size:clamp(1.65rem,8vw,2.2rem)}
  .site-nav .nav-inner{grid-template-columns:48px minmax(0,1fr) 48px;min-height:var(--nav-h);padding-left:14px;padding-right:14px;gap:8px}
  .site-nav .nav-actions{display:contents}
  .site-nav .nav-toggle{grid-column:1;grid-row:1;display:flex;justify-self:start;width:44px;height:44px}
  .site-nav .brand{grid-column:2;grid-row:1;justify-self:center;margin:0;gap:0;text-align:center;min-width:0}
  .site-nav .brand-logo{display:none!important}
  .site-nav .brand-text{display:block;font-size:clamp(1rem,4.7vw,1.24rem);line-height:1;letter-spacing:.04em;white-space:nowrap;overflow:visible;text-overflow:clip}
  .site-nav .login-icon{grid-column:3;grid-row:1;justify-self:end;width:44px;height:44px;padding:0;border-radius:50%}
  .site-nav .login-icon span{display:none}
  .site-nav .login-icon svg{width:22px;height:22px}
  .nav-links{position:fixed;left:0;right:0;top:var(--nav-h);background:rgba(10,31,51,.98);border-bottom:1px solid rgba(255,255,255,.08);flex-direction:column;align-items:flex-start;gap:0;padding:0 24px;max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease}
  .nav-links.is-open{max-height:460px;padding-top:10px;padding-bottom:18px}
  .nav-links a{width:100%;padding:12px 0}
  .hero-slideshow{height:auto;min-height:704px}
  .hero-content{padding-top:48px!important;padding-bottom:48px!important}
  .hero-eyebrow{font-size:.7rem;letter-spacing:.13em}
  .hero-content h1{font-size:clamp(2.45rem,12vw,3.35rem)}
  .hero-content p{font-size:1rem;line-height:1.65}
  .hero-cta-row,.modal-actions{flex-direction:column;align-items:stretch}
  .btn{width:100%;text-align:center}
  .hero-badges span{font-size:.68rem}
  .slide-arrows{display:none}
  .stats-grid{grid-template-columns:1fr 1fr;gap:18px}
  .stat-card{border-right:0;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:16px}
  .card-grid,.program-grid,.facility-grid,.testimonial-grid,.service-list,.gallery-grid,.contact-cards,.about-grid,.booking-grid,.contact-grid,.coach-hero-grid,.coach-two-col,.coach-card-grid,.coach-mini-grid{grid-template-columns:1fr}
  .map-card,.map-card iframe{min-height:300px}
  .map-open-link{position:static;border-radius:0;min-height:46px}
  .site-footer{padding-top:44px}
  .footer-grid{grid-template-columns:1fr 1fr!important;gap:26px 18px!important;text-align:left;align-items:start}
  .footer-grid>div:first-child{grid-column:1/-1;text-align:left}
  .footer-grid>div:nth-child(2){grid-column:1}
  .footer-grid>div:nth-child(3){grid-column:2}
  .footer-grid>div:nth-child(4){grid-column:1/-1;text-align:left!important;justify-self:stretch;max-width:none;width:100%;margin-top:4px}
  .footer-grid>div:nth-child(4) h3,.footer-grid>div:nth-child(4) p{text-align:left!important}
  .footer-grid h3{margin-bottom:10px;font-size:.8rem}
  .footer-grid a,.footer-grid p{font-size:.84rem}
  .footer-bottom{margin-top:32px}
  .footer-bottom span{font-size:.72rem;line-height:1.35}
  .modal-card{padding:34px 20px 26px;border-radius:20px}
  .coach-hero{padding:54px 0 48px}
  .coach-actions{flex-direction:column}
  .champion-spotlight{grid-template-columns:1fr;text-align:center}
  .champion-medal{margin:0 auto}
  .coach-stat-grid{grid-template-columns:1fr 1fr}
  .coach-stat-card{border-right:0;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:16px}
  .public-login-section{min-height:auto;display:block;padding:34px 0 48px;overflow-x:hidden}
  .public-login-wrap{display:block;margin-left:auto;margin-right:auto;overflow:hidden;box-sizing:border-box}
  .public-login-intro{width:100%;max-width:100%;margin:0 auto 24px;box-sizing:border-box}
  .public-login-intro h1{display:none!important}
  .public-login-intro .section-tag{justify-content:center}
  .public-login-intro p{width:100%;max-width:100%;min-width:0;text-align:justify;font-size:.98rem;line-height:1.65;overflow-wrap:break-word;box-sizing:border-box}
  .public-login-card{width:100%;max-width:100%;min-width:0;margin:0 auto;padding:24px 22px;border-radius:20px;overflow:hidden;box-sizing:border-box}
  .public-login-card h2{font-size:2rem}
  .public-login-card p{font-size:.94rem}
  .public-login-form,.public-form-group,.public-input-wrap{width:100%;max-width:100%;min-width:0;box-sizing:border-box}
  .public-input-wrap input{width:100%;max-width:100%;min-width:0;box-sizing:border-box}
  .public-login-options{align-items:flex-start;flex-direction:column}
}

/* Small mobile tuning */
@media (max-width:380px){
  .wrap,.hero-content,.public-login-wrap{padding-left:14px!important;padding-right:14px!important}
  .site-nav .brand-text{font-size:clamp(.94rem,4.2vw,1.08rem);letter-spacing:.03em}
  .site-nav .nav-inner{grid-template-columns:44px minmax(0,1fr) 44px;padding-left:10px;padding-right:10px}
  .site-nav .login-icon,.nav-toggle{width:42px;height:42px}
  .public-login-card{padding-left:18px;padding-right:18px}
  .public-input-wrap input{height:50px}
  .footer-grid{gap:24px 14px}
}

/* Short laptop height tuning */
@media (min-width:992px) and (max-height:780px){
  .public-login-section{padding:20px 0}
  .public-login-intro h1{font-size:1.8rem!important;margin-bottom:14px!important}
  .public-login-intro p{font-size:.96rem;line-height:1.55}
  .public-login-card{padding:22px 28px;border-radius:20px}
  .public-login-card-head{margin-bottom:16px}
  .public-login-card h2{font-size:2rem}
  .public-login-form{gap:12px}
  .public-input-wrap input{height:48px}
  .public-login-submit{min-height:48px}
}

/* Very short screens: never clip login content */
@media (max-height:640px){
  .public-login-section{min-height:auto;align-items:flex-start}
}

/* =========================================================
   SVA Remaining Responsive Fixes - 2026-07-01
   Fixes only:
   1) mobile navigation dropdown position
   2) mobile hero buttons in one row
   3) about coach image sizing/position
   4) coach name single line on desktop/laptop
   5) slightly smaller home hero title
   ========================================================= */

/* Slightly reduce homepage hero title without changing design */
.hero-content h1{
  font-size:clamp(2.45rem,5.8vw,4.85rem) !important;
}

/* Keep mobile hamburger dropdown professional and below header */
@media (max-width:1060px){
  .site-nav{
    position:sticky;
    top:0;
    z-index:3000;
  }

  .site-nav .nav-inner{
    position:relative;
  }

  .site-nav .nav-links{
    position:absolute !important;
    top:100% !important;
    left:0 !important;
    right:0 !important;
    width:100% !important;
    max-width:none !important;
    z-index:2999 !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    justify-content:flex-start !important;
    gap:0 !important;
    background:rgba(10,31,51,.98) !important;
    border-top:1px solid rgba(255,255,255,.08) !important;
    border-bottom:1px solid rgba(255,255,255,.10) !important;
    box-shadow:0 18px 35px rgba(0,0,0,.24) !important;
    backdrop-filter:blur(12px) !important;
    padding:0 clamp(18px,5vw,28px) !important;
    max-height:0 !important;
    overflow:hidden !important;
    opacity:0 !important;
    visibility:hidden !important;
    transform:translateY(-6px) !important;
    transition:max-height .28s ease, padding .28s ease, opacity .22s ease, transform .22s ease, visibility .22s ease !important;
  }

  .site-nav .nav-links.is-open{
    max-height:420px !important;
    padding-top:12px !important;
    padding-bottom:14px !important;
    opacity:1 !important;
    visibility:visible !important;
    transform:translateY(0) !important;
  }

  .site-nav .nav-links a{
    width:100% !important;
    display:block !important;
    text-align:left !important;
    padding:11px 0 !important;
    margin:0 !important;
    line-height:1.25 !important;
  }

  .site-nav .nav-links a:after{
    bottom:5px !important;
  }
}

/* Homepage mobile buttons: keep side-by-side where space permits */
@media (max-width:575px){
  .hero-cta-row{
    display:flex !important;
    flex-direction:row !important;
    flex-wrap:wrap !important;
    align-items:center !important;
    gap:10px !important;
  }

  .hero-cta-row .btn{
    flex:1 1 calc(50% - 5px) !important;
    width:auto !important;
    min-width:138px !important;
    padding:12px 12px !important;
    font-size:.88rem !important;
    line-height:1.15 !important;
    white-space:nowrap !important;
  }

  .hero-content h1{
    font-size:clamp(2.2rem,10.2vw,2.95rem) !important;
  }
}

@media (max-width:340px){
  .hero-cta-row .btn{
    flex-basis:100% !important;
    width:100% !important;
  }
}

/* About Coach: image full visibility, smaller frame, upward position */
.coach-photo-panel{
  transform:translateY(clamp(-34px,-3.2vw,-12px)) !important;
}

.coach-photo-frame-large{
  width:min(310px,72vw) !important;
  height:auto !important;
  aspect-ratio:1/1 !important;
}

.coach-photo-frame-large img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  object-position:center 36% !important;
  padding:clamp(8px,1.45vw,14px) !important;
}

/* About Coach: keep name in one line on desktop/laptop */
@media (min-width:768px){
  .coach-hero h1{
    font-size:clamp(2.65rem,4.15vw,4.2rem) !important;
    white-space:nowrap !important;
    max-width:100% !important;
  }

  .coach-hero h1 span{
    display:inline !important;
  }

  .coach-hero h1 span:before{
    content:" ";
  }
}

/* Desktop/laptop coach image tuning */
@media (min-width:1200px){
  .coach-photo-frame-large{
    width:310px !important;
  }
}

@media (min-width:992px) and (max-width:1199px){
  .coach-photo-frame-large{
    width:270px !important;
  }

  .coach-photo-panel{
    transform:translateY(-24px) !important;
  }

  .coach-hero h1{
    font-size:clamp(2.45rem,3.9vw,3.55rem) !important;
  }
}

@media (min-width:768px) and (max-width:991px){
  .coach-photo-frame-large{
    width:min(270px,62vw) !important;
  }

  .coach-photo-panel{
    transform:translateY(-18px) !important;
  }

  .coach-hero h1{
    font-size:clamp(2.4rem,5.4vw,3.35rem) !important;
  }
}

/* Mobile coach image: smaller and centered */
@media (max-width:575px){
  .coach-photo-panel{
    transform:translateY(-10px) !important;
  }

  .coach-photo-frame-large{
    width:min(210px,62vw) !important;
  }

  .coach-photo-frame-large img{
    object-position:center 34% !important;
    padding:9px !important;
  }

  .coach-hero h1{
    font-size:clamp(2.1rem,10vw,2.8rem) !important;
  }
}

@media (max-width:380px){
  .coach-photo-frame-large{
    width:min(195px,62vw) !important;
  }
}

/* =========================================================
   SVA Cache, Zoom, Badges and Coach Fixes - 2026-07-01
   - Header/nav unchanged.
   - Scales page content slightly.
   - Fixes coach name/photo responsiveness.
   - Fixes mobile hero badges and buttons.
   ========================================================= */

/* Scale down only page content areas, not header/navbar */
body:not(.landing-login-page) main,
body:not(.landing-login-page) .stats-strip,
body:not(.landing-login-page) .site-footer{
  zoom:.90;
}

@supports not (zoom:1){
  body:not(.landing-login-page) main,
  body:not(.landing-login-page) .stats-strip,
  body:not(.landing-login-page) .site-footer{
    transform:scale(.90);
    transform-origin:top center;
    width:111.111%;
    margin-left:-5.555%;
  }
}

/* Keep homepage hero title slightly smaller and balanced */
.hero-content h1{
  font-size:clamp(2.30rem,5.35vw,4.55rem) !important;
}

/* Mobile homepage CTA buttons in one row where possible */
@media (max-width:575px){
  .hero-cta-row{
    display:flex !important;
    flex-direction:row !important;
    flex-wrap:wrap !important;
    align-items:center !important;
    gap:10px !important;
  }

  .hero-cta-row .btn{
    flex:1 1 calc(50% - 5px) !important;
    width:auto !important;
    min-width:132px !important;
    padding:11px 10px !important;
    font-size:.84rem !important;
    line-height:1.15 !important;
    white-space:nowrap !important;
  }

  /* Two badges per row on mobile */
  .hero-badges{
    display:grid !important;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:10px !important;
    width:100% !important;
    max-width:100% !important;
  }

  .hero-badges span{
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;
    width:100% !important;
    min-width:0 !important;
    white-space:normal !important;
    line-height:1.25 !important;
    padding:7px 8px !important;
    font-size:.66rem !important;
  }
}

@media (max-width:340px){
  .hero-cta-row .btn{
    flex-basis:100% !important;
    width:100% !important;
  }
}

/* About Coach: keep Adnan Ansari in one row on mobile also */
.coach-hero h1{
  white-space:nowrap !important;
}

.coach-hero h1 span{
  display:inline !important;
}

.coach-hero h1 span:before{
  content:" ";
}

/* About Coach photo: smaller frame, full image visible, slightly upward */
.coach-photo-panel{
  transform:translateY(clamp(-34px,-3vw,-12px)) !important;
}

.coach-photo-frame-large{
  width:min(300px,70vw) !important;
  height:auto !important;
  aspect-ratio:1/1 !important;
}

.coach-photo-frame-large img{
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  object-position:center 32% !important;
  padding:clamp(8px,1.35vw,13px) !important;
}

/* Desktop and laptop: one-line coach name with proportional font */
@media (min-width:992px){
  .coach-hero h1{
    font-size:clamp(2.35rem,3.8vw,3.95rem) !important;
  }

  .coach-photo-frame-large{
    width:285px !important;
  }
}

@media (min-width:768px) and (max-width:991px){
  .coach-hero h1{
    font-size:clamp(2.25rem,4.7vw,3.10rem) !important;
  }

  .coach-photo-frame-large{
    width:min(260px,58vw) !important;
  }
}

/* Mobile: smaller coach image and one-line name */
@media (max-width:575px){
  .coach-hero h1{
    font-size:clamp(1.70rem,8.2vw,2.35rem) !important;
    white-space:nowrap !important;
  }

  .coach-photo-panel{
    transform:translateY(-8px) !important;
  }

  .coach-photo-frame-large{
    width:min(190px,58vw) !important;
  }

  .coach-photo-frame-large img{
    object-position:center 30% !important;
    padding:8px !important;
  }
}

@media (max-width:380px){
  .coach-hero h1{
    font-size:clamp(1.55rem,7.6vw,2.05rem) !important;
  }

  .coach-photo-frame-large{
    width:min(175px,58vw) !important;
  }
}

/* =========================================================
   Mobile Hero Badges Gap Reduction - 2026-07-01
   Reduces excess vertical space after .hero-badges on mobile.
   ========================================================= */
@media (max-width:575px){
  .hero-slideshow{
    min-height:535px !important;
    height:auto !important;
    max-height:none !important;
  }

  .hero-content{
    padding-top:28px !important;
    padding-bottom:56px !important;
    justify-content:flex-start !important;
  }

  .hero-badges{
    margin-top:18px !important;
    margin-bottom:0 !important;
  }

  .slide-dots{
    bottom:18px !important;
  }
}

@media (max-width:380px){
  .hero-slideshow{
    min-height:520px !important;
  }

  .hero-content{
    padding-top:24px !important;
    padding-bottom:52px !important;
  }

  .hero-badges{
    margin-top:14px !important;
  }

  .slide-dots{
    bottom:16px !important;
  }
}

/* =========================================================
   Desktop Laptop Sticky Header Fix - 2026-07-01
   Keeps header/navbar sticky on desktop and laptop scrolling.
   Mobile behavior is not changed.
   ========================================================= */
@media (min-width:768px){
  .site-nav{
    position:sticky !important;
    position:-webkit-sticky !important;
    top:0 !important;
    z-index:6000 !important;
    width:100% !important;
  }

  .site-nav .nav-inner{
    position:relative !important;
    z-index:6001 !important;
  }

  html{
    scroll-padding-top:82px !important;
  }
}

/* =========================================================
   Fixed Header Navbar All Views - 2026-07-01
   Makes .site-nav / .site-nav .nav-inner visible at top
   while scrolling on desktop, laptop, tablet and mobile.
   ========================================================= */
:root{
  --sva-fixed-header-height:70px;
}

html{
  scroll-padding-top:var(--sva-fixed-header-height) !important;
}

body{
  padding-top:var(--sva-fixed-header-height) !important;
}

.site-nav{
  position:fixed !important;
  position:-webkit-sticky !important;
  top:0 !important;
  left:0 !important;
  right:0 !important;
  width:100% !important;
  z-index:99999 !important;
  transform:none !important;
  will-change:auto !important;
}

.site-nav .nav-inner{
  position:relative !important;
  z-index:100000 !important;
}

/* Mobile/tablet dropdown must open directly below the fixed header */
@media (max-width:1060px){
  .site-nav .nav-links{
    position:absolute !important;
    top:100% !important;
    left:0 !important;
    right:0 !important;
    width:100% !important;
    z-index:99998 !important;
  }
}

/* Keep header height variable aligned with the existing responsive header sizes */
@media (min-width:1200px){
  :root{
    --sva-fixed-header-height:70px;
  }
}

@media (min-width:768px) and (max-width:1199px){
  :root{
    --sva-fixed-header-height:70px;
  }
}

@media (max-width:767px){
  :root{
    --sva-fixed-header-height:70px;
  }
}

/* =========================================================
   Mobile Fixed Header and Refresh Top Fix - 2026-07-01
   Fixes:
   - Mobile header/nav stays fixed at top.
   - Mobile dropdown opens below header.
   - Prevents visual content from sliding under fixed header.
   ========================================================= */

/* Use an explicit fixed-header height variable */
:root{
  --sva-fixed-header-height:70px;
}

html{
  scroll-padding-top:var(--sva-fixed-header-height) !important;
}

body{
  padding-top:var(--sva-fixed-header-height) !important;
}

/* Fixed header for all devices */
.site-nav{
  position:fixed !important;
  top:0 !important;
  left:0 !important;
  right:0 !important;
  width:100% !important;
  z-index:999999 !important;
  transform:none !important;
  margin:0 !important;
}

/* Ensure the visible header row itself remains fixed-looking and above all content */
.site-nav .nav-inner{
  position:relative !important;
  z-index:1000000 !important;
  width:100% !important;
  max-width:var(--maxw) !important;
  margin-left:auto !important;
  margin-right:auto !important;
}

/* Mobile/tablet menu opens below the fixed header, not in the hero middle */
@media (max-width:1060px){
  :root{
    --sva-fixed-header-height:70px;
  }

  body{
    padding-top:var(--sva-fixed-header-height) !important;
  }

  .site-nav{
    position:fixed !important;
    top:0 !important;
    left:0 !important;
    right:0 !important;
    width:100% !important;
    min-height:var(--sva-fixed-header-height) !important;
  }

  .site-nav .nav-inner{
    min-height:var(--sva-fixed-header-height) !important;
    width:100% !important;
    max-width:none !important;
  }

  .site-nav .nav-links{
    position:fixed !important;
    top:var(--sva-fixed-header-height) !important;
    left:0 !important;
    right:0 !important;
    width:100% !important;
    z-index:999998 !important;
    background:rgba(10,31,51,.985) !important;
    border-top:1px solid rgba(255,255,255,.08) !important;
    border-bottom:1px solid rgba(255,255,255,.10) !important;
    box-shadow:0 18px 35px rgba(0,0,0,.24) !important;
    backdrop-filter:blur(12px) !important;
    padding-left:24px !important;
    padding-right:24px !important;
  }

  .site-nav .nav-links.is-open{
    max-height:420px !important;
    padding-top:12px !important;
    padding-bottom:14px !important;
  }
}

/* Small mobile alignment */
@media (max-width:575px){
  :root{
    --sva-fixed-header-height:70px;
  }

  .site-nav .nav-inner{
    min-height:var(--sva-fixed-header-height) !important;
  }
}

@media (max-width:380px){
  :root{
    --sva-fixed-header-height:66px;
  }

  .site-nav .nav-inner{
    min-height:var(--sva-fixed-header-height) !important;
  }
}

/* =========================================================
   About Coach Photo Frame Fit Fix - 2026-07-02
   Keeps the coach image inside the first circular coach-photo-frame.
   This overrides earlier contain/padding rules that made portrait photos
   appear as a rectangle inside the circle.
   ========================================================= */
body.coach-page .coach-photo-frame-large{
  position:relative !important;
  display:grid !important;
  place-items:center !important;
  overflow:hidden !important;
  border-radius:50% !important;
}

body.coach-page .coach-photo-frame-large::before{
  content:none !important;
  display:none !important;
  border:0 !important;
}

body.coach-page .coach-photo-frame-large img{
  position:absolute !important;
  inset:0 !important;
  z-index:1 !important;
  width:100% !important;
  height:100% !important;
  max-width:none !important;
  max-height:none !important;
  padding:0 !important;
  margin:0 !important;
  border-radius:50% !important;
  object-fit:cover !important;
  object-position:center 37% !important;
  clip-path:circle(50% at 50% 50%) !important;
}

body.coach-page .coach-photo-fallback{
  z-index:0 !important;
}

/* =========================================================
   About Coach - Head Coach Tag Below Photo Frame
   Adds a clear role tag directly below the circular coach photo.
   ========================================================= */
.coach-photo-panel{
  flex-direction:column !important;
  align-items:center !important;
  gap:18px !important;
}

.coach-photo-panel::after{
  content:"Head Coach";
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:180px;
  padding:10px 22px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--champion-gold),#ff8f00);
  color:#08192a;
  font-family:'Oswald',sans-serif;
  font-size:1rem;
  font-weight:700;
  letter-spacing:.10em;
  line-height:1;
  text-transform:uppercase;
  box-shadow:0 14px 35px rgba(255,182,39,.24);
  border:1px solid rgba(255,255,255,.18);
}

@media (max-width:575px){
  .coach-photo-panel{
    gap:12px !important;
  }

  .coach-photo-panel::after{
    min-width:150px;
    padding:9px 18px;
    font-size:.84rem;
    letter-spacing:.08em;
  }
}

/* =========================================================
   Public Login / Landing Professional Theme Refinement
   Presentation-only update for the Sports Vault Arena theme.
   ========================================================= */
:root{
  --sva-ui-blue:#1d4ed8;
  --sva-ui-cyan:#0ea5e9;
  --sva-ui-gold:#f5b21a;
  --sva-ui-red:#ff3b35;
  --sva-ui-navy:#071b3f;
}

.landing-login-page .public-login-section{
  background:
    radial-gradient(circle at 12% 8%,rgba(14,165,233,.18),transparent 24rem),
    radial-gradient(circle at 92% 12%,rgba(245,178,26,.14),transparent 22rem),
    linear-gradient(135deg,#06182c 0%,#0b223d 55%,#101827 100%);
}

.landing-login-page .public-login-card{
  border:1px solid rgba(255,255,255,.14) !important;
  box-shadow:0 28px 80px rgba(0,0,0,.34) !important;
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(245,250,255,.94)) !important;
}

.landing-login-page .public-login-card-head h2{
  color:var(--sva-ui-navy) !important;
}

.landing-login-page .public-login-card-head .eyebrow,
.landing-login-page .public-login-intro .eyebrow{
  color:var(--sva-ui-gold) !important;
}

.landing-login-page .input-icon input{
  border-color:rgba(29,78,216,.20) !important;
  background:#fff !important;
  box-shadow:0 8px 20px rgba(15,23,42,.05) !important;
}

.landing-login-page .input-icon input:focus{
  border-color:var(--sva-ui-blue) !important;
  box-shadow:0 0 0 .22rem rgba(29,78,216,.16) !important;
}

.landing-login-page .public-login-submit{
  background:linear-gradient(135deg,var(--sva-ui-blue),var(--sva-ui-cyan)) !important;
  box-shadow:0 18px 34px rgba(29,78,216,.28) !important;
}

.landing-login-page .public-login-submit:hover{
  transform:translateY(-2px);
  box-shadow:0 22px 44px rgba(29,78,216,.36) !important;
}

.landing-login-page .login-alert{
  border-left:5px solid currentColor !important;
  border-radius:16px !important;
}

.site-nav{
  background:rgba(6,24,44,.92) !important;
  border-bottom:1px solid rgba(255,255,255,.10) !important;
  backdrop-filter:blur(16px) !important;
}

.site-nav .nav-links a.is-active,
.site-nav .nav-links a:hover{
  color:var(--sva-ui-gold) !important;
}

/* =========================================================
   Public Landing Desktop Fit Standardization - 2026-07-03
   Purpose:
   - Fix homepage/public landing layout on all desktop resolutions.
   - Remove the earlier 90% visual zoom from landing pages only.
   - Use fluid desktop gutters and wider containers so the hero/header
     fit 1920, 1680, 1600, 1440, 1366, 1280, 1152 and 1024 widths.
   - Preserve mobile/tablet menu behavior and existing theme.
   ========================================================= */
:root{
  --sva-landing-gutter:clamp(28px,4.2vw,84px);
  --sva-landing-container:calc(100vw - (var(--sva-landing-gutter) * 2));
}

/* The public website should fit the screen naturally.  The admin/app
   90% compacting remains in app.css; landing pages must not be zoomed,
   otherwise large desktops show oversized empty side zones. */
body:not(.landing-login-page) main,
body:not(.landing-login-page) .stats-strip,
body:not(.landing-login-page) .site-footer{
  zoom:1 !important;
  transform:none !important;
  transform-origin:initial !important;
  width:100% !important;
  max-width:none !important;
  margin-left:0 !important;
  margin-right:0 !important;
}

/* Fluid page width for desktop and laptop public pages */
.wrap,
.hero-content,
.public-login-wrap,
.site-nav .nav-inner{
  width:min(var(--sva-landing-container),var(--maxw)) !important;
  max-width:var(--maxw) !important;
  margin-left:auto !important;
  margin-right:auto !important;
  padding-left:0 !important;
  padding-right:0 !important;
}

.site-nav .nav-inner{
  padding-top:10px !important;
  padding-bottom:10px !important;
}

.hero-content{
  min-width:0 !important;
}

.hero-slideshow{
  width:100% !important;
  min-height:clamp(560px,calc(100svh - var(--sva-fixed-header-height,70px)),790px) !important;
  height:clamp(560px,calc(100svh - var(--sva-fixed-header-height,70px)),790px) !important;
  max-height:790px !important;
}

.hero-content h1{
  max-width:12.5ch !important;
}

.hero-content p{
  max-width:58ch !important;
}

.slide img{
  object-fit:cover !important;
  object-position:center center !important;
}

/* Very large monitors */
@media (min-width:1800px){
  :root{
    --maxw:1680px;
    --sva-landing-gutter:clamp(70px,5vw,110px);
  }
  .hero-content h1{font-size:clamp(3.6rem,4.7vw,5.25rem) !important;}
  .hero-content p{font-size:1.08rem !important;}
  .nav-links{gap:clamp(22px,1.7vw,34px) !important;}
}

/* 1600 to 1799 desktops */
@media (min-width:1600px) and (max-width:1799px){
  :root{
    --maxw:1520px;
    --sva-landing-gutter:clamp(52px,4.2vw,78px);
  }
  .hero-content h1{font-size:clamp(3.35rem,4.6vw,4.95rem) !important;}
}

/* 1440 to 1599 desktops */
@media (min-width:1440px) and (max-width:1599px){
  :root{
    --maxw:1360px;
    --sva-landing-gutter:clamp(38px,3.6vw,56px);
  }
  .nav-links{gap:22px !important;}
  .hero-content h1{font-size:clamp(3.05rem,4.8vw,4.65rem) !important;}
}

/* 1366/1400 laptops and small desktops */
@media (min-width:1280px) and (max-width:1439px){
  :root{
    --maxw:calc(100vw - 72px);
    --sva-landing-gutter:36px;
  }
  .site-nav .nav-inner{
    grid-template-columns:minmax(210px,.88fr) auto minmax(96px,.62fr) !important;
    gap:18px !important;
  }
  .nav-links{gap:18px !important;}
  .nav-links a{font-size:.80rem !important;}
  .brand-text{font-size:1rem !important;}
  .login-icon{padding:9px 17px !important;}
  .hero-content h1{font-size:clamp(2.85rem,5vw,4.15rem) !important;}
  .hero-content p{font-size:1.02rem !important;max-width:55ch !important;}
}

/* 1152 and 1024 width desktops */
@media (min-width:992px) and (max-width:1279px){
  :root{
    --maxw:calc(100vw - 52px);
    --sva-landing-gutter:26px;
  }
  .site-nav .nav-inner{
    grid-template-columns:minmax(185px,.8fr) auto minmax(82px,.55fr) !important;
    gap:14px !important;
  }
  .nav-links{gap:14px !important;}
  .nav-links a{font-size:.74rem !important;letter-spacing:.045em !important;}
  .brand-text{font-size:.93rem !important;}
  .site-nav .brand-logo{width:38px !important;height:38px !important;min-width:38px !important;min-height:38px !important;}
  .login-icon{padding:8px 14px !important;font-size:.78rem !important;}
  .hero-slideshow{min-height:600px !important;height:clamp(600px,calc(100svh - 70px),760px) !important;max-height:760px !important;}
  .hero-content h1{font-size:clamp(2.55rem,5.3vw,3.75rem) !important;}
  .hero-content p{font-size:.98rem !important;max-width:52ch !important;}
  .hero-cta-row{gap:12px !important;margin-top:26px !important;}
  .hero-badges{margin-top:22px !important;}
}

/* Low-height desktops/laptops like 1366x768 and 1280x720 */
@media (min-width:992px) and (max-height:820px){
  .hero-slideshow{
    min-height:calc(100svh - var(--sva-fixed-header-height,70px)) !important;
    height:calc(100svh - var(--sva-fixed-header-height,70px)) !important;
    max-height:none !important;
  }
  .hero-content{
    justify-content:center !important;
  }
  .hero-eyebrow{margin-bottom:14px !important;}
  .hero-content p{margin-top:18px !important;line-height:1.55 !important;}
  .hero-cta-row{margin-top:24px !important;}
  .hero-badges{margin-top:20px !important;}
  .stats-strip{padding:26px 0 !important;}
}

/* Keep tablet/mobile layouts from earlier fixes intact; only normalize width. */
@media (max-width:991px){
  .wrap,
  .hero-content,
  .public-login-wrap{
    width:100% !important;
    max-width:100% !important;
    padding-left:clamp(18px,4.6vw,34px) !important;
    padding-right:clamp(18px,4.6vw,34px) !important;
  }
  .site-nav .nav-inner{
    width:100% !important;
    max-width:none !important;
  }
}

/* =========================================================
   1024px Desktop Header Action Alignment Fix - 2026-07-03
   Keeps the Login button and hamburger menu at the far right
   on 1024x768 / small desktop widths without changing other
   landing page layouts.
   ========================================================= */
@media (min-width:992px) and (max-width:1060px){
  .site-nav .nav-inner{
    width:100% !important;
    max-width:none !important;
    padding-left:18px !important;
    padding-right:18px !important;
    grid-template-columns:minmax(0,1fr) auto !important;
    gap:12px !important;
  }

  .site-nav .brand{
    grid-column:1 !important;
    justify-self:start !important;
    min-width:0 !important;
  }

  .site-nav .nav-actions{
    grid-column:2 !important;
    justify-self:end !important;
    display:flex !important;
    align-items:center !important;
    justify-content:flex-end !important;
    gap:10px !important;
    min-width:max-content !important;
  }

  .site-nav .login-icon{
    order:1 !important;
    flex:0 0 auto !important;
    padding:8px 14px !important;
    min-height:42px !important;
  }

  .site-nav .nav-toggle{
    order:2 !important;
    display:flex !important;
    flex:0 0 42px !important;
    width:42px !important;
    height:42px !important;
    position:static !important;
    margin:0 !important;
  }

  .site-nav .nav-links{
    left:0 !important;
    right:0 !important;
    width:100% !important;
  }
}

/* =========================================================
   Stats Strip 80px Horizontal Center Fix - 2026-07-03
   Keeps the strip height at 80px, vertically centers the
   statistic content, and restores the earlier horizontal
   four-column spacing/gap across screen sizes.
   ========================================================= */
.stats-strip{
  height:80px !important;
  min-height:80px !important;
  max-height:80px !important;
  padding:0 !important;
  display:flex !important;
  align-items:center !important;
  overflow:hidden !important;
}

.stats-strip .wrap{
  height:100% !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}

.stats-grid{
  width:100% !important;
  height:80px !important;
  display:grid !important;
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:clamp(14px,2vw,24px) !important;
  align-items:center !important;
  text-align:center !important;
}

.stat-card{
  height:80px !important;
  min-height:80px !important;
  padding:0 12px !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  justify-content:center !important;
  border-right:1px solid rgba(255,255,255,.14) !important;
  border-bottom:0 !important;
  overflow:hidden !important;
}

.stat-card:last-child{
  border-right:0 !important;
}

.stat-card strong{
  font-size:clamp(1.55rem,2.25vw,2.05rem) !important;
  line-height:.95 !important;
  margin:0 !important;
  display:block !important;
}

.stat-card span{
  margin-top:5px !important;
  font-size:clamp(.58rem,.76vw,.72rem) !important;
  line-height:1.12 !important;
  letter-spacing:.065em !important;
  display:block !important;
  white-space:normal !important;
  max-width:100% !important;
}

@media (max-width:991px){
  .stats-strip{
    height:80px !important;
    min-height:80px !important;
    max-height:80px !important;
  }

  .stats-grid{
    grid-template-columns:repeat(4,minmax(0,1fr)) !important;
    gap:clamp(8px,1.8vw,16px) !important;
  }

  .stat-card{
    padding:0 6px !important;
  }

  .stat-card strong{
    font-size:clamp(1.30rem,3.8vw,1.72rem) !important;
  }

  .stat-card span{
    font-size:clamp(.50rem,1.25vw,.62rem) !important;
    letter-spacing:.045em !important;
  }
}

@media (max-width:575px){
  .stats-strip .wrap{
    padding-left:10px !important;
    padding-right:10px !important;
  }

  .stats-grid{
    gap:6px !important;
  }

  .stat-card{
    padding:0 4px !important;
  }

  .stat-card strong{
    font-size:clamp(1.15rem,5.6vw,1.45rem) !important;
  }

  .stat-card span{
    margin-top:4px !important;
    font-size:clamp(.44rem,2.05vw,.55rem) !important;
    line-height:1.08 !important;
    letter-spacing:.03em !important;
  }
}

/* =========================================================
   Stats Strip Card Gap Increase - 2026-07-03
   Keeps 80px height and vertical centering, while increasing
   horizontal space between statistic cards.
   ========================================================= */
.stats-grid{
  gap:clamp(30px,4vw,72px) !important;
}

.stat-card{
  padding-left:clamp(10px,1.2vw,18px) !important;
  padding-right:clamp(10px,1.2vw,18px) !important;
}

@media (max-width:1199px){
  .stats-grid{
    gap:clamp(22px,3vw,42px) !important;
  }
}

@media (max-width:991px){
  .stats-grid{
    gap:clamp(14px,2.4vw,28px) !important;
  }

  .stat-card{
    padding-left:6px !important;
    padding-right:6px !important;
  }
}

@media (max-width:575px){
  .stats-grid{
    gap:10px !important;
  }

  .stat-card{
    padding-left:4px !important;
    padding-right:4px !important;
  }
}

/* =========================================================
   About Section Left Content Up Adjustment - 2026-07-03
   Moves only the "About Sports Vault Arena" text block slightly
   upward on desktop/laptop while preserving the cards and all
   other landing page layouts.
   ========================================================= */
@media (min-width:992px){
  #about.about-section .about-grid > div:first-child{
    transform:translateY(-28px) !important;
  }
}

@media (min-width:768px) and (max-width:991px){
  #about.about-section .about-grid > div:first-child{
    transform:translateY(-16px) !important;
  }
}
