*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--surface:#1a1d2e;--surface-2:#21253a;--border:#2a2e42;--text:#e2e4ea;--text-2:#8b8fa8;--text-3:#555978;--accent:#7c8aff;--accent-light:rgba(124,138,255,.12);--html-color:#7dd3fc;--pdf-color:#fca5a5;--danger:#f87171;--success:#4ade80;--font:system-ui,-apple-system,sans-serif}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh}header{background:#161822;border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;z-index:50}.nav-inner{max-width:1600px;margin:0 auto;padding:0 1.5rem;height:58px;gap:1rem}.brand,.nav-inner{display:flex;align-items:center}.brand{font-size:1rem;font-weight:700;color:var(--accent);text-decoration:none;gap:.5rem}.nav-sep{width:1px;height:22px;background:var(--border)}.nav-label{font-size:.8rem;color:var(--text-2)}.nav-right{margin-left:auto;display:flex;align-items:center;gap:.75rem}.lang-toggle{display:flex;border:1px solid var(--border);border-radius:7px;overflow:hidden}.btn-lang{padding:.3rem .65rem;font-size:.75rem;font-weight:600;background:transparent;color:var(--text-2);border:none;cursor:pointer;font-family:inherit;transition:all .14s;line-height:1}.btn-lang.active{background:var(--accent);color:#fff}.btn-lang:hover:not(.active){background:var(--surface-2);color:var(--text)}.btn{display:inline-flex;align-items:center;gap:.35rem;padding:.375rem .875rem;border-radius:7px;font-size:.8rem;font-weight:600;cursor:pointer;border:none;font-family:inherit;transition:all .14s;text-decoration:none;line-height:1}.btn-upload{background:var(--accent);color:#fff}.btn-upload:hover{background:#6879ee}.btn-success{background:var(--success);color:#0f1117}.btn-success:hover{background:#22c55e}.btn-success:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--text-2);border:1px solid var(--border)}.btn-ghost.active{background:var(--accent-light);color:var(--accent);border-color:rgba(124,138,255,.3)}.btn-ghost.active:hover,.btn-ghost:hover.active{background:rgba(124,138,255,.18)}.btn-danger{background:transparent;color:var(--danger);border:1px solid hsla(0,91%,71%,.3)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.role-badge{padding:.2rem .55rem;border-radius:5px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.role-admin{background:rgba(250,204,21,.15);color:#fbbf24;border:1px solid rgba(250,204,21,.25)}.role-teacher{background:rgba(74,222,128,.12);color:#4ade80;border:1px solid rgba(74,222,128,.2)}.role-student{background:rgba(125,211,252,.12);color:#7dd3fc;border:1px solid rgba(125,211,252,.2)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:var(--bg);background-image:radial-gradient(ellipse 80% 55% at 50% 45%,rgba(124,138,255,.08) 0,transparent 70%)}.login-box{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-top:2px solid var(--accent);border-radius:16px;padding:2.5rem 2rem 2rem;display:flex;flex-direction:column;gap:1.25rem;box-shadow:0 24px 64px rgba(0,0,0,.45)}.login-brand{font-size:1.5rem;font-weight:800;color:var(--accent);letter-spacing:-.03em;display:flex;align-items:center;gap:.5rem}.login-subtitle{font-size:.82rem;color:var(--text-3);margin-top:-.75rem;letter-spacing:.02em}.btn-google{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:.65rem 1rem;border-radius:9px;border:1px solid var(--border);background:var(--surface-2,#21253a);color:var(--text);font-size:.875rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .14s,border-color .14s}.btn-google:hover:not(:disabled){background:#2a2f46;border-color:#3a3f5c}.btn-google:disabled{opacity:.6;cursor:not-allowed}.login-divider{display:flex;align-items:center;gap:.75rem;color:var(--text-3);font-size:.75rem}.login-divider:after,.login-divider:before{content:"";flex:1 1;height:1px;background:var(--border)}.login-field{display:flex;flex-direction:column;gap:.35rem}.login-field label{font-size:.78rem;font-weight:600;color:var(--text-2)}.login-field input{padding:.55rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.9rem;font-family:inherit;outline:none;transition:border-color .14s}.login-field input:focus{border-color:var(--accent)}.login-error{color:#fca5a5;font-size:.8rem;background:hsla(0,94%,82%,.08);border:1px solid hsla(0,94%,82%,.2);border-radius:7px;padding:.5rem .75rem}.login-form{display:flex;flex-direction:column;gap:1rem}.btn-login{width:100%;padding:.7rem;background:var(--accent);color:#fff;border:none;border-radius:9px;font-size:.9rem;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .14s,background .14s;margin-top:.25rem}.btn-login:hover:not(:disabled){background:#8f9eff}.btn-login:disabled{opacity:.6;cursor:not-allowed}.login-hint{font-size:.72rem;color:var(--text-3);text-align:center}.page{max-width:1600px;margin:0 auto;padding:1.5rem}@media (min-width:1400px){.page{padding:2rem 2.5rem}.nav-inner{padding:0 2.5rem}}@media (min-width:1800px){.page{max-width:1900px;padding:2rem 4rem}.nav-inner{max-width:1900px;padding:0 4rem}}.upload-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.25rem;margin-bottom:1.5rem}.upload-panel-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);margin-bottom:1rem}.upload-grid{display:grid;grid-template-columns:2fr 1.5fr 1fr 1fr 1fr auto;grid-gap:.75rem;gap:.75rem;align-items:end}@media (max-width:900px){.upload-grid{grid-template-columns:1fr 1fr}.field-submit{grid-column:1/-1}}.field-desc{grid-column:1/-1}.desc-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.desc-label-row label{font-size:.75rem;color:var(--text-2)}.field textarea{background:var(--bg);border:1px solid var(--border);color:var(--text);font-size:.8125rem;padding:.45rem .65rem;border-radius:6px;outline:none;font-family:inherit;width:100%;resize:vertical;line-height:1.5}.field textarea:focus{border-color:var(--accent)}.btn-ai{background:rgba(167,139,250,.12);color:#a78bfa;border:1px solid rgba(167,139,250,.25)}.btn-ai:hover:not(:disabled){background:rgba(167,139,250,.22)}.btn-ai:disabled{opacity:.5;cursor:not-allowed}.field{display:flex;flex-direction:column;gap:4px}.field label{font-size:.75rem;color:var(--text-2)}.field input,.field select{background:var(--bg);border:1px solid var(--border);color:var(--text);font-size:.8125rem;padding:.4rem .65rem;border-radius:6px;outline:none;font-family:inherit;width:100%}.field input:focus,.field select:focus{border-color:var(--accent)}.field select option{background:var(--surface)}.field input[type=file]{font-size:.75rem;padding:.35rem .5rem}.upload-feedback{margin-top:.75rem;font-size:.8125rem}.feedback-success{color:var(--success)}.feedback-error{color:var(--danger)}.filters-row{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;padding:.75rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:1.75rem}.filter-label{font-size:.75rem;color:var(--text-3)}.filters-row select{background:var(--bg);border:1px solid var(--border);color:var(--text);font-size:.8125rem;padding:.35rem .65rem;border-radius:6px;outline:none;font-family:inherit;cursor:pointer}.filters-row select:focus{border-color:var(--accent)}.filters-row select option{background:var(--surface)}.filter-count{margin-left:auto;font-size:.75rem;color:var(--text-3)}.state-center{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 1rem;gap:1rem;color:var(--text-3)}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.empty-state .empty-icon{font-size:2.5rem;opacity:.2}.empty-state p{font-size:.9rem}.resource-group{margin-bottom:2.5rem}.group-heading{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.625rem;border-bottom:1px solid var(--border)}.group-heading h2{font-size:1rem;font-weight:700;color:var(--text)}.form-badge{font-size:.7rem;font-weight:700;background:var(--accent-light);color:var(--accent);padding:.15rem .55rem;border-radius:999px}.group-count{font-size:.75rem;color:var(--text-3);margin-left:auto}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:1rem;gap:1rem}@media (min-width:1400px){.card-grid{gap:1.25rem}}@media (max-width:480px){.card-grid{grid-template-columns:1fr}}.res-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;overflow:hidden;transition:border-color .15s,box-shadow .15s,transform .15s}.res-card:hover{border-color:rgba(124,138,255,.35);box-shadow:0 6px 24px rgba(0,0,0,.3);transform:translateY(-2px)}.card-stripe{height:4px;width:100%;flex-shrink:0}.stripe-html{background:linear-gradient(90deg,#7dd3fc,#38bdf8)}.stripe-pdf{background:linear-gradient(90deg,#fca5a5,#f87171)}.stripe-both{background:linear-gradient(90deg,#7c8aff,#a78bfa)}.card-header-row{padding:1rem 1rem .5rem;display:flex;align-items:flex-start;gap:.75rem}.card-icon{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:.58rem;font-weight:800;flex-shrink:0}.icon-html{background:rgba(125,211,252,.12);color:var(--html-color);border:1px solid rgba(125,211,252,.2)}.icon-pdf{background:hsla(0,94%,82%,.12);color:var(--pdf-color);border:1px solid hsla(0,94%,82%,.2)}.icon-both{background:rgba(124,138,255,.12);color:var(--accent);border:1px solid rgba(124,138,255,.2)}.card-title-block{flex:1 1;min-width:0}.card-title{font-size:.9rem;font-weight:700;color:var(--text);line-height:1.3;word-break:break-word}.card-body-row{padding:.25rem 1rem .5rem;flex:1 1}.card-desc{font-size:.78rem;color:var(--text-2);line-height:1.5;margin-bottom:.5rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.card-badges{display:flex;gap:.4rem;flex-wrap:wrap}.badge{font-size:.68rem;font-weight:600;padding:.15rem .55rem;border-radius:6px}.badge-subject{background:hsla(0,0%,100%,.06);color:var(--text-2)}.badge-form{background:var(--accent-light);color:var(--accent)}.card-preview-panel{background:var(--bg);border-top:1px solid var(--border)}.card-preview-panel iframe{width:100%;height:640px;border:none;display:block}.card-expanded{grid-column:1/-1}.card-expanded .card-preview-panel iframe{height:75vh;min-height:500px}.card-footer-row{padding:.75rem 1rem;border-top:1px solid var(--border);display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.btn-card{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .8rem;border-radius:7px;font-size:.775rem;font-weight:600;cursor:pointer;border:none;font-family:inherit;transition:background .14s;text-decoration:none;line-height:1}.btn-card-html{background:rgba(125,211,252,.1);color:var(--html-color);border:1px solid rgba(125,211,252,.2)}.btn-card-html:hover{background:rgba(125,211,252,.18)}.btn-card-pdf{background:hsla(0,91%,71%,.18);color:#fca5a5;border:1px solid hsla(0,91%,71%,.45);font-weight:700}.btn-card-pdf:hover{background:hsla(0,91%,71%,.28);border-color:#f87171}.btn-card-pdf.active{background:#f87171;color:#fff;border-color:#f87171}.btn-card-pdf-ext{background:hsla(0,94%,82%,.07);color:var(--pdf-color);border:1px solid hsla(0,94%,82%,.15)}.btn-card-pdf-ext:hover{background:hsla(0,94%,82%,.14)}.btn-card-edit{background:rgba(124,138,255,.1);color:var(--accent);border:1px solid rgba(124,138,255,.25)}.btn-card-edit:hover{background:rgba(124,138,255,.2)}.btn-card-del{margin-left:auto;padding:.35rem .55rem;background:transparent;color:var(--text-3);border:1px solid transparent;border-radius:7px;cursor:pointer;font-family:inherit;font-size:.9rem;transition:all .14s;opacity:0}.res-card:hover .btn-card-del{opacity:1}.btn-card-del:hover{color:var(--danger);border-color:hsla(0,91%,71%,.25);background:hsla(0,91%,71%,.08)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:100}.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.5rem;width:90%;max-width:360px;box-shadow:0 20px 60px rgba(0,0,0,.4)}.modal-title{font-size:.95rem;font-weight:700;margin-bottom:.5rem}.modal-body{font-size:.8375rem;color:var(--text-2);margin-bottom:1.25rem;line-height:1.6}.modal-body strong{color:var(--text)}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.modal-edit-box{max-width:520px}.edit-modal-form{display:flex;flex-direction:column;gap:.875rem;margin:1rem 0}.edit-modal-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:.75rem;gap:.75rem}@keyframes cardIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.res-card{animation:cardIn .25s ease forwards}