*{box-sizing:border-box}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,sans-serif;background:#121521;color:#e5e7ef}a{color:inherit;text-decoration:none}:root{--primary:#6a3de8;--primary-accent:#4c2ab1;--primary-grad-end:#2f2f81;--bg:#121521;--bg-alt:#1d2330;--bg-alt2:#232b3a;--border:#2e3747;--border-strong:#3b4659;--text:#e5e7ef;--text-dim:#9aa3b5;--danger:#dc3545;--success:#16a34a;--warning:#f59e0b;--radius:10px;--focus-ring:0 0 0 2px #ffffff15,0 0 0 4px var(--primary);--shadow:0 4px 14px -4px #00000080,0 2px 4px -2px #00000066}.page-container{max-width:1400px;margin:0 auto;padding:1.25rem 1.75rem 3rem}.card{background:linear-gradient(145deg,#1d2330,#18202c);border:1px solid var(--border);border-radius:var(--radius);padding:1.4rem 1.6rem 2rem;box-shadow:var(--shadow)}.card+.card{margin-top:1.25rem}.section-title{font-size:1.3rem;font-weight:650;margin:0 0 1.1rem;background:linear-gradient(90deg,var(--primary),#4a53ff)}label{display:block;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-dim);margin:0 0 .4rem .1rem}.text-input,input:not([type]),input[type=text],select{width:100%;background:var(--bg-alt2);border:1px solid var(--border);color:var(--text);font-size:.85rem;padding:.65rem .75rem;border-radius:8px;outline:none;transition:border .18s,background .18s,box-shadow .2s}input:focus,select:focus{border-color:var(--primary);box-shadow:var(--focus-ring)}input::placeholder{color:#5a6477}select[disabled]{opacity:.6;cursor:not-allowed}button{font-family:inherit;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.65rem 1rem;border-radius:8px;border:1px solid var(--primary-accent);background:linear-gradient(135deg,var(--primary) 0,var(--primary-accent) 100%);color:#fff;cursor:pointer;display:inline-flex;align-items:center;gap:.45rem;box-shadow:0 2px 4px -1px #0009;position:relative;overflow:hidden}button:hover:not(:disabled){filter:brightness(1.06)}button:active:not(:disabled){transform:translateY(1px)}button:disabled{opacity:.45;cursor:not-allowed}button.secondary{background:var(--bg-alt2);border-color:var(--border-strong);color:var(--text-dim)}button.secondary:hover:not(:disabled){background:var(--bg-alt);color:var(--text)}button.danger{background:linear-gradient(135deg,#dc3545,#9f1d29);border-color:#b52735}button.danger:hover{filter:brightness(1.07)}button.outline{background:transparent;border:1px solid var(--border-strong);color:var(--text)}button.outline:hover{border-color:var(--primary);color:#fff}.pill-container{display:flex;flex-wrap:wrap;gap:.55rem;padding:.75rem .8rem;background:var(--bg-alt2);border:1px solid var(--border);border-radius:10px;max-height:180px;overflow-y:auto;scrollbar-width:thin}.pill{--accent:var(--primary);display:inline-flex;align-items:center;gap:.55rem;font-size:.65rem;font-weight:600;padding:.45rem .65rem;border-radius:100px;background:linear-gradient(135deg,var(--accent) 0,color-mix(in srgb,var(--accent) 80%,#000) 100%);color:#fff;box-shadow:0 2px 4px -2px #0008;position:relative;letter-spacing:.4px}.pill.reprobada{--accent:#dc3545}.pill small{font-family:monospace;font-size:.65rem;font-weight:500;opacity:.85}.pill button.remove{border:none;background:#ffffff15;color:#fff;width:18px;height:18px;border-radius:50%;cursor:pointer;font-size:.7rem;display:grid;place-items:center;padding:0}.pill button.remove:hover{background:#ffffff25}.results-wrapper{margin-top:.55rem;border:1px solid var(--border);border-radius:10px;background:var(--bg-alt2);max-height:230px;overflow-y:auto;scrollbar-width:thin}.result-item{width:100%;text-align:left;padding:.5rem .75rem;display:grid;grid-template-columns:70px 1fr 40px;grid-gap:.75rem;gap:.75rem;background:transparent;border:none;border-bottom:1px solid var(--border);font-size:.7rem;color:var(--text);cursor:pointer;position:relative}.result-item:last-child{border-bottom:none}.result-item:hover{background:var(--bg-alt)}.result-item span.codigo{font-family:monospace;font-size:.7rem;opacity:.9}.result-item span.creditos{justify-self:end;font-weight:600;color:var(--primary)}.badge{font-size:.55rem;font-weight:700;display:inline-block;padding:2px 6px;background:linear-gradient(135deg,var(--primary),var(--primary-accent));border-radius:6px;letter-spacing:.5px;color:#fff}.badge.reprobada{background:linear-gradient(135deg,#dc3545,#9f1d29)}.badge.nueva{background:linear-gradient(135deg,#2563eb,#1e40af)}.meta-bar{font-size:.7rem;font-weight:600;color:var(--text-dim);background:var(--bg-alt2);padding:.6rem .9rem;border:1px solid var(--border);border-radius:8px;display:flex;flex-wrap:wrap;gap:.9rem}.resultados-table{width:100%;border-collapse:collapse;margin-top:.9rem;font-size:.72rem;background:var(--bg-alt2);border:1px solid var(--border);border-radius:10px;overflow:hidden}.resultados-table thead th{text-align:left;font-size:.65rem;font-weight:600;padding:.6rem .75rem;background:linear-gradient(90deg,var(--primary),var(--primary-accent));letter-spacing:.6px;color:#fff}.resultados-table tbody td{padding:.55rem .75rem;border-top:1px solid var(--border)}.resultados-table tbody tr:hover td{background:var(--bg-alt)}.resultados-table tbody td.valor{font-weight:600;color:#fff;text-align:right}.resultados-table tbody tr.gratuito td.valor{color:var(--success)}.alert{font-size:.65rem;line-height:1.35;padding:.65rem .75rem;background:linear-gradient(135deg,#1e293b,#162132);border:1px solid var(--border);border-radius:8px;color:var(--text-dim)}@media (max-width:900px){.card{padding:1.1rem 1rem 1.4rem}.section-title{font-size:1.15rem}button{font-size:.72rem;padding:.55rem .85rem}.pill-container{max-height:220px}}.mt{margin-top:1.15rem}.gap-s{gap:.65rem}.wrap{flex-wrap:wrap}:root{--font-sans:"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;--transition:.18s cubic-bezier(.4,0,.2,1);--radius-sm:4px;--radius-md:8px;--radius-lg:14px;--shadow-sm:0 1px 2px rgba(0,0,0,.08);--shadow-md:0 4px 12px rgba(0,0,0,.12)}body:not([data-theme]),body[data-theme=light]{--color-bg:#f4f6fa;--color-gradient-start:#6d28d9;--color-gradient-end:#3b82f6;--color-surface:#fff;--color-surface-alt:#f0f3f8;--color-border:#d2dae4;--color-text:#1e293b;--color-text-secondary:#5b6675;--color-primary:#6d28d9;--color-primary-accent:#7e3af2;--color-warning:#fbbf24;--color-danger:#dc2626}body[data-theme=dark]{--color-bg:#0d1117;--color-gradient-start:#6d28d9;--color-gradient-end:#1d4ed8;--color-surface:#1b2431;--color-surface-alt:#222e3d;--color-border:#2f3c4d;--color-text:#f1f5f9;--color-text-secondary:#93a2b5;--color-primary:#7e3af2;--color-primary-accent:#9d5bff;--color-warning:#fbbf24;--color-danger:#f87171}body{background:var(--color-bg);color:var(--color-text);font-family:var(--font-sans);margin:0;padding:0;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;inset:0;background:radial-gradient(at 15% 15%,rgba(125,73,255,.18),transparent 60%),radial-gradient(at 85% 35%,rgba(0,122,255,.12),transparent 65%);pointer-events:none;z-index:-1}.container{max-width:1180px;margin:0 auto;padding:1.25rem 1.5rem}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem 1.75rem;box-shadow:var(--shadow-sm);transition:var(--transition);position:relative;overflow:hidden}.card:hover{box-shadow:var(--shadow-md)}.card:after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(135deg,hsla(0,0%,100%,.04),transparent 60%);opacity:.4;mix-blend-mode:overlay}.grid{display:grid;grid-gap:1.25rem;gap:1.25rem}.btn{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;border:1px solid transparent;font-weight:600;font-size:.9rem;background:linear-gradient(90deg,var(--color-gradient-start),var(--color-gradient-end));color:#fff;padding:.6rem 1rem;border-radius:999px;transition:var(--transition);letter-spacing:.3px}.btn:hover{background:var(--color-primary-accent)}.btn.outline{background:transparent;color:var(--color-primary);border-color:var(--color-primary)}.btn.outline:hover{background:var(--color-primary);color:#fff}button.theme-toggle{background:var(--color-surface-alt);border:1px solid var(--color-border);color:var(--color-text);padding:.55rem .9rem;border-radius:999px;cursor:pointer;font-size:.75rem;font-weight:600;display:inline-flex;align-items:center;gap:.4rem}button.theme-toggle:hover{background:var(--color-primary);color:#fff}button.theme-toggle .icon{font-size:1rem;line-height:1}button.theme-toggle .toggle-text{display:inline}table{width:100%;border-collapse:collapse;font-size:.9rem}td,th{padding:.55rem .75rem;text-align:left}th{font-weight:600}tbody tr:nth-child(2n),th{background:var(--color-surface-alt)}tbody tr:hover{background:var(--color-primary-accent);color:#fff}input,select{width:100%;padding:.75rem 1rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:.95rem;font-family:inherit;transition:var(--transition)}input:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(37,99,235,.25)}.input-lg{padding:.75rem 1rem!important;font-size:.95rem!important;border-radius:14px!important;border-width:2px!important}input.search-input{width:100%;padding:.75rem 1rem;font-size:.95rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);box-sizing:border-box;transition:var(--transition)}input.search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(37,99,235,.25)}input.search-input::placeholder{color:var(--color-text);opacity:1}label{color:var(--color-text)}.results-container{background:var(--color-surface);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--color-border);border-radius:16px;box-shadow:0 4px 14px -4px rgba(0,0,0,.25);overflow:hidden}.results-container table{font-size:.9rem}.results-container th{background:linear-gradient(90deg,var(--color-surface-alt),var(--color-surface));font-size:.75rem;letter-spacing:.6px}.results-container tbody tr{transition:var(--transition)}.results-container tbody tr:hover{background:linear-gradient(90deg,var(--color-primary-accent),var(--color-primary));color:#fff}.results-container tbody tr:hover .btn.outline{background:hsla(0,0%,100%,.18);color:#fff;border-color:#fff}.results-container tbody tr:hover .btn.outline:hover{background:#fff;color:var(--color-primary)}.btn-pill-sm{font-size:.7rem;border-radius:999px;padding:.4rem .8rem;display:inline-flex;align-items:center;font-weight:600}.subject-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:18px;padding:.85rem 1rem .9rem;box-shadow:0 2px 6px -2px rgba(0,0,0,.25);transition:var(--transition)}.subject-card:hover{box-shadow:0 6px 18px -6px rgba(0,0,0,.4);transform:translateY(-2px)}.subject-card h4{margin:0 0 .35rem;font-size:.9rem;font-weight:600;letter-spacing:.3px}.subject-meta{font-size:.65rem;opacity:.7;display:flex;gap:1.25rem;font-weight:500}.subject-selected{padding:1rem 1.15rem 1.1rem}.subject-header{display:flex;align-items:center;gap:.6rem;margin-bottom:.4rem;flex-wrap:wrap}.subject-name{font-size:1.05rem;font-weight:600;letter-spacing:.4px;line-height:1.2}.badge-reprobada{background:rgba(251,191,36,.15);color:var(--color-warning);font-size:.62rem;font-weight:700;padding:.25rem .45rem;border-radius:6px;letter-spacing:.5px;text-transform:uppercase}.subject-info-row{display:flex;align-items:center;gap:1.4rem;flex-wrap:nowrap;font-size:.85rem;font-weight:500;opacity:.95}.subject-info-row .meta-item{white-space:nowrap}.subject-info-row .meta-item strong{font-weight:600;letter-spacing:.3px}.subject-info-row .delete-subject{margin-left:auto;background:rgba(220,38,38,.15);border-color:var(--color-danger);color:var(--color-danger);width:34px;height:34px}.subject-info-row .delete-subject:hover{background:var(--color-danger);color:#fff}.btn-icon{display:inline-flex;align-items:center;justify-content:center;background:var(--color-surface-alt);border:1px solid var(--color-border);color:var(--color-text);width:30px;height:30px;border-radius:10px;font-size:.85rem;font-weight:600;cursor:pointer;transition:var(--transition)}.btn-icon:hover{background:var(--color-danger);border-color:var(--color-danger);color:#fff}.delete-subject{margin-left:auto}@media (max-width:880px){.subject-info-row{flex-wrap:wrap;gap:.9rem 1.25rem;font-size:.8rem}.subject-info-row .delete-subject{order:10;margin-left:auto}}@media (max-width:680px){.subject-name{font-size:.95rem}}.muted{color:var(--color-text-secondary);font-size:.8rem}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.gap-xs{gap:.35rem}.justify-between{justify-content:space-between}.items-center{align-items:center}.mt{margin-top:1rem}.section-title{font-size:1.05rem;font-weight:600;margin:0 0 .65rem;letter-spacing:.5px;background:linear-gradient(90deg,var(--color-gradient-start),var(--color-gradient-end));-webkit-background-clip:text;background-clip:text;color:transparent}.app-bar{justify-content:space-between;gap:1rem;padding:.85rem 1.2rem;border-radius:var(--radius-lg);background:linear-gradient(90deg,var(--color-gradient-start),var(--color-gradient-end));color:#fff;box-shadow:0 4px 18px -4px rgba(0,0,0,.35);position:-webkit-sticky;position:sticky;top:.75rem;z-index:50;flex-wrap:wrap}.app-bar,.app-brand{display:flex;align-items:center}.app-brand{gap:.65rem;font-weight:700;font-size:1.05rem;letter-spacing:.5px}.app-brand img{height:34px;width:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.35))}.logo-wrap{position:relative;width:150px;height:48px}.app-title{font-size:1.45rem;margin:0;font-weight:800;letter-spacing:.6px;text-shadow:0 1px 2px rgba(0,0,0,.18)}.spacer{flex:1 1}.nav-links{display:flex;gap:1rem;font-size:.75rem;letter-spacing:.5px}.nav-links a{color:hsla(0,0%,100%,.85);text-decoration:none;font-weight:500}.nav-links a:hover{color:#fff}.fade-border{border-top:1px solid var(--color-border);margin:1rem 0}@media (max-width:768px){.grid-cols-2,.grid-cols-3{grid-template-columns:1fr!important}}@media (max-width:600px){.app-bar{gap:.65rem}.spacer{display:none}.theme-toggle{order:1;margin-left:auto;padding:.45rem .55rem}.theme-toggle .toggle-text{display:none}.app-title{font-size:1.05rem;order:3;width:100%;text-align:center;margin-top:.15rem}.logo-wrap{width:120px;height:40px}}dialog.modal{width:min(92vw,520px);border:1px solid var(--color-border);border-radius:16px;padding:1rem 1.1rem;background:var(--color-surface);color:var(--color-text);box-shadow:0 12px 28px rgba(0,0,0,.35)}dialog.modal::-webkit-backdrop{background:rgba(0,0,0,.5)}dialog.modal::backdrop{background:rgba(0,0,0,.5)}.details-box{position:relative;border-radius:16px;padding:1rem;background:linear-gradient(180deg,var(--color-surface-alt),var(--color-surface));border:1px solid var(--color-border);box-shadow:inset 0 0 0 1px hsla(0,0%,100%,.02),0 6px 18px -6px rgba(0,0,0,.3)}.details-box:before{content:"";position:absolute;inset:-1px;border-radius:17px;padding:1px;background:linear-gradient(120deg,rgba(125,73,255,.35),rgba(37,99,235,.25));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.details-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.75rem .9rem;gap:.75rem .9rem}@media (max-width:700px){.details-grid{grid-template-columns:1fr}}.detail-item{display:flex;align-items:center;gap:.75rem;padding:.7rem .8rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;transition:transform .15s ease,box-shadow .2s ease}.detail-item:hover{transform:translateY(-1px);box-shadow:0 8px 20px -10px rgba(0,0,0,.35)}.detail-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:10px;color:var(--color-primary);background:rgba(126,58,242,.14);box-shadow:inset 0 0 0 1px rgba(126,58,242,.25)}.detail-text{line-height:1.25;font-size:.95rem}.detail-label{font-weight:700;letter-spacing:.3px}.detail-value{font-weight:500;opacity:.95}@media (max-width:480px){.container{padding:.9rem}table{font-size:.85rem}td,th{padding:.5rem .6rem}.results-container{border-radius:12px;position:relative;z-index:10}.results-container>table{min-width:520px}input.search-input{font-size:.95rem;padding:.7rem .9rem}}