/* ============================================================
   500 FEST — shared stylesheet
   Colors sampled from the event logo: navy #0c2243, red #ed1c24
   ============================================================ */

:root{
  --navy:#0c2243;
  --navy-700:#091a34;
  --red:#ed1c24;
  --red-700:#c8141b;
  --white:#ffffff;
  --paper:#f4f7fc;
  --paper-2:#eef2f9;
  --ink:#16203a;
  --muted:#5b6479;
  --line:#e1e7f1;

  --f-display:'Anton', Impact, sans-serif;
  --f-script:'Kaushan Script', cursive;
  --f-body:'Barlow', system-ui, sans-serif;
  --f-cond:'Barlow Condensed', sans-serif;

  --wrap:1120px;
  --radius:14px;
  --shadow:0 10px 30px rgba(12,34,67,.10);
  --shadow-sm:0 4px 14px rgba(12,34,67,.08);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--white);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--red-700)}

/* ---------- layout helpers ---------- */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 22px}
.section{padding:72px 0}
.section--paper{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section--tight{padding:48px 0}
.lead{font-size:1.18rem;color:var(--ink)}
.center{text-align:center}
.muted{color:var(--muted)}

/* ---------- top flag stripe ---------- */
.topstripe{height:6px;background:linear-gradient(90deg,var(--red) 0 50%,var(--navy) 50% 100%)}

/* ---------- nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.96);
  backdrop-filter:saturate(160%) blur(6px);
  border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 22px;
}
.nav__brand{
  display:inline-flex;align-items:center;gap:2px;
  text-decoration:none;line-height:1;
}
.nav__logo{height:42px;width:auto;display:block}
@media (max-width:820px){ .nav__logo{height:36px} }
.nav__brand-500{font-family:var(--f-display);color:var(--navy);font-size:1.8rem;letter-spacing:.5px}
.nav__brand-fest{font-family:var(--f-script);color:var(--red);font-size:1.5rem}
.nav__links{display:flex;align-items:center;gap:6px}
.nav__links a{
  font-family:var(--f-cond);font-weight:600;font-size:1.05rem;letter-spacing:.03em;
  text-transform:uppercase;color:var(--navy);text-decoration:none;
  padding:8px 12px;border-radius:8px;transition:background .15s,color .15s;
}
.nav__links a:hover{background:var(--paper-2)}
.nav__links a.active{color:var(--red)}
.nav__toggle{display:none;border:0;background:transparent;cursor:pointer;width:40px;height:40px;padding:8px}
.nav__toggle span{display:block;height:3px;background:var(--navy);border-radius:3px;margin:4px 0;transition:.2s}
.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)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.4em;
  font-family:var(--f-cond);font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  font-size:1.08rem;line-height:1;
  padding:14px 26px;border-radius:10px;border:2px solid transparent;
  text-decoration:none;cursor:pointer;transition:transform .12s,background .15s,box-shadow .15s;
}
.btn:active{transform:translateY(1px)}
.btn--red{background:var(--red);color:#fff}
.btn--red:hover{background:var(--red-700);box-shadow:var(--shadow-sm)}
.btn--navy{background:var(--navy);color:#fff}
.btn--navy:hover{background:var(--navy-700);box-shadow:var(--shadow-sm)}
.btn--ghost{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn--ghost:hover{background:var(--navy);color:#fff}
.btn--fb{background:#1877f2;color:#fff;padding:10px 16px;font-size:1rem}
.btn--fb:hover{background:#0f63d4}
.btn--lg{font-size:1.2rem;padding:16px 32px}
.btn[disabled],.btn.is-disabled{opacity:.5;pointer-events:none}

/* ---------- ribbon section header (SIGNATURE) ---------- */
.ribbon-wrap{display:flex;align-items:center;justify-content:center;gap:14px;margin:0 0 14px}
.ribbon-wrap .star{color:var(--red);font-size:1.6rem;line-height:1;filter:drop-shadow(0 1px 0 rgba(0,0,0,.06))}
.ribbon{
  position:relative;display:inline-block;
  background:var(--navy);color:#fff;
  font-family:var(--f-display);font-weight:400;letter-spacing:.02em;text-transform:uppercase;
  font-size:clamp(1.35rem,3.6vw,2.2rem);line-height:1.05;
  padding:.55em 2.3em;
  clip-path:polygon(0 0,100% 0,calc(100% - 18px) 50%,100% 100%,0 100%,18px 50%);
}
.ribbon--red{background:var(--red)}
.eyebrow{font-family:var(--f-script);color:var(--red);font-size:1.5rem;line-height:1;margin:0 0 2px}

/* ---------- star divider ---------- */
.stardiv{display:flex;align-items:center;justify-content:center;gap:14px;color:var(--red);margin:40px auto;max-width:340px}
.stardiv::before,.stardiv::after{content:"";height:2px;flex:1;background:linear-gradient(90deg,transparent,var(--navy))}
.stardiv::after{background:linear-gradient(90deg,var(--navy),transparent)}
.stardiv span{font-size:1.2rem}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(1200px 380px at 50% -120px, rgba(12,34,67,.06), transparent 70%), var(--white)}
.hero__inner{max-width:980px;margin:0 auto;padding:42px 22px 64px;text-align:center}
.hero__logo{width:min(560px,86%);margin:0 auto 10px;animation:rise .7s ease both}
.hero__title{
  font-family:var(--f-display);font-weight:400;color:var(--navy);
  font-size:clamp(2rem,6vw,3.4rem);line-height:1;text-transform:uppercase;
  margin:14px 0 8px;animation:rise .7s .05s ease both
}
.hero__sub{font-size:1.2rem;color:var(--muted);margin:0 0 22px;animation:rise .7s .1s ease both}
.facts{
  list-style:none;margin:0 0 26px;padding:0;
  display:flex;flex-wrap:wrap;gap:10px;justify-content:center;animation:rise .7s .15s ease both
}
.facts li{
  background:var(--paper);border:1px solid var(--line);border-radius:999px;
  padding:8px 18px;font-family:var(--f-cond);font-weight:600;font-size:1.06rem;
  text-transform:uppercase;letter-spacing:.03em;color:var(--navy)
}
.facts li b{color:var(--red)}
.hero__cta{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;animation:rise .7s .2s ease both}

