*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans KR,Roboto,Helvetica Neue,Arial,sans-serif}body{background:#f5f5f5;color:#1e293b;line-height:1.7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.card{background:var(--color-bg);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:1.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:var(--transition)}.btn:disabled{opacity:.5;cursor:not-allowed}.page-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.page-header-info h2{font-size:1.375rem;font-weight:700;color:var(--color-text-primary);margin:0 0 .25rem}.page-header-info p{font-size:.875rem;color:var(--color-text-muted);margin:0}.btn-primary-add{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition);white-space:nowrap}.btn-primary-add:hover{background-color:var(--color-primary-hover)}.btn-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .875rem;background-color:var(--color-bg);color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition)}.btn-secondary:hover{background-color:var(--color-bg-subtle);border-color:var(--color-primary);color:var(--color-primary)}.table-section{background-color:var(--color-bg);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:visible}.table-section-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border);background-color:var(--color-bg-subtle)}.table-section-title{font-size:.9375rem;font-weight:600;color:var(--color-text-primary);margin:0}.table-section-count{font-size:.8125rem;color:var(--color-text-muted)}.table-search{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:var(--transition)}.table-search:focus-within{border-color:var(--color-primary)}.table-search svg{color:var(--color-text-muted);flex-shrink:0}.table-search input{border:none;background:transparent;font-size:.875rem;color:var(--color-text-primary);outline:none;width:100%;min-width:140px}.table-search input::placeholder{color:var(--color-text-muted)}.filter-section{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:.375rem}.filter-group label{font-size:.75rem;font-weight:500;color:var(--color-text-muted)}.filter-select,.filter-input{padding:.5rem .75rem;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;color:var(--color-text-primary);min-width:150px;transition:var(--transition)}.filter-select:focus,.filter-input:focus{outline:none;border-color:var(--color-primary)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;color:var(--color-text-muted);text-align:center}.empty-state svg{margin-bottom:1rem;opacity:.5}.empty-state p{font-size:.9375rem;margin:0}.loading-state{display:flex;align-items:center;justify-content:center;padding:3rem;color:var(--color-text-muted)}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1rem;border-top:1px solid var(--color-border)}.pagination-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background-color:var(--color-bg);color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.8125rem;cursor:pointer;transition:var(--transition)}.pagination-btn:hover:not(:disabled){background-color:var(--color-bg-subtle);border-color:var(--color-primary)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{font-size:.875rem;color:var(--color-text-secondary)}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem;margin-bottom:1.5rem}.stat-item{display:flex;flex-direction:column;align-items:center;padding:1rem;background-color:var(--color-bg);border-radius:var(--radius-md);text-align:center}.stat-label{font-size:.75rem;font-weight:500;color:var(--color-text-muted);margin-bottom:.25rem}.stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text-primary)}.stat-item.stat-present{background-color:#dcfce7;border-color:#bbf7d0;color:#166534}.stat-item.stat-absent{background-color:#fee2e2;border-color:#fecaca;color:#991b1b}.stat-item.stat-exception{background-color:#fef3c7;border-color:#fde68a;color:#92400e}[data-theme=dark] .stat-item.stat-present{background-color:#03bf4026;border-color:#03bf404d;color:#6ee7b7}[data-theme=dark] .stat-item.stat-absent{background-color:#ff424226;border-color:#ff42424d;color:#fca5a5}[data-theme=dark] .stat-item.stat-exception{background-color:#f59e0b26;border-color:#f59e0b4d;color:#fcd34d}.action-menu-wrapper{position:relative}.action-menu-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:1px solid transparent;border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;transition:var(--transition)}.action-menu-btn:hover{background-color:var(--color-bg-subtle);border-color:var(--color-border);color:var(--color-text-primary)}.action-dropdown{position:absolute;top:100%;right:0;z-index:100;min-width:140px;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);overflow:hidden}.action-dropdown button{display:flex;align-items:center;gap:.5rem;width:100%;padding:.625rem .875rem;background:transparent;border:none;font-size:.8125rem;color:var(--color-text-primary);cursor:pointer;transition:var(--transition)}.action-dropdown button:hover{background-color:var(--color-bg-subtle)}.action-dropdown button.danger{color:var(--color-danger)}.action-dropdown button.danger:hover{background-color:var(--color-danger-light)}.text-muted{color:var(--color-text-muted);font-size:.875rem}.table-container{overflow:visible}.user-cell{display:flex;align-items:center;gap:.75rem}.user-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:50%;color:var(--color-text-muted)}@media(max-width:640px){.page-header-row{flex-direction:column;align-items:stretch}.stats-row{grid-template-columns:repeat(2,1fr)}.filter-section{flex-direction:column}.table-section-header{flex-direction:column;gap:.75rem;align-items:stretch}}:root{--color-primary: #0283F0;--color-primary-hover: #0172D6;--color-primary-light: #dbeafe;--color-success: #03BF40;--color-success-hover: #029E35;--color-success-light: #dcfce7;--color-danger: #FF4242;--color-danger-hover: #E03030;--color-danger-light: #fecaca;--color-warning: #ea580c;--color-warning-light: #ffedd5;--color-neutral: #64748b;--color-neutral-light: #f8fafc;--color-text-primary: #1e293b;--color-text-secondary: #475569;--color-text-muted: #64748b;--color-border: #e5e7eb;--color-bg: #ffffff;--color-bg-subtle: #F5F5F5;--color-bg-secondary: #f8fafc;--color-bg-tertiary: #f1f5f9;--color-bg-hover: #f1f5f9;--color-primary-bg: #e0f1fe;--color-primary-dark: #0172D6;--color-text-tertiary: #94a3b8;--color-success-bg: #dcfce7;--color-danger-bg: #fee2e2;--color-warning-bg: #fff7ed;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .03);--shadow-md: 0 2px 4px -1px rgba(0, 0, 0, .04);--shadow-lg: 0 4px 8px -2px rgba(0, 0, 0, .05);--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--transition: background-color .2s ease, border-color .2s ease, color .2s ease, opacity .2s ease}[data-theme=dark]{--color-primary: #0283F0;--color-primary-hover: #29A0FF;--color-primary-light: #013d74;--color-success: #03BF40;--color-success-hover: #029E35;--color-success-light: #064e3b;--color-danger: #FF4242;--color-danger-hover: #E03030;--color-danger-light: #7f1d1d;--color-warning: #f97316;--color-warning-light: #78350f;--color-neutral: #94a3b8;--color-neutral-light: #27272a;--color-text-primary: #f4f4f5;--color-text-secondary: #d4d4d8;--color-text-muted: #a1a1aa;--color-border: #3f3f46;--color-bg: #18181b;--color-bg-subtle: #0f0f10;--color-bg-secondary: #27272a;--color-bg-tertiary: #3f3f46;--color-bg-hover: #27272a;--color-primary-bg: rgba(2, 131, 240, .1);--color-primary-dark: #29A0FF;--color-text-tertiary: #71717a;--color-success-bg: rgba(3, 191, 64, .15);--color-danger-bg: rgba(255, 66, 66, .15);--color-warning-bg: rgba(249, 115, 22, .15);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .5);--shadow-md: 0 2px 4px -1px rgba(0, 0, 0, .6);--shadow-lg: 0 4px 8px -2px rgba(0, 0, 0, .7)}[data-theme=dark] body{background:#0f0f10;color:#f4f4f5}.stats-bar-inline{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;flex:1}.stat-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:9999px;font-size:.8125rem;font-weight:500;border:1px solid}.stat-badge-label{color:inherit;opacity:.8}.stat-badge-value{font-weight:700}.stat-badge-apply{background-color:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.stat-badge-warning{background-color:var(--color-warning-light);border-color:var(--color-warning);color:var(--color-warning)}.stat-badge-ns1{background-color:var(--color-success-light);border-color:var(--color-success);color:var(--color-success)}.stat-badge-ns2{background-color:#ede9fe;border-color:#7c3aed;color:#7c3aed}[data-theme=dark] .stat-badge-apply{background-color:#1e3a5f}[data-theme=dark] .stat-badge-warning{background-color:#78350f}[data-theme=dark] .stat-badge-ns1{background-color:#064e3b}[data-theme=dark] .stat-badge-ns2{background-color:#312e81}.filters-container{margin-bottom:1rem;display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.filter-select{background-color:var(--color-bg);border:1px solid var(--color-border);padding:.625rem .875rem;border-radius:var(--radius-md);min-width:120px;box-shadow:var(--shadow-sm);font-size:.875rem;color:var(--color-text-primary);transition:var(--transition);cursor:pointer}.filter-select:hover{border-color:var(--color-primary)}.filter-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.filter-select-wide{min-width:140px}.attendance-table-container{overflow:auto;max-height:60vh;background-color:var(--color-bg);border-radius:var(--radius-lg);box-shadow:none;border:1px solid var(--color-border)}.attendance-table{min-width:100%;font-size:.9375rem;border-collapse:collapse}.attendance-table-header{position:sticky;top:0;z-index:20;background:var(--color-bg);box-shadow:0 2px 4px -1px #0000000f}.attendance-table-header th{text-align:left;padding:1rem .875rem;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border)}.th-student-id{width:8rem}.th-slot-active{background-color:var(--color-warning-light);color:var(--color-warning)}.attendance-table-row{border-bottom:1px solid var(--color-border);transition:var(--transition)}.attendance-table-row:last-child{border-bottom:none}.attendance-table-row:nth-child(odd){background-color:var(--color-bg)}.attendance-table-row:nth-child(2n){background-color:var(--color-bg-subtle)}.attendance-table-row:hover{background-color:var(--color-primary-light)}.attendance-table-row td{padding:1rem .875rem;vertical-align:middle;font-size:.875rem}@media(min-width:768px){.attendance-table-row td{font-size:.9375rem}}.td-slot-active{background-color:var(--color-warning-light)}.name-cell{display:flex;align-items:center;gap:.75rem}.student-id-mobile{display:none}.student-name-btn{font-weight:500;text-align:left;color:var(--color-primary);background:none;border:none;cursor:pointer;padding:0;font-size:.9375rem;transition:var(--transition)}.student-name-btn:hover{color:var(--color-primary-hover);text-decoration:underline}.student-name-btn:focus{outline:none;text-decoration:underline}.not-applied{font-size:.875rem;color:var(--color-text-muted);font-style:italic}.status-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:500}.status-badge-present{background-color:var(--color-success-light);color:#065f46;border:1px solid #a7f3d0}.status-badge-absent{background-color:var(--color-danger-light);color:#991b1b;border:1px solid #fecaca}.status-badge-na{background-color:var(--color-neutral-light);color:var(--color-text-secondary);border:1px solid var(--color-border)}[data-theme=dark] .status-badge-present{background-color:#03bf4026;color:#4ade80;border-color:#03bf404d}[data-theme=dark] .status-badge-absent{background-color:#ff424226;color:#f87171;border-color:#ff42424d}.exception-badge{display:inline-flex;align-items:center;padding:.125rem .5rem;border-radius:9999px;font-size:.6875rem;font-weight:500;margin-left:.25rem}.exception-badge-overnight{background-color:#dbeafe;color:#0172d6;border:1px solid #93c5fd}.exception-badge-sick{background-color:#fce7f3;color:#9d174d;border:1px solid #f9a8d4}.exception-badge-approved{background-color:#d1fae5;color:#065f46;border:1px solid #6ee7b7}.exception-badge-other{background-color:#e0e7ff;color:#3730a3;border:1px solid #a5b4fc}[data-theme=dark] .exception-badge-overnight{background-color:#1e3a5f;color:#93c5fd;border:1px solid #0283F0}[data-theme=dark] .exception-badge-sick{background-color:#831843;color:#f9a8d4;border:1px solid #ec4899}[data-theme=dark] .exception-badge-approved{background-color:#064e3b;color:#6ee7b7;border:1px solid #03BF40}[data-theme=dark] .exception-badge-other{background-color:#312e81;color:#a5b4fc;border:1px solid #6366f1}.exception-selector{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--color-bg-subtle);border-radius:var(--radius-md);margin-top:.5rem}.exception-label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary);white-space:nowrap}.exception-select{flex:1;padding:.5rem .75rem;font-size:.875rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text-primary);cursor:pointer;transition:var(--transition)}.exception-select:hover:not(:disabled){border-color:var(--color-primary)}.exception-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.exception-select:disabled{opacity:.6;cursor:not-allowed}.status-view{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}.attendance-buttons{display:flex;flex-direction:column;gap:.5rem}@media(min-width:640px){.attendance-buttons{flex-direction:row;align-items:center;gap:.375rem}}.attendance-btn{flex:1;font-size:.8125rem;padding:.5rem .75rem;min-width:80px;border-radius:var(--radius-sm);border:1px solid var(--color-border);cursor:pointer;transition:var(--transition);font-weight:500;background-color:var(--color-bg);color:var(--color-text-primary)}@media(min-width:640px){.attendance-btn{flex:none}}@media(min-width:768px){.attendance-btn{font-size:.875rem;padding:.5rem .875rem}}.attendance-btn:hover{background-color:var(--color-neutral-light);border-color:var(--color-primary)}.attendance-btn:focus{outline:none;box-shadow:0 0 0 3px var(--color-primary-light)}.attendance-btn-present-active{background-color:var(--color-success-light);border-color:var(--color-success);color:#065f46;font-weight:600}.attendance-btn-absent-active{background-color:var(--color-danger-light);border-color:var(--color-danger);color:#991b1b;font-weight:600}.attendance-btn-na-active{background-color:var(--color-neutral-light);border-color:var(--color-neutral);color:var(--color-text-secondary);font-weight:600}.warning-badge-container{display:inline-flex;align-items:center;gap:.5rem;margin-left:.5rem}.warning-badge{font-size:.75rem;padding:.25rem .625rem;border-radius:9999px;display:inline-flex;align-items:center;gap:.375rem;border:1px solid;cursor:pointer;transition:var(--transition);font-weight:500}.warning-badge:hover{opacity:.9}.warning-badge:focus{outline:none;box-shadow:0 0 0 3px #ff424233}.warning-badge-absent{color:var(--color-text-primary);background-color:var(--color-neutral-light);border-color:var(--color-border)}.warning-badge-absent:hover{background-color:var(--color-bg-subtle)}.warning-badge-phone{color:#92400e;background-color:var(--color-warning-light);border-color:#fde68a}.warning-badge-phone:hover{background-color:#fde68a}.warning-icon{width:.875rem;height:.875rem;flex-shrink:0}.warning-badge-text{font-size:.6875rem}[data-theme=dark] .warning-badge-absent{background-color:var(--color-neutral-light);border-color:var(--color-border);color:var(--color-text-primary)}[data-theme=dark] .warning-badge-absent:hover{background-color:var(--color-bg-subtle)}[data-theme=dark] .warning-badge-phone{background-color:#fbbf2433;border-color:#fbbf244d;color:#fcd34d}[data-theme=dark] .warning-badge-phone:hover{background-color:#fbbf244d}.modal-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:1rem;background-color:#00000073;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.modal-backdrop{position:absolute;inset:0;background-color:#00000080}.modal-container{position:relative;background-color:var(--color-bg);border-radius:var(--radius-lg);box-shadow:0 4px 6px -2px #0000000d,0 20px 40px -8px #00000026;border:1px solid var(--color-border);width:100%;max-width:520px;padding:1.75rem;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.modal-title{font-size:1.25rem;font-weight:600;color:var(--color-text-primary);margin-bottom:.25rem}.modal-subtitle{font-size:.875rem;color:var(--color-text-secondary)}.modal-close{color:var(--color-text-secondary);background:none;border:none;cursor:pointer;font-size:1.5rem;padding:.25rem;line-height:1;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:var(--transition);flex-shrink:0}.modal-close:hover{color:var(--color-text-primary);background-color:var(--color-neutral-light)}.modal-loading{padding:2rem 0;text-align:center;font-size:.875rem;color:var(--color-text-secondary)}.modal-warning{margin-bottom:1rem;padding:1rem;border-radius:var(--radius-md);background-color:var(--color-danger-light);border:1px solid #fecaca}.modal-warning-title{font-weight:600;color:var(--color-danger);margin-bottom:.5rem}.modal-warning-detail{font-size:.8125rem;color:var(--color-text-secondary);white-space:pre-wrap;line-height:1.6}[data-theme=dark] .modal-warning{background-color:#ff424226;border-color:#ff42424d}[data-theme=dark] .modal-warning-title{color:var(--color-danger)}[data-theme=dark] .modal-container,[data-theme=dark] .modal-content{box-shadow:0 4px 6px -2px #0000004d,0 20px 40px -8px #00000080}.modal-info{font-size:.875rem}.modal-info-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:.75rem 0;border-bottom:1px solid var(--color-border)}.modal-info-row:last-child{border-bottom:none;padding-bottom:0}.modal-info-label{color:var(--color-text-secondary);font-weight:500;flex-shrink:0;min-width:7.5rem}.modal-info-value{font-weight:500;color:var(--color-text-primary);text-align:right;word-break:break-word}.modal-content{position:relative;background-color:var(--color-bg);border-radius:var(--radius-lg);box-shadow:0 4px 6px -2px #0000000d,0 20px 40px -8px #00000026;border:1px solid var(--color-border);width:100%;max-width:500px;padding:1.75rem;max-height:90vh;overflow-y:auto}.modal-content.modal-wide{max-width:800px}.modal-content .modal-title{margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.modal-actions{margin-top:1.5rem;display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid var(--color-border)}.modal-btn{padding:.625rem 1.25rem;color:#fff;border-radius:var(--radius-md);border:none;cursor:pointer;transition:var(--transition);font-weight:500;font-size:.875rem;box-shadow:none}.modal-btn:hover:not(:disabled){opacity:.95}.modal-btn:disabled{opacity:.6;cursor:not-allowed}.modal-btn-approve{background-color:var(--color-success)}.modal-btn-approve:hover:not(:disabled){background-color:var(--color-success-hover)}.modal-btn-close{background-color:var(--color-primary)}.modal-btn-close:hover:not(:disabled){background-color:var(--color-primary-hover)}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;background:var(--color-bg);padding:1.75rem;border-radius:var(--radius-lg);box-shadow:none;border:1px solid var(--color-border);flex-wrap:wrap;gap:1rem}.history-date{font-size:1rem;font-weight:500;color:var(--color-text-primary)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:var(--color-bg-subtle)}.login-card{background:var(--color-bg);border-radius:var(--radius-lg);box-shadow:0 8px 16px -4px #0000001a;border:1px solid var(--color-border);padding:2.5rem;width:100%;max-width:28rem}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:1.875rem;font-weight:600;color:var(--color-text-primary);margin-bottom:.5rem}.login-header p{color:var(--color-text-secondary);font-size:.875rem}.login-error{background:transparent;border:none;color:#ff4242;font-size:.875rem;font-weight:500;padding:0}[data-theme=dark] .login-error{background:transparent;border:none;color:#ff9b9b}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--color-text-primary)}.form-group input{padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;background-color:var(--color-bg);transition:var(--transition);color:var(--color-text-primary)}.form-group input::placeholder{color:var(--color-text-muted)}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-group input:disabled{background-color:var(--color-neutral-light);cursor:not-allowed;opacity:.6}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{flex:1;padding-right:2.75rem}.password-toggle-btn{position:absolute;right:.75rem;display:flex;align-items:center;justify-content:center;padding:.25rem;background:transparent;border:none;border-radius:3px;color:var(--color-text-tertiary);cursor:pointer;transition:color .2s}.password-toggle-btn:hover{color:var(--color-text-primary)}.login-loading{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1rem;color:var(--color-text-muted);font-size:.875rem}.login-loading .login-spinner{animation:spin 1s linear infinite;flex-shrink:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.google-login-section{display:flex;justify-content:center;margin-top:.75rem;margin-bottom:.75rem}.user-name{font-size:.875rem;font-weight:500;color:var(--color-text-primary)}.theme-toggle-btn{display:flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;padding:.5rem;background-color:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);color:var(--color-text-secondary)}.theme-toggle-btn:hover{background-color:var(--color-neutral-light);color:var(--color-text-primary)}.theme-toggle-btn svg{width:1.125rem;height:1.125rem}.loading-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.loading-spinner{width:3rem;height:3rem;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@media(max-width:480px){.user-name{width:100%;text-align:center;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.stat-card{padding:.875rem}.stat-value{font-size:1.125rem}.filters-container{flex-direction:row;align-items:center}.filter-select{flex:1;min-width:0;padding:.75rem;font-size:1rem}.attendance-table-container{max-height:none;overflow:visible}.attendance-table{display:block}.attendance-table-header{display:none}.attendance-table tbody{display:flex;flex-direction:column;gap:.5rem}.attendance-table-row{display:flex;flex-direction:column;padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);box-shadow:none;margin-bottom:0;gap:.5rem}.attendance-table-row:hover{background-color:var(--color-bg)}.attendance-table-row td{display:block;padding:0;border:none;background:transparent!important}.td-student-id{display:none!important}.student-id-mobile{display:inline;font-size:.75rem;color:var(--color-text-secondary);margin-left:auto;font-weight:500}.td-name{padding-bottom:0;border-bottom:none}.name-cell{display:flex;flex-direction:row;align-items:center;gap:.5rem;flex-wrap:nowrap}.student-name-btn{font-size:1rem;font-weight:600}.attendance-table-row .slots-container{display:flex;flex-direction:row;gap:.5rem}.td-slot{display:flex!important;flex-direction:column;gap:.25rem;flex:1}.td-slot:before{content:attr(data-label);font-size:.6875rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase}.td-slot-active{background-color:var(--color-warning-light)!important;padding:.5rem!important;border-radius:var(--radius-sm)}.td-slot:not(.td-slot-active){padding:.5rem;background-color:var(--color-bg-subtle);border-radius:var(--radius-sm)}.td-slot:not(.td-slot-active) .attendance-buttons{display:none}.td-slot:not(.td-slot-active) .status-view{display:block}.attendance-buttons{flex-direction:row;gap:.375rem}.attendance-btn{flex:1;min-width:unset;padding:.625rem .25rem;font-size:.8125rem;min-height:44px}.warning-badge-container{margin-left:0;margin-top:0}.warning-badge{padding:.25rem .5rem;font-size:.75rem}.modal-overlay{padding:0}.modal-container{max-width:100%;max-height:100%;height:100%;border-radius:0;padding:1.25rem}.modal-title{font-size:1.125rem}.modal-btn{padding:.875rem 1rem;min-height:48px}.modal-actions{flex-direction:column;gap:.5rem}.modal-actions .modal-btn{width:100%}.history-header{flex-direction:column;align-items:stretch;padding:1rem}.history-date{text-align:center}.login-card{padding:1.5rem;border-radius:var(--radius-md);box-shadow:0 8px 16px -4px #0000001a}.login-header h1{font-size:1.5rem}.form-group input{padding:.875rem;font-size:1rem}.readonly-notice{width:100%;text-align:center}}@media(min-width:481px)and (max-width:768px){.attendance-buttons{flex-direction:row}.attendance-btn{min-height:44px}.modal-container{margin:1rem;max-height:calc(100vh - 2rem)}}@media(hover:none)and (pointer:coarse){.attendance-btn,.bulk-btn,.duty-tab,.filter-select,.export-btn,.back-btn,.logout-btn{min-height:44px}.attendance-btn:active,.bulk-btn:active,.duty-tab:active,.export-btn:active{opacity:.9}.attendance-table-container{-webkit-overflow-scrolling:touch}button{-webkit-user-select:none;user-select:none}}@supports (padding: max(0px)){.dashboard-container,.history-container,.login-container{padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right));padding-bottom:max(1rem,env(safe-area-inset-bottom))}.modal-container{padding-bottom:max(1.5rem,env(safe-area-inset-bottom))}}@media(max-height:500px)and (orientation:landscape){.modal-container{max-height:100vh}.attendance-table-container{max-height:50vh}}.filter-input{padding:.625rem .875rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg);color:var(--color-text-primary);font-size:.875rem}.data-table-container{overflow-x:auto;background-color:var(--color-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table th{text-align:left;padding:1rem .75rem;background-color:var(--color-bg-subtle);font-weight:600;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);text-transform:none}.data-table th.text-center{text-align:center}.data-table td{padding:.875rem .75rem;border-bottom:1px solid var(--color-border);color:var(--color-text-primary)}.data-table td.text-center{text-align:center}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover{background-color:var(--color-bg-subtle)}.data-table-empty{text-align:center;color:var(--color-text-muted);padding:2rem!important}.role-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600}.role-badge-admin{background-color:var(--color-warning-light);color:var(--color-warning)}.role-badge-user{background-color:var(--color-success-light);color:var(--color-success)}.role-badge-duty{background-color:var(--color-primary-light);color:var(--color-primary)}.role-badge-homeroom{background-color:#f3e8ff;color:#7c3aed}.table-actions{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}.table-btn{padding:.375rem .75rem;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.8125rem;font-weight:500;transition:var(--transition)}.table-btn-edit{background-color:var(--color-primary);color:#fff}.table-btn-edit:hover{background-color:var(--color-primary-hover)}.table-btn-log{background-color:#8b5cf6;color:#fff}.table-btn-log:hover{background-color:#7c3aed}.table-btn-delete{background-color:var(--color-danger);color:#fff}.table-btn-delete:hover{background-color:#ff4242}.notfound-layout{min-height:100vh;background-color:var(--color-bg-secondary);display:flex;flex-direction:column}.notfound-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;background-color:var(--color-bg);border-bottom:1px solid var(--color-border)}.notfound-logo{display:flex;align-items:center;gap:.75rem}.notfound-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 1.5rem;text-align:center}.notfound-icon-wrapper{width:120px;height:120px;background:#fecaca;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:2rem}.notfound-icon{width:64px;height:64px;color:#ff4242}[data-theme=dark] .notfound-icon-wrapper{background:#7f1d1d}[data-theme=dark] .notfound-icon{color:#ff4242}.notfound-icon-wrapper.warning{background:#fde68a}.notfound-icon-wrapper.warning .notfound-icon{color:#d97706}[data-theme=dark] .notfound-icon-wrapper.warning{background:#78350f}[data-theme=dark] .notfound-icon-wrapper.warning .notfound-icon{color:#fbbf24}.notfound-code{font-size:4rem;font-weight:800;color:var(--color-text-primary);line-height:1;margin-bottom:1rem;letter-spacing:-.02em}.notfound-title{font-size:1.75rem;font-weight:600;color:var(--color-text-primary);margin-bottom:1rem}.notfound-description{font-size:1rem;line-height:1.6;color:var(--color-text-secondary);margin-bottom:2.5rem;max-width:480px}.notfound-actions{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.notfound-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--radius-md);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.notfound-btn-primary{background-color:#0283f0;color:#fff}.notfound-btn-primary:hover{background-color:#0283f0;transform:translateY(-1px);box-shadow:0 4px 12px #0283f04d}.notfound-btn-secondary{background-color:var(--color-bg);color:var(--color-text-primary);border:1px solid var(--color-border)}.notfound-btn-secondary:hover{background-color:var(--color-bg-secondary);border-color:var(--color-text-muted)}@media(max-width:768px){.notfound-header{padding:1rem 1.5rem}.notfound-content{padding:3rem 1.5rem}.notfound-icon-wrapper{width:100px;height:100px}.notfound-icon{width:52px;height:52px}.notfound-code{font-size:3rem}.notfound-title{font-size:1.5rem}.notfound-description{font-size:.9375rem}.notfound-actions{flex-direction:column;width:100%;max-width:280px}.notfound-btn{width:100%;justify-content:center}}.modal-form-group{margin-bottom:1rem}.modal-form-group:last-of-type{margin-bottom:1.5rem}.modal-form-group label{display:block;margin-bottom:.375rem;font-weight:600;font-size:.875rem;color:var(--color-text-primary)}.modal-form-group input,.modal-form-group select,.modal-form-group textarea{width:100%;padding:.625rem .875rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg);color:var(--color-text-primary);font-size:.875rem;transition:var(--transition);font-family:inherit;resize:vertical}.modal-form-group input:focus,.modal-form-group select:focus,.modal-form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.modal-form-group input:disabled,.modal-form-group select:disabled,.modal-form-group textarea:disabled{background-color:var(--color-bg-subtle);cursor:not-allowed;opacity:.7}.modal-form-group .form-hint{font-size:.75rem;color:var(--color-text-muted);margin-top:.25rem}.modal-form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border)}.btn-submit{padding:.625rem 1.25rem;background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.875rem;transition:var(--transition)}.btn-submit:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.btn-cancel{padding:.625rem 1.25rem;background-color:var(--color-neutral);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:500;font-size:.875rem;transition:var(--transition)}.btn-cancel:hover{background-color:#4b5563}.duty-title{font-size:1.5rem;font-weight:600;color:var(--color-text-primary)}.duty-calendar{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.duty-admin-badge{font-size:.625rem;padding:.125rem .375rem;background:var(--color-primary);color:#fff;border-radius:9999px}@media(max-width:768px){.duty-calendar{margin:0 -1rem;border-radius:0;border-left:none;border-right:none}.duty-admin-badge{font-size:.5rem;padding:.0625rem .25rem}}.swap-request-panel{position:relative;width:90%;max-width:500px;max-height:80vh;overflow-y:auto;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-lg)}.swap-panel-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.swap-panel-header h3{font-size:1.125rem;color:var(--color-text-primary);margin:0;flex:1}.swap-pending-badge{background:var(--color-warning);color:#fff;font-size:.75rem;padding:.25rem .5rem;border-radius:var(--radius-sm)}.swap-loading,.swap-empty{text-align:center;padding:1.5rem;color:var(--color-text-secondary)}.swap-section{margin-bottom:1.5rem}.swap-section h4{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.swap-list{list-style:none;padding:0;margin:0}.swap-item{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.75rem;background:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:.5rem}.swap-item-info{display:flex;align-items:center;gap:.375rem;flex:1;min-width:200px;flex-wrap:wrap}.swap-from,.swap-to{font-weight:500;color:var(--color-text-primary)}.swap-duty{font-size:.875rem;color:var(--color-primary);font-weight:500}.swap-arrow{color:var(--color-text-muted)}.swap-mutual{color:var(--color-success);font-weight:700}.swap-item-meta{display:flex;align-items:center;gap:.5rem}.swap-status{font-size:.75rem;padding:.125rem .5rem;border-radius:var(--radius-sm)}.swap-status.status-pending{background:var(--color-warning-light);color:var(--color-warning)}.swap-status.status-approved{background:var(--color-success-light);color:var(--color-success)}.swap-status.status-rejected{background:var(--color-danger-light);color:var(--color-danger)}.swap-status.status-cancelled{background:var(--color-neutral-light);color:var(--color-neutral)}.swap-reason{font-size:.75rem;color:var(--color-text-muted);cursor:help}.swap-actions{display:flex;gap:.375rem;width:100%;margin-top:.5rem}.btn-approve{flex:1;padding:.375rem .5rem;background:var(--color-success);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer;transition:var(--transition)}.btn-approve:hover:not(:disabled){background:var(--color-success-hover)}.btn-reject,.btn-cancel-swap{flex:1;padding:.375rem .5rem;background:var(--color-danger);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer;transition:var(--transition)}.btn-reject:hover:not(:disabled),.btn-cancel-swap:hover:not(:disabled){background:var(--color-danger-hover)}.btn-approve:disabled,.btn-reject:disabled,.btn-cancel-swap:disabled{opacity:.5;cursor:not-allowed}.swap-duty-info{background:var(--color-primary-light);padding:.75rem;border-radius:var(--radius-md);margin-bottom:1rem}.swap-duty-info p{margin:0;font-size:.875rem;color:var(--color-text-primary)}@media(max-width:768px){.swap-request-panel{width:95%;max-height:90vh;padding:1rem}.swap-item-info{min-width:100%}}.modal-lg{max-width:700px}.generator-steps{display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.generator-step{display:flex;flex-direction:column;align-items:center;gap:.25rem;flex:1;opacity:.5}.generator-step.active{opacity:1}.generator-step.completed{opacity:.8}.step-number{width:1.75rem;height:1.75rem;display:flex;align-items:center;justify-content:center;background:var(--color-border);color:var(--color-text-primary);border-radius:50%;font-size:.75rem;font-weight:600}.generator-step.active .step-number{background:var(--color-primary);color:#fff}.generator-step.completed .step-number{background:var(--color-success);color:#fff}.step-label{font-size:.75rem;color:var(--color-text-secondary)}.generator-step.active .step-label{color:var(--color-text-primary);font-weight:500}.generator-content{min-height:300px;max-height:400px;overflow-y:auto;margin-bottom:1rem}.generator-section h3{font-size:1rem;color:var(--color-text-primary);margin-bottom:1rem}.generator-select{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;background:var(--color-bg);color:var(--color-text-primary)}.generator-select-all{margin-bottom:.75rem;padding:.375rem .75rem;background:var(--color-bg);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer}.generator-select-all:hover{border-color:var(--color-primary)}.generator-user-list{display:flex;flex-direction:column;gap:.5rem;max-height:250px;overflow-y:auto}.generator-user-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer}.generator-user-item:hover{border-color:var(--color-primary)}.generator-user-item input{width:1rem;height:1rem}.generator-hint{font-size:.75rem;color:var(--color-text-secondary);margin-top:.5rem}.generator-warning{font-size:.875rem;color:var(--color-danger);margin-top:.5rem;padding:.5rem;background:var(--color-danger-light);border-radius:var(--radius-sm)}.generator-date-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.25rem;margin-top:.5rem}.generator-date{padding:.5rem;background:var(--color-bg);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;cursor:pointer;text-align:center}.generator-date:hover{border-color:var(--color-primary)}.generator-date.saturday{color:#2563eb}.generator-date.sunday{color:var(--color-danger)}[data-theme=dark] .generator-date.saturday{color:#60a5fa}.generator-date.excluded{background:var(--color-danger-light);border-color:var(--color-danger);color:var(--color-danger);text-decoration:line-through}.generator-stats{margin-bottom:1rem}.generator-stats h4,.generator-assignments h4{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:.5rem}.generator-stats-table{width:100%;border-collapse:collapse;font-size:.875rem}.generator-stats-table th,.generator-stats-table td{padding:.5rem;text-align:left;border-bottom:1px solid var(--color-border);color:var(--color-text-primary)}.generator-stats-table th{background:var(--color-bg-subtle);color:var(--color-text-secondary);font-weight:500}.generator-stats-table td.positive{color:var(--color-success)}.generator-assignments-list{max-height:200px;overflow-y:auto}.generator-assignment{display:flex;gap:.5rem;padding:.375rem .5rem;font-size:.75rem;color:var(--color-text-primary);border-radius:var(--radius-sm);margin-bottom:.25rem}.generator-assignment.new{background:var(--color-success-light)}.generator-assignment.unchanged{background:var(--color-bg-subtle)}.assignment-date{font-weight:500}.assignment-slot{color:var(--color-primary)}.assignment-user{flex:1}.assignment-change{color:var(--color-warning);font-size:.625rem}.generator-actions{border-top:1px solid var(--color-border);padding-top:1rem}@media(max-width:768px){.modal-lg{max-width:95%}.generator-steps{flex-wrap:wrap;gap:.5rem}.generator-step{flex:none;width:18%}.step-label{display:none}}.loading-fullpage{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem}.loading-spinner-small{width:1.25rem;height:1.25rem;border-width:2px}.loading-spinner-medium{width:2rem;height:2rem;border-width:3px}.loading-spinner-large{width:3rem;height:3rem;border-width:4px}.loading-text{color:var(--color-text-secondary);font-size:.875rem;margin:0}.loading-spinner-inline{display:inline-block;width:1rem;height:1rem;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;vertical-align:middle;margin-right:.5rem}.form-field-error{color:var(--color-danger);font-size:.75rem;margin-top:.25rem}.form-input-error{border-color:var(--color-danger)!important}.form-input-error:focus{box-shadow:0 0 0 3px var(--color-danger-light)!important}@media(min-width:768px)and (max-width:1024px){.data-table-container{margin:0 -.5rem}.modal-content{max-width:90%}.modal-content.modal-wide{max-width:95%}}@media(max-width:767px){.user-name{display:none}.data-table-container{margin:0 -1rem;border-radius:0;box-shadow:none;border-left:none;border-right:none}.data-table{font-size:.8125rem}.data-table th,.data-table td{padding:.75rem .5rem}.data-table th:first-child,.data-table td:first-child{padding-left:1rem}.data-table th:last-child,.data-table td:last-child{padding-right:1rem}.table-actions{flex-direction:column;gap:.375rem}.table-btn{width:100%;padding:.5rem;font-size:.75rem}.modal-overlay{padding:0;align-items:flex-end}.modal-content{max-width:100%;max-height:92vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:1.5rem 1.25rem;padding-bottom:max(1.5rem,env(safe-area-inset-bottom));box-shadow:0 -4px 24px #0000001f}.modal-content.modal-wide{max-width:100%}.modal-title{font-size:1.125rem}.modal-form-group label{font-size:.8125rem}.modal-form-group input,.modal-form-group select,.modal-form-group textarea{padding:.75rem;font-size:1rem}.modal-form-actions{flex-direction:column-reverse;gap:.5rem}.btn-submit,.btn-cancel,.btn-secondary{width:100%;padding:.875rem}.filter-select,.filter-input{width:100%}.pagination-btn{flex:1;min-width:80px}.role-badge{font-size:.6875rem;padding:.1875rem .5rem}.loading-fullpage{min-height:40vh}}@media(max-width:480px){.data-table{font-size:.75rem}.data-table th,.data-table td{padding:.625rem .375rem}.data-table-container{position:relative}.data-table-container:after{content:"";position:absolute;right:0;top:0;bottom:0;width:20px;background:linear-gradient(to right,transparent,var(--color-bg));pointer-events:none;opacity:.8}.modal-content{padding:1rem}.modal-title{font-size:1rem}}@media(min-width:1200px){.data-table{font-size:.9375rem}.modal-content{max-width:520px}.modal-content.modal-wide{max-width:900px}}@keyframes notice-blink{0%,to{opacity:1;background-color:var(--color-danger-light)}50%{opacity:.7;background-color:#fecaca}}@keyframes notice-blink-dark{0%,to{opacity:1;background-color:var(--color-danger-light)}50%{opacity:.7;background-color:#991b1b}}.notice-pinned-badge{background-color:var(--color-danger);color:#fff;padding:.125rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:600;flex-shrink:0}.notice-title{font-weight:600;color:var(--color-text-primary);flex-shrink:0}.notice-separator{color:var(--color-text-muted);flex-shrink:0}.notice-text{color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notice-content-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notice-textarea{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:inherit;font-size:.875rem;resize:vertical;min-height:100px;background-color:var(--color-bg);color:var(--color-text-primary);transition:var(--transition)}.notice-textarea:focus{outline:none;border-color:var(--color-primary)}.toggle-btn{padding:.25rem .625rem;border-radius:var(--radius-sm);border:1px solid;font-size:.75rem;font-weight:500;cursor:pointer;transition:var(--transition)}.toggle-btn:disabled{opacity:.6;cursor:not-allowed}.toggle-btn-active{background-color:var(--color-success-light);border-color:var(--color-success);color:var(--color-success)}.toggle-btn-inactive{background-color:var(--color-neutral-light);border-color:var(--color-border);color:var(--color-text-secondary)}.toggle-btn-pinned{background-color:var(--color-warning-light);border-color:var(--color-warning);color:var(--color-warning)}.toggle-btn-normal{background-color:var(--color-neutral-light);border-color:var(--color-border);color:var(--color-text-secondary)}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;color:var(--color-text-primary)}.checkbox-label input[type=checkbox]{width:1rem;height:1rem;cursor:pointer;accent-color:var(--color-primary)}@media(max-width:768px){.notice-text{flex-basis:100%;white-space:normal;margin-top:.25rem}.notice-content-cell{max-width:120px}}@media(max-width:480px){.notice-pinned-badge{font-size:.625rem;padding:.0625rem .375rem}}.home-layout{display:flex;min-height:100vh;background-color:var(--color-bg-secondary)}.home-sidebar{width:240px;background-color:var(--color-bg);border-right:1px solid var(--color-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100}.sidebar-logo{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border)}.logo-icon{width:32px;height:32px;background:#0d1b2e;border-radius:5px;display:flex;align-items:center;justify-content:center}.logo-text{font-size:1.125rem;font-weight:700;color:var(--color-text-primary)}.sidebar-nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.25rem}.sidebar-nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:5px;border:none;background:transparent;color:var(--color-text-secondary);font-size:.9375rem;cursor:pointer;transition:all .15s ease;width:100%;text-align:left}.sidebar-nav-item:hover{background-color:var(--color-bg-secondary);color:var(--color-text-primary)}.sidebar-nav-item.active{background-color:#0283f0;color:#fff}.sidebar-footer{padding:1rem .75rem;border-top:1px solid var(--color-border)}.sidebar-logout{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:5px;border:none;background:transparent;color:var(--color-text-muted);font-size:.9375rem;cursor:pointer;transition:all .15s ease;width:100%;text-align:left}.sidebar-logout:hover{background-color:#fef2f2;color:#ff4242}.home-main{flex:1;margin-left:240px;display:flex;flex-direction:column}.home-content{padding:1.5rem 2rem;flex:1}.home-stats-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:1.5rem;margin-bottom:2rem}.home-time-card{background:#0283f0;border-radius:10px;padding:1.5rem;color:#fff;min-height:140px}.time-card-header{display:flex;align-items:center;gap:.5rem;font-size:.875rem;opacity:.9;margin-bottom:.75rem}.time-card-display{display:flex;align-items:baseline;gap:.75rem;margin-bottom:.5rem}.time-period{font-size:1.25rem;font-weight:500}.time-value{font-size:3rem;font-weight:700;letter-spacing:-.02em}.time-card-date{font-size:.9375rem;opacity:.85}.home-stat-card{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:10px;padding:1.5rem;min-height:140px}.stat-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;font-size:.875rem;color:var(--color-text-secondary)}.stat-card-header svg{color:var(--color-text-muted)}.stat-card-actions{display:flex;gap:.5rem;margin-bottom:1rem}.slot-toggle-btn{flex:1;padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:var(--color-text-secondary);background-color:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:5px;cursor:pointer;transition:all .2s ease}.slot-toggle-btn:hover{background-color:var(--color-bg-hover);border-color:var(--color-primary-light)}.slot-toggle-btn.active{color:#fff;background-color:var(--color-primary);border-color:var(--color-primary);font-weight:600}.stat-card-row{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-top:1rem}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}.stat-label{font-size:1rem;color:var(--color-text-secondary);font-weight:500}.stat-value{font-size:2.25rem;font-weight:700}.stat-value.highlight-blue{color:#0283f0}.stat-divider{width:1px;height:40px;background-color:var(--color-border)}.stat-card-value{font-size:2.5rem;font-weight:700;margin-bottom:.25rem}.stat-card-value.highlight-blue{color:#0283f0}.stat-card-value.highlight-red{color:#ff4242}.stat-card-sub{font-size:.8125rem;color:var(--color-text-muted)}.home-quick-section{margin-bottom:2rem}.home-section-title{font-size:.9375rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:1rem}.home-quick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.home-quick-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:7px;cursor:pointer;transition:all .15s ease;text-align:left;width:100%}.home-quick-card:hover{border-color:var(--color-primary);box-shadow:0 4px 12px #0000000d}.quick-card-icon{width:40px;height:40px;border-radius:6px;background-color:var(--color-bg-secondary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.quick-card-content{flex:1;min-width:0}.quick-card-content h3{font-size:.9375rem;font-weight:600;color:var(--color-text-primary);margin-bottom:.25rem}.quick-card-content p{font-size:.8125rem;color:var(--color-text-muted)}.quick-card-arrow{color:var(--color-text-muted);flex-shrink:0}.home-quick-card:hover .quick-card-arrow{color:var(--color-primary)}.home-bottom-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.home-card{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:10px;padding:1.5rem;min-height:200px}.home-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border)}.home-card-header svg{color:var(--color-text-muted)}.home-card-header h3{font-size:.9375rem;font-weight:600;color:var(--color-text-primary)}.home-card-content{min-height:120px}.home-empty{color:var(--color-text-muted);font-size:.875rem;text-align:center;padding:2rem}.home-notice-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.home-notice-item{display:flex;gap:.75rem}.notice-dot{width:8px;height:8px;border-radius:50%;background-color:#0283f0;margin-top:.5rem;flex-shrink:0}.notice-content strong{display:block;font-size:.875rem;font-weight:600;color:var(--color-text-primary);margin-bottom:.25rem}.notice-content p{font-size:.8125rem;color:var(--color-text-muted);line-height:1.4}.home-handover{display:flex;flex-direction:column;gap:.75rem}.handover-date{font-size:.875rem;font-weight:600;color:#0283f0}.handover-text{font-size:.875rem;color:var(--color-text-primary);line-height:1.6;white-space:pre-wrap}@media(max-width:1200px){.home-stats-grid,.home-quick-grid,.home-bottom-grid{grid-template-columns:1fr}}@media(max-width:768px){.home-content{padding:1rem}.time-value{font-size:2.5rem}}[data-theme=dark] .logo-icon{background:#0d1b2e}[data-theme=dark] .sidebar-logout:hover{background-color:#450a0a}[data-theme=dark] .home-time-card{background:#0172d6}[data-theme=dark] .quick-card-icon{background-color:var(--color-bg-tertiary)}.dashboard-layout{display:flex;min-height:100vh;background-color:var(--color-bg-secondary)}.dashboard-main{flex:1;margin-left:240px;display:flex;flex-direction:column;min-width:0}.dashboard-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background-color:var(--color-bg);border-bottom:1px solid var(--color-border);position:relative;gap:1rem;flex-wrap:wrap}.dashboard-header-title{font-size:1.25rem;font-weight:600;color:var(--color-text-primary);flex-shrink:0;min-width:0}.header-notice-center{flex:0 1 auto;display:flex;flex-direction:column;gap:.5rem;max-width:600px;min-width:0;order:3;width:100%}@media(min-width:1500px){.header-notice-center{position:absolute;left:50%;transform:translate(-50%);width:auto;order:0}}.header-notice-badge{font-size:.875rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;min-width:0;word-break:break-word;color:var(--color-danger)}.header-notice-badge .notice-title,.header-notice-badge .notice-text{min-width:0;word-break:break-word}.dashboard-header-right{display:flex;align-items:center;gap:1rem;flex-shrink:0;margin-left:auto}@media(max-width:768px){.dashboard-header{padding:1rem}.dashboard-header-title{font-size:1.125rem}.header-notice-badge{font-size:.8125rem}}@media(max-width:640px){.dashboard-header{gap:.75rem}.dashboard-header-right{order:2}}.header-user-info{display:flex;flex-direction:column;align-items:flex-end;gap:.125rem}.header-user-name{font-size:.875rem;font-weight:600;color:var(--color-text-primary);line-height:1.2}.header-user-role{font-size:.75rem;color:var(--color-text-muted);line-height:1.2}.dashboard-content{display:flex;padding:1.5rem;gap:1.5rem;flex:1;min-width:0}.dashboard-left{flex:1;min-width:0}.dashboard-right{width:280px;flex-shrink:0;display:flex;flex-direction:column;gap:1rem}.dashboard-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.dashboard-stat-card{padding:1.25rem;border-radius:7px;text-align:center}.dashboard-stat-card .stat-label{display:block;font-size:.8125rem;font-weight:500;margin-bottom:.5rem}.dashboard-stat-card .stat-value{display:block;font-size:2rem;font-weight:700}.stat-present{background-color:#dcfce7;color:#166534}.stat-absent{background-color:#fee2e2;color:#991b1b}.stat-exception{background-color:#fef3c7;color:#92400e}.stat-na{background-color:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-secondary)}.dashboard-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.dashboard-tabs{display:flex;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:5px;overflow:hidden}.dashboard-tab{padding:.625rem 1rem;font-size:.875rem;font-weight:500;color:var(--color-text-secondary);background:transparent;border:none;cursor:pointer;transition:all .15s ease}.dashboard-tab:not(:last-child){border-right:1px solid var(--color-border)}.dashboard-tab:hover{background-color:var(--color-bg-secondary)}.dashboard-tab.active{background-color:#0283f0;color:#fff}.dashboard-filters{display:flex;align-items:center;gap:.75rem}.dashboard-filter-search{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:4px}.dashboard-filter-search input{border:none;background:transparent;outline:none;font-size:.8125rem;color:var(--color-text-primary);width:120px}.dashboard-filter-search input::placeholder{color:var(--color-text-muted)}.dashboard-filter-search svg{color:var(--color-text-muted);flex-shrink:0}.dashboard-filter-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:4px;font-size:.8125rem;color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.dashboard-filter-btn:hover{background-color:var(--color-bg-secondary)}.dashboard-filter-btn svg{color:var(--color-text-muted)}.dashboard-filter-btn.active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.dashboard-filter-btn.active svg{color:#fff}.filter-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;height:1.25rem;padding:0 .375rem;background-color:#fff;color:var(--color-primary);border-radius:6px;font-size:.6875rem;font-weight:600}.dashboard-filter-wrapper{position:relative}.filter-panel{position:absolute;top:calc(100% + .5rem);right:0;min-width:200px;padding:1rem;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:5px;box-shadow:0 4px 12px #0000001a;z-index:100}.filter-panel-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.filter-panel-row label{flex-shrink:0;width:2.5rem;font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.filter-panel-row select{flex:1;padding:.5rem .75rem;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:4px;font-size:.875rem;color:var(--color-text-primary);cursor:pointer}.filter-panel-actions{display:flex;gap:.5rem;margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--color-border)}.filter-reset-btn{flex:1;padding:.5rem;background-color:transparent;border:1px solid var(--color-border);border-radius:4px;font-size:.8125rem;color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.filter-reset-btn:hover{background-color:var(--color-bg-secondary)}.filter-apply-btn{flex:1;padding:.5rem;background-color:var(--color-primary);border:1px solid var(--color-primary);border-radius:4px;font-size:.8125rem;color:#fff;cursor:pointer;transition:all .15s ease}.filter-apply-btn:hover{background-color:var(--color-primary-dark)}[data-theme=dark] .filter-panel{box-shadow:0 4px 20px #0006}[data-theme=dark] .filter-panel-row select{background-color:var(--color-bg-secondary)}[data-theme=dark] .filter-panel-row select option{background-color:var(--color-bg-secondary);color:var(--color-text-primary)}.dashboard-table-container{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:7px;overflow:hidden}.dashboard-table{width:100%;border-collapse:collapse}.dashboard-table thead{background-color:var(--color-bg-secondary)}.dashboard-table th{padding:.875rem 1rem;text-align:left;font-size:.8125rem;font-weight:600;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border)}.dashboard-table td{padding:.875rem 1rem;font-size:.875rem;color:var(--color-text-primary);border-bottom:1px solid var(--color-border)}.dashboard-table tbody tr:last-child td{border-bottom:none}.dashboard-table tbody tr:hover{background-color:var(--color-bg-secondary)}.table-loading,.table-empty{text-align:center;padding:3rem 1rem!important;color:var(--color-text-muted)}.student-name-link{background:none;border:none;color:var(--color-text-primary);font-weight:500;cursor:pointer;padding:0;font-size:inherit;display:inline-flex;align-items:center;gap:.375rem}.student-name-link:hover{color:#0283f0;text-decoration:underline}.warning-dot{width:6px;height:6px;border-radius:50%;background-color:#ff4242}.dashboard-actions{display:flex;gap:.5rem}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.375rem;padding:.625rem .75rem;border-radius:5px;font-size:.8125rem;font-weight:500;cursor:pointer}.action-btn-secondary{background-color:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-secondary)}.action-btn-primary{background-color:#0283f0;border:none;color:#fff}.dashboard-panel{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:7px;padding:1rem}.panel-title{font-size:.875rem;font-weight:600;color:var(--color-text-primary);margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border)}.panel-content,.bulk-action-list{display:flex;flex-direction:column;gap:.5rem}.bulk-blocked-notice{padding:.625rem .75rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:5px;font-size:.75rem;color:#ff4242;text-align:center;line-height:1.4}[data-theme=dark] .bulk-blocked-notice{background-color:#ff424226;border-color:#ff42424d;color:#f87171}.bulk-action-item{display:flex;align-items:center;gap:.5rem;padding:.625rem .75rem;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:5px;font-size:.8125rem;color:var(--color-text-primary);cursor:pointer;transition:all .15s ease;width:100%;text-align:left}.bulk-action-item:hover:not(:disabled){background-color:var(--color-bg);border-color:var(--color-text-muted)}.bulk-action-item:disabled{opacity:.5;cursor:not-allowed}.bulk-dot{width:8px;height:8px;border-radius:50%}.bulk-dot-present{background-color:#03bf40}.bulk-dot-absent{background-color:#ff4242}.bulk-dot-na{background-color:#9ca3af}.readonly-notice{padding:.75rem;background-color:#fef3c7;border:1px solid #fbbf24;border-radius:5px;font-size:.8125rem;color:#92400e;text-align:center}.dashboard-panel .handover-textarea{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:5px;font-size:.8125rem;color:var(--color-text-primary);background-color:var(--color-bg-secondary);resize:vertical;font-family:inherit}.dashboard-panel .handover-textarea::placeholder{color:var(--color-text-muted)}.dashboard-panel .handover-textarea:focus{outline:none;border-color:#0283f0}.handover-save-btn{padding:.625rem;background-color:#0283f0;border:none;border-radius:5px;font-size:.8125rem;font-weight:500;color:#fff;cursor:pointer;transition:all .15s ease}.handover-save-btn:hover{background-color:#0283f0}@media(max-width:1200px){.dashboard-content{flex-direction:column}.dashboard-right{width:100%;flex-direction:row;flex-wrap:wrap}.dashboard-right>*{flex:1;min-width:200px}.dashboard-actions{width:100%}}@media(max-width:768px){.dashboard-main{margin-left:0}.dashboard-header,.dashboard-content{padding:1rem}.dashboard-stats-row{grid-template-columns:repeat(2,1fr)}.dashboard-toolbar{flex-direction:column;align-items:stretch}.dashboard-tabs{width:100%}.dashboard-tab{flex:1;text-align:center}.dashboard-filters{width:100%}.dashboard-filter-search{flex:1}.dashboard-filter-search input{width:100%}}[data-theme=dark] .stat-present{background-color:#03bf4026;color:#4ade80}[data-theme=dark] .stat-absent{background-color:#ff424226;color:#f87171}[data-theme=dark] .stat-exception{background-color:#fbbf2426;color:#fbbf24}[data-theme=dark] .readonly-notice{background-color:#fbbf2426;border-color:#fbbf244d;color:#fbbf24}.attendance-btn-group{display:flex;gap:.375rem}.attendance-btn-item{padding:.375rem .75rem;border-radius:4px;font-size:.75rem;font-weight:500;border:1px solid var(--color-border);background-color:var(--color-bg);color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.attendance-btn-item:hover:not(:disabled){border-color:var(--color-text-muted);background-color:var(--color-bg-secondary)}.attendance-btn-item:disabled{opacity:.6;cursor:not-allowed}.attendance-btn-item.active-present{background-color:#03bf40;border-color:#03bf40;color:#fff}.attendance-btn-item.active-present:hover:not(:disabled){background-color:#03bf40;border-color:#03bf40}.attendance-btn-item.active-absent{background-color:#ff4242;border-color:#ff4242;color:#fff}.attendance-btn-item.active-absent:hover:not(:disabled){background-color:#ff4242;border-color:#ff4242}.attendance-btn-item.active-na{background-color:#9ca3af;border-color:#9ca3af;color:#fff}.attendance-btn-item.active-na:hover:not(:disabled){background-color:#6b7280;border-color:#6b7280}[data-theme=dark] .attendance-btn-item{background-color:var(--color-bg-secondary);border-color:var(--color-border)}[data-theme=dark] .attendance-btn-item:hover:not(:disabled){background-color:var(--color-bg-tertiary)}[data-theme=dark] .attendance-btn-item.active-present{background-color:#03bf40;border-color:#03bf40}[data-theme=dark] .attendance-btn-item.active-absent{background-color:#ff4242;border-color:#ff4242}[data-theme=dark] .attendance-btn-item.active-na{background-color:#6b7280;border-color:#6b7280}.exception-badge-btn{padding:.375rem .875rem;border-radius:4px;font-size:.75rem;font-weight:600;border:none;color:#fff;cursor:pointer;transition:all .15s ease}.exception-badge-btn:hover{opacity:.85;transform:scale(1.02)}.duty-layout{display:flex;min-height:100vh;background-color:var(--color-bg-secondary)}.duty-main{flex:1;margin-left:240px;display:flex;flex-direction:column}.duty-content{display:flex;padding:1.5rem;gap:1.5rem;flex:1}.duty-left{flex:1;min-width:0}.duty-right{width:280px;flex-shrink:0;display:flex;flex-direction:column;gap:1rem}.duty-title-row{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem}.duty-page-title{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin-bottom:.25rem}.duty-page-desc{font-size:.875rem;color:var(--color-text-muted)}.duty-add-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background-color:#0283f0;border:none;border-radius:5px;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .15s ease}.duty-add-btn:hover{background-color:#0283f0}.duty-month-nav{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.duty-month-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.duty-month-btn:hover{background-color:var(--color-bg-secondary);color:var(--color-text-primary)}.duty-month-title{font-size:1rem;font-weight:600;color:var(--color-text-primary)}.duty-calendar-container{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:7px;overflow:hidden}.duty-loading{padding:3rem;text-align:center;color:var(--color-text-muted)}.duty-calendar-header{display:grid;grid-template-columns:repeat(7,1fr);background-color:var(--color-bg-secondary);border-bottom:1px solid var(--color-border)}.duty-weekday{padding:.75rem;text-align:center;font-size:.8125rem;font-weight:600;color:var(--color-text-secondary)}.duty-weekday.sunday{color:#ff4242}.duty-weekday.saturday{color:#0283f0}.duty-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr)}.duty-day{min-height:100px;padding:.5rem;border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.duty-day:nth-child(7n){border-right:none}.duty-day-empty{background-color:var(--color-bg-secondary)}.duty-day-today{background-color:#eff6ff}[data-theme=dark] .duty-day-today{background-color:#0283f01a}.duty-day-number{font-size:.875rem;font-weight:500;color:var(--color-text-primary);margin-bottom:.5rem}.duty-day-number.sunday{color:#ff4242}.duty-day-number.saturday{color:#0283f0}.duty-day-slots{display:flex;flex-direction:column;gap:.25rem}.duty-slot-badge{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:3px;font-size:.6875rem;cursor:pointer;transition:all .15s ease}.duty-slot-badge.slot-1{background-color:#dbeafe;color:#0283f0}.duty-slot-badge.slot-2{background-color:#ede9fe;color:#6d28d9}.duty-slot-badge:hover{opacity:.8}.duty-slot-badge.selected{outline:2px solid #0283F0;outline-offset:1px}.slot-label{font-weight:600}.slot-name{font-weight:400}.duty-panel{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:7px;overflow:hidden}.duty-panel-title{padding:1rem;font-size:.9375rem;font-weight:600;color:var(--color-text-primary);border-bottom:1px solid var(--color-border);margin:0}.duty-panel-content{padding:1rem}.duty-today-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 0}.duty-today-item:not(:last-child){border-bottom:1px solid var(--color-border)}.duty-today-avatar{width:40px;height:40px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff}.duty-today-avatar.slot-1{background-color:#0283f0}.duty-today-avatar.slot-2{background-color:#8b5cf6}.duty-today-info{display:flex;flex-direction:column;gap:.125rem}.duty-today-name{font-size:.875rem;font-weight:500;color:var(--color-text-primary)}.duty-today-time{font-size:.75rem;color:var(--color-text-muted)}.duty-today-empty{padding:.75rem 0;font-size:.8125rem;color:var(--color-text-muted)}.duty-swap-empty{font-size:.8125rem;color:var(--color-text-muted);text-align:center;padding:1rem 0}.duty-swap-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.duty-swap-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:5px;gap:.75rem;transition:all .15s ease}.duty-swap-item:hover{background-color:var(--color-bg);border-color:var(--color-primary)}.duty-swap-item>span{flex:1;font-size:.8125rem;color:var(--color-text-primary);font-weight:500}.duty-swap-view-btn{padding:.375rem .875rem;background-color:var(--color-primary);color:#fff;border:none;border-radius:4px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap;box-shadow:0 1px 2px #0000000d}.duty-swap-view-btn:hover{background-color:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 2px 4px #0283f033}.duty-swap-view-btn:active{transform:translateY(0);box-shadow:0 1px 2px #0000000d}.duty-swap-all-btn{width:100%;padding:.625rem;margin-top:.75rem;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:5px;font-size:.8125rem;color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.duty-swap-all-btn:hover{background-color:var(--color-bg);color:var(--color-text-primary)}.duty-assign-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:200}.duty-assign-modal{background-color:var(--color-bg);border-radius:10px;width:100%;max-width:400px;max-height:80vh;overflow:auto}.duty-assign-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border)}.duty-assign-header h3{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin:0}.duty-close-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;font-size:1.5rem;color:var(--color-text-muted);cursor:pointer}.duty-close-btn:hover{color:var(--color-text-primary)}.duty-current-assign{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background-color:var(--color-bg-secondary);font-size:.875rem;color:var(--color-text-secondary)}.duty-delete-btn{padding:.375rem .75rem;background-color:#fee2e2;border:none;border-radius:4px;font-size:.75rem;color:#ff4242;cursor:pointer}.duty-swap-request-btn{padding:.375rem .75rem;background-color:var(--color-primary-light);border:none;border-radius:4px;font-size:.75rem;color:var(--color-primary);cursor:pointer;transition:all .2s}.duty-swap-request-btn:hover{background-color:var(--color-primary);color:#fff}.duty-delete-btn:hover{background-color:#fecaca}.duty-user-select{padding:1rem 1.25rem}.duty-user-select-title{font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:.75rem}.duty-user-grid{display:flex;flex-direction:column;gap:.5rem}.duty-user-btn{padding:.75rem 1rem;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:5px;font-size:.875rem;color:var(--color-text-primary);cursor:pointer;text-align:left;transition:all .15s ease;display:flex;align-items:center;gap:.5rem}.duty-user-btn:hover{border-color:#0283f0;background-color:var(--color-bg)}.duty-user-btn.current{border-color:#0283f0;background-color:#eff6ff}.duty-user-btn .admin-badge{font-size:.6875rem;padding:.125rem .375rem;background-color:#fef3c7;color:#92400e;border-radius:3px}@media(max-width:1024px){.duty-content{flex-direction:column}.duty-right{width:100%;flex-direction:row}.duty-right>*{flex:1}}@media(max-width:768px){.duty-main{margin-left:0}.duty-content{padding:1rem}.duty-right{flex-direction:column}.duty-day{min-height:80px;padding:.25rem}.duty-slot-badge{font-size:.625rem;padding:.125rem .25rem}.duty-title-row{flex-direction:column;gap:1rem;align-items:stretch}.duty-add-btn{width:100%;justify-content:center}.duty-month-title{font-size:1rem}}@media(max-width:480px){.duty-day{min-height:70px;padding:.125rem}.duty-day-number{font-size:.6875rem}.duty-slot-badge{font-size:.5625rem;padding:.0625rem .125rem}.duty-slot-badge .slot-label{display:none}.duty-weekday{font-size:.6875rem;padding:.375rem 0}.duty-panel{padding:.875rem}.duty-panel-title{font-size:.875rem}}[data-theme=dark] .duty-slot-badge.slot-1{background-color:#0283f033;color:#0283f0}[data-theme=dark] .duty-slot-badge.slot-2{background-color:#8b5cf633;color:#a78bfa}[data-theme=dark] .duty-user-btn.current{background-color:#0283f01a}.handover-loading{padding:1rem;text-align:center;color:var(--color-text-muted);font-size:.875rem}.handover-save-btn:disabled{opacity:.6;cursor:not-allowed}.history-student{display:flex;flex-direction:column;gap:.125rem}.student-name{font-weight:600;color:var(--color-text-primary)}.student-id{font-size:.75rem;color:var(--color-text-muted)}.history-badge{display:inline-flex;align-items:center;justify-content:center;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:500}.badge-present{background-color:#03bf401a;color:#03bf40}.badge-absent{background-color:#ff42421a;color:#ff4242}.badge-exception{background-color:#8b5cf61a;color:#7c3aed}.badge-na{background-color:var(--color-bg-subtle);color:var(--color-text-muted)}.history-time{font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:.8125rem;color:var(--color-text-secondary)}@media(max-width:640px){.history-main .table-section{overflow-x:auto;-webkit-overflow-scrolling:touch}.history-main .data-table{min-width:480px}.history-main .data-table th,.history-main .data-table td{padding:.625rem .75rem;white-space:nowrap}.history-student{min-width:100px}.table-container{overflow-x:auto}.table-container .data-table{min-width:600px}.table-container .data-table th,.table-container .data-table td{padding:.625rem .75rem;white-space:nowrap}}[data-theme=dark] .badge-present{background-color:#03bf4033;color:#4ade80}[data-theme=dark] .badge-absent{background-color:#ff424233;color:#f87171}[data-theme=dark] .badge-exception{background-color:#8b5cf633;color:#a78bfa}.user-mgmt-overlay{position:fixed;inset:0;z-index:40}.audit-cell-time{font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:.8125rem;color:var(--color-text-secondary);white-space:nowrap}.audit-cell-user{font-weight:500}.audit-cell-target{color:var(--color-text-secondary)}.audit-cell-ip{font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:.8125rem;color:var(--color-text-muted)}.audit-cell-change{max-width:200px}.audit-old{color:var(--color-danger);text-decoration:line-through}.audit-arrow{color:var(--color-text-muted)}.audit-new{color:var(--color-success)}.audit-action-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:500}.audit-action-badge.badge-primary{background-color:#0283f01a;color:#0283f0}.audit-action-badge.badge-info{background-color:#06b6d41a;color:#0891b2}.audit-action-badge.badge-warning{background-color:#f59e0b1a;color:#d97706}.audit-action-badge.badge-success{background-color:#03bf401a;color:#03bf40}.audit-action-badge.badge-secondary{background-color:var(--color-bg-subtle);color:var(--color-text-secondary)}.notice-title-cell{display:flex;align-items:center;gap:.5rem}.notice-pin-icon{color:var(--color-warning);flex-shrink:0}.notice-title-text{font-weight:500}.notice-status-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:500;border:none;cursor:pointer;transition:var(--transition)}.notice-status-badge.active{background-color:#03bf401a;color:#03bf40}.notice-status-badge.inactive{background-color:var(--color-bg-subtle);color:var(--color-text-muted)}.notice-status-badge:hover:not(:disabled){opacity:.8}.notice-pin-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:500;border:none;cursor:pointer;transition:var(--transition);background-color:var(--color-bg-subtle);color:var(--color-text-muted)}.notice-pin-badge.pinned{background-color:#f59e0b1a;color:#d97706}.notice-pin-badge:hover:not(:disabled){opacity:.8}.notice-overlay{position:fixed;inset:0;z-index:40}.sidebar-toggle-btn{display:none;position:fixed;top:1rem;left:1rem;z-index:200;width:44px;height:44px;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);cursor:pointer;box-shadow:var(--shadow-md);transition:left .3s cubic-bezier(.4,0,.2,1),background-color .2s,transform .2s}.sidebar-toggle-btn.sidebar-open{left:calc(240px + 1rem)}.sidebar-toggle-btn:hover{background-color:var(--color-bg-subtle)}.sidebar-toggle-btn:active{transform:scale(.95)}.sidebar-overlay{display:none;position:fixed;inset:0;background-color:#00000080;z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media(max-width:1200px){.sidebar-toggle-btn{display:flex;align-items:center;justify-content:center}.home-sidebar{transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}.home-sidebar.sidebar-open{transform:translate(0);box-shadow:4px 0 20px #00000026}.sidebar-overlay{display:block}.dashboard-main,.home-main,.duty-main{margin-left:0!important;width:100%}.dashboard-header,.home-header{padding-left:4rem}}@media(max-width:1024px){.dashboard-content,.duty-content{flex-direction:column;gap:1.5rem}.dashboard-left,.dashboard-right,.duty-left,.duty-right{width:100%}.dashboard-right,.duty-right{flex-direction:row;flex-wrap:wrap;gap:1rem}.dashboard-right>*,.duty-right>*{flex:1;min-width:280px}.dashboard-stats-row{grid-template-columns:repeat(3,1fr);gap:.75rem}.home-stats-grid{grid-template-columns:1fr 1fr;gap:1rem}.home-time-card{grid-column:span 2}.attendance-table-container,.audit-table-container,.notice-table-container,.user-mgmt-table-container,.history-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.attendance-table,.audit-log-table,.notice-table,.user-mgmt-table,.history-table,.data-table{min-width:700px}}@media(max-width:768px){.dashboard-header{flex-wrap:wrap;gap:.75rem;padding:1rem 1rem 1rem 4rem}.dashboard-header-title{font-size:1.125rem}.dashboard-header-right{flex-shrink:0}.header-notice-center{order:3;width:100%}.dashboard-content{padding:1rem}.dashboard-stats-row{grid-template-columns:repeat(2,1fr);gap:.5rem}.dashboard-stat-card{padding:.875rem}.stat-value{font-size:1.375rem}.stat-label{font-size:.6875rem}.home-stats-grid{grid-template-columns:1fr;gap:1rem}.home-time-card{grid-column:span 1;padding:1.25rem}.time-value{font-size:2.25rem}.home-stat-card{padding:1.25rem}.stat-card-value{font-size:2rem}.dashboard-toolbar{flex-direction:column;align-items:stretch;gap:.75rem}.dashboard-tabs{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:.25rem}.dashboard-tabs::-webkit-scrollbar{display:none}.dashboard-tab{flex:0 0 auto;white-space:nowrap;padding:.5rem .875rem;font-size:.8125rem}.dashboard-filters{width:100%;flex-direction:column;gap:.5rem}.dashboard-filter-search,.dashboard-filter-search input{width:100%}.home-quick-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.attendance-table,.audit-log-table,.notice-table,.user-mgmt-table,.history-table{min-width:600px}.attendance-table th,.attendance-table td,.audit-log-table th,.audit-log-table td,.notice-table th,.notice-table td,.user-mgmt-table th,.user-mgmt-table td{padding:.5rem .625rem;font-size:.75rem}.modal-overlay{padding:1rem}.modal-content{max-height:calc(100vh - 2rem);max-width:100%;border-radius:var(--radius-lg)}.modal-header,.modal-body{padding:1rem}.header-notice-center{max-width:100%;order:10}}@media(max-width:480px){.dashboard-header{padding:.875rem .875rem .875rem 3.5rem}.sidebar-toggle-btn{top:.75rem;left:.75rem;width:40px;height:40px}.sidebar-toggle-btn.sidebar-open{left:calc(240px + .75rem)}.dashboard-stats-row{grid-template-columns:1fr 1fr;gap:.5rem}.dashboard-stat-card{padding:.75rem}.stat-value{font-size:1.25rem}.home-quick-grid{grid-template-columns:1fr;gap:.625rem}.time-value{font-size:1.875rem}.time-period{font-size:1rem}.attendance-table,.audit-log-table,.notice-table,.user-mgmt-table,.history-table{min-width:500px}.dashboard-content,.home-content{padding:.875rem}.modal-content{margin:.5rem;max-height:calc(100vh - 1rem)}.modal-header{padding:.875rem}.modal-title{font-size:1rem}.modal-body{padding:.875rem}.form-group label{font-size:.75rem}.form-group input,.form-group select,.form-group textarea{padding:.5rem .75rem;font-size:.875rem}.login-card{padding:1.5rem;margin:1rem}}@media(hover:none)and (pointer:coarse){.sidebar-nav-item,.sidebar-logout{padding:.875rem 1rem;min-height:48px}.dashboard-tab{min-height:44px}.attendance-btn-item{padding:.5rem .875rem;min-height:40px}.sidebar-nav-item:hover,.dashboard-tab:not(.active):hover,.attendance-btn-item:hover{background-color:transparent}.sidebar-nav-item:active,.dashboard-tab:not(.active):active{background-color:var(--color-bg-subtle)}.user-mgmt-dropdown button,.notice-dropdown button{padding:.875rem 1rem;min-height:48px}}@media(max-height:500px)and (orientation:landscape){.home-sidebar{padding:.5rem 0}.sidebar-logo{padding:.75rem 1rem}.sidebar-nav-item,.sidebar-footer{padding:.5rem 1rem}.modal-content{max-height:95vh}.modal-body{max-height:60vh;overflow-y:auto}}@media print{.home-sidebar,.sidebar-toggle-btn,.sidebar-overlay,.dashboard-header-right,.notice-dropdown,.user-mgmt-dropdown{display:none!important}.dashboard-main,.home-main,.duty-main{margin-left:0!important}.dashboard-content{padding:0}.attendance-table,.audit-log-table,.notice-table,.user-mgmt-table{min-width:100%}}@supports (padding: max(0px)){.home-sidebar{padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(0px,env(safe-area-inset-right))}.dashboard-header,.home-header{padding-left:max(4rem,calc(3rem + env(safe-area-inset-left)));padding-right:max(1rem,env(safe-area-inset-right))}.dashboard-content,.home-content{padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right));padding-bottom:max(1rem,env(safe-area-inset-bottom))}@media(max-width:1200px){.dashboard-header,.home-header{padding-left:max(4rem,calc(3rem + env(safe-area-inset-left)))}}}[data-theme=dark] .sidebar-toggle-btn{background-color:var(--color-bg);border-color:var(--color-border)}[data-theme=dark] .sidebar-overlay{background-color:#000000b3}[data-theme=dark] .home-sidebar.sidebar-open{box-shadow:4px 0 30px #0006}.modal-container-with-tabs{display:flex;flex-direction:column;max-height:85vh}.modal-tabs{display:flex;border-bottom:1px solid var(--color-border);padding:0 1.25rem;gap:.25rem;flex-shrink:0}.modal-tab{padding:.75rem 1rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--color-text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;min-height:44px}.modal-tab:hover{color:var(--color-text-primary);background-color:var(--color-bg-subtle)}.modal-tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.modal-tab-active:hover{color:var(--color-primary);background-color:transparent}.history-tab-content{padding:1rem 1.25rem;overflow-y:auto;flex:1;min-height:0}.history-loading,.history-empty{padding:2rem;text-align:center;color:var(--color-text-secondary)}.history-summary{margin-bottom:1rem}.history-summary-title{font-size:.75rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.history-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.history-stat-card{background-color:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.875rem}.history-stat-label{font-size:.75rem;color:var(--color-text-secondary);margin-bottom:.25rem}.history-stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);line-height:1.2}.history-stat-detail{font-size:.6875rem;color:var(--color-text-tertiary);margin-top:.25rem}.history-table-wrapper{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-md)}.history-table{width:100%;border-collapse:collapse;font-size:.8125rem}.history-table th,.history-table td{padding:.625rem .75rem;text-align:center;border-bottom:1px solid var(--color-border)}.history-table th{background-color:var(--color-bg-subtle);font-weight:600;color:var(--color-text-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.02em}.history-table tbody tr:last-child td{border-bottom:none}.history-table tbody tr:hover{background-color:var(--color-bg-subtle)}.history-date{font-weight:500;color:var(--color-text-primary)}.history-status{display:inline-block;padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.history-status-present{background-color:var(--color-success-bg);color:var(--color-success)}.history-status-absent{background-color:var(--color-danger-bg);color:var(--color-danger)}.history-status-exception{background-color:var(--color-warning-bg);color:var(--color-warning)}.history-status-na{background-color:var(--color-bg-subtle);color:var(--color-text-tertiary)}.mobile-student-list{display:flex;flex-direction:column;gap:.5rem}.mobile-student-card{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1rem;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);gap:.75rem}.mobile-student-card.has-warning{border-color:var(--color-warning);background-color:var(--color-warning-bg)}.mobile-student-info{display:flex;flex-direction:column;gap:.125rem;min-width:0;flex:1}.mobile-student-name{font-weight:600;font-size:.9375rem;color:var(--color-text-primary);display:flex;align-items:center;gap:.375rem}.mobile-student-id{font-size:.75rem;color:var(--color-text-secondary)}.mobile-student-warning{display:inline-flex;align-items:center;justify-content:center;width:1.125rem;height:1.125rem;background-color:var(--color-warning);color:#fff;border-radius:50%;font-size:.6875rem;font-weight:700;flex-shrink:0}.mobile-attendance-btns{display:flex;gap:.375rem;flex-shrink:0}.mobile-attendance-btn{min-width:44px;min-height:44px;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg);color:var(--color-text-secondary);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.mobile-attendance-btn:active{transform:scale(.95)}.mobile-attendance-btn.present{background-color:var(--color-success);border-color:var(--color-success);color:#fff}.mobile-attendance-btn.absent{background-color:var(--color-danger);border-color:var(--color-danger);color:#fff}.mobile-attendance-btn.exception{background-color:var(--color-warning);border-color:var(--color-warning);color:#fff}.mobile-student-card-detail-btn{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--color-text-tertiary);cursor:pointer;border-radius:var(--radius-sm);font-size:1.125rem}.mobile-student-card-detail-btn:hover{background-color:var(--color-bg-subtle);color:var(--color-text-secondary)}.mobile-view-only{display:none}.desktop-view-only{display:block}@media(max-width:768px){.mobile-view-only{display:block}.desktop-view-only{display:none}.modal-container{max-width:100%;max-height:100%;width:100%;height:100%;border-radius:0;margin:0}.modal-container-with-tabs{max-height:100vh;height:100vh}.history-stats-grid{grid-template-columns:1fr}.history-stat-value{font-size:1.25rem}.mobile-student-card{padding:.75rem}.mobile-attendance-btn{min-width:40px;min-height:40px;padding:.375rem .5rem;font-size:.6875rem}}@media(max-width:480px){.modal-tabs{padding:0 1rem}.modal-tab{padding:.625rem .75rem;font-size:.8125rem}.history-tab-content{padding:.875rem 1rem}.history-table th,.history-table td{padding:.5rem;font-size:.75rem}}.calendar{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem;width:100%}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.calendar-nav-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.calendar-nav-btn:hover{background-color:var(--color-bg-subtle);color:var(--color-text-primary)}.calendar-title{display:flex;align-items:baseline;gap:.375rem;font-weight:600}.calendar-year{font-size:.875rem;color:var(--color-text-secondary)}.calendar-month{font-size:1.125rem;color:var(--color-text-primary)}.calendar-today-btn{width:100%;padding:.5rem;margin-bottom:.75rem;background-color:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s ease}.calendar-today-btn:hover{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:.125rem;margin-bottom:.25rem}.calendar-weekday{text-align:center;font-size:.6875rem;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;padding:.375rem 0}.calendar-weekday.sunday{color:var(--color-danger)}.calendar-weekday.saturday{color:var(--color-primary)}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:.125rem}.calendar-day{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;aspect-ratio:1;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease;padding:.25rem}.calendar-day:hover:not(.disabled){background-color:var(--color-bg-subtle)}.calendar-day.other-month{opacity:.3}.calendar-day.today{background-color:var(--color-primary-bg)}.calendar-day.today .calendar-day-number{color:var(--color-primary);font-weight:700}.calendar-day.selected{background-color:var(--color-primary)}.calendar-day.selected .calendar-day-number{color:#fff;font-weight:600}.calendar-day.selected .calendar-day-dot{background-color:#fff}.calendar-day.disabled{opacity:.3;cursor:not-allowed}.calendar-day-number{font-size:.8125rem;color:var(--color-text-primary);line-height:1}.calendar-day-dot{position:absolute;bottom:.25rem;width:4px;height:4px;background-color:var(--color-primary);border-radius:50%}.calendar-day.has-data:not(.selected) .calendar-day-dot{background-color:var(--color-success)}.history-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:1rem}.history-header-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.history-date-header{display:flex;align-items:center;gap:.75rem}.history-date-input{padding:.5rem 1rem;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;font-weight:600;color:var(--color-text-primary);cursor:pointer;transition:all .2s}.history-date-input:hover{border-color:var(--color-primary)}.history-date-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0283f01a}[data-theme=dark] .history-date-input::-webkit-calendar-picker-indicator{filter:invert(1)}.history-today-badge{display:inline-flex;align-items:center;padding:.25rem .5rem;background-color:var(--color-primary-light);color:var(--color-primary);font-size:.75rem;font-weight:600;border-radius:var(--radius-sm)}.history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:var(--color-text-tertiary);text-align:center}.history-empty svg{margin-bottom:1rem;opacity:.5}.history-empty p{font-size:.9375rem;margin:0}@media(max-width:768px){.calendar{padding:.75rem}.calendar-day{padding:.125rem}.calendar-day-number{font-size:.75rem}.calendar-day-dot{width:3px;height:3px;bottom:.125rem}}.floor-status-container{padding:0}.floor-info-banner{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;margin-bottom:1.5rem;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:5px;font-size:.875rem;color:var(--color-text-secondary)}.floor-info-banner .floor-info-icon{font-size:1rem;flex-shrink:0}.floor-info-banner strong{color:#03bf40;font-weight:600}.floor-loading{display:flex;justify-content:center;align-items:center;min-height:200px;color:var(--color-text-muted)}.floor-section{margin-bottom:2rem}.floor-section-title{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:600;color:var(--color-text-primary);margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid var(--color-border)}.floor-cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.floor-card{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:7px;padding:1.25rem;transition:box-shadow .2s ease}.floor-card:hover{box-shadow:0 4px 12px #00000014}[data-theme=dark] .floor-card:hover{box-shadow:0 4px 12px #0000004d}.floor-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:.75rem}.floor-card-title{font-size:1.125rem;font-weight:600;color:var(--color-text-primary);margin:0}.floor-card-gender{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;font-weight:500;margin-left:auto}.floor-card-gender .gender-male{color:#0283f0}.floor-card-gender .gender-female{color:#ec4899}.floor-card-gender .gender-divider{color:var(--color-text-muted)}.floor-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.25rem}.floor-stat{display:flex;flex-direction:column;align-items:center;padding:.75rem .5rem;border-radius:5px;background-color:var(--color-bg-secondary)}.floor-stat-value{font-size:1.5rem;font-weight:700;line-height:1}.floor-stat-label{font-size:.75rem;color:var(--color-text-muted);margin-top:.25rem}.floor-stat-present .floor-stat-value{color:#03bf40}.floor-stat-absent .floor-stat-value{color:#ff4242}.floor-stat-exception .floor-stat-value{color:#f59e0b}.floor-stat-notchecked .floor-stat-value{color:#9ca3af}.floor-class-list{border-top:1px solid var(--color-border);padding-top:1rem}.floor-class-list-title{font-size:.8125rem;font-weight:600;color:var(--color-text-muted);margin:0 0 .75rem}.floor-class-table{width:100%;border-collapse:collapse;font-size:.8125rem}.floor-class-table th,.floor-class-table td{padding:.5rem;text-align:center;border-bottom:1px solid var(--color-border)}.floor-class-table th{font-weight:500;color:var(--color-text-muted);background-color:var(--color-bg-secondary)}.floor-class-table th:first-child,.floor-class-table td:first-child{text-align:left}.floor-class-table tbody tr:last-child td{border-bottom:none}.floor-class-table .stat-present{color:#03bf40;font-weight:600}.floor-class-table .stat-absent{color:#ff4242;font-weight:600}.floor-class-table .stat-exception{color:#f59e0b;font-weight:600}.gender-male{color:#0283f0;font-weight:500}.gender-female{color:#ec4899;font-weight:500}.stat-gender{white-space:nowrap}.stat-gender .gender-male,.stat-gender .gender-female{font-size:.75rem;margin:0 .125rem}@media(max-width:768px){.floor-cards-grid{grid-template-columns:1fr}.floor-stats-grid{grid-template-columns:repeat(2,1fr)}.floor-section-title{font-size:1.125rem}.floor-stat-value{font-size:1.25rem}}.female-management-container{display:flex;flex-direction:column;gap:2rem}.female-section{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:7px;padding:1.5rem}.female-section-title{display:flex;align-items:center;gap:.75rem;font-size:1.125rem;font-weight:600;color:var(--color-text-primary);margin:0 0 1rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.female-toast{padding:.75rem 1rem;border-radius:5px;margin-bottom:1rem;font-size:.875rem;font-weight:500;animation:fadeIn .2s ease-out}.female-toast.success{background-color:var(--color-success-bg, #d1fae5);color:var(--color-success, #065f46);border:1px solid var(--color-success-border, #6ee7b7)}.female-toast.error{background-color:var(--color-danger-bg, #fee2e2);color:var(--color-danger, #991b1b);border:1px solid var(--color-danger-border, #fca5a5)}.female-count{font-size:.875rem;font-weight:500;color:var(--color-text-muted);background-color:var(--color-bg-secondary);padding:.25rem .5rem;border-radius:7px}.female-add-form{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.female-input-group{display:flex;gap:.5rem}.female-input{flex:1;padding:.625rem .875rem;border:1px solid var(--color-border);border-radius:5px;background-color:var(--color-bg);color:var(--color-text-primary);font-size:.875rem}.female-input:focus{outline:none;border-color:var(--color-primary)}.female-add-btn{padding:.625rem 1rem;background-color:var(--color-primary);color:#fff;border:none;border-radius:5px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .15s}.female-add-btn:hover:not(:disabled){background-color:var(--color-primary-hover)}.female-add-btn:disabled{opacity:.5;cursor:not-allowed}.female-bulk-toggle{align-self:flex-start;padding:.5rem .75rem;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:4px;font-size:.8125rem;color:var(--color-text-secondary);cursor:pointer;transition:all .15s}.female-bulk-toggle:hover{background-color:var(--color-bg);border-color:var(--color-text-muted)}.female-bulk-form{display:flex;flex-direction:column;gap:.5rem}.female-bulk-textarea{padding:.75rem;border:1px solid var(--color-border);border-radius:5px;background-color:var(--color-bg);color:var(--color-text-primary);font-size:.875rem;resize:vertical;font-family:inherit}.female-bulk-textarea:focus{outline:none;border-color:var(--color-primary)}.female-bulk-add-btn{align-self:flex-end;padding:.5rem 1rem;background-color:#03bf40;color:#fff;border:none;border-radius:4px;font-size:.8125rem;font-weight:500;cursor:pointer}.female-bulk-add-btn:hover:not(:disabled){background-color:#03bf40}.female-quick-add{border-top:1px solid var(--color-border);padding-top:1rem}.female-subsection-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--color-text-secondary);margin:0 0 .75rem}.female-quick-list{display:flex;flex-wrap:wrap;gap:.5rem}.female-quick-item{display:flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:4px;font-size:.75rem;color:var(--color-text-primary);cursor:pointer;transition:all .15s}.female-quick-item:hover:not(:disabled){background-color:#fce7f3;border-color:#f9a8d4;color:#be185d}[data-theme=dark] .female-quick-item:hover:not(:disabled){background-color:#ec489933;border-color:#ec489966;color:#f472b6}.female-quick-info{font-size:.6875rem;color:var(--color-text-muted)}.female-quick-more{padding:.375rem .625rem;font-size:.75rem;color:var(--color-text-muted)}.female-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.female-clear-btn{padding:.375rem .75rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:4px;font-size:.75rem;color:#ff4242;cursor:pointer;transition:all .15s}.female-clear-btn:hover:not(:disabled){background-color:#fee2e2}[data-theme=dark] .female-clear-btn{background-color:#ff424226;border-color:#ff42424d;color:#f87171}.female-search{margin-bottom:1rem}.female-search-input{width:100%;padding:.625rem .875rem;border:1px solid var(--color-border);border-radius:5px;background-color:var(--color-bg-secondary);color:var(--color-text-primary);font-size:.875rem}.female-search-input:focus{outline:none;border-color:var(--color-primary);background-color:var(--color-bg)}.female-loading,.female-empty{padding:2rem;text-align:center;color:var(--color-text-muted)}.female-list{overflow-x:auto}.female-table{width:100%;border-collapse:collapse;font-size:.875rem}.female-table th,.female-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--color-border)}.female-table th{font-weight:600;color:var(--color-text-muted);background-color:var(--color-bg-secondary);font-size:.8125rem}.female-table tbody tr:hover{background-color:var(--color-bg-secondary)}.female-table .female-inactive{opacity:.6}.female-status{display:inline-block;padding:.25rem .5rem;border-radius:3px;font-size:.75rem;font-weight:500}.female-status.active{background-color:#dcfce7;color:#166534}.female-status.inactive{background-color:#f3f4f6;color:#6b7280}[data-theme=dark] .female-status.active{background-color:#03bf4033;color:#86efac}[data-theme=dark] .female-status.inactive{background-color:#6b728033;color:#9ca3af}.female-remove-btn{padding:.25rem .5rem;background-color:transparent;border:1px solid #fecaca;border-radius:3px;font-size:.75rem;color:#ff4242;cursor:pointer;transition:all .15s}.female-remove-btn:hover:not(:disabled){background-color:#fef2f2}[data-theme=dark] .female-remove-btn{border-color:#ff42424d}[data-theme=dark] .female-remove-btn:hover:not(:disabled){background-color:#ff424226}@media(max-width:768px){.female-section{padding:1rem}.female-input-group{flex-direction:column}.female-add-btn{width:100%}.female-table{font-size:.8125rem}.female-table th,.female-table td{padding:.5rem}}.cstats-page{display:flex;flex-direction:column;gap:1.25rem;flex:1;min-width:0;width:100%}.cstats-controls{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem 1.25rem}.cstats-control-group{display:flex;align-items:center;gap:.625rem}.cstats-label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary);white-space:nowrap}.cstats-select{padding:.4rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text-primary);font-size:.875rem;cursor:pointer}.cstats-slot-tabs{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.cstats-slot-tab{padding:.4rem .875rem;background:var(--color-bg);color:var(--color-text-secondary);border:none;font-size:.875rem;cursor:pointer;transition:var(--transition)}.cstats-slot-tab+.cstats-slot-tab{border-left:1px solid var(--color-border)}.cstats-slot-tab.active{background:var(--color-primary);color:#fff;font-weight:500}.cstats-export-btn{padding:.4rem .875rem;background:var(--color-bg);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;cursor:pointer;transition:var(--transition);white-space:nowrap}.cstats-export-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.cstats-state{padding:3rem;text-align:center;color:var(--color-text-secondary);font-size:.875rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.cstats-error{color:var(--color-danger)}.cstats-table-wrapper{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow-x:auto}.cstats-table{width:100%;border-collapse:collapse;font-size:.8125rem;min-width:900px}.cstats-table thead tr{background:var(--color-bg-subtle);border-bottom:2px solid var(--color-border)}.cstats-th-class{padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--color-text-secondary);white-space:nowrap;min-width:90px;position:sticky;left:0;background:var(--color-bg-subtle);z-index:1}.cstats-th-month,.cstats-th-avg{padding:.75rem .5rem;text-align:center;font-weight:600;color:var(--color-text-secondary);white-space:nowrap;min-width:60px}.cstats-th-avg{border-left:2px solid var(--color-border);background:var(--color-bg-subtle)}.cstats-table tbody tr{border-bottom:1px solid var(--color-border)}.cstats-table tbody tr:last-child{border-bottom:none}.cstats-table tbody tr:hover .cstats-td-class{background:var(--color-bg-hover)}.cstats-td-class{padding:.625rem 1rem;font-weight:500;color:var(--color-text-primary);white-space:nowrap;position:sticky;left:0;background:var(--color-bg);z-index:1;border-right:1px solid var(--color-border)}.cstats-td-rate{padding:.625rem .5rem;text-align:center;font-weight:500;transition:background-color .15s ease}.cstats-td-rate.weekend{background-color:var(--color-bg-subtle)!important;color:var(--color-text-muted);font-size:.75rem;opacity:.7}.cstats-th-month.weekend{color:var(--color-danger)}.cstats-td-avg{border-left:2px solid var(--color-border);font-weight:600}.cstats-legend{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:.875rem 1.25rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.cstats-legend-title{font-size:.75rem;font-weight:600;color:var(--color-text-secondary);margin-right:.25rem}.cstats-legend-item{padding:.25rem .625rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;color:var(--color-text-primary)}.cstats-legend-empty{background:var(--color-bg-subtle);border:1px solid var(--color-border)}.cstats-control-actions{display:flex;align-items:center;gap:.5rem;margin-left:auto}.cstats-config-btn{padding:.5rem 1rem;border-radius:8px;border:1px solid var(--color-border);background:var(--color-bg-card);color:var(--color-text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.cstats-config-btn:hover{background:var(--color-bg-hover);border-color:var(--color-primary)}.class-config-table-wrap{max-height:360px;overflow-y:auto;border:1px solid var(--color-border);border-radius:8px;margin-bottom:.75rem}.class-config-table{width:100%;border-collapse:collapse;font-size:.875rem}.class-config-table th,.class-config-table td{padding:.5rem .75rem;text-align:center;border-bottom:1px solid var(--color-border)}.class-config-table th{background:var(--color-bg-subtle);font-weight:600;color:var(--color-text-secondary);font-size:.8125rem;position:sticky;top:0}.class-config-table tr:last-child td{border-bottom:none}.class-config-select{padding:.25rem .5rem;border-radius:6px;border:1px solid var(--color-border);background:var(--color-bg-card);color:var(--color-text-primary);font-size:.875rem;width:100%}.class-config-input{width:80px;padding:.25rem .5rem;border-radius:6px;border:1px solid var(--color-border);background:var(--color-bg-card);color:var(--color-text-primary);font-size:.875rem;text-align:center}.class-config-delete-btn{padding:.25rem .625rem;border-radius:6px;border:1px solid var(--color-danger);background:transparent;color:var(--color-danger);font-size:.8125rem;cursor:pointer;transition:background .15s}.class-config-delete-btn:hover{background:#ef44441a}.class-config-add-btn{display:block;width:100%;padding:.5rem;border-radius:8px;border:1px dashed var(--color-border);background:transparent;color:var(--color-text-secondary);font-size:.875rem;cursor:pointer;margin-bottom:1rem;transition:background .15s,color .15s}.class-config-add-btn:hover{background:var(--color-bg-hover);color:var(--color-primary)}@media(max-width:767px){.cstats-controls{gap:.75rem;padding:.875rem 1rem}.cstats-control-actions{margin-left:0;width:100%;flex-direction:column}.cstats-config-btn,.cstats-export-btn{width:100%}.cstats-table{font-size:.75rem}.cstats-th-class,.cstats-td-class{min-width:70px;padding-left:.75rem;padding-right:.75rem}}
