:root{--color-white: #ffffff;--color-gray-50: #fafafa;--color-gray-100: #f5f5f7;--color-gray-200: #e8e8ed;--color-gray-300: #d2d2d7;--color-gray-400: #86868b;--color-gray-500: #6e6e73;--color-gray-600: #515154;--color-gray-700: #3a3a3c;--color-gray-800: #2c2c2e;--color-gray-900: #1d1d1f;--color-black: #000000;--color-primary: #0071e3;--color-primary-hover: #0077ed;--color-primary-active: #006edb;--color-success: #34c759;--color-success-light: #e8f9ed;--color-warning: #ff9500;--color-warning-light: #fff4e5;--color-error: #ff3b30;--color-error-light: #ffebe9;--color-info: #5ac8fa;--color-status-available: #34c759;--color-status-occupied: #ff9500;--color-status-reserved: #5ac8fa;--color-status-maintenance: #8e8e93;--color-order-pending: #ff9500;--color-order-preparing: #5ac8fa;--color-order-ready: #34c759;--color-order-served: #8e8e93;--font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Helvetica Neue", Helvetica, Arial, sans-serif;--font-family-mono: "SF Mono", SFMono-Regular, ui-monospace, Menlo, Monaco, monospace;--text-xs: .6875rem;--text-sm: .75rem;--text-base: .875rem;--text-md: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.75rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--font-regular: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-tight: 1.1;--leading-snug: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.625;--tracking-tight: -.022em;--tracking-normal: -.016em;--tracking-wide: .012em;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.25rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .16);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--transition-spring: .4s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown: 100;--z-sticky: 200;--z-modal-backdrop: 300;--z-modal: 400;--z-toast: 500;--container-sm: 640px;--container-md: 768px;--container-lg: 1024px;--container-xl: 1280px}@media (prefers-color-scheme: dark){:root{--color-background: var(--color-gray-900);--color-surface: var(--color-gray-800);--color-text-primary: var(--color-white);--color-text-secondary: var(--color-gray-400)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-family);font-size:var(--text-base);font-weight:var(--font-regular);line-height:var(--leading-normal);letter-spacing:var(--tracking-normal);color:var(--color-gray-900);background-color:var(--color-gray-50);min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:var(--font-semibold);letter-spacing:var(--tracking-tight);line-height:var(--leading-tight);color:var(--color-gray-900)}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-md)}p{color:var(--color-gray-600)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}::selection{background-color:#0071e333}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none}input,textarea,select{font-family:inherit;font-size:inherit}ul,ol{list-style:none}img{max-width:100%;height:auto;display:block}table{border-collapse:collapse;width:100%}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fadeIn var(--transition-base) ease-out}.animate-slide-up{animation:slideUp var(--transition-slow) ease-out}.animate-scale-in{animation:scaleIn var(--transition-base) ease-out}:root{--hrms-primary: #1e40af;--hrms-primary-light: #3b82f6;--hrms-primary-dark: #1e3a8a;--hrms-success: #16a34a;--hrms-warning: #d97706;--hrms-danger: #dc2626;--hrms-info: #0891b2;--hrms-sidebar-width: 240px;--hrms-header-height: 56px;--shift-blue: #3b82f6;--shift-green: #22c55e;--shift-orange: #f97316;--shift-purple: #a855f7;--shift-red: #ef4444;--shift-teal: #14b8a6}.hrms-layout{display:flex;min-height:100vh;background:var(--bg-secondary, #f3f4f6)}.hrms-sidebar{width:var(--hrms-sidebar-width);background:#fff;border-right:1px solid var(--border-color, #e5e7eb);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:30;overflow-y:auto}.hrms-sidebar-header{padding:16px;border-bottom:1px solid var(--border-color, #e5e7eb)}.hrms-sidebar-header h2{font-size:18px;font-weight:700;color:var(--hrms-primary);margin:0}.hrms-sidebar-section{padding:8px 0}.hrms-sidebar-section-label{padding:8px 16px 4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary, #9ca3af)}.hrms-sidebar-item{display:flex;align-items:center;gap:10px;padding:8px 16px;font-size:14px;color:var(--text-secondary, #6b7280);text-decoration:none;border-left:3px solid transparent;transition:all .15s ease}.hrms-sidebar-item:hover{background:var(--bg-secondary, #f3f4f6);color:var(--text-primary, #111827)}.hrms-sidebar-item.router-link-active,.hrms-sidebar-item.active{background:#eff6ff;color:var(--hrms-primary);border-left-color:var(--hrms-primary);font-weight:500}.hrms-main{margin-left:var(--hrms-sidebar-width);flex:1;min-width:0}.hrms-header{height:var(--hrms-header-height);background:#fff;border-bottom:1px solid var(--border-color, #e5e7eb);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:20}.hrms-content{padding:24px}.hrms-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.hrms-page-header h1{font-size:24px;font-weight:700;color:var(--text-primary, #111827);margin:0}.hrms-card{background:#fff;border-radius:8px;border:1px solid var(--border-color, #e5e7eb);padding:20px}.hrms-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.hrms-stat-card{background:#fff;border-radius:8px;border:1px solid var(--border-color, #e5e7eb);padding:16px}.hrms-stat-card .stat-label{font-size:13px;color:var(--text-tertiary, #9ca3af);margin-bottom:4px}.hrms-stat-card .stat-value{font-size:28px;font-weight:700;color:var(--text-primary, #111827)}.hrms-stat-card .stat-sub{font-size:12px;color:var(--text-tertiary, #9ca3af);margin-top:2px}.hrms-table{width:100%;border-collapse:collapse}.hrms-table th{padding:10px 12px;text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary, #9ca3af);border-bottom:1px solid var(--border-color, #e5e7eb)}.hrms-table td{padding:12px;font-size:14px;border-bottom:1px solid var(--border-color, #e5e7eb)}.hrms-table tr:hover{background:var(--bg-secondary, #f9fafb)}.shift-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:500;color:#fff}.shift-badge.blue{background:var(--shift-blue)}.shift-badge.green{background:var(--shift-green)}.shift-badge.orange{background:var(--shift-orange)}.shift-badge.purple{background:var(--shift-purple)}.shift-badge.red{background:var(--shift-red)}.shift-badge.teal{background:var(--shift-teal)}.status-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:9999px;font-size:12px;font-weight:500}.status-badge.clocked-in{background:#dcfce7;color:#166534}.status-badge.clocked-out{background:#e0e7ff;color:#3730a3}.status-badge.missed{background:#fef3c7;color:#92400e}.status-badge.corrected{background:#f3e8ff;color:#6b21a8}.status-badge.late{background:#fee2e2;color:#991b1b}.status-badge.draft{background:#f3f4f6;color:#374151}.status-badge.published{background:#dcfce7;color:#166534}.status-badge.archived{background:#e5e7eb;color:#6b7280}.status-badge.pending{background:#fef3c7;color:#92400e}.status-badge.approved{background:#dcfce7;color:#166534}.status-badge.rejected{background:#fee2e2;color:#991b1b}.clock-status{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:8px;font-size:14px;font-weight:500}.clock-status.active{background:#dcfce7;color:#166534}.clock-status.inactive{background:#f3f4f6;color:#6b7280}.roster-grid{display:grid;grid-template-columns:180px repeat(7,1fr);gap:1px;background:var(--border-color, #e5e7eb);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;overflow:hidden}.roster-grid-header{background:var(--bg-secondary, #f3f4f6);padding:10px 8px;font-size:12px;font-weight:600;text-align:center;color:var(--text-secondary, #6b7280)}.roster-grid-staff{background:#fff;padding:10px 12px;font-size:13px;font-weight:500;display:flex;align-items:center}.roster-grid-cell{background:#fff;padding:6px;min-height:60px;cursor:pointer;transition:background .1s}.roster-grid-cell:hover{background:#f0f9ff}.roster-grid-cell .shift-badge{width:100%;justify-content:center;font-size:11px}.qr-display-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;background:#111827;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;z-index:50}.qr-display-fullscreen .qr-code{background:#fff;padding:24px;border-radius:16px;margin:24px 0}.qr-display-fullscreen .branch-name{font-size:24px;font-weight:700}.qr-display-fullscreen .current-time{font-size:48px;font-weight:700;font-variant-numeric:tabular-nums}.qr-display-fullscreen .expires-in{font-size:14px;color:#9ca3af}.hrms-form-group{margin-bottom:16px}.hrms-form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary, #374151);margin-bottom:4px}.hrms-form-group input,.hrms-form-group select,.hrms-form-group textarea{width:100%;padding:8px 12px;border:1px solid var(--border-color, #d1d5db);border-radius:6px;font-size:14px}.btn-primary{background:var(--hrms-primary);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s}.btn-primary:hover{background:var(--hrms-primary-dark)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#fff;color:var(--text-secondary, #374151);border:1px solid var(--border-color, #d1d5db);padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer}.btn-secondary:hover{background:var(--bg-secondary, #f3f4f6)}.btn-danger{background:var(--hrms-danger);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer}.btn-danger:hover{background:#b91c1c}.btn-success{background:var(--hrms-success);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer}.btn-success:hover{background:#15803d}.overtime-warning{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#fef3c7;border:1px solid #fde68a;border-radius:8px;color:#92400e;font-size:13px}.week-picker{display:flex;align-items:center;gap:12px}.week-picker button{background:none;border:1px solid var(--border-color, #d1d5db);border-radius:6px;padding:6px 10px;cursor:pointer;font-size:14px}.week-picker button:hover{background:var(--bg-secondary, #f3f4f6)}.week-picker .week-label{font-size:15px;font-weight:600;min-width:180px;text-align:center}.hrms-filters{display:flex;gap:12px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.hrms-filters select,.hrms-filters input{padding:6px 10px;border:1px solid var(--border-color, #d1d5db);border-radius:6px;font-size:13px}.hrms-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:50}.hrms-modal{background:#fff;border-radius:12px;padding:24px;max-width:480px;width:90%;max-height:90vh;overflow-y:auto}.hrms-modal h3{font-size:18px;font-weight:600;margin:0 0 16px}.hrms-modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}.hrms-empty{text-align:center;padding:48px 24px;color:var(--text-tertiary, #9ca3af)}.hrms-empty h3{font-size:16px;font-weight:600;color:var(--text-secondary, #6b7280);margin-bottom:8px}.hrms-loading{display:flex;align-items:center;justify-content:center;padding:48px;color:var(--text-tertiary, #9ca3af)}@media (max-width: 768px){.hrms-sidebar{display:none}.hrms-main{margin-left:0}.hrms-content{padding:16px}.roster-grid{overflow-x:auto}}
