*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f7f7f5;--surface: #ffffff;--border: #e5e4e0;--border-strong: #c9c8c2;--text: #1a1a18;--text-muted: #6b6b66;--text-hint: #9e9e98;--accent: #2563eb;--accent-bg: #eff6ff;--accent-border: #bfdbfe;--green: #16a34a;--green-bg: #f0fdf4;--green-border: #86efac;--amber: #d97706;--amber-bg: #fffbeb;--amber-border: #fcd34d;--red: #dc2626;--red-bg: #fef2f2;--red-border: #fca5a5;--radius: 8px;--radius-lg: 12px}@media(prefers-color-scheme:dark){:root{--bg: #141413;--surface: #1e1e1c;--border: #2e2e2b;--border-strong: #444441;--text: #f0efeb;--text-muted: #9e9e98;--text-hint: #6b6b66;--accent: #60a5fa;--accent-bg: #1e2a3a;--accent-border: #1d4ed8;--green: #4ade80;--green-bg: #0d2818;--green-border: #166534;--amber: #fbbf24;--amber-bg: #291d08;--amber-border: #78350f;--red: #f87171;--red-bg: #2d0d0d;--red-border: #991b1b}}body{font-family:-apple-system,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;line-height:1.5}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.login-card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:48px 40px;width:100%;max-width:380px;text-align:center}.login-logo{width:52px;height:52px;background:var(--accent);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;color:#fff;font-size:24px}.login-card h1{font-size:20px;font-weight:600;margin-bottom:6px}.login-card p{color:var(--text-muted);margin-bottom:32px;font-size:14px}.btn-ms{width:100%;padding:11px 20px;border-radius:var(--radius);border:.5px solid var(--border-strong);background:var(--surface);color:var(--text);font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:background .15s}.btn-ms:hover{background:var(--bg)}.btn-ms svg{width:20px;height:20px;flex-shrink:0}.app-screen{min-height:100vh}.topbar{background:var(--surface);border-bottom:.5px solid var(--border);padding:0 20px;display:flex;align-items:center;justify-content:space-between;height:52px;position:sticky;top:0;z-index:10}.topbar-left{display:flex;align-items:center;gap:10px}.topbar-logo{width:28px;height:28px;background:var(--accent);border-radius:6px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px}.topbar-title{font-weight:600;font-size:15px}.topbar-right{display:flex;align-items:center;gap:10px}.user-pill{display:flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;border:.5px solid var(--border);border-radius:20px;cursor:pointer;transition:background .15s}.user-pill:hover{background:var(--bg)}.avatar{width:26px;height:26px;border-radius:50%;background:var(--accent-bg);border:.5px solid var(--accent-border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--accent)}.user-name{font-size:13px;color:var(--text-muted)}.tabs{background:var(--surface);border-bottom:.5px solid var(--border);padding:0 20px;display:flex;gap:0}.tab-btn{padding:12px 16px;font-size:14px;cursor:pointer;color:var(--text-muted);border:none;background:none;border-bottom:2px solid transparent;font-weight:500;transition:color .15s}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-btn:hover:not(.active){color:var(--text)}.content{padding:20px;max-width:900px;margin:0 auto}.month-cal{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-lg);margin-bottom:20px;overflow:hidden}.cal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:.5px solid var(--border)}.cal-month-title{font-size:15px;font-weight:600}.cal-nav{background:none;border:.5px solid var(--border);cursor:pointer;color:var(--text-muted);padding:4px 12px;border-radius:var(--radius);font-size:16px;line-height:1.5;transition:all .15s}.cal-nav:hover{background:var(--bg);color:var(--text);border-color:var(--border-strong)}.cal-dows{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:.5px solid var(--border)}.cal-dow{padding:6px 0;text-align:center;font-size:11px;font-weight:600;color:var(--text-hint);text-transform:uppercase;letter-spacing:.04em}.cal-body{display:grid;grid-template-columns:repeat(7,1fr);gap:.5px;background:var(--border)}.cal-day{background:var(--surface);padding:8px 4px 6px;min-height:54px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;transition:background .12s}.cal-day:hover:not(.cal-empty){background:var(--bg)}.cal-empty{background:var(--bg);cursor:default;pointer-events:none}.cal-day.cal-today .cal-day-num{background:var(--accent);color:#fff;border-radius:50%}.cal-day.cal-selected{background:var(--accent-bg)}.cal-day.cal-selected .cal-day-num{color:var(--accent);font-weight:700}.cal-day.cal-today.cal-selected .cal-day-num{background:var(--accent);color:#fff}.cal-day.cal-past{opacity:.5}.cal-day-num{font-size:13px;font-weight:500;color:var(--text);width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0}.cal-count{font-size:11px;font-weight:600;padding:1px 5px;border-radius:20px}.cal-count.has-free{background:var(--green-bg);color:var(--green)}.cal-count.no-free{color:var(--border-strong);font-size:10px}.cal-count.loading{background:var(--border);border-radius:8px;width:18px;height:10px;color:transparent}.stats-bar{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}.stat-card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);padding:12px 16px}.stat-num{font-size:24px;font-weight:600}.stat-num.green{color:var(--green)}.stat-num.amber{color:var(--amber)}.stat-label{font-size:12px;color:var(--text-muted);margin-top:2px}.spots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}.spot-card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);padding:12px 14px;cursor:default;transition:border-color .15s,transform .1s;position:relative}.spot-card.free{border-color:var(--green-border);background:var(--green-bg);cursor:pointer}.spot-card.free:hover{transform:translateY(-1px);border-color:var(--green)}.spot-card.mine{border-color:var(--accent-border);background:var(--accent-bg)}.spot-card.mine.available{cursor:pointer}.spot-card.mine.available:hover{transform:translateY(-1px);border-color:var(--accent)}.spot-card.reserved{border-color:var(--amber-border);background:var(--amber-bg)}.spot-card.taken{border-color:var(--border)}.spot-dropdown{background:var(--surface);border:.5px solid var(--border-strong);border-radius:var(--radius);box-shadow:0 4px 16px #00000026;overflow:hidden;min-width:160px;z-index:9999}.spot-dropdown-item{display:block;width:100%;padding:10px 14px;font-size:13px;font-family:inherit;color:var(--text);background:none;border:none;border-bottom:.5px solid var(--border);text-align:left;cursor:pointer;outline:none}.spot-dropdown-item:last-child{border-bottom:none}.spot-dropdown-item:hover,.spot-dropdown-item[data-highlighted]{background:var(--bg);color:var(--text)}.spot-card.taken .spot-num,.spot-card.taken .spot-owner,.spot-card.taken .spot-type-tag{color:var(--text-hint)}.spot-num{font-size:22px;font-weight:700;letter-spacing:-.5px}.spot-card.free .spot-num{color:var(--green)}.spot-card.mine .spot-num{color:var(--accent)}.spot-card.reserved .spot-num{color:var(--amber)}.spot-owner{font-size:12px;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spot-card.free .spot-owner{color:var(--green)}.spot-card.mine .spot-owner{color:var(--accent)}.spot-badge{display:inline-block;margin-top:8px;font-size:11px;font-weight:500;padding:2px 8px;border-radius:20px}.badge-free{background:var(--green-border);color:var(--green)}.badge-mine{background:var(--accent-border);color:var(--accent)}.badge-mine-avail{background:var(--green-bg);color:var(--green);border:.5px solid var(--green-border)}.badge-mine-reserved{background:var(--amber-bg);color:var(--amber);border:.5px solid var(--amber-border)}.badge-taken{background:var(--border);color:var(--text-hint)}.badge-reserved{background:var(--amber-border);color:var(--amber)}.spot-type-tag{font-size:10px;color:var(--text-hint);margin-top:3px;display:flex;align-items:center;gap:3px}.spot-type-tag .type-icon{font-size:9px;opacity:.7}.my-spot-hero{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:24px;display:flex;align-items:center;gap:20px;margin-bottom:20px}.spot-big-num{font-size:48px;font-weight:800;color:var(--accent);letter-spacing:-2px;line-height:1}.my-spot-info h2{font-size:18px;font-weight:600}.my-spot-info p{color:var(--text-muted);font-size:13px;margin-top:4px}.section-title{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px}.availability-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px;margin-bottom:24px}.avail-card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);padding:12px 14px;display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.avail-date{font-size:13px;font-weight:500}.avail-sub{font-size:11px;color:var(--text-muted)}.toggle-wrap{display:flex;align-items:center}.toggle{width:38px;height:22px;border-radius:11px;background:var(--border-strong);position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}.toggle.on{background:var(--green)}.toggle-knob{width:18px;height:18px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform .2s;box-shadow:0 1px 3px #0003}.toggle.on .toggle-knob{transform:translate(16px)}.add-avail-card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:20px}.form-row{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end;margin-top:12px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:12px;color:var(--text-muted);font-weight:500}input[type=date]{padding:8px 12px;border-radius:var(--radius);border:.5px solid var(--border-strong);background:var(--surface);color:var(--text);font-size:14px;outline:none}input[type=date]:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-bg)}.btn{padding:9px 18px;border-radius:var(--radius);border:.5px solid var(--border-strong);background:var(--surface);color:var(--text);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.btn:hover{background:var(--bg)}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{opacity:.9}.btn-danger{color:var(--red);border-color:var(--red-border)}.btn-danger:hover{background:var(--red-bg)}.history-list{display:flex;flex-direction:column;gap:8px}.history-item{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);padding:12px 16px;display:flex;align-items:center;justify-content:space-between}.history-main{font-size:14px;font-weight:500}.history-sub{font-size:12px;color:var(--text-muted);margin-top:2px}.history-badge{font-size:11px;padding:3px 10px;border-radius:20px;font-weight:500}.modal-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:100;align-items:center;justify-content:center;padding:20px}.modal-overlay.open{display:flex}.modal{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:360px}.modal h3{font-size:16px;font-weight:600;margin-bottom:8px}.modal p{font-size:14px;color:var(--text-muted);margin-bottom:20px}.modal-actions{display:flex;gap:8px;justify-content:flex-end}.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%) translateY(80px);background:var(--text);color:var(--bg);padding:10px 20px;border-radius:20px;font-size:14px;font-weight:500;transition:transform .3s;z-index:200;white-space:nowrap}.toast.show{transform:translate(-50%) translateY(0)}.empty{text-align:center;padding:48px 20px;color:var(--text-muted)}.empty-icon{font-size:36px;margin-bottom:12px}.empty h3{font-size:16px;font-weight:500;color:var(--text);margin-bottom:6px}.spinner{width:20px;height:20px;border-radius:50%;border:2px solid var(--border);border-top-color:var(--accent);animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading{display:flex;align-items:center;gap:10px;color:var(--text-muted);padding:20px}.notice{background:var(--amber-bg);border:.5px solid var(--amber-border);border-radius:var(--radius);padding:12px 16px;font-size:14px;color:var(--amber);margin-bottom:20px}input[type=text],input[type=email],select{padding:8px 12px;border-radius:var(--radius);border:.5px solid var(--border-strong);background:var(--surface);color:var(--text);font-size:14px;outline:none;font-family:inherit}input[type=text]:focus,input[type=email]:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-bg)}.admin-table{display:flex;flex-direction:column;gap:4px;margin-bottom:24px}.admin-row{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);padding:10px 14px;display:grid;grid-template-columns:80px 1fr 1fr 120px auto;gap:12px;align-items:center}.admin-cell-num{font-size:15px;font-weight:700;color:var(--accent)}.admin-cell-name{font-size:14px;font-weight:500}.admin-cell-email{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-cell-actions{display:flex;gap:6px;justify-content:flex-end}.admin-email-row{background:var(--surface);border:.5px solid var(--border);border-radius:var(--radius);padding:10px 14px;display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.admin-email-row span{font-size:14px}@media(max-width:480px){.stats-bar{grid-template-columns:repeat(3,1fr)}.my-spot-hero{flex-direction:column;align-items:flex-start;gap:12px}.spot-big-num{font-size:40px}.admin-row{grid-template-columns:1fr}}.calamari-tag{display:inline-flex;align-items:center;gap:3px;margin-top:4px;font-size:10px;font-weight:500;color:#f97316;background:#fff7ed;border:.5px solid #fed7aa;border-radius:20px;padding:2px 7px}.calamari-tag svg{flex-shrink:0}@media(prefers-color-scheme:dark){.calamari-tag{color:#fb923c;background:#1a0d00;border-color:#7c2d12}}
