.leaflet-image-layer,.leaflet-layer,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-pane,.leaflet-pane>canvas,.leaflet-pane>svg,.leaflet-tile,.leaflet-tile-container,.leaflet-zoom-box{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-bottom,.leaflet-top{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-pan-anim .leaflet-tile,.leaflet-zoom-anim .leaflet-tile{transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-control,.leaflet-popup-pane{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:grabbing}.leaflet-image-layer,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-image-layer.leaflet-interactive,.leaflet-marker-icon.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078A8}.leaflet-zoom-box{border:2px dotted #38f;background:rgba(255,255,255,.5)}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px rgba(0,0,0,.65);border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:black}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:focus,.leaflet-bar a:hover{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px rgba(0,0,0,.4);background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(/_next/static/media/layers.ef6db872.png);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(/_next/static/media/layers-2x.9859cd12.png);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(/_next/static/media/marker-icon.d577052a.png)}.leaflet-container .leaflet-control-attribution{background:#fff;background:rgba(255,255,255,.8);margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:focus,.leaflet-control-attribution a:hover{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;box-sizing:border-box;background:rgba(255,255,255,.8);text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-bar,.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers{box-shadow:none}.leaflet-touch .leaflet-bar,.leaflet-touch .leaflet-control-layers{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:white;color:#333;box-shadow:0 3px 14px rgba(0,0,0,.4)}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:focus,.leaflet-container a.leaflet-popup-close-button:hover{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678,M12=0.70710678,M21=-0.70710678,M22=0.70710678)}.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px rgba(0,0,0,.4)}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before,.leaflet-tooltip-top:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}:root{color-scheme:light;--bg:#f5f7fb;--surface:#ffffff;--surface-muted:#f0f4f8;--border:#d8e0ea;--text:#17202a;--muted:#64748b;--primary:#006b5f;--primary-dark:#005248;--danger:#b42318;--warning:#a15c07;--success:#087443}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:Arial,Helvetica,sans-serif}a{color:inherit}button,input,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.login-shell{min-height:100svh;display:flex;align-items:center;justify-content:center;overflow:hidden;background:radial-gradient(circle at 100% 95%,rgba(52,181,98,.18) 0 9%,transparent 10%),linear-gradient(135deg,#fffffd,#fffaf0 58%,#fff3dd);padding:44px 28px}.login-panel{width:min(100%,360px)}.login-brand{display:flex;flex-direction:column;align-items:flex-start}.login-logo{width:150px;height:auto;display:block;-webkit-user-select:none;-moz-user-select:none;user-select:none}.login-copy{margin-top:38px}.login-copy h1{margin:0;color:#25684f;font-size:36px;font-weight:800;line-height:1.12}.login-copy h1 span{display:block}.login-copy p{margin:14px 0 0;color:#526781;font-size:16px;font-weight:500}.login-form{margin-top:44px;display:flex;flex-direction:column;gap:24px}.login-field{min-height:40px;display:flex;align-items:center;gap:12px;border-bottom:1px solid #d8e0ea;color:#94a3b8;transition:border-color .16s ease,color .16s ease}.login-field:focus-within{border-color:#29aa90;color:#166552}.login-icon{width:18px;height:22px;flex:0 0 18px;display:grid;place-items:center}.login-icon img{max-width:18px;max-height:22px;display:block}.login-icon-active{display:none}.login-field:focus-within .login-icon-default{display:none}.login-field:focus-within .login-icon-active{display:grid}.login-field input{width:100%;min-width:0;border:0;outline:0;background:transparent;color:#334155;font-size:15px;line-height:1.4;padding:8px 0 11px}.login-field input::placeholder{color:#94a3b8}.login-password-control{min-width:0;flex:1 1;display:flex;align-items:center;gap:10px}.login-eye{width:34px;height:34px;flex:0 0 34px;display:grid;place-items:center;border:0;background:transparent;padding:0}.login-eye img{width:18px;height:18px;display:block}.login-options{display:flex;align-items:center;justify-content:space-between;color:#526781;font-size:15px}.login-remember{display:inline-flex;align-items:center;gap:8px}.login-remember input{width:16px;height:16px;accent-color:#089c49}.login-error{margin-top:-6px;border:1px solid #fecdd3;border-radius:6px;background:#fff1f2;color:#be123c;padding:11px 13px;font-size:14px;line-height:1.4}.login-submit{width:100%;min-height:40px;border:0;border-radius:6px;background:#089c49;color:#ffffff;font-size:12px;font-weight:800;letter-spacing:.24em;text-transform:uppercase;transition:background-color .16s ease,transform .16s ease}.login-submit:hover:not(:disabled){background:#10a957}.login-submit:active:not(:disabled){transform:translateY(1px)}@media (max-width:420px){.login-shell{align-items:flex-start;padding:44px 24px 28px}.login-copy{margin-top:36px}.login-copy h1{font-size:34px}.login-form{margin-top:42px}}.app-shell{min-height:100vh;padding:24px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;max-width:1160px;margin:0 auto 20px}.brand{display:flex;flex-direction:column;gap:4px}.brand h1{margin:0;font-size:26px;line-height:1.2}.brand p{margin:0;color:var(--muted)}.nav-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.container{max-width:1160px;margin:0 auto}.grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,420px);grid-gap:18px;gap:18px;align-items:start}.attendance-app-shell{min-height:100svh;display:grid;place-items:center;background:#eef4fb;padding:0}.attendance-phone{position:relative;width:min(100vw,430px);height:100svh;max-height:100svh;min-height:100svh;display:flex;flex-direction:column;overflow:hidden;background:radial-gradient(circle at 50% 42%,rgba(66,123,255,.08),transparent 31%),linear-gradient(180deg,#fbfdff,#f8fbff 62%,#ffffff);color:#111827}.phone-status{height:48px;display:flex;align-items:flex-end;justify-content:space-between;padding:0 32px 8px;color:#050a16;font-size:16px;font-weight:800}.phone-indicators{display:flex;align-items:center;gap:6px}.phone-indicators i{display:block;background:#050a16}.phone-indicators i:first-child{width:18px;height:12px;border-radius:3px 3px 1px 1px;-webkit-clip-path:polygon(0 70%,20% 70%,20% 45%,40% 45%,40% 25%,60% 25%,60% 10%,80% 10%,80% 0,100% 0,100% 100%,0 100%);clip-path:polygon(0 70%,20% 70%,20% 45%,40% 45%,40% 25%,60% 25%,60% 10%,80% 10%,80% 0,100% 0,100% 100%,0 100%)}.phone-indicators i:nth-child(2){width:18px;height:13px;border-radius:50% 50% 0 0;background:transparent;border:4px solid #050a16;border-bottom:0}.phone-indicators i:nth-child(3){width:25px;height:13px;border-radius:4px;border:2px solid #050a16;background:linear-gradient(90deg,#050a16 78%,transparent 0)}.phone-header{position:-webkit-sticky;position:sticky;top:0;z-index:40;flex:0 0 auto;height:58px;display:grid;grid-template-columns:42px minmax(0,1fr) 42px;align-items:center;padding:0 28px;background:rgba(251,253,255,.92);border-bottom:1px solid rgba(226,232,240,.65);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.phone-header h1{margin:0;text-align:center;font-size:19px;font-weight:650;line-height:1}.home-screen{display:flex;flex:1 1;min-height:0;flex-direction:column;overflow-y:auto}.account-screen,.adjust-request-screen,.history-detail-screen,.history-screen,.home-screen,.leave-create-screen,.leave-screen,.mode-checkin-screen{scrollbar-width:none;-ms-overflow-style:none}.account-screen::-webkit-scrollbar,.adjust-request-screen::-webkit-scrollbar,.history-detail-screen::-webkit-scrollbar,.history-screen::-webkit-scrollbar,.home-screen::-webkit-scrollbar,.leave-create-screen::-webkit-scrollbar,.leave-screen::-webkit-scrollbar,.mode-checkin-screen::-webkit-scrollbar{display:none}.icon-button{width:34px;height:34px;display:grid;place-items:center;border:0;background:transparent;color:#101827}.bottom-nav svg,.connection-card svg,.icon-button svg,.office-card svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.employee-card{display:grid;grid-template-columns:52px minmax(0,1fr);align-items:center;grid-gap:12px;gap:12px;padding:14px 32px 8px}.employee-avatar{width:52px;height:52px;display:grid;place-items:center;border-radius:999px;background:#dbeafe;box-shadow:none;overflow:hidden}.employee-avatar img{width:100%;height:100%;object-fit:cover}.employee-avatar span{margin-top:0;color:#0f2e2a;font-size:15px;font-weight:700}.employee-card h2{margin:0;font-size:15px;font-weight:650;line-height:1.2}.employee-title-row{display:flex;align-items:center;gap:8px;margin:0 0 5px;min-width:0}.employee-title-row h2{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.connection-badge{flex:0 0 auto;min-height:24px;border:0;border-radius:999px;background:rgba(22,163,74,.12);color:#16a34a;padding:0 9px;font-size:11px;font-weight:650;line-height:24px}.connection-badge.invalid{background:rgba(239,68,68,.12);color:#dc2626}.connection-badge.location{background:rgba(47,125,246,.1);color:#2f7df6}.connection-badge.business{background:rgba(249,115,22,.1);color:#f97316}.connection-badge:not(.invalid){cursor:default}.employee-card p{margin:0;color:#667085;font-size:12px;line-height:1.35}.employee-card p span{padding:0 5px}.connection-card{width:-moz-fit-content;width:fit-content;max-width:calc(100% - 64px);display:grid;grid-template-columns:38px minmax(0,1fr);align-items:center;grid-gap:11px;gap:11px;margin:14px auto 0;padding:10px 17px 10px 12px;border:1px solid #edf2f7;border-radius:20px;background:rgba(255,255,255,.92);color:inherit;box-shadow:0 14px 34px rgba(31,41,55,.08);text-align:left}.connection-card:not(.invalid){cursor:default}.connection-icon{width:38px;height:38px;display:grid;place-items:center;border-radius:18px;background:#dcfce7;color:#16a34a}.connection-card.invalid .connection-icon{background:#fee2e2;color:#ef4444}.connection-card.location .connection-icon{background:#eaf2ff;color:#2f7df6}.connection-card.business .connection-icon{background:#ffedd5;color:#f97316}.connection-icon svg{width:22px;height:22px;fill:none;stroke:currentColor}.connection-card strong{display:block;color:#16a34a;font-size:14px;font-weight:650;line-height:1.2}.connection-card.invalid strong{color:#ef4444}.connection-card.location strong{color:#2f7df6}.connection-card.business strong{color:#f97316}.connection-card span{display:block;color:#667085;font-size:12px;margin-top:4px}.orb-stage{position:relative;height:min(58vw,252px);margin:18px 8px 28px;display:grid;place-items:center}.orbit{position:absolute;border-radius:999px;border:1px solid rgba(37,99,235,.12)}.orbit-1{width:95%;aspect-ratio:1}.orbit-2{width:80%;aspect-ratio:1;background:rgba(37,99,235,.025)}.orbit-3{width:64%;aspect-ratio:1;background:rgba(37,99,235,.055)}.orb-stage.complete .orbit{border-color:rgba(0,96,91,.14)}.orb-stage.running .orbit{border-color:rgba(239,68,68,.15)}.orb-stage.running .orbit-2{background:rgba(239,68,68,.035)}.orb-stage.running .orbit-3{background:rgba(239,68,68,.075)}.orb-stage.complete .orbit-2{background:rgba(0,96,91,.035)}.orb-stage.complete .orbit-3{background:rgba(0,96,91,.075)}.orbit-dot{position:absolute;width:7px;height:7px;border-radius:999px;background:rgba(37,99,235,.28)}.orb-stage.complete .orbit-dot{background:rgba(0,96,91,.25)}.orb-stage.running .orbit-dot{background:rgba(239,68,68,.35)}.dot-1{top:14%;left:28%}.dot-2{top:28%;right:16%;width:5px;height:5px}.dot-3{bottom:20%;left:18%;width:6px;height:6px}.dot-4{right:28%;bottom:10%;width:5px;height:5px}.orb-pulse{position:absolute;z-index:1;width:min(38vw,172px);aspect-ratio:1;border-radius:999px;background:rgba(59,130,246,.16);animation:mockup-orb-pulse 2.7s ease-out infinite}.pulse-2{animation-delay:.7s}.pulse-3{animation-delay:1.4s}.orb-stage.running .orb-pulse{background:rgba(239,68,68,.16)}.orb-stage.complete .orb-pulse{display:none}.mockup-orb{position:relative;z-index:2;width:min(38vw,172px);aspect-ratio:1;display:grid;place-items:center;align-content:center;grid-gap:8px;gap:8px;border:0;border-radius:999px;background:linear-gradient(145deg,#3b82f6,#6d5dfc);color:#fff;box-shadow:0 0 0 22px rgba(59,130,246,.08),0 18px 42px rgba(59,130,246,.26);transition:transform .16s ease}.mockup-orb.running{background:linear-gradient(145deg,#ef4444,#dc2626);box-shadow:0 0 0 22px rgba(239,68,68,.08),0 18px 42px rgba(220,38,38,.24)}.mockup-orb.complete{background:#16a34a;box-shadow:0 0 0 22px rgba(22,163,74,.08),0 18px 42px rgba(22,163,74,.22)}.mockup-orb:not(:disabled):active{transform:scale(.97)}.mockup-orb:disabled{cursor:default;opacity:1}.mockup-orb strong{max-width:82%;color:#fff;font-size:clamp(17px,5vw,23px);font-weight:600;line-height:1.16;text-align:center}.mockup-orb span{color:rgba(255,255,255,.88);font-size:11px;font-weight:500}.mockup-orb .orb-loading{width:22px;height:22px;border:2px solid rgba(255,255,255,.38);border-top-color:#ffffff;border-radius:999px;animation:orb-loading-spin .76s linear infinite}.mockup-orb .orb-check{font-size:26px;line-height:1}.mockup-orb em{color:#fff;font-size:14px;font-style:normal;font-weight:600}.orb-icon{display:grid;place-items:center;color:#fff}.orb-icon.exit svg{width:54px;height:54px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.orb-icon.check{width:54px;height:54px;border-radius:999px;background:#fff;color:#16a34a;font-size:28px;font-weight:700}.phase-panel{display:grid;grid-gap:12px;gap:12px;margin-top:0}.phase-panel.idle{margin-top:20px}.completion-copy{width:calc(100% - 48px);max-width:320px;min-height:70px;display:block;margin-inline:auto;border:1px solid #d9f5e4;border-radius:16px;background:#f4fffa;padding:14px 18px;text-align:center}.completion-copy strong{display:block;color:#111827;font-size:15px;font-weight:600;line-height:1.25}.completion-copy em{display:block;margin-top:5px;color:#667085;font-size:12px;font-style:normal;line-height:1.35}.running-note{display:flex;align-items:center;justify-content:center;gap:10px;padding:0 26px;color:#334155;font-size:14px;text-align:center}.running-note svg{width:22px;height:22px;flex:0 0 auto;fill:none;stroke:#ef4444;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}.running-note strong{color:#ef4444}.work-period-note{display:grid;grid-template-columns:48px minmax(0,1fr);align-items:center;grid-gap:14px;gap:14px;margin:0 24px;border:0;border-radius:18px;background:rgba(0,96,91,.08);padding:14px 16px}.work-period-note>svg{width:32px;height:32px;color:#00605b;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.work-period-note em,.work-period-note strong{display:block}.work-period-note strong{color:#00605b;font-size:14px;font-weight:650;line-height:1.25}.work-period-note em{color:#475467;font-size:12px;font-style:normal;line-height:1.35;margin-top:5px}.work-period-note.break{background:rgba(239,68,68,.08)}.work-period-note.break strong,.work-period-note.break>svg{color:#dc2626}.work-summary-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);grid-gap:10px;gap:10px;margin:0 24px}.work-summary-card{display:grid;align-items:center;grid-gap:12px;gap:12px;margin:0 24px;padding:16px;border:1px solid #edf2f7;border-radius:18px;background:rgba(255,255,255,.96);box-shadow:0 12px 34px rgba(31,41,55,.07)}.work-summary-card.running{min-height:74px;grid-template-columns:46px minmax(0,1fr);gap:12px;margin:0;padding:12px;border-radius:14px}.work-summary-card.complete{grid-template-columns:42px minmax(0,1fr);width:calc(100% - 48px);max-width:276px;margin-inline:auto;padding:14px}.summary-icon{width:52px;height:52px;display:grid;place-items:center;border-radius:18px}.work-summary-card.running .summary-icon{width:46px;height:46px;border-radius:17px;background:#fee2e2;color:#ef4444}.work-summary-card.running.total .summary-icon{background:rgba(47,125,246,.12);color:#2f7df6}.work-summary-card.complete .summary-icon{background:#dcfce7;color:#16a34a;width:40px;height:40px;border-radius:14px}.history-card svg,.summary-icon svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.work-summary-card span{display:block;color:#667085;font-size:13px;line-height:1.3}.work-summary-card strong{display:block;margin-top:6px;color:#334155;font-size:16px;font-weight:650;line-height:1.2}.work-summary-card.running.total strong{color:#ef4444}.complete-duration strong{color:#16a34a;font-size:20px;font-weight:650}.work-summary-card.complete.danger .complete-duration strong{color:#ef4444}.history-card{max-width:276px;width:calc(100% - 48px);min-height:56px;display:grid;grid-template-columns:34px minmax(0,1fr) 22px;align-items:center;grid-gap:10px;gap:10px;margin-inline:auto;border:1px solid #edf2f7;border-radius:16px;background:rgba(255,255,255,.96);color:#667085;padding:0 15px;text-align:left;box-shadow:0 12px 34px rgba(31,41,55,.06)}.history-card span{color:#334155;font-size:15px}.history-card>svg:last-child{justify-self:end;width:18px;height:18px;stroke-width:2.4}.office-card{display:grid;grid-template-columns:48px minmax(0,1fr) 22px;align-items:center;grid-gap:12px;gap:12px;margin:auto 24px 14px;padding:14px;border:1px solid #edf2f7;border-radius:20px;background:rgba(255,255,255,.95);box-shadow:0 12px 34px rgba(31,41,55,.07)}.office-card>svg:last-child{justify-self:end;width:20px;height:20px;fill:none;stroke:#98a2b3;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.phase-panel .office-card{margin-top:0;margin-bottom:0}.office-card.danger .office-icon{background:rgba(0,96,91,.12);color:#00605b}.office-card.danger .office-icon svg{fill:#00605b;stroke:#00605b}.office-icon{width:46px;height:46px;display:grid;place-items:center;border-radius:18px;background:rgba(0,96,91,.12);color:#00605b}.office-icon svg{width:24px;height:24px;fill:#00605b;stroke:#00605b}.office-card span,.office-card strong{display:block}.office-card strong{font-size:14px;font-weight:650}.office-card span{margin-top:4px;color:#667085;font-size:12px;line-height:1.35}.office-card button{min-height:42px;display:inline-flex;align-items:center;gap:6px;border:1px solid #e4e7ec;border-radius:14px;padding:0 12px;background:#fff;color:#667085;font-weight:600}.office-card button svg{width:18px;height:18px}.bottom-nav{position:-webkit-sticky;position:sticky;bottom:0;z-index:30;height:84px;display:grid;grid-template-columns:repeat(4,1fr);align-items:start;margin-top:auto;border-top:1px solid #edf2f7;background:rgba(255,255,255,.96);padding:10px 18px max(8px,env(safe-area-inset-bottom))}.bottom-nav button{display:grid;place-items:center;grid-gap:5px;gap:5px;border:0;background:transparent;color:#667085;font-size:13px;font-weight:400}.bottom-nav button.active{color:#2f7df6}.bottom-nav svg{width:27px;height:27px;stroke-width:1.9}.checkout-confirm-backdrop{position:absolute;inset:0;z-index:50;display:grid;place-items:center;background:rgba(15,23,42,.28);padding:24px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.checkout-confirm-dialog{max-width:340px;grid-gap:10px;gap:10px;text-align:center}.checkout-confirm-dialog,.mode-checkout-dialog{width:100%;display:grid;border:1px solid rgba(226,232,240,.86);border-radius:20px;background:rgba(255,255,255,.98);padding:18px;box-shadow:0 22px 54px rgba(15,23,42,.18)}.mode-checkout-dialog{max-width:360px;grid-gap:12px;gap:12px}.checkout-confirm-dialog strong,.mode-checkout-dialog>strong{color:#111827;font-size:17px;font-weight:600;line-height:1.25}.mode-checkout-dialog>strong{text-align:center}.checkout-confirm-dialog span,.mode-checkout-dialog>span{color:#667085;font-size:13px;line-height:1.45}.mode-checkout-dialog>span{text-align:center}.checkout-confirm-dialog .checkout-confirm-error,.mode-checkout-dialog>.checkout-confirm-error{border:1px solid #fecaca;border-radius:12px;background:#fef2f2;color:#dc2626;padding:8px 10px;font-weight:600}.checkout-confirm-actions{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px;margin-top:8px}.checkout-confirm-actions.single{grid-template-columns:1fr}.checkout-confirm-actions button{min-height:44px;border-radius:14px;border:1px solid #e5e7eb;background:#ffffff;color:#334155;font-size:14px;font-weight:500}.checkout-confirm-actions button:last-child{border-color:#ef4444;background:#ef4444;color:#ffffff}.checkout-confirm-actions.single button:last-child{border-color:#0878ff;background:#0878ff}.checkout-confirm-actions button:disabled{cursor:not-allowed;opacity:.64}.mode-checkin-screen{display:flex;flex:1 1;min-height:0;flex-direction:column;gap:14px;overflow-y:auto;padding:0 22px 22px}.mode-checkin-header{position:-webkit-sticky;position:sticky;top:0;z-index:40;flex:0 0 auto;display:grid;grid-template-columns:34px minmax(0,1fr) 34px;align-items:center;margin-inline:-22px;padding:18px 22px 14px;background:rgba(251,253,255,.92);border-bottom:1px solid rgba(226,232,240,.65);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.mode-checkin-header h1{margin:0;color:#111827;text-align:center;font-size:17px;font-weight:600;line-height:1.15}.mode-checkin-header .icon-button svg{width:21px;height:21px;fill:none;stroke:currentColor;stroke-width:2.3;stroke-linecap:round;stroke-linejoin:round}.mode-checkin-card{display:grid;grid-gap:16px;gap:16px;border:1px solid #edf2f7;border-radius:18px;background:rgba(255,255,255,.98);box-shadow:0 12px 34px rgba(31,41,55,.07);padding:16px}.mode-checkin-note{display:grid;grid-template-columns:38px minmax(0,1fr);grid-gap:11px;gap:11px;align-items:start;border-radius:14px;background:#eaf2ff;color:#2f7df6;padding:12px}.mode-checkin-note.business{background:#fff7ed;color:#f97316}.mode-checkin-note>svg{width:32px;height:32px;border-radius:999px;background:#2f7df6;color:#fff;padding:7px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.mode-checkin-note.business>svg{background:#f97316}.mode-checkin-note span,.mode-checkin-note strong{display:block}.mode-checkin-note strong{color:#111827;font-size:13px;font-weight:600;line-height:1.25}.mode-checkin-note span{margin-top:4px;color:#52627a;font-size:11px;line-height:1.45}.mode-info-row>span,.mode-location-card>span,.mode-reason-field>span{color:#111827;font-size:13px;font-weight:600;line-height:1.25}.mode-info-row{display:flex;align-items:center;justify-content:space-between;gap:14px}.mode-info-row strong{color:#111827;font-size:13px;font-weight:600;line-height:1.25;text-align:right;white-space:nowrap}.attendance-auth-section{display:grid;grid-gap:9px;gap:9px}.attendance-auth-section>strong{color:#111827;font-size:13px;font-weight:600;line-height:1.25}.attendance-auth-options{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.attendance-auth-options button{min-height:50px;display:grid;grid-template-columns:34px minmax(0,1fr);align-items:center;grid-gap:9px;gap:9px;border:1px solid #b8d2ff;border-radius:7px;background:#ffffff;color:#1677ff;padding:8px 10px;text-align:left}.attendance-auth-options button.complete{border-color:#86efac;background:#f0fdf4;color:#16a34a}.attendance-auth-options svg{width:30px;height:30px;border-radius:8px;background:#1677ff;color:#ffffff;padding:7px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.attendance-auth-options button.complete svg{background:#16a34a}.attendance-auth-options em,.attendance-auth-options span,.attendance-auth-options strong{display:block;min-width:0}.attendance-auth-options strong{overflow-wrap:anywhere;color:#111827;font-size:12px;font-weight:600;line-height:1.2}.attendance-auth-options em{margin-top:3px;overflow-wrap:anywhere;color:#667085;font-size:10px;font-style:normal;line-height:1.25}.attendance-auth-section>small{color:#ef4444;font-size:11px;font-weight:500;line-height:1.35}.mode-location-card{display:grid;grid-gap:8px;gap:8px}.mode-map{position:relative;height:112px;overflow:hidden;border:1px solid #edf2f7;border-radius:10px 10px 0 0;background:linear-gradient(35deg,transparent 47%,rgba(148,163,184,.28) 48% 52%,transparent 53%),linear-gradient(120deg,transparent 45%,rgba(148,163,184,.22) 46% 50%,transparent 51%),linear-gradient(0deg,rgba(226,232,240,.55) 1px,transparent 0),linear-gradient(90deg,rgba(226,232,240,.55) 1px,transparent 0),#eef5ff;background-size:100% 100%,100% 100%,34px 34px,34px 34px}.mode-map i{width:78px;height:78px;background:rgba(47,125,246,.18);box-shadow:0 0 0 22px rgba(47,125,246,.1)}.mode-map i,.mode-map svg{position:absolute;left:50%;top:50%;border-radius:999px;transform:translate(-50%,-50%)}.mode-map svg{width:34px;height:34px;background:#2f7df6;color:#fff;padding:8px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.mode-map.large{height:270px;border-radius:12px}.attendance-leaflet-map{height:270px;overflow:hidden;border:1px solid #dbe6f5;border-radius:12px;background:#eef5ff}.attendance-leaflet-map .leaflet-container{width:100%;height:100%;font:inherit}.attendance-leaflet-map .leaflet-tooltip{border:0;border-radius:8px;box-shadow:0 8px 22px rgba(15,23,42,.14);color:#111827;font-size:11px;font-weight:600}.mode-location-status{display:inline-flex;align-items:center;gap:6px;color:#16a34a;font-size:12px;font-weight:600}.mode-location-status.pending{color:#64748b}.mode-location-status.error{color:#ef4444}.mode-location-status svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2.3;stroke-linecap:round;stroke-linejoin:round}.mode-location-card>strong{color:#111827;font-size:13px;font-weight:600}.mode-location-card small,.mode-location-card>span:not(:first-child){color:#52627a;font-size:12px;line-height:1.35}.location-address-options{display:grid;grid-gap:7px;gap:7px}.location-address-options button{width:100%;border:0;border-radius:9px;background:#eef5ff;color:#475569;padding:9px 10px;text-align:left;font-size:11px;font-weight:500;line-height:1.35}.location-address-options button.active{background:#dbeafe;color:#0f56d9}.location-address-options button span,.location-address-options button strong{display:block}.location-address-options button strong{color:inherit;font-size:11px;font-weight:600;line-height:1.25}.location-address-options button span{margin-top:3px;color:#64748b;font-size:10px;font-weight:500;line-height:1.3}.location-address-options button.active span{color:#2563eb}.location-current-button{min-height:44px;border:0;border-radius:9px;background:#e8f1ff;color:#0f56d9;font-size:13px;font-weight:600}.mode-reason-field{position:relative;display:grid;grid-gap:8px;gap:8px}.mode-reason-field em{color:#64748b;font-style:normal;font-weight:500}.mode-reason-field textarea{min-height:82px;resize:none;border:1px solid #dfe7f1;border-radius:10px;background:#fff;padding:12px;color:#111827;font-size:13px;line-height:1.4}.mode-reason-field textarea::placeholder{color:#94a3b8}.mode-reason-field small{position:absolute;right:10px;bottom:9px;color:#64748b;font-size:11px}.mode-confirm-button{min-height:48px;border:0;border-radius:9px;background:#1677ff;color:#fff;font-size:14px;font-weight:600;box-shadow:0 10px 22px rgba(22,119,255,.18)}.mode-confirm-button:disabled{cursor:not-allowed;opacity:.62}.attendance-camera-screen{position:relative;flex:1 1;min-height:0;display:grid;grid-template-rows:auto minmax(0,1fr) auto;overflow:hidden;background:#020617;color:#ffffff}.attendance-camera-header{position:relative;z-index:3;display:grid;grid-template-columns:44px minmax(0,1fr) 44px;align-items:center;padding:22px 24px 14px}.attendance-camera-header h1{margin:0;text-align:center;font-size:20px;font-weight:500;line-height:1.15}.camera-icon-button{width:44px;height:44px;display:grid;place-items:center;border:0;background:transparent;color:#ffffff}.camera-icon-button svg{width:27px;height:27px;fill:none;stroke:currentColor;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}.attendance-camera-stage{position:relative;min-height:0;margin:10px 28px 0;overflow:hidden;border-radius:8px;background:#111827}.attendance-camera-stage video{width:100%;height:100%;min-height:460px;object-fit:cover;display:block}.camera-grid{inset:0;background:linear-gradient(90deg,transparent 33%,rgba(255,255,255,.35) 33.15% 33.3%,transparent 33.45% 66%,rgba(255,255,255,.35) 66.15% 66.3%,transparent 66.45%),linear-gradient(0deg,transparent 33%,rgba(255,255,255,.35) 33.15% 33.3%,transparent 33.45% 66%,rgba(255,255,255,.35) 66.15% 66.3%,transparent 66.45%)}.camera-corners,.camera-grid{position:absolute;pointer-events:none}.camera-corners{inset:150px 20px 120px}.camera-corners span{position:absolute;width:46px;height:46px;border-color:#ffffff}.camera-corners span:first-child{left:0;top:0;border-left:5px solid;border-top:5px solid;border-radius:8px 0 0 0}.camera-corners span:nth-child(2){right:0;top:0;border-right:5px solid;border-top:5px solid;border-radius:0 8px 0 0}.camera-corners span:nth-child(3){left:0;bottom:0;border-left:5px solid;border-bottom:5px solid;border-radius:0 0 0 8px}.camera-corners span:nth-child(4){right:0;bottom:0;border-right:5px solid;border-bottom:5px solid;border-radius:0 0 8px 0}.camera-meta{position:absolute;z-index:2;display:grid;grid-gap:6px;gap:6px;border-radius:8px;background:rgba(0,0,0,.62);padding:8px 10px;color:#ffffff;font-size:12px;font-weight:500;line-height:1.3;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}.camera-meta.time{left:18px;top:18px}.camera-meta.place{right:18px;top:18px;max-width:155px;text-align:left}.camera-meta span{display:inline-flex;align-items:center;gap:6px}.camera-meta svg{width:16px;height:16px;flex:0 0 auto;fill:none;stroke:currentColor;stroke-width:2.1;stroke-linecap:round;stroke-linejoin:round}.camera-error,.camera-hint{position:absolute;left:24px;right:24px;bottom:30px;border-radius:8px;background:rgba(0,0,0,.68);color:#ffffff;padding:8px 10px;text-align:center;font-size:12px;font-weight:400;line-height:1.35}.camera-error{background:rgba(220,38,38,.88)}.attendance-camera-actions{display:grid;grid-template-columns:1fr 104px 1fr;align-items:center;grid-gap:12px;gap:12px;padding:28px 28px 32px}.attendance-camera-actions button{display:grid;place-items:center;grid-gap:7px;gap:7px;border:0;background:transparent;color:#ffffff;font-size:12px;font-weight:400}.attendance-camera-actions button>svg{width:34px;height:34px;fill:none;stroke:currentColor;stroke-width:2.1;stroke-linecap:round;stroke-linejoin:round}.camera-shutter{width:86px;height:86px;border-radius:999px;border:5px solid #ffffff!important;padding:6px}.camera-shutter span{width:100%;height:100%;border-radius:inherit;background:#ffffff}.mode-location-card.compact{gap:7px}.mode-location-card.compact .mode-map{height:96px}.business-photo-capture{min-height:150px;display:grid;place-items:center;align-content:center;grid-gap:7px;gap:7px;border:1px dashed #b8c7db;border-radius:16px;background:#f8fbff;color:#2f7df6;padding:16px}.business-photo-capture svg{width:38px;height:38px;border-radius:999px;background:#eaf2ff;padding:9px;fill:none;stroke:currentColor;stroke-width:2.1;stroke-linecap:round;stroke-linejoin:round}.business-photo-capture em,.business-photo-capture strong{display:block;text-align:center}.business-photo-capture strong{color:#1677ff;font-size:14px;font-weight:600;line-height:1.25}.business-photo-capture em{max-width:230px;color:#64748b;font-size:12px;font-style:normal;line-height:1.35}.business-photo-capture.captured{border-color:#86efac;background:#f0fdf4;color:#16a34a}.business-photo-capture.captured svg{background:#dcfce7}.attendance-mode-dialog{width:100%;max-width:360px;display:grid;grid-gap:12px;gap:12px;border:1px solid rgba(226,232,240,.86);border-radius:20px;background:rgba(255,255,255,.98);padding:18px;box-shadow:0 22px 54px rgba(15,23,42,.18)}.attendance-mode-dialog>strong{color:#111827;font-size:17px;font-weight:600;line-height:1.25;text-align:center}.attendance-mode-dialog>span{color:#667085;font-size:13px;line-height:1.45;text-align:center}.attendance-mode-options{display:grid;grid-gap:10px;gap:10px;margin-top:2px}.attendance-mode-options button{min-height:72px;display:grid;grid-template-columns:42px minmax(0,1fr);align-items:center;grid-gap:12px;gap:12px;border:1px solid #e5e7eb;border-radius:16px;background:#ffffff;color:#334155;padding:12px;text-align:left}.attendance-mode-options button:first-child svg{background:#eaf2ff;color:#2f7df6}.attendance-mode-options button:nth-child(2) svg{background:#ffedd5;color:#f97316}.attendance-mode-options svg{width:42px;height:42px;border-radius:14px;padding:9px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.attendance-mode-options em,.attendance-mode-options strong{display:block}.attendance-mode-options strong{color:#111827;font-size:14px;font-weight:600;line-height:1.25}.attendance-mode-options em{margin-top:4px;color:#667085;font-size:12px;font-style:normal;line-height:1.35}.attendance-mode-cancel{min-height:42px;border:1px solid #e5e7eb;border-radius:14px;background:#ffffff;color:#475569;font-size:14px;font-weight:500}.history-screen{display:flex;flex:1 1;min-height:0;flex-direction:column;gap:18px;padding:0 22px;overflow-y:auto}.history-header{position:-webkit-sticky;position:sticky;top:0;z-index:40;flex:0 0 auto;display:grid;grid-template-columns:34px minmax(0,1fr) 34px;align-items:center;margin-inline:-22px;padding:18px 22px 14px;background:rgba(251,253,255,.92);border-bottom:1px solid rgba(226,232,240,.65);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.history-header h1{margin:0;text-align:center;font-size:17px;font-weight:600;line-height:1.15}.history-header .icon-button{width:30px;height:30px}.history-header .icon-button svg{width:19px;height:19px}.history-days{display:grid;grid-template-columns:repeat(7,minmax(38px,1fr));align-items:center;grid-gap:6px;gap:6px;margin-inline:-6px}.history-days button{min-height:52px;display:grid;place-items:center;grid-gap:4px;gap:4px;border:0;border-radius:13px;background:#f7f9fc;color:#475569;font-size:12px;font-weight:500;box-shadow:none}.history-days button strong{color:#1f2937;font-size:12px;font-weight:500}.history-days .all{background:#f2f6ff;color:#2f73e8}.history-days .active{background:#dcfce7;color:#15803d;box-shadow:0 8px 16px rgba(22,163,74,.12)}.history-days .active strong{color:#15803d}.history-days .sunday span{color:#ef4444;font-weight:550}.history-stats-card{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid #edf2f7;border-radius:18px;background:rgba(255,255,255,.96);box-shadow:0 12px 34px rgba(31,41,55,.07);padding:18px 10px}.history-stats-card>div{display:grid;justify-items:center;grid-gap:6px;gap:6px;padding:0 6px;text-align:center;border-right:1px solid #e5e7eb}.history-stats-card>div:last-child{border-right:0}.history-stats-card svg{width:22px;height:22px;fill:none;stroke:#2f7df6;stroke-width:2.3;stroke-linecap:round;stroke-linejoin:round}.history-stats-card>div:nth-child(2) svg{stroke:#16a34a}.history-stats-card>div:nth-child(3) svg{stroke:#f97316}.history-stats-card em,.history-stats-card span{color:#667085;font-size:12px;font-style:normal}.history-stats-card strong{color:#111827;font-size:14px;font-weight:560;white-space:nowrap}.history-section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:8px 0 -2px}.history-section-title{margin:0;font-size:16px;font-weight:500}.history-section-head .icon-button{width:30px;height:30px;color:#334155}.history-section-head .icon-button svg{width:19px;height:19px}.history-list{display:grid;grid-gap:10px;gap:10px}.history-row{position:relative;min-height:88px;grid-template-columns:minmax(0,1fr) 18px;align-items:center;border:1px solid #edf2f7;border-radius:16px;background:rgba(255,255,255,.98);box-shadow:0 10px 28px rgba(31,41,55,.06);padding:13px 12px;color:inherit;text-align:left;cursor:pointer}.history-row,.history-row-content{display:grid;grid-gap:12px;gap:12px}.history-row-content{min-width:0}.history-row>svg{width:18px;height:18px;fill:none;stroke:#334155;stroke-width:2.3;stroke-linecap:round;stroke-linejoin:round}.history-row-head{display:grid;grid-template-columns:1fr 1fr;align-items:center;grid-gap:10px;gap:10px}.history-row-head strong{font-size:14px;font-weight:500}.history-row-head span{justify-self:start;margin-left:14px;border-radius:999px;background:#dcfce7;color:#16a34a;padding:5px 9px;font-size:12px;font-weight:500;line-height:1.1;white-space:nowrap}.history-row.warning .history-row-head span{background:#ffedd5;color:#f97316}.history-row.danger .history-row-head span{background:#fee2e2;color:#ef4444}.history-times{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px;margin-top:0}.history-times>div{position:relative;display:flex;align-items:flex-start;min-width:0}.history-times>div+div{border-left:1px solid #e5e7eb;padding-left:14px}.history-times span{display:grid;grid-gap:5px;gap:5px;color:#667085;font-size:13px}.history-time-label{color:#667085;font-size:13px;font-weight:500}.history-time-label.start{color:#16a34a}.history-time-label.end{color:#ef4444}.history-time-mode{margin-top:3px;color:#667085;font-size:13px;font-style:normal;font-weight:400;line-height:1.2}.history-times small{color:#94a3b8;font-size:13px;font-weight:400;line-height:1.25;overflow-wrap:anywhere}.history-times strong{color:#111827;font-size:14px;font-weight:500}.history-info-card{display:grid;grid-template-columns:54px minmax(0,1fr);grid-gap:12px;gap:12px;margin:18px 0 22px;border-radius:16px;background:#eaf2ff;padding:16px;color:#1d4ed8}.history-list .history-info-card,.leave-list .history-info-card{grid-template-columns:1fr;margin:0}.history-info-card>div:first-child{width:42px;height:42px;display:grid;place-items:center;border-radius:12px;background:#2f7df6;color:#fff}.history-info-card svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:2.3;stroke-linecap:round;stroke-linejoin:round}.history-info-card span,.history-info-card strong{display:block}.history-info-card strong{margin-bottom:8px;color:#111827;font-size:15px;font-weight:650}.history-info-card span{font-size:14px;line-height:1.45}.adjust-request-screen,.history-detail-screen{display:flex;flex:1 1;min-height:0;flex-direction:column;gap:16px;padding:0 16px 96px;overflow-y:auto}.adjust-request-screen{padding-bottom:96px}.history-detail-header{position:-webkit-sticky;position:sticky;top:0;z-index:40;flex:0 0 auto;display:grid;grid-template-columns:34px minmax(0,1fr) 34px;align-items:center;margin-inline:-16px;padding:17px 18px 14px;background:rgba(251,253,255,.94);border-bottom:1px solid rgba(226,232,240,.75);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.history-detail-header h1{margin:0;text-align:center;color:#0f172a;font-size:17px;font-weight:650;line-height:1.15}.history-detail-header .icon-button{width:31px;height:31px;color:#0f172a}.history-detail-header svg{width:21px;height:21px}.adjust-day-card,.adjust-form-card,.workday-card,.workday-hero-card{border:1px solid #edf2f7;border-radius:8px;background:rgba(255,255,255,.98);box-shadow:0 12px 34px rgba(31,41,55,.06)}.workday-hero-card{display:grid;grid-template-columns:50px minmax(0,1fr);align-items:center;grid-gap:12px;gap:12px;padding:14px 12px}.workday-hero-icon{width:48px;height:48px;display:grid;place-items:center;border-radius:13px;background:#f2f6ff;color:#334b72}.adjust-day-card svg,.adjust-upload-box svg,.workday-hero-icon svg,.workday-note svg,.workday-summary-list svg{fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.workday-hero-icon svg{width:28px;height:28px}.workday-hero-title-row{display:flex;align-items:center;gap:10px;min-width:0}.workday-hero-card strong{min-width:0;color:#0f172a;font-size:15px;font-weight:650;line-height:1.2;flex:1 1 auto}.workday-hero-card span,.workday-hero-card strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.workday-hero-card span{margin-top:6px;color:#64748b;font-size:13px;font-weight:600}.workday-hero-card em{flex:0 0 auto;border-radius:999px;background:#fff2e6;color:#f97316;padding:8px 10px;font-size:12px;font-style:normal;font-weight:600;white-space:nowrap}.workday-hero-card em.success{background:#e8f8ef;color:#16a34a}.adjust-day-card,.adjust-form-card,.workday-card{padding:0 16px 18px}.adjust-day-card h2,.adjust-form-card h2,.workday-card h2{margin:0 -16px 18px;background:#eaf3ff;border-bottom:1px solid #d7e7fb;border-radius:8px 8px 0 0;padding:12px 16px;color:#174ea6;font-size:15px;font-weight:550;line-height:1.25}.workday-check-grid{display:block}.workday-check-list{position:relative;display:grid;grid-gap:26px;gap:26px}.workday-check-list:before{content:"";position:absolute;left:5.5px;top:12px;height:72px;width:1px;background:#d7dee8}.workday-check-row{position:relative;display:grid;grid-template-columns:12px minmax(0,1fr) minmax(92px,auto);grid-gap:8px 12px;gap:8px 12px;align-items:center;min-height:46px}.workday-dot{grid-row:1/span 2;align-self:start;justify-self:center;width:12px;height:12px;margin-top:5px;border-radius:999px;background:#9ca3af;box-shadow:0 0 0 2px #fff;z-index:1}.workday-dot.active{background:#18b65a}.workday-check-label{display:flex;align-items:center;justify-content:flex-start;gap:7px;min-width:0}.workday-check-label span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.workday-check-label,.workday-check-row>span:not(.workday-dot){color:#17233c;font-size:14px;font-weight:500}.workday-check-list strong{color:#0f172a;font-size:14px;font-weight:650}.workday-check-list strong.muted{color:#64748b}.workday-check-list em{grid-column:3;display:block;min-width:0;color:#64748b;font-size:13px;font-style:normal;font-weight:400;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}.workday-check-status{grid-column:2;color:#94a3b8;font-size:12px;font-style:italic;font-weight:400;line-height:1.2}.workday-check-status.success,.workday-check-status.warning{color:#94a3b8}.workday-check-label b{flex:0 0 auto;border-radius:999px;background:#eef6ff;color:#2f7df6;padding:1px 5px;font-size:10px;font-weight:600;line-height:1.25}.workday-check-list em.success{color:#16a34a}.workday-proof-list{display:grid;grid-gap:12px;gap:12px}.workday-avatar-placeholder,.workday-photo-placeholder{width:68px;height:68px;display:grid;place-items:center;overflow:hidden;border-radius:13px;background:linear-gradient(145deg,#f0f3f8,#ffffff);color:#94a3b8}.workday-avatar-placeholder img{width:100%;height:100%;object-fit:cover}.workday-avatar-placeholder svg,.workday-photo-placeholder svg{width:28px;height:28px;fill:none;stroke:currentColor;stroke-width:2.2}.workday-summary-list{display:grid;grid-gap:19px;gap:19px;margin:22px 0 0;padding:20px 0 0;border-top:1px solid #e5eaf2}.workday-summary-list div{display:grid;grid-template-columns:26px minmax(0,1fr) minmax(92px,auto);align-items:center;grid-gap:12px;gap:12px}.workday-summary-list svg{width:22px;height:22px;color:#7c8aa3}.workday-summary-list dt{color:#17233c;font-size:15px;font-weight:500}.workday-summary-list dd{margin:0;color:#0f172a;font-size:15px;font-weight:500;white-space:nowrap;text-align:left}.adjust-day-card dl div:last-child dd,.adjust-help-text strong,.workday-summary-list dd.danger{color:#ef233c;font-weight:650}.workday-summary-list dd.success{color:#22c55e;font-weight:600}.workday-warning-box{display:grid;grid-gap:16px;gap:16px;border-radius:10px;background:#fff1e8;padding:15px 16px}.workday-warning-box span{display:flex;align-items:center;gap:12px;color:#111827;font-size:15px;font-weight:500}.workday-warning-box svg{width:20px;height:20px;flex:0 0 auto;fill:none;stroke:#f97316;stroke-width:2.3}.empty-adjust-box,.empty-review-box{min-height:84px;display:grid;place-items:center;grid-gap:8px;gap:8px;border:1px dashed #cbd5e1;border-radius:8px;color:#64748b;font-size:14px;text-align:center}.empty-adjust-box svg{width:30px;height:30px;fill:none;stroke:#64748b;stroke-width:2}.adjust-request-list{display:grid;grid-gap:10px;gap:10px}.adjust-request-item{display:grid;grid-template-columns:28px minmax(0,1fr) auto;align-items:center;grid-gap:10px;gap:10px;border:1px solid #dbe5f2;border-radius:8px;padding:10px;background:#ffffff}.adjust-request-item>svg{width:24px;height:24px;color:#2f7df6;fill:none;stroke:currentColor;stroke-width:2}.adjust-request-item em,.adjust-request-item span,.adjust-request-item strong{display:block;min-width:0}.adjust-request-item strong{color:#0f172a;font-size:13px;font-weight:600;line-height:1.25}.adjust-request-item em{margin-top:3px;color:#64748b;font-size:12px;font-style:normal;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.adjust-request-item b{border-radius:999px;background:#fff7ed;color:#f97316;padding:5px 8px;font-size:11px;font-weight:600;white-space:nowrap}.adjust-request-item b.approved{background:#e8f8ef;color:#16a34a}.adjust-request-item b.cancelled,.adjust-request-item b.rejected{background:#fef2f2;color:#ef4444}.approval-history-list{display:grid;grid-gap:10px;gap:10px}.approval-history-item{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;grid-gap:12px;gap:12px;border:1px solid #e5eaf2;border-radius:8px;padding:12px;background:#ffffff}.approval-history-item em,.approval-history-item small,.approval-history-item span,.approval-history-item strong{display:block;min-width:0}.approval-history-item strong{color:#0f172a;font-size:14px;font-weight:600;line-height:1.25}.approval-history-item em{margin-top:4px;color:#475569;font-size:13px;font-style:normal}.approval-history-item small{margin-top:4px;color:#64748b;font-size:12px;line-height:1.35}.approval-history-item b{border-radius:999px;padding:6px 9px;background:#fff7ed;color:#f97316;font-size:12px;font-weight:600;white-space:nowrap}.approval-history-item b.approved{background:#e8f8ef;color:#16a34a}.primary-wide-button{width:100%;min-height:52px;display:flex;align-items:center;justify-content:center;gap:13px;margin-top:12px;border:0;border-radius:8px;background:#0878ff;color:#fff;font-size:15px;font-weight:650;box-shadow:0 10px 20px rgba(8,120,255,.24)}.primary-wide-button svg{width:23px;height:23px;fill:none;stroke:currentColor;stroke-width:2.2}.primary-wide-button:disabled{opacity:.68;cursor:not-allowed}.workday-note{display:grid;grid-template-columns:22px minmax(0,1fr);grid-gap:10px;gap:10px;border-radius:10px;background:#eaf2ff;padding:14px;color:#1d4ed8;font-size:14px;line-height:1.45}.workday-note svg{width:18px;height:18px;margin-top:2px}.adjust-day-card h2{margin-bottom:16px;font-size:14px}.adjust-day-hero{display:grid;grid-template-columns:50px minmax(0,1fr);align-items:center;grid-gap:12px;gap:12px;padding:14px 12px}.adjust-day-hero dl{grid-column:1/-1;margin-top:4px}.adjust-day-card p{display:flex;align-items:center;gap:12px;margin:0;color:#17233c;font-size:15px}.adjust-day-card p span{min-width:0;flex:1 1 auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.adjust-day-card p em{flex:0 0 auto;border-radius:999px;background:#fff2e6;color:#f97316;padding:5px 8px;font-size:11px;font-style:normal;font-weight:650;white-space:nowrap}.adjust-day-card p em.success{background:#e8f8ef;color:#16a34a}.adjust-day-card p svg{width:18px;height:18px;color:#64748b}.adjust-day-card dl{display:grid;grid-gap:17px;gap:17px;margin:0}.adjust-day-card dl div{display:flex;justify-content:space-between;gap:16px;color:#17233c;font-size:15px}.adjust-day-card dd,.adjust-day-card dt{margin:0}.adjust-day-card dd{color:#1e293b;text-align:right}.adjust-form-card h2 span{color:#ef233c}.adjust-form-card h2 .optional{color:#64748b;font-weight:500}.adjust-radio-list{display:grid;grid-gap:18px;gap:18px}.adjust-radio-list label{display:flex;align-items:center;gap:13px;color:#0f172a;font-size:15px;font-weight:500}.adjust-radio-list input{width:19px;height:19px;accent-color:#0878ff}.adjust-time-row{display:grid;grid-template-columns:minmax(0,1fr) 38px minmax(0,1fr);align-items:center;grid-gap:12px;gap:12px}.adjust-time-row span{min-height:48px;display:grid;place-items:center;border:1px solid #cbd5e1;border-radius:8px;color:#0f172a;font-size:15px;font-weight:500}.adjust-time-row svg{width:22px;height:22px;justify-self:center;fill:none;stroke:#334155;stroke-width:2.2}.adjust-help-text{margin:10px 0 26px;color:#64748b;font-size:15px}.adjust-textarea{min-height:122px;display:grid;border:1px solid #cbd5e1;border-radius:8px;background:#fff;padding:13px}.adjust-textarea.small{min-height:100px}.adjust-textarea textarea{width:100%;min-height:76px;resize:none;border:0;outline:0;color:#0f172a;font:inherit;font-size:15px}.adjust-textarea textarea::placeholder{color:#94a3b8}.adjust-textarea span{justify-self:end;align-self:end;color:#64748b;font-size:13px}.adjust-form-message{margin:10px 0 0;font-size:13px;line-height:1.35}.adjust-form-message.error{color:#ef4444}.adjust-form-message.success{color:#16a34a}.adjust-upload-box{min-height:132px;display:grid;place-items:center;border:1px dashed #d5dde8;border-radius:8px;color:#64748b;padding:18px;text-align:center}.adjust-upload-box svg{width:28px;height:28px;color:#64748b}.adjust-upload-box span{margin-top:8px;color:#64748b;font-size:14px}.adjust-upload-box small{margin-top:3px;color:#64748b;font-size:12px}.adjust-upload-box button{margin-top:10px;border:1px solid #cbd5e1;border-radius:8px;background:#fff;color:#0878ff;padding:9px 18px;font-size:14px;font-weight:700}.account-screen{display:flex;flex:1 1;min-height:0;flex-direction:column;gap:18px;overflow-y:auto;padding:0 22px 22px}.account-header{position:-webkit-sticky;position:sticky;top:0;z-index:40;flex:0 0 auto;display:grid;grid-template-columns:34px minmax(0,1fr) 34px;align-items:center;margin-inline:-22px;padding:18px 22px 14px;background:rgba(251,253,255,.92);border-bottom:1px solid rgba(226,232,240,.65);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.account-header h1{margin:0;text-align:center;font-size:17px;font-weight:600;line-height:1.15}.account-logout-icon{color:#ef4444}.account-header .icon-button{width:30px;height:30px}.account-header .icon-button svg{width:20px;height:20px}.account-menu-icon svg{width:25px;height:25px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.account-menu-card{border:1px solid #edf2f7;border-radius:18px;background:rgba(255,255,255,.96);box-shadow:0 12px 34px rgba(31,41,55,.07);padding:8px 16px}.account-menu-row{width:100%;min-height:72px;display:grid;grid-template-columns:52px minmax(0,1fr) 20px;align-items:center;grid-gap:14px;gap:14px;border:0;border-bottom:1px solid #edf2f7;background:transparent;padding:10px 0;text-align:left}.account-menu-row:last-child{border-bottom:0}.account-menu-icon{width:46px;height:46px;display:grid;place-items:center;border-radius:15px}.account-menu-icon.blue{background:#eaf2ff;color:#2f7df6}.account-menu-icon.green{background:#dcfce7;color:#16a34a}.account-menu-icon.purple{background:#ede9fe;color:#6d5dfc}.account-menu-icon.orange{background:#ffedd5;color:#f97316}.account-menu-icon.gray{background:#f1f5f9;color:#64748b}.account-menu-row em,.account-menu-row strong{display:block}.account-menu-row strong{color:#111827;font-size:15px;font-weight:650;line-height:1.25}.account-menu-row em{margin-top:5px;color:#667085;font-size:14px;font-style:normal;line-height:1.25}.account-menu-row>svg{width:19px;height:19px;fill:none;stroke:#667085;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}.leave-create-screen,.leave-screen{display:flex;flex:1 1;min-height:0;flex-direction:column;gap:17px;overflow-y:auto;padding:0 22px 22px}.leave-create-screen{padding-bottom:14px;justify-content:flex-start}.leave-create-header,.leave-header{position:-webkit-sticky;position:sticky;top:0;z-index:40;flex:0 0 auto;display:grid;grid-template-columns:34px minmax(0,1fr) 34px;align-items:center;margin-inline:-22px;padding:18px 22px 14px;background:rgba(251,253,255,.92);border-bottom:1px solid rgba(226,232,240,.65);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.leave-create-header h1,.leave-header h1{margin:0;text-align:center;font-size:17px;font-weight:600;line-height:1.15}.leave-create-header .icon-button,.leave-header .icon-button{width:30px;height:30px}.leave-create-header .icon-button svg,.leave-header .icon-button svg{width:21px;height:21px;fill:none;stroke:currentColor;stroke-width:2.3;stroke-linecap:round;stroke-linejoin:round}.leave-stats-card{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid #edf2f7;border-radius:18px;background:rgba(255,255,255,.96);box-shadow:0 12px 34px rgba(31,41,55,.07);padding:18px 10px}.leave-stats-card>div{display:grid;justify-items:center;grid-gap:6px;gap:6px;padding:0 6px;text-align:center;border-right:1px solid #e5e7eb}.leave-stats-card>div:last-child{border-right:0}.leave-create-button svg,.leave-form-card svg,.leave-note-card svg,.leave-row svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.leave-stats-card svg{width:22px;height:22px;fill:none;stroke:#2f7df6;stroke-width:2.3;stroke-linecap:round;stroke-linejoin:round}.leave-stats-card>div:nth-child(2) svg{stroke:#16a34a}.leave-stats-card>div:nth-child(3) svg{stroke:#f97316}.leave-stats-card span{color:#667085;font-size:12px;font-style:normal}.leave-stats-card strong{color:#111827;font-size:14px;font-weight:560;white-space:nowrap}.leave-create-button{min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:10px;border:0;border-radius:10px;background:#1677ff;color:#fff;font-size:16px;font-weight:500;box-shadow:0 12px 26px rgba(22,119,255,.18)}.leave-create-button svg{width:22px;height:22px;stroke-width:2.3}.leave-tabs{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid #e5e7eb}.leave-tabs button{position:relative;min-height:47px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border:0;background:transparent;color:#475569;font-size:14px;font-weight:500}.leave-tabs button.active{color:#1677ff}.leave-tabs button.active:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:#1677ff}.leave-tabs span{min-width:18px;height:18px;display:grid;place-items:center;border-radius:999px;background:#e11d48;color:#fff;font-size:11px;line-height:1}.leave-list{display:grid;grid-gap:11px;gap:11px}.leave-row{min-height:92px;display:grid;grid-template-columns:minmax(0,1fr) 18px;align-items:center;grid-gap:12px;gap:12px;border:1px solid #edf2f7;border-radius:16px;background:rgba(255,255,255,.98);box-shadow:0 10px 28px rgba(31,41,55,.06);padding:13px 12px}.leave-row-content{min-width:0;display:grid;grid-gap:5px;gap:5px}.leave-row-line{min-width:0;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;grid-gap:12px;gap:12px}.leave-row-line strong:first-child{color:#111827;font-size:14px;font-weight:500;line-height:1.2}.leave-row-line em,.leave-row-line small,.leave-row-line span:not(.leave-status){color:#52627a;font-size:12px;font-style:normal;line-height:1.3}.leave-status{border-radius:999px;padding:4px 8px;font-size:12px;font-weight:500;line-height:1.1;white-space:nowrap}.leave-status.pending{background:#ffedd5;color:#f97316}.leave-status.approved{background:#dcfce7;color:#16a34a}.leave-status.rejected{background:#fee2e2;color:#dc2626}.leave-status.cancelled{background:#f1f5f9;color:#64748b}.leave-row-line small{color:#64748b;white-space:nowrap}.leave-duration{color:#52627a;font-size:12px;font-weight:500;line-height:1.2;white-space:nowrap}.leave-row>svg{align-self:center;width:16px;height:16px;color:#64748b;stroke-width:2.3}.leave-note-card{display:grid;grid-template-columns:44px minmax(0,1fr);grid-gap:12px;gap:12px;align-items:center;border-radius:16px;background:#eaf2ff;padding:16px;color:#1d4ed8}.leave-note-card svg{width:35px;height:35px;fill:#2f7df6;stroke:#fff}.leave-note-card span,.leave-note-card strong{display:block}.leave-note-card strong{margin-bottom:6px;color:#111827;font-size:15px;font-weight:650}.leave-note-card span{color:#334155;font-size:13px;line-height:1.55}.leave-note-card.compact{align-items:start;margin-top:3px}.leave-note-card.compact span{position:relative;padding-left:12px}.leave-note-card.compact span:before{content:"•";position:absolute;left:0}.leave-form-card{display:grid;grid-gap:20px;gap:20px;border:1px solid #edf2f7;border-radius:18px;background:rgba(255,255,255,.98);box-shadow:0 12px 34px rgba(31,41,55,.07);padding:18px 16px}.leave-form-card h2{margin:0;color:#111827;font-size:17px;font-weight:600;line-height:1.2}.leave-user-summary{display:grid;grid-template-columns:62px minmax(0,1fr);grid-gap:12px;gap:12px;align-items:center}.leave-avatar{width:58px;height:58px}.leave-user-summary span,.leave-user-summary strong{display:block}.leave-user-summary strong{color:#111827;font-size:16px;font-weight:600;line-height:1.25}.leave-user-summary span{margin-top:5px;color:#52627a;font-size:13px;line-height:1.25}.leave-balance-card{grid-column:1/-1;display:grid;grid-template-columns:28px minmax(0,1fr);grid-gap:2px 10px;gap:2px 10px;align-items:center;border-radius:14px;background:#dcfce7;padding:14px;color:#16a34a}.leave-balance-card svg{grid-row:span 3;width:24px;height:24px}.leave-balance-card span{margin:0;color:#334155;font-size:13px}.leave-balance-card strong{color:#16a34a;font-size:26px;font-weight:650;line-height:1.05}.leave-balance-card em{color:#475569;font-size:15px;font-style:normal;font-weight:500}.leave-balance-card small{color:#667085;font-size:11px}.leave-field{position:relative;display:grid;grid-gap:6px;gap:6px;color:#334155}.leave-field>span{color:#334155;font-size:14px;font-weight:400;line-height:1.25}.leave-field>span em{color:#ef4444;font-style:normal}.leave-field>span small{color:#64748b;font-size:14px;font-weight:500}.leave-date-picker,.leave-days-total,.leave-reason,.leave-select{width:100%;border:0;border-bottom:1px solid #d3dde3;border-radius:0;background:#fffff0;color:#334155;transition:border-color .18s ease}.leave-date-input:focus-visible,.leave-date-picker:hover,.leave-days-total:hover,.leave-reason:focus,.leave-reason:hover,.leave-select:focus-visible,.leave-select:hover{border-bottom-color:#8ec9cd}.leave-select-dropdown{position:relative}.leave-select{min-height:32px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:0 12px;text-align:left;font-size:14px;font-weight:400;outline:none}.leave-select.placeholder{color:#94a3b8}.leave-select>span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.leave-select>svg{flex:0 0 auto;width:16px;height:16px;color:#64748b}.leave-select-menu{position:absolute;left:0;top:calc(100% + 4px);z-index:40;min-width:100%;max-width:90vw;overflow:hidden;border:1px solid #d3dde3;border-radius:6px;background:#fff;box-shadow:0 16px 36px rgba(15,23,42,.14);padding:4px}.leave-select-menu button{display:flex;width:100%;min-width:0;align-items:center;gap:8px;border:0;border-radius:6px;background:transparent;padding:9px 8px;color:#334155;text-align:left;font-size:14px}.leave-select-menu button.selected,.leave-select-menu button:hover{background:#f8fafc}.leave-select-menu button.selected{color:#0f172a;font-weight:600}.leave-select-check{display:inline-flex;width:16px;height:16px;align-items:center;justify-content:center;color:#334155}.leave-select-check svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}.leave-select-empty{display:block;padding:10px 8px;color:#64748b;font-size:13px}.leave-date-grid{display:grid;grid-template-columns:minmax(0,1fr) 20px minmax(0,1fr);align-items:center;grid-gap:10px;gap:10px}.leave-date-grid>i{color:#64748b;font-style:normal;text-align:center}.leave-date-picker{position:relative;min-height:54px;display:flex;flex-direction:column;justify-content:center;gap:6px;padding:6px 12px;text-align:left}.leave-date-grid small{color:#64748b;font-size:12px}.leave-date-input{display:flex;width:100%;align-items:center;justify-content:space-between;gap:10px;border:0;background:transparent;color:#334155;font-size:14px;font-weight:400;text-align:left;outline:none}.leave-date-input svg{flex:0 0 auto;width:16px;height:16px;color:#00605b}.leave-calendar-panel{position:absolute;left:0;top:calc(100% + 8px);z-index:45;width:min(310px,calc(100vw - 40px));border:1px solid #dfe7f1;border-radius:10px;background:#fff;box-shadow:0 18px 42px rgba(15,23,42,.16);padding:10px}.leave-date-grid .leave-date-picker:last-child .leave-calendar-panel{left:auto;right:0}.leave-calendar-caption{display:grid;grid-template-columns:68px minmax(0,1fr) 68px;align-items:center;grid-gap:6px;gap:6px;margin-bottom:8px}.leave-calendar-caption>div{display:flex;gap:4px}.leave-calendar-caption>div:last-child{justify-content:flex-end}.leave-calendar-caption button{width:26px;height:26px;border:0;border-radius:6px;background:transparent;color:#64748b;font-size:18px;line-height:1}.leave-calendar-caption button:hover{background:#f1f5f9}.leave-calendar-caption strong{min-width:0;color:#0f172a;font-size:13px;font-weight:700;text-align:center;white-space:nowrap}.leave-calendar-grid,.leave-calendar-weekdays{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-gap:3px;gap:3px}.leave-calendar-weekdays{margin-bottom:4px}.leave-calendar-weekdays span{color:#64748b;font-size:11px;font-weight:700;text-align:center}.leave-calendar-grid button{aspect-ratio:1;border:0;border-radius:7px;background:transparent;color:#0f172a;font-size:13px;font-weight:500}.leave-calendar-grid button:hover{background:#eef6ff}.leave-calendar-grid button.in-range{background:#e8f2ff;color:#0f4ea8}.leave-calendar-grid button.excluded{background:transparent;color:#94a3b8;text-decoration:line-through}.leave-calendar-grid button.outside{color:#cbd5e1}.leave-calendar-grid button.today{background:transparent;color:#008060;box-shadow:none}.leave-calendar-grid button.selected{background:#d9ebff;color:#0f4ea8;box-shadow:inset 0 0 0 1px #93c5fd}.leave-calendar-grid button:disabled{cursor:not-allowed;color:#cbd5e1;background:transparent}.leave-days-total{min-height:32px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 12px;text-align:left;cursor:pointer}.leave-days-total span{color:#334155;font-size:14px}.leave-days-total strong{color:#00605b;font-size:14px;font-weight:600}.leave-day-popup-backdrop{position:fixed;inset:0;z-index:80;display:grid;place-items:center;background:rgba(15,23,42,.24);padding:20px}.leave-day-popup{width:min(354px,100%);display:grid;grid-template-rows:auto minmax(0,1fr) auto;grid-gap:12px;gap:12px;max-height:min(620px,calc(100dvh - 40px));border-radius:12px;background:#fff;box-shadow:0 24px 70px rgba(15,23,42,.22);padding:14px}.leave-day-popup header{display:flex;align-items:center;justify-content:space-between;gap:12px}.leave-day-popup header strong{color:#0f172a;font-size:15px;font-weight:560}.leave-day-popup header button{width:30px;height:30px;display:grid;place-items:center;border:0;border-radius:8px;background:#f8fafc;color:#475569}.leave-day-popup header svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.leave-day-popup-row{display:grid;grid-template-columns:minmax(0,1fr) 132px;align-items:center;grid-gap:10px;gap:10px}.leave-day-popup-list{display:grid;align-content:start;grid-gap:8px;gap:8px;max-height:342px;min-height:0;overflow-y:auto;padding-right:2px;overscroll-behavior:contain}.leave-day-popup-row{min-height:42px;border-bottom:1px solid #eef2f7;padding-bottom:8px}.leave-day-popup-row>span{min-width:0;color:#334155;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leave-day-popup-done{min-height:40px;border:0;border-radius:10px;background:#1677ff;color:#fff;font-size:14px;font-weight:560}.leave-day-part-dropdown{position:relative;min-width:0}.leave-day-part-select{width:100%;min-height:34px;display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px solid #d7e2ef;border-radius:8px;background:#fffff0;color:#334155;padding:0 10px;text-align:left;font-size:13px;font-weight:400;outline:none}.leave-day-part-select>span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.leave-day-part-select>svg{flex:0 0 auto;width:15px;height:15px;color:#334155}.leave-day-part-menu{position:absolute;left:0;top:calc(100% + 4px);z-index:90;min-width:100%;overflow:hidden;border:1px solid #d3dde3;border-radius:8px;background:#fff;box-shadow:0 16px 36px rgba(15,23,42,.14);padding:4px}.leave-day-part-dropdown.open-up .leave-day-part-menu{top:auto;bottom:calc(100% + 4px)}.leave-day-part-menu button{display:flex;width:100%;min-width:0;align-items:center;gap:8px;border:0;border-radius:6px;background:transparent;padding:9px 8px;color:#334155;text-align:left;font-size:13px}.leave-day-part-menu button.selected,.leave-day-part-menu button:hover{background:#f8fafc}.leave-day-part-menu button.selected{color:#0f172a;font-weight:600}.leave-help{color:#64748b;font-size:12px;line-height:1.35}.leave-reason{min-height:112px;resize:none;padding:10px 12px 24px;font-size:14px;line-height:1.35;outline:none}.leave-count{position:absolute;right:14px;bottom:12px;color:#64748b;font-size:12px}.leave-form-error{margin:-4px 0 0;color:#dc2626;font-size:13px;line-height:1.35}.leave-form-actions{display:grid;grid-template-columns:1fr 1.6fr;grid-gap:12px;gap:12px;margin-top:0;padding:8px 0 0}.leave-form-actions button{min-height:51px;border-radius:12px;border:1px solid #8bb7ff;background:#fff;color:#4f5f75;font-size:16px;font-weight:560}.leave-form-actions button:last-child{border-color:#2f7df6;background:#2f7df6;color:#fff}.leave-date-input:disabled,.leave-days-total:disabled,.leave-form-actions button:disabled,.leave-reason:disabled{cursor:not-allowed;opacity:.65}.attendance-shell{min-height:100svh;padding:14px 14px calc(18px + env(safe-area-inset-bottom))}.attendance-topbar{max-width:480px;margin-bottom:12px}.attendance-topbar .brand h1{font-size:24px}.attendance-topbar .brand p{font-size:14px;line-height:1.35;overflow-wrap:anywhere}.attendance-topbar .nav-actions{width:100%;justify-content:stretch}.attendance-topbar .nav-actions .button{flex:1 1}.attendance-container{gap:14px}.attendance-container,.attendance-dot-container{display:flex;flex-direction:column;max-width:480px}.attendance-dot-container{min-height:calc(100svh - 32px);align-items:center;justify-content:center;gap:22px}.attendance-orb-wrap{position:relative;display:grid;place-items:center;width:min(76vw,292px);aspect-ratio:1}.attendance-orb-wrap:after,.attendance-orb-wrap:before{content:"";position:absolute;inset:16px;border-radius:999px;background:rgba(14,165,233,.18);animation:attendance-ripple 2.25s ease-out infinite}.attendance-orb-wrap:after{animation-delay:.72s}.attendance-orb-wrap.running:after,.attendance-orb-wrap.running:before{background:rgba(220,38,38,.18)}.attendance-orb-wrap.complete:after,.attendance-orb-wrap.complete:before{background:rgba(0,96,91,.14);animation-play-state:paused;opacity:.45}.attendance-orb{position:relative;z-index:1;display:grid;place-items:center;width:min(62vw,228px);aspect-ratio:1;border:0;border-radius:999px;background:#0ea5e9;color:#fff;box-shadow:none;transition:transform .18s ease,opacity .18s ease}.attendance-orb.running{background:#dc2626;box-shadow:none}.attendance-orb.complete{background:#00605b;box-shadow:none}.attendance-orb:not(:disabled):active{transform:scale(.96)}.attendance-orb:disabled{cursor:default;opacity:1}.attendance-orb span{max-width:90%;font-size:clamp(22px,6.2vw,32px);font-weight:800;line-height:1.12;text-align:center;white-space:nowrap}.attendance-time{display:flex;min-height:78px;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--muted);text-align:center}.attendance-time strong{color:var(--text);font-size:clamp(38px,13vw,56px);line-height:1;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;letter-spacing:0}.attendance-time span{font-size:15px}.attendance-meta-card{width:100%;display:grid;grid-gap:10px;gap:10px;border:1px solid var(--border);border-radius:8px;background:rgba(255,255,255,.82);padding:12px;box-shadow:0 10px 24px rgba(15,23,42,.06)}.attendance-meta-grid{display:grid;grid-template-columns:auto minmax(0,1fr);grid-gap:9px 14px;gap:9px 14px;font-size:14px}.attendance-meta-grid span{color:var(--muted)}.attendance-meta-grid strong{min-width:0;text-align:right;overflow-wrap:anywhere}.attendance-refresh{min-height:40px}@keyframes attendance-ripple{0%{transform:scale(.72);opacity:.58}72%{opacity:0}to{transform:scale(1.34);opacity:0}}@keyframes mockup-orb-pulse{0%{transform:scale(.9);opacity:.46}62%{opacity:.12}to{transform:scale(1.62);opacity:0}}@keyframes orb-loading-spin{to{transform:rotate(1turn)}}.attendance-container .panel{padding:14px}.attendance-container .panel h2{font-size:18px;line-height:1.25}.attendance-container .row{align-items:flex-start;gap:10px;padding:9px 0}.attendance-container .badge,.attendance-container .value{max-width:58%;text-align:right;overflow-wrap:anywhere}.attendance-actions{position:-webkit-sticky;position:sticky;bottom:max(10px,env(safe-area-inset-bottom));z-index:10}.attendance-button-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.attendance-button-row .button{min-height:52px;width:100%}.attendance-button-row .button:last-child{grid-column:1/-1;min-height:46px}.admin-shell{min-width:768px}.admin-container,.admin-topbar{max-width:1240px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:18px;box-shadow:0 10px 24px rgba(15,23,42,.06)}.panel h2,.panel h3{margin:0 0 14px}.stack{flex-direction:column;gap:14px}.row,.stack{display:flex}.row{align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid var(--border);padding:10px 0}.row:last-child{border-bottom:0}.label{color:var(--muted);font-size:14px}.value{text-align:right}.badge,.value{font-weight:700}.badge{display:inline-flex;align-items:center;min-height:28px;border-radius:999px;padding:4px 10px;font-size:13px;background:var(--surface-muted);color:var(--text)}.badge.success{background:#e7f7ef;color:var(--success)}.badge.warning{background:#fff3dc;color:var(--warning)}.badge.danger{background:#fee4e2;color:var(--danger)}.button{display:inline-flex;align-items:center;justify-content:center;min-height:42px;border:1px solid var(--border);border-radius:6px;padding:0 14px;background:var(--surface);color:var(--text);text-decoration:none;font-weight:700}.button.primary{border-color:var(--primary);background:var(--primary);color:#fff}.button.primary:hover{background:var(--primary-dark)}.button.danger{border-color:#fecdca;color:var(--danger)}.button-row{display:flex;gap:10px;flex-wrap:wrap}.input{width:100%;min-height:42px;border:1px solid var(--border);border-radius:6px;padding:0 12px;background:#fff}.form{gap:14px}.form,.form-field{display:flex;flex-direction:column}.form-field{gap:6px}.message{border-radius:6px;padding:10px 12px;background:var(--surface-muted);color:var(--text)}.message.error{background:#fee4e2;color:var(--danger)}.camera-frame{display:grid;grid-gap:12px;gap:12px}.camera-video,.snapshot-preview{width:100%;aspect-ratio:3/4;border-radius:8px;border:1px solid var(--border);background:#0f172a;object-fit:cover}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:14px}td,th{border-bottom:1px solid var(--border);padding:10px;text-align:left;vertical-align:top}th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.03em}.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.tab{border:1px solid var(--border);background:#fff;border-radius:999px;padding:8px 12px;font-weight:700}.tab.active{border-color:var(--primary);color:var(--primary)}@media (max-width:860px){.app-shell{padding:14px}.topbar{align-items:flex-start;flex-direction:column}.nav-actions{justify-content:flex-start}.grid{grid-template-columns:1fr}.admin-shell{min-width:768px;padding:18px}}@media (min-width:560px){.attendance-shell{padding-top:24px}.attendance-container,.attendance-dot-container,.attendance-topbar{max-width:520px}}@media (max-width:380px){.attendance-shell{padding:10px}.attendance-container .panel{padding:12px}.attendance-button-row{grid-template-columns:1fr}.attendance-button-row .button:last-child{grid-column:auto}.attendance-dot-container{gap:16px}.attendance-meta-card{padding:10px}.brand h1{font-size:22px}}