:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--bg-light);cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--primary-red: #FF5F5E;--header-grey: #2A2A2A73;--bg-light: #FFFFFF;--text-dark: #595959;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:var(--text-dark);background-color:var(--bg-light);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background-color:var(--bg-light);color:var(--text-dark);overflow-x:hidden;width:100vw;position:relative}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center;width:100%}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.read-the-docs{color:#888}button{font-family:inherit;cursor:pointer;transition:all .2s ease}.btn-primary,.save-btn,.create-event-btn,.book-btn{background-color:var(--primary-red);color:#fff;border:none;padding:10px 20px;border-radius:6px;font-weight:500;box-shadow:0 2px 4px #ff5f5e33}.btn-primary:hover,.save-btn:hover,.create-event-btn:hover,.book-btn:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 4px 8px #ff5f5e4d}.btn-secondary,.cancel-btn,.view-details-btn{background-color:#fff;color:var(--text-dark);border:1px solid #ddd;padding:8px 16px;border-radius:6px}.btn-secondary:hover,.cancel-btn:hover,.view-details-btn:hover{background-color:#f8f8f8;border-color:#ccc}.tabs{display:flex;margin-bottom:25px;gap:10px;justify-content:center;flex-wrap:wrap}.tabs button{padding:10px 24px;background-color:#fff;color:var(--text-dark);border:1px solid #e0e0e0;border-radius:20px;font-weight:500;font-size:.95rem}.tabs button:hover{background-color:#fff0f0;border-color:var(--primary-red);color:var(--primary-red)}.tabs button.active{background-color:var(--primary-red);color:#fff;border-color:var(--primary-red);box-shadow:0 2px 8px #ff5f5e40}.card form{display:flex;flex-direction:column;gap:15px;max-width:400px;margin:0 auto}.card form div{display:flex;flex-direction:column;text-align:left}.attendance-view{display:flex;gap:20px;align-items:flex-start;text-align:left;flex-direction:column}@media(min-width:768px){.attendance-view{flex-direction:row}}.schedule-list{flex:1;width:100%}.attendance-form{flex:2;background-color:#fff;border:1px solid #eee;border-radius:8px;padding:20px;width:100%;box-sizing:border-box}.attendance-form h3{margin-top:0}.form-group{display:flex;flex-direction:column;gap:15px;margin-top:20px}.form-group select,.form-group textarea,.form-group input{padding:10px;background-color:#fff;border:1px solid #ccc;color:var(--text-dark);border-radius:4px;font-family:inherit}.form-group textarea{min-height:80px;resize:vertical}.schedule-list,.schedule-list ul{list-style:none;padding:0;margin:0}.schedule-list li{padding:15px;cursor:pointer;border-bottom:1px solid #eee;transition:background-color .2s;background-color:#fff}.schedule-list li:hover{background-color:#fff;border-left:4px solid var(--primary-red)}.admin-dashboard-container{display:flex;gap:20px;flex-direction:column;width:100%;max-width:1200px;margin:0 auto;text-align:left;box-sizing:border-box;overflow-x:hidden}@media(min-width:768px){.admin-dashboard-container{flex-direction:row;height:80vh}}.teacher-list-panel{flex:1;min-width:250px;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;width:100%;max-width:100%}.teacher-detail-panel{flex:3;overflow-y:auto;display:flex;flex-direction:column;width:100%;max-width:100%}.teacher-detail-panel .tabs{justify-content:flex-start;flex-wrap:wrap}.user-list-table{width:100%;border-collapse:collapse;margin-top:20px}.list-item-content{display:flex;justify-content:space-between;align-items:flex-start;width:100%}.list-item-content>div:first-child{flex:1;min-width:0;padding-right:10px;word-break:break-word;overflow-wrap:break-word}@media(max-width:480px){.list-item-content{flex-direction:column;gap:10px}}.user-list-table th,.user-list-table td{padding:12px;text-align:left;border-bottom:1px solid #eee}.user-list-table th{background-color:#f5f5f5;color:var(--text-dark)}.roster-table{width:100%;border-collapse:collapse}.roster-table th,.roster-table td{padding:12px;text-align:left;border-bottom:1px solid #eee}.roster-table th{background-color:#f5f5f5}.level-select{padding:8px 12px;border-radius:4px;background-color:#fff;color:var(--text-dark);border:1px solid #ccc;width:100%;max-width:250px;cursor:pointer}.level-select:focus{outline:none;border-color:var(--primary-red)}.events-container{padding:20px}.event-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:10px}.create-event-btn{background-color:var(--primary-red);color:#fff;padding:10px 20px;border:none;border-radius:8px;cursor:pointer;font-size:1rem}.events-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.event-card{background-color:#fff;border:1px solid #eee;border-radius:8px;padding:20px;display:flex;flex-direction:column;box-shadow:0 2px 4px #0000000d}.event-card h3{margin-top:0;color:var(--text-dark)}.event-info p{margin:5px 0;color:#666}.event-actions{margin-top:auto;padding-top:15px;display:flex;gap:10px}.view-details-btn{background-color:#fff;color:var(--text-dark);padding:8px 16px;border:1px solid #ccc;border-radius:4px;cursor:pointer;width:100%}.view-details-btn:hover{background-color:#f9f9f9}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#fff;padding:30px;border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;border:none;box-shadow:0 10px 25px #0003}.modal-content h2{margin-top:0;margin-bottom:20px;border-bottom:1px solid #eee;padding-bottom:10px;color:var(--text-dark)}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:8px;color:#555;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px;border-radius:6px;border:1px solid #ccc;background-color:#fff;color:var(--text-dark)}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:25px}.cancel-btn{background-color:transparent;color:#666;border:1px solid #ccc;padding:8px 16px;border-radius:4px;cursor:pointer}.save-btn{background-color:var(--primary-red);color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer}.dashboard-container{max-width:1200px;margin:0 auto;padding:20px;width:100%;box-sizing:border-box}.table-container{display:flex;justify-content:center;width:100%;margin-top:20px;overflow-x:auto}.admin-table,.roster-table,.user-list-table{width:100%;border-collapse:separate;border-spacing:0;background-color:transparent;box-shadow:none;margin-top:20px}.admin-table th,.roster-table th,.user-list-table th{background-color:#f8f8f8;color:var(--text-dark);padding:18px 25px;text-align:center;font-weight:600;border-bottom:2px solid #eee;letter-spacing:.5px}.admin-table td,.roster-table td,.user-list-table td{padding:15px 25px;color:var(--text-dark);border-bottom:1px solid #eee;text-align:center;vertical-align:middle}.admin-table tr:hover,.roster-table tr:hover,.user-list-table tr:hover{background-color:#f9f9f9;transition:background-color .2s ease;cursor:default}.status-badge{padding:4px 8px;border-radius:12px;font-size:.85em;font-weight:700;text-transform:capitalize}.status-badge.present{background-color:#28a7451a;color:#28a745;border:1px solid #28a745}.status-badge.absent{background-color:#dc35451a;color:#dc3545;border:1px solid #dc3545}.status-badge.late{background-color:#ffc1071a;color:#e0a800;border:1px solid #ffc107}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:60px;background-color:#fff;border-top:1px solid #ddd;justify-content:space-around;align-items:center;z-index:9999;padding-bottom:env(safe-area-inset-bottom)}@media(max-width:768px){.tabs,.admin-tabs{display:none!important}.bottom-nav{display:flex!important}.more-menu-overlay{position:fixed;inset:0 0 60px;background-color:#00000080;z-index:999;display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-end;padding-bottom:20px;padding-right:20px}.more-menu-content{background-color:#fff;border-radius:12px;padding:10px;display:flex;flex-direction:column;gap:10px;box-shadow:0 4px 15px #0003;min-width:150px;border:1px solid #eee;animation:slideUp .2s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.more-menu-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:none;border:none;border-radius:8px;width:100%;text-align:left;color:var(--text-dark);font-weight:500}.more-menu-item:hover{background-color:#f5f5f5}.more-menu-item.active{background-color:#fff0f0;color:var(--primary-red)}body{padding-bottom:80px}.dashboard-container{padding:10px}h1{font-size:1.5rem}h2{font-size:1.25rem}h3{font-size:1.1rem}.admin-table,.roster-table,.user-list-table{background:transparent;box-shadow:none;display:block;width:100%}.admin-table thead,.roster-table thead,.user-list-table thead{display:none}.admin-table tbody,.roster-table tbody,.user-list-table tbody{display:block;width:100%}.admin-table tr,.roster-table tr,.user-list-table tr{background-color:#fff;border-radius:8px;box-shadow:0 2px 5px #0000000d;border:1px solid #eee;display:flex;flex-direction:column;margin-bottom:15px;padding:15px}.admin-table td,.roster-table td,.user-list-table td{display:block;text-align:left;padding:5px 0;border:none;font-size:.95rem}}.profile-header{display:flex;justify-content:space-between;align-items:center;padding:10px 20px;background-color:#2a2a2a;background-color:#2a2a2a73;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);box-shadow:0 2px 4px #0000001a;margin-bottom:20px;color:#fff;border-radius:6px}.header-logo{height:60px;width:auto}.header-right.desktop-only{display:flex;align-items:center;gap:20px}.header-info{display:flex;flex-direction:column;text-align:right;line-height:1.2}.header-name{font-weight:600;color:#fff}.header-role-badge{font-size:.8rem;color:#333;background-color:#ffffffe6;padding:2px 8px;border-radius:12px;align-self:flex-end}.header-logout-btn{background-color:transparent;color:#fff;border:1px solid rgba(255,255,255,.5);padding:6px 14px;border-radius:6px;font-size:.9rem}.header-logout-btn:hover{background-color:#ffffff1a;border-color:#fff}.header-right.mobile-only{display:none}@media(max-width:768px){.profile-header{padding:10px;height:auto}.header-logo{height:40px}.header-right.desktop-only{display:none}.header-right.mobile-only{display:flex;flex:1;justify-content:flex-end}.header-pills-row{display:flex;gap:8px;align-items:center}.header-pill{background-color:#fff3;color:#fff;padding:6px 12px;border-radius:20px;font-size:.8rem;font-weight:600;white-space:nowrap;box-shadow:0 1px 2px #0000001a;border:1px solid rgba(255,255,255,.1)}.id-pill{background-color:#ffffff1a}}.mobile-only-logout{display:none}@media(max-width:768px){.mobile-only-logout{display:block;padding-bottom:20px}}.mobile-view{display:block}.desktop-view{display:none}@media(min-width:768px){.mobile-view{display:none}.desktop-view{display:block}@keyframes mobileModalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes mobileModalSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.mobile-modal-overlay{animation:mobileModalFadeIn .2s ease-out forwards}.mobile-modal-content{animation:mobileModalSlideUp .3s cubic-bezier(.16,1,.3,1) forwards}}@media(min-width:768px){.admin-dashboard-container.desktop-view{display:flex!important;align-items:flex-start;gap:20px;background-color:transparent;box-shadow:none}.teacher-list-panel{flex:1;min-width:300px}.teacher-detail-panel{flex:2;margin-top:0;animation:fadeIn .3s ease}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}
