:root{--pink:#FF2E9F;--orange:#FF7A00;--cyan:#00E5FF;--purple:#A64DFF;--blue:#7B9FFF;--teal:#00C9A7;--gold:#FFD23F;--white:#F2F2F2;--muted:#bfc4cc;--bg:#000}
*{box-sizing:border-box}html,body{margin:0;min-height:100%;background:#000;color:#fff;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;overflow-x:hidden}body{background:radial-gradient(circle at 50% 0%,rgba(0,229,255,.1),transparent 28rem),#000}a{color:inherit;text-decoration:none}.hero{max-width:1100px;margin:0 auto;padding:34px 20px 22px;text-align:center}.site-logo{width:min(160px,38vw);display:block;margin:0 auto 4px}.year{letter-spacing:.45em;color:#eee;margin:0 0 8px;text-transform:uppercase}.hero h1{font-size:clamp(3.5rem,13vw,8.5rem);line-height:.85;margin:0;text-transform:uppercase;letter-spacing:.05em;color:var(--pink);text-shadow:0 0 22px rgba(255,46,159,.65)}.rule{height:3px;width:min(440px,72vw);margin:22px auto;background:linear-gradient(90deg,var(--cyan),var(--pink),var(--orange));box-shadow:0 0 18px rgba(255,46,159,.7)}.hero h2{font-size:clamp(1.1rem,3vw,1.75rem);letter-spacing:.08em;text-transform:uppercase;margin:12px 0 6px}.hero h3{font-size:clamp(1rem,2.6vw,1.35rem);margin:0 0 10px;background:linear-gradient(90deg,var(--cyan),var(--pink),var(--orange));-webkit-background-clip:text;background-clip:text;color:transparent}.intro{max-width:740px;margin:0 auto 18px;color:#d6d6d6;line-height:1.55}.year-btn{display:inline-block;border:1px solid rgba(255,255,255,.9);border-radius:12px;padding:13px 22px;text-transform:uppercase;letter-spacing:.11em;font-weight:800;background:rgba(255,255,255,.06);box-shadow:0 0 18px rgba(255,255,255,.14)}.year-btn:hover{border-color:transparent;background:linear-gradient(90deg,var(--cyan),var(--pink),var(--orange));color:#000}.subtext{color:var(--muted);margin:12px 0 0}main{max-width:1200px;margin:0 auto;padding:0 18px 50px}.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin:18px 0 26px}.card{--accent:#fff;min-height:310px;border:1px solid color-mix(in srgb,var(--accent),transparent 15%);border-radius:20px;padding:18px;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.02));box-shadow:0 0 22px color-mix(in srgb,var(--accent),transparent 78%);display:flex;flex-direction:column;align-items:center;justify-content:space-between;position:relative;overflow:hidden}.card:before{content:"";position:absolute;inset:-70% -40% auto;height:65%;background:radial-gradient(circle,color-mix(in srgb,var(--accent),transparent 55%),transparent 60%);pointer-events:none}.card img{width:100%;height:145px;object-fit:contain;position:relative;z-index:1}.card h4{font-size:1.35rem;text-transform:uppercase;letter-spacing:.08em;text-align:center;margin:10px 0;color:#fff;text-shadow:0 0 12px var(--accent)}.actions{display:grid;gap:9px;width:100%}.actions a,.actions button,.viewer-actions a,.mobile-actions a{border:1px solid var(--accent);border-radius:10px;background:rgba(0,0,0,.55);color:var(--accent);text-transform:uppercase;font-weight:800;letter-spacing:.08em;padding:10px 12px;text-align:center;cursor:pointer;font:inherit;font-size:.82rem}.actions a:hover,.actions button:hover,.viewer-actions a:hover,.mobile-actions a:hover{background:var(--accent);color:#000}.sachse{--accent:#f2f2f2}.acappella{--accent:#00E5FF}.bella{--accent:#A64DFF}.concert{--accent:#7B9FFF}.mane{--accent:#FF7A00}.spur{--accent:#FF2E9F}.allregion{--accent:#FFD23F}.parents{--accent:#00C9A7}.mobile-picker{display:none}.viewer{border:1px solid rgba(255,255,255,.22);border-radius:22px;background:rgba(255,255,255,.045);padding:18px;box-shadow:0 0 30px rgba(255,46,159,.12)}.viewer-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.eyebrow{color:var(--pink);letter-spacing:.18em;text-transform:uppercase;font-weight:800;margin:0 0 4px}.viewer h2{margin:0;font-size:2rem}.viewer-actions{display:flex;gap:10px}.viewer-actions a{--accent:#FF2E9F}.calendar-frame-wrap{height:720px;border-radius:16px;overflow:hidden;background:#111;border:1px solid rgba(255,255,255,.14)}iframe{width:100%;height:100%;border:0;display:block}.note{text-align:center;color:var(--muted);margin:18px 0 0}
@media (max-width:900px){.cards{grid-template-columns:repeat(2,1fr)}.card{min-height:275px}.card img{height:120px}.viewer-head{flex-direction:column;align-items:flex-start}.viewer-actions{width:100%;display:grid;grid-template-columns:1fr 1fr}.calendar-frame-wrap{height:620px}}
@media (max-width:640px){body{background:#000}.hero{padding:24px 16px 10px}.site-logo{width:124px}.year{font-size:.8rem;letter-spacing:.28em}.intro{font-size:.95rem}.cards{display:none}.mobile-picker{display:block;border:1px solid rgba(255,255,255,.2);border-radius:18px;padding:16px;margin:16px 0 22px;background:rgba(255,255,255,.045)}.mobile-picker label{display:block;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-size:.8rem;margin-bottom:8px}select{width:100%;font-size:1rem;padding:13px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.35);background:#050505;color:#fff}.mobile-actions{display:grid;grid-template-columns:1fr;gap:10px;margin-top:12px}.mobile-actions a{--accent:#00E5FF}.viewer{padding:14px;margin-bottom:30px}.viewer-actions{display:none}.viewer h2{font-size:1.45rem}.calendar-frame-wrap{display:none}.viewer:after{content:"For the smoothest phone experience, use the Open Calendar button above. The full embedded calendar is shown on desktop.";display:block;color:var(--muted);line-height:1.45;margin-top:10px}.note{font-size:.9rem}}


/* Mobile single-screen rebuild: avoids scroll traps by removing embedded calendars and tall card stacks on phones. */
.mobile-home{display:none}
@media (max-width:640px){
  html,body{
    width:100%;
    max-width:100%;
    min-height:100svh;
    overflow-x:hidden;
    touch-action:pan-y;
    overscroll-behavior:none;
  }
  body{
    background:
      radial-gradient(circle at 20% 0%,rgba(0,229,255,.18),transparent 18rem),
      radial-gradient(circle at 85% 12%,rgba(255,46,159,.14),transparent 14rem),
      #000;
  }
  .hero{
    min-height:auto;
    padding:18px 14px 8px;
  }
  .site-logo{width:92px;margin-bottom:2px}
  .year{font-size:.68rem;letter-spacing:.22em;margin-bottom:4px}
  .hero h1{font-size:clamp(2.15rem,13.5vw,3.35rem);line-height:.9;letter-spacing:.025em;text-align:center;width:100%;max-width:100%;overflow-wrap:normal}
  .rule{width:68vw;margin:12px auto;height:2px}
  .hero h2{font-size:.86rem;line-height:1.25;margin:8px auto 4px;max-width:330px}
  .hero h3{font-size:.86rem;margin-bottom:6px}
  .intro{display:none}
  .year-btn{padding:10px 13px;font-size:.68rem;border-radius:10px;letter-spacing:.07em}
  .subtext{display:none}
  main{padding:0 12px 14px;max-width:520px}
  .cards,.mobile-picker,.viewer{display:none!important}
  .mobile-home{display:block;margin:8px auto 0}
  .mobile-home-panel{
    border:1px solid rgba(255,255,255,.18);
    border-radius:18px;
    padding:12px;
    background:rgba(255,255,255,.045);
    box-shadow:0 0 24px rgba(0,229,255,.10);
  }
  .mobile-kicker{
    margin:0 0 9px;
    color:var(--cyan);
    text-transform:uppercase;
    letter-spacing:.15em;
    font-weight:900;
    font-size:.72rem;
    text-align:center;
  }
  .mobile-calendar-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
  }
  .mobile-calendar-link{
    min-height:44px;
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    padding:9px 8px;
    border-radius:12px;
    border:1px solid var(--mobile-accent,#fff);
    color:var(--mobile-accent,#fff);
    background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.025));
    font-size:.74rem;
    line-height:1.1;
    font-weight:900;
    letter-spacing:.045em;
    text-transform:uppercase;
    box-shadow:0 0 14px color-mix(in srgb,var(--mobile-accent,#fff),transparent 82%);
  }
  .sachse-link{--mobile-accent:#f2f2f2}.acappella-link{--mobile-accent:#00E5FF}.bella-link{--mobile-accent:#A64DFF}.concert-link{--mobile-accent:#7B9FFF}.mane-link{--mobile-accent:#FF7A00}.spur-link{--mobile-accent:#FF2E9F}.allregion-link{--mobile-accent:#FFD23F}.parents-link{--mobile-accent:#00C9A7}
  .mobile-help{
    margin:10px 2px 0;
    color:var(--muted);
    font-size:.74rem;
    line-height:1.3;
    text-align:center;
  }
}
@media (max-width:380px){
  .hero{padding-top:12px}
  .site-logo{width:78px}
  .hero h1{font-size:2.15rem;letter-spacing:.02em}
  .hero h2{display:none}
  .year-btn{font-size:.62rem;padding:9px 10px}
  .mobile-calendar-link{min-height:40px;font-size:.68rem;padding:7px 6px}
  .mobile-help{font-size:.68rem;margin-top:7px}
}
