@tailwind base;@tailwind components;@tailwind utilities;@layer base{html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility}body{font-family:Inter,sans-serif}@apply bg-neutral-100 text-neutral-800 dark:bg-neutral-950 dark:text-neutral-100;}:root{--brand-primary:#cf3943;--brand-gradient:linear-gradient(135deg, #cf3943, #f94f62);--brand-white:#fff;--brand-gray:#1d1d1d;--brand-surface:#cf39430d;--bg-app:#f5f5f5;--bg-sidebar:#fff;--bg-surface:#fff;--bg-card:#fff;--bg-hover:#f3f4f6;--bg-input:#fff;--text-primary:#111827;--text-secondary:#6b7280;--text-tertiary:#9ca3af;--border-color:#e5e7eb;--border-subtle:#e5e7eb;--status-online-bg:#ecfdf5;--status-online-text:#065f46;--status-idle-bg:#fffbeb;--status-idle-text:#92400e;--status-break-bg:#f5f3ff;--status-break-text:#5b21b6;--status-offline-bg:#f1f5f9;--status-offline-text:#475569;--sidebar-width:240px;--header-height:64px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--color-primary:#cf3943;--color-success:#059669;--color-warning:#d97706;--color-danger:#dc2626;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-weight:400;line-height:1.5}html.dark{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg-app:#0f0f0f;--bg-sidebar:#161616;--bg-surface:#1c1c1c;--bg-card:#1a1a1a;--bg-hover:#252525;--bg-input:#1e1e1e;--text-primary:#f9fafb;--text-secondary:#9ca3af;--text-tertiary:#6b7280;--border-color:#2a2a2a;--border-subtle:#222;--shadow-sm:0 1px 2px 0 #0006;--shadow-md:0 4px 6px -1px #00000080, 0 2px 4px -1px #0000004d;--status-online-bg:#022c22;--status-online-text:#34d399;--status-idle-bg:#1c1a09;--status-idle-text:#fbbf24;--status-break-bg:#1e1b3a;--status-break-text:#a78bfa;--status-offline-bg:#1a1f2e;--status-offline-text:#94a3b8}body{background-color:var(--bg-app);min-width:320px;min-height:100vh;color:var(--text-primary);margin:0;overflow-x:hidden}#root{min-height:100vh}button{cursor:pointer;border:none;outline:none;font-family:inherit;transition:all .3s cubic-bezier(.4,0,.2,1)}button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0000001a}::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#6366f180}.metric-card{background:var(--bg-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid #e2e8f099;flex-direction:column;gap:16px;padding:24px;transition:all .2s;display:flex;position:relative;overflow:hidden}.metric-card:hover{box-shadow:var(--shadow-md);border-color:#cbd5e1;transform:translateY(-2px)}.metric-card-header{align-items:center;gap:12px;display:flex}.metric-header-content{align-items:center;gap:8px;display:flex}.metric-icon{width:32px;height:32px;color:var(--text-tertiary);box-shadow:none;background:0 0;border-radius:8px;justify-content:center;align-items:center;display:flex}.metric-trend{border-radius:99px;align-items:center;margin-left:auto;padding:2px 8px;font-size:12px;font-weight:500;display:inline-flex}.metric-trend.positive{color:var(--status-online-text);background:var(--status-online-bg)}.metric-trend.negative{color:var(--status-idle-text);background:var(--status-idle-bg)}.metric-content h3{color:var(--text-secondary);text-transform:none;letter-spacing:normal;margin:0;font-size:13px;font-weight:500}.metric-value{color:var(--text-primary);letter-spacing:-.02em;text-shadow:none;margin-top:4px;font-size:32px;font-weight:700;line-height:1.1}.time-activity-chart{background:var(--bg-surface);border-radius:var(--radius-xl);border:1px solid var(--border-color);height:100%;box-shadow:var(--shadow-sm);flex-direction:column;padding:32px;transition:all .3s;display:flex}.time-activity-chart:hover{box-shadow:var(--shadow-md);border-color:var(--border-subtle)}.chart-header{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.chart-header h2{color:var(--text-primary);letter-spacing:-.02em;margin:0;font-size:18px;font-weight:600}.chart-legend{gap:16px;display:flex}.legend-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;font-weight:500;display:flex}.legend-dot{border-radius:50%;width:6px;height:6px}.chart-container{flex:1;min-height:0;margin-bottom:8px}.time-stats{border-top:1px solid var(--border-color);justify-content:flex-start;gap:32px;padding-top:24px;display:flex}.time-stat-item{flex-direction:column;gap:4px;display:flex}.stat-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:500}.stat-value{color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.01em;font-size:15px;font-weight:600}.custom-tooltip{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:8px;min-width:140px;padding:12px 16px;box-shadow:0 4px 6px -1px #00000026,0 2px 4px -1px #0000001a}.custom-tooltip .label{color:var(--text-primary);border-bottom:1px solid var(--border-subtle);margin:0 0 8px;padding-bottom:8px;font-size:13px;font-weight:600}.tooltip-content{flex-direction:column-reverse;gap:4px;display:flex}.tooltip-item{justify-content:space-between;align-items:center;gap:12px;margin-bottom:0;font-size:12px;display:flex}.tooltip-indicator{border-radius:2px;width:4px;height:12px;margin-right:4px}.tooltip-name{color:var(--text-secondary);font-weight:500}.tooltip-dot{border-radius:50%;width:6px;height:6px}.tooltip-name{color:var(--text-secondary);flex:1}.tooltip-value{color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:500}@media (width<=768px){.time-stats{grid-template-columns:repeat(2,1fr)}}.ahv-root{background:var(--bg-app,#f8fafc);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.ahv-header{background:var(--bg-surface,#fff);border-bottom:1px solid var(--border-subtle,#e2e8f0);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;height:56px;padding:0 32px;display:flex}.ahv-header-left{align-items:center;gap:10px;display:flex}.ahv-header-icon{color:var(--text-tertiary,#94a3b8)}.ahv-header-title{color:var(--text-primary,#0f172a);letter-spacing:-.01em;margin:0;font-size:15px;font-weight:600}.ahv-header-right{align-items:center;gap:8px;display:flex}.ahv-date-nav{background:var(--bg-app,#f8fafc);border:1px solid var(--border-subtle,#e2e8f0);border-radius:8px;align-items:center;gap:0;padding:3px;display:flex}.ahv-icon-btn{width:28px;height:28px;color:var(--text-secondary,#475569);cursor:pointer;background:0 0;border:none;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;transition:background .12s,color .12s;display:flex}.ahv-icon-btn:hover{background:var(--bg-surface,#fff);color:var(--text-primary,#0f172a)}.ahv-date-pill{color:var(--text-primary,#0f172a);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;align-items:center;gap:6px;padding:4px 10px;font-size:13px;font-weight:500;display:flex;position:relative}.ahv-date-pill svg{color:var(--text-tertiary,#94a3b8);flex-shrink:0}.ahv-date-pill input[type=date]{opacity:0;cursor:pointer;background:0 0;border:none;width:100%;position:absolute;inset:0}.ahv-btn-ghost{border:1px solid var(--border-subtle,#e2e8f0);color:var(--text-secondary,#475569);cursor:pointer;white-space:nowrap;background:0 0;border-radius:7px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;transition:background .12s,border-color .12s,color .12s;display:inline-flex}.ahv-btn-ghost:hover{background:var(--bg-surface,#fff);color:var(--text-primary,#0f172a);border-color:#cbd5e1}.ahv-summary{background:var(--bg-surface,#fff);border-bottom:1px solid var(--border-subtle,#e2e8f0);flex-shrink:0;gap:0;padding:16px 32px;display:flex}.ahv-stat-card{border-right:1px solid var(--border-subtle,#e2e8f0);flex-direction:column;gap:2px;margin-right:24px;padding:0 24px 0 0;display:flex}.ahv-stat-card:last-child{border-right:none;margin-right:0;padding-right:0}.ahv-stat-header{align-items:center;gap:6px;display:flex}.ahv-stat-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.ahv-stat-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary,#94a3b8);font-size:11px;font-weight:500}.ahv-stat-value{color:var(--text-primary,#0f172a);letter-spacing:-.02em;font-size:20px;font-weight:700;line-height:1.2}.ahv-stat-pct{color:var(--text-tertiary,#94a3b8);font-variant-numeric:tabular-nums;font-size:12px}.ahv-controls{background:var(--bg-app,#f8fafc);box-sizing:border-box;flex-shrink:0;align-items:center;gap:10px;width:100%;min-width:0;padding:10px 32px;display:flex;overflow:hidden}.ahv-filters{scrollbar-width:none;flex:1;align-items:center;gap:4px;min-width:0;display:flex;overflow:auto hidden}.ahv-filters::-webkit-scrollbar{display:none}.ahv-filter-btn{border:1px solid var(--border-subtle,#e2e8f0);background:var(--bg-surface,#fff);color:var(--text-secondary,#475569);cursor:pointer;white-space:nowrap;border-radius:6px;flex-shrink:0;align-items:center;gap:6px;padding:5px 12px;font-size:12px;font-weight:500;line-height:1;transition:background .12s,border-color .12s,color .12s,box-shadow .12s;display:inline-flex}.ahv-filter-btn:hover{background:var(--bg-hover,#f8fafc);color:var(--text-primary,#0f172a);border-color:#cbd5e1}.ahv-filter-btn--active{font-weight:600;box-shadow:0 1px 2px #0000000f}.ahv-filter-btn--active:not([style]){background:var(--text-primary,#0f172a);border-color:var(--text-primary,#0f172a);color:#fff}.ahv-filter-btn--active:not([style]) .ahv-filter-dot{background:#ffffffb3!important}.ahv-filter-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px;transition:background .12s}.ahv-search{background:var(--bg-surface,#fff);border:1px solid var(--border-subtle,#e2e8f0);color:var(--text-tertiary,#94a3b8);border-radius:7px;flex-shrink:0;align-items:center;gap:8px;padding:6px 12px;transition:border-color .12s;display:flex}.ahv-search:focus-within{color:var(--text-secondary,#475569);border-color:#93c5fd;box-shadow:0 0 0 3px #3b82f614}.ahv-search input{color:var(--text-primary,#0f172a);background:0 0;border:none;outline:none;width:160px;font-size:12px}.ahv-search input::placeholder{color:#cbd5e1}.ahv-divider{background:var(--border-subtle,#e2e8f0);flex-shrink:0;height:1px}.ahv-scroll{background:var(--bg-app,#f8fafc);flex:1;min-height:0;padding:8px 32px 32px;overflow-y:auto}.ahv-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:72px 24px;display:flex}.ahv-spinner{border:2px solid var(--border-subtle,#e2e8f0);border-top-color:#3b82f6;border-radius:50%;width:20px;height:20px;animation:.7s linear infinite ahv-spin}@keyframes ahv-spin{to{transform:rotate(360deg)}}.ahv-empty-icon{margin-bottom:4px;font-size:32px}.ahv-empty-title{color:var(--text-secondary,#475569);margin:0;font-size:14px;font-weight:600}.ahv-empty-sub{color:var(--text-tertiary,#94a3b8);max-width:260px;margin:0;font-size:12px}.ahv-list{flex-direction:column;padding-top:8px;display:flex}.ahv-row{gap:16px;padding:12px 0;display:flex;position:relative}.ahv-row:not(:last-child){border-bottom:1px solid var(--border-subtle,#e2e8f0)}.ahv-timeline-col{flex-direction:column;flex-shrink:0;align-items:center;width:16px;padding-top:4px;display:flex}.ahv-tl-dot{width:8px;height:8px;box-shadow:0 0 0 2px var(--bg-app,#f8fafc);border-radius:50%;flex-shrink:0}.ahv-tl-line{background:var(--border-subtle,#e2e8f0);flex:1;width:1px;min-height:20px;margin-top:6px}.ahv-row-content{flex:1;min-width:0}.ahv-row-top{justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:5px;display:flex}.ahv-row-time{color:var(--text-primary,#0f172a);font-variant-numeric:tabular-nums;letter-spacing:-.01em;font-size:13px;font-weight:600}.ahv-row-dur{color:var(--text-tertiary,#94a3b8);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:12px;font-weight:500}.ahv-row-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:4px;display:flex}.ahv-type-badge{text-transform:uppercase;letter-spacing:.06em;border:1px solid #0000;border-radius:4px;flex-shrink:0;align-items:center;padding:2px 7px;font-size:10px;font-weight:700;line-height:1.6;display:inline-flex}.ahv-app-name{color:var(--text-secondary,#475569);font-size:13px;font-weight:500}.ahv-break-type{color:var(--text-tertiary,#94a3b8);font-size:12px;font-style:italic}.ahv-row-desc{color:var(--text-tertiary,#94a3b8);margin:0;font-size:12px;line-height:1.5}.app-usage-list{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);flex-direction:column;height:100%;padding:0;display:flex;overflow:hidden}.app-usage-header{border-bottom:1px solid var(--border-subtle);background:var(--bg-subtle);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);grid-template-columns:2fr 1fr 1fr;padding:12px 24px;font-size:11px;font-weight:600;display:grid}.app-list{flex-direction:column;padding:8px 0;display:flex;overflow-y:auto}.app-item{cursor:default;grid-template-columns:2fr 1fr 1fr;align-items:center;padding:12px 24px;font-size:13px;transition:background-color .15s;display:grid}.app-item:hover{background-color:var(--bg-subtle)}.app-item--active{background-color:#f0fdf4}.app-item--active:hover{background-color:#dcfce7}.app-active-badge{color:#16a34a;letter-spacing:.02em;background:#dcfce7;border:1px solid #bbf7d0;border-radius:4px;flex-shrink:0;padding:1px 6px;font-size:10px;font-weight:600}.app-empty-state{text-align:center;color:var(--text-muted);padding:32px 24px;font-size:13px}.app-info{align-items:center;gap:12px;display:flex;overflow:hidden}.app-icon{background:var(--color-indigo-100);width:24px;height:24px;color:var(--color-indigo-600);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;display:flex}.app-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.app-duration{color:var(--text-secondary);font-variant-numeric:tabular-nums}.app-bar-container{align-items:center;gap:12px;display:flex}.app-bar-bg{background:var(--bg-subtle);border-radius:3px;flex:1;height:6px;overflow:hidden}.app-bar-fill{background-color:var(--color-indigo-500);border-radius:3px;height:100%}.app-percentage{color:var(--text-muted);text-align:right;font-variant-numeric:tabular-nums;width:32px;font-size:12px}.attendance-panel{flex-direction:column;gap:20px;max-width:640px;margin:0 auto;padding:24px;display:flex}.attendance-clock{text-align:center;background:linear-gradient(135deg, var(--bg-card) 0%, #6366f10a 100%);border:1px solid var(--border-subtle);border-radius:var(--radius-lg,12px);padding:32px 24px 24px}.clock-time{color:var(--text-primary);letter-spacing:-1px;font-variant-numeric:tabular-nums;font-size:48px;font-weight:700;line-height:1}.clock-date{color:var(--text-secondary);justify-content:center;align-items:center;gap:6px;margin-top:8px;font-size:13px;display:flex}.attendance-department{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-sm,8px);color:var(--text-secondary);align-items:center;gap:8px;padding:10px 16px;font-size:13px;font-weight:500;display:flex}.attendance-alert{border-radius:var(--radius-sm,8px);align-items:center;gap:10px;padding:12px 16px;font-size:13px;font-weight:500;display:flex}.attendance-error{color:#f87171;background:#dc26261a;border:1px solid #dc26264d}.attendance-success{color:#22c55e;background:#16a34a1a;border:1px solid #16a34a4d}.attendance-warning{color:#f59e0b;background:#f59e0b1a;border:1px solid #f59e0b4d;flex-direction:row;align-items:flex-start;padding:16px}.attendance-warning svg{flex-shrink:0;margin-top:2px}.alert-content{flex-direction:column;flex:1;gap:8px;display:flex}.alert-title{color:#f59e0b;font-size:14px;font-weight:600}.alert-message{color:var(--text-secondary);font-size:13px;font-weight:400;line-height:1.5}.alert-actions{gap:8px;margin-top:4px;display:flex}.btn-alert-primary,.btn-alert-secondary{cursor:pointer;border:none;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:600;transition:all .15s}.btn-alert-primary{color:#fff;background:#f59e0b}.btn-alert-primary:hover{background:#d97706}.btn-alert-secondary{color:var(--text-secondary);border:1px solid var(--border-color);background:0 0}.btn-alert-secondary:hover{background:var(--bg-hover)}.attendance-active-shift{border-radius:var(--radius-lg,12px);background:#16a34a14;border:1px solid #16a34a4d;justify-content:space-between;align-items:center;gap:16px;padding:20px;display:flex}.active-shift-info{flex-direction:column;gap:6px;display:flex}.active-shift-badge{color:#22c55e;text-transform:uppercase;letter-spacing:.03em;align-items:center;gap:6px;font-size:12px;font-weight:600;display:flex}.pulse-dot{background:#16a34a;border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite pulse-green}@keyframes pulse-green{0%,to{opacity:1;box-shadow:0 0 #16a34a66}50%{opacity:.8;box-shadow:0 0 0 6px #16a34a00}}.active-shift-name{color:var(--text-primary);font-size:16px;font-weight:600}.active-shift-time{color:#4ade80;align-items:center;gap:6px;font-size:13px;display:flex}.btn-clock-out{color:#fff;border-radius:var(--radius-sm,8px);cursor:pointer;white-space:nowrap;background:#dc2626;border:none;align-items:center;gap:8px;padding:12px 20px;font-size:14px;font-weight:600;transition:all .15s;display:flex}.btn-clock-out:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px)}.btn-clock-out:disabled{opacity:.6;cursor:not-allowed}.attendance-shifts{flex-direction:column;gap:12px;display:flex}.shifts-header{justify-content:space-between;align-items:center;display:flex}.shifts-header h3{color:var(--text-primary);margin:0;font-size:15px;font-weight:600}.btn-refresh{border:1px solid var(--border-subtle);border-radius:var(--radius-sm,8px);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;justify-content:center;align-items:center;transition:all .15s;display:flex}.btn-refresh:hover{background:var(--bg-hover);color:var(--text-primary)}.shifts-empty{color:var(--text-tertiary);background:var(--bg-card);border:1px dashed var(--border-subtle);border-radius:var(--radius-sm,8px);flex-direction:column;align-items:center;gap:8px;padding:40px 20px;font-size:13px;display:flex}.shifts-list{flex-direction:column;gap:8px;display:flex}.shift-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-sm,8px);padding:16px;transition:all .15s}.shift-card.shift-current{background:#6366f108;border-color:#6366f14d}.shift-card.shift-active{background:#16a34a0f;border-color:#16a34a59}.shift-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.shift-card-name{color:var(--text-primary);font-size:14px;font-weight:600}.shift-card-time{color:var(--text-secondary);font-variant-numeric:tabular-nums;font-size:13px;font-weight:500}.shift-card-attendance{background:#0000000a;border-radius:6px;flex-direction:column;gap:8px;margin-bottom:10px;padding:10px 12px;display:flex}html.dark .shift-card-attendance{background:#ffffff08}.attendance-times{gap:16px;display:flex}.attendance-time-item{color:var(--text-secondary);align-items:center;gap:5px;font-size:12px;display:flex}.attendance-status-badge{letter-spacing:.02em;border-radius:20px;align-self:flex-start;align-items:center;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.status-working{color:#16a34a;background:#16a34a26}.status-present{color:#3b82f6;background:#2563eb1f}.status-late,.status-early{color:#f59e0b;background:#d9770626}.status-absent{color:#f87171;background:#dc26261f}.attendance-penalties{gap:8px;display:flex}.penalty-tag{color:#f59e0b;background:#d9770626;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:500}.shift-card-actions{gap:8px;display:flex}.btn-shift-clock-in{color:#fff;border-radius:var(--radius-sm,8px);cursor:pointer;background:#16a34a;border:none;justify-content:center;align-items:center;gap:6px;width:100%;padding:10px 16px;font-size:13px;font-weight:600;transition:all .15s;display:flex;box-shadow:0 1px 3px #16a34a66,0 0 #16a34a00}.btn-shift-clock-in:hover:not(:disabled){background:#15803d;transform:translateY(-1px);box-shadow:0 4px 12px #16a34a73}.btn-shift-clock-in:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 3px #16a34a4d}.btn-shift-clock-in:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.btn-shift-clock-out{color:#fff;border-radius:var(--radius-sm,8px);cursor:pointer;background:#dc2626;border:none;justify-content:center;align-items:center;gap:6px;width:100%;padding:8px 16px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.btn-shift-clock-out:hover:not(:disabled){background:#b91c1c}.btn-shift-clock-out:disabled{opacity:.5;cursor:not-allowed}.shift-completed-badge{color:#22c55e;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;display:flex}.attendance-loading{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:80px 20px;font-size:14px;display:flex}.spinning{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.attendance-request-zone{justify-content:center;padding-top:4px;display:flex}.btn-adjustment-request{color:#6b7280;cursor:pointer;background:0 0;border:1.5px dashed #d1d5db;border-radius:9px;justify-content:center;align-items:center;gap:7px;width:100%;padding:9px 20px;font-size:13px;font-weight:500;transition:color .15s,border-color .15s,background .15s;display:flex}.btn-adjustment-request:hover{color:#3b82f6;background:#3b82f60a;border-color:#93c5fd}.arp-inline{flex-direction:column;flex:1;min-height:0;display:flex}.arp-tabs{border-bottom:1px solid var(--border-color);flex-shrink:0;gap:2px;margin-bottom:0;padding:0;display:flex}.arp-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:5px;margin-bottom:-1px;padding:7px 14px;font-size:12.5px;font-weight:500;transition:color .15s,border-color .15s;display:flex}.arp-tab:hover{color:var(--text-primary)}.arp-tab--active{color:#3b82f6;border-bottom-color:#3b82f6}.arp-body{flex:1;padding:20px 0 0;overflow-y:auto}.arp-form{flex-direction:column;gap:14px;display:flex}.arp-field{flex-direction:column;gap:6px;display:flex}.arp-label{color:var(--text-secondary);align-items:center;gap:5px;font-size:12px;font-weight:500;display:flex}.arp-checkbox-label{color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex}.arp-checkbox-label input[type=checkbox]{cursor:pointer;accent-color:#3b82f6;width:15px;height:15px}.arp-input{width:100%;color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border-color);box-sizing:border-box;border-radius:8px;outline:none;padding:8px 10px;font-size:13px;transition:border-color .15s,box-shadow .15s}.arp-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f626}.arp-input--time{max-width:140px;margin-top:4px}.arp-textarea{width:100%;color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border-color);resize:vertical;box-sizing:border-box;border-radius:8px;outline:none;padding:8px 10px;font-family:inherit;font-size:13px;line-height:1.5;transition:border-color .15s,box-shadow .15s}.arp-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f626}.arp-char-count{color:var(--text-secondary);text-align:right;margin-top:-2px;font-size:11px}.arp-alert{border-radius:8px;align-items:flex-start;gap:8px;padding:10px 12px;font-size:12.5px;line-height:1.5;display:flex}.arp-alert--success{color:#16a34a;background:#16a34a1a;border:1px solid #16a34a4d}.arp-alert--error{color:#dc2626;background:#dc262614;border:1px solid #dc262640}.arp-submit-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:9px;justify-content:center;align-items:center;gap:6px;padding:10px 20px;font-size:13.5px;font-weight:600;transition:background .15s,transform .1s;display:flex}.arp-submit-btn:hover:not(:disabled){background:#2563eb}.arp-submit-btn:active:not(:disabled){transform:scale(.98)}.arp-submit-btn:disabled{opacity:.6;cursor:not-allowed}.arp-spin{animation:.8s linear infinite arp-rotate}@keyframes arp-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.arp-history-loading,.arp-history-empty{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:40px 20px;font-size:13px;display:flex}.arp-request-list{flex-direction:column;gap:10px;display:flex}.arp-request-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:10px;flex-direction:column;gap:6px;padding:12px 14px;display:flex}.arp-request-top{justify-content:space-between;align-items:center;display:flex}.arp-request-date{color:var(--text-primary);align-items:center;gap:5px;font-size:12px;font-weight:600;display:flex}.arp-status-badge{border:1px solid;border-radius:99px;align-items:center;gap:4px;padding:3px 9px;font-size:11px;font-weight:600;display:flex}.arp-request-shift{color:var(--text-secondary);margin:0;font-size:11.5px}.arp-request-times{flex-wrap:wrap;gap:6px;display:flex}.arp-time-chip{border-radius:6px;padding:3px 9px;font-size:11.5px;font-weight:500}.arp-time-chip--in{color:#3b82f6;background:#3b82f61a}.arp-time-chip--out{color:#7c3aed;background:#8b5cf61a}.arp-request-reason{color:var(--text-primary);margin:0;font-size:12.5px;font-style:italic;line-height:1.5}.arp-admin-note{color:#d97706;background:#d9770614;border:1px solid #d9770633;border-radius:7px;padding:7px 10px;font-size:12px;line-height:1.5}.arp-admin-note span{font-weight:600}.arp-request-meta{color:var(--text-secondary);margin:0;font-size:11px}.rp-root{flex-direction:column;gap:24px;height:100%;min-height:0;padding:28px 32px 24px;display:flex;overflow-y:auto}.rp-page-header{flex-shrink:0}.rp-page-title{color:var(--text-primary);margin:0 0 4px;font-size:20px;font-weight:700}.rp-page-sub{color:var(--text-secondary);margin:0;font-size:13px}.rp-layout{flex:1;grid-template-columns:280px 1fr;align-items:start;gap:20px;min-height:0;display:grid}.rp-type-list{flex-direction:column;gap:8px;display:flex}.rp-type-list-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin:0 0 4px 2px;font-size:11px;font-weight:600}.rp-type-card{background:var(--bg-surface);border:1.5px solid var(--border-color);cursor:pointer;text-align:left;border-radius:12px;align-items:center;gap:12px;width:100%;padding:12px 14px;transition:border-color .15s,background .15s,box-shadow .15s;display:flex}.rp-type-card:hover{border-color:#93c5fd;box-shadow:0 2px 8px #3b82f614}.rp-type-card--active{box-shadow:0 2px 10px #3b82f61f}.rp-type-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.rp-type-text{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.rp-type-title{color:var(--text-primary);font-size:13px;font-weight:600;line-height:1.3}.rp-type-desc{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:11px;line-height:1.4;display:-webkit-box;overflow:hidden}.rp-type-arrow{color:var(--text-secondary);flex-shrink:0;transition:color .15s}.rp-content{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:14px;min-height:400px;overflow:hidden}.rp-empty-state{flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:60px 24px;display:flex}.rp-empty-icon{opacity:.45;font-size:40px}.rp-empty-title{color:var(--text-primary);margin:0;font-size:15px;font-weight:600}.rp-empty-sub{color:var(--text-secondary);text-align:center;max-width:260px;margin:0;font-size:13px;line-height:1.5}.rp-panel-wrapper{flex-direction:column;height:100%;display:flex}.rp-panel-header{border-bottom:1px solid var(--border-color);flex-shrink:0;align-items:center;gap:14px;padding:18px 20px 16px;display:flex}.rp-panel-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.rp-panel-title{color:var(--text-primary);margin:0 0 3px;font-size:14px;font-weight:700}.rp-panel-desc{color:var(--text-secondary);margin:0;font-size:12px;line-height:1.4}.rp-panel-body{flex-direction:column;flex:1;padding:0 20px 20px;display:flex;overflow-y:auto}.chat-screen{background:var(--bg-main);flex-direction:column;flex:1;height:100%;min-height:0;display:flex;overflow:hidden}.chat-screen-header{background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.chat-screen-header-info{align-items:center;gap:10px;display:flex}.chat-screen-avatar{color:#fff;background:#3b82f6;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.85rem;font-weight:700;display:flex}.chat-screen-title{color:var(--text-primary);font-size:.9rem;font-weight:600}.chat-screen-status{color:var(--text-secondary);align-items:center;gap:5px;margin-top:2px;font-size:.72rem;display:flex}.chat-status-dot{border-radius:50%;width:7px;height:7px;display:inline-block}.chat-status-dot.online{background:#22c55e;box-shadow:0 0 0 2px #22c55e33}.chat-status-dot.offline{background:#94a3b8}.chat-screen-messages{flex-direction:column;gap:2px;height:100%;min-height:0;padding:16px 20px 6rem;display:flex;overflow-y:auto}.chat-screen-messages::-webkit-scrollbar{width:4px}.chat-screen-messages::-webkit-scrollbar-track{background:0 0}.chat-screen-messages::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.chat-screen-empty{text-align:center;color:var(--text-secondary);flex-direction:column;align-items:center;gap:8px;margin:auto;display:flex}.chat-screen-empty p{color:var(--text-primary);margin:0;font-size:.9rem;font-weight:500}.chat-screen-empty span{color:var(--text-secondary);font-size:.78rem}.chat-date-divider{color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase;align-items:center;gap:10px;margin:14px 0 10px;font-size:.7rem;font-weight:500;display:flex}.chat-date-divider:before,.chat-date-divider:after{content:"";background:var(--border-subtle);flex:1;height:1px}.chat-msg-row{align-items:flex-end;gap:8px;margin-bottom:6px;display:flex}.chat-msg-row.me{flex-direction:row-reverse}.chat-msg-avatar{color:#fff;background:#3b82f6;border-radius:50%;flex-shrink:0;justify-content:center;align-self:flex-end;align-items:center;width:28px;height:28px;font-size:.7rem;font-weight:700;display:flex}.chat-msg-body{flex-direction:column;gap:3px;max-width:65%;display:flex}.chat-msg-row.me .chat-msg-body{align-items:flex-end}.chat-msg-row.admin .chat-msg-body{align-items:flex-start}.chat-bubble{word-break:break-word;background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-subtle);border-radius:4px 14px 14px;padding:9px 13px;font-size:.85rem;line-height:1.5}.chat-msg-row.me .chat-bubble{color:#f8fafc;background:#0f172a;border:none;border-radius:14px 4px 14px 14px}[data-theme=light] .chat-msg-row.me .chat-bubble{color:#fff;background:#1d4ed8}.chat-msg-time{color:var(--text-secondary);padding:0 2px;font-size:.68rem}.chat-screen-input-bar{background:var(--bg-surface);border-top:1px solid var(--border-subtle);flex-shrink:0;align-self:center;align-items:flex-end;gap:8px;width:78%;padding:12px 16px;display:flex;position:absolute;bottom:0;right:0}.chat-screen-textarea{background:var(--bg-main);border:1px solid var(--border-color);color:var(--text-primary);resize:none;border-radius:10px;outline:none;flex:1;max-height:100px;padding:9px 12px;font-family:inherit;font-size:.85rem;line-height:1.5;transition:border-color .15s;overflow-y:auto}.chat-screen-textarea:focus{border-color:#3b82f6}.chat-screen-textarea::placeholder{color:var(--text-secondary)}.chat-screen-send-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,opacity .15s;display:flex}.chat-screen-send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-screen-send-btn:not(:disabled):hover{background:#2563eb}.settings-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000000bf;justify-content:center;align-items:center;animation:.3s cubic-bezier(.4,0,.2,1) fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.settings-modal{background:#fff;border:1px solid #e2e8f0;border-radius:16px;width:90%;max-width:520px;animation:.4s cubic-bezier(.4,0,.2,1) slideUp;box-shadow:0 8px 32px #0000001f,0 0 0 1px #0000000a}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.settings-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:24px 28px;display:flex}.settings-header h2{color:#0f172a;letter-spacing:-.02em;align-items:center;gap:10px;margin:0;font-size:18px;font-weight:600;display:flex}.close-btn{color:#64748b;cursor:pointer;background:0 0;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.close-btn:hover{color:#ef4444;background:#fef2f2;border-color:#fecaca;transform:none}.settings-content{max-height:60vh;padding:32px;overflow-y:auto}.form-group{margin-bottom:20px}.form-group label{color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.form-group input{color:#0f172a;box-sizing:border-box;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;width:100%;padding:10px 14px;font-size:14px;transition:all .2s}.form-group input:focus{background:#fff;border-color:#4f46e5;outline:none;box-shadow:0 0 0 3px #4f46e514}.form-group input::placeholder{color:#94a3b8}.message{border-radius:8px;margin-top:16px;padding:12px 16px;font-size:14px}.message.success{color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0}.message.error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.settings-footer{border-top:1px solid #e2e8f0;justify-content:flex-end;gap:10px;padding:16px 28px;display:flex}.btn-primary,.btn-secondary{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.btn-primary{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);box-shadow:0 4px 12px #6366f14d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #6366f166}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{color:#374151;background:#fff;border:1px solid #e2e8f0}.btn-secondary:hover{background:#f8fafc;border-color:#cbd5e1;transform:none}.sidebar{width:var(--sidebar-width);background-color:var(--bg-sidebar);border-right:1px solid var(--border-color);z-index:50;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0}.sidebar-header{height:var(--header-height);border-bottom:1px solid var(--border-subtle);align-items:center;gap:12px;padding:0 24px;display:flex}.logo-icon{background:var(--text-primary);color:#fff;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.logo-text{color:var(--text-primary);font-size:16px;font-weight:600}.logo-accent{color:var(--text-secondary);font-weight:400}.sidebar-content{flex-direction:column;flex:1;padding:24px 16px;display:flex;overflow-y:auto}.sidebar-section{flex-direction:column;gap:4px;margin-bottom:24px;display:flex}.section-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;padding:0 12px;font-size:11px;font-weight:600}.nav-item{color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:8px 12px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{background-color:var(--bg-hover);color:var(--text-primary)}.nav-item.active{color:var(--text-primary);box-shadow:inset 2px 0 0 var(--text-primary);background-color:#0000000a;font-weight:600}.nav-item span:not(.nav-badge){flex:1}.nav-badge{color:#fff;background:#ef4444;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:auto;padding:0 4px;font-size:10px;font-weight:700;line-height:1;display:flex}.break-section{border-top:1px solid var(--border-subtle);margin-top:8px;padding-top:16px}.break-trigger{justify-content:space-between}.break-trigger.expanded{background-color:var(--bg-hover);color:var(--text-primary)}.break-trigger.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.break-trigger.disabled:hover{background-color:#0000}.break-disabled-badge{color:var(--text-tertiary);background:var(--bg-hover);border-radius:10px;margin-left:auto;padding:2px 8px;font-size:10px;font-weight:600}.break-options-list{flex-direction:column;gap:2px;margin-top:4px;padding-left:12px;animation:.2s ease-out slideDown;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.break-option-item{text-align:left;cursor:pointer;border-radius:var(--radius-sm);width:100%;color:var(--text-secondary);background:0 0;border:none;align-items:center;gap:12px;padding:8px 12px;font-size:13px;transition:all .15s;display:flex}.break-option-item:hover{background-color:var(--brand-surface);color:var(--brand-primary)}.break-option-item:hover .play-hint{opacity:1}.play-hint{opacity:0;margin-left:auto;transition:opacity .15s}.active-break-card{background:var(--status-idle-bg);border-radius:var(--radius-sm);text-align:center;border:1px solid #f59e0b33;flex-direction:column;align-items:center;margin:0 4px;padding:16px;animation:.3s fadeIn;display:flex}.break-status-row{align-items:center;gap:8px;margin-bottom:8px;display:flex}.break-pulse{background-color:var(--status-idle-text);border-radius:50%;width:8px;height:8px;animation:2s infinite pulse-dot;box-shadow:0 0 #92400e66}@keyframes pulse-dot{0%{transform:scale(.95);box-shadow:0 0 #92400e66}70%{transform:scale(1);box-shadow:0 0 0 6px #92400e00}to{transform:scale(.95);box-shadow:0 0 #92400e00}}.break-title{text-transform:uppercase;color:var(--status-idle-text);letter-spacing:.05em;font-size:12px;font-weight:600}.break-timer{font-size:24px;font-family:var(--font-mono,monospace);color:var(--status-idle-text);font-variant-numeric:tabular-nums;margin-bottom:4px;font-weight:700;line-height:1}.break-type-badge{color:var(--status-idle-text);opacity:.8;margin-bottom:12px;font-size:11px}.end-break-btn{border-radius:var(--radius-sm);width:100%;color:var(--status-idle-text);cursor:pointer;background:#fff;border:1px solid #92400e33;justify-content:center;align-items:center;gap:8px;padding:8px;font-size:12px;font-weight:600;transition:all .2s;display:flex;box-shadow:0 1px 2px #0000000d}.end-break-btn:hover{background:#fffbeb;border-color:#92400e66;transform:translateY(-1px)}.ml-auto{margin-left:auto}.mt-auto{margin-top:auto}.sidebar-footer{border-top:1px solid var(--border-subtle);flex-direction:column;gap:8px;margin-top:auto;padding:12px 14px 14px;display:flex}.sidebar-controls{flex-direction:column;gap:6px;display:flex}.theme-toggle-switch{border:1px solid var(--border-color);background:var(--bg-surface);width:100%;color:var(--text-secondary);cursor:pointer;box-sizing:border-box;border-radius:8px;justify-content:space-between;align-items:center;padding:5px 8px;font-size:.72rem;font-weight:500;transition:all .15s;display:flex}.theme-toggle-switch:hover{background:var(--bg-hover);color:var(--text-primary)}.theme-label-group{align-items:center;gap:6px;display:flex}.toggle-pill{background:var(--border-color);border-radius:8px;flex-shrink:0;width:28px;height:16px;transition:background .2s;position:relative}.toggle-pill.active{background:#6366f1}.toggle-knob{background:#fff;border-radius:50%;width:12px;height:12px;transition:transform .2s;display:block;position:absolute;top:2px;left:2px}.toggle-pill.active .toggle-knob{transform:translate(12px)}.user-profile{border-radius:var(--radius-md);cursor:pointer;align-items:center;gap:12px;padding:8px;transition:background .2s;display:flex}.user-profile:hover{background-color:var(--bg-hover)}.avatar{width:32px;height:32px;color:var(--text-secondary);background:#e2e8f0;border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex}.user-info{flex-direction:column;flex:1;display:flex}.user-name{color:var(--text-primary);font-size:13px;font-weight:500}.user-role{color:var(--text-tertiary);font-size:11px}.user-menu-trigger{color:var(--text-tertiary)}.status-indicator{border:1px solid #0000;border-radius:999px;align-items:center;gap:8px;padding:6px 14px;font-size:13px;font-weight:500;display:inline-flex}.status-dot{background-color:currentColor;border-radius:50%;flex-shrink:0;width:8px;height:8px}.status-label{font-weight:600;line-height:1}.status-sep{opacity:.4;font-size:11px}.status-desc{opacity:.8;font-size:12px;font-weight:400;line-height:1}.status-online{background-color:var(--status-online-bg);color:var(--status-online-text);border-color:#065f4626}.status-online .status-dot{animation:2s infinite pulse-online;box-shadow:0 0 0 3px #05966933}@keyframes pulse-online{0%,to{box-shadow:0 0 0 2px #05966933}50%{box-shadow:0 0 0 5px #0596691a}}.status-idle{background-color:var(--status-idle-bg);color:var(--status-idle-text);border-color:#92400e26}.status-break{background-color:var(--status-break-bg);color:var(--status-break-text);border-color:#5b21b626}.status-offline{background-color:var(--status-offline-bg);color:var(--status-offline-text);border-color:#47556926}.main-header{height:var(--header-height);background-color:var(--bg-app);z-index:40;border-bottom:1px solid #0000;justify-content:space-between;align-items:center;padding:0 40px;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:24px;display:flex}.page-title{color:var(--text-primary);letter-spacing:-.03em;margin:0;font-size:24px;font-weight:700}.header-left .status-indicator{box-shadow:none;background:0 0;border:none;padding:0}.header-actions{align-items:center;gap:12px;display:flex}.date-selector{border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;background:#fff;align-items:center;gap:8px;padding:8px 12px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.date-selector:hover{border-color:var(--text-tertiary);color:var(--text-primary)}.filter-btn{border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);background:#fff;align-items:center;gap:8px;padding:8px 12px;font-size:13px;font-weight:500;display:flex}.filter-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.notification-system{z-index:10000;pointer-events:none;width:400px;max-height:100vh;position:fixed;overflow:hidden}.notification-system.top-right{top:20px;right:20px}.notification-system.top-left{top:20px;left:20px}.notification-system.bottom-right{bottom:20px;right:20px}.notification-system.bottom-left{bottom:20px;left:20px}.notification-header{pointer-events:all;background:#fff;border:1px solid #e5e7eb;border-radius:8px 8px 0 0;justify-content:space-between;align-items:center;margin-bottom:2px;padding:8px 12px;display:flex;box-shadow:0 2px 8px #0000001a}.notification-count{color:#6b7280;align-items:center;gap:6px;font-size:12px;font-weight:500;display:flex}.clear-all-btn{color:#374151;cursor:pointer;background:#f3f4f6;border:none;border-radius:4px;padding:4px 8px;font-size:11px;transition:background-color .2s}.clear-all-btn:hover{background:#e5e7eb}.notification-list{flex-direction:column;gap:8px;display:flex}.notification{pointer-events:all;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;transform:translate(100%);box-shadow:0 4px 12px #00000026}.notification:before{content:"";width:4px;position:absolute;top:0;bottom:0;left:0}.notification-info:before{background:#3b82f6}.notification-success:before{background:#10b981}.notification-warning:before{background:#f59e0b}.notification-error:before{background:#ef4444}.notification-enter{transform:translate(0)}.notification-exit{opacity:0;transform:translate(100%)}.notification-icon{flex-shrink:0;align-items:flex-start;margin-top:2px;margin-right:12px;display:flex}.notification-info .notification-icon{color:#3b82f6}.notification-success .notification-icon{color:#10b981}.notification-warning .notification-icon{color:#f59e0b}.notification-error .notification-icon{color:#ef4444}.notification-content{flex:1;min-width:0}.notification-header-content{justify-content:space-between;align-items:flex-start;margin-bottom:4px;display:flex}.notification-title{color:#111827;margin:0;font-size:14px;font-weight:600;line-height:1.2}.notification-time{color:#9ca3af;white-space:nowrap;margin-left:8px;font-size:11px}.notification-message{color:#6b7280;margin:0 0 12px;font-size:13px;line-height:1.4}.notification-action{cursor:pointer;background:0 0;border:1px solid;border-radius:4px;padding:6px 12px;font-size:12px;font-weight:500;transition:all .2s}.notification-info .notification-action{color:#3b82f6}.notification-info .notification-action:hover{color:#fff;background:#3b82f6}.notification-success .notification-action{color:#10b981}.notification-success .notification-action:hover{color:#fff;background:#10b981}.notification-warning .notification-action{color:#f59e0b}.notification-warning .notification-action:hover{color:#fff;background:#f59e0b}.notification-error .notification-action{color:#ef4444}.notification-error .notification-action:hover{color:#fff;background:#ef4444}.notification-close{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;transition:all .2s;position:absolute;top:8px;right:8px}.notification-close:hover{color:#6b7280;background:#f3f4f6}.notification:hover{transform:translate(-4px);box-shadow:0 6px 20px #0003}.notification:hover .notification-close{opacity:1}.notification[data-duration]:not([data-duration="0"]):after{content:"";height:2px;animation:notification-progress var(--duration,5s) linear;opacity:.6;background:currentColor;position:absolute;bottom:0;left:0}@keyframes notification-progress{0%{width:100%}to{width:0%}}@media (width<=480px){.notification-system{width:calc(100vw - 40px);left:20px!important;right:20px!important}.notification{padding:12px}.notification-title{font-size:13px}.notification-message{font-size:12px}}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-100%)}to{opacity:1;transform:translate(0)}}.top-right .notification-enter,.bottom-right .notification-enter{animation:.3s cubic-bezier(.4,0,.2,1) slideInRight}.top-left .notification-enter,.bottom-left .notification-enter{animation:.3s cubic-bezier(.4,0,.2,1) slideInLeft}@media (prefers-color-scheme:dark){.notification,.notification-header{background:#1f2937;border-color:#374151}.notification-title{color:#f9fafb}.notification-message{color:#d1d5db}.notification-time{color:#6b7280}.clear-all-btn{color:#d1d5db;background:#374151}.clear-all-btn:hover{background:#4b5563}.notification-close:hover{color:#d1d5db;background:#374151}}@media (prefers-reduced-motion:reduce){.notification{transition:none;animation:none}.notification:after{animation:none}}@media (prefers-contrast:high){.notification{border-width:2px}.notification:before{width:6px}}.app-layout{background-color:var(--bg-app);height:100vh;display:flex;overflow:hidden}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-width:0;height:100vh;display:flex;overflow-x:hidden}.view-switcher{border-bottom:1px solid var(--border-color,#e5e7eb);gap:4px;padding:20px 40px 0;display:flex}.view-btn{color:var(--text-secondary,#6b7280);cursor:pointer;background:0 0;border:none;border-radius:8px 8px 0 0;align-items:center;gap:8px;padding:12px 16px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.view-btn:hover{background:var(--bg-hover,#f3f4f6);color:var(--text-primary,#111827)}.view-btn.active{color:var(--text-primary,#111827);border:1px solid var(--border-color,#e5e7eb);z-index:1;background:#fff;border-bottom:1px solid #fff;position:relative}.dashboard-container{box-sizing:border-box;flex:1;width:100%;max-width:1600px;min-height:0;margin:0 auto;padding:32px 40px;overflow-y:auto}.history-container{box-sizing:border-box;flex-direction:column;flex:1;width:100%;min-height:0;display:flex;overflow:hidden}.metrics-grid{grid-template-columns:repeat(3,1fr);gap:32px;margin-bottom:40px;display:grid}.chart-section-full{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);min-height:400px;box-shadow:var(--shadow-sm);margin-bottom:24px;padding:24px}.apps-section-full{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px 20px 0;overflow:hidden}.section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section-title{color:var(--text-secondary);margin:0;font-size:14px;font-weight:500}.loading-state{text-align:center;color:var(--text-secondary);background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);padding:40px}.dashboard-container{animation:.4s ease-out fadeIn}@media (width<=1200px){.dashboard-grid{grid-template-columns:1fr;gap:32px}.metrics-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=968px){.metrics-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.app-layout{flex-direction:column}.main-content{margin-left:0}.dashboard-container{padding:20px}.metrics-grid{grid-template-columns:1fr}}.check-in-warning-banner{background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);border-bottom:2px solid #f59e0b;padding:16px 32px;animation:.3s ease-out slideDown}.warning-content{align-items:center;gap:16px;max-width:1200px;margin:0 auto;display:flex}.warning-icon{flex-shrink:0;font-size:28px}.warning-text{flex-direction:column;flex:1;gap:4px;display:flex}.warning-title{color:#92400e;letter-spacing:-.01em;font-size:15px;font-weight:700}.warning-message{color:#78350f;font-size:13px;line-height:1.5}.btn-go-to-attendance{color:#fff;cursor:pointer;white-space:nowrap;background:#f59e0b;border:none;border-radius:8px;padding:10px 20px;font-size:13px;font-weight:600;transition:all .2s;box-shadow:0 2px 4px #f59e0b4d}.btn-go-to-attendance:hover{background:#d97706;transform:translateY(-1px);box-shadow:0 4px 8px #f59e0b66}.btn-go-to-attendance:active{transform:translateY(0)}.dashboard-container.disabled-overlay{opacity:.5;pointer-events:none;position:relative}.dashboard-container.disabled-overlay:after{content:"";-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:10;background:#ffffffb3;position:absolute;inset:0}.auth-container{color:#1d1d1f;background-color:#f5f5f7;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex}.auth-card{text-align:center;background:#fff;border-radius:12px;width:100%;max-width:400px;padding:2.5rem;box-shadow:0 4px 24px #00000014}.auth-card h2{margin-top:0;margin-bottom:.5rem;font-size:1.5rem}.auth-subtitle{color:#86868b;margin-bottom:2rem;font-size:.9rem}.form-group{text-align:left;margin-bottom:1.25rem}.form-group label{color:#424245;margin-bottom:.4rem;font-size:.8rem;font-weight:500;display:block}.form-group input{box-sizing:border-box;color:#1d1d1f;background-color:#fff;border:1px solid #d2d2d7;border-radius:8px;width:100%;padding:.8rem;font-size:1rem}button{color:#fff;cursor:pointer;background:#0071e3;border:none;border-radius:8px;width:100%;margin-top:1rem;padding:.8rem;font-size:1rem;font-weight:500;transition:background .2s}button:hover{background:#0077ed}button:disabled{cursor:not-allowed;background:#d2d2d7}button.secondary{color:#1d1d1f;background:0 0;border:1px solid #d2d2d7}button.secondary:hover{background:#f5f5f7}.hw-info{color:#86868b;word-break:break-all;margin-top:1rem;font-size:.75rem}.auth-error{color:#d70015;text-align:left;background:#fff2f2;border-radius:8px;margin-bottom:1.5rem;padding:.8rem;font-size:.9rem}.status-icon{margin-bottom:1rem;font-size:3rem}.status-icon.pending{animation:2s ease-in-out infinite pulse}.status-icon.error{opacity:.9}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-card p{color:#424245;line-height:1.5}.status-card .status-message{color:#1a1a1a;margin-bottom:1rem;font-size:1.05rem}.device-info-box{word-break:break-all;background:#f5f5f7;border-radius:6px;margin:1rem 0;padding:.75rem 1rem;font-family:Monaco,Courier New,monospace}.info-box{text-align:left;background:#e8f5e9;border-left:3px solid #4caf50;border-radius:4px;margin:1.5rem 0;padding:1rem}.info-box p{color:#2e7d32;margin:.5rem 0}.last-checked{color:#666;margin:1rem 0;font-size:.9rem}.last-checked small{color:#999;font-size:.85rem}.error-detail{color:#c62828;background:#ffebee;border-left:3px solid #f44336;border-radius:4px;margin:1rem 0;padding:.75rem 1rem}.actions{justify-content:center;gap:.75rem;margin-top:2rem;display:flex}.actions button.secondary{color:#424245;background:#f5f5f7}.actions button.secondary:hover{background:#e8e8ea}
