*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--slate-50:#f8fafc;--slate-100:#f1f5f9;--slate-200:#e2e8f0;--slate-300:#cbd5e1;--slate-400:#94a3b8;--slate-500:#64748b;--slate-600:#475569;--slate-700:#334155;--slate-800:#1e293b;--slate-900:#0f172a;--slate-950:#020617;--amber-50:#fffbeb;--amber-100:#fef3c7;--amber-200:#fde68a;--amber-400:#fbbf24;--amber-500:#f59e0b;--amber-600:#d97706;--amber-700:#b45309;--bg:#f8fafc;--bg-card:#fff;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--border:#e2e8f0;--accent:#f59e0b;--accent-dark:#d97706;--accent-light:#fef3c7;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#3b82f6;--font-sans:"Plus Jakarta Sans",system-ui,sans-serif;--font-mono:"DM Mono",monospace;--nav-height:60px;--sidebar-width:240px;--radius:10px;--radius-sm:6px;--radius-lg:16px;--shadow-sm:0 1px 2px #0000000f;--shadow:0 2px 8px #00000014;--shadow-md:0 4px 16px #0000001a;--shadow-lg:0 8px 32px #0000001f}html,body{height:100%}body{font-family:var(--font-sans);background:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.6;overflow-x:hidden}#root{flex-direction:column;min-height:100%;display:flex}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-thumb{background:var(--slate-300);border-radius:3px}.btn{border-radius:var(--radius-sm);font-family:var(--font-sans);cursor:pointer;white-space:nowrap;-webkit-tap-highlight-color:transparent;border:none;justify-content:center;align-items:center;gap:6px;min-height:40px;padding:9px 18px;font-size:14px;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-dark)}.btn-secondary{background:var(--slate-100);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--slate-200)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--slate-100);color:var(--text-primary)}.btn-danger{color:var(--danger);background:#fef2f2;border:1px solid #fecaca}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff}.btn-sm{min-height:32px;padding:6px 12px;font-size:13px}.btn-lg{min-height:48px;padding:14px 28px;font-size:16px}.btn-icon{border-radius:var(--radius-sm);width:36px;min-height:36px;padding:8px}.w-full{width:100%}.card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:20px}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{color:var(--text-primary);font-size:16px;font-weight:700}.form-group{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.form-label{color:var(--text-secondary);font-size:13px;font-weight:600}.form-input,.form-select,.form-textarea{border-radius:var(--radius-sm);border:1.5px solid var(--border);width:100%;font-family:var(--font-sans);color:var(--text-primary);appearance:none;background:#fff;outline:none;padding:10px 14px;font-size:16px;transition:border-color .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #f59e0b1f}.form-textarea{resize:vertical;min-height:80px}.form-hint{color:var(--text-muted);font-size:12px}.form-error{color:var(--danger);font-size:12px}.badge{border-radius:20px;align-items:center;gap:4px;padding:3px 8px;font-size:12px;font-weight:600;display:inline-flex}.badge-amber{background:var(--amber-100);color:var(--amber-700)}.badge-green{color:#065f46;background:#d1fae5}.badge-red{color:#991b1b;background:#fee2e2}.badge-blue{color:#1d4ed8;background:#dbeafe}.badge-slate{background:var(--slate-100);color:var(--slate-600)}.status-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.status-dot.published{background:var(--success)}.status-dot.draft{background:var(--slate-400)}.page{max-width:100%;padding:16px}.page-header{margin-bottom:20px}.page-title{color:var(--text-primary);font-size:20px;font-weight:800}.page-subtitle{color:var(--text-muted);margin-top:4px;font-size:13px}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:48px 20px;display:flex}.empty-state-icon{opacity:.4;margin-bottom:16px;font-size:48px}.empty-state-title{color:var(--text-primary);margin-bottom:8px;font-size:16px;font-weight:700}.empty-state-text{color:var(--text-muted);max-width:300px;font-size:14px}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen{background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:flex-end;padding:0;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:#fff;width:100%;max-height:90vh;padding:20px;animation:.2s slideUp;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-title{font-size:18px;font-weight:700}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.alert{border-radius:var(--radius-sm);border-left:4px solid;margin-bottom:16px;padding:12px 16px;font-size:14px;font-weight:500}.alert-success{border-color:var(--success);color:#065f46;background:#d1fae5}.alert-error{border-color:var(--danger);color:#991b1b;background:#fee2e2}.alert-warning{background:var(--amber-100);border-color:var(--warning);color:var(--amber-700)}.alert-info{border-color:var(--info);color:#1d4ed8;background:#dbeafe}.table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:14px}th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:var(--slate-50);border-bottom:1px solid var(--border);padding:10px 14px;font-size:12px;font-weight:700}td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 14px}tr:last-child td{border-bottom:none}tr:hover td{background:var(--slate-50)}.avatar{background:var(--accent-light);width:36px;height:36px;color:var(--accent-dark);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.avatar-sm{width:28px;height:28px;font-size:11px}.avatar-lg{width:48px;height:48px;font-size:16px}.divider{background:var(--border);height:1px;margin:20px 0}.stat-card{border:1px solid var(--border);border-radius:var(--radius);background:#fff;flex-direction:column;gap:6px;padding:16px;display:flex}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:700}.stat-value{color:var(--text-primary);font-size:26px;font-weight:800}.stat-sub{color:var(--text-muted);font-size:12px}.shift-chip{border-radius:var(--radius-sm);white-space:nowrap;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.tabs{border-bottom:1px solid var(--border);-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:2px;margin-bottom:20px;display:flex;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab-btn{color:var(--text-muted);cursor:pointer;white-space:nowrap;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 14px;font-size:14px;font-weight:600;transition:all .15s}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.bottom-nav-item{color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:8px 4px;font-size:10px;font-weight:600;text-decoration:none;transition:color .15s;display:flex}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-item svg{width:22px;height:22px}.sidebar-logo-mark{background:var(--accent);color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;font-weight:900;display:flex}.sidebar-nav-item{border-radius:var(--radius-sm);color:var(--slate-400);cursor:pointer;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:10px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.sidebar-nav-item:hover{color:#fff;background:#ffffff0f}.sidebar-nav-item.active{color:#fff;background:#f59e0b26}.sidebar-nav-item.active svg{color:var(--accent)}.sidebar-nav-item svg{flex-shrink:0;width:18px;height:18px}.schedule-grid{background:#fff;grid-template-columns:100px repeat(7,1fr);min-width:600px;display:grid}.schedule-grid-header{background:var(--slate-50);text-align:center;color:var(--text-muted);border-bottom:1px solid var(--border);border-right:1px solid var(--border);padding:8px 6px;font-size:11px;font-weight:700}.schedule-grid-header:first-child{text-align:left;padding-left:10px}.schedule-grid-header.today{color:var(--accent);background:var(--amber-50)}.schedule-grid-employee{border-bottom:1px solid var(--border);border-right:1px solid var(--border);background:var(--slate-50);align-items:center;gap:6px;min-height:56px;padding:8px 10px;display:flex}.schedule-grid-cell{border-bottom:1px solid var(--border);border-right:1px solid var(--border);flex-direction:column;gap:2px;min-height:56px;padding:3px;display:flex;position:relative}.schedule-grid-cell:hover{background:var(--amber-50);cursor:pointer}.schedule-grid-cell.today{background:#fffbf0}.grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.grid-4{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}@media (width>=1024px){.main-content{margin-left:var(--sidebar-width)}.page{padding:24px}.grid-4{grid-template-columns:repeat(4,1fr)}.modal{border-radius:var(--radius-lg);max-width:520px}.modal-overlay{align-items:center;padding:20px}}@media (width<=1023px){.sidebar{display:none}.main-content{padding-bottom:calc(64px + env(safe-area-inset-bottom))}.grid-2,.grid-3{grid-template-columns:1fr 1fr}}@media (width<=640px){.grid-2,.grid-3{grid-template-columns:1fr}.card{padding:14px}.page{padding:12px}.page-title{font-size:18px}.stat-value{font-size:22px}.modal{padding:16px}}@media (width<=1023px){input,select,textarea{font-size:16px!important}}
