@import"https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400}a{font-weight:500;text-decoration:inherit}body{margin:0;min-width:320px;min-height:100vh}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Archivo,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5;color:#333;line-height:1.6}.app-container{min-height:100vh;display:flex;flex-direction:column}.header{background:linear-gradient(135deg,#9e1b2e,#7a1524);color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.header h1{font-size:1.5rem;font-weight:600}.selectors{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.select-wrapper{display:flex;align-items:center;gap:.5rem}.select-wrapper label{font-size:.9rem;font-weight:500}.select-wrapper select{padding:.5rem 1rem;border:none;border-radius:4px;font-size:.9rem;min-width:180px}.nav{background:#2d2d2d;padding:0 2rem;display:flex;gap:0}.nav a{color:#ccc;text-decoration:none;padding:1rem 1.5rem;transition:all .2s;border-bottom:3px solid transparent}.nav a:hover{color:#fff;background:#3d3d3d}.nav a.active{color:#f2ca1c;border-bottom-color:#f2ca1c}.main{flex:1;padding:2rem;max-width:1400px;margin:0 auto;width:100%}.select-prompt{text-align:center;padding:4rem 2rem;color:#666;font-size:1.2rem}.loading{text-align:center;padding:2rem;color:#666}.message{padding:1rem;border-radius:4px;margin-bottom:1rem}.message.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.message.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.dashboard h2,.intake h2,.attendance h2,.checkin h2,.reports h2,.groups h2{margin-bottom:.5rem;color:#333}.dashboard-subtitle{color:#666;margin-bottom:1.5rem;font-style:italic}.dashboard h3{margin:1.5rem 0 1rem;color:#555}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;text-align:center;border-top:4px solid #9e1b2e}.stat-card h3{font-size:2.5rem;color:#333;margin-bottom:.5rem}.stat-card p{color:#666;font-size:.9rem}.stat-card.flagged{border-top-color:#dc3545}.stat-card.flagged h3{color:#dc3545}.data-table{width:100%;background:#fff;border-collapse:collapse;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a;margin-bottom:1.5rem}.data-table th,.data-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #eee}.data-table th{background:#9e1b2e;color:#fff;font-weight:600}.data-table tbody tr:hover{background:#fef9e7}.flagged-row{background:#fff5f5!important}.absent-row{background:#fff9e6!important}.flag-badge{background:#dc3545;color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.ok-badge{background:#28a745;color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.form{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;max-width:600px}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#9e1b2e;box-shadow:0 0 0 3px #9e1b2e1a}.form-row{display:flex;gap:1rem;flex-wrap:wrap}.form-row .form-group{flex:1;min-width:200px}.btn-primary{background:#9e1b2e;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s}.btn-primary:hover{background:#7a1524}.btn-primary:disabled{background:#ccc;cursor:not-allowed}.btn-secondary{background:#6c757d;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s}.btn-secondary:hover{background:#5a6268}.btn-danger{background:#dc3545;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;font-size:1rem;cursor:pointer}.btn-danger:hover{background:#c82333}.btn-small{padding:.25rem .5rem;font-size:.8rem}.btn-large{padding:1rem 2rem;font-size:1.1rem;margin-top:1rem}.button-group{display:flex;gap:.5rem;align-items:center}.mode-selector{display:flex;gap:1.5rem;margin-bottom:1.5rem;padding:1rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.mode-selector label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.mode-selector input[type=radio]:checked+span,.mode-selector input[type=radio]:checked~*{color:#9e1b2e}.attendance-summary{display:flex;gap:2rem;margin-bottom:1rem;font-weight:600}.attendance-summary .present{color:#28a745}.attendance-summary .absent{color:#dc3545}.status-btn{padding:.25rem .75rem;border:none;border-radius:4px;cursor:pointer;font-weight:500;min-width:80px;transition:all .2s}.status-btn.present{background:#d4edda;color:#155724}.status-btn.present:hover{background:#c3e6cb}.status-btn.absent{background:#f8d7da;color:#721c24}.status-btn.absent:hover{background:#f5c6cb}.makeup-section{margin:1.5rem 0}.makeup-select{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.makeup-select select{flex:1;min-width:250px;padding:.5rem;border:1px solid #ddd;border-radius:4px}.checkin .form{max-width:900px}.questions-container{display:flex;flex-direction:column;gap:1.5rem;margin:2rem 0}.question-card{background:#f8f9fa;padding:1.25rem;border-radius:8px;border-left:4px solid #9e1b2e}.question-text{font-weight:500;margin-bottom:1rem}.likert-scale{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.likert-option{display:flex;flex-direction:column;align-items:center;gap:.25rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:background .2s;flex:1;min-width:80px;text-align:center}.likert-option:hover{background:#fef9e7}.likert-option input{width:auto;accent-color:#9e1b2e}.likert-value{font-weight:600;font-size:1.1rem;color:#9e1b2e}.likert-label{font-size:.75rem;color:#666}.report-controls{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:1.5rem;display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-end}.report-controls .form-group{margin-bottom:0}.report-results{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.result-count{padding:1rem 1.5rem;background:#fef9e7;border-bottom:1px solid #f2ca1c;font-weight:500}.table-container{overflow-x:auto}.no-data{text-align:center;color:#666;padding:2rem}@media(max-width:768px){.header{flex-direction:column;text-align:center}.selectors{width:100%;justify-content:center}.nav{flex-wrap:wrap;justify-content:center}.nav a{padding:.75rem 1rem}.main{padding:1rem}.stats-grid{grid-template-columns:1fr 1fr}.form{padding:1.5rem}.likert-scale{flex-direction:column}.likert-option{flex-direction:row;justify-content:flex-start;gap:1rem}}.admin h2{margin-bottom:1.5rem}.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem}.admin-section{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.admin-section h3{margin-bottom:1rem;color:#9e1b2e;border-bottom:2px solid #f2ca1c;padding-bottom:.5rem}.admin-section h4{margin:1.5rem 0 .75rem;color:#555;font-size:.95rem}.inline-form{display:flex;gap:.5rem;flex-wrap:wrap}.inline-form input,.inline-form select{flex:1;min-width:150px;padding:.5rem;border:1px solid #ddd;border-radius:4px}.item-list{list-style:none;padding:0;margin:0}.item-list li{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #eee}.item-list li:last-child{border-bottom:none}.item-list small{color:#888;margin-left:.5rem}.empty-state{color:#888;font-style:italic}.admin-link{margin-left:auto!important}.admin-link:after{content:"";display:inline-block;width:6px;height:6px;background:#f2ca1c;border-radius:50%;margin-left:6px;vertical-align:middle}.select-prompt a{color:#9e1b2e}.intake-form{max-width:800px}.intake-form h3{margin-top:1.5rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #f2ca1c;color:#9e1b2e}.intake-form h3:first-of-type{margin-top:0}.loading-screen{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.2rem;color:#666}.login-page{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#9e1b2e,#7a1524,#5a1018);padding:1rem}.login-container{background:#fff;padding:3rem;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-width:400px;width:100%;text-align:center}.login-container h1{color:#9e1b2e;font-size:1.5rem;margin-bottom:.25rem}.login-container h2{color:#666;font-size:1rem;font-weight:400;margin-bottom:2rem}.login-form{text-align:left}.login-form .form-group{margin-bottom:1.25rem}.login-form .btn-primary{width:100%}.login-help{margin-top:1.5rem;font-size:.85rem;color:#888}.header-right{display:flex;align-items:center;gap:2rem;flex-wrap:wrap}.user-info{display:flex;align-items:center;gap:1rem;font-size:.9rem}.user-info span{opacity:.9}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.checkbox-label input{width:auto;accent-color:#9e1b2e}.admin-badge{background:#f2ca1c;color:#333;padding:.15rem .4rem;border-radius:3px;font-size:.7rem;margin-left:.5rem;vertical-align:middle;font-weight:600}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:#fff;padding:2rem;border-radius:8px;max-width:400px;width:90%;box-shadow:0 10px 40px #0000004d}.modal h3{margin-bottom:1rem;color:#9e1b2e}.modal .form-group{margin-bottom:1rem}.modal .button-group{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1.5rem}.highlight{background:#fef9e7;border-left:3px solid #f2ca1c;padding-left:.5rem}
