@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";:root{--c-brand-50: #eff6ff;--c-brand-100: #dbeafe;--c-brand-200: #bfdbfe;--c-brand-300: #93c5fd;--c-brand-400: #60a5fa;--c-brand-500: #3b82f6;--c-brand-600: #2563eb;--c-brand-700: #1d4ed8;--c-brand-800: #1e3a8a;--c-brand-900: #1e2d6b;--navbar-grad: linear-gradient(135deg, #1e2d6b 0%, #1d4ed8 55%, #2563eb 100%);--navbar-h: 64px;--bg-app: #f0f4f8;--bg-surface: #ffffff;--bg-elevated: #ffffff;--bg-subtle: #f8fafc;--bg-muted: #f1f5f9;--border-color: #e2e8f0;--border-strong: #cbd5e1;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 20px;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--text-invert: #ffffff;--text-brand: #2563eb;--shadow-xs: 0 1px 2px rgba(15,23,42,.05);--shadow-sm: 0 1px 6px rgba(15,23,42,.07);--shadow-md: 0 4px 16px rgba(15,23,42,.08);--shadow-lg: 0 8px 32px rgba(15,23,42,.1);--shadow-xl: 0 16px 48px rgba(15,23,42,.12);--c-success-bg: #f0fdf4;--c-success-txt: #15803d;--c-success-bdr: #bbf7d0;--c-error-bg: #fef2f2;--c-error-txt: #dc2626;--c-error-bdr: #fecaca;--c-warn-bg: #fffbeb;--c-warn-txt: #92400e;--c-warn-bdr: #fde68a;--c-info-bg: #eff6ff;--c-info-txt: #1d4ed8;--c-info-bdr: #bfdbfe;--font-sans: "Plus Jakarta Sans", "Segoe UI", system-ui, sans-serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--ease-out: cubic-bezier(.2, 0, 0, 1);--duration: .15s}[data-theme=dark]{--bg-app: #0b1120;--bg-surface: #131c2e;--bg-elevated: #1a2540;--bg-subtle: #111827;--bg-muted: #1e2d40;--border-color: #1e3a5f;--border-strong: #2d4a70;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #475569;--text-brand: #60a5fa;--shadow-xs: 0 1px 2px rgba(0,0,0,.3);--shadow-sm: 0 1px 6px rgba(0,0,0,.35);--shadow-md: 0 4px 16px rgba(0,0,0,.4);--shadow-lg: 0 8px 32px rgba(0,0,0,.45);--shadow-xl: 0 16px 48px rgba(0,0,0,.5);--c-success-bg: #052e16;--c-success-txt: #4ade80;--c-success-bdr: #14532d;--c-error-bg: #450a0a;--c-error-txt: #f87171;--c-error-bdr: #7f1d1d;--c-warn-bg: #1c1100;--c-warn-txt: #fbbf24;--c-warn-bdr: #451a03;--c-info-bg: #0c1a3a;--c-info-txt: #93c5fd;--c-info-bdr: #1e3a8a}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:1.6;color:var(--text-primary);background-color:var(--bg-app);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s var(--ease-out),color .3s var(--ease-out)}#root{min-height:100vh;display:flex;flex-direction:column}.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-content{flex:1;padding-top:var(--navbar-h);background:var(--bg-app)}.content-wrapper{max-width:1280px;margin:0 auto;padding:var(--space-8) var(--space-6)}@media(max-width:768px){.content-wrapper{padding:var(--space-5) var(--space-4)}}.topnav{position:fixed;top:0;left:0;right:0;height:var(--navbar-h);z-index:1000;background:var(--navbar-grad);box-shadow:0 2px 20px #1e3a8a59;display:flex;align-items:stretch}.topnav-inner{width:100%;max-width:1440px;margin:0 auto;padding:0 var(--space-6);display:flex;align-items:center;gap:var(--space-4)}.topnav-brand{display:flex;align-items:center;gap:var(--space-2);text-decoration:none;flex-shrink:0;margin-right:var(--space-4)}.topnav-brand-icon{width:34px;height:34px;background:#ffffff26;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.topnav-brand-name{font-size:var(--text-lg);font-weight:800;color:#fff;letter-spacing:-.03em;white-space:nowrap}.topnav-links{display:flex;align-items:center;gap:var(--space-1);flex:1}.topnav-link{display:inline-flex;align-items:center;gap:var(--space-2);padding:7px 14px;border-radius:var(--radius-md);border:none;background:transparent;color:#ffffffb8;font-size:var(--text-sm);font-weight:600;font-family:var(--font-sans);cursor:pointer;white-space:nowrap;transition:background var(--duration) var(--ease-out),color var(--duration) var(--ease-out);text-decoration:none}.topnav-link:hover{background:#ffffff1f;color:#fff}.topnav-link.active{background:#ffffff2e;color:#fff}.topnav-link-icon{flex-shrink:0}.topnav-admin-group{position:relative}.topnav-admin-dropdown{position:absolute;top:calc(100% + 10px);left:0;min-width:220px;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:var(--space-2);opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .2s,transform .2s,visibility .2s;z-index:999}.topnav-admin-group:hover .topnav-admin-dropdown,.topnav-admin-group.open .topnav-admin-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.topnav-dropdown-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-2) var(--space-3);border:none;background:none;color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;font-family:var(--font-sans);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--duration),color var(--duration);text-align:left}.topnav-dropdown-item:hover{background:var(--bg-muted);color:var(--text-primary)}.topnav-dropdown-item.active{background:var(--c-brand-50);color:var(--c-brand-700)}[data-theme=dark] .topnav-dropdown-item.active{background:#3b82f626;color:var(--c-brand-400)}.topnav-right{display:flex;align-items:center;gap:var(--space-2);margin-left:auto;flex-shrink:0}.topnav-theme-btn{width:34px;height:34px;border:none;background:#ffffff1f;border-radius:var(--radius-md);color:#ffffffd9;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--duration)}.topnav-theme-btn:hover{background:#ffffff38}.topnav-role-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:.68rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap}.topnav-role-badge--admin{background:#4ade802e;color:#4ade80;border:1px solid rgba(74,222,128,.3)}.topnav-role-badge--student{background:#ffffff24;color:#ffffffe6;border:1px solid rgba(255,255,255,.2)}.topnav-avatar{width:34px;height:34px;border-radius:50%;background:#fff3;border:2px solid rgba(255,255,255,.35);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.topnav-logout{display:inline-flex;align-items:center;gap:var(--space-2);padding:7px 14px;border:1px solid rgba(255,255,255,.2);background:#ffffff14;border-radius:var(--radius-md);color:#ffffffd9;font-size:var(--text-sm);font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:background var(--duration),border-color var(--duration);white-space:nowrap}.topnav-logout:hover{background:#ef444440;border-color:#ef444466;color:#fff}.topnav-hamburger{display:none;width:34px;height:34px;border:none;background:#ffffff1f;border-radius:var(--radius-md);color:#fff;cursor:pointer;align-items:center;justify-content:center;flex-shrink:0}.topnav-mobile-overlay{display:none;position:fixed;inset:0;top:var(--navbar-h);background:#00000080;z-index:998;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.topnav-mobile-overlay.open{display:block}.topnav-mobile-drawer{position:fixed;top:var(--navbar-h);left:0;width:280px;height:calc(100vh - var(--navbar-h));background:var(--bg-surface);z-index:999;padding:var(--space-4);overflow-y:auto;box-shadow:var(--shadow-xl);transform:translate(-100%);transition:transform .25s var(--ease-out)}.topnav-mobile-drawer.open{transform:translate(0)}.topnav-mobile-link{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);border:none;background:none;color:var(--text-secondary);font-size:var(--text-sm);font-weight:600;font-family:var(--font-sans);cursor:pointer;border-radius:var(--radius-md);transition:background var(--duration),color var(--duration);text-align:left}.topnav-mobile-link:hover,.topnav-mobile-link.active{background:var(--c-brand-50);color:var(--c-brand-700)}[data-theme=dark] .topnav-mobile-link:hover,[data-theme=dark] .topnav-mobile-link.active{background:#3b82f626;color:var(--c-brand-400)}.topnav-mobile-divider{border:none;border-top:1px solid var(--border-color);margin:var(--space-2) 0}.topnav-mobile-section-label{font-size:var(--text-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-2) var(--space-4)}@media(max-width:900px){.topnav-links{display:none}.topnav-hamburger{display:flex!important}.topnav-logout span,.topnav-role-badge{display:none}}@media(max-width:480px){.topnav-inner{padding:0 var(--space-4)}.topnav-logout{display:none}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:9px 20px;border-radius:var(--radius-md);border:1px solid transparent;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;cursor:pointer;white-space:nowrap;transition:all var(--duration) var(--ease-out);text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--c-brand-600);color:#fff;border-color:var(--c-brand-600);box-shadow:0 1px 4px #2563eb4d}.btn-primary:hover{background:var(--c-brand-700);border-color:var(--c-brand-700);box-shadow:0 3px 10px #2563eb59;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-surface);color:var(--text-primary);border-color:var(--border-color);box-shadow:var(--shadow-xs)}.btn-secondary:hover{background:var(--bg-muted);border-color:var(--border-strong)}.btn-danger{background:#dc2626;color:#fff;border-color:#dc2626}.btn-danger:hover{background:#b91c1c;border-color:#b91c1c;transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover{background:var(--bg-muted);color:var(--text-primary)}.btn-sm{padding:6px 14px;font-size:var(--text-xs)}.btn-lg{padding:12px 28px;font-size:var(--text-base)}.btn-icon{padding:8px;border-radius:var(--radius-md)}.card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--duration),border-color var(--duration),transform var(--duration)}.card:hover{box-shadow:var(--shadow-md)}.card-interactive:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--border-strong)}.card-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color)}.card-body{padding:var(--space-5) var(--space-6)}.card-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color);background:var(--bg-subtle);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.form-label .required{color:#ef4444;margin-left:2px}.form-control{width:100%;padding:9px 14px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);transition:border-color var(--duration),box-shadow var(--duration);outline:none}.form-control::placeholder{color:var(--text-muted)}.form-control:focus{border-color:var(--c-brand-500);box-shadow:0 0 0 3px #3b82f626}.form-control:disabled{background:var(--bg-muted);opacity:.6;cursor:not-allowed}textarea.form-control{resize:vertical;min-height:100px}select.form-control{cursor:pointer}.table-wrapper{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.table{width:100%;border-collapse:collapse;font-size:var(--text-sm);background:var(--bg-surface)}.table thead tr{background:var(--bg-subtle);border-bottom:1px solid var(--border-color)}.table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.table td{padding:var(--space-3) var(--space-4);color:var(--text-secondary);border-bottom:1px solid var(--border-color);vertical-align:middle}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:var(--bg-subtle)}.table-cell-strong{color:var(--text-primary);font-weight:600}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:var(--text-xs);font-weight:700;letter-spacing:.03em;white-space:nowrap}.badge-blue{background:var(--c-brand-100);color:var(--c-brand-700)}.badge-green{background:#dcfce7;color:#15803d}.badge-red{background:#fee2e2;color:#dc2626}.badge-yellow{background:#fef3c7;color:#92400e}.badge-purple{background:#f5f3ff;color:#7c3aed}.badge-gray{background:var(--bg-muted);color:var(--text-secondary)}[data-theme=dark] .badge-blue{background:#3b82f62e;color:var(--c-brand-300)}[data-theme=dark] .badge-green{background:#4ade801f;color:#4ade80}[data-theme=dark] .badge-red{background:#ef444426;color:#f87171}[data-theme=dark] .badge-yellow{background:#fbbf241f;color:#fbbf24}[data-theme=dark] .badge-purple{background:#a78bfa1f;color:#a78bfa}[data-theme=dark] .badge-gray{background:var(--bg-muted);color:var(--text-secondary)}.alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);line-height:1.5;border:1px solid;margin-bottom:var(--space-4)}.alert-icon{flex-shrink:0;margin-top:1px}.alert-text{flex:1}.alert-close{background:none;border:none;cursor:pointer;opacity:.6;flex-shrink:0;padding:0;display:flex;align-items:center;transition:opacity var(--duration)}.alert-error{background:var(--c-error-bg);color:var(--c-error-txt);border-color:var(--c-error-bdr)}.alert-success{background:var(--c-success-bg);color:var(--c-success-txt);border-color:var(--c-success-bdr)}.alert-warn{background:var(--c-warn-bg);color:var(--c-warn-txt);border-color:var(--c-warn-bdr)}.alert-info{background:var(--c-info-bg);color:var(--c-info-txt);border-color:var(--c-info-bdr)}.toast{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:var(--space-3);background:var(--text-primary);color:var(--bg-surface);padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);font-size:var(--text-sm);font-weight:600;z-index:2000;animation:toastIn .3s var(--ease-out)}.page-header{margin-bottom:var(--space-8)}.page-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.page-title{font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);letter-spacing:-.03em;margin:0 0 4px}.page-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.page-actions{display:flex;gap:var(--space-2);flex-shrink:0}.breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-5)}.breadcrumb-btn{background:none;border:none;padding:0;color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:color var(--duration)}.breadcrumb-btn:hover{color:var(--text-brand)}.breadcrumb-current{color:var(--text-primary);font-weight:600}.state-loading,.state-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-12) var(--space-6);text-align:center;color:var(--text-muted)}.state-empty-icon{width:64px;height:64px;background:var(--bg-muted);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.state-title{font-size:var(--text-base);font-weight:600;color:var(--text-secondary);margin:0}.state-desc{font-size:var(--text-sm);color:var(--text-muted);margin:0;max-width:320px}.spinner{width:24px;height:24px;border:2.5px solid var(--border-color);border-top-color:var(--c-brand-500);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.spinner-sm{width:16px;height:16px;border-width:2px;border-color:#ffffff59;border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-backdrop{position:fixed;inset:0;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1500;display:flex;align-items:center;justify-content:center;padding:var(--space-4);animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:modalIn .25s var(--ease-out)}@keyframes modalIn{0%{transform:translateY(20px) scale(.97);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color)}.modal-title{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin:0}.modal-body{padding:var(--space-6)}.modal-footer{display:flex;gap:var(--space-3);justify-content:flex-end;padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color);background:var(--bg-subtle);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.modal-close-btn{width:32px;height:32px;background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:background var(--duration),color var(--duration)}.modal-close-btn:hover{background:var(--bg-muted);color:var(--text-primary)}.stat-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:var(--space-4)}.stat-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-value{font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);letter-spacing:-.03em;line-height:1}.stat-label{font-size:var(--text-xs);color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.toggle{position:relative;display:inline-flex;align-items:center;cursor:pointer;gap:var(--space-3)}.toggle input{position:absolute;opacity:0;width:0;height:0}.toggle-track{width:40px;height:22px;background:var(--border-strong);border-radius:20px;transition:background .2s;flex-shrink:0;position:relative}.toggle input:checked+.toggle-track{background:var(--c-brand-500)}.toggle-track:after{content:"";position:absolute;width:16px;height:16px;background:#fff;border-radius:50%;top:3px;left:3px;transition:transform .2s var(--ease-out);box-shadow:0 1px 3px #0003}.toggle input:checked+.toggle-track:after{transform:translate(18px)}.search-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;color:var(--text-muted);pointer-events:none;flex-shrink:0}.search-input{width:100%;padding:9px 14px 9px 38px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);outline:none;transition:border-color var(--duration),box-shadow var(--duration)}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{border-color:var(--c-brand-400);box-shadow:0 0 0 3px #3b82f61f}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.w-full{width:100%}.text-sm{font-size:var(--text-sm)}.text-muted{color:var(--text-muted)}.font-semibold{font-weight:600}.font-bold{font-weight:700}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:root{--primary-blue: var(--c-brand-600);--light-blue: var(--c-brand-50);--dark-blue: var(--c-brand-800);--white: #ffffff;--gray-light: var(--bg-app);--gray-dark: var(--text-primary);--danger: #dc2626}.auth-container{position:fixed;inset:0;display:flex;justify-content:center;align-items:center;padding:20px;overflow:auto;background:var(--bg-app)}.auth-container:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse 80% 60% at 30% 20%,rgba(37,99,235,.12) 0%,transparent 60%),radial-gradient(ellipse 60% 60% at 80% 80%,rgba(29,78,216,.08) 0%,transparent 55%);pointer-events:none;z-index:0}.auth-card{position:relative;z-index:1;background:var(--bg-surface);padding:40px;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:420px;border:1px solid var(--border-color);animation:authCardIn .35s var(--ease-out)}@keyframes authCardIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.auth-logo{text-align:center;margin-bottom:32px}.auth-logo-icon-wrap{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--navbar-grad);border-radius:16px;margin-bottom:16px;box-shadow:0 4px 16px #2563eb59}.auth-logo h1{font-family:var(--font-sans);color:var(--text-primary);font-size:1.75rem;font-weight:800;margin:0 0 6px;letter-spacing:-.04em}.auth-subtitle{color:var(--text-secondary);font-size:var(--text-sm);margin:0}.auth-divider{display:flex;align-items:center;gap:12px;margin-bottom:20px;color:var(--text-muted);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.06em}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.auth-hint{text-align:center;color:var(--text-secondary);font-size:var(--text-sm);margin:0 0 14px}.btn-google{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;background:var(--bg-surface);color:var(--text-primary);border:1.5px solid var(--border-color);border-radius:var(--radius-md);padding:11px 16px;font-size:var(--text-sm);font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:background var(--duration),box-shadow var(--duration),border-color var(--duration),transform var(--duration);box-shadow:var(--shadow-xs)}.btn-google:hover:not(:disabled){background:var(--bg-muted);border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-google:disabled{opacity:.55;cursor:not-allowed}.google-icon{width:18px;height:18px;flex-shrink:0}.auth-dev-panel{border-top:1px dashed var(--border-color);padding-top:20px;margin-top:20px}.auth-dev-panel p{text-align:center;color:var(--text-muted);font-size:var(--text-xs);margin:0 0 12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.auth-dev-buttons{display:flex;gap:10px;justify-content:center}.auth-dev-buttons button{flex:1;padding:9px 14px;border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:opacity .15s,transform .15s}.auth-dev-buttons button:first-child{background:#059669;color:#fff}.auth-dev-buttons button:last-child{background:var(--c-brand-600);color:#fff}.auth-dev-buttons button:hover{opacity:.88;transform:translateY(-1px)}.alert-error{display:flex;align-items:flex-start;gap:10px;background:var(--c-error-bg);color:var(--c-error-txt);padding:12px 14px;border-radius:var(--radius-md);border:1px solid var(--c-error-bdr);margin-bottom:20px;font-size:var(--text-sm);line-height:1.5}.alert-icon{flex-shrink:0}.alert-error span:nth-child(2){flex:1}.alert-close{background:none;border:none;color:var(--c-error-txt);cursor:pointer;font-size:.85rem;padding:0;flex-shrink:0;opacity:.7}.alert-close:hover{opacity:1}@media(max-width:480px){.auth-card{padding:28px 20px}.auth-logo h1{font-size:1.5rem}}.mat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:20px}.mat-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow .2s var(--ease-out),transform .15s var(--ease-out),border-color .15s;position:relative}.mat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--mat-accent, var(--c-brand-500));border-radius:var(--radius-lg) var(--radius-lg) 0 0}.mat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:var(--border-strong)}.mat-card-icon{width:48px;height:48px;border-radius:var(--radius-md);margin:20px 20px 0;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mat-card-body{flex:1;padding:14px 20px 16px}.mat-card-nombre{font-size:var(--text-base);font-weight:700;color:var(--text-primary);margin:0 0 6px;letter-spacing:-.01em}.mat-card-desc{font-size:var(--text-sm);color:var(--text-secondary);margin:0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.mat-card-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--bg-subtle);border:none;width:100%;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;color:var(--text-brand);cursor:pointer;transition:background var(--duration),color var(--duration);border-top:1px solid var(--border-color)}.mat-card-footer:hover{background:var(--c-brand-50);color:var(--c-brand-700)}[data-theme=dark] .mat-card-footer:hover{background:#3b82f61a}.mat-card-footer:disabled{opacity:.5;cursor:not-allowed}.mat-modos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.mat-modo-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:28px 24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px;transition:box-shadow .2s,transform .15s}.mat-modo-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.mat-modo-card--test{border-top:3px solid var(--c-brand-500)}.mat-modo-card--examen{border-top:3px solid #059669}.mat-modo-icon{width:52px;height:52px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.mat-modo-title{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.02em}.mat-modo-desc{font-size:var(--text-sm);color:var(--text-secondary);margin:0;line-height:1.6}.mat-modo-meta{display:flex;flex-wrap:wrap;gap:8px}.mat-modo-meta span{display:inline-flex;align-items:center;gap:5px;font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);background:var(--bg-muted);padding:4px 10px;border-radius:20px}.mat-modo-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.mat-modo-list li{font-size:var(--text-sm);color:var(--text-secondary);padding-left:18px;position:relative}.mat-modo-list li:before{content:"✓";position:absolute;left:0;color:var(--c-brand-500);font-weight:700;font-size:.8rem}.mat-modo-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;border:none;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:700;cursor:pointer;transition:all var(--duration) var(--ease-out);margin-top:auto}.mat-modo-btn:disabled{opacity:.5;cursor:not-allowed}.mat-btn-test{background:var(--c-brand-600);color:#fff;box-shadow:0 2px 8px #2563eb4d}.mat-btn-test:hover:not(:disabled){background:var(--c-brand-700);transform:translateY(-1px);box-shadow:0 4px 14px #2563eb66}.mat-btn-examen{background:#059669;color:#fff;box-shadow:0 2px 8px #0596694d}.mat-btn-examen:hover:not(:disabled){background:#047857;transform:translateY(-1px);box-shadow:0 4px 14px #05966966}.mat-btn-retomar{background:var(--c-warn-bg);color:var(--c-warn-txt);border:1px solid var(--c-warn-bdr)}.mat-btn-retomar:hover:not(:disabled){background:#fde68a}.mat-toast{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:10px;background:var(--text-primary);color:var(--bg-surface);padding:12px 20px;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);font-size:var(--text-sm);font-weight:600;font-family:var(--font-sans);z-index:2000;animation:toastIn .3s var(--ease-out)}@keyframes toastIn{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.mat-breadcrumb{display:flex;align-items:center;gap:6px;font-size:var(--text-sm);color:var(--text-muted);margin-bottom:20px}.mat-breadcrumb button{background:none;border:none;padding:0;color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:color var(--duration)}.mat-breadcrumb button:hover{color:var(--text-brand)}.mat-breadcrumb span{color:var(--text-primary);font-weight:600}.mat-header{margin-bottom:28px}.mat-title{font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);margin:0 0 4px;letter-spacing:-.03em}.mat-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.mat-detail-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:28px}.mat-back-btn{display:inline-flex;align-items:center;gap:6px;background:var(--bg-surface);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--radius-md);padding:7px 14px;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;cursor:pointer;box-shadow:var(--shadow-xs);transition:background var(--duration),border-color var(--duration);white-space:nowrap;flex-shrink:0;margin-top:5px}.mat-back-btn:hover{background:var(--bg-muted);border-color:var(--border-strong)}.mat-error-banner{display:flex;align-items:center;gap:8px;background:var(--c-error-bg);border:1px solid var(--c-error-bdr);color:var(--c-error-txt);border-radius:var(--radius-md);padding:12px 16px;margin-bottom:20px;font-size:var(--text-sm)}.mat-error-banner button{background:none;border:none;color:var(--c-error-txt);cursor:pointer}.mat-warn-banner{display:flex;align-items:center;gap:8px;background:var(--c-warn-bg);border:1px solid var(--c-warn-bdr);color:var(--c-warn-txt);border-radius:var(--radius-md);padding:12px 16px;margin-bottom:20px;font-size:var(--text-sm)}.mat-state{display:flex;align-items:center;gap:12px;padding:48px 0;color:var(--text-muted);font-size:var(--text-sm)}.mat-spinner{width:22px;height:22px;border:2.5px solid var(--border-color);border-top-color:var(--c-brand-500);border-radius:50%;animation:mat-spin .7s linear infinite}.mat-spinner-sm{width:16px;height:16px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:mat-spin .7s linear infinite}@keyframes mat-spin{to{transform:rotate(360deg)}}.mat-empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:56px 20px;text-align:center;color:var(--text-muted)}.mat-empty p{margin:0;font-size:var(--text-sm);color:var(--text-secondary)}.mat-empty-icon{width:60px;height:60px;background:var(--bg-muted);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}@media(max-width:640px){.mat-grid,.mat-modos-grid{grid-template-columns:1fr}}.mat-root{max-width:1100px;margin:0 auto;padding-bottom:40px}.ev-root{max-width:820px;margin:0 auto;padding-bottom:40px}.ev-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;flex-wrap:wrap}.ev-topbar-left{display:flex;align-items:center;gap:14px;min-width:0}.ev-mode-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ev-mode-icon--test{background:var(--c-info-bg);color:var(--c-info-txt)}.ev-mode-icon--examen{background:#f5f3ff;color:#7c3aed}[data-theme=dark] .ev-mode-icon--test{background:#1d4ed826;color:#93c5fd}[data-theme=dark] .ev-mode-icon--examen{background:#a78bfa1f;color:#a78bfa}.ev-mode-label{font-size:var(--text-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.ev-mode-sub{font-size:var(--text-base);font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ev-timer{display:inline-flex;align-items:center;gap:7px;padding:6px 14px;border-radius:var(--radius-md);background:var(--c-info-bg);border:1px solid var(--c-info-bdr);color:var(--c-info-txt);font-size:var(--text-base);font-weight:800;font-family:monospace;white-space:nowrap}.ev-timer--urgente{background:var(--c-error-bg);border-color:var(--c-error-bdr);color:var(--c-error-txt);animation:ev-blink 1s infinite}@keyframes ev-blink{0%,50%{opacity:1}51%,to{opacity:.5}}.ev-salir-btn,.ev-btn-volver{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;cursor:pointer;flex-shrink:0;transition:background .15s,border-color .15s,transform .1s}.ev-salir-btn:hover,.ev-btn-volver:hover{background:var(--bg-muted);border-color:var(--border-strong);transform:translateY(-1px)}.ev-error-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;margin-bottom:20px;background:var(--c-error-bg);border:1px solid var(--c-error-bdr);color:var(--c-error-txt);border-radius:var(--radius-md);font-size:var(--text-sm)}.ev-progress-bar-wrap{margin-bottom:20px}.ev-progress-labels{display:flex;justify-content:space-between;font-size:var(--text-xs);color:var(--text-muted);font-weight:600;margin-bottom:6px}.ev-progress-track{height:7px;background:var(--border-color);border-radius:4px;overflow:hidden}.ev-progress-fill{height:100%;border-radius:4px;transition:width .4s var(--ease-out)}.ev-progress-fill--test{background:linear-gradient(90deg,var(--c-brand-500),var(--c-brand-400))}.ev-progress-fill--examen{background:linear-gradient(90deg,#7c3aed,#a78bfa)}.ev-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-md);margin-bottom:20px}.ev-badges{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}.ev-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:var(--text-xs);font-weight:700}.ev-badge--num{background:var(--bg-muted);color:var(--text-secondary)}.ev-badge--tipo{background:var(--c-info-bg);color:var(--c-info-txt);border:1px solid var(--c-info-bdr)}.ev-badge--ok{background:var(--c-success-bg);color:var(--c-success-txt);border:1px solid var(--c-success-bdr)}.ev-badge--fail{background:var(--c-error-bg);color:var(--c-error-txt);border:1px solid var(--c-error-bdr)}.ev-badge--respondida{background:var(--c-brand-50);color:var(--c-brand-600)}.ev-enunciado{font-size:var(--text-base);font-weight:500;color:var(--text-primary);line-height:1.65;margin:0 0 20px}.ev-imagen{max-width:100%;border-radius:var(--radius-lg);margin-bottom:20px;border:1px solid var(--border-color)}.ev-opciones{display:flex;flex-direction:column;gap:10px}.ev-opcion{display:flex;align-items:center;gap:14px;width:100%;padding:13px 16px;background:var(--bg-subtle);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;font-family:var(--font-sans);font-size:var(--text-sm);text-align:left;transition:border-color .15s,background .15s,transform .1s}.ev-opcion--idle{border-color:var(--border-color)}.ev-opcion--seleccionada{border-color:var(--c-brand-500);background:var(--c-brand-50)}.ev-opcion--correcta{border-color:#22c55e;background:var(--c-success-bg)}.ev-opcion--incorrecta{border-color:#ef4444;background:var(--c-error-bg)}.ev-opcion:disabled{cursor:default}[data-theme=dark] .ev-opcion--seleccionada{background:#2563eb1a}[data-theme=dark] .ev-opcion--correcta{background:#22c55e14}[data-theme=dark] .ev-opcion--incorrecta{background:#ef444414}.ev-opcion-radio{flex-shrink:0;color:var(--text-muted);display:flex;align-items:center}.ev-opcion-radio--idle{color:var(--text-muted)}.ev-opcion-radio--seleccionada{color:var(--c-brand-500)}.ev-opcion-radio--correcta{color:#22c55e}.ev-opcion-radio--incorrecta{color:#ef4444}.ev-opcion-letra{flex-shrink:0;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:800;background:var(--bg-muted);color:var(--text-secondary)}.ev-opcion-letra--seleccionada{background:var(--c-brand-600);color:#fff}.ev-opcion-letra--correcta{background:#22c55e;color:#fff}.ev-opcion-letra--incorrecta{background:#ef4444;color:#fff}.ev-opcion-letra--idle{background:var(--bg-muted);color:var(--text-secondary)}.ev-opcion-texto{flex:1;color:var(--text-primary);font-weight:500}.ev-feedback{display:flex;align-items:flex-start;gap:10px;margin-top:16px;padding:12px 16px;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600}.ev-feedback--ok{background:var(--c-success-bg);color:var(--c-success-txt);border:1px solid var(--c-success-bdr)}.ev-feedback--fail{background:var(--c-error-bg);color:var(--c-error-txt);border:1px solid var(--c-error-bdr)}.ev-feedback-sub{font-size:var(--text-xs);font-weight:400;margin:4px 0 0;opacity:.9}.ev-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.ev-nav-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:700;cursor:pointer;border:none;transition:background .15s,opacity .15s,transform .1s}.ev-nav-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.ev-nav-btn--prev{background:var(--bg-muted);color:var(--text-secondary)}.ev-nav-btn--next{background:var(--c-brand-600);color:#fff}.ev-nav-btn--finish{background:#059669;color:#fff}.ev-nav-btn--prev:hover:not(:disabled){background:var(--bg-surface)}.ev-nav-btn--next:hover:not(:disabled){background:var(--c-brand-700);transform:translateY(-1px)}.ev-nav-btn--finish:hover:not(:disabled){background:#047857;transform:translateY(-1px)}.ev-dots{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;flex:1}.ev-dot{width:10px;height:10px;border-radius:50%;border:none;cursor:pointer;padding:0;background:var(--border-color);transition:background .2s,transform .15s}.ev-dot:hover{transform:scale(1.3)}.ev-dot--actual{background:var(--c-brand-500);transform:scale(1.25)}.ev-dot--ok{background:#22c55e}.ev-dot--fail{background:#ef4444}.ev-dot--respondida{background:var(--c-brand-300)}.ev-resultado{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px 24px;text-align:center;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.ev-resultado-icon{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center}.ev-resultado-icon--ok{background:var(--c-success-bg);color:var(--c-success-txt)}.ev-resultado-icon--fail{background:var(--c-error-bg);color:var(--c-error-txt)}.ev-resultado-title{font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);margin:0}.ev-resultado-sub{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.ev-resultado-nota{display:flex;align-items:baseline;gap:4px}.ev-nota-num{font-size:4rem;font-weight:900;line-height:1}.ev-nota-den{font-size:var(--text-xl);font-weight:700;color:var(--text-muted)}.ev-nota--ok{color:var(--c-success-txt)}.ev-nota--fail{color:var(--c-error-txt)}.ev-resultado-stats{display:flex;align-items:center;gap:24px;background:var(--bg-muted);border-radius:var(--radius-lg);padding:16px 28px;flex-wrap:wrap;justify-content:center}.ev-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.ev-stat-val{font-size:var(--text-xl);font-weight:800;color:var(--text-primary);line-height:1}.ev-stat-label{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.ev-stat-sep{width:1px;height:36px;background:var(--border-color)}.ev-spinner-sm{width:18px;height:18px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:ev-spin .7s linear infinite}@keyframes ev-spin{to{transform:rotate(360deg)}}.ev-modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;animation:ev-fade-in .15s ease}@keyframes ev-fade-in{0%{opacity:0}to{opacity:1}}.ev-modal{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:32px;max-width:400px;width:100%;box-shadow:var(--shadow-xl);animation:ev-slide-up .2s var(--ease-out)}@keyframes ev-slide-up{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.ev-modal-icon{width:56px;height:56px;border-radius:50%;background:var(--c-warn-bg);color:var(--c-warn-txt);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.ev-modal-title{font-size:var(--text-lg);font-weight:800;color:var(--text-primary);margin:0 0 8px;text-align:center}.ev-modal-msg{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 24px;text-align:center;line-height:1.6}.ev-modal-actions{display:flex;gap:10px;justify-content:center}.ev-modal-btn{padding:10px 22px;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:700;cursor:pointer;border:none;transition:background .15s,transform .1s}.ev-modal-btn--cancel{background:var(--bg-muted);color:var(--text-secondary)}.ev-modal-btn--confirm{background:var(--c-brand-600);color:#fff}.ev-modal-btn--cancel:hover{background:var(--bg-surface)}.ev-modal-btn--confirm:hover{background:var(--c-brand-700);transform:translateY(-1px)}@media(max-width:600px){.ev-card{padding:20px 16px}.ev-resultado{padding:32px 16px}.ev-nota-num{font-size:3rem}.ev-resultado-stats{gap:16px;padding:14px 18px}.ev-nav{flex-direction:column;align-items:stretch}.ev-nav-btn{justify-content:center}.ev-dots{order:-1}}.ev-opcion--hover{cursor:pointer}.ev-opcion--hover:hover:not(:disabled){border-color:var(--c-brand-400);background:var(--c-brand-50);transform:translate(3px)}[data-theme=dark] .ev-opcion--hover:hover:not(:disabled){background:#2563eb14}.hi-root{max-width:1100px;margin:0 auto;padding:8px 0 40px}.hi-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}.hi-titulo{font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);margin:0 0 4px;letter-spacing:-.03em}.hi-subtitulo{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.hi-tabs{display:flex;gap:4px;margin-bottom:24px;background:var(--bg-muted);border-radius:var(--radius-md);padding:4px;width:fit-content}.hi-tab{display:inline-flex;align-items:center;gap:7px;padding:8px 18px;border:none;background:none;border-radius:var(--radius-sm);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s}.hi-tab--active{background:var(--bg-surface);color:var(--text-primary);box-shadow:var(--shadow-xs)}.hi-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px}.hi-stat{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px 18px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:flex-start;gap:8px;transition:box-shadow .2s,border-color .15s}.hi-stat:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong)}.hi-stat-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.hi-stat-icon--blue{background:var(--c-brand-50);color:var(--c-brand-600)}.hi-stat-icon--green{background:var(--c-success-bg);color:var(--c-success-txt)}.hi-stat-icon--teal{background:#f0fdfa;color:#0d9488}.hi-stat-icon--orange{background:var(--c-warn-bg);color:#d97706}[data-theme=dark] .hi-stat-icon--blue{background:#2563eb26;color:var(--c-brand-400)}[data-theme=dark] .hi-stat-icon--green{background:#22c55e1f;color:#4ade80}[data-theme=dark] .hi-stat-icon--teal{background:#0d94881f;color:#2dd4bf}[data-theme=dark] .hi-stat-icon--orange{background:#f59e0b1f;color:#fbbf24}.hi-stat-val{font-size:var(--text-2xl);font-weight:800;line-height:1}.hi-stat-val--blue{color:var(--c-brand-600)}.hi-stat-val--green{color:var(--c-success-txt)}.hi-stat-val--teal{color:#0d9488}.hi-stat-val--orange{color:#d97706}[data-theme=dark] .hi-stat-val--blue{color:var(--c-brand-400)}[data-theme=dark] .hi-stat-val--green{color:#4ade80}[data-theme=dark] .hi-stat-val--teal{color:#2dd4bf}[data-theme=dark] .hi-stat-val--orange{color:#fbbf24}.hi-stat-label{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;line-height:1.3}.hi-filtros-wrap{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:20px}.hi-filtros-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex:1}.hi-filtros-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.hi-search{position:relative;flex:1;min-width:180px;max-width:300px}.hi-search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.hi-search input{width:100%;padding:9px 14px 9px 36px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);outline:none;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.hi-search input:focus{border-color:var(--c-brand-500);box-shadow:0 0 0 3px #3b82f61f}.hi-select-wrap{position:relative;flex-shrink:0}.hi-select-wrap select{appearance:none;padding:9px 34px 9px 12px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);cursor:pointer;outline:none;transition:border-color .15s}.hi-select-wrap select:focus{border-color:var(--c-brand-500)}.hi-select-arrow{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.hi-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;cursor:pointer;border:1px solid transparent;transition:background .15s,border-color .15s,box-shadow .15s,transform .1s;white-space:nowrap}.hi-btn--primary{background:var(--c-brand-600);color:#fff;border-color:var(--c-brand-600)}.hi-btn--primary:hover{background:var(--c-brand-700);box-shadow:var(--shadow-md);transform:translateY(-1px)}.hi-btn--export{background:var(--bg-surface);color:var(--text-secondary);border-color:var(--border-color)}.hi-btn--export:hover{background:var(--bg-muted);border-color:var(--border-strong)}.hi-btn--ghost{background:none;color:var(--text-muted);border-color:transparent}.hi-btn--ghost:hover{color:var(--text-secondary);background:var(--bg-muted)}.hi-tabla{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.hi-tabla-head{display:grid;grid-template-columns:1fr 90px 150px 130px 110px 90px;padding:10px 20px;background:var(--bg-muted);border-bottom:1px solid var(--border-color)}.hi-tabla-head--todos{grid-template-columns:170px 1fr 90px 150px 130px 110px 90px}.hi-tabla-head span{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.hi-fila{display:grid;grid-template-columns:1fr 90px 150px 130px 110px 90px;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background .15s;gap:8px}.hi-fila:last-child{border-bottom:none}.hi-fila:hover{background:var(--bg-subtle)}.hi-fila-usuario{display:flex;align-items:center;gap:10px;min-width:0;grid-column:1}.hi-avatar{width:32px;height:32px;border-radius:50%;background:var(--c-brand-600);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:700;flex-shrink:0}.hi-usuario-nombre{display:block;font-size:var(--text-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hi-usuario-correo{display:block;font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hi-fila-materia{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hi-fila-modo{display:flex;align-items:center}.hi-fila-puntuacion{display:flex;flex-direction:column;gap:2px}.hi-pct{font-size:var(--text-base);font-weight:800;color:var(--text-primary);line-height:1}.hi-correctas{font-size:var(--text-xs);color:var(--text-muted)}.hi-fila-fecha,.hi-fila-duracion{display:flex;align-items:center;gap:5px;font-size:var(--text-xs);color:var(--text-secondary);font-weight:500}.hi-icon-sm{color:var(--text-muted);flex-shrink:0}.hi-fila-estado{display:flex;align-items:center}.hi-modo-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:var(--text-xs);font-weight:700}.hi-modo-badge--examen{background:#f5f3ff;color:#7c3aed;border:1px solid #ddd6fe}.hi-modo-badge--test{background:var(--c-info-bg);color:var(--c-info-txt);border:1px solid var(--c-info-bdr)}[data-theme=dark] .hi-modo-badge--examen{background:#a78bfa1f;color:#a78bfa;border-color:#a78bfa33}.hi-estado-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:var(--text-xs);font-weight:700}.hi-estado-badge--ok{background:var(--c-success-bg);color:var(--c-success-txt);border:1px solid var(--c-success-bdr)}.hi-estado-badge--fail{background:var(--c-error-bg);color:var(--c-error-txt);border:1px solid var(--c-error-bdr)}.hi-state{display:flex;flex-direction:column;align-items:center;gap:14px;padding:60px 20px;text-align:center;color:var(--text-muted);font-size:var(--text-sm)}.hi-state--error{color:var(--c-error-txt)}.hi-spinner{width:24px;height:24px;border:2.5px solid var(--border-color);border-top-color:var(--c-brand-500);border-radius:50%;animation:hi-spin .7s linear infinite}@keyframes hi-spin{to{transform:rotate(360deg)}}.hi-back{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:none;border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);cursor:pointer;margin-bottom:24px;transition:background .15s,border-color .15s}.hi-back:hover{background:var(--bg-muted);border-color:var(--border-strong)}.hi-detalle-header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;margin-bottom:16px;box-shadow:var(--shadow-sm)}.hi-detalle-titulo{font-size:var(--text-xl);font-weight:800;color:var(--text-primary);margin:0 0 10px}.hi-detalle-meta{display:flex;flex-wrap:wrap;align-items:center;gap:12px}.hi-detalle-meta span{display:inline-flex;align-items:center;gap:5px;font-size:var(--text-xs);color:var(--text-muted);font-weight:500}.hi-detalle-nota{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0}.hi-detalle-nota-num{font-size:var(--text-3xl);font-weight:900;line-height:1}.hi-detalle-nota--ok{color:var(--c-success-txt)}.hi-detalle-nota--fail{color:var(--c-error-txt)}.hi-detalle-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.hi-dstat{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:18px 16px;display:flex;flex-direction:column;align-items:center;gap:4px;box-shadow:var(--shadow-xs)}.hi-dstat span{font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);line-height:1}.hi-dstat small{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.hi-detalle-placeholder{display:flex;flex-direction:column;align-items:center;gap:14px;padding:48px 20px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);text-align:center;color:var(--text-muted)}.hi-detalle-placeholder p{margin:0;font-size:var(--text-sm)}@media(max-width:900px){.hi-stats,.hi-detalle-stats{grid-template-columns:repeat(2,1fr)}.hi-tabla-head,.hi-fila{grid-template-columns:1fr 100px 100px 80px}.hi-tabla-head--todos,.hi-fila.hi-fila--todos{grid-template-columns:140px 1fr 100px 80px}.hi-fila-duracion{display:none}.hi-tabla-head span:nth-child(6){display:none}}@media(max-width:600px){.hi-stats,.hi-detalle-stats{grid-template-columns:repeat(2,1fr)}.hi-filtros-wrap{flex-direction:column;align-items:stretch}.hi-filtros-row{flex-direction:column}.hi-search{max-width:100%}.hi-tabla-head,.hi-fila{grid-template-columns:1fr 90px 80px}.hi-fila-modo,.hi-fila-fecha,.hi-fila-duracion{display:none}.hi-detalle-header{flex-direction:column}.hi-detalle-nota{align-items:flex-start}}.fo-root{max-width:860px;margin:0 auto;padding-bottom:40px}.fo-header{margin-bottom:24px}.fo-titulo{font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);margin:0 0 4px;letter-spacing:-.03em}.fo-subtitulo{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.fo-filtros{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px;align-items:center}.fo-filtro-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:20px;font-family:var(--font-sans);font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:background .15s,border-color .15s,color .15s}.fo-filtro-btn:hover{background:var(--bg-muted);border-color:var(--border-strong)}.fo-filtro-btn--active{background:var(--c-brand-600);color:#fff;border-color:var(--c-brand-600)}.fo-filtro-count{background:#ffffff40;border-radius:20px;padding:0 6px;font-size:10px;font-weight:700}.fo-filtro-btn:not(.fo-filtro-btn--active) .fo-filtro-count{background:var(--bg-muted);color:var(--text-muted)}.fo-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;cursor:pointer;border:none;transition:background .15s,transform .1s,box-shadow .15s}.fo-btn--primary{background:var(--c-brand-600);color:#fff}.fo-btn--primary:hover{background:var(--c-brand-700);transform:translateY(-1px);box-shadow:var(--shadow-md)}.fo-btn--ghost{background:none;color:var(--text-secondary);border:1px solid var(--border-color)}.fo-btn--ghost:hover{background:var(--bg-muted);border-color:var(--border-strong)}.fo-btn--success{background:#059669;color:#fff}.fo-btn--success:hover{background:#047857;transform:translateY(-1px)}.fo-btn--sm{padding:6px 12px;font-size:var(--text-xs)}.fo-lista{display:flex;flex-direction:column;gap:12px}.fo-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);cursor:pointer;transition:box-shadow .2s,border-color .15s,transform .15s}.fo-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong);transform:translateY(-1px)}.fo-card-titulo{font-size:var(--text-base);font-weight:700;color:var(--text-primary);margin:0 0 8px;line-height:1.4}.fo-card-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:var(--text-xs);color:var(--text-muted);font-weight:500}.fo-card-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}.fo-tags{display:flex;gap:6px;flex-wrap:wrap}.fo-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:20px;font-size:var(--text-xs);font-weight:700}.fo-tag--cat{background:var(--c-info-bg);color:var(--c-info-txt);border:1px solid var(--c-info-bdr)}.fo-tag--nuevo{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}.fo-tag--resuelto{background:var(--bg-muted);color:var(--text-muted);border:1px solid var(--border-color)}[data-theme=dark] .fo-tag--nuevo{background:#22c55e1a;color:#4ade80;border-color:#22c55e33}.fo-avatar{width:34px;height:34px;border-radius:50%;background:var(--c-brand-600);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:700;flex-shrink:0}.fo-like-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:20px;background:var(--bg-muted);border:1px solid var(--border-color);font-family:var(--font-sans);font-size:var(--text-xs);font-weight:700;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.fo-like-btn:hover{background:var(--c-error-bg);color:var(--c-error-txt);border-color:var(--c-error-bdr)}.fo-like-btn--sm{padding:3px 8px}.fo-resp-count{display:inline-flex;align-items:center;gap:5px;font-size:var(--text-xs);color:var(--text-muted);font-weight:600}.fo-detalle{display:flex;flex-direction:column;gap:16px}.fo-back{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:none;border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:background .15s,border-color .15s}.fo-back:hover{background:var(--bg-muted);border-color:var(--border-strong)}.fo-pregunta-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-md)}.fo-pregunta-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.fo-pregunta-titulo{font-size:var(--text-xl);font-weight:800;color:var(--text-primary);margin:0;flex:1;line-height:1.35}.fo-pregunta-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:var(--text-xs);color:var(--text-muted);font-weight:500;margin-bottom:16px}.fo-pregunta-contenido{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.7;margin-bottom:20px}.fo-pregunta-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding-top:16px;border-top:1px solid var(--border-color)}.fo-respuestas{display:flex;flex-direction:column;gap:12px}.fo-resp-titulo{font-size:var(--text-base);font-weight:700;color:var(--text-secondary);margin:0 0 12px;display:flex;align-items:center;gap:8px}.fo-resp-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--shadow-xs)}.fo-resp-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.fo-resp-autor{display:flex;flex-direction:column;gap:1px}.fo-resp-nombre{font-size:var(--text-sm);font-weight:700;color:var(--text-primary)}.fo-resp-fecha{font-size:var(--text-xs);color:var(--text-muted)}.fo-resp-texto{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.65}.fo-reply-box{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm)}.fo-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.fo-field label{font-size:var(--text-xs);font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.fo-field input,.fo-field textarea,.fo-field select{padding:9px 12px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);outline:none;resize:vertical;transition:border-color .15s,box-shadow .15s}.fo-field input:focus,.fo-field textarea:focus,.fo-field select:focus{border-color:var(--c-brand-500);box-shadow:0 0 0 3px #3b82f61f}.fo-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;animation:fo-fade .15s ease}@keyframes fo-fade{0%{opacity:0}to{opacity:1}}.fo-modal{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:520px;box-shadow:var(--shadow-xl);animation:fo-up .2s var(--ease-out);display:flex;flex-direction:column;max-height:90vh}@keyframes fo-up{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.fo-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color)}.fo-modal-header h3{font-size:var(--text-lg);font-weight:800;color:var(--text-primary);margin:0}.fo-modal-close{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;transition:color .15s,background .15s}.fo-modal-close:hover{color:var(--text-primary);background:var(--bg-muted)}.fo-modal-form{padding:20px 24px;overflow-y:auto;flex:1}.fo-modal-actions{display:flex;gap:10px;justify-content:flex-end;padding:16px 24px;border-top:1px solid var(--border-color)}.fo-empty{display:flex;flex-direction:column;align-items:center;gap:14px;padding:60px 20px;text-align:center;color:var(--text-muted)}.fo-empty h3{font-size:var(--text-base);font-weight:700;margin:0}.fo-empty p{font-size:var(--text-sm);margin:0}.ab-root{max-width:860px;margin:0 auto}.ab-hero{text-align:center;padding:48px 24px 40px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);margin-bottom:24px;position:relative;overflow:hidden}.ab-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 70% 50% at 50% 0%,rgba(37,99,235,.07) 0%,transparent 70%);pointer-events:none}.ab-hero-icon{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;background:var(--navbar-grad);border-radius:20px;color:#fff;margin-bottom:20px;box-shadow:0 6px 20px #2563eb59}.ab-hero-title{font-size:var(--text-3xl);font-weight:800;color:var(--text-primary);margin:0 0 12px;letter-spacing:-.04em}.ab-hero-desc{font-size:var(--text-base);color:var(--text-secondary);max-width:560px;margin:0 auto;line-height:1.7}.ab-stats{display:flex;align-items:center;justify-content:center;gap:0;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);margin-bottom:24px;overflow:hidden}.ab-stat{display:flex;flex-direction:column;align-items:center;gap:4px;padding:24px 32px;flex:1}.ab-stat-icon{color:var(--c-brand-500);margin-bottom:4px}.ab-stat-val{font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);letter-spacing:-.03em}.ab-stat-label{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.ab-stat-sep{width:1px;background:var(--border-color);align-self:stretch;flex-shrink:0}.ab-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:20px;margin-bottom:20px}.ab-section{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-sm)}.ab-section-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.ab-section-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ab-section-title{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);margin:0}.ab-section-text{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.75;margin:0}.ab-feature-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.ab-feature-item{display:flex;align-items:flex-start;gap:10px}.ab-feature-icon{width:28px;height:28px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.ab-feature-text{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;flex:1}.ab-feature-title{font-weight:700;color:var(--text-primary);display:block;margin-bottom:2px}.ab-tech-grid{display:flex;flex-wrap:wrap;gap:8px}.ab-tech-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;background:var(--bg-muted);border:1px solid var(--border-color);font-size:var(--text-xs);font-weight:700;color:var(--text-secondary)}.ab-tech-chip-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.ab-contact-list{display:flex;flex-direction:column;gap:12px}.ab-contact-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--radius-md);background:var(--bg-subtle);border:1px solid var(--border-color);font-size:var(--text-sm);color:var(--text-secondary)}.ab-contact-icon{color:var(--c-brand-500);flex-shrink:0}.ab-version-card{background:var(--navbar-grad);border-radius:var(--radius-xl);padding:24px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:20px}.ab-version-label{font-size:var(--text-sm);color:#ffffffb3;font-weight:600;margin:0 0 4px}.ab-version-val{font-size:var(--text-xl);font-weight:800;color:#fff;margin:0;letter-spacing:-.02em}.ab-version-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:#ffffff26;border:1px solid rgba(255,255,255,.25);border-radius:20px;font-size:var(--text-xs);font-weight:700;color:#ffffffe6}@media(max-width:768px){.ab-stats{flex-direction:column}.ab-stat-sep{width:100%;height:1px}.ab-stat{padding:18px 24px}.ab-grid{grid-template-columns:1fr}.ab-hero-title{font-size:var(--text-2xl)}}.gm-root{max-width:1000px;margin:0 auto;padding-bottom:40px}.gm-section{margin-bottom:36px}.gm-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;flex-wrap:wrap}.gm-section-title{font-size:var(--text-xl);font-weight:800;color:var(--text-primary);margin:0;letter-spacing:-.02em}.gm-error-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;margin-bottom:20px;background:var(--c-error-bg);border:1px solid var(--c-error-bdr);color:var(--c-error-txt);border-radius:var(--radius-md);font-size:var(--text-sm)}.gm-state{display:flex;flex-direction:column;align-items:center;gap:14px;padding:48px 20px;text-align:center;color:var(--text-muted);font-size:var(--text-sm)}.gm-toast{position:fixed;bottom:24px;right:24px;z-index:9999;padding:12px 20px;border-radius:var(--radius-md);background:#1e293b;color:#fff;font-size:var(--text-sm);font-weight:600;box-shadow:var(--shadow-xl);animation:gm-slide-up .25s var(--ease-out)}@keyframes gm-slide-up{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.gm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.gm-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow .2s,border-color .15s,transform .15s}.gm-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong);transform:translateY(-2px)}.gm-card-icon{width:100%;height:80px;background:var(--navbar-grad);display:flex;align-items:center;justify-content:center;color:#ffffffb3}.gm-icon-green{background:linear-gradient(135deg,#059669,#34d399)}.gm-card-body{padding:16px}.gm-card-nombre{font-size:var(--text-base);font-weight:700;color:var(--text-primary);margin:0 0 8px;line-height:1.3}.gm-badge-count{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:20px;background:var(--bg-muted);color:var(--text-secondary);font-size:var(--text-xs);font-weight:700}.gm-card-fecha{font-size:var(--text-xs);color:var(--text-muted);margin-top:6px}.gm-card-footer{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border-color);background:var(--bg-subtle)}.gm-btn-primary{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--c-brand-600);color:#fff;border:none;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s}.gm-btn-primary:hover{background:var(--c-brand-700);transform:translateY(-1px);box-shadow:var(--shadow-md)}.gm-btn-secondary{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.gm-btn-secondary:hover{background:var(--bg-muted);border-color:var(--border-strong)}.gm-btn-delete{display:inline-flex;align-items:center;gap:5px;padding:7px 12px;background:var(--c-error-bg);color:var(--c-error-txt);border:1px solid var(--c-error-bdr);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-xs);font-weight:700;cursor:pointer;transition:background .15s,transform .1s}.gm-btn-delete:hover{background:#fee2e2;transform:translateY(-1px)}.gm-input--err{border-color:var(--c-error-txt)!important;box-shadow:0 0 0 3px #dc26261f!important}.gm-input-error{font-size:var(--text-xs);color:var(--c-error-txt);margin-top:4px}.gm-actions-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:28px}.gm-action-card{flex:1;min-width:200px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:18px;display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow-xs);cursor:pointer;transition:box-shadow .2s,border-color .15s,transform .15s;text-decoration:none}.gm-action-card:hover{box-shadow:var(--shadow-md);border-color:var(--c-brand-300);transform:translateY(-2px)}.gm-action-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--c-brand-50);color:var(--c-brand-600);display:flex;align-items:center;justify-content:center}.gm-action-title{font-size:var(--text-sm);font-weight:700;color:var(--text-primary)}.gm-action-desc{font-size:var(--text-xs);color:var(--text-muted)}.gm-action-link{font-size:var(--text-xs);color:var(--c-brand-600);font-weight:600;margin-top:auto}.gm-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.gm-confirm-modal{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:32px;max-width:400px;width:100%;box-shadow:var(--shadow-xl);animation:gm-slide-up .2s var(--ease-out)}.gm-confirm-icon{width:56px;height:56px;border-radius:50%;background:var(--c-error-bg);color:var(--c-error-txt);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.gm-confirm-title{font-size:var(--text-lg);font-weight:800;color:var(--text-primary);margin:0 0 8px;text-align:center}.gm-confirm-msg{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 24px;text-align:center;line-height:1.6}.gm-confirm-actions{display:flex;gap:10px;justify-content:center}.gm-confirm-btn{padding:10px 22px;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:700;cursor:pointer;border:none;transition:background .15s,transform .1s}.gm-confirm-btn--cancel{background:var(--bg-muted);color:var(--text-secondary)}.gm-confirm-btn--cancel:hover{background:var(--bg-surface)}.gm-confirm-btn--delete{background:#dc2626;color:#fff}.gm-confirm-btn--delete:hover{background:#b91c1c;transform:translateY(-1px)}.gm-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:24px;flex-wrap:wrap}.gm-title{font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);margin:0 0 4px;letter-spacing:-.03em}.gm-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.gm-empty{display:flex;flex-direction:column;align-items:center;gap:14px;padding:60px 20px;text-align:center;color:var(--text-muted);font-size:var(--text-sm)}.gm-empty-icon{width:64px;height:64px;border-radius:var(--radius-xl);background:var(--bg-muted);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.gm-spinner{width:24px;height:24px;border:2.5px solid var(--border-color);border-top-color:var(--c-brand-500);border-radius:50%;animation:gm-spin .7s linear infinite}@keyframes gm-spin{to{transform:rotate(360deg)}}.gm-btn-edit{display:inline-flex;align-items:center;gap:5px;padding:7px 12px;background:var(--c-info-bg);color:var(--c-info-txt);border:1px solid var(--c-info-bdr);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-xs);font-weight:700;cursor:pointer;transition:background .15s,transform .1s}.gm-btn-edit:hover{background:#dbeafe;transform:translateY(-1px)}.gm-input{width:100%;padding:9px 12px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);outline:none;transition:border-color .15s,box-shadow .15s}.gm-input:focus{border-color:var(--c-brand-500);box-shadow:0 0 0 3px #3b82f61f}.gm-label{font-size:var(--text-xs);font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:6px}.gm-modal{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:480px;box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-height:90vh;animation:gm-slide-up .2s var(--ease-out)}.gm-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color)}.gm-modal-header h3{font-size:var(--text-lg);font-weight:800;color:var(--text-primary);margin:0}.gm-modal-close{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:var(--radius-sm);display:flex;transition:color .15s,background .15s}.gm-modal-close:hover{color:var(--text-primary);background:var(--bg-muted)}.gm-modal-body{padding:20px 24px;overflow-y:auto;flex:1}.gm-modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:16px 24px;border-top:1px solid var(--border-color)}.gp-root{max-width:1000px;margin:0 auto;padding-bottom:40px}.gp-page{padding-bottom:40px}.gp-page--form{max-width:720px}.gp-page-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:24px;flex-wrap:wrap}.gp-page-footer{display:flex;justify-content:flex-end;gap:10px;padding-top:20px;border-top:1px solid var(--border-color);margin-top:24px}.gp-back-link{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);cursor:pointer;text-decoration:none;transition:background .15s,border-color .15s}.gp-back-link:hover{background:var(--bg-muted);border-color:var(--border-strong)}.gp-topbar{display:flex;align-items:center;gap:12px;margin-bottom:24px;flex-wrap:wrap}.gp-topbar-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.gp-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}.gp-section-title{font-size:var(--text-lg);font-weight:800;color:var(--text-primary);margin:0}.gp-error-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;margin-bottom:20px;background:var(--c-error-bg);border:1px solid var(--c-error-bdr);color:var(--c-error-txt);border-radius:var(--radius-md);font-size:var(--text-sm)}.gp-state{display:flex;flex-direction:column;align-items:center;gap:14px;padding:48px 20px;text-align:center;color:var(--text-muted);font-size:var(--text-sm)}.gp-toast{position:fixed;bottom:24px;right:24px;z-index:9999;padding:12px 20px;border-radius:var(--radius-md);background:#1e293b;color:#fff;font-size:var(--text-sm);font-weight:600;box-shadow:var(--shadow-xl);animation:gp-up .25s var(--ease-out)}@keyframes gp-up{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.gp-no-materia{display:flex;flex-direction:column;align-items:center;gap:16px;padding:60px 20px;text-align:center;color:var(--text-muted)}.gp-no-materia-icon{width:72px;height:72px;border-radius:var(--radius-xl);background:var(--bg-muted);display:flex;align-items:center;justify-content:center}.gp-materia-selector{position:relative;margin-bottom:24px}.gp-materia-btn{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;color:var(--text-primary);cursor:pointer;text-align:left;transition:border-color .15s,box-shadow .15s}.gp-materia-btn:hover{border-color:var(--c-brand-400);box-shadow:0 0 0 3px #3b82f61a}.gp-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:100;max-height:260px;overflow-y:auto}.gp-dropdown-item{display:flex;align-items:center;gap:10px;padding:11px 16px;font-size:var(--text-sm);font-weight:500;color:var(--text-primary);cursor:pointer;transition:background .12s}.gp-dropdown-item:hover{background:var(--bg-muted)}.gp-dropdown-item--active{background:var(--c-brand-50);color:var(--c-brand-700);font-weight:700}[data-theme=dark] .gp-dropdown-item--active{background:#2563eb1a;color:var(--c-brand-400)}.gp-dropdown-empty,.gp-dropdown-loading{padding:16px;font-size:var(--text-sm);color:var(--text-muted);text-align:center}.gp-badge-count{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;background:var(--bg-muted);color:var(--text-secondary);font-size:var(--text-xs);font-weight:700}.gp-modo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:28px}.gp-modo-card{background:var(--bg-surface);border:2px solid var(--border-color);border-radius:var(--radius-xl);padding:20px;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s}.gp-modo-card:hover{border-color:var(--c-brand-400);box-shadow:var(--shadow-md);transform:translateY(-2px)}.gp-modo-card--maint{opacity:.5;cursor:not-allowed}.gp-modo-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:12px}.gp-modo-blue{background:var(--c-info-bg);color:var(--c-info-txt)}.gp-modo-green{background:var(--c-success-bg);color:var(--c-success-txt)}.gp-modo-list{font-size:var(--text-xs);color:var(--text-muted);margin-top:8px;display:flex;flex-direction:column;gap:3px}.gp-modo-list--green{color:var(--c-success-txt)}.gp-action-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:16px;cursor:pointer;display:flex;flex-direction:column;gap:8px;text-decoration:none;transition:box-shadow .2s,border-color .15s,transform .15s}.gp-action-card:hover{box-shadow:var(--shadow-md);border-color:var(--c-brand-300);transform:translateY(-2px)}.gp-action-card--config{border-color:#ddd6fe}.gp-action-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.gp-icon-blue{background:var(--c-info-bg);color:var(--c-info-txt)}.gp-icon-amber{background:var(--c-warn-bg);color:var(--c-warn-txt)}.gp-action-title{font-size:var(--text-sm);font-weight:700;color:var(--text-primary)}.gp-action-desc{font-size:var(--text-xs);color:var(--text-muted)}.gp-action-link{font-size:var(--text-xs);color:var(--c-brand-600);font-weight:600;margin-top:auto}.gp-list{display:flex;flex-direction:column;gap:10px}.gp-item{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xs);transition:box-shadow .15s,border-color .15s}.gp-item:hover{box-shadow:var(--shadow-sm);border-color:var(--border-strong)}.gp-item-body{display:flex;align-items:flex-start;gap:14px;padding:16px}.gp-item-num{width:30px;height:30px;border-radius:50%;background:var(--bg-muted);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:800;flex-shrink:0}.gp-item-enunciado{flex:1;font-size:var(--text-sm);font-weight:500;color:var(--text-primary);line-height:1.55}.gp-item-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:6px}.gp-item-actions{display:flex;gap:8px;flex-shrink:0}.gp-opts-count{font-size:var(--text-xs);color:var(--text-muted);font-weight:600}.gp-tipo-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:20px;font-size:var(--text-xs);font-weight:700}.gp-tipo-MULTIPLE{background:var(--c-info-bg);color:var(--c-info-txt);border:1px solid var(--c-info-bdr)}.gp-tipo-VERDADERO_FALSO{background:#f5f3ff;color:#7c3aed;border:1px solid #ddd6fe}.gp-tipo-COMPLETAR{background:var(--c-warn-bg);color:var(--c-warn-txt);border:1px solid var(--c-warn-bdr)}.gp-form-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-sm);margin-bottom:16px}.gp-form-tipo-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:20px;font-size:var(--text-xs);font-weight:700;background:var(--c-info-bg);color:var(--c-info-txt);border:1px solid var(--c-info-bdr)}.gp-form-error{font-size:var(--text-xs);color:var(--c-error-txt);margin-top:4px}.gp-input--err{border-color:var(--c-error-txt)!important;box-shadow:0 0 0 3px #dc26261f!important}.gp-hint{font-size:var(--text-xs);color:var(--text-muted);margin-top:4px}.gp-tipo-grid{display:flex;gap:10px;flex-wrap:wrap}.gp-tipo-card{flex:1;min-width:120px;padding:14px;background:var(--bg-muted);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;text-align:center;transition:border-color .15s,background .15s}.gp-tipo-card:hover{border-color:var(--c-brand-400)}.gp-tipo-icon{margin:0 auto 6px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.gp-label-opt{font-size:var(--text-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;display:block}.gp-add-opcion{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;background:var(--bg-muted);color:var(--text-secondary);border:1px dashed var(--border-strong);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;cursor:pointer;margin-top:8px;transition:background .15s,border-color .15s}.gp-add-opcion:hover{background:var(--c-brand-50);border-color:var(--c-brand-400);color:var(--c-brand-600)}.gp-opcion-del{display:inline-flex;align-items:center;padding:4px;background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:color .15s,background .15s}.gp-opcion-del:hover{color:var(--c-error-txt);background:var(--c-error-bg)}.gp-opcion-radio--active{color:var(--c-brand-600)}.gp-opcion-row--correct{background:var(--c-success-bg);border-radius:var(--radius-md)}.gp-btn-delete{display:inline-flex;align-items:center;gap:5px;padding:7px 12px;background:var(--c-error-bg);color:var(--c-error-txt);border:1px solid var(--c-error-bdr);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-xs);font-weight:700;cursor:pointer;transition:background .15s,transform .1s}.gp-btn-delete:hover{background:#fee2e2;transform:translateY(-1px)}.gp-cfg-info{background:var(--c-info-bg);border:1px solid var(--c-info-bdr);border-radius:var(--radius-lg);padding:16px;margin-bottom:20px;font-size:var(--text-sm);color:var(--c-info-txt)}.gp-cfg-list{display:flex;flex-direction:column;gap:16px}.gp-cfg-row{display:flex;flex-direction:column;gap:6px}.gp-cfg-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:20px;font-size:var(--text-xs);font-weight:700}.gp-cfg-tag--EXAMEN{background:#f5f3ff;color:#7c3aed;border:1px solid #ddd6fe}.gp-cfg-tag--TEST{background:var(--c-info-bg);color:var(--c-info-txt);border:1px solid var(--c-info-bdr)}.gp-cfg-badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.gp-cfg-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;background:var(--bg-muted);color:var(--text-secondary);border:1px solid var(--border-color);font-size:var(--text-xs);font-weight:600}.gp-cfg-badge--empty{opacity:.5}.gp-cfg-exists{font-size:var(--text-xs);color:var(--c-success-txt);font-weight:600}.gp-cfg-modo-row{display:flex;gap:10px}.gp-cfg-modo-card{flex:1;padding:14px;border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:border-color .15s,background .15s}.gp-cfg-modo-card--active{border-color:var(--c-brand-600);background:var(--c-brand-50)}[data-theme=dark] .gp-cfg-modo-card--active{background:#2563eb14}.gp-cfg-modo-name{font-size:var(--text-sm);font-weight:700;color:var(--text-primary)}.gp-cfg-modo-desc{font-size:var(--text-xs);color:var(--text-muted);margin-top:4px}.gp-vf-card{padding:14px 18px;border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:border-color .15s}.gp-vf-card--active{border-color:var(--c-brand-600);background:var(--c-brand-50)}[data-theme=dark] .gp-vf-card--active{background:#2563eb14}.gp-vf-row{display:flex;align-items:center;gap:10px}.gp-title{font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);margin:0 0 4px;letter-spacing:-.03em}.gp-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.gp-empty{display:flex;flex-direction:column;align-items:center;gap:14px;padding:60px 20px;text-align:center;color:var(--text-muted);font-size:var(--text-sm)}.gp-empty-icon{width:64px;height:64px;border-radius:var(--radius-xl);background:var(--bg-muted);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.gp-spinner{width:24px;height:24px;border:2.5px solid var(--border-color);border-top-color:var(--c-brand-500);border-radius:50%;animation:gp-spin .7s linear infinite}.gp-spinner-sm{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:gp-spin .7s linear infinite}@keyframes gp-spin{to{transform:rotate(360deg)}}.gp-actions-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:28px}.gp-back-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:background .15s,border-color .15s}.gp-back-btn:hover{background:var(--bg-muted);border-color:var(--border-strong)}.gp-btn-primary{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--c-brand-600);color:#fff;border:none;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background .15s,transform .1s}.gp-btn-primary:hover{background:var(--c-brand-700);transform:translateY(-1px)}.gp-btn-secondary{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background .15s}.gp-btn-secondary:hover{background:var(--bg-muted)}.gp-btn-edit{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;background:var(--c-info-bg);color:var(--c-info-txt);border:1px solid var(--c-info-bdr);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-xs);font-weight:700;cursor:pointer;transition:background .15s}.gp-btn-edit:hover{background:#dbeafe}.gp-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.gp-label{font-size:var(--text-xs);font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.gp-input,.gp-textarea{width:100%;padding:9px 12px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);outline:none;transition:border-color .15s,box-shadow .15s}.gp-textarea{resize:vertical;min-height:80px}.gp-input:focus,.gp-textarea:focus{border-color:var(--c-brand-500);box-shadow:0 0 0 3px #3b82f61f}.gp-opciones{display:flex;flex-direction:column;gap:8px}.gp-opcion-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-subtle);border:1px solid var(--border-color);border-radius:var(--radius-md)}.gp-opcion-input{flex:1;padding:7px 10px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-primary);outline:none}.gp-opcion-input:focus{border-color:var(--c-brand-400)}.gp-opcion-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--border-color);background:var(--bg-surface);cursor:pointer;flex-shrink:0;transition:border-color .15s,background .15s;display:flex;align-items:center;justify-content:center}.gu-root{max-width:1000px;margin:0 auto;padding-bottom:40px}.gu-error-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 16px;margin-bottom:20px;background:var(--c-error-bg);border:1px solid var(--c-error-bdr);color:var(--c-error-txt);border-radius:var(--radius-md);font-size:var(--text-sm)}.gu-error-close{background:none;border:none;cursor:pointer;color:var(--c-error-txt);padding:2px;opacity:.7;flex-shrink:0}.gu-error-close:hover{opacity:1}.gu-btn-add{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--c-brand-600);color:#fff;border:none;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s}.gu-btn-add:hover{background:var(--c-brand-700);transform:translateY(-1px);box-shadow:var(--shadow-md)}.gu-btn-delete{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;background:var(--c-error-bg);color:var(--c-error-txt);border:1px solid var(--c-error-bdr);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-xs);font-weight:700;cursor:pointer;transition:background .15s}.gu-btn-delete:hover{background:#fee2e2}.gu-tabla{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.gu-thead{display:grid;grid-template-columns:60px 1fr 180px 110px 80px 80px;padding:10px 20px;background:var(--bg-muted);border-bottom:1px solid var(--border-color)}.gu-thead span{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.gu-fila{display:grid;grid-template-columns:60px 1fr 180px 110px 80px 80px;align-items:center;padding:12px 20px;border-bottom:1px solid var(--border-color);transition:background .12s}.gu-fila:last-child{border-bottom:none}.gu-fila:hover{background:var(--bg-subtle)}.gu-td-id{font-size:var(--text-xs);color:var(--text-muted);font-weight:600}.gu-td-email{font-size:var(--text-sm);color:var(--text-secondary)}.gu-td-state{display:flex;align-items:center}.gu-badge--ADMINISTRADOR{display:inline-flex;padding:3px 10px;border-radius:20px;font-size:var(--text-xs);font-weight:700;background:#f5f3ff;color:#7c3aed;border:1px solid #ddd6fe}.gu-badge--ESTUDIANTE{display:inline-flex;padding:3px 10px;border-radius:20px;font-size:var(--text-xs);font-weight:700;background:var(--c-info-bg);color:var(--c-info-txt);border:1px solid var(--c-info-bdr)}[data-theme=dark] .gu-badge--ADMINISTRADOR{background:#a78bfa1f;color:#a78bfa;border-color:#a78bfa33}.gu-switch{position:relative;display:inline-flex;cursor:pointer;width:40px;height:22px}.gu-switch input{opacity:0;width:0;height:0;position:absolute}.gu-switch-track{width:40px;height:22px;border-radius:11px;background:var(--border-color);transition:background .2s;position:relative}.gu-switch-track:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px #0003}.gu-switch--on .gu-switch-track{background:#22c55e}.gu-switch--on .gu-switch-track:after{transform:translate(18px)}.gu-switch--disabled{opacity:.45;cursor:not-allowed}.gu-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:24px;flex-wrap:wrap}.gu-title{font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);margin:0 0 4px;letter-spacing:-.03em}.gu-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.gu-spinner{width:24px;height:24px;border:2.5px solid var(--border-color);border-top-color:var(--c-brand-500);border-radius:50%;animation:gu-spin .7s linear infinite}@keyframes gu-spin{to{transform:rotate(360deg)}}.gu-badge{display:inline-flex;padding:3px 10px;border-radius:20px;font-size:var(--text-xs);font-weight:700;background:var(--bg-muted);color:var(--text-secondary)}.gu-actions{display:flex;gap:8px;align-items:center}.gu-table-wrap{overflow-x:auto}.gu-table{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);min-width:600px}.gi-root{max-width:1000px;margin:0 auto;padding-bottom:40px}.gi-error-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;margin-bottom:20px;background:var(--c-error-bg);border:1px solid var(--c-error-bdr);color:var(--c-error-txt);border-radius:var(--radius-md);font-size:var(--text-sm)}.gi-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:28px}.gi-stat{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:18px 16px;display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow-xs)}.gi-stat-icon{width:38px;height:38px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.gi-stat-icon--blue{background:var(--c-brand-50);color:var(--c-brand-600)}.gi-stat-icon--green{background:var(--c-success-bg);color:var(--c-success-txt)}.gi-stat-icon--red{background:var(--c-error-bg);color:var(--c-error-txt)}.gi-stat-num{font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);line-height:1}.gi-stat-lbl{font-size:var(--text-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.gi-search-box{position:relative;flex:1;min-width:180px;max-width:300px}.gi-search-ico{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.gi-search-box input{width:100%;padding:9px 34px 9px 36px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);outline:none;transition:border-color .15s}.gi-search-box input:focus{border-color:var(--c-brand-500)}.gi-search-clr{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px}.gi-search-clr:hover{color:var(--text-primary)}.gi-sel-wrap{position:relative;flex-shrink:0}.gi-sel-wrap select{appearance:none;padding:9px 32px 9px 12px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);cursor:pointer;outline:none}.gi-sel-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.gi-tabla{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.gi-thead{display:grid;grid-template-columns:160px 1fr 100px 100px 110px 80px;padding:10px 20px;background:var(--bg-muted);border-bottom:1px solid var(--border-color)}.gi-thead span{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.gi-fila{display:grid;grid-template-columns:160px 1fr 100px 100px 110px 80px;align-items:center;padding:12px 20px;border-bottom:1px solid var(--border-color);transition:background .12s}.gi-fila:last-child{border-bottom:none}.gi-fila:hover{background:var(--bg-subtle)}.gi-student-name{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.gi-student-email{font-size:var(--text-xs);color:var(--text-muted)}.gi-td-mat{font-size:var(--text-sm);color:var(--text-primary)}.gi-td-state{display:flex;align-items:center}.gi-fecha{font-size:var(--text-xs);color:var(--text-muted)}.gi-actions{display:flex;gap:6px}.gi-badge-status,.gi-badge-modo{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:20px;font-size:var(--text-xs);font-weight:700}.gi-badge-status--ACTIVA{background:var(--c-success-bg);color:var(--c-success-txt);border:1px solid var(--c-success-bdr)}.gi-badge-status--INACTIVA{background:var(--bg-muted);color:var(--text-muted);border:1px solid var(--border-color)}.gi-badge-modo--EXAMEN{background:#f5f3ff;color:#7c3aed;border:1px solid #ddd6fe}.gi-badge-modo--TEST{background:var(--c-info-bg);color:var(--c-info-txt);border:1px solid var(--c-info-bdr)}.gi-sw{position:relative;display:inline-flex;cursor:pointer;width:40px;height:22px;flex-shrink:0}.gi-sw input{opacity:0;width:0;height:0;position:absolute}.gi-sw-track{width:40px;height:22px;border-radius:11px;background:var(--border-color);transition:background .2s;position:relative}.gi-sw-track:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px #0003}.gi-sw--on .gi-sw-track{background:#22c55e}.gi-sw--on .gi-sw-track:after{transform:translate(18px)}.gi-sw--off .gi-sw-track{background:var(--c-error-txt)}.gi-btn-add{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--c-brand-600);color:#fff;border:none;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s}.gi-btn-add:hover{background:var(--c-brand-700);transform:translateY(-1px);box-shadow:var(--shadow-md)}.gi-btn-confirm{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--c-brand-600);color:#fff;border:none;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background .15s}.gi-btn-confirm:hover{background:var(--c-brand-700)}.gi-empty-icon{width:64px;height:64px;border-radius:var(--radius-xl);background:var(--bg-muted);display:flex;align-items:center;justify-content:center;color:var(--text-muted);margin:0 auto}.gi-inline-error{font-size:var(--text-xs);color:var(--c-error-txt);margin-top:4px}.gi-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.gi-field label{font-size:var(--text-xs);font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.gi-field input,.gi-field select{padding:9px 12px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);outline:none;transition:border-color .15s,box-shadow .15s}.gi-field input:focus,.gi-field select:focus{border-color:var(--c-brand-500);box-shadow:0 0 0 3px #3b82f61f}.gi-modo-grid{display:flex;gap:10px;flex-wrap:wrap}.gi-modo-card{flex:1;min-width:130px;padding:16px;background:var(--bg-muted);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;text-align:center;transition:border-color .15s,background .15s}.gi-modo-card:hover{border-color:var(--c-brand-400)}.gi-modo-card--active{border-color:var(--c-brand-600);background:var(--c-brand-50)}[data-theme=dark] .gi-modo-card--active{background:#2563eb14}.gi-modo-emoji{font-size:1.5rem;margin-bottom:6px}.gi-modo-name{font-size:var(--text-sm);font-weight:700;color:var(--text-primary)}.gi-modo-desc{font-size:var(--text-xs);color:var(--text-muted);margin-top:4px}.gi-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.gi-modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color)}.gi-modal-head h3{font-size:var(--text-lg);font-weight:800;color:var(--text-primary);margin:0}.gi-modal-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--c-brand-50);color:var(--c-brand-600);display:flex;align-items:center;justify-content:center}.gi-modal-x{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:var(--radius-sm);display:flex;transition:color .15s,background .15s}.gi-modal-x:hover{color:var(--text-primary);background:var(--bg-muted)}.gi-modal-loading{display:flex;align-items:center;gap:10px;padding:32px;justify-content:center;color:var(--text-muted)}.gi-modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:16px 24px;border-top:1px solid var(--border-color)}.gi-title{font-size:var(--text-2xl);font-weight:800;color:var(--text-primary);margin:0 0 4px;letter-spacing:-.03em}.gi-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.gi-spinner{width:24px;height:24px;border:2.5px solid var(--border-color);border-top-color:var(--c-brand-500);border-radius:50%;animation:gi-spin .7s linear infinite}@keyframes gi-spin{to{transform:rotate(360deg)}}.gi-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.gi-search{position:relative;flex:1;min-width:180px;max-width:300px}.gi-search input{width:100%;padding:9px 14px 9px 36px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);outline:none;box-sizing:border-box}.gi-select{appearance:none;padding:9px 32px 9px 12px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);cursor:pointer;outline:none}.gi-label{font-size:var(--text-xs);font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:6px}.gi-table-wrap{overflow-x:auto}.gi-table{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);min-width:700px}.gi-modal{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:500px;box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-height:90vh;animation:gi-up .2s var(--ease-out)}@keyframes gi-up{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.gi-modal-body{padding:20px 24px;overflow-y:auto;flex:1}.gi-btn-cancel{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--bg-muted);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background .15s}.gi-btn-cancel:hover{background:var(--bg-surface)}.gi-btn-del{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;background:var(--c-error-bg);color:var(--c-error-txt);border:1px solid var(--c-error-bdr);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-xs);font-weight:700;cursor:pointer;transition:background .15s}.gi-btn-del:hover{background:#fee2e2}.ce-root{max-width:1000px;margin:0 auto;padding-bottom:40px}.ce-topbar{display:flex;align-items:center;gap:12px;margin-bottom:24px;flex-wrap:wrap}.ce-title{font-size:var(--text-xl);font-weight:800;color:var(--text-primary);margin:0}.ce-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.ce-back-btn,.ce-back-link{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);cursor:pointer;text-decoration:none;transition:background .15s,border-color .15s}.ce-back-btn:hover,.ce-back-link:hover{background:var(--bg-muted);border-color:var(--border-strong)}.ce-info-banner,.ce-error-banner{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-radius:var(--radius-md);font-size:var(--text-sm);margin-bottom:16px;line-height:1.5}.ce-info-banner{background:var(--c-info-bg);border:1px solid var(--c-info-bdr);color:var(--c-info-txt)}.ce-error-banner{background:var(--c-error-bg);border:1px solid var(--c-error-bdr);color:var(--c-error-txt)}.ce-dropzone{border:2px dashed var(--border-color);border-radius:var(--radius-xl);padding:48px 32px;text-align:center;cursor:pointer;background:var(--bg-subtle);transition:border-color .2s,background .2s}.ce-dropzone:hover,.ce-dropzone--active{border-color:var(--c-brand-400);background:var(--c-brand-50)}[data-theme=dark] .ce-dropzone:hover,[data-theme=dark] .ce-dropzone--active{background:#2563eb0f}.ce-drop-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:var(--radius-xl);background:var(--bg-muted);color:var(--text-muted);margin:0 auto 16px}.ce-drop-hint{font-size:var(--text-sm);color:var(--text-muted);margin:8px 0 0}.ce-plantilla-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);cursor:pointer;margin-top:16px;transition:background .15s,border-color .15s}.ce-plantilla-btn:hover{background:var(--bg-muted);border-color:var(--border-strong)}.ce-tabla{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:20px}.ce-fila{border-bottom:1px solid var(--border-color);padding:14px 18px;transition:background .15s}.ce-fila:last-child{border-bottom:none}.ce-fila:hover{background:var(--bg-subtle)}.ce-fila--error{background:var(--c-error-bg)}.ce-fila--editing{background:var(--c-info-bg)}.ce-fila-header{display:flex;align-items:center;gap:12px;margin-bottom:6px}.ce-fila-num{width:28px;height:28px;border-radius:50%;background:var(--bg-muted);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:800;flex-shrink:0}.ce-fila-actions{display:flex;gap:8px;margin-left:auto}.ce-btn-edit,.ce-btn-del,.ce-btn-cargar,.ce-btn-cambiar,.ce-btn-forzar,.ce-btn-omitir{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-xs);font-weight:600;cursor:pointer;border:1px solid transparent;transition:background .15s,transform .1s}.ce-btn-edit{background:var(--c-info-bg);color:var(--c-info-txt);border-color:var(--c-info-bdr)}.ce-btn-del{background:var(--c-error-bg);color:var(--c-error-txt);border-color:var(--c-error-bdr)}.ce-btn-cargar{background:var(--c-brand-600);color:#fff}.ce-btn-cambiar{background:var(--c-warn-bg);color:var(--c-warn-txt);border-color:var(--c-warn-bdr)}.ce-btn-forzar{background:#f5f3ff;color:#7c3aed;border-color:#ddd6fe}.ce-btn-omitir{background:var(--bg-muted);color:var(--text-secondary);border-color:var(--border-color)}.ce-btn-edit:hover,.ce-btn-del:hover,.ce-btn-cargar:hover,.ce-btn-cambiar:hover,.ce-btn-forzar:hover,.ce-btn-omitir:hover{transform:translateY(-1px);opacity:.9}.ce-enunciado{font-size:var(--text-sm);font-weight:500;color:var(--text-primary);line-height:1.6}.ce-input-enunciado{width:100%;padding:8px 12px;margin-bottom:10px;background:var(--bg-surface);border:1px solid var(--c-brand-400);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-primary);outline:none;resize:vertical}.ce-err-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;background:var(--c-error-bg);color:var(--c-error-txt);border:1px solid var(--c-error-bdr);font-size:11px;font-weight:700}.ce-tipo-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:20px;font-size:var(--text-xs);font-weight:700}.ce-tipo-MULTIPLE{background:var(--c-info-bg);color:var(--c-info-txt);border:1px solid var(--c-info-bdr)}.ce-tipo-VERDADERO{background:#f5f3ff;color:#7c3aed;border:1px solid #ddd6fe}.ce-tipo-COMPLETAR{background:var(--c-warn-bg);color:var(--c-warn-txt);border:1px solid var(--c-warn-bdr)}.ce-opciones-preview{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.ce-opcion-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;background:var(--bg-muted);color:var(--text-secondary);border:1px solid var(--border-color);font-size:var(--text-xs);font-weight:600}.ce-opcion-chip--ok{background:var(--c-success-bg);color:var(--c-success-txt);border-color:var(--c-success-bdr)}.ce-letra{font-weight:800;font-size:10px;width:16px;height:16px;border-radius:50%;background:currentColor;display:inline-flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.ce-opciones-edit{display:flex;flex-direction:column;gap:8px;margin-top:10px}.ce-opcion-edit-row{display:flex;align-items:center;gap:8px}.ce-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--border-color);background:var(--bg-surface);cursor:pointer;flex-shrink:0;transition:border-color .15s,background .15s}.ce-radio--active{border-color:var(--c-brand-600);background:var(--c-brand-600)}.ce-input-opcion{flex:1;padding:7px 10px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-primary);outline:none}.ce-input-opcion:focus{border-color:var(--c-brand-400)}.ce-vf-edit{display:flex;gap:10px;margin-top:8px}.ce-vf-opt{flex:1;padding:10px;border:2px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-surface);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);cursor:pointer;text-align:center;transition:border-color .15s,background .15s}.ce-vf-opt--active{border-color:var(--c-brand-600);background:var(--c-brand-50);color:var(--c-brand-700)}.ce-duplicados{background:var(--c-warn-bg);border:1px solid var(--c-warn-bdr);border-radius:var(--radius-lg);padding:16px;margin-bottom:16px}.ce-dup-list{display:flex;flex-direction:column;gap:8px;margin-top:10px}.ce-dup-item{background:var(--bg-surface);border:1px solid var(--c-warn-bdr);border-radius:var(--radius-md);padding:12px}.ce-dup-fila{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.ce-dup-icon{color:var(--c-warn-txt);flex-shrink:0;margin-top:2px}.ce-dup-texto{font-size:var(--text-sm);color:var(--text-primary);flex:1}.ce-dup-pregunta{font-size:var(--text-xs);color:var(--text-muted);margin-top:4px}.ce-dup-btns{display:flex;gap:6px;flex-shrink:0}.ce-resumen{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius-md);margin-bottom:16px;font-size:var(--text-sm);font-weight:600}.ce-resumen--ok{background:var(--c-success-bg);border:1px solid var(--c-success-bdr);color:var(--c-success-txt)}.ce-resumen--err{background:var(--c-error-bg);border:1px solid var(--c-error-bdr);color:var(--c-error-txt)}.ce-resumen--file{background:var(--c-info-bg);border:1px solid var(--c-info-bdr);color:var(--c-info-txt)}.ce-resumen-item{display:flex;align-items:center;gap:6px}.ce-resultado{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:32px;text-align:center;box-shadow:var(--shadow-md)}.ce-res-icon{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.ce-res-icon--ok{background:var(--c-success-bg);color:var(--c-success-txt)}.ce-res-icon--warn{background:var(--c-warn-bg);color:var(--c-warn-txt)}.ce-res-stats{display:flex;gap:24px;justify-content:center;margin:20px 0;flex-wrap:wrap}.ce-res-stat{display:flex;flex-direction:column;align-items:center;gap:4px}.ce-res-num{font-size:var(--text-2xl);font-weight:900;color:var(--text-primary);line-height:1}.ce-res-num--ok{color:var(--c-success-txt)}.ce-res-num--err{color:var(--c-error-txt)}.ce-res-btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:20px}.ce-res-errores{margin-top:20px;text-align:left}.ce-res-err-title{font-size:var(--text-sm);font-weight:700;color:var(--c-error-txt);margin-bottom:8px}.ce-res-err-row{font-size:var(--text-xs);color:var(--text-secondary);padding:4px 0;border-bottom:1px solid var(--border-color)}.ce-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 0;border-top:1px solid var(--border-color);flex-wrap:wrap}.ce-footer-info{font-size:var(--text-sm);color:var(--text-muted)}.ce-vacio{display:flex;flex-direction:column;align-items:center;gap:14px;padding:48px 20px;text-align:center;color:var(--text-muted)}.ce-spinner{width:24px;height:24px;border:2.5px solid var(--border-color);border-top-color:var(--c-brand-500);border-radius:50%;animation:ce-spin .7s linear infinite}@keyframes ce-spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;animation:mo-fade .15s ease}@keyframes mo-fade{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:480px;box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-height:90vh;overflow:hidden;animation:mo-up .2s var(--ease-out)}@keyframes mo-up{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color);flex-shrink:0}.modal-header h3{font-size:var(--text-lg);font-weight:800;color:var(--text-primary);margin:0}.modal-close{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;transition:color .15s,background .15s}.modal-close:hover{color:var(--text-primary);background:var(--bg-muted)}.modal-form{padding:20px 24px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px}.modal-field{display:flex;flex-direction:column;gap:6px}.modal-field label{font-size:var(--text-xs);font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.modal-field input,.modal-field select{padding:9px 12px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);outline:none;transition:border-color .15s,box-shadow .15s}.modal-field input:focus,.modal-field select:focus{border-color:var(--c-brand-500);box-shadow:0 0 0 3px #3b82f61f}.modal-field-error{font-size:var(--text-xs);color:var(--c-error-txt);margin-top:2px}.modal-error{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius-md);background:var(--c-error-bg);border:1px solid var(--c-error-bdr);color:var(--c-error-txt);font-size:var(--text-sm)}.modal-actions{display:flex;gap:10px;justify-content:flex-end;padding:16px 24px;border-top:1px solid var(--border-color);flex-shrink:0}.btn-cancel{padding:9px 18px;background:var(--bg-muted);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background .15s}.btn-cancel:hover{background:var(--bg-surface)}.btn-save{padding:9px 18px;background:var(--c-brand-600);color:#fff;border:none;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background .15s,transform .1s;display:inline-flex;align-items:center;gap:6px}.btn-save:hover{background:var(--c-brand-700);transform:translateY(-1px)}.btn-save:disabled{opacity:.6;cursor:not-allowed;transform:none}
