:root{--bg: #F2F2F7;--bg2: #FFFFFF;--bg3: #F2F2F7;--bg4: #E5E5EA;--border: rgba(60,60,67,.13);--border2: rgba(60,60,67,.22);--border3: rgba(60,60,67,.38);--text: #1C1C1E;--text2: #3C3C43;--text3: #8E8E93;--red: #FF3B30;--red-dark: #D70015;--red-light: rgba(255,59,48,.1);--green: #34C759;--green-dark: #248A3D;--green-light: rgba(52,199,89,.1);--blue: #007AFF;--blue-light: rgba(0,122,255,.1);--orange: #FF9500;--yellow: #FF9500;--yellow-light: rgba(255,149,0,.12);--purple: #AF52DE;--purple-light: rgba(175,82,222,.1);--confirmed: #248A3D;--leaning: #C47000;--neutral: #8E8E93;--oppose: #FF3B30;--font: -apple-system, BlinkMacSystemFont, "SF Pro Display", "Helvetica Neue", Arial, sans-serif;--mono: "JetBrains Mono", "SF Mono", ui-monospace, "Menlo", monospace;--sidebar-w: 220px;--topbar-h: 52px;--bottom-nav-h: 60px;--radius: 13px;--shadow-sm: 0 1px 3px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.04);--shadow: 0 4px 20px rgba(0,0,0,.09), 0 1px 4px rgba(0,0,0,.05);--shadow-lg: 0 12px 44px rgba(0,0,0,.14), 0 2px 8px rgba(0,0,0,.07)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}canvas{max-width:100%;display:block}html{height:100%;overflow-x:hidden}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;min-height:100%;width:100%;max-width:100vw;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;overflow-x:hidden}.app-shell{display:flex;min-height:100vh;overflow-x:hidden;width:100%}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:200;transition:transform .28s cubic-bezier(.25,.46,.45,.94);overflow:hidden}.sidebar-logo{padding:16px 14px 15px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);flex-shrink:0}.logo-icon{width:34px;height:34px;background:linear-gradient(135deg,#ff3b30,#c8001a);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:12.5px;font-weight:800;color:#fff;flex-shrink:0;letter-spacing:-.5px;box-shadow:0 2px 8px #ff3b304d}.logo-text{font-weight:700;font-size:14px;color:var(--text);letter-spacing:-.2px}.logo-sub{font-size:11px;color:var(--text3);margin-top:1px}.sidebar-nav{flex:1;padding:8px;overflow-y:auto}.nav-group-label{font-size:11px;font-weight:600;color:var(--text3);padding:10px 10px 5px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;color:var(--text2);cursor:pointer;text-decoration:none;font-size:15px;font-weight:500;border-radius:10px;transition:all .15s;margin-bottom:2px;border-left:none;position:relative}.nav-item:hover{background:#0000000a;color:var(--text)}.nav-item.active{background:#ff3b3014;color:var(--red);font-weight:600}.nav-icon{font-size:14px;width:20px;text-align:center;flex-shrink:0}.sidebar-footer{padding:12px;border-top:1px solid var(--border);flex-shrink:0}.user-info{display:flex;align-items:center;gap:9px}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#ff3b30,#c8001a);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}.user-name{font-size:13px;font-weight:600;color:var(--text)}.user-role{font-size:11px;color:var(--text3)}.btn-logout{margin-top:8px;width:100%}.main-wrap{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;min-width:0}.topbar{height:var(--topbar-h);background:#f2f2f7f0;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right));gap:12px;position:sticky;top:0;z-index:100;backdrop-filter:blur(20px) saturate(1.8);-webkit-backdrop-filter:blur(20px) saturate(1.8)}.topbar-title{font-size:17px;font-weight:700;flex:1;min-width:0;color:var(--text);letter-spacing:-.3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-badge{font-size:11px;font-family:var(--mono);letter-spacing:.2px;padding:3px 10px;border-radius:20px;background:#ff3b3014;color:var(--red);border:1px solid rgba(255,59,48,.2);font-weight:600}.menu-btn{display:none;background:none;border:none;color:var(--text3);font-size:20px;cursor:pointer;padding:4px}.page-content{flex:1;padding:20px;padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right));overflow-x:hidden;min-width:0;max-width:100%}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:calc(var(--bottom-nav-h) + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background:#f9f9f9eb;border-top:1px solid rgba(60,60,67,.18);z-index:200;backdrop-filter:blur(28px) saturate(1.8);-webkit-backdrop-filter:blur(28px) saturate(1.8)}.bottom-nav-inner{display:flex;height:var(--bottom-nav-h);width:100%}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--text3);text-decoration:none;font-size:10px;font-weight:500;letter-spacing:.1px;border:none;background:none;cursor:pointer;position:relative;padding:0 2px;-webkit-tap-highlight-color:transparent;transition:color .18s}.bottom-nav-item .bn-icon{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:10px;transition:transform .25s cubic-bezier(.34,1.56,.64,1),background .18s}.bottom-nav-item .bn-icon svg{width:22px;height:22px}.bottom-nav-item.active{color:var(--red)}.bottom-nav-item.active .bn-icon{background:#ff3b301a;transform:translateY(-2px) scale(1.08)}.bottom-nav-item:active .bn-icon{transform:scale(.86)!important;transition-duration:.1s}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.span-2{grid-column:span 2}.span-3{grid-column:span 3}.card{background:#fff;border:none;border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);position:relative;min-width:0}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:8px}.card-title{font-size:13px;font-weight:600;color:var(--text3);letter-spacing:0}.stat-card{background:#fff;border:none;border-radius:var(--radius);padding:16px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow .2s,transform .2s}.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.stat-accent{position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius) var(--radius) 0 0}.stat-label{font-size:12px;font-weight:600;color:var(--text3);margin-top:6px}.stat-value{font-size:28px;font-weight:700;font-family:var(--mono);margin:6px 0 2px;line-height:1.1;letter-spacing:-1.5px;color:var(--text)}.stat-sub{font-size:12px;color:var(--text3)}.accent-red{background:#ff3b30}.accent-green{background:#34c759}.accent-blue{background:#007aff}.accent-orange{background:#ff9500}.accent-yellow{background:#fc0}.accent-purple{background:#af52de}.progress{height:4px;background:#00000012;border-radius:2px;overflow:hidden;margin-top:8px}.progress-fill{height:100%;border-radius:2px;transition:width .6s ease}.fill-red{background:#ff3b30}.fill-green{background:#34c759}.fill-blue{background:#007aff}.fill-orange{background:#ff9500}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;border:none;transition:all .15s;white-space:nowrap;font-family:var(--font);letter-spacing:-.1px}.btn-primary{background:#ff3b30;color:#fff;box-shadow:0 1px 4px #ff3b304d}.btn-primary:hover{background:#d70015;box-shadow:0 2px 12px #ff3b3066;transform:translateY(-1px)}.btn-green{background:#34c759;color:#fff;box-shadow:0 1px 4px #34c75940}.btn-green:hover{background:#248a3d}.btn-ghost{background:#0000000d;color:var(--text2);border:1px solid var(--border2)}.btn-ghost:hover{background:#00000014;color:var(--text);border-color:var(--border3)}.btn-danger{background:#ff3b3014;color:#ff3b30;border:1px solid rgba(255,59,48,.2)}.btn-danger:hover{background:#ff3b3026}.btn-sm{padding:6px 12px;font-size:13px}.btn-xs{padding:4px 9px;font-size:11px;border-radius:7px}.btn-icon{padding:7px 9px}.btn:disabled{opacity:.35;cursor:not-allowed;transform:none!important;box-shadow:none!important}.form-row{display:grid;gap:12px;margin-bottom:14px}.form-row.cols-2{grid-template-columns:1fr 1fr}.form-row.cols-3{grid-template-columns:1fr 1fr 1fr}.form-group{display:flex;flex-direction:column;gap:5px}label{font-size:13px;font-weight:600;color:var(--text);letter-spacing:0}input,select,textarea{background:#7676801f;border:1.5px solid transparent;border-radius:10px;color:var(--text);font-family:var(--font);font-size:15px;padding:10px 12px;transition:border-color .15s,box-shadow .15s,background .15s;outline:none;width:100%}input:focus,select:focus,textarea:focus{border-color:#007aff;box-shadow:0 0 0 3px #007aff26;background:#fff}input::placeholder,textarea::placeholder{color:var(--text3)}select option{background:#fff;color:var(--text)}textarea{min-height:80px;resize:vertical}input[type=file]{color:var(--text2);font-size:13px;padding:8px 10px}input[type=file]::file-selector-button{background:#007aff1a;border:1px solid rgba(0,122,255,.2);border-radius:7px;color:#007aff;font-size:12px;padding:4px 10px;cursor:pointer;margin-right:8px;font-family:var(--font)}.checkbox-group{display:flex;flex-wrap:wrap;gap:8px}.checkbox-item{display:flex;align-items:center;gap:6px;cursor:pointer;padding:7px 13px;border:1.5px solid var(--border2);border-radius:20px;font-size:13px;font-weight:500;transition:all .15s;-webkit-user-select:none;user-select:none;background:#fff;color:var(--text2)}.checkbox-item:hover{border-color:var(--red);color:var(--text)}.checkbox-item.checked{background:#ff3b3012;border-color:var(--red);color:var(--red);font-weight:600}.checkbox-item input{display:none}.table-wrap{overflow-x:auto;width:100%;max-width:100%;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse;font-size:14px}th{font-size:12px;font-weight:600;color:var(--text3);text-align:left;padding:10px 14px;border-bottom:1px solid var(--border);white-space:nowrap;background:#00000005}th:first-child{border-radius:0}th:last-child{border-radius:0}td{padding:11px 14px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}tr:hover td{background:#00000005}tr:last-child td{border-bottom:none}.td-mono{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--text2)}.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}.badge-active{background:#34c7591f;color:#248a3d}.badge-inactive{background:#0000000f;color:var(--text3)}.badge-shifted{background:#ff95001f;color:#c47000}.badge-dead{background:#ff3b301a;color:#ff3b30}.badge-voted{background:#34c7591f;color:#248a3d}.badge-not-voted{background:#0000000f;color:var(--text3)}.badge-strong{background:#34c7591f;color:#248a3d}.badge-leaning{background:#ff95001f;color:#c47000}.badge-neutral{background:#0000000f;color:var(--text3)}.badge-oppose{background:#ff3b301a;color:#ff3b30}.badge-admin{background:#af52de1a;color:#af52de}.search-bar{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.search-bar input,.search-bar select{flex:1;min-width:140px}.search-bar .search-input{flex:2}.pagination{display:flex;align-items:center;gap:8px;justify-content:flex-end;margin-top:16px}.page-info{font-size:12px;color:var(--text3);font-family:var(--mono)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal{background:#fff;border:none;border-radius:18px;width:100%;max-width:540px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.modal-lg{max-width:720px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-header h2{font-size:17px;font-weight:700;color:var(--text)}.modal-close{background:#0000000f;border:none;color:var(--text3);font-size:16px;cursor:pointer;padding:4px 9px;border-radius:8px;transition:background .15s}.modal-close:hover{background:#0000001a;color:var(--text)}.modal-body{padding:22px;overflow-y:auto}.modal-footer{padding:14px 22px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;flex-shrink:0;background:#00000004;border-radius:0 0 18px 18px}.toast-container{position:fixed;bottom:24px;right:24px;z-index:2000;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{padding:12px 18px;border-radius:14px;font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px;animation:slideUp .2s ease;pointer-events:all;max-width:340px;box-shadow:var(--shadow-lg)}.toast-success{background:#fff;color:#248a3d;box-shadow:var(--shadow-lg),0 0 0 1px #34c75933}.toast-error{background:#fff;color:#ff3b30;box-shadow:var(--shadow-lg),0 0 0 1px #ff3b3033}.toast-info{background:#fff;color:#007aff;box-shadow:var(--shadow-lg),0 0 0 1px #007aff33}@keyframes slideUp{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.candidate-card{background:#fff;border:2px solid var(--border);border-radius:var(--radius);padding:14px;transition:all .15s;cursor:pointer;position:relative}.candidate-card:hover{border-color:var(--border2);box-shadow:var(--shadow-sm)}.candidate-card.selected{border-color:#34c759;background:#34c7590d;box-shadow:0 0 0 3px #34c7591f}.candidate-card.disabled{opacity:.4;cursor:not-allowed}.candidate-photo{width:48px;height:48px;border-radius:50%;object-fit:cover;background:var(--bg4);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;flex-shrink:0;overflow:hidden}.candidate-photo img{width:100%;height:100%;object-fit:cover}.candidate-info{flex:1;min-width:0}.candidate-name{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.candidate-party{font-size:12px;color:var(--text3);margin-top:2px}.candidate-stats{margin-top:10px}.pledge-bar{height:4px;background:#00000012;border-radius:2px;overflow:hidden;margin-top:4px}.pledge-fill{height:100%;background:#34c759;border-radius:2px;transition:width .5s}.checkmark{position:absolute;top:8px;right:8px;width:22px;height:22px;border-radius:50%;background:#34c759;display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff;box-shadow:0 1px 6px #34c75959}.quick-input-wrap{display:flex;gap:10px;max-width:500px;margin:0 auto 24px}.quick-input-wrap input{font-size:24px;font-family:var(--mono);text-align:center;letter-spacing:4px}.voter-result-card{max-width:500px;margin:0 auto;background:#fff;border-radius:var(--radius);border:none;overflow:hidden;box-shadow:var(--shadow)}.voter-result-header{padding:16px;background:var(--bg3);display:flex;align-items:center;gap:12px}.voter-list-no{font-family:var(--mono);font-size:24px;font-weight:700;color:#34c759}.voter-result-body{padding:16px}.voter-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.voter-detail-item{background:var(--bg3);padding:8px 10px;border-radius:8px;border:1px solid var(--border)}.voter-detail-label{font-size:11px;color:var(--text3);font-weight:600}.voter-detail-value{font-size:14px;font-weight:600;margin-top:3px;color:var(--text)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);position:relative;overflow:hidden;padding:20px}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(255,59,48,.07) 0%,transparent 60%);pointer-events:none}.login-card{background:#fff;border:none;border-radius:22px;padding:40px 36px;width:100%;max-width:380px;box-shadow:var(--shadow-lg);position:relative;z-index:1}.login-logo{text-align:center;margin-bottom:30px}.login-logo h1{font-size:24px;font-weight:800;letter-spacing:-.5px;color:var(--text)}.login-logo p{font-size:13px;color:var(--text3);margin-top:4px}.login-icon-wrap{width:64px;height:64px;background:#ff3b3014;border:none;border-radius:18px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:28px}.live-dot{display:inline-block;flex-shrink:0;width:7px;height:7px;border-radius:50%;background:#34c759;box-shadow:0 0 0 2px #34c75933;animation:live-pulse 2s ease-in-out infinite}@keyframes live-pulse{0%,to{opacity:1;box-shadow:0 0 0 2px #34c75940}50%{opacity:.7;box-shadow:0 0 0 5px #34c75912}}.empty-state{display:flex;align-items:center;justify-content:center;min-height:260px;color:var(--text3);font-size:14px}.chart-wrap{position:relative;height:200px;width:100%}.chart-wrap-sm{height:160px}.chart-wrap-lg{height:260px}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#00000024;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#00000038}.text-mono{font-family:var(--mono)}.text-sm{font-size:12px}.text-xs{font-size:11px}.text-muted{color:var(--text3)}.text-red{color:var(--red)}.text-green{color:var(--confirmed)}.text-yellow{color:var(--leaning)}.flex{display:flex}.flex-1{flex:1}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mb-16{margin-bottom:16px}.mb-8{margin-bottom:8px}.fw-600{font-weight:600}.divider{border:none;border-top:1px solid var(--border);margin:16px 0}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:8px 0 40px #0003}.main-wrap{margin-left:0;padding-bottom:calc(var(--bottom-nav-h) + env(safe-area-inset-bottom))}.bottom-nav{display:flex}.menu-btn{display:block}.topbar{padding-top:0;padding-bottom:0;padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right));gap:8px}.topbar-signout{display:none!important}.page-content{padding:12px;padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right))}.card,.stat-card{padding:14px}.stat-value{font-size:24px;letter-spacing:-1px}.grid-4,.grid-3{grid-template-columns:1fr 1fr}.grid-2{grid-template-columns:1fr}.span-2,.span-3{grid-column:span 1}.hide-mobile{display:none!important}.form-row.cols-2,.form-row.cols-3{grid-template-columns:1fr}th{padding:8px 10px}td{padding:9px 10px}.modal-overlay{padding:0;align-items:flex-end}.modal{border-radius:22px 22px 0 0;max-height:88vh;max-width:100%}.modal-header{padding:14px 16px}.modal-body{padding:16px}.modal-footer{padding:12px 16px;border-radius:0}.login-card{padding:28px 20px;border-radius:16px}.login-logo h1{font-size:22px}.quick-input-wrap input{font-size:20px;letter-spacing:3px}}@media (max-width: 480px){.grid-4{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:1fr}.topbar-badge{display:none}.topbar-title{font-size:16px}.card,.stat-card{padding:12px}.stat-value{font-size:22px}.card-title{font-size:12px}td,th{white-space:nowrap}.search-bar{flex-direction:column}.search-bar input,.search-bar select,.search-bar .search-input{flex:unset;width:100%}.login-card{margin:0 8px;padding:24px 16px}.pagination{flex-wrap:wrap;justify-content:center}}@media (max-width: 360px){.grid-4{grid-template-columns:1fr}.stat-value{font-size:20px}.page-content{padding:10px}.topbar{padding:0 10px}.bottom-nav-item{font-size:9px}}
