:root{
  --bg:#f4f7fb;
  --ink:#101828;
  --muted:#667085;
  --line:#e4e7ec;
  --panel:#ffffff;
  --nav:#0b1220;
  --nav2:#111c33;
  --accent:#155eef;
  --accent2:#12b76a;
  --warning:#f79009;
  --danger:#d92d20;
  --shadow:0 18px 45px rgba(16,24,40,.08);
  --radius:22px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--ink)}
a{color:inherit}.app-shell{min-height:100vh}.auth-shell{min-height:100vh;background:#0b1220}.sidebar{position:fixed;inset:0 auto 0 0;width:286px;background:linear-gradient(180deg,var(--nav),var(--nav2));padding:24px 18px;color:#fff;display:flex;flex-direction:column;z-index:20}.brand-box{display:flex;align-items:center;gap:12px;margin-bottom:24px}.brand-mark,.login-logo{display:grid;place-items:center;background:linear-gradient(135deg,#2e90fa,#12b76a);color:#fff;font-weight:900}.brand-mark{width:44px;height:44px;border-radius:15px}.brand{font-weight:900;font-size:22px;letter-spacing:-.04em}.brand-box small{color:#a4b5d2;font-size:12px}.user-pill{display:flex;gap:12px;align-items:center;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.06);border-radius:18px;padding:12px;margin-bottom:22px}.user-pill span{width:36px;height:36px;border-radius:12px;background:#fff;color:#0b1220;display:grid;place-items:center;font-weight:900}.user-pill strong{display:block;font-size:13px}.user-pill small{display:block;color:#a4b5d2;text-transform:capitalize}.nav-menu{display:grid;gap:7px}.nav-link,.logout-form button{display:flex;align-items:center;width:100%;gap:10px;text-align:left;color:#dce8ff;text-decoration:none;background:transparent;border:0;padding:13px 14px;border-radius:14px;font-size:15px;font-weight:700;cursor:pointer}.nav-link:hover,.logout-form button:hover{background:rgba(255,255,255,.09);color:#fff}.nav-link:before{content:"";width:8px;height:8px;border-radius:999px;background:#2e90fa;box-shadow:0 0 0 4px rgba(46,144,250,.12)}.security-box{margin-top:auto;border:1px solid rgba(255,255,255,.1);background:rgba(18,183,106,.1);padding:16px;border-radius:18px}.security-box strong{display:block;margin-bottom:6px}.security-box p{margin:0;color:#bed0ea;font-size:12px;line-height:1.45}.logout-form{margin-top:14px}.content{margin-left:286px;padding:28px;max-width:1500px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px}.topbar h1{margin:4px 0 0;font-size:34px;letter-spacing:-.04em}.eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:#155eef;font-weight:900}.eyebrow.light{color:#d1e9ff}.topbar-badge{background:#eef4ff;color:#155eef;border:1px solid #c7d7fe;border-radius:999px;padding:9px 14px;font-weight:900;font-size:13px}.page-subtitle,.muted{color:var(--muted);margin-top:-8px;line-height:1.6}.cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin:24px 0}.card,.panel,.login-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.metric{padding:22px;position:relative;overflow:hidden}.metric:after{content:"";position:absolute;right:-28px;top:-28px;width:90px;height:90px;border-radius:999px;background:linear-gradient(135deg,rgba(21,94,239,.13),rgba(18,183,106,.13))}.metric span{color:var(--muted);font-weight:800;font-size:13px}.metric strong{display:block;font-size:42px;letter-spacing:-.06em;margin:8px 0 2px}.metric em{font-style:normal;color:#98a2b3;font-size:13px;font-weight:700}.panel{padding:24px;margin-bottom:20px}.panel h2{margin:0 0 14px;font-size:21px;letter-spacing:-.03em}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:12px}.mini-link{font-size:13px;text-decoration:none;color:#155eef;background:#eef4ff;border-radius:999px;padding:9px 12px;font-weight:900}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}.gradient-panel{background:linear-gradient(135deg,#155eef,#0b1220);color:#fff}.gradient-panel p{color:#d1e9ff;line-height:1.7}.primary-link,.primary,button{border:0;border-radius:14px;padding:14px 18px;background:var(--accent);color:#fff;font-weight:900;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px}.primary-link{background:#fff;color:#155eef}.table-wrap{overflow:auto;border-radius:16px;border:1px solid var(--line)}table{width:100%;border-collapse:collapse;background:#fff}th,td{padding:14px 16px;border-bottom:1px solid var(--line);text-align:left;white-space:nowrap}tr:last-child td{border-bottom:0}th{font-size:12px;color:#667085;text-transform:uppercase;letter-spacing:.08em;background:#f9fafb}.count-badge,.audit-action{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:5px 10px;font-weight:900;font-size:12px}.count-badge{background:#ecfdf3;color:#027a48}.audit-action{background:#eef4ff;color:#155eef}.empty{color:#98a2b3;text-align:center;font-weight:700}.auth-content{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top left,rgba(21,94,239,.45),transparent 32%),radial-gradient(circle at bottom right,rgba(18,183,106,.25),transparent 28%),#0b1220}.login-card{width:min(450px,92vw);padding:38px}.login-logo{width:58px;height:58px;border-radius:20px;font-size:28px;margin-bottom:18px}.login-card h1{font-size:42px;letter-spacing:-.06em;margin:0 0 8px}.login-card p{color:var(--muted);line-height:1.6}.login-form{margin-top:20px}.login-note{margin-top:18px;background:#f9fafb;border:1px solid var(--line);border-radius:14px;padding:12px;color:#667085;font-size:13px;font-weight:700}label{display:block;font-weight:900;margin:14px 0 8px;color:#344054}input,select,textarea{width:100%;border:1px solid #d0d5dd;border-radius:14px;padding:13px 14px;font-size:15px;background:#fff;color:#101828;outline:none;transition:.18s ease}input:focus,select:focus,textarea:focus{border-color:#2e90fa;box-shadow:0 0 0 4px rgba(46,144,250,.12)}textarea{resize:vertical}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.full{grid-column:1/-1}.survey-form{display:grid;gap:18px}.form-section{display:grid;grid-template-columns:58px 1fr;gap:18px;align-items:start}.section-number{width:46px;height:46px;border-radius:16px;display:grid;place-items:center;background:#eef4ff;color:#155eef;font-weight:900}.territory-chain{background:#f9fafb;border:1px dashed #b2ccff;border-radius:16px;padding:13px;margin-top:14px;color:#475467;font-weight:700}.contact-card{margin-top:18px;background:#f9fafb;border:1px solid var(--line);border-radius:18px;padding:18px}.check{font-weight:700;display:flex;gap:10px;align-items:flex-start;line-height:1.4}.check input{width:auto;margin-top:3px}.sticky-actions{position:sticky;bottom:16px;background:rgba(255,255,255,.86);backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:20px;padding:14px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow)}.sticky-actions span{color:#667085;font-weight:700}.alert{padding:14px 16px;border-radius:16px;margin-bottom:18px;font-weight:800;border:1px solid}.alert.error{background:#fef3f2;color:#b42318;border-color:#fecdca}.alert.success{background:#ecfdf3;color:#027a48;border-color:#abefc6}.hidden{display:none!important}.mobile-menu{display:none;position:fixed;right:16px;bottom:16px;z-index:50;width:52px;height:52px;border-radius:18px;background:#155eef;box-shadow:var(--shadow)}
@media(max-width:1100px){.cards{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}}
@media(max-width:860px){.mobile-menu{display:grid;place-items:center}.sidebar{transform:translateX(-105%);transition:.25s ease}.sidebar.open{transform:translateX(0)}.content{margin-left:0;padding:18px 16px 90px}.topbar{align-items:flex-start}.topbar h1{font-size:28px}.cards,.form-grid{grid-template-columns:1fr}.form-section{grid-template-columns:1fr}.sticky-actions{position:relative;bottom:auto;display:grid}.auth-content{padding:16px}}

/* Instalador */
.install-body{min-height:100vh;background:radial-gradient(circle at top left,#26395f 0,#0e1526 38%,#070b14 100%);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:#172033;margin:0}.install-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:28px}.install-card{width:min(760px,100%);background:#fff;border-radius:28px;box-shadow:0 28px 90px rgba(0,0,0,.35);padding:34px}.brand-mark{width:56px;height:56px;border-radius:18px;background:linear-gradient(135deg,#172033,#4966ff);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:28px;margin-bottom:16px}.install-card h1{margin:0 0 8px;font-size:32px}.muted{color:#667085;margin:0 0 22px}.form-grid{display:grid;gap:16px}.form-grid label{font-weight:700;color:#344054}.form-grid input{width:100%;box-sizing:border-box;margin-top:7px;border:1px solid #d0d5dd;border-radius:14px;padding:13px 14px;font-size:15px}.grid-2{display:grid;grid-template-columns:1fr 160px;gap:14px}.checks{display:grid;gap:8px;background:#f8fafc;border:1px solid #e4e7ec;border-radius:16px;padding:14px}.check{display:flex;gap:8px;align-items:center;font-weight:600!important}.check input{width:auto;margin:0}.help{font-size:13px;color:#667085;margin:-6px 0 0}.actions{display:flex;gap:12px;justify-content:flex-end;margin-top:6px}.btn{border:0;border-radius:14px;padding:12px 18px;font-weight:800;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.btn.primary{background:#172033;color:#fff}.btn.ghost{background:#eef2ff;color:#172033}.btn.full{width:100%;box-sizing:border-box}.alert{border-radius:16px;padding:13px 15px;margin:16px 0;font-weight:650}.alert.success{background:#ecfdf3;color:#027a48;border:1px solid #abefc6}.alert.danger{background:#fef3f2;color:#b42318;border:1px solid #fecdca}.alert.warning{background:#fffaeb;color:#93370d;border:1px solid #fedf89}.test-result{border-radius:14px;padding:12px;background:#f2f4f7;color:#344054}.test-result.ok{background:#ecfdf3;color:#027a48}.test-result.bad{background:#fef3f2;color:#b42318}@media(max-width:640px){.install-card{padding:24px;border-radius:22px}.grid-2{grid-template-columns:1fr}.actions{flex-direction:column}.btn{width:100%}}

/* v1.7 Panel administrativo */
.compact-form{align-items:end}.status-pill,.role-pill,.urgency{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:6px 10px;font-weight:900;font-size:12px;text-transform:capitalize}.status-pill.active,.status-pill.accepted{background:#ecfdf3;color:#027a48}.status-pill.inactive,.status-pill.pending{background:#fffaeb;color:#93370d}.status-pill.suspended,.status-pill.blocked,.status-pill.revoked{background:#fef3f2;color:#b42318}.role-pill{background:#f2f4f7;color:#344054}.urgency.low{background:#f2f4f7;color:#344054}.urgency.medium{background:#eef4ff;color:#155eef}.urgency.high{background:#fffaeb;color:#93370d}.urgency.critical{background:#fef3f2;color:#b42318}.nav-menu{overflow:auto;padding-right:4px}.nav-menu::-webkit-scrollbar{width:6px}.nav-menu::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:999px}.panel-head .mini-link{white-space:nowrap}.form-grid.compact-form{grid-template-columns:repeat(4,minmax(0,1fr))}@media(max-width:1100px){.form-grid.compact-form{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.form-grid.compact-form{grid-template-columns:1fr}th,td{white-space:normal}.topbar-badge{display:none}}


/* v1.8 Login limpio */
.clean-login{position:relative;}
.login-version{position:fixed;top:24px;right:28px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);color:#dce8ff;border-radius:999px;padding:9px 14px;font-weight:900;font-size:13px;}
.auth-alert{position:fixed;top:24px;left:50%;transform:translateX(-50%);width:min(520px,90vw);z-index:10;}
@media(max-width:640px){.login-version{position:static;margin:0 auto 16px;display:inline-flex}.auth-alert{position:static;transform:none;width:100%;margin-bottom:16px}}


/* v1.14 Seguridad, reportes y territorios */
.muted-inline{color:#667085;font-size:12px;font-weight:700}.mini-stats{display:flex;gap:6px;flex-wrap:wrap}.mini-stats span{display:inline-flex;border-radius:999px;background:#f2f4f7;color:#344054;padding:5px 8px;font-size:12px;font-weight:900}.row-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.row-actions form{margin:0}.tiny-btn{border-radius:999px;padding:9px 11px;font-size:12px;font-weight:900}.tiny-btn.warning{background:#fffaeb;color:#93370d;border:1px solid #fedf89}.tiny-btn.success{background:#ecfdf3;color:#027a48;border:1px solid #abefc6}.danger-btn{background:#d92d20!important}.table-wrap td .mini-link{display:inline-flex}.panel-head .count-badge{white-space:nowrap}@media(max-width:760px){.row-actions{display:grid}.mini-stats{display:grid}.tiny-btn,.table-wrap td .mini-link{width:100%;justify-content:center}}

/* v1.15 Jerarquía territorial ciudad -> comuna -> barrio */
.hierarchy-steps{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;gap:14px;align-items:stretch;margin:14px 0 24px}.hierarchy-step{border:1px solid var(--line);background:#f9fafb;border-radius:18px;padding:16px}.hierarchy-step span{width:30px;height:30px;border-radius:11px;background:#eef4ff;color:#155eef;display:grid;place-items:center;font-weight:900;margin-bottom:10px}.hierarchy-step strong{display:block;font-size:17px;margin-bottom:4px}.hierarchy-step p{margin:0;color:#667085;font-size:13px;line-height:1.45}.hierarchy-arrow{display:grid;place-items:center;color:#98a2b3;font-weight:900;font-size:22px}.field-help{display:block;color:#667085;font-size:12px;font-weight:700;margin-top:8px;line-height:1.4}.territory-tree{display:grid;gap:18px}.tree-city{border:1px solid var(--line);border-radius:20px;padding:18px;background:#fff}.tree-title{display:flex;align-items:center;gap:10px;margin-bottom:12px}.tree-title span{background:#eef4ff;color:#155eef;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.tree-title strong{font-size:19px}.tree-title.small strong{font-size:16px}.tree-title.small span{background:#f2f4f7;color:#344054}.tree-commune{margin:12px 0 0 24px;border-left:3px solid #d1e9ff;padding:10px 0 8px 16px}.neighborhood-list{display:flex;gap:8px;flex-wrap:wrap}.neighborhood-list span{display:inline-flex;border:1px solid #d0d5dd;background:#fff;border-radius:999px;padding:7px 10px;font-weight:800;font-size:13px;color:#344054}.empty-tree{padding:18px;border:1px dashed #d0d5dd;border-radius:18px;color:#667085;font-weight:800;background:#f9fafb}@media(max-width:900px){.hierarchy-steps{grid-template-columns:1fr}.hierarchy-arrow{display:none}.tree-commune{margin-left:0}}

/* v1.16 listado técnico territorial filtrado */
.technical-filter{max-width:380px;margin:14px 0 20px}.technical-city-list{display:grid;gap:18px}.technical-city-block{border:1px solid var(--line);border-radius:20px;background:#fff;padding:18px}.technical-city-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px}.technical-city-head h3{margin:2px 0 0;font-size:24px;letter-spacing:-.04em}.neighborhood-list.compact{gap:6px}.neighborhood-list.compact span{font-size:12px;padding:5px 8px;background:#f9fafb}.muted-inline{color:#98a2b3;font-weight:800;font-size:13px}@media(max-width:760px){.technical-city-head{align-items:flex-start;flex-direction:column}.technical-filter{max-width:100%}}

/* v1.17 Dolores ciudadanos desde encuestas recolectadas */
.pain-summary .metric-text{font-size:24px;line-height:1.05;letter-spacing:-.04em;word-break:break-word;max-width:100%;}
.comments-list{display:grid;gap:12px;}
.comment-card{border:1px solid var(--line);background:#fff;border-radius:16px;padding:14px;}
.comment-card strong{color:#101828;}
.comment-card span{color:#667085;font-weight:800;}
.comment-card p{margin:8px 0;color:#344054;line-height:1.55;}
.comment-card small{color:#667085;font-weight:800;line-height:1.45;}
.config-panel .table-wrap{max-height:320px;overflow:auto;}
@media(max-width:1100px){.pain-summary.cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.pain-summary.cards{grid-template-columns:1fr}.pain-summary .metric-text{font-size:22px}}

/* v1.18 formulario público por líder y registro de simpatizantes */
.form-link-box{display:flex;flex-direction:column;gap:6px;max-width:260px}.copy-field{font-size:11px;padding:7px 9px;border:1px solid #dbe4f0;border-radius:10px;color:#64748b;background:#f8fafc;width:100%}.public-survey-shell{font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;margin:0;min-height:100vh;background:linear-gradient(135deg,#071225,#172554 55%,#0f766e);color:#0f172a}.public-survey-wrap{min-height:100vh;display:grid;place-items:center;padding:28px}.public-survey-card{width:min(860px,100%);background:#fff;border-radius:28px;padding:34px;box-shadow:0 30px 80px rgba(2,6,23,.35)}.public-badge{display:inline-flex;background:#dbeafe;color:#1d4ed8;border:1px solid #bfdbfe;border-radius:999px;padding:8px 12px;font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.08em}.public-brand{display:flex;gap:16px;align-items:center;margin:18px 0 24px}.public-brand h1{margin:0;font-size:34px;letter-spacing:-.04em}.public-brand p{margin:6px 0 0;color:#475569;line-height:1.5}.public-form .form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.public-form label{display:block;font-weight:800;margin-bottom:8px;color:#1e293b}.public-form input,.public-form select,.public-form textarea{width:100%;border:1px solid #cbd5e1;border-radius:14px;padding:13px 14px;font:inherit;box-sizing:border-box}.public-form .full{grid-column:1/-1}.consent-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:14px}.consent-box .check{display:flex;align-items:flex-start;gap:10px;font-weight:700;line-height:1.45}.consent-box input{width:auto;margin-top:3px}.public-submit{margin-top:18px}.public-note{color:#64748b;font-size:13px;line-height:1.5}.public-alert{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:10;width:min(720px,calc(100% - 28px));border-radius:16px;padding:14px 18px;font-weight:800;box-shadow:0 16px 40px rgba(2,6,23,.25)}.public-alert.success{background:#dcfce7;color:#166534;border:1px solid #86efac}.public-alert.error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}@media(max-width:760px){.public-survey-card{padding:22px;border-radius:22px}.public-brand{align-items:flex-start}.public-brand h1{font-size:26px}.public-form .form-grid{grid-template-columns:1fr}}

/* v1.19 formularios de encuesta y flujo real de simpatizantes */
.page-intro{padding:24px;margin-bottom:20px}.page-intro h2{margin:4px 0 8px;font-size:28px;letter-spacing:-.04em}.page-intro p{margin:0;color:#667085;line-height:1.6}.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}.section-head h2{margin:4px 0 6px}.section-head p{margin:0;color:#667085;line-height:1.55}.pill,.mini-badge{display:inline-flex;align-items:center;border-radius:999px;font-weight:900}.pill{background:#eef4ff;color:#155eef;padding:6px 10px;font-size:12px}.mini-badge{background:#f2f4f7;color:#344054;padding:5px 8px;font-size:11px;margin:2px}.copy-input{min-width:320px;max-width:100%;font-size:12px;padding:9px 10px;background:#f8fafc;color:#475467}.btn.small{padding:9px 12px;border-radius:12px;font-size:12px}.btn.ghost{background:#eef4ff;color:#155eef}.text-muted{color:#667085;font-weight:800}.actions{white-space:nowrap}.soft-card{padding:24px;background:linear-gradient(135deg,#fff,#f8fbff)}.flow-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:16px}.flow-grid>div{border:1px solid var(--line);background:#fff;border-radius:18px;padding:16px}.flow-grid strong{display:block;color:#101828;margin-bottom:6px}.flow-grid p{margin:0;color:#667085;line-height:1.5;font-size:13px}@media(max-width:1000px){.flow-grid{grid-template-columns:repeat(2,1fr)}.copy-input{min-width:240px}}@media(max-width:640px){.section-head{flex-direction:column}.flow-grid{grid-template-columns:1fr}.copy-input{min-width:0}}
/* v1.20 */
.form-actions{display:flex;gap:10px;align-items:center}.pill.success{background:#ecfdf3;color:#027a48}.btn.warn{background:#fffaeb;color:#93370d;border:1px solid #fedf89}.text-muted{color:#667085;font-weight:700}.copy-input{min-width:280px;font-size:12px}.card.page-intro p,.card p{line-height:1.6}.form-grid.compact-form .full{grid-column:1/-1}

/* v1.21 métricas piramidales */
.pyramid-stats .strong, .mini-badge.strong { font-weight: 900; background: #eaf2ff; color: #1747d4; }
.pyramid-stats { gap: 6px; }

.actions-inline{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

/* v1.24 panel principal avanzado */
.dashboard-hero{display:grid;grid-template-columns:1.4fr .9fr;gap:22px;align-items:stretch;background:linear-gradient(135deg,#155eef,#0b1220 70%);color:#fff;border-radius:28px;padding:28px;margin:22px 0;box-shadow:0 24px 60px rgba(16,24,40,.16);overflow:hidden;position:relative}.dashboard-hero:after{content:"";position:absolute;right:-80px;top:-80px;width:260px;height:260px;background:rgba(255,255,255,.08);border-radius:999px}.dashboard-hero h2{font-size:38px;letter-spacing:-.055em;margin:8px 0 10px}.dashboard-hero p{color:#d1e9ff;line-height:1.65;max-width:760px}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}.ghost-link{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;border:1px solid rgba(255,255,255,.25);color:#fff;border-radius:14px;padding:14px 18px;font-weight:900}.hero-kpis{display:grid;grid-template-columns:1fr;gap:12px;z-index:1}.hero-kpis div{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);border-radius:20px;padding:18px}.hero-kpis strong{display:block;font-size:36px;letter-spacing:-.06em}.hero-kpis span{color:#d1e9ff;font-weight:800;font-size:13px}.dashboard-metrics{grid-template-columns:repeat(4,minmax(0,1fr))}.dashboard-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}.span-2{grid-column:span 2}.line-bars{height:260px;display:grid;grid-template-columns:repeat(14,1fr);gap:10px;align-items:end;padding:18px 8px 0}.line-bar-item{height:100%;display:flex;flex-direction:column;justify-content:flex-end;gap:8px;text-align:center}.line-bar{border-radius:14px 14px 6px 6px;background:linear-gradient(180deg,#155eef,#12b76a);min-height:8px;position:relative;display:flex;justify-content:center;align-items:flex-start}.line-bar span{position:absolute;top:-24px;font-size:11px;font-weight:900;color:#344054}.line-bar-item small{font-size:11px;color:#667085;font-weight:800}.donut-wrap{display:grid;place-items:center;gap:16px}.donut,.gauge{border-radius:999px;position:relative;display:grid;place-items:center}.donut{width:188px;height:188px}.donut:after,.gauge:after{content:"";position:absolute;background:#fff;border-radius:999px}.donut:after{width:118px;height:118px}.donut span,.gauge span{position:relative;z-index:1;font-size:28px;font-weight:900;letter-spacing:-.05em}.legend-list{display:grid;gap:8px;width:100%}.legend-list div{display:flex;align-items:center;gap:8px;color:#475467;font-weight:800}.legend-list strong{margin-left:auto;color:#101828}.legend-list i{width:11px;height:11px;border-radius:999px;display:inline-flex}.c-critical{background:#d92d20}.c-high{background:#f79009}.c-medium{background:#155eef}.c-low{background:#12b76a}.rank-bars{display:grid;gap:14px}.rank-row{display:grid;grid-template-columns:210px 1fr 92px;gap:14px;align-items:center}.rank-label strong{display:block;color:#101828}.rank-label small{color:#667085;font-weight:800}.rank-track{height:14px;background:#eef2f7;border-radius:999px;overflow:hidden}.rank-track span{display:block;height:100%;background:linear-gradient(90deg,#155eef,#12b76a);border-radius:999px}.rank-value{text-align:right;font-weight:900}.rank-value small{display:block;color:#667085;font-size:11px}.gauge-list{display:grid;gap:14px}.gauge-card{display:grid;grid-template-columns:98px 1fr;gap:14px;align-items:center;border:1px solid var(--line);border-radius:18px;padding:14px;background:#fff}.gauge{width:92px;height:92px}.gauge:after{width:62px;height:62px}.gauge span{font-size:17px}.gauge-card strong{display:block}.gauge-card small{display:block;color:#667085;line-height:1.45;font-weight:700}.warn-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:5px 10px;font-weight:900;font-size:12px;background:#fffaeb;color:#b54708}.insight-panel{background:linear-gradient(180deg,#fff,#f8fbff)}.insight-list{padding-left:20px;color:#344054;line-height:1.65;font-weight:700}.insight-list li{margin-bottom:10px}.empty-box{padding:18px;border:1px dashed #d0d5dd;border-radius:18px;color:#667085;font-weight:800;background:#f9fafb;text-align:center}.dashboard-grid-3 .panel{min-width:0}@media(max-width:1200px){.dashboard-metrics{grid-template-columns:repeat(2,1fr)}.dashboard-grid-3{grid-template-columns:1fr}.span-2{grid-column:auto}.dashboard-hero{grid-template-columns:1fr}.hero-kpis{grid-template-columns:repeat(3,1fr)}}@media(max-width:760px){.dashboard-metrics{grid-template-columns:1fr}.dashboard-hero{padding:22px;border-radius:22px}.dashboard-hero h2{font-size:30px}.hero-kpis{grid-template-columns:1fr}.line-bars{gap:5px;height:220px}.rank-row{grid-template-columns:1fr;gap:8px}.rank-value{text-align:left}.gauge-card{grid-template-columns:1fr;text-align:center}.gauge{margin:auto}}
