:root{--bg-0: #030A16;--bg-1: #091526;--bg-2: #0D1F35;--bg-card: #0F2038;--bg-card-h: #132744;--bg-input: #0A1A2E;--border: #1A3050;--border-l: #1E3A5F;--primary: #4CAF50;--primary-d: #388E3C;--primary-l: #66BB6A;--accent: #FF6B35;--accent-d: #E55A2B;--info: #3B82F6;--info-d: #2563EB;--cyan: #4CAF50;--cyan-d: #388E3C;--green: #4CAF50;--green-d: #388E3C;--amber: #FF6B35;--amber-d: #E55A2B;--red: #FF4D6A;--red-d: #CC2244;--purple: #3B82F6;--text-1: #E8F4FF;--text-2: #8BA8C8;--text-3: #4A6480;--font-head: "Plus Jakarta Sans", sans-serif;--font-body: "Inter", sans-serif;--font-mono: "Fira Code", monospace;--radius: 12px;--radius-sm: 8px;--transition: .2s ease;--shadow: 0 2px 8px rgba(0,0,0,.3)}[data-theme=light]{--bg-0: #F0F4F8;--bg-1: #E2E8F0;--bg-2: #EDF2F7;--bg-card: #FFFFFF;--bg-card-h: #F7FAFC;--bg-input: #EDF2F7;--border: #CBD5E0;--border-l: #A0AEC0;--primary: #43A047;--primary-d: #2E7D32;--primary-l: #66BB6A;--accent: #F4511E;--accent-d: #D84315;--info: #2563EB;--info-d: #1D4ED8;--cyan: #43A047;--cyan-d: #2E7D32;--green: #43A047;--green-d: #2E7D32;--amber: #F4511E;--amber-d: #D84315;--red: #DC2626;--red-d: #B91C1C;--purple: #2563EB;--text-1: #1A202C;--text-2: #4A5568;--text-3: #718096;--shadow: 0 2px 8px rgba(0,0,0,.08)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg-0);color:var(--text-1);min-height:100vh;overflow-x:hidden}.app-shell{display:flex;min-height:100vh}.main-content{flex:1;margin-left:240px;height:100vh;display:flex;flex-direction:column;overflow:hidden}.page-body{flex:1;padding:24px 28px;overflow-y:auto;overflow-x:hidden}.sidebar{width:240px;height:100vh;position:fixed;left:0;top:0;background:var(--bg-1);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100}.sidebar-logo{padding:20px 20px 16px;border-bottom:1px solid var(--border)}.logo-mark{display:flex;align-items:center;gap:10px}.logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--primary),var(--primary-d));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}.logo-text{font-family:var(--font-head);font-weight:800;font-size:1.1rem;color:var(--text-1);line-height:1}.logo-sub{font-size:.7rem;color:var(--text-3);font-weight:400;margin-top:2px}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:2px}.nav-section-label{font-size:.65rem;font-weight:600;letter-spacing:.1em;color:var(--text-3);text-transform:uppercase;padding:12px 8px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);color:var(--text-2);text-decoration:none;font-weight:500;font-size:.88rem;transition:var(--transition);cursor:pointer;border:1px solid transparent}.nav-item:hover{background:var(--bg-2);color:var(--text-1);border-color:var(--border)}.nav-item.active{background:linear-gradient(135deg,#00d4ff1f,#00e5a014);color:var(--cyan);border-color:#00d4ff40}.nav-item.active .nav-dot{background:var(--cyan)}.nav-dot{width:5px;height:5px;border-radius:50%;background:transparent;margin-left:auto;transition:var(--transition)}.sidebar-footer{padding:16px 12px;border-top:1px solid var(--border)}.sidebar-badge{background:linear-gradient(135deg,#00d4ff1a,#00e5a01a);border:1px solid rgba(0,212,255,.2);border-radius:var(--radius-sm);padding:10px 12px}.badge-title{font-family:var(--font-head);font-size:.75rem;color:var(--cyan);font-weight:700}.badge-sub{font-size:.68rem;color:var(--text-3);margin-top:2px}.badge-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--green);margin-right:5px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.topbar{height:60px;border-bottom:1px solid var(--border);padding:0 28px;display:flex;align-items:center;justify-content:space-between;background:var(--bg-1);position:sticky;top:0;z-index:50}.topbar-left h1{font-family:var(--font-head);font-size:1.05rem;font-weight:700;color:var(--text-1)}.topbar-left p{font-size:.72rem;color:var(--text-3);margin-top:1px}.topbar-right{display:flex;align-items:center;gap:12px}.date-filter{display:flex;align-items:center;gap:4px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px}.date-btn{padding:5px 12px;border-radius:5px;border:none;background:transparent;color:var(--text-2);font-family:var(--font-body);font-size:.78rem;font-weight:500;cursor:pointer;transition:var(--transition)}.date-btn:hover{color:var(--text-1);background:var(--border)}.date-btn.active{background:linear-gradient(135deg,var(--cyan-d),var(--cyan));color:#000;font-weight:700}.custom-date-wrapper{position:relative}.custom-date-popup{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-card);border:1px solid var(--border-l);border-radius:var(--radius);padding:20px;z-index:200;box-shadow:0 20px 60px #0009;width:320px}.custom-date-popup h4{font-family:var(--font-head);font-size:.85rem;margin-bottom:14px;color:var(--text-1)}.date-inputs{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}.date-input-group label{display:block;font-size:.68rem;color:var(--text-3);margin-bottom:5px;text-transform:uppercase;letter-spacing:.05em}.date-input-group input{width:100%;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 10px;color:var(--text-1);font-family:var(--font-mono);font-size:.8rem;outline:none;transition:var(--transition)}.date-input-group input:focus{border-color:var(--cyan)}.apply-btn{width:100%;padding:9px;background:linear-gradient(135deg,var(--cyan-d),var(--cyan));border:none;border-radius:var(--radius-sm);color:#000;font-weight:700;font-size:.82rem;cursor:pointer;transition:var(--transition)}.apply-btn:hover{opacity:.85}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;position:relative;overflow:hidden;transition:var(--transition)}.kpi-card:hover{border-color:var(--border-l);transform:translateY(-2px);box-shadow:0 8px 32px #0000004d}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;border-radius:var(--radius) var(--radius) 0 0}.kpi-card.cyan:before{background:linear-gradient(90deg,var(--cyan),transparent)}.kpi-card.green:before{background:linear-gradient(90deg,var(--green),transparent)}.kpi-card.amber:before{background:linear-gradient(90deg,var(--amber),transparent)}.kpi-card.red:before{background:linear-gradient(90deg,var(--red),transparent)}.kpi-card.purple:before{background:linear-gradient(90deg,var(--purple),transparent)}.kpi-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}.kpi-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}.kpi-icon.cyan{background:#00d4ff1f}.kpi-icon.green{background:#00e5a01f}.kpi-icon.amber{background:#ffb0201f}.kpi-icon.red{background:#ff4d6a1f}.kpi-icon.purple{background:#a855f71f}.kpi-badge{display:flex;align-items:center;gap:3px;font-size:.7rem;font-weight:600;padding:3px 7px;border-radius:20px}.kpi-badge.up{background:#00e5a01f;color:var(--green)}.kpi-badge.down{background:#ff4d6a1f;color:var(--red)}.kpi-value{font-family:var(--font-head);font-size:1.7rem;font-weight:800;color:var(--text-1);line-height:1;margin-bottom:6px}.kpi-label{font-size:.75rem;color:var(--text-2);font-weight:400}.kpi-sub{font-size:.68rem;color:var(--text-3);margin-top:4px}.charts-row{display:grid;gap:16px;margin-bottom:24px}.charts-row.col-2{grid-template-columns:1fr 1fr}.charts-row.col-3{grid-template-columns:2fr 1fr}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.chart-title{font-family:var(--font-head);font-size:.9rem;font-weight:700;color:var(--text-1)}.chart-sub{font-size:.68rem;color:var(--text-3);margin-top:3px}.chart-legend{display:flex;gap:14px}.legend-item{display:flex;align-items:center;gap:5px;font-size:.7rem;color:var(--text-2)}.legend-dot{width:8px;height:8px;border-radius:50%}.markets-section{margin-bottom:24px}.markets-toolbar{display:flex;align-items:center;gap:16px;margin-bottom:16px}.markets-toolbar-left,.markets-toolbar-right{flex-shrink:0}.chorva-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 18px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-family:var(--font-head);font-size:.82rem;font-weight:700;border-radius:20px;text-decoration:none;white-space:nowrap;transition:var(--transition);box-shadow:0 4px 14px #10b98159}.chorva-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98180}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-title{font-family:var(--font-head);font-size:1rem;font-weight:700}.section-sub{font-size:.72rem;color:var(--text-3);margin-top:2px}.filter-row{display:flex;gap:8px;align-items:center}.filter-chip{padding:5px 12px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-2);font-size:.75rem;cursor:pointer;transition:var(--transition);font-family:var(--font-body);font-weight:500}.filter-chip:hover{border-color:var(--border-l);color:var(--text-1)}.filter-chip.active{background:var(--cyan);border-color:var(--cyan);color:#000;font-weight:700}.markets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px}.market-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px 22px;cursor:pointer;transition:var(--transition);position:relative;overflow:hidden}.market-card:hover{border-color:var(--border-l);transform:translateY(-3px);box-shadow:0 12px 40px #00000059}.market-card:after{content:"";position:absolute;top:0;left:0;width:3px;height:100%;border-radius:var(--radius) 0 0 var(--radius)}.market-card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.market-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px}.market-status{font-size:.72rem;font-weight:700;padding:4px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.04em}.market-status.faol{background:#00e5a01f;color:var(--green)}.market-status.barqaror{background:#ffb0201f;color:var(--amber)}.market-status.past{background:#ff4d6a1f;color:var(--red)}.market-name{font-family:var(--font-head);font-size:1.2rem;font-weight:700;color:var(--text-1);margin-bottom:5px}.market-district{font-size:.82rem;color:var(--text-3)}.market-units{margin-top:20px;padding-top:18px;border-top:1px solid var(--border)}.market-unit-total{background:var(--bg-2);border-radius:10px;padding:14px 16px;margin-bottom:10px}.market-unit-total-value{font-family:var(--font-mono);font-size:1.8rem;font-weight:700;line-height:1;margin-bottom:4px}.market-unit-total-label{font-size:.72rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em}.market-unit-revenue{font-family:var(--font-mono);font-size:1.3rem;font-weight:600;color:var(--text-1);margin:4px 0 2px}.market-unit-row{display:flex;gap:8px}.market-unit-item{flex:1;padding:10px 12px;background:var(--bg-2);border-radius:10px}.market-unit-value{font-family:var(--font-mono);font-size:1.15rem;font-weight:700;line-height:1;margin-bottom:4px}.market-unit-revenue-sm{font-family:var(--font-mono);font-size:.75rem;font-weight:600;color:var(--text-2);margin:3px 0 2px}.market-unit-label{font-size:.67rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.03em}.market-growth{display:flex;align-items:center;gap:4px;font-size:.82rem;font-weight:600;margin-top:16px}.market-growth.up{color:var(--green)}.market-growth.down{color:var(--red)}.table-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.table-header-row{display:grid;grid-template-columns:30px 1fr 120px 120px 100px 80px;gap:12px;padding:10px 20px;border-bottom:1px solid var(--border);font-size:.68rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.table-row{display:grid;grid-template-columns:30px 1fr 120px 120px 100px 80px;gap:12px;padding:12px 20px;border-bottom:1px solid var(--border);transition:var(--transition);align-items:center}.table-row:last-child{border-bottom:none}.table-row:hover{background:var(--bg-card-h)}.table-rank{font-family:var(--font-mono);font-size:.75rem;color:var(--text-3);font-weight:500}.table-market-name{font-weight:600;font-size:.85rem;color:var(--text-1)}.table-district{font-size:.7rem;color:var(--text-3);margin-top:2px}.table-value{font-family:var(--font-mono);font-size:.82rem;color:var(--text-1)}.table-value.muted{color:var(--text-2)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:12px;color:var(--text-3);font-size:.85rem}.spinner{width:32px;height:32px;border:2px solid var(--border);border-top-color:var(--cyan);border-radius:50%;animation:spin .7s linear infinite}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;z-index:500;display:flex;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-box{background:var(--bg-1);border:1px solid var(--border-l);border-radius:16px;width:100%;max-width:840px;max-height:90vh;overflow-y:auto;box-shadow:0 40px 100px #000000b3}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-family:var(--font-head);font-size:1.1rem;font-weight:800}.modal-close{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text-2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.modal-close:hover{background:var(--bg-2);color:var(--text-1)}.modal-body{padding:20px 24px}.modal-total-row{display:flex;align-items:center;background:var(--bg-2);border-radius:12px;padding:16px 20px;margin-bottom:20px}.modal-total-item{flex:1;text-align:center}.modal-total-val{font-family:var(--font-mono);font-size:1.2rem;font-weight:700;line-height:1;margin-bottom:5px}.modal-total-lbl{font-size:.65rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.03em}.modal-total-divider{width:1px;height:40px;background:var(--border);flex-shrink:0}.modal-units-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.modal-unit-card{background:var(--bg-2);border:1px solid var(--border);border-top:3px solid var(--unit-color, var(--border));border-radius:12px;padding:16px}.modal-unit-header{display:flex;align-items:center;gap:7px;margin-bottom:12px}.modal-unit-icon{font-size:1.1rem}.modal-unit-label{font-size:.78rem;font-weight:600;color:var(--text-2)}.modal-unit-count{font-family:var(--font-mono);font-size:2rem;font-weight:700;line-height:1;margin-bottom:4px}.modal-unit-revenue{font-family:var(--font-mono);font-size:.88rem;color:var(--text-1);margin-bottom:14px}.modal-unit-bar-bg{height:5px;background:var(--bg-card);border-radius:3px;overflow:hidden;margin-bottom:6px}.modal-unit-bar-fill{height:100%;border-radius:3px;transition:width .6s ease}.modal-unit-pct{font-size:.68rem;opacity:.8}.modal-footer{padding:16px 24px;border-top:1px solid var(--border)}.modal-platform-btn{display:flex;align-items:center;gap:10px;width:100%;padding:13px 18px;border:1px solid;border-radius:12px;color:#fff;font-family:var(--font-head);font-size:.9rem;font-weight:700;text-decoration:none;transition:var(--transition);box-sizing:border-box}.modal-platform-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000004d;filter:brightness(1.15)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}.mt-1{margin-top:4px}.mb-4{margin-bottom:16px}.mono{font-family:var(--font-mono)}.text-cyan{color:var(--cyan)}.text-green{color:var(--green)}.text-amber{color:var(--amber)}.text-red{color:var(--red)}.text-muted{color:var(--text-3)}.text-sm{font-size:.8rem}.font-bold{font-weight:700}.head-font{font-family:var(--font-head)}.page-title{font-family:var(--font-head);font-size:1.5rem;font-weight:800;margin-bottom:4px}.page-sub{font-size:.8rem;color:var(--text-3);margin-bottom:24px}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-l);border-radius:3px}.district-badge{padding:4px 10px;border-radius:6px;font-size:.68rem;font-weight:600;border:1px solid}.search-input{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 12px 7px 32px;color:var(--text-1);font-family:var(--font-body);font-size:.82rem;outline:none;width:200px;transition:var(--transition)}.search-input:focus{border-color:var(--cyan);width:240px}.search-wrapper{position:relative}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none}.activity-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.activity-item:last-child{border-bottom:none}.activity-dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}.activity-text{font-size:.78rem;color:var(--text-2);line-height:1.4}.activity-time{font-size:.68rem;color:var(--text-3);margin-top:2px;font-family:var(--font-mono)}.recharts-text{fill:var(--text-2)!important}.theme-toggle{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--bg-2);border:1px solid var(--border);border-radius:20px;cursor:pointer;transition:var(--transition);-webkit-user-select:none;user-select:none;font-size:.72rem;color:var(--text-2);font-family:var(--font-body)}.theme-toggle:hover{border-color:var(--cyan);color:var(--text-1)}.theme-toggle-icon{font-size:1rem;line-height:1}[data-theme=light] .sidebar{background:#fff;border-color:#e2e8f0}[data-theme=light] .topbar{background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-color:#e2e8f0}[data-theme=light] .market-card{box-shadow:var(--shadow)}[data-theme=light] .market-card:after{opacity:.06}[data-theme=light] .modal-overlay{background:#0000004d}[data-theme=light] .modal-box{background:#fff;box-shadow:0 20px 60px #00000026}[data-theme=light] .login-card{box-shadow:0 20px 60px #0000001a}[data-theme=light] .config-card,[data-theme=light] .chart-card{box-shadow:var(--shadow)}[data-theme=light] .nav-item.active{background:#4caf501a}[data-theme=light] .date-btn.active{background:var(--primary);color:#fff}[data-theme=light] .filter-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}[data-theme=light] .sidebar-badge{background:#4caf500f;border-color:#4caf5026}[data-theme=light] .kpi-card{box-shadow:var(--shadow)}[data-theme=light] input,[data-theme=light] select{background:var(--bg-input);color:var(--text-1);border-color:var(--border)}[data-theme=light] .custom-date-popup{background:#fff;box-shadow:0 8px 30px #0000001f}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-0)}.login-card{width:100%;max-width:400px;padding:40px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 20px 60px #00000080}.login-logo{display:flex;align-items:center;gap:14;margin-bottom:32}.login-form{display:flex;flex-direction:column;gap:16}.login-field label{display:block;font-size:.72rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6;font-weight:600}.login-field input{width:100%;padding:10px 14px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-1);font-family:var(--font-body);font-size:.88rem;outline:none;transition:border-color .2s}.login-field input:focus{border-color:var(--cyan)}.login-error{padding:10px 14px;background:#ff4d6a1a;border:1px solid rgba(255,77,106,.25);border-radius:var(--radius-sm);color:var(--red);font-size:.78rem}.login-btn{padding:12px;background:linear-gradient(135deg,var(--primary),var(--primary-d));border:none;border-radius:var(--radius-sm);color:#fff;font-family:var(--font-head);font-size:.9rem;font-weight:700;cursor:pointer;transition:.2s;letter-spacing:.02em}.login-btn:hover{filter:brightness(1.1)}.login-btn:disabled{opacity:.6;cursor:default}.logout-btn{width:100%;padding:10px;background:#ff4d6a1a;border:1px solid rgba(255,77,106,.2);border-radius:var(--radius-sm);color:var(--red);font-family:var(--font-body);font-size:.78rem;font-weight:600;cursor:pointer;transition:.2s}.logout-btn:hover{background:#ff4d6a33}.settings-action-btn{display:flex;align-items:center;gap:8;padding:8px 16px;background:linear-gradient(135deg,var(--primary),var(--primary-d));border:none;border-radius:var(--radius-sm);color:#fff;font-family:var(--font-body);font-size:.82rem;font-weight:600;cursor:pointer;transition:.2s}.settings-action-btn:hover{filter:brightness(1.1)}.settings-action-btn.secondary{background:var(--bg-card);border:1px solid var(--border);color:var(--text-2)}.settings-action-btn.secondary:hover{border-color:var(--text-3)}.settings-empty{text-align:center;padding:60px 20px;background:var(--bg-card);border:1px dashed var(--border);border-radius:var(--radius);color:var(--text-2)}.config-form-card{background:var(--bg-card);border:1px solid var(--cyan)40;border-radius:var(--radius);padding:24px;margin-bottom:20px}.config-form-title{font-family:var(--font-head);font-size:1rem;font-weight:700;color:var(--text-1);margin-bottom:16}.config-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14}.config-field label{display:block;font-size:.68rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5;font-weight:600}.config-field input,.config-field select{width:100%;padding:9px 12px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-1);font-family:var(--font-body);font-size:.82rem;outline:none;transition:border-color .2s}.config-field input:focus,.config-field select:focus{border-color:var(--cyan)}.config-field select{cursor:pointer}.config-field select option{background:var(--bg-1);color:var(--text-1)}.configs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14}.config-card{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--border);border-radius:var(--radius);padding:18px}.config-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12}.config-card-name{font-weight:700;font-size:.92rem;color:var(--text-1);margin-bottom:3}.config-card-district{font-size:.75rem;font-weight:600}.config-status{display:flex;align-items:center;gap:4;font-size:.68rem;padding:3px 10px;border-radius:20px;font-weight:600}.config-status.connected{background:#00e5a01f;color:var(--green)}.config-status.disconnected{background:#ff4d6a1a;color:var(--red)}.config-card-info{display:flex;gap:16;font-size:.75rem;color:var(--text-2);margin-bottom:12}.config-label{color:var(--text-3);margin-right:4px}.config-test-result{display:flex;align-items:center;gap:6;font-size:.75rem;padding:6px 10px;border-radius:var(--radius-sm);margin-bottom:12;font-weight:600}.config-test-result.ok{background:#00e5a01a;color:var(--green)}.config-test-result.fail{background:#ff4d6a1a;color:var(--red)}.config-card-actions{display:flex;gap:6;border-top:1px solid var(--border);padding-top:12}.config-btn{display:flex;align-items:center;gap:5;padding:6px 12px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-2);font-family:var(--font-body);font-size:.72rem;cursor:pointer;transition:.2s}.config-btn:hover{border-color:var(--text-3);color:var(--text-1)}.config-btn.danger:hover{border-color:var(--red);color:var(--red)}.config-btn:disabled{opacity:.5;cursor:default}@keyframes spin{to{transform:rotate(360deg)}}.spinning{animation:spin 1s linear infinite}
