@charset "UTF-8";:root{--primary: #667eea;--primary-dark: #5568d3;--primary-light: #e0e7ff;--accent: #764ba2;--gradient-primary: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-primary-shadow: rgba(102, 126, 234, .35);--success: #22c55e;--success-bg: #dcfce7;--success-text: #166534;--danger: #ef4444;--danger-bg: #fee2e2;--danger-text: #b91c1c;--warning: #f59e0b;--warning-bg: #fef3c7;--warning-text: #b45309;--info: #3b82f6;--info-bg: #dbeafe;--info-text: #1d4ed8;--bg-page: #f5f5f5;--bg-page-gradient: linear-gradient(to bottom, #f8f9fa 0%, #f5f5f5 100%);--surface: #ffffff;--border: #e0e0e0;--border-light: #f0f0f0;--text: #333333;--text-secondary: #666666;--text-muted: #999999;--radius-sm: 6px;--radius: 8px;--radius-lg: 12px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow: 0 2px 12px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--page-padding-x: 16px;--page-padding-y: 16px;--page-main-padding-x: 16px;--page-main-padding-y: 20px;--content-max-width: 100%;--header-height: auto;--font-size-h1: 1.35rem;--grid-gap: 16px;--stat-card-min: 120px;--session-card-min: 280px}@media (min-width: 576px){:root{--page-padding-x: 20px;--page-main-padding-x: 20px;--font-size-h1: 1.5rem;--stat-card-min: 130px}}@media (min-width: 768px){:root{--page-padding-x: 24px;--page-padding-y: 20px;--page-main-padding-x: 32px;--page-main-padding-y: 24px;--content-max-width: 1400px;--font-size-h1: 1.6rem;--grid-gap: 20px;--stat-card-min: 140px;--session-card-min: 300px}}@media (min-width: 992px){:root{--page-padding-x: 40px;--page-padding-y: 20px;--page-main-padding-x: 40px;--page-main-padding-y: 30px;--font-size-h1: 1.75rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text);background:var(--bg-page);line-height:1.5}a{text-decoration:none;color:inherit}button{font-family:inherit;cursor:pointer}.page{min-height:100vh;background:var(--bg-page-gradient)}.page-header{background:var(--surface);padding:var(--page-padding-y) var(--page-padding-x);display:flex;align-items:center;gap:12px;row-gap:10px;flex-wrap:wrap;box-shadow:var(--shadow-sm);border-bottom:1px solid var(--border)}.page-header .back-btn{background:none;border:none;font-size:15px;color:var(--primary);padding:8px 12px;border-radius:var(--radius);display:inline-flex;align-items:center;gap:6px;transition:all .2s;min-height:44px}.page-header .back-btn:hover{background:var(--border-light);transform:translate(-2px)}.page-header h1{flex:1;margin:0;color:var(--text);font-size:var(--font-size-h1);font-weight:600;min-width:0;line-height:1.3}.page-header .header-actions{display:flex;gap:8px;flex-wrap:wrap;width:100%}@media (min-width: 768px){.page-header .header-actions{width:auto}}.page-header .header-actions .btn{flex:1 1 auto;min-width:0}@media (min-width: 576px){.page-header .header-actions .btn{flex:none}}.page-header .session-info,.page-header .user-info{width:100%;margin:4px 0 0;color:var(--text-secondary);font-size:13px}@media (min-width: 576px){.page-header .session-info,.page-header .user-info{font-size:14px}}.page-main{padding:var(--page-main-padding-y) var(--page-main-padding-x);max-width:var(--content-max-width);margin:0 auto;width:100%}.btn{padding:12px 20px;border:none;border-radius:var(--radius);font-size:14px;font-weight:600;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px}@media (min-width: 576px){.btn{padding:12px 24px;min-height:auto}}.btn:disabled{opacity:.6;cursor:not-allowed}.btn.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 12px var(--gradient-primary-shadow)}.btn.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px var(--gradient-primary-shadow)}.btn.btn-primary:active:not(:disabled){transform:translateY(0)}.btn.btn-secondary{background:var(--success);color:#fff}.btn.btn-secondary:hover:not(:disabled){background:#38a169}.btn.btn-outline{background:transparent;color:var(--primary);border:2px solid var(--primary)}.btn.btn-outline:hover:not(:disabled){background:var(--primary-light)}.btn.btn-danger{background:var(--danger);color:#fff}.btn.btn-danger:hover:not(:disabled){background:#c0392b}.btn.btn-success{background:var(--success);color:#fff}.btn.btn-success:hover:not(:disabled){background:#38a169}.btn.btn-sm{padding:8px 16px;font-size:13px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:var(--text);font-weight:500}.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 14px;border:2px solid var(--border);border-radius:var(--radius);font-size:16px;background:var(--surface);transition:border-color .2s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary)}.form-group input::placeholder,.form-group textarea::placeholder,.form-group select::placeholder{color:var(--text-muted)}.form-group textarea{min-height:100px;resize:vertical}.form-group select{cursor:pointer}.form-group .form-hint{display:block;margin-top:6px;font-size:13px;color:var(--text-secondary)}.form-group .error-message{display:block;color:var(--danger);font-size:13px;margin-top:6px}.form-actions{display:flex;gap:12px;justify-content:stretch;flex-wrap:wrap;margin-top:24px}.form-actions .btn{flex:1 1 100%;min-width:0}@media (min-width: 576px){.form-actions{justify-content:flex-end}.form-actions .btn{flex:none}}.form-card{background:var(--surface);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow);border:1px solid var(--border-light);margin-bottom:24px;width:100%;max-width:640px}@media (min-width: 576px){.form-card{padding:24px}}@media (min-width: 768px){.form-card{padding:28px}}.form-card h2{margin:0 0 8px;color:var(--text);font-size:1.15rem}@media (min-width: 576px){.form-card h2{font-size:20px}}.form-card .form-hint{color:var(--text-secondary);font-size:14px;margin-bottom:20px}.search-section{margin-bottom:24px}.search-box{display:flex;align-items:center;background:var(--surface);border-radius:var(--radius-lg);padding:12px 16px;box-shadow:var(--shadow);border:2px solid var(--border);transition:border-color .2s}.search-box:focus-within{border-color:var(--primary)}.search-box .search-icon{font-size:18px;margin-right:12px;color:var(--text-muted)}.search-box .search-input{flex:1;border:none;outline:none;font-size:16px;color:var(--text);min-width:0}.search-box .search-input::placeholder{color:var(--text-muted)}.search-box .clear-search{background:none;border:none;color:var(--text-muted);font-size:18px;padding:4px 8px;border-radius:var(--radius-sm);transition:all .2s}.search-box .clear-search:hover{background:var(--border-light);color:var(--text-secondary)}.search-results-info{margin-top:12px;padding:8px 16px;background:var(--info-bg);border-radius:var(--radius-sm);color:var(--info-text);font-size:14px;font-weight:500}.card{background:var(--surface);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow);border:1px solid var(--border-light);transition:all .2s}.card-clickable{cursor:pointer}.card-clickable:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary)}.data-table{background:var(--surface);border-radius:var(--radius-lg);overflow-x:auto;-webkit-overflow-scrolling:touch;box-shadow:var(--shadow);border:1px solid var(--border-light);margin-bottom:24px}.data-table table{width:100%;min-width:600px;border-collapse:collapse}.data-table thead{background:var(--gradient-primary);color:#fff}.data-table thead th{padding:12px;text-align:left;font-weight:600;font-size:13px;white-space:nowrap}@media (min-width: 768px){.data-table thead th{padding:14px 16px;font-size:14px}}.data-table tbody tr{border-bottom:1px solid var(--border);transition:background .15s}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr:hover{background:#f9fafb}.data-table tbody tr td{padding:12px;color:var(--text);font-size:13px}@media (min-width: 768px){.data-table tbody tr td{padding:14px 16px;font-size:14px}}.badge{padding:4px 10px;border-radius:var(--radius-sm);font-weight:600;font-size:12px}.badge.badge-present{background:var(--success-bg);color:var(--success-text)}.badge.badge-absent{background:var(--danger-bg);color:var(--danger-text)}.badge.badge-late{background:var(--warning-bg);color:var(--warning-text)}.badge.badge-excused{background:var(--info-bg);color:var(--info-text)}.loading,.error,.empty-state,.no-results{text-align:center;padding:48px 24px;color:var(--text-secondary);font-size:16px}.error{color:var(--danger);background:var(--danger-bg);border-radius:var(--radius);margin-bottom:20px;padding:14px 20px}.empty-state,.no-results{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.empty-state p,.no-results p{margin:0 0 20px}.empty-state .no-results-icon,.empty-state .empty-icon,.no-results .no-results-icon,.no-results .empty-icon{font-size:48px;display:block;margin-bottom:16px;opacity:.5}.error-alert{background:var(--danger-bg);color:var(--danger-text);padding:12px 16px;border-radius:var(--radius);margin-bottom:20px;text-align:center;font-size:14px}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;min-height:100dvh;background:var(--gradient-primary);padding:16px}@media (min-width: 576px){.login-container{padding:20px}}.login-card{background:var(--surface);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}@media (min-width: 576px){.login-card{padding:32px 40px}}.login-card h1{text-align:center;color:var(--primary);margin-bottom:8px;font-size:1.5rem}@media (min-width: 576px){.login-card h1{font-size:1.75rem}}.login-card h2{text-align:center;color:var(--text);margin-bottom:24px;font-weight:400;font-size:1rem}@media (min-width: 576px){.login-card h2{margin-bottom:28px;font-size:1.1rem}}.submit-btn{width:100%;padding:14px;min-height:48px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.submit-btn:hover:not(:disabled){background:var(--primary-dark)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.container-responsive{width:100%;max-width:var(--content-max-width);margin-left:auto;margin-right:auto;padding-left:var(--page-main-padding-x);padding-right:var(--page-main-padding-x)}@media (max-width: 575px){.hide-sm{display:none!important}}@media (min-width: 576px) and (max-width: 767px){.hide-md{display:none!important}}@media (min-width: 768px) and (max-width: 991px){.hide-lg{display:none!important}}@media (min-width: 576px){.show-sm{display:none!important}}@media (max-width: 575px){.show-md{display:none!important}}@media (min-width: 768px){.show-md{display:block!important}}@media (min-width: 992px){.show-lg{display:block!important}}@media (max-width: 991px){.show-lg{display:none!important}}
