:root{--bg: #f4f6fb;--ink: #1a2233;--ink-soft: #5a667a;--accent: #4f46e5;--accent-soft: #eef2ff;--green: #16a34a;--green-soft: #dcfce7;--red: #dc2626;--red-soft: #fee2e2;--amber: #f59e0b;--card: #ffffff;--shadow: 0 10px 30px rgba(15, 23, 42, .08);--radius: 16px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--ink);background:radial-gradient(1000px 600px at 10% -10%,#e0e7ff 0%,transparent 60%),radial-gradient(900px 500px at 110% 110%,#fce7f3 0%,transparent 60%),var(--bg);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;overscroll-behavior-y:none}@supports (padding: max(0px)){body{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}}button{font:inherit;cursor:pointer;border:none;background:transparent;touch-action:manipulation}.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}.auth-card{width:100%;max-width:420px;background:var(--card);border-radius:24px;box-shadow:var(--shadow);padding:32px}.brand{text-align:center;margin-bottom:20px}.brand-logo{font-size:48px}.brand h1{margin:8px 0 4px;font-size:26px}.brand p{margin:0;color:var(--ink-soft)}.tabs{display:flex;background:#f1f3f9;padding:4px;border-radius:12px;margin:20px 0}.tab{flex:1;padding:10px 12px;border-radius:8px;color:var(--ink-soft);font-weight:600;transition:all .15s ease}.tab.active{background:#fff;color:var(--ink);box-shadow:0 2px 6px #0000000f}.auth-form{display:grid;gap:14px}.auth-form label{display:grid;gap:6px;font-size:14px;color:var(--ink-soft)}.auth-form input{padding:12px 14px;font-size:15px;border-radius:10px;border:1.5px solid #e2e6ef;background:#fbfcfe;outline:none;transition:border-color .15s ease}.auth-form input:focus{border-color:var(--accent);background:#fff}.primary{padding:12px 16px;border-radius:12px;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;font-weight:700;font-size:15px;box-shadow:0 6px 16px #4f46e559;transition:transform .08s ease}.primary:hover:not(:disabled){transform:translateY(-1px)}.primary:disabled{opacity:.7;cursor:wait}.ghost{padding:8px 12px;border-radius:10px;color:var(--ink-soft);font-weight:600}.ghost:hover{background:#f1f3f9;color:var(--ink)}.error{background:var(--red-soft);color:var(--red);padding:10px 12px;border-radius:10px;font-size:14px}.dash{max-width:960px;margin:0 auto;padding:24px 20px 60px}.topbar{display:flex;justify-content:space-between;align-items:center;padding:6px 4px 18px}.brand-small{display:flex;align-items:center;gap:8px;font-size:17px}.brand-logo-small{font-size:22px}.who{display:flex;align-items:center;gap:12px;color:var(--ink-soft);font-size:14px}.status-banner{display:flex;align-items:center;gap:16px;background:var(--card);padding:18px 20px;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:28px}.status-emoji{font-size:40px}.status-title{font-size:18px;font-weight:600}.status-sub{color:var(--ink-soft);font-size:14px;margin-top:2px}.status-banner>div:nth-child(2){flex:1}.duplex{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}.deck{padding:6px 0}.deck-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.deck-emoji{font-size:20px}.deck h2{margin:0;font-size:16px;letter-spacing:.3px;text-transform:uppercase;color:var(--ink-soft)}.deck-count{margin-left:auto;font-size:13px;color:var(--ink-soft)}.deck-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.bike-zone .deck-grid{grid-template-columns:repeat(5,1fr)}.auth-checking{text-align:center;padding:40px 32px}.auth-checking .brand-logo{font-size:48px}.checking-msg{margin:14px 0 0;color:var(--ink-soft);font-size:15px}.deck-divider{display:flex;align-items:center;gap:12px;color:var(--ink-soft);font-size:12px;margin:22px 0;text-transform:uppercase;letter-spacing:1px}.deck-divider:before,.deck-divider:after{content:"";flex:1;height:1px;background:repeating-linear-gradient(90deg,#d0d7e5 0 6px,transparent 6px 12px)}.slot{aspect-ratio:1 / 1;border-radius:14px;border:2px dashed transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:10px;font-weight:600;transition:transform .08s ease,box-shadow .15s ease,background .15s ease;position:relative}.slot:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 18px #0f172a14}.slot:disabled{cursor:not-allowed}.slot-label{font-size:22px;font-weight:800;letter-spacing:1px}.slot-car{font-size:28px;min-height:34px}.slot-status{font-size:12px;font-weight:500}.slot.free{background:var(--green-soft);color:var(--green);border-color:#86efac}.slot.free:hover{background:#bbf7d0}.slot.taken{background:var(--red-soft);color:var(--red);border-style:solid;border-color:#fecaca}.slot.taken .slot-status{font-size:11px;opacity:.9}.slot.mine{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border-color:transparent;box-shadow:0 10px 22px #4f46e559}.slot.mine:hover{filter:brightness(1.05)}.loading{padding:40px;text-align:center;color:var(--ink-soft)}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);padding:12px 18px;border-radius:12px;font-weight:600;box-shadow:var(--shadow);animation:rise .25s ease;max-width:90vw}.toast.success{background:var(--green-soft);color:var(--green)}.toast.error{background:var(--red-soft);color:var(--red)}@keyframes rise{0%{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%)}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px;z-index:100;animation:fadeIn .18s ease}.modal-card{width:100%;max-width:420px;background:var(--card);border-radius:24px;box-shadow:0 24px 64px #0f172a59;padding:28px;animation:popIn .22s cubic-bezier(.34,1.56,.64,1)}.modal-emoji{font-size:44px;text-align:center;margin-bottom:8px}.modal-title{margin:0 0 6px;font-size:22px;text-align:center}.modal-sub{margin:0 0 20px;text-align:center;color:var(--ink-soft);font-size:14px}.modal-slot-pill{display:inline-block;background:var(--accent-soft, #eef0ff);color:var(--accent, #4f46e5);padding:4px 10px;border-radius:999px;font-weight:700;font-size:13px;margin:0 4px}.modal-actions{display:flex;gap:10px;margin-top:6px}.modal-actions .ghost{flex:1;border:1.5px solid #e2e6ef}.modal-actions .primary{flex:1.2}.modal-actions .danger{flex:1.2;padding:12px 16px;border-radius:12px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-weight:700;font-size:15px;box-shadow:0 6px 16px #dc262659;transition:transform .08s ease}.modal-actions .danger:hover{transform:translateY(-1px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@media (max-width: 640px){.dash{padding:14px 14px 28px}.topbar{padding:4px 0 14px}.brand-small{font-size:16px}.who{gap:8px;font-size:13px}.who span{display:none}.status-banner{flex-wrap:wrap;padding:14px 16px;gap:12px;margin-bottom:18px}.status-emoji{font-size:32px}.status-title{font-size:16px}.status-sub{font-size:13px}.status-banner>.primary{width:100%}.duplex{padding:14px;border-radius:18px}.deck h2{font-size:14px}.deck-grid{grid-template-columns:repeat(2,1fr);gap:10px}.deck-divider{margin:16px 0;font-size:11px}.slot{border-radius:12px;padding:8px}.slot-label{font-size:18px}.slot-car{font-size:24px;min-height:28px}.slot-status{font-size:11px}.auth-card{padding:24px 20px;border-radius:20px}.brand-logo{font-size:40px}.brand h1{font-size:22px}.modal-card{padding:22px 20px;border-radius:20px}.modal-emoji{font-size:36px}.modal-title{font-size:19px}.modal-actions{flex-direction:column-reverse}.modal-actions .ghost,.modal-actions .primary,.modal-actions .danger{flex:none;width:100%}.toast{left:16px;right:16px;bottom:16px;transform:none;text-align:center;animation:none}}@media (max-width: 360px){.deck-grid{gap:8px}.slot-label{font-size:16px}}
