.mondo-header{background:#fff;min-height:55px;position:sticky;top:0;z-index:1000}.mondo-header-inner{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1000px;padding:8px 0;width:86%}.mondo-header-inner.page-style{max-width:1000px;padding:0;width:86%}.mondo-header-inner.badge-mode{width:90%}.mondo-header-logo{align-items:center;display:flex}.mondo-header-logo img{height:auto;margin-bottom:0;margin-top:5px;width:250px}.mondo-header-logo.badge-mode img{width:200px}.mondo-header-nav{align-items:center;display:flex;gap:2rem}.mondo-header-nav a{color:#717b87;font-family:Oxygen,sans-serif;font-size:13px;font-weight:400;letter-spacing:.1em;text-decoration:none;text-transform:uppercase;transition:color .2s;white-space:nowrap}.mondo-header-nav a:first-child{color:#595959;font-weight:700}.mondo-header-nav a:hover{color:#4b4950}.mondo-header-nav .nav-active{color:#4b4950;font-weight:700}.mondo-header-badge{color:#919191;font-family:Oxygen,sans-serif;font-size:11px;font-weight:700;letter-spacing:.091em;padding:8px 12px;text-transform:uppercase}.mondo-header-yellow-bar{background-color:#ffc53b;height:7px;margin:0;padding:0}@media (max-width:768px){.mondo-header-inner{flex-direction:column;gap:1rem;padding:1rem 0;width:90%}.mondo-header-inner.page-style{padding:1.5rem 0}.mondo-header-logo img{width:180px}.mondo-header-nav{flex-wrap:wrap;gap:1.2rem;justify-content:center}.mondo-header-nav a{font-size:14px}.mondo-header-logo.badge-mode img{width:160px}}@media (max-width:480px){.mondo-header-logo img{width:160px}.mondo-header-nav{gap:.8rem}.mondo-header-nav a{align-items:center;display:flex;font-size:13px;min-height:44px;padding:8px 4px}}@media (max-width:375px){.mondo-header-inner{width:95%}.mondo-header-logo img{width:140px}.mondo-header-nav{gap:.6rem;width:100%}.mondo-header-nav a{flex:1 1;font-size:12px;justify-content:center;text-align:center}}@media (max-width:768px){.mondo-header-nav a:active{background:#0000000d;border-radius:4px}}.mondo-header nav a,.mondo-header nav a:active,.mondo-header nav a:hover,.mondo-header nav a:link,.mondo-header nav a:visited{text-decoration:none}.mondo-footer{background-color:#ffc53b;margin-top:2rem;padding:2rem 0;width:100%}.mondo-footer-content{margin:0 auto;max-width:1000px;text-align:center;width:86%}.social-links{display:flex;gap:1.5rem;justify-content:center;margin-bottom:1.5rem}.social-links a{align-items:center;background:#fff3;border-radius:50%;color:#fff;display:inline-flex;height:40px;justify-content:center;text-decoration:none;transition:background .2s,transform .2s;width:40px}.social-links a:hover{background:#ffffff4d;transform:scale(1.1)}.social-icon{fill:currentColor;height:20px;width:20px}.footer-text{margin-bottom:1rem}.copyright{color:#fff;font-size:14px;margin:0 0 .5rem}.copyright,.copyright br{line-height:1.8}.attribution{color:#fffc;font-size:12px;font-style:italic;margin:0}.footer-links{border-top:1px solid #fff3;margin-top:1rem;padding-top:1rem}.footer-links a{color:#fff;font-size:12px;text-decoration:none;transition:opacity .2s}.footer-links a:hover{opacity:.8}.footer-links span{color:#fff9}@media (max-width:1024px){.mondo-footer-content{width:90%}}@media (max-width:600px){.social-links{gap:1rem}.footer-links,.footer-links a{font-size:10px}}.mondo-auth-title{background:#fffc!important;border-radius:8px;box-shadow:0 2px 8px #00000026;padding:15px 20px!important}@media (min-width:769px){.mondo-auth-layout{background-position:center -27px!important}}@media (max-width:768px){.mondo-auth-layout{background-position:16% -27px!important;background-size:1600px auto!important}}.mondo-legal-page{background:#eff2f4;color:#717b87;font-family:Oxygen,sans-serif;font-size:14px;min-height:100vh}.mondo-legal-container{margin:0 auto;max-width:1000px;padding:0;width:86%}.mondo-legal-content{margin:0;padding:0;text-align:center}.mondo-legal-title{color:#4b4950;font-family:Lato,sans-serif;font-size:1.75rem;font-weight:300;letter-spacing:-.019em;line-height:1.4;margin-bottom:.5rem;margin-top:0;padding:2rem 0 0;text-transform:uppercase}.mondo-legal-intro{margin:0;padding:20px 0}.mondo-legal-intro p{color:#717b87;font-family:Oxygen,sans-serif;font-size:14px;font-weight:400;line-height:1.4;margin:0}.mondo-legal-details{padding:20px 0;text-align:center}.mondo-legal-details p{color:#717b87;font-family:Oxygen,sans-serif;font-size:14px;font-weight:400;line-height:1.4;margin:0 0 .3rem}@media (min-width:769px){.mondo-legal-container{max-width:none;width:100%}.mondo-legal-content{align-items:flex-end;display:flex;flex-direction:column;gap:1.5rem;padding-right:5%;padding-top:2rem}.mondo-legal-title{background:#fffc;padding:15px 20px}.mondo-legal-details,.mondo-legal-intro,.mondo-legal-title{border-radius:8px;box-shadow:0 2px 8px #00000026;width:400px}.mondo-legal-details,.mondo-legal-intro{background:#ffffffd9;padding:20px 30px}.mondo-legal-intro p{max-width:340px}.mondo-legal-details a,.mondo-legal-details p,.mondo-legal-intro p{color:#4b4950}.mondo-legal-details{margin-bottom:100px}}.mondo-legal-details p:last-child{margin-bottom:0}.mondo-legal-info{margin-top:1rem}.mondo-legal-contact-methods{margin-top:.5rem}.mondo-legal-details a{color:#717b87;text-decoration:underline;transition:color .2s}.mondo-legal-details a:hover{color:#4b4950}@media (max-width:768px){.mondo-legal-container{padding-top:2rem;width:90%}.mondo-legal-title{display:inline-block;padding:15px 20px}.mondo-legal-details,.mondo-legal-intro,.mondo-legal-title{background:#fffc;border-radius:8px;box-shadow:0 2px 8px #00000026}.mondo-legal-details,.mondo-legal-intro{margin:20px 0;padding:20px}.mondo-legal-details p,.mondo-legal-intro p{color:#4b4950;font-size:16px}}.mondo-faq{font-family:Lato,sans-serif;margin:0 auto;max-width:1024px;padding:20px}.mondo-faq-header{margin-bottom:30px;text-align:center}.mondo-faq-header h1{color:#2d5016;font-size:2rem;font-weight:300;margin-bottom:10px}.mondo-faq-subtitle{color:#666;font-size:1rem;margin:0}.mondo-faq-controls{margin-bottom:20px}.mondo-faq-search{margin-bottom:15px;position:relative}.mondo-faq-search-input{border:2px solid #ddd;border-radius:8px;font-family:Lato,sans-serif;font-size:16px;padding:12px 40px 12px 15px;transition:border-color .3s;width:100%}.mondo-faq-search-input:focus{border-color:#2d5016;outline:none}.mondo-faq-clear-search{background:#0000;border:none;color:#999;cursor:pointer;font-size:20px;padding:5px 10px;position:absolute;right:10px;top:50%;transform:translateY(-50%);transition:color .2s}.mondo-faq-clear-search:hover{color:#333}.mondo-faq-expand-buttons{display:flex;gap:10px;justify-content:center}.mondo-faq-expand-btn{background:#f5f5f5;border:1px solid #ddd;border-radius:5px;cursor:pointer;font-family:Lato,sans-serif;font-size:14px;padding:8px 16px;transition:all .2s}.mondo-faq-expand-btn:hover{background:#2d5016;border-color:#2d5016;color:#fff}.mondo-faq-results-count{color:#666;font-size:14px;font-style:italic;margin-bottom:15px;text-align:center}.mondo-faq-sections{margin-bottom:30px}.mondo-faq-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:20px;overflow:hidden}.mondo-faq-section-header{align-items:center;background:#f9f9f9;border:none;cursor:pointer;display:flex;font-family:Lato,sans-serif;justify-content:space-between;padding:15px 20px;transition:background .2s;width:100%}.mondo-faq-section-header:hover{background:#f0f0f0}.mondo-faq-section-header.expanded{background:#2d5016}.mondo-faq-section-header h2{color:#333;font-size:1.2rem;font-weight:600;margin:0;text-align:left}.mondo-faq-section-header.expanded h2{color:#fff}.mondo-faq-section-icon{color:#666;font-size:24px;font-weight:700;transition:transform .3s}.mondo-faq-section-header.expanded .mondo-faq-section-icon{color:#fff}.mondo-faq-questions{padding:10px}.mondo-faq-question-item{border:1px solid #e8e8e8;border-radius:5px;margin-bottom:10px;overflow:hidden;transition:box-shadow .3s}.mondo-faq-question-item.highlight{animation:highlightPulse .5s ease-in-out;box-shadow:0 0 0 3px #2d50164d}@keyframes highlightPulse{0%,to{box-shadow:0 0 0 3px #2d50164d}50%{box-shadow:0 0 0 6px #2d501633}}.mondo-faq-question{align-items:flex-start;background:#fff;border:none;cursor:pointer;display:flex;font-family:Lato,sans-serif;gap:10px;padding:15px;text-align:left;transition:background .2s;width:100%}.mondo-faq-question:hover{background:#f9f9f9}.mondo-faq-question.expanded{background:#f5f5f5;border-bottom:1px solid #e0e0e0}.mondo-faq-question-number{color:#2d5016;flex-shrink:0;font-weight:600}.mondo-faq-question-text{color:#333;flex:1 1;font-size:16px;font-weight:500;line-height:1.4}.mondo-faq-question-icon{color:#999;flex-shrink:0;font-size:12px;margin-top:3px}.mondo-faq-answer{background:#fafafa;border-top:1px solid #e0e0e0;padding:15px 20px}.mondo-faq-answer p{color:#555;font-size:14px;line-height:1.6;margin:0 0 15px}.mondo-faq-copy-link{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-family:Lato,sans-serif;font-size:13px;padding:6px 12px;transition:all .2s}.mondo-faq-copy-link:hover{background:#2d5016;border-color:#2d5016;color:#fff}mark{background-color:#ffeb3b;border-radius:2px;font-weight:600;padding:2px 4px}.mondo-faq-no-results{color:#666;padding:40px 20px;text-align:center}.mondo-faq-no-results p{font-size:16px;margin:10px 0}.mondo-faq-footer{background:#f9f9f9;border-radius:8px;margin-top:40px;padding:30px 20px;text-align:center}.mondo-faq-footer h3{color:#2d5016;font-size:1.3rem;font-weight:600;margin-bottom:10px}.mondo-faq-footer p{color:#555;font-size:15px;line-height:1.6;margin:10px 0}.mondo-faq-footer-note{border-top:1px solid #e0e0e0;color:#777;font-size:14px;margin-top:15px;padding-top:15px}@media (max-width:768px){.mondo-faq{padding:15px}.mondo-faq-header h1{font-size:1.5rem}.mondo-faq-section-header{padding:12px 15px}.mondo-faq-section-header h2{font-size:1rem}.mondo-faq-question{padding:12px}.mondo-faq-question-text{font-size:15px}.mondo-faq-answer{padding:12px 15px}.mondo-faq-expand-buttons{flex-direction:column}.mondo-faq-expand-btn{width:100%}}@media (max-width:480px){.mondo-faq-header h1{font-size:1.3rem}.mondo-faq-subtitle{font-size:.9rem}.mondo-faq-question-text{font-size:14px}.mondo-faq-answer p{font-size:13px}}.today-schedule{background:#f5f7fa;min-height:100vh;padding-bottom:80px}.schedule-header{background:linear-gradient(135deg,#2d5016,#1a300d);box-shadow:0 2px 8px #0000001a;color:#fff;padding:24px 20px}.schedule-header h1{font-size:28px;font-weight:700;margin:0 0 8px}.schedule-date{font-size:16px;margin:0 0 4px;opacity:.9}.coach-name{font-size:14px;margin:0;opacity:.8}.empty-state{padding:60px 20px;text-align:center}.empty-icon{font-size:80px;margin-bottom:20px}.empty-state h2{color:#333;font-size:24px;margin:0 0 8px}.empty-state p{color:#666;font-size:16px;margin:0}.courses-list{padding:16px}.course-card{background:#fff;border-left:4px solid #ddd;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:16px;padding:20px;transition:all .2s ease}.course-card:active{transform:scale(.98)}.course-card.completed{border-left-color:#28a745}.course-card.pending{border-left-color:#ffc107}.course-card.current{border-left-color:#007bff;box-shadow:0 4px 12px #007bff33}.course-card.upcoming{border-left-color:#6c757d}.course-header{border-bottom:1px solid #eee;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.course-header,.course-time{align-items:center;display:flex}.course-time{gap:8px}.status-icon{font-size:20px}.time-text{color:#333;font-size:18px;font-weight:600}.training-group{background:#e8f5e9;border-radius:20px;color:#2d5016;font-size:14px;font-weight:600;padding:6px 12px}.course-info{margin-bottom:16px}.info-item{align-items:center;display:flex;font-size:15px;justify-content:space-between;padding:8px 0}.info-label{color:#666;font-weight:500}.info-value{color:#333;font-weight:600}.info-item.warning .info-label,.info-item.warning .info-value{color:#ff6b00}.attendance-marked{align-items:center;background:#d4edda;border-radius:8px;color:#155724;display:inline-flex;font-size:14px;font-weight:600;gap:6px;margin-top:8px;padding:8px 12px}.course-actions{display:flex;gap:12px}.mark-button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:16px;font-weight:600;height:52px;justify-content:center;transition:all .2s ease}.mark-button.primary{background:linear-gradient(135deg,#2d5016,#1a300d);box-shadow:0 4px 12px #2d50164d;color:#fff}.mark-button.primary:active{box-shadow:0 2px 6px #2d50164d;transform:translateY(1px)}.mark-button.secondary{background:#fff;border:2px solid #2d5016;color:#2d5016}.mark-button.secondary:active{background:#f5f7fa}.mark-button.disabled{background:#e0e0e0;color:#999;cursor:not-allowed}@media (max-width:480px){.schedule-header{padding:20px 16px}.schedule-header h1{font-size:24px}.courses-list{padding:12px}.course-card{padding:16px}.course-actions{flex-direction:column}.mark-button{width:100%}}.mark-attendance{background:#f5f7fa;min-height:100vh;padding-bottom:100px}.attendance-header{background:linear-gradient(135deg,#2d5016,#1a300d);box-shadow:0 2px 8px #0000001a;color:#fff;padding:16px 20px 24px}.back-button{align-items:center;background:#0000;border:none;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:4px;margin-bottom:12px;padding:8px 0}.header-info h1{font-size:24px;font-weight:700;margin:0 0 4px}.course-info{font-size:15px;margin:0;opacity:.9}.attendance-summary{padding:20px}.summary-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:20px;text-align:center}.summary-label{color:#666;font-size:14px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.summary-value{color:#2d5016;font-size:36px;font-weight:700}.message{border-radius:8px;font-size:14px;font-weight:600;margin:0 20px 16px;padding:12px 16px;text-align:center}.error-message{background:#fff5f5;border:1px solid #feb2b2;color:#c53030}.success-message{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.students-list{padding:0 20px 20px}.student-item{align-items:center;background:#fff;border:2px solid #0000;border-radius:12px;box-shadow:0 2px 6px #0000000f;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:12px;padding:16px;transition:all .2s ease}.student-item:active{transform:scale(.98)}.student-item.present{background:#f0fff4;border-color:#28a745}.student-item.absent{border-color:#ddd}.student-item.absent_notified{background:#fffbf0;border-color:#ffc107}.student-info{flex:1 1}.student-name{color:#333;font-size:16px;font-weight:600;margin-bottom:4px}.student-meta{align-items:center;color:#666;display:flex;font-size:14px;gap:8px}.absence-badge{color:#ff6b00;font-size:12px;font-weight:600}.checkbox-container{flex-shrink:0;margin-left:12px}.checkbox{align-items:center;background:#fff;border:2px solid #ddd;border-radius:8px;display:flex;font-size:18px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.checkbox.checked,.student-item.present .checkbox{background:#28a745;border-color:#28a745;color:#fff}.attendance-actions{background:#fff;bottom:0;box-shadow:0 -2px 8px #0000001a;display:flex;gap:12px;left:0;padding:16px 20px;position:fixed;right:0;z-index:100}.action-button{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;height:52px;transition:all .2s ease}.action-button.primary{background:linear-gradient(135deg,#2d5016,#1a300d);box-shadow:0 4px 12px #2d50164d;color:#fff}.action-button.primary:active{transform:translateY(1px)}.action-button.secondary{background:#fff;border:2px solid #ddd;color:#666}.action-button.secondary:active{background:#f5f7fa}.action-button:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:480px){.attendance-header{padding:12px 16px 20px}.header-info h1{font-size:20px}.attendance-summary{padding:16px}.students-list{padding:0 16px 16px}.student-item{padding:14px}.attendance-actions{padding:12px 16px}}.coach-stats{background:#f5f7fa;min-height:100vh;padding-bottom:80px}.stats-header{background:linear-gradient(135deg,#2d5016,#1a300d);box-shadow:0 2px 8px #0000001a;color:#fff;padding:24px 20px}.stats-header h1{font-size:28px;font-weight:700;margin:0 0 8px}.date-range{font-size:15px;margin:0;opacity:.9}.time-range-selector{background:#fff;box-shadow:0 2px 4px #0000000d;display:flex;gap:12px;padding:16px 20px}.range-button{background:#fff;border:2px solid #ddd;border-radius:8px;color:#666;cursor:pointer;flex:1 1;font-size:15px;font-weight:600;height:44px;transition:all .2s ease}.range-button.active{background:#2d5016;border-color:#2d5016;color:#fff}.stats-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr);padding:20px}.stat-card{background:#fff;border:2px solid #0000;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:20px;text-align:center;transition:all .2s ease}.stat-card:active{transform:scale(.98)}.stat-card.primary{background:linear-gradient(135deg,#2d5016,#1a300d);color:#fff;grid-column:1/-1}.stat-card.success{border-color:#28a745}.stat-card.danger{border-color:#dc3545}.stat-card.warning{border-color:#ffc107}.stat-icon{font-size:32px;margin-bottom:8px}.stat-value{font-size:36px;font-weight:700;margin-bottom:4px}.stat-card.primary .stat-value{font-size:48px}.stat-label{font-size:13px;font-weight:600;letter-spacing:.5px;opacity:.8;text-transform:uppercase}.stat-card.primary .stat-label{opacity:.9}.low-attendance-section{padding:20px}.low-attendance-section h2{color:#333;font-size:18px;font-weight:700;margin:0 0 16px}.students-list{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.student-stat-item{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:16px}.student-stat-item:last-child{border-bottom:none}.student-stat-info{flex:1 1}.student-stat-name{color:#333;font-size:16px;font-weight:600;margin-bottom:4px}.student-stat-meta{color:#666;font-size:13px}.student-stat-rate{border-radius:8px;font-size:24px;font-weight:700;margin-left:12px;padding:8px 16px}.student-stat-rate.low{background:#fff3cd;color:#856404}.student-stat-rate.critical{background:#f8d7da;color:#721c24}.empty-state-small{padding:40px 20px;text-align:center}.empty-state-small .empty-icon{font-size:60px;margin-bottom:12px}.empty-state-small p{color:#666;font-size:16px;margin:0}.error-container,.loading-container{min-height:50vh}@media (max-width:480px){.stats-header{padding:20px 16px}.stats-header h1{font-size:24px}.time-range-selector{padding:12px 16px}.stats-grid{gap:10px}.stat-card,.stats-grid{padding:16px}.stat-value{font-size:32px}.stat-card.primary .stat-value{font-size:42px}.low-attendance-section{padding:16px}.student-stat-item{padding:14px}}.coach-documents{padding:1rem 1rem 80px}.category-scroll{display:flex;gap:.5rem;margin-bottom:1rem;overflow-x:auto;padding-bottom:.5rem;scrollbar-width:none}.category-scroll::-webkit-scrollbar{display:none}.cat-pill{background:#f0f0f0;border:1px solid #ddd;border-radius:20px;cursor:pointer;flex-shrink:0;font-size:.85rem;padding:.3rem .9rem;transition:background .2s;white-space:nowrap}.cat-pill:hover{background:#e0e0e0}.cat-pill.active{background:#1abc9c;border-color:#1abc9c;color:#fff}.docs-list{flex-direction:column}.doc-card,.docs-list{display:flex;gap:.75rem}.doc-card{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;justify-content:space-between;padding:.9rem 1rem}.doc-card-left{align-items:flex-start;display:flex;flex:1 1;gap:.7rem;min-width:0}.doc-icon{flex-shrink:0;font-size:1.6rem}.doc-info{display:flex;flex-direction:column;min-width:0}.doc-name{font-size:.92rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doc-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.2rem}.doc-cat{background:#e8f4f1;border-radius:10px;color:#1abc9c;font-size:.75rem;font-weight:600;padding:.1rem .5rem}.doc-date,.doc-size{color:#888;font-size:.78rem}.doc-desc{color:#777;font-size:.78rem;margin-top:.2rem}.doc-download-btn{background:#1abc9c;border:none;border-radius:8px;color:#fff;cursor:pointer;flex-shrink:0;font-size:.82rem;font-weight:600;padding:.45rem .8rem;white-space:nowrap}.doc-download-btn:active{background:#16a085}.fab-upload{align-items:center;background:#1abc9c;border:none;border-radius:50%;bottom:80px;box-shadow:0 4px 12px #0003;color:#fff;cursor:pointer;display:flex;font-size:1.6rem;height:52px;justify-content:center;line-height:1;position:fixed;right:1rem;width:52px;z-index:100}.fab-upload:active{background:#16a085}.modal-overlay{align-items:flex-end;background:#00000080;display:flex;inset:0;justify-content:center;position:fixed;z-index:200}.modal-box{background:#fff;border-radius:16px 16px 0 0;max-height:85vh;max-width:480px;overflow-y:auto;padding:1.5rem;width:100%}.modal-box h3{font-size:1.1rem;margin:0 0 1rem}.modal-field{margin-bottom:.9rem}.modal-field label{color:#444;display:block;font-size:.85rem;font-weight:600;margin-bottom:.3rem}.modal-field input[type=file],.modal-field select,.modal-field textarea{border:1px solid #ccc;border-radius:8px;box-sizing:border-box;font-size:.9rem;padding:.5rem .7rem;width:100%}.modal-field textarea{resize:vertical}.hint{color:#999;display:block;font-size:.76rem;margin-top:.2rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}.btn-cancel{background:#f0f0f0;border:1px solid #ddd;border-radius:8px;padding:.5rem 1rem}.btn-cancel,.btn-save{cursor:pointer;font-size:.9rem}.btn-save{background:#1abc9c;border:none;border-radius:8px;color:#fff;font-weight:600;padding:.5rem 1.2rem}.btn-save:disabled{opacity:.6}.docs-empty,.docs-loading{color:#888;padding:2rem;text-align:center}.bottom-nav{background:#fff;border-top:1px solid #e0e0e0;bottom:0;box-shadow:0 -2px 8px #0000001a;height:70px;justify-content:space-around;left:0;padding:0 env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);position:fixed;right:0;z-index:900}.bottom-nav,.nav-tab{align-items:center;display:flex}.nav-tab{background:#0000;border:none;color:#666;cursor:pointer;flex:1 1;flex-direction:column;height:100%;justify-content:center;padding:8px;position:relative;transition:all .2s ease}.nav-tab:before{background:#2d5016;content:"";height:3px;left:50%;position:absolute;top:0;transform:translateX(-50%);transition:width .3s ease;width:0}.nav-tab.active:before{width:60px}.nav-tab:active{background:#f5f7fa}.nav-tab.active{color:#2d5016}.nav-icon{font-size:24px;margin-bottom:4px;transition:transform .2s ease}.nav-tab.active .nav-icon{transform:scale(1.1)}.nav-label{font-size:11px;font-weight:600;letter-spacing:.3px}.nav-tab.active .nav-label{font-weight:700}@media (max-width:480px){.bottom-nav{height:65px}.nav-icon{font-size:22px}.nav-label{font-size:10px}}@supports (padding-bottom:env(safe-area-inset-bottom)){.bottom-nav{height:calc(70px + env(safe-area-inset-bottom));padding-bottom:calc(env(safe-area-inset-bottom) + 8px)}}:root{--color-primary-light:#667eea;--color-primary-dark:#764ba2;--color-white:#fff;--color-gray-50:#f7fafc;--color-gray-100:#edf2f7;--color-gray-200:#e2e8f0;--color-gray-300:#cbd5e0;--color-gray-600:#4a5568;--color-gray-700:#2d3748;--color-gray-900:#1a202c;--color-red-500:#e53e3e;--color-red-50:#fff5f5;--color-green-300:#68d391;--color-primary-darker:#5a67d8;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:12px;--spacing-lg:16px;--spacing-xl:20px;--spacing-2xl:24px;--spacing-3xl:30px;--spacing-4xl:40px;--font-size-xs:12px;--font-size-sm:13px;--font-size-base:14px;--font-size-md:16px;--font-size-lg:24px;--font-size-xl:28px;--font-size-2xl:64px;--font-weight-normal:400;--font-weight-semibold:600;--font-weight-bold:700;--line-height-normal:1.5;--line-height-relaxed:1.6;--border-radius-sm:6px;--border-radius-md:8px;--border-radius-lg:12px;--border-width:1px;--shadow-md:0 4px 12px #00000026;--shadow-lg:0 20px 60px #0000004d;--transition-fast:0.2s ease;--transition-base:0.3s ease-out;--font-system:-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;--font-mono:"Courier New",Courier,monospace}.error-boundary-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);background:linear-gradient(135deg,var(--color-primary-light) 0,var(--color-primary-dark) 100%);display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-family:var(--font-system);justify-content:center;min-height:100vh;padding:20px;padding:var(--spacing-xl)}.error-boundary-card{animation:slideIn .3s ease-out;animation:slideIn var(--transition-base);background:#fff;background:var(--color-white);border-radius:12px;border-radius:var(--border-radius-lg);box-shadow:0 20px 60px #0000004d;box-shadow:var(--shadow-lg);max-width:600px;padding:40px;padding:var(--spacing-4xl);text-align:center;width:100%}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.error-boundary-icon{animation:pulse 2s ease-in-out infinite;font-size:64px;font-size:var(--font-size-2xl);margin-bottom:20px;margin-bottom:var(--spacing-xl)}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.error-boundary-title{color:#1a202c;color:var(--color-gray-900);font-size:28px;font-size:var(--font-size-xl);font-weight:700;font-weight:var(--font-weight-bold);margin:0 0 16px;margin:0 0 var(--spacing-lg) 0}.error-boundary-message{color:#4a5568;color:var(--color-gray-600);font-size:16px;font-size:var(--font-size-md);line-height:1.6;line-height:var(--line-height-relaxed);margin:0 0 30px;margin:0 0 var(--spacing-3xl) 0}.error-boundary-details{background:#f7fafc;background:var(--color-gray-50);border:1px solid #e2e8f0;border:var(--border-width) solid var(--color-gray-200);border-radius:8px;border-radius:var(--border-radius-md);margin:20px 0;margin:var(--spacing-xl) 0;max-height:400px;overflow-y:auto;padding:20px;padding:var(--spacing-xl);text-align:left}.error-boundary-details h3{color:#e53e3e;color:var(--color-red-500);font-size:14px;font-size:var(--font-size-base);font-weight:600;font-weight:var(--font-weight-semibold);letter-spacing:.5px;margin:0 0 16px;margin:0 0 var(--spacing-lg) 0;text-transform:uppercase}.error-boundary-component-stack,.error-boundary-error-message,.error-boundary-stack{margin-bottom:16px;margin-bottom:var(--spacing-lg)}.error-boundary-details strong{color:#2d3748;color:var(--color-gray-700);display:block;font-size:12px;font-size:var(--font-size-xs);font-weight:600;font-weight:var(--font-weight-semibold);letter-spacing:.5px;margin-bottom:8px;margin-bottom:var(--spacing-sm);text-transform:uppercase}.error-boundary-details pre{background:#1a202c;background:var(--color-gray-900);border-radius:6px;border-radius:var(--border-radius-sm);color:#68d391;color:var(--color-green-300);font-family:Courier New,Courier,monospace;font-family:var(--font-mono);font-size:12px;font-size:var(--font-size-xs);line-height:1.5;line-height:var(--line-height-normal);margin:0;overflow-x:auto;padding:12px;padding:var(--spacing-md);white-space:pre-wrap;word-break:break-word}.error-boundary-actions{display:flex;gap:12px;gap:var(--spacing-md);justify-content:center;margin:30px 0;margin:var(--spacing-3xl) 0}.error-boundary-btn{border:none;border-radius:8px;border-radius:var(--border-radius-md);cursor:pointer;font-family:inherit;font-size:16px;font-size:var(--font-size-md);font-weight:600;font-weight:var(--font-weight-semibold);padding:12px 16px;padding:var(--spacing-md) var(--spacing-lg);transition:all .2s ease;transition:all var(--transition-fast)}.error-boundary-btn:hover{box-shadow:0 4px 12px #00000026;box-shadow:var(--shadow-md);transform:translateY(-2px)}.error-boundary-btn:active{transform:translateY(0)}.error-boundary-btn-primary{background:#667eea;background:var(--color-primary-light);color:#fff;color:var(--color-white)}.error-boundary-btn-primary:hover{background:#5a67d8;background:var(--color-primary-darker)}.error-boundary-btn-secondary{background:#edf2f7;background:var(--color-gray-100);color:#2d3748;color:var(--color-gray-700)}.error-boundary-btn-secondary:hover{background:#e2e8f0;background:var(--color-gray-200)}.error-boundary-count{background:#fff5f5;background:var(--color-red-50);border-radius:6px;border-radius:var(--border-radius-sm);color:#e53e3e;color:var(--color-red-500);display:inline-block;font-size:14px;font-size:var(--font-size-base);font-weight:600;font-weight:var(--font-weight-semibold);margin:20px 0 0;margin:var(--spacing-xl) 0 0 0;padding:8px 16px;padding:var(--spacing-sm) var(--spacing-lg)}.error-boundary-footer{border-top:1px solid #e2e8f0;border-top:var(--border-width) solid var(--color-gray-200);margin-top:30px;margin-top:var(--spacing-3xl);padding-top:20px;padding-top:var(--spacing-xl);text-align:left}.error-boundary-footer p{color:#4a5568;color:var(--color-gray-600);font-size:14px;font-size:var(--font-size-base);font-weight:600;font-weight:var(--font-weight-semibold);margin:0 0 12px;margin:0 0 var(--spacing-md) 0}.error-boundary-footer ul{list-style:none;margin:0;padding:0}.error-boundary-footer li{color:#cbd5e0;color:var(--color-gray-300);font-family:Courier New,Courier,monospace;font-family:var(--font-mono);font-size:13px;font-size:var(--font-size-sm);padding:4px 0;padding:var(--spacing-xs) 0}@media (max-width:600px){.error-boundary-card{padding:24px;padding:var(--spacing-2xl)}.error-boundary-title{font-size:24px;font-size:var(--font-size-lg)}.error-boundary-message{font-size:14px;font-size:var(--font-size-base)}.error-boundary-actions{flex-direction:column}.error-boundary-btn{width:100%}.error-boundary-details{max-height:200px}}*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;overflow-x:hidden}.app-loading{align-items:center;background:linear-gradient(135deg,#2d5016,#1a300d);color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.app-loading .spinner{animation:spin .8s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;width:50px}.app-loading p{font-size:16px;margin-top:16px;opacity:.9}.app-container{display:flex;flex-direction:column;min-height:100vh}.app-header{align-items:center;background:linear-gradient(135deg,#2d5016,#1a300d);box-shadow:0 2px 8px #0000001a;color:#fff;display:flex;justify-content:space-between;padding:16px 20px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.app-title h1{font-size:20px;font-weight:700;margin:0 0 2px}.app-title p{font-size:13px;margin:0;opacity:.9}.logout-button{background:#ffffff26;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s ease}.logout-button:active{background:#ffffff40}.app-content{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto}.coming-soon{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:calc(100vh - 150px);padding:40px 20px;text-align:center}.coming-soon-icon{font-size:80px;margin-bottom:20px}.coming-soon h2{color:#333;font-size:24px;margin:0 0 8px}.coming-soon p{color:#666;font-size:16px;margin:0;max-width:300px}@media (display-mode:standalone){.app-header{padding-top:calc(16px + env(safe-area-inset-top))}}@media (max-width:480px){.app-header{padding:12px 16px}.app-title h1{font-size:18px}.app-title p{font-size:12px}.logout-button{font-size:12px;padding:6px 12px}}.mark-button,.nav-tab,.student-item,button{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}html{scroll-behavior:smooth}.clickable,a,button{min-height:44px;min-width:44px}.error-container,.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:60vh;padding:20px}.spinner{animation:spin .8s linear infinite;border:4px solid #e0e0e0;border-radius:50%;border-top-color:#2d5016;height:50px;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.loading-container p{color:#666;font-size:16px;margin-top:16px}.error-text{color:#dc3545;font-size:16px;margin-bottom:20px}.retry-button{background:#2d5016;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px}
/*# sourceMappingURL=main.1a771c53.css.map*/