/* PEI · capa visual premium compatible con Nodo Andino
   Sobria, institucional, sutil; evita estética infantil o colores saturados. */
:root{
    --pei-ink:#151923;
    --pei-ink-2:#243047;
    --pei-muted:#677084;
    --pei-bg:#f7f4ee;
    --pei-bg-2:#eee8dc;
    --pei-surface:rgba(255,255,255,.82);
    --pei-surface-solid:#fffdf8;
    --pei-line:rgba(21,25,35,.10);
    --pei-gold:#a8956a;
    --pei-gold-soft:#d9c48f;
    --pei-radius:24px;
    --pei-shadow:0 24px 70px rgba(21,25,35,.10);
    --azul:var(--pei-ink-2);
    --violeta:var(--pei-gold);
    --fondo:var(--pei-bg);
    --tinta:var(--pei-ink);
    --muted:var(--pei-muted);
    --card:var(--pei-surface-solid);
    --borde:var(--pei-line);
}
html{background:var(--pei-bg);}
body{
    font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
    background:
        radial-gradient(circle at 14% 10%, rgba(168,149,106,.14), transparent 34%),
        radial-gradient(circle at 88% 16%, rgba(21,25,35,.07), transparent 32%),
        linear-gradient(180deg,var(--pei-bg),var(--pei-bg-2));
    color:var(--pei-ink);
    letter-spacing:-.012em;
}
a{color:var(--pei-ink-2)}
.top{
    min-height:68px;
    padding:12px clamp(18px,4vw,52px);
    background:rgba(247,244,238,.78);
    border-bottom:1px solid rgba(21,25,35,.08);
    box-shadow:none;
    backdrop-filter:saturate(150%) blur(18px);
}
.brand{gap:12px;font-weight:720;letter-spacing:-.02em;}
.brand span{
    width:44px;height:44px;border-radius:14px;
    background-image:url('pei-mark.svg');
    background-size:cover;background-position:center;
    color:transparent;font-size:0;box-shadow:0 12px 28px rgba(21,25,35,.14);
}
.brand small{font-size:.82rem;color:var(--pei-muted);font-weight:560;letter-spacing:-.01em;}
.top nav{align-items:center;gap:8px;}
.top nav a,.btn,.theme-toggle{
    border:1px solid rgba(21,25,35,.10);
    border-radius:999px;
    background:#151923;
    color:#f7f4ee;
    padding:10px 16px;
    font-size:.9rem;
    font-weight:650;
    box-shadow:none;
    transition:transform .18s ease, background .18s ease, border-color .18s ease;
}
.top nav a:hover,.btn:hover,.theme-toggle:hover{transform:translateY(-1px);background:#243047;}
.top nav a:first-child,.secondary,.theme-toggle{
    background:rgba(255,255,255,.62)!important;
    color:#151923!important;
    border-color:rgba(21,25,35,.12)!important;
}
.wrap{width:min(1160px,calc(100% - 32px));padding:34px 0 70px;}
.hero{
    position:relative;overflow:hidden;
    display:grid;grid-template-columns:1.08fr .92fr;gap:32px;
    align-items:start;
    padding:clamp(28px,5vw,56px);
    border:1px solid rgba(21,25,35,.08);
    border-radius:34px;
    background:linear-gradient(135deg,rgba(255,255,255,.86),rgba(247,244,238,.72));
    box-shadow:var(--pei-shadow);
}
.hero:before{
    content:"";position:absolute;right:-120px;top:-110px;width:360px;height:360px;border-radius:50%;
    background:radial-gradient(circle,rgba(168,149,106,.18),transparent 67%);pointer-events:none;
}
.hero > *{position:relative;z-index:1;}
.badge{
    display:inline-flex;align-items:center;gap:8px;
    border:1px solid rgba(168,149,106,.28);
    border-radius:999px;
    padding:8px 12px;
    background:rgba(255,255,255,.48);
    color:#4f5870;
    font-size:.78rem;font-weight:680;letter-spacing:.02em;text-transform:uppercase;
}
h1{
    max-width:740px;
    margin:18px 0 16px;
    font-size:clamp(2.2rem,5vw,4.45rem);
    line-height:.98;
    letter-spacing:-.065em;
    font-weight:720;
    color:#151923;
}
h2{font-size:clamp(1.45rem,2.4vw,2.4rem);letter-spacing:-.04em;font-weight:710;color:#151923;}
h3{letter-spacing:-.025em;font-weight:700;color:#151923;}
.lead{font-size:clamp(1rem,1.8vw,1.22rem);line-height:1.62;color:#5e687b;max-width:680px;}
.actions{margin:22px 0 20px;}
.panel,.card,.metric{
    background:rgba(255,255,255,.74);
    border:1px solid rgba(21,25,35,.09);
    border-radius:24px;
    box-shadow:0 18px 48px rgba(21,25,35,.08);
}
.card{padding:20px;}
.grid{gap:14px;}
.card p{color:#687286;line-height:1.55;}
.login{
    align-self:start;
    margin-top:4px;
    background:rgba(255,253,248,.86);
    backdrop-filter:blur(10px);
}
.field label{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:#5e687b;font-weight:760;}
input,select,textarea{
    border:1px solid rgba(21,25,35,.13);
    border-radius:15px;
    background:rgba(255,255,255,.86);
    color:#151923;
    padding:12px 14px;
    outline:none;
}
input:focus,select:focus,textarea:focus{border-color:rgba(168,149,106,.65);box-shadow:0 0 0 4px rgba(168,149,106,.13);}
.btn{background:#151923!important;color:#f7f4ee!important;}
.btn.secondary,.secondary{background:rgba(255,255,255,.65)!important;color:#151923!important;}
.dash-shell{gap:22px;}
.side{
    background:rgba(255,253,248,.82);
    border:1px solid rgba(21,25,35,.09);
    box-shadow:0 18px 54px rgba(21,25,35,.08);
}
.side:before{
    content:"";display:block;height:82px;margin:0 0 12px;border-radius:18px;
    background:url('pei-emblem-wide.svg') center/cover no-repeat;
}
.side-head{border-bottom:1px solid rgba(21,25,35,.08);padding-bottom:12px;margin-bottom:10px;}
.side-head strong{color:#151923;font-weight:720;letter-spacing:-.025em;}
.side-link{font-weight:660;color:#333c50;border-radius:14px;}
.side-link:hover{background:rgba(168,149,106,.10);border-color:rgba(168,149,106,.22)}
.side-link.active{background:#151923;color:#f7f4ee;box-shadow:none;}
.side-group{margin:7px 0;border:1px solid rgba(21,25,35,.08);border-radius:18px;background:rgba(255,255,255,.34);overflow:hidden;}
.side-group summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:9px;padding:11px 12px;font-weight:760;color:#151923;border-radius:18px;}
.side-group summary::-webkit-details-marker{display:none;}
.side-group summary:after{content:'▾';margin-left:auto;color:#8a7550;font-size:.85rem;transition:transform .18s ease;}
.side-group:not([open]) summary:after{transform:rotate(-90deg);}
.side-sub{padding:0 8px 9px;display:grid;gap:3px;}
.side-sub .side-link{font-size:.91rem;padding:9px 10px;border-radius:12px;margin:0;}
.side-sub .side-link span{opacity:.78;}
.dash-title h1{font-size:clamp(2rem,4vw,3.4rem);}
.table-wrap{width:100%;overflow-x:auto;}
.table th{background:#f1ece2;color:#333c50;border-color:rgba(21,25,35,.10);font-weight:760;}
.table td{border-color:rgba(21,25,35,.08);}
.compact-panel{padding:14px;}
.compact-table{font-size:.82rem;width:100%;}
.compact-table th{white-space:nowrap;padding:8px 8px;}
.compact-table td{padding:6px 6px;vertical-align:middle;}
.compact-table input,.compact-table select{width:100%;padding:7px 8px;border-radius:10px;font-size:.8rem;}
.students-compact th:nth-child(1){width:24%;}.students-compact th:nth-child(2){width:38%;}.students-compact th:nth-child(3){width:24%;}.students-compact th:nth-child(4){width:14%;}
.mini-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:5px;align-items:center;}
.students-compact td:nth-child(3) .mini-grid{grid-template-columns:1fr 76px;}
.row-actions{min-width:120px;white-space:nowrap;}
.compact-btn{padding:7px 9px!important;font-size:.76rem!important;margin:2px;}
.danger-btn{border-color:#b91c1c!important;color:#b91c1c!important;}
.ok{background:#edf7ef;color:#1d5f36;border-color:#b9dfc2}.err{background:#fff0f1;color:#9d1734;border-color:#f2bcc7}
.foot{color:#777f8f;background:transparent;border-top:1px solid rgba(21,25,35,.08);}
.pei-hero-visual{display:none;}
@media(max-width:900px){
    .hero{grid-template-columns:1fr;padding:26px;border-radius:26px;}
    .wrap{width:min(100% - 20px,1160px);}
    .top{align-items:flex-start;flex-direction:column;}
    .top nav a,.theme-toggle{font-size:.82rem;padding:9px 12px;}
}
html[data-theme="dark"]{
    --pei-ink:#f3efe7;--pei-ink-2:#f7f4ee;--pei-muted:#c6bfaf;--pei-bg:#0f1117;--pei-bg-2:#171a23;--pei-surface:rgba(26,29,39,.82);--pei-surface-solid:#1a1d27;--pei-line:rgba(255,255,255,.12);--azul:#d9c48f;--violeta:#a8956a;--tinta:#f3efe7;--muted:#c6bfaf;--card:#1a1d27;--borde:rgba(255,255,255,.12);color-scheme:dark;
}
html[data-theme="dark"] body{background:radial-gradient(circle at 14% 10%,rgba(168,149,106,.16),transparent 34%),linear-gradient(180deg,#0f1117,#171a23);}
html[data-theme="dark"] .top,html[data-theme="dark"] .hero,html[data-theme="dark"] .panel,html[data-theme="dark"] .card,html[data-theme="dark"] .side,html[data-theme="dark"] .metric{background:rgba(26,29,39,.82);border-color:rgba(255,255,255,.12);box-shadow:0 24px 70px rgba(0,0,0,.32)}
html[data-theme="dark"] h1,html[data-theme="dark"] h2,html[data-theme="dark"] h3,html[data-theme="dark"] .side-head strong,html[data-theme="dark"] .side-group summary{color:#f7f4ee;}
html[data-theme="dark"] .lead,html[data-theme="dark"] .card p,html[data-theme="dark"] .manual-section p,html[data-theme="dark"] .manual-section li{color:#c6bfaf;}
html[data-theme="dark"] .badge,html[data-theme="dark"] .top nav a:first-child,html[data-theme="dark"] .secondary,html[data-theme="dark"] .theme-toggle{background:rgba(255,255,255,.07)!important;color:#f7f4ee!important;border-color:rgba(255,255,255,.14)!important;}
html[data-theme="dark"] .btn{background:#f7f4ee!important;color:#151923!important;}
html[data-theme="dark"] input,html[data-theme="dark"] select,html[data-theme="dark"] textarea{background:#10131b;color:#f7f4ee;border-color:rgba(255,255,255,.14)}
html[data-theme="dark"] .side-group{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.10)}
html[data-theme="dark"] .table th{background:#222734!important;color:#f7f4ee!important}html[data-theme="dark"] .table td{background:#171a23!important;color:#efe9dd!important;border-color:rgba(255,255,255,.10)!important}


.top-school-logo{width:44px;height:44px;border-radius:14px;object-fit:contain;background:rgba(255,255,255,.78);padding:5px;box-shadow:0 12px 28px rgba(21,25,35,.12)}
.side-school-logo{display:block;width:74px;height:74px;object-fit:contain;border-radius:18px;background:rgba(255,255,255,.72);padding:8px;margin:0 auto 10px;box-shadow:0 12px 28px rgba(21,25,35,.10);border:1px solid rgba(21,25,35,.08)}
.school-logo-preview{display:flex;align-items:center;gap:14px;margin:16px 0 10px;padding:12px 14px;border:1px solid rgba(21,25,35,.09);border-radius:18px;background:rgba(255,255,255,.46)}
.school-logo-preview span{font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;font-weight:760;color:#5e687b}.school-logo-preview img{width:86px;height:86px;object-fit:contain;border-radius:16px;background:#fff;padding:8px;border:1px solid rgba(21,25,35,.08)}
.palette-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin:12px 0 18px}.palette-option{display:grid;grid-template-columns:auto 1fr;gap:5px 10px;align-items:center;padding:13px;border:1px solid rgba(21,25,35,.10);border-radius:18px;background:rgba(255,255,255,.55);cursor:pointer}.palette-option input{grid-row:1/3;width:auto}.palette-option strong{font-size:.94rem}.palette-option small{grid-column:2;color:#687286;line-height:1.3}.palette-option:has(input:checked){border-color:var(--pei-gold);box-shadow:0 0 0 4px rgba(168,149,106,.13)}.palette-swatch{width:46px;height:26px;border-radius:999px;border:1px solid rgba(21,25,35,.10);box-shadow:inset 0 0 0 5px rgba(255,255,255,.42)}
.palette-arena .palette-swatch{background:linear-gradient(90deg,#f7f4ee,#d9c48f,#243047)}.palette-salvia .palette-swatch{background:linear-gradient(90deg,#f1f6ee,#c8d9b9,#24372f)}.palette-cielo .palette-swatch{background:linear-gradient(90deg,#eef6fa,#c5dfef,#20364a)}.palette-lavanda .palette-swatch{background:linear-gradient(90deg,#f4f0f8,#d7c9ea,#302946)}.palette-durazno .palette-swatch{background:linear-gradient(90deg,#fbf0e8,#ecc6ad,#442f29)}
html[data-palette="salvia"] .side-link.active,html[data-palette="salvia"] .btn{background:#24372f!important}html[data-palette="cielo"] .side-link.active,html[data-palette="cielo"] .btn{background:#20364a!important}html[data-palette="lavanda"] .side-link.active,html[data-palette="lavanda"] .btn{background:#302946!important}html[data-palette="durazno"] .side-link.active,html[data-palette="durazno"] .btn{background:#442f29!important}
html[data-theme="dark"] .top-school-logo,html[data-theme="dark"] .side-school-logo,html[data-theme="dark"] .school-logo-preview{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12)}

/* UX premium: clearer task panels, safer dense tables, and action affordances */
.flow-panel{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;padding:22px 24px;background:linear-gradient(135deg,rgba(255,255,255,.84),rgba(255,255,255,.55));}
.flow-panel h2{margin:.45rem 0 .25rem;font-size:1.45rem;}
.flow-panel .actions{margin:0;justify-content:flex-end;min-width:220px;}
.table-wrap{border:1px solid rgba(21,25,35,.08);border-radius:18px;background:rgba(255,255,255,.42);}
.compact-table th:first-child,.compact-table td:first-child{white-space:nowrap;}
.compact-table input[type="checkbox"]{width:18px;height:18px;accent-color:var(--pei-ink-2);}
.row-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap;}
.row-actions form{display:inline;}
.danger-btn{background:rgba(255,255,255,.65)!important;border-color:#b91c1c!important;color:#991b1b!important;}
.danger-btn:hover{background:#fee2e2!important;color:#7f1d1d!important;}
.muted{color:var(--pei-muted);font-size:.83rem;line-height:1.4;}
select option{color:#151923;}
@media(max-width:720px){.flow-panel{display:block}.flow-panel .actions{justify-content:flex-start;margin-top:14px}.compact-table{min-width:760px}.students-compact{min-width:980px}}
html[data-theme="dark"] .flow-panel,html[data-theme="dark"] .table-wrap{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.10)}
html[data-theme="dark"] .danger-btn{background:rgba(127,29,29,.22)!important;color:#fecaca!important;border-color:#ef4444!important;}
/* School-friendly visual refresh: brighter, warmer, and less corporate. */
:root{
    --pei-ink:#17324d;
    --pei-ink-2:#176b87;
    --pei-muted:#5f7187;
    --pei-bg:#f4f9ff;
    --pei-bg-2:#eef8f2;
    --pei-surface:rgba(255,255,255,.88);
    --pei-surface-solid:#ffffff;
    --pei-line:rgba(23,50,77,.12);
    --pei-gold:#f6b44b;
    --pei-gold-soft:#ffe7a8;
    --school-blue:#2f80ed;
    --school-teal:#1aa6a6;
    --school-green:#45b36b;
    --school-coral:#f26d5b;
    --school-yellow:#ffd166;
    --azul:#176b87;
    --violeta:#f26d5b;
    --fondo:#f4f9ff;
    --tinta:#17324d;
    --muted:#5f7187;
    --card:#ffffff;
    --borde:rgba(23,50,77,.12);
}
html{background:#f4f9ff;}
body{
    background:
        linear-gradient(135deg, rgba(47,128,237,.10) 0 18%, transparent 18% 100%),
        linear-gradient(225deg, rgba(69,179,107,.10) 0 16%, transparent 16% 100%),
        linear-gradient(180deg,#f4f9ff 0%,#eef8f2 52%,#fff8e8 100%);
    color:#17324d;
    letter-spacing:0;
}
.top{
    background:rgba(255,255,255,.88);
    border-bottom:1px solid rgba(23,50,77,.10);
    box-shadow:0 10px 28px rgba(47,128,237,.08);
}
.brand small{color:#43627f;font-weight:700;}
.top nav a,.btn,.theme-toggle{
    border-radius:14px;
    background:#176b87;
    color:#fff;
    border:1px solid rgba(23,107,135,.18);
    font-weight:750;
}
.top nav a:hover,.btn:hover,.theme-toggle:hover{background:#1aa6a6;}
.top nav a:first-child,.secondary,.theme-toggle{
    background:#fff!important;
    color:#176b87!important;
    border-color:rgba(47,128,237,.18)!important;
}
.hero,.panel,.card,.metric,.side{
    background:rgba(255,255,255,.88);
    border-color:rgba(23,50,77,.11);
    box-shadow:0 18px 42px rgba(23,50,77,.08);
}
.hero{background:linear-gradient(135deg,#ffffff,#f5fbff 58%,#fff7e3);}
.hero:before{display:none;}
h1,h2,h3,.side-head strong,.side-group summary{color:#17324d;letter-spacing:0;}
.lead,.card p{color:#5f7187;}
.badge{
    background:#e8f7f7;
    border-color:rgba(26,166,166,.22);
    color:#176b87;
    letter-spacing:.03em;
}
.side{background:linear-gradient(180deg,#ffffff,#f4fbff);}
.side-group{background:#f8fbff;border-color:rgba(47,128,237,.12);}
.side-group summary{color:#17324d;}
.side-group summary:after{color:#f26d5b;}
.side-link{color:#2c4661;font-weight:720;}
.side-link:hover{background:#eaf6ff;border-color:#bfe2ff;}
.side-link.active{
    background:linear-gradient(135deg,#176b87,#1aa6a6);
    color:#fff;
    box-shadow:0 10px 22px rgba(26,166,166,.18);
}
.metric{position:relative;overflow:hidden;background:#fff;}
.metric:before{content:"";position:absolute;left:0;right:0;top:0;height:5px;background:linear-gradient(90deg,#2f80ed,#1aa6a6,#45b36b,#ffd166,#f26d5b);}
.metric strong{color:#176b87;}
.table-wrap,.table{background:#fff;}
.table th{background:#eaf6ff!important;color:#17324d!important;}
.table tr:nth-child(even) td{background:#fbfdff;}
input,select,textarea{
    background:#fff;
    border-color:rgba(23,50,77,.15);
    border-radius:12px;
}
input:focus,select:focus,textarea:focus{
    border-color:#1aa6a6;
    box-shadow:0 0 0 4px rgba(26,166,166,.14);
}
.flow-panel{
    background:linear-gradient(135deg,#ffffff,#edf9ff 55%,#fff6dc);
    border-color:rgba(47,128,237,.13);
}
.danger-btn{border-color:#f26d5b!important;color:#bf3d31!important;}
.danger-btn:hover{background:#fff0ed!important;color:#9f2f25!important;}
.palette-grid .palette-option{border-radius:14px;}
html[data-theme="dark"] body{
    background:linear-gradient(180deg,#102033,#112b36 52%,#1f2937);
}
html[data-theme="dark"] .side:before{opacity:.9;}
html[data-theme="dark"] .hero,html[data-theme="dark"] .panel,html[data-theme="dark"] .card,html[data-theme="dark"] .metric,html[data-theme="dark"] .side{
    background:rgba(17,32,51,.9);
    border-color:rgba(255,255,255,.12);
}
html[data-theme="dark"] .table tr:nth-child(even) td{background:#13243a!important;}

/* PEI refined school navigation */

.side{
    font-family:"Segoe UI Variable","Aptos","Segoe UI",system-ui,sans-serif;
    background:linear-gradient(180deg,#ffffff,#f4fbff 58%,#eef8f4);
}
.side:before{
    height:86px;
    margin-bottom:14px;
    border-radius:18px;
    background:url('pei-emblem-wide.svg') center/contain no-repeat,linear-gradient(135deg,#f7fbff,#edf8f4);
    border:1px solid rgba(23,107,135,.12);
    box-shadow:0 14px 32px rgba(23,107,135,.10);
}
.side-head strong{
    font-family:"Segoe UI Variable","Aptos","Segoe UI",system-ui,sans-serif;
    font-weight:760;
    letter-spacing:0;
}
.side-head small{
    letter-spacing:.05em;
    color:#60768a;
}
.side-link{
    display:flex;
    align-items:center;
    gap:10px;
    min-height:42px;
    padding:10px 11px;
    border-radius:12px;
    color:#28465f;
    font-size:.95rem;
    font-weight:680;
    letter-spacing:.01em;
    line-height:1.18;
}
.side-link span,.side-group summary span{
    display:inline-grid;
    place-items:center;
    min-width:30px;
    height:24px;
    padding:0 7px;
    border-radius:8px;
    background:#e8f4ff;
    color:#176b87;
    font-size:.68rem;
    font-weight:840;
    letter-spacing:.055em;
    box-shadow:inset 0 0 0 1px rgba(23,107,135,.08);
}
.side-link:hover{
    background:#eaf6ff;
    border-color:#bfe2ff;
}
.side-link.active{
    background:linear-gradient(135deg,#176b87,#1d927f);
    color:#fff;
    box-shadow:0 10px 22px rgba(23,107,135,.18);
}
.side-link.active span{
    background:rgba(255,255,255,.18);
    color:#fff;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.18);
}
.side-group{
    border-radius:14px;
    background:#f8fbff;
    border-color:rgba(47,128,237,.12);
}
.side-group summary{
    min-height:42px;
    padding:10px 11px;
    color:#17324d;
    font-size:.78rem;
    font-weight:820;
    letter-spacing:.075em;
    text-transform:uppercase;
}
.side-group summary:after{
    color:#1d927f;
}
.side-sub{
    padding:0 8px 9px;
}
.side-sub .side-link{
    min-height:38px;
    font-size:.91rem;
    font-weight:650;
    padding:8px 9px;
}
html[data-theme="dark"] .side:before{
    background:url('pei-emblem-wide.svg') center/contain no-repeat,linear-gradient(135deg,#102033,#112b36);
    border-color:rgba(255,255,255,.14);
}
html[data-theme="dark"] .side-link span,html[data-theme="dark"] .side-group summary span{
    background:rgba(255,255,255,.08);
    color:#d7f6ef;
}

/* PEI compact listados */
.list-index{display:grid;grid-template-columns:repeat(auto-fit,minmax(128px,1fr));gap:10px;margin:0 0 16px}
.list-index a{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border:1px solid rgba(23,107,135,.12);border-radius:12px;background:#fff;color:#17324d;text-decoration:none;box-shadow:0 10px 26px rgba(23,107,135,.06)}
.list-index strong{font-size:1.25rem;color:#176b87}.list-index span{font-size:.82rem;font-weight:760}
.list-panel{padding:16px;margin-bottom:14px}.list-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.list-head h2{font-size:1.18rem;margin:0}
.list-table{font-size:.78rem}.list-table th{padding:7px}.list-table td{padding:5px}.list-table input,.list-table select{padding:6px 7px;border-radius:8px;font-size:.78rem}
.row-detail{position:relative;display:inline-block}.row-detail summary{list-style:none;cursor:pointer;border:1px solid rgba(23,107,135,.18);background:#eef8f4;color:#176b87;border-radius:8px;padding:7px 9px;font-size:.74rem;font-weight:800}.row-detail summary::-webkit-details-marker{display:none}
.row-detail[open] summary{background:#176b87;color:#fff}.row-detail div{position:absolute;right:0;top:calc(100% + 6px);z-index:20;width:min(340px,80vw);padding:14px;border-radius:14px;background:#fff;border:1px solid rgba(23,107,135,.14);box-shadow:0 22px 54px rgba(23,50,77,.18);text-align:left;white-space:normal}.row-detail h4{margin:0 0 8px;font-size:1rem}.row-detail dl{display:grid;grid-template-columns:112px 1fr;gap:5px 10px;margin:0}.row-detail dt{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:#60768a;font-weight:800}.row-detail dd{margin:0;color:#17324d;font-size:.85rem;word-break:break-word}
html[data-theme="dark"] .list-index a,html[data-theme="dark"] .row-detail div{background:#112033;border-color:rgba(255,255,255,.12)}html[data-theme="dark"] .row-detail dd{color:#eef8f4}
@media(max-width:720px){.list-table{min-width:920px}.row-detail div{left:0;right:auto}}

/* PEI usuarios y accesos */
.access-table{min-width:1120px}
.access-table td{vertical-align:top}
.access-table small{display:block;margin-top:4px}
.access-table .mini-grid{grid-template-columns:repeat(2,minmax(110px,1fr))}
.inline-check{display:flex;align-items:center;gap:6px;margin-top:6px;font-size:.76rem;font-weight:760;color:#28465f}
.inline-check input{width:16px!important;height:16px!important;margin:0;accent-color:#176b87}
html[data-theme="dark"] .inline-check{color:#d7f6ef}

/* PEI escritorio ancho y busqueda */
@media(min-width:1100px){
    .wrap{
        width:calc(100% - 28px);
        max-width:none;
        margin-left:auto;
        margin-right:auto;
    }
    .dash-shell{
        grid-template-columns:272px minmax(0,1fr);
        gap:16px;
    }
    .dash-main{
        width:100%;
        min-width:0;
    }
    .dash-main > .panel,
    .dash-main > .metrics,
    .dash-main > .grid{
        width:100%;
    }
    .list-panel,
    .compact-panel,
    .panel:has(.table-wrap){
        padding:14px;
        border-radius:18px;
    }
    .table-wrap{
        width:100%;
        max-width:100%;
    }
    .compact-table,
    .list-table{
        table-layout:auto;
    }
}
.table-tools{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    margin:0 0 10px;
}
.table-search{
    width:min(420px,100%);
    border:1px solid rgba(23,107,135,.16);
    border-radius:12px;
    padding:9px 12px;
    font-size:.9rem;
    background:#fff;
}
.table-count{
    color:#60768a;
    font-size:.8rem;
    font-weight:760;
    white-space:nowrap;
}
.table-empty-row td{
    text-align:center;
    color:#60768a;
    font-weight:760;
    padding:16px!important;
}
html[data-theme="dark"] .table-search{
    background:#0f1f32;
    color:#eef8f4;
    border-color:rgba(255,255,255,.16);
}
html[data-theme="dark"] .table-count,
html[data-theme="dark"] .table-empty-row td{
    color:#b8c7d8;
}
@media(max-width:720px){
    .table-tools{align-items:stretch;flex-direction:column}
    .table-count{white-space:normal}
}

/* PEI carreras overview */
.career-overview{padding:16px}
.career-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}
.career-card{border:1px solid rgba(23,107,135,.12);border-radius:14px;background:#fff;padding:14px;box-shadow:0 10px 24px rgba(23,107,135,.06)}
.career-card h3{margin:8px 0 6px;font-size:1rem;color:#17324d}
.career-card p{margin:0 0 10px;color:#60768a;font-size:.84rem;line-height:1.35}
.career-card small{font-weight:800;color:#176b87}
.level-chip{display:inline-flex;align-items:center;border-radius:999px;padding:5px 9px;font-size:.72rem;font-weight:850;background:#e8f4ff;color:#176b87;border:1px solid rgba(23,107,135,.12)}
.level-inicial{background:#fff7df;color:#9a6a00}.level-primaria{background:#eaf8e9;color:#2f7a34}.level-secundaria{background:#e8f4ff;color:#176b87}.level-postprimario{background:#f1eafd;color:#6742a3}.level-terciario{background:#eef2ff;color:#3344a0}
html[data-theme="dark"] .career-card{background:#112033;border-color:rgba(255,255,255,.12)}html[data-theme="dark"] .career-card h3{color:#eef8f4}

/* PEI carreras nivel claro */
.career-card h3{margin-top:0}
.career-level{
    display:grid;
    gap:5px;
    margin:8px 0 10px;
    padding:10px;
    border-radius:12px;
    background:#f8fbff;
    border:1px solid rgba(23,107,135,.10);
}
.career-level span{
    color:#60768a;
    font-size:.72rem;
    font-weight:850;
    letter-spacing:.06em;
    text-transform:uppercase;
}
.career-level .level-chip{
    justify-content:center;
    width:fit-content;
    font-size:.86rem;
    padding:7px 11px;
}
html[data-theme="dark"] .career-level{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.12)}
