@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-ease:initial}}}@layer theme{:root,:host{--color-slate-50:#f8fafc;--color-slate-950:#020618;--radius-lg:.5rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--ease-out:cubic-bezier(0, 0, .2, 1);--ease-in-out:cubic-bezier(.4, 0, .2, 1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-geist-sans);--default-mono-font-family:var(--font-geist-mono)}@supports (color:lab(0% 0 0)){:root,:host{--color-slate-50:lab(98.1434% -.369549 -1.05968);--color-slate-950:lab(1.76974% 1.32743 -9.28855)}}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.inline-grid{display:inline-grid}.table{display:table}.h-dvh{height:100dvh}.h-full{height:100%}.min-h-full{min-height:100%}.w-full{width:100%}.flex-shrink{flex-shrink:1}.border-collapse{border-collapse:collapse}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.overflow-hidden{overflow:hidden}.rounded{border-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.border-0{border-style:var(--tw-border-style);border-width:0}.bg-slate-50{background-color:var(--color-slate-50)}.bg-slate-950{background-color:var(--color-slate-950)}.uppercase{text-transform:uppercase}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}}:root{--background:#fff;--foreground:#171717}@media (prefers-color-scheme:dark){:root{--background:#0a0a0a;--foreground:#ededed}}body{background:var(--background);color:var(--foreground);font-family:Arial,Helvetica,sans-serif}.you-marker,.home-gps-marker-pulse{background:#1e3a8a;border:3px solid #fff;border-radius:999px;width:18px;height:18px;box-shadow:0 0 0 8px #1e3a8a2e}.home-gps-marker-pulse{place-items:center;width:28px;height:28px;display:grid}.pin-inner{background:#fff;border-radius:999px;width:10px;height:10px}:root{--bg:#1e3a8a;--bg-soft:#172554;--surface:#fff;--surface-2:#f8fafc;--surface-3:#eef2ff;--border:#e2e8f0;--border-strong:#cbd5e1;--text:#0f172a;--text-soft:#475569;--text-muted:#94a3b8;--primary:#1e3a8a;--accent:#1e3a8a;--accent-soft:#eff6ff;--accent-strong:#1d4ed8;--accent-bright:#3b82f6;--danger:#b91c1c;--danger-soft:#fee2e2;--success:#059669;--success-soft:#ecfdf5;--warn:#a16207;--warn-soft:#fef9c3;--info:#1e40af;--info-soft:#dbeafe;--shadow-sm:0 8px 22px #0f172a0f;--shadow-md:0 14px 36px #0f172a14;--shadow-lg:0 24px 60px #0f172a29;--radius:16px;--radius-lg:24px}html[data-theme=dark]{--bg:#0a0e1a;--bg-soft:#11162a;--surface:#16192e;--surface-2:#1d2140;--surface-3:#252a4a;--border:#2d3155;--border-strong:#3d4275;--text:#e8eaf6;--text-soft:#b0b4cd;--text-muted:#7a7f9a;--primary:#e8eaf6;--accent:#6464c8;--accent-soft:#2d2d6d;--accent-strong:#8484e8;--accent-bright:#8484e8;--danger:#ef4444;--danger-soft:#4a1818;--success:#22c55e;--success-soft:#1a3a24;--warn:#eab308;--warn-soft:#3a3018;--info:#3b82f6;--info-soft:#1a2a4a;--shadow-sm:0 1px 2px #0000004d, 0 1px 3px #0006;--shadow-md:0 4px 6px #0000004d, 0 10px 20px #0006;--shadow-lg:0 10px 30px #0006, 0 20px 50px #00000080}html,body,.step,.admin-shell,.card,.auth-screen,.modal,header,nav,button,input,textarea,select{transition:background-color .25s,border-color .25s,color .25s}*{box-sizing:border-box;margin:0;padding:0}html,body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-feature-settings:"kern","liga","ss01","cv11";color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;min-height:100vh;padding-top:env(safe-area-inset-top,0);padding-bottom:env(safe-area-inset-bottom,0);padding-left:env(safe-area-inset-left,0);padding-right:env(safe-area-inset-right,0);background:radial-gradient(circle at 0 0,#1e3a8a14,#0000 34%),linear-gradient(#f8fafc 0%,#eef2ff 100%);font-family:Plus Jakarta Sans,Inter Tight,DM Sans,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;line-height:1.5}.app-shell{background:#ffffffdb;border-left:1px solid #e2e8f0cc;border-right:1px solid #e2e8f0cc;flex-direction:column;max-width:1100px;min-height:100vh;margin:0 auto;display:flex;position:relative;overflow-x:hidden;box-shadow:0 24px 70px #0f172a14}html,body{max-width:100%;overflow-x:hidden}.app-shell>main,.app-shell>.step,.app-shell>section:not(footer),.app-shell>.progress-bar{flex-shrink:0}.app-shell>.app-footer{margin-top:auto}#pullToRefreshIndicator{color:#fff;z-index:9997;pointer-events:none;background:linear-gradient(135deg,#1e3a8a 0%,#2563eb 100%);justify-content:center;align-items:center;height:0;font-size:13px;font-weight:600;transition:height .2s ease-out;display:flex;position:fixed;top:0;left:0;right:0;overflow:hidden}#pullToRefreshIndicator.pulling{transition:none}#pullToRefreshIndicator.refreshing{height:60px!important}#pullToRefreshIndicator .ptr-icon{margin-right:8px;font-size:18px;transition:transform .2s;display:inline-block}#pullToRefreshIndicator.ready .ptr-icon{transform:rotate(180deg)}#pullToRefreshIndicator.refreshing .ptr-icon{animation:.8s linear infinite ptrSpin}@keyframes ptrSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-screen{text-align:center;max-width:440px;margin:0 auto;padding:32px 24px;animation:.4s ease-out authFadeIn;position:relative}@keyframes authFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.auth-back{border:1px solid var(--border);color:var(--text-soft);cursor:pointer;background:0 0;border-radius:8px;padding:6px 12px;font-size:13px;transition:all .15s;position:absolute;top:16px;left:16px}.auth-back:hover{background:var(--surface-2);color:var(--text)}.auth-logo{background:#fff;border-radius:24px;justify-content:center;align-items:center;width:88px;height:88px;margin:16px auto 20px;padding:8px;display:flex;overflow:hidden;box-shadow:0 8px 32px #4040882e}.auth-logo img{object-fit:contain;width:100%;height:100%}.auth-title{letter-spacing:-.02em;color:var(--text);margin:0 0 8px;font-family:Inter Tight,sans-serif;font-size:26px;font-weight:800}.auth-subtitle{color:var(--text-soft);margin:0 0 28px;font-size:14px}.auth-options{flex-direction:column;gap:12px;margin-bottom:24px;display:flex}.auth-btn{border:1.5px solid var(--border);background:var(--surface);cursor:pointer;text-align:left;border-radius:14px;align-items:center;gap:14px;width:100%;padding:16px 18px;font-family:Inter Tight,sans-serif;transition:all .2s;display:flex}.auth-btn:hover{border-color:#404088;transform:translateY(-1px);box-shadow:0 4px 16px #4040881f}.auth-btn-primary{color:#fff;background:linear-gradient(135deg,#404088 0%,#5a5ab8 100%);border-color:#0000}.auth-btn-primary:hover{box-shadow:0 8px 24px #40408859}.auth-btn-icon{flex-shrink:0;font-size:28px}.auth-btn-title{margin-bottom:2px;font-size:15px;font-weight:700}.auth-btn-sub{opacity:.75;font-size:12px}.auth-footer-hint{color:var(--text-muted);opacity:.7;margin:16px 0 0;font-size:11px}.auth-form{text-align:left;margin-top:20px}.auth-field{margin-bottom:16px}.auth-field label{color:var(--text-soft);letter-spacing:.02em;text-transform:uppercase;margin-bottom:7px;font-size:12px;font-weight:700;display:block}.auth-field input{background:var(--surface-2);border:1.5px solid var(--border);width:100%;color:var(--text);border-radius:12px;outline:none;padding:14px 16px;font-family:Inter Tight,sans-serif;font-size:15px;transition:all .2s}.auth-field input:focus{background:var(--surface);border-color:#404088;box-shadow:0 0 0 4px #4040881f}.auth-hint{color:var(--text-muted);margin-top:6px;font-size:11px;display:block}.auth-pwd-wrap{position:relative}.auth-pwd-wrap input{padding-right:48px}.auth-pwd-toggle{cursor:pointer;opacity:.5;background:0 0;border:none;padding:8px;font-size:18px;transition:opacity .15s;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.auth-pwd-toggle:hover{opacity:1}.auth-pwd-bar{background:var(--surface-2);border-radius:2px;height:4px;margin-top:8px;overflow:hidden}.auth-pwd-fill{border-radius:2px;height:100%;transition:all .3s}.auth-pwd-fill.weak{background:#dc2626;width:33%}.auth-pwd-fill.medium{background:#f59e0b;width:66%}.auth-pwd-fill.strong{background:#16a34a;width:100%}.auth-error{color:#dc2626;background:#dc262614;border:1px solid #dc262640;border-radius:10px;margin-bottom:14px;padding:10px 14px;font-size:13px;font-weight:600;animation:.4s shakeAuth}@keyframes shakeAuth{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.auth-submit{color:#fff;cursor:pointer;letter-spacing:.02em;background:linear-gradient(135deg,#404088 0%,#5a5ab8 100%);border:none;border-radius:12px;width:100%;margin-top:8px;padding:15px;font-family:Inter Tight,sans-serif;font-size:15px;font-weight:700;transition:all .2s;box-shadow:0 4px 14px #40408840}.auth-submit:hover{transform:translateY(-1px);box-shadow:0 8px 20px #40408859}.auth-submit:active{transform:translateY(0)}.auth-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.auth-forgot{text-align:center;color:#404088;cursor:pointer;margin:16px 0 0;font-size:13px;font-weight:600}.auth-forgot:hover{text-decoration:underline}.auth-stepper{justify-content:center;align-items:center;gap:10px;margin:20px 0 24px;display:flex}.auth-step-dot{background:var(--surface-2);width:32px;height:32px;color:var(--text-muted);border:2px solid var(--border);border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.auth-step-dot.active{color:#fff;background:linear-gradient(135deg,#404088 0%,#5a5ab8 100%);border-color:#0000;box-shadow:0 2px 8px #4040884d}.auth-step-dot.done{color:#fff;background:#16a34a;border-color:#0000}.auth-step-line{background:var(--border);border-radius:1px;width:60px;height:2px}.auth-step-line.active{background:#16a34a}.auth-greeting{text-align:center;background:linear-gradient(135deg,#4040880f 0%,#5a5ab80f 100%);border:1px solid #40408826;border-radius:12px;margin-bottom:20px;padding:14px 18px}.auth-greeting strong{color:#404088;margin-bottom:2px;font-size:15px;display:block}.auth-rules{background:var(--surface-2);color:var(--text-soft);border-radius:10px;margin:12px 0;padding:12px 14px;font-size:12px}.auth-rules strong{color:var(--text);margin-bottom:4px;display:block}.auth-rules ul{margin:0;padding-left:18px}.auth-rules li{margin:2px 0}.logout-btn{color:#dc2626;cursor:pointer;background:#dc26261f;border:1px solid #dc262640;border-radius:8px;align-items:center;gap:4px;padding:6px 10px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s;display:inline-flex}.logout-btn:hover{background:#dc262633}.floating-logout-btn{top:calc(env(safe-area-inset-top,0px) + 12px);color:#dc2626;cursor:pointer;z-index:1000;-webkit-backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #dc26264d;border-radius:12px;align-items:center;gap:6px;padding:8px 14px;font-family:Inter Tight,sans-serif;font-size:13px;font-weight:700;transition:all .2s;display:flex;position:fixed;right:16px;box-shadow:0 4px 14px #00000014,0 0 0 1px #00000005}.floating-logout-btn:hover{color:#fff;background:#dc2626f2;transform:translateY(-1px);box-shadow:0 6px 20px #dc262640}.floating-logout-btn:active{transform:translateY(0)}.theme-toggle-btn{top:calc(env(safe-area-inset-top,0px) + 12px);width:40px;height:40px;color:var(--text);border:1px solid var(--border);cursor:pointer;z-index:1000;-webkit-backdrop-filter:blur(10px);background:#fffffff2;border-radius:50%;justify-content:center;align-items:center;font-size:18px;transition:all .25s;display:flex;position:fixed;right:16px;box-shadow:0 4px 14px #00000014,0 0 0 1px #00000005}.theme-toggle-btn:hover{transform:translateY(-1px)rotate(15deg);box-shadow:0 8px 20px #0000001f}.theme-toggle-btn:active{transform:translateY(0)rotate(0)}[data-theme=dark] .theme-toggle-btn{border-color:var(--border-strong);color:#fbbf24;background:#1e2140f2}body.employee-mode .theme-toggle-btn{display:none!important}@media (max-width:500px){.auth-screen{padding:20px 16px}.auth-title{font-size:22px}.auth-logo{width:72px;height:72px}.auth-btn{padding:14px 16px}}.app-footer{border-top:1px solid var(--border);background:0 0;margin-top:32px;padding:16px 24px 20px}.footer-mini{color:var(--text-muted);letter-spacing:.01em;flex-wrap:wrap;justify-content:center;align-items:center;gap:6px 10px;font-size:11px;display:flex}.footer-brand-mini strong{color:var(--text-soft);font-weight:700}.footer-dot{color:var(--border);font-size:10px}.footer-tag{color:var(--text-soft)}.footer-std{color:var(--text-muted);opacity:.7;font-family:JetBrains Mono,monospace;font-size:10px}@media (max-width:500px){.app-footer{padding:14px 16px 18px}.footer-mini{gap:4px 8px;font-size:10px}.footer-std{font-size:9px}}.app-header{color:#fff;background:radial-gradient(circle at 12% 0,#60a5fa52,#0000 30%),linear-gradient(135deg,#1e3a8a 0%,#172554 100%);border-bottom:0;justify-content:space-between;align-items:center;padding:22px 32px;display:flex;position:relative;box-shadow:0 18px 40px #1e3a8a42}.app-header:after{content:"";background:linear-gradient(90deg,#0000,#ffffff6b,#0000);height:1px;position:absolute;bottom:0;left:32px;right:32px}.brand{align-items:center;gap:14px;display:flex}.brand-mark{background:#fff;border-radius:16px;place-items:center;width:46px;height:46px;padding:4px;display:grid;position:relative;overflow:hidden;box-shadow:0 12px 24px #0f172a38}.brand-mark img{object-fit:contain;width:100%;height:100%}.brand-text{flex-direction:column;line-height:1.15;display:flex}.brand-title{letter-spacing:.04em;color:#fff;font-size:16px;font-weight:700}.brand-sub{color:#fff9;letter-spacing:.05em;text-transform:uppercase;margin-top:2px;font-family:JetBrains Mono,monospace;font-size:11px}.header-meta{align-items:center;gap:18px;font-size:12px;display:flex}.header-date{color:#ffffffb3;font-family:JetBrains Mono,monospace}.admin-btn{color:#ffffffdb;cursor:pointer;letter-spacing:.04em;text-transform:uppercase;background:#ffffff1f;border:1px solid #ffffff38;border-radius:999px;padding:9px 14px;font-family:inherit;font-size:11px;font-weight:500;transition:all .15s}.admin-btn:hover{color:#fff;background:#ffffff2e;border-color:#fff6}.stepper{background:var(--surface-2);border-bottom:1px solid var(--border);grid-template-columns:repeat(5,1fr);padding:0;display:grid}.step-tab{text-align:center;border-right:1px solid var(--border);background:var(--surface-2);padding:16px 12px;transition:background .15s;position:relative}.step-tab:last-child{border-right:none}.step-tab.active,.step-tab.done{background:var(--surface)}.step-tab.active:after{content:"";background:var(--accent);height:3px;position:absolute;bottom:-1px;left:0;right:0}.step-num{background:var(--surface-3);width:22px;height:22px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;margin-right:6px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700;transition:all .2s;display:inline-flex}.step-tab.active .step-num{background:var(--accent);color:#fff}.step-tab.done .step-num{background:var(--success);color:#fff}.step-tab.done .step-num:before{content:"✓"}.step-tab.done .step-num span{display:none}.step-label{color:var(--text-soft);letter-spacing:.02em;font-size:12px;font-weight:600}.step-tab.active .step-label,.step-tab.done .step-label{color:var(--text)}.step{padding:36px 40px;animation:.3s ease-out stepIn;display:none}.step.active{display:block}.attendance-screen-pane{padding:36px 40px;animation:.3s ease-out stepIn}@keyframes stepIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.step-eyebrow{letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600}.step-title{letter-spacing:-.025em;color:var(--text);margin-bottom:6px;font-size:26px;font-weight:700}.step-desc{color:var(--text-soft);max-width:640px;margin-bottom:28px;font-size:14px}.banner{border-radius:var(--radius);border-left:3px solid;align-items:flex-start;gap:12px;margin:16px 0;padding:14px 16px;font-size:13px;display:flex}.banner-icon{border-radius:50%;flex-shrink:0;place-items:center;width:18px;height:18px;margin-top:1px;font-size:11px;font-weight:700;display:grid}.banner-warn{background:var(--warn-soft);border-color:var(--warn);color:#713f12}.banner-warn .banner-icon{background:var(--warn);color:#fff}.banner-info{background:var(--info-soft);border-color:var(--info);color:#1e3a8a}.banner-info .banner-icon{background:var(--info);color:#fff}.banner-success{background:var(--success-soft);border-color:var(--success);color:#14532d}.banner-success .banner-icon{background:var(--success);color:#fff}.banner strong{font-weight:600}.form-grid{grid-template-columns:1fr 1fr;gap:18px;display:grid}.form-grid .full{grid-column:1/-1}.field{flex-direction:column;gap:6px;display:flex}.field label{color:var(--text);letter-spacing:.02em;font-size:12px;font-weight:600}.field label .req{color:var(--danger);margin-left:2px}.field-hint{color:var(--text-muted);font-size:11px}.field input,.field select,.field textarea{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);padding:11px 14px;font-family:inherit;font-size:14px;transition:all .15s}.field input:hover,.field select:hover{border-color:var(--border-strong)}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.field input.error{border-color:var(--danger)}.btn{border-radius:var(--radius);cursor:pointer;letter-spacing:.01em;border:1px solid #0000;align-items:center;gap:8px;padding:12px 20px;font-family:inherit;font-size:13px;font-weight:600;text-decoration:none;transition:transform .16s,box-shadow .16s,background-color .16s,border-color .16s;display:inline-flex}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn-primary{color:#fff;background:linear-gradient(135deg,#1e3a8a 0%,#1d4ed8 100%);box-shadow:0 12px 24px #1e3a8a3d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#172554 0%,#1e3a8a 100%)}.btn-accent{color:#fff;background:linear-gradient(135deg,#1e3a8a 0%,#2563eb 100%);box-shadow:0 12px 24px #2563eb38}.btn-accent:hover:not(:disabled){background:var(--accent-strong)}.btn-success{color:#fff;background:linear-gradient(135deg,#059669 0%,#10b981 100%);box-shadow:0 12px 24px #05966938}.btn-success:hover:not(:disabled){background:linear-gradient(135deg,#047857 0%,#059669 100%)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#991b1b}.btn-ghost{color:var(--text);border-color:var(--border);background:#fff}.btn-ghost:hover{background:var(--accent-soft);color:var(--accent);border-color:#bfdbfe}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-lg{padding:13px 24px;font-size:14px}.btn-sm{padding:7px 12px;font-size:12px}.btn-row{flex-wrap:wrap;gap:10px;margin-top:24px;display:flex}.lesson-grid{gap:12px;margin-bottom:8px;display:grid}.lesson-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;align-items:center;gap:16px;padding:18px 20px;transition:all .15s;display:flex;position:relative}.lesson-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-1px)}.lesson-card.selected{border-color:var(--accent);background:linear-gradient(180deg, #fff 0%, var(--accent-soft) 100%);border-width:2px;padding:17px 19px;box-shadow:0 16px 34px #1e3a8a24}.lesson-card-icon{color:#fff;background:linear-gradient(135deg,#1e3a8a 0%,#2563eb 100%);border-radius:16px;flex-shrink:0;place-items:center;width:44px;height:44px;font-family:JetBrains Mono,monospace;font-size:14px;font-weight:700;display:grid}.lesson-card.selected .lesson-card-icon{background:var(--accent)}.lesson-card-body{flex:1;min-width:0}.lesson-card-title{color:var(--text);margin-bottom:2px;font-size:15px;font-weight:600}.lesson-card-meta{color:var(--text-muted);flex-wrap:wrap;gap:12px;font-size:12px;display:flex}.lesson-card-status{background:var(--surface-2);color:var(--text-soft);border-radius:999px;flex-shrink:0;padding:4px 8px;font-size:11px;font-weight:600}.lesson-card-status.ready{background:var(--success-soft);color:var(--success)}.empty-state{text-align:center;border:1px dashed var(--border);border-radius:var(--radius-lg);color:var(--text-muted);box-shadow:var(--shadow-sm);background:#fff;padding:60px 20px}.empty-state strong{color:var(--text);margin-bottom:6px;font-size:15px;display:block}.video-card{background:var(--bg);border-radius:var(--radius-lg);aspect-ratio:16/9;margin-bottom:14px;position:relative;overflow:hidden}#trainingVideo{background:var(--bg);object-fit:contain;width:100%;height:100%;display:block}.video-overlay{cursor:pointer;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f141980;place-items:center;transition:opacity .2s;display:grid;position:absolute;inset:0}.video-overlay.hidden{opacity:0;pointer-events:none}.play-circle{background:var(--accent);color:#fff;border-radius:50%;place-items:center;width:76px;height:76px;padding-left:5px;font-size:28px;display:grid;box-shadow:0 6px 30px #d9770680}.video-bar{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:14px;margin-bottom:14px;padding:14px 16px;display:flex}.play-toggle{background:var(--bg);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;place-items:center;width:36px;height:36px;font-size:13px;transition:background .15s;display:grid}.play-toggle:hover:not(:disabled){background:var(--accent)}.play-toggle:disabled{opacity:.5;cursor:not-allowed}.video-progress{background:var(--surface-3);border-radius:3px;flex:1;height:6px;position:relative;overflow:hidden}.video-progress-fill{background:var(--accent);width:0;height:100%;transition:width .2s linear}.video-time{color:var(--text-soft);font-variant-numeric:tabular-nums;flex-shrink:0;font-family:JetBrains Mono,monospace;font-size:12px}.video-pct{background:var(--bg);color:#fff;border-radius:4px;padding:4px 8px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600}.quiz-progress{background:var(--surface-2);border-radius:var(--radius);align-items:center;gap:12px;margin-bottom:18px;padding:12px 16px;font-size:13px;display:flex}.quiz-progress-track{background:var(--surface-3);border-radius:2px;flex:1;height:4px;overflow:hidden}.quiz-progress-fill{background:var(--accent);width:0;height:100%;transition:width .3s}.quiz-progress-num{color:var(--text);font-family:JetBrains Mono,monospace;font-weight:600}.question-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:14px;padding:20px 22px;transition:border-color .15s,box-shadow .15s,transform .15s}.question-card.answered{background:linear-gradient(180deg, #fff 0%, var(--success-soft) 100%);border-color:#a7f3d0}.question-num{color:#fff;letter-spacing:.05em;background:linear-gradient(135deg,#1e3a8a 0%,#2563eb 100%);border-radius:999px;margin-bottom:10px;padding:3px 8px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600;display:inline-block}.question-text{color:var(--text);margin-bottom:14px;font-size:15px;font-weight:600;line-height:1.45}.options-list{flex-direction:column;gap:8px;display:flex}.option-row{border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;background:var(--surface);align-items:center;gap:12px;padding:12px 14px;font-size:14px;transition:all .12s;display:flex}.option-row:hover{border-color:var(--border-strong);background:var(--surface-2)}.option-row.selected{border-color:var(--accent);background:var(--accent-soft)}.option-row input{display:none}.option-letter{border:1.5px solid var(--border-strong);border-radius:50%;flex-shrink:0;place-items:center;width:24px;height:24px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700;transition:all .12s;display:grid}.option-row.selected .option-letter{background:var(--accent);color:#fff;border-color:var(--accent)}.signature-frame{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface-2);margin:14px 0;padding:4px;position:relative}.signature-frame:before{content:"X _________________________";color:var(--text-muted);letter-spacing:.05em;pointer-events:none;opacity:.4;font-family:JetBrains Mono,monospace;font-size:13px;position:absolute;bottom:18px;left:30px}#sigPad{background:var(--surface);cursor:crosshair;touch-action:none;border-radius:6px;width:100%;height:200px;display:block}.summary-table{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);margin:18px 0;overflow:hidden}.summary-row{border-bottom:1px solid var(--border);grid-template-columns:180px 1fr;padding:11px 18px;font-size:13px;display:grid}.summary-row:last-child{border-bottom:none}.summary-row .k{color:var(--text-muted);letter-spacing:.02em;font-weight:500}.summary-row .v{color:var(--text);font-weight:600}.result-panel{text-align:center;border-radius:var(--radius-lg);padding:50px 30px;position:relative;overflow:hidden}.result-panel.pass{color:#fff;background:linear-gradient(135deg,#14532d 0%,#15803d 100%)}.result-panel.fail{color:#fff;background:linear-gradient(135deg,#7f1d1d 0%,#b91c1c 100%)}.result-icon{background:#ffffff2e;border:2px solid #fff6;border-radius:50%;place-items:center;width:76px;height:76px;margin:0 auto 18px;font-size:38px;font-weight:800;display:grid}.result-eyebrow{letter-spacing:.2em;text-transform:uppercase;opacity:.8;margin-bottom:6px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600}.result-title{letter-spacing:-.02em;margin-bottom:18px;font-size:32px;font-weight:800}.result-score{background:#ffffff26;border-radius:8px;align-items:baseline;gap:6px;margin:8px 0 18px;padding:14px 26px;font-family:JetBrains Mono,monospace;display:inline-flex}.result-score-big{font-size:44px;font-weight:700;line-height:1}.result-score-sm{opacity:.7;font-size:18px}.result-msg{opacity:.95;max-width:480px;margin:0 auto;font-size:15px;line-height:1.55}.cert-badge{letter-spacing:.05em;background:#00000040;border-radius:4px;margin-top:20px;padding:10px 14px;font-family:JetBrains Mono,monospace;font-size:12px;display:inline-block}.admin-shell{padding:36px 40px}.admin-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;padding-bottom:16px;display:flex}.admin-title{letter-spacing:-.02em;font-size:22px;font-weight:700}.admin-tabs{border:1px solid var(--border);-webkit-overflow-scrolling:touch;scrollbar-width:thin;box-shadow:var(--shadow-sm);background:#fff;border-radius:20px;gap:6px;margin-bottom:24px;padding:6px;display:flex;overflow-x:auto}.admin-tabs::-webkit-scrollbar{height:6px}.admin-tabs::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.admin-tab{color:var(--text-soft);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:16px;flex:1 0 auto;min-width:max-content;padding:10px 15px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.admin-tab:hover{color:var(--text)}@media (max-width:768px){.admin-tabs{flex-wrap:nowrap}.admin-tab{padding:8px 11px;font-size:12px}}.stat-grid{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:22px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:16px 18px}.stat-card .stat-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:6px;font-size:11px;font-weight:600}.stat-card .stat-value{color:var(--text);letter-spacing:-.02em;font-family:JetBrains Mono,monospace;font-size:26px;font-weight:700}.stat-card .stat-trend{color:var(--text-muted);margin-top:4px;font-size:11px}.stat-card.accent .stat-value{color:var(--accent)}.stat-card.success .stat-value{color:var(--success)}.stat-card.danger .stat-value{color:var(--danger)}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.toolbar-left{flex-wrap:wrap;flex:1;gap:8px;display:flex}.toolbar input.search{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);min-width:220px;padding:8px 12px;font-family:inherit;font-size:13px}.data-table{border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-sm);font-size:13px;overflow:hidden}.data-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border);background:#f8fafc;padding:10px 12px;font-size:11px;font-weight:600}.data-table tbody td{border-bottom:1px solid var(--border);vertical-align:middle;padding:11px 12px}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--surface-2)}.tbl-empty{text-align:center;color:var(--text-muted);padding:50px}.badge{letter-spacing:.02em;border-radius:4px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-pass{background:var(--success-soft);color:var(--success)}.badge-fail{background:var(--danger-soft);color:var(--danger)}.sig-thumb{object-fit:contain;border:1px solid var(--border);background:var(--surface);cursor:pointer;border-radius:4px;width:70px;height:32px}.selfie-thumb{object-fit:cover;border:2px solid var(--border);cursor:pointer;background:var(--surface-2);border-radius:50%;width:36px;height:36px;transition:transform .15s,border-color .15s;display:block}.selfie-thumb:hover{border-color:var(--accent);transform:scale(1.1)}.selfie-thumb-empty{color:var(--text-muted);cursor:default;justify-content:center;align-items:center;font-size:16px;display:inline-flex}.selfie-thumb-empty:hover{transform:none}.row-actions{gap:4px;display:flex}.icon-btn{border:1px solid var(--border);cursor:pointer;width:28px;height:28px;color:var(--text-soft);background:0 0;border-radius:4px;place-items:center;font-size:12px;transition:all .15s;display:grid}.icon-btn:hover{background:var(--surface-2);color:var(--text)}.icon-btn.danger:hover{background:var(--danger-soft);color:var(--danger);border-color:var(--danger)}.lessons-list{flex-direction:column;gap:10px;margin-bottom:18px;display:flex}.lesson-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);align-items:center;gap:14px;padding:14px 16px;display:flex}.lesson-row-id{background:var(--bg);color:#fff;border-radius:4px;flex-shrink:0;padding:4px 8px;font-family:JetBrains Mono,monospace;font-size:11px}.lesson-row-body{flex:1;min-width:0}.lesson-row-title{margin-bottom:2px;font-size:14px;font-weight:600}.lesson-row-meta{color:var(--text-muted);font-size:12px}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);text-align:center;cursor:pointer;background:var(--surface-2);padding:30px 20px;transition:all .15s}.upload-zone:hover{border-color:var(--accent);background:var(--accent-soft)}.upload-zone.has-file{border-color:var(--success);background:var(--success-soft);border-style:solid}.upload-zone.dragover{border-color:var(--accent);background:var(--accent-soft)}.upload-icon{opacity:.7;margin-bottom:8px;font-size:32px}.upload-zone strong{margin-bottom:4px;font-size:14px;display:block}.upload-zone .hint{color:var(--text-muted);font-size:12px}.upload-progress{background:var(--surface-3);border-radius:3px;height:6px;margin-top:14px;display:none;overflow:hidden}.upload-progress.active{display:block}.upload-progress-fill{background:var(--success);width:0;height:100%;transition:width .3s}.editor-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:16px;padding:22px}.editor-section h3{letter-spacing:-.01em;margin-bottom:14px;font-size:14px;font-weight:700}.editor-section .edit-row{align-items:center;gap:12px;margin-bottom:10px;display:flex}.editor-section .edit-row label{width:140px;color:var(--text-soft);flex-shrink:0;font-size:12px;font-weight:600}.editor-section .edit-row input,.editor-section .edit-row select{border:1px solid var(--border);border-radius:var(--radius);flex:1;padding:9px 12px;font-family:inherit;font-size:13px}.qedit-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:12px;padding:18px;position:relative}.qedit-card.collapsed .qedit-body{display:none}.qedit-head{cursor:pointer;justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.qedit-num{background:var(--bg);color:#fff;border-radius:4px;padding:3px 8px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600}.qedit-controls{gap:4px;display:flex}.qedit-fields{flex-direction:column;gap:8px;display:flex}.qedit-fields input,.qedit-fields select{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:8px 11px;font-family:inherit;font-size:13px}.qedit-options{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.qedit-option-wrap{align-items:center;gap:6px;display:flex}.qedit-option-wrap .letter{background:var(--surface-3);border-radius:4px;flex-shrink:0;padding:5px 8px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700}.qedit-correct{border-top:1px dashed var(--border);align-items:center;gap:8px;margin-top:4px;padding-top:8px;display:flex}.qedit-correct label{color:var(--text-soft);font-size:12px;font-weight:600}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f1419b3;justify-content:center;align-items:center;padding:20px;display:none;position:fixed;inset:0}.modal-overlay.active{display:flex}.login-modal{border:1px solid var(--border);box-shadow:0 24px 64px #40408840,0 0 0 1px #ffffff0a;background:var(--surface)!important}.login-close-btn{color:#fff9;cursor:pointer;z-index:2;background:#ffffff14;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:22px;line-height:1;transition:all .15s;display:flex;position:absolute;top:14px;right:14px}.login-close-btn:hover{color:#fff;background:#ffffff29;transform:rotate(90deg)}.login-header{text-align:center;color:#fff;background:linear-gradient(135deg,#404088 0%,#5a5ab8 100%);padding:36px 32px 28px;position:relative}.login-header:after{content:"";pointer-events:none;background:radial-gradient(circle at 30% 40%,#ffffff14,#0000 60%);position:absolute;inset:0}.login-logo{color:#fff;z-index:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff26;border:2px solid #ffffff40;border-radius:18px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 14px;display:flex;position:relative}.login-title{letter-spacing:-.02em;z-index:1;margin:0 0 6px;font-family:Inter Tight,sans-serif;font-size:22px;font-weight:800;position:relative}.login-subtitle{opacity:.85;z-index:1;margin:0;font-size:13px;position:relative}.login-body{padding:28px 32px 32px}.login-field{margin-bottom:16px}.login-label{color:var(--text-soft);letter-spacing:.02em;text-transform:uppercase;margin-bottom:7px;font-size:12px;font-weight:700;display:block}.login-input{background:var(--surface-2);border:1.5px solid var(--border);width:100%;color:var(--text);border-radius:10px;outline:none;padding:13px 14px;font-family:Inter Tight,sans-serif;font-size:14px;transition:all .2s}.login-input:focus{background:var(--surface);border-color:#404088;box-shadow:0 0 0 4px #4040881f}.login-input::placeholder{color:var(--text-muted)}.login-pwd-wrap{position:relative}.login-pwd-wrap .login-input{padding-right:44px}.login-pwd-toggle{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:8px;transition:all .15s;display:flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.login-pwd-toggle:hover{background:var(--surface-2);color:var(--text)}.login-error{color:#dc2626;text-align:center;background:#dc262614;border:1px solid #dc262640;border-radius:8px;margin-bottom:14px;padding:10px 14px;font-size:13px;font-weight:600;animation:.4s shakeLogin}@keyframes shakeLogin{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.login-submit{color:#fff;cursor:pointer;letter-spacing:.02em;background:linear-gradient(135deg,#404088 0%,#5a5ab8 100%);border:none;border-radius:10px;width:100%;margin-top:6px;padding:14px;font-family:Inter Tight,sans-serif;font-size:15px;font-weight:700;transition:all .2s;box-shadow:0 4px 14px #40408840}.login-submit:hover{background:linear-gradient(135deg,#4a4a96 0%,#6a6ac8 100%);transform:translateY(-1px);box-shadow:0 8px 20px #40408859}.login-submit:active{transform:translateY(0);box-shadow:0 2px 8px #40408833}.login-hint{text-align:center;color:var(--text-muted);opacity:.7;margin:18px 0 0;font-size:11px}@media (max-width:480px){.login-modal{max-width:92vw!important}.login-header{padding:28px 24px 22px}.login-body{padding:22px 24px 26px}.login-logo{width:56px;height:56px}.login-title{font-size:20px}}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:520px;max-height:90vh;box-shadow:var(--shadow-lg);border:1px solid #e2e8f0eb;flex-direction:column;animation:.2s ease-out modalIn;display:flex;overflow:hidden}@keyframes modalIn{0%{opacity:0;transform:scale(.96)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-head{border-bottom:1px solid var(--border);background:linear-gradient(#fff 0%,#f8fafc 100%);flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-title{font-size:16px;font-weight:700}.modal-close{background:var(--surface-2);cursor:pointer;width:34px;height:34px;color:var(--text-muted);border:none;border-radius:999px;font-size:18px}.modal-close:hover{background:var(--surface-2);color:var(--text)}.modal-body{flex:1;min-height:0;padding:24px;overflow-y:auto}.modal-foot{border-top:1px solid var(--border);background:#f8fafc;flex-shrink:0;justify-content:flex-end;gap:8px;padding:16px 24px;display:flex}.toast-stack{top:calc(18px + env(safe-area-inset-top,0px));z-index:200;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;right:18px}.toast{color:var(--text);pointer-events:all;border:1px solid var(--border);border-left:5px solid var(--accent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffffff5;border-radius:18px;align-items:center;gap:10px;max-width:360px;padding:13px 16px;font-size:13px;font-weight:650;animation:.3s ease-out toastIn;display:flex;box-shadow:0 18px 38px #0f172a29}.toast.success{border-left-color:var(--success);color:#065f46;background:#f0fdf4}.toast.error{border-left-color:var(--danger);color:#7f1d1d;background:#fef2f2}.toast.warn{border-left-color:var(--warn);color:#713f12;background:#fffbeb}@keyframes toastIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.toast.removing{animation:.2s forwards toastOut}@keyframes toastOut{to{opacity:0;transform:translate(20px)}}.cert-preview{border:8px double var(--accent);text-align:center;background:#fff;max-width:600px;margin:16px auto;padding:32px;font-family:Inter Tight,serif;position:relative}.cert-preview:before{content:"";border:1px solid var(--accent);pointer-events:none;position:absolute;inset:4px}.cert-preview .cert-eyebrow{letter-spacing:.3em;color:var(--text-muted);margin-bottom:6px;font-size:11px}.cert-preview .cert-title{letter-spacing:-.02em;color:var(--bg);margin-bottom:14px;font-size:26px;font-weight:800}.cert-preview .cert-recipient{color:var(--accent);border-bottom:1px solid var(--border);margin:18px 0 8px;padding:0 30px 6px;font-size:22px;font-weight:700;display:inline-block}.cert-preview .cert-text{color:var(--text-soft);margin:12px 0;font-size:14px}.login-box{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);max-width:460px;padding:24px}.login-box .field input{letter-spacing:.05em;text-align:center;padding:14px;font-family:JetBrains Mono,monospace;font-size:18px}.emp-found{background:var(--success-soft);border:1px solid var(--success);border-radius:var(--radius);align-items:center;gap:14px;margin-top:14px;padding:14px 16px;display:flex}.emp-avatar{background:var(--success);color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:44px;height:44px;font-size:16px;font-weight:700;display:grid}.emp-found-body{flex:1}.emp-found-name{color:var(--text);font-size:15px;font-weight:700}.emp-found-meta{color:var(--text-soft);margin-top:2px;font-size:12px}.emp-not-found{background:var(--danger-soft);border:1px solid var(--danger);border-radius:var(--radius);color:#7f1d1d;margin-top:14px;padding:14px 16px;font-size:13px}.already-done{background:var(--warn-soft);border:1px solid var(--warn);border-radius:var(--radius);margin-top:14px;padding:16px}.already-done strong{color:var(--text);font-size:14px}.already-done p{color:var(--text-soft);margin-top:4px;font-size:13px}.already-done .ad-cert{background:var(--surface);border-radius:4px;margin-top:10px;padding:8px 10px;font-family:JetBrains Mono,monospace;font-size:11px;display:inline-block}@media (max-width:720px){.app-shell{border:none;overflow-x:hidden}.app-header{flex-wrap:wrap;gap:12px;padding:16px 20px}.header-meta{justify-content:space-between;width:100%}.step{padding:24px 20px}.admin-shell{max-width:100%;padding:20px 14px;overflow-x:hidden}.step-title{font-size:22px}.form-grid{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}.stepper{grid-template-columns:repeat(5,1fr)}.step-tab{padding:10px 4px}.step-label{display:none}.step-num{margin-right:0}.qedit-options{grid-template-columns:1fr}.data-table{font-size:12px}.data-table thead th,.data-table tbody td{padding:8px 6px}.project-table{font-size:12px}.project-table th,.project-table td{padding:8px}.summary-row{grid-template-columns:1fr;gap:2px;padding:10px 14px}.editor-section .edit-row{flex-direction:column;align-items:stretch;gap:6px}.editor-section .edit-row label{width:auto}.toast-stack{top:12px;left:12px;right:12px}.toast{max-width:none}}@media print{body *{visibility:hidden}#printArea,#printArea *{visibility:visible}#printArea{width:100%;position:absolute;top:0;left:0}}.clock-display{text-align:center;background:linear-gradient(135deg, var(--accent) 0%, var(--accent-bright) 100%);border-radius:var(--radius-lg);color:#fff;margin:24px 0;padding:24px}.clock-time{font-variant-numeric:tabular-nums;letter-spacing:-.02em;font-family:JetBrains Mono,monospace;font-size:48px;font-weight:700}.clock-date{opacity:.9;margin-top:4px;font-size:14px}.att-emp-card{background:var(--surface-2);border-radius:var(--radius);align-items:center;gap:12px;margin-bottom:16px;padding:14px 16px;display:flex}.att-emp-avatar{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:44px;height:44px;font-size:18px;font-weight:700;display:grid}.att-emp-info{flex:1;min-width:0}.att-emp-name{font-size:15px;font-weight:600}.att-emp-meta{color:var(--text-muted);margin-top:2px;font-size:12px}.gps-status{background:var(--info-soft);border:1px solid var(--info);border-radius:var(--radius);align-items:center;gap:12px;margin-bottom:12px;padding:14px 16px;display:flex}.gps-status.success{background:var(--success-soft);border-color:var(--success)}.gps-status.error{background:var(--danger-soft);border-color:var(--danger)}.gps-spinner{border:2.5px solid var(--info);border-top-color:#0000;border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.8s linear infinite spin}.gps-status.success .gps-spinner,.gps-status.error .gps-spinner{display:none}.gps-text{font-size:13px;font-weight:500}@keyframes spin{to{transform:rotate(360deg)}}.project-info{background:var(--surface-2);border-radius:var(--radius);margin-bottom:16px;padding:14px 16px;font-size:13px}.project-row{justify-content:space-between;padding:4px 0;display:flex}.project-label{color:var(--text-muted)}.project-value{font-family:JetBrains Mono,monospace;font-size:12px;font-weight:600}.att-warning-box{background:var(--warn-soft);border-left:4px solid var(--warn);border-radius:var(--radius);margin-bottom:16px;padding:12px 16px;font-size:13px}.att-warning-box strong{color:var(--warn);margin-bottom:4px;display:block}.att-warning-box p{color:var(--text-soft)}.att-info-box{background:var(--success-soft);border-left:4px solid var(--success);border-radius:var(--radius);margin-bottom:16px;padding:12px 16px;font-size:13px}.att-info-box strong{color:var(--success);margin-bottom:4px;display:block}.att-actions{flex-direction:column;gap:10px;margin-top:8px;display:flex}.btn-clock-in,.btn-clock-out{border-radius:var(--radius-lg);cursor:pointer;color:#fff;border:none;justify-content:center;align-items:center;gap:12px;width:100%;padding:18px;font-family:inherit;font-size:17px;font-weight:700;transition:transform .1s,box-shadow .2s;display:flex}.btn-clock-in{background:linear-gradient(135deg, var(--success) 0%, #16a34a 100%);box-shadow:0 4px 14px #15803d4d}.btn-clock-in:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #15803d66}.btn-clock-in:disabled{background:var(--surface-3);color:var(--text-muted);cursor:not-allowed;box-shadow:none}.btn-clock-out{background:linear-gradient(135deg, var(--danger) 0%, #dc2626 100%);box-shadow:0 4px 14px #b91c1c4d}.btn-clock-out:hover{transform:translateY(-1px);box-shadow:0 6px 20px #b91c1c66}.btn-att-secondary{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius);cursor:pointer;width:100%;color:var(--text-soft);padding:12px;font-family:inherit;font-size:13px}.btn-att-secondary:hover{background:var(--surface-2)}.btn-icon{font-size:22px}.map-container{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface-2);z-index:1;width:100%;max-width:100%;height:220px;margin-bottom:16px;position:relative;overflow:hidden}.map-container.admin-map{height:480px}.leaflet-container{z-index:1;font-family:Inter Tight,sans-serif!important}.leaflet-pane,.leaflet-tile-pane,.leaflet-overlay-pane,.leaflet-shadow-pane,.leaflet-marker-pane,.leaflet-tooltip-pane,.leaflet-popup-pane{z-index:1!important}.leaflet-control{z-index:2!important}.modal-overlay{z-index:9000}.modal{z-index:9001}.map-toolbar{background:var(--surface-2);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;padding:10px;font-size:12px;display:flex}.map-toolbar .hint{color:var(--text-muted);flex:1}.project-table{border-collapse:collapse;width:100%;margin-top:16px;font-size:13px}.project-table th{background:var(--surface-2);text-align:left;color:var(--text-muted);text-transform:uppercase;border-bottom:1px solid var(--border);padding:10px 12px;font-size:12px;font-weight:600}.project-table td{border-bottom:1px solid var(--border);padding:12px}.project-table tr:hover td{background:var(--surface-2)}.project-color-dot{vertical-align:middle;border-radius:50%;width:14px;height:14px;margin-right:8px;display:inline-block}.coord-display{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:11px}.radius-slider{width:100%;margin:8px 0}.radius-value{background:var(--accent-soft);color:var(--accent-strong);border-radius:6px;padding:4px 10px;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:600;display:inline-block}.leaflet-popup-content{margin:10px 12px;font-size:12px}.leaflet-popup-content b{margin-bottom:4px;font-size:13px;display:block}.you-marker{background:var(--accent);border:3px solid #fff;border-radius:50%;animation:2s infinite pulse-marker;box-shadow:0 2px 8px #0000004d}@keyframes pulse-marker{0%,to{box-shadow:0 0 #40408899}50%{box-shadow:0 0 0 12px #40408800}}.btn-remote-request{background:var(--warn);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;width:100%;margin-top:12px;padding:12px;font-family:inherit;font-size:13px;font-weight:600;display:block}.btn-remote-request:hover{opacity:.9}.rr-step.active{background:var(--accent);color:#fff}.rr-step.done{background:var(--success);color:#fff}.pending-badge{background:var(--danger);color:#fff;text-align:center;border-radius:10px;min-width:20px;margin-left:4px;padding:1px 8px;font-size:10px;font-weight:700;display:inline-block}.rr-filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}@media (max-width:720px){.rr-card{grid-template-columns:1fr}}#splashScreen{z-index:999999;background:linear-gradient(135deg,#fff 0%,#f0f4ff 50%,#e0e7ff 100%);justify-content:center;align-items:center;animation:.5s ease-in-out 2.5s forwards splashFadeOut;display:flex;position:fixed;inset:0;overflow:hidden}.splash-particle{background:radial-gradient(circle,#6366f140 0%,#6366f100 70%);border-radius:50%;animation:6s ease-in-out infinite splashFloat;position:absolute}.splash-particle.p1{width:280px;height:280px;animation-delay:0s;top:10%;left:5%}.splash-particle.p2{width:200px;height:200px;animation-delay:1.5s;bottom:15%;right:8%}.splash-particle.p3{width:160px;height:160px;animation-delay:3s;top:40%;right:20%}.splash-particle.p4{width:240px;height:240px;animation-delay:.8s;bottom:30%;left:25%}.splash-particle.p5{width:120px;height:120px;animation-delay:2.2s;top:65%;left:60%}@keyframes splashFloat{0%,to{opacity:.4;transform:translate(0)scale(1)}50%{opacity:.2;transform:translate(30px,-40px)scale(1.2)}}.splash-content{text-align:center;z-index:2;position:relative}.splash-glow{background:radial-gradient(circle,#6366f159 0%,#6366f100 60%);border-radius:50%;width:280px;height:280px;animation:2s ease-in-out infinite splashGlow;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes splashGlow{0%,to{opacity:.4;transform:translate(-50%,-50%)scale(1)}50%{opacity:.7;transform:translate(-50%,-50%)scale(1.1)}}.splash-logo-wrap{justify-content:center;align-items:center;width:140px;height:140px;margin:0 auto 24px;display:flex;position:relative}.splash-logo-ring{border:3px solid #6464c8;border-color:#6464c8 #6464c8 #0000 #0000;border-radius:50%;animation:1.5s linear infinite splashRingSpin;position:absolute;inset:0}.splash-logo-ring.ring2{border-color:#0000 #0000 #6366f180 #6366f180;animation:2s linear infinite reverse splashRingSpin;inset:-10px}@keyframes splashRingSpin{to{transform:rotate(360deg)}}.splash-logo{object-fit:contain;filter:drop-shadow(0 8px 24px #6366f166);opacity:0;width:100px;height:100px;animation:1s cubic-bezier(.34,1.56,.64,1) forwards splashLogoEnter,2s ease-in-out 1s infinite splashLogoPulse;transform:scale(.3)}@keyframes splashLogoEnter{0%{opacity:0;transform:scale(.3)rotate(-180deg)}to{opacity:1;transform:scale(1)rotate(0)}}@keyframes splashLogoPulse{0%,to{transform:scale(1)rotate(0)}50%{transform:scale(1.05)rotate(0)}}.splash-text{opacity:0;margin-bottom:32px;animation:.8s .5s forwards splashTextEnter;transform:translateY(10px)}@keyframes splashTextEnter{to{opacity:1;transform:translateY(0)}}.splash-title{color:#1a1a2e;letter-spacing:4px;text-shadow:0 4px 20px #6366f14d;margin-bottom:6px;font-family:Inter Tight,sans-serif;font-size:28px;font-weight:800}.splash-sub{color:#5a5a8a;letter-spacing:2px;font-family:Inter Tight,sans-serif;font-size:11px;font-weight:600}.splash-loading{opacity:0;background:#6366f126;border-radius:2px;width:180px;height:3px;margin:0 auto;animation:.5s .8s forwards splashLoadingEnter;overflow:hidden}@keyframes splashLoadingEnter{to{opacity:1}}.splash-loading-bar{background:linear-gradient(90deg,#0000,#6464c8,#0000);border-radius:2px;width:30%;height:100%;animation:1.5s ease-in-out infinite splashLoadingSlide}@keyframes splashLoadingSlide{0%{width:30%;transform:translate(-100%)}50%{width:50%}to{width:30%;transform:translate(380%)}}.splash-footer{color:#7878a8;letter-spacing:1px;opacity:0;margin-top:12px;font-family:Inter Tight,sans-serif;font-size:11px;animation:.5s 1s forwards splashTextEnter}@keyframes splashFadeOut{to{opacity:0;visibility:hidden;pointer-events:none}}@media (max-width:480px){.splash-title{letter-spacing:3px;font-size:22px}.splash-sub{font-size:10px}.splash-logo-wrap{width:120px;height:120px}.splash-logo{width:80px;height:80px}}.mobile-screen{animation:.3s screenFadeIn}@keyframes screenFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.admin-pane[style*="display: block"]{animation:.25s paneFadeIn}@keyframes paneFadeIn{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}.btn,.admin-tab,.home-action-card,.auth-btn{position:relative;overflow:hidden}.btn:after,.admin-tab:after,.home-action-card:after,.auth-btn:after{content:"";pointer-events:none;opacity:0;background:#ffffff80;border-radius:50%;width:0;height:0;transition:width .4s ease-out,height .4s ease-out,opacity .4s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.btn:active:after,.admin-tab:active:after,.home-action-card:active:after,.auth-btn:active:after{opacity:0;width:300px;height:300px;transition:width,height}.skeleton{background:linear-gradient(90deg, var(--surface-2) 25%, var(--surface-3) 50%, var(--surface-2) 75%);background-size:200% 100%;border-radius:8px;animation:1.4s infinite skeletonShimmer}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.request-fab-btn{bottom:calc(80px + env(safe-area-inset-bottom,0px));color:#1c1917;cursor:pointer;z-index:998;background:linear-gradient(135deg,#facc15 0%,#eab308 100%);border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:24px;transition:all .2s;display:flex;position:fixed;right:20px;box-shadow:0 8px 24px #eab30873,0 2px 6px #eab30833}body.employee-mode .request-fab-btn{display:none!important}.request-fab-btn:hover{transform:translateY(-2px);box-shadow:0 12px 32px #eab3088c}.request-fab-btn:active{transform:translateY(0)}.req-modal-overlay{z-index:99998;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f172a85;justify-content:center;align-items:flex-end;display:none;position:fixed;inset:0}.req-modal-overlay.show{display:flex}.req-modal{background:var(--surface);width:100%;max-width:540px;max-height:92vh;padding-bottom:env(safe-area-inset-bottom,0px);border:1px solid #e2e8f0e6;border-radius:30px 30px 0 0;flex-direction:column;animation:.3s slideUpReq;display:flex;overflow:hidden;box-shadow:0 -24px 70px #0f172a38}@keyframes slideUpReq{0%{transform:translateY(100%)}to{transform:translateY(0)}}.req-modal-handle{background:#cbd5e1;border-radius:2px;flex-shrink:0;width:48px;height:4px;margin:12px auto 8px}.req-modal-header{border-bottom:1px solid var(--border);background:linear-gradient(#fff 0%,#f8fafc 100%);flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 20px 16px;display:flex}.req-modal-title{color:var(--text);font-size:18px;font-weight:700}.req-modal-close{background:var(--surface-2);cursor:pointer;width:36px;height:36px;color:var(--text-soft);box-shadow:inset 0 0 0 1px var(--border);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:18px;display:flex}.req-modal-body{flex:1;padding:18px 20px 22px;overflow-y:auto}.req-modal-tabs{background:#f1f5f9;border-radius:18px;margin-bottom:16px;padding:4px;display:flex}.req-tab{color:var(--text-soft);cursor:pointer;background:0 0;border:none;border-radius:14px;flex:1;padding:10px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s}.req-tab.active{background:var(--surface);color:var(--accent);box-shadow:0 8px 18px #0f172a14}.req-type-group{margin-bottom:16px}.req-type-group-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding:0 4px;font-size:12px}.req-type-item{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:18px;align-items:center;gap:12px;margin-bottom:8px;padding:14px 16px;transition:all .15s;display:flex}.req-type-item:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-1px);box-shadow:0 12px 28px #1e3a8a1f}.req-type-icon{background:var(--accent-soft);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.req-type-name{color:var(--text);font-weight:600}.req-card{border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#fff;border-radius:20px;margin-bottom:10px;padding:14px}.req-card-head{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.req-card-type{color:var(--text);align-items:center;gap:8px;font-weight:600;display:flex}.req-card-status{text-transform:uppercase;border-radius:12px;padding:3px 10px;font-size:11px;font-weight:700}.req-status-pending{color:#a16207;background:#eab30826}.req-status-approved{background:var(--success-soft);color:var(--success)}.req-status-rejected{color:#b91c1c;background:#ef444426}.req-card-body{color:var(--text-soft);font-size:13px;line-height:1.5}.req-card-date{color:var(--text-muted);margin-top:6px;font-size:11px}.req-form-field{margin-bottom:14px}.req-form-field label{color:var(--text);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.req-form-field input,.req-form-field textarea,.req-form-field select{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);border-radius:16px;padding:12px;font-family:inherit;font-size:14px}.req-form-field input:focus,.req-form-field textarea:focus,.req-form-field select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 4px #2563eb1f}.req-form-field textarea{resize:vertical;min-height:80px}.req-clock-type-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.req-clock-type-btn{background:var(--surface);border:2px solid var(--border);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:14px;flex-direction:column;align-items:center;gap:4px;padding:14px 12px;font-family:inherit;transition:all .2s;display:flex}.req-clock-type-btn:hover{border-color:var(--accent);transform:translateY(-1px)}.req-clock-type-btn.selected{background:var(--accent-soft);border-color:var(--accent);box-shadow:0 4px 12px -2px #40408833}.req-clock-type-btn[data-clock-type=in].selected{background:#16a34a1a;border-color:#16a34a;box-shadow:0 4px 12px -2px #16a34a4d}.req-clock-type-btn[data-clock-type=out].selected{background:#6366f11a;border-color:#6366f1;box-shadow:0 4px 12px -2px #6366f14d}.req-clock-icon{font-size:22px;font-weight:800;line-height:1}.req-clock-type-btn[data-clock-type=in] .req-clock-icon{color:#16a34a}.req-clock-type-btn[data-clock-type=out] .req-clock-icon{color:#6366f1}.req-clock-label{color:var(--text);font-family:Sora,Inter Tight,sans-serif;font-size:15px;font-weight:700}.req-clock-sub{color:var(--text-muted);font-family:DM Sans,sans-serif;font-size:11px}.req-submit-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#1e3a8a 0%,#2563eb 100%);border:none;border-radius:18px;width:100%;margin-top:8px;padding:15px;font-family:inherit;font-size:15px;font-weight:700;box-shadow:0 16px 30px #1e3a8a3d}.req-submit-btn:disabled{opacity:.5;cursor:not-allowed}.lesson-fab-btn{color:#fff;cursor:pointer;z-index:9999;white-space:nowrap;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);border:none;border-radius:18px;align-items:center;gap:12px;padding:18px 28px;font-family:inherit;font-size:16px;font-weight:700;transition:all .2s;animation:2s ease-in-out infinite lessonFabPulse;display:flex;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 12px 32px #f59e0b80,0 0 0 4px #f59e0b26}.lesson-fab-icon{font-size:24px;line-height:1}.lesson-fab-label{letter-spacing:.2px;font-weight:700}.lesson-fab-badge{color:#fff;background:#dc2626;border:3px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:14px;font-weight:800;animation:1.2s ease-in-out infinite lessonFabBadgePulse;display:flex;position:absolute;top:-8px;right:-8px;box-shadow:0 2px 8px #dc262680}@keyframes lessonFabPulse{0%,to{transform:translate(-50%,-50%)scale(1);box-shadow:0 12px 32px #f59e0b80,0 0 0 4px #f59e0b26}50%{transform:translate(-50%,-50%)scale(1.03);box-shadow:0 16px 40px #f59e0ba6,0 0 0 12px #f59e0b1a}}@keyframes lessonFabBadgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.lesson-fab-btn:hover{transform:translate(-50%,-50%)scale(1.05)}.lesson-fab-btn:active{transform:translate(-50%,-50%)scale(.97)}@media (max-width:500px){.lesson-fab-btn{border-radius:16px;padding:16px 22px;font-size:15px}.lesson-fab-icon{font-size:22px}}.safety-fab-btn{bottom:calc(150px + env(safe-area-inset-bottom,0px));color:#fff;cursor:pointer;z-index:998;background:linear-gradient(135deg,#dc2626 0%,#991b1b 100%);border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:26px;transition:all .2s;animation:2.5s ease-in-out infinite safetyPulse;display:flex;position:fixed;right:20px;box-shadow:0 8px 24px #dc262673}@keyframes safetyPulse{0%,to{box-shadow:0 8px 24px #dc262673}50%{box-shadow:0 8px 32px #dc2626a6,0 0 0 8px #dc26261a}}.safety-fab-btn:hover{transform:translateY(-3px)scale(1.05)}.safety-fab-btn:active{transform:scale(.95)}@media (max-width:500px){.safety-fab-btn{width:52px;height:52px;bottom:calc(140px + env(safe-area-inset-bottom,0px));font-size:22px}}.hazard-type-option{background:var(--surface-2);border:2px solid var(--border);cursor:pointer;border-radius:10px;align-items:center;gap:8px;padding:10px;font-size:12px;font-weight:600;transition:all .15s;display:flex}.hazard-type-option:hover{background:#dc26260d;border-color:#dc2626}.hazard-type-option.selected{color:#991b1b;background:#dc26261a;border-color:#dc2626}.hazard-type-option>span{font-size:18px}.severity-option{text-align:center;cursor:pointer;border:2px solid;border-radius:10px;padding:8px;font-size:12px;font-weight:700;transition:all .15s}.severity-option.selected{transform:scale(1.05);box-shadow:0 4px 12px #00000026}.admin-fab-btn{color:#fff;cursor:pointer;z-index:998;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:24px;transition:all .2s;animation:.4s fabBounceIn;display:flex;position:fixed;right:20px}@keyframes fabBounceIn{0%{opacity:0;transform:scale(.5)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.admin-fab-broadcast{bottom:calc(150px + env(safe-area-inset-bottom,0px));background:linear-gradient(135deg,#3b82f6 0%,#1e40af 100%);box-shadow:0 8px 24px #3b82f666}.admin-fab-broadcast:hover{transform:translateY(-3px)scale(1.05);box-shadow:0 12px 28px #3b82f680}.admin-fab-ai{bottom:calc(220px + env(safe-area-inset-bottom,0px));background:linear-gradient(135deg,#6464c8 0%,#404088 100%);box-shadow:0 8px 24px #6464c866}.admin-fab-ai:hover{transform:translateY(-3px)scale(1.05);box-shadow:0 12px 28px #6464c880}.admin-fab-btn:active{transform:scale(.95)}@media (max-width:500px){.admin-fab-btn{width:52px;height:52px;font-size:22px}.admin-fab-broadcast{bottom:calc(140px + env(safe-area-inset-bottom,0px))}.admin-fab-ai{bottom:calc(204px + env(safe-area-inset-bottom,0px))}}.bottom-nav{background:var(--surface);border-top:1px solid var(--border);z-index:997;height:calc(64px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);box-sizing:border-box;display:none;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 16px #0000000d}.bottom-nav.show{display:flex}.bottom-nav-item{cursor:pointer;color:var(--text-muted);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:10px 4px 8px;font-family:inherit;font-size:11px;font-weight:600;transition:color .2s;display:flex;position:relative}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-icon{margin-bottom:4px;font-size:22px}.bottom-nav-badge{background:var(--danger);color:#fff;text-align:center;border-radius:10px;min-width:16px;margin-right:-22px;padding:2px 5px;font-size:9px;font-weight:700;position:absolute;top:4px;right:50%}.mobile-screen{max-width:540px;min-height:calc(100vh - 80px);margin:0 auto;padding:8px 16px 90px;display:none}.mobile-screen.active{display:block}body.has-bottom-nav #employeeView>.step,body.has-bottom-nav #employeeView>.stepper,body.has-bottom-nav .app-footer{display:none!important}body.has-bottom-nav #employeeView{display:contents;margin:0!important;padding:0!important}body.has-bottom-nav .app-shell{border:none;min-height:0!important;display:block!important}body.has-bottom-nav{min-height:0!important}body.has-bottom-nav .mobile-screen{margin-top:0!important}#screenHome{padding:0!important}#screenHome>:not(.home-map-wrap){margin-left:14px;margin-right:14px}.home-map-wrap{background:var(--surface-2);width:100%;height:58vh;min-height:380px;max-height:580px;margin-bottom:14px;position:relative;overflow:hidden}.home-map .leaflet-control-attribution{border-radius:6px;margin-bottom:4px;margin-right:4px;font-size:9px;background:#ffffffb3!important;padding:2px 6px!important}.home-map-header{z-index:500;-webkit-backdrop-filter:blur(20px);background:#fffffff5;border:1px solid #ffffffb3;border-radius:16px;align-items:center;gap:10px;padding:10px 14px 10px 10px;display:flex;position:absolute;top:14px;left:14px;right:14px;box-shadow:0 8px 24px -8px #0f14192e,0 2px 8px #0f14190f}.home-map-status-pill{z-index:500;-webkit-backdrop-filter:blur(16px);white-space:nowrap;background:#fffffff7;border:1px solid #ffffffb3;border-radius:100px;align-items:center;gap:8px;max-width:calc(100% - 28px);padding:9px 18px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;transition:all .3s;display:flex;position:absolute;top:78px;left:50%;transform:translate(-50%);box-shadow:0 6px 16px -4px #0f141926,0 2px 6px #0f14190f}@keyframes pillPulse{0%,to{opacity:1;transform:translate(-50%)scale(1)}50%{opacity:.7;transform:translate(-50%)scale(.98)}}.home-map-status-pill.checking{color:var(--text);animation:1.4s ease-in-out infinite pillPulse}.home-map-recenter{z-index:500;border:1px solid var(--border);width:44px;height:44px;color:var(--accent);cursor:pointer;background:#fff;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;bottom:100px;right:14px;box-shadow:0 6px 16px -4px #0f14192e,0 2px 6px #0f14190f}.home-map-recenter:hover{transform:translateY(-1px);box-shadow:0 8px 20px -4px #0f141938,0 4px 8px #0f141914}.home-map-recenter:active{transform:translateY(0)}.home-map-hero-btn-wrap{z-index:500;width:calc(100% - 28px);max-width:380px;position:absolute;bottom:28px;left:50%;transform:translate(-50%)}.home-map-hero-btn{cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;background:#fff;border:none;border-radius:100px;align-items:center;gap:14px;width:100%;padding:14px 20px 14px 16px;font-family:Sora,Inter Tight,sans-serif;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 12px 32px -8px #0f141938,0 4px 12px #0f14191a,inset 0 1px #fff9}html[data-theme=dark] .home-map-hero-btn{background:#1d2140}.home-map-hero-btn .hero-btn-icon{color:#fff;background:linear-gradient(135deg,#16a34a 0%,#15803d 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;padding:12px;display:flex;box-shadow:0 4px 12px -2px #16a34a66}.home-map-hero-btn-out .hero-btn-icon{background:linear-gradient(135deg,#f97316 0%,#ea580c 100%);box-shadow:0 4px 12px -2px #f9731666}.home-map-hero-btn .hero-btn-content{text-align:left;flex:1}.home-map-hero-btn .hero-btn-sub{color:var(--text-muted);margin-top:2px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:500}.home-map-hero-btn.out-of-range{opacity:.7;cursor:not-allowed}.home-map-hero-btn.out-of-range .hero-btn-icon{box-shadow:none!important;background:linear-gradient(135deg,#9ca3af 0%,#6b7280 100%)!important}.home-fab-btn-primary:active{transform:translateY(0)}.home-gps-marker-pulse:before{content:"";background:#f9731633;border-radius:50%;animation:2s ease-out infinite gpsMarkerPulse;position:absolute;inset:0}.home-gps-marker-pulse .pin{background:linear-gradient(135deg,#f97316 0%,#ea580c 100%);border:3px solid #fff;border-radius:50% 50% 50% 0;justify-content:center;align-items:center;width:36px;height:36px;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotate(-45deg);box-shadow:0 4px 10px #f9731666}.home-gps-marker-pulse .pin:after{content:"";background:#fff;border-radius:50%;width:14px;height:14px;transform:rotate(45deg)}@keyframes gpsMarkerPulse{0%{opacity:1;transform:translate(-50%,-50%)scale(.5)}to{opacity:0;transform:translate(-50%,-50%)scale(2.4)}}.home-action-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:16px;align-items:center;gap:14px;margin-bottom:10px;padding:14px 16px;transition:all .25s;display:flex}.home-action-desc{color:var(--text-muted);font-family:DM Sans,sans-serif;font-size:12px}.home-action-arrow{color:var(--text-muted);font-size:22px;font-weight:300}.home-section-title{color:var(--text);letter-spacing:.02em;text-transform:uppercase;justify-content:space-between;align-items:center;margin-bottom:12px;font-family:Sora,Inter Tight,sans-serif;font-size:13px;font-weight:700;display:flex}.home-greeting{color:#fff;letter-spacing:-.01em;background:radial-gradient(circle at 100% 0,#ffffff1f 0%,#0000 50%),radial-gradient(circle at 0 100%,#ffffff14 0%,#0000 50%),linear-gradient(135deg,#2d2d6d 0%,#404088 45%,#6464c8 100%);border-radius:24px;margin-bottom:18px;padding:28px 24px 26px;position:relative;overflow:hidden;box-shadow:0 20px 40px -12px #40408873,0 4px 12px #40408840,inset 0 1px #ffffff26}.home-greeting:before{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff14 0%,#0000 70%);border-radius:50%;width:250px;height:250px;position:absolute;top:-50%;right:-20%}.home-greeting:after{content:"";background:linear-gradient(90deg,#0000,#ffffff4d,#0000);height:1px;position:absolute;bottom:0;left:0;right:0}.home-greeting-time{letter-spacing:.12em;text-transform:uppercase;opacity:.85;margin-bottom:8px;font-family:Plus Jakarta Sans,Sora,system-ui,sans-serif;font-size:12px;font-weight:600}.home-greeting-name{letter-spacing:-.02em;margin-bottom:6px;font-family:Sora,Inter Tight,system-ui,sans-serif;font-size:28px;font-weight:700;line-height:1.15}.home-greeting-dept{opacity:.85;-webkit-backdrop-filter:blur(10px);background:#ffffff1f;border:1px solid #ffffff26;border-radius:20px;align-items:center;gap:8px;padding:6px 12px;font-family:DM Sans,system-ui,sans-serif;font-size:13px;font-weight:500;display:inline-flex}.home-stat-row{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:14px;display:grid}.home-stat-card{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:18px;padding:18px 16px;transition:all .25s;position:relative;overflow:hidden}.home-stat-card:before{content:"";background:linear-gradient(90deg, var(--accent) 0%, var(--accent-bright) 100%);opacity:.6;height:3px;position:absolute;top:0;left:0;right:0}.home-stat-card:hover{transform:translateY(-2px);box-shadow:0 12px 24px -8px #4040882e,0 2px 8px #40408814}.home-stat-icon{margin-bottom:8px;font-size:28px;line-height:1;display:inline-block}.home-stat-value{color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:-.02em;margin-bottom:4px;font-family:Sora,Inter Tight,system-ui,sans-serif;font-size:22px;font-weight:700}.home-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-family:DM Sans,system-ui,sans-serif;font-size:11px;font-weight:600}#homeTodayHoursCard{position:relative;color:#fff!important;background:radial-gradient(circle at 80% 0,#ffffff26 0%,#0000 50%),linear-gradient(135deg,#404088 0%,#5454a8 60%,#6464c8 100%)!important;border:none!important;border-radius:22px!important;margin-bottom:18px!important;padding:24px 22px!important;overflow:hidden!important;box-shadow:0 16px 32px -8px #40408866,0 4px 12px #40408833,inset 0 1px #ffffff26!important}#homeTodayHoursCard:before{content:"⏱";opacity:.07;pointer-events:none;font-size:80px;position:absolute;top:10px;right:12px}#homeTodayHoursCard>div:first-child{letter-spacing:.15em!important;text-transform:uppercase!important;opacity:.85!important;margin-bottom:8px!important;font-family:Plus Jakarta Sans,sans-serif!important;font-size:11px!important;font-weight:700!important}#homeTodayHours.home-sheet-value{font-size:14px!important;font-weight:700!important}#homeTodayHoursStatus{opacity:.9!important;margin-top:6px!important;font-family:DM Sans,sans-serif!important;font-size:12px!important;font-weight:500!important}.home-week-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;margin-bottom:14px;padding:18px;box-shadow:0 2px 8px #4040880a}.home-section-title{color:var(--text);letter-spacing:.02em;text-transform:uppercase;justify-content:space-between;align-items:center;margin-top:4px;margin-bottom:14px;font-family:Sora,Inter Tight,system-ui,sans-serif;font-size:13px;font-weight:700;display:flex}.home-section-title:before{content:"";background:linear-gradient(180deg, var(--accent), var(--accent-bright));vertical-align:middle;border-radius:2px;width:3px;height:14px;margin-right:8px;display:inline-block}.home-section-title>span:first-child{flex:1}.home-clock-card{background:var(--surface);border:1px solid var(--border);border-radius:22px;margin-bottom:14px;padding:22px;transition:all .3s;position:relative;overflow:hidden;box-shadow:0 10px 24px -12px #4040882e,0 2px 8px #4040880f}.home-clock-card:before{content:"";opacity:.9;background:linear-gradient(90deg,#16a34a 0%,#22c55e 50%,#16a34a 100%);height:4px;position:absolute;top:0;left:0;right:0}.home-clock-card.done:before{background:linear-gradient(90deg, var(--accent) 0%, var(--accent-bright) 50%, var(--accent) 100%)}.home-clock-status{align-items:center;gap:14px;margin-bottom:18px;padding-top:4px;display:flex}.home-clock-status-icon{color:#16a34a;background:linear-gradient(135deg,#16a34a26 0%,#22c55e14 100%);border:1px solid #16a34a33;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:24px;display:flex;box-shadow:0 4px 12px -4px #16a34a33}.home-clock-status-text{flex:1;min-width:0}.home-clock-status-title{color:var(--text);letter-spacing:-.01em;margin-bottom:4px;font-family:Sora,Inter Tight,sans-serif;font-size:16px;font-weight:700;line-height:1.2}.home-clock-status-desc{color:var(--text-muted);font-family:DM Sans,sans-serif;font-size:12px;line-height:1.4}.home-clock-card.done .home-clock-status-icon{background:linear-gradient(135deg, var(--accent-soft) 0%, #40408814 100%);color:var(--accent);border-color:#40408833;box-shadow:0 4px 12px -4px #40408833}.home-clock-buttons{gap:12px;display:flex}.home-clock-btn{color:#fff;cursor:pointer;letter-spacing:-.01em;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;border:none;border-radius:16px;flex:1;justify-content:center;align-items:center;gap:10px;padding:16px 18px;font-family:Sora,Inter Tight,sans-serif;font-size:15px;font-weight:700;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.home-clock-btn:after{content:"";pointer-events:none;background:linear-gradient(#ffffff26 0%,#0000 100%);height:50%;position:absolute;top:0;left:0;right:0}.home-clock-btn:hover:not(:disabled):not(.out-of-range){transform:translateY(-2px)}.home-clock-btn:active:not(:disabled):not(.out-of-range){transform:translateY(0)}.home-clock-btn:disabled{opacity:.5;cursor:not-allowed}.home-clock-btn-in{background:linear-gradient(135deg,#16a34a 0%,#15803d 100%);box-shadow:0 8px 16px -4px #16a34a66,0 2px 4px #16a34a33,inset 0 1px #ffffff26}.home-clock-btn-in:hover:not(:disabled):not(.out-of-range){box-shadow:0 12px 20px -4px #16a34a80,0 4px 8px #16a34a40,inset 0 1px #fff3}.home-clock-btn-out{background:linear-gradient(135deg,#6366f1 0%,#4338ca 100%);box-shadow:0 8px 16px -4px #6366f166,0 2px 4px #6366f133,inset 0 1px #ffffff26}.home-clock-btn-out:hover:not(:disabled):not(.out-of-range){box-shadow:0 12px 20px -4px #6366f180,0 4px 8px #6366f140,inset 0 1px #fff3}.home-clock-btn.out-of-range{opacity:.7;cursor:not-allowed!important;background:linear-gradient(135deg,#9ca3af 0%,#6b7280 100%)!important;box-shadow:0 2px 4px #0000000d!important}.home-clock-btn.out-of-range:after{opacity:.3}.home-clock-gps-status{letter-spacing:.01em;border-radius:12px;justify-content:center;align-items:center;gap:8px;margin-top:14px;padding:12px 14px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;transition:all .3s;display:flex}.home-clock-gps-status.in-range{color:#16a34a;background:linear-gradient(135deg,#16a34a14 0%,#16a34a0a 100%);border:1px solid #16a34a33}.home-clock-gps-status.out-of-range{color:#d97706;background:linear-gradient(135deg,#f59e0b14 0%,#f59e0b0a 100%);border:1px solid #f59e0b33}.home-clock-gps-status.checking{color:#6366f1;background:linear-gradient(135deg,#6366f114 0%,#6366f10a 100%);border:1px solid #6366f133}.home-clock-gps-status.error{color:#dc2626;background:linear-gradient(135deg,#dc262614 0%,#dc26260a 100%);border:1px solid #dc262633}@keyframes gpsBlink{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.home-clock-gps-status.checking .gps-dot{animation:1s ease-in-out infinite gpsBlink}.home-clock-btn-icon{font-size:22px;font-weight:800;line-height:1}.home-action-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:16px;align-items:center;gap:14px;margin-bottom:10px;padding:14px 16px;transition:all .25s;display:flex;position:relative}.home-action-card:hover{border-color:#40408826;transform:translateY(-1px);box-shadow:0 8px 20px -8px #40408826,0 2px 6px #4040880d}.home-action-card:active{transform:translateY(0)}.home-action-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:22px;display:flex}.home-action-content{flex:1;min-width:0}.home-action-title{color:var(--text);letter-spacing:-.01em;margin-bottom:2px;font-family:Sora,Inter Tight,sans-serif;font-size:14px;font-weight:600}.home-action-desc{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-family:DM Sans,sans-serif;font-size:12px;line-height:1.4;overflow:hidden}.home-action-arrow{color:var(--text-muted);margin-left:4px;font-size:22px;font-weight:300;transition:transform .2s}.home-action-card:hover .home-action-arrow{color:var(--accent);transform:translate(2px)}body.has-bottom-nav{padding-bottom:70px}.home-week-row{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.home-week-day{flex-direction:column;align-items:center;gap:6px;display:flex}.home-week-label{color:var(--text-muted);text-transform:uppercase;font-size:10px;font-weight:600}.home-week-circle{border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.home-week-circle.present{background:var(--success);color:#fff}.home-week-circle.absent{background:var(--surface-3);color:var(--text-muted)}.home-week-circle.today{background:var(--accent);color:#fff;box-shadow:0 0 0 3px var(--accent-soft)}.home-week-circle.weekend{background:var(--surface-2);color:var(--text-muted)}#screenHome.mobile-screen{width:100%!important;max-width:none!important;min-height:0!important;margin:0!important;padding:0!important}#screenHome.mobile-screen.active{z-index:100;pointer-events:none;width:100vw;height:100dvh;inset:0;overflow:hidden;position:fixed!important}#screenHome.mobile-screen.active>*{pointer-events:auto}#screenHome>:not(.home-map-wrap):not(.home-bottom-sheet){margin-left:14px;margin-right:14px}html.screen-home-active,body.screen-home-active{width:100%!important;max-width:none!important;height:100%!important;margin:0!important;padding:0!important;overflow:hidden!important}body.employee-mode.has-bottom-nav.screen-home-active .app-shell{border:none;max-width:100%;margin:0;overflow:visible}body.employee-mode.screen-home-active{overflow:hidden;padding-top:0!important;padding-left:0!important;padding-right:0!important}.home-map-wrap{z-index:1;background:#c5e8ce;width:100%;height:100%;margin:0;padding:0;position:absolute;inset:0;overflow:hidden}.home-map{z-index:1;width:100%;height:100%;position:absolute;inset:0}.home-map .leaflet-control-attribution{border-radius:6px;font-size:9px;background:#ffffffb3!important;padding:2px 6px!important}.home-map .leaflet-control-zoom{display:none!important}.home-map-header{top:calc(env(safe-area-inset-top,0px) + 14px);z-index:500;-webkit-backdrop-filter:blur(20px);background:#fffffff5;border:1px solid #ffffffb3;border-radius:16px;align-items:center;gap:10px;padding:10px 14px 10px 10px;display:flex;position:absolute;left:14px;right:14px;box-shadow:0 8px 24px -8px #0f14192e,0 2px 8px #0f14190f}html[data-theme=dark] .home-map-header{background:#16192eeb;border-color:#ffffff14}.home-map-logo{border-radius:12px;flex-shrink:0;width:44px;height:44px;overflow:hidden;box-shadow:0 4px 10px #40408840}.home-map-logo img{object-fit:cover;width:100%;height:100%;display:block}.home-map-avatar{color:#fff;background:linear-gradient(135deg,#404088 0%,#6464c8 100%);border:2px solid #fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-family:Sora,Inter Tight,sans-serif;font-size:18px;font-weight:700;display:flex;overflow:hidden;box-shadow:0 4px 10px #4040884d}html[data-theme=dark] .home-map-avatar{border-color:#1d2140}.home-map-avatar img{object-fit:cover;width:100%;height:100%;display:block}.home-map-company{flex:1;min-width:0}.home-map-company-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.01em;font-family:Sora,Inter Tight,sans-serif;font-size:14px;font-weight:700;line-height:1.2;overflow:hidden}.home-map-company-sub{color:var(--text-soft);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:500;overflow:hidden}.home-map-status-pill{top:calc(env(safe-area-inset-top,0px) + 80px);z-index:500;-webkit-backdrop-filter:blur(16px);white-space:nowrap;text-overflow:ellipsis;max-width:calc(100% - 90px);color:var(--text);pointer-events:none;background:#fffffff7;border:1px solid #ffffffb3;border-radius:100px;align-items:center;gap:6px;padding:8px 14px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;transition:all .3s;display:inline-flex;position:absolute;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 6px 16px -4px #0f141926,0 2px 6px #0f14190f}html[data-theme=dark] .home-map-status-pill{background:#16192eeb;border-color:#ffffff14}.home-map-status-pill.in-range{color:#fff;background:#22c55ef5;border-color:#22c55e;box-shadow:0 6px 18px -4px #22c55e80}.home-map-status-pill.out-of-range{color:#fff;background:#fb923cf5;border-color:#fb923c;box-shadow:0 6px 18px -4px #fb923c80}.home-map-status-pill.error{color:#fff;background:#dc2626f5;border-color:#dc2626}.home-map-status-pill.checking{animation:1.4s ease-in-out infinite pillPulse}.home-map-recenter{top:calc(env(safe-area-inset-top,0px) + 80px);z-index:500;border:1px solid var(--border);width:44px;height:44px;color:var(--accent);cursor:pointer;background:#fff;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;right:14px;box-shadow:0 6px 16px -4px #0f14192e,0 2px 6px #0f14190f}html[data-theme=dark] .home-map-recenter{color:var(--accent-bright);background:#1d2140;border-color:#ffffff14}.home-map-recenter:hover{transform:translateY(-1px)}.home-map-hero-btn-wrap{z-index:500;pointer-events:none;flex-direction:column;align-items:center;gap:6px;width:calc(100% - 28px);max-width:320px;display:flex;position:absolute;bottom:28px;left:50%;transform:translate(-50%)}.home-map-hero-btn-wrap>*{pointer-events:auto}.home-map-hero-btn{color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;background:linear-gradient(135deg,#16a34a 0%,#15803d 100%);border:none;border-radius:100px;flex-direction:row;justify-content:center;align-items:center;gap:10px;width:100%;height:auto;padding:16px 28px;font-family:Sora,Inter Tight,sans-serif;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 12px 32px -8px #16a34a8c,0 4px 12px #16a34a40,inset 0 1px #fff3}.home-map-hero-btn:hover:not(:disabled):not(.out-of-range){transform:translateY(-2px);box-shadow:0 16px 40px -8px #16a34aa6,0 8px 16px #16a34a4d}.home-map-hero-btn:active:not(:disabled):not(.out-of-range){transform:translateY(0)scale(.98)}.home-map-hero-btn .hero-btn-icon{flex-shrink:0;width:22px;height:22px}.home-map-hero-btn .hero-btn-emoji{flex-shrink:0;font-size:22px;font-weight:800;line-height:1}.home-map-hero-btn-out{background:linear-gradient(135deg,#16a34a 0%,#15803d 100%)}.home-map-hero-btn .hero-btn-label{color:#fff;letter-spacing:-.01em;font-size:16px;font-weight:700;line-height:1}.home-map-hero-btn .hero-btn-sub{display:none}.home-map-hero-btn.out-of-range{cursor:not-allowed;opacity:.85;background:linear-gradient(135deg,#9ca3af 0%,#6b7280 100%)!important;box-shadow:0 8px 16px -6px #6b728066!important}.home-map-hero-btn.out-of-range:hover{transform:none!important}.home-hero-live-timer{-webkit-backdrop-filter:blur(12px);color:var(--accent);font-variant-numeric:tabular-nums;letter-spacing:-.01em;white-space:nowrap;background:#fffffff7;border:1px solid #ffffffb3;border-radius:100px;padding:5px 14px;font-family:Sora,Inter Tight,sans-serif;font-size:13px;font-weight:700;box-shadow:0 4px 12px -2px #0f141926}html[data-theme=dark] .home-hero-live-timer{background:#16192eeb;border-color:#ffffff14}.home-hero-live-timer.hidden{display:none}.home-fab-row{grid-template-columns:1fr;gap:10px;margin-bottom:14px;display:grid}.home-fab-btn{cursor:pointer;letter-spacing:-.01em;-webkit-tap-highlight-color:transparent;border:none;border-radius:16px;justify-content:center;align-items:center;gap:8px;padding:14px 18px;font-family:Sora,Inter Tight,sans-serif;font-size:14px;font-weight:700;transition:all .2s;display:flex}.home-fab-btn-primary{color:#1c1917;background:linear-gradient(135deg,#facc15 0%,#eab308 100%);box-shadow:0 8px 20px -6px #eab30880,0 2px 6px #eab30840,inset 0 1px #fff6}.home-fab-btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 24px -6px #eab30899}.home-fab-btn-secondary{background:var(--surface);color:#eab308;border:1.5px solid #eab3084d;box-shadow:0 4px 10px -2px #0f14190f}.home-fab-btn-secondary:hover{background:#eab3080d;border-color:#eab30880;transform:translateY(-1px)}.home-today-panel{background:var(--surface);border:1px solid var(--border);border-radius:18px;margin-bottom:14px;padding:16px 18px;box-shadow:0 2px 8px #0f14190a}.home-today-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:baseline;margin-bottom:12px;padding-bottom:10px;display:flex}.home-today-title{color:var(--text);letter-spacing:-.02em;font-family:Sora,Inter Tight,sans-serif;font-size:17px;font-weight:700}.home-today-date{color:var(--text-muted);font-family:DM Sans,sans-serif;font-size:12px;font-weight:500}.home-today-row{justify-content:space-between;align-items:center;padding:8px 0;display:flex}.home-today-row+.home-today-row{border-top:1px dashed var(--border)}.home-today-label{color:var(--text-soft);font-family:DM Sans,sans-serif;font-size:13px;font-weight:500}.home-today-value{color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:-.01em;font-family:Sora,Inter Tight,sans-serif;font-size:15px;font-weight:700}.home-today-row-highlight .home-today-label{color:var(--text);font-weight:600}.home-today-row-highlight .home-today-value-hours{color:var(--accent);font-size:18px}.home-section-header{color:var(--text);letter-spacing:.05em;text-transform:uppercase;align-items:center;gap:8px;margin-bottom:4px;padding:4px 4px 12px;font-family:Sora,Inter Tight,sans-serif;font-size:13px;font-weight:700;display:flex}.home-section-header svg{color:var(--accent);flex-shrink:0}.home-gps-marker-icon{background:0 0!important;border:none!important}.home-bottom-sheet{left:0;right:0;bottom:calc(64px + env(safe-area-inset-bottom,0px));z-index:600;background:var(--surface);border-top:1px solid var(--border);touch-action:none;border-radius:24px 24px 0 0;flex-direction:column;max-width:1100px;height:80vh;max-height:80vh;margin:0 auto;transition:transform .35s cubic-bezier(.32,.72,0,1);display:flex;position:fixed;transform:translateY(calc(100% - 28px));box-shadow:0 -8px 32px -8px #0f14192e,0 -2px 8px #0f14190f}.home-bottom-sheet:not(.expanded){pointer-events:none}.home-bottom-sheet:not(.expanded) .home-sheet-handle{pointer-events:auto}.home-bottom-sheet.expanded{transform:translateY(0)}.home-sheet-handle{cursor:grab;-webkit-user-select:none;user-select:none;flex-shrink:0;justify-content:center;padding:10px 0 12px;display:flex}.home-sheet-handle:active{cursor:grabbing}.home-sheet-handle-bar{background:var(--text-muted);opacity:.6;border-radius:100px;width:48px;height:5px;transition:all .2s}.home-bottom-sheet:not(.expanded) .home-sheet-handle-bar{opacity:.7;width:56px}.home-bottom-sheet.expanded .home-sheet-handle-bar{opacity:.4}.home-sheet-top-buttons{flex-shrink:0;grid-template-columns:1fr 1fr;gap:10px;padding:4px 16px 14px;display:grid}.home-sheet-btn{cursor:pointer;letter-spacing:-.01em;-webkit-tap-highlight-color:transparent;border:none;border-radius:100px;justify-content:center;align-items:center;gap:8px;padding:14px 16px;font-family:Sora,Inter Tight,sans-serif;font-size:14px;font-weight:700;transition:all .2s;display:flex}.home-sheet-btn-primary{color:#1c1917;background:linear-gradient(135deg,#facc15 0%,#eab308 100%);box-shadow:0 6px 16px -4px #eab30873,0 2px 4px #eab30833,inset 0 1px #fff6}.home-sheet-btn-primary:hover{transform:translateY(-1px);box-shadow:0 10px 22px -4px #eab3088c}.home-sheet-btn-secondary{color:#ca8a04;background:#eab3081a;border:1.5px solid #eab3084d}.home-sheet-btn-secondary:hover{background:#eab30826;border-color:#eab30880;transform:translateY(-1px)}html[data-theme=dark] .home-sheet-btn-secondary{color:#fbbf24;background:#eab30814}.home-sheet-content{-webkit-overflow-scrolling:touch;flex:1;padding:0 16px 20px;overflow-y:auto}.home-sheet-section{border-top:1px solid var(--border);padding:14px 0}.home-sheet-section:first-child{border-top:none;padding-top:4px}.home-sheet-head{justify-content:space-between;align-items:baseline;margin-bottom:10px;display:flex}.home-sheet-title{color:var(--text);letter-spacing:-.02em;font-family:Sora,Inter Tight,sans-serif;font-size:18px;font-weight:700}.home-sheet-subtitle{color:var(--text-muted);font-family:DM Sans,sans-serif;font-size:12px;font-weight:500}.home-sheet-row{border-top:1px dashed var(--border);justify-content:space-between;align-items:center;padding:9px 0;display:flex}.home-sheet-row:first-of-type{border-top:none}.home-sheet-label{color:var(--text-soft);font-family:DM Sans,sans-serif;font-size:14px;font-weight:500}.home-sheet-value{color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:-.01em;font-family:Sora,Inter Tight,sans-serif;font-size:14px;font-weight:700}.home-sheet-value-hours{color:var(--accent);font-size:14px;font-weight:700}.home-week-table-wrap{background:var(--surface-2);border:1px solid var(--border);border-radius:14px;overflow:hidden}.home-week-table{border-collapse:collapse;width:100%;font-family:DM Sans,sans-serif}.home-week-table thead{background:var(--accent-soft)}.home-week-table thead th{color:var(--text-soft);text-transform:uppercase;letter-spacing:.05em;text-align:left;padding:10px 8px;font-size:11px;font-weight:700}.home-week-table thead th:nth-child(2),.home-week-table thead th:nth-child(3),.home-week-table thead th:nth-child(4){text-align:center;font-variant-numeric:tabular-nums}.home-week-table thead th:last-child{text-align:right;padding-right:12px}.home-week-table tbody tr{border-top:1px solid var(--border)}.home-week-table tbody td{color:var(--text);vertical-align:middle;padding:12px 8px;font-size:13px}.home-week-table tbody td:nth-child(2),.home-week-table tbody td:nth-child(3),.home-week-table tbody td:nth-child(4){text-align:center;font-variant-numeric:tabular-nums;font-weight:600}.home-week-table tbody td:last-child{text-align:right;padding-right:12px}.home-week-table .day-cell{font-family:Sora,Inter Tight,sans-serif}.home-week-table .day-date{color:var(--text);letter-spacing:-.01em;font-size:13px;font-weight:700}.home-week-table .day-name{color:var(--text-muted);margin-top:2px;font-size:11px;font-weight:500}.home-week-table .day-today .day-date{color:var(--accent)}.home-week-table .status-pill{border-radius:100px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.home-week-table .status-present{color:#16a34a;background:#16a34a1f}.home-week-table .status-absent{color:#dc2626;background:#dc26261f}.home-week-table .status-leave{color:#ca8a04;background:#eab30826}.home-week-table .status-weekend{background:var(--surface-3);color:var(--text-muted)}.home-week-table .status-today{color:#6366f1;background:#6366f11f}@keyframes sheetSlideUp{0%{transform:translateY(100%)}to{transform:translateY(calc(100% - 28px))}}.home-bottom-sheet{animation:.5s cubic-bezier(.32,.72,0,1) backwards sheetSlideUp}.home-bottom-sheet.expanded{animation:none}.home-gps-marker-pulse{width:60px;height:60px;position:relative}.home-gps-marker-pulse:before{content:"";background:#40408866;border-radius:50%;width:100%;height:100%;animation:2s ease-out infinite gpsMarkerPulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.home-gps-marker-pulse:after{content:"";background:#40408833;border-radius:50%;width:100%;height:100%;animation:2s ease-out .8s infinite gpsMarkerPulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.home-gps-marker-pulse .pin-inner{z-index:2;background:linear-gradient(135deg,#404088 0%,#2d2d6d 100%);border-radius:50%;width:26px;height:26px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 4px 12px #404088b3,0 0 0 4px #fff}.ai-suggestion-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:16px;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s}.ai-suggestion-btn:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong)}.ai-message{gap:10px;margin-bottom:14px;animation:.3s fadeIn;display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.ai-message.user{flex-direction:row-reverse}.ai-msg-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.ai-msg-avatar.user{background:var(--accent);color:#fff}.ai-msg-avatar.bot{color:#fff;background:linear-gradient(135deg,#6464c8,#404088)}.ai-msg-bubble{white-space:pre-wrap;word-wrap:break-word;border-radius:14px;max-width:80%;padding:10px 14px;font-size:14px;line-height:1.5}.ai-msg-bubble.user{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.ai-msg-bubble.bot{background:var(--surface-2);color:var(--text);border-bottom-left-radius:4px}.ai-msg-typing{gap:4px;display:inline-flex}.ai-msg-typing span{background:var(--text-muted);border-radius:50%;width:8px;height:8px;animation:1.4s infinite aiTyping}.ai-msg-typing span:nth-child(2){animation-delay:.2s}.ai-msg-typing span:nth-child(3){animation-delay:.4s}@keyframes aiTyping{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.shift-type-option{background:var(--surface-2);border:2px solid var(--border);cursor:pointer;border-radius:12px;align-items:center;gap:8px;padding:12px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.shift-type-option:hover{border-color:var(--accent);background:var(--accent-soft)}.shift-type-option.selected{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong)}.shift-type-option>span{font-size:20px}body{background:radial-gradient(circle at 50% -10%,#2563eb29,#0000 34%),linear-gradient(#f8fafc 0%,#eef2ff 100%)!important}.app-shell{background:#f8fafcf5!important;border:1px solid #e2e8f0e6!important;box-shadow:0 28px 90px #0f172a24!important}.app-header{background:radial-gradient(circle at 10% 0,#60a5fa61,#0000 32%),linear-gradient(135deg,#1e3a8a 0%,#172554 100%)!important;border-bottom:0!important;box-shadow:0 18px 46px #1e3a8a52!important}.brand-mark{border-radius:18px!important;box-shadow:0 14px 30px #0f172a47!important}.admin-shell,.step,.attendance-screen-pane{background:0 0!important}.admin-header{background:#fff!important;border:1px solid #e2e8f0!important;border-radius:28px!important;margin-bottom:18px!important;padding:22px 24px!important;box-shadow:0 14px 36px #0f172a12!important}.admin-title,.step-title{color:#0f172a!important;letter-spacing:-.04em!important}.admin-tabs{background:#fff!important;border:1px solid #e2e8f0!important;border-radius:24px!important;gap:8px!important;padding:8px!important;box-shadow:0 14px 36px #0f172a12!important}.admin-tab{color:#475569!important;border-radius:18px!important;min-height:40px!important}.admin-tab.active{color:#fff!important;background:linear-gradient(135deg,#1e3a8a 0%,#2563eb 100%)!important;box-shadow:0 12px 26px #1e3a8a47!important}.stat-card,.lesson-card,.question-card,.empty-state,.data-table,.project-info,.gps-status,.editor-section,.admin-pane>div[style*=border],.admin-pane>div[style*=background]{background:#fff!important;border:1px solid #e2e8f0!important;border-radius:26px!important;box-shadow:0 14px 34px #0f172a12!important}.stat-card .stat-value,.stat-card.accent .stat-value,.step-eyebrow,a{color:#1e3a8a!important}.stat-card.success .stat-value,.banner-success,.lesson-card-status.ready,.req-status-approved{color:#059669!important}.btn,button.login-submit,.req-submit-btn,.admin-btn,.auth-btn-primary{border-radius:18px!important}.btn-primary,.btn-accent,button.login-submit,.auth-btn-primary,#aiChatSendBtn,#broadcastSendBtn,#sigLaunchBtn{color:#fff!important;background:linear-gradient(135deg,#1e3a8a 0%,#2563eb 100%)!important;box-shadow:0 14px 30px #1e3a8a3d!important}.btn-success,.btn-clock-in{color:#fff!important;background:linear-gradient(135deg,#059669 0%,#10b981 100%)!important;box-shadow:0 14px 30px #0596693d!important}input,textarea,select,.login-input{border-color:#e2e8f0!important;border-radius:16px!important}.modal,.req-modal{border:1px solid #e2e8f0!important;border-radius:30px 30px 0 0!important;box-shadow:0 -24px 80px #0f172a40!important}.modal-head,.req-modal-header{background:linear-gradient(#fff 0%,#f8fafc 100%)!important}.toast{border-radius:20px!important}@media (max-width:768px){.app-shell{border:0!important}.app-header{border-radius:0 0 28px 28px!important}.admin-shell,.step,.attendance-screen-pane{padding:18px 14px!important}.admin-header{border-radius:24px!important}}.app-shell,body.has-bottom-nav .app-shell{box-shadow:none!important;background:#070b1f!important;border:0!important}.app-header{background:radial-gradient(circle at 10% 0,#39ff8829,#0000 30%),linear-gradient(135deg,#111733 0%,#070b1f 100%)!important;box-shadow:0 18px 46px #00000057!important}.mobile-screen,#employeeView,.admin-shell,.step,.attendance-screen-pane{color:#f8fafc!important;background:#070b1f!important}body.has-bottom-nav,body.has-bottom-nav .mobile-screen{background:#070b1f!important}.theme-toggle-btn,#profileThemeCard{display:none!important}.home-map-header,.home-map-status-pill:not(.in-range):not(.out-of-range):not(.error),.home-map-recenter,.home-bottom-sheet,.bottom-nav,.admin-header,.admin-tabs,.stat-card,.lesson-card,.question-card,.empty-state,.data-table,.modal,.req-modal,.req-card,.req-type-item,.home-today-panel,.home-action-card,.home-stat-card,.home-week-card,.home-clock-card,.project-info,.gps-status,.editor-section,.admin-pane>div[style*=background],.admin-pane>div[style*=border],.mobile-screen [style*="background:#fff"],.mobile-screen [style*="background: #fff"],.mobile-screen [style*="background:var(--surface)"],.mobile-screen [style*="background: var(--surface)"],.mobile-screen [style*="background:#f9fafb"],.mobile-screen [style*="background:#f8fafc"],.mobile-screen [style*="background:var(--surface-2)"]{color:#f8fafc!important;background:#111733!important;border-color:#94a3b82e!important;box-shadow:0 16px 34px #00000047!important}.home-bottom-sheet{background:#0f1530!important;border-top:1px solid #39ff8838!important}.bottom-nav-item.active,.home-section-header svg,.home-section-title:before,.home-today-row-highlight .home-today-value-hours,.home-stat-card:before,.stat-card .stat-value,.stat-card.accent .stat-value,.step-eyebrow,a{color:#39ff88!important}.bottom-nav-item.active .bottom-nav-icon{filter:drop-shadow(0 0 8px #39ff886b)}.home-section-title,.home-section-header,.home-action-title,.home-today-title,.home-today-value,.home-stat-value,.admin-title,.step-title,.brand-title,.req-card-type,.lesson-card-title,.question-text,.field label,.req-form-field label,h1,h2,h3,h4,strong{color:#f8fafc!important}.home-action-desc,.home-today-label,.home-today-date,.home-stat-label,.req-card-body,.req-card-date,.step-desc,.brand-sub,.field-hint,small,p{color:#aab4d6!important}.admin-tab,.req-tab,.btn-ghost,.home-fab-btn-secondary{color:#cbd5e1!important;background:#151b3a!important;border-color:#94a3b838!important}.btn-primary,.btn-accent,button.login-submit,.auth-btn-primary,.home-map-hero-btn,#aiChatSendBtn,#broadcastSendBtn,#sigLaunchBtn{color:#fff!important;background:linear-gradient(135deg,#1e3a8a 0%,#2563eb 100%)!important}input,textarea,select,.login-input,.toolbar input.search{color:#f8fafc!important;background:#0b1028!important;border-color:#94a3b842!important}.modal-head,.req-modal-header{background:#111733!important;border-bottom-color:#94a3b82e!important}#profileName,#profileSubtitle,#profileCode{color:#f8fafc!important}@media (max-width:768px){.app-header{display:none!important}.mobile-screen{max-width:100%!important}}:root{--bg:#0f172a;--bg-soft:#1e3a8a;--surface:#fff;--surface-2:#f8fafc;--surface-3:#eef2ff;--border:#e5e7eb;--border-strong:#cbd5e1;--text:#1f2937;--text-soft:#64748b;--text-muted:#94a3b8;--primary:#243f96;--accent:#243f96;--accent-soft:#eaf2ff;--accent-strong:#1e3a8a;--accent-bright:#00b876;--success:#00b876;--success-soft:#e9fff5}html,body{color:#1f2937!important;background:#eef3fb!important}.app-shell,body.has-bottom-nav .app-shell{background:#f8fafc!important;border:0!important;box-shadow:0 24px 80px #0f172a24!important}.app-header{color:#fff!important;box-shadow:none!important;background:radial-gradient(circle at 5% 5%,#00b87638,#0000 28%),linear-gradient(145deg,#2949a6 0%,#1e3a8a 55%,#172554 100%)!important;border-radius:0 0 28px 28px!important;padding:26px 24px 30px!important;display:flex!important}.brand-title{color:#fff!important;letter-spacing:.18em!important;text-transform:uppercase!important;font-size:20px!important}.brand-sub{color:#b7ffe0!important;letter-spacing:.24em!important}.brand-mark{background:#ffffff21!important;border:1px solid #ffffff2e!important;border-radius:18px!important}.header-date,.admin-btn{color:#ffffffe6!important}.mobile-screen,#employeeView,.admin-shell,.step,.attendance-screen-pane,body.has-bottom-nav,body.has-bottom-nav .mobile-screen{color:#1f2937!important;background:#f8fafc!important}.admin-header,.admin-tabs,.stat-card,.lesson-card,.question-card,.empty-state,.data-table,.modal,.req-modal,.req-card,.req-type-item,.home-today-panel,.home-action-card,.home-stat-card,.home-week-card,.home-clock-card,.project-info,.gps-status,.editor-section,.admin-pane>div[style*=background],.admin-pane>div[style*=border],.mobile-screen [style*="background:#fff"],.mobile-screen [style*="background: #fff"],.mobile-screen [style*="background:var(--surface)"],.mobile-screen [style*="background: var(--surface)"],.mobile-screen [style*="background:#f9fafb"],.mobile-screen [style*="background:#f8fafc"],.mobile-screen [style*="background:var(--surface-2)"]{color:#1f2937!important;background:#fff!important;border:1px solid #e5e7eb!important;border-radius:22px!important;box-shadow:0 12px 30px #0f172a14!important}.home-map-header,.home-map-status-pill:not(.in-range):not(.out-of-range):not(.error),.home-map-recenter{color:#fff!important;background:#243f96f5!important;border:1px solid #ffffff2e!important}.home-map-company-name,.home-map-company-sub{color:#fff!important}.home-bottom-sheet{background:#f8fafc!important;border-top:1px solid #e5e7eb!important;border-radius:28px 28px 0 0!important;box-shadow:0 -20px 48px #0f172a29!important}.bottom-nav{background:#fffffff5!important;border-top:1px solid #e5e7eb!important;box-shadow:0 -10px 28px #0f172a14!important}.bottom-nav-item{color:#8aa0c2!important}.bottom-nav-item.active,.stat-card .stat-value,.stat-card.accent .stat-value,.step-eyebrow,a{color:#243f96!important}.home-section-title,.home-section-header,.home-action-title,.home-today-title,.home-today-value,.home-stat-value,.admin-title,.step-title,.req-card-type,.lesson-card-title,.question-text,.field label,.req-form-field label,h1,h2,h3,h4,strong{color:#1f2937!important}.home-action-desc,.home-today-label,.home-today-date,.home-stat-label,.req-card-body,.req-card-date,.step-desc,.field-hint,small,p{color:#64748b!important}.admin-tab,.req-tab,.btn-ghost,.home-fab-btn-secondary{color:#64748b!important;background:#fff!important;border:1px solid #e5e7eb!important}.admin-tab.active,.req-tab.active{color:#fff!important;background:#243f96!important;box-shadow:0 12px 24px #243f963d!important}.btn-primary,.btn-accent,button.login-submit,.auth-btn-primary,.home-map-hero-btn,#aiChatSendBtn,#broadcastSendBtn,#sigLaunchBtn{color:#fff!important;background:#243f96!important;box-shadow:0 14px 28px #243f963d!important}.btn-success,.btn-clock-in,.home-fab-btn-primary,.req-submit-btn{color:#fff!important;background:#00b876!important;box-shadow:0 14px 28px #00b8763d!important}#homeTodayHoursCard,.profile-hours-card,.mobile-screen [style*="background:linear-gradient(135deg,#15803d"],.mobile-screen [style*="background: linear-gradient(135deg,#15803d"],.mobile-screen [style*="background:linear-gradient(135deg, #15803d"]{color:#fff!important;background:#168341!important;border:0!important}#profileCode,.req-status-approved,.lesson-card-status.ready{color:#00a86b!important;background:#e9fff5!important}input,textarea,select,.login-input,.toolbar input.search{color:#1f2937!important;background:#fff!important;border:1px solid #dbe3ef!important;border-radius:16px!important}input::placeholder,textarea::placeholder{color:#94a3b8!important}input:focus,textarea:focus,select:focus,.login-input:focus{border-color:#243f96!important;box-shadow:0 0 0 4px #243f961f!important}.modal-head,.req-modal-header{background:#fff!important;border-bottom:1px solid #e5e7eb!important}.toast{color:#1f2937!important;background:#fff!important;border-color:#e5e7eb!important}.toast.success{color:#047857!important;background:#e9fff5!important;border-left-color:#00b876!important}.data-table thead th,.project-table th{color:#64748b!important;background:#f1f5ff!important}.data-table tbody td,.project-table td{color:#1f2937!important;border-color:#e5e7eb!important}#profileName,#profileSubtitle{color:#1f2937!important}#notificationsList>div,#colleaguesList>div,.mobile-screen [style*=border-radius\:16px],.mobile-screen [style*="border-radius: 16px"]{color:#1f2937!important;background:#fff!important;border-color:#e5e7eb!important}@media (max-width:768px){.app-header{display:flex!important}.mobile-screen{max-width:100%!important}}html.screen-home-active,body.screen-home-active,body.employee-mode.screen-home-active,body.has-bottom-nav.screen-home-active{background:#eef3fb!important;overflow:hidden!important}body.screen-home-active .app-header{display:none!important}body.screen-home-active #screenHome.mobile-screen,body.screen-home-active #screenHome.mobile-screen.active{pointer-events:none!important;z-index:100!important;background:0 0!important}body.screen-home-active #screenHome.mobile-screen.active>*{pointer-events:auto!important}body.screen-home-active .home-map-wrap{z-index:1!important;background:#dbeafe!important;width:100vw!important;height:100dvh!important;margin:0!important;padding:0!important;display:block!important;position:fixed!important;inset:0!important;overflow:hidden!important}body.screen-home-active .home-map,body.screen-home-active .home-map .leaflet-container{opacity:1!important;visibility:visible!important;width:100%!important;height:100%!important;display:block!important}body.screen-home-active .home-map-header,body.screen-home-active .home-map-status-pill,body.screen-home-active .home-map-recenter{z-index:520!important}body.screen-home-active .home-bottom-sheet{z-index:600!important;background:#f8fafc!important}body.screen-home-active .bottom-nav{z-index:700!important}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
