*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;line-height:1.6;color:#333;background-color:#fff}:root{--primary: #1d3557;--secondary: #457b9d;--accent: #e63946;--neutral: #f8f9fa}.container{width:90%;max-width:1500px;margin:0 auto}.navbar{background:var(--primary);color:var(--neutral);position:fixed;top:0;left:0;width:100%;z-index:1000;box-shadow:0 2px 4px #0000001a}.navbar .container{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.logo-container{display:flex;align-items:center;gap:15px}.navbar .logo{font-size:1.5rem;font-weight:700}.navbar .logo-image img{height:50px;width:auto}.navbar .nav-links{list-style:none;display:flex;gap:1.5rem}.navbar .nav-links a{color:#fff;text-decoration:none;font-weight:700;transition:color .3s}.navbar .nav-links a:hover{color:var(--accent)}.portal-link{background:var(--accent);color:#fff!important;padding:.5rem 1rem;border-radius:25px;transition:background-color .3s ease}.portal-link:hover{background:#c4303d}.mobile-menu-btn{display:none;background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.5rem;transition:color .3s;width:40px;height:40px;border-radius:4px;display:flex;align-items:center;justify-content:center}.mobile-menu-btn:hover{color:var(--accent);background-color:#ffffff1a}.mobile-sidebar{position:fixed;top:0;right:-300px;width:300px;height:100vh;background:var(--primary);z-index:2000;transition:right .3s ease;box-shadow:-2px 0 10px #0000004d}.mobile-sidebar.open{right:0}.mobile-sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.mobile-sidebar-close{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.5rem;transition:color .3s}.mobile-sidebar-close:hover{color:var(--accent)}.mobile-nav-links{list-style:none;padding:1rem 0}.mobile-nav-links li{border-bottom:1px solid rgba(255,255,255,.1)}.mobile-nav-links a{display:block;color:#fff;text-decoration:none;padding:1rem;font-weight:700;transition:background-color .3s}.mobile-nav-links a:hover{background-color:#ffffff1a;color:var(--accent)}.mobile-portal-link{background:var(--accent);color:#fff!important;margin:1rem;padding:.75rem 1rem;border-radius:25px;text-align:center;display:block;transition:background-color .3s ease}.mobile-portal-link:hover{background:#c4303d}.mobile-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:1500;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.mobile-overlay.open{opacity:1;visibility:visible}.hero{position:relative;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-top:60px;scroll-margin-top:80px}.hero-video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;z-index:-1}.hero:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#0006;z-index:0}.hero-content{text-align:center;color:#fff;z-index:1;max-width:800px;padding:0 20px}.hero-content h1{font-size:4rem;font-weight:700;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.hero-content p{font-size:1.25rem;margin-bottom:2rem;text-shadow:1px 1px 2px rgba(0,0,0,.5)}.btn{display:inline-block;background:var(--accent);color:#fff;padding:1rem 2rem;text-decoration:none;border-radius:50px;font-weight:700;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.btn:hover{background:#c4303d;transform:translateY(-2px);box-shadow:0 10px 25px #e639464d}section{padding:5rem 0;scroll-margin-top:80px}section h2{text-align:center;font-size:2.5rem;margin-bottom:3rem;color:var(--primary)}.about{background:#fff}.about p{font-size:1.1rem;text-align:center;max-width:800px;margin:0 auto;line-height:1.8}.classes{background:var(--neutral)}.class-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:3rem}.pricing{background:#fff}.pricing-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:3rem}.card{background:#fff;padding:2rem;border-radius:15px;box-shadow:0 10px 30px #0000001a;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.card:hover{transform:translateY(-5px);box-shadow:0 20px 40px #00000026}.card h3{color:var(--primary);margin-bottom:1rem;font-size:1.5rem}.card p{color:#666;line-height:1.6}.price{font-size:2.5rem;font-weight:700;color:var(--accent);margin:1rem 0}.card ul{list-style:none;margin:1.5rem 0}.card ul li{padding:.5rem 0;border-bottom:1px solid #eee}.card ul li:last-child{border-bottom:none}.contact{background:var(--neutral)}.contact p{text-align:center;margin-bottom:2rem;font-size:1.1rem}.contact form{max-width:600px;margin:0 auto 3rem}.contact label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.contact input,.contact textarea{width:100%;padding:.75rem;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;margin-bottom:1rem;transition:border-color .3s ease}.contact input:focus,.contact textarea:focus{outline:none;border-color:var(--accent)}.contact button{background:var(--secondary);color:#fff;padding:1rem 2rem;border:none;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:background-color .3s ease;width:100%}.contact button:hover{background:#356487}.locations-section{margin-top:4rem}.locations-section h3{text-align:center;font-size:2rem;margin-bottom:2rem;color:var(--primary)}.location-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;margin-top:2rem}.location-card{background:#fff;border-radius:15px;overflow:hidden;box-shadow:0 10px 30px #0000001a;transition:transform .3s ease}.location-card:hover{transform:translateY(-5px)}.location-image{width:100%;height:200px;overflow:hidden}.location-image img{width:100%;height:100%;object-fit:cover}.location-content{padding:1.5rem}.location-content h4{color:var(--primary);margin-bottom:.5rem;font-size:1.25rem}.location-day{color:var(--secondary);font-weight:500;margin-bottom:.5rem}.location-address{color:#666;margin-bottom:1rem;line-height:1.5}.location-map-btn{background:var(--accent);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:25px;cursor:pointer;font-weight:500;transition:background-color .3s ease;width:100%}.location-map-btn:hover{background:#c4303d}.contact-info{text-align:center;margin-top:3rem}.contact-info p{margin-bottom:.5rem}.contact-info a{color:var(--accent);text-decoration:none;font-weight:500}.contact-info a:hover{text-decoration:underline}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.modal-content{background:#fff;border-radius:15px;padding:2rem;max-width:600px;width:100%;position:relative;max-height:90vh;overflow-y:auto}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;cursor:pointer;color:#666;line-height:1}.modal-close:hover{color:#333}.modal-content h3{color:var(--primary);margin-bottom:.5rem}.modal-content p{margin-bottom:1rem;color:#666}.modal-external-link{display:inline-block;background:var(--accent);color:#fff;padding:.75rem 1.5rem;text-decoration:none;border-radius:8px;margin-top:1rem;font-weight:500;transition:background-color .3s ease}.modal-external-link:hover{background:#c4303d}footer{background:var(--primary);color:#fff;text-align:center;padding:2rem 0}.protected-content{margin-top:60px;min-height:calc(100vh - 60px);background:#f8f9fa;padding:2rem}.loading-container{text-align:center;padding:3rem 0}.loading-spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.error-container{text-align:center;padding:3rem 0}.error-icon{font-size:3rem;margin-bottom:1rem}.retry-button{background:#3b82f6;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .3s}.retry-button:hover{background:#2563eb}.portal-header{margin-bottom:2rem}.portal-header h1{font-size:2rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.portal-header p{color:#6b7280;font-size:1rem}.empty-state{text-align:center;padding:3rem 0}.empty-icon{font-size:3rem;display:block;margin-bottom:1rem}.empty-state h3{font-size:1.1rem;font-weight:500;color:#1f2937;margin-bottom:.5rem}.empty-state p{color:#6b7280;font-size:.9rem}.students-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.student-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1.5rem;transition:box-shadow .3s}.student-card:hover{box-shadow:0 4px 8px #00000026}.student-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.student-name{font-size:1.1rem;font-weight:600;color:#1f2937}.student-grade{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;color:#6b7280}.student-info{margin-bottom:1.5rem}.student-info-item{display:flex;align-items:center;font-size:.9rem;color:#6b7280;margin-bottom:.75rem}.student-info-item span:first-child{margin-right:.5rem}.student-info-item.expired{color:#dc2626}.admin-tabs-container{border-bottom:1px solid #e5e7eb;margin-bottom:2rem}.admin-tabs{display:flex;gap:2rem}.admin-tab{padding:.5rem .25rem;border-bottom:2px solid transparent;font-weight:500;font-size:.875rem;display:flex;align-items:center;gap:.5rem;background:none;border:none;cursor:pointer;color:#6b7280;transition:all .3s}.admin-tab:hover{color:#374151;border-bottom-color:#d1d5db}.admin-tab.active{border-bottom-color:#3b82f6;color:#3b82f6}.admin-overview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.admin-stat-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1.5rem}.admin-stat-content{display:flex;align-items:center}.admin-stat-icon{font-size:2rem;margin-right:1rem}.admin-stat-icon.users{color:#3b82f6}.admin-stat-icon.students{color:#10b981}.admin-stat-icon.grades{color:#f59e0b}.admin-stat-info{flex:1}.admin-stat-label{font-size:.875rem;font-weight:500;color:#6b7280;margin:0}.admin-stat-value{font-size:2rem;font-weight:600;color:#1f2937;margin:0}.admin-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.admin-section-header{padding:1.5rem;border-bottom:1px solid #e5e7eb}.admin-section-title{display:flex;justify-content:space-between;align-items:center}.admin-section-title h3{font-size:1.125rem;font-weight:500;color:#1f2937;margin:0}.admin-add-btn{display:inline-flex;align-items:center;padding:.5rem 1rem;border:none;border-radius:4px;font-size:.875rem;font-weight:500;color:#fff;background:#3b82f6;cursor:pointer;transition:background-color .3s}.admin-add-btn:hover{background:#2563eb}.admin-add-btn span{margin-right:.5rem}.admin-table-container{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse}.admin-table th{padding:.75rem 1.5rem;text-align:left;font-size:.75rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;background:#f9fafb;border-bottom:1px solid #e5e7eb}.admin-table td{padding:.75rem 1.5rem;border-bottom:1px solid #e5e7eb}.admin-table-cell{font-size:.875rem;color:#1f2937;font-weight:500}.admin-badge{display:inline-flex;padding:.25rem .5rem;font-size:.75rem;font-weight:600;border-radius:9999px}.admin-badge.admin{background:#dbeafe;color:#1e40af}.admin-badge.member{background:#dcfce7;color:#166534}.admin-badge.disabled{background:#f3f4f6;color:#6b7280}.admin-action-btn{background:none;border:none;cursor:pointer;font-size:1rem;margin-right:.75rem;transition:opacity .3s}.admin-action-btn:hover{opacity:.7}.admin-action-btn.edit{color:#3b82f6}.admin-action-btn.delete{color:#dc2626}.admin-action-btn.assign{color:#059669}.admin-action-btn.records{color:#7c3aed}.student-name-btn{background:none;border:none;color:#3b82f6;cursor:pointer;padding:0;font-size:inherit;font-weight:500;text-decoration:underline;text-decoration-color:transparent;transition:all .2s}.student-name-btn:hover{color:#2563eb;text-decoration-color:#2563eb}.admin-subtabs{display:flex;gap:1rem;padding:0 1.5rem;border-bottom:1px solid #e5e7eb;margin-bottom:1rem}.admin-subtab{padding:.75rem 1rem;border:none;background:none;cursor:pointer;font-size:.875rem;font-weight:500;color:#6b7280;border-bottom:2px solid transparent;transition:all .3s}.admin-subtab:hover{color:#374151}.admin-subtab.active{color:#3b82f6;border-bottom-color:#3b82f6}.admin-form{padding:1rem}.admin-form .form-group{margin-bottom:1rem}.admin-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.admin-form label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.admin-form input,.admin-form select,.admin-form textarea{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:4px;font-size:.875rem;transition:border-color .3s}.admin-form input:focus,.admin-form select:focus,.admin-form textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.admin-form textarea{resize:vertical;min-height:80px}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e5e7eb}.admin-btn{padding:.5rem 1rem;border:none;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .3s}.admin-btn.primary{background:#3b82f6;color:#fff}.admin-btn.primary:hover{background:#2563eb}.admin-btn.secondary{background:#6b7280;color:#fff}.admin-btn.secondary:hover{background:#4b5563}.admin-modal{max-width:600px;width:90%}.modal-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid #e5e7eb;margin-bottom:1rem}.modal-header h3{margin:0;font-size:1.125rem;font-weight:600;color:#1f2937}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .3s}.modal-close:hover{background:#f3f4f6}.form-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid #e5e7eb;margin-bottom:1rem}.form-header h3{margin:0;font-size:1.125rem;font-weight:600;color:#1f2937}.form-section{margin-bottom:1.5rem}.form-section h4{margin:0 0 .75rem;font-size:1rem;font-weight:500;color:#374151}.empty-message{color:#6b7280;font-style:italic;margin:0}.assigned-users-list{display:flex;flex-direction:column;gap:.5rem}.assigned-user-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:4px}.assigned-user-item span{font-size:.875rem;color:#374151}.assign-user-controls{display:flex;gap:.75rem;align-items:flex-end}.form-select{flex:1;padding:.5rem;border:1px solid #d1d5db;border-radius:4px;font-size:.875rem;background:#fff}.form-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.admin-btn.small{padding:.25rem .5rem;font-size:.75rem}.student-records{background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-width:800px;margin:0 auto}.records-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb}.records-header h3{margin:0;font-size:1.125rem;font-weight:600;color:#1f2937}.records-actions{padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb}.records-list{max-height:600px;overflow-y:auto}.record-item{border-bottom:1px solid #f3f4f6;padding:1rem 1.5rem}.record-item:last-child{border-bottom:none}.record-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.record-type{display:flex;align-items:center}.type-badge{padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.025em}.type-badge.note{background:#dbeafe;color:#1e40af}.type-badge.tournament{background:#fef3c7;color:#92400e}.type-badge.grading{background:#dcfce7;color:#166534}.type-badge.seminar{background:#f3e8ff;color:#7c3aed}.type-badge.achievement,.type-badge.incident{background:#fef2f2;color:#dc2626}.record-content h4{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:#1f2937}.record-text{margin:0 0 .75rem;color:#4b5563;line-height:1.5}.record-meta{display:flex;gap:1rem;font-size:.75rem;color:#6b7280}.record-date,.record-author,.record-created{display:flex;align-items:center}.record-actions{display:flex;gap:.5rem}.student-sidebar{position:fixed;top:0;right:0;width:800px;height:100vh;background:#fff;border-left:1px solid #e5e7eb;box-shadow:-4px 0 6px #0000001a;overflow-y:auto;z-index:1000;transform:translate(100%);transition:transform .3s ease-in-out}.student-sidebar.open{transform:translate(0)}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb;background:#f9fafb;position:sticky;top:0;z-index:10}.sidebar-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#1f2937}.sidebar-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;padding:.25rem;border-radius:4px;transition:background-color .2s}.sidebar-close:hover{background:#e5e7eb;color:#374151}.student-details{padding:.75rem 1.5rem}.student-header{margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #3b82f6}.student-header h3{margin:0 0 .5rem;font-size:1.5rem;font-weight:700;color:#1f2937}.student-id{font-size:.875rem;color:#6b7280;font-weight:500}.detail-section{margin-bottom:1.25rem}.detail-section h4{margin:0 0 1rem;font-size:1rem;font-weight:600;color:#374151;padding-bottom:.5rem;border-bottom:1px solid #e5e7eb}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.detail-item{display:flex;justify-content:space-between;align-items:flex-start;padding:.375rem 0}.detail-item label{font-weight:500;color:#4b5563;min-width:120px;flex-shrink:0}.detail-item span{color:#1f2937;text-align:right;flex:1;margin-left:1rem}.detail-item span.expired{color:#dc2626;font-weight:500}.records-section{padding:1rem 1.5rem;border-top:1px solid #e5e7eb}.records-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.records-header h4{margin:0;font-size:1rem;font-weight:600;color:#374151}.add-record-btn{background:#3b82f6;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.add-record-btn:hover{background:#2563eb}.records-list{display:flex;flex-direction:column;gap:.75rem}.record-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:.75rem;transition:box-shadow .2s}.record-card:hover{box-shadow:0 2px 4px #0000001a}.record-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.record-type{display:flex;align-items:center;gap:.5rem}.record-icon{font-size:1.25rem}.record-type-label{font-size:.875rem;font-weight:500;color:#374151}.record-actions{display:flex;gap:.25rem}.record-action-btn{background:none;border:none;cursor:pointer;padding:.25rem;border-radius:4px;transition:background-color .2s;font-size:.875rem}.record-action-btn:hover{background:#e5e7eb}.record-action-btn.edit{color:#3b82f6}.record-action-btn.delete{color:#dc2626}.record-content h5{margin:0 0 .375rem;font-size:1rem;font-weight:600;color:#1f2937}.record-text{margin:0 0 .5rem;color:#4b5563;line-height:1.5;font-size:.875rem}.record-meta{display:flex;flex-direction:column;gap:.25rem;font-size:.75rem;color:#6b7280}.record-date,.record-author{display:flex;align-items:center;gap:.25rem}.sidebar-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000}.sidebar-modal-content{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.sidebar-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb}.sidebar-modal-header h3{margin:0;font-size:1.125rem;font-weight:600;color:#1f2937}@media (max-width: 768px){.student-sidebar{width:100%}.detail-grid{grid-template-columns:1fr}.detail-item{flex-direction:column;align-items:flex-start;gap:.25rem}.detail-item span{text-align:left;margin-left:0}}.admin-content.sidebar-open{margin-right:800px;transition:margin-right .3s ease-in-out}@media (max-width: 1200px){.admin-content.sidebar-open{margin-right:0}.detail-grid{grid-template-columns:1fr}}.sidebar-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000004d;z-index:999;opacity:0;visibility:hidden;transition:opacity .3s ease-in-out,visibility .3s ease-in-out}.sidebar-backdrop.open{opacity:1;visibility:visible}.view-details-btn{width:100%;display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;background:#3b82f6;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background-color .3s}.view-details-btn:hover{background:#2563eb}@media (max-width: 768px){.hero-content h1{font-size:2.5rem}.nav-links{display:none!important}.mobile-menu-btn{display:flex!important}.user-widget{display:none}.navbar .container{padding:.5rem 1rem}.navbar .logo{font-size:1.2rem}.navbar .logo-image img{height:40px}.container{width:95%}section{padding:3rem 0}.location-cards,.class-cards,.pricing-cards{grid-template-columns:1fr}}@media (max-width: 480px){.hero-content h1{font-size:2rem}.navbar .logo{font-size:1rem}.navbar .logo-image img{height:35px}.container{width:98%}.mobile-menu-btn{font-size:1.2rem;width:35px;height:35px}}.user-widget{display:flex;align-items:center;gap:1rem;color:#fff;font-size:.9rem}.logout-btn{background:var(--accent);color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.8rem;transition:background-color .3s}.logout-btn:hover{background:#c4303d}.login-modal{max-width:400px}.login-modal h3{text-align:center;margin-bottom:1.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input{width:100%;padding:.75rem;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;transition:border-color .3s ease}.form-group input:focus{outline:none;border-color:var(--accent)}.login-btn{width:100%;background:var(--accent);color:#fff;padding:.75rem;border:none;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:background-color .3s ease;margin-top:1rem}.login-btn:hover{background:#c4303d}.error-message{background:#fee;color:#c53030;padding:.75rem;border-radius:4px;margin-top:1rem;font-size:.9rem}.demo-credentials{margin-top:1.5rem;padding:1rem;background:#f8f9fa;border-radius:8px;font-size:.9rem;color:#666}.demo-credentials p{margin:.25rem 0}.mobile-user-info{padding:1rem;border-top:1px solid rgba(255,255,255,.1);color:#fff;font-size:.9rem;text-align:center}.mobile-logout-btn{background:var(--accent);color:#fff;border:none;padding:.75rem 1rem;border-radius:25px;cursor:pointer;font-weight:500;transition:background-color .3s ease;width:100%;margin:0 1rem}.mobile-logout-btn:hover{background:#c4303d}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb;color:#111827}.min-h-screen{min-height:100vh}.max-w-7xl{max-width:80rem}.mx-auto{margin-left:auto;margin-right:auto}.px-4{padding-left:1rem;padding-right:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-8{padding-top:2rem;padding-bottom:2rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-4{padding-top:1rem;padding-bottom:1rem}.px-3{padding-left:.75rem;padding-right:.75rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.px-1{padding-left:.25rem;padding-right:.25rem}.p-6{padding:1.5rem}.p-4{padding:1rem}.mb-8{margin-bottom:2rem}.mb-6{margin-bottom:1.5rem}.mb-4{margin-bottom:1rem}.mb-2{margin-bottom:.5rem}.mb-12{margin-bottom:3rem}.mt-4{margin-top:1rem}.mt-2{margin-top:.5rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.ml-4{margin-left:1rem}.mr-3{margin-right:.75rem}.mr-2{margin-right:.5rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.flex-1{flex:1 1 0%}.space-x-2>*+*{margin-left:.5rem}.space-x-3>*+*{margin-left:.75rem}.space-x-4>*+*{margin-left:1rem}.space-x-8>*+*{margin-left:2rem}.space-y-3>*+*{margin-top:.75rem}.space-y-4>*+*{margin-top:1rem}.space-y-6>*+*{margin-top:1.5rem}.space-y-8>*+*{margin-top:2rem}.grid{display:grid}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3,.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.gap-4{gap:1rem}.bg-gray-50{background-color:#f9fafb}.bg-white{background-color:#fff}.bg-blue-600{background-color:#2563eb}.bg-blue-700{background-color:#1d4ed8}.bg-green-600{background-color:#16a34a}.bg-green-700{background-color:#15803d}.bg-red-50{background-color:#fef2f2}.bg-blue-50{background-color:#eff6ff}.bg-green-50{background-color:#f0fdf4}.bg-yellow-50{background-color:#fefce8}.bg-purple-50{background-color:#faf5ff}.bg-gray-100{background-color:#f3f4f6}.text-gray-900{color:#111827}.text-gray-600{color:#4b5563}.text-gray-500{color:#6b7280}.text-gray-700{color:#374151}.text-blue-600{color:#2563eb}.text-blue-700{color:#1d4ed8}.text-green-600{color:#16a34a}.text-green-700{color:#15803d}.text-red-600{color:#dc2626}.text-red-800{color:#991b1b}.text-blue-800{color:#1e40af}.text-green-800{color:#166534}.text-purple-800{color:#6b21a8}.text-yellow-500{color:#eab308}.text-yellow-600{color:#ca8a04}.text-white{color:#fff}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-gray-200{border-color:#e5e7eb}.border-transparent{border-color:transparent}.border-blue-500{border-color:#3b82f6}.border-b-2{border-bottom-width:2px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-full{border-radius:9999px}.rounded-t-md{border-top-left-radius:.375rem;border-top-right-radius:.375rem}.rounded-b-md{border-bottom-left-radius:.375rem;border-bottom-right-radius:.375rem}.shadow{box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.shadow-md{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.shadow-sm{box-shadow:0 1px 2px #0000000d}button{cursor:pointer}.inline-flex{display:inline-flex}.inline{display:inline}.w-full{width:100%}.w-12{width:3rem}.w-8{width:2rem}.w-4{width:1rem}.w-5{width:1.25rem}.h-12{height:3rem}.h-8{height:2rem}.h-6{height:1.5rem}.h-5{height:1.25rem}.h-4{height:1rem}.hover\:bg-blue-700:hover{background-color:#1d4ed8}.hover\:bg-green-700:hover{background-color:#15803d}.hover\:text-blue-700:hover{color:#1d4ed8}.hover\:text-red-600:hover{color:#dc2626}.hover\:text-blue-600:hover{color:#2563eb}.hover\:text-green-600:hover{color:#16a34a}.hover\:text-gray-700:hover{color:#374151}.hover\:border-gray-300:hover{border-color:#d1d5db}.hover\:shadow-lg:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{box-shadow:0 0 0 3px #3b82f680}.focus\:ring-blue-500:focus{box-shadow:0 0 0 3px #3b82f680}.focus\:border-blue-500:focus{border-color:#3b82f6}.focus\:z-10:focus{z-index:10}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-shadow{transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}@media (min-width: 768px){.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:text-sm{font-size:.875rem;line-height:1.25rem}}@media (min-width: 1024px){.lg\:px-8{padding-left:2rem;padding-right:2rem}}.whitespace-nowrap{white-space:nowrap}.overflow-x-auto{overflow-x:auto}.divide-y>*+*{border-top-width:1px;border-color:#e5e7eb}.divide-gray-200>*+*{border-color:#e5e7eb}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.group:hover .group-hover\:translate-x-1>*{transform:translate(.25rem)}.group:hover .group-hover\:text-blue-700>*{color:#1d4ed8}.group:hover .group-hover\:text-green-700>*{color:#15803d}nav{background-color:#fff;box-shadow:0 1px 2px #0000000d;border-bottom:1px solid #e5e7eb}nav .flex{display:flex;justify-content:space-between;align-items:center;height:4rem}nav .flex>div{display:flex;align-items:center}nav .flex>div:last-child{gap:1rem}table{width:100%;border-collapse:collapse}th{background-color:#f9fafb;padding:.75rem 1.5rem;text-align:left;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:#6b7280}td{padding:1rem 1.5rem;background-color:#fff}tr{border-bottom:1px solid #e5e7eb}input{width:100%;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;line-height:1.25rem}input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}a{text-decoration:none;color:inherit}a:hover{text-decoration:none}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:#f9fafb;padding:3rem 1rem}.login-form{max-width:28rem;width:100%}.login-header{text-align:center;margin-bottom:2rem}.login-icon{margin:0 auto;height:3rem;width:3rem;display:flex;align-items:center;justify-content:center;border-radius:9999px;background-color:#dbeafe}.login-title{margin-top:1.5rem;font-size:1.875rem;line-height:2.25rem;font-weight:800;color:#111827}.login-subtitle{margin-top:.5rem;font-size:.875rem;line-height:1.25rem;color:#6b7280}.form-group{margin-bottom:1.5rem}.form-inputs{border-radius:.375rem;box-shadow:0 1px 2px #0000000d;margin-bottom:1.5rem}.form-inputs input:first-child{border-top-left-radius:.375rem;border-top-right-radius:.375rem;border-bottom-left-radius:0;border-bottom-right-radius:0}.form-inputs input:last-child{border-top-left-radius:0;border-top-right-radius:0;border-bottom-left-radius:.375rem;border-bottom-right-radius:.375rem}.form-inputs input:not(:first-child):not(:last-child){border-radius:0}.submit-button{width:100%;display:flex;justify-content:center;align-items:center;padding:.5rem 1rem;border:1px solid transparent;font-size:.875rem;font-weight:500;border-radius:.375rem;color:#fff;background-color:#2563eb;transition:background-color .15s}.submit-button:hover:not(:disabled){background-color:#1d4ed8}.submit-button:disabled{opacity:.5;cursor:not-allowed}.demo-credentials{text-align:center;font-size:.875rem;color:#6b7280;margin-top:1.5rem}.demo-credentials p{margin-bottom:.25rem}.demo-credentials strong{font-weight:600}.error-message{border-radius:.375rem;background-color:#fef2f2;padding:1rem;margin-bottom:1.5rem}.error-message .flex{display:flex}.error-message .flex>div:last-child{margin-left:.75rem}.error-message h3{font-size:.875rem;font-weight:500;color:#991b1b}.loading-spinner{text-align:center;padding:3rem 1rem}.spinner{margin:0 auto;height:3rem;width:3rem;border:2px solid transparent;border-bottom-color:#2563eb;border-radius:9999px;animation:spin 1s linear infinite}.loading-text{margin-top:1rem;color:#6b7280}.card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;padding:1.5rem;transition:box-shadow .15s}.card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.card-title{font-size:1.125rem;font-weight:600;color:#111827}.card-icon{height:2rem;width:2rem;color:#2563eb}.card-icon.green{color:#16a34a}.card-icon.yellow{color:#eab308}.card-content{margin-bottom:1.5rem}.card-footer{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:1px solid transparent;font-size:.875rem;font-weight:500;border-radius:.375rem;color:#fff;background-color:#2563eb;transition:background-color .15s;text-decoration:none}.card-footer:hover{background-color:#1d4ed8}.tab-nav{border-bottom:1px solid #e5e7eb;margin-bottom:2rem}.tab-nav nav{display:flex;gap:2rem;background:none;box-shadow:none;border:none}.tab-nav button{padding:.5rem .25rem;border-bottom:2px solid transparent;font-size:.875rem;font-weight:500;background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:.5rem}.tab-nav button.active{border-bottom-color:#3b82f6;color:#2563eb}.tab-nav button:not(.active){color:#6b7280}.tab-nav button:not(.active):hover{color:#374151;border-bottom-color:#d1d5db}.table-container{background-color:#fff;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border-radius:.5rem}.table-header{padding:1.5rem;border-bottom:1px solid #e5e7eb}.table-header .flex{display:flex;align-items:center;justify-content:space-between}.table-title{font-size:1.125rem;font-weight:500;color:#111827}.add-button{display:inline-flex;align-items:center;padding:.5rem 1rem;border:1px solid transparent;font-size:.875rem;font-weight:500;border-radius:.375rem;color:#fff;background-color:#2563eb;text-decoration:none}.add-button:hover{background-color:#1d4ed8}.status-badge{display:inline-flex;padding:.25rem .5rem;font-size:.75rem;font-weight:600;border-radius:9999px}.status-badge.disabled{background-color:#fef2f2;color:#dc2626}.status-badge.member{background-color:#eff6ff;color:#2563eb}.status-badge.admin{background-color:#f0fdf4;color:#16a34a}.status-badge.unknown{background-color:#f3f4f6;color:#4b5563}.action-button{font-size:.875rem;font-weight:500;background:none;border:none;cursor:pointer;margin-right:.75rem}.action-button.edit{color:#2563eb}.action-button.edit:hover{color:#1d4ed8}.action-button.delete{color:#dc2626}.action-button.delete:hover{color:#b91c1c}.empty-state{text-align:center;padding:3rem 1.5rem}.empty-state-icon{margin:0 auto;height:3rem;width:3rem;color:#9ca3af}.empty-state-title{margin-top:.5rem;font-size:.875rem;font-weight:500;color:#111827}.empty-state-description{margin-top:.25rem;font-size:.875rem;color:#6b7280}.student-tabs{border-bottom:1px solid #e5e7eb;margin-bottom:2rem}.student-tabs nav{display:flex;gap:2rem;background:none;box-shadow:none;border:none}.student-tabs button{padding:.5rem .25rem;border-bottom:2px solid transparent;font-size:.875rem;font-weight:500;background:none;border:none;cursor:pointer}.student-tabs button.active{border-bottom-color:#3b82f6;color:#2563eb}.student-tabs button:not(.active){color:#6b7280}.student-tabs button:not(.active):hover{color:#374151;border-bottom-color:#d1d5db}.record-badge{display:inline-flex;padding:.25rem .5rem;font-size:.75rem;font-weight:600;border-radius:9999px}.record-badge.grading{background-color:#f0fdf4;color:#166534}.record-badge.training{background-color:#eff6ff;color:#1e40af}.record-badge.event{background-color:#faf5ff;color:#6b21a8}.record-badge.default{background-color:#f3f4f6;color:#374151}.back-button{display:inline-flex;align-items:center;font-size:.875rem;color:#2563eb;text-decoration:none;margin-bottom:1rem}.back-button:hover{color:#1d4ed8}.student-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.student-info h1{font-size:1.875rem;font-weight:700;color:#111827}.student-info p{color:#6b7280}.student-grade{text-align:right}.student-grade .flex{display:flex;align-items:center;gap:.5rem}.student-grade .grade-title{font-size:1.125rem;font-weight:600;color:#111827}.student-grade .grade-date{font-size:.875rem;color:#6b7280}.licence-expired{color:#dc2626}.licence-expired:after{content:" (EXPIRED)"}@media (min-width: 768px){.responsive-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1024px){.responsive-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.home-container{padding:3rem 0}.home-header{text-align:center;margin-bottom:3rem}.home-title{font-size:2.25rem;font-weight:700;color:#111827;margin-bottom:1rem}.home-subtitle{font-size:1.25rem;color:#6b7280}.home-grid{display:grid;gap:2rem;max-width:64rem;margin:0 auto}@media (min-width: 768px){.home-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.home-card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;padding:1.5rem;transition:box-shadow .15s;text-decoration:none;color:inherit}.home-card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.home-card-header{display:flex;align-items:center;margin-bottom:1rem}.home-card-icon{height:2rem;width:2rem;margin-right:.75rem}.home-card-icon.blue{color:#2563eb}.home-card-icon.green{color:#16a34a}.home-card-title{font-size:1.25rem;font-weight:600;color:#111827}.home-card-content{margin-bottom:1rem;color:#6b7280}.home-card-footer{display:flex;align-items:center;color:#2563eb;font-weight:500}.home-card-footer:hover{color:#1d4ed8}.home-card-footer .arrow{margin-left:.5rem;transition:transform .15s}.home-card:hover .arrow{transform:translate(.25rem)}.signin-button{display:inline-flex;align-items:center;padding:.75rem 1.5rem;border:1px solid transparent;font-size:1rem;font-weight:500;border-radius:.375rem;color:#fff;background-color:#2563eb;text-decoration:none;margin-top:2rem}.signin-button:hover{background-color:#1d4ed8}.signin-button .arrow{margin-left:.5rem}
