*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#2e2a50;background:#ddd9f0;font-family:system-ui,-apple-system,sans-serif;font-size:16px}.loading-screen{color:#6a659a;flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:100vh;display:flex}.loading-spinner{border:3px solid #ccc8e8;border-top-color:#6057c8;border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.status-text{color:#8880aa;text-align:center;padding:32px 0;font-size:15px}.login-screen{width:100%;min-height:100vh;display:flex}.login-left{background:#4a4480;flex-direction:column;flex:1;justify-content:space-between;padding:36px;display:flex;position:relative;overflow:hidden}.login-watermark{pointer-events:none;z-index:0;position:absolute;inset:0}.login-left-top{z-index:1;position:relative}.login-tag{letter-spacing:.12em;text-transform:uppercase;color:#b8b0e8;margin-bottom:14px;font-size:12px;font-weight:600}.login-title{color:#ede9ff;margin-bottom:10px;font-size:28px;font-weight:600;line-height:1.4}.login-subtitle{color:#c8c0f0;font-size:15px;line-height:1.6}.login-stats{z-index:1;position:relative}.login-stats-label{letter-spacing:.1em;text-transform:uppercase;color:#9990cc;text-align:center;margin-bottom:10px;font-size:12px;font-weight:600}.login-stats-grid{grid-template-columns:repeat(5,1fr);gap:6px;display:grid}.login-stat-card{text-align:center;background:#ffffff17;border:1px solid #ffffff21;border-radius:8px;padding:10px 4px}.login-stat-year{color:#b8b0e8;letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px;font-size:11px;font-weight:600}.login-stat-n{color:#ede9ff;font-size:26px;font-weight:600;line-height:1}.login-stat-tipo{color:#b8b0e8;text-transform:uppercase;letter-spacing:.03em;margin:2px 0;font-size:10px}.login-stat-plazas,.login-stat-de{color:#6dde9e;font-size:11px;font-weight:600}.login-author{z-index:1;align-items:center;gap:12px;display:flex;position:relative}.login-avatar{color:#ede9ff;background:#6b60d4;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;font-size:16px;font-weight:600;display:flex}.login-author-name{color:#ede9ff;font-size:18px;font-weight:600}.login-author-email{color:#9990cc;margin-top:2px;font-size:13px}.login-right{background:#f0eef8;flex:1;justify-content:center;align-items:center;padding:40px;display:flex}.login-form{width:100%;max-width:320px}.login-form-logo{align-items:center;gap:10px;margin-bottom:28px;display:flex}.login-form-name{color:#2e2a50;font-size:16px;font-weight:600;line-height:1.4}.login-form-sub{color:#8880aa;margin-top:2px;font-size:13px}.login-form-title{color:#2e2a50;margin-bottom:6px;font-size:24px;font-weight:600}.login-form-desc{color:#8880aa;margin-bottom:24px;font-size:14px}.login-form-footer{text-align:center;color:#8880aa;margin-top:18px;font-size:13px}.form-group{margin-bottom:14px}.form-group label{color:#6a659a;margin-bottom:4px;font-size:14px;display:block}.form-group input{color:#2e2a50;background:#f8f7fd;border:1px solid #ccc8e8;border-radius:7px;outline:none;width:100%;padding:10px 12px;font-size:15px}.form-group input:focus{border-color:#6057c8}.error-msg{color:#d95555;margin-bottom:12px;font-size:13px}.btn{color:#4a4480;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #ccc8e8;border-radius:7px;align-items:center;gap:6px;padding:7px 16px;font-size:13px;display:inline-flex}.btn:hover:not(:disabled){background:#f0eefa}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{color:#fff;background:#6057c8;border-color:#6057c8}.btn-primary:hover:not(:disabled){background:#4a4480}.btn-full{justify-content:center;width:100%;padding:12px;font-size:16px}.btn-sidebar{color:#ede9ff;background:#5c57a0;border-color:#6b60d4}.btn-sidebar:hover{background:#4a4480}.app{height:100vh;display:flex;overflow:hidden}.sidebar{background:#4a4480;flex-direction:column;width:226px;min-width:226px;display:flex;overflow-y:auto}.sidebar-header{cursor:pointer;border-bottom:1px solid #5c57a0;align-items:center;gap:10px;padding:16px;display:flex}.logo{color:#ede9ff;font-size:14px;font-weight:600;line-height:1.4}.logo span{color:#b8b0e8;margin-top:2px;font-size:12px;font-weight:400;display:block}.sidebar-nav{flex:1;padding-bottom:8px}.nav-group{padding:8px 0}.nav-label{letter-spacing:.06em;text-transform:uppercase;color:#9990cc;padding:6px 14px 4px;font-size:11px;font-weight:600}.nav-item{color:#ede9ff;cursor:pointer;text-align:left;opacity:.85;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:8px 14px;font-size:13px;display:flex}.nav-item:hover{opacity:1;color:#fff;background:#5c57a0}.nav-item.active{color:#fff;opacity:1;background:#6b60d4;font-weight:500}.nav-emoji{min-width:18px;font-size:15px}.user-footer{border-top:1px solid #5c57a0;flex-direction:column;gap:8px;padding:14px;display:flex}.user-info{color:#ede9ff;align-items:center;gap:6px;font-size:13px;display:flex}.group-badge{border-radius:10px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.group-badge.group-inicial{color:#90c4ef;background:#1c3d6e}.group-badge.group-avanzado{color:#9ecf62;background:#2d4a1a}.main{flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{background:#fff;border-bottom:1px solid #ccc8e8;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.topbar-title{color:#2e2a50;font-size:17px;font-weight:600}.topbar-right{align-items:center;gap:10px;display:flex}.role-badge{border-radius:20px;padding:3px 10px;font-size:12px;font-weight:500}.role-badge.role-profe{color:#4a4480;background:#e8e5fa}.role-badge.role-inicial{color:#1a4d80;background:#def}.role-badge.role-avanzado{color:#2d6a1f;background:#dff0d8}.content{flex:1;padding:20px;overflow-y:auto}.stats-bar{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px;display:grid}.stat{background:#fff;border:1px solid #ccc8e8;border-radius:8px;padding:10px 14px}.stat-n{font-size:24px;font-weight:600}.stat-l{color:#8880aa;margin-top:2px;font-size:12px}.resources-grid{grid-template-columns:repeat(auto-fill,minmax(195px,1fr));align-items:stretch;gap:12px;display:grid}.card{background:#fff;border:1px solid #ccc8e8;border-radius:10px;flex-direction:column;height:100%;padding:14px;display:flex}.card-top{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.type-badge{border-radius:6px;padding:2px 8px;font-size:11px;font-weight:500}.type-badge.type-pdf{color:#8b3a1e;background:#fde8df}.type-badge.type-video{color:#1a4d80;background:#def}.type-badge.type-pptx{color:#2d6a1f;background:#dff0d8}.status-label{color:#8880aa;align-items:center;gap:4px;font-size:11px;display:flex}.status-dot{border-radius:50%;width:7px;height:7px;display:inline-block}.card-title{color:#2e2a50;margin-bottom:4px;font-size:14px;font-weight:500;line-height:1.4}.card-desc,.card-date,.card-groups{color:#8880aa;margin-bottom:4px;font-size:12px}.expiry-bar{background:#e8e5f5;border-radius:2px;height:3px;margin:8px 0;overflow:hidden}.expiry-fill{border-radius:2px;height:100%;transition:width .3s}.card-actions{flex-wrap:wrap;gap:6px;margin-top:auto;padding-top:8px;display:flex}.view-btn{color:#5a558a;cursor:pointer;background:0 0;border:1px solid #ccc8e8;border-radius:6px;align-items:center;gap:4px;padding:5px 12px;font-size:12px;display:flex}.view-btn:hover:not(:disabled){background:#f0eefa}.edit-btn{cursor:pointer;color:#8880aa;background:0 0;border:1px solid #ccc8e8;border-radius:6px;padding:5px 9px;font-size:12px}.edit-btn:hover{background:#f0eefa}.modal-overlay{z-index:100;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.viewer-modal{background:#fff;border-radius:12px;flex-direction:column;width:90vw;max-width:900px;height:88vh;display:flex;overflow:hidden}.viewer-header{border-bottom:1px solid #ccc8e8;justify-content:space-between;align-items:center;padding:12px 18px;font-size:15px;font-weight:500;display:flex}.viewer-body{background:#f4f4f8;flex:1;overflow:auto}.close-btn{cursor:pointer;color:#8880aa;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:17px}.close-btn:hover{background:#f0eefa}.pdf-viewer{-webkit-user-select:none;user-select:none;padding:16px}.pdf-loading{text-align:center;color:#8880aa;padding:16px;font-size:14px}.pdf-nav{justify-content:center;align-items:center;gap:12px;padding:12px;display:flex}.pdf-nav button{cursor:pointer;background:#fff;border:1px solid #ccc8e8;border-radius:6px;padding:6px 14px;font-size:13px}.pdf-nav button:disabled{opacity:.4;cursor:not-allowed}.pdf-nav span{color:#6a659a;font-size:13px}.modal-box{background:#fff;border-radius:12px;width:400px;max-height:90vh;padding:22px;overflow-y:auto}.modal-header{color:#2e2a50;justify-content:space-between;align-items:center;margin-bottom:16px;font-size:16px;font-weight:600;display:flex}.modal-field{margin-bottom:12px}.modal-field label{color:#6a659a;margin-bottom:4px;font-size:13px;display:block}.modal-field input,.modal-field select{color:#2e2a50;background:#f8f7fd;border:1px solid #ccc8e8;border-radius:7px;outline:none;width:100%;padding:8px 10px;font-size:14px}.modal-field input:focus,.modal-field select:focus{border-color:#6057c8}.modal-field small{color:#8880aa;margin-top:3px;font-size:12px;display:block}.modal-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.group-toggles{gap:8px;display:flex}.group-toggle{color:#6a659a;cursor:pointer;background:#f8f7fd;border:1px solid #ccc8e8;border-radius:7px;padding:7px 16px;font-size:13px}.group-toggle.active{color:#4a4480;background:#e8e5fa;border-color:#6057c8;font-weight:500}.upload-progress{margin-bottom:12px}.upload-bar{background:#6057c8;border-radius:2px;height:4px}.upload-progress small{color:#8880aa;margin-top:4px;font-size:12px;display:block}.modal-actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}.enlaces-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;display:grid}.enlace-card{text-align:center;cursor:pointer;background:#fff;border:1px solid #ccc8e8;border-radius:10px;flex-direction:column;align-items:center;gap:8px;padding:18px 14px;transition:box-shadow .15s;display:flex;position:relative}.enlace-card:hover{box-shadow:0 2px 12px #6057c826}.enlace-favicon{border-radius:8px;width:36px;height:36px}.enlace-name{color:#2e2a50;font-size:13px;font-weight:500;line-height:1.4}.enlace-url{color:#8880aa;font-size:11px}.enlace-delete{cursor:pointer;opacity:0;background:0 0;border:none;font-size:14px;transition:opacity .15s;position:absolute;top:6px;right:6px}.enlace-card:hover .enlace-delete{opacity:1}.add-link-form{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.add-link-form input{color:#2e2a50;background:#fff;border:1px solid #ccc8e8;border-radius:7px;outline:none;flex:1;min-width:140px;padding:7px 10px;font-size:14px}.alumnos-list{flex-direction:column;gap:8px;display:flex}.alumno-row{background:#fff;border:1px solid #ccc8e8;border-radius:8px;align-items:center;gap:12px;padding:12px 16px;display:flex}.alumno-info{flex:1}.alumno-name{color:#2e2a50;font-size:14px;font-weight:500;display:block}.alumno-email{color:#8880aa;font-size:12px;display:block}.group-select{color:#2e2a50;cursor:pointer;background:#f8f7fd;border:1px solid #ccc8e8;border-radius:6px;padding:6px 8px;font-size:13px}.home-content{padding:20px}.home-welcome{background:#4a4480;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:20px;padding:22px 26px;display:flex}.home-welcome h1{color:#ede9ff;margin-bottom:4px;font-size:20px;font-weight:600}.home-welcome p{color:#b8b0e8;font-size:14px}.home-welcome-right{text-align:right;flex-direction:column;align-items:flex-end;gap:6px;display:flex}.home-date{color:#9990cc;font-size:13px}.home-section-title{color:#2e2a50;align-items:center;gap:8px;margin-bottom:12px;font-size:15px;font-weight:600;display:flex}.home-section-title span{color:#8880aa;font-size:13px;font-weight:400}.home-recursos{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:4px;display:grid}.home-rcard{background:#fff;border:1px solid #ccc8e8;border-radius:10px;padding:14px}.home-rcard-top{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.home-rcard-section{color:#8880aa;font-size:11px}.home-rcard-title{color:#2e2a50;margin-bottom:6px;font-size:14px;font-weight:500;line-height:1.4}.home-rcard-date{color:#8880aa;font-size:12px}.aviso-form{gap:8px;margin-bottom:12px;display:flex}.aviso-form input{color:#2e2a50;background:#fff;border:1px solid #ccc8e8;border-radius:8px;outline:none;flex:1;padding:9px 12px;font-size:14px}.aviso-form input:focus{border-color:#6057c8}.avisos-list{background:#fff;border:1px solid #ccc8e8;border-radius:10px;overflow:hidden}.aviso-row{border-bottom:1px solid #f0eef8;align-items:flex-start;gap:12px;padding:13px 16px;display:flex}.aviso-row:last-child{border-bottom:none}.aviso-dot{background:#6057c8;border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.aviso-text{color:#2e2a50;font-size:14px;line-height:1.5}.aviso-date{color:#8880aa;margin-top:3px;font-size:12px}.hamburger-btn,.sidebar-overlay,.login-mobile-btn,.login-mobile-back{display:none}@media (width<=768px){.app{flex-direction:column}.sidebar{z-index:200;width:280px;transition:transform .25s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.sidebar-open{transform:translate(0)}.sidebar-overlay{z-index:199;background:#00000073;display:block;position:fixed;inset:0}.main{width:100%;height:100vh}.topbar{gap:10px;padding:10px 14px}.hamburger-btn{cursor:pointer;background:0 0;border:none;flex-direction:column;flex-shrink:0;justify-content:center;gap:5px;width:36px;height:36px;padding:4px;display:flex}.hamburger-btn span{background:#4a4480;border-radius:2px;width:22px;height:2px;display:block}.topbar-title{font-size:15px}.resources-grid{grid-template-columns:1fr}.stats-bar{grid-template-columns:repeat(2,1fr)}.home-recursos{grid-template-columns:1fr}.btn{padding:10px 18px;font-size:14px}.view-btn{padding:8px 14px;font-size:13px}.edit-btn{padding:8px 12px;font-size:13px}.nav-item{padding:12px 14px;font-size:14px}.content,.home-content{padding:14px}.modal-box{width:95vw!important}.login-screen{height:100dvh;min-height:unset;position:relative;overflow:hidden}.login-left{-webkit-overflow-scrolling:touch;z-index:2;justify-content:flex-start;gap:24px;width:100%;height:100%;padding-bottom:24px;transition:transform .35s;position:absolute;top:0;left:0;overflow-y:auto}.login-left.login-left-shifted{transform:translate(-50%)}.login-right{-webkit-overflow-scrolling:touch;z-index:3;align-items:flex-start;width:50%;height:100%;padding:24px 16px;transition:transform .35s;position:absolute;top:0;right:0;overflow-y:auto;transform:translate(100%)}.login-right.login-right-visible{transform:translate(0)}.login-stats-grid{grid-template-columns:repeat(3,1fr)}.login-stat-n{font-size:20px}.login-stat-card{padding:8px 4px}.login-title{font-size:22px}.login-mobile-btn{color:#fff;cursor:pointer;z-index:1;background:#ffffff26;border:2px solid #fff6;border-radius:8px;margin:8px auto 0;padding:12px 32px;font-size:15px;font-weight:600;display:block;position:relative}.login-mobile-back{color:#8880aa;cursor:pointer;background:0 0;border:none;margin-bottom:16px;padding:0;font-size:13px;display:block}}
