.navbar{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--glass-border);padding:16px 0;position:sticky;top:0;z-index:100;transition:var(--transition)}.navbar-brand{display:flex;align-items:center;gap:12px;font-size:1.2rem;font-weight:700;color:var(--text-primary);text-decoration:none;transition:var(--transition)}.navbar-brand:hover{transform:scale(1.02)}.navbar-logo{width:40px;height:40px;border-radius:8px;background:var(--primary-color);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.2rem;box-shadow:var(--shadow-light)}.navbar-brand-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.navbar-nav{display:flex;align-items:center;gap:24px;list-style:none;margin:0;padding:0}.navbar-link{color:var(--text-primary);text-decoration:none;font-weight:500;padding:8px 16px;border-radius:6px;transition:var(--transition);white-space:nowrap;display:flex;align-items:center;gap:8px}.navbar-link:hover,.navbar-link.active{background:#ffffff1a;color:var(--primary-color);transform:translateY(-1px)}.navbar-user{display:flex;align-items:center;gap:16px}.navbar-user-info{display:flex;align-items:center;gap:12px}.navbar-logout-icon{background:transparent;border:none;cursor:pointer;font-size:1.35rem;line-height:1;padding:6px;border-radius:8px;color:var(--text-primary);transition:var(--transition)}.navbar-logout-icon:hover{background:#ffffff1f;color:var(--danger-color);transform:translateY(-1px)}.navbar-user-mobile{display:flex;align-items:center;gap:12px}.navbar-user-name{font-weight:600;color:var(--text-primary);font-size:.9rem}.navbar-user-role{font-size:.8rem;color:var(--text-secondary);background:var(--glass-bg);padding:4px 8px;border-radius:4px;border:1px solid var(--glass-border)}.navbar-toggle{display:none;background:none;border:none;font-size:1.5rem;color:var(--text-primary);cursor:pointer;padding:8px;border-radius:6px;transition:var(--transition)}.navbar-toggle:hover{background:#ffffff1a}.navbar-mobile-menu{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;height:100dvh;background:#000000bf;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:99999;animation:fadeIn .3s ease-out;overflow:hidden}.navbar-mobile-content{position:fixed;top:0;right:0;width:280px;height:100vh;height:100dvh;background:#fff;border-left:3px solid var(--primary-color);box-shadow:-8px 0 30px #0000004d;padding:20px;overflow-y:auto;animation:slideInRight .3s ease-out;z-index:100000}@media (max-width: 480px){.navbar-mobile-content{width:85%;max-width:300px}}.navbar-mobile-section{margin-bottom:24px}.navbar-mobile-section h3{font-size:.9rem;font-weight:600;color:var(--text-secondary);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.navbar-mobile-link{display:flex;align-items:center;gap:12px;padding:12px 16px;color:var(--text-primary);text-decoration:none;border-radius:8px;transition:var(--transition);margin-bottom:4px}.navbar-mobile-link:hover,.navbar-mobile-link.active{background:#ffffff1a;color:var(--primary-color)}.navbar-mobile-icon{font-size:1.2rem;width:24px;text-align:center}.navbar-mobile-user{padding:16px;background:#ffffff0d;border-radius:8px;border:1px solid var(--glass-border)}.navbar-mobile-user-info h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:4px}.navbar-mobile-user-info p{font-size:.8rem;color:var(--text-secondary);margin-bottom:12px}@media (max-width: 480px){.navbar{position:static!important;z-index:auto!important}.navbar-content{padding:0 12px}.navbar-brand-text{font-size:1rem;max-width:120px}.navbar-logo{width:36px;height:36px;font-size:1rem}.navbar-user-name{font-size:.8rem;max-width:80px;overflow:hidden;text-overflow:ellipsis}.navbar-toggle{display:block;font-size:1.3rem}.navbar-mobile-content{width:100%;padding:16px}}@media (min-width: 481px) and (max-width: 768px){.navbar{position:static!important;z-index:auto!important}.navbar-nav{display:none}.navbar-toggle{display:block}.navbar-brand-text{font-size:1.1rem}.navbar-user-name{font-size:.85rem}}@media (min-width: 769px) and (max-width: 1024px){.navbar-nav{gap:16px}.navbar-link{padding:6px 12px;font-size:.9rem}.navbar-brand-text{font-size:1.1rem}.navbar-user-info{gap:8px}.navbar-user-name{font-size:.9rem}.navbar-user-role{font-size:.75rem;padding:3px 6px}}@media (min-width: 1025px) and (max-width: 1200px){.navbar-content{max-width:1000px}.navbar-nav{gap:20px}}@media (min-width: 1201px){.navbar-content{max-width:1200px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.navbar.scrolled{background:#ffffff26;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px)}.navbar-mobile-menu.closing{animation:fadeOut .3s ease-out forwards}.navbar-mobile-content.closing{animation:slideOutRight .3s ease-out forwards}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideOutRight{0%{transform:translate(0)}to{transform:translate(100%)}}.navbar-link:focus,.navbar-toggle:focus{outline:2px solid var(--primary-color);outline-offset:2px}.navbar-mobile-link:focus{outline:2px solid var(--primary-color);outline-offset:2px}@media (prefers-color-scheme: dark){.navbar{background:#0003;border-bottom-color:#ffffff1a}.navbar-mobile-content{background:#fff!important;border-left-color:var(--primary-color)!important}}.d-mobile-none,.d-tablet-none,.d-desktop-none{display:none}@media (min-width: 769px){.d-mobile-none{display:block}}@media (min-width: 1025px){.d-tablet-none{display:block}}@media (max-width: 1024px){.d-desktop-none{display:block}}.landing-page{width:100%}.landing-page .container{max-width:1200px;margin:0 auto;padding:0 20px}.hero-section{background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:#fff;padding:100px 0;text-align:center;position:relative;overflow:hidden}.hero-section:before,.hero-section:after{content:"";position:absolute;border-radius:50%;filter:blur(60px);opacity:.35;pointer-events:none}.hero-section:before{width:520px;height:520px;left:-160px;bottom:-140px;background:radial-gradient(closest-side,rgba(255,255,255,.35),transparent 70%)}.hero-section:after{width:480px;height:480px;right:-140px;top:-120px;background:radial-gradient(closest-side,rgba(255,255,255,.25),transparent 70%)}.hero-content{max-width:800px;margin:0 auto}.hero-icon{width:112px;height:112px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 6px 18px rgba(0,0,0,.25))}.hero-icon .bar{transform-origin:center bottom;animation:rise 1.2s ease-in-out forwards}.hero-icon .bar1{animation-delay:.05s}.hero-icon .bar2{animation-delay:.18s}.hero-icon .bar3{animation-delay:.32s}.hero-icon .dot{opacity:0;animation:pop .6s ease forwards}.hero-icon .dot1{animation-delay:.5s}.hero-icon .dot2{animation-delay:.7s}.hero-icon .dot3{animation-delay:.9s}@keyframes rise{0%{transform:scaleY(.2);opacity:.5}60%{transform:scaleY(1.1)}to{transform:scaleY(1);opacity:1}}@keyframes pop{0%{transform:translateY(6px) scale(.6);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.hero-title{font-size:3.5rem;font-weight:700;margin-bottom:20px;line-height:1.2}.hero-subtitle{font-size:1.25rem;margin-bottom:40px;line-height:1.6;opacity:.95}.hero-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.hero-section .btn-primary{background-image:linear-gradient(135deg,var(--primary-color),var(--secondary-color));box-shadow:0 8px 20px #0000001f;border:none}.hero-section .btn-primary:hover{filter:brightness(1.03);box-shadow:var(--shadow-lg)}.btn-large{padding:16px 32px;font-size:1.1rem}.features-section{padding:80px 0;background:var(--light-color)}.section-title{text-align:center;font-size:2.5rem;font-weight:700;color:var(--text-primary);margin-bottom:60px}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:32px}.feature-card{background:#fff;padding:40px;border-radius:var(--border-radius);box-shadow:var(--shadow);text-align:center;transition:var(--transition)}.feature-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}.feature-icon{font-size:3.5rem;margin-bottom:20px}.feature-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:12px}.feature-description{font-size:1rem;color:var(--text-secondary);line-height:1.6}.stats-section{padding:80px 0;background:#fff}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:32px}.stat-box{text-align:center;padding:40px 20px;border-radius:var(--border-radius);background:#fff;border:1px solid var(--border-color);color:var(--text-primary);box-shadow:var(--shadow);transition:var(--transition)}.stat-box:hover{border-color:var(--secondary-color);transform:translateY(-5px);box-shadow:var(--shadow-lg)}.stats-grid .stat-box:nth-child(1){background:#dbeafe;border-color:#bfdbfe}.stats-grid .stat-box:nth-child(1) .stat-number{color:#1e40af}.stats-grid .stat-box:nth-child(1) .stat-label{color:#1e3a8a}.stats-grid .stat-box:nth-child(2){background:#dcfce7;border-color:#bbf7d0}.stats-grid .stat-box:nth-child(2) .stat-number{color:#047857}.stats-grid .stat-box:nth-child(2) .stat-label{color:#065f46}.stats-grid .stat-box:nth-child(3){background:#fef3c7;border-color:#fde68a}.stats-grid .stat-box:nth-child(3) .stat-number{color:#92400e}.stats-grid .stat-box:nth-child(3) .stat-label{color:#b45309}.stats-grid .stat-box:nth-child(4){background:#e0e7ff;border-color:#c7d2fe}.stats-grid .stat-box:nth-child(4) .stat-number{color:#3730a3}.stats-grid .stat-box:nth-child(4) .stat-label{color:#4338ca}.stat-number{font-size:3rem;font-weight:700;margin-bottom:12px;color:var(--primary-color)}.stat-label{font-size:1.1rem;color:var(--text-secondary)}.cta-section{padding:80px 0;background:var(--light-color)}.cta-card{background:#fff;padding:60px 40px;border-radius:var(--border-radius);box-shadow:var(--shadow-lg);text-align:center}.cta-title{font-size:2.5rem;font-weight:700;color:var(--text-primary);margin-bottom:20px}.cta-description{font-size:1.25rem;color:var(--text-secondary);margin-bottom:40px;line-height:1.6}.landing-footer{background:var(--dark-color);color:#fff;padding:60px 0 40px}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:40px}.footer-brand h3{font-size:1.5rem;margin-bottom:12px}.footer-brand p{opacity:.8}.footer-links h4,.footer-info h4{font-size:1.2rem;margin-bottom:16px}.footer-links ul{list-style:none}.footer-links li{margin-bottom:8px}@media (max-width: 768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.1rem}.section-title{font-size:2rem}.features-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.hero-section{padding:60px 0}.hero-title{font-size:2rem}.features-section,.stats-section,.cta-section{padding:60px 0}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);position:relative;overflow:hidden}.login-page:before,.login-page:after{content:"";position:absolute;border-radius:50%;filter:blur(60px);opacity:.35;pointer-events:none}.login-page:before{width:520px;height:520px;left:-160px;bottom:-140px;background:radial-gradient(closest-side,rgba(255,255,255,.35),transparent 70%)}.login-page:after{width:480px;height:480px;right:-140px;top:-120px;background:radial-gradient(closest-side,rgba(255,255,255,.25),transparent 70%)}.login-container{width:100%;max-width:500px;background:#fff;border:1px solid #eef2ff;border-radius:16px;box-shadow:0 24px 48px #00000024;padding:24px 36px;position:relative;z-index:1;animation:slideInUp .6s ease-out}.login-header{text-align:center;margin-bottom:24px}.login-logo{width:96px;height:96px;background:var(--primary-color);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3rem;margin:0 auto 20px;box-shadow:var(--shadow);animation:none}.login-title{font-size:2.25rem;font-weight:800;color:var(--primary-color);margin-bottom:8px;line-height:1.2}.login-subtitle{color:#6b7280;font-size:.95rem;margin:0}.login-form-container{margin-bottom:32px}.login-form{margin-bottom:24px}.form-label{display:block;margin-bottom:8px;font-weight:600;color:#374151;font-size:.9rem}.form-input{width:100%;padding:14px 16px;border:1px solid #e5e7eb;border-radius:10px;background:#eef2ff;color:var(--text-primary);font-size:.95rem;transition:var(--transition);min-height:48px}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a;background:#fff}.form-input::placeholder{color:#9aa3b2}.form-input:disabled{opacity:.6;cursor:not-allowed}.btn-login{width:100%;padding:14px 24px;font-size:1rem;font-weight:600;min-height:48px;display:flex;align-items:center;justify-content:center;gap:8px;transition:var(--transition);background-image:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border:none;border-radius:10px}.btn-login:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg);filter:brightness(1.03)}.back-link{text-align:center;margin-top:32px}.back-link a{color:var(--primary-color);text-decoration:none;font-weight:600}.back-link a:hover{text-decoration:underline}.btn-login.loading{opacity:.8;cursor:not-allowed}.loading-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}.login-info{background:var(--light-color);border:1px solid var(--border-color);border-radius:8px;padding:20px;text-align:center}.login-info h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:16px;display:flex;align-items:center;justify-content:center;gap:8px}.login-credentials{display:flex;flex-direction:column;gap:8px}.credential-item{font-size:.85rem;color:var(--text-secondary);display:flex;justify-content:space-between;align-items:center;padding:4px 0}.credential-item strong{color:var(--text-primary);font-weight:600}.login-footer{text-align:center;padding-top:20px;border-top:1px solid var(--border-color)}.login-footer p{font-size:.8rem;color:var(--text-light);margin:4px 0}@media (max-width: 480px){.login-page{padding:16px}.login-container{padding:24px;max-width:100%}.login-logo{width:60px;height:60px;font-size:2rem}.login-title{font-size:1.5rem}.login-subtitle{font-size:.9rem}.form-input{padding:12px 14px;font-size:.9rem}.btn-login{padding:12px 20px;font-size:.95rem}.login-info{padding:16px}.login-info h3{font-size:.9rem}.credential-item{font-size:.8rem;flex-direction:column;gap:2px;text-align:center}}@media (min-width: 481px) and (max-width: 768px){.login-container{padding:24px 28px}.login-logo{width:70px;height:70px;font-size:2.2rem}.login-title{font-size:1.6rem}}@media (min-width: 769px) and (max-width: 1024px){.login-container{padding:28px 36px;max-width:440px}.login-logo{width:80px;height:80px;font-size:2.5rem}.login-title{font-size:2rem}}@media (min-width: 1025px){.login-container{padding:30px 44px;max-width:480px}}.login-container:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.form-input.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-input.success{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.form-input:focus,.btn-login:focus{outline:2px solid var(--primary-color);outline-offset:2px}@media (prefers-color-scheme: dark){.login-container{background:#fff;border-color:#eef2ff}.login-title{color:var(--primary-color)}.login-subtitle{color:#6b7280}.login-info{background:#0003;border-color:#ffffff1a}}.dashboard{min-height:100vh;padding:20px 0}.dashboard-loading{display:flex;align-items:center;justify-content:center;min-height:100vh}.loading-container{text-align:center;color:var(--text-primary)}.loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:var(--primary-color);animation:spin 1s ease-in-out infinite;margin:0 auto 16px}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;padding:24px;background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:var(--border-radius)}.dashboard-title h1{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.dashboard-title p{color:var(--text-secondary);font-size:1rem}.año-selector{margin-top:16px;display:flex;align-items:center;gap:12px}.año-selector label{font-weight:600;color:var(--text-primary);font-size:.95rem}.select-año{padding:10px 36px 10px 12px;border:1px solid var(--border-color);border-radius:6px;background:#fff;color:var(--text-primary);font-size:.95rem;font-weight:600;cursor:pointer;transition:var(--transition);appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--text-secondary) 50%),linear-gradient(135deg,var(--text-secondary) 50%,transparent 50%);background-position:calc(100% - 18px) calc(50% - 3px),calc(100% - 12px) calc(50% - 3px);background-size:6px 6px,6px 6px;background-repeat:no-repeat}.select-año:hover{border-color:var(--primary-color)}.select-año:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.dashboard-time{text-align:right}.current-time{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:8px;padding:16px;min-width:200px}.time-display{font-size:1.8rem;font-weight:700;color:var(--primary-color);font-family:Courier New,monospace;margin-bottom:4px}.date-display{font-size:.9rem;color:var(--text-secondary);text-transform:capitalize}.stats-grid{display:grid;gap:20px;margin-bottom:32px}.stats-grid.grid-1{grid-template-columns:1fr}.stats-grid.grid-2{grid-template-columns:repeat(2,1fr)}.stats-grid.grid-4{grid-template-columns:repeat(4,1fr)}.stat-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:var(--border-radius);padding:24px;text-align:center;transition:var(--transition);cursor:pointer;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s}.stat-card:hover:before{left:100%}.stat-icon{font-size:3rem;margin-bottom:16px;display:block;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.stat-content{position:relative;z-index:1}.stat-number{font-size:2.2rem;font-weight:700;color:var(--primary-color);margin-bottom:8px;line-height:1.2}.stat-label{font-size:.95rem;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.charts-grid{display:grid;gap:24px;margin-bottom:32px}.charts-grid.grid-1{grid-template-columns:1fr}.charts-grid.grid-2{grid-template-columns:repeat(2,1fr)}.chart-container{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:var(--border-radius);padding:24px;transition:var(--transition)}.chart-container:hover{transform:translateY(-2px);box-shadow:var(--shadow-medium)}.chart-title{font-size:1.2rem;font-weight:600;color:var(--text-primary);margin-bottom:20px;text-align:center}.chart-wrapper{height:300px;position:relative}.grados-section{margin-bottom:32px}.grados-section h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:24px;display:flex;align-items:center;gap:12px;position:relative}.grados-section h2:after{content:"";position:absolute;left:0;bottom:-8px;width:120px;height:4px;border-radius:999px;background:linear-gradient(90deg,#4f46e5,#7c3aed,#06b6d4,#22c55e)}.ranking-section{margin:28px 0}.ranking-section h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:8px;margin-bottom:16px}.ranking-grid{display:grid;gap:16px;grid-template-columns:1fr}.ranking-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--border-radius);box-shadow:var(--shadow);overflow-x:auto;-webkit-overflow-scrolling:touch}.ranking-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 16px;border-bottom:1px solid var(--glass-border)}.ranking-header h3{margin:0;font-size:1rem;font-weight:700;color:var(--text-primary)}.ranking-actions{display:flex;gap:8px;align-items:center;flex-wrap:nowrap}.meses-section{margin:28px 0}.meses-section h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:8px;margin-bottom:8px}.meses-actions{display:flex;justify-content:flex-end;gap:8px;margin-bottom:8px}.grados-grid{display:grid;gap:20px}.grados-grid.grid-1{grid-template-columns:1fr}.grados-grid.grid-2{grid-template-columns:repeat(2,1fr)}.grados-grid.grid-3{grid-template-columns:repeat(3,1fr)}.grado-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:var(--border-radius);padding:20px;transition:var(--transition);position:relative;overflow:hidden}.grado-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-medium)}.grado-card:before{content:"";position:absolute;left:0;top:0;right:0;height:4px;background:linear-gradient(90deg,#4f46e5,#7c3aed,#06b6d4,#22c55e)}.grado-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.grado-header h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.grado-nivel{font-size:.8rem;color:var(--text-secondary);background:#ffffff1a;padding:4px 8px;border-radius:4px;border:1px solid var(--glass-border)}.grado-stats{margin-bottom:16px}.grado-stat{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.9rem}.grado-stat-label{color:var(--text-secondary);font-weight:500}.grado-stat-value{color:var(--text-primary);font-weight:600}.grado-progress{margin-top:16px}.progress-bar{width:100%;height:8px;background:#fff3;border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,#10b981,#059669);border-radius:4px;transition:width .5s ease}.progress-text{font-size:.8rem;color:var(--text-secondary);text-align:center;display:block}.meses-section{margin-bottom:32px}.meses-section h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:24px;display:flex;align-items:center;gap:12px}.ranking-card{background:#fff;border:1px solid var(--border-color);border-radius:var(--border-radius);padding:20px;box-shadow:var(--shadow)}.ranking-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px}.ranking-actions{display:flex;gap:8px}.export-btn{padding:8px 16px;background-color:var(--primary-color);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:var(--transition)}.export-btn:hover:not(:disabled){background-color:var(--secondary-color)}.export-btn:disabled{opacity:.5;cursor:not-allowed}.ranking-section{margin-bottom:32px}.ranking-section h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:24px;display:flex;align-items:center;gap:12px}.ranking-grid{display:grid;grid-template-columns:1fr;gap:24px}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.modal{background:#fff;border-radius:var(--border-radius);box-shadow:var(--shadow-heavy);max-width:900px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0;font-size:1.2rem;color:var(--text-primary)}.close-btn{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:4px 8px;border-radius:4px;transition:var(--transition)}.close-btn:hover{background:var(--light-color);color:var(--text-primary)}.modal-actions{padding:16px 24px;display:flex;border-bottom:1px solid var(--border-color)}.modal-body{padding:20px 24px;overflow-y:auto;flex:1}.modal-footer{padding:16px 24px;border-top:1px solid var(--border-color);display:flex;gap:24px;justify-content:center;background:var(--light-color)}.footer-item{font-size:.9rem;color:var(--text-secondary)}.footer-item strong{color:var(--text-primary);font-weight:600}.filter-select{padding:6px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:.9rem;background:#fff;cursor:pointer}.table-wrapper{overflow-x:auto}.archivos-section{margin-bottom:32px}.archivos-section h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:24px;display:flex;align-items:center;gap:12px;position:relative}.archivos-section h2:after{content:"";position:absolute;left:0;bottom:-8px;width:160px;height:4px;border-radius:999px;background:linear-gradient(90deg,#4f46e5,#7c3aed,#06b6d4,#22c55e)}.archivos-list{display:flex;flex-direction:column;gap:12px}.archivo-item{display:flex;align-items:center;gap:16px;padding:16px;background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:var(--border-radius);transition:var(--transition)}.archivo-item:hover{transform:translate(4px);box-shadow:var(--shadow-light)}.archivo-icon{font-size:2rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border-radius:8px;border:1px solid var(--glass-border)}.archivo-info{flex:1}.archivo-nombre{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:4px}.archivo-meta{display:flex;gap:16px;font-size:.8rem;color:var(--text-secondary)}.archivo-tipo{background:var(--primary-color);color:#fff;padding:2px 6px;border-radius:4px;font-weight:600}.archivo-status{font-size:.8rem;font-weight:600}.status-success{color:#10b981}.status-error{color:#ef4444}@media (max-width: 480px){.dashboard{padding:16px 0}.dashboard-header{flex-direction:column;gap:16px;text-align:center;padding:20px}.dashboard-title h1{font-size:1.5rem}.dashboard-title p{font-size:.9rem}.current-time{min-width:auto;padding:12px}.time-display{font-size:1.4rem}.date-display{font-size:.8rem}.stat-card{padding:20px}.stat-icon{font-size:2.5rem}.stat-number{font-size:1.8rem}.stat-label{font-size:.85rem}.chart-container{padding:20px}.chart-wrapper{height:250px}.grado-card{padding:16px}.archivo-item{padding:12px;gap:12px}.archivo-icon{font-size:1.5rem;width:40px;height:40px}.archivo-meta{flex-direction:column;gap:4px}}@media (min-width: 481px) and (max-width: 768px){.dashboard-header{flex-direction:column;gap:20px;text-align:center}.dashboard-title h1{font-size:1.8rem}.stat-card{padding:22px}.stat-icon{font-size:2.8rem}.stat-number{font-size:2rem}.chart-wrapper{height:280px}}@media (min-width: 769px) and (max-width: 1024px){.dashboard-header{padding:20px}.dashboard-title h1{font-size:1.9rem}.stat-card{padding:22px}.stat-icon{font-size:2.8rem}.stat-number{font-size:2rem}.chart-wrapper{height:300px}}@media (min-width: 1025px) and (max-width: 1200px){.chart-wrapper{height:320px}}@media (min-width: 1201px){.chart-wrapper{height:350px}}.dashboard{animation:fadeIn .5s ease-out}.stat-card{animation:slideInUp .5s ease-out}.stat-card:nth-child(1){animation-delay:.1s}.stat-card:nth-child(2){animation-delay:.2s}.stat-card:nth-child(3){animation-delay:.3s}.stat-card:nth-child(4){animation-delay:.4s}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.stat-card.loading,.chart-container.loading{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s infinite}.d-mobile-none,.d-tablet-none{display:block}.d-desktop-none{display:none}@media (max-width: 768px){.d-mobile-none{display:none}}@media (min-width: 769px) and (max-width: 1024px){.d-tablet-none{display:none}}@media (min-width: 1025px){.d-desktop-none{display:block}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:9999}.modal{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--border-radius);box-shadow:var(--shadow-heavy);width:95vw!important;max-width:1200px!important;min-width:900px;max-height:80vh;display:flex;flex-direction:column;overflow:auto;box-sizing:border-box;z-index:10000}.modal-header{position:sticky;top:0;z-index:2;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--glass-border);background:var(--background, #ffffff);background-color:#fff}.close-btn{background:transparent;border:1px solid var(--glass-border);border-radius:6px;padding:4px 8px;cursor:pointer}.modal-actions{position:sticky;top:48px;z-index:1;display:flex;justify-content:flex-end;gap:8px;padding:8px 16px;border-bottom:1px solid var(--glass-border);background:var(--background, #ffffff);background-color:#fff}.export-btn{background-image:linear-gradient(135deg,#4f46e5,#7c3aed,#06b6d4);color:#fff;border:none;border-radius:8px;padding:8px 14px;cursor:pointer;box-shadow:0 6px 14px #6366f133}.export-btn:disabled{opacity:.6;cursor:not-allowed}.modal-body{padding:12px 16px 16px}.filter-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding:8px 32px 8px 10px;border:1px solid var(--glass-border);border-radius:8px;background:#fff;color:var(--text-primary);font-weight:600;box-shadow:var(--shadow-light);background-image:linear-gradient(45deg,transparent 50%,#666 50%),linear-gradient(135deg,#666 50%,transparent 50%),linear-gradient(to right,transparent,transparent);background-position:calc(100% - 18px) calc(50% - 3px),calc(100% - 12px) calc(50% - 3px),calc(100% - 2.5em) .5em;background-size:6px 6px,6px 6px,1px 1.5em;background-repeat:no-repeat}.filter-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #1976d226}.table-wrapper{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.table{width:100%;border-collapse:collapse;table-layout:auto;min-width:500px}.table th,.table td{padding:12px 14px;border-bottom:1px solid var(--glass-border)}.table thead tr{background:#1976d21f}.table th{text-align:left;color:var(--text-primary);font-weight:700}.table tbody tr:nth-child(2n){background:#ffffff0a}.clickable-row{transition:background-color .2s ease,transform .1s ease}.clickable-row:hover{background-color:#f0f9ff!important;transform:translate(2px)}.clickable-row:active{transform:translate(0)}.modal-footer{position:sticky;bottom:0;z-index:1;display:flex;gap:16px;justify-content:flex-end;padding:10px 16px;border-top:1px solid var(--glass-border);background:var(--background, #ffffff)}.modal-footer .footer-item{font-size:.9rem;color:var(--text-primary)}@media (max-width: 768px){.modal{min-width:auto!important;width:95vw!important;max-width:95vw!important;max-height:85vh!important;margin:10px}.modal-header{padding:12px 16px}.modal-header h3{font-size:1rem;line-height:1.3}.modal-body{padding:8px!important}.modal-body .chart-wrapper{margin:0!important;padding:0!important;width:100%!important}.modal-body .chart-container{padding:8px 4px!important;margin:0!important}.modal-footer{flex-wrap:wrap;gap:8px;padding:12px;font-size:.8rem}.footer-item{font-size:.75rem;flex:1 1 45%;min-width:45%}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%}.table{min-width:600px;font-size:.85rem}.table th,.table td{padding:8px 10px;white-space:nowrap}.chart-wrapper{height:280px!important;width:100%!important;padding:0!important;margin:0!important}.chart-container{padding:12px 8px}.export-btn{padding:6px 12px;font-size:.8rem}.ranking-actions,.modal-actions{flex-wrap:wrap;gap:6px;justify-content:center!important}.ranking-header{flex-direction:column;align-items:flex-start!important;gap:8px}.ranking-header h3{width:100%;text-align:center}.navbar-mobile-section h3{font-size:.85rem;margin-bottom:8px}.navbar-mobile-link{padding:10px 14px;font-size:.9rem}.meses-section h2,.ranking-section h2,.grados-section h2{font-size:1.2rem}.modal-body>div{padding:0!important}.modal-body .table thead{position:sticky!important;top:0!important;z-index:10!important;background:#1976d226!important}.modal-body .table thead th{background:#1976d226!important}}@media (max-width: 480px){.modal{max-height:90vh!important}.modal-header h3{font-size:.9rem}.table{font-size:.75rem;min-width:500px}.table th,.table td{padding:6px 8px}.chart-wrapper{height:220px!important}.export-btn{padding:5px 10px;font-size:.75rem}.chart-container{padding:8px 4px}.chart-wrapper{height:240px!important}.ranking-actions,.modal-actions{width:100%;justify-content:center!important}.modal[style*="maxWidth:'1000px'"] .chart-wrapper,.modal[style*="max-width:1000px"] .chart-wrapper{height:320px!important;padding:0 4px!important}}.admin-page{padding:20px;max-width:1200px;margin:0 auto}.page-header{margin-bottom:24px}.page-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:8px;display:flex;align-items:center;gap:12px}.page-subtitle{color:var(--text-secondary);font-size:1rem}.page-actions{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.table-container{background:#fff;border-radius:var(--border-radius);border:1px solid var(--border-color);overflow:hidden;box-shadow:var(--shadow);margin-bottom:24px}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.responsive-table{width:100%;border-collapse:collapse;min-width:600px}.responsive-table th,.responsive-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-color)}.responsive-table thead{background:#1976d214}.responsive-table th{font-weight:600;color:var(--text-primary);white-space:nowrap}.responsive-table tbody tr:hover{background:#1976d20a}.form-grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.form-group{margin-bottom:16px}.form-label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:8px;font-size:.9rem}.form-input,.form-select,.form-textarea{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:.95rem;transition:var(--transition)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #1976d21a}.color-picker-group{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.color-swatch{width:60px;height:60px;border-radius:8px;border:2px solid var(--border-color);cursor:pointer;transition:var(--transition)}.color-swatch:hover{transform:scale(1.05);box-shadow:var(--shadow-medium)}.search-bar{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.search-input{flex:1;min-width:200px;padding:10px 16px;border:1px solid var(--border-color);border-radius:6px;font-size:.95rem}.upload-section{background:#fff;padding:24px;border-radius:var(--border-radius);border:1px solid var(--border-color);margin-bottom:24px}.upload-group{margin-bottom:20px}.file-input-wrapper{display:flex;gap:12px;flex-wrap:wrap;align-items:center}@media (max-width: 768px){.admin-page{padding:12px}.page-title{font-size:1.5rem}.page-subtitle{font-size:.9rem}.page-actions{flex-direction:column;align-items:stretch;gap:8px}.page-actions>div,.page-actions .año-selector{width:100%;flex-direction:column;gap:8px!important}.page-actions button,.page-actions .btn{width:100%;justify-content:center}.page-actions select{width:100%}.table-container{margin:0 -12px 20px;border-radius:0;border-left:none;border-right:none}.responsive-table{font-size:.85rem;min-width:700px}.responsive-table th,.responsive-table td{padding:10px 12px}.form-grid{grid-template-columns:1fr}.form-input,.form-select,.form-textarea{font-size:16px}.search-bar{flex-direction:column}.search-input{width:100%;min-width:auto}.upload-section{padding:16px;margin:0 -12px 20px;border-radius:0;border-left:none;border-right:none;display:flex!important;flex-direction:column!important;grid-template-columns:1fr!important}.upload-section>div{flex-direction:column;align-items:stretch!important;gap:8px!important}.upload-section button{width:100%;margin-top:8px}.file-input-wrapper{flex-direction:column;align-items:stretch}.file-input-wrapper button{width:100%}.color-swatch{width:50px;height:50px}}@media (max-width: 480px){.admin-page{padding:8px}.page-title{font-size:1.3rem;flex-direction:column;align-items:flex-start;gap:8px}.responsive-table{font-size:.75rem;min-width:600px}.responsive-table th,.responsive-table td{padding:8px 10px}.upload-section{padding:12px}.color-swatch{width:45px;height:45px}}:root{--primary-color: #1976d2;--secondary-color: #764ba2;--success-color: #10b981;--danger-color: #ef4444;--warning-color: #f59e0b;--info-color: #3b82f6;--light-color: #f3f4f6;--dark-color: #1f2937;--text-color: #374151;--border-color: #e5e7eb;--background-gradient: linear-gradient(135deg, #f3f4f6 0%, #e5e7eb 100%);--glass-bg: rgba(255, 255, 255, .9);--glass-border: rgba(229, 231, 235, .8);--text-primary: #1f2937;--text-secondary: #6b7280;--text-light: #9ca3af;--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-light: 0 4px 6px rgba(0, 0, 0, .1);--shadow-medium: 0 8px 25px rgba(0, 0, 0, .15);--shadow-heavy: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--border-radius: 8px;--transition: all .3s ease}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,sans-serif;background:var(--light-color);min-height:100vh;color:var(--text-color);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.container{max-width:1200px;margin:0 auto;padding:0 16px}.grid{display:grid;gap:20px}.grid-1{grid-template-columns:1fr}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.glass-card{background:#fff;border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow);padding:24px;transition:var(--transition)}.glass-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-heavy)}.stat-card{background:#fff;border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow);padding:20px;text-align:center;transition:var(--transition);cursor:pointer}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-heavy)}.stat-icon{font-size:2.5rem;margin-bottom:12px;display:block}.stat-number{font-size:2rem;font-weight:700;color:var(--primary-color);margin-bottom:8px}.stat-label{font-size:.9rem;color:var(--text-secondary);font-weight:500}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:none;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:var(--transition);text-decoration:none;gap:8px;min-height:44px}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--secondary-color)}.btn-secondary{background-color:var(--light-color);color:var(--text-color);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background-color:#e5e7eb}.btn-success{background-color:var(--success-color);color:#fff}.btn-danger{background-color:var(--danger-color);color:#fff}.btn-warning{background-color:var(--warning-color);color:#fff}.form-group{margin-bottom:20px}.form-label{display:block;margin-bottom:8px;font-weight:600;color:var(--text-primary)}.form-input{width:100%;padding:12px 16px;border:1px solid var(--glass-border);border-radius:8px;background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-primary);font-size:.9rem;transition:var(--transition);min-height:44px}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #1976d21a}.form-select{width:100%;padding:12px 16px;border:1px solid var(--glass-border);border-radius:8px;background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-primary);font-size:.9rem;cursor:pointer;min-height:44px}.table-container{overflow-x:auto;border-radius:var(--border-radius);background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border)}.table{width:100%;border-collapse:collapse;min-width:600px}.table th,.table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--glass-border)}.table th{background:#ffffff1a;font-weight:600;color:var(--text-primary);position:sticky;top:0}.table tbody tr:hover{background:#ffffff0d}.navbar{background:#fff;box-shadow:var(--shadow);border-bottom:1px solid var(--border-color);padding:16px 0;position:sticky;top:0;z-index:1000}.navbar-content{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:0 16px}.navbar-brand{display:flex;align-items:center;gap:12px;font-size:1.2rem;font-weight:700;color:var(--text-primary);text-decoration:none}.navbar-logo{width:40px;height:40px;border-radius:8px;background:var(--primary-color);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}.navbar-nav{display:flex;align-items:center;gap:24px;list-style:none}.navbar-link{color:var(--text-primary);text-decoration:none;font-weight:500;padding:8px 16px;border-radius:6px;transition:var(--transition)}.navbar-link:hover,.navbar-link.active{background:#ffffff1a;color:var(--primary-color)}.navbar-toggle{display:none;background:none;border:none;font-size:1.5rem;color:var(--text-primary);cursor:pointer;padding:8px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:16px}.modal{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:var(--border-radius);box-shadow:var(--shadow-heavy);max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--glass-border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:1.2rem;font-weight:700;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:4px}.modal-body{padding:24px}.modal-footer{padding:16px 24px 20px;border-top:1px solid var(--glass-border);display:flex;gap:12px;justify-content:flex-end}.chart-container{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:var(--border-radius);padding:20px;margin-bottom:20px}.chart-title{font-size:1.1rem;font-weight:600;margin-bottom:16px;color:var(--text-primary);text-align:center}.upload-area{border:2px dashed var(--glass-border);border-radius:var(--border-radius);padding:40px 20px;text-align:center;background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:var(--transition);cursor:pointer}.upload-area:hover,.upload-area.dragover{border-color:var(--primary-color);background:#1976d21a}.upload-icon{font-size:3rem;color:var(--primary-color);margin-bottom:16px}.upload-text{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:8px}.upload-subtext{color:var(--text-secondary);font-size:.9rem}@media (max-width: 480px){.container{padding:0 12px}.glass-card,.stat-card{padding:16px}.stat-icon{font-size:2rem}.stat-number{font-size:1.5rem}.btn{padding:10px 16px;font-size:.85rem}.navbar-nav{display:none}.navbar-toggle{display:block}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.modal{margin:16px;max-width:none}.table-container{font-size:.8rem}.table th,.table td{padding:8px 12px}}@media (min-width: 481px) and (max-width: 768px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}.navbar-nav{gap:16px}.navbar-link{padding:6px 12px;font-size:.9rem}}@media (min-width: 769px) and (max-width: 1024px){.grid-4{grid-template-columns:repeat(3,1fr)}.navbar-nav{gap:20px}.stat-card{padding:18px}}@media (min-width: 1025px) and (max-width: 1200px){.container{max-width:1000px}}@media (min-width: 1201px){.container{max-width:1200px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.fade-in{animation:fadeIn .5s ease-out}.slide-in{animation:slideIn .5s ease-out}.pulse{animation:pulse 2s infinite}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.p-1{padding:8px}.p-2{padding:16px}.p-3{padding:24px}.p-4{padding:32px}.d-none{display:none}.d-block{display:block}.d-flex{display:flex}.d-grid{display:grid}.w-100{width:100%}.h-100{height:100%}@media (max-width: 768px){.d-mobile-none{display:none}.d-mobile-block{display:block}.d-mobile-flex{display:flex}}@media (min-width: 769px){.d-tablet-none{display:none}.d-tablet-block{display:block}.d-tablet-flex{display:flex}}@media (min-width: 1025px){.d-desktop-none{display:none}.d-desktop-block{display:block}.d-desktop-flex{display:flex}}.loading{display:inline-block;width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:var(--primary-color);animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s infinite}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb{background:var(--primary-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--secondary-color)}
