:root{
  --bg:#f5f7fb;
  --bg-soft:#eef2f7;
  --panel:#ffffff;
  --panel-2:#fcfcfe;
  --line:#e5e7eb;
  --line-strong:#d1d5db;
  --text:#1f2937;
  --muted:#6b7280;
  --primary:#7a164b;
  --primary-2:#a61f66;
  --accent:#c23b7a;
  --accent-soft:#fae8f0;
  --success:#15803d;
  --success-soft:#eaf7ef;
  --warning:#b45309;
  --warning-soft:#fff4e5;
  --danger:#b42318;
  --danger-soft:#fff1f2;
  --info:#1d4ed8;
  --info-soft:#eff6ff;
  --radius:22px;
  --shadow:0 12px 36px rgba(15,23,42,.08);
  --shadow-soft:0 4px 18px rgba(15,23,42,.05);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,Segoe UI,Arial,sans-serif;
  background:
    radial-gradient(circle at top right, rgba(194,59,122,.08), transparent 26%),
    radial-gradient(circle at top left, rgba(122,22,75,.05), transparent 20%),
    linear-gradient(180deg,#fbfcfe 0%, var(--bg) 100%);
  color:var(--text);
  line-height:1.5;
}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}
.container{width:min(1240px,calc(100% - 2rem));margin:0 auto}
.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(122,22,75,.08);
  box-shadow:0 4px 18px rgba(15,23,42,.04);
}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:14px 0}
.brand{display:flex;align-items:center;gap:16px}
.brand img{height:50px;width:auto;filter:drop-shadow(0 3px 10px rgba(122,22,75,.12))}
.brand h1{font-size:1.12rem;margin:0;color:#4b1230}
.brand p{margin:.15rem 0 0;color:var(--muted);font-size:.93rem;max-width:58ch}
.top-actions{display:flex;gap:.75rem;flex-wrap:wrap}
.hero{padding:30px 0 16px}
.hero-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:1.2rem;align-items:stretch}
.panel{
  background:linear-gradient(180deg,var(--panel),var(--panel-2));
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:24px;
}
.hero-card{
  background:
    linear-gradient(135deg, rgba(122,22,75,.04), rgba(194,59,122,.03) 42%, rgba(255,255,255,.95)),
    linear-gradient(180deg,var(--panel),var(--panel-2));
}
.hero-card h2{font-size:clamp(1.8rem,3vw,3rem);line-height:1.1;margin:.35rem 0 1rem;color:#3f1129}
.hero-card p{color:#4b5563;font-size:1.03rem}
.mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:18px}
.mini-stat{
  padding:16px;border-radius:18px;background:linear-gradient(180deg,#fff,#fbfbfd);
  border:1px solid var(--line);box-shadow:var(--shadow-soft)
}
.mini-stat strong{display:block;font-size:1.35rem;color:var(--primary)}
.notice{
  background:linear-gradient(180deg,#fff,#fcf7fa);
  padding:18px;border-radius:18px;border:1px solid #f0d7e4;
  border-left:5px solid var(--accent);
}
.badge{
  display:inline-flex;align-items:center;padding:.38rem .78rem;border-radius:999px;
  background:var(--accent-soft);color:#8a1f54;font-size:.84rem;font-weight:700;border:1px solid #f3d0df
}
.button,.btn{
  appearance:none;border:none;border-radius:999px;
  background:linear-gradient(90deg,var(--primary),var(--primary-2));
  color:#fff;padding:12px 18px;font-weight:700;cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;gap:.5rem;box-shadow:0 8px 20px rgba(122,22,75,.18);
  transition:transform .15s ease, box-shadow .15s ease, opacity .15s ease;
}
.button:hover,.btn:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(122,22,75,.24);text-decoration:none}
.btn-secondary{
  background:#fff;color:var(--primary);border:1px solid rgba(122,22,75,.18);box-shadow:none
}
.btn-ghost{background:#fff;color:var(--text);border:1px solid var(--line);box-shadow:none}
.form-shell{padding:10px 0 40px}
.stepper{display:grid;grid-template-columns:repeat(8,1fr);gap:10px;margin-bottom:18px}
.step{
  padding:14px 10px;border-radius:18px;background:#fff;border:1px solid var(--line);
  font-size:.9rem;text-align:center;color:var(--muted);font-weight:600;box-shadow:var(--shadow-soft)
}
.step.active{background:linear-gradient(180deg,#fff1f7,#ffe9f2);border-color:#f2bfd5;color:#8a1f54}
.step.done{background:var(--success-soft);border-color:#b7e0c1;color:var(--success)}
.form-step{display:none}
.form-step.active{display:block}
.section-title{margin-top:0;margin-bottom:.4rem;font-size:1.45rem;color:#4b1230}
.section-help{color:var(--muted);margin-top:-4px;margin-bottom:18px}
.grid{display:grid;gap:16px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
label{display:block;margin-bottom:6px;font-weight:650;color:#374151}
input,select,textarea{
  width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--line-strong);
  background:#fff;color:var(--text);transition:border-color .15s ease, box-shadow .15s ease, background .15s ease
}
input::placeholder,textarea::placeholder{color:#9ca3af}
input[type=file]{padding:10px;background:#fff}
textarea{min-height:110px;resize:vertical}
input:hover,select:hover,textarea:hover{border-color:#c4c9d1}
input:focus,select:focus,textarea:focus,button:focus,.btn:focus,a:focus{
  outline:none;border-color:#c23b7a;box-shadow:0 0 0 4px rgba(194,59,122,.14)
}
.help,.hint,.muted{font-size:.9rem;color:var(--muted)}
.field-card{
  padding:16px;border-radius:18px;background:linear-gradient(180deg,#fff,#fbfbfd);
  border:1px solid var(--line);box-shadow:var(--shadow-soft)
}
.inline{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.radio-group{display:flex;gap:16px;flex-wrap:wrap}
.radio-group label,.inline label{display:flex;gap:8px;align-items:center;font-weight:500}
.actions{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:24px}
.accordion details{background:#fff;border:1px solid var(--line);border-radius:18px;padding:10px 16px;margin-bottom:12px;box-shadow:var(--shadow-soft)}
.accordion summary{cursor:pointer;font-weight:700;padding:8px 0;color:#4b1230}
.alert{padding:16px 18px;border-radius:18px;border:1px solid var(--line);background:#fff}
.alert.success{border-color:#b7e0c1;background:var(--success-soft);color:#14532d}
.alert.error{border-color:#fecdd3;background:var(--danger-soft);color:#881337}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.kpi{
  padding:18px;border-radius:20px;background:linear-gradient(180deg,#fff,#fbfbfd);
  border:1px solid var(--line);box-shadow:var(--shadow-soft)
}
.kpi strong{display:block;color:var(--muted);font-size:.9rem}
.kpi div{font-size:1.8rem;font-weight:800;margin-top:6px;color:#4b1230}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:18px;background:#fff}
table{width:100%;border-collapse:collapse;background:#fff}
th,td{padding:12px 14px;border-bottom:1px solid #edf0f3;text-align:left;vertical-align:top}
th{background:#faf7f9;color:#4b1230;font-weight:700}
tr:hover td{background:#fcfbfd}
.status{display:inline-flex;padding:.35rem .65rem;border-radius:999px;font-size:.82rem;font-weight:700;border:1px solid transparent}
.status-recibida{background:var(--accent-soft);color:#8a1f54;border-color:#f3d0df}
.status-en_revision,.status-observada{background:var(--warning-soft);color:#9a3412;border-color:#fed7aa}
.status-aprobada,.status-acreditada{background:var(--success-soft);color:#166534;border-color:#b7e0c1}
.status-rechazada{background:var(--danger-soft);color:#b42318;border-color:#fecdd3}
.admin-layout{display:grid;grid-template-columns:340px 1fr;gap:18px}
.admin-sidebar{position:sticky;top:82px;height:calc(100vh - 110px);overflow:auto}
.list-group{display:grid;gap:10px}.list-item{padding:14px;border-radius:16px;background:#fff;border:1px solid var(--line);cursor:pointer;box-shadow:var(--shadow-soft)}
.list-item.active{outline:2px solid rgba(194,59,122,.35);background:#fff8fb}
.chart-box{height:300px}
pre{background:#fafbfc;border:1px solid var(--line);padding:14px;border-radius:14px;color:var(--text)}
hr{border:none;border-top:1px solid var(--line)}
footer{padding:28px 0 40px;color:var(--muted);font-size:.9rem}
@media (max-width:1100px){
  .hero-grid,.admin-layout,.grid-4,.grid-3,.grid-2,.kpis,.stepper{grid-template-columns:1fr}
  .admin-sidebar{position:static;height:auto}
  .mini-grid{grid-template-columns:1fr}
}

.form-toolbar{display:flex;justify-content:space-between;gap:16px;align-items:center;flex-wrap:wrap;margin:0 0 22px}
.progress-wrap{flex:1 1 420px}
.progress-meta{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:8px;color:#4b1230}
.progress-bar{height:12px;border-radius:999px;background:#f4dfe9;overflow:hidden;border:1px solid #efcddd}
.progress-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--primary),var(--accent));transition:width .25s ease}
.file-feedback{margin-top:8px;padding:10px 12px;border-radius:12px;background:#fff7fb;border:1px solid #f0d7e4;color:#8a1f54;font-size:.9rem}
.file-feedback.ok{background:var(--success-soft);border-color:#b7e0c1;color:#166534}
.file-feedback.error{background:var(--danger-soft);border-color:#fecdd3;color:#9f1239}
.summary-card{margin-top:18px;padding:18px;border-radius:20px;background:linear-gradient(180deg,#fff,#fcfbfd);border:1px solid var(--line);box-shadow:var(--shadow-soft)}
.summary-header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;flex-wrap:wrap;margin-bottom:14px}
.summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.summary-item{padding:14px;border-radius:16px;background:#fff;border:1px solid var(--line)}
.summary-item strong{display:block;font-size:.88rem;color:var(--muted);margin-bottom:4px}
.btn[disabled]{opacity:.65;cursor:not-allowed;transform:none;box-shadow:none}
@media (max-width:1100px){.summary-grid{grid-template-columns:1fr}}

.admin-badges,.filters-head,.pagination-bar,.wrap{display:flex;flex-wrap:wrap}.admin-badges{gap:10px}.badge-soft{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:#fff5fa;border:1px solid #f0d4e2;color:#8a1f54;font-size:.88rem;font-weight:700}
.filters-head{justify-content:space-between;gap:16px;align-items:flex-start}.gap-sm{gap:10px}.compact-grid{align-items:end}.grid-5{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}
.table-meta-card{display:flex;flex-direction:column;justify-content:center;padding:12px 16px;border-radius:16px;background:#fff8fb;border:1px solid #f0d4e2;color:#8a1f54;min-height:64px}.table-meta-card strong{font-size:1.3rem}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:20px;background:#fff}.data-table{width:100%;border-collapse:collapse;min-width:980px}.data-table th,.data-table td{padding:14px 12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}.data-table th{font-size:.9rem;color:#7a5368;background:#fff8fb;position:sticky;top:0;z-index:1}.data-table tbody tr:hover{background:#fffafc}.data-table tr.is-selected{background:#fff1f7}.table-sub{color:var(--muted);font-size:.85rem;margin-top:4px}
.pagination-bar{justify-content:space-between;align-items:center;gap:12px;margin-top:16px}.btn-xs{padding:8px 12px;border-radius:12px;font-size:.85rem}
.phase-ribbon{display:flex;gap:8px;flex-wrap:wrap}.phase-chip{padding:8px 12px;border-radius:999px;background:#f8f4f7;border:1px solid var(--line);color:#6f5b66;font-weight:700;font-size:.84rem}.phase-chip.active{background:#fff0f7;border-color:#efcfe0;color:#8a1f54}
.file-row{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:12px 0;border-bottom:1px solid var(--line)}.file-row:last-child{border-bottom:none}
.detail-pro-grid{align-items:start}
.status{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:.82rem;font-weight:700;background:#f4f4f5;color:#444}.status-recibida{background:#eef2ff;color:#3730a3}.status-en_revision{background:#fff7ed;color:#9a3412}.status-observada{background:#fff1f2;color:#be123c}.status-aprobada{background:#ecfdf5;color:#166534}.status-rechazada{background:#fef2f2;color:#991b1b}.status-acreditada{background:#eff6ff;color:#1d4ed8}
@media (max-width:1200px){.grid-5{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:760px){.grid-5{grid-template-columns:1fr}.filters-head,.pagination-bar{flex-direction:column;align-items:stretch}}


.enterprise-topbar{background:linear-gradient(90deg,#4b1230,#7a164b 58%,#b4236c)}
.enterprise-hero{background:linear-gradient(180deg,#fff,#fff8fb)}
.enterprise-kpi-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:16px}
.kpi-card-enterprise{padding:18px;border-radius:22px}
.kpi-card-enterprise .kpi-label{font-size:.88rem;color:var(--muted);font-weight:700}
.kpi-card-enterprise .kpi-value{font-size:2rem;font-weight:800;color:#4b1230;margin:8px 0 4px}
.kpi-card-enterprise .kpi-sub{font-size:.84rem;color:var(--muted)}
.kpi-card-enterprise.warning{background:linear-gradient(180deg,#fff,#fff7ed)}
.kpi-card-enterprise.danger{background:linear-gradient(180deg,#fff,#fff1f2)}
.kpi-card-enterprise.success{background:linear-gradient(180deg,#fff,#f0fdf4)}
.kpi-card-enterprise.info{background:linear-gradient(180deg,#fff,#eff6ff)}
.panel-soft{background:linear-gradient(180deg,#fff,#fcfbfd)}
.mini-metrics{display:grid;gap:12px}.mini-metrics div{padding:12px 14px;border:1px solid var(--line);border-radius:16px;background:#fff}.mini-metrics strong{display:block;font-size:1.35rem;color:#4b1230}.mini-metrics span{color:var(--muted);font-size:.9rem}
.compact-list{display:grid;gap:10px}.compact-item{padding:12px 14px}.compact-item span{display:block;color:var(--muted);font-size:.9rem;margin-top:4px}
.quick-filters{display:grid;gap:10px}
.grid-6{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:14px}
.sla-pill{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-weight:700;font-size:.82rem;border:1px solid transparent}
.sla-ok{background:#ecfdf5;color:#166534;border-color:#b7e0c1}.sla-risk{background:#fff7ed;color:#9a3412;border-color:#fed7aa}.sla-overdue{background:#fef2f2;color:#991b1b;border-color:#fecdd3}
.sla-banner{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:14px 16px;border-radius:18px;border:1px solid var(--line);background:#f8fafc;color:#334155}
.sla-banner.ok{background:#f0fdf4;border-color:#bbf7d0;color:#166534}.sla-banner.risk{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.sla-banner.overdue{background:#fef2f2;border-color:#fecdd3;color:#991b1b}
.enterprise-detail-grid{align-items:start}
@media (max-width:1360px){.enterprise-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-6{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:860px){.enterprise-kpi-grid,.grid-6{grid-template-columns:1fr}}

.permissions-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.permission-item{padding:10px 12px;border:1px solid var(--line);border-radius:14px;background:#fff}.permission-item input{margin-right:8px}.inline input[type="text"]{flex:1 1 160px}.chart-box{min-height:280px}
@media (max-width:900px){.permissions-grid{grid-template-columns:1fr}}


/* Ajustes frontend público · cPanel/IPN */
html{scroll-behavior:smooth}
.topbar{position:sticky;top:0;z-index:50;backdrop-filter:blur(12px)}
.hero{transition:max-height .35s ease,opacity .25s ease,margin .25s ease,padding .25s ease;overflow:hidden}
body.compact-intro .hero{max-height:0;opacity:0;margin:0;padding:0;pointer-events:none}
body.compact-intro .topbar .brand p,
body.compact-intro .topbar .top-actions{display:none}
body.compact-intro .topbar-inner{padding-block:10px}
.stepper{position:sticky;top:78px;z-index:20;background:rgba(255,255,255,.96);backdrop-filter:blur(10px)}
.form-step{scroll-margin-top:150px}
.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.58);display:flex;align-items:center;justify-content:center;padding:24px;z-index:1200}
.modal-card{width:min(100%,640px);background:#fff;border-radius:26px;box-shadow:0 32px 80px rgba(15,23,42,.28);position:relative;padding:28px;border:1px solid rgba(15,23,42,.08)}
.modal-close{position:absolute;top:14px;right:16px;border:none;background:transparent;font-size:30px;line-height:1;cursor:pointer;color:#475569}
.modal-icon{width:72px;height:72px;border-radius:999px;display:grid;place-items:center;font-size:34px;font-weight:800;margin:0 auto 16px;background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#166534}
.modal-body{text-align:center;display:grid;gap:12px}
.modal-body h2{margin:0;font-size:clamp(1.45rem,2vw,2rem);color:#0f172a}
.modal-body p{margin:0;color:#334155;line-height:1.65}
.modal-folio{display:inline-flex;justify-content:center;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:#eff6ff;color:#1d4ed8;font-weight:700}
.modal-actions{display:flex;justify-content:center;margin-top:20px}
body.modal-open{overflow:hidden}
@media (max-width:900px){.stepper{top:70px}.modal-card{padding:24px 20px}}

.modal[hidden]{
  display:none !important;
}

.modal{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(15,23,42,.45);
  padding:24px;
  z-index:9999;
}

.modal-dialog{
  position:relative;
  width:min(680px, 100%);
  background:#fff;
  border-radius:24px;
  padding:32px 28px;
  box-shadow:0 30px 80px rgba(15,23,42,.25);
}

body.modal-open{
  overflow:hidden;
}
