/* Shared styles for Bro Streak and Games. */
:root {
      --bg: #0b1020;
      --card: #151b2f;
      --card2: #10172a;
      --text: #f5f7fb;
      --muted: #9aa4bf;
      --line: rgba(255,255,255,.11);
      --good: #33d17a;
      --bad: #ff5c7a;
      --today: #8ab4ff;
      --warn: #f6c177;
      --shadow: 0 22px 60px rgba(0,0,0,.35);
      --radius: 24px;
    }

    * { box-sizing: border-box; }

    body {
      margin: 0;
      font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
      background:
        radial-gradient(circle at top left, rgba(138,180,255,.18), transparent 35%),
        radial-gradient(circle at top right, rgba(51,209,122,.12), transparent 30%),
        var(--bg);
      color: var(--text);
      min-height: 100vh;
      padding: 24px;
    }

    .app {
      max-width: 1180px;
      margin: 0 auto;
    }

    header {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      gap: 20px;
      margin-bottom: 22px;
    }

    h1 {
      margin: 0;
      font-size: clamp(32px, 6vw, 56px);
      letter-spacing: -.06em;
      line-height: .95;
    }

    .subtitle {
      margin: 12px 0 0;
      color: var(--muted);
      font-size: 16px;
      max-width: 680px;
    }

    .pill {
      border: 1px solid var(--line);
      background: rgba(255,255,255,.05);
      color: var(--muted);
      border-radius: 999px;
      padding: 10px 14px;
      font-size: 13px;
      white-space: nowrap;
    }

    .header-actions {
      display: grid;
      justify-items: end;
      gap: 10px;
    }

    .profile-switch {
      display: flex;
      flex-wrap: wrap;
      justify-content: flex-end;
      gap: 8px;
    }

    .profile-btn {
      padding: 10px 12px;
      border-radius: 999px;
      color: var(--muted);
      font-size: 13px;
    }

    .profile-btn.active {
      color: var(--text);
      background: rgba(138,180,255,.16);
      border-color: rgba(138,180,255,.45);
    }

    .site-nav {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-bottom: 18px;
    }

    .nav-link {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 42px;
      border: 1px solid var(--line);
      border-radius: 999px;
      padding: 10px 14px;
      color: var(--muted);
      background: rgba(255,255,255,.045);
      font-size: 13px;
      font-weight: 900;
      text-decoration: none;
    }

    .nav-link.active {
      color: var(--text);
      background: rgba(138,180,255,.16);
      border-color: rgba(138,180,255,.45);
    }

    .welcome-page {
      display: grid;
      place-items: center;
      padding: 20px;
    }

    .welcome-shell {
      width: min(100%, 460px);
    }

    .welcome-card {
      background: rgba(21,27,47,.82);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 28px;
      box-shadow: var(--shadow);
      backdrop-filter: blur(12px);
    }

    .welcome-card h1 {
      margin-top: 12px;
    }

    .welcome-badge {
      display: inline-flex;
      align-items: center;
      border: 1px solid rgba(138,180,255,.38);
      border-radius: 999px;
      padding: 8px 11px;
      color: var(--today);
      background: rgba(138,180,255,.12);
      font-size: 13px;
      font-weight: 900;
    }

    .access-form {
      display: grid;
      gap: 10px;
      margin-top: 22px;
    }

    .access-form label {
      color: var(--muted);
      font-size: 13px;
      font-weight: 900;
    }

    .access-form input {
      width: 100%;
      min-height: 48px;
      border: 1px solid var(--line);
      border-radius: 16px;
      padding: 12px 14px;
      color: var(--text);
      background: rgba(255,255,255,.06);
      font: inherit;
      outline: none;
    }

    .access-form input:focus {
      border-color: rgba(138,180,255,.6);
      box-shadow: 0 0 0 3px rgba(138,180,255,.12);
    }

    .access-error {
      color: var(--bad);
      font-size: 13px;
      font-weight: 900;
    }

    .top-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0,1fr));
      gap: 16px;
      margin-bottom: 16px;
    }

    .stat {
      background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.035));
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 18px;
      box-shadow: var(--shadow);
    }

    .stat .label {
      color: var(--muted);
      font-size: 13px;
      margin-bottom: 8px;
    }

    .stat .value {
      font-size: 32px;
      font-weight: 800;
      letter-spacing: -.04em;
    }

    .stat .value.small {
      font-size: 24px;
      letter-spacing: 0;
    }

    .players {
      display: grid;
      grid-template-columns: repeat(2, minmax(0,1fr));
      gap: 16px;
      margin-bottom: 16px;
    }

    .player-card {
      background: rgba(21,27,47,.78);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 18px;
      box-shadow: var(--shadow);
      backdrop-filter: blur(12px);
    }

    .player-card.active {
      border-color: rgba(138,180,255,.58);
      box-shadow: 0 0 0 2px rgba(138,180,255,.12) inset, var(--shadow);
    }

    .player-head {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 12px;
      margin-bottom: 12px;
    }

    .player-name {
      font-size: 24px;
      font-weight: 800;
      letter-spacing: -.04em;
    }

    .mini-stats {
      display: grid;
      grid-template-columns: repeat(2, minmax(0,1fr));
      gap: 10px;
      margin: 14px 0;
    }

    .mini {
      background: rgba(255,255,255,.04);
      border: 1px solid var(--line);
      border-radius: 18px;
      padding: 12px;
    }

    .mini span {
      display: block;
      color: var(--muted);
      font-size: 12px;
      margin-bottom: 4px;
    }

    .mini strong {
      font-size: 24px;
    }

    .actions {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 10px;
    }

    button {
      appearance: none;
      border: 0;
      cursor: pointer;
      border-radius: 16px;
      padding: 13px 14px;
      font-weight: 800;
      color: var(--text);
      background: rgba(255,255,255,.08);
      border: 1px solid var(--line);
      transition: transform .12s ease, background .12s ease, border-color .12s ease;
    }

    button:hover {
      transform: translateY(-1px);
      background: rgba(255,255,255,.12);
    }

    button:disabled {
      cursor: not-allowed;
      opacity: .45;
      transform: none;
    }

    button.good {
      background: rgba(51,209,122,.15);
      border-color: rgba(51,209,122,.45);
    }

    button.bad {
      background: rgba(255,92,122,.14);
      border-color: rgba(255,92,122,.45);
    }

    .achievements-shell {
      background: rgba(21,27,47,.78);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 18px;
      margin-bottom: 16px;
      box-shadow: var(--shadow);
      backdrop-filter: blur(12px);
    }

    .achievements-top {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      gap: 14px;
      margin-bottom: 14px;
    }

    .achievements-actions {
      display: flex;
      flex-wrap: wrap;
      justify-content: flex-end;
      gap: 8px;
    }

    .toggle-btn {
      padding: 10px 12px;
      border-radius: 999px;
      color: var(--muted);
      font-size: 13px;
    }

    .section-title {
      font-size: 22px;
      font-weight: 900;
      letter-spacing: -.04em;
    }

    .section-subtitle {
      color: var(--muted);
      font-size: 13px;
      margin-top: 4px;
    }

    .achievements-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0,1fr));
      gap: 10px;
    }

    .locked-achievements {
      margin-top: 14px;
      padding-top: 14px;
      border-top: 1px solid var(--line);
    }

    .locked-achievements[hidden] {
      display: none;
    }

    .locked-title {
      color: var(--muted);
      font-size: 13px;
      font-weight: 900;
      margin-bottom: 10px;
      text-transform: uppercase;
    }

    .empty-achievements {
      color: var(--muted);
      border: 1px dashed var(--line);
      border-radius: 18px;
      padding: 14px;
      font-size: 13px;
    }

    .achievement {
      min-height: 104px;
      display: flex;
      align-items: stretch;
      gap: 12px;
      overflow: hidden;
      background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.025));
      border: 1px solid var(--line);
      border-radius: 10px;
      padding: 10px;
      box-shadow: 0 14px 34px rgba(0,0,0,.22);
    }

    .achievement.unlocked {
      background:
        linear-gradient(90deg, rgba(51,209,122,.16), transparent 42%),
        linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
      border-color: rgba(51,209,122,.38);
    }

    .achievement.focused {
      border-color: rgba(138,180,255,.5);
      box-shadow: 0 0 0 2px rgba(138,180,255,.1) inset;
    }

    .achievement.locked {
      opacity: .72;
    }

    .achievement-media {
      width: 82px;
      height: 82px;
      flex: 0 0 auto;
      border-radius: 8px;
      background-image: url("../assets/achievement-badges.png");
      background-size: 400% 400%;
      background-position: var(--icon-position);
      border: 1px solid rgba(255,255,255,.18);
      box-shadow: inset 0 0 0 1px rgba(0,0,0,.28), 0 10px 22px rgba(0,0,0,.28);
    }

    .achievement.locked .achievement-media {
      filter: grayscale(1) brightness(.62);
      opacity: .9;
    }

    .achievement-body {
      min-width: 0;
      display: flex;
      flex: 1;
      flex-direction: column;
      gap: 6px;
    }

    .achievement-owner {
      color: var(--muted);
      font-size: 11px;
      font-weight: 800;
      text-transform: uppercase;
    }

    .achievement-title {
      color: var(--text);
      font-weight: 900;
      line-height: 1.15;
    }

    .achievement-description {
      color: var(--muted);
      font-size: 12px;
      line-height: 1.35;
    }

    .achievement-progress {
      margin-top: auto;
      display: grid;
      gap: 6px;
    }

    .progress-bar {
      height: 7px;
      overflow: hidden;
      border-radius: 999px;
      background: rgba(255,255,255,.08);
    }

    .progress-fill {
      height: 100%;
      width: var(--progress);
      border-radius: inherit;
      background: linear-gradient(90deg, var(--today), var(--good));
    }

    .progress-label {
      color: var(--muted);
      font-size: 11px;
      font-weight: 800;
    }

    .achievement-status {
      color: var(--good);
      font-size: 11px;
      font-weight: 900;
      text-transform: uppercase;
    }

    .achievement.locked .achievement-status {
      color: var(--warn);
    }

    .calendar-shell {
      background: rgba(21,27,47,.78);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 18px;
      box-shadow: var(--shadow);
      backdrop-filter: blur(12px);
    }

    .calendar-top {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 12px;
      margin-bottom: 14px;
    }

    .calendar-title {
      font-size: 22px;
      font-weight: 900;
      letter-spacing: -.04em;
    }

    .month-buttons {
      display: flex;
      gap: 8px;
    }

    .legend {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin: 12px 0 16px;
      color: var(--muted);
      font-size: 13px;
    }

    .legend-item {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      border: 1px solid var(--line);
      border-radius: 999px;
      padding: 7px 10px;
      background: rgba(255,255,255,.035);
    }

    .dot {
      width: 10px;
      height: 10px;
      border-radius: 999px;
      background: rgba(255,255,255,.16);
    }

    .dot.good { background: var(--good); }
    .dot.bad { background: var(--bad); }
    .dot.today { background: var(--today); }

    .calendar-grid {
      display: grid;
      grid-template-columns: repeat(7, minmax(0,1fr));
      gap: 8px;
    }

    .weekday {
      color: var(--muted);
      font-size: 12px;
      text-align: center;
      padding: 6px;
      font-weight: 800;
    }

    .day {
      min-height: 100px;
      background: rgba(255,255,255,.035);
      border: 1px solid var(--line);
      border-radius: 18px;
      padding: 10px;
      display: flex;
      flex-direction: column;
      gap: 8px;
    }

    .day.outside {
      opacity: .32;
    }

    .day.today {
      border-color: rgba(138,180,255,.75);
      box-shadow: 0 0 0 2px rgba(138,180,255,.12) inset;
    }

    .day.future {
      opacity: .45;
    }

    .day.before-start {
      opacity: .3;
    }

    .date-number {
      color: var(--muted);
      font-size: 12px;
      font-weight: 800;
      display: flex;
      justify-content: space-between;
      align-items: center;
    }

    .badge {
      font-size: 10px;
      border-radius: 999px;
      padding: 3px 6px;
      color: var(--today);
      background: rgba(138,180,255,.12);
      border: 1px solid rgba(138,180,255,.3);
    }

    .check-row {
      display: grid;
      gap: 6px;
      margin-top: auto;
    }

    .check {
      display: flex;
      justify-content: space-between;
      align-items: center;
      border-radius: 12px;
      padding: 7px 8px;
      font-size: 12px;
      background: rgba(255,255,255,.045);
      border: 1px solid rgba(255,255,255,.08);
      user-select: none;
    }

    .check.done {
      background: rgba(51,209,122,.13);
      border-color: rgba(51,209,122,.38);
    }

    .check.fail {
      background: rgba(255,92,122,.12);
      border-color: rgba(255,92,122,.35);
    }

    .mark {
      font-weight: 900;
      color: var(--muted);
    }

    .check.done .mark { color: var(--good); }
    .check.fail .mark { color: var(--bad); }

    .notice {
      margin-top: 14px;
      color: var(--muted);
      font-size: 13px;
      line-height: 1.5;
      border: 1px dashed rgba(246,193,119,.35);
      background: rgba(246,193,119,.08);
      border-radius: 18px;
      padding: 12px;
    }

    .toast {
      position: fixed;
      left: 50%;
      bottom: 22px;
      transform: translateX(-50%);
      background: #0e1628;
      border: 1px solid var(--line);
      color: var(--text);
      padding: 12px 16px;
      border-radius: 999px;
      box-shadow: var(--shadow);
      opacity: 0;
      pointer-events: none;
      transition: opacity .2s ease, transform .2s ease;
      z-index: 20;
    }

    .toast.show {
      opacity: 1;
      transform: translateX(-50%) translateY(-4px);
    }

    @media (max-width: 850px) {
      body { padding: 16px; }
      header { flex-direction: column; }
      .header-actions { justify-items: start; }
      .profile-switch { justify-content: flex-start; }
      .top-grid, .players, .achievements-grid { grid-template-columns: 1fr; }
      .day { min-height: 88px; padding: 8px; border-radius: 14px; }
      .calendar-grid { gap: 6px; }
      .check { font-size: 11px; padding: 6px; }
      .actions { grid-template-columns: 1fr; }
      .achievements-top { flex-direction: column; }
      .achievements-actions { justify-content: flex-start; }
    }

    @media (min-width: 1500px) {
      .site-nav {
        position: fixed;
        top: 136px;
        left: calc((100vw - 1180px) / 2 - 148px);
        width: 124px;
        flex-direction: column;
      }

      .nav-link {
        width: 100%;
      }
    }

    @media (max-width: 560px) {
      .calendar-grid { gap: 4px; }
      .weekday { font-size: 10px; padding: 4px 1px; }
      .day { min-height: 76px; }
      .check {
        justify-content: center;
      }
      .check .person-label {
        display: none;
      }
    }

