:root{
  --primary:#222d31;
  --primary-2:#37393d;
  --primary-3:#4d5055;
  --primary-dark:#111618;
  --brand-green:#78ab46;
  --brand-green-dark:#6a9b3d;
  --brand-green-soft:#eef6e5;
  --accent:#d4d2ce;
  --bg:#f3f3f2;
  --surface:#ffffff;
  --surface-soft:#f7f7f6;
  --line:#d7d3ce;
  --line-strong:#c3beb8;
  --text:#111618;
  --muted:#4d5055;
  --muted-2:#6a6d72;
  --danger:#b8403b;
  --shadow:0 24px 60px rgba(17,22,24,.08);
  --shadow-soft:0 14px 36px rgba(17,22,24,.06);
  --radius-xl:28px;
  --radius-lg:20px;
  --radius-md:14px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:var(--bg)}
a{color:inherit}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}

.ss-shell{display:flex;min-height:100vh}
.ss-sidebar{width:298px;background:linear-gradient(180deg,var(--primary-dark) 0%,var(--primary) 100%);color:#fff;border-right:1px solid rgba(255,255,255,.08);position:sticky;top:0;height:100vh;overflow-y:auto;padding-bottom:18px}
.ss-main{flex:1;display:flex;flex-direction:column;min-width:0}
.ss-content{padding:28px}

.ss-topbar{height:76px;background:rgba(255,255,255,.84);backdrop-filter:blur(12px);border-bottom:1px solid rgba(195,190,184,.5);display:flex;align-items:center;justify-content:space-between;padding:0 20px;position:sticky;top:0;z-index:20}
.ss-topbar__left,.ss-topbar__right{display:flex;align-items:center;gap:14px}
.ss-topbar__title{display:flex;flex-direction:column;gap:3px}
.ss-topbar__eyebrow{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2)}
.ss-topbar__app{font-size:1rem;font-weight:800}
.ss-topbar__user{color:var(--muted);font-size:14px}
.ss-topbar__badge{padding:8px 12px;border-radius:999px;background:var(--brand-green-soft);color:var(--brand-green-dark);font-size:12px;font-weight:700;border:1px solid rgba(120,171,70,.18)}
.ss-burger{display:none;border:1px solid var(--line);background:#fff;border-radius:12px;padding:10px 12px;cursor:pointer;box-shadow:var(--shadow-soft)}

.ss-sidebar__brand{padding:24px 20px 18px;border-bottom:1px solid rgba(255,255,255,.08)}
.ss-brand__image{width:212px;max-width:100%;margin-bottom:14px}
.ss-brand__eyebrow{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.58);margin-bottom:6px}
.ss-brand__logo{font-size:1.6rem;font-weight:800;letter-spacing:-.03em}
.ss-brand__sub{color:rgba(255,255,255,.76);font-size:13px;line-height:1.5;margin-top:6px}

.ss-nav{padding:14px 12px}
.ss-nav__group{margin-top:6px}
.ss-nav__section{color:rgba(255,255,255,.52);font-size:11px;letter-spacing:.16em;text-transform:uppercase;margin:16px 10px 8px}
.ss-nav__item{display:flex;gap:12px;align-items:center;padding:12px 14px;border-radius:16px;color:#f4f7f4;text-decoration:none;margin:5px 0;transition:all .2s ease;border:1px solid transparent}
.ss-nav__item:hover{background:rgba(255,255,255,.06);transform:translateX(2px)}
.ss-nav__item--active{background:rgba(120,171,70,.18);border-color:rgba(120,171,70,.24)}
.ss-nav__item--danger{color:#ffd8d5}
.ss-nav__item--danger:hover{background:rgba(184,64,59,.18)}
.ss-ico{width:22px;text-align:center;opacity:.92}
.ss-nav__divider{height:1px;background:rgba(255,255,255,.08);margin:12px 8px}
.ss-sidebar__footer{margin:14px 16px 0;padding:16px;border-radius:18px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08)}
.ss-foot__label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:8px}
.ss-foot__name{font-weight:700;font-size:14px}
.ss-foot__role,.ss-foot__copy{color:rgba(255,255,255,.66);font-size:12px;margin-top:4px}


