*{box-sizing:border-box}body,html{padding:0;margin:0;font-family:Arial,Helvetica,sans-serif;background:#f3f6fb;color:#0f172a}a{color:inherit;text-decoration:none}button,input,select{font:inherit}.login-page,.page-shell{min-height:100vh}.login-page{display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(180deg,#eef4ff,#f8fafc)}.login-card{width:100%;max-width:430px;background:#fff;border-radius:22px;padding:32px;box-shadow:0 18px 50px rgba(15,23,42,.08);border:1px solid #e2e8f0}.login-title{margin:0 0 10px;font-size:30px}.login-subtitle{margin:0 0 24px;color:#64748b}.form-group{margin-bottom:16px}.form-label{display:block;margin-bottom:8px;font-weight:600}.form-input{width:100%;padding:13px 14px;border-radius:14px;border:1px solid #cbd5e1;background:#fff}.form-input:focus{outline:none;border-color:#0f766e;box-shadow:0 0 0 4px rgba(15,118,110,.08)}.error-text{color:#dc2626;margin-bottom:16px}.primary-btn{width:100%;padding:13px 16px;border-radius:14px;border:none;background:#0f766e;color:#fff;font-weight:700;cursor:pointer}.primary-btn:disabled{opacity:.7;cursor:not-allowed}.dashboard-layout{min-height:100vh;display:flex;background:#f3f6fb}.sidebar{width:270px;background:#0f172a;color:#fff;padding:28px 20px;display:flex;flex-direction:column;gap:24px}.sidebar-brand{font-size:28px;font-weight:800;letter-spacing:.04em}.sidebar-nav{display:flex;flex-direction:column;gap:10px}.sidebar-link{padding:12px 14px;border-radius:14px;color:#cbd5e1}.sidebar-link:hover{background:hsla(0,0%,100%,.08);color:#fff}.dashboard-main{flex:1;padding:32px}.dashboard-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:28px}.dashboard-title{margin:0;font-size:34px}.dashboard-subtitle{margin:8px 0 0;color:#64748b}.dashboard-actions{display:flex;gap:12px;flex-wrap:wrap}.logout-btn{border:none;border-radius:14px;background:#111827;color:#fff;padding:12px 16px;cursor:pointer;font-weight:700}.dashboard-selector{display:flex;flex-direction:column;gap:6px;min-width:220px}.dashboard-selector-label{font-size:12px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.04em}.dashboard-selector-input{padding:12px 14px;border:1px solid #cbd5e1;border-radius:14px;background:#fff;color:#0f172a;min-width:220px}.dashboard-filterbar{margin-bottom:24px;padding:18px;background:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 8px 24px rgba(15,23,42,.04)}.dashboard-filterbar-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}.dashboard-filterbar-title{margin:0;font-size:18px;font-weight:800}.dashboard-filterbar-subtitle{margin:6px 0 0;color:#64748b;font-size:14px}.dashboard-filter-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.dashboard-filter-item{display:flex;flex-direction:column;gap:6px;min-width:0}.dashboard-filter-item label{font-size:12px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.03em}.dashboard-filter-item input,.dashboard-filter-item select{padding:12px 14px;border:1px solid #cbd5e1;border-radius:14px;background:#fff;color:#0f172a}.dashboard-filter-item input:focus,.dashboard-filter-item select:focus{outline:none;border-color:#0f766e;box-shadow:0 0 0 4px rgba(15,118,110,.08)}.dashboard-filter-reset{border:none;border-radius:14px;background:#111827;color:#fff;padding:12px 16px;cursor:pointer;font-weight:700;white-space:nowrap}.dashboard-filter-reset:disabled{opacity:.5;cursor:not-allowed}.dashboard-filterbar-active{margin-top:14px;padding:10px 12px;border-radius:12px;background:#ecfeff;color:#0f766e;font-size:13px;font-weight:600}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.kpi-grid,.section-block{margin-bottom:36px}.section-head{display:flex;justify-content:space-between;align-items:end;gap:16px;margin-bottom:16px}.section-title{margin:0;font-size:24px}.section-text{margin:6px 0 0;color:#64748b}.section-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.kpi-card{background:#fff;border-radius:20px;padding:22px;box-shadow:0 14px 34px rgba(15,23,42,.06);border:1px solid #e5e7eb;min-height:132px;display:flex;flex-direction:column;justify-content:center}.kpi-title{font-size:14px;color:#64748b;margin-bottom:10px}.kpi-value{font-size:32px;font-weight:800;margin-bottom:8px;line-height:1.1}.kpi-value.is-empty{color:#94a3b8}.kpi-subtitle{color:#94a3b8;font-size:13px}.chart-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:16px}.chart-grid-top{margin-bottom:36px}.chart-card{background:#fff;border-radius:20px;padding:22px;box-shadow:0 14px 34px rgba(15,23,42,.06);border:1px solid #e5e7eb;min-height:320px}.chart-title{font-size:16px;font-weight:700;margin-bottom:16px}.chart-empty{min-height:240px;display:flex;flex-direction:column;justify-content:center;color:#94a3b8}.chart-empty-title{font-size:16px;font-weight:700;color:#64748b;margin-bottom:6px}.chart-empty-text{font-size:14px;line-height:1.5}.chart-recharts-wrapper{width:100%;height:320px}.dashboard-empty-state{background:#fff;border:1px solid #e5e7eb;border-radius:20px;padding:32px;box-shadow:0 14px 34px rgba(15,23,42,.06)}.dashboard-empty-state h2{margin:0 0 10px;font-size:24px}.dashboard-empty-state p{margin:0;color:#64748b;line-height:1.6}.loading-block,.loading-card,.loading-chart{position:relative;overflow:hidden;background:#e2e8f0}.loading-block:after,.loading-card:after,.loading-chart:after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,hsla(0,0%,100%,0),hsla(0,0%,100%,.55) 50%,hsla(0,0%,100%,0));animation:dashboard-loading 1.4s infinite}.loading-title{width:220px;height:34px;border-radius:12px;margin-bottom:10px}.loading-subtitle{width:160px;height:18px;border-radius:10px}.loading-filterbar{width:100%;height:92px;border-radius:18px}.loading-card{height:132px;border-radius:20px}.loading-chart{height:320px;border-radius:20px}@keyframes dashboard-loading{to{transform:translateX(100%)}}.chart-inner{width:100%;height:250px}.bar-chart{align-items:end;gap:12px;overflow-x:auto;padding-top:8px}.bar-chart,.bar-item{height:100%;display:flex}.bar-item{min-width:56px;flex-direction:column;justify-content:end;align-items:center;gap:8px}.bar-value{font-size:12px;color:#475569}.bar-wrapper{width:100%;height:180px;display:flex;align-items:end;justify-content:center;background:#f8fafc;border-radius:12px;padding:6px}.bar-fill{width:100%;background:linear-gradient(180deg,#14b8a6,#0f766e);border-radius:10px;min-height:6px}.bar-label{font-size:11px;color:#64748b;text-align:center;word-break:break-word}.line-chart-svg{width:100%;height:180px;color:#0f766e;display:block}.line-labels{display:grid;grid-template-columns:repeat(auto-fit,minmax(60px,1fr));gap:8px;margin-top:12px}.line-label{font-size:11px;color:#64748b;text-align:center}.pie-layout{display:flex;gap:20px;align-items:center}.pie-chart-svg{width:180px;height:180px;flex-shrink:0}.pie-legend{display:flex;flex-direction:column;gap:10px;min-width:0}.pie-legend-item{display:flex;align-items:center;gap:8px;font-size:13px}.pie-legend-dot{width:12px;height:12px;border-radius:999px;flex-shrink:0}.pie-legend-label{color:#334155;flex:1}.pie-legend-value{color:#0f172a;font-weight:700}@media (max-width:1200px){.kpi-grid,.section-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.chart-grid{grid-template-columns:1fr}.dashboard-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:900px){.dashboard-layout{flex-direction:column}.sidebar{width:100%}.dashboard-header{flex-direction:column}.dashboard-filterbar-head{flex-direction:column;align-items:stretch}}@media (max-width:640px){.dashboard-filter-grid,.kpi-grid,.section-grid{grid-template-columns:1fr}.dashboard-main{padding:20px}.pie-layout{flex-direction:column;align-items:flex-start}.pie-chart-svg{width:150px;height:150px}.dashboard-title{font-size:28px}}