/* ── Calendar page styles ──────────────────────────────────── */

/* Hero — compact, dark */
.cal-hero{min-height:520px!important;padding:96px 40px 80px!important}
.cal-hero .hero-inner{grid-template-columns:1fr!important;max-width:1200px}
.cal-hero h1{font-size:clamp(72px,12vw,180px)}

/* Legend strip */
.cal-legend{background:#0a0a0a;padding:20px 40px;border-bottom:1px solid #1c1c1c}
.cal-legend-inner{max-width:1640px;margin:0 auto;display:flex;gap:28px;align-items:center;flex-wrap:wrap}
.cal-legend-label{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted)}
.legend-dot{display:inline-flex;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.15em;text-transform:uppercase;color:#c5c2bd}
.legend-dot::before{content:"";width:10px;height:10px;border-radius:1px;flex-shrink:0}
.legend-dot.wynland::before{background:var(--pink)}
.legend-dot.kidi::before{background:#29B6E8}
.legend-dot.wag::before{background:var(--gold)}
.legend-dot.general::before{background:#555}

/* Calendar body */
.cal-body{background:var(--bone);padding:80px 40px 120px}
.cal-body-inner{max-width:1640px;margin:0 auto}

/* Month section */
.cal-month{margin-bottom:64px}
.cal-month:last-child{margin-bottom:0}
.cal-month-head{display:flex;align-items:baseline;gap:20px;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid #c9c4ba}
.cal-month-name{font-family:'Big Shoulders Display',sans-serif;font-weight:900;text-transform:uppercase;font-size:clamp(40px,5vw,72px);line-height:1;color:var(--black);letter-spacing:-0.01em}
.cal-month-year{font-family:'JetBrains Mono',monospace;font-size:13px;color:#8a8784;letter-spacing:0.2em;text-transform:uppercase}
.cal-month-count{margin-left:auto;font-family:'JetBrains Mono',monospace;font-size:11px;color:#8a8784;letter-spacing:0.15em;text-transform:uppercase}

/* Event table */
.cal-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #d4cfc5}
.cal-table thead th{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.18em;text-transform:uppercase;text-align:left;color:var(--muted);padding:12px 18px;background:#141414;border-right:1px solid #222;font-weight:500}
.cal-table thead th:last-child{border-right:none}
.cal-table tbody td{padding:16px 18px;border-bottom:1px solid #e8e3d8;border-right:1px solid #e8e3d8;color:#1a1a1a;vertical-align:middle;font-size:14px;line-height:1.35}
.cal-table tbody td:last-child{border-right:none}
.cal-table tbody tr:last-child td{border-bottom:none}
.cal-table tbody tr:hover td{background:#faf8f4}

/* Date cell */
.cal-date{font-family:'Big Shoulders Display',sans-serif;font-weight:900;font-size:26px;line-height:1;color:var(--black);letter-spacing:0.01em;white-space:nowrap;min-width:56px}
.cal-date .month-abbr{display:block;font-family:'JetBrains Mono',monospace;font-weight:400;font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);margin-top:2px}

/* Discipline tag */
.cal-disc{white-space:nowrap}
.disc-tag{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.18em;text-transform:uppercase;padding:4px 9px;color:#fff;line-height:1}
.disc-tag.wynland{background:var(--pink)}
.disc-tag.kidi{background:#29B6E8;color:#0a1418}
.disc-tag.wag{background:var(--gold);color:#0a0a0a}
.disc-tag.general{background:#444;color:#fff}

/* Event cell */
.cal-event-name{font-family:'Big Shoulders Display',sans-serif;font-weight:800;font-size:18px;text-transform:uppercase;letter-spacing:0.02em;color:var(--black)}
.cal-participant{display:block;font-family:'JetBrains Mono',monospace;font-size:11px;color:#5a5a5a;letter-spacing:0.06em;margin-top:3px}

/* Venue cell */
.cal-venue{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted);letter-spacing:0.1em;text-transform:uppercase}
.cal-venue.tbc{color:#F0C400}

/* Divider row for school terms */
.cal-term-row td{background:#141414;padding:8px 18px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);border-bottom:1px solid #222;border-right:none!important}

/* Note at bottom */
.cal-note{display:flex;gap:16px;padding:20px 24px;background:#fff;border:1px solid #d4cfc5;border-left:3px solid var(--pink);align-items:flex-start;font-size:14px;color:#3a3a3a;line-height:1.55;margin-top:12px}
.cal-note .n{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--pink);letter-spacing:0.2em;flex-shrink:0;padding-top:2px;text-transform:uppercase}

/* Responsive */
@media (max-width:1024px){
  .cal-body{padding:60px 24px 80px}
  .cal-legend{padding:16px 24px}
}
@media (max-width:720px){
  .cal-hero{padding:64px 20px 56px!important;min-height:auto!important}
  .cal-body{padding:40px 0 64px}
  .cal-body-inner{padding:0 20px}
  .cal-legend{padding:14px 20px}
  .cal-legend-inner{gap:12px}
  .cal-month{margin-bottom:48px}
  .cal-month-head{flex-wrap:wrap;gap:6px;padding-bottom:12px;margin-bottom:14px}
  .cal-month-name{font-size:clamp(32px,9vw,52px)}
  .cal-month-count{margin-left:0;order:3;width:100%}

  /* Mobile event cards — one card per row */
  .cal-table-wrap{overflow:visible}
  .cal-table{width:100%;border:none;background:transparent}
  .cal-table thead{display:none}
  .cal-table tbody{display:flex;flex-direction:column;gap:10px}
  .cal-table tr{display:grid;grid-template-columns:56px 1fr;grid-template-rows:auto auto;gap:0;background:#fff;border:1px solid #d4cfc5;overflow:hidden}
  .cal-table td{display:block;padding:0;border:none!important}

  /* Date — spans full left column, both rows */
  .cal-table td:nth-child(1){grid-column:1;grid-row:1/3;background:#141414;display:flex;align-items:center;justify-content:center;padding:12px 8px}
  .cal-date{font-size:18px;color:#fff;text-align:center}
  .cal-date .month-abbr{color:var(--muted)}

  /* Discipline tag — top right */
  .cal-table td:nth-child(2){grid-column:2;grid-row:1;padding:10px 14px 4px}

  /* Event name + participant — bottom right */
  .cal-table td:nth-child(3){grid-column:2;grid-row:2;padding:0 14px 10px}

  /* Venue — hide on mobile to save space */
  .cal-table td:nth-child(4){display:none}

  .cal-event-name{font-size:15px}
  .cal-participant{font-size:10px}
  .cal-term-row{display:none}
  .cal-note{flex-direction:column;gap:8px}
}
