@charset "UTF-8";

/* ========== Design Tokens ========== */
:root{
  --brand-maroon:#8B2E29;
  --brand-maroon-700:#742622;
  --brand-accent:#30475e;
  --brand-accent-2:#4C96A7;
  --bg:#f7f7f9;
  --card:#ffffff;
  --ink:#111;
  --muted:#555;
  --link:#0b66c3;
  --ok:#2e7d32;
  --warn:#d32f2f;

  --radius:16px;
  --radius-sm:10px;
  --shadow:0 10px 24px rgba(0,0,0,.08);
  --shadow-sm:0 4px 12px rgba(0,0,0,.06);

  --container:1100px;
}

/* ========== Base ========== */
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family: "Roboto", system-ui, -apple-system, Segoe UI, Arial, sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  text-rendering:optimizeLegibility;
}

img{max-width:100%;height:auto;display:block}
a{color:var(--link);text-decoration:none}
a:focus,
button:focus{outline:3px solid #99c3ff;outline-offset:2px}
.hidden{display:none!important}

.container{max-width:var(--container);margin:auto;padding:0 16px}

/* Utilities */
.center{text-align:center}
.stack{display:flex;flex-direction:column;gap:16px}
.container.narrow{max-width:780px}
.grid{display:grid;gap:16px}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.filters-grid{display:grid;gap:16px;grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width:900px){
  .grid-3{grid-template-columns:1fr 1fr}
  .grid-4{grid-template-columns:1fr 1fr}
  .filters-grid{grid-template-columns:repeat(2,minmax(0,1fr))}

}
@media (max-width:640px){
  .grid-4,.grid-3,.grid-2,.filters-grid{grid-template-columns:1fr;}
}

/* Responsive photo sizing */
.club-photo{max-width:300px;width:100%;display:block;margin:0 auto 16px;border-radius:var(--radius)}

/* ========== Header ========== */
.top-ribbon{
  background:var(--ok);
  color:#fff;
  text-align:center;
  padding:8px 12px;
  font-size:14px;
}
.top-ribbon::before,.top-ribbon::after{content:"🐬";margin:0 4px}
.top-ribbon a{color:#fff;text-decoration:underline}

body > header{
  background:var(--brand-maroon);
  color:#fff;
  position:sticky;top:0;z-index:1000;
  box-shadow:var(--shadow-sm);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0}
.logo{max-width:220px;height:auto;flex-shrink:0}
.header-cta{display:flex;align-items:center;gap:10px}
.header-cta .button{display:none}
@media (min-width:400px){.header-cta .trial{display:inline-flex}}
@media (min-width:600px){.header-cta .register{display:inline-flex}}
@media (min-width:760px){.header-cta .facebook{display:inline-flex}}

@media (max-width:500px){
  .logo{max-width:180px}
  .header-cta{gap:8px}
  .header-cta .button{padding:8px 10px}
}

.button{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--brand-accent-2);
  color:#fff;
  padding:10px 14px;border-radius:10px;font-weight:600;
  transition:transform .08s ease, background .2s ease;
}
.button:hover{transform:translateY(-1px);background:#3a7f90}
.button.secondary{background:transparent;border:2px solid #fff}
.button.maroon{background:var(--brand-maroon)}
.button.light{background:#fff;color:#000}
.button.ghost{background:transparent;border:1px solid rgba(255,255,255,.5);color:#fff}

.button.loading{
  pointer-events:none;
  opacity:.75;
}
.button.loading::after{
  content:"";
  width:16px;height:16px;
  border:2px solid currentColor;
  border-top-color:transparent;
  border-radius:50%;
  animation:spin .6s linear infinite;
  margin-left:8px;
}
@keyframes spin{
  to{transform:rotate(360deg)}
}

/* Header CTA visibility */
.header-cta .trial,.header-cta .register,.header-cta .facebook{display:none}
@media (min-width:400px){.header-cta .trial{display:inline-flex}}
@media (min-width:600px){.header-cta .register{display:inline-flex}}
@media (min-width:760px){.header-cta .facebook{display:inline-flex}}

/* Nav */
nav{border-top:1px solid rgba(255,255,255,.15)}
.navbar{display:flex;gap:8px;flex-wrap:wrap;padding:8px 0}
.navbar a{
  color:#fff;font-weight:500;padding:8px 10px;border-radius:8px
}
.navbar a[aria-current="page"]{background:rgba(255,255,255,.12)}
.navbar a:hover{background:rgba(255,255,255,.2)}

/* Mobile Nav */
.burger{
  display:none;background:none;border:0;color:#fff;cursor:pointer;
  width:42px;height:42px;border-radius:10px
}
.burger svg{width:26px;height:26px}
@media (max-width:900px){
  .navbar{display:none}
  .burger{display:inline-flex;align-items:center;justify-content:center}
}
.mobile-drawer{
  position:fixed;inset:0 0 0 30%;
  translate:100% 0;background:var(--brand-maroon);
  color:#fff;padding:18px;transition:translate .25s ease;
  display:flex;flex-direction:column;gap:6px;z-index:9999
}
.mobile-drawer.open{translate:0 0}
.mobile-drawer a{color:#fff;padding:12px;border-radius:10px}
.mobile-drawer a:hover{background:rgba(255,255,255,.12)}
.mobile-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.35);backdrop-filter:saturate(0.8) blur(2px);
  opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:9998
}
.mobile-backdrop.show{opacity:1;pointer-events:auto}

/* ========== Hero / Intro ========== */
.intro{
  position:relative;min-height:420px;background:#000;color:#fff;overflow:hidden
}
.video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.7
}
.intro-overlay{
  position:relative;z-index:1;padding:70px 0 90px
}
.intro h1{font-size:clamp(28px,4vw,44px);line-height:1.1;margin:0 0 10px}
.intro p{max-width:720px;margin:0 auto 18px;color:#e9eef6}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}

/* ========== Sections ========== */
.section{padding:48px 0}
.section .kicker{letter-spacing:.08em;text-transform:uppercase;font-size:13px;color:var(--brand-accent);display:inline-block;margin-bottom:4px;font-weight:700}
.policy-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px 28px 36px;gap:28px}
.policy-header{gap:12px}
.policy-header .lead{margin-top:8px;max-width:60ch}
.policy-card ul{margin:0;padding-left:22px}
.policy-card li{margin-bottom:6px}
.policy-section{display:flex;flex-direction:column;gap:12px;padding-top:12px;border-top:1px solid #e8e8ee}
.policy-section:first-of-type{border-top:0;padding-top:0}
.policy-callout{background:linear-gradient(135deg,rgba(76,150,167,.12),rgba(48,71,94,.08));border:1px solid rgba(48,71,94,.2);border-radius:var(--radius-sm);padding:20px 22px;display:flex;flex-direction:column;gap:10px}
.policy-callout__title{margin:0;font-size:18px;color:var(--brand-accent)}
.policy-callout ul{display:grid;gap:8px;padding-left:20px;margin:0}
.policy-callout li{margin:0;line-height:1.5}
@media (max-width:640px){
  .policy-card{padding:22px 18px;gap:22px}
  .policy-callout{padding:18px}
}
.card{
  background:var(--card);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:20px
}
.card h3{margin:0 0 8px}
.card p{margin:0}

.lead{font-size:20px;color:var(--muted)}
h1,h2{line-height:1.2}
h2{font-size:clamp(22px,3vw,30px);margin:0 0 12px}
h1{font-size:clamp(26px,4vw,36px)}
hr{border:0;border-top:1px solid #e8e8ee;margin:12px 0 16px}

/* Accordions */
.accordion{border-radius:var(--radius);overflow:hidden}
.accordion-item{border:1px solid #e8e8ee;background:#fff;border-radius:12px;margin-bottom:10px}
.accordion-button{
  width:100%;text-align:left;background:#fff;border:0;padding:16px 18px;
  font-weight:600;cursor:pointer;border-radius:12px;display:flex;justify-content:space-between;align-items:center
}
.accordion-content{display:grid;grid-template-rows:0fr;transition:grid-template-rows .25s ease,padding .25s ease}
.accordion-content.open{grid-template-rows:1fr}
.accordion-inner{overflow:hidden}
.accordion-item.open .accordion-content{padding:0 18px 16px}

/* Tables */
.table{width:100%;border-collapse:collapse;border-radius:12px;overflow:hidden}
.table th,.table td{padding:12px;border-bottom:1px solid #ececf1;text-align:left}
.table th{background:#fafafc}
.table tr:last-child td{border-bottom:0}
.table td:last-child{text-align:right}
.table-wrapper{overflow-x:auto}
.table-status{margin-bottom:12px}
.table-status.status-error{color:#8b2e29;font-weight:500}

/* Sponsors */
.sponsors{background:#fff}
.sponsor-layout{display:flex;gap:40px;align-items:stretch}
.sponsor-major{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:16px;
  text-align:center;
  padding:24px 22px;
  background:#fff;
  border:1px solid #d9dde5;
  border-radius:24px;
  flex:0 0 clamp(240px,30%,340px);
  max-width:340px;
}
.sponsor-supporting{flex:1;display:flex;flex-direction:column}
.sponsor-major__badge,
.sponsor-list-heading{
  margin:0;
  font-size:1rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#4f4f4f;
}
.sponsor-major__badge{margin-bottom:6px}
.sponsor-major__card{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  max-width:320px;
  padding:4px 0 0;
  margin-inline:auto;
}
.sponsor-major__card img{
  display:block;
  max-height:160px;
  width:100%;
  max-width:320px;
  object-fit:contain;
}
.sponsor-list-heading{margin:0 0 20px;text-align:left}
.sponsor-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:center;padding-top:28px;border-top:4px solid #eff2f7}
@media (min-width:1100px){.sponsor-row{grid-template-columns:repeat(4,1fr)}}
@media (max-width:900px){
  .sponsor-layout{flex-direction:column;gap:32px}
  .sponsor-major{flex-basis:auto;max-width:520px}
  .sponsor-list-heading{text-align:center}
  .sponsor-row{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:680px){
  .sponsor-major{padding:22px 20px;gap:14px}
  .sponsor-major__card{padding:4px 0 0}
  .sponsor-major__card img{max-height:150px}
}
@media (max-width:520px){
  .sponsor-row{grid-template-columns:repeat(2,1fr)}
  .sponsor-major__card{padding:4px 0 0}
  .sponsor-major__card img{max-height:130px}
}
.sponsor{background:#fff;border:1px solid #eee;border-radius:14px;padding:12px;display:flex;align-items:center;justify-content:center}
.sponsor img{max-height:50px;width:auto}

/* ========== Footer ========== */
footer{background:#1f1f1f;color:#fff;padding:36px 0;margin-top:40px}
footer a{color:#cde2ff}
.footer-grid{display:grid;gap:16px;grid-template-columns:2fr 1fr 1fr}
@media (max-width:800px){.footer-grid{grid-template-columns:1fr}}

/* ========== Page-specific helpers ========== */
.hero-note{
  background:#eaf6ee;color:#0a5722;border:1px solid #bfe6c8;border-radius:12px;
  padding:10px 14px;display:inline-block;font-weight:600
}

.meta{color:#666;font-size:14px}
.kicker{font-weight:700;color:var(--brand-accent);text-transform:uppercase;letter-spacing:.04em}

/* Forms */

input,select,textarea{
  width:100%;padding:12px;border:1px solid #e2e2ea;border-radius:10px;background:#fff
}
label span{font-weight:600;margin-bottom:6px;display:block}

/* Signup form */
.form-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.swimmer{border:1px solid #e2e2ea;border-radius:var(--radius-sm);padding:16px;position:relative}
.swimmer legend{font-weight:700;padding:0 6px}
.swimmer .remove-swimmer{position:absolute;top:10px;right:10px}
.age-display{align-self:end;font-weight:600}
.checkbox{display:flex;align-items:center;gap:8px;margin-top:8px}
.agreement{display:flex;flex-direction:column;align-items:flex-start;gap:8px;margin-top:8px}
.agreement span{font-weight:400;margin-bottom:0}
.agreement select{max-width:200px}
.voucher-toggle{display:flex;align-items:center;gap:4px;margin-top:8px}
.voucher-toggle input{width:20px;height:20px}
.cost-summary{margin-top:20px;padding-top:16px;border-top:1px solid #e2e2ea}
.cost-summary ul{list-style:none;margin:0 0 12px;padding:0}
.cost-summary li{margin-bottom:6px}
.cost-summary .total{font-size:20px;font-weight:700}
.cost-summary .discount-line{color:var(--brand-maroon);font-weight:700;margin:8px 0}
.discount{color:var(--brand-maroon);font-weight:700;font-size:14px;margin-left:4px}
.alert-banner{
  background:linear-gradient(135deg,rgba(255,214,102,.32),rgba(255,179,71,.24));
  border:2px solid rgba(139,46,41,.3);
  border-radius:var(--radius);
  padding:14px 18px;
  font-weight:800;
  color:var(--brand-maroon);
  text-align:center;
  box-shadow:0 10px 24px rgba(0,0,0,.06);
}
.signup-banner{
  background:linear-gradient(135deg,rgba(139,46,41,.08),rgba(76,150,167,.12));
  border:1px solid rgba(139,46,41,.2);
  border-radius:var(--radius-sm);
  padding:14px 18px;
  font-weight:600;
  color:var(--brand-maroon);
}

input.error,select.error{border:2px solid var(--brand-maroon)}
.error-message{color:var(--brand-maroon);font-size:14px;margin-top:4px}

/* Steps diagram */
.steps{counter-reset:step;display:flex;flex-wrap:wrap;gap:20px;margin:20px 0;list-style:none;padding-left:0}
.steps li{counter-increment:step;position:relative;flex:1;min-width:200px;background:var(--card);padding:20px;border-radius:var(--radius);box-shadow:var(--shadow);text-align:center}
.steps li::before{content:counter(step);position:absolute;top:-16px;left:50%;transform:translateX(-50%);width:32px;height:32px;border-radius:50%;background:var(--brand-maroon);color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center}
.steps li:not(:last-child)::after{content:'';position:absolute;top:16px;right:-20px;width:40px;height:2px;background:var(--brand-accent-2)}
@media(max-width:640px){.steps{flex-direction:column}.steps li:not(:last-child)::after{display:none}}

/* Modal */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:1000}
.modal.open{display:flex}
.modal-content{background:#fff;padding:20px;border-radius:var(--radius);max-width:90%;max-height:90%;overflow:auto;position:relative}
.modal-close{position:absolute;top:10px;right:10px;background:none;border:0;font-size:24px;cursor:pointer}
.info-link{margin-left:4px;font-size:14px}

/* 404 page */
.not-found{padding:80px 20px}
.dolphin{font-size:8rem;margin:40px 0}

/* Dashboard switcher */
.dashboard-switcher{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin:16px 0 24px;
  padding:12px 16px;
  border:1px solid rgba(122,29,33,.14);
  border-radius:14px;
  background:rgba(255,255,255,.92);
  box-shadow:0 18px 34px rgba(81,16,20,.12);
}
.dashboard-switcher__link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 20px;
  border-radius:999px;
  font-weight:600;
  color:var(--brand-maroon);
  background:rgba(122,29,33,.08);
  text-decoration:none;
  transition:background .2s ease,color .2s ease,box-shadow .2s ease;
}
.dashboard-switcher__link:hover,
.dashboard-switcher__link:focus-visible{
  background:rgba(122,29,33,.16);
  color:var(--brand-maroon);
  box-shadow:0 12px 22px rgba(81,16,20,.18);
  outline:none;
}
.dashboard-switcher__link.is-active,
.dashboard-switcher__link[aria-current="page"]{
  background:linear-gradient(135deg,#7a1d21 0%,#9d2f33 100%);
  color:#fff;
  box-shadow:0 18px 32px rgba(81,16,20,.24);
}
@media(max-width:640px){
  .dashboard-switcher{
    flex-direction:column;
    align-items:stretch;
  }
  .dashboard-switcher__link{
    width:100%;
  }
}
