@import url("https://fonts.googleapis.com/css2?family=Cairo:wght@400;500;600;700;800;900&display=swap");
:root{--primary:#0f766e;--primary-dark:#0d5f59;--primary-soft:#d9f7f2;--navy:#10233f;--ink:#1e293b;--muted:#64748b;--line:#e2e8f0;--bg:#f5f8fb;--white:#fff;--blue:#2563eb;--success:#15803d;--warning:#a16207;--danger:#b91c1c;--radius:20px}*{box-sizing:border-box}html,body{margin:0;min-height:100%;font-family:"Cairo","Tahoma",Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:14px}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.app-shell{min-height:100vh}.sidebar{position:fixed;right:0;top:0;bottom:0;width:275px;background:linear-gradient(180deg,#10233f,#0b4b4b);color:#fff;padding:24px 16px;display:flex;flex-direction:column;z-index:30;box-shadow:-8px 0 28px rgba(15,23,42,.12)}.brand{display:flex;gap:12px;align-items:center;padding:0 8px 18px}.brand-icon,.install-mark,.banner-emblem{display:grid;place-items:center;font-weight:900;color:#fff;background:linear-gradient(135deg,#15a394,#0f766e);box-shadow:0 8px 22px rgba(15,118,110,.25)}.brand-icon{border-radius:16px;width:48px;height:48px;font-size:12px}.brand h1{font-size:17px;margin:0}.brand p{margin:2px 0 0;color:#b7d6d5;font-size:12px}.office-identity{margin:0 8px 16px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.08);padding:10px;border-radius:12px;font-size:12px;font-weight:800;text-align:center}.nav{display:grid;gap:5px}.nav a{padding:12px 14px;border-radius:13px;color:#dce8f2;font-weight:700;transition:.2s}.nav a:hover,.nav a.active{background:#fff;color:#0f5f5d}.sidebar-footer{margin-top:auto;margin-inline:8px;border-top:1px solid rgba(255,255,255,.15);padding-top:16px;display:grid;gap:3px}.sidebar-footer strong{font-size:13px}.sidebar-footer span{font-size:11px;color:#b7d6d5}.main{width:calc(100% - 275px);margin-right:275px;padding:26px 30px 42px}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;gap:16px}.topbar h2{margin:0;font-size:26px;color:#10233f}.topbar p{margin:5px 0 0;color:var(--muted)}.user-chip{background:#fff;border:1px solid var(--line);box-shadow:0 6px 18px rgba(15,23,42,.04);border-radius:15px;padding:9px 14px;display:grid;gap:2px;min-width:145px}.user-chip b{font-size:13px}.user-chip span{font-size:11px;color:var(--muted)}.menu-toggle{display:none;border:0;background:#fff;border-radius:11px;padding:8px 11px;font-size:20px}.political-office-banner{background:linear-gradient(105deg,#10233f 0%,#0f766e 58%,#159e8f 100%);color:#fff;border-radius:24px;padding:23px 26px;display:flex;align-items:center;gap:17px;margin-bottom:20px;box-shadow:0 15px 35px rgba(13,94,89,.17)}.banner-emblem{width:62px;height:62px;border-radius:22px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);box-shadow:none}.political-office-banner span{font-size:12px;color:#d9f7f2;font-weight:800}.political-office-banner h1{font-size:24px;margin:3px 0}.political-office-banner p{margin:0;color:#e7fffc;font-size:13px}.banner-meta{margin-right:auto;display:grid;text-align:left;gap:5px}.banner-meta b{font-size:12px}.banner-meta span{font-weight:400}.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:0 9px 25px rgba(15,23,42,.035)}.form-card{border-top:4px solid var(--primary)}.stats-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;margin-bottom:18px}.stat{display:flex;justify-content:space-between;align-items:center;padding:17px}.stat .label{color:var(--muted);font-weight:700;font-size:12px}.stat .num{font-size:28px;color:#10233f;font-weight:900;margin-top:5px;line-height:1}.stat .icon{width:44px;height:44px;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary);border-radius:15px;font-size:22px;font-weight:900}.stat.voters{grid-column:span 1}.tiny{font-size:11px;color:var(--muted);line-height:1.7}.section-title{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:15px}.section-title h3{font-size:18px;margin:0;color:#10233f}.section-title p{margin:5px 0 0}.muted{color:var(--muted)}.form{display:grid;gap:15px}.form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.grid{display:grid;gap:14px}.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.form-heading{font-weight:900;color:#0f5f5d;padding-top:4px;border-top:1px dashed #cbd5e1;margin-top:5px;padding-top:15px}.form-heading:first-child{border:0;padding-top:0;margin-top:0}.field label{display:block;font-weight:800;margin-bottom:6px}.field small{display:block;color:var(--muted);font-size:11px;margin-top:5px}.field input,.field select,.field textarea{width:100%;border:1px solid #d8e2ed;border-radius:13px;padding:10px 12px;outline:none;background:#fff;color:#243244;transition:.15s}.field input:focus,.field select:focus,.field textarea:focus{border-color:#14a899;box-shadow:0 0 0 3px rgba(20,168,153,.12)}.field textarea{min-height:98px;resize:vertical}.field input:disabled{background:#f8fafc;color:#64748b}.actions{display:flex;align-items:center;gap:7px;flex-wrap:wrap}.align-end{align-self:end}.btn{border:0;border-radius:12px;padding:10px 14px;font-weight:800;cursor:pointer;display:inline-flex;justify-content:center;align-items:center;gap:6px;white-space:nowrap;transition:.15s}.btn:hover{transform:translateY(-1px)}.btn.primary{background:linear-gradient(135deg,#0f766e,#149c8d);color:#fff;box-shadow:0 7px 16px rgba(15,118,110,.18)}.btn.light{background:#f6fafb;color:#31506a;border:1px solid var(--line)}.btn.dark{background:#10233f;color:#fff}.btn.danger{background:#fef0f0;color:#b91c1c;border:1px solid #fecaca}.btn.success{background:#e9f9ed;color:#15803d;border:1px solid #bbf7d0}.btn.warning{background:#fff8e5;color:#a16207;border:1px solid #fde68a}.btn.small{padding:7px 10px;border-radius:10px;font-size:12px}.full-btn{width:100%}.alert{border-radius:14px;padding:12px 14px;margin-bottom:15px;font-weight:700}.alert.success{background:#edfdf1;border:1px solid #bbf7d0;color:#166534}.alert.danger{background:#fff1f2;border:1px solid #fecdd3;color:#be123c}.check-row{display:flex;gap:9px;align-items:center;font-weight:700}.check-row input{width:16px;height:16px}.coordinate-helper{display:flex;align-items:center;gap:6px;margin-top:6px;flex-wrap:wrap}.coordinate-helper .btn{padding:5px 8px;font-size:11px}.city-coordinate-preview{font-size:11px;color:var(--muted);font-weight:700}.voters-preview,.score-preview{padding:10px 12px;border-radius:12px;background:#f0fdfa;color:#0f766e;font-size:12px;font-weight:700;border:1px dashed #99f6e4}.score-preview b{font-size:16px}.filter-form{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}.filter-form .field{min-width:155px}.filter-form .grow{flex:1;min-width:220px}.table-wrap{border:1px solid var(--line);border-radius:15px;overflow:auto}.table-wrap table{border-collapse:collapse;min-width:940px;width:100%;font-size:13px}.table-wrap th,.table-wrap td{text-align:right;padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:top}.table-wrap th{background:#f8fafc;color:#334155;font-weight:900;white-space:nowrap}.table-wrap tr:last-child td{border-bottom:0}.table-wrap tbody tr:hover td{background:#fcfefe}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:4px 9px;font-size:11px;font-weight:900;white-space:nowrap}.badge.success{background:#dcfce7;color:#15803d}.badge.warning{background:#fef3c7;color:#a16207}.badge.danger{background:#fee2e2;color:#b91c1c}.badge.info{background:#dbeafe;color:#1d4ed8}.avatar{width:44px;height:44px;object-fit:cover;border-radius:14px;border:2px solid #fff;box-shadow:0 4px 12px rgba(15,23,42,.12);display:inline-grid;place-items:center}.avatar-sm{width:38px;height:38px;border-radius:12px}.avatar-md{width:52px;height:52px;border-radius:16px}.avatar-lg{width:74px;height:74px;border-radius:20px}.placeholder-avatar{background:linear-gradient(135deg,#dff7f4,#b9ede7);color:#0f766e;font-weight:900}.current-photo{display:flex;flex-direction:column;align-items:flex-start}.empty-cell,.empty-state{text-align:center;padding:24px;color:var(--muted)}.wrap-cell{min-width:180px;white-space:normal}.person-line{display:flex;align-items:center;gap:10px}.top-candidates-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:13px}.candidate-card{border:1px solid var(--line);border-radius:17px;padding:14px}.candidate-card.compact{display:flex;justify-content:space-between;align-items:center;gap:12px}.candidate-card h3{font-size:14px;margin:0 0 2px}.candidate-card p{font-size:11px;margin:0 0 6px;color:var(--muted)}.score-pill{min-width:62px;border-radius:14px;padding:9px 7px;text-align:center;font-weight:900;font-size:16px}.score-pill.success{background:#e8f9ec;color:#15803d}.score-pill.warning{background:#fff7dc;color:#a16207}.score-pill.danger{background:#fff0f0;color:#b91c1c}.wide-map-card{padding:22px}.map-title{align-items:center}.libya-map{position:relative;overflow:hidden;border-radius:24px;border:1px solid #c6e2e4;background:#d7dde1;aspect-ratio:1200/1243;width:100%!important;max-width:640px!important;margin:0 auto;min-height:0}.libya-map:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 38% 26%,rgba(255,255,255,.16),transparent 28%),radial-gradient(circle at 77% 70%,rgba(255,255,255,.12),transparent 27%);pointer-events:none;z-index:1}.map-reference-image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}.map-connections{position:absolute;inset:0;width:100%;height:100%;z-index:2;pointer-events:none}.office-link{stroke:#1e293b;stroke-opacity:.55;stroke-width:.26;stroke-dasharray:1.1 1.1;vector-effect:non-scaling-stroke}.marker{position:absolute;transform:translate(-50%,-50%);z-index:4}.marker-dot{width:18px;height:18px;border:3px solid #fff;border-radius:50%;background:rgba(15,118,110,.92);box-shadow:0 0 0 6px rgba(15,118,110,.20),0 10px 18px rgba(15,118,110,.24)}.marker.office .marker-dot{width:12px;height:12px;background:rgba(37,99,235,.95);box-shadow:0 0 0 4px rgba(37,99,235,.18),0 6px 14px rgba(37,99,235,.22)}.marker strong{position:absolute;right:26px;top:-10px;white-space:nowrap;background:rgba(255,255,255,.94);color:#10233f;padding:4px 8px;border-radius:999px;border:1px solid #dbe5ed;box-shadow:0 5px 14px rgba(15,23,42,.10);font-size:11px}.marker small{position:absolute;right:24px;top:20px;white-space:nowrap;color:#fff;background:rgba(15,23,42,.76);border-radius:999px;padding:2px 6px;font-size:10px;font-weight:800;opacity:0;transition:.15s}.marker.district small{opacity:0;background:rgba(15,118,110,.82)}.marker.district:hover small{opacity:1}.marker.office:hover small{opacity:1}.map-legend{display:flex;gap:14px;flex-wrap:wrap;margin-top:12px}.legend-item{display:inline-flex;gap:6px;align-items:center;color:var(--muted);font-size:12px;font-weight:800}.legend-dot{display:inline-block;width:12px;height:12px;border-radius:50%;background:var(--primary)}.legend-dot.office{background:var(--blue)}.legend-line{display:inline-block;width:25px;height:0;border-top:2px dashed #334155}.candidate-study-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.study-card{border:1px solid var(--line);border-radius:18px;padding:15px}.strong-card{border-color:#86efac;background:linear-gradient(180deg,#fff,#f1fdf4)}.study-card-head{display:flex;justify-content:space-between;align-items:center;gap:8px}.study-card h3{margin:0;font-size:16px}.study-card p{margin:3px 0 6px;color:var(--muted);font-size:11px}.study-meta,.mini-scores{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px}.study-meta span,.mini-scores div{background:#f8fafc;border-radius:9px;padding:5px 7px;font-size:11px}.study-notes{margin-top:12px;border-top:1px dashed var(--line);padding-top:7px}.study-notes p{margin:4px 0;font-size:12px;color:#475569}.login-page{display:grid;place-items:center;min-height:100vh;padding:20px;background:radial-gradient(circle at 20% 15%,#bcf4ec,transparent 25%),linear-gradient(135deg,#10233f,#0e6b64)}.login-card{width:min(470px,100%);background:#fff;padding:30px;border-radius:27px;box-shadow:0 25px 70px rgba(0,0,0,.24)}.login-card.wide-login{width:min(680px,100%)}.install-mark{width:58px;height:58px;border-radius:19px;margin-bottom:16px}.login-card h1{margin:0 0 6px;font-size:23px;color:#10233f}.login-card p{margin:0 0 22px;color:var(--muted);line-height:1.8}.profile-sheet{width:min(900px,calc(100% - 40px));margin:20px auto;background:#fff;border:1px solid var(--line);border-radius:24px;padding:26px;box-shadow:0 12px 30px rgba(15,23,42,.08)}.print-sheet-body{background:#f1f5f9}.print-toolbar{width:min(900px,calc(100% - 40px));margin:20px auto 0;display:flex;gap:8px;justify-content:flex-start}.sheet-header{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid #0f766e;padding-bottom:14px}.sheet-header span{color:#0f766e;font-weight:900;font-size:12px}.sheet-header h1{margin:4px 0;font-size:25px;color:#10233f}.sheet-header p{margin:0;color:#64748b;font-size:12px}.sheet-badge{background:#def7f3;color:#0f766e;padding:8px 13px;border-radius:13px;font-weight:900}.strong-badge{background:#dcfce7;color:#15803d}.profile-hero{display:flex;gap:19px;align-items:center;padding:20px 0}.profile-hero h2{margin:0 0 8px;color:#10233f;font-size:23px}.profile-hero p{margin:3px 0;font-size:13px;color:#475569}.profile-photo{width:136px;height:136px;border-radius:20px;object-fit:cover;border:3px solid #e6fffb;display:grid;place-items:center;font-size:50px}.chance-seal{margin-right:auto;width:105px;height:105px;border-radius:50%;display:grid;place-items:center;text-align:center;padding:12px;align-content:center}.chance-seal span{font-size:10px}.chance-seal b{font-size:25px}.chance-seal.success{background:#dcfce7;color:#15803d}.chance-seal.warning{background:#fef3c7;color:#a16207}.chance-seal.danger{background:#fee2e2;color:#b91c1c}.profile-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.profile-grid>div{padding:11px;border:1px solid var(--line);border-radius:12px;min-height:60px}.profile-grid span{display:block;font-size:11px;color:#64748b;margin-bottom:5px}.profile-grid b{font-size:13px;color:#25364b}.profile-grid .full{grid-column:span 2}.preline{line-height:1.8}.sheet-section{margin-top:14px}.sheet-section h3,.mini-heading{font-size:16px;color:#0f5f5d;margin:0 0 9px}.voter-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.voter-strip>div{padding:14px;background:#f0fdfa;border:1px solid #c8f3ed;border-radius:14px;text-align:center}.voter-strip span,.voter-strip small{display:block;color:#0f766e;font-size:11px}.voter-strip b{display:block;color:#10233f;font-size:22px;margin:4px 0}.score-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:9px}.score-grid>div{background:#f8fafc;padding:10px;border-radius:11px;font-size:12px}.score-grid b{float:left;color:#0f766e}.signature-row{margin-top:26px;display:flex;justify-content:space-between;gap:12px;color:#475569;font-weight:700;font-size:12px}.report-stats{grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:16px}.report-voter-box{border:1px solid #d6f5ef;background:#fcfffe;border-radius:16px;padding:15px;margin-bottom:16px}.report-voter-box h3{margin:0 0 5px;color:#0f5f5d;font-size:16px}.report-voter-box p{margin:0 0 12px}.print-report-brand{font-size:13px;font-weight:900;color:#0f766e;margin-bottom:3px}.report-title{margin-bottom:16px}.report-title h1{font-size:22px;margin:0 0 4px;color:#10233f}.report-title p{font-size:11px;margin:0;color:#64748b}
@media(max-width:1200px){.stats-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.top-candidates-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.libya-map{width:100%;min-height:0}}@media(max-width:980px){.sidebar{transform:translateX(110%);transition:.2s}.sidebar-open .sidebar{transform:translateX(0)}.main{margin-right:0;width:100%;padding:20px}.menu-toggle{display:block}.form-grid,.grid.cols-3{grid-template-columns:repeat(2,minmax(0,1fr))}.candidate-study-grid{grid-template-columns:1fr}.libya-map{width:100%;min-height:0}.banner-meta{display:none}}@media(max-width:650px){.main{padding:16px}.topbar h2{font-size:20px}.topbar p,.user-chip{display:none}.political-office-banner{padding:18px}.political-office-banner h1{font-size:19px}.political-office-banner p{font-size:12px}.stats-grid,.report-stats,.top-candidates-grid,.form-grid,.grid.cols-2,.grid.cols-3,.profile-grid,.voter-strip,.score-grid{grid-template-columns:1fr}.stat.voters{grid-column:auto}.filter-form{display:grid;grid-template-columns:1fr}.filter-form .field{min-width:0}.candidate-card.compact{align-items:flex-start}.libya-map{width:100%;min-height:0}.marker strong{display:none}.profile-sheet{width:calc(100% - 20px);padding:16px}.profile-hero{align-items:flex-start;flex-wrap:wrap}.chance-seal{margin-right:0}.profile-grid .full{grid-column:auto}.signature-row{display:grid;gap:14px}.sheet-header h1{font-size:20px}}
@media print{*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.sidebar,.topbar,.no-print,.print-toolbar{display:none!important}.main{width:100%;margin:0;padding:0}.card{box-shadow:none;border:0;border-radius:0;padding:0}.table-wrap{border:0;border-radius:0;overflow:visible}.table-wrap table{min-width:0}.table-wrap th,.table-wrap td{padding:6px 7px;font-size:10px}.table-wrap th{background:#edf5f5!important}.avatar{width:28px;height:28px;border:0;box-shadow:none}.stats-grid{gap:7px}.stat{border:1px solid #cbd5e1!important;padding:8px}.stat .num{font-size:19px}.stat .icon{display:none}.political-office-banner{box-shadow:none!important;margin-bottom:10px}.libya-map{width:100%;min-height:0}.candidate-study-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.study-card{padding:8px}.profile-sheet{box-shadow:none;border:0;width:100%;margin:0;padding:0}.print-sheet-body{background:#fff}.profile-photo{width:100px;height:100px}.sheet-header h1{font-size:20px}.profile-hero{padding:12px 0}.profile-grid>div{padding:7px;min-height:45px}.report-card{padding:0}.print-only{display:block!important}}


/* تحسينات مركز رؤية للإستشارات */
:root{--primary:#075e59;--primary-dark:#064c49;--primary-soft:#e3f7f4;--navy:#0d2038;--bg:#f4f7fb}
.print-only{display:none}.print-report-brand,.sheet-header span{letter-spacing:.2px}.profile-sheet{border-top:8px solid var(--primary);position:relative;overflow:hidden}.profile-sheet:before{content:"مركز رؤية للإستشارات";position:absolute;left:22px;top:18px;color:rgba(15,118,110,.08);font-weight:900;font-size:34px}.sheet-header{background:linear-gradient(135deg,#f8fffe,#eef8f7);border:1px solid #d8eee9;border-radius:18px;padding:16px 18px;margin-bottom:12px}.sheet-badge{box-shadow:0 6px 14px rgba(15,118,110,.10)}.profile-grid>div{background:#fbfefd}.signature-row>div{border-top:1px dashed #94a3b8;padding-top:10px;min-width:230px}.print-toolbar{position:sticky;top:10px;z-index:20}.report-card{position:relative}.report-title{border:1px solid #dbe8ea;background:linear-gradient(135deg,#f8fffe,#f3f7fb);border-radius:16px;padding:13px 16px}.print-report-brand{font-size:14px;color:var(--primary);font-weight:900}.monitor-dot{width:10px;height:10px;border-radius:50%;display:inline-block;background:#16a34a;box-shadow:0 0 0 4px #dcfce7}
@media print{body{background:#fff!important;color:#111827!important;font-size:11px}.card{background:#fff!important}.report-title{display:block!important;margin-bottom:10px}.profile-sheet{border:0;border-top:6px solid var(--primary);border-radius:0}.profile-sheet:before{display:none}.sheet-header{border-radius:0;border:1px solid #b7d7d2}.profile-grid>div{border:1px solid #d2dce5;background:#fff!important;break-inside:avoid}.table-wrap table{width:100%!important}.table-wrap th{background:#edf7f5!important;color:#0f172a!important}.table-wrap tr{break-inside:avoid}.btn{display:none!important}}

/* v10: visible scrollbars for menus/tables/lists */
.sidebar{overflow-y:auto;scrollbar-gutter:stable;padding-left:10px}.nav{padding-bottom:10px}.table-wrap{overflow:auto;max-height:68vh;scrollbar-gutter:stable}.field select{max-height:260px}.sidebar::-webkit-scrollbar,.table-wrap::-webkit-scrollbar,.field select::-webkit-scrollbar{width:10px;height:10px}.sidebar::-webkit-scrollbar-track,.table-wrap::-webkit-scrollbar-track{background:rgba(15,23,42,.08);border-radius:999px}.sidebar::-webkit-scrollbar-thumb,.table-wrap::-webkit-scrollbar-thumb{background:#0f766e;border-radius:999px;border:2px solid rgba(255,255,255,.45)}.sidebar{scrollbar-width:thin;scrollbar-color:#0f766e rgba(255,255,255,.18)}.table-wrap{scrollbar-width:thin;scrollbar-color:#0f766e #edf5f5}

/* v10: printable report charts */
.report-charts-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:0 0 16px}.report-chart{border:1px solid #d6e8e7;background:linear-gradient(180deg,#ffffff,#f8fffe);border-radius:18px;padding:15px;break-inside:avoid}.chart-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:12px}.chart-head h3{margin:0;color:#0f5f5d;font-size:16px}.chart-head p{margin:2px 0 0;color:#64748b;font-size:11px}.chart-bars{display:grid;gap:9px}.chart-row{display:grid;grid-template-columns:130px 1fr 74px;align-items:center;gap:10px}.chart-label{font-size:12px;font-weight:800;color:#334155;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chart-track{height:14px;border-radius:999px;background:#e9f1f2;overflow:hidden;border:1px solid #d9e7e7}.chart-track i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#0f766e,#22a69a)}.chart-row b{font-size:12px;color:#10233f;text-align:left}.chart-columns{height:190px;display:flex;align-items:end;gap:12px;border-bottom:1px solid #d7e4e4;padding:10px 4px 0}.chart-column{flex:1;display:grid;justify-items:center;gap:5px;min-width:52px}.column-box{height:120px;width:46px;border-radius:14px 14px 4px 4px;background:#edf5f5;display:flex;align-items:end;overflow:hidden;border:1px solid #d9e7e7}.column-box i{display:block;width:100%;background:linear-gradient(180deg,#22a69a,#0f766e);border-radius:14px 14px 0 0}.chart-column b{font-size:12px;color:#10233f}.chart-column span{font-size:11px;color:#475569;font-weight:800;text-align:center}.gender-chart{display:grid;gap:10px}.gender-track{display:flex;height:28px;border:1px solid #d9e7e7;border-radius:999px;overflow:hidden;background:#edf5f5}.gender-track i{display:block;background:#0f766e}.gender-track em{display:block;background:#2563eb}.gender-legend{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;color:#334155;font-size:12px;font-weight:800}.report-chart+.mini-heading{margin-top:15px}
@media(max-width:900px){.report-charts-grid{grid-template-columns:1fr}.chart-row{grid-template-columns:100px 1fr 60px}}
@media print{.table-wrap{max-height:none!important;overflow:visible!important}.report-charts-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:8px;margin-bottom:10px}.report-chart{border:1px solid #b8d5d4!important;background:#fff!important;border-radius:10px;padding:8px}.chart-head{margin-bottom:6px}.chart-head h3{font-size:12px}.chart-head p{font-size:9px}.chart-row{grid-template-columns:85px 1fr 45px;gap:5px}.chart-label,.chart-row b,.chart-column b,.chart-column span,.gender-legend{font-size:9px}.chart-track{height:10px}.chart-columns{height:125px}.column-box{height:82px;width:32px}.gender-track{height:18px}.report-voter-box,.report-chart{break-inside:avoid}}
/* v11: political analysis page */
.analysis-block{border:1px solid #d6e8e7;background:#fff;border-radius:18px;padding:15px;margin-bottom:14px;break-inside:avoid}.analysis-block h3{font-size:16px;color:#0f5f5d;margin:0 0 12px;border-bottom:1px dashed #cbd5e1;padding-bottom:8px}.political-print-sheet .profile-grid b{font-weight:800}.political-print-sheet .table-wrap{margin-top:8px}.political-print-sheet .report-charts-grid{margin-top:8px}.political-print-sheet .empty-cell{padding:14px}.print-only{display:none}
@media print{.political-print-sheet{box-shadow:none!important;border:0!important;padding:0!important}.analysis-block{border:1px solid #b8d5d4!important;border-radius:8px;padding:8px;margin-bottom:8px}.analysis-block h3{font-size:12px;margin-bottom:7px;padding-bottom:5px}.political-print-sheet .profile-grid{gap:5px}.political-print-sheet .profile-grid>div{padding:6px;min-height:38px}.political-print-sheet .profile-grid span{font-size:8.5px}.political-print-sheet .profile-grid b{font-size:9.5px}.political-print-sheet .table-wrap th,.political-print-sheet .table-wrap td{font-size:8.7px;padding:4px 5px}.political-print-sheet .report-title h1{font-size:15px}.political-print-sheet .report-title p{font-size:9px}}

/* v12 dashboard exactly styled like requested map screen */
body{background:#f6f8fb}.electoral-dashboard{display:grid;gap:18px}.ed-head{display:flex;justify-content:flex-end;align-items:center;text-align:right}.ed-head h1{margin:0;color:#10233f;font-size:28px;font-weight:900}.ed-head p{margin:4px 0 0;color:#64748b;font-size:13px}.ed-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.ed-stat{height:96px;background:#fff;border:1px solid #e6edf5;border-radius:14px;box-shadow:0 10px 26px rgba(15,23,42,.06);display:flex;align-items:center;justify-content:space-between;padding:18px 22px;overflow:hidden}.ed-stat b{display:block;font-size:13px;margin-bottom:6px}.ed-stat strong{display:block;font-size:26px;line-height:1;font-weight:900}.ed-stat span{display:block;font-size:12px;color:#64748b;margin-top:5px}.ed-stat i{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;font-style:normal;font-size:26px}.ed-stat.orange b,.ed-stat.orange strong{color:#f28a16}.ed-stat.orange i{background:#fff3df}.ed-stat.blue b,.ed-stat.blue strong{color:#2563eb}.ed-stat.blue i{background:#edf4ff}.ed-stat.green b,.ed-stat.green strong{color:#16a765}.ed-stat.green i{background:#e8f8ef}.ed-stat.purple b,.ed-stat.purple strong{color:#7e3ff2}.ed-stat.purple i{background:#f2e9ff}.ed-main-grid{display:grid;grid-template-columns:280px 220px 1fr;gap:18px;align-items:stretch}.ed-list-card{background:#fff;border:1px solid #e4ebf4;border-radius:14px;box-shadow:0 10px 26px rgba(15,23,42,.06);padding:16px;min-height:560px;display:flex;flex-direction:column}.ed-list-card h3{margin:0 0 12px;color:#10233f;font-size:18px;font-weight:900;display:flex;justify-content:space-between}.ed-list-sub{font-size:12px;color:#64748b;margin:0 0 8px}.ed-scroll-list{overflow:auto;border-top:1px solid #edf1f6;border-bottom:1px solid #edf1f6;max-height:440px;scrollbar-gutter:stable}.ed-scroll-list::-webkit-scrollbar{width:9px;height:9px}.ed-scroll-list::-webkit-scrollbar-thumb{background:#2563eb;border-radius:20px}.ed-scroll-list::-webkit-scrollbar-track{background:#eef4ff;border-radius:20px}.ed-mini-table{width:100%;border-collapse:collapse;font-size:13px}.ed-mini-table th,.ed-mini-table td{padding:10px 8px;border-bottom:1px solid #edf1f6;text-align:right;white-space:nowrap}.ed-mini-table th{color:#64748b;background:#fbfdff;font-size:12px}.ed-mini-table strong{color:#24324a}.ed-dot{display:inline-block;width:9px;height:9px;background:#2563eb;border-radius:50%;margin-left:8px}.ed-num{display:inline-grid;place-items:center;min-width:24px;height:24px;background:#e6f1ff;color:#2563eb;border-radius:8px;font-weight:900}.ed-more{margin:14px auto 0;display:inline-flex;align-items:center;justify-content:center;border:1px solid #e6edf5;border-radius:10px;padding:8px 14px;color:#2563eb;background:#fff;font-weight:800;font-size:12px}.ed-map-card{background:#fff;border:1px solid #e4ebf4;border-radius:14px;padding:0;box-shadow:0 10px 26px rgba(15,23,42,.06);position:relative;overflow:hidden}.ed-libya-map{position:relative;width:100%;height:560px;border-radius:14px;overflow:hidden;background:#cfe7ff}.ed-map-base,.ed-connections{position:absolute;inset:0;width:100%;height:100%}.ed-map-base{z-index:1}.ed-land{filter:drop-shadow(0 2px 2px rgba(15,23,42,.22))}.ed-border{fill:none;stroke:#1e293b;stroke-width:.45;stroke-linejoin:round}.ed-region{fill:none;stroke:#7b8f7c;stroke-width:.18;opacity:.7}.ed-connections{z-index:2;pointer-events:none}.ed-connections line{stroke:#38a6de;stroke-width:.22;stroke-opacity:.78;vector-effect:non-scaling-stroke}.ed-office-pin{position:absolute;z-index:4;width:12px;height:12px;border-radius:50%;background:#2563eb;border:2px solid #fff;box-shadow:0 2px 8px rgba(37,99,235,.35);transform:translate(-50%,-50%)}.ed-district-pin{position:absolute;z-index:5;width:29px;height:29px;border-radius:50%;background:#0fa36b;color:#fff;border:2px solid #d9fff1;box-shadow:0 6px 16px rgba(15,163,107,.35);display:grid;place-items:center;transform:translate(-50%,-50%);font-size:13px;font-weight:900}.ed-district-pin>span:first-child{line-height:1}.ed-map-pin{cursor:pointer;outline:none}.ed-map-pin:focus-visible{box-shadow:0 0 0 4px rgba(245,158,11,.48),0 5px 16px rgba(15,23,42,.28)}.ed-pin-tooltip{position:absolute;right:50%;bottom:calc(100% + 11px);transform:translateX(50%) translateY(5px);width:max-content;max-width:220px;padding:8px 10px;border-radius:10px;background:rgba(15,35,67,.96);color:#fff;box-shadow:0 10px 24px rgba(15,23,42,.24);font-size:11px;line-height:1.5;text-align:right;white-space:normal;pointer-events:none;opacity:0;visibility:hidden;transition:opacity .16s ease,transform .16s ease,visibility .16s;z-index:20}.ed-pin-tooltip:after{content:"";position:absolute;top:100%;right:50%;transform:translateX(50%);border:6px solid transparent;border-top-color:rgba(15,35,67,.96)}.ed-pin-tooltip b{display:block;font-size:12px;font-weight:900;white-space:nowrap}.ed-pin-tooltip small{display:block;color:#d9e8ff;font-size:10px;white-space:nowrap}.ed-map-pin:hover .ed-pin-tooltip,.ed-map-pin:focus .ed-pin-tooltip{opacity:1;visibility:visible;transform:translateX(50%) translateY(0)}.ed-map-pin:hover{z-index:12}.ed-office-pin:hover{transform:translate(-50%,-50%) scale(1.3)}.ed-district-pin:hover{transform:translate(-50%,-50%) scale(1.08)}.ed-map-tools{position:absolute;left:12px;top:12px;z-index:8;display:grid;gap:8px}.ed-map-tools button{width:38px;height:38px;border:1px solid #d8e2ef;background:#fff;border-radius:9px;font-size:20px;color:#334155;box-shadow:0 6px 13px rgba(15,23,42,.07)}.ed-map-legend{position:absolute;right:16px;bottom:14px;z-index:8;background:rgba(255,255,255,.95);border:1px solid #dbe7f1;border-radius:10px;padding:9px 12px;display:flex;gap:18px;align-items:center;font-size:12px;font-weight:800;color:#334155;box-shadow:0 8px 22px rgba(15,23,42,.08)}.ed-map-legend span{display:flex;align-items:center;gap:7px}.ed-map-legend i{display:inline-block}.ed-map-legend .green,.ed-map-legend .blue{width:10px;height:10px;border-radius:50%}.ed-map-legend .green{background:#0fa36b}.ed-map-legend .blue{background:#2563eb}.ed-map-legend .line{width:25px;border-top:2px solid #38a6de}.ed-stats.bottom{margin-top:0}.sidebar{background:linear-gradient(180deg,#0b2343,#0a5560);width:285px}.main{width:calc(100% - 285px);margin-right:285px}.brand{justify-content:flex-start}.brand-icon{background:#fff0;border-radius:0;width:50px;height:50px;background-image:linear-gradient(135deg,#f59e0b 0 40%,transparent 40%),linear-gradient(#183b72,#0c5c61);border:2px solid rgba(255,255,255,.35)}.brand h1{font-size:20px}.office-identity{font-size:15px;background:transparent;border:0;padding-top:0;color:#fff}.nav{gap:10px}.nav a{display:flex;align-items:center;justify-content:flex-start;padding:12px 15px;border-radius:9px;color:#eef8ff;font-size:14px}.nav a.active{background:#4f75d9;color:#fff;box-shadow:0 8px 18px rgba(54,91,196,.28)}
@media(max-width:1250px){.ed-main-grid{grid-template-columns:1fr}.ed-list-card{min-height:auto}.ed-scroll-list{max-height:250px}.ed-libya-map{height:520px}.ed-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:700px){.ed-stats{grid-template-columns:1fr}.ed-libya-map{height:420px}.ed-map-legend{position:static;margin:8px;flex-wrap:wrap}.ed-main-grid{gap:12px}.ed-list-card{padding:12px}}
@media print{.ed-head{display:block!important}.ed-stats{grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:7px}.ed-stat{height:auto;padding:8px;border:1px solid #d8e2ee!important;box-shadow:none!important}.ed-stat i{display:none}.ed-stat strong{font-size:18px}.ed-main-grid{grid-template-columns:1fr!important}.ed-list-card{display:none}.ed-map-card{box-shadow:none!important;border:1px solid #d0d8e0!important}.ed-libya-map{height:520px}.ed-map-tools{display:none}.ed-map-legend{box-shadow:none;border:1px solid #d0d8e0}.ed-stats.bottom{display:none}.ed-office-pin{width:8px;height:8px}.ed-district-pin{width:22px;height:22px;font-size:10px}}
