@import "https://fonts.googleapis.com/css2?family=Sarabun:wght@300;400;500;600;700&display=swap";.ls-sidebar{flex-direction:column;height:100%;padding:0;display:flex}.ls-brand{border-bottom:1px solid #ffffff1a;padding:18px 20px}.ls-brand-title{color:#fff;font-size:1.15rem;font-weight:700}.ls-brand-sub{color:#fff9;margin-top:2px;font-size:.78rem}.ls-nav{flex:1;padding:10px 0;overflow-y:auto}.ls-group{color:#ffffff73;text-transform:uppercase;letter-spacing:1px;padding:14px 20px 6px;font-size:.72rem}.ls-link{color:#ffffffd9;border-left:3px solid #0000;align-items:center;gap:10px;padding:10px 20px;font-size:.92rem;text-decoration:none;transition:all .15s;display:flex}.ls-link:hover{color:#fff;background:#ffffff0f}.ls-link.active{border-left-color:var(--color-blue);color:#fff;background:#ffffff1a;font-weight:600}.ls-footer{border-top:1px solid #ffffff1a;padding:10px 0}.ls-link-external{color:#fff9;font-size:.85rem}.leave-header{border-bottom:1px solid var(--color-border);background:#fff;justify-content:space-between;align-items:center;padding:14px 24px;display:flex}.leave-header-name{color:var(--color-text);font-weight:600}.leave-header-role{color:var(--color-muted);margin-left:10px;font-size:.8rem;font-weight:400}.leave-header-actions{gap:8px;display:flex}.leave-header-btn{background:var(--color-bg);width:36px;height:36px;color:var(--color-text);border:1px solid var(--color-border);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;text-decoration:none;transition:all .15s;display:inline-flex}.leave-header-btn:hover{background:var(--color-blue);color:#fff;border-color:var(--color-blue)}.leave-layout{background:var(--color-bg);min-height:100vh;display:flex}.leave-layout-sidebar{background:var(--color-navy);color:#fff;flex-shrink:0;width:240px;height:100vh;position:sticky;top:0;overflow-y:auto}.leave-layout-main{flex-direction:column;flex:1;min-width:0;display:flex}.leave-layout-content{flex:1;padding:0}@media (width<=900px){.leave-layout{flex-direction:column}.leave-layout-sidebar{width:100%;height:auto;max-height:none;position:static}}.landing{max-width:1000px;margin:0 auto;padding:25px 20px 60px}.landing-greeting{background:linear-gradient(135deg, var(--color-navy) 0%, var(--color-blue) 100%);color:#fff;border-radius:12px;margin-bottom:24px;padding:22px 26px}.landing-greeting-hi{opacity:.85;font-size:.9rem}.landing-greeting-name{margin-top:4px;font-size:1.5rem;font-weight:700}.landing-greeting-role{opacity:.8;margin-top:6px;font-size:.85rem}.landing-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px;display:grid}.landing-card{background:var(--color-card);cursor:pointer;color:inherit;border-radius:10px;align-items:flex-start;gap:14px;padding:18px;text-decoration:none;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 1px 4px #0000000f}.landing-card:hover{transform:translateY(-2px);box-shadow:0 6px 14px #0000001a}.landing-card-icon{background:var(--color-bg);width:44px;height:44px;color:var(--color-blue);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.4rem;display:flex}.landing-card-title{color:var(--color-text);font-weight:600}.landing-card-desc{color:var(--color-muted);margin-top:3px;font-size:.86rem}.leave-page{max-width:1100px;margin:0 auto;padding:20px}.leave-title{color:#2c3e50;align-items:center;gap:10px;margin-bottom:20px;font-size:1.4rem;display:flex}.leave-card{background:#fff;border-radius:10px;margin-bottom:20px;padding:20px;box-shadow:0 2px 8px #0000000f}.leave-card-header{color:#34495e;border-bottom:2px solid #ecf0f1;align-items:center;gap:8px;margin-bottom:15px;padding-bottom:10px;font-weight:700;display:flex}.leave-grid{grid-template-columns:1fr 1fr 1fr;gap:15px;display:grid}.leave-field{flex-direction:column;display:flex}.leave-field-half{grid-column:span 1}.leave-field-full{grid-column:1/-1}.leave-field label{color:#7f8c8d;align-items:center;gap:5px;margin-bottom:6px;font-size:.85rem;display:flex}.leave-input{color:#2c3e50;background:#fff;border:1px solid #dcdde1;border-radius:6px;padding:9px 12px;font-size:.95rem}.leave-input:focus{border-color:#3498db;outline:none}.leave-checkbox{cursor:pointer;color:#2c3e50;align-items:center;gap:6px;display:flex}.leave-btn-primary{color:#fff;cursor:pointer;background:#3498db;border:none;border-radius:6px;margin-top:18px;padding:10px 22px;font-weight:700}.leave-btn-primary:disabled{cursor:not-allowed;background:#95a5a6}.leave-btn-danger{color:#fff;cursor:pointer;background:#e74c3c;border:none;border-radius:4px;align-items:center;gap:5px;margin-top:8px;padding:6px 12px;font-size:.85rem;display:inline-flex}.leave-btn-success{color:#fff;cursor:pointer;background:#27ae60;border:none;border-radius:4px;align-items:center;gap:5px;padding:8px 14px;font-weight:700;display:inline-flex}.leave-btn-reject{color:#fff;cursor:pointer;background:#e67e22;border:none;border-radius:4px;align-items:center;gap:5px;padding:8px 14px;font-weight:700;display:inline-flex}.leave-empty{text-align:center;color:#95a5a6;padding:40px}.leave-list{flex-direction:column;gap:12px;display:flex}.leave-row{background:#f8f9fa;border-left:4px solid #3498db;border-radius:8px;justify-content:space-between;gap:15px;padding:14px 16px;display:flex}.leave-row-main{flex:1}.leave-row-type{color:#2c3e50;margin-bottom:4px;font-weight:700}.leave-row-dates{color:#34495e;font-size:.95rem}.leave-row-note{color:#7f8c8d;margin-top:5px;font-size:.88rem}.leave-row-attach{color:#3498db;align-items:center;gap:4px;margin-top:5px;font-size:.88rem;text-decoration:none;display:inline-flex}.leave-row-attach:hover{text-decoration:underline}.leave-row-reject{color:#c0392b;margin-top:5px;font-size:.88rem;font-style:italic}.leave-row-side{flex-direction:column;align-items:flex-end;gap:8px;display:flex}.leave-status-pill{color:#fff;border-radius:20px;align-items:center;gap:5px;padding:5px 12px;font-size:.82rem;font-weight:700;display:inline-flex}.leave-approval-group{background:#fff;border:1px solid #ecf0f1;border-left:4px solid #f39c12;border-radius:8px;margin-bottom:14px;padding:14px 18px}.leave-approval-head{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.leave-approval-teacher{color:#2c3e50;font-size:1.05rem;font-weight:700}.leave-approval-meta{color:#7f8c8d;font-size:.85rem}.leave-approval-actions{gap:10px;margin-top:12px;display:flex}.leave-radio-row{flex-wrap:wrap;gap:8px;margin-top:6px;display:flex}.leave-radio-chip{cursor:pointer;color:#2c3e50;background:#ecf0f1;border:2px solid #0000;border-radius:20px;padding:8px 16px;font-weight:500;transition:all .15s}.leave-radio-chip input{display:none}.leave-radio-chip.active{color:#fff;background:#3498db;border-color:#2980b9}.leave-radio-chip:hover:not(.active){background:#d6dbdf}.leave-late-badge{color:#fff;background:#e67e22;border-radius:10px;align-items:center;gap:4px;margin-left:8px;padding:2px 8px;font-size:.72rem;font-weight:700;display:inline-flex}.leave-cancel-badge{color:#fff;background:#95a5a6;border-radius:10px;align-items:center;gap:4px;margin-left:8px;padding:2px 8px;font-size:.72rem;font-weight:700;display:inline-flex}.leave-tabs{border-bottom:2px solid #ecf0f1;gap:8px;margin-bottom:14px;display:flex}.leave-tab{cursor:pointer;color:#7f8c8d;background:0 0;border:none;border-bottom:3px solid #0000;align-items:center;gap:6px;padding:10px 18px;font-family:inherit;font-size:.95rem;font-weight:500;display:inline-flex}.leave-tab:hover{color:#2c3e50}.leave-tab.active{color:#3498db;border-bottom-color:#3498db;font-weight:700}.leave-range-bar{background:#f8f9fa;border-radius:8px;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;padding:10px 14px;display:flex}.leave-quota-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;display:grid}.leave-quota-item{background:#f8f9fa;border:1px solid #ecf0f1;border-radius:8px;padding:12px 14px}.leave-quota-label{color:#2c3e50;margin-bottom:6px;font-weight:700}.leave-quota-bar{background:#ecf0f1;border-radius:4px;height:8px;margin-bottom:6px;overflow:hidden}.leave-quota-fill{height:100%;transition:width .3s}.leave-quota-text{color:#34495e;font-size:.85rem}.leave-quota-hint{color:#3498db;margin-top:4px;font-size:.82rem}.leave-preview-bar{color:#2c3e50;background:#e8f5fe;border-left:4px solid #3498db;border-radius:6px;margin-top:15px;padding:10px 14px;font-size:.92rem}.leave-preview-bar.leave-preview-error{color:#c0392b;background:#fdedec;border-left-color:#e74c3c}.leave-autofill-bar{background:#eaf6fc;border-left:4px solid #3498db;border-radius:6px;align-items:center;gap:10px;margin-bottom:15px;padding:10px 15px;display:flex}@media (width<=768px){.leave-grid{grid-template-columns:1fr}.leave-row{flex-direction:column}.leave-row-side{align-items:stretch}.leave-page{padding:10px 10px 90px}.leave-radio-row{flex-direction:column}.leave-radio-chip{text-align:center}}.substitution-container{background-color:#f8f9fa;min-height:100vh;padding:30px;font-family:Sarabun,sans-serif}.page-title{color:#2c3e50;align-items:center;gap:10px;margin-bottom:25px;font-size:24px;font-weight:700;display:flex}.sub-card{background:#fff;border:1px solid #eef2f7;border-radius:12px;margin-bottom:30px;padding:25px;box-shadow:0 4px 6px #0000000d}.card-header{color:#34495e;border-bottom:2px solid #f0f2f5;align-items:center;gap:10px;margin-bottom:20px;padding-bottom:10px;font-size:18px;font-weight:700;display:flex}.input-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:20px;display:grid}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:#555;font-size:14px;font-weight:600}.form-control{border:1px solid #ddd;border-radius:6px;padding:10px 12px;font-family:Sarabun,sans-serif;font-size:14px;transition:border-color .2s}.form-control:focus{border-color:#3498db;outline:none;box-shadow:0 0 0 3px #3498db1a}.radio-group{gap:20px;padding:10px 0;display:flex}.radio-label{cursor:pointer;color:#333;align-items:center;gap:8px;font-size:15px;display:flex}.radio-label input[type=radio]{accent-color:#3498db;transform:scale(1.2)}.btn-submit{color:#fff;cursor:pointer;background-color:#27ae60;border:none;border-radius:6px;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px 25px;font-size:15px;font-weight:700;transition:all .2s;display:flex}.btn-submit:hover{background-color:#219150;transform:translateY(-1px)}.sub-table{border-collapse:separate;border-spacing:0;width:100%}.sub-table th{color:#7f8c8d;text-align:left;background-color:#f8f9fa;border-bottom:2px solid #eef2f7;padding:15px;font-weight:600}.sub-table td{vertical-align:middle;border-bottom:1px solid #f0f2f5;padding:15px}.sub-table tr:hover td{background-color:#fbfbfb}.period-badge{color:#fff;background-color:#3498db;border-radius:20px;padding:4px 10px;font-size:13px;font-weight:700;display:inline-block}.status-badge{border-radius:4px;align-items:center;gap:5px;padding:4px 10px;font-size:13px;font-weight:600;display:inline-flex}.status-empty{color:#e74c3c;background-color:#fbecec}.status-assigned{color:#27ae60;background-color:#e8f8f5}.btn-assign{color:#fff;cursor:pointer;text-shadow:0 1px 1px #0000001a;background-color:#f1c40f;border:none;border-radius:4px;align-items:center;gap:5px;padding:6px 12px;font-size:13px;font-weight:700;transition:all .2s;display:flex}.btn-assign:hover{background-color:#f39c12}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content{background:#fff;border-radius:12px;flex-direction:column;width:450px;max-height:85vh;padding:30px;animation:.3s ease-out slideUp;display:flex;box-shadow:0 10px 25px #0003}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.teacher-list{border:1px solid #eee;border-radius:8px;flex:1;margin:15px 0;overflow-y:auto}.teacher-option{cursor:pointer;border-bottom:1px solid #f0f0f0;align-items:center;gap:10px;padding:12px 15px;transition:all .2s;display:flex}.teacher-option:hover{color:#3498db;background-color:#f5f9ff}.teacher-option:last-child{border-bottom:none}.btn-close{color:#fff;cursor:pointer;background-color:#95a5a6;border:none;border-radius:6px;width:100%;margin-top:10px;padding:10px}.btn-close:hover{background-color:#7f8c8d}.printable-report{display:none}@media print{@page{margin:25mm 20mm 20mm 25mm;size:A4 portrait!important}body{visibility:hidden;background:#fff;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.sidebar,.navbar,.sub-card,.page-title,.modal-overlay,.no-print{display:none!important}.printable-report{visibility:visible;color:#000;background:#fff;width:100%;padding:15mm 0 0;font-family:Sarabun,sans-serif;position:absolute;top:0;left:0;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;display:block!important}.printable-report *{visibility:visible}.printable-report img{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.memo-header-top{justify-content:center;align-items:center;min-height:80px;margin-bottom:20px;padding:0 80px;display:flex;position:relative}.report-logo{object-fit:contain;width:75px;height:75px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.memo-title-text{text-align:center;font-size:28px;font-weight:700;line-height:1.2}.gov-header{border-top:none;margin-bottom:15px;padding-top:5px;font-size:16px;line-height:1.6}.gov-line{flex-wrap:wrap;margin-bottom:2px;display:flex}.gov-label{min-width:80px;margin-right:10px;font-weight:700}.gov-content{border-bottom:1px dotted #999;flex-grow:1;padding-left:5px}.gov-row-split{justify-content:space-between;display:flex}.gov-left,.gov-right{width:45%;display:flex}.report-body{text-indent:2.5cm;text-align:justify;margin-top:25px;margin-bottom:20px;font-size:16px;line-height:1.6}.print-table{border-collapse:collapse;width:100%;margin:10px 0;font-size:14px}.print-table th,.print-table td{text-align:center;vertical-align:middle;border:1px solid #000;padding:8px}.print-table th{-webkit-print-color-adjust:exact;font-weight:700;background-color:#f0f0f0!important}.print-footer{page-break-inside:avoid;justify-content:space-between;margin-top:40px;padding:0 20px;display:flex}.print-sign-box{text-align:center;width:40%}}.print-only-section{display:none!important}.official-table{border-collapse:collapse;background-color:#fff;width:100%;margin-top:10px;font-size:14px}.official-table th{color:#333;text-align:center;background-color:#f8f9fa;border:1px solid #ddd;padding:10px;font-weight:700}.official-table td{vertical-align:middle;border:1px solid #ddd;padding:10px}.period-badge{color:#fff;text-align:center;background:#34495e;border-radius:50%;width:25px;height:25px;font-weight:700;line-height:25px;display:inline-block}.tutoring-container{background-color:#f0f2f5;min-height:100vh;padding:20px;font-family:Sarabun,sans-serif}.sub-card{background:#fff;border-radius:8px;margin-bottom:20px;padding:20px;box-shadow:0 2px 4px #0000001a}.level-checkbox-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:10px;display:grid}.level-box{cursor:pointer;border:1px solid #ddd;border-radius:4px;align-items:center;gap:5px;padding:8px;display:flex}.level-box.selected{color:#27ae60;background:#eafaf1;border-color:#27ae60}.level-box.selected-joint{color:#e67e22;background:#fdf2e9;border-color:#e67e22}.subject-pool{background:#f8f9fa;border:2px dashed #ccc;border-radius:8px;gap:10px;min-height:80px;margin-top:10px;padding:10px;display:flex;overflow-x:auto}.pool-item{text-align:center;background:#fff;border:1px solid #ccc;border-radius:4px;min-width:110px;padding:8px;box-shadow:0 2px 4px #0000000d}.schedule-grid td{text-align:center;vertical-align:top;border:1px solid #eee;min-width:100px;height:70px}.slot-item{color:#fff;border-radius:4px;flex-direction:column;justify-content:center;height:90%;padding:5px;display:flex}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content.sub-modal{background:#fff;border-radius:8px;flex-direction:column;width:210mm;height:90vh;display:flex;overflow:hidden}.modal-header{background:#f8f9fa;border-bottom:1px solid #ddd;justify-content:space-between;align-items:center;padding:15px;display:flex}.modal-body{background:#fff;flex:1;padding:20px;overflow-y:auto}.modal-footer{text-align:right;background:#f8f9fa;border-top:1px solid #ddd;padding:10px}.btn-icon{cursor:pointer;color:#fff;border:none;border-radius:4px;align-items:center;gap:5px;padding:6px 12px;display:flex}.btn-icon.view{background:#3498db}.btn-icon.delete{background:#e74c3c}.btn-icon.print-btn{background:#34495e}.btn-close,.btn-close-icon{cursor:pointer;background:0 0;border:none;font-size:16px}.btn-close{color:#fff;background:#95a5a6;border-radius:4px;padding:8px 20px}@media print{@page{size:A4 portrait!important;margin:10mm!important}*,:before,:after{box-sizing:border-box!important}body{visibility:hidden!important;background:#fff!important;margin:0!important;padding:0!important}.modal-overlay{visibility:visible!important;z-index:9999!important;background:#fff!important;width:100%!important;height:auto!important;margin:0!important;padding:0!important;display:block!important;position:absolute!important;top:0!important;left:0!important}.modal-content.sub-modal{visibility:visible!important;width:100%!important;max-width:100%!important;box-shadow:none!important;border:none!important;margin:0!important;padding:0!important;position:static!important;overflow:visible!important}.modal-body{visibility:visible!important;width:100%!important;padding:0!important;overflow:visible!important}.modal-body *{visibility:visible!important}.no-print,.modal-header,.modal-footer,.btn-close,.sidebar,.navbar{display:none!important}.print-only-section{display:block!important}.official-doc-header{text-align:center;border-bottom:2px solid #000;width:100%;margin-bottom:15px;padding-bottom:10px}.doc-title{color:#000;margin:0;font-size:20px;font-weight:700;line-height:1.2}.doc-subtitle{color:#000;margin:5px 0;font-size:16px}.date-group{page-break-inside:avoid;width:100%;margin-bottom:20px}.official-table{border-collapse:collapse;color:#000;table-layout:fixed;font-size:13px;width:100%!important}.official-table th{white-space:nowrap;padding:6px 4px;color:#000!important;background-color:#eee!important;border:1px solid #000!important}.official-table td{word-wrap:break-word;padding:6px 4px;color:#000!important;border:1px solid #000!important}.official-footer{page-break-inside:avoid;margin-top:30px;flex-direction:row!important;justify-content:space-between!important;align-items:flex-start!important;width:100%!important;display:flex!important}.sign-block{text-align:center;width:45%!important}.sign-line{border-bottom:1px dotted #000;width:80%;height:1px;margin:30px auto 10px}}.viewer-container{box-sizing:border-box;background-color:#f0f2f5;flex-direction:column;align-items:center;min-height:100vh;padding:20px;font-family:Sarabun,sans-serif;display:flex}.viewer-controls{z-index:10;background:#fff;border-radius:8px;flex-wrap:wrap;align-items:center;gap:15px;margin-bottom:20px;padding:12px 20px;display:flex;box-shadow:0 2px 8px #00000014}.control-group{color:#333;align-items:center;gap:8px;font-size:14px;display:flex}.control-group select{border:1px solid #ddd;border-radius:4px;outline:none;min-width:160px;padding:6px 10px;font-family:Sarabun,sans-serif}.btn-search{color:#fff;cursor:pointer;background:#3498db;border:none;border-radius:4px;padding:8px 15px}.btn-print{color:#fff;cursor:pointer;background:#2c3e50;border:none;border-radius:4px;padding:8px 15px}.timetable-paper{box-sizing:border-box;background:#fff;border-radius:2px;width:297mm;min-height:210mm;margin:0 auto;padding:15mm;position:relative;box-shadow:0 0 15px #0000001a}.paper-header{justify-content:center;align-items:center;gap:20px;margin-bottom:15px;padding-bottom:5px;display:flex}.logo-area img{width:auto;height:70px}.text-area{text-align:center;color:#000}.text-area h1{margin:0;font-size:22px;font-weight:700;line-height:1.2}.text-area h2{margin:2px 0;font-size:16px;font-weight:700}.text-area h3{color:#333;margin:2px 0;font-size:16px;font-weight:700}.text-area p{color:#000;margin:2px 0;font-size:14px}.timetable-grid{border-collapse:collapse;table-layout:fixed;width:100%;margin-bottom:20px}.timetable-grid th,.timetable-grid td{text-align:center;vertical-align:middle;box-sizing:border-box;border:1px solid #000;padding:0;overflow:hidden}.timetable-grid th{background-color:#e0e0e0;height:40px;padding:5px;font-size:14px;font-weight:700}.day-header{width:70px}.day-cell{background-color:#f5f5f5;width:70px;font-size:16px;font-weight:700}.slot-cell{vertical-align:top;height:80px}.cell-content{box-sizing:border-box;text-align:center;border-radius:0;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:5px;font-size:13px;display:flex}.project-cell{border:2px solid #fff;box-shadow:inset 0 0 0 1px #eee}.tutor-cell{color:#e65100;background:#fff3e0;border:1px solid #ffe0b2;font-weight:700}.regular-cell{color:#33691e;background:#f1f8e9;border:1px solid #c5e1a5}.break-header{background-color:#dcdcdc!important}.merged-break{border:1px solid #000;padding:0;background-color:#f0f0f0!important}.vertical-text{writing-mode:vertical-rl;white-space:nowrap;color:#333;letter-spacing:2px;justify-content:center;align-items:center;height:100%;margin:0 auto;font-size:16px;font-weight:700;display:flex;transform:rotate(180deg)}.time-range{color:#555;margin-top:2px;font-size:11px;font-weight:400}.paper-footer{justify-content:space-around;margin-top:30px;padding-top:10px;display:flex}.sign-box{text-align:center;min-width:200px}.dots{margin-bottom:5px;font-size:14px;font-weight:700}.sign-name{margin-bottom:2px;font-size:13px}.sign-role{font-size:13px;font-weight:700}.sub-list-section{border-top:2px dashed #ccc;margin-top:20px;padding-top:10px;font-size:14px}.sub-list-section ul{padding-left:20px}.sub-list-section li{margin-bottom:5px}@media print{@page{size:A4 landscape;margin:5mm}.sidebar,.navbar,.viewer-controls,.no-print{display:none!important}html,body,#root,.app-container,.main-content,.viewer-container{background:#fff!important;width:100%!important;height:auto!important;min-height:0!important;margin:0!important;padding:0!important;display:block!important;overflow:visible!important}.timetable-paper{width:100%!important;max-width:100%!important;min-height:0!important;box-shadow:none!important;page-break-inside:avoid!important;break-inside:avoid!important;visibility:visible!important;border:none!important;margin:0!important;padding:0!important}.timetable-paper *{visibility:visible!important}*{-webkit-print-color-adjust:economy!important;print-color-adjust:economy!important}.day-cell{width:70px!important}.slot-cell,.break-cell{height:80px!important}.project-cell,.tutor-cell,.regular-cell{color:#000!important;box-shadow:none!important;background-color:#fff!important;border:1px solid #999!important}.timetable-grid th,.day-cell,.break-header,.merged-break{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;background-color:#e0e0e0!important}}.data-table{border-collapse:collapse;background:#fff;width:100%;margin-top:10px;font-size:14px}.data-table th{color:#2c3e50;text-align:left;background-color:#ecf0f1;padding:12px;font-weight:600}.data-table td{vertical-align:middle;border-bottom:1px solid #eee;padding:10px 12px}.no-data{text-align:center;color:#999;padding:20px}.hint-text{color:#7f8c8d;margin-bottom:15px;font-size:14px}.form-control{color:#2c3e50;background:#fff;border:1px solid #ddd;border-radius:4px;width:100%;padding:10px;font-size:14px}.form-control:focus{border-color:#3498db;outline:none}.form-group{margin-bottom:15px}.form-group label{color:#2c3e50;margin-bottom:5px;font-weight:500;display:block}.grid-2{grid-template-columns:1fr 1fr;gap:15px;display:grid}.btn-save{color:#fff;cursor:pointer;background-color:#27ae60;border:none;border-radius:4px;align-items:center;gap:6px;padding:10px 25px;font-weight:700;display:inline-flex}.btn-save:hover{background-color:#219150}.btn-save:disabled{cursor:not-allowed;background-color:#95a5a6}.btn-blue{color:#fff;cursor:pointer;background-color:#3498db;border:none;border-radius:4px;align-items:center;gap:6px;padding:8px 15px;display:inline-flex}.btn-blue:hover{background-color:#2980b9}.btn-gray{color:#fff;cursor:pointer;background-color:#95a5a6;border:none;border-radius:4px;padding:8px 15px}.btn-gray:hover{background-color:#7f8c8d}.btn-icon-del{color:#e74c3c;cursor:pointer;background:0 0;border:none;font-size:16px}.btn-icon-del:hover{color:#c0392b}.page-title{color:#2c3e50;align-items:center;gap:10px;margin:0 0 20px;font-size:1.4rem;display:flex}.config-box{background-color:#f8f9fa;border:1px solid #e0e0ea;border-radius:8px;margin-bottom:20px;padding:20px}.flex-row{flex-wrap:wrap;align-items:flex-end;gap:15px;display:flex}.divider{border:none;border-top:1px solid #eee;margin:20px 0}.tab-content{background-color:#fff;border-radius:10px;padding:24px;box-shadow:0 1px 4px #0000000f}.badge{border-radius:10px;padding:3px 8px;font-size:12px;font-weight:600;display:inline-block}input[type=date],input[type=time],input[type=number],input[type=text],input[type=url],select,textarea{font-family:inherit}:root{--color-navy:#1a1a4e;--color-blue:#3498db;--color-green:#27ae60;--color-orange:#f39c12;--color-red:#e74c3c;--color-text:#2c3e50;--color-muted:#7f8c8d;--color-bg:#f4f6f9;--color-card:#fff;--color-border:#e0e0ea;font-family:Sarabun,system-ui,sans-serif;line-height:1.5}*{box-sizing:border-box}body{background:var(--color-bg);color:var(--color-text);margin:0;padding:0}#root{min-height:100vh}.leave-app{min-height:100vh;display:flex}.leave-app-main{flex:1;padding:0;overflow-x:hidden}.leave-app-content{max-width:1100px;margin:0 auto;padding:20px}.leave-loading{min-height:60vh;color:var(--color-muted);justify-content:center;align-items:center;display:flex}