/* Games page styles. Kept in the shared bundle so static hosting stays simple. */
:root {
      --bg: #0b1020;
      --card: #151b2f;
      --text: #f5f7fb;
      --muted: #9aa4bf;
      --line: rgba(255,255,255,.11);
      --good: #33d17a;
      --bad: #ff5c7a;
      --today: #8ab4ff;
      --warn: #f6c177;
      --shadow: 0 22px 60px rgba(0,0,0,.35);
      --radius: 24px;
    }

    * { box-sizing: border-box; }

    body {
      margin: 0;
      font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
      background:
        radial-gradient(circle at top left, rgba(138,180,255,.18), transparent 35%),
        radial-gradient(circle at top right, rgba(51,209,122,.12), transparent 30%),
        var(--bg);
      color: var(--text);
      min-height: 100vh;
      padding: 24px;
    }

    .app {
      max-width: 1180px;
      margin: 0 auto;
    }

    header {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      gap: 20px;
      margin-bottom: 22px;
    }

    h1 {
      margin: 0;
      font-size: clamp(32px, 6vw, 56px);
      letter-spacing: -.06em;
      line-height: .95;
    }

    .subtitle {
      margin: 12px 0 0;
      color: var(--muted);
      font-size: 16px;
      max-width: 680px;
    }

    .site-nav {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-bottom: 18px;
    }

    .nav-link {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 42px;
      border: 1px solid var(--line);
      border-radius: 999px;
      padding: 10px 14px;
      color: var(--muted);
      background: rgba(255,255,255,.045);
      font-size: 13px;
      font-weight: 900;
      text-decoration: none;
    }

    .nav-link.active {
      color: var(--text);
      background: rgba(138,180,255,.16);
      border-color: rgba(138,180,255,.45);
    }

    .game-shell {
      display: grid;
      grid-template-columns: minmax(0, 1fr) 320px;
      gap: 16px;
      align-items: start;
    }

    .game-card,
    .score-card {
      background: rgba(21,27,47,.78);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      backdrop-filter: blur(12px);
    }

    .game-card {
      padding: 18px;
    }

    .score-card {
      padding: 18px;
      display: grid;
      gap: 14px;
    }

    .game-top {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 12px;
      margin-bottom: 14px;
    }

    .game-title {
      font-size: 24px;
      font-weight: 900;
      letter-spacing: -.04em;
    }

    .pill {
      border: 1px solid var(--line);
      background: rgba(255,255,255,.05);
      color: var(--muted);
      border-radius: 999px;
      padding: 10px 14px;
      font-size: 13px;
      white-space: nowrap;
    }

    .board-wrap {
      width: min(100%, 620px);
      margin: 0 auto;
      aspect-ratio: 1;
      border: 1px solid rgba(138,180,255,.24);
      border-radius: 18px;
      overflow: hidden;
      background: #080d18;
      box-shadow: inset 0 0 0 1px rgba(255,255,255,.04);
    }

    canvas {
      display: block;
      width: 100%;
      height: 100%;
      image-rendering: pixelated;
    }

    .score-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0,1fr));
      gap: 10px;
    }

    .mini {
      background: rgba(255,255,255,.04);
      border: 1px solid var(--line);
      border-radius: 16px;
      padding: 12px;
    }

    .mini span {
      display: block;
      color: var(--muted);
      font-size: 12px;
      margin-bottom: 4px;
    }

    .mini strong {
      font-size: 28px;
    }

    .actions,
    .dpad {
      display: grid;
      gap: 10px;
    }

    .actions {
      grid-template-columns: 1fr 1fr;
    }

    button {
      appearance: none;
      border: 1px solid var(--line);
      cursor: pointer;
      border-radius: 16px;
      padding: 13px 14px;
      font-weight: 900;
      color: var(--text);
      background: rgba(255,255,255,.08);
      transition: transform .12s ease, background .12s ease, border-color .12s ease;
    }

    button:hover {
      transform: translateY(-1px);
      background: rgba(255,255,255,.12);
    }

    button.good {
      background: rgba(51,209,122,.15);
      border-color: rgba(51,209,122,.45);
    }

    button.bad {
      background: rgba(255,92,122,.14);
      border-color: rgba(255,92,122,.45);
    }

    .dpad {
      grid-template-columns: repeat(3, 1fr);
    }

    .dpad button {
      min-height: 48px;
      padding: 0;
    }

    .dpad .up { grid-column: 2; }
    .dpad .left { grid-column: 1; }
    .dpad .right { grid-column: 3; }
    .dpad .down { grid-column: 2; }

    .hint {
      color: var(--muted);
      font-size: 13px;
      line-height: 1.5;
      border: 1px dashed rgba(246,193,119,.35);
      background: rgba(246,193,119,.08);
      border-radius: 18px;
      padding: 12px;
    }

    .planner-shell {
      display: grid;
      grid-template-columns: minmax(0, 1fr) 340px;
      gap: 16px;
      align-items: start;
    }

    .planner-card,
    .planner-panel {
      background: rgba(21,27,47,.78);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      backdrop-filter: blur(12px);
    }

    .planner-card,
    .planner-panel {
      padding: 18px;
    }

    .planner-panel {
      display: grid;
      gap: 16px;
    }

    .planner-filters {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-bottom: 14px;
    }

    .planner-grid {
      display: grid;
      grid-template-columns: repeat(7, minmax(0,1fr));
      gap: 8px;
    }

    .planner-day {
      min-height: 132px;
      background: rgba(255,255,255,.035);
      border: 1px solid var(--line);
      border-radius: 16px;
      padding: 9px;
      display: flex;
      flex-direction: column;
      gap: 8px;
    }

    .planner-day.outside {
      opacity: .36;
    }

    .planner-day.today {
      border-color: rgba(138,180,255,.75);
      box-shadow: 0 0 0 2px rgba(138,180,255,.12) inset;
    }

    .planner-date {
      color: var(--muted);
      font-size: 12px;
      font-weight: 900;
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 8px;
    }

    .planner-events {
      display: grid;
      gap: 6px;
    }

    .planner-event {
      position: relative;
      display: grid;
      gap: 2px;
      border: 1px solid rgba(255,255,255,.1);
      border-left-width: 4px;
      border-radius: 10px;
      padding: 7px 26px 7px 8px;
      background: rgba(255,255,255,.05);
      overflow-wrap: anywhere;
    }

    .planner-event.person-a {
      border-left-color: var(--today);
      background: rgba(138,180,255,.11);
    }

    .planner-event.person-b {
      border-left-color: var(--good);
      background: rgba(51,209,122,.1);
    }

    .event-time,
    .event-date-range,
    .event-person,
    .event-note {
      color: var(--muted);
      font-size: 11px;
      line-height: 1.25;
    }

    .event-date-range {
      color: var(--warn);
      font-weight: 900;
    }

    .event-title {
      color: var(--text);
      font-size: 12px;
      font-weight: 900;
      line-height: 1.2;
    }

    .event-delete {
      position: absolute;
      top: 5px;
      right: 5px;
      width: 20px;
      height: 20px;
      min-height: 0;
      display: grid;
      place-items: center;
      border-radius: 999px;
      padding: 0;
      color: var(--muted);
      font-size: 13px;
      line-height: 1;
      background: rgba(0,0,0,.2);
    }

    .event-form {
      display: grid;
      gap: 11px;
    }

    .event-form label {
      display: grid;
      gap: 6px;
      color: var(--muted);
      font-size: 13px;
      font-weight: 900;
    }

    .event-form input,
    .event-form select,
    .event-form textarea {
      width: 100%;
      border: 1px solid var(--line);
      border-radius: 14px;
      padding: 11px 12px;
      color: var(--text);
      background: rgba(255,255,255,.06);
      font: inherit;
      outline: none;
    }

    .event-form textarea {
      resize: vertical;
    }

    .event-form input:focus,
    .event-form select:focus,
    .event-form textarea:focus {
      border-color: rgba(138,180,255,.6);
      box-shadow: 0 0 0 3px rgba(138,180,255,.12);
    }

    .time-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 10px;
    }

    @media (max-width: 900px) {
      body { padding: 16px; }
      header { flex-direction: column; }
      .game-shell,
      .planner-shell { grid-template-columns: 1fr; }
      .game-top { flex-direction: column; align-items: flex-start; }
      .planner-grid { grid-template-columns: 1fr; }
      .planner-day { min-height: auto; }
    }

    @media (min-width: 1500px) {
      .site-nav {
        position: fixed;
        top: 136px;
        left: calc((100vw - 1180px) / 2 - 148px);
        width: 124px;
        flex-direction: column;
      }

      .nav-link {
        width: 100%;
      }
    }