.ss-hero{display:flex;justify-content:space-between;gap:24px;align-items:stretch;background:linear-gradient(135deg,#fbfcfa 0%, #f5f7f2 55%, #f1f3ef 100%);border:1px solid var(--line);border-radius:var(--radius-xl);padding:30px;box-shadow:var(--shadow-soft);margin-bottom:24px}
.ss-hero--dashboard{position:relative;overflow:hidden}
.ss-hero--dashboard::after{content:"";position:absolute;right:-120px;top:-120px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(120,171,70,.14) 0%, rgba(120,171,70,0) 68%);pointer-events:none}
.ss-hero__content{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:space-between;gap:18px;min-width:0}
.ss-hero h1{margin:6px 0 10px;font-size:clamp(2rem,3vw,3rem);line-height:1.02;letter-spacing:-.05em;max-width:780px}
.ss-hero p{max-width:760px;color:var(--muted);margin:0;font-size:1rem;line-height:1.7}
.ss-kicker{display:inline-flex;padding:8px 12px;border-radius:999px;background:var(--brand-green-soft);color:var(--brand-green-dark);font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.ss-hero__actions{display:flex;gap:12px;flex-wrap:wrap}

.hero-insight{position:relative;z-index:1;flex:0 0 360px;display:flex;flex-direction:column;gap:18px;padding:22px;border-radius:24px;border:1px solid rgba(17,22,24,.08);background:rgba(255,255,255,.82);backdrop-filter:blur(8px);box-shadow:0 22px 48px rgba(17,22,24,.07)}
.hero-insight__top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.hero-insight__eyebrow{font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:800;color:var(--muted-2)}
.hero-insight__status{display:inline-flex;align-items:center;justify-content:center;min-height:32px;padding:0 12px;border-radius:999px;border:1px solid var(--line);font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.hero-insight__status--danger{background:#fff0ef;color:#a43f39;border-color:#ecc2bf}
.hero-insight__status--warning{background:#fff6e5;color:#8a6711;border-color:#ead29b}
.hero-insight__status--success{background:#eef6e5;color:#5e8b35;border-color:#cfe2bd}
.hero-insight__status--neutral{background:#f4f6f8;color:#52606d;border-color:#d9e0e5}
.hero-insight__value strong{display:block;font-size:3rem;line-height:.95;letter-spacing:-.07em;color:var(--primary)}
.hero-insight__value span{display:block;margin-top:6px;color:var(--muted);font-size:.95rem}
.hero-insight__copy{margin:0;color:var(--muted);line-height:1.6}
.hero-insight__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.hero-insight__mini{padding:14px 16px;border-radius:18px;background:var(--surface-soft);border:1px solid var(--line)}
.hero-insight__mini span{display:block;font-size:.86rem;color:var(--muted);margin-bottom:6px}
.hero-insight__mini strong{display:block;font-size:1.45rem;line-height:1;color:var(--primary)}

.stats-grid,.ss-grid-2,.info-grid,.diagnostic-intro,.dashboard-main-grid{display:grid;gap:18px}
.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:22px}
.stats-grid--dashboard{margin-bottom:24px}
.ss-grid-2{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:22px}
.dashboard-main-grid{grid-template-columns:minmax(0,1.45fr) minmax(320px,.95fr);margin-bottom:22px}
.info-grid{grid-template-columns:repeat(4,minmax(0,1fr));margin-top:14px}
.diagnostic-intro{grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:22px}

.stat-card,.card,.info-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft)}
.stat-card{padding:22px}
.stat-card--premium{padding:24px;background:linear-gradient(180deg,#ffffff 0%, #fbfbfa 100%)}
.stat-card strong{display:block;font-size:2.2rem;line-height:1;margin:12px 0 8px;letter-spacing:-.06em}
.stat-card small,.stat-card__label,.table-meta,.empty-state,.section-head__copy,.list-item span,.ss-form-copy,.diagnostic-item__desc{color:var(--muted)}
.stat-card__label{font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}
.stat-card--accent{background:linear-gradient(135deg,var(--brand-green-soft),#f7fbf1)}
.card{padding:24px}
.card--premium{padding:26px}
.card--soft{background:linear-gradient(180deg,var(--surface),var(--surface-soft))}
.card--highlight{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:#fff;border-color:rgba(17,22,24,.15)}
.card--highlight .section-head__eyebrow,.card--highlight h2,.card--highlight li{color:#fff}
.card--highlight-soft{background:linear-gradient(180deg,#ffffff 0%, #f8faf6 100%)}
.card--activities{margin-top:22px}
.card--login{padding:28px}
.form-card{max-width:900px}

.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}
.section-head--spread{align-items:flex-end}
.section-head--tight{margin-bottom:20px}
.section-head h2{margin:4px 0 0;font-size:1.55rem;letter-spacing:-.04em}
.section-head__eyebrow,.ss-form-brand{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--brand-green-dark);font-weight:800}
.section-head__copy{margin:8px 0 0;max-width:700px;line-height:1.65}
.section-summary{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;background:var(--surface-soft);border:1px solid var(--line);font-size:.83rem;font-weight:800;color:var(--primary)}

.list-stack{display:flex;flex-direction:column;gap:12px}
.list-stack--premium{gap:14px}
.list-item{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 18px;border-radius:18px;border:1px solid var(--line);background:var(--surface-soft);text-decoration:none;transition:all .18s ease}
.list-item--premium{padding:18px 20px;background:linear-gradient(180deg,#fff 0%, #fafaf9 100%);border-color:#ddd8d2}
.list-item:hover{background:#f7f9fa;transform:translateY(-2px);box-shadow:var(--shadow-soft);cursor:pointer}
.list-item--static:hover{transform:none;cursor:default}
.list-item__content{min-width:0}
.list-item strong{display:block;margin-bottom:4px}
.list-pill,.list-score{display:inline-flex;align-items:center;justify-content:center;min-height:36px;padding:0 12px;border-radius:999px;border:1px solid var(--line);font-size:.82rem;font-weight:800;background:#fff;color:var(--primary);white-space:nowrap}
.list-score{background:var(--brand-green-soft);border-color:#cfe2bd;color:var(--brand-green-dark)}

.dashboard-alerts{display:grid;gap:14px;margin:0 0 24px}
.dashboard-alerts--premium{grid-template-columns:repeat(4,minmax(0,1fr))}
.dashboard-alert{display:flex;gap:14px;align-items:flex-start;padding:18px;border-radius:20px;border:1px solid var(--line);background:linear-gradient(180deg,#ffffff 0%, #fafaf9 100%);box-shadow:var(--shadow-soft);transition:all .18s ease}
.dashboard-alert:hover{transform:translateY(-2px);box-shadow:0 18px 36px rgba(17,22,24,.07)}
.dashboard-alert__icon{flex:0 0 42px;width:42px;height:42px;border-radius:14px;background:var(--surface-soft);border:1px solid var(--line);position:relative}
.dashboard-alert__icon::before{content:"";position:absolute;inset:50% auto auto 50%;width:12px;height:12px;border-radius:50%;transform:translate(-50%,-50%);background:currentColor}
.dashboard-alert__body{min-width:0}
.dashboard-alert__body small{display:block;margin-bottom:6px;font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2)}
.dashboard-alert strong{display:block;color:var(--primary);font-size:15px;font-weight:800;line-height:1.35;margin-bottom:6px}
.dashboard-alert span{display:block;color:var(--muted);font-size:14px;line-height:1.55}
.dashboard-alert--danger{background:#fff4f3;border-color:#ecc2bf;color:#a43f39}
.dashboard-alert--warning{background:#fff8ea;border-color:#ead29b;color:#9a6a00}
.dashboard-alert--neutral{background:#f6f8fa;border-color:#d9e0e5;color:#52606d}
.dashboard-alert--success{background:#f1f7eb;border-color:#cfe2bd;color:#5e8b35}

.metric-caption{display:block;font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);margin-bottom:10px}
.dash-progress-card{display:flex;flex-direction:column;gap:16px}
.dash-progress-card--premium{gap:18px}
.dash-progress-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.dash-progress-card__top strong{font-size:2.6rem;line-height:.95;color:var(--primary);letter-spacing:-.06em}
.dash-progress-card__tag{display:inline-flex;align-items:center;justify-content:center;min-height:36px;padding:0 12px;border-radius:999px;font-size:.8rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;border:1px solid var(--line)}
.dash-progress-card__tag.is-danger{background:#faebea;border-color:#e3b1ad;color:#a33a32}
.dash-progress-card__tag.is-warning{background:#f8f3e8;border-color:#e9d19a;color:#9a6a00}
.dash-progress-card__tag.is-success{background:#edf6e5;border-color:#b9d79b;color:#4d7a22}
.dash-progress{width:100%;height:14px;border-radius:999px;overflow:hidden;background:#ece9e4}
.dash-progress--sm{height:10px}
.dash-progress__bar{height:100%;border-radius:999px}
.dash-progress__bar.is-danger{background:#c43d2f}
.dash-progress__bar.is-warning{background:#c48a2f}
.dash-progress__bar.is-success{background:#78ab46}
.dash-progress__bar.is-neutral{background:#62707a}
.dash-progress-card__legend{display:flex;justify-content:space-between;font-size:.8rem;color:var(--muted)}
.dash-mini-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.dash-mini-card{background:var(--surface-soft);border:1px solid var(--line);border-radius:18px;padding:16px}
.dash-mini-card span{display:block;color:var(--muted);font-size:.9rem;margin-bottom:6px}
.dash-mini-card strong{font-size:1.6rem;line-height:1;color:var(--primary)}

.insight-list{display:grid;gap:12px}
.insight-row{padding:16px 18px;border-radius:18px;background:#fff;border:1px solid var(--line)}
.insight-row strong{display:block;font-size:1.8rem;line-height:1;color:var(--primary);letter-spacing:-.05em;margin-bottom:6px}
.insight-row span{display:block;color:var(--muted);line-height:1.45}
.insight-row--danger{background:#fff4f3;border-color:#ecc2bf}

.risk-item{border:1px solid var(--line);background:var(--surface-soft);border-radius:18px;padding:14px 16px}
.risk-item__head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}
.risk-item__head strong{display:block;margin-bottom:4px}
.risk-item__head span{color:var(--muted);font-size:.92rem}
.risk-item__head small{font-weight:800;color:var(--primary)}

.activity-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:6px}
.activity-grid--premium{grid-template-columns:repeat(2,minmax(0,1fr))}
.activity-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:20px;transition:.18s ease}
.activity-card--premium{background:linear-gradient(180deg,#ffffff 0%, #fbfbfa 100%);border-color:#ddd8d2}
.activity-card:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(0,0,0,.08)}
.activity-card__head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}
.activity-card__title{min-width:0}
.activity-card__title h3{margin:0 0 8px;color:var(--primary);font-size:1.32rem;line-height:1.12;letter-spacing:-.03em}
.activity-card__title p{margin:0;color:var(--muted);font-size:14px;line-height:1.55}
.activity-card__status{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 14px;border-radius:999px;font-size:.78rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;border:1px solid var(--line);background:var(--surface-soft);color:var(--primary)}
.activity-card__status--pendiente{background:#fff3dd;color:#8a6711;border-color:#f0ddab}
.activity-card__status--en_curso{background:#e7f0ff;color:#2d5e9b;border-color:#c9daf4}
.activity-card__status--completado{background:var(--brand-green-soft);color:var(--brand-green-dark);border-color:#cfe2bd}
.activity-card__status--atrasado{background:#fff0ef;color:#a43f39;border-color:#ecc2bf}
.activity-card__status--neutral{background:#f1f0ed;color:var(--muted);border-color:#dfd9d1}
.activity-card__description{margin:0 0 16px;color:var(--muted);line-height:1.65;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.activity-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.activity-meta__item{padding:14px 15px;border-radius:16px;background:var(--surface-soft);border:1px solid var(--line)}
.activity-meta__item span{display:block;font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);margin-bottom:7px}
.activity-meta__item strong{display:block;font-size:15px;line-height:1.35;color:var(--primary)}
.activity-progress{width:100%;height:10px;border-radius:999px;overflow:hidden;background:#ece9e4;margin-top:16px}
.activity-progress__bar{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--brand-green),var(--brand-green-dark))}


.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:14px;padding:13px 18px;border:1px solid transparent;text-decoration:none;font-weight:800;cursor:pointer;transition:all .2s ease;min-height:48px}
.btn--primary{background:var(--brand-green);color:#fff;box-shadow:0 12px 24px rgba(120,171,70,.24)}
.btn--primary:hover{background:var(--brand-green-dark);transform:translateY(-1px)}
.btn--ghost{background:var(--surface);color:var(--primary);border-color:var(--line)}
.btn--ghost:hover{background:var(--surface-soft)}
.btn--auto{width:auto}
.btn--save{width:100%;min-height:48px;border:none;border-radius:16px;background:var(--brand-green);color:#fff;font-weight:800;font-size:16px;cursor:pointer;box-shadow:0 14px 28px rgba(120,171,70,.18)}
.btn--save:hover{background:var(--brand-green-dark)}

label{display:block;margin:0 0 8px;font-size:14px;font-weight:700;color:var(--primary)}
input,select,textarea{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:14px;background:#fff;color:var(--text);outline:none;transition:border-color .2s ease, box-shadow .2s ease}
input:focus,select:focus,textarea:focus{border-color:var(--brand-green);box-shadow:0 0 0 4px rgba(120,171,70,.12)}
.ss-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.ss-form-grid .ss-actions-row,.ss-form-grid .btn{grid-column:1 / -1}
.alert{padding:14px 16px;border-radius:14px;margin-bottom:16px;border:1px solid transparent}
.alert--error{background:#fff1f0;border-color:#f2c9c6;color:#932f2c}
.alert--success{background:#f1f7eb;border-color:#cfe2bd;color:#4d7a22}

.table-wrap{width:100%;overflow-x:auto;border:1px solid var(--line);border-radius:22px;background:var(--surface)}
.ss-table{width:100%;min-width:1200px;border-collapse:separate;border-spacing:0;background:#fff}
.ss-table thead th{background:var(--surface-soft);font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-2);padding:14px 16px;text-align:left;border-bottom:1px solid var(--line);white-space:nowrap}
.ss-table tbody td{padding:16px;border-bottom:1px solid #ece8e3;vertical-align:top}
.ss-table tbody tr:hover{background:#fcfcfb}
.ss-table tbody tr:last-child td{border-bottom:none}
.ss-table td strong{display:block;color:var(--primary);font-size:16px;line-height:1.35;margin-bottom:6px}
.ss-table select,.ss-table input[type="number"],.ss-table input[type="text"]{width:100%;min-width:0;height:48px;border:1px solid var(--line-strong);border-radius:16px;background:#fff;padding:0 14px;font-size:15px;color:var(--text)}
.ss-table input[type="number"]{max-width:90px}
.actions-inline{display:flex;flex-wrap:wrap;gap:10px}
.actions-inline a{font-weight:700;color:var(--brand-green-dark);text-decoration:none}
.actions-inline a:hover{text-decoration:underline}

.cell-title{min-width:260px}
.cell-state{min-width:150px}
.cell-avance{min-width:110px}
.cell-priority{min-width:150px}
.cell-dates{min-width:130px;font-size:14px;line-height:1.5;color:var(--text)}
.cell-evidence{min-width:220px}
.cell-observations{min-width:220px}
.cell-action{min-width:140px}

.badge{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.04em;border:1px solid transparent}
.badge--pendiente{background:#fff3dd;color:#8a6711;border-color:#f0ddab}
.badge--en_curso{background:#e7f0ff;color:#2d5e9b;border-color:#c9daf4}
.badge--completado{background:var(--brand-green-soft);color:var(--brand-green-dark);border-color:#cfe2bd}
.badge--atrasado{background:#fff0ef;color:#a43f39;border-color:#ecc2bf}
.badge--neutral{background:#f1f0ed;color:var(--muted);border-color:#dfd9d1}
.badge--success{background:var(--brand-green-soft);color:var(--brand-green-dark);border-color:#cfe2bd}
.badge--warning{background:#fff3dd;color:#8a6711;border-color:#f0ddab}
.badge--danger{background:#fff0ef;color:#a43f39;border-color:#ecc2bf}

.metric-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}
.metric-card{padding:16px;border:1px solid var(--line);border-radius:18px;background:var(--surface-soft)}
.metric-card span{display:block;font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);margin-bottom:8px}
.metric-card strong{display:block;font-size:1.7rem;line-height:1;color:var(--primary);letter-spacing:-.04em}
.muted{color:var(--muted);line-height:1.5}
.span-2{grid-column:span 2}

.info-card{padding:18px}
.info-card span{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted-2);margin-bottom:10px}
.info-card strong{font-size:1rem;line-height:1.5}
.ss-actions-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.empty-state{line-height:1.7}
.feature-points{margin:12px 0 0;padding-left:20px;line-height:1.8}

.diagnostic-form{display:flex;flex-direction:column;gap:16px}
.diagnostic-item{padding:18px;border:1px solid var(--line);border-radius:18px;background:var(--surface-soft)}
.diagnostic-item__head{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:8px}
.diagnostic-item__code{font-weight:800;color:var(--primary)}
.diagnostic-item__weight{font-size:12px;padding:7px 10px;border-radius:999px;background:#fff;border:1px solid var(--line);color:var(--muted)}
.diagnostic-item__desc{margin:0 0 14px;line-height:1.6}

.ss-login{min-height:100vh;display:grid;grid-template-columns:minmax(0,1.15fr) minmax(420px,520px);background:radial-gradient(circle at top left,#fdfefd 0%, #eef6e5 40%, #f3f3f2 100%)}
.ss-login__panel{padding:48px;display:flex;flex-direction:column;justify-content:center}
.ss-login__logo{width:min(430px,100%);margin-bottom:24px}
.ss-login__eyebrow{display:inline-flex;margin-bottom:14px;padding:9px 14px;border-radius:999px;background:rgba(120,171,70,.12);color:var(--brand-green-dark);font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;width:max-content}
.ss-login h1{font-size:clamp(2.1rem,4vw,4.2rem);line-height:.96;letter-spacing:-.05em;margin:0 0 18px;max-width:760px}
.ss-login p{color:var(--muted);font-size:1.05rem;line-height:1.75;max-width:680px;margin:0}
.ss-login__panel--form{background:rgba(255,255,255,.72);border-left:1px solid rgba(195,190,184,.4);backdrop-filter:blur(8px)}
.ss-feature-list{display:grid;gap:14px;margin-top:28px;max-width:700px}
.ss-feature-item{padding:18px 20px;border-radius:20px;background:rgba(255,255,255,.72);border:1px solid rgba(195,190,184,.45);box-shadow:var(--shadow-soft)}
.ss-feature-item strong{display:block;margin-bottom:6px;font-size:1rem}
.ss-feature-item span{color:var(--muted);line-height:1.6}
.ss-public-shell{padding:0}

.evidence-link{display:inline-flex;align-items:center;gap:8px;margin-bottom:10px;font-weight:700;color:var(--brand-green-dark);text-decoration:none}
.evidence-link:hover{text-decoration:underline}
.file-upload{display:flex;flex-direction:column;gap:10px}
.file-upload__input{display:none}
.file-upload__label{display:inline-flex;align-items:center;justify-content:center;height:44px;padding:0 16px;border-radius:14px;border:1px solid var(--line-strong);background:var(--surface-soft);color:var(--primary);font-weight:700;cursor:pointer;transition:.2s ease}
.file-upload__label:hover{background:var(--brand-green-soft);border-color:var(--brand-green)}
.file-upload__name{font-size:13px;color:var(--muted);line-height:1.4;word-break:break-word}

.dash-progress-card{display:flex;flex-direction:column;gap:14px}
.dash-progress-card__top{display:flex;align-items:center;justify-content:space-between;gap:12px}
.dash-progress-card__top strong{font-size:2.3rem;line-height:1;color:var(--primary)}
.dash-progress-card__tag{display:inline-flex;align-items:center;justify-content:center;min-height:36px;padding:0 12px;border-radius:999px;font-size:.8rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;border:1px solid var(--line)}
.dash-progress-card__tag.is-danger{background:#faebea;border-color:#e3b1ad;color:#a33a32}
.dash-progress-card__tag.is-warning{background:#f8f3e8;border-color:#e9d19a;color:#9a6a00}
.dash-progress-card__tag.is-success{background:#edf6e5;border-color:#b9d79b;color:#4d7a22}
.dash-progress{width:100%;height:14px;border-radius:999px;overflow:hidden;background:#ece9e4}
.dash-progress--sm{height:10px}
.dash-progress__bar{height:100%;border-radius:999px}
.dash-progress__bar.is-danger{background:#c43d2f}
.dash-progress__bar.is-warning{background:#c48a2f}
.dash-progress__bar.is-success{background:#78ab46}
.dash-progress-card__legend{display:flex;justify-content:space-between;font-size:.8rem;color:var(--muted)}
.dash-mini-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.dash-mini-card{background:var(--surface-soft);border:1px solid var(--line);border-radius:18px;padding:16px}
.dash-mini-card span{display:block;color:var(--muted);font-size:.9rem;margin-bottom:6px}
.dash-mini-card strong{font-size:1.6rem;line-height:1;color:var(--primary)}

@media (max-width: 1320px){
  .dashboard-alerts--premium{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (max-width: 1200px){
  .stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .ss-grid-2,.info-grid,.diagnostic-intro,.dashboard-main-grid{grid-template-columns:1fr}
  .ss-login{grid-template-columns:1fr}
  .ss-login__panel--form{border-left:0;border-top:1px solid rgba(195,190,184,.4)}
}

@media (max-width: 980px){
  .ss-burger{display:inline-flex}
  .ss-sidebar{position:fixed;left:0;top:0;transform:translateX(-105%);transition:transform .2s ease;z-index:50;width:290px}
  body.ss-sidebar-open .ss-sidebar{transform:translateX(0)}
  body.ss-sidebar-open::before{content:"";position:fixed;inset:0;background:rgba(17,22,24,.38);z-index:40}
  .ss-content{padding:20px}
  .ss-hero{flex-direction:column;align-items:flex-start}
  .hero-insight{width:100%;flex:1 1 auto}
  .ss-form-grid{grid-template-columns:1fr}
}

@media (max-width: 900px){
  .activity-grid,.activity-grid--premium,.dashboard-alerts--premium{grid-template-columns:1fr}
}

@media (max-width: 860px){
  .dash-progress-card__top,
  .risk-item__head,
  .activity-card__head,
  .hero-insight__top{
    flex-direction:column;
    align-items:flex-start;
  }

  .dash-mini-grid,
  .hero-insight__grid,
  .activity-meta{grid-template-columns:1fr}
}

@media (max-width: 680px){
  .stats-grid{grid-template-columns:1fr}
  .ss-topbar{padding:0 14px;height:70px}
  .ss-topbar__badge{display:none}
  .ss-login__panel{padding:28px 20px}
  .ss-login h1{font-size:2.3rem}
  .ss-hero,.card,.stat-card,.hero-insight{padding:20px}
}


/* ===================== DASHBOARD ESTRUCTURADO ===================== */
.dashboard-shell{display:flex;flex-direction:column;gap:24px}
.card--dashboard-header,
.card--dashboard-panel,
.card--activities-board{padding:24px 26px;border-radius:24px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-soft)}
.dashboard-header{display:flex;align-items:flex-start;justify-content:space-between;gap:24px}
.dashboard-header h1{margin:6px 0 10px;font-size:clamp(2rem,3vw,2.6rem);line-height:1.02;letter-spacing:-.04em;color:var(--primary)}
.dashboard-header__text{margin:0;max-width:760px;color:var(--muted);line-height:1.65}
.dashboard-header__actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}

.dashboard-kpi-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:16px}
.kpi-card{padding:20px;border-radius:22px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-soft);min-height:148px;display:flex;flex-direction:column;justify-content:space-between}
.kpi-card__label{display:block;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);font-weight:800}
.kpi-card__value{display:block;margin:10px 0 8px;font-size:2rem;line-height:1;color:var(--primary)}
.kpi-card__text{margin:0;color:var(--muted);line-height:1.5;font-size:.95rem}
.kpi-card--danger{background:#fff6f5;border-color:#f1d1cd}
.kpi-card--warning{background:#fffaf1;border-color:#eadab5}
.kpi-card--success{background:#f5faef;border-color:#d4e5c0}
.kpi-card--neutral{background:var(--surface)}

.dashboard-grid-primary{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(340px,.95fr);gap:20px}
.dashboard-grid-secondary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}
.status-chip{display:inline-flex;align-items:center;justify-content:center;padding:9px 12px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--line);background:var(--surface-soft);color:var(--muted)}
.status-chip--danger{background:#fff1ef;border-color:#edc4bf;color:#a73b32}
.status-chip--warning{background:#fff8ea;border-color:#ead39d;color:#9a6a00}
.status-chip--success{background:#eff7e8;border-color:#c9ddaf;color:#557f2c}

.dashboard-score-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:8px}
.dashboard-score-card{padding:18px;border-radius:20px;background:var(--surface-soft);border:1px solid var(--line)}
.dashboard-score-card span{display:block;color:var(--muted);font-size:.92rem;margin-bottom:8px}
.dashboard-score-card strong{display:block;font-size:1.9rem;line-height:1;color:var(--primary)}
.dashboard-progress-block{margin-top:18px;padding:18px;border-radius:20px;background:#fcfcfb;border:1px solid var(--line)}
.dashboard-progress-labels{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.dashboard-progress-labels span{color:var(--muted);font-size:.94rem}
.dashboard-progress-labels strong{font-size:1.1rem;color:var(--primary)}
.dash-progress--lg{height:14px}
.distribution-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:18px}
.distribution-item{padding:16px;border-radius:18px;background:var(--surface-soft);border:1px solid var(--line)}
.distribution-item span{display:block;font-size:.9rem;color:var(--muted);margin-bottom:8px}
.distribution-item strong{display:block;font-size:1.5rem;line-height:1;color:var(--primary)}

.focus-list{display:flex;flex-direction:column;gap:14px;margin-top:6px}
.focus-item{display:grid;grid-template-columns:14px minmax(0,1fr);gap:14px;padding:16px 18px;border-radius:18px;border:1px solid var(--line);background:var(--surface-soft)}
.focus-item__dot{width:10px;height:10px;border-radius:999px;background:#c7c2bc;margin-top:6px}
.focus-item strong{display:block;margin-bottom:6px;color:var(--primary)}
.focus-item p{margin:0;color:var(--muted);line-height:1.55}
.focus-item--danger{background:#fff6f5;border-color:#f1d1cd}
.focus-item--danger .focus-item__dot{background:#c43d2f}
.focus-item--warning{background:#fffaf1;border-color:#eadab5}
.focus-item--warning .focus-item__dot{background:#c48a2f}
.focus-item--success{background:#f5faef;border-color:#d4e5c0}
.focus-item--success .focus-item__dot{background:#78ab46}
.summary-grid--compact{margin-top:18px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.summary-mini-card{padding:16px;border-radius:18px;border:1px solid var(--line);background:var(--surface)}
.summary-mini-card span{display:block;font-size:.85rem;color:var(--muted);margin-bottom:8px}
.summary-mini-card strong{display:block;font-size:1.2rem;color:var(--primary);line-height:1.3}

.activities-counter-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.counter-chip{display:inline-flex;align-items:center;justify-content:center;padding:9px 12px;border-radius:999px;font-size:12px;font-weight:800;border:1px solid var(--line);background:var(--surface-soft);color:var(--muted)}
.counter-chip--warning{background:#fff8ea;border-color:#ead39d;color:#9a6a00}
.counter-chip--danger{background:#fff1ef;border-color:#edc4bf;color:#a73b32}
.activity-grid--executive{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.activity-card--executive{padding:20px;border-radius:22px;border:1px solid var(--line);background:var(--surface);box-shadow:none}
.activity-card--executive .activity-card__description{margin:14px 0 0;color:var(--muted);line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:48px}
.activity-data-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:16px}
.activity-data-item{padding:14px;border-radius:16px;background:var(--surface-soft);border:1px solid var(--line)}
.activity-data-item span{display:block;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-2);font-weight:800;margin-bottom:8px}
.activity-data-item strong{display:block;font-size:.98rem;line-height:1.4;color:var(--primary)}
.activity-progress-block{margin-top:16px;padding-top:2px}
.activity-progress-block__top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.activity-progress-block__top span{color:var(--muted);font-size:.92rem}
.activity-progress-block__top strong{color:var(--primary)}

@media (max-width: 1480px){
  .dashboard-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .activity-grid--executive{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 1200px){
  .dashboard-grid-primary,.dashboard-grid-secondary{grid-template-columns:1fr}
  .distribution-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 900px){
  .dashboard-header{flex-direction:column;align-items:flex-start}
  .dashboard-kpi-grid,.dashboard-score-row,.summary-grid--compact,.activity-grid--executive{grid-template-columns:1fr}
  .activity-data-grid{grid-template-columns:1fr}
}
@media (max-width: 680px){
  .card--dashboard-header,.card--dashboard-panel,.card--activities-board{padding:20px}
  .dashboard-header h1{font-size:1.9rem}
  .distribution-grid{grid-template-columns:1fr}
}
/* ============================= */
/* 📎 UPLOAD PREMIUM */
/* ============================= */

.ss-file-upload__input {
  display: none !important;
}

.ss-file-dropzone {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  padding: 18px;
  border: 1px dashed #cfe0bb;
  border-radius: 16px;
  background: #fbfdf8;
  transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.ss-file-dropzone.is-dragover {
  background: #f1f8e8;
  border-color: #99c25a;
  box-shadow: 0 0 0 4px rgba(127, 176, 67, 0.08);
}

.ss-file-upload__trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: flex-start;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 12px;
  background: #eaf4df;
  color: #5f8f2f;
  font-weight: 600;
  font-size: 13px;
  border: 1px solid #d6e8c2;
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.2s ease;
}

.ss-file-upload__trigger:hover {
  background: #dff0c9;
  color: #4e7a27;
}

.ss-file-dropzone__content {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ss-file-dropzone__content strong {
  font-size: 13px;
  color: #2c3e50;
}

.ss-file-dropzone__content span {
  font-size: 12px;
  color: #7f8c8d;
}

.ss-file-upload__label {
  font-size: 12px;
  color: #6f7a83;
  word-break: break-word;
}

.ss-file-upload__help {
  display: block;
  margin-top: 8px;
  font-size: 11px;
  color: #98a1a8;
}
