:root{
  --bg:#f7f8fb; --panel:#ffffff; --panel-2:#f0f3f9;
  --fg:#16213a; --fg-dim:#5a6b8a;
  --accent:#2c6df2; --accent-2:#16a085;
  --warn:#e08e3a; --bad:#d4504e;
  --line:#e3e8f1;
  --radius:14px;
  --shadow:0 1px 2px rgba(20,30,60,.04), 0 1px 8px rgba(20,30,60,.04);
  --possible:#e08e3a;
  --booked:#2c6df2;
  --attended:#16a085;
}
*{box-sizing:border-box}
[hidden]{display:none !important}
html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);
  font:16px/1.4 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
}
body{padding-bottom:env(safe-area-inset-bottom)}

.topbar{position:sticky;top:0;background:rgba(247,248,251,.92);
  backdrop-filter:saturate(180%) blur(10px);
  -webkit-backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--line);
  padding:14px 16px 10px;z-index:10}
.topbar-row{display:flex;justify-content:space-between;align-items:center;gap:8px}
.topbar h1{margin:0;font-size:17px;font-weight:600;letter-spacing:.1px}
.who-select{background:var(--panel);color:var(--fg);border:1px solid var(--line);
  padding:6px 10px;border-radius:8px;font-size:13px}

.view-toggle{display:flex;gap:4px;margin-top:10px;background:var(--panel-2);
  padding:3px;border-radius:10px;width:fit-content}
.vt{flex:0 0 auto;background:transparent;border:0;color:var(--fg-dim);
  padding:6px 14px;border-radius:8px;font-size:13px;cursor:pointer;font-weight:500}
.vt-active{background:var(--panel);color:var(--fg);
  box-shadow:0 1px 3px rgba(20,30,60,.08)}

