*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#0a0e27,#1a1f3a 50%,#0f1419);color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-blue:#2563eb;--dark-blue:#0f1419;--medium-blue:#3b82f6;--purple:#7c3aed;--black:#0a0e27;--white:#fff;--gray:#d1d5db;--light-gray:#f3f4f6;--error:#ef4444;--success:#10b981;--warning:#f59e0b;--text-secondary:#9ca3af;--card-bg:#1a1f3a66;--card-border:#3b82f61a}svg{display:inline-block;vertical-align:middle}.device-blocker{align-items:center;background:linear-gradient(135deg,#0a0e27,#1a1f3a 50%,#0f1419);display:flex;flex-direction:column;justify-content:space-between;min-height:100vh;overflow:hidden;padding:40px 20px;position:relative}.device-blocker:before{animation:rotate 30s linear infinite;background:radial-gradient(circle,#3b82f61a 0,#0000 70%);content:"";height:200%;left:-50%;position:absolute;top:-50%;width:200%}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.blocker-content{animation:fadeInUp .8s ease-out;max-width:700px;text-align:center;z-index:1}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.blocker-icon-group{display:flex;gap:40px;justify-content:center;margin-bottom:40px}.device-icon{align-items:center;display:flex;flex-direction:column;gap:10px;position:relative}.device-icon svg{font-size:60px;transition:all .3s ease}.device-icon.allowed svg{color:var(--success);filter:drop-shadow(0 0 10px rgba(16,185,129,.5))}.device-icon.blocked svg{color:var(--error);opacity:.5}.device-icon.blocked{position:relative}.block-icon{animation:pulse 2s infinite;color:var(--error)!important;filter:drop-shadow(0 0 10px rgba(239,68,68,.8))!important;font-size:40px!important;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}@keyframes pulse{0%,to{opacity:1;transform:translate(-50%,-50%) scale(1)}50%{opacity:.7;transform:translate(-50%,-50%) scale(1.1)}}.device-icon span{color:var(--white);font-size:14px;font-weight:600;letter-spacing:1px;text-transform:uppercase}.blocker-logo{filter:drop-shadow(0 4px 20px rgba(59,130,246,.3));height:auto;margin-bottom:30px;width:250px}.device-blocker h1{color:var(--white);font-size:36px;font-weight:700;margin-bottom:20px;text-shadow:0 2px 10px #00000080}.blocker-message{color:var(--gray);font-size:18px;line-height:1.6;margin-bottom:40px}.blocker-instructions{background:#ffffff0d;border:1px solid var(--card-border);border-radius:15px;margin-bottom:40px;padding:30px;text-align:left}.blocker-instructions h3{color:var(--medium-blue);font-size:20px;margin-bottom:20px;text-align:center}.blocker-instructions ul{list-style:none;margin:0;padding:0}.blocker-instructions li{color:var(--white);font-size:16px;line-height:1.5;padding:12px 0 12px 30px;position:relative}.blocker-instructions li:before{color:var(--success);content:"✓";font-size:18px;font-weight:700;left:0;position:absolute}.blocker-qr{margin:40px 0}.qr-text{color:var(--gray);font-size:14px;font-weight:500;margin-bottom:15px}.qr-container{background:var(--white);border-radius:15px;box-shadow:0 10px 30px #00000080;display:inline-block;padding:20px;transition:transform .3s ease,box-shadow .3s ease}.qr-container:hover{box-shadow:0 15px 40px #0009;transform:translateY(-5px)}.qr-container svg{display:block}.qr-url{color:var(--medium-blue);font-size:16px;font-weight:600;letter-spacing:.5px;margin-top:15px}.bypass-link{background:none;border:none;color:#ffffff4d;cursor:pointer;font-size:12px;margin-top:20px;padding:10px;transition:color .3s ease}.bypass-link:hover{color:#fff9}.bypass-hint{animation:fadeIn .3s ease;background:#3b82f61a;border:1px solid var(--medium-blue);border-radius:10px;color:var(--medium-blue);font-size:13px;margin-top:10px;padding:15px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.blocker-footer{color:var(--gray);font-size:14px;text-align:center;z-index:1}.bypass-indicator{align-items:center;background:#ef4444e6;border:2px solid var(--error);border-radius:25px;box-shadow:0 4px 15px #ef444466;color:var(--white);cursor:pointer;display:flex;font-size:12px;font-weight:600;gap:8px;padding:8px 16px;position:fixed;right:20px;top:20px;transition:all .3s ease;z-index:9999}.bypass-indicator:hover{background:var(--error);transform:scale(1.05)}@media (max-width:768px){.device-blocker h1{font-size:28px}.blocker-message{font-size:16px}.blocker-icon-group{gap:20px}.device-icon svg{font-size:40px}.block-icon{font-size:30px!important}.blocker-logo{width:180px}.qr-container{padding:15px}.qr-container svg{height:180px!important;width:180px!important}.qr-url{font-size:14px}.blocker-instructions{padding:20px}}.auth-container{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--card-bg);border:1px solid var(--card-border);border-radius:20px;box-shadow:0 10px 40px #00000080;max-width:450px;padding:40px;width:100%}.auth-logo{margin-bottom:30px;text-align:center}.auth-logo h1{color:var(--medium-blue);font-size:32px;font-weight:700;margin-bottom:10px}.auth-logo p{color:var(--gray);font-size:14px}.auth-form{gap:20px}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{color:var(--text-secondary);font-size:14px;font-weight:500}.form-group input{background:#0f141999;border:1px solid var(--card-border);border-radius:10px;color:var(--white);font-size:16px;padding:12px 16px;transition:all .3s ease}.form-group input:focus{background:#0f1419cc;border-color:var(--medium-blue);box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-group input::placeholder{color:#fff6}.form-options{font-size:14px;justify-content:space-between}.form-options,.remember-me{align-items:center;display:flex}.remember-me{color:var(--gray);gap:8px}.remember-me input[type=checkbox]{cursor:pointer;height:18px;width:18px}.forgot-password{color:var(--medium-blue);text-decoration:none;transition:color .3s ease}.forgot-password:hover{color:var(--purple)}.btn-primary{background:linear-gradient(135deg,var(--medium-blue) 0,var(--purple) 100%);border:none;border-radius:10px;box-shadow:0 4px 15px #3b82f64d;color:var(--white);cursor:pointer;font-size:16px;font-weight:600;margin-top:10px;padding:14px 24px;transition:all .3s ease}.btn-primary:hover{box-shadow:0 8px 25px #3b82f666,0 4px 15px #7c3aed4d;transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#0000;border:1px solid var(--medium-blue);border-radius:10px;color:var(--medium-blue);cursor:pointer;font-size:14px;font-weight:500;margin-top:20px;padding:12px 24px;transition:all .3s ease}.btn-secondary:hover{background:#3a7bd51a;border-color:var(--purple);color:var(--purple)}.password-requirements{color:var(--gray);font-size:12px;line-height:1.5;margin-top:5px}.password-requirements.error{color:var(--error)}.success-message{background:#2ecc7133;border:1px solid var(--success);border-radius:10px;color:var(--success)}.error-message,.success-message{font-size:14px;padding:12px 16px;text-align:center}.error-message{background:#e74c3c33;border:1px solid var(--error);border-radius:10px;color:var(--error)}.recovery-step{margin-bottom:20px;text-align:center}.recovery-step .step-indicator{background:var(--medium-blue);border-radius:50%;color:var(--white);display:inline-block;font-weight:700;height:40px;line-height:40px;margin-bottom:10px;width:40px}@media (max-width:768px){.auth-card{padding:30px 20px}.auth-logo h1{font-size:28px}.form-options{align-items:flex-start;flex-direction:column;gap:10px}}.register-card{max-width:550px}.form-group label svg{margin-right:5px}.form-group input.error{border-color:var(--error)}.form-group .error-message{background:#0000;border:none;color:var(--error);font-size:12px;margin-top:5px;padding:0}.terms-section{margin:10px 0}.terms-checkbox{align-items:flex-start;color:var(--gray);cursor:pointer;display:flex;font-size:14px;gap:10px}.terms-checkbox input[type=checkbox]{cursor:pointer;flex-shrink:0;height:18px;margin-top:2px;width:18px}.terms-checkbox span{line-height:1.5}.link-button{background:none;border:none;color:var(--medium-blue);cursor:pointer;font-family:inherit;font-size:inherit;padding:0;text-decoration:underline}.link-button:hover{color:var(--purple)}.auth-footer{color:var(--gray);font-size:14px;margin-top:20px;text-align:center}.auth-footer a{color:var(--medium-blue);font-weight:600;text-decoration:none}.auth-footer a:hover{color:var(--purple)}.modal-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{background:var(--card-bg);border:1px solid var(--card-border);box-shadow:0 20px 60px #0009;display:flex;flex-direction:column;max-height:85vh;max-width:800px}.modal-header{border-bottom:1px solid var(--card-border);justify-content:space-between;padding:25px 30px}.modal-header,.modal-header h2{align-items:center;display:flex}.modal-header h2{color:var(--white);font-size:24px;gap:10px}.modal-close{align-items:center;background:none;border:none;color:var(--gray);cursor:pointer;display:flex;font-size:32px;height:40px;justify-content:center;padding:0;transition:color .3s ease;width:40px}.modal-close:hover{color:var(--white)}.modal-body{flex:1 1;overflow-y:auto;padding:30px}.modal-body h3{color:var(--medium-blue);font-size:20px;margin-bottom:15px;margin-top:25px}.modal-body h3:first-child{margin-top:0}.modal-body h4{color:var(--white);font-size:16px;margin-bottom:10px;margin-top:20px}.modal-body p{color:var(--gray);font-size:14px;line-height:1.8;margin-bottom:15px}.modal-body section{margin-bottom:30px}.gdpr-section{border-top:2px solid var(--card-border);margin-top:30px;padding-top:30px}.modal-footer{border-top:1px solid var(--card-border);display:flex;justify-content:flex-end;padding:20px 30px}@media (max-width:768px){.modal-content{max-height:90vh}.modal-header{padding:20px}.modal-header h2{font-size:20px}.modal-body{padding:20px}.modal-body h3{font-size:18px}.modal-footer{padding:15px 20px}}.school-selection-container{margin:0 auto;max-width:1400px;min-height:100vh;padding:20px 20px 100px}.school-selection-header{margin-bottom:40px;padding:30px 20px;text-align:center}.header-logo{height:auto;margin-bottom:20px;width:200px}.school-selection-header h1{color:var(--white);font-size:32px;font-weight:700;margin-bottom:10px}.school-selection-header p{color:var(--gray);font-size:16px;margin:0 auto;max-width:600px}.search-section{margin:0 auto 40px;max-width:600px}.search-box{align-items:center;background:#ffffff0d;border:2px solid var(--card-border);border-radius:15px;display:flex;gap:15px;padding:15px 20px;transition:all .3s ease}.search-box:focus-within{background:#ffffff14;border-color:var(--medium-blue)}.search-box svg{color:var(--gray);font-size:20px}.search-box input{background:#0000;border:none;color:var(--white);flex:1 1;font-size:16px;outline:none}.search-box input::placeholder{color:var(--gray)}.schools-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-bottom:30px}.school-card{background:var(--card-bg);border:2px solid var(--card-border);border-radius:20px;cursor:pointer;min-height:280px;overflow:hidden;padding:25px;position:relative;transition:all .3s ease}.school-card:hover{border-color:var(--medium-blue);box-shadow:0 10px 30px #3b82f64d;transform:translateY(-5px)}.school-card.selected{background:#10b9811a;border-color:var(--success)}.selected-badge{background:var(--success);border-radius:50%;box-shadow:0 4px 10px #10b98166;color:var(--white);font-size:18px;font-weight:700;height:35px;position:absolute;right:15px;top:15px;width:35px;z-index:2}.school-logo,.selected-badge{align-items:center;display:flex;justify-content:center}.school-logo{background:#ffffff0d;border-radius:12px;height:100px;margin-bottom:20px;padding:15px;width:100%}.school-logo img{filter:brightness(1.2);max-height:100%;max-width:100%;object-fit:contain}.school-info{display:flex;flex-direction:column;gap:12px}.school-info h3{color:var(--white);font-size:20px;font-weight:700;margin-bottom:5px}.school-detail{align-items:center;color:var(--gray);display:flex;font-size:14px;gap:10px}.school-detail svg{color:var(--medium-blue);flex-shrink:0;font-size:14px}.school-detail span{word-break:break-word}.no-results{color:var(--gray);font-size:18px;padding:60px 20px;text-align:center}.selection-footer{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0a0e27f2;border-top:2px solid var(--card-border);bottom:0;display:flex;justify-content:space-between;left:0;padding:20px;position:fixed;right:0;z-index:100}.selection-info{font-weight:600}.btn-continue,.selection-info{color:var(--white);font-size:16px}.btn-continue{background:linear-gradient(135deg,var(--medium-blue) 0,var(--purple) 100%);border:none;border-radius:12px;box-shadow:0 4px 15px #3b82f64d;cursor:pointer;font-weight:700;padding:15px 40px;transition:all .3s ease}.btn-continue:hover:not(:disabled){box-shadow:0 8px 25px #3b82f666;transform:translateY(-2px)}.btn-continue:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.school-selection-header h1{font-size:24px}.schools-grid{grid-template-columns:1fr}.selection-footer{flex-direction:column;gap:15px;padding:15px}.btn-continue{width:100%}}.dashboard-container{min-height:100vh;padding:20px}.dashboard-header{align-items:center;background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;display:flex;justify-content:space-between;margin-bottom:40px;padding:15px 30px}.dashboard-title{align-items:center;display:flex;gap:15px}.dashboard-logo{height:45px;object-fit:contain;width:45px}.dashboard-title h1{color:var(--white);font-size:26px;font-weight:600;letter-spacing:.5px}.dashboard-actions{align-items:center;display:flex;gap:15px}.language-flags{align-items:center;display:flex;gap:8px}.flag-button{background:#0000;border:2px solid #0000;border-radius:8px;cursor:pointer;font-size:28px;line-height:1;opacity:.6;padding:4px 8px;transition:all .3s ease}.flag-button:hover{background:#3b82f61a;transform:scale(1.1)}.flag-button.active,.flag-button:hover{border-color:var(--medium-blue);opacity:1}.flag-button.active{background:#3b82f633;box-shadow:0 2px 8px #3b82f64d}.profile-button{align-items:center;background:linear-gradient(135deg,var(--medium-blue) 0,var(--purple) 100%);border:2px solid #fff3;border-radius:50%;box-shadow:0 4px 12px #3b82f64d;cursor:pointer;display:flex;font-size:20px;height:45px;justify-content:center;overflow:hidden;transition:all .3s ease;width:45px}.profile-button:hover{box-shadow:0 6px 20px #7c3aed66;transform:scale(1.1)}.profile-button img{height:100%;object-fit:cover;width:100%}.class-groups-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));padding:0 20px}.class-group-card{border:1px solid var(--card-border);border-radius:16px;box-shadow:0 4px 20px #00000080;cursor:pointer;height:380px;overflow:hidden;position:relative;transition:transform .3s ease,box-shadow .3s ease}.class-group-card:hover{box-shadow:0 12px 35px #3b82f64d,0 0 20px #7c3aed33;transform:translateY(-8px)}.class-group-image{background-color:var(--card-bg);object-fit:cover;z-index:1}.class-group-image,.class-group-overlay{height:100%;left:0;position:absolute;top:0;width:100%}.class-group-overlay{background:linear-gradient(180deg,#0000 0,#0000004d 40%,#000c 70%,#000000f2);z-index:2}.card-inner{bottom:0;display:flex;flex-direction:column;justify-content:space-between;left:0;padding:20px;position:absolute;right:0;top:0;z-index:3}.school-badge{align-items:center;align-self:flex-start;background:linear-gradient(135deg,var(--medium-blue) 0,var(--purple) 100%);border-radius:20px;box-shadow:0 4px 12px #3b82f64d;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:8px 16px}.class-group-content{color:var(--white);max-height:100%;overflow-y:auto}.class-group-info h3{font-size:18px;font-weight:600;margin-bottom:10px}.group-name-title{color:var(--white);font-size:20px;font-weight:700;margin-bottom:6px;text-shadow:0 2px 4px #0006}.sport-subtitle{color:var(--medium-blue);font-size:14px;font-weight:500;margin-bottom:10px;text-transform:capitalize}.class-group-details{color:var(--gray);display:flex;flex-direction:column;font-size:13px;gap:6px;margin-bottom:10px}.class-group-details div{align-items:center;display:inline-flex;gap:6px}.students-section-card{margin-top:10px}.students-count{align-items:center;color:var(--medium-blue);display:inline-flex;font-size:13px;font-weight:600;gap:6px;margin-bottom:8px}.students-list-card{display:flex;flex-direction:column;gap:5px}.student-item-card{align-items:center;background:#ffffff1a;border-radius:6px;display:flex;font-size:12px;gap:8px;justify-content:space-between;padding:5px 8px}.student-name{color:var(--white);flex:1 1;font-size:12px;font-weight:500}.student-level{align-items:center;color:var(--text-secondary);display:flex;font-size:11px;gap:3px;white-space:nowrap}.star-icon{color:#fbbf24;font-size:10px}.more-students{color:var(--medium-blue);font-size:11px;font-weight:600;padding:4px;text-align:center}.students-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.student-badge{background:#fff3;border-radius:12px;color:var(--white);font-size:12px;padding:4px 10px}.menu-button{background:#0000;border:none;color:var(--white);cursor:pointer;display:none;font-size:28px;margin-left:auto;padding:8px;transition:all .3s ease}.menu-button:hover{color:var(--medium-blue);transform:scale(1.1)}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;height:100%;left:0;opacity:0;position:fixed;top:0;transition:all .3s ease;visibility:hidden;width:100%;z-index:999}.sidebar-overlay.show{opacity:1;visibility:visible}.sidebar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1a1f3afa;border-right:1px solid var(--card-border);box-shadow:4px 0 20px #00000080;display:flex;flex-direction:column;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;transform:translateX(-100%);transition:transform .3s ease;width:320px;z-index:1000}.sidebar.open{transform:translateX(0)}.sidebar-header{align-items:center;border-bottom:1px solid var(--card-border);display:flex;justify-content:space-between;padding:20px}.sidebar-header h3{color:var(--white);font-size:20px;font-weight:600}.close-sidebar{align-items:center;background:#0000;border:none;color:var(--white);cursor:pointer;display:flex;font-size:24px;justify-content:center;padding:8px;transition:all .3s ease}.close-sidebar:hover{color:var(--medium-blue);transform:rotate(90deg)}.sidebar-profile{align-items:center;border-bottom:1px solid var(--card-border);display:flex;flex-direction:column;gap:15px;padding:30px 20px}.sidebar-avatar{align-items:center;background:linear-gradient(135deg,var(--medium-blue) 0,var(--purple) 100%);border:3px solid #fff3;border-radius:50%;box-shadow:0 4px 12px #3b82f64d;color:var(--white);display:flex;font-size:32px;height:80px;justify-content:center;overflow:hidden;width:80px}.sidebar-avatar img{height:100%;object-fit:cover;width:100%}.sidebar-profile h3{color:var(--white);font-size:18px;font-weight:600;margin:0;text-align:center}.sidebar-profile p{color:#fff9;font-size:14px;margin:0;text-align:center}.sidebar-language{border-bottom:1px solid var(--card-border);padding:20px}.sidebar-language h4{color:#fff9;font-size:14px;font-weight:500;letter-spacing:1px;margin:0 0 15px;text-transform:uppercase}.language-dropdown{-webkit-appearance:none;appearance:none;background:#ffffff1a;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='12' height='8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='m1 1 5 5 5-5' stroke='%23fff' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 16px center;background-repeat:no-repeat;border:2px solid #fff3;border-radius:12px;color:var(--white);cursor:pointer;font-size:15px;outline:none;padding:12px 40px 12px 16px;transition:all .3s ease;width:100%}.language-dropdown:hover{background:#ffffff26;border-color:var(--medium-blue)}.language-dropdown:focus{border-color:var(--medium-blue);box-shadow:0 0 0 3px #3b82f633}.language-dropdown option{background:var(--dark-bg);color:var(--white);padding:10px}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:10px;padding:20px}.sidebar-nav-btn{align-items:center;background:#ffffff0d;border:2px solid #0000;border-radius:12px;color:var(--white);cursor:pointer;display:flex;font-size:15px;font-weight:500;gap:12px;padding:14px 16px;transition:all .3s ease}.sidebar-nav-btn svg{color:var(--medium-blue);font-size:20px}.sidebar-nav-btn:hover{background:#ffffff1a;border-color:var(--medium-blue);transform:translateX(4px)}.sidebar-logout{border-top:1px solid var(--card-border);padding:20px}.sidebar-logout button{align-items:center;background:#ef44441a;border:2px solid #0000;border-radius:12px;color:#ef4444;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:12px;justify-content:center;padding:14px 16px;transition:all .3s ease;width:100%}.sidebar-logout button svg{font-size:20px}.sidebar-logout button:hover{background:#ef444433;border-color:#ef4444;transform:scale(1.02)}.sidebar-nav-btn.has-alerts{animation:pulse-alert 2s ease-in-out infinite;border:2px solid #fbbf24!important;box-shadow:0 0 15px #fbbf2499,0 0 30px #fbbf244d}@keyframes pulse-alert{0%,to{box-shadow:0 0 15px #fbbf2499,0 0 30px #fbbf244d}50%{box-shadow:0 0 20px #fbbf24cc,0 0 40px #fbbf2480}}.floating-bell{align-items:center;animation:shake 3s ease-in-out infinite;background:linear-gradient(135deg,#fbbf24,#f59e0b);border:3px solid #fbbf2466;border-radius:50%;bottom:30px;box-shadow:0 4px 20px #fbbf2480;color:var(--dark-bg);cursor:pointer;display:flex;font-size:26px;height:60px;justify-content:center;position:fixed;right:30px;transition:all .3s ease;width:60px;z-index:998}.floating-bell:hover{box-shadow:0 6px 30px #fbbf24b3;transform:scale(1.1)}@keyframes shake{0%,90%,to{transform:rotate(0deg)}92%{transform:rotate(-15deg)}94%{transform:rotate(15deg)}96%{transform:rotate(-10deg)}98%{transform:rotate(10deg)}}.desktop-only{display:flex}@media (max-width:768px){.desktop-only{display:none!important}.menu-button{display:block}.sidebar{width:280px}.dashboard-header{padding:12px 20px}.dashboard-title h1{font-size:20px}.dashboard-logo{height:40px;width:40px}.class-groups-grid{grid-template-columns:1fr;padding:0}.class-group-card{height:350px}}.class-group-detail{min-height:100vh;padding:20px}.detail-header{align-items:center;background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;display:flex;gap:15px;margin-bottom:20px;padding:15px 25px}.detail-logo{height:35px;object-fit:contain;width:35px}.detail-title{color:var(--white);font-size:20px;font-weight:600;letter-spacing:.5px}.back-button{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;padding:10px 12px}.group-header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;box-shadow:0 3px 15px #0000004d;margin-bottom:22px;padding:22px}.group-header-top{justify-content:space-between;margin-bottom:15px}.group-header-top,.school-name{align-items:center;display:flex}.school-name{color:var(--medium-blue);font-size:21px;font-weight:700;gap:8px}.sport-badge{align-items:center;background:linear-gradient(135deg,var(--medium-blue) 0,var(--purple) 100%);border-radius:15px;box-shadow:0 3px 9px #3b82f64d;display:flex;font-size:12px;font-weight:600;gap:6px;padding:7px 15px}.group-image-container{border-radius:12px;box-shadow:0 4px 15px #0006;margin:15px 0;overflow:hidden;width:100%}.group-image{display:block;height:20vh;object-fit:cover;width:100%}.group-section-title{border-bottom:2px solid var(--medium-blue);color:var(--white);font-size:18px;font-weight:600;margin:20px 0 15px;padding-bottom:10px}.group-info-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr);margin-bottom:18px;margin-top:12px}.info-item{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;display:flex;flex-direction:column;gap:5px;padding:10px 14px;transition:all .3s ease}.info-item:hover{background:#ffffff14;border-color:var(--medium-blue);transform:translateY(-2px)}.info-label{align-items:center;color:#fff9;display:flex;font-size:10px;font-weight:500;gap:4px;letter-spacing:.4px;text-transform:uppercase}.info-value{color:var(--white);font-size:14px;font-weight:600}.students-section{background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;margin-top:15px;padding:18px}.students-section h3{align-items:center;color:var(--white);display:flex;font-size:15px;font-weight:600;gap:8px;margin-bottom:12px}.students-table{display:flex;flex-direction:column;gap:6px}.student-row{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;display:grid;grid-template-columns:1fr auto;padding:8px 12px;transition:all .3s ease}.student-row:hover{background:#3b82f61a;border-color:var(--medium-blue);transform:translateX(5px)}.student-name-col{color:var(--white);font-size:13px;font-weight:500;text-align:left}.student-level-col{align-items:center;color:var(--medium-blue);display:flex;font-size:13px;font-weight:600;gap:5px;text-align:right}.student-level-col .star-icon{color:#fbbf24;font-size:11px}.classes-section{margin-top:20px}.classes-section h2{color:var(--white);font-size:24px;margin-bottom:20px;padding:0 10px}.load-more-container{display:flex;justify-content:center;margin-top:20px;padding:30px 0}.load-more-button{align-items:center;background:linear-gradient(135deg,var(--medium-blue) 0,var(--purple) 100%);border:2px solid #0000;border-radius:12px;box-shadow:0 4px 15px #3b82f64d;color:var(--white);cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:10px;padding:14px 40px;transition:all .3s ease}.load-more-button:hover{border-color:#fff3;box-shadow:0 6px 20px #7c3aed66;transform:translateY(-2px)}.load-more-button:active{transform:translateY(0)}.classes-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.class-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--card-bg);border:1px solid var(--card-border);border-radius:15px;box-shadow:0 4px 15px #0000004d;padding:20px;transition:all .3s ease}.class-card:hover{border-color:var(--medium-blue);box-shadow:0 8px 25px #3b82f64d;transform:translateY(-3px)}.class-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;margin-bottom:15px;padding-bottom:15px}.class-date-time{display:flex;flex-direction:column;gap:5px}.class-date-time .date{color:var(--white);font-size:18px;font-weight:600}.class-date-time .time{color:var(--gray);font-size:14px}.countdown{background:linear-gradient(135deg,var(--purple) 0,var(--medium-blue) 100%);border-radius:10px;padding:10px 15px;text-align:center}.countdown-label{color:#fffc;font-size:11px;margin-bottom:3px}.countdown-time{color:var(--white);font-size:16px;font-weight:700}.class-students{margin:15px 0}.class-students h4{align-items:center;color:var(--gray);display:flex;font-size:14px;gap:5px;margin-bottom:10px}.students-list-class{display:flex;flex-direction:column;gap:8px}.student-item-class{align-items:center;background:#3b82f61a;border-radius:8px;display:flex;font-size:14px;justify-content:space-between;padding:8px 12px}.student-name-class{color:var(--white);flex:1 1}.student-level-class{align-items:center;color:var(--gray);display:flex;font-size:13px;gap:5px}.student-count{color:var(--medium-blue);font-weight:600}.class-actions{margin-top:15px}.btn-actions{background:#0000;border:1px solid var(--medium-blue);border-radius:10px;color:var(--medium-blue);cursor:pointer;font-size:14px;font-weight:600;padding:12px;transition:all .3s ease;width:100%}.btn-actions:hover{background:linear-gradient(135deg,var(--medium-blue) 0,var(--purple) 100%);border-color:#0000;color:var(--white)}.modal-overlay{align-items:center;background:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:var(--dark-blue);border:1px solid #ffffff1a;border-radius:20px;max-width:500px;padding:30px;position:relative;width:100%}.modal-header{margin-bottom:20px}.modal-header h3{color:var(--white);font-size:22px;margin-bottom:10px}.modal-body{color:var(--gray);line-height:1.6;margin-bottom:25px}.modal-actions{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(3,1fr)}.modal-button{border:none;border-radius:10px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 20px;transition:all .3s ease}.modal-button.confirm{background:var(--success);color:var(--white)}.modal-button.confirm:hover{background:#27ae60;transform:translateY(-2px)}.modal-button.cancel{background:var(--error);color:var(--white)}.modal-button.cancel:hover{background:#c0392b;transform:translateY(-2px)}.modal-button.notice{background:var(--warning);color:var(--white)}.modal-button.notice:hover{background:#e67e22;transform:translateY(-2px)}.modal-button.close{background:#ffffff1a;border:1px solid #fff3;color:var(--white);grid-column:1/-1}.modal-button.close:hover{background:#ffffff26}textarea.modal-textarea{background:#ffffff1a;border:1px solid #fff3;border-radius:10px;color:var(--white);font-family:inherit;font-size:14px;margin-top:10px;min-height:100px;padding:12px;resize:vertical;width:100%}textarea.modal-textarea:focus{border-color:var(--medium-blue);outline:none}@media (max-width:1024px){.group-info-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.group-header-top{flex-direction:column;gap:15px;text-align:center}.classes-grid,.group-info-grid,.modal-actions{grid-template-columns:1fr}.modal-button.close{grid-column:1}}.profile-container{margin:0 auto;max-width:1200px;min-height:100vh;padding:20px}.profile-header{align-items:center;background:#ffffff08;border:1px solid #ffffff1a;border-radius:15px;display:flex;gap:15px;margin-bottom:30px;padding:15px 20px}.profile-logo{height:40px;object-fit:contain;width:40px}.profile-title{color:var(--white);flex-grow:1;font-size:24px;font-weight:700;letter-spacing:.5px}.back-button{align-items:center;background:var(--card-bg);border:1px solid var(--card-border);border-radius:8px;color:var(--white);cursor:pointer;display:flex;font-size:18px;justify-content:center;margin-left:auto;padding:10px 14px;transition:all .3s ease}.back-button:hover{background:#3b82f633;border-color:var(--medium-blue);transform:translateX(3px)}.profile-content{grid-gap:25px;display:grid;gap:25px}.profile-section{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--card-bg);border:1px solid var(--card-border);border-radius:20px;box-shadow:0 4px 20px #0000004d;max-width:100%;overflow:hidden;padding:30px}.profile-section h2{align-items:center;color:var(--white);display:flex;font-size:22px;gap:10px;margin-bottom:20px}.avatar-section{text-align:center}.avatar-upload{margin:0 auto 20px}.avatar-preview,.avatar-upload{height:150px;position:relative;width:150px}.avatar-preview{align-items:center;background:linear-gradient(135deg,var(--medium-blue) 0,var(--purple) 100%);border:3px solid var(--white);border-radius:50%;display:flex;font-size:60px;justify-content:center;overflow:hidden}.avatar-preview img{height:100%;object-fit:cover;width:100%}.avatar-overlay{align-items:center;background:#0009;border-radius:50%;bottom:0;cursor:pointer;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.avatar-preview:hover .avatar-overlay{opacity:1}.avatar-overlay span{color:var(--white);font-size:14px;font-weight:600}.avatar-input{display:none}.btn-upload{background:linear-gradient(135deg,var(--medium-blue) 0,var(--purple) 100%);border:none;border-radius:10px;color:var(--white);cursor:pointer;font-size:14px;font-weight:600;margin-top:10px;padding:10px 20px;transition:all .3s ease}.btn-upload:hover{box-shadow:0 5px 15px #3a7bd566;transform:translateY(-2px)}.form-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.form-group-profile{display:flex;flex-direction:column;gap:8px}.form-group-profile label{color:var(--text-secondary);font-size:14px;font-weight:500}.form-group-profile input,.form-group-profile select{background:#0f141999;border:1px solid var(--card-border);border-radius:10px;color:var(--white);font-size:16px;padding:12px 16px;transition:all .3s ease}.form-group-profile input:focus,.form-group-profile select:focus{background:#0f1419cc;border-color:var(--medium-blue);box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-group-profile select option{background:var(--dark-blue);color:var(--white)}.preferences-list{display:flex;flex-direction:column;gap:20px}.school-preference{background:#0f141999;border:1px solid var(--card-border);border-radius:15px;padding:20px}.school-name-header{color:var(--medium-blue);font-size:18px;font-weight:600;margin-bottom:15px}.availability-slots{display:flex;flex-direction:column;gap:10px}.time-slot{grid-gap:15px;align-items:center;background:#ffffff0d;border-radius:10px;display:grid;gap:15px;grid-template-columns:150px 1fr 1fr;padding:12px}.time-slot-day{color:var(--white);font-weight:500}.time-slot input{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:var(--white);font-size:14px;padding:8px 12px}.time-slot input:focus{border-color:var(--medium-blue);outline:none}.btn-save{background:linear-gradient(135deg,var(--medium-blue) 0,var(--purple) 100%);border:none;border-radius:10px;box-shadow:0 4px 15px #3b82f64d;color:var(--white);cursor:pointer;font-size:16px;font-weight:600;margin-top:20px;padding:12px 24px;transition:all .3s ease}.btn-save:hover{box-shadow:0 8px 25px #3b82f666,0 4px 15px #7c3aed4d;transform:translateY(-2px)}.success-toast{animation:slideIn .3s ease;background:var(--success);border-radius:10px;box-shadow:0 5px 15px #0000004d;color:var(--white);padding:15px 25px;position:fixed;right:20px;top:20px;z-index:1000}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.school-selector{background:#ffffff0d;border:1px solid var(--card-border);border-radius:10px;color:var(--white);cursor:pointer;font-size:15px;padding:12px 16px;transition:all .3s ease;width:100%}.school-selector:focus,.school-selector:hover{background:#ffffff14;border-color:var(--medium-blue);outline:none}.availability-grid{-webkit-overflow-scrolling:touch;background:#ffffff05;border-radius:10px;margin-top:20px;overflow-x:auto;overflow-y:visible;padding:10px;width:100%}.grid-header,.grid-row{grid-gap:6px;display:grid;gap:6px;grid-template-columns:60px repeat(7,minmax(50px,1fr));margin-bottom:6px;min-width:550px}.grid-corner{background:#0a0e2799;box-shadow:2px 0 4px #0003;left:0;position:-webkit-sticky;position:sticky;z-index:2}.grid-day-header{background:#3b82f633;border-radius:6px;color:var(--white);font-size:11px;font-weight:600;letter-spacing:.3px;padding:8px 3px;text-align:center;text-transform:uppercase}.grid-hour-label{align-items:center;background:#0a0e2799;border-radius:6px;box-shadow:2px 0 4px #0003;color:#ffffffb3;display:flex;font-size:11px;font-weight:500;justify-content:center;left:0;padding:0 5px;position:-webkit-sticky;position:sticky;z-index:1}.grid-cell{border:1.5px solid #0000;border-radius:5px;cursor:pointer;min-height:35px;transition:all .2s ease}.grid-cell.available{background:#10b9814d;border-color:#10b98180}.grid-cell.available:hover{background:#10b98180;border-color:#10b981cc;transform:scale(1.05)}.grid-cell.unavailable{background:#dc26264d;border-color:#dc262680}.grid-cell.unavailable:hover{background:#dc262680;border-color:#dc2626cc;transform:scale(1.05)}.availability-legend{background:#ffffff08;border-radius:8px;display:flex;gap:20px;justify-content:center;margin-top:15px;padding:12px}.legend-item{align-items:center;color:var(--white);display:flex;font-size:13px;gap:8px}.legend-color{border:1.5px solid #0000;border-radius:5px;height:24px;width:24px}.legend-color.available{background:#10b9814d;border-color:#10b98180}.legend-color.unavailable{background:#dc26264d;border-color:#dc262680}@media (max-width:768px){.profile-header{gap:10px;padding:12px 15px}.profile-logo{height:35px;width:35px}.profile-title{font-size:20px}.back-button{font-size:16px;padding:8px 12px}.form-grid,.time-slot{grid-template-columns:1fr}.time-slot{gap:10px}.time-slot-day{font-weight:600}.grid-header,.grid-row{gap:4px;grid-template-columns:60px repeat(7,minmax(40px,1fr))}.grid-hour-label{font-size:11px}.grid-day-header{font-size:11px;padding:8px 2px}.grid-cell{min-height:35px}.availability-legend{flex-direction:column;gap:15px}}.alerts-page{min-height:100vh;padding:20px}.alerts-header{align-items:center;background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;display:flex;gap:15px;margin-bottom:20px;padding:15px 25px}.alerts-logo{height:35px;object-fit:contain;width:35px}.alerts-title{color:var(--white);font-size:20px;font-weight:600;letter-spacing:.5px}.alerts-back-button{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;color:var(--white);cursor:pointer;display:flex;font-size:18px;justify-content:center;margin-left:auto;padding:10px 12px;transition:all .3s ease}.alerts-back-button:hover{background:#3b82f633;border-color:var(--medium-blue);transform:translateX(3px)}.alerts-container{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;box-shadow:0 3px 15px #0000004d;padding:22px}.alerts-page-title{align-items:center;border-bottom:2px solid var(--medium-blue);color:var(--white);display:flex;font-size:24px;font-weight:600;gap:12px;margin-bottom:25px;padding-bottom:15px}.alerts-list{display:flex;flex-direction:column;gap:15px}.alert-card{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;padding:18px;transition:all .3s ease}.alert-card:hover{background:#ffffff14;border-color:var(--medium-blue);transform:translateX(5px)}.alert-card.school{border-left:4px solid var(--medium-blue)}.alert-card.system{border-left:4px solid var(--purple)}.alert-card.urgent{background:#ef444414;border-left:4px solid #ef4444}.alert-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.alert-from{color:var(--medium-blue);font-size:15px;font-weight:600}.alert-date{color:#fff9;font-size:12px}.alert-time{color:#ffffff80;font-size:11px;margin-top:8px;text-align:right}.alert-message{color:var(--white);font-size:14px;line-height:1.6}.no-alerts{color:#ffffff80;padding:60px 20px;text-align:center}.no-alerts-icon{color:#fff3;font-size:64px;margin-bottom:20px}.no-alerts p{font-size:16px}@media (max-width:768px){.alerts-page{padding:15px}.alerts-container{padding:18px}.alert-card{padding:15px}}
/*# sourceMappingURL=main.a0bf83e4.css.map*/