:root{--bg: #0f172a;--surface: #1e293b;--surface-2: #293548;--surface-3: #334155;--border: #334155;--text: #f1f5f9;--text-muted: #94a3b8;--text-subtle: #64748b;--primary: #2563eb;--primary-hover: #1d4ed8;--primary-light: #1e3a6e;--success: #22c55e;--success-bg: #14532d;--danger: #ef4444;--danger-bg: #450a0a;--warning: #f59e0b;--radius: 14px;--radius-sm: 8px;--shadow: 0 4px 16px rgba(0, 0, 0, .35);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .25);--transition: .2s ease;--header-h: 60px}@media(prefers-color-scheme:light){:root:not([data-theme=dark]){--bg: #f1f5f9;--surface: #ffffff;--surface-2: #f8fafc;--surface-3: #f1f5f9;--border: #e2e8f0;--text: #0f172a;--text-muted: #475569;--text-subtle: #94a3b8;--primary-light: #dbeafe;--success-bg: #dcfce7;--danger-bg: #fee2e2;--shadow: 0 4px 16px rgba(0, 0, 0, .08);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06)}}:root[data-theme=light]{--bg: #f1f5f9;--surface: #ffffff;--surface-2: #f8fafc;--surface-3: #f1f5f9;--border: #e2e8f0;--text: #0f172a;--text-muted: #475569;--text-subtle: #94a3b8;--primary-light: #dbeafe;--success-bg: #dcfce7;--danger-bg: #fee2e2;--shadow: 0 4px 16px rgba(0, 0, 0, .08);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06)}:root[data-theme=dark]{--bg: #0f172a;--surface: #1e293b;--surface-2: #293548;--surface-3: #334155;--border: #334155;--text: #f1f5f9;--text-muted: #94a3b8;--text-subtle: #64748b;--primary-light: #1e3a6e;--success-bg: #14532d;--danger-bg: #450a0a;--shadow: 0 4px 16px rgba(0, 0, 0, .35);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .25)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;-webkit-tap-highlight-color:transparent}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100%;line-height:1.5;overscroll-behavior:none}#app{min-height:100dvh;display:flex;flex-direction:column}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}.app-header{position:sticky;top:0;z-index:100;height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.header-logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.1rem;color:var(--text);flex:1}.header-logo img{width:30px;height:30px}.header-actions{display:flex;align-items:center;gap:8px}.header-user{font-size:.85rem;color:var(--text-muted);display:none}@media(min-width:480px){.header-user{display:block}}.icon-btn{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:background var(--transition),color var(--transition)}.icon-btn:hover{background:var(--surface-3);color:var(--text)}.sse-dot{width:8px;height:8px;border-radius:50%;background:var(--text-subtle);transition:background var(--transition);flex-shrink:0}.sse-dot.connected{background:var(--success);box-shadow:0 0 6px var(--success)}.main-content{flex:1;padding:20px 16px 100px;max-width:900px;margin:0 auto;width:100%}.login-wrap{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:var(--bg)}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:36px 28px;width:100%;max-width:380px;box-shadow:var(--shadow)}.login-logo{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:28px}.login-logo img{width:48px;height:48px}.login-logo h1{font-size:1.4rem;font-weight:700}.form-group{margin-bottom:16px}.form-label{display:block;font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.form-input{width:100%;padding:11px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:1rem;transition:border-color var(--transition),box-shadow var(--transition);outline:none}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 20%,transparent)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;transition:background var(--transition),opacity var(--transition),transform var(--transition);cursor:pointer;border:none}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-primary{background:var(--primary);color:#fff;width:100%}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-trigger{background:var(--primary);color:#fff;padding:9px 16px;font-size:.85rem;border-radius:var(--radius-sm);flex:1}.btn-trigger:hover:not(:disabled){background:var(--primary-hover)}.btn-trigger.loading{opacity:.7}.btn-ghost{background:var(--surface-3);color:var(--text-muted);padding:9px 14px;font-size:.85rem;border-radius:var(--radius-sm)}.btn-ghost:hover{color:var(--text)}.error-msg{color:var(--danger);font-size:.85rem;margin-top:12px;text-align:center}.location-section{margin-bottom:28px}.location-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}.location-icon{width:34px;height:34px;background:var(--primary-light);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--primary);flex-shrink:0}.location-name{font-size:1rem;font-weight:700;color:var(--text)}.location-count{font-size:.75rem;color:var(--text-subtle);background:var(--surface-3);padding:2px 8px;border-radius:20px;margin-left:auto}.gate-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.gate-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm);transition:box-shadow var(--transition),border-color var(--transition);display:flex;flex-direction:column;gap:14px}.gate-card:hover{box-shadow:var(--shadow)}.gate-card-top{display:flex;align-items:center;gap:12px}.gate-icon-wrap{width:44px;height:44px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--primary-light);color:var(--primary)}.gate-info{flex:1;min-width:0}.gate-name{font-size:.95rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gate-status{display:inline-flex;align-items:center;gap:5px;font-size:.75rem;font-weight:600;margin-top:3px;text-transform:uppercase;letter-spacing:.05em}.status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.status-dot.open{background:var(--success);box-shadow:0 0 5px var(--success)}.status-dot.closed{background:var(--danger)}.status-dot.unknown{background:var(--text-subtle)}.gate-status.open{color:var(--success)}.gate-status.closed{color:var(--danger)}.gate-status.unknown{color:var(--text-subtle)}.gate-card-actions{display:flex;gap:8px}.gate-updated{font-size:.7rem;color:var(--text-subtle);margin-top:-8px}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:200;opacity:0;pointer-events:none;transition:opacity var(--transition)}.drawer-overlay.open{opacity:1;pointer-events:all}.drawer{position:fixed;right:0;top:0;bottom:0;width:min(420px,100vw);background:var(--surface);border-left:1px solid var(--border);z-index:201;display:flex;flex-direction:column;transform:translate(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow)}.drawer.open{transform:translate(0)}.drawer-header{padding:16px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;flex-shrink:0}.drawer-title{font-size:1rem;font-weight:700;flex:1}.drawer-subtitle{font-size:.8rem;color:var(--text-muted);margin-top:2px}.drawer-body{flex:1;overflow-y:auto;padding:16px 18px;-webkit-overflow-scrolling:touch}.history-list{display:flex;flex-direction:column;gap:2px}.history-entry{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.history-entry:last-child{border-bottom:none}.history-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.history-icon.trigger{background:var(--primary-light);color:var(--primary)}.history-icon.open{background:var(--success-bg);color:var(--success)}.history-icon.closed{background:var(--danger-bg);color:var(--danger)}.history-icon.unknown{background:var(--surface-3);color:var(--text-subtle)}.history-body{flex:1;min-width:0}.history-label{font-size:.875rem;font-weight:600;color:var(--text)}.history-meta{font-size:.75rem;color:var(--text-muted);margin-top:2px}.history-time{font-size:.72rem;color:var(--text-subtle);flex-shrink:0;text-align:right}.load-more-btn{width:100%;margin-top:14px;padding:10px;background:var(--surface-3);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.85rem;font-weight:600;transition:background var(--transition),color var(--transition)}.load-more-btn:hover{background:var(--border);color:var(--text)}.empty-state{text-align:center;padding:40px 20px;color:var(--text-subtle);font-size:.9rem}.empty-state svg{margin-bottom:12px;opacity:.4}.toast-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:300;display:flex;flex-direction:column;gap:8px;pointer-events:none;width:min(360px,calc(100vw - 32px))}.toast{background:var(--surface-3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;font-size:.875rem;font-weight:500;box-shadow:var(--shadow);display:flex;align-items:center;gap:10px;animation:toast-in .22s ease}.toast.success{border-color:var(--success);color:var(--success)}.toast.error{border-color:var(--danger);color:var(--danger)}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 50%,var(--surface-2) 75%);background-size:800px 100%;animation:shimmer 1.4s infinite;border-radius:var(--radius-sm)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:3px}.role-badge{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 7px;border-radius:20px;flex-shrink:0}.role-badge--admin{background:var(--primary-light);color:var(--primary)}.role-badge--opener{background:var(--surface-3);color:var(--text-muted)}.user-avatar{width:38px;height:38px;border-radius:50%;background:var(--primary-light);color:var(--primary);font-size:.9rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border)}.user-item-info{flex:1;min-width:0}.user-item-name{font-size:.875rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-item-meta{display:flex;align-items:center;gap:6px;margin-top:3px}.user-item-username{font-size:.75rem;color:var(--text-subtle)}.user-item-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.icon-btn--danger{color:var(--danger)}.icon-btn--danger:hover{background:var(--danger-bg);color:var(--danger)}.icon-btn:disabled{opacity:.35;cursor:not-allowed}.btn-danger-sm{padding:5px 10px;font-size:.78rem;font-weight:700;background:var(--danger);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;transition:opacity var(--transition)}.btn-danger-sm:hover{opacity:.85}.password-wrap{position:relative}.password-wrap .form-input{padding-right:42px}.password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--text-subtle);display:flex;align-items:center;cursor:pointer;background:none;border:none;padding:4px;transition:color var(--transition)}.password-toggle:hover{color:var(--text)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer}.settings-section{margin-bottom:24px}.settings-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:10px}.segment-group{display:flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px;gap:3px}.segment-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:7px 10px;border-radius:calc(var(--radius-sm) - 2px);font-size:.82rem;font-weight:600;color:var(--text-muted);background:none;border:none;cursor:pointer;transition:background var(--transition),color var(--transition),box-shadow var(--transition);white-space:nowrap}.segment-btn:hover:not(.active){background:var(--surface-3);color:var(--text)}.segment-btn.active{background:var(--surface);color:var(--text);box-shadow:0 1px 4px #00000026}