@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ---------- cards grid ---------- */
.grid{display:grid;gap:20px}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;box-shadow:var(--shadow-sm);position:relative;
  transition:transform .15s,box-shadow .15s
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.card__time{font-family:var(--f-cond);font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:.05em;font-size:1rem}
.card__title{font-family:var(--f-display);font-weight:400;color:var(--navy);font-size:1.5rem;text-transform:uppercase;margin:.2em 0 .35em;line-height:1.05}
.card p{margin:0;color:var(--muted)}
.card__link{display:inline-block;margin-top:14px;font-family:var(--f-cond);font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--navy);text-decoration:none}
.card__link:hover{color:var(--red)}

/* ---------- page header (interior pages) ---------- */
.pagehead{background:var(--navy);color:#fff;text-align:center;padding:54px 22px 48px;position:relative}
.pagehead::after{content:"";position:absolute;left:0;right:0;bottom:0;height:6px;background:linear-gradient(90deg,var(--red) 0 50%,#fff 50% 100%)}
.pagehead .eyebrow{color:#ffd2d4}
.pagehead h1{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:clamp(2rem,6vw,3.4rem);line-height:1;margin:6px 0 12px}
.pagehead p{max-width:680px;margin:0 auto;color:#cdd6e6;font-size:1.12rem}
.pagehead__meta{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:18px}
.pagehead__meta span{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:7px 16px;font-family:var(--f-cond);font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.pagehead__meta span b{color:#ffd2d4}

/* logo slot for tournament logos (added later) */
.logo-slot{width:140px;height:140px;margin:0 auto 4px;border:2px dashed rgba(255,255,255,.3);border-radius:16px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.45);font-family:var(--f-cond);font-weight:600;text-transform:uppercase;font-size:.85rem;text-align:center;padding:10px}
.logo-slot img{width:100%;height:100%;object-fit:contain}

/* ---------- division cards (wiffle) ---------- */
.divcard{background:#fff;border:1px solid var(--line);border-top:6px solid var(--red);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}
.divcard h3{font-family:var(--f-display);font-weight:400;color:var(--navy);font-size:1.7rem;text-transform:uppercase;margin:0 0 2px}
.divcard .age{font-family:var(--f-cond);font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.divcard .fee{font-family:var(--f-display);color:var(--red);font-size:2rem;margin:10px 0 2px}
.divcard ul{margin:12px 0 0;padding-left:18px;color:var(--muted)}
.divcard li{margin:4px 0}
.capbar{margin-top:14px}
.capbar__track{height:10px;background:var(--paper-2);border-radius:99px;overflow:hidden}
.capbar__fill{height:100%;background:var(--navy);width:0;transition:width .4s}
.capbar__label{font-family:var(--f-cond);font-weight:600;text-transform:uppercase;letter-spacing:.03em;font-size:.95rem;margin-top:6px;color:var(--navy)}
.capbar.is-full .capbar__fill{background:var(--red)}
.capbar.is-full .capbar__label{color:var(--red)}

/* ---------- schedule ---------- */
.sched{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.sched__head{background:var(--navy);color:#fff;display:grid;grid-template-columns:130px 1fr 1fr;font-family:var(--f-cond);font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.sched__head div{padding:12px 16px}
.sched__row{display:grid;grid-template-columns:130px 1fr 1fr;border-top:1px solid var(--line)}
.sched__row > div{padding:13px 16px}
.sched__time{font-family:var(--f-cond);font-weight:700;color:var(--red);text-transform:uppercase}
.sched__row--special{background:var(--paper)}
.sched__row--special .sched__game{font-weight:600;color:var(--navy)}
.sched__game{color:var(--ink)}
.sched__field-tag{display:none}

/* ---------- rules accordion ---------- */
.rules{max-width:820px;margin:0 auto}
.rule{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:12px;overflow:hidden;box-shadow:var(--shadow-sm)}
.rule>summary{
  cursor:pointer;list-style:none;padding:16px 20px;
  font-family:var(--f-cond);font-weight:700;text-transform:uppercase;letter-spacing:.03em;
  font-size:1.18rem;color:var(--navy);display:flex;align-items:center;justify-content:space-between;
}
.rule>summary::-webkit-details-marker{display:none}
.rule>summary::after{content:"+";color:var(--red);font-size:1.5rem;line-height:1;font-family:var(--f-body)}
.rule[open]>summary::after{content:"–"}
.rule__body{padding:0 20px 18px}
.rule__body p{margin:.4em 0}
.rule__body ul{margin:.4em 0;padding-left:20px}
.rule__body li{margin:4px 0}
.rule__body strong{color:var(--navy)}
.rule__spirit{background:var(--navy);color:#fff;border-radius:12px;padding:22px 24px;margin-bottom:22px;text-align:center}
.rule__spirit p{margin:.3em 0;color:#dbe3f0}
.rule__spirit b{color:#fff;font-family:var(--f-cond);text-transform:uppercase;letter-spacing:.04em;font-size:1.2rem}

/* ---------- forms ---------- */
.formwrap{max-width:640px;margin:0 auto}
.form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--f-cond);font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--navy);margin-bottom:6px;font-size:1rem}
.field .req{color:var(--red)}
.field input,.field select{
  width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:10px;
  font-family:var(--f-body);font-size:1rem;color:var(--ink);background:#fff;transition:border-color .15s,box-shadow .15s
}
.field input:focus,.field select:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(237,28,36,.15)}
.field .hint{font-size:.9rem;color:var(--muted);margin-top:5px}
.roster-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}
.roster-row input{flex:1}
.roster-row .remove{border:0;background:var(--paper-2);color:var(--navy);width:38px;height:38px;border-radius:8px;cursor:pointer;font-size:1.2rem;flex:none}
.roster-row .remove:hover{background:#dfe5f0}
.addplayer{background:transparent;border:1.5px dashed var(--line);color:var(--navy);font-family:var(--f-cond);font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:10px;width:100%;border-radius:10px;cursor:pointer}
.addplayer:hover{border-color:var(--navy)}
.addplayer[disabled]{opacity:.4;cursor:not-allowed}
.check{display:flex;gap:10px;align-items:flex-start;background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:12px 14px}
.check input{width:18px;height:18px;margin-top:3px;flex:none;accent-color:var(--red)}
.check label{font-family:var(--f-body);text-transform:none;letter-spacing:0;font-weight:500;color:var(--ink);margin:0;font-size:.98rem}
.feeline{display:flex;align-items:baseline;justify-content:space-between;background:var(--navy);color:#fff;border-radius:10px;padding:14px 18px;margin:6px 0 18px}
.feeline span{font-family:var(--f-cond);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.feeline b{font-family:var(--f-display);font-size:1.8rem;color:#fff}
.form__msg{margin-top:14px;padding:12px 16px;border-radius:10px;font-weight:500;display:none}
.form__msg.show{display:block}
.form__msg.err{background:#fde8e9;color:#9b1119;border:1px solid #f5c4c7}
.form__msg.ok{background:#e7f6ec;color:#15633a;border:1px solid #bfe6cd}

/* success panel */
.success{display:none;text-align:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px 28px;box-shadow:var(--shadow)}
.success.show{display:block}
.success h3{font-family:var(--f-display);font-weight:400;color:var(--navy);font-size:1.8rem;text-transform:uppercase;margin:0 0 8px}
.success p{color:var(--muted);margin:.4em 0}
.success .paynote{background:var(--paper);border:1px dashed var(--line);border-radius:10px;padding:14px 16px;margin:16px 0;color:var(--ink)}

/* full banner */
.fullbanner{display:none;background:var(--red);color:#fff;border-radius:12px;padding:16px 20px;text-align:center;font-family:var(--f-cond);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:1.15rem;margin-bottom:18px}
.fullbanner.show{display:block}

/* ---------- music lineup ---------- */
.act{display:grid;grid-template-columns:160px 1fr;gap:24px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm);margin-bottom:18px}
.act__time{font-family:var(--f-display);color:var(--red);font-size:1.9rem;line-height:1;text-align:center}
.act__time small{display:block;font-family:var(--f-cond);font-size:.95rem;color:var(--muted);letter-spacing:.04em;margin-top:4px}
.act h3{font-family:var(--f-display);font-weight:400;color:var(--navy);font-size:1.7rem;text-transform:uppercase;margin:0 0 4px;line-height:1.05}
.act p{margin:0;color:var(--muted)}
.act__band{font-family:var(--f-cond);font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--red)}
.finale{text-align:center;background:var(--navy);color:#fff;border-radius:var(--radius);padding:30px;margin-top:8px}
.finale h3{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:2rem;margin:0 0 6px}
.finale p{margin:0;color:#cdd6e6}

/* ---------- kids ---------- */
.tickets{display:flex;flex-wrap:wrap;gap:20px;align-items:stretch}
.ticket{flex:1;min-width:260px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.ticket__top{background:var(--red);color:#fff;text-align:center;padding:18px}
.ticket__price{font-family:var(--f-display);font-size:3rem;line-height:1}
.ticket__top span{font-family:var(--f-cond);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.ticket__body{padding:22px 24px}
.ticket__body ul{margin:0;padding-left:18px;color:var(--ink)}
.ticket__body li{margin:7px 0}
.ticket__note{background:var(--paper);border-top:1px solid var(--line);padding:14px 24px;font-family:var(--f-cond);font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--navy);text-align:center}

/* ---------- location ---------- */
.loc{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:center}
.loc__card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm)}
.loc__card h3{font-family:var(--f-display);font-weight:400;color:var(--navy);font-size:1.6rem;text-transform:uppercase;margin:0 0 8px}
.loc iframe{width:100%;height:300px;border:0;border-radius:var(--radius);box-shadow:var(--shadow-sm)}

/* ---------- footer ---------- */
.footer{background:var(--navy);color:#cdd6e6;text-align:center;padding:48px 22px;border-top:6px solid var(--red)}
.footer__logo{width:260px;margin:0 auto 18px;background:#fff;border-radius:14px;padding:16px}
.footer__line{margin:.3em auto;max-width:640px}
.footer__line a{color:#fff}
.footer .btn{margin:14px 0 18px}
.footer__fine{font-size:.9rem;color:#7c8aa6;margin-top:14px}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .grid--3{grid-template-columns:1fr 1fr}
  .loc{grid-template-columns:1fr}
}
@media (max-width:820px){
  .nav__toggle{display:block}
  .nav__links{
    position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);
    flex-direction:column;align-items:stretch;gap:0;padding:8px 14px 16px;
    display:none;box-shadow:var(--shadow)
  }
  .nav__links.is-open{display:flex}
  .nav__links a{padding:12px 10px;border-radius:8px}
  .nav__links .btn--fb{margin-top:8px;justify-content:center}
}
@media (max-width:680px){
  .section{padding:52px 0}
  .grid--3,.grid--2{grid-template-columns:1fr}
  .act{grid-template-columns:1fr;text-align:center;gap:10px}
  .sched__head{display:none}
  .sched__row{grid-template-columns:1fr;padding:6px 0}
  .sched__row > div{padding:4px 16px}
  .sched__field-tag{display:inline;font-family:var(--f-cond);font-weight:700;text-transform:uppercase;color:var(--muted);margin-right:6px}
  .sched__time{padding-top:12px!important;font-size:1.1rem}
}

/* ---------- accessibility ---------- */
:focus-visible{outline:3px solid var(--red);outline-offset:2px;border-radius:4px}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