.chips{display:flex;gap:6px;margin-top:10px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{background:var(--panel);color:var(--fg-dim);border:1px solid var(--line);
  padding:6px 12px;border-radius:999px;font-size:13px;white-space:nowrap;cursor:pointer;
  transition:all .15s ease}
.chip:hover{border-color:#c8d2e3}
.chip-active{background:var(--accent);color:#fff;border-color:transparent;font-weight:600}
.meta{margin-top:8px;color:var(--fg-dim);font-size:12px}

main{padding:12px 16px 60px;display:flex;flex-direction:column;gap:10px}

.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:14px;box-shadow:var(--shadow)}
.card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:8px}
.card-date{flex-shrink:0;text-align:center;background:var(--panel-2);border-radius:10px;
  padding:6px 10px;min-width:62px}
.date-d{font-size:22px;font-weight:700;line-height:1;color:var(--fg)}
.date-m{font-size:11px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.date-t{font-size:11px;color:var(--fg-dim);margin-top:3px}
.card-score{flex-shrink:0;color:#fff;border-radius:999px;
  padding:4px 12px;font-weight:700;font-size:13px;background:var(--accent)}
.score-9,.score-10{background:var(--accent-2)}
.score-7,.score-8{background:var(--accent)}
.score-5,.score-6{background:var(--warn)}
.score-1,.score-2,.score-3,.score-4{background:#b8c2d4;color:#fff}
.card-title{margin:0 0 4px;font-size:16px;line-height:1.3;font-weight:600;color:var(--fg)}
.card-venue{color:var(--fg-dim);font-size:13px;margin-bottom:6px}
.card-attendee{display:inline-block;background:var(--panel-2);color:var(--fg);
  padding:3px 10px;border-radius:999px;font-size:12px;margin-bottom:8px}
.attendee-Lauren{background:#fce4ff;color:#8b3aa0}
.attendee-Jeremiah{background:#dceefb;color:#1d5b95}
.attendee-Both{background:#dff5e9;color:#1c7b58}
.attendee-Skip{background:#fde2e2;color:#a93232}
.card-reason{margin:8px 0;font-size:13px;color:var(--fg-dim)}
.card-reason summary{cursor:pointer;color:var(--accent);outline:none;font-weight:500}
.card-reason p{margin:6px 0 0;color:var(--fg-dim)}

.status-row{display:flex;gap:6px;margin-top:12px}
.pill{flex:1;background:var(--panel);border:1px solid var(--line);color:var(--fg-dim);
  padding:8px 6px;border-radius:10px;font-size:13px;font-weight:500;cursor:pointer;
  transition:all .15s ease;text-align:center}
.pill:hover{border-color:#c8d2e3}
.pill.active{color:#fff;border-color:transparent;font-weight:600}
.pill-possible.active{background:var(--possible)}
.pill-booked.active{background:var(--booked)}
.pill-attended.active{background:var(--attended)}
.pill.active::after{content:" ✕";font-size:11px;opacity:.9}
.status-meta{margin-top:8px;padding:7px 10px;background:var(--panel-2);
  border-radius:8px;font-size:12px;color:var(--fg-dim)}

.card-foot{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:10px}
.card-link{color:var(--accent);font-size:13px;text-decoration:none;font-weight:500}
.card-link:hover{text-decoration:underline}

#toast{border:0;border-radius:12px;background:var(--fg);color:#fff;
  padding:14px 18px;box-shadow:0 6px 24px rgba(20,30,60,.18);font-size:14px;
  position:fixed;top:auto;bottom:24px;left:50%;transform:translateX(-50%)}
#toast::backdrop{background:transparent}

.empty{color:var(--fg-dim);text-align:center;padding:40px 16px}

/* ---- Calendar view ---- */
#calendar-view{padding:14px 16px 60px}
.cal-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.cal-head h2{margin:0;font-size:16px;font-weight:600}
.cal-head button{background:var(--panel);border:1px solid var(--line);color:var(--fg);
  width:34px;height:34px;border-radius:8px;font-size:18px;cursor:pointer;line-height:1}
.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;
  font-size:11px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.5px;
  text-align:center;padding:0 2px 6px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-cell{aspect-ratio:1/1.4;background:var(--panel);border:1px solid var(--line);
  border-radius:8px;padding:5px 5px 4px;font-size:11px;cursor:pointer;
  display:flex;flex-direction:column;
  transition:transform .1s ease;overflow:hidden;position:relative;min-height:0}
@media (min-width: 640px){.cal-cell{aspect-ratio:1/1;font-size:12px}}
.cal-cell:active{transform:scale(.95)}
.cal-cell.dim{background:transparent;border-color:transparent;cursor:default;color:transparent}
.cal-cell.today .day-num{color:var(--accent);font-weight:700}
.cal-cell.selected{background:var(--accent);color:#fff;border-color:transparent}
.cal-cell.has-booked{background:#e8f0fe}
.cal-cell.has-possible{background:#fdf0e2}
.cal-cell.has-attended{background:#dff5e9}
.cal-cell.has-booked.has-possible,
.cal-cell.has-booked.has-attended,
.cal-cell.has-possible.has-attended{background:linear-gradient(135deg,#e8f0fe 50%,#dff5e9 50%)}
.cal-cell.selected.has-booked,
.cal-cell.selected.has-possible,
.cal-cell.selected.has-attended{background:var(--accent)}
.day-num{font-weight:500;line-height:1}
.cal-chips{display:flex;flex-direction:column;gap:2px;margin-top:3px;flex:1;
  overflow:hidden;min-height:0}
.cal-chip{display:block;padding:1px 4px;border-radius:3px;background:#eef1f7;
  color:var(--fg);font-size:10px;line-height:1.25;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  border-left:3px solid #b8c2d4;cursor:pointer}
.cal-chip.possible{background:#fdf0e2;border-color:var(--possible);color:#7a4a18}
.cal-chip.booked{background:#dceefb;border-color:var(--booked);color:#1d4a8f}
.cal-chip.attended{background:#dff5e9;border-color:var(--attended);color:#0e6b4f}
.cal-chip-more{padding:1px 4px;font-size:10px;color:var(--fg-dim);text-align:left}
.cal-cell.selected .cal-chip{filter:brightness(1.05)}
.cell-count{font-size:9px;color:var(--fg-dim);text-align:right;line-height:1}
.cal-cell.selected .cell-count{color:#fff;opacity:.8}
.dot{display:inline-block;width:8px;height:8px;border-radius:999px;background:#b8c2d4}
.dot-possible{background:var(--possible)}
.dot-booked{background:var(--booked)}
.dot-attended{background:var(--attended)}
.cal-legend{display:flex;gap:14px;justify-content:center;font-size:12px;
  color:var(--fg-dim);margin-top:14px}
.cal-legend .dot{width:8px;height:8px;margin-right:4px}

.day-panel{margin-top:18px;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--radius);padding:14px;box-shadow:var(--shadow)}
.day-panel h3{margin:0 0 10px;font-size:14px;color:var(--fg-dim);font-weight:600}
.day-panel #day-panel-events{display:flex;flex-direction:column;gap:10px}
