:root{--font-sans:"Inter", "Sarabun", system-ui, -apple-system, sans-serif;--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--primary:#2563eb;--primary-hover:#1d4ed8;--primary-light:#eff6ff;--accent:#ea580c;--accent-hover:#c2410c;--accent-light:#fff7ed;--success:#16a34a;--success-light:#f0fdf4;--warning:#ca8a04;--warning-light:#fefce8;--danger:#dc2626;--danger-light:#fef2f2;--border-color:#e2e8f0;--border-focus:#93c5fd;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--shadow-glow:0 0 15px #2563ff26;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-normal:.25s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--bg-primary:#090d16;--bg-secondary:#111827;--bg-tertiary:#1f2937;--text-primary:#f9fafb;--text-secondary:#d1d5db;--text-muted:#6b7280;--primary:#3b82f6;--primary-hover:#60a5fa;--primary-light:#3b82f61a;--accent:#f97316;--accent-hover:#fb923c;--accent-light:#f973161a;--success:#22c55e;--success-light:#22c55e1a;--warning:#eab308;--warning-light:#eab3081a;--danger:#ef4444;--danger-light:#ef44441a;--border-color:#2d3748;--border-focus:#3b82f6;--shadow-sm:0 1px 2px 0 #00000080;--shadow-md:0 4px 6px -1px #0006, 0 2px 4px -2px #0006;--shadow-lg:0 10px 15px -3px #00000080, 0 4px 6px -4px #00000080;--shadow-glow:0 0 20px #3b82f640}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);transition:background-color var(--transition-normal), color var(--transition-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;overflow-x:hidden}button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}a{color:inherit;text-decoration:none}#root{flex-direction:column;min-height:100vh;display:flex}.app-wrapper{flex-direction:column;flex-grow:1;width:100%;max-width:1200px;margin:0 auto;padding:1.5rem;display:flex}.main-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.25rem;display:flex}.brand-section{align-items:center;gap:.75rem;display:flex}.brand-logo-container{background:linear-gradient(135deg, var(--primary), #4f46e5);border-radius:var(--radius-md);color:#fff;width:2.75rem;height:2.75rem;box-shadow:var(--shadow-md);justify-content:center;align-items:center;display:flex}.brand-logo-container.shabu-mode{background:linear-gradient(135deg, var(--accent), #f97316)}.brand-title{color:var(--text-primary);letter-spacing:-.025em;flex-direction:column;font-size:1.35rem;font-weight:700;display:flex}.brand-subtitle{color:var(--text-secondary);font-size:.75rem;font-weight:500}.header-controls{align-items:center;gap:.75rem;display:flex}.theme-toggle-btn{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;width:2.5rem;height:2.5rem;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);justify-content:center;align-items:center;display:flex}.theme-toggle-btn:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--text-muted)}.nav-tabs{background-color:var(--bg-tertiary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);gap:.25rem;width:fit-content;margin-bottom:2rem;padding:.35rem;display:flex}@media (width<=768px){.nav-tabs{white-space:nowrap;-webkit-overflow-scrolling:touch;width:100%;overflow-x:auto}}.nav-tab-btn{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.9rem;font-weight:600;display:flex}.nav-tab-btn:hover{color:var(--text-primary)}.nav-tab-btn.active{background-color:var(--bg-secondary);color:var(--primary);box-shadow:var(--shadow-sm)}.nav-tab-btn.active.shabu-accent-tab{color:var(--accent)}.grid-container{grid-template-columns:1fr;gap:1.5rem;display:grid}@media (width>=1024px){.grid-container.split-layout{grid-template-columns:2fr 1fr}}.card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);transition:box-shadow var(--transition-fast), border-color var(--transition-fast);max-width:100%;padding:1.5rem;overflow:hidden}.card:hover{box-shadow:var(--shadow-lg)}.card-title{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:1.25rem;font-size:1.15rem;font-weight:700;display:flex}.dashboard-overview{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.stat-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);align-items:center;gap:1rem;padding:1.25rem;display:flex}.stat-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:2.75rem;height:2.75rem;font-size:1.25rem;display:flex}.stat-icon.primary{background-color:var(--primary-light);color:var(--primary)}.stat-icon.success{background-color:var(--success-light);color:var(--success)}.stat-icon.warning{background-color:var(--warning-light);color:var(--warning)}.stat-number{color:var(--text-primary);font-size:1.5rem;font-weight:700}.stat-label{color:var(--text-secondary);font-size:.8rem;font-weight:500}.coverage-timeline-wrapper{margin-top:1rem;position:relative;overflow-x:auto}.coverage-timeline{min-width:600px;padding:1rem 0}.timeline-hours{border-bottom:1px solid var(--border-color);margin-bottom:1rem;padding-bottom:.5rem;display:flex}.hour-tick{text-align:left;color:var(--text-muted);flex:1;font-size:.75rem;font-weight:600}.employee-timeline-row{align-items:center;margin-bottom:.75rem;display:flex}.employee-timeline-name{width:120px;min-width:120px;color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:600;overflow:hidden}.employee-timeline-bar-container{background-color:var(--bg-tertiary);border-radius:var(--radius-sm);flex-grow:1;height:1.75rem;position:relative;overflow:hidden}.employee-timeline-bar{border-radius:var(--radius-sm);color:#fff;height:100%;box-shadow:var(--shadow-sm);text-shadow:0 1px 1px #0003;background:linear-gradient(90deg,#3b82f6,#2563eb);justify-content:center;align-items:center;font-size:.7rem;font-weight:700;display:flex;position:absolute}.employee-timeline-bar.off-duty{color:var(--text-muted);text-align:center;background:0 0;justify-content:center;width:100%;font-weight:500}.schedule-controls{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.week-navigation{align-items:center;gap:.75rem;display:flex}.schedule-grid-container{border-radius:var(--radius-lg);border:1px solid var(--border-color);width:100%;max-width:100%;box-shadow:var(--shadow-sm);display:block;overflow-x:auto}.schedule-table{border-collapse:collapse;text-align:left;width:100%;min-width:800px}.schedule-table th,.schedule-table td{border-bottom:1px solid var(--border-color);border-right:1px solid var(--border-color);padding:.75rem 1rem}.schedule-table th:last-child,.schedule-table td:last-child{border-right:none}.schedule-table tr:last-child td{border-bottom:none}.schedule-table th{background-color:var(--bg-tertiary);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;font-weight:600}.employee-cell-info{flex-direction:column;display:flex}.emp-name-bold{color:var(--text-primary);font-size:.9rem;font-weight:700}.emp-role-small{color:var(--text-secondary);font-size:.75rem}.shift-cell-edit{cursor:pointer;transition:background-color var(--transition-fast);position:relative;padding:.5rem!important}.shift-cell-edit:hover{background-color:var(--bg-tertiary)}.shift-badge{border-radius:var(--radius-sm);text-align:center;width:100%;transition:all var(--transition-fast);border:1px solid #0000;justify-content:center;align-items:center;padding:.35rem .65rem;font-size:.8rem;font-weight:700;display:inline-flex}.shift-badge.shift-off{background-color:var(--bg-tertiary);color:var(--text-secondary)}.shift-badge.shift-morning{color:#1d4ed8;background-color:#eff6ff;border-color:#bfdbfe}.shift-badge.shift-evening{color:#7e22ce;background-color:#faf5ff;border-color:#e9d5ff}.shift-badge.shift-custom{color:#0f766e;background-color:#f0fdfa;border-color:#ccfbf1}.shift-cell-input-wrapper{gap:.25rem;display:flex}.shift-cell-input{border:1.5px solid var(--primary);border-radius:var(--radius-sm);text-transform:uppercase;text-align:center;background-color:var(--bg-secondary);width:100%;padding:.25rem .4rem;font-size:.8rem;font-weight:700}.shift-cell-input:focus{outline:none}.shabu-planner-header{border-left:4px solid var(--accent);border-radius:var(--radius-md);background:linear-gradient(135deg,#ea580c14,#f9731608);margin-bottom:1.5rem;padding:1.25rem}.shabu-planner-title{color:var(--accent);align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:1.25rem;font-weight:800;display:flex}.shabu-planner-description{color:var(--text-secondary);font-size:.875rem}.planner-controls{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.form-group{flex-direction:column;gap:.4rem;display:flex}.form-label{color:var(--text-secondary);font-size:.8rem;font-weight:700}.form-input,.form-select{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast);padding:.5rem .75rem;font-weight:500}.form-input:focus,.form-select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563ff26}.form-input.accent-focus:focus,.form-select.accent-focus:focus{border-color:var(--accent);box-shadow:0 0 0 3px #ea580c26}.availability-grid{grid-template-columns:1fr;gap:1rem;margin-bottom:1.5rem;display:grid}@media (width>=768px){.availability-grid{grid-template-columns:1fr 1fr}}.availability-card{border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1rem}.availability-card.success-border{border-top:3px solid var(--success)}.availability-card.danger-border{border-top:3px solid var(--danger)}.availability-card-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:.9rem;font-weight:700;display:flex}.availability-count-badge{border-radius:9999px;padding:.15rem .5rem;font-size:.75rem;font-weight:700}.availability-count-badge.success-bg{background-color:var(--success-light);color:var(--success)}.availability-count-badge.danger-bg{background-color:var(--danger-light);color:var(--danger)}.availability-list{flex-direction:column;gap:.5rem;display:flex}.availability-item{border-radius:var(--radius-sm);background-color:var(--bg-tertiary);justify-content:space-between;align-items:center;padding:.5rem;font-size:.85rem;font-weight:600;display:flex}.availability-item-status-pill{border-radius:var(--radius-sm);padding:.1rem .4rem;font-size:.75rem;font-weight:700}.availability-item-status-pill.free{background-color:var(--success-light);color:var(--success)}.availability-item-status-pill.busy{background-color:var(--danger-light);color:var(--danger)}.recommendation-panel{background-color:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-color);margin-bottom:1.5rem;padding:1.25rem}.recommendation-title{align-items:center;gap:.4rem;margin-bottom:.75rem;font-size:.95rem;font-weight:700;display:flex}.recommendation-list{flex-direction:column;gap:.5rem;display:flex}.recommendation-item{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:.75rem 1rem;font-size:.85rem;font-weight:600;display:flex}.recommendation-item.best-match{border:2px solid var(--accent);box-shadow:0 0 10px #ea580c1a}.recommendation-score{color:var(--accent);font-weight:800}.recommendation-score.best{background-color:var(--accent-light);border-radius:var(--radius-sm);padding:.25rem .5rem}.share-box{border:1px dashed var(--border-color);border-radius:var(--radius-md);background-color:var(--bg-secondary);padding:1rem}.share-textarea{border:1px solid var(--border-color);border-radius:var(--radius-sm);resize:none;background-color:var(--bg-tertiary);width:100%;height:6rem;color:var(--text-primary);margin-bottom:.75rem;padding:.5rem;font-family:inherit;font-size:.85rem;font-weight:500}.share-textarea:focus{outline:none}.btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;display:inline-flex}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover{background-color:var(--primary-hover);box-shadow:var(--shadow-md)}.btn-accent{background-color:var(--accent);color:#fff}.btn-accent:hover{background-color:var(--accent-hover);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary)}.btn-secondary:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.btn-danger{background-color:var(--danger-light);color:var(--danger);border-color:#dc262633}.btn-danger:hover{background-color:var(--danger);color:#fff}.btn-sm{border-radius:var(--radius-sm);padding:.25rem .5rem;font-size:.75rem}.admin-employees-section{grid-template-columns:1fr;gap:1.5rem;display:grid}@media (width>=768px){.admin-employees-section{grid-template-columns:1fr 2fr}}.employee-form-card{flex-direction:column;gap:1rem;display:flex}.employee-list-table{border-collapse:collapse;width:100%}.employee-list-table th,.employee-list-table td{border-bottom:1px solid var(--border-color);padding:.75rem}.employee-list-table th{color:var(--text-secondary);font-size:.85rem;font-weight:700}.employee-list-item-row:hover{background-color:var(--bg-tertiary)}.data-backup-section{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem;margin-top:1rem;display:grid}.backup-card{border:1px solid var(--border-color);border-radius:var(--radius-md);flex-direction:column;justify-content:space-between;gap:1rem;padding:1.25rem;display:flex}.backup-card-info{flex-direction:column;gap:.25rem;display:flex}.backup-card-title{font-size:.95rem;font-weight:700}.backup-card-description{color:var(--text-secondary);font-size:.8rem}.file-input-hidden{display:none}.toast-notification{background-color:var(--bg-secondary);border:1.5px solid var(--border-color);box-shadow:var(--shadow-lg);border-radius:var(--radius-md);z-index:999;align-items:center;gap:.75rem;padding:.75rem 1.25rem;font-size:.85rem;font-weight:600;animation:.25s ease-out forwards slideInUp;display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.toast-notification.success{border-left:4px solid var(--success)}.toast-notification.info{border-left:4px solid var(--primary)}@keyframes slideInUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.help-card-rules{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-top:1rem;padding:1rem;font-size:.85rem}.help-card-rules h4{color:var(--text-primary);margin-bottom:.5rem;font-weight:700}.help-card-rules ul{color:var(--text-secondary);flex-direction:column;gap:.25rem;padding-left:1.25rem;display:flex}.main-footer{border-top:1px solid var(--border-color);text-align:center;color:var(--text-muted);margin-top:3rem;padding:1.5rem 0;font-size:.8rem;font-weight:500}@media (width<=768px){.app-wrapper{padding:.75rem .75rem 5rem!important}.card{padding:1rem!important}.main-header{flex-direction:column!important;align-items:stretch!important;gap:.75rem!important;margin-bottom:1.25rem!important;padding-bottom:.85rem!important}.brand-section{justify-content:center!important;width:100%!important}.header-controls{justify-content:space-between!important;gap:.35rem!important;width:100%!important}.nav-tabs{border-top:1px solid var(--border-color)!important;background-color:var(--bg-secondary)!important;z-index:1000!important;border-radius:0!important;justify-content:space-around!important;width:100%!important;margin:0!important;padding:.4rem .25rem!important;display:flex!important;position:fixed!important;bottom:0!important;left:0!important;right:0!important;box-shadow:0 -3px 10px #00000014!important}.nav-tab-btn{border-radius:var(--radius-sm)!important;color:var(--text-muted)!important;background:0 0!important;flex-direction:column!important;flex:1!important;justify-content:center!important;align-items:center!important;gap:.15rem!important;padding:.35rem .2rem!important;font-size:.65rem!important}.nav-tab-btn.active{color:var(--primary)!important;box-shadow:none!important;background-color:#0000!important;font-weight:700!important}.nav-tab-btn.active.shabu-accent-tab{color:var(--accent)!important}.nav-tab-btn svg{width:20px!important;height:20px!important}.dashboard-overview{grid-template-columns:repeat(3,1fr)!important;gap:.4rem!important;margin-bottom:1rem!important}.stat-card{text-align:center!important;flex-direction:column!important;align-items:center!important;gap:.25rem!important;padding:.5rem .35rem!important}.stat-icon{border-radius:var(--radius-sm)!important;width:1.85rem!important;height:1.85rem!important;font-size:.9rem!important}.stat-icon svg{width:14px!important;height:14px!important}.stat-number{font-size:1.05rem!important;line-height:1.1!important}.stat-label{font-size:.6rem!important;line-height:1.1!important}.schedule-table th,.schedule-table td{padding:.4rem!important;font-size:.75rem!important}.shift-badge{padding:.15rem .25rem!important;font-size:.7rem!important}.employee-list-table th,.employee-list-table td{padding:.4rem .25rem!important;font-size:.8rem!important}.main-footer{margin-top:1.5rem!important;padding:1rem 0!important}}
