@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Manrope:wght@600;700;800&display=swap";:root{color-scheme:light;--font-ui: Inter, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;--font-display: Manrope, Inter, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;--bg: #f5f6f8;--bg-soft: #e8ebf1;--bg-card: #ffffff;--bg-card2: #fafbfc;--bg-elevated: #ffffff;--text: #0f172a;--text-secondary: #334155;--muted: #64748b;--muted-light: #94a3b8;--primary: #e30013;--primary-hover: #ff1d2d;--primary-dark: #b8000f;--primary-light: rgba(227, 0, 19, .08);--primary-medium: rgba(227, 0, 19, .12);--primary-glow: rgba(227, 0, 19, .2);--accent: #8b5cf6;--accent-light: #a78bfa;--accent-soft: rgba(139, 92, 246, .1);--accent-glow: rgba(139, 92, 246, .15);--danger: #dc2626;--danger-dark: #b91c1c;--danger-soft: rgba(220, 38, 38, .08);--danger-light: rgba(220, 38, 38, .15);--success: #10b981;--success-soft: rgba(16, 185, 129, .1);--success-glow: rgba(16, 185, 129, .18);--blue: #3b82f6;--blue-soft: rgba(59, 130, 246, .1);--blue-glow: rgba(59, 130, 246, .18);--yellow: #f59e0b;--yellow-soft: rgba(245, 158, 11, .1);--purple: #8b5cf6;--purple-light: #a78bfa;--purple-dark: #7c3aed;--purple-glow: rgba(139, 92, 246, .15);--teal: #06b6d4;--teal-soft: rgba(6, 182, 212, .1);--teal-glow: rgba(6, 182, 212, .18);--orange: #f97316;--orange-soft: rgba(249, 115, 22, .1);--border: rgba(15, 23, 42, .08);--border-light: rgba(15, 23, 42, .05);--border-medium: rgba(15, 23, 42, .12);--border-active: rgba(227, 0, 19, .3);--border-focus: rgba(227, 0, 19, .4);--shadow-xs: 0 1px 2px rgba(15, 23, 42, .04);--shadow-sm: 0 2px 8px rgba(15, 23, 42, .06);--shadow: 0 6px 20px rgba(15, 23, 42, .08);--shadow-md: 0 12px 32px rgba(15, 23, 42, .1);--shadow-lg: 0 20px 48px rgba(15, 23, 42, .12);--shadow-xl: 0 28px 64px rgba(15, 23, 42, .15);--shadow-2xl: 0 36px 80px rgba(15, 23, 42, .18);--shadow-red: 0 8px 24px rgba(227, 0, 19, .18);--shadow-red-lg: 0 14px 36px rgba(227, 0, 19, .25);--shadow-purple: 0 10px 28px rgba(139, 92, 246, .15);--shadow-blue: 0 10px 28px rgba(59, 130, 246, .15);--shadow-success: 0 10px 28px rgba(16, 185, 129, .15);--radius-2xl: 24px;--radius-xl: 20px;--radius-lg: 16px;--radius-md: 12px;--radius-sm: 10px;--radius-xs: 8px;--radius-2xs: 6px;--gradient-primary: linear-gradient(135deg, #e30013 0%, #ff4545 100%);--gradient-purple: linear-gradient(135deg, #7c3aed 0%, #a78bfa 100%);--gradient-teal: linear-gradient(135deg, #0891b2 0%, #22d3ee 100%);--gradient-blue: linear-gradient(135deg, #2563eb 0%, #60a5fa 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #34d399 100%);--gradient-bg: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);--gradient-hero: linear-gradient(180deg, #ffffff 0%, #f5f6f8 100%);--glass-bg: rgba(255, 255, 255, .85);--glass-bg-strong: rgba(255, 255, 255, .92);--glass-border: rgba(15, 23, 42, .08);--glass-shadow: 0 8px 32px rgba(15, 23, 42, .08);--transition-fast: .12s;--transition-normal: .2s;--transition-slow: .3s;--ease-out: cubic-bezier(.25, .46, .45, .94);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}body.dark-theme{color-scheme:dark;--bg: #0f172a;--bg-soft: #1e293b;--bg-card: #1e293b;--bg-card2: #162032;--bg-elevated: #243044;--text: #f1f5f9;--text-secondary: #cbd5e1;--muted: #94a3b8;--muted-light: #64748b;--primary: #ff2d3f;--primary-hover: #ff4555;--primary-dark: #e30013;--primary-light: rgba(255, 45, 63, .12);--primary-medium: rgba(255, 45, 63, .18);--primary-glow: rgba(255, 45, 63, .25);--accent: #a78bfa;--accent-light: #c4b5fd;--accent-soft: rgba(167, 139, 250, .12);--accent-glow: rgba(167, 139, 250, .18);--danger: #f87171;--danger-dark: #ef4444;--danger-soft: rgba(248, 113, 113, .1);--danger-light: rgba(248, 113, 113, .2);--success: #34d399;--success-soft: rgba(52, 211, 153, .1);--success-glow: rgba(52, 211, 153, .18);--blue: #60a5fa;--blue-soft: rgba(96, 165, 250, .1);--blue-glow: rgba(96, 165, 250, .18);--yellow: #fbbf24;--yellow-soft: rgba(251, 191, 36, .1);--purple: #a78bfa;--purple-light: #c4b5fd;--purple-dark: #8b5cf6;--purple-glow: rgba(167, 139, 250, .18);--teal: #22d3ee;--teal-soft: rgba(34, 211, 238, .1);--teal-glow: rgba(34, 211, 238, .18);--orange: #fb923c;--orange-soft: rgba(251, 146, 60, .1);--border: rgba(255, 255, 255, .08);--border-light: rgba(255, 255, 255, .05);--border-medium: rgba(255, 255, 255, .13);--border-active: rgba(255, 45, 63, .4);--border-focus: rgba(255, 45, 63, .5);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .2);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .25);--shadow: 0 6px 20px rgba(0, 0, 0, .3);--shadow-md: 0 12px 32px rgba(0, 0, 0, .35);--shadow-lg: 0 20px 48px rgba(0, 0, 0, .4);--shadow-xl: 0 28px 64px rgba(0, 0, 0, .45);--shadow-2xl: 0 36px 80px rgba(0, 0, 0, .5);--shadow-red: 0 8px 24px rgba(255, 45, 63, .25);--shadow-red-lg: 0 14px 36px rgba(255, 45, 63, .35);--gradient-bg: linear-gradient(180deg, #1e293b 0%, #0f172a 100%);--gradient-hero: linear-gradient(180deg, #1e293b 0%, #0f172a 100%);--glass-bg: rgba(30, 41, 59, .85);--glass-bg-strong: rgba(30, 41, 59, .95);--glass-border: rgba(255, 255, 255, .08);--glass-shadow: 0 8px 32px rgba(0, 0, 0, .3);--input-bg: #1e293b;--card-menu-bg: #243044}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}html,body,#app,#root{margin:0;min-height:100%;font-family:var(--font-ui);background:var(--gradient-bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:geometricPrecision;font-size:15px;line-height:1.6}*:focus-visible{outline:2px solid var(--primary);outline-offset:2px}:focus:not(:focus-visible){outline:none}a{color:inherit;text-decoration:none;transition:color var(--transition-fast) ease}button,input,textarea,select{font:inherit}::selection{background:var(--primary-light);color:var(--primary-dark)}::-moz-selection{background:var(--primary-light);color:var(--primary-dark)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#0f172a26;border-radius:999px;transition:background var(--transition-normal) ease}body.dark-theme ::-webkit-scrollbar-thumb{background:#ffffff26}::-webkit-scrollbar-thumb:hover{background:#0f172a40}body.dark-theme ::-webkit-scrollbar-thumb:hover{background:#ffffff40}::-webkit-scrollbar-corner{background:transparent}*{scrollbar-width:thin;scrollbar-color:rgba(15,23,42,.15) transparent}body.dark-theme *{scrollbar-color:rgba(255,255,255,.15) transparent}.muted,.empty-inline{color:var(--muted)}.app-shell{min-height:100vh;background:var(--gradient-bg)}.page{width:min(1440px,calc(100% - 32px));margin:0 auto;padding:20px 0 64px}.panel,.station-card,.error-box,.empty-state{border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);background:var(--bg-card);transition:all var(--transition-normal) var(--ease-out)}.panel:hover{box-shadow:var(--shadow)}.panel{padding:18px;margin-bottom:18px}.panel__header h2,.section-block__header h4{margin:0 0 16px;color:var(--text);font-family:var(--font-display);font-size:17px;font-weight:800;letter-spacing:-.2px;line-height:1.3}.error-box{padding:16px 20px;margin-bottom:18px;color:var(--danger);background:var(--danger-soft);border-color:var(--danger-light);font-size:14px;font-weight:700;display:flex;align-items:center;gap:10px}.error-box:before{content:"⚠️";font-size:18px;flex-shrink:0}.empty-state{text-align:center;padding:64px 24px;border-style:dashed;border-color:var(--border-light)}.empty-state__icon{font-size:56px;margin-bottom:16px;opacity:.2;display:block}.empty-state p{color:var(--muted);font-size:16px;margin:0;font-weight:600}.placeholder-grid,.cards-grid{display:flex;flex-direction:column;gap:14px}.skeleton-card{height:140px;border-radius:var(--radius-xl);background:linear-gradient(90deg,var(--bg-card) 0%,rgba(15,23,42,.04) 50%,var(--bg-card) 100%);background-size:200% 100%;animation:shimmer 1.5s infinite linear;border:1px solid var(--border-light)}body.dark-theme .skeleton-card{background:linear-gradient(90deg,var(--bg-card) 0%,rgba(255,255,255,.04) 50%,var(--bg-card) 100%);background-size:200% 100%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.load-more-wrap{display:flex;justify-content:center;margin-top:24px}.btn-load-more{min-width:220px;height:46px;font-size:14px}.offline-banner{padding:12px 20px;margin-bottom:14px;border-radius:var(--radius-lg);background:var(--gradient-primary);color:#fff;font-size:13px;font-weight:900;text-align:center;box-shadow:var(--shadow-red-lg);animation:pulse-offline 3s ease-in-out infinite;display:flex;align-items:center;justify-content:center;gap:8px}.offline-banner:before{content:"⚠️";font-size:16px}@keyframes pulse-offline{0%,to{opacity:1;box-shadow:var(--shadow-red-lg)}50%{opacity:.9;box-shadow:var(--shadow-red)}}.btn{height:40px;padding:0 20px;border:0;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal) var(--ease-out);font-weight:800;font-size:13px;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;letter-spacing:.03em;position:relative;overflow:hidden;gap:6px}.btn:hover{transform:translateY(-2px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{color:#fff;background:var(--gradient-primary);box-shadow:var(--shadow-red)}.btn-primary:hover{box-shadow:var(--shadow-red-lg)}.btn-secondary{color:var(--text-secondary);background:var(--bg-card);border:1.5px solid var(--border);box-shadow:var(--shadow-xs)}.btn-secondary:hover{background:#0f172a05;color:var(--text);border-color:var(--border-medium);box-shadow:var(--shadow-sm)}body.dark-theme .btn-secondary:hover{background:#ffffff0d}.btn-danger{color:#fff;background:linear-gradient(135deg,#ef4444,#b91c1c);box-shadow:0 10px 26px #ef444438}.btn-danger:hover{box-shadow:0 16px 40px #ef444447}.btn-success{color:#fff;background:var(--gradient-success);box-shadow:var(--shadow-success)}.btn-success:hover{box-shadow:0 14px 36px #10b98140}.btn-small{height:32px;padding:0 12px;font-size:12px;border-radius:var(--radius-sm)}.btn-large{height:48px;padding:0 24px;font-size:15px;border-radius:var(--radius-lg)}.btn:after{content:"";position:absolute;inset:0;background:radial-gradient(circle,rgba(255,255,255,.3) 0%,transparent 70%);opacity:0;transform:scale(0);transition:opacity .3s,transform .3s}.btn:active:after{opacity:1;transform:scale(2)}.station-card{overflow:hidden;background:var(--bg-card2);position:relative}.station-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:var(--gradient-primary);transition:width var(--transition-normal) var(--ease-out);z-index:1;border-radius:var(--radius-xl) 0 0 var(--radius-xl)}.station-card:after{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,#0f172a00,#0f172a0f 30% 70%,#0f172a00);pointer-events:none;z-index:2}body.dark-theme .station-card:after{background:linear-gradient(90deg,#fff0,#ffffff0f 30% 70%,#fff0)}.station-card:hover{border-color:var(--border-active);box-shadow:var(--shadow-md),0 0 0 1px var(--primary-light);transform:translateY(-3px)}.station-card:hover:before{width:4px}.station-card.expanded{border-color:var(--border-active);box-shadow:var(--shadow-lg),0 0 0 1px var(--primary-medium);transform:translateY(-2px)}.station-card.expanded:before{width:4px}.station-card__summary{display:flex;flex-direction:column;cursor:pointer}.station-card__summary-main{flex:1;min-width:0;display:flex;flex-direction:column}.station-card__header{display:grid;grid-template-columns:auto 1fr auto auto;grid-template-rows:auto auto;align-items:center;padding:10px 12px 8px;gap:6px 8px}.expand-toggle-bar{display:flex;justify-content:center;align-items:center;padding:6px 0 8px;cursor:pointer;opacity:.2;transition:opacity var(--transition-normal);-webkit-user-select:none;user-select:none}.expand-toggle-bar:hover{opacity:.5}.station-card.expanded .expand-toggle-bar{opacity:.3}.expand-toggle-arrow-bottom{display:inline-block;font-size:20px;color:var(--text-secondary);line-height:1;transform:rotate(90deg);transition:transform var(--transition-normal) var(--ease-spring)}.expand-toggle-arrow-bottom.rotated{transform:rotate(-90deg)}.station-badge{grid-column:1;grid-row:1;min-width:64px;padding:6px 12px;border-radius:var(--radius-md);background:var(--gradient-primary);color:#fff;font-weight:900;font-size:13px;text-align:center;letter-spacing:.04em;flex-shrink:0;box-shadow:var(--shadow-red)}.station-title{margin:0;font-family:var(--font-display);font-size:17px;font-weight:800;color:var(--text);letter-spacing:-.2px;line-height:1.3}.station-subtitle{margin:3px 0 0;color:var(--muted);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.preview-header-actions{grid-column:3 / 5;grid-row:1;display:flex;gap:6px;flex-shrink:0;margin-left:auto;align-items:center}.chip-btn{height:30px;padding:0 12px;border:none;border-radius:999px;cursor:pointer;font-size:11px;font-weight:900;white-space:nowrap;display:inline-flex;align-items:center;gap:6px;transition:all var(--transition-normal) var(--ease-out);color:#fff;line-height:1;position:relative;overflow:hidden}.chip-btn:hover{transform:translateY(-2px) scale(1.02);filter:brightness(1.08)}.chip-btn:active{transform:translateY(0) scale(.98)}.chip-btn svg{width:14px;height:14px}.chip-btn--outage{background:linear-gradient(135deg,#dc2626,#ef4444);box-shadow:var(--shadow-lg)}.chip-btn--map{background:var(--gradient-blue);box-shadow:var(--shadow-lg)}.chip-btn--weather{background:var(--gradient-teal);box-shadow:var(--shadow-lg)}.chip-btn--tech{background:var(--gradient-purple);box-shadow:var(--shadow-lg)}.bands-editor{display:flex;flex-direction:column;gap:6px}.bands-editor__row{display:flex;gap:8px;align-items:center}.bands-editor__input{flex:1}.bands-chips-view{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-top:4px}.band-chip-detail{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:#8b5cf61f;border:1.5px solid rgba(139,92,246,.25);color:var(--purple-dark);font-size:.8em;font-weight:900;white-space:nowrap;transition:all var(--transition-fast) ease}body.dark-theme .band-chip-detail{background:#8b5cf633;border-color:#8b5cf659;color:var(--purple-light)}.band-chip-detail:hover{background:#8b5cf62e;border-color:#8b5cf659;transform:translateY(-1px);box-shadow:0 2px 8px #8b5cf626}.transit-chip-detail{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:var(--primary-light);border:1.5px solid var(--primary-medium);color:var(--primary);font-size:.8em;font-weight:900;white-space:nowrap;transition:all var(--transition-fast) ease}.transit-chip-detail:hover{background:var(--primary-medium);border-color:var(--primary-glow);transform:translateY(-1px);box-shadow:0 2px 8px var(--primary-glow)}body.dark-theme .transit-chip-detail{background:#e3001326;border-color:#e300134d;color:#ff4555}.station-preview-grid{display:flex;gap:16px;padding:6px 18px 14px;align-items:flex-start}.preview-right{flex:1;display:flex;flex-direction:column;gap:8px;min-width:0}.preview-mini-fields{display:flex;gap:6px;flex-wrap:wrap}.preview-mini-field{padding:6px 10px;border-radius:var(--radius-md);background:#0f172a05;border:1.5px solid var(--border-light);font-size:12px;display:flex;flex-direction:column;gap:3px;min-width:62px;transition:all var(--transition-fast) ease}body.dark-theme .preview-mini-field{background:#ffffff08}.preview-mini-field:hover{background:#0f172a0a;border-color:var(--border)}.preview-mini-label{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:800}.preview-mini-value{font-weight:800;color:var(--text);font-size:13px}.preview-contacts{display:flex;flex-direction:column;gap:5px}.preview-contact-card{padding:6px 12px;border-radius:var(--radius-md);background:#0f172a05;border:1.5px solid var(--border-light);display:flex;flex-wrap:wrap;gap:4px 12px;align-items:center;font-size:12px}body.dark-theme .preview-contact-card{background:#ffffff08}.preview-contact-name{font-weight:900;font-size:12px;color:var(--text)}.scroll-top-btn{position:fixed;bottom:28px;right:24px;z-index:9999;width:46px;height:46px;border-radius:999px;border:none;background:var(--gradient-primary);color:#fff;font-size:20px;font-weight:900;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-red-lg);transition:all var(--transition-normal) var(--ease-out);line-height:1}.scroll-top-btn:hover{transform:translateY(-4px) scale(1.1);box-shadow:0 20px 48px #e3001366}.scroll-top-btn:active{transform:translateY(0) scale(.95)}.scroll-top-fade-enter-active,.scroll-top-fade-leave-active{transition:opacity .25s ease,transform .25s var(--ease-out)}.scroll-top-fade-enter-from,.scroll-top-fade-leave-to{opacity:0;transform:translateY(16px) scale(.85)}.network-dot{position:absolute;top:15px;right:15px;width:10px;height:10px;border-radius:999px;background:var(--success);box-shadow:0 0 0 3px var(--success-soft),0 0 10px var(--success-glow);animation:status-pulse 2s ease-in-out infinite;z-index:10;pointer-events:none}.network-dot.offline{background:var(--danger);box-shadow:0 0 0 3px var(--danger-soft),0 0 10px #dc262640;animation:none}@keyframes status-pulse{0%,to{opacity:1}50%{opacity:.7}}.hero{display:flex;gap:10px;align-items:center;justify-content:space-between;padding:16px 20px;margin-bottom:18px;border:1px solid var(--border);border-radius:var(--radius-xl);background:var(--glass-bg-strong);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow);min-height:72px;overflow:hidden;position:relative;transition:all var(--transition-normal) var(--ease-out)}.hero:hover{box-shadow:var(--shadow-md)}.hero:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--gradient-primary);box-shadow:0 0 20px #e3001340}.hero:after{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(15,23,42,.06) 30%,rgba(15,23,42,.06) 70%,transparent 100%);pointer-events:none}body.dark-theme .hero:after{background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.06) 30%,rgba(255,255,255,.06) 70%,transparent 100%)}.hero-logo{height:44px;width:auto;object-fit:contain;flex-shrink:0;display:block;border-radius:var(--radius-md);transition:transform var(--transition-normal) var(--ease-out);box-shadow:var(--shadow)}.hero-logo:hover{transform:scale(1.02)}.hero-info{flex:1;min-width:0;margin-left:12px}.eyebrow{color:var(--primary);text-transform:uppercase;letter-spacing:.18em;font-size:.6em;margin-bottom:3px;font-weight:800;display:block}.hero h1{margin:0;font-family:var(--font-display);font-size:clamp(15px,2vw,20px);font-weight:800;line-height:1.25;color:var(--text);letter-spacing:-.3px}.subtitle{margin:3px 0 0;color:var(--muted);font-size:.8em;font-weight:500}.hero-right{display:flex;align-items:center;gap:12px;flex-shrink:0;margin-right:15px}.hero-admin-btn{height:36px;padding:0 16px;font-size:.9em;font-weight:800;gap:6px;display:inline-flex;align-items:center}.hero-admin-label{display:inline}.hero-user{display:flex;align-items:center;gap:10px;padding-left:12px;border-left:1px solid var(--border-light)}.hero-user-info{display:flex;align-items:center;gap:8px}.hero-username{font-size:1em;font-weight:700;color:var(--text-secondary);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hero-role-badge--admin,.hero-role-badge--user{color:var(--primary);font-size:1em}.hero-role-badge svg{vertical-align:middle;margin-right:4px}.hero-role-badge--admin svg{color:var(--primary)}.hero-role-badge--user svg{color:var(--primary)}.hero-logout{width:auto;height:36px;padding:0 12px;gap:6px;display:inline-flex;align-items:center}@keyframes theme-icon-in{0%{opacity:0;transform:rotate(-20deg) scale(.8)}to{opacity:1;transform:rotate(0) scale(1)}}.toolbar{display:flex;gap:12px;align-items:center;justify-content:space-between;padding:14px 18px;margin-bottom:18px;border-radius:var(--radius-xl);background:var(--glass-bg-strong);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:all var(--transition-normal) var(--ease-out)}.toolbar:hover{box-shadow:var(--shadow)}.toolbar-add-btn{flex-shrink:0}.search-wrap{flex:1;min-width:0}.search-field-with-icon{flex:1;position:relative;display:flex;align-items:center;min-width:0}.search-icon{position:absolute;left:14px;width:18px;height:18px;color:var(--muted);pointer-events:none;flex-shrink:0;transition:color var(--transition-fast) ease}.search-input{width:100%;height:44px;border-radius:var(--radius-lg);border:1.5px solid var(--border);background:var(--bg-card);color:var(--text);padding:0 14px 0 44px;outline:none;transition:all var(--transition-normal) var(--ease-out);font-size:1em}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-light);transform:translateY(-1px)}.search-input:focus~.search-icon{color:var(--primary)}.search-input:hover:not(:focus){border-color:var(--border-medium)}.search-input::placeholder{color:var(--muted-light)}.search-input.has-value{padding-right:110px}.search-clear-btn{position:absolute;right:72px;width:28px;height:28px;border:1.5px solid var(--border-light);background:#0f172a08;color:var(--muted);border-radius:999px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8em;transition:all var(--transition-fast) ease;padding:0}body.dark-theme .search-clear-btn{background:#ffffff0d}.search-clear-btn:hover{background:#0f172a0f;color:var(--text);border-color:var(--border);transform:scale(1.05)}body.dark-theme .search-clear-btn:hover{background:#ffffff14}.search-clear-btn:active{transform:scale(.95)}.search-submit-btn{position:absolute;right:6px;height:34px;padding:0 14px;border:none;background:var(--gradient-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8em;font-weight:800;white-space:nowrap;transition:all var(--transition-normal) var(--ease-out);box-shadow:var(--shadow-red)}.search-submit-btn:hover{box-shadow:var(--shadow-red-lg);transform:translateY(-2px) scale(1.02)}.search-submit-btn:active{transform:translateY(0) scale(.98)}.search-submit-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.login-overlay{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gradient-hero);padding:20px;position:relative;overflow:hidden}.login-overlay:before{content:"";position:absolute;inset:-200px;background:radial-gradient(circle at 20% 20%,rgba(227,0,19,.08),transparent 45%),radial-gradient(circle at 80% 30%,rgba(139,92,246,.08),transparent 50%),radial-gradient(circle at 60% 90%,rgba(6,182,212,.06),transparent 55%);pointer-events:none;animation:subtle-pulse 8s ease-in-out infinite alternate}@keyframes subtle-pulse{0%{opacity:1}to{opacity:.7}}.login-box{background:var(--glass-bg-strong);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);padding:36px 32px;width:100%;max-width:340px;text-align:center;position:relative;z-index:1;animation:modal-scale-in .4s var(--ease-out)}.login-logo img{width:72px;height:72px;border-radius:var(--radius-lg);margin-bottom:14px;display:block;margin-left:auto;margin-right:auto;object-fit:cover;box-shadow:var(--shadow-md)}.login-title{margin:0 0 4px;font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--text);letter-spacing:-.4px;line-height:1.2}.login-subtitle{margin:0 0 24px;color:var(--muted);font-size:13px;font-weight:500;line-height:1.5}.login-form{text-align:left;display:flex;flex-direction:column;gap:16px}.login-field{display:flex;flex-direction:column;gap:6px}.login-label{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}.login-input-wrap{position:relative;display:flex;align-items:center}.login-field-icon{position:absolute;left:14px;color:var(--muted);pointer-events:none;flex-shrink:0;transition:color var(--transition-fast) ease;z-index:1}.login-input-wrap:focus-within .login-field-icon,.login-password-wrap:focus-within .login-field-icon{color:var(--primary)}.login-input{width:100%;height:46px;border:1.5px solid var(--border);border-radius:var(--radius-md);padding:0 16px 0 42px;background:var(--bg-card);color:var(--text);font-size:14px;outline:none;transition:all var(--transition-normal) var(--ease-out)}.login-input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-light);transform:translateY(-1px)}.login-input:hover:not(:focus){border-color:var(--border-medium)}.login-input::placeholder{color:var(--muted-light)}.login-password-wrap{position:relative;display:flex;align-items:center}.login-password-wrap .login-input{padding-right:48px}.login-eye-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:var(--radius-sm);background:transparent;border:none;cursor:pointer;font-size:0;color:var(--muted);transition:all var(--transition-fast) ease;display:flex;align-items:center;justify-content:center;padding:0}.login-eye-btn:hover{color:var(--primary);background:var(--primary-light);transform:translateY(-50%) scale(1.05)}.login-eye-btn:active{transform:translateY(-50%) scale(.95)}.login-error{background:var(--danger-soft);border:1.5px solid var(--danger-light);border-radius:var(--radius-md);color:var(--danger);font-size:13px;padding:10px 14px;font-weight:700;text-align:center}.login-submit{width:100%;height:48px;font-size:14px;font-weight:800;margin-top:4px;letter-spacing:.03em}.card-menu-wrapper{grid-column:5;grid-row:1;position:relative;flex-shrink:0}.card-menu-trigger{width:32px;height:32px;border:1.5px solid var(--border);border-radius:var(--radius-md);background:var(--bg-card);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all var(--transition-fast) ease;padding:0}.card-menu-trigger:hover{background:var(--primary-light);border-color:var(--primary-light);color:var(--primary);transform:rotate(90deg);box-shadow:var(--shadow-sm)}.card-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:var(--glass-bg-strong);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1.5px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:100;overflow:hidden}.card-menu-item{width:100%;padding:12px 18px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;gap:12px;font-size:13px;font-weight:700;color:var(--text-secondary);transition:all var(--transition-fast) ease;text-align:left}.card-menu-item:hover{background:#0f172a0a;color:var(--text)}body.dark-theme .card-menu-item:hover{background:#ffffff0d}.card-menu-item+.card-menu-item{border-top:1px solid var(--border-light)}.card-menu-item--danger{color:var(--danger)}.card-menu-item--danger:hover{background:var(--danger-soft);color:var(--danger)}.menu-pop-enter-active{transition:all .18s var(--ease-out)}.menu-pop-leave-active{transition:all .12s var(--ease-out)}.menu-pop-enter-from,.menu-pop-leave-to{opacity:0;transform:translateY(-8px) scale(.96)}.modal-overlay{position:fixed;inset:0;z-index:100000;background:#0f172a99;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;padding:24px;animation:modal-fade-in .2s var(--ease-out)}body.dark-theme .modal-overlay{background:#000000b3}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal-box{background:var(--glass-bg-strong);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1.5px solid var(--border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-2xl);max-width:480px;width:100%;overflow:hidden;display:flex;flex-direction:column;max-height:92vh;position:relative}.modal-box--tech{max-width:640px}.modal-box--archive{max-width:600px}.modal-box--admin{max-width:640px}.modal-box--outage{max-width:580px}.modal-header{display:flex;align-items:center;gap:12px;padding:12px;border-bottom:1.5px solid var(--border-light);box-shadow:0 1px 2px #0000000d,0 4px 8px #0000000f,0 8px 16px #0000000a;flex-shrink:0;background:#0f172a05;margin-bottom:10px}body.dark-theme .modal-header{background:#ffffff05}.modal-icon{font-size:24px;flex-shrink:0}.modal-icon svg{height:100%}.modal-icon:hover svg{transform:rotate(25deg)}.modal-title{margin:0;font-family:var(--font-display);font-size:18px;font-weight:900;color:var(--text);flex:1;letter-spacing:-.2px;line-height:1.3}.modal-close-btn{width:32px;height:32px;border:1.5px solid var(--border-light);background:#0f172a08;border-radius:999px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--muted);transition:all var(--transition-fast) ease;padding:0}body.dark-theme .modal-close-btn{background:#ffffff0d}.modal-close-btn:hover{background:var(--danger-soft);color:var(--danger);border-color:var(--danger-light);transform:rotate(90deg)}.modal-body{padding:20px 24px;font-size:14px;color:var(--text-secondary);line-height:1.7;white-space:pre-wrap;word-break:break-word}.modal-body--scrollable{overflow-y:auto;max-height:65vh;-webkit-overflow-scrolling:touch}.modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:12px;flex-shrink:0;border-top:1.5px solid var(--border-light);background:#0f172a05;box-shadow:0 -1px 2px #0000000d,0 -4px 8px #0000000f,0 -8px 16px #0000000a;margin-top:10px}body.dark-theme .modal-footer{background:#ffffff05}.modal-fade-leave-active{animation:modal-fade-out .15s var(--ease-out)}@keyframes modal-fade-out{0%{opacity:1}to{opacity:0}}.modal-fade-enter-active .modal-box{animation:modal-scale-in .25s var(--ease-out)}@keyframes modal-scale-in{0%{transform:scale(.94) translateY(12px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.preview-outages{display:flex;flex-direction:column;gap:5px}.preview-outage-item{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:var(--radius-md);background:var(--danger-soft);border:1.5px solid var(--danger-light);font-size:12px;color:var(--danger);font-weight:700}.preview-outage-icon{font-size:13px;flex-shrink:0}.preview-outage-icon svg{display:flex;flex-wrap:nowrap}.preview-outage-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-outage-date{color:var(--muted);font-size:11px;flex-shrink:0}.outage-card{padding:12px 14px;border-radius:var(--radius-md);background:var(--danger-soft);border:1.5px solid var(--danger-light);display:flex;align-items:flex-start;gap:10px;margin-bottom:8px}.outage-card__body{display:flex;min-width:0}.outage-card__comment{display:flex;font-size:14px;color:var(--text);word-break:break-word;font-weight:800;line-height:1.5;justify-content:space-between}.outage-card__meta{display:inline-flex;font-size:12px;color:var(--muted);margin-top:4px;font-weight:600;justify-content:space-between}.outage-form{display:flex;gap:10px;margin-top:12px}.outage-form input{flex:1;height:40px;border:1.5px solid var(--border);border-radius:var(--radius-md);padding:0 14px;background:var(--bg-card);color:var(--text);font-size:14px;outline:none;transition:all var(--transition-normal) var(--ease-out)}.outage-form input::placeholder{color:var(--muted-light)}.outage-form input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-light)}.outage-form input:hover:not(:focus){border-color:var(--border-medium)}.archive-list{display:flex;flex-direction:column;gap:8px}.outage-card--archive{background:var(--yellow-soft)!important;border-color:var(--orange-soft)!important}.outage-card--archive .outage-card__comment{color:var(--text-secondary)!important}.outage-modal-tabs{display:flex;gap:0;border-bottom:1.5px solid var(--border-light);background:#0f172a05;flex-shrink:0}body.dark-theme .outage-modal-tabs{background:#ffffff05}.outage-tab{flex:1;height:44px;border:none;background:transparent;cursor:pointer;font-size:12px;font-weight:800;color:var(--muted);transition:all var(--transition-fast) ease;border-bottom:2.5px solid transparent;margin-bottom:-1.5px;letter-spacing:.02em;display:flex;align-items:center;justify-content:center;gap:6px}.outage-tab svg{flex-shrink:0;opacity:.7}.outage-tab.active svg{opacity:1}.outage-tab:hover{color:var(--text);background:#0f172a08}body.dark-theme .outage-tab:hover{background:#ffffff0a}.outage-tab.active{color:var(--primary);border-bottom-color:var(--primary);background:var(--primary-light)}.outage-modal-section-label{font-size:11px;font-weight:900;color:var(--muted);text-transform:uppercase;letter-spacing:.09em;margin-bottom:8px;margin-top:4px}.outage-current-list{margin-bottom:16px}.outage-today-bs{font-size:12px;font-weight:900;color:var(--primary);margin-bottom:3px;letter-spacing:.03em;display:flex;align-items:center}.outage-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px;color:var(--muted);font-size:14px;font-weight:600;text-align:center;gap:4px}.outage-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:32px;color:var(--muted);font-size:14px;font-weight:600}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin .9s linear infinite}.outage-modal-item{display:flex;align-items:center;gap:10px;margin-bottom:8px}.outage-modal-row{flex:1;min-width:0;padding:10px 14px;border-radius:var(--radius-md);background:var(--danger-soft);border:1.5px solid var(--danger-light)}.outage-modal-row--archive{background:var(--yellow-soft);border-color:var(--orange-soft)}.outage-modal-row--today{background:var(--danger-soft);border-color:var(--danger-light)}.outage-delete-btn{flex-shrink:0;width:32px;height:32px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast) ease;padding:0}.outage-delete-btn:hover{background:var(--danger);color:#fff;border-color:var(--danger);transform:scale(1.08)}.outage-delete-btn:active{transform:scale(.95)}.photo-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.photo-gallery__item{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-soft);cursor:zoom-in;aspect-ratio:4 / 3;border:1.5px solid var(--border-light);transition:all var(--transition-normal) var(--ease-out)}.photo-gallery__item:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px) scale(1.02);border-color:var(--border)}.photo-gallery__item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform var(--transition-slow) var(--ease-out)}.photo-gallery__item:hover img{transform:scale(1.08)}.photo-gallery__delete{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:999px;background:#e30013e6;color:#fff;border:0;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;opacity:0;transition:all var(--transition-normal) ease;box-shadow:var(--shadow-red)}.photo-gallery__delete:hover{background:var(--danger);transform:scale(1.1)}.photo-gallery__item:hover .photo-gallery__delete{opacity:1}.upload-zone{margin-top:14px}.upload-label{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:10px 20px;border-radius:var(--radius-lg);background:var(--primary-light);border:2px dashed var(--primary-medium);color:var(--primary);cursor:pointer;font-weight:900;font-size:13px;transition:all var(--transition-normal) var(--ease-out);gap:8px}.upload-label:hover{background:var(--primary-medium);box-shadow:0 0 0 4px var(--primary-light);transform:translateY(-2px)}.upload-label svg{transition:transform var(--transition-normal) ease}.upload-label:hover svg{transform:scale(1.1)}.upload-label input{display:none}.upload-hint{display:block;margin-top:6px;font-size:12px;color:var(--muted);font-weight:600}.photo-empty{color:var(--muted);padding:24px;border-radius:var(--radius-lg);background:#0f172a05;border:2px dashed var(--border);text-align:center;font-size:14px;font-weight:600}body.dark-theme .photo-empty{background:#ffffff08}.photo-carousel{display:flex;flex-direction:column;gap:8px}.photo-main{position:relative;overflow:hidden;border-radius:var(--radius-xl);background:var(--bg-soft);min-height:130px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--border-light);box-shadow:inset 0 2px 8px #00000008}.photo-main__image{width:100%;max-height:260px;object-fit:cover;cursor:zoom-in;display:block;transition:transform var(--transition-slow) var(--ease-out)}.photo-main__image:hover{transform:scale(1.02)}.carousel-nav,.lightbox-nav,.lightbox-close{border:0;cursor:pointer}.carousel-nav{position:absolute;top:50%;transform:translateY(-50%);width:34px;height:34px;border-radius:999px;background:#0f172abf;color:#fff;font-size:18px;box-shadow:var(--shadow);transition:all var(--transition-normal) var(--ease-out);display:flex;align-items:center;justify-content:center}body.dark-theme .carousel-nav{background:#000000bf}.carousel-nav:hover{background:var(--primary);box-shadow:var(--shadow-red-lg);transform:translateY(-50%) scale(1.1)}.carousel-nav:active{transform:translateY(-50%) scale(.95)}.carousel-nav.left{left:10px}.carousel-nav.right{right:10px}.photo-thumbs{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px}.photo-thumb{padding:0;border:2.5px solid transparent;border-radius:var(--radius-sm);overflow:hidden;background:transparent;cursor:pointer;flex:0 0 56px;transition:all var(--transition-fast) ease}.photo-thumb.active{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.photo-thumb img{width:56px;height:44px;object-fit:cover;display:block}.photo-counter{color:var(--muted);font-size:12px;font-weight:600}.photo-toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}.lightbox{position:fixed;inset:0;z-index:99999;background:#000000f0;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:flex;align-items:center;justify-content:center;padding:32px;animation:lightbox-fade-in .3s var(--ease-out)}@keyframes lightbox-fade-in{0%{opacity:0}to{opacity:1}}.lightbox-image{max-width:min(92vw,1300px);max-height:88vh;border-radius:var(--radius-xl);object-fit:contain;cursor:zoom-out;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;box-shadow:0 40px 100px #000c;animation:lightbox-scale-in .4s var(--ease-out)}@keyframes lightbox-scale-in{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.lightbox-close{position:absolute;top:20px;right:20px;width:44px;height:44px;border-radius:999px;background:#ffffff26;color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-normal) ease;border:1.5px solid rgba(255,255,255,.2)}.lightbox-close:hover{background:var(--primary);border-color:var(--primary);transform:rotate(90deg)}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:999px;background:#ffffff1f;color:#fff;font-size:24px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-normal) var(--ease-out);border:1.5px solid rgba(255,255,255,.15)}.lightbox-nav:hover{background:var(--primary);box-shadow:var(--shadow-red-lg);transform:translateY(-50%) scale(1.1);border-color:var(--primary)}.lightbox-nav:active{transform:translateY(-50%) scale(.95)}.lightbox-nav.left{left:24px}.lightbox-nav.right{right:24px}.lightbox-caption{position:absolute;bottom:24px;color:#ffffffb3;font-size:14px;font-weight:600;text-align:center;max-width:80%;padding:10px 20px;background:#00000080;border-radius:999px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.station-card__details{padding:16px 18px 18px;border-top:1.5px solid var(--border-light)}.details-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:16px}.detail-box{padding:12px 14px;border-radius:var(--radius-md);background:var(--bg-card);border:1.5px solid var(--border-light);transition:all var(--transition-normal) ease}.detail-box:hover{border-color:var(--border);background:#0f172a05;transform:translateY(-1px);box-shadow:var(--shadow-xs)}body.dark-theme .detail-box:hover{background:#ffffff08}.detail-box--full{grid-column:1 / -1}.detail-label{display:block;color:var(--muted);font-size:10px;margin-bottom:5px;text-transform:uppercase;letter-spacing:.09em;font-weight:800}.detail-value{white-space:pre-wrap;word-break:break-word;font-size:14px;color:var(--text);font-weight:600;line-height:1.5}.contacts-compact{display:flex;flex-direction:column;gap:8px;margin-top:6px}.compact-contact{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius-md);background:var(--bg-card);border:1.5px solid var(--border-light);flex-wrap:wrap;transition:all var(--transition-normal) ease}.compact-contact:hover{border-color:var(--border);background:#0f172a05;box-shadow:var(--shadow-xs)}body.dark-theme .compact-contact:hover{background:#ffffff08}.compact-contact__main{display:flex;align-items:center;gap:10px;flex-shrink:0}.compact-contact__name{font-size:14px;font-weight:900;color:var(--text)}.compact-contact__role{font-size:11px;color:var(--muted);background:#0f172a08;border:1.5px solid var(--border-light);border-radius:999px;padding:3px 10px;font-weight:700}body.dark-theme .compact-contact__role{background:#ffffff0d}.compact-contact__links{display:flex;gap:10px;flex-wrap:wrap}.contact-link{color:var(--primary);font-size:13px;width:fit-content;transition:color var(--transition-fast) ease;font-weight:800;display:flex;align-items:center;gap:4px}.contact-link:hover{color:var(--primary-hover);text-decoration:underline}.section-block{margin-top:14px;padding:14px 16px;border-radius:var(--radius-xl);background:#0f172a05;border:1.5px solid var(--border-light);box-shadow:var(--shadow-xs)}body.dark-theme .section-block{background:#ffffff08}.section-block__header h4{margin:0 0 12px;font-size:15px;display:flex;align-items:center;gap:8px;font-weight:900;color:var(--text);font-family:var(--font-display)}.station-form{width:100%}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.field{display:flex;flex-direction:column;gap:6px}.field--full{grid-column:1 / -1}.field__label{color:var(--muted);font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.09em}.field input,.field textarea,.field select{width:100%;border:1.5px solid var(--border);border-radius:var(--radius-md);padding:12px 14px;background:var(--bg-card);color:var(--text);outline:none;transition:all var(--transition-normal) var(--ease-out);font-size:14px}.field input::placeholder,.field textarea::placeholder{color:var(--muted-light)}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-light);background:var(--bg-card)}.field input:hover:not(:focus),.field textarea:hover:not(:focus),.field select:hover:not(:focus){border-color:var(--border-medium);background:var(--bg-card2)}.field textarea{resize:vertical;min-height:72px;line-height:1.6}.field select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748B' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}.form-actions,.action-row,.contact-edit-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}.contacts-editor__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.contact-edit-card{padding:14px;background:var(--bg-card);border:1.5px solid var(--border-light);border-radius:var(--radius-lg);margin-bottom:10px}.contact-edit-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.inline-edit-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;margin-bottom:16px;border-radius:var(--radius-md);background:var(--primary-light);border:1.5px solid var(--primary-medium);font-size:13px;font-weight:800;color:var(--primary)}.inline-edit-banner__icon{font-size:18px;flex-shrink:0}.inline-edit-input{width:100%;height:38px;border:1.5px solid var(--border);border-radius:var(--radius-md);padding:0 12px;background:var(--bg-card);color:var(--text);font-size:14px;outline:none;transition:all var(--transition-normal) var(--ease-out)}.inline-edit-input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-light)}.inline-edit-input:hover:not(:focus){border-color:var(--border-medium)}.inline-edit-input::placeholder{color:var(--muted-light)}textarea.inline-edit-input{height:auto;min-height:56px;padding:10px 12px;resize:vertical}.inline-edit-select{width:100%;height:38px;border:1.5px solid var(--border);border-radius:var(--radius-md);padding:0 12px;background:var(--bg-card);color:var(--text);font-size:14px;outline:none;transition:all var(--transition-normal) var(--ease-out);cursor:pointer}.inline-edit-select:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-light)}.inline-edit-select:hover:not(:focus){border-color:var(--border-medium)}.contacts-edit-inline{display:flex;flex-direction:column;gap:10px}.contact-edit-inline-card{display:flex;gap:10px;align-items:flex-start;padding:12px;background:var(--bg-card);border:1.5px solid var(--border-light);border-radius:var(--radius-md)}.contact-edit-inline-grid{flex:1;display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.inline-edit-field{display:inline-flex;align-items:center}.inline-edit-field__editing{display:flex;align-items:center;gap:6px}.inline-edit-field__input{height:30px;border:1.5px solid var(--primary-medium);border-radius:var(--radius-sm);padding:0 10px;background:var(--bg-card);color:var(--text);font-size:14px;outline:none;min-width:130px;box-shadow:0 0 0 4px var(--primary-light)}.inline-edit-field__btn{width:28px;height:28px;border:none;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all var(--transition-fast) ease}.inline-edit-field__btn--save{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-red)}.inline-edit-field__btn--save:hover{transform:scale(1.05)}.inline-edit-field__btn--cancel{background:#0f172a0a;color:var(--muted);border:1.5px solid var(--border-light)}body.dark-theme .inline-edit-field__btn--cancel{background:#ffffff0d}.inline-edit-field__btn--cancel:hover{background:var(--danger-soft);color:var(--danger)}.inline-edit-field__display{cursor:pointer;display:inline-flex;align-items:center;gap:6px;color:var(--text);transition:all var(--transition-fast) ease}.inline-edit-field__display:hover{color:var(--primary)}.admin-body{display:flex;flex-direction:column;gap:16px;max-height:68vh;overflow-y:auto;padding:0 24px}.admin-users-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.admin-user-card{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-lg);background:var(--bg-card);border:1.5px solid var(--border-light);transition:all var(--transition-normal) ease}.admin-user-card:hover{border-color:var(--border);background:#0f172a05;box-shadow:var(--shadow-sm);transform:translate(2px)}body.dark-theme .admin-user-card:hover{background:#ffffff08}.admin-user-card--editing{border-color:var(--border-active)!important;background:var(--primary-light);flex-direction:column;align-items:stretch;box-shadow:0 0 0 4px var(--primary-light)!important}.admin-user-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.admin-user-name{font-weight:900;font-size:15px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-role-badge{display:flex;font-size:12px;padding:4px 12px;border-radius:999px;font-weight:900;white-space:nowrap;align-items:center}.admin-role-badge--admin{background:var(--primary-light);color:var(--primary);border:1.5px solid var(--primary-medium)}.admin-role-badge--admin svg{margin-right:3px}.admin-role-badge--user{background:#0f172a0a;color:var(--muted);border:1.5px solid var(--border-light)}body.dark-theme .admin-role-badge--user{background:#ffffff0d}.admin-user-actions{display:flex;gap:6px;flex-shrink:0}.admin-edit-form{display:flex;flex-direction:column;gap:10px;width:100%}.admin-edit-row{display:grid;grid-template-columns:90px 1fr;align-items:center;gap:10px}.admin-edit-label{font-size:11px;font-weight:900;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.admin-edit-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:6px}.admin-create-section{border-top:1.5px solid var(--border-light);padding-top:16px}.admin-create-form{display:flex;flex-direction:column;gap:10px;padding:16px;background:var(--bg-card);border-radius:var(--radius-lg);border:1.5px solid var(--border-light)}.tech-card-view{display:flex;flex-direction:column;gap:8px}.tech-card-section{padding:5px 10px;border-radius:var(--radius-lg);background:var(--bg-card);border:1.5px solid var(--border-light)}.tech-card-section-label{font-size:.8em;text-transform:uppercase;letter-spacing:.09em;font-weight:900;color:var(--muted);margin-bottom:5px}.tech-card-values{display:flex;flex-direction:column;gap:6px}.tech-card-value-chip{padding:8px 14px;background:#0f172a05;border:1.5px solid var(--border-light);border-radius:var(--radius-md);font-size:14px;color:var(--text);font-weight:600}body.dark-theme .tech-card-value-chip{background:#ffffff08}.tech-card-edit{display:flex;flex-direction:column;gap:14px}.tech-card-edit-section{display:flex;flex-direction:column;gap:8px}.tech-card-edit-label{font-size:11px;text-transform:uppercase;letter-spacing:.09em;font-weight:900;color:var(--muted)}.tech-card-edit-values{display:flex;flex-direction:column;gap:6px}.tech-card-edit-row{display:flex;gap:8px;align-items:center}.tech-card-edit-input{flex:1;min-width:0;height:40px;border:1.5px solid var(--border);border-radius:var(--radius-md);padding:0 14px;background:var(--bg-card);color:var(--text);font-size:14px;outline:none;transition:all var(--transition-normal) var(--ease-out)}.tech-card-edit-input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-light)}.tech-card-edit-input:hover:not(:focus){border-color:var(--border-medium)}.preview-autolock-row{grid-column:1 / -1;grid-row:4;display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:center;padding:0;background:transparent;border:none;box-shadow:none}.preview-autolock-chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:#3b82f61f;border:1.5px solid rgba(59,130,246,.25);color:var(--blue);font-size:11px;font-weight:900;white-space:nowrap;transition:all var(--transition-fast) ease}.preview-autolock-chip:hover{background:#3b82f633;box-shadow:0 2px 8px #3b82f626}body.dark-theme .preview-autolock-chip{background:#3b82f626;border-color:#3b82f64d;color:#60a5fa}.autolock-chip-detail{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:#3b82f61f;border:1.5px solid rgba(59,130,246,.25);color:var(--blue);font-size:.8em;font-weight:900;white-space:nowrap;transition:all var(--transition-fast) ease}.autolock-chip-detail:hover{background:#3b82f62e;border-color:#3b82f659;transform:translateY(-1px);box-shadow:0 2px 8px #3b82f626}body.dark-theme .autolock-chip-detail{background:#3b82f626;border-color:#3b82f64d;color:#60a5fa}.fade-slide-enter-active,.fade-slide-leave-active{transition:all .3s var(--ease-out)}.fade-slide-enter-from,.fade-slide-leave-to{opacity:0;transform:translateY(-12px)}.list-enter-active{transition:all .3s var(--ease-out)}.list-enter-from{opacity:0;transform:translateY(10px)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}@media(max-width:1024px){.toolbar{flex-direction:column;align-items:stretch}.station-preview-grid{flex-direction:column}.details-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid,.contact-edit-grid,.contact-edit-inline-grid{grid-template-columns:1fr}.photo-gallery{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.page{width:calc(100% - 20px);padding-top:12px}.station-card__header{padding:12px 14px 8px}.preview-header-actions{flex-wrap:wrap}.hero-admin-label{display:none}.admin-edit-row{grid-template-columns:1fr}.modal-box--tech,.modal-box--archive,.modal-box--admin{max-width:90vw}}@media(max-width:800px){html,body,#app,#root{font-size:15px}.page{width:calc(100% - 12px);padding:10px 0 56px}.hero{padding:0 10px;min-height:64px;flex-wrap:wrap;display:flex;justify-content:space-between;gap:5px}.eyebrow,.subtitle{display:none}.hero-right{display:flex;justify-content:center;align-items:center;margin-right:10px;gap:5px}.hero:before,.station-card:before,.station-card:hover:before,.station-card.expanded:before{display:none}.hero-logo{height:38px}.hero-info{margin-left:8px}.hero h1{font-size:.9em}.hero-admin-label{display:none}.hero-username{max-width:80px;font-size:.9em;margin-left:4px}.hero-user{order:3;border-left:none;padding-left:0}.hero-logout{width:30px;height:30px}.toolbar{padding:12px;flex-direction:column;align-items:stretch}.toolbar-add-btn{display:none}.search-input{height:46px;font-size:15px;padding:0 14px 0 42px}.search-input.has-value{padding-right:105px}.search-clear-btn{right:70px;width:26px;height:26px}.search-submit-btn{height:36px;font-size:12px;padding:0 12px}.station-card__header{display:grid;grid-template-columns:auto 1fr auto auto;grid-template-rows:auto auto;align-items:center;padding:10px 12px 8px;gap:6px 8px}.station-badge{grid-column:1;grid-row:1;min-width:48px;font-size:11px;padding:4px 8px}.station-title-block{grid-column:2;grid-row:1;min-width:0;overflow:hidden}.station-title{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.station-subtitle{font-size:11px}.station-preview-grid{flex-direction:column;padding:6px 14px 12px;gap:10px}.preview-mini-fields{gap:5px}.preview-mini-field{padding:5px 8px;min-width:54px}.preview-mini-label{font-size:8px}.preview-mini-value{font-size:12px}.preview-header-actions{grid-column:3 / 5;grid-row:1;display:flex;gap:4px;align-items:center;margin-left:0;flex-wrap:nowrap}.chip-btn{width:30px;height:30px;padding:0;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:0;gap:0}.chip-btn svg{width:14px;height:14px;flex-shrink:0}.chip-btn__label{display:none}.card-menu-wrapper{grid-column:5;grid-row:1}.card-menu-trigger{width:28px;height:28px}.station-card__details{padding:12px 14px 14px;font-size:13px}.station-card__details .detail-label{font-size:9px;margin-bottom:4px}.station-card__details .detail-value{font-size:13px;line-height:1.45}.station-card__details .section-block__header h4{font-size:14px}.station-card__details .band-chip-detail{font-size:10px;padding:3px 8px}.station-card__details .outage-card__comment{font-size:13px}.station-card__details .outage-card__meta{font-size:11px}.details-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.detail-box{padding:10px 12px}.section-block{padding:12px}.form-grid{grid-template-columns:1fr;gap:10px}.contact-edit-grid,.contact-edit-inline-grid{grid-template-columns:1fr}.photo-gallery{grid-template-columns:repeat(auto-fill,minmax(95px,1fr));gap:6px}.outage-form{flex-direction:column}.outage-form input{width:100%}.outage-tab{font-size:11px;height:40px}.lightbox-nav{display:none}.lightbox{padding:16px;background:#000000f5}.lightbox-image{max-width:96vw;max-height:82vh}.lightbox-close{top:12px;right:12px;width:40px;height:40px}.panel{padding:14px}.btn{height:38px;padding:0 14px;font-size:.8em}.btn-small{height:30px;padding:10px;font-size:14px}.btn-small svg{width:18px;height:18px;flex-shrink:0}.btn-load-more{min-width:170px;height:44px}.modal-box--tech,.modal-box--archive,.modal-box--admin{max-width:96vw;max-height:95vh}.modal-header,.modal-body,.modal-footer{padding-left:18px;padding-right:18px}.admin-edit-row{grid-template-columns:1fr}.compact-contact{flex-direction:column;align-items:flex-start;gap:6px}.login-box{padding:28px 20px;max-width:100%;margin:0}.login-title{font-size:20px}.preview-bands-row{grid-column:1 / -1;grid-row:2;padding:2px 0 4px;gap:4px;flex-wrap:wrap}.preview-band-chip{font-size:10px;padding:3px 8px}.expand-toggle-bar{padding:4px 0 5px}.outage-card{flex-direction:column;align-items:flex-start}.preview-outage-item{display:flex;flex-direction:row;align-items:center;gap:8px;padding:6px 12px;border-radius:var(--radius-md);background:var(--danger-soft);border:1.5px solid var(--danger-light);font-size:12px;color:var(--danger);font-weight:700}.hero-user-info{display:flex;align-items:center;gap:4px}.scroll-top-btn{bottom:20px;right:16px;width:40px;height:40px;font-size:17px}.network-dot{position:absolute;top:10px;right:10px;width:8px;height:8px}.hero-role-badge svg{margin:0}}@media print{.hero,.toolbar,.card-menu-wrapper,.expand-toggle-bar,.btn,.search-submit-btn{display:none}.station-card{break-inside:avoid;box-shadow:none;border:1px solid #ccc}body{background:#fff;color:#000}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.m-0{margin:0}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:4px}.gap-2{gap:8px}.w-full{width:100%}.h-full{height:100%}.hidden{display:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
