/* EduSmart360 V1.2.8 - Componentes compartidos */
html,body{font-family:var(--font-ui);background:var(--color-bg);color:var(--color-text);}
.es360-hidden{display:none!important;}
.app{background:var(--color-bg);}
.sidebar{background:#fff;color:var(--color-text);border-right:1px solid var(--color-border);box-shadow:var(--shadow-soft);}
.logo-area{border-bottom:1px solid var(--color-border);}
.logo-ic{background:var(--color-primary-light);color:var(--color-primary-dark);font-weight:900;}
.logo-nm{color:var(--color-text);}.logo-nm span{color:#FF8A00;}.logo-tg{color:var(--color-muted);}
.sec-lbl{color:#8390A0;text-transform:uppercase;letter-spacing:.13em;font-weight:850;}
.mi{color:var(--color-text);font-weight:750;border-radius:12px;margin:2px 12px;}
.mi:hover{background:#EEF4FA;color:var(--color-primary-dark);}
.mi.on{background:var(--color-primary-light);color:var(--color-primary-dark);box-shadow:none;}
.mi-ic{background:transparent;color:var(--color-primary);font-size:0;}
.mi-ic svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;}
.mi-badge{background:#FDECEC;color:var(--color-danger);border:1px solid #F1B9B9;}
.sf{border-top:1px solid var(--color-border);}.uc{background:#F8FAFC;border:1px solid var(--color-border);}.un{color:var(--color-text);}.ur{color:var(--color-muted);}.uav{background:var(--color-primary-light);color:var(--color-primary-dark);}
.topbar{background:#fff;border-bottom:1px solid var(--color-border);box-shadow:none;}
.tb-title{color:var(--color-text);}.tb-bc,#tb-fecha{color:var(--color-muted);}
.top-action,.mobile-menu-btn{height:38px;display:inline-flex;align-items:center;gap:8px;border:1px solid var(--color-border);border-radius:10px;background:#fff;color:var(--color-primary-dark);padding:0 13px;font-weight:850;cursor:pointer;font-size:13px;font-family:var(--font-ui);}
.top-action svg,.mobile-menu-btn svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.top-action.secondary b{min-width:18px;height:18px;border-radius:999px;background:var(--color-primary-light);display:inline-flex;align-items:center;justify-content:center;font-size:11px;}
.top-action.danger{background:var(--color-primary-dark);border-color:var(--color-primary-dark);color:#fff;}
.side-logout{width:100%;margin-top:10px;border:1px solid #F1B9B9;background:#fff;color:var(--color-danger);border-radius:10px;min-height:42px;font-weight:900;display:flex;gap:8px;align-items:center;justify-content:center;cursor:pointer;font-family:var(--font-ui);}
.side-logout svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.side-logout:hover{background:#FDECEC;}
.main{background:var(--color-bg);}.pt{color:var(--color-text);font-weight:950;letter-spacing:-.04em;}.ps,.muted{color:var(--color-muted);}
.card,.sc,.saas-card,.v210-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);}
.sc-ac{background:var(--color-primary);}.sc-ic{background:var(--color-primary-light);color:var(--color-primary-dark);}.sc-n{color:var(--color-text);}.sc-l{color:var(--color-muted);}
.btn{border-radius:10px;font-weight:850;font-family:var(--font-ui);}.btn-p,.btn-v,.btn-g{background:var(--color-primary);color:#fff;border:1px solid var(--color-primary);}.btn-p:hover,.btn-v:hover,.btn-g:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);}.btn-o{background:#fff;color:var(--color-primary-dark);border:1px solid #C7D7E5;}.btn-r{background:#FDECEC;color:var(--color-danger);}
.tbl{width:100%;border-collapse:collapse;}.tbl th{background:#F0F4F7;color:var(--color-muted);border-bottom:1px solid var(--color-border);}.tbl td{border-bottom:1px solid #EDF1F4;color:var(--color-text);}.card:has(.tbl){overflow-x:auto;}.card:has(.tbl) .tbl{min-width:760px;}
.fi,.si,select,textarea,input{border-color:#C9D6E2;color:var(--color-text);background:#fff;}.fi:focus,.si:focus,input:focus,select:focus,textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(30,111,168,.12);outline:0;}
.bx,.badge,.tag,.saas-pill,.v210-chip,.rep-badge{border-radius:999px;font-weight:850;border:1px solid transparent;}.bv,.ok{background:#EAF7EE;color:var(--color-success);border-color:#BFE8CA;}.br,.lock{background:#FDECEC;color:var(--color-danger);border-color:#F1B9B9;}.ba{background:#FFF4DB;color:var(--color-warning);border-color:#EACB7A;}.baz{background:var(--color-primary-light);color:var(--color-primary-dark);border-color:#B7D6EF;}.bgr{background:#EEF2F5;color:var(--color-muted);}
.saas-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;}.saas-panel{border-left:5px solid var(--color-primary);}.empty-state,.error-state{border:1px dashed var(--color-border);border-radius:14px;background:#fff;padding:16px;color:var(--color-muted);}.error-state{border-color:#F1B9B9;color:var(--color-danger);}
.toast.ok{background:var(--color-success);color:#fff}.toast.err{background:var(--color-danger);color:#fff}.toast{border-radius:10px;box-shadow:0 16px 34px rgba(18,63,92,.16);}
.mobile-menu-btn{display:none;margin-right:8px;padding:0 10px;}
@media(max-width:1280px){.g4{grid-template-columns:repeat(2,1fr);}.g24{grid-template-columns:1fr;}}
@media(max-width:1024px){.mobile-menu-btn{display:inline-flex;}.sidebar{transform:translateX(-105%);transition:transform .22s ease;z-index:300;}.shell-sidebar-open .sidebar{transform:translateX(0);}.topbar{left:0;}.main{margin-left:0;}.shell-sidebar-open::after{content:'';position:fixed;inset:0;background:rgba(18,63,92,.32);z-index:250;}}
@media(max-width:768px){.topbar{height:auto;min-height:58px;flex-wrap:wrap;gap:8px;padding:10px 14px;}.tb-left,.tb-right{width:100%;}.tb-right{justify-content:flex-start;flex-wrap:wrap;}.main{padding:14px;margin-top:82px;}.g4,.g3,.g2,.g24,.frow,.frow3{grid-template-columns:1fr;} .top-action{height:36px;padding:0 10px}.top-action span{display:inline}.card{padding:14px}.pt{font-size:20px}}
@media(max-width:480px){.top-action span{display:none}.top-action.secondary span{display:inline}.main{padding:12px}.login-box{width:min(94vw,420px)}}

/* V1.2.8 - Responsive real, estados de módulos y reportes profesionales */
:root{--content-max:1440px;--topbar-height:64px;--sidebar-width:238px;}
.main{max-width:var(--content-max);}
.page{max-width:var(--content-max);margin:0 auto;}
.g4,.g3,.g2,.g24,.v210-grid,.cards,.grid,.dashboard-grid{gap:clamp(10px,1.2vw,18px);}
.table-responsive,.audit-table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:14px;}
.table-responsive .tbl,.audit-table-wrap .tbl{min-width:760px;}
.tbl th,.tbl td{vertical-align:middle;line-height:1.45;}
.es-table-state{padding:0!important;background:#fff!important;}
.es-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:6px;min-height:92px;padding:18px;border:1px dashed var(--color-border);border-radius:14px;background:#fff;color:var(--color-muted);}
.es-state b{font-size:13px;color:var(--color-text);}
.es-state small{font-size:11.5px;color:var(--color-muted);max-width:520px;line-height:1.45;}
.es-state-loading{background:linear-gradient(180deg,#fff,#F8FAFC);}
.es-state-empty{background:#FBFCFD;}
.es-state-error{border-color:#F1B9B9;background:#FFF8F8;}.es-state-error b{color:var(--color-danger);}
.spin{width:18px;height:18px;border-radius:50%;border:2px solid #D8E4EE;border-top-color:var(--color-primary);animation:spin .8s linear infinite;display:inline-block;}
@keyframes spin{to{transform:rotate(360deg)}}
.report-shell{display:grid;grid-template-columns:1fr;gap:14px;}
.report-filter-card{grid-column:1/-1;padding:16px;border-left:5px solid var(--color-primary);}
.report-filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(145px,1fr));gap:10px;align-items:end;}
.report-section-title{grid-column:1/-1;margin:18px 0 0;padding:14px 16px;border:1px solid var(--color-border);border-radius:14px;background:#fff;box-shadow:var(--shadow-soft);}
.report-section-title b{display:block;color:var(--color-primary-dark);font-size:14px;margin-bottom:3px;}.report-section-title small{color:var(--color-muted);line-height:1.45;}
.report-card{background:#fff;border:1px solid var(--color-border);border-radius:16px;padding:16px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:10px;min-height:170px;position:relative;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease;}
.report-card:hover{transform:translateY(-2px);border-color:#B7D6EF;box-shadow:var(--shadow-card);}
.report-card .report-badge{position:absolute;right:12px;top:12px;background:var(--color-primary-light);color:var(--color-primary-dark);border:1px solid #B7D6EF;border-radius:999px;font-size:9px;font-weight:900;letter-spacing:.06em;padding:3px 7px;text-transform:uppercase;}
.report-card h3{font-size:14px;line-height:1.25;color:var(--color-text);margin:8px 0 0;padding-right:72px;}
.report-card p{font-size:12px;line-height:1.5;color:var(--color-muted);margin:0;flex:1;}
.report-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:auto;}.report-actions.one{grid-template-columns:1fr;}
.license-layout,.health-layout{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;align-items:stretch;}
.license-detail,.health-detail{background:#fff;border:1px solid var(--color-border);border-radius:16px;padding:16px;box-shadow:var(--shadow-soft);}
.status-line{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid #EDF1F4;font-size:13px;}.status-line:last-child{border-bottom:0;}.status-line span{color:var(--color-muted);}.status-line b{color:var(--color-text);text-align:right;}
.form-grid-6,.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;align-items:end;}
.btn{min-height:36px;display:inline-flex;align-items:center;justify-content:center;gap:6px;}
.btn-xs{min-height:30px;padding:6px 10px;}
@media(max-width:1280px){.main{padding-right:18px}.g4{grid-template-columns:repeat(2,minmax(0,1fr))}.v210-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.report-actions{grid-template-columns:1fr}}
@media(max-width:1024px){body.shell-sidebar-open{overflow:hidden}.sidebar{width:min(86vw,320px)}.topbar{position:fixed;left:0!important;right:0;top:0;z-index:220}.main{margin-left:0!important;padding:16px;margin-top:74px}.page{width:100%}.tb-left{min-width:0}.tb-title{max-width:calc(100vw - 72px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tb-bc{display:none}.table-responsive .tbl,.audit-table-wrap .tbl{min-width:720px}.report-filter-card{padding:14px}}
@media(max-width:768px){.main{padding:12px;margin-top:96px}.topbar{align-items:flex-start}.tb-right{gap:6px}.pt{font-size:clamp(20px,7vw,26px);line-height:1.1}.ps{font-size:12.5px;line-height:1.45}.card,.sc,.license-detail,.health-detail,.report-card{border-radius:14px;padding:14px}.g4,.g3,.g2,.g24,.v210-grid{grid-template-columns:1fr!important}.report-filter-grid{grid-template-columns:1fr}.report-card h3{padding-right:0;margin-top:22px}.report-card .report-badge{left:12px;right:auto}.login-copy-panel{display:none}.login-box{grid-template-columns:1fr!important;width:min(94vw,460px)}.login-form-panel{padding:28px!important}.table-responsive .tbl,.audit-table-wrap .tbl{min-width:680px}}
@media(max-width:480px){.main{padding:10px;margin-top:104px}.top-action{padding:0 9px}.top-action.secondary span{display:none}.top-action.danger span{display:none}.mobile-menu-btn{min-width:38px}.report-actions{grid-template-columns:1fr}.tbl th,.tbl td{font-size:11.5px;padding:9px 8px}.es-state{min-height:84px;padding:14px}.login-form-panel h2{font-size:23px}.login-form-panel p{font-size:13px}}
