*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#eef1f8;--surface:#fff;--sidebar:#07101f;--sidebar-mid:#0d1930;--navy:#07101f;--blue:#1a4fd6;--blue-mid:#3b6ef0;--blue-light:#eef2ff;--blue-glow:#1a4fd626;--gold:#c09020;--gold-mid:#d4a535;--gold-light:#fdf8ed;--gold-glow:#c090202e;--champagne:#f0dcaa;--green:#059669;--green-bg:#ecfdf5;--red:#dc2626;--red-bg:#fef2f2;--text:#0a1628;--text-mid:#2c3e67;--text-muted:#64748b;--text-dim:#94a3b8;--border:#dde4f0;--border-light:#eef1f8;--shadow-xs:0 1px 4px #0a16280f;--shadow-sm:0 2px 10px #0a162812;--shadow-md:0 8px 32px #0a16281a;--shadow-lg:0 20px 64px #0a162821;--shadow-xl:0 40px 96px #0a162829;--shadow-blue:0 12px 40px #1a4fd62e;--shadow-gold:0 12px 40px #c090202e;--radius:18px;--radius-lg:26px;--font:"Sarabun","Inter",sans-serif}html,body{height:100%;font-family:var(--font);-webkit-font-smoothing:antialiased;background:var(--bg);color:var(--text)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#c8d1e8;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--blue)}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes shimmerTx{0%{background-position:-200%}to{background-position:200%}}@keyframes rotateBg{0%,to{background-position:0%}50%{background-position:100%}}@keyframes floatOrb{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-20px)scale(1.06)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.login-page{background:linear-gradient(-40deg,#060e1c,#0f1e38,#08162e,#130b22,#060e1c) 0 0/400% 400%;justify-content:center;align-items:center;min-height:100vh;animation:16s infinite rotateBg;display:flex;position:relative;overflow:hidden}.orb{pointer-events:none;border-radius:50%;position:absolute}.orb-1{background:radial-gradient(circle,#1a4fd617 0%,#0000 65%);width:700px;height:700px;animation:14s ease-in-out infinite floatOrb;top:-200px;right:-180px}.orb-2{background:radial-gradient(circle,#c0902012 0%,#0000 65%);width:500px;height:500px;animation:11s ease-in-out -6s infinite floatOrb;bottom:-120px;left:-100px}.orb-3{background:radial-gradient(circle,#3b6ef00d 0%,#0000 65%);width:300px;height:300px;animation:9s ease-in-out -3s infinite floatOrb;top:40%;left:30%}.login-page:before{content:"";background:linear-gradient(90deg,#0000,#d4a53599,#0000);height:2px;position:absolute;top:0;left:0;right:0}.login-box{z-index:1;-webkit-backdrop-filter:blur(48px);background:#ffffff0e;border:1px solid #ffffff17;border-radius:32px;width:480px;padding:56px 50px 48px;animation:.8s cubic-bezier(.22,1,.36,1) fadeUp;position:relative;box-shadow:0 60px 120px #0000008c,0 0 0 1px #ffffff0d,inset 0 1px #ffffff17}.login-logo-ring{background:linear-gradient(135deg,#c09020,#f0d060,#c09020) 0 0/200%;border-radius:22px;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 20px;font-size:2rem;animation:4s infinite rotateBg;display:flex;box-shadow:0 8px 32px #c0902080,inset 0 1px #ffffff4d}.login-title{text-align:center;letter-spacing:-.5px;background:linear-gradient(135deg,#fff 20%,#f0d060 55%,#fff 90%) 0 0/200%;-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:5px;font-size:1.9rem;font-weight:900;animation:5s ease-in-out infinite shimmerTx}.login-sub{color:#b4c8f073;text-align:center;letter-spacing:1px;text-transform:uppercase;margin-bottom:38px;font-size:.82rem;font-weight:400}.form-group{margin-bottom:18px}.form-label{color:#b4c8f080;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:7px;font-size:.7rem;font-weight:700;display:block}.form-input{color:#fff;width:100%;font-size:.93rem;font-family:var(--font);background:#ffffff0e;border:1px solid #ffffff17;border-radius:13px;outline:none;padding:13px 18px;transition:all .22s}.form-input:focus{background:#c090200d;border-color:#c0902099;box-shadow:0 0 0 3px #c090201a}.form-input::placeholder{color:#ffffff2e}.btn-login{color:#07101f;width:100%;font-size:.95rem;font-weight:800;font-family:var(--font);cursor:pointer;letter-spacing:.5px;background:linear-gradient(135deg,#a87010,#d4a535,#f0c050,#d4a535,#a87010) 0 0/300%;border:none;border-radius:14px;margin-top:12px;padding:15px;transition:all .35s;box-shadow:0 8px 32px #c0902059}.btn-login:hover{background-position:100%;transform:translateY(-2px);box-shadow:0 16px 40px #c0902080}.btn-login:active{transform:translateY(0)}.btn-login:disabled{opacity:.5;cursor:not-allowed;transform:none}.error-msg{color:#fca5a5;background:#dc26261a;border:1px solid #dc262633;border-radius:12px;margin-top:14px;padding:11px 16px;font-size:.85rem}.dashboard-layout{background:var(--bg);min-height:100vh;display:flex}.sidebar{background:var(--sidebar);border-right:1px solid #ffffff0a;flex-direction:column;flex-shrink:0;width:288px;height:100vh;min-height:100vh;padding:0;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar:before{content:"";background:linear-gradient(90deg,#0000,#c09020,#f0d060,#c09020,#0000);flex-shrink:0;height:3px;display:block}.sidebar-inner{flex-direction:column;flex:1;gap:15px;padding:28px 20px;display:flex}.sidebar-logo{align-items:center;gap:12px;padding-bottom:6px;display:flex}.sidebar-logo-icon{background:linear-gradient(135deg,#9a6e14,#d4a535,#f0d060);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.15rem;display:flex;box-shadow:0 6px 20px #c0902073}.sidebar-logo-text{color:#fff;letter-spacing:-.3px;font-size:1rem;font-weight:800;line-height:1.2}.sidebar-logo-sub{color:#b4c8f047;letter-spacing:2px;text-transform:uppercase;font-size:.62rem;font-weight:500}.sidebar-divider{border:none;border-top:1px solid #ffffff0d}.sidebar-user{background:#ffffff0a;border:1px solid #ffffff0f;border-radius:13px;align-items:center;gap:10px;padding:11px 13px;display:flex}.sidebar-user-avatar{color:#fff;background:linear-gradient(135deg,#1a4fd6,#3b6ef0);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:.82rem;font-weight:800;display:flex;box-shadow:0 4px 12px #1a4fd666}.sidebar-user-name{color:#fff;font-size:.85rem;font-weight:700}.sidebar-user-role{color:#b4c8f04d;letter-spacing:.5px;font-size:.65rem}.btn-logout{color:#fca5a5a6;width:100%;font-family:var(--font);cursor:pointer;text-align:left;background:#dc26260f;border:1px solid #dc26261f;border-radius:12px;align-items:center;gap:8px;padding:10px 14px;font-size:.82rem;font-weight:700;transition:all .2s;display:flex}.btn-logout:hover{color:#fca5a5;background:#dc26261f;border-color:#dc262640;transform:translate(3px)}.sidebar-section{color:#b4c8f040;letter-spacing:3px;text-transform:uppercase;padding-left:2px;font-size:.63rem;font-weight:800}.sidebar-label{color:#b4c8f080;align-items:center;gap:5px;margin-bottom:7px;font-size:.77rem;font-weight:700;display:flex}.file-upload-area{cursor:pointer;text-align:center;background:#c0902006;border:1.5px dashed #c090202e;border-radius:14px;padding:18px 12px;transition:all .22s}.file-upload-area:hover{background:#c090200f;border-color:#c090206b}.file-upload-area.has-file{background:#0596690a;border-style:solid;border-color:#05966959}.file-upload-icon{margin-bottom:6px;font-size:1.5rem;display:block}.file-upload-text{color:#b4c8f059;font-size:.76rem;line-height:1.5}.file-name{color:#34d399;word-break:break-all;margin-top:5px;font-size:.73rem;font-weight:700;display:block}.sidebar-tip{color:#b4c8f047;background:#ffffff06;border:1px solid #ffffff0a;border-radius:12px;margin-top:auto;padding:14px 12px;font-size:.7rem;line-height:1.9}.sidebar-tip strong{color:#c0902080}.main-content{flex:1;min-width:0;padding:48px 52px;overflow-x:hidden}.dashboard-header{text-align:center;margin-bottom:52px;position:relative}.dashboard-header:after{content:"";background:linear-gradient(90deg,#0000,#c09020,#0000);width:80px;height:2px;margin:16px auto 0;display:block}.main-title{letter-spacing:-2px;-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#07101f 0%,#1a4fd6 35%,#c09020 65%,#07101f 100%) 0 0/200%;-webkit-background-clip:text;background-clip:text;margin-bottom:10px;font-size:2.9rem;font-weight:900;line-height:1.1;animation:7s ease-in-out infinite shimmerTx}.main-subtitle{color:var(--text-muted);letter-spacing:4px;text-transform:uppercase;justify-content:center;align-items:center;gap:14px;font-size:.72rem;font-weight:600;display:flex}.main-subtitle:before,.main-subtitle:after{content:"";background:linear-gradient(to right,transparent,var(--border),transparent);flex:1;max-width:70px;height:1px}.metrics-strip{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);grid-template-columns:repeat(4,1fr);margin-bottom:28px;display:grid;overflow:hidden}.metric-cell{align-items:center;gap:14px;padding:20px 22px;transition:background .2s;display:flex;position:relative}.metric-cell:hover{background:#fafbff}.metric-cell+.metric-cell{border-left:1px solid var(--border-light)}.metric-cell-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.1rem;display:flex}.metric-icon-blue{background:var(--blue-light);box-shadow:0 4px 12px var(--blue-glow)}.metric-icon-gold{background:var(--gold-light);box-shadow:0 4px 12px var(--gold-glow)}.metric-icon-green{background:#ecfdf5;box-shadow:0 4px 12px #0596691f}.metric-icon-purple{background:#f5f3ff;box-shadow:0 4px 12px #7c3aed1a}.metric-cell-body{min-width:0}.metric-label{color:var(--text-dim);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:3px;font-size:.65rem;font-weight:700}.metric-value{color:var(--text);letter-spacing:-.5px;font-size:1.35rem;font-weight:900;line-height:1.1}.metric-sub{color:var(--text-muted);margin-top:2px;font-size:.72rem;font-weight:500}.ward-filter-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:28px;padding:22px 26px}.ward-filter-top{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;display:flex}.ward-filter-title{color:var(--text);align-items:center;gap:8px;font-size:.88rem;font-weight:800;display:flex}.ward-filter-count{background:var(--blue-light);color:var(--blue);letter-spacing:.5px;border-radius:50px;padding:3px 11px;font-size:.68rem;font-weight:800}.ward-filter-btns{gap:6px;display:flex}.ward-filter-btn{border:1px solid var(--border);color:var(--text-muted);font-family:var(--font);cursor:pointer;background:0 0;border-radius:8px;padding:6px 14px;font-size:.75rem;font-weight:700;transition:all .18s}.ward-filter-btn:hover{background:var(--blue-light);color:var(--blue);border-color:#1a4fd633}.ward-filter-btn.danger:hover{background:var(--red-bg);color:var(--red);border-color:#dc262633}.ward-chips{flex-wrap:wrap;gap:8px;display:flex}.ward-chip{cursor:pointer;font-size:.8rem;font-weight:700;font-family:var(--font);white-space:nowrap;border:1.5px solid;border-radius:50px;align-items:center;gap:5px;padding:7px 16px;line-height:1;transition:all .2s;display:inline-flex}.ward-chip.active{color:#fff;box-shadow:0 4px 16px #1a4fd647}.ward-chip.active:hover{filter:brightness(1.12);transform:translateY(-1px)}.ward-chip.inactive{color:var(--text-mid);border-color:var(--border);background:#fff}.ward-chip.inactive:hover{color:var(--blue);background:var(--blue-light);border-color:#1a4fd659;transform:translateY(-1px)}.kpi-grid{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:52px;display:grid}.card-light,.card-dark{border-radius:var(--radius-lg);text-align:center;padding:36px 32px;transition:all .4s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}.card-light{background:linear-gradient(150deg,#0f1e35 0%,#152d52 60%,#0f1e35 100%);border:1px solid #3b6ef033;box-shadow:0 24px 64px #0a16284d,0 0 0 1px #3b6ef01a,inset 0 1px #ffffff0f}.card-light:before{content:"";background:linear-gradient(90deg,#0000,#3b6ef0,#93b4f8,#3b6ef0,#0000);height:3px;position:absolute;top:0;left:0;right:0}.card-light:after{content:"";pointer-events:none;background:radial-gradient(circle at 100% 0,#3b6ef01f,#0000 65%);width:200px;height:100%;position:absolute;top:0;right:0}.card-light:hover{transform:translateY(-10px);box-shadow:0 40px 80px #0a162859,0 0 60px #1a4fd61f}.card-dark{background:linear-gradient(150deg,#2a1a00 0%,#3d2600 50%,#1e1300 100%);border:1px solid #c0902040;box-shadow:0 24px 64px #0a16284d,0 0 0 1px #c090201f,inset 0 1px #f0d0600f}.card-dark:before{content:"";background:linear-gradient(90deg,#0000,#c09020,#f0d060,#c09020,#0000);height:3px;position:absolute;top:0;left:0;right:0}.card-dark:after{content:"";pointer-events:none;background:radial-gradient(circle at 100% 0,#d4a5351a,#0000 65%);width:200px;height:100%;position:absolute;top:0;right:0}.card-dark:hover{transform:translateY(-10px);box-shadow:0 40px 80px #0a162859,0 0 60px #c090201a}.kpi-label-light{color:#93b4f899;letter-spacing:3px;text-transform:uppercase;margin-bottom:20px;font-size:.65rem;font-weight:700}.kpi-label-dark{color:#d4a5358c;letter-spacing:3px;text-transform:uppercase;margin-bottom:20px;font-size:.65rem;font-weight:700}.kpi-val-light{color:#fff;letter-spacing:-2px;text-shadow:0 0 40px #93b4f866;margin:0 0 20px;font-size:4rem;font-weight:900;line-height:1}.kpi-val-dark{color:#f0d060;letter-spacing:-2px;text-shadow:0 0 40px #d4a53580,0 0 80px #d4a53533;margin:0 0 20px;font-size:4rem;font-weight:900;line-height:1}.badge-label{color:#93b4f873;margin-bottom:8px;font-size:.73rem}.badge-label-dark{color:#d4a53573;margin-bottom:8px;font-size:.73rem}.badge-light{color:#93b4f8;background:#3b6ef026;border:1px solid #3b6ef033;border-radius:8px;padding:5px 16px;font-size:.85rem;font-weight:700;display:inline-block}.badge-dark{color:#d4a535;background:#c0902026;border:1px solid #c0902033;border-radius:8px;padding:5px 16px;font-size:.85rem;font-weight:700;display:inline-block}.growth-badge{border-radius:50px;align-items:center;gap:6px;margin-top:18px;padding:9px 24px;font-size:1.15rem;font-weight:900;display:inline-flex}.section-header{color:var(--text);align-items:center;gap:14px;margin:52px 0 18px;padding-left:18px;font-size:1.2rem;font-weight:800;display:flex;position:relative}.section-header:before{content:"";background:linear-gradient(#1a4fd6,#c09020);border-radius:4px;width:4px;height:110%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.section-header:after{content:"";background:linear-gradient(to right,var(--border),transparent);flex:1;height:1px}.action-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin:52px 0 18px;display:flex}.action-row .section-header{margin:0}.btn-export{color:#fff;font-family:var(--font);cursor:pointer;letter-spacing:.3px;white-space:nowrap;background:linear-gradient(135deg,#047857,#059669,#10b981) 0 0/200%;border:none;border-radius:12px;align-items:center;gap:8px;padding:11px 22px;font-size:.83rem;font-weight:800;transition:all .28s;display:inline-flex;box-shadow:0 6px 22px #0596694d}.btn-export:hover{background-position:100%;transform:translateY(-2px);box-shadow:0 12px 32px #0596696b}.btn-export:active{transform:translateY(0)}.chart-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:24px;padding:28px 24px;transition:all .3s}.chart-box:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.chart-title{color:var(--text-muted);letter-spacing:2.5px;text-transform:uppercase;text-align:center;margin-bottom:10px;font-size:.68rem;font-weight:700}.chart-grid-2{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px;display:grid}.table-wrapper{border-radius:14px;overflow-x:auto}.data-table{border-collapse:separate;border-spacing:0;width:100%;font-size:.88rem}.data-table thead tr{position:relative}.data-table th{color:var(--text-muted);text-align:left;letter-spacing:2px;text-transform:uppercase;border-bottom:1px solid var(--border);background:linear-gradient(#f8faff,#f2f5fc);padding:13px 18px;font-size:.65rem;font-weight:700}.data-table th:first-child{border-radius:14px 0 0}.data-table th:last-child{border-radius:0 14px 0 0}.data-table td{color:var(--text);border-bottom:1px solid #f2f5fb;padding:13px 18px}.data-table tr:hover td{background:#f8faff}.data-table tr:last-child td{border-bottom:none}.data-table tr:last-child td:first-child{border-radius:0 0 0 14px}.data-table tr:last-child td:last-child{border-radius:0 0 14px}.data-table td.positive{color:var(--green);font-weight:800}.data-table td.negative{color:var(--red);font-weight:800}.data-table td.neutral{color:var(--text-muted);font-weight:700}.data-table td.ward-cell{color:var(--text);font-weight:700}.empty-state{text-align:center;background:var(--surface);border-radius:var(--radius-lg);border:1px dashed var(--border);box-shadow:var(--shadow-sm);padding:100px 40px;animation:.5s fadeUp}.empty-state-icon{opacity:.5;margin-bottom:18px;font-size:3.5rem}.empty-state-title{color:var(--text);margin-bottom:10px;font-size:1.4rem;font-weight:800}.empty-state-sub{color:var(--text-muted);font-size:.92rem;line-height:1.7}.loading-bar{text-align:center;color:var(--blue);letter-spacing:2px;text-transform:uppercase;justify-content:center;align-items:center;gap:10px;padding:32px;font-size:.85rem;font-weight:700;display:flex}.loading-spinner{border:2px solid var(--border);border-top-color:var(--blue);border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}.fade-up{animation:.6s cubic-bezier(.22,1,.36,1) fadeUp}@media (max-width:1200px){.metrics-strip{grid-template-columns:repeat(2,1fr)}.metric-cell+.metric-cell:nth-child(3){border-left:none;border-top:1px solid var(--border-light)}}@media (max-width:1100px){.main-content{padding:32px 28px}}@media (max-width:900px){.kpi-grid,.chart-grid-2{grid-template-columns:1fr}.main-title{font-size:2rem}.sidebar{width:260px}.action-row{flex-direction:column;align-items:flex-start}}@media (max-width:640px){.dashboard-layout{flex-direction:column}.sidebar{width:100%;height:auto;position:static}.main-content{padding:20px 16px}.metrics-strip{grid-template-columns:1fr 1fr}}
