/* ==========================================================
   EduSmart360 V1.3.4.3 · EdTech Enterprise UI Layer
   Enfoque: Google Classroom / Microsoft Education / PowerSchool
   CSS puro. No frameworks. Variables white-label reutilizables.
   ========================================================== */
:root{
 --edu-primary:#1A73E8;
 --edu-primary-600:#2563EB;
 --edu-primary-700:#174EA6;
 --edu-primary-50:#EFF6FF;
 --edu-primary-100:#DBEAFE;
 --edu-success:#16A34A;
 --edu-success-50:#ECFDF3;
 --edu-warning:#D97706;
 --edu-warning-50:#FFF7E6;
 --edu-danger:#DC2626;
 --edu-danger-50:#FEF2F2;
 --edu-info:#0284C7;
 --edu-info-50:#E0F2FE;
 --edu-bg:#F8FAFC;
 --edu-surface:#FCFCFD;
 --edu-surface-2:#F1F5F9;
 --edu-text:#172033;
 --edu-text-2:#334155;
 --edu-muted:#64748B;
 --edu-border:#E2E8F0;
 --edu-border-2:#CBD5E1;
 --edu-ring:rgba(26,115,232,.18);
 --edu-radius-sm:8px;
 --edu-radius-md:12px;
 --edu-radius-lg:18px;
 --edu-radius-xl:24px;
 --edu-shadow-xs:0 1px 2px rgba(15,23,42,.05);
 --edu-shadow-sm:0 2px 10px rgba(15,23,42,.06);
 --edu-shadow-md:0 10px 30px rgba(15,23,42,.08);
 --edu-shadow-lg:0 20px 60px rgba(15,23,42,.12);
 --font-ui:'Inter',Roboto,'Segoe UI',system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
 --color-primary:var(--edu-primary);
 --color-primary-dark:var(--edu-primary-700);
 --color-primary-light:var(--edu-primary-100);
 --color-secondary:var(--edu-success);
 --color-secondary-dark:#15803D;
 --color-secondary-light:#DCFCE7;
 --color-bg:var(--edu-bg);
 --color-surface:var(--edu-surface);
 --color-text:var(--edu-text);
 --color-muted:var(--edu-muted);
 --color-border:var(--edu-border);
 --color-success:var(--edu-success);
 --color-warning:var(--edu-warning);
 --color-danger:var(--edu-danger);
 --color-info:var(--edu-info);
 --shadow-card:var(--edu-shadow-md);
 --shadow-soft:var(--edu-shadow-sm);
}
html{font-family:var(--font-ui);font-size:16px;background:var(--edu-bg);color:var(--edu-text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
body{font-family:var(--font-ui);background:var(--edu-bg);color:var(--edu-text);font-size:14px;line-height:1.5;}
*{box-sizing:border-box;}
::selection{background:var(--edu-primary-100);color:var(--edu-primary-700);}
:focus-visible{outline:3px solid var(--edu-ring);outline-offset:2px;border-radius:10px;}
.app.auth-app{display:block;background:var(--edu-bg);min-height:100vh;}

/* ===== Shell / layout ===== */
.sidebar{width:256px;background:linear-gradient(180deg,#182235 0%,#111827 100%);border-right:1px solid rgba(226,232,240,.08);box-shadow:8px 0 30px rgba(15,23,42,.16);}
.logo-area{padding:22px 18px 18px;border-bottom:1px solid rgba(226,232,240,.10);}
.logo-row{gap:12px;}
.logo-ic,.brand-mark{background:linear-gradient(135deg,var(--edu-primary),#38BDF8);border-radius:16px;box-shadow:0 10px 22px rgba(26,115,232,.28);color:#F8FAFC;}
.logo-ic{width:42px;height:42px;}
.logo-ic svg,.brand-mark svg,.mi-ic svg,.top-action svg,.ui-icon,.lucide-icon{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;}
.logo-nm{font-size:18px;font-weight:800;letter-spacing:-.03em;color:#F8FAFC;}
.logo-nm span,.wordmark span{color:#93C5FD;}
.logo-tg,.sec-lbl{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#94A3B8;font-weight:700;}
.menu{padding:12px 10px 18px;}
.sec-lbl{padding:16px 12px 7px;}
.mi{height:42px;margin:2px 0;border-radius:12px;padding:0 12px;color:#CBD5E1;font-size:13.5px;font-weight:600;gap:12px;transition:background .18s ease,color .18s ease,transform .18s ease;}
.mi:hover{background:rgba(248,250,252,.07);color:#F8FAFC;transform:translateX(2px);}
.mi.on{background:rgba(26,115,232,.18);color:#F8FAFC;box-shadow:inset 3px 0 0 var(--edu-primary),0 8px 24px rgba(26,115,232,.10);font-weight:700;}
.mi.on::before{display:none;}
.mi-ic{width:32px;height:32px;border-radius:10px;background:rgba(248,250,252,.08);color:#BFDBFE;}
.mi.on .mi-ic{background:var(--edu-primary);color:#F8FAFC;}
.sf{border-top:1px solid rgba(226,232,240,.10);padding:14px;}
.uc{background:rgba(248,250,252,.08);border:1px solid rgba(226,232,240,.10);border-radius:16px;padding:10px;}
.uav{background:linear-gradient(135deg,var(--edu-primary),#06B6D4);width:36px;height:36px;}
.un{font-size:13px}.ur{font-size:11px;color:#94A3B8;}
.topbar{left:256px;height:64px;background:rgba(252,252,253,.86);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--edu-border);box-shadow:none;padding:0 26px;}
.tb-title{font-size:17px;font-weight:800;color:var(--edu-text);letter-spacing:-.02em;}
.tb-bc,.esx-cc2098df40{font-size:12px;color:var(--edu-muted);}
.tb-right{gap:10px;}
.main{margin-left:256px;margin-top:64px;padding:26px;min-height:calc(100vh - 64px);background:radial-gradient(circle at 10% 0%,rgba(26,115,232,.06),transparent 28%),var(--edu-bg);}
.page{animation:edFade .18s ease;}
@keyframes edFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.pt{font-size:clamp(22px,2.3vw,30px);line-height:1.15;font-weight:800;letter-spacing:-.04em;color:var(--edu-text);margin:0 0 6px;}
.ps{font-size:13.5px;line-height:1.6;color:var(--edu-muted);margin-bottom:20px;max-width:980px;}

/* ===== Cards / KPIs ===== */
.card,.saas-panel,.license-detail,.health-detail,.v210-section{background:var(--edu-surface);border:1px solid var(--edu-border);border-radius:var(--edu-radius-xl);box-shadow:var(--edu-shadow-sm);padding:20px;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease;}
.card:hover,.saas-panel:hover,.v210-section:hover{border-color:#C7D2FE;box-shadow:var(--edu-shadow-md);}
.ct{font-size:14px;line-height:1.35;font-weight:800;color:var(--edu-text);letter-spacing:-.01em;margin-bottom:14px;}
.g2,.g3,.g4,.g24,.v210-grid{gap:18px;margin-bottom:18px;}
.g4{grid-template-columns:repeat(4,minmax(0,1fr));}.g3{grid-template-columns:repeat(3,minmax(0,1fr));}.g2{grid-template-columns:repeat(2,minmax(0,1fr));}.g24{grid-template-columns:minmax(0,2fr) minmax(300px,1fr);}
.sc{background:var(--edu-surface);border:1px solid var(--edu-border);border-radius:22px;box-shadow:var(--edu-shadow-sm);padding:18px;min-height:150px;}
.sc:hover{transform:translateY(-2px);box-shadow:var(--edu-shadow-md);border-color:#C7D2FE;}
.sc-l{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--edu-muted);font-weight:800;}
.sc-n{font-size:clamp(26px,3vw,36px);line-height:1;font-weight:800;letter-spacing:-.06em;color:var(--edu-text);}
.sc-tr{font-size:12px;color:var(--edu-muted);font-weight:700;}
.sc-tr.up,.bv,.success,.ok{color:var(--edu-success)}.sc-tr.dn,.br,.danger,.err{color:var(--edu-danger)}
.sc-ic,.report-card-icon,.quick-ic{background:var(--edu-primary-50);color:var(--edu-primary);border:1px solid var(--edu-primary-100);border-radius:16px;}
.sc-ic{width:54px;height:54px;}
.sc-ic svg,.report-card-icon svg{width:24px;height:24px;}
.pbw{height:7px;background:var(--edu-surface-2);border-radius:999px;}.pbf{background:linear-gradient(90deg,var(--edu-primary),#22C55E);}

/* ===== Buttons ===== */
.btn,button.btn,.top-action,.tb-btn,.ai-btn{font-family:var(--font-ui);min-height:38px;border-radius:12px;font-weight:700;font-size:13px;letter-spacing:-.005em;transition:background .16s ease,border-color .16s ease,color .16s ease,box-shadow .16s ease,transform .16s ease;}
.btn{padding:9px 14px;gap:8px;align-items:center;justify-content:center;}
.btn svg{width:16px;height:16px;flex:0 0 auto;}
.btn:active,.top-action:active,.ai-btn:active{transform:translateY(1px);}
.btn-p,.btn-v,.btn-g,.btn-primary{background:var(--edu-primary);color:#F8FAFC;border:1px solid var(--edu-primary);box-shadow:0 1px 2px rgba(15,23,42,.08),0 8px 20px rgba(26,115,232,.18);}
.btn-p:hover,.btn-v:hover,.btn-g:hover{background:var(--edu-primary-700);border-color:var(--edu-primary-700);}
.btn-o,.btn-secondary{background:var(--edu-surface);color:var(--edu-text-2);border:1px solid var(--edu-border);box-shadow:var(--edu-shadow-xs);}
.btn-o:hover{background:var(--edu-primary-50);border-color:#BFDBFE;color:var(--edu-primary-700);}
.btn-r,.btn-destructive{background:var(--edu-danger-50);color:var(--edu-danger);border:1px solid #FECACA;}
.btn-r:hover{background:#FEE2E2;border-color:#FCA5A5;}
.btn[disabled],.btn.disabled{opacity:.55;cursor:not-allowed;box-shadow:none;}
.btn-sm{min-height:32px;padding:7px 11px;font-size:12px;border-radius:10px;}.btn-xs{min-height:28px;padding:5px 9px;font-size:12px;border-radius:9px;}
.top-action{background:var(--edu-surface);border:1px solid var(--edu-border);color:var(--edu-text-2);padding:8px 12px;display:inline-flex;align-items:center;gap:8px;}
.top-action:hover{background:var(--edu-primary-50);border-color:#BFDBFE;color:var(--edu-primary);}
.top-action.danger{color:var(--edu-danger);}.top-action.secondary b{background:var(--edu-primary);color:#F8FAFC;min-width:20px;height:20px;border-radius:999px;font-size:11px;display:inline-flex;align-items:center;justify-content:center;}

/* ===== Forms ===== */
.fg{margin-bottom:14px;}.fl,label.fl{display:block;font-size:12.5px;font-weight:700;color:var(--edu-text-2);margin:0 0 6px;}
.fi,.si,select.fi,textarea.fi,input.fi{font-family:var(--font-ui);font-size:14px;color:var(--edu-text);background:var(--edu-surface);border:1px solid var(--edu-border-2);border-radius:12px;min-height:42px;padding:10px 12px;box-shadow:0 1px 0 rgba(15,23,42,.02);}
.fi::placeholder,.si::placeholder{color:#94A3B8;}
.fi:hover,.si:hover{border-color:#94A3B8;}
.fi:focus,.si:focus{outline:0;border-color:var(--edu-primary);box-shadow:0 0 0 4px var(--edu-ring);}
textarea.fi{min-height:96px;line-height:1.5;}
input[type="color"].fi{padding:4px;min-height:44px;}
.frow,.frow3,.v210-form,.report-filter-grid{gap:14px;}
.frow{grid-template-columns:repeat(2,minmax(0,1fr));}.frow3,.v210-form{grid-template-columns:repeat(3,minmax(0,1fr));}
.sb{gap:10px;align-items:center;margin-bottom:18px;}.si{min-width:260px;padding-left:38px;background-color:var(--edu-surface);}

/* ===== Tables ===== */
.table-responsive{width:100%;overflow:auto;border-radius:16px;border:1px solid var(--edu-border);background:var(--edu-surface);}
.table-responsive .tbl{border:0;}
.tbl{width:100%;border-collapse:separate;border-spacing:0;background:var(--edu-surface);}
.tbl th{position:sticky;top:0;z-index:1;background:#F1F5F9;color:#475569;font-size:12px;font-weight:800;text-transform:none;letter-spacing:.01em;padding:12px 14px;border-bottom:1px solid var(--edu-border);white-space:nowrap;}
.tbl td{font-size:13.5px;color:var(--edu-text-2);padding:13px 14px;border-bottom:1px solid #EEF2F7;vertical-align:middle;}
.tbl tbody tr:nth-child(even) td{background:#FAFBFC;}
.tbl tbody tr:hover td{background:var(--edu-primary-50);}
.tbl td b,.grade-value,.calificacion,.promedio{font-weight:800;color:var(--edu-text);font-size:15px;}

/* ===== Badges / states ===== */
.bx,.badge,.report-badge{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:800;border:1px solid transparent;}
.bv{background:var(--edu-success-50);border-color:#BBF7D0;color:#15803D;}.br{background:var(--edu-danger-50);border-color:#FECACA;color:#B91C1C;}.ba{background:var(--edu-warning-50);border-color:#FED7AA;color:#B45309;}.baz{background:var(--edu-primary-50);border-color:#BFDBFE;color:var(--edu-primary-700);}.bmo{background:var(--edu-info-50);border-color:#BAE6FD;color:#0369A1;}.bgr{background:#F1F5F9;border-color:var(--edu-border);color:#475569;}
.loading,.es-state{border-radius:18px;background:linear-gradient(180deg,var(--edu-surface),#F8FAFC);border:1px solid var(--edu-border);padding:22px;text-align:center;color:var(--edu-muted);font-weight:700;}
.es-state b{display:block;color:var(--edu-text);font-size:15px;margin-bottom:4px;}.es-state small{display:block;color:var(--edu-muted);font-weight:500;}
.spin,.loader,.es-skeleton{background:linear-gradient(90deg,#E2E8F0 0%,#F8FAFC 45%,#E2E8F0 90%);background-size:240% 100%;animation:edSkeleton 1.2s ease-in-out infinite;}
.spin{width:18px;height:18px;border-radius:999px;display:inline-block;margin-right:8px;vertical-align:middle;}
@keyframes edSkeleton{0%{background-position:160% 0}100%{background-position:-80% 0}}

/* ===== Modal / toast / dropdown-like surfaces ===== */
.modal{background:rgba(15,23,42,.46);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:18px;}
.mbox{border:1px solid var(--edu-border);border-radius:24px;background:var(--edu-surface);box-shadow:var(--edu-shadow-lg);padding:24px;}
.mtitle{font-size:18px;font-weight:800;color:var(--edu-text);letter-spacing:-.02em;}
.cbtn{border:1px solid var(--edu-border);background:var(--edu-surface-2);border-radius:12px;color:var(--edu-text-2);font-size:0;}
.cbtn::after{content:'×';font-size:19px;line-height:1;}
.cbtn:hover{background:var(--edu-danger-50);border-color:#FECACA;color:var(--edu-danger);}
.toast{right:22px;bottom:22px;border-radius:16px;box-shadow:var(--edu-shadow-lg);background:var(--edu-text);font-weight:800;max-width:min(420px,calc(100vw - 36px));}
.toast.ok{background:var(--edu-success);}.toast.err{background:var(--edu-danger);}.toast.warn{background:var(--edu-warning);}.toast.info{background:var(--edu-info);}

/* ===== Attendance thumb-first cards ===== */
.ag{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;}
.ai{border-radius:22px;border:1px solid var(--edu-border);box-shadow:var(--edu-shadow-sm);background:var(--edu-surface);min-height:270px;}
.ai::before{height:5px;background:#CBD5E1;}.ai:hover{box-shadow:var(--edu-shadow-md);border-color:#BFDBFE;}
.ai-head{gap:12px;margin-bottom:12px;}.ai-av{width:48px;height:48px;border-radius:16px;background:#E2E8F0;color:#475569;}
.ai-n{font-size:14px;font-weight:800;color:var(--edu-text);}.ai-mat{font-size:12px;color:var(--edu-muted);}
.ai-status-row{gap:10px;}.ai-pill{background:#F8FAFC;border:1px solid var(--edu-border);border-radius:14px;padding:10px;}.ai-pill .k{font-size:11px}.ai-pill .v{font-size:13px;}
.ai-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px;}
.ai-btn{min-height:44px;border-radius:14px;font-size:12.5px;border-width:1px;}
.ai-btn.P::before{content:'✓';}.ai-btn.F::before{content:'×';}.ai-btn.T::before{content:'◷';}.ai-btn.J::before{content:'i';}.ai-btn::before{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:999px;border:1px solid currentColor;margin-right:4px;font-weight:800;}
.ai-btn.P{color:#15803D;background:var(--edu-success-50);border-color:#BBF7D0;}.ai-btn.F{color:#B91C1C;background:var(--edu-danger-50);border-color:#FECACA;}.ai-btn.T{color:#B45309;background:var(--edu-warning-50);border-color:#FED7AA;}.ai-btn.J{color:#0369A1;background:var(--edu-info-50);border-color:#BAE6FD;}
.ai.P{border-color:#BBF7D0;background:linear-gradient(180deg,var(--edu-success-50),var(--edu-surface) 45%);}.ai.P::before{background:var(--edu-success);}.ai.P .ai-av{background:var(--edu-success);color:#F8FAFC;}.ai.P .ai-btn.P{background:var(--edu-success);color:#F8FAFC;border-color:var(--edu-success);}
.ai.F{border-color:#FECACA;background:linear-gradient(180deg,var(--edu-danger-50),var(--edu-surface) 45%);}.ai.F::before{background:var(--edu-danger);}.ai.F .ai-av{background:var(--edu-danger);color:#F8FAFC;}.ai.F .ai-btn.F{background:var(--edu-danger);color:#F8FAFC;border-color:var(--edu-danger);}
.ai.T{border-color:#FED7AA;background:linear-gradient(180deg,var(--edu-warning-50),var(--edu-surface) 45%);}.ai.T::before{background:var(--edu-warning);}.ai.T .ai-av{background:var(--edu-warning);color:#F8FAFC;}.ai.T .ai-btn.T{background:var(--edu-warning);color:#F8FAFC;border-color:var(--edu-warning);}
.ai.J{border-color:#BAE6FD;background:linear-gradient(180deg,var(--edu-info-50),var(--edu-surface) 45%);}.ai.J::before{background:var(--edu-info);}.ai.J .ai-av{background:var(--edu-info);color:#F8FAFC;}.ai.J .ai-btn.J{background:var(--edu-info);color:#F8FAFC;border-color:var(--edu-info);}
.ai-obs{border-radius:14px;border:1px solid var(--edu-border);background:#F8FAFC;min-height:70px;font-family:var(--font-ui);font-size:13px;padding:10px;}
.ai-saving{font-size:12px;font-weight:800;color:var(--edu-success);min-height:18px;margin-top:5px;}
.as-topbar{background:var(--edu-surface);border:1px solid var(--edu-border);border-radius:20px;padding:14px;box-shadow:var(--edu-shadow-sm);display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:16px;}
.as-legend{margin-left:auto;display:flex;gap:10px;flex-wrap:wrap;color:var(--edu-muted);font-size:12px;}

/* ===== Reports / configurable templates ===== */
.report-shell{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px;}
.report-filter-card,.report-builder-card,.report-section-title{grid-column:1/-1;}
.report-filter-card,.report-builder-card{border-radius:24px;overflow:hidden;}
.report-filter-card::before,.report-builder-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(180deg,var(--edu-primary),var(--edu-info));}
.report-builder-card{position:relative;background:linear-gradient(135deg,var(--edu-surface) 0%,var(--edu-primary-50) 100%);}
.report-builder-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin:12px 0;}
.field-chip-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;}.field-chip{display:inline-flex;gap:6px;align-items:center;padding:7px 10px;border-radius:999px;border:1px solid var(--edu-border);background:var(--edu-surface);font-size:12px;font-weight:700;color:var(--edu-text-2);}.field-chip input{accent-color:var(--edu-primary);}
.report-card{border-radius:22px;background:var(--edu-surface);border:1px solid var(--edu-border);box-shadow:var(--edu-shadow-sm);}
.report-card:hover{box-shadow:var(--edu-shadow-md);border-color:#BFDBFE;}
.report-card h3{font-size:16px;line-height:1.3;color:var(--edu-text);}.report-card p{font-size:13px;color:var(--edu-muted);}
.report-section-title{background:linear-gradient(135deg,#F8FAFC,#EFF6FF);border:1px solid var(--edu-border);border-radius:18px;padding:16px 18px;}
.report-section-title b{font-size:15px;color:var(--edu-primary-700);}.report-section-title small{color:var(--edu-muted);}

/* ===== White label preview ===== */
.brand-preview-card{border:1px dashed #93C5FD;background:linear-gradient(135deg,#F8FAFC,#EFF6FF);border-radius:22px;padding:18px;}
.brand-preview-card .preview-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}.brand-preview-card .preview-logo{width:44px;height:44px;border-radius:14px;background:var(--edu-primary);color:#F8FAFC;display:flex;align-items:center;justify-content:center;font-weight:800}.brand-preview-card .preview-title{font-size:18px;font-weight:800;color:var(--edu-text)}.brand-preview-card .preview-sub{color:var(--edu-muted);font-size:13px}

/* ===== Login enterprise ===== */
body:has(.auth-card){background:radial-gradient(circle at 10% 10%,rgba(26,115,232,.16),transparent 26%),radial-gradient(circle at 90% 20%,rgba(14,165,233,.12),transparent 24%),var(--edu-bg);}
.auth-card{width:min(1080px,100%);border:1px solid var(--edu-border);border-radius:28px;background:var(--edu-surface);box-shadow:var(--edu-shadow-lg);}
.brand-panel{background:linear-gradient(145deg,#173B73 0%,#1A73E8 54%,#38BDF8 120%);}
.brand-panel h1{font-size:clamp(30px,4vw,44px);letter-spacing:-.05em;}.brand-panel p{font-size:15.5px}.security-note{background:rgba(248,250,252,.12);border-color:rgba(248,250,252,.22);border-radius:18px;color:#E2E8F0;}
.form-panel h2{font-size:26px;letter-spacing:-.03em;color:var(--edu-text);}.form-panel .copy{color:var(--edu-muted);}

/* ===== Responsive: tablet / mobile ===== */
.mobile-menu-btn{display:none;}
@media (max-width:1100px){.g4{grid-template-columns:repeat(2,minmax(0,1fr));}.g24{grid-template-columns:1fr}.v210-form,.frow3{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media (max-width:840px){
 .mobile-menu-btn{display:inline-flex}.sidebar{transform:translateX(-105%);transition:transform .2s ease;z-index:500;width:min(292px,86vw)}body.shell-sidebar-open .sidebar{transform:translateX(0)}body.shell-sidebar-open::after{content:'';position:fixed;inset:0;background:rgba(15,23,42,.42);z-index:450;backdrop-filter:blur(4px)}.topbar{left:0;height:60px;padding:0 14px}.main{margin-left:0;margin-top:60px;padding:16px 14px 86px}.tb-right .top-action span,.tb-right .btn{display:none}.pt{font-size:23px}.ps{font-size:13px}.g2,.g3,.g4,.g24,.v210-grid{grid-template-columns:1fr}.frow,.frow3,.v210-form{grid-template-columns:1fr}.as-topbar{align-items:stretch}.as-topbar .fi{flex:1 1 100%}.as-legend{margin-left:0;width:100%}.ag{grid-template-columns:1fr}.ai-btn{min-height:50px;font-size:13px}.auth-card{grid-template-columns:1fr;border-radius:22px}.brand-panel{min-height:auto;padding:28px}.form-panel{padding:28px}.brand-panel h1{font-size:28px;margin-top:26px}
 .table-responsive{border:0;background:transparent;overflow:visible}.table-responsive table.tbl{display:block;background:transparent}.table-responsive thead{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}.table-responsive tbody{display:grid;gap:12px}.table-responsive tr{display:block;background:var(--edu-surface);border:1px solid var(--edu-border);border-radius:18px;box-shadow:var(--edu-shadow-xs);overflow:hidden}.table-responsive td{display:grid;grid-template-columns:minmax(104px,42%) 1fr;gap:10px;align-items:center;padding:10px 12px;border-bottom:1px solid #EEF2F7;background:var(--edu-surface) !important;min-height:42px}.table-responsive td:last-child{border-bottom:0}.table-responsive td::before{content:attr(data-label);font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:800;color:var(--edu-muted)}
}
@media (max-width:520px){.main{padding:14px 10px 84px}.card,.saas-panel,.v210-section{padding:16px;border-radius:20px}.report-shell{grid-template-columns:1fr}.report-builder-grid{grid-template-columns:1fr}.btn{width:100%;justify-content:center}.sb .btn{width:auto}.ct{align-items:flex-start;flex-direction:column}.ai-actions{grid-template-columns:1fr}.brand-panel,.form-panel{padding:22px}.wordmark{font-size:24px}}

/* ===== Print / boletas visual alignment ===== */
@media print{body{background:#F8FAFC;color:#172033}.sidebar,.topbar,.btn,.no-print{display:none !important}.main{margin:0;padding:0}.card,.sheet{box-shadow:none;border:1px solid #CBD5E1}.tbl th{background:#EFF6FF !important;color:#174EA6 !important}}
