:root{--bg:#f4f6f9;--surface:#fff;--surface-2:#eef2f7;--ink:#0f172a;--ink-soft:#334155;--muted:#64748b;--border:#e3e8ef;--border-strong:#cbd5e1;--brand:#0d9488;--brand-strong:#0f766e;--brand-tint:#e6f6f4;--accent:#0d9488;--ok:#059669;--ok-tint:#e7f7f0;--warn:#d97706;--danger:#e11d48;--danger-tint:#fdeaee;--r-sm:10px;--r:14px;--r-lg:22px;--shadow-sm:0 1px 2px rgba(15,23,42,.06);--shadow:0 1px 2px rgba(15,23,42,.05),0 10px 26px -16px rgba(15,23,42,.28);--shadow-lg:0 1px 3px rgba(15,23,42,.06),0 24px 48px -24px rgba(15,23,42,.36);--font:"Inter",system-ui,-apple-system,"Segoe UI","Noto Sans HK","Microsoft JhengHei",sans-serif}*{box-sizing:border-box}body,html{margin:0;padding:0;background:radial-gradient(900px 500px at 100% -10%,rgba(13,148,136,.06),transparent 60%),radial-gradient(700px 500px at -10% 0,rgba(13,148,136,.05),transparent 55%),var(--bg);background-attachment:fixed;color:var(--ink);font-family:var(--font);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;line-height:1.55}a{color:inherit;text-decoration:none}.container{max-width:1140px;margin:0 auto;padding:32px 20px 64px}h1{font-size:30px;font-weight:800;letter-spacing:-.02em;margin:0 0 6px}h2{font-size:19px;font-weight:700;letter-spacing:-.01em;margin:0 0 14px}.muted{color:var(--muted)}.navbar{gap:22px;padding:14px 28px;background:hsla(0,0%,100%,.85);-webkit-backdrop-filter:saturate(180%) blur(12px);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;z-index:40}.navbar,.navbar .brand{display:flex;align-items:center}.navbar .brand{font-weight:800;font-size:17px;letter-spacing:-.01em;gap:8px;white-space:nowrap}.navbar nav{display:flex;gap:4px;flex-wrap:wrap}.navbar nav a{color:var(--muted);font-size:14px;font-weight:500;padding:7px 12px;border-radius:999px;transition:background .15s,color .15s}.navbar nav a:hover{color:var(--ink);background:var(--surface-2)}.navbar .spacer{flex:1 1}.hero{position:relative;overflow:hidden;border-radius:var(--r-lg);padding:44px 40px;margin-bottom:30px;color:#fff;background:radial-gradient(1200px 400px at 90% -20%,hsla(0,0%,100%,.22),transparent),linear-gradient(135deg,#0d9488,#0f766e 45%,#115e59);box-shadow:var(--shadow-lg)}.hero h1{color:#fff;font-size:38px}.hero p{color:hsla(0,0%,100%,.86);font-size:16px;max-width:56ch;margin:8px 0 0}.hero .eyebrow{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:hsla(0,0%,100%,.78);margin-bottom:12px}.page-head{display:flex;align-items:flex-end;gap:16px;margin-bottom:18px}.page-head .spacer{flex:1 1}.sport-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));grid-gap:18px;gap:18px}.sport-card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:30px 20px 24px;text-align:center;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease;overflow:hidden}.sport-card:before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:var(--accent);opacity:.85}.sport-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border-strong)}.sport-card .icon{position:relative;font-size:36px;width:74px;height:74px;margin:6px auto 16px;display:grid;place-items:center;border-radius:22px;background:linear-gradient(150deg,color-mix(in srgb,var(--accent) 78%,#fff) 0,var(--accent) 52%,color-mix(in srgb,var(--accent) 78%,#000) 100%);box-shadow:0 12px 22px -8px color-mix(in srgb,var(--accent) 55%,transparent),0 2px 4px rgba(15,23,42,.12),inset 0 1px 0 hsla(0,0%,100%,.5);transition:transform .18s ease,box-shadow .18s ease}.sport-card .icon:after{content:"";position:absolute;inset:1px 1px 45% 1px;border-radius:21px 21px 40% 40%;background:linear-gradient(180deg,hsla(0,0%,100%,.34),hsla(0,0%,100%,0));pointer-events:none}.sport-card:hover .icon{transform:translateY(-3px) scale(1.05) rotate(-2deg);box-shadow:0 18px 30px -8px color-mix(in srgb,var(--accent) 62%,transparent),0 3px 6px rgba(15,23,42,.14),inset 0 1px 0 hsla(0,0%,100%,.55)}.sport-card .label{font-weight:700;font-size:16px}.sport-card .go{display:block;margin-top:4px;font-size:13px;color:var(--muted)}.sport-card.active{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 22%,transparent),var(--shadow)}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:22px;margin-bottom:22px;box-shadow:var(--shadow-sm)}.filters{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-end}.field{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:var(--ink-soft)}button,input,label,select,textarea{font-family:inherit}input,select,textarea{background:var(--surface);color:var(--ink);border:1px solid var(--border-strong);border-radius:var(--r-sm);padding:9px 11px;font-size:14px;font-weight:500;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-tint)}.multiselect{min-height:112px;padding:4px}.multiselect option{padding:5px 8px;border-radius:6px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:linear-gradient(180deg,#12a99b 0,var(--brand) 100%);color:#fff;border:1px solid transparent;border-radius:var(--r-sm);padding:10px 16px;font-weight:600;font-size:14px;cursor:pointer;transition:filter .15s,transform .05s,box-shadow .15s;box-shadow:0 1px 2px rgba(15,23,42,.12),0 4px 12px -6px rgba(13,148,136,.5)}.btn:hover{filter:brightness(1.06);box-shadow:0 2px 4px rgba(15,23,42,.14),0 8px 18px -8px rgba(13,148,136,.55)}.btn:active{transform:translateY(1px)}.btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--brand-tint),0 0 0 5px color-mix(in srgb,var(--brand) 45%,transparent)}.btn:disabled{opacity:.55;cursor:default}.btn.secondary{background:var(--surface);color:var(--ink);border-color:var(--border-strong);box-shadow:none}.btn.secondary:hover{background:var(--surface-2)}.btn.ghost{background:transparent;color:var(--muted);border-color:var(--border-strong);box-shadow:none}.btn.ghost:hover{color:var(--ink);background:var(--surface-2)}.chip-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.chip{position:relative;display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--border-strong);border-radius:999px;background:var(--surface);color:var(--ink-soft);font-size:13px;font-weight:600;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background .12s,border-color .12s,color .12s,box-shadow .12s}.chip:hover{background:var(--surface-2);border-color:var(--muted)}.chip.on{background:var(--brand);border-color:var(--brand);color:#fff;box-shadow:0 2px 6px -2px color-mix(in srgb,var(--brand) 55%,transparent)}.chip input{position:absolute;width:1px;height:1px;opacity:0;margin:0;pointer-events:none}.chip:focus-within{box-shadow:0 0 0 3px var(--brand-tint)}.courts-toolbar{display:flex;align-items:flex-start;gap:12px}.courts-toolbar>.field{flex:1 1;min-width:0}.district-picker{display:flex;flex-direction:column;gap:8px;margin-top:2px}.region-block{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.region-block+.region-block{border-top:1px solid var(--border);padding-top:10px;margin-top:2px}.chip.region{background:transparent;border-style:dashed;border-color:var(--border-strong);color:var(--brand-strong);font-weight:700}.chip.region:hover{background:var(--brand-tint);border-color:var(--brand)}.chip.region.on{background:var(--brand-strong);border-color:var(--brand-strong);border-style:solid;color:#fff;box-shadow:0 2px 6px -2px color-mix(in srgb,var(--brand) 55%,transparent)}.checkbox{display:inline-flex;align-items:center;gap:10px;color:var(--ink-soft);font-weight:600;font-size:14px;padding:8px 14px;border:1px solid var(--border);border-radius:999px;background:var(--surface-2);cursor:pointer}.checkbox input{accent-color:var(--brand);width:16px;height:16px}.table-wrap{border:1px solid var(--border);border-radius:var(--r);overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse}thead th{text-align:left;padding:12px 16px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:var(--surface-2)}tbody td,thead th{border-bottom:1px solid var(--border)}tbody td{padding:13px 16px;font-size:14px;vertical-align:top}tbody tr:last-child td{border-bottom:none}tbody tr{transition:background .12s}tbody tr:hover{background:var(--brand-tint)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;line-height:1.6;background:var(--surface-2);color:var(--ink-soft)}.badge.beginner{background:var(--ok-tint);color:var(--ok)}.badge.mtr{background:var(--surface-2);color:var(--ink-soft);margin-top:6px}.badge.flagged{background:var(--danger-tint);color:var(--danger)}.badge.pending{background:var(--brand-tint);color:var(--brand-strong)}.comp-filters{gap:16px;align-items:flex-end}.comp-filters,.crit-tags{display:flex;flex-wrap:wrap}.crit-tags{gap:4px}.nowrap{white-space:nowrap}.restrict-note{margin-top:5px;font-size:12px;font-weight:600;color:#b45309;background:#fde7c3;border-radius:var(--r-sm);padding:3px 8px;display:inline-block;max-width:320px}.count-pill{display:inline-grid;place-items:center;min-width:30px;height:30px;padding:0 8px;border-radius:999px;font-weight:700;font-size:14px;background:var(--ok-tint);color:var(--ok)}.count-pill.zero{background:var(--surface-2);color:var(--muted)}.view-toggle{display:inline-flex;border:1px solid var(--border-strong);border-radius:999px;overflow:hidden}.view-toggle button{border:none;background:var(--surface);color:var(--muted);padding:8px 18px;font-weight:600;font-size:14px;cursor:pointer}.view-toggle button.on{background:var(--brand);color:#fff}.day-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.day-btn{display:flex;flex-direction:column;align-items:center;gap:1px;min-width:60px;padding:8px 12px;border:1px solid var(--border-strong);border-radius:var(--r-sm);background:var(--surface);color:var(--ink-soft);cursor:pointer;transition:background .12s,border-color .12s,color .12s}.day-btn:hover{background:var(--surface-2)}.day-btn .dow{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}.day-btn .day{font-size:14px;font-weight:700}.day-btn.on{background:var(--brand);border-color:var(--brand)}.day-btn.on .day,.day-btn.on .dow{color:#fff}.grid-legend{display:flex;gap:16px;align-items:center;margin:4px 0 14px;font-size:13px;color:var(--muted)}.legend-swatch{display:inline-block;width:14px;height:14px;border-radius:4px;margin-right:6px;vertical-align:-2px}.legend-swatch.free{background:var(--ok)}.legend-swatch.full{background:var(--danger)}.legend-swatch.none{background:var(--surface-2);border:1px solid var(--border-strong)}.legend-swatch.freed,.legend-swatch.to-release{background:#f59e0b}.grid-fullbleed{margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);padding:0 24px;display:flex;justify-content:center}.grid-wrap{width:-moz-fit-content;width:fit-content;max-width:100%;max-height:80vh;overflow:auto;border:1px solid var(--border);border-radius:var(--r)}.grid-table{border-collapse:separate;border-spacing:0}.grid-table td,.grid-table th{padding:0;margin:0}.grid-table thead th{position:-webkit-sticky;position:sticky;top:0;background:var(--surface-2);color:var(--muted);font-size:11px;font-weight:700;height:40px;min-width:46px;border-bottom:1px solid var(--border);border-right:1px solid var(--border);z-index:1}.grid-table .vcol-head{left:0;z-index:3;text-align:left;padding-left:14px;min-width:190px}.grid-table .vcol{position:-webkit-sticky;position:sticky;left:0;background:var(--surface);text-align:left;padding:8px 14px;font-weight:600;font-size:13px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);z-index:2;white-space:nowrap}.grid-table .vcol .vdist{display:block;font-size:11px;font-weight:500;color:var(--muted)}.gcell{width:46px;min-width:46px;height:38px;text-align:center;font-size:12px;font-weight:700;border-right:1px solid var(--border);border-bottom:1px solid var(--border)}.gcell.free{background:var(--ok-tint);color:var(--ok)}.gcell.full{background:var(--danger-tint);color:var(--danger)}.gcell.none{background:var(--surface-2);color:transparent}.gcell.freed,.gcell.to-release{background:#fde7c3;color:#b45309;box-shadow:inset 0 0 0 2px #f59e0b}.gcell.to-release{cursor:help}.gcell.to-release.upcoming{background:#fff6e8;box-shadow:inset 0 0 0 2px #f59e0b;opacity:.85}.gcell.split{padding:0}.split-cell{display:flex;height:38px}.split-cell .half{flex:1 1;display:grid;place-items:center;font-size:11px;font-weight:700}.split-cell .half:first-child{border-right:1px dashed var(--border-strong)}.split-cell .half.free{background:var(--ok-tint);color:var(--ok)}.split-cell .half.full{background:var(--danger-tint);color:var(--danger)}.split-cell .half.none{background:var(--surface-2);color:transparent}.practice-tag{display:inline-block;margin-left:6px;padding:1px 7px;border-radius:999px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;background:#ede9fe;color:#6d28d9}.row-upcoming{background:#fff7ed!important}.badge.freed-badge,.badge.to-release{background:#fde7c3;color:#b45309}.badge.freed-badge{margin-left:10px;font-size:12px;vertical-align:middle}.discrepancy{color:var(--danger);font-size:13px;margin-top:6px;font-weight:500}.weather-banner{background:var(--danger-tint);border:1px solid color-mix(in srgb,var(--danger) 30%,transparent);color:var(--danger);padding:12px 16px;border-radius:var(--r-sm);margin:0 0 18px;font-weight:600}.row-actions{display:flex;gap:8px}.src-cell{align-items:flex-start;gap:4px}.src-cell,.src-edit{display:flex;flex-direction:column}.src-edit{gap:6px;min-width:200px}.src-edit input{width:100%;font-size:13px}.btn.btn-xs{padding:3px 9px;font-size:12px}.link{color:var(--brand-strong);font-weight:600}.link:hover{text-decoration:underline}.form-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.form-grid .full{grid-column:1/-1}.notice{padding:14px 16px;border-radius:var(--r-sm);background:var(--ok-tint);color:var(--ok);font-weight:600}.empty{text-align:center;color:var(--muted);padding:32px 0}.grid-mobile{display:none}.vcard{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-sm);padding:14px 14px 12px}.vcard-head{display:flex;flex-wrap:wrap;align-items:center;gap:6px 8px;margin-bottom:10px}.vcard-head .vname{font-weight:700;font-size:15px}.vcard-head .vdist{color:var(--muted);font-size:12px;width:100%}.slot-chips{display:flex;flex-wrap:wrap;gap:6px}.mslot{display:inline-flex;align-items:center;gap:5px;padding:5px 9px;border-radius:999px;font-size:12px;font-weight:600;line-height:1}.mslot b{font-weight:700}.mslot.free{background:var(--ok-tint);color:var(--ok)}.mslot.release{background:#fde7c3;color:#b45309;box-shadow:inset 0 0 0 1px #f59e0b}.mslot.release.upcoming{background:#fff6e8}.mslot.practice{background:var(--surface-2);color:var(--ink-soft);padding:4px 8px}.mslot .mhalves{display:inline-flex;gap:2px}.mslot .mhalf{min-width:15px;text-align:center;padding:1px 3px;border-radius:4px;font-size:10px;font-weight:700}.mslot .mhalf.free{background:var(--ok);color:#fff}.mslot .mhalf.full{background:var(--danger);color:#fff}.mslot .mhalf.none{background:var(--border);color:transparent}.slot-empty{color:var(--muted);font-size:13px}@media (max-width:860px){.container{padding:22px 16px 56px}h1{font-size:26px}.hero{padding:34px 24px}.hero h1{font-size:32px}.sport-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}}@media (max-width:720px){.navbar{flex-wrap:wrap;gap:10px 12px;padding:10px 14px}.navbar .spacer{display:none}.navbar .brand{font-size:15px;flex:1 1 auto;min-width:0}.navbar nav{order:3;width:100%;flex-wrap:nowrap;overflow-x:auto;gap:6px;margin:0 -14px;padding:2px 14px 4px;scrollbar-width:none;-webkit-overflow-scrolling:touch}.navbar nav::-webkit-scrollbar{display:none}.navbar nav a{white-space:nowrap;flex:0 0 auto}.hero{padding:26px 20px;border-radius:var(--r);margin-bottom:22px}.hero h1{font-size:26px}.hero p{font-size:15px}.page-head{flex-direction:column;align-items:flex-start;gap:8px}.form-grid{grid-template-columns:1fr}.comp-filters,.filters{gap:12px}.comp-filters .checkbox,.comp-filters .field,.comp-filters .field input,.comp-filters .field select,.filters .field,.filters .field input,.filters .field select{width:100%}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-wrap table{min-width:600px}.panel>table{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}tbody td,thead th{padding:11px 12px}.courts-toolbar{flex-direction:column;align-items:stretch}.courts-toolbar .btn{width:100%}.grid-fullbleed.grid-desktop{display:none}.grid-mobile{display:flex;flex-direction:column;gap:12px}.grid-legend{flex-wrap:wrap;gap:10px 14px}.grid-legend .spacer{display:none}.sport-grid{grid-template-columns:1fr 1fr;gap:12px}.sport-card{padding:22px 14px 18px}.sport-card .icon{width:62px;height:62px;font-size:32px}.panel{padding:18px 16px}}@media (max-width:430px){.sport-grid{grid-template-columns:1fr}h1{font-size:23px}.hero h1{font-size:24px}}