:root{--inn-bg-deep: #fafafa;--inn-bg: #ffffff;--inn-bg-soft: #f5f5f4;--inn-card: #ffffff;--inn-bg-input: #ffffff;--inn-bg-hover: #fff7ed;--inn-bg-overlay: rgba(15, 23, 42, .45);--inn-border: #e2e8f0;--inn-border-subtle: #f1f5f9;--inn-text: #0f172a;--inn-muted: #64748b;--inn-text-dim: #94a3b8;--inn-text-inv: #ffffff;--inn-primary: #ff751f;--inn-primary-hover: #e5651a;--inn-primary-sub: rgba(255, 117, 31, .08);--inn-primary-dull: #ffedd5;--inn-primary-glow: rgba(255, 117, 31, .15);--inn-success: #10b981;--inn-success-bg: rgba(16, 185, 129, .08);--inn-danger: #ef4444;--inn-danger-h: #dc2626;--inn-danger-bg: rgba(239, 68, 68, .08);--inn-warning: #f59e0b;--inn-warning-bg: rgba(245, 158, 11, .08);--inn-info: #3b82f6;--inn-info-bg: rgba(59, 130, 246, .08);--inn-font: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--inn-mono: "JetBrains Mono", "SF Mono", monospace;--s1: 4px;--s2: 8px;--s3: 12px;--s4: 16px;--s5: 20px;--s6: 24px;--s8: 32px;--s10: 40px;--s12: 48px;--r-sm: 6px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--r-full: 9999px;--sh-sm: 0 1px 2px rgba(0, 0, 0, .04);--sh-md: 0 4px 12px rgba(0, 0, 0, .06);--sh-lg: 0 8px 24px rgba(0, 0, 0, .1);--sh-glow: 0 0 24px var(--inn-primary-glow);--sidebar-w: 232px;--sidebar-w-sm: 200px;--content-max: 1100px;--inn-ease-fast: .15s ease;--inn-ease: .2s ease;--inn-ease-slow: .3s ease}@keyframes inn-spin{to{transform:rotate(360deg)}}@keyframes inn-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes inn-fade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}@keyframes inn-scale{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:none}}.inn-spinner{width:18px;height:18px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:inn-spin .6s linear infinite;display:inline-block;flex-shrink:0}.inn-skeleton{background:linear-gradient(90deg,var(--inn-bg-soft) 0%,var(--inn-bg-hover) 50%,var(--inn-bg-soft) 100%);background-size:200% 100%;animation:inn-shimmer 1.5s ease infinite;border-radius:var(--r-md)}.inn-fade{animation:inn-fade .3s ease both}.inn-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;font-family:var(--inn-font);font-weight:600;font-size:14px;height:40px;padding:0 20px;border-radius:var(--r-full);white-space:nowrap;transition:all var(--inn-ease-fast);outline:none;text-decoration:none}.inn-btn:focus-visible{box-shadow:0 0 0 3px var(--inn-primary-sub)}.inn-btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.inn-btn.primary{background:var(--inn-primary);color:var(--inn-text-inv);box-shadow:0 1px 3px #ff751f4d}.inn-btn.primary:hover{background:var(--inn-primary-hover);box-shadow:0 2px 8px #ff751f40}.inn-btn.secondary{background:var(--inn-card);color:var(--inn-text);border:1px solid var(--inn-border)}.inn-btn.secondary:hover{background:var(--inn-bg-hover);border-color:#cbd5e1}.inn-btn.ghost{background:transparent;color:var(--inn-muted)}.inn-btn.ghost:hover{background:var(--inn-bg-hover);color:var(--inn-text)}.inn-btn.danger{background:var(--inn-danger);color:#fff}.inn-btn.danger:hover{background:var(--inn-danger-h)}.inn-btn.sm{height:32px;padding:0 14px;font-size:12px}.inn-btn.lg{height:48px;padding:0 28px;font-size:16px}.inn-btn.icon-only{width:40px;padding:0}.inn-field{display:flex;flex-direction:column;gap:6px}.inn-label{font-size:12px;font-weight:600;color:var(--inn-muted);letter-spacing:.04em;text-transform:uppercase}.inn-input{height:44px;padding:0 16px;background:var(--inn-bg-input);border:1px solid var(--inn-border);border-radius:var(--r-lg);color:var(--inn-text);font-family:var(--inn-font);font-size:14px;outline:none;width:100%;transition:border var(--inn-ease-fast)}.inn-input:focus{border-color:var(--inn-primary);box-shadow:0 0 0 3px var(--inn-primary-sub)}.inn-input.has-error{border-color:var(--inn-danger)}.inn-input.has-error:focus{box-shadow:0 0 0 3px var(--inn-danger-bg)}.inn-input::placeholder{color:var(--inn-text-dim)}.inn-error-msg{font-size:12px;color:var(--inn-danger);margin-top:2px}.inn-card{background:var(--inn-card);border:1px solid var(--inn-border);border-radius:var(--r-xl);padding:var(--s6);box-shadow:var(--sh-sm)}.inn-card.flush{padding:0;overflow:hidden}.inn-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:var(--r-full);font-size:11px;font-weight:600;letter-spacing:.01em;white-space:nowrap}.inn-badge.clock-in{background:var(--inn-primary-sub);color:var(--inn-primary)}.inn-badge.clock-out{background:var(--inn-info-bg);color:var(--inn-info)}.inn-badge.random-check{background:var(--inn-warning-bg);color:var(--inn-warning)}.inn-badge.ok{background:var(--inn-success-bg);color:var(--inn-success)}.inn-badge.err{background:var(--inn-danger-bg);color:var(--inn-danger)}.inn-badge.neutral{background:var(--inn-bg-hover);color:var(--inn-muted)}.inn-badge.admin{background:#8b5cf61f;color:#a78bfa}.inn-badge.employee{background:var(--inn-primary-sub);color:var(--inn-primary)}.inn-avatar{width:40px;height:40px;border-radius:var(--r-full);background:var(--inn-bg-soft);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--inn-primary);overflow:hidden;flex-shrink:0}.inn-avatar img{width:100%;height:100%;object-fit:cover}.inn-avatar.sm{width:32px;height:32px;font-size:11px}.inn-avatar.lg{width:56px;height:56px;font-size:18px}.inn-avatar.xl{width:72px;height:72px;font-size:22px}.inn-table{width:100%;border-collapse:collapse}.inn-table th{padding:10px 16px;text-align:left;font-size:11px;font-weight:600;color:var(--inn-text-dim);letter-spacing:.05em;text-transform:uppercase;border-bottom:1px solid var(--inn-border);background:var(--inn-bg-soft);white-space:nowrap}.inn-table th:first-child{border-radius:var(--r-lg) 0 0 0}.inn-table th:last-child{border-radius:0 var(--r-lg) 0 0}.inn-table td{padding:14px 16px;border-bottom:1px solid var(--inn-border-subtle);font-size:14px;vertical-align:middle}.inn-table tbody tr{transition:background var(--inn-ease-fast)}.inn-table tbody tr:hover td{background:var(--inn-bg-hover)}.inn-table tbody tr:last-child td{border-bottom:none}.inn-banner{display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:var(--r-lg);font-size:13px;font-weight:500}.inn-banner.info{background:var(--inn-info-bg);color:var(--inn-info);border:1px solid rgba(96,165,250,.15)}.inn-banner.warn{background:var(--inn-warning-bg);color:var(--inn-warning);border:1px solid rgba(251,191,36,.15)}.inn-banner.imp{background:var(--inn-primary-sub);color:var(--inn-primary);border:1px solid rgba(255,117,31,.12)}.inn-banner.err{background:var(--inn-danger-bg);color:var(--inn-danger);border:1px solid rgba(248,113,113,.15)}.inn-modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--inn-bg-overlay);display:flex;align-items:center;justify-content:center;z-index:1000;animation:inn-fade .15s ease}.inn-modal{background:var(--inn-card);border:1px solid var(--inn-border);border-radius:var(--r-xl);padding:var(--s8);width:100%;max-width:480px;animation:inn-scale .2s ease both;box-shadow:var(--sh-lg)}.inn-search{position:relative;display:inline-flex;align-items:center}.inn-search input{height:40px;padding:0 16px 0 40px;background:var(--inn-bg-input);border:1px solid var(--inn-border);border-radius:var(--r-full);color:var(--inn-text);font-family:var(--inn-font);font-size:14px;outline:none;width:100%;transition:border var(--inn-ease-fast)}.inn-search input:focus{border-color:var(--inn-primary);box-shadow:0 0 0 3px var(--inn-primary-sub)}.inn-search input::placeholder{color:var(--inn-text-dim)}.inn-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--inn-text-dim);pointer-events:none;display:flex}.inn-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:48px 24px;gap:12px}.inn-empty .e-icon{width:48px;height:48px;border-radius:var(--r-xl);background:var(--inn-bg-hover);display:flex;align-items:center;justify-content:center;color:var(--inn-text-dim);margin-bottom:4px}.inn-empty h3{font-size:16px;font-weight:600;color:var(--inn-text);margin:0}.inn-empty p{font-size:14px;color:var(--inn-muted);max-width:320px;margin:0}.inn-stat{background:var(--inn-card);border:1px solid var(--inn-border);border-radius:var(--r-xl);padding:var(--s5);display:flex;flex-direction:column;gap:var(--s3);box-shadow:var(--sh-sm)}.inn-stat .st-label{font-size:12px;font-weight:600;color:var(--inn-text-dim);letter-spacing:.04em;text-transform:uppercase}.inn-stat .st-val{font-size:32px;font-weight:700;color:var(--inn-text);letter-spacing:-.02em;line-height:1}.inn-stat .st-sub{font-size:12px;color:var(--inn-muted)}.inn-stat-icon{width:32px;height:32px;border-radius:var(--r-md);background:var(--inn-primary-sub);display:flex;align-items:center;justify-content:center;color:var(--inn-primary)}.inn-app-shell{display:flex;min-height:100vh;background:var(--inn-bg)}.inn-sidebar{width:var(--sidebar-w);min-height:100vh;background:var(--inn-bg-deep);border-right:1px solid var(--inn-border);padding:var(--s5) var(--s3);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;position:sticky;top:0;align-self:flex-start}.inn-sidebar.sm{width:var(--sidebar-w-sm)}.inn-sidebar .brand{display:flex;align-items:center;gap:10px;padding:var(--s2) var(--s3);margin-bottom:var(--s6)}.inn-sidebar .brand .dot{width:10px;height:10px;border-radius:50%;background:var(--inn-primary);flex-shrink:0}.inn-sidebar .brand span{font-size:16px;font-weight:700;color:var(--inn-text)}.inn-sidebar .brand-sub{font-size:12px;color:var(--inn-text-dim);margin-top:2px}.inn-sidebar .grp{font-size:10px;font-weight:600;color:var(--inn-text-dim);letter-spacing:.08em;text-transform:uppercase;padding:var(--s4) var(--s3) var(--s1)}.inn-sidebar .nav-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--r-md);font-size:14px;font-weight:500;color:var(--inn-muted);cursor:pointer;transition:all var(--inn-ease-fast);text-decoration:none;border:none;background:none;font-family:var(--inn-font);width:100%;text-align:left}.inn-sidebar .nav-item:hover{background:var(--inn-bg-hover);color:var(--inn-text)}.inn-sidebar .nav-item.active{background:var(--inn-primary-sub);color:var(--inn-primary);font-weight:600}.inn-sidebar .nav-item svg{flex-shrink:0}.inn-sidebar .spacer{flex:1}.inn-sidebar .signout{margin-top:auto;padding-top:var(--s4);border-top:1px solid var(--inn-border-subtle)}.inn-main{flex:1;overflow:auto;min-width:0}.inn-page{padding:var(--s8);max-width:var(--content-max);animation:inn-fade .3s ease both}.inn-page-header{margin-bottom:var(--s6)}.inn-page-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--s4);flex-wrap:wrap}.inn-page-title{font-size:20px;font-weight:700;line-height:1.3;margin:0}.inn-page-subtitle{font-size:14px;color:var(--inn-muted);margin:4px 0 0}.inn-page-actions{display:flex;gap:8px;flex-shrink:0;align-items:center;flex-wrap:wrap}.inn-tabs{display:flex;gap:4px;padding:2px;background:var(--inn-bg-soft);border-radius:var(--r-full);width:fit-content}.inn-tab{padding:6px 14px;border-radius:var(--r-full);font-size:13px;font-weight:500;color:var(--inn-muted);cursor:pointer;transition:all var(--inn-ease-fast);border:none;background:none;font-family:var(--inn-font)}.inn-tab:hover{color:var(--inn-text)}.inn-tab.active{background:var(--inn-card);color:var(--inn-text);font-weight:600;box-shadow:var(--sh-sm)}.inn-login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--s6);background:var(--inn-bg)}.inn-login-card{width:min(420px,100%);padding:var(--s10) var(--s8);box-shadow:var(--sh-glow);border:1px solid rgba(255,117,31,.15)}.inn-login-brand{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:var(--s3)}.inn-login-brand .dot-lg{width:12px;height:12px;border-radius:50%;background:var(--inn-primary)}.inn-login-brand h1{font-size:24px;font-weight:800;letter-spacing:-.02em;margin:0}.inn-login-footer{text-align:center;font-size:12px;color:var(--inn-text-dim);margin-top:var(--s4)}.inn-mono{font-family:var(--inn-mono)}.inn-muted{color:var(--inn-muted)}.inn-dim{color:var(--inn-text-dim)}.inn-text-error{color:var(--inn-danger)}.inn-toolbar{display:flex;align-items:center;gap:var(--s4);margin-bottom:var(--s6);flex-wrap:wrap}.inn-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s4);margin-bottom:var(--s8)}.inn-grid-2-1{display:grid;grid-template-columns:2fr 1fr;gap:var(--s4)}.inn-grid-1-1{display:grid;grid-template-columns:1fr 1fr;gap:var(--s6)}.inn-stack{display:flex;flex-direction:column;gap:var(--s4)}.inn-row{display:flex;align-items:center;gap:var(--s3)}.inn-activity-row{display:flex;align-items:center;gap:var(--s3);padding:var(--s3) 0;border-bottom:1px solid var(--inn-border-subtle)}.inn-activity-row:last-child{border-bottom:none}.inn-placeholder-box{border:2px dashed var(--inn-border);border-radius:var(--r-xl);padding:var(--s8);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--s2);color:var(--inn-text-dim);min-height:200px}.inn-link{color:var(--inn-primary);text-decoration:none;font-weight:500}.inn-link:hover{text-decoration:underline}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (max-width: 900px){.inn-app-shell{flex-direction:column}.inn-sidebar{width:100%;min-height:auto;position:relative;border-right:none;border-bottom:1px solid var(--inn-border-subtle)}.inn-grid-3,.inn-grid-2-1,.inn-grid-1-1{grid-template-columns:1fr}.inn-page{padding:var(--s4)}}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%}body{font-family:var(--inn-font);background:var(--inn-bg);color:var(--inn-text);line-height:1.5;-webkit-font-smoothing:antialiased}::selection{background:var(--inn-primary);color:var(--inn-text-inv)}a{color:var(--inn-primary)}.card{background:var(--inn-card);border:1px solid var(--inn-border);border-radius:var(--r-xl);padding:var(--s6);box-shadow:var(--sh-sm)}.muted{color:var(--inn-muted)}.small{font-size:.875rem}.error,.inn-text-error{color:var(--inn-danger)}.mono{font-family:var(--inn-mono);word-break:break-all}.page-loader{min-height:40vh;display:flex;align-items:center;justify-content:center;padding:var(--s6);flex-direction:column;gap:var(--s3)}.page-loader p{color:var(--inn-muted);font-size:14px}button.btn-secondary,a.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:40px;padding:0 20px;border-radius:var(--r-full);font-family:var(--inn-font);font-weight:600;font-size:14px;cursor:pointer;text-decoration:none;background:transparent;color:var(--inn-text);border:1px solid var(--inn-border);transition:all var(--inn-ease-fast)}button.btn-secondary:hover,a.btn-secondary:hover{background:var(--inn-bg-hover)}.event-photo{max-width:100%;max-height:420px;border-radius:var(--r-lg);border:1px solid var(--inn-border)}.event-map{width:100%;height:280px;border:1px solid var(--inn-border);border-radius:var(--r-lg);margin-top:var(--s2)}.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--s4);margin-bottom:var(--s4)}.profile-dl{display:grid;grid-template-columns:120px 1fr;gap:var(--s2) var(--s3);margin:0 0 var(--s3)}.profile-dl dt{color:var(--inn-muted);font-size:.875rem}.profile-dl dd{margin:0}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--s3)}.form-row label{display:flex;flex-direction:column;gap:6px;font-size:.875rem}.form-row input,.form-row select,.form-row textarea{height:44px;padding:0 16px;background:var(--inn-bg-input);border:1px solid var(--inn-border);border-radius:var(--r-lg);color:var(--inn-text);font-family:var(--inn-font);font-size:14px}.form-actions{display:flex;align-items:center;gap:var(--s4);margin-top:var(--s2)}.success-msg{color:var(--inn-success)}.day-heading{margin:0 0 var(--s2);font-size:1rem;color:var(--inn-muted)}.day-group{margin-bottom:var(--s4)}.person-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s2);margin:0 0 var(--s3)}.person-meta div{display:flex;flex-direction:column;gap:2px}.person-meta dt{font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:var(--inn-text-dim)}.person-meta dd{margin:0;font-size:.875rem}.people-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--s3)}.person-card-head{display:flex;justify-content:space-between;gap:var(--s3);margin-bottom:var(--s3)}.person-name{margin:0;font-size:1.1rem;color:var(--inn-primary);text-decoration:none}.person-card-actions{display:flex;gap:var(--s3);align-items:center}.toolbar{display:flex;align-items:flex-end;gap:var(--s4);margin-bottom:var(--s6);flex-wrap:wrap}.sort-field select{height:40px;padding:0 16px;background:var(--inn-bg-input);border:1px solid var(--inn-border);border-radius:var(--r-full);color:var(--inn-text);font-family:var(--inn-font)}@media (max-width: 640px){.person-meta{grid-template-columns:1fr}}.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}.azure-face-steps{margin:12px 0;padding-left:1.25rem;line-height:1.5}.azure-face-actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px}
