:root{--primary-blue:#234e8a;--secondary-blue:#1a3b69;--accent-blue:#2b65bd;--white:#fff;--bg-main:#f4f6f9;--bg-surface:#fff;--bg-surface-alt:#f8faf8;--text-main:#333;--text-muted:#666;--text-inverse:#fff;--border-light:#00000014;--shadow-sm:0 2px 8px #0000000f;--shadow-md:0 4px 15px #0000001a;--glass-bg:#fffc;--glass-border:#fff6;--font-heading:"Montserrat", system-ui, -apple-system, sans-serif;--font-body:"Open Sans", system-ui, -apple-system, sans-serif}[data-theme=dark]{--bg-main:#0f172a;--bg-surface:#1e293b;--bg-surface-alt:#334155;--text-main:#f8fafc;--text-muted:#94a3b8;--text-inverse:#0f172a;--border-light:#ffffff1a;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 15px #00000080;--glass-bg:#0f172acc;--glass-border:#ffffff1a;--primary-blue:#3b82f6;--accent-blue:#60a5fa}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);color:var(--text-main);background-color:var(--bg-main);line-height:1.6;transition:background-color .3s,color .3s}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--primary-blue);font-weight:700}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:var(--font-body)}.course-detail-page{max-width:1200px;min-height:100vh;margin:0 auto;padding:40px 20px}.course-detail-container{flex-direction:column;gap:60px;display:flex}.course-hero-section{grid-template-columns:350px 1fr;align-items:flex-start;gap:50px;display:grid}.carousel-container{background-color:#000;border:1px solid #ffffff1a;border-radius:20px;position:relative;overflow:hidden;box-shadow:0 10px 30px #0000004d}.carousel-main{aspect-ratio:9/16;justify-content:center;align-items:center;display:flex;position:relative}.carousel-image{object-fit:contain;width:100%;height:100%}.carousel-control{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;z-index:10;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.carousel-control:hover{background:#fff3}.carousel-control.prev{left:10px}.carousel-control.next{right:10px}.carousel-indicators{z-index:10;gap:6px;display:flex;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.indicator{cursor:pointer;background:#ffffff4d;border-radius:50%;width:5px;height:5px}.indicator.active{background:#fff;border-radius:3px;width:15px}.course-hero-info{flex-direction:column;gap:20px;display:flex}.breadcrumb{color:var(--text-muted);align-items:center;gap:8px;font-size:.85rem;display:flex}.course-title-main{color:var(--primary-blue);margin:0 0 15px;font-size:2.6rem;font-weight:800;line-height:1.1;display:inline-block;position:relative}.course-title-main:after{content:"";background:var(--accent-blue);border-radius:3px;width:120px;height:5px;position:absolute;bottom:-10px;left:0}.course-short-desc{color:var(--text-main);opacity:.9;font-size:1.1rem;line-height:1.6}.course-quick-stats{grid-template-columns:repeat(2,1fr);gap:15px;margin-top:10px;display:grid}.stat-item{background:var(--bg-surface-alt);color:var(--text-main);border:1px solid var(--border-light);border-radius:12px;align-items:center;gap:12px;padding:16px 20px;font-size:.95rem;transition:all .3s;display:flex}.stat-item:hover{border-color:var(--accent-blue);transform:translateY(-2px)}.stat-item svg{color:var(--accent-blue);flex-shrink:0;width:20px!important;height:20px!important}.stat-icon{color:var(--accent-blue)}.course-price-box{background:var(--bg-surface-alt);border:1px solid var(--border-light);border-radius:12px;flex-direction:column;gap:4px;width:fit-content;padding:16px 24px;display:flex}.price-label{text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;font-size:.85rem;font-weight:700}.price-value{color:var(--primary-blue);font-size:2rem;font-weight:800}.course-actions-hero{gap:15px;margin-top:15px;display:flex}.btn-large{border-radius:10px;padding:12px 24px;font-size:1rem;font-weight:700}.btn-whatsapp{color:#fff;background-color:#25d366}.course-content-grid{grid-template-columns:1fr 320px;gap:40px;display:grid}.course-main-content{flex-direction:column;gap:50px;display:flex}.info-card{background:var(--bg-surface);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);border-radius:24px;padding:30px}.section-title{color:var(--primary-blue);margin-bottom:25px;font-size:1.6rem;font-weight:700;display:inline-block;position:relative}.section-title:after{content:"";background:var(--accent-blue);border-radius:2px;width:100%;max-width:80px;height:4px;position:absolute;bottom:-10px;left:0}.learnings-list{grid-template-columns:1fr 1fr;gap:20px;display:grid}.learning-item{color:var(--text-main);align-items:flex-start;gap:12px;font-size:1.05rem;display:flex}.check-icon{color:#25d366;flex-shrink:0;margin-top:4px}.full-description{color:var(--text-main);opacity:.9;font-size:1.1rem;line-height:1.7}.buy-card{background:var(--primary-blue);color:#fff;border-radius:20px;flex-direction:column;gap:20px;padding:30px;display:flex;position:sticky;top:30px;box-shadow:0 15px 35px #234e8a40}.buy-card h3{color:#fff;margin:0;font-size:1.5rem;line-height:1.2}.buy-card p{opacity:.9;font-size:1rem;line-height:1.5}.sidebar-price{margin:10px 0;font-size:2.2rem;font-weight:800}@media (width<=900px){.course-hero-section{grid-template-columns:1fr;justify-items:center}.course-hero-info{text-align:center;align-items:center;width:100%}.course-content-grid{grid-template-columns:1fr}.carousel-container{max-width:320px}.course-quick-stats,.course-actions-hero{justify-content:center}}@media (width<=600px){.course-quick-stats,.learnings-list{grid-template-columns:1fr}}.course-detail-loading{flex-direction:column;justify-content:center;align-items:center;gap:20px;min-height:60vh;display:flex}.loader{border:4px solid var(--border-light);border-bottom-color:var(--primary-blue);border-radius:50%;width:40px;height:40px;animation:1s linear infinite rotation}@keyframes rotation{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--auth-bg-dark:#0f172a;--auth-sidebar-bg:#1e293b;--auth-accent-blue:#3b82f6;--auth-input-bg:#ebf2ff;--auth-text-gray:#94a3b8}.auth-page{color:#fff;background-color:#0f172a;width:100%;min-height:100vh;font-family:Inter,system-ui,-apple-system,sans-serif;display:flex;overflow:hidden}.auth-main-side{z-index:10;background-color:#1e293b;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:40px;display:flex}.auth-form-container{flex-direction:column;align-items:flex-start;width:100%;max-width:400px;display:flex}.back-to-home{color:#94a3b8;align-items:center;gap:8px;margin-bottom:25px;font-size:.8rem;text-decoration:none;transition:color .2s;display:flex}.back-to-home:hover{color:#fff}.auth-logo-img{object-fit:contain;width:180px;height:auto;margin-bottom:35px;display:block}.auth-welcome-text{width:100%}.auth-welcome-text h1{color:#fff;margin-bottom:8px;font-size:2rem;font-weight:700}.auth-welcome-text p{color:#94a3b8;margin-bottom:35px;font-size:.9rem}.auth-nav-tabs{background:#ffffff0d;border-radius:12px;width:100%;margin-bottom:30px;padding:5px;display:flex}.auth-nav-tab{text-align:center;color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:10px;flex:1;justify-content:center;align-items:center;padding:12px;font-size:.85rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.auth-nav-tab.active{color:#fff;background:#ffffff1a;box-shadow:0 4px 12px #0000001a}.auth-form-body{width:100%}.auth-form-group{width:100%;margin-bottom:20px}.auth-input-container{align-items:center;width:100%;display:flex;position:relative}.auth-input-icon{color:#64748b;position:absolute;left:16px}.auth-input-field{color:#1e293b;background:#ebf2ff;border:1px solid #e2e8f0;border-radius:10px;outline:none;width:100%;padding:14px 16px 14px 48px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.auth-input-field:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.auth-forgot-link{color:#fff;margin-top:5px;font-size:.85rem;font-weight:600;text-decoration:none;display:inline-block}.auth-forgot-link:hover{text-decoration:underline}.auth-btn-continue{color:#fff;cursor:pointer;background-color:#3b82f6;border:none;border-radius:10px;width:100%;margin-top:30px;padding:14px;font-size:1rem;font-weight:600;transition:all .2s}.auth-btn-continue:hover{background-color:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.auth-btn-continue:active{transform:translateY(0)}.auth-divider{color:#64748b;letter-spacing:1px;text-transform:uppercase;align-items:center;width:100%;margin:35px 0;font-size:.75rem;font-weight:700;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:#ffffff1a;flex:1;height:1px}.auth-divider:before{margin-right:15px}.auth-divider:after{margin-left:15px}.auth-social-row{justify-content:center;width:100%;display:flex}.auth-google-btn{cursor:pointer;background:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:all .2s;display:flex;box-shadow:0 2px 8px #0003}.auth-google-btn:hover{transform:scale(1.1);box-shadow:0 4px 12px #0000004d}.auth-google-btn img{width:24px;height:24px}.auth-illustration-side{background-color:#0f172a;flex:1.2;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.auth-hero-img{z-index:5;filter:drop-shadow(0 20px 50px #00000080);max-width:80%;height:auto}@media (width<=1024px){.auth-illustration-side{display:none}.auth-main-side{max-width:100%;padding:40px 20px}}.dashboard-layout{background-color:var(--bg-main);min-height:100vh;font-family:var(--font-body);display:flex}.dashboard-sidebar{background:var(--bg-surface);border-right:1px solid var(--border-light);z-index:100;flex-direction:column;width:260px;transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden auto}.sidebar-header{border-bottom:1px solid var(--border-light);flex-shrink:0;align-items:center;gap:12px;padding:24px 20px;display:flex}.sidebar-header img{width:auto;height:38px}.sidebar-brand{font-family:var(--font-heading);color:var(--primary-blue);white-space:nowrap;font-size:1rem;font-weight:700}.sidebar-menu-label{letter-spacing:1.5px;text-transform:uppercase;color:var(--text-muted);opacity:.6;padding:20px 20px 8px;font-size:.7rem;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:8px 12px;display:flex}.sidebar-link{color:var(--text-main);cursor:pointer;border-radius:10px;align-items:center;gap:12px;padding:11px 16px;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .2s;display:flex;position:relative}.sidebar-link:hover{color:var(--primary-blue);background-color:#234e8a0d}.sidebar-link.active{color:var(--primary-blue);background:linear-gradient(135deg,#234e8a14,#2b65bd1f);font-weight:600}.sidebar-link.active:before{content:"";background:var(--primary-blue);border-radius:0 3px 3px 0;width:3px;height:60%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-link-icon{text-align:center;flex-shrink:0;width:24px;font-size:1.2rem}.sidebar-link-label{white-space:nowrap}.sidebar-divider{background:var(--border-light);height:1px;margin:8px 16px}.sidebar-profile{border-top:1px solid var(--border-light);flex-shrink:0;align-items:center;gap:12px;padding:16px 20px;display:flex}.sidebar-profile-avatar{background:linear-gradient(135deg,#234e8a1a,#2b65bd26);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.3rem;display:flex}.sidebar-profile-info{overflow:hidden}.sidebar-profile-name{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.sidebar-profile-role{color:var(--text-muted);text-transform:capitalize;font-size:.75rem}.sidebar-logout{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:8px;margin-left:auto;padding:6px;font-size:1.1rem;transition:all .2s}.sidebar-logout:hover{color:#dc3545;background:#dc354514}.dashboard-main{flex-direction:column;flex:1;min-height:100vh;margin-left:260px;transition:margin-left .35s cubic-bezier(.4,0,.2,1);display:flex}.dashboard-topbar{background:var(--bg-surface);border-bottom:1px solid var(--border-light);z-index:50;justify-content:space-between;align-items:center;height:68px;padding:0 32px;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:16px;display:flex}.topbar-hamburger{cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px;transition:background .2s;display:none}.topbar-hamburger:hover{background:#0000000d}.hamburger-bar{background:var(--text-main);border-radius:2px;width:22px;height:2.5px;margin:4px 0;transition:all .3s;display:block}.topbar-title{font-family:var(--font-heading);color:var(--primary-blue);font-size:1.35rem;font-weight:700}.topbar-search{background:var(--bg-surface-alt);border:1px solid var(--border-light);border-radius:10px;align-items:center;gap:8px;min-width:280px;padding:8px 16px;transition:all .2s;display:flex}.topbar-search:focus-within{border-color:var(--primary-blue);background:var(--bg-surface);box-shadow:0 0 0 3px #234e8a14}.topbar-search-icon{color:var(--text-muted);font-size:.95rem}.topbar-search input{width:100%;color:var(--text-main);font-size:.9rem;font-family:var(--font-body);background:0 0;border:none;outline:none}.topbar-search input::placeholder{color:var(--text-muted);opacity:.7}.topbar-right{align-items:center;gap:8px;display:flex}.topbar-icon-btn{cursor:pointer;width:40px;height:40px;color:var(--text-main);background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;font-size:1.2rem;transition:all .2s;display:flex;position:relative}.topbar-icon-btn:hover{color:var(--primary-blue);background:#234e8a0f}.notification-badge{border:2px solid var(--bg-surface);background:#dc3545;border-radius:50%;width:8px;height:8px;position:absolute;top:6px;right:6px}.topbar-avatar{cursor:pointer;background:linear-gradient(135deg,#234e8a1a,#2b65bd33);border:2px solid #0000;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;margin-left:4px;font-size:1.2rem;transition:all .2s;display:flex}.topbar-avatar:hover{border-color:var(--primary-blue);transform:scale(1.05)}.dashboard-content{flex:1;padding:28px 32px;overflow-y:auto}.welcome-banner{background:linear-gradient(135deg, var(--primary-blue) 0%, var(--accent-blue) 100%);color:var(--white);border-radius:16px;margin-bottom:28px;padding:32px 36px;position:relative;overflow:hidden}.welcome-banner:before{content:"";pointer-events:none;background:#ffffff0d;border-radius:50%;width:400px;height:400px;position:absolute;top:-50%;right:-20%}.welcome-banner:after{content:"";pointer-events:none;background:#ffffff08;border-radius:50%;width:300px;height:300px;position:absolute;bottom:-60%;left:-10%}.welcome-banner h2{color:var(--white);z-index:1;margin-bottom:6px;font-size:1.6rem;position:relative}.welcome-banner p{opacity:.85;z-index:1;font-size:.95rem;position:relative}.stats-grid{grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:28px;display:grid}.stat-card{background:var(--bg-surface);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);border-radius:14px;align-items:center;gap:16px;padding:22px 24px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.stat-card:hover{border-color:#234e8a1a;transform:translateY(-4px);box-shadow:0 8px 25px #234e8a1a}.stat-card-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.5rem;display:flex}.stat-card-icon.blue{background:#234e8a14}.stat-card-icon.green{background:#22c55e14}.stat-card-icon.purple{background:#9333ea14}.stat-card-icon.orange{background:#f9731614}.stat-card-info h3{color:var(--primary-blue);margin-bottom:2px;font-size:1.6rem;font-weight:700;line-height:1.2}.stat-card-info p{color:var(--text-muted);font-size:.82rem;font-weight:500}.stat-card-trend{border-radius:20px;margin-top:4px;padding:3px 8px;font-size:.75rem;font-weight:600;display:inline-block}.stat-card-trend.up{color:#16a34a;background:#22c55e1a}.stat-card-trend.down{color:#dc2626;background:#ef44441a}.dashboard-grid{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:28px;display:grid}.dashboard-grid.three-col{grid-template-columns:2fr 1fr}.dashboard-card{background:var(--bg-surface);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);border-radius:14px;padding:24px;transition:all .3s}.dashboard-card:hover{box-shadow:0 6px 20px #234e8a14}.dashboard-card-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.dashboard-card-header h3{color:var(--primary-blue);font-size:1.05rem;font-weight:700}.dashboard-card-header .view-all{color:var(--accent-blue);cursor:pointer;background:0 0;border:none;font-size:.82rem;font-weight:600;text-decoration:none;transition:color .2s}.dashboard-card-header .view-all:hover{color:var(--primary-blue)}.dashboard-card.full-width{grid-column:1/-1}.course-progress-list{flex-direction:column;gap:16px;display:flex}.course-progress-item{background:var(--bg-surface-alt);cursor:pointer;border:1px solid var(--border-light);border-radius:12px;align-items:center;gap:16px;padding:16px;transition:all .25s;display:flex}.course-progress-item:hover{background:#234e8a0d;transform:translate(4px)}.course-emoji{background:var(--bg-surface);width:48px;height:48px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.5rem;display:flex}.course-progress-details{flex:1;min-width:0}.course-progress-details h4{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:.92rem;font-weight:600;overflow:hidden}.course-progress-details .course-category{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:600}.course-progress-meta{color:var(--text-muted);align-items:center;gap:16px;margin-top:8px;font-size:.8rem;display:flex}.progress-bar-container{background:#0000000f;border-radius:10px;flex:1;height:6px;margin-top:10px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--primary-blue), var(--accent-blue));border-radius:10px;height:100%;transition:width 1s cubic-bezier(.4,0,.2,1)}.course-progress-action{color:var(--accent-blue);white-space:nowrap;cursor:pointer;font-size:.8rem;font-weight:600;transition:color .2s}.course-progress-action:hover{color:var(--primary-blue)}.course-recommend-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.course-recommend-card{background:var(--bg-surface-alt);cursor:pointer;border:1px solid var(--border-light);border-radius:12px;padding:20px;transition:all .3s}.course-recommend-card:hover{background:var(--bg-surface);border-color:var(--primary-blue);box-shadow:var(--shadow-md);transform:translateY(-3px)}.course-recommend-card .course-emoji{margin-bottom:12px}.course-recommend-card h4{color:var(--text-main);margin-bottom:6px;font-size:.9rem;font-weight:600;line-height:1.3}.course-recommend-card .course-meta{color:var(--text-light);align-items:center;gap:12px;font-size:.78rem;display:flex}.course-recommend-card .course-rating{color:#f59e0b;font-weight:600}.course-recommend-card .course-students{color:var(--text-light)}.task-list{flex-direction:column;gap:10px;display:flex}.task-item{background:var(--bg-surface-alt);border:1px solid var(--border-light);border-radius:10px;align-items:center;gap:14px;padding:14px 16px;transition:all .2s;display:flex}.task-item:hover{background:#234e8a0a}.task-status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.task-status-dot.pendiente{background:#f59e0b;box-shadow:0 0 0 3px #f59e0b26}.task-status-dot.entregada{background:var(--accent-blue);box-shadow:0 0 0 3px #2b65bd26}.task-status-dot.calificada{background:#22c55e;box-shadow:0 0 0 3px #22c55e26}.task-info{flex:1;min-width:0}.task-info h4{color:var(--text-main);margin-bottom:2px;font-size:.88rem;font-weight:600}.task-info p{color:var(--text-muted);font-size:.78rem}.task-due{color:var(--text-light);white-space:nowrap;font-size:.78rem;font-weight:500}.task-grade{color:var(--primary-blue);background:#234e8a14;border-radius:8px;padding:4px 10px;font-size:.85rem;font-weight:700}.announcement-list{flex-direction:column;gap:12px;display:flex}.announcement-item{background:var(--bg-surface-alt);border-left:4px solid;border-top:1px solid var(--border-light);border-right:1px solid var(--border-light);border-bottom:1px solid var(--border-light);border-radius:10px;padding:16px;transition:all .2s}.announcement-item:hover{transform:translate(4px)}.announcement-item.info{border-color:var(--accent-blue);background-color:#2b65bd0d}.announcement-item.warning{background-color:#f59e0b0d;border-color:#f59e0b}.announcement-item.success{background-color:#22c55e0d;border-color:#22c55e}.announcement-item h4{color:var(--text-dark);margin-bottom:4px;font-size:.9rem;font-weight:600}.announcement-item p{color:var(--text-light);margin-bottom:6px;font-size:.82rem;line-height:1.5}.announcement-meta{color:var(--text-light);opacity:.7;align-items:center;gap:12px;font-size:.72rem;display:flex}.users-table-wrapper{overflow-x:auto}.users-table{border-collapse:separate;border-spacing:0;width:100%}.users-table th{text-align:left;color:var(--text-light);text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid #0000000f;padding:12px 16px;font-size:.75rem;font-weight:700}.users-table td{color:var(--text-dark);border-bottom:1px solid #00000008;padding:14px 16px;font-size:.88rem}.users-table tr:hover td{background:#234e8a05}.users-table .user-cell{align-items:center;gap:10px;display:flex}.users-table .user-avatar-sm{background:linear-gradient(135deg,#234e8a14,#2b65bd1f);border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9rem;display:flex}.role-badge{letter-spacing:.3px;border-radius:20px;padding:4px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.role-badge.admin{color:#7c3aed;background:#9333ea1a}.role-badge.estudiante{color:#16a34a;background:#22c55e1a}.role-badge.tutor{color:var(--primary-blue);background:#234e8a1a}.status-badge{border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.status-badge.active{color:#16a34a;background:#22c55e1a}.status-badge.active:before{content:"";background:#22c55e;border-radius:50%;width:6px;height:6px}.activity-chart{align-items:flex-end;gap:12px;height:160px;padding-top:16px;display:flex}.chart-bar-wrapper{flex-direction:column;flex:1;align-items:center;gap:8px;height:100%;display:flex}.chart-bar{background:linear-gradient(180deg, var(--accent-blue), var(--primary-blue));cursor:pointer;border-radius:8px 8px 4px 4px;width:100%;max-width:40px;min-height:4px;transition:height 1s cubic-bezier(.4,0,.2,1);position:relative}.chart-bar:hover{filter:brightness(1.15)}.chart-bar-value{color:var(--primary-blue);opacity:0;white-space:nowrap;font-size:.7rem;font-weight:700;transition:opacity .2s;position:absolute;top:-22px;left:50%;transform:translate(-50%)}.chart-bar:hover .chart-bar-value{opacity:1}.chart-bar-label{color:var(--text-light);font-size:.72rem;font-weight:600}.weekly-calendar{gap:8px;display:flex}.calendar-day{cursor:pointer;border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:6px;padding:10px 8px;transition:all .2s;display:flex}.calendar-day:hover{background:#234e8a0a}.calendar-day.active{background:var(--primary-blue)}.calendar-day-name{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;font-size:.7rem;font-weight:700}.calendar-day.active .calendar-day-name{color:#fffc}.calendar-day-number{color:var(--text-dark);border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.05rem;font-weight:700;display:flex}.calendar-day.active .calendar-day-number{color:var(--white);background:#ffffff26}.profile-sidebar-card{text-align:center;border-bottom:1px solid #0000000d;flex-direction:column;align-items:center;margin-bottom:20px;padding-bottom:20px;display:flex}.profile-avatar-lg{background:linear-gradient(135deg,#234e8a1a,#2b65bd33);border-radius:20px;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:12px;font-size:2.2rem;display:flex}.profile-sidebar-card h3{color:var(--text-dark);margin-bottom:2px;font-size:1.05rem}.profile-sidebar-card p{color:var(--text-light);font-size:.82rem}.profile-stats-row{justify-content:center;gap:24px;margin-top:16px;display:flex}.profile-stat{flex-direction:column;align-items:center;display:flex}.profile-stat-value{color:var(--primary-blue);font-size:1.3rem;font-weight:800;line-height:1}.profile-stat-label{color:var(--text-light);margin-top:4px;font-size:.68rem;font-weight:600}.student-list{flex-direction:column;gap:12px;display:flex}.student-item{background:var(--bg-light);border-radius:10px;align-items:center;gap:12px;padding:12px 14px;transition:all .2s;display:flex}.student-item:hover{background:#234e8a0a;transform:translate(3px)}.student-avatar{background:var(--white);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.1rem;display:flex;box-shadow:0 2px 6px #0000000f}.student-info{flex:1;min-width:0}.student-info h4{color:var(--text-dark);margin-bottom:1px;font-size:.88rem;font-weight:600}.student-info p{color:var(--text-light);font-size:.75rem}.student-last-active{color:var(--text-light);white-space:nowrap;font-size:.72rem}.mini-progress-bar{background:#0000000f;border-radius:4px;flex-shrink:0;width:60px;height:4px;overflow:hidden}.mini-progress-fill{background:var(--accent-blue);border-radius:4px;height:100%}.session-list{flex-direction:column;gap:10px;display:flex}.session-item{background:var(--bg-light);border-radius:10px;align-items:center;gap:14px;padding:14px 16px;transition:all .2s;display:flex}.session-item:hover{background:#234e8a0d}.session-time{background:var(--white);border-radius:8px;flex-direction:column;align-items:center;min-width:60px;padding:8px 12px;display:flex;box-shadow:0 2px 6px #0000000f}.session-time-hour{color:var(--primary-blue);font-size:.9rem;font-weight:700}.session-time-period{color:var(--text-muted);text-transform:uppercase;font-size:.65rem;font-weight:600}.session-details h4{color:var(--text-main);margin-bottom:2px;font-size:.88rem;font-weight:600}.session-details p{color:var(--text-muted);font-size:.78rem}.sidebar-overlay{z-index:90;-webkit-backdrop-filter:blur(4px);background:#0006;display:none;position:fixed;inset:0}.sidebar-overlay.visible{display:block}@keyframes dashFadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.dash-delay-1{opacity:0;animation-delay:50ms}.dash-delay-2{opacity:0;animation-delay:.1s}.dash-delay-3{opacity:0;animation-delay:.15s}.dash-delay-4{opacity:0;animation-delay:.2s}.dash-delay-5{opacity:0;animation-delay:.25s}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;display:flex}.empty-state-icon{margin-bottom:12px;font-size:2.5rem}.empty-state p{color:var(--text-muted);font-size:.9rem}@media (width<=1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid,.dashboard-grid.three-col{grid-template-columns:1fr}.course-recommend-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=900px){.dashboard-sidebar{transform:translate(-100%)}.dashboard-sidebar.open{transform:translate(0)}.dashboard-main{margin-left:0}.topbar-hamburger{display:block}.topbar-search{min-width:180px}.dashboard-content{padding:20px}.welcome-banner{padding:24px}.welcome-banner h2{font-size:1.3rem}}@media (width<=600px){.stats-grid{grid-template-columns:1fr}.dashboard-topbar{height:60px;padding:0 16px}.topbar-search{display:none}.topbar-title{font-size:1.1rem}.dashboard-content{padding:16px}.welcome-banner{border-radius:12px;margin-bottom:20px;padding:20px}.welcome-banner h2{font-size:1.15rem}.course-recommend-grid{grid-template-columns:1fr}.weekly-calendar{padding-bottom:8px;overflow-x:auto}.calendar-day{min-width:48px}.activity-chart{height:120px}.stat-card{padding:16px}.stat-card-icon{width:44px;height:44px;font-size:1.2rem}.stat-card-info h3{font-size:1.3rem}.dashboard-card{padding:18px}.profile-stats-row{gap:16px}}.role-selector-group{margin-bottom:16px}.role-selector-group label{color:var(--text-dark);margin-bottom:8px;font-size:.82rem;font-weight:600;display:block}.role-selector{border:1px solid var(--border-light);background-color:var(--bg-surface-alt);width:100%;font-size:.95rem;font-family:var(--font-body);color:var(--text-main);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-position:right 16px center;background-repeat:no-repeat;background-size:16px;border-radius:12px;padding:14px 16px;transition:all .2s}.role-selector:focus{border-color:var(--primary-blue);background-color:var(--bg-surface);outline:none;box-shadow:0 0 0 3px #234e8a1a}.mock-hint{background:var(--border-light);color:var(--primary-blue);border-radius:10px;align-items:center;gap:6px;margin-bottom:16px;padding:10px 14px;font-size:.78rem;font-weight:500;display:flex}.mock-hint-icon{font-size:1rem}.modal-overlay{-webkit-backdrop-filter:blur(5px);z-index:9999;background-color:#0f172ab3;justify-content:center;align-items:center;width:100vw;height:100vh;padding:20px;display:flex;position:fixed;top:0;left:0}.modal-container{background-color:var(--bg-surface);width:100%;max-width:550px;max-height:90vh;box-shadow:var(--shadow-md);border:1px solid var(--border-light);border-radius:16px;flex-direction:column;animation:.4s cubic-bezier(.16,1,.3,1) modalSlideUp;display:flex;overflow:hidden}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(30px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:24px 30px;display:flex}.modal-header h2{color:var(--primary-blue);margin:0;font-size:1.4rem;font-weight:700}.modal-close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:4px;font-size:1.5rem;transition:all .2s;display:flex}.modal-close-btn:hover{background-color:var(--border-light);color:var(--text-main)}.modal-body{padding:30px;overflow-y:auto}.modal-footer{background-color:var(--bg-surface-alt);border-top:1px solid var(--border-light);justify-content:flex-end;gap:12px;padding:20px 30px;display:flex}.modal-form-group{flex-direction:column;gap:6px;margin-bottom:20px;display:flex}.modal-form-group label{color:var(--text-main);font-size:.9rem;font-weight:600}.modal-form-group input,.modal-form-group textarea,.modal-form-group select{border:1px solid var(--border-light);background-color:var(--bg-surface-alt);color:var(--text-main);font-size:.95rem;font-family:var(--font-body);border-radius:10px;outline:none;width:100%;padding:12px 16px;transition:all .2s}.modal-form-group input:focus,.modal-form-group textarea:focus{border-color:var(--primary-blue);background-color:var(--bg-surface);box-shadow:0 0 0 3px #234e8a1a}@media (width<=600px){.modal-container{border-radius:0;max-height:100vh;position:fixed;inset:0}.modal-overlay{padding:0}}:root{--admin-primary:var(--primary-blue);--admin-secondary:var(--secondary-blue);--admin-accent:var(--accent-blue);--admin-bg:var(--bg-main);--admin-card-radius:14px;--admin-shadow:var(--shadow-sm);--admin-shadow-hover:var(--shadow-md)}@keyframes dashFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dash-fade-in{animation:.5s ease-out forwards dashFadeIn}.dash-delay-1{animation-delay:.1s}.dash-delay-2{animation-delay:.15s}.dash-delay-3{animation-delay:.2s}.dash-delay-4{animation-delay:.25s}.dash-delay-5{animation-delay:.3s}.admin-page-header{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex}.admin-page-header h1{color:var(--admin-primary);font-size:1.6rem;font-weight:700}.admin-btn-primary{background:linear-gradient(135deg, var(--admin-primary), var(--admin-accent));color:#fff;cursor:pointer;border:none;border-radius:10px;padding:10px 20px;font-weight:600;transition:all .3s;box-shadow:0 4px 12px #234e8a33}.admin-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 15px #234e8a4d}.admin-btn-secondary{background:var(--bg-surface);color:var(--admin-primary);border:1px solid var(--border-light);cursor:pointer;border-radius:10px;padding:10px 20px;font-weight:600;transition:all .3s}.admin-btn-secondary:hover{background:var(--bg-surface-alt)}.admin-filter-bar{background:var(--bg-surface);border-radius:var(--admin-card-radius);box-shadow:var(--admin-shadow);border:1px solid var(--border-light);flex-wrap:wrap;gap:16px;margin-bottom:24px;padding:16px;display:flex}.admin-filter-bar input,.admin-filter-bar select{border:1px solid var(--border-light);background:var(--bg-surface-alt);color:var(--text-main);border-radius:8px;outline:none;padding:10px 14px;font-size:.9rem;transition:border-color .2s}.admin-filter-bar input:focus,.admin-filter-bar select:focus{border-color:var(--admin-primary)}.search-input-wrapper{flex:1;min-width:200px}.admin-table-container{background:var(--bg-surface);border-radius:var(--admin-card-radius);box-shadow:var(--admin-shadow);border:1px solid var(--border-light);overflow:hidden}.admin-table{border-collapse:collapse;text-align:left;width:100%}.admin-table th{color:var(--text-light);text-transform:uppercase;letter-spacing:1px;background:#234e8a08;padding:16px 24px;font-size:.75rem;font-weight:700}.admin-table td{border-bottom:1px solid var(--border-light);color:var(--text-main);padding:16px 24px;font-size:.9rem}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#234e8a03}.badge{border-radius:20px;padding:4px 10px;font-size:.75rem;font-weight:600}.badge.admin{color:#9333ea;background:#9333ea1a}.badge.estudiante{color:var(--admin-primary);background:#234e8a1a}.badge.tutor{color:#16a34a;background:#22c55e1a}.status-dot{border-radius:50%;width:8px;height:8px;margin-right:8px;display:inline-block}.status-dot.active{background:#22c55e;box-shadow:0 0 0 3px #22c55e33}.status-dot.inactive{background:#94a3b8}.settings-container{grid-template-columns:240px 1fr;gap:32px;display:grid}.settings-tabs{flex-direction:column;gap:8px;display:flex}.settings-tab{color:var(--text-light);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;padding:12px 18px;font-weight:600;transition:all .2s}.settings-tab:hover{color:var(--admin-primary);background:#234e8a0d}.settings-tab.active{background:var(--bg-surface);color:var(--admin-primary);box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.settings-card{background:var(--bg-surface);border-radius:var(--admin-card-radius);box-shadow:var(--admin-shadow);border:1px solid var(--border-light);margin-bottom:24px;padding:28px}.settings-card h3{color:var(--admin-primary);border-bottom:1px solid #0000000d;margin-bottom:20px;padding-bottom:12px;font-size:1.1rem}.form-group{margin-bottom:20px}.form-group label{color:var(--text-dark);margin-bottom:8px;font-size:.85rem;font-weight:600;display:block}.form-control{border:1px solid var(--border-light);background:var(--bg-surface-alt);width:100%;color:var(--text-main);border-radius:10px;padding:12px 16px;transition:all .2s}.form-control:focus{background:var(--bg-surface);border-color:var(--admin-primary);outline:none;box-shadow:0 0 0 3px #234e8a1a}.toggle-switch{cursor:pointer;align-items:center;gap:12px;display:flex}.toggle-bg{background:#cbd5e1;border-radius:20px;width:44px;height:24px;transition:all .3s;position:relative}.toggle-dot{background:var(--white);border-radius:50%;width:18px;height:18px;transition:all .3s;position:absolute;top:3px;left:3px}.toggle-switch.active .toggle-bg{background:var(--admin-primary)}.toggle-switch.active .toggle-dot{transform:translate(20px)}.chart-placeholder{background:linear-gradient(#0000 0%,#234e8a0d 100%);border-radius:12px;align-items:flex-end;gap:15px;height:300px;padding:20px;display:flex;position:relative}.bar-stub{background:linear-gradient(to top, var(--admin-primary), var(--admin-accent));border-radius:4px 4px 0 0;flex:1;transition:height 1s ease-out}.donut-placeholder{background:conic-gradient(var(--admin-primary) 0% 45%, var(--admin-accent) 45% 75%, #e2e8f0 75% 100%);border-radius:50%;width:200px;height:200px;margin:0 auto;position:relative}.donut-placeholder:after{content:"";background:var(--bg-surface);border-radius:50%;position:absolute;inset:25%}.course-workspace-header{background:var(--bg-surface);border-radius:var(--admin-card-radius);box-shadow:var(--admin-shadow);border:1px solid var(--border-light);justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:20px;padding:20px 22px;display:flex}.course-back-link{color:var(--admin-accent);margin-bottom:8px;font-size:.86rem;font-weight:600;text-decoration:none;display:inline-block}.course-back-link:hover{color:var(--admin-primary)}.course-workspace-header h1{color:var(--admin-primary);margin-bottom:6px;font-size:1.5rem}.course-workspace-header p{color:var(--text-muted);font-size:.9rem}.course-header-actions{align-items:center;gap:10px;display:flex}.course-section-tabs{grid-template-columns:repeat(8,minmax(120px,1fr));gap:10px;margin-bottom:20px;padding-bottom:4px;display:grid;overflow-x:auto}.course-tab-btn{border:1px solid var(--border-light);background:var(--bg-surface);color:var(--text-main);white-space:nowrap;cursor:pointer;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:10px 12px;font-size:.84rem;font-weight:600;transition:all .2s;display:flex}.course-tab-btn:hover{background:#234e8a0a}.course-tab-btn.active{border-color:var(--admin-primary);color:var(--admin-primary);background:linear-gradient(135deg,#234e8a12,#2b65bd1f)}.course-main-grid{grid-template-columns:1.7fr 1fr;gap:20px;margin-bottom:24px;display:grid}.course-muted-paragraph{color:var(--text-muted);margin-bottom:16px;font-size:.92rem;line-height:1.6}.course-mini-stats{grid-template-columns:repeat(3,1fr);margin-bottom:0}.course-progress-large{flex-direction:column;gap:12px;display:flex}.course-progress-large .course-progress-value{color:var(--admin-primary);font-size:2rem;font-weight:800}.course-progress-large p{color:var(--text-muted);font-size:.88rem}.course-module-list{flex-direction:column;gap:12px;display:flex}.course-module-item{background:var(--admin-bg);border-radius:10px;justify-content:space-between;align-items:center;gap:16px;padding:14px 16px;display:flex}.course-module-item h4{color:var(--admin-primary);margin-bottom:4px;font-size:.98rem}.course-module-item p{color:var(--text-muted);font-size:.84rem}.course-module-meta{color:var(--text-muted);flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;font-size:.8rem;display:flex}.course-table-wrapper{overflow-x:auto}.course-evaluation-list{flex-direction:column;gap:10px;display:flex}.course-file-list{flex-direction:column;gap:12px;display:flex}.course-file-item{background:var(--admin-bg);border-radius:10px;justify-content:space-between;align-items:center;gap:14px;padding:14px 16px;display:flex}.course-file-item h4{color:var(--admin-primary);margin-bottom:2px;font-size:.92rem}.course-file-item p{color:var(--text-muted);font-size:.8rem}.course-file-actions{align-items:center;gap:10px;display:flex}.course-file-actions span{color:var(--text-muted);font-size:.8rem}.course-people-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.course-person-card{background:var(--admin-bg);border-radius:10px;align-items:center;gap:10px;padding:12px;display:flex}.course-person-avatar{background:#234e8a1a;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.2rem;display:flex}.course-person-card h4{color:var(--admin-primary);margin-bottom:2px;font-size:.88rem}.course-person-card p{color:var(--text-muted);font-size:.78rem}@media (width<=1100px){.course-main-grid{grid-template-columns:1fr}.course-people-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=820px){.course-workspace-header{flex-direction:column}.course-header-actions{width:100%}.course-header-actions .admin-btn-primary,.course-header-actions .admin-btn-secondary{flex:1}.course-mini-stats{grid-template-columns:1fr}.course-module-item,.course-file-item{flex-direction:column;align-items:flex-start}.course-module-meta,.course-file-actions{justify-content:space-between;width:100%}.course-people-grid{grid-template-columns:1fr}}.status-selector-container{flex-direction:column;align-items:flex-end;gap:8px;display:flex}.status-selector-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;opacity:.8;font-size:.7rem;font-weight:700}.status-buttons-group{background:var(--bg-surface-alt);border:1px solid var(--border-light);border-radius:12px;gap:4px;padding:4px;display:flex;box-shadow:inset 0 2px 4px #00000005}.status-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:9px;align-items:center;padding:8px 16px;font-size:.82rem;font-weight:600;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex}.status-btn:hover{color:var(--text-main);background:#00000008}.status-btn.active{transform:scale(1.02);box-shadow:0 4px 10px #0000000d,0 1px 3px #0000001a}.status-btn.active.borrador{color:#b45309;background:#fffbeb;border:1px solid #fde68a}.status-btn.active.oculto{color:#475569;background:#f8fafc;border:1px solid #e2e8f0}.status-btn.active.publicado{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0}@keyframes gradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes floatIcon{0%{transform:translateY(0)}50%{transform:translateY(-10px)}to{transform:translateY(0)}}.fade-in-up{animation:.8s cubic-bezier(.16,1,.3,1) forwards fadeInUp}.delay-1{animation-delay:.1s}.delay-2{animation-delay:.3s}.delay-3{animation-delay:.5s}.btn{cursor:pointer;letter-spacing:.5px;border:none;border-radius:8px;justify-content:center;align-items:center;padding:.6rem 1.4rem;font-weight:600;transition:all .2s cubic-bezier(.25,.8,.25,1);display:inline-flex}.btn:active{transform:scale(.96)}.btn-primary{background-color:var(--primary-blue);color:var(--white);box-shadow:0 4px 10px #234e8a33}.btn-primary:hover{background-color:var(--accent-blue);transform:translateY(-2px);box-shadow:0 6px 15px #2b65bd59}.btn-outline{color:var(--primary-blue);border:2px solid var(--primary-blue);background-color:#0000}.btn-outline:hover{background-color:var(--border-light);color:var(--secondary-blue);border-color:var(--secondary-blue)}[data-theme=dark] .btn-outline:hover{color:var(--accent-blue);border-color:var(--accent-blue);background-color:#3b82f626}.btn-large{margin-top:1.5rem;padding:.8rem 2rem;font-size:1.1rem}.navbar{background-color:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-light);z-index:1000;align-items:center;height:80px;display:flex;position:sticky;top:0}.nav-container{justify-content:space-between;align-items:center;width:100%;max-width:1400px;margin:0 auto;padding:0 40px;display:flex}.mobile-toggle{cursor:pointer;z-index:1000;flex-direction:column;justify-content:space-between;width:30px;height:21px;display:none}.mobile-toggle .bar{background-color:var(--primary-blue);border-radius:3px;width:100%;height:3px;transition:all .3s}.mobile-toggle .bar.open:first-child{transform:translateY(9px)rotate(45deg)}.mobile-toggle .bar.open:nth-child(2){opacity:0}.mobile-toggle .bar.open:nth-child(3){transform:translateY(-9px)rotate(-45deg)}.nav-menu{flex:1;justify-content:flex-end;align-items:center;gap:40px;display:flex}.nav-links{align-items:center;gap:24px;display:flex}.nav-links a{color:var(--text-main);white-space:nowrap;background-color:#0000;border-radius:8px;padding:8px 14px;font-size:.95rem;font-weight:600;transition:all .2s}.nav-links a:hover,.nav-links a.active{color:var(--primary-blue);background-color:var(--border-light)}.nav-actions{align-items:center;gap:16px;display:flex}.theme-toggle-btn{background:var(--bg-surface-alt);border:1px solid var(--border-light);color:var(--text-main);cursor:pointer;width:40px;height:40px;box-shadow:var(--shadow-sm);border-radius:10px;justify-content:center;align-items:center;transition:all .2s;display:flex}.theme-toggle-btn:hover{background:var(--primary-blue);color:#fff;transform:translateY(-2px)}.nav-actions .btn{justify-content:center;min-width:155px}.hero{background-color:#234e8a;align-items:center;min-height:85vh;display:flex;position:relative;overflow:hidden}.hero-wrap{background:linear-gradient(to right, var(--bg-surface) 45%, var(--primary-blue) 45%);flex-wrap:wrap;width:100%;min-height:85vh;display:flex;position:relative}.hero-text-col{color:#fff;z-index:5;flex-direction:column;flex:55%;justify-content:center;padding:80px;display:flex;position:relative;overflow:hidden}.hero-background-effects{z-index:1;pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0;overflow:hidden}.orb{-webkit-filter:blur(80px);border-radius:50%;animation:20s ease-in-out infinite alternate floatOrb;position:absolute}.orb-1{background:var(--accent-blue);opacity:.4;width:450px;height:450px;animation-delay:0s;top:-100px;right:-50px}.orb-2{background:#2b65bd66;width:600px;height:600px;animation-duration:25s;animation-delay:-5s;bottom:-200px;left:20%}.orb-3{mix-blend-mode:overlay;background:#ffffff80;width:450px;height:450px;animation-duration:22s;top:40%;left:-50px}.orb-white{-webkit-filter:blur(100px);background:#ffffff26;border-radius:50%;width:700px;height:700px;animation:28s ease-in-out infinite alternate floatOrb;top:20%;right:15%}@keyframes floatOrb{0%{transform:translate(0)scale(1)}33%{transform:translate(40px,-60px)scale(1.1)}66%{transform:translate(-30px,40px)scale(.95)}to{transform:translate(0)scale(1)}}.hero-text-content{z-index:3;max-width:600px;position:relative}.hero-img-col{z-index:5;flex:45%;min-height:500px;position:relative}.hero-image-full{object-fit:cover;z-index:3;width:100%;height:100%;position:absolute;top:0;left:0}.interactive-hero-img-wrapper{z-index:5;width:100%;height:100%;position:relative}.floating-img-anim{transform-origin:bottom;animation:8s ease-in-out infinite floatSlow}.hero-badge{-webkit-backdrop-filter:blur(10px);color:var(--primary-blue);z-index:10;white-space:nowrap;background:#ffffffe6;border:1px solid #ffffff80;border-radius:50px;align-items:center;gap:10px;padding:12px 20px;font-size:.95rem;font-weight:700;transition:transform .3s cubic-bezier(.175,.885,.32,1);display:flex;position:absolute;box-shadow:0 15px 30px #0000001a}.hero-badge:hover{transform:scale(1.08)translateY(-5px)!important}.hero-badge .badge-icon{font-size:1.4rem}.badge-top-left{top:15%;left:20px}.badge-bottom-right{bottom:20%;right:-20px}.badge-middle-left{top:55%;left:40px}.float-anim-1{animation:5s ease-in-out infinite floatSlow}.float-anim-2{animation:6s ease-in-out 1s infinite floatSlow}.float-anim-3{animation:7s ease-in-out 2s infinite floatSlow}@keyframes floatSlow{0%{transform:translateY(0)}50%{transform:translateY(-12px)}to{transform:translateY(0)}}.status-pill{color:#fff;-webkit-backdrop-filter:blur(8px);background:#ffffff14;border:1px solid #ffffff26;border-radius:50px;align-items:center;gap:12px;padding:8px 18px;font-size:.9rem;font-weight:600;display:inline-flex;box-shadow:0 4px 15px #0000001a}.pulse-dot{background-color:#4ade80;border-radius:50%;width:10px;height:10px;animation:2s infinite pulseGreenLight;box-shadow:0 0 #4ade80b3}@keyframes pulseGreenLight{0%{transform:scale(.95);box-shadow:0 0 #4ade80b3}70%{transform:scale(1);box-shadow:0 0 0 8px #4ade8000}to{transform:scale(.95);box-shadow:0 0 #4ade8000}}.interactive-title{transform-origin:0;transition:transform .4s cubic-bezier(.175,.885,.32,1)}.interactive-title:hover{transform:scale(1.02)rotate(-1deg)}.hover-glow-container{transition:all .3s cubic-bezier(.25,.8,.25,1)}.hover-glow-container:focus-within{transform:translateY(-3px);box-shadow:0 25px 40px #00000040!important}.btn-glow{border:none;position:relative;overflow:hidden}.btn-glow:after{content:"";background:linear-gradient(90deg,#fff0 0%,#fff6 50%,#fff0 100%);width:200%;height:200%;animation:4s linear infinite flashButton;position:absolute;top:-50%;left:-50%;transform:rotate(30deg)translateY(0)}@keyframes flashButton{0%{transform:scale(1)rotate(45deg)translate(-150%)}25%{transform:scale(1)rotate(45deg)translate(150%)}to{transform:scale(1)rotate(45deg)translate(150%)}}.hero-trust{border-top:1px solid #ffffff26;align-items:center;gap:15px;margin-top:35px;padding-top:25px;display:flex}.avatar-stack{align-items:center;display:flex}.avatar{border:2px solid var(--primary-blue);background-color:var(--white);width:38px;height:38px;color:var(--primary-blue);border-radius:50%;justify-content:center;align-items:center;margin-left:-14px;font-size:.8rem;font-weight:800;transition:transform .3s cubic-bezier(.175,.885,.32,1);display:flex;position:relative;box-shadow:0 4px 10px #00000026}.avatar-stack .avatar:first-child{margin-left:0}.avatar-stack:hover .avatar{transform:translateY(-8px)}.avatar.a1{background:linear-gradient(135deg,#aedeec,#5ebdf1)}.avatar.a2{background:linear-gradient(135deg,#fcd5ce,#ffb5a7)}.avatar.a3{background:linear-gradient(135deg,#e2ece9,#dfe7fd)}.trust-text{color:#ffffffe6;margin:0;font-size:.95rem;font-weight:600}.search-bar-container{background:var(--bg-surface);box-shadow:var(--shadow-md);border:1px solid var(--border-light);border-radius:12px;align-items:center;width:100%;max-width:500px;margin-top:40px;padding:6px;display:flex}.search-bar-container input{color:var(--text-main);background:0 0;border:none;outline:none;flex:1;padding:16px 15px;font-size:1rem}.hero-subtitle{color:#ffffffe6!important;text-align:left!important;margin-top:24px!important;font-size:1.25rem!important;line-height:1.6!important}.title-image-container{width:100%;max-width:600px;margin:0 auto;animation:6s ease-in-out infinite floatIcon}.floating-title-img{object-fit:contain;filter:drop-shadow(0 10px 15px #234e8a26);width:100%;max-height:200px}.hero-text-box{margin-top:2rem;padding:0 1rem}.cinematic-subtitle{color:var(--text-dark);font-size:1.3rem;font-weight:500;line-height:1.6}.hero-buttons{flex-wrap:wrap;justify-content:center;gap:1.5rem;margin-top:2rem;display:flex}.glow-effect{box-shadow:0 0 15px #2b65bd66}.glow-effect:hover{box-shadow:0 0 25px #2b65bd99}.outline-light{border-color:var(--primary-blue);color:var(--primary-blue)}.outline-light:hover{background:var(--primary-blue);color:#fff}.about-modern{background-color:var(--bg-main);padding:100px 40px;position:relative;overflow:hidden}.about-modern-container{grid-template-columns:1fr 1fr;align-items:center;gap:80px;max-width:1200px;margin:0 auto;display:grid}.about-image-col{align-items:center;height:100%;min-height:450px;display:flex;position:relative}.image-wrapper{z-index:2;border-radius:24px;width:100%;transition:transform .5s ease-out,box-shadow .5s ease-out;position:relative;box-shadow:0 20px 40px #234e8a26}.image-wrapper:before{content:"";background:linear-gradient(135deg, var(--primary-blue), var(--accent-blue));z-index:-1;opacity:.15;border-radius:24px;width:100%;height:100%;transition:all .5s ease-out;position:absolute;top:-15px;left:-15px}.hover-scale:hover{transform:translateY(-10px)scale(1.02);box-shadow:0 30px 50px #234e8a33}.hover-scale:hover:before{opacity:.25;top:-20px;left:-20px}.about-main-img{object-fit:cover;border-radius:24px;width:100%;height:100%;display:block}.floating-badge{background:var(--bg-surface);box-shadow:var(--shadow-md);z-index:10;border:1px solid var(--border-light);border-radius:16px;align-items:center;gap:12px;padding:1rem 1.5rem;animation:6s ease-in-out infinite floatNode;display:flex;position:absolute;bottom:-25px;right:-25px}@keyframes floatNode{0%{transform:translateY(0)rotate(0)}50%{transform:translateY(-10px)rotate(2deg)}to{transform:translateY(0)rotate(0)}}.floating-badge .badge-icon{font-size:2rem}.floating-badge .badge-text{color:var(--primary-blue);font-size:1.1rem;font-weight:700}.about-content-col h2{color:var(--primary-blue);margin-bottom:1.5rem;font-size:2.5rem;line-height:1.2}.content-badge{color:var(--primary-blue);letter-spacing:1px;background-color:#234e8a1a;border-radius:50px;margin-bottom:20px;padding:6px 14px;font-size:.8rem;font-weight:800;display:inline-block}.pulse-badge{background:linear-gradient(135deg,#234e8a1a,#2b65bd33);border:1px solid #2b65bd26;animation:2s infinite pulseBadge;box-shadow:0 0 #2b65bd66}@keyframes pulseBadge{0%{box-shadow:0 0 #2b65bd66}70%{box-shadow:0 0 0 10px #2b65bd00}to{box-shadow:0 0 #2b65bd00}}.highlight-text{color:var(--primary-blue);border-left:4px solid var(--accent-blue);margin-bottom:2rem;padding-left:20px;font-size:1.35rem;font-weight:600;line-height:1.5}.about-description{opacity:.85;font-size:1.1rem;line-height:1.8}.about-stats{border-top:1px solid var(--border-light);gap:20px;margin-top:3rem;padding-top:2.5rem;display:flex}.stat-item{background:var(--bg-surface);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);border-radius:16px;flex:1;align-items:center;gap:15px;padding:15px 20px;transition:all .3s;display:flex}.hover-lift-sm:hover{transform:translateY(-6px);box-shadow:0 12px 25px #234e8a14}.stat-icon{background:var(--bg-surface-alt);border-radius:12px;justify-content:center;align-items:center;width:55px;height:55px;font-size:2.2rem;display:flex}.stat-info{flex-direction:column;display:flex}.stat-info strong{color:var(--primary-blue);font-size:1.8rem;line-height:1.2}.stat-info span{color:var(--text-muted);font-size:.9rem;font-weight:600}@media (width<=900px){.about-modern{padding:60px 20px}.about-modern-container{grid-template-columns:1fr;gap:40px}.about-image-col,.user-image-placeholder{min-height:300px}}.destacados{background-color:var(--bg-surface);border-top:1px solid var(--border-light);border-bottom:1px solid var(--border-light);padding:5rem 2rem}.areas-header{text-align:center;margin-bottom:3rem}.areas-header h2{color:var(--primary-blue);font-size:2.5rem;font-weight:800}.divider{background-color:var(--accent-blue);border-radius:2px;width:80px;height:4px;margin:1rem auto}.animated-divider{width:0;animation:1s ease-out forwards expandWidth}@keyframes expandWidth{to{width:80px}}.destacados-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;max-width:1200px;margin:0 auto;display:grid}.destacado-card{background-color:var(--bg-main);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);z-index:1;border-radius:20px;flex-direction:column;justify-content:flex-start;align-items:flex-start;padding:2.5rem;transition:all .4s cubic-bezier(.175,.885,.32,1.275);display:flex;position:relative;overflow:hidden}.destacado-card:before{content:"";background:linear-gradient(90deg, var(--primary-blue), var(--accent-blue));z-index:-1;width:100%;height:6px;transition:all .4s;position:absolute;top:0;left:0}.destacado-card:hover{border-color:#234e8a1a;transform:translateY(-12px);box-shadow:0 20px 40px #234e8a1f}.destacado-card:hover:before{opacity:.02;height:100%}.card-icon-wrapper{background:linear-gradient(135deg,#234e8a0d,#2b65bd05);border-radius:16px;justify-content:center;align-items:center;width:60px;height:60px;margin-bottom:1.5rem;font-size:1.8rem;transition:transform .4s cubic-bezier(.175,.885,.32,1.275);display:flex}.destacado-card:hover .card-icon-wrapper{background:linear-gradient(135deg,#234e8a1a,#2b65bd0d);transform:scale(1.15)rotate(5deg)}.destacado-card h3{color:var(--primary-blue);margin-top:0;margin-bottom:1rem;font-size:1.6rem;transition:color .3s}.destacado-card:hover h3{color:var(--accent-blue)}.destacado-card p{color:var(--text-muted);margin-bottom:1.5rem;line-height:1.6}.destacado-card .card-btn{width:100%;transition:all .4s}.destacado-card:hover .card-btn{background-color:var(--primary-blue);color:#fff;box-shadow:0 8px 15px #234e8a33}.footer{background:var(--bg-surface);color:var(--text-main);border-top:1px solid var(--border-light);margin-top:4rem;padding:3rem 2rem}.footer-content{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;display:flex}.footer-text{opacity:.8;font-size:.95rem}.app-container{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1}.page-container{max-width:1200px;margin:0 auto;padding:4rem 2rem}.page-header h1{margin-bottom:1rem;font-size:3rem}.page-header p{opacity:.8;font-size:1.2rem}.recursos-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-top:2rem;display:grid}.recurso-card{background-color:var(--bg-surface);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);border-radius:16px;flex-direction:column;transition:all .3s cubic-bezier(.25,.8,.25,1);display:flex;overflow:hidden}.recurso-card:hover{transform:translateY(-8px);box-shadow:0 15px 30px #0000001a}.recurso-card-img{object-fit:cover;width:100%;height:200px}.recurso-card-content{flex-direction:column;flex:1;padding:2rem;display:flex}.recurso-card-content h3{margin-bottom:.5rem;font-size:1.3rem}.formacion-section{margin-top:4rem}.areas-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:2rem;display:grid}.area-color-card{background-color:var(--bg-main);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);cursor:pointer;border-radius:12px;align-items:center;gap:1.2rem;padding:1.5rem;transition:all .3s;display:flex}.area-color-card:hover{box-shadow:var(--shadow-md);transform:translate(5px)translateY(-2px)}.area-bullet{border-radius:6px;flex-shrink:0;width:24px;height:24px}.placeholder-box{background-color:var(--bg-surface-alt);border:2px dashed var(--accent-blue);text-align:center;color:var(--text-muted);border-radius:12px;flex-direction:column;align-items:center;gap:1rem;margin-top:1.5rem;padding:3rem;display:flex}.blog-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2.5rem;margin-top:3rem;display:grid}.blog-card{background-color:var(--bg-surface);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);border-radius:16px;transition:transform .3s,box-shadow .3s;overflow:hidden}.blog-card:hover{box-shadow:var(--shadow-md);transform:translateY(-8px)}.blog-img-placeholder{object-fit:cover;width:100%;height:220px;transition:transform .5s}.blog-card:hover .blog-img-placeholder{transform:scale(1.03)}.blog-content{padding:1.5rem 2rem}.blog-content h3{margin-bottom:.8rem;line-height:1.3}.equipo-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:2rem;display:grid}.miembro-card{background-color:var(--bg-surface);box-shadow:var(--shadow-sm);text-align:center;border:1px solid var(--border-light);border-radius:16px;padding:2rem;transition:transform .3s}.miembro-card:hover{box-shadow:var(--shadow-md);transform:translateY(-5px)}.foto-placeholder{background:var(--bg-surface-alt);border:4px solid var(--bg-surface);width:120px;height:120px;box-shadow:var(--shadow-sm);border-radius:50%;margin:0 auto 1.5rem;overflow:hidden}.foto-placeholder img{object-fit:cover;width:100%;height:100%}.aliados-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-top:2rem;display:grid}.aliado-card{background-color:var(--white);box-shadow:var(--shadow-sm);text-align:center;border:1px solid var(--border-light);border-radius:12px;padding:2rem;transition:all .3s}.aliado-card:hover{background-color:var(--bg-surface-alt);transform:scale(1.02)}.journey-section{background-color:var(--bg-main);padding:5rem 2rem}.journey-gallery{grid-template-columns:repeat(3,1fr);grid-auto-rows:250px;gap:20px;max-width:1200px;margin:3rem auto 0;display:grid}@media (width<=1100px){.journey-gallery{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.journey-gallery{grid-template-columns:1fr;grid-auto-rows:auto}.journey-item.large{grid-area:span 1/span 1}.journey-item{height:300px}}.journey-item{box-shadow:var(--shadow-sm);cursor:pointer;z-index:1;border:1px solid var(--border-light);border-radius:16px;transition:all .4s cubic-bezier(.175,.885,.32,1);position:relative;overflow:hidden}.journey-item.large{grid-area:span 2/span 2}.journey-item img{object-fit:cover;width:100%;height:100%;transition:transform .6s}.journey-item:hover{box-shadow:var(--shadow-md);z-index:2;border-color:var(--accent-blue);transform:translateY(-8px)}.journey-item:hover img{transform:scale(1.05)}.journey-overlay{color:#fff;opacity:.8;background:linear-gradient(#0000 0%,#0009 40%,#000000f2 100%);width:100%;padding:2.5rem 1.5rem 1.5rem;transition:all .4s;position:absolute;bottom:0;left:0;transform:translateY(20px)}.journey-item:hover .journey-overlay{opacity:1;transform:translateY(0)}.journey-overlay h4{color:var(--white);text-shadow:0 2px 4px #00000080;margin:0 0 .5rem;font-size:1.3rem;font-weight:700}.journey-overlay p{opacity:.9;text-shadow:0 1px 2px #00000080;margin:0;font-size:.95rem}@media (width<=900px){.nav-container{padding:0 20px}.mobile-toggle{display:flex}.nav-menu{-webkit-backdrop-filter:blur(15px);background-color:#ffffffe6;flex-direction:column;justify-content:flex-start;gap:32px;width:80%;max-width:300px;height:100vh;padding:80px 40px;transition:all .4s ease-in-out;position:fixed;top:0;right:-100%;box-shadow:-10px 0 30px #0000001a}.nav-menu.active{right:0}.nav-links{flex-direction:column;align-items:flex-start;width:100%}.nav-actions{flex-direction:column;width:100%}.hero-wrap{background:linear-gradient(to bottom, white 380px, var(--primary-blue) 380px);flex-direction:column}.hero-text-col{text-align:center;flex:none;order:2;align-items:center;width:100%;padding:50px 20px}.hero-text-content{flex-direction:column;align-items:center;margin:0 auto;display:flex}.floating-title-img{margin:0 auto 1.5rem!important}.hero-img-col{flex:none;order:1;width:100%;height:380px;min-height:380px}.hero-badge{padding:8px 14px;font-size:.8rem;transform:scale(.85)}.hero-badge:hover{transform:scale(.9)translateY(-2px)!important}.hero-badge .badge-icon{font-size:1.1rem}.badge-top-left{top:10%;left:15px}.badge-bottom-right{bottom:10%;right:0}.badge-middle-left{display:none}.hero-trust{text-align:center;flex-direction:column;justify-content:center;gap:12px}.hero-subtitle{text-align:center!important;margin-top:16px!important;font-size:1.1rem!important}.search-bar-container{box-shadow:var(--shadow-md);background:var(--bg-surface);border:1px solid var(--border-light);border-radius:20px;flex-direction:column;gap:16px;width:100%;max-width:100%;margin-top:32px;padding:20px}.search-input-wrapper{background:var(--bg-surface-alt);border:1px solid var(--border-light);border-radius:12px;width:100%;padding:10px 15px;box-shadow:inset 0 2px 4px #00000005}.search-bar-container button{border-radius:12px;width:100%;padding:14px 20px}.inicio-contacto-section{padding:4rem 1rem!important}.contacto-container{grid-template-columns:1fr!important;gap:2rem!important}.final-cta-section{padding:4rem 1rem!important}.final-cta-section h2{font-size:2rem!important}.about-stats{flex-direction:column;gap:15px}.stat-item{width:100%}}@media (width<=480px){.hero-img-col{height:300px;min-height:300px}.hero-wrap{background:linear-gradient(to bottom, var(--bg-surface) 300px, var(--primary-blue) 300px)}.hero-badge{display:none}.areas-header h2{font-size:1.8rem}}body,html,.landing-container{width:100%;overflow-x:hidden}.inicio-contacto-section{background:var(--bg-surface);border-top:1px solid var(--border-light);padding:6rem 2rem}.contacto-container{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));align-items:center;gap:4rem;max-width:1200px;margin:0 auto;display:grid}.final-cta-section{background:linear-gradient(135deg, var(--primary-blue), var(--secondary-blue));text-align:center;padding:8rem 2rem;position:relative;overflow:hidden}.cta-content{zIndex:2;max-width:800px;margin:0 auto;position:relative}.scroll-reveal{opacity:0;animation:1s ease-out forwards fadeInUp}.hover-lift{transition:transform .4s cubic-bezier(.175,.885,.32,1.275),box-shadow .4s}.hover-lift:hover{box-shadow:var(--shadow-md);transform:translateY(-8px)}.pulse-low{animation:3s infinite alternate pulseLowAnim}@keyframes pulseLowAnim{0%{filter:brightness();transform:scale(1)}to{filter:brightness(1.2);transform:scale(1.1)}}.course-horizontal-card{background:var(--bg-surface);border:1px solid var(--border-light);height:200px;box-shadow:var(--shadow-sm);border-radius:16px;margin-bottom:1.5rem;transition:all .4s cubic-bezier(.16,1,.3,1);display:flex;overflow:hidden}.course-horizontal-card:hover{border-color:var(--primary-blue);transform:translateY(-5px)scale(1.01);box-shadow:0 20px 40px #0000001a}.course-card-image-wrapper{flex:0 0 220px;position:relative;overflow:hidden}.course-card-image{object-fit:cover;width:100%;height:100%;transition:transform .6s cubic-bezier(.16,1,.3,1)}.course-horizontal-card:hover .course-card-image{transform:scale(1.1)}.course-card-content{flex-direction:column;flex:1;justify-content:space-between;min-width:0;padding:1.5rem;display:flex}.course-card-header{margin-bottom:.5rem}.school-tag{text-transform:uppercase;letter-spacing:.5px;border-radius:50px;align-items:center;gap:8px;margin-bottom:.75rem;padding:4px 12px;font-size:.75rem;font-weight:700;display:inline-flex}.school-dot{border-radius:50%;width:8px;height:8px}.course-card-title{color:var(--text-main);white-space:normal;margin:0;font-size:1.05rem;font-weight:700;line-height:1.3}.course-card-body{flex:1;margin-bottom:1rem}.course-card-description{color:var(--text-muted);-webkit-line-clamp:3;white-space:normal;-webkit-box-orient:vertical;margin:0;font-size:.8rem;line-height:1.5;display:-webkit-box}.course-card-footer{justify-content:flex-end;display:flex}.btn-sm{padding:.4rem 1rem;font-size:.85rem}[data-theme=dark] .course-horizontal-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1e293bb3;border:1px solid #ffffff0d}[data-theme=dark] .course-horizontal-card:hover{border-color:var(--primary-blue);background:#1e293be6;box-shadow:0 25px 50px -12px #00000080}@media (width<=768px){.course-horizontal-card{flex-direction:column;height:auto}.course-card-image-wrapper{flex:0 0 180px}.course-card-content{padding:1.2rem}}
