:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--brand:#2d6a4f;--brand-hover:#1b4332;--brand-soft:#d8f3dc;--brand-soft-2:#b7e4c7;--bg:#f6f8f7;--card:#fff;--border:#e5e7eb;--border-strong:#d1d5db;--text:#111827;--text-muted:#6b7280;--text-subtle:#9ca3af;--accent:#0ea5e9;--danger:#dc2626;--danger-soft:#fee2e2;--warn:#d97706;--warn-soft:#fef3c7;--ok:#16a34a;--ok-soft:#dcfce7;--shadow-sm:0 1px 2px #0f172a0a, 0 1px 3px #0f172a0f;--shadow-md:0 4px 6px -1px #0f172a14, 0 2px 4px -2px #0f172a0d;--shadow-lg:0 20px 40px -8px #0f172a2e;--radius-sm:6px;--radius:10px;--radius-lg:14px;--font:-apple-system, BlinkMacSystemFont, "Inter", "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--mono:ui-monospace, SFMono-Regular, Menlo, "DejaVu Sans Mono", monospace}*{box-sizing:border-box}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;margin:0;font-size:14px;line-height:1.5}a{color:var(--brand);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{letter-spacing:-.01em;margin:0;font-weight:600}h1{font-size:22px}h2{font-size:18px}h3{font-size:15px}h4{font-size:13px}code,kbd{font-family:var(--mono);font-size:12px}.muted{color:var(--text-muted)}.subtle{color:var(--text-subtle)}.small{font-size:12px}.center{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.row.between{justify-content:space-between}.stack>*+*{margin-top:16px}.grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}@media (width<=600px){.grid{grid-template-columns:1fr}}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px 20px}.card+.card{margin-top:16px}.card h2{margin-bottom:12px}form{flex-direction:column;gap:12px;display:flex}label{color:var(--text-muted);flex-direction:column;gap:4px;font-size:12px;font-weight:500;display:flex}input,select,textarea{font:inherit;color:var(--text);border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:#fff;outline:none;padding:8px 10px;transition:border-color .12s,box-shadow .12s}input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}input[type=checkbox]{padding:0}button{font:inherit;border-radius:var(--radius-sm);border:1px solid var(--border-strong);color:var(--text);cursor:pointer;background:#fff;padding:8px 14px;font-weight:500;transition:background .12s,border-color .12s,transform 50ms}button:hover:not(:disabled){background:#f3f4f6}button:active:not(:disabled){transform:translateY(1px)}button:disabled{opacity:.55;cursor:not-allowed}button.primary{background:var(--brand);color:#fff;border-color:var(--brand)}button.primary:hover:not(:disabled){background:var(--brand-hover);border-color:var(--brand-hover)}button.danger{color:var(--danger);background:#fff;border-color:#fecaca}button.danger:hover:not(:disabled){background:var(--danger-soft);border-color:var(--danger)}button.ghost{background:0 0;border-color:#0000}button.ghost:hover:not(:disabled){background:#f3f4f6}button.link{color:var(--brand);cursor:pointer;background:0 0;border:none;padding:0}button.link:hover{text-decoration:underline}.err{background:var(--danger-soft);color:#991b1b;border-radius:var(--radius-sm);border:1px solid #fecaca;padding:10px 12px;font-size:13px}.pill{border-radius:999px;align-items:center;padding:2px 8px;font-size:11px;font-weight:500;line-height:1.6;display:inline-flex}.pill.owner{background:var(--brand-soft);color:var(--brand-hover)}.pill.manager{color:#3730a3;background:#e0e7ff}.pill.active{background:var(--ok-soft);color:#14532d}.pill.cancelled{color:var(--text-muted);background:#f3f4f6}.pill.player{color:#075985;background:#e0f2fe}.pill.club_admin{background:var(--brand-soft);color:var(--brand-hover)}.login{background:linear-gradient(135deg,#f0fdf4 0%,#eef2ff 100%);place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{background:var(--card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border);width:100%;max-width:380px;padding:32px}.login-card .brand-block{text-align:center;margin-bottom:24px}.login-card .brand-mark{background:var(--brand);color:#fff;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:10px;font-size:22px;font-weight:700;display:inline-flex}.login-card h1{margin:0 0 2px;font-size:20px}.login-card p{color:var(--text-muted);margin:0;font-size:13px}.shell{grid-template-columns:240px 1fr;min-height:100vh;display:grid}@media (width<=820px){.shell{grid-template-columns:1fr}.nav{z-index:5;position:sticky;top:0}}.nav{color:#e2e8f0;background:#0f172a;flex-direction:column;gap:2px;padding:20px 14px;display:flex}.nav .brand{align-items:center;gap:10px;margin-bottom:14px;padding:4px 8px;font-size:16px;font-weight:600;display:flex}.nav .brand:before{content:"🎾";background:var(--brand);border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:inline-flex}.nav .section-label{text-transform:uppercase;letter-spacing:.08em;color:#64748b;padding:10px 10px 6px;font-size:10px;font-weight:700}.nav .club-meta{border-bottom:1px solid #1e293b;margin-bottom:10px;padding:6px 10px 14px}.nav .club-meta .name{color:#fff;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.nav .club-meta .role{color:#94a3b8;margin-top:2px;font-size:11px}.nav a{color:#cbd5e1;border-radius:8px;padding:8px 10px;font-size:13.5px;transition:background .12s,color .12s;display:block}.nav a:hover{color:#fff;background:#1e293b;text-decoration:none}.nav a.active{background:var(--brand);color:#fff}.nav .spacer{flex:1}.nav .logout{color:#94a3b8;text-align:left;background:0 0;border:1px solid #1e293b;margin-top:12px}.nav .logout:hover{color:#fff;background:#1e293b}main{width:100%;max-width:1100px;padding:24px 28px}main>h1:first-child{margin-bottom:14px}.t{border-collapse:separate;border-spacing:0;width:100%}.t th,.t td{text-align:left;border-bottom:1px solid var(--border);padding:10px 12px;font-size:13px}.t th{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);background:#f9fafb;font-size:11px;font-weight:600}.t tr:hover td{background:#fafafa}.t tr.cancelled td{color:var(--text-subtle);text-decoration:line-through}.list{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.list li{border-radius:var(--radius-sm);padding:8px 10px;transition:background .12s}.list li:hover{background:#f9fafb}.gallery{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-top:10px;display:grid}.gallery figure{border-radius:var(--radius-sm);background:#f3f4f6;border:2px solid #0000;margin:0;transition:border-color .12s,transform .12s;position:relative;overflow:hidden}.gallery figure.main{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}.gallery figure:hover{transform:translateY(-1px)}.gallery img{aspect-ratio:1;object-fit:cover;width:100%;display:block}.gallery figcaption{opacity:0;background:linear-gradient(#0000,#0009);justify-content:flex-end;gap:4px;padding:6px;transition:opacity .12s;display:flex;position:absolute;bottom:0;left:0;right:0}.gallery figure:hover figcaption{opacity:1}.gallery figcaption button{background:#fff;border:none;padding:3px 8px;font-size:11px}.wh{grid-template-columns:repeat(7,1fr);gap:8px;margin:10px 0;display:grid}.wh-day{border-radius:var(--radius-sm);border:1px solid var(--border);background:#f9fafb;padding:8px}.wh-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:4px;font-size:11px;font-weight:600}.wh-interval{align-items:center;gap:3px;margin-top:4px;display:flex}.wh-interval input{text-align:center;width:54px;padding:3px 4px;font-size:11px}.wh-interval button{color:var(--danger);border-color:#0000;padding:2px 6px;font-size:11px;line-height:1}.wh-day>button{width:100%;color:var(--brand);border-style:dashed;margin-top:6px;padding:3px;font-size:11px}.schedule-toolbar{justify-content:space-between;align-items:center;gap:10px;display:flex}.schedule-court{border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);background:#fff;padding:12px 14px}.schedule-court h3{align-items:center;gap:10px;margin-bottom:8px;display:flex}.slots-grid{grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:4px;margin-top:6px;display:grid}.slot{border-radius:var(--radius-sm);text-align:left;cursor:default;border:1px solid #0000;flex-direction:column;align-items:flex-start;padding:6px 8px;font-size:11px;line-height:1.3;display:flex}.slot .when{font-weight:600}.slot .status{opacity:.8;font-size:10px}.slot.free{background:var(--brand-soft);color:var(--brand-hover);border-color:var(--brand-soft-2);cursor:pointer}.slot.free:hover{background:var(--brand-soft-2)}.slot.booked{background:var(--danger-soft);color:#991b1b;cursor:not-allowed;border-color:#fecaca}.slot.past{color:var(--text-subtle);border-color:var(--border);cursor:not-allowed;background:#f3f4f6}.court-gallery{border-top:1px dashed var(--border);margin-top:14px;padding-top:14px}.modal-bg{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:10;background:#0f172a80;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-lg);width:100%;min-width:320px;max-width:480px;max-height:85vh;box-shadow:var(--shadow-lg);background:#fff;padding:22px 24px;overflow:auto}.modal h3{margin-bottom:14px}.modal pre{color:#e2e8f0;border-radius:var(--radius-sm);background:#0f172a;padding:10px;font-size:11px;overflow-x:auto}.dim{opacity:.55}.empty{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:13px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slide-in{0%{opacity:0;transform:translateY(-8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}@keyframes fade-out{0%{opacity:1}to{opacity:0;transform:translate(12px)}}.card{animation:.2s both slide-in}.modal{animation:.18s both slide-in}.spinner{vertical-align:-3px;border:2px solid;border-top-color:#0000;border-radius:50%;width:14px;height:14px;margin-right:6px;animation:.7s linear infinite spin;display:inline-block}button.primary:disabled .spinner{opacity:.8}.toasts{z-index:50;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;top:18px;right:18px}.toast{pointer-events:auto;min-width:240px;max-width:380px;color:var(--text);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);background:#fff;align-items:center;gap:10px;padding:10px 14px;font-size:13.5px;animation:.2s both slide-in-right,.4s 3s forwards fade-out;display:flex}.toast-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-weight:700;display:inline-flex}.toast-success{border-left:4px solid var(--ok)}.toast-success .toast-icon{background:var(--ok-soft);color:#14532d}.toast-error{border-left:4px solid var(--danger)}.toast-error .toast-icon{background:var(--danger-soft);color:#991b1b}.toast-info{border-left:4px solid var(--accent)}.toast-info .toast-icon{color:#075985;background:#e0f2fe}
