*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;background:#f6f7fb;color:#111827;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.small-muted{color:#6b7280;font-size:.9rem;margin-top:4px}.muted{color:#9ca3af}.hint{color:#94a3b8;font-size:.85rem}button{background:#0f172a;color:#fff;border:none;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:.95rem}button:disabled{opacity:.6;cursor:not-allowed}button.secondary{background:#fff;color:#0f172a;border:1px solid #e6e9ef}.btn{display:inline-flex;align-items:center;gap:8px}.btn-flat{background:transparent;color:#0b5394;border:1px solid transparent;padding:6px 10px}.btn-outline{background:transparent;color:#0f172a;border:1px solid #e6e9ef;padding:6px 10px}label{display:block;margin-top:12px;font-weight:600;font-size:.95rem}input[type=text],input[type=password],select,textarea{width:100%;padding:8px 10px;font-size:1rem;border-radius:6px;border:1px solid #e6e9ef;margin-top:6px;background:#fff}textarea{min-height:120px;resize:vertical}.form-row{margin-top:8px}.error{color:#b91c1c;margin-top:6px;font-size:.9rem}.app-shell{display:flex;min-height:100vh;width:100%}.left-nav,.ln{width:220px;padding:12px;background:#fff;border-right:1px solid #eef2f7;height:100vh;position:fixed;left:0;top:0;overflow:auto;z-index:50}.left-nav ul{list-style:none;padding:0;margin:12px 0}.left-nav li{margin-bottom:8px}.left-nav a{color:#0b5394;text-decoration:none;padding:8px 6px;display:inline-block}.ln{display:flex;flex-direction:column;justify-content:space-between}.ln-top{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px 4px}.ln-brand{display:flex;align-items:center;gap:8px}.ln-logo{width:38px;height:38px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#0b5394,#07407a);color:#fff;font-weight:700;font-size:1rem;box-shadow:0 4px 14px #0b53941f}.ln-title{font-weight:700;color:#0b5394}.ln-mode-btn{font-size:.85rem;color:#374151;background:transparent;border:none;cursor:pointer;padding:6px}.ln-nav{padding-top:8px}.ln-group{margin-bottom:6px}.ln-group-header{width:100%;text-align:left;background:transparent;border:none;padding:8px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;color:#0b5394;font-weight:600;border-radius:6px}.ln-submenu{display:none;padding-left:8px;margin-top:6px}.ln-submenu.show{display:block}.ln-item{display:block;padding:6px 8px;color:#0b5394;text-decoration:none;border-radius:6px;margin-bottom:4px}.ln-item:hover{background:#f1f5f9}.caret{transition:transform .18s ease;color:#6b7280}.caret.open{transform:rotate(90deg)}.ln-footer{padding:12px;text-align:center;font-size:.85rem;color:#9ca3af}.main-area{border-left:1px solid #eef2f7;flex:1;min-height:100vh;display:flex;flex-direction:column}.topnav{display:flex;justify-content:space-between;align-items:center;padding:12px 18px 12px 12px;border-bottom:1px solid #eef2f7;background:#fff;position:sticky;top:0;z-index:40}.topnav-left .app-title{font-size:1.05rem;font-weight:700;color:#0b5394}.topnav-right{display:flex;align-items:center;gap:12px}.topnav-user{font-weight:600;color:#0f172a}.dashboard-main{padding:18px;background:transparent}.page-container{max-width:980px;margin:24px auto;padding:20px;background:#fff;border-radius:8px;box-shadow:0 6px 20px #06070f0f}.header-row{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:12px 0;border-bottom:1px solid #eef2f7;margin-bottom:16px}.card{background:#fff;padding:12px;border-radius:8px;box-shadow:0 2px 8px #0f172a0a;margin-bottom:12px}.card h3{margin:0 0 8px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.table-wrap{overflow:auto;background:#fff;border-radius:8px;border:1px solid #eef2f7;padding:6px}table{border-collapse:collapse;width:100%}th,td{padding:10px 12px;border-bottom:1px solid #f3f4f6;text-align:left;font-size:.95rem}th{background:#f8fafc;font-weight:700;position:sticky;top:0;z-index:1;text-transform:uppercase;font-size:.85rem;color:#0b5394}.s-table-compressed th,.s-table-compressed td{padding:8px 10px;font-size:.92rem}.table-empty{padding:24px;color:#6b7280;text-align:center}.pagination{display:flex;gap:8px;align-items:center;padding:12px;justify-content:flex-end}.ps-modal-backdrop{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#07091447;z-index:2000}.ps-modal-square{width:320px;max-width:92%;background:#fff;border-radius:12px;padding:22px;text-align:center;box-shadow:0 12px 40px #02061747}.ps-spinner{margin:6px auto 14px;width:58px;height:58px;border-radius:50%;border:6px solid rgba(15,23,42,.08);border-top-color:#0f172a;animation:ps-spin 1s linear infinite}@keyframes ps-spin{to{transform:rotate(360deg)}}.ps-modal-title{font-size:1.1rem;margin:6px 0;font-weight:700}.ps-modal-message{color:#6b7280;margin-top:6px;font-size:.95rem}@media(max-width:980px){.left-nav,.ln{width:180px}.main-area{margin-left:180px}}@media(max-width:720px){.left-nav,.ln{display:none}.main-area{margin-left:0}.topnav{padding:10px}.header-row{flex-direction:column;align-items:flex-start;gap:8px}}.dashboard-main.partner{background:linear-gradient(180deg,#f8fbff,#fff)}.dashboard-main.admin{background:linear-gradient(180deg,#fffaf8,#fff)}.dashboard-main.region{background:linear-gradient(180deg,#f7fffb,#fff)}.badge{display:inline-block;padding:4px 8px;border-radius:999px;font-weight:600;font-size:.8rem;background:#eef2ff;color:#0b5394}.quick-links{list-style:none;padding:0;margin:0}.quick-links li{margin-bottom:6px}.quick-links a{color:#0b5394;text-decoration:none}.center{text-align:center}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.space-between{display:flex;justify-content:space-between;align-items:center}.table-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:28px}.btn-warning{background:#f59e0b;color:#fff;border:none;padding:8px 10px;border-radius:6px;cursor:pointer}.btn-warning:disabled{opacity:.6;cursor:not-allowed}.btn-sm{padding:6px 8px;font-size:13px;border-radius:6px}.ps-loader{width:42px;aspect-ratio:1;border-radius:50%;margin:8px auto 16px;background:linear-gradient(#2563eb 0 0),linear-gradient(#2563eb 0 0),linear-gradient(#dc2626 0 0),linear-gradient(#dc2626 0 0),linear-gradient(#facc15 0 0),linear-gradient(#facc15 0 0),linear-gradient(#16a34a 0 0),linear-gradient(#16a34a 0 0),linear-gradient(#fb923c 0 0),linear-gradient(#fb923c 0 0),#fff;background-repeat:no-repeat;background-position:top left,bottom right;animation:ps-loader-anim 2.5s infinite ease-in-out}@keyframes ps-loader-anim{0%{background-size:0 100%,0 100%,100% 0,100% 0,0 100%,0 100%,100% 0,100% 0,0 0}20%,25%{background-size:0 100%,0 100%,100% 0,100% 0,0 100%,0 100%,100% 50%,100% 50%,0 0}45%,50%{background-size:0 100%,0 100%,100% 0,100% 0,50% 100%,50% 100%,100% 50%,100% 50%,0 0}70%,75%{background-size:0 100%,0 100%,100% 50%,100% 50%,50% 100%,50% 100%,100% 50%,100% 50%,0 0}95%,to{background-size:50% 100%,50% 100%,100% 50%,100% 50%,50% 100%,50% 100%,100% 50%,100% 50%,0 0}}.up-map{background:transparent;height:100%;width:100%;justify-content:center;align-items:center;display:flex;margin-bottom:5%;overflow:visible}.state-outline{fill:none;stroke:#000;stroke-width:3}.district-shape{stroke:#1e1e1e;stroke-width:1.2;vector-effect:non-scaling-stroke;cursor:pointer;will-change:transform,filter;transform-box:fill-box;transform-origin:center;transition:fill .2s ease,stroke .2s ease,stroke-width .15s ease,filter .2s ease,transform .15s ease}.district-shape.active{stroke:#000;stroke-width:3;filter:brightness(1.2)}.district-shape:hover{stroke:#000;stroke-width:2.2;filter:brightness(1.15) drop-shadow(0 0 2px rgba(0,0,0,.4));transform:scale(1.02);pointer-events:auto}.d1{fill:#7f1d1d}.d2{fill:#881337}.d3{fill:#991b1b}.d4{fill:#9f1239}.d5{fill:#b91c1c}.d6{fill:#be123c}.d7{fill:#dc2626}.d8{fill:#e11d48}.d9{fill:#ef4444}.d10{fill:#f43f5e}.d11{fill:#f87171}.d12{fill:#fb7185}.d13{fill:#fecaca}.d14{fill:#ffe4e6}.d15{fill:#450a0a}.d16{fill:#4c0519}.d17{fill:#5f0f0f}.d18{fill:#6b0f1a}.d19{fill:#7a1414}.d20{fill:#8b0000}.d21{fill:#9a1b1b}.d22{fill:#a11212}.d23{fill:#b91c1c}.d24{fill:#c81e1e}.d25{fill:#dc2626}.d26{fill:#e02424}.d27{fill:#ef4444}.d28{fill:#f05252}.d29{fill:#f87171}.d30{fill:#faa5a5}.d31{fill:#7c2d12}.d32{fill:#8a2c2c}.d33{fill:#9b2c2c}.d34{fill:#a83232}.d35{fill:#b93838}.d36{fill:#c43c3c}.d37{fill:#d14343}.d38{fill:#dc4c4c}.d39{fill:#e85d5d}.d40{fill:#f27a7a}.d41{fill:#3f0a0a}.d42{fill:#4a0e0e}.d43{fill:#550f0f}.d44{fill:#601313}.d45{fill:#6d1717}.d46{fill:#7a1a1a}.d47{fill:#871d1d}.d48{fill:#941f1f}.d49{fill:#a12121}.d50{fill:#ae2323}.d51{fill:#5b0f14}.d52{fill:#661017}.d53{fill:#73121a}.d54{fill:#80141d}.d55{fill:#8d1620}.d56{fill:#9a1823}.d57{fill:#a71a26}.d58{fill:#b41c29}.d59{fill:#c11e2c}.d60{fill:#ce202f}.d61{fill:#2b0606}.d62{fill:#330707}.d63{fill:#3b0808}.d64{fill:#430909}.d65{fill:#4b0a0a}.d66{fill:#530b0b}.d67{fill:#5b0c0c}.d68{fill:#630d0d}.d69{fill:#6b0e0e}.d70{fill:#731010}.d71{fill:#7b1111}.d72{fill:#831212}.d73{fill:#8b1313}.d74{fill:#931414}.d75{fill:#9b1515}.district-label{font-size:5px;font-weight:600;fill:#374151;pointer-events:none;-webkit-user-select:none;user-select:none}
