:root{--surface:#fbf8fc;--surface-low:#f5f3f6;--surface-lowest:#fff;--surface-high:#eae7ea;--surface-highest:#e4e2e5;--primary:#00071b;--primary-container:#0f1f3d;--primary-fixed:#d8e2ff;--primary-fixed-dim:#b7c6ed;--secondary:#005fac;--secondary-fixed:#d4e3ff;--secondary-container:#63a8ff;--tertiary-fixed:#ffdcc0;--error:#ba1a1a;--error-container:#ffdad6;--on-surface:#1b1b1e;--on-muted:#45474e;--outline:#75777e;--outline-variant:#c5c6ce;color:var(--on-surface);background:var(--surface);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font:14px/1.5 Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}img,video,canvas,svg{max-width:100%;height:auto}#app{height:100%;display:contents}html{max-width:100%;height:100%;overflow:hidden}body{overscroll-behavior:none;background:var(--surface);width:100%;min-width:0;height:100%;margin:0;overflow:hidden}@media (width>=520px){body{background:#e8ebf0}}button,input,select,textarea{font:inherit;appearance:none;-webkit-tap-highlight-color:transparent}input:disabled,textarea:disabled,select:disabled{-webkit-text-fill-color:currentColor;opacity:1}input,select,textarea{font-size:16px}button{cursor:pointer}button:disabled{cursor:not-allowed}a{color:inherit;text-decoration:none}h1,h2,h3,p{margin:0}h1,h2,h3,.font-headline{font-family:Manrope,Inter,sans-serif}.material-symbols-outlined{letter-spacing:0;text-transform:none;white-space:nowrap;word-wrap:normal;font-feature-settings:"liga";-webkit-font-feature-settings:"liga";-webkit-font-smoothing:antialiased;font-variation-settings:"FILL" 0, "wght" 500, "GRAD" 0, "opsz" 24;font-display:block;direction:ltr;font-family:Material Symbols Outlined,sans-serif;font-size:24px;font-style:normal;font-weight:400;line-height:1;display:inline-block}.icon-fill{font-variation-settings:"FILL" 1, "wght" 600, "GRAD" 0, "opsz" 24}.app-shell{overscroll-behavior-y:none;-webkit-overflow-scrolling:touch;background:var(--surface);isolation:isolate;width:100%;max-width:430px;height:100svh;margin:0 auto;position:relative;overflow:hidden auto}@media (width>=520px){.app-shell{height:min(100svh,932px);min-height:min(100svh,932px);box-shadow:0 24px 80px #0f1f3d29}}.page{min-height:100svh;padding:calc(22px + env(safe-area-inset-top,0px)) 20px calc(104px + env(safe-area-inset-bottom,0px))}.top-bar{margin:calc(-22px - env(safe-area-inset-top,0px)) -20px 22px;padding:calc(14px + env(safe-area-inset-top,0px)) 20px 12px;background:var(--surface);justify-content:space-between;align-items:center;gap:16px;display:flex}.top-bar-title{align-items:center;gap:12px;display:flex}.avatar,.logo-mark{border-radius:14px;flex:none;place-items:center;width:44px;height:44px;display:grid}.avatar{color:var(--primary);background:var(--secondary-fixed);font-family:Manrope,sans-serif;font-weight:900}.logo-mark{color:#fff;background:var(--primary);box-shadow:0 18px 48px #00071b1f}.icon-button{width:44px;height:44px;color:var(--on-muted);background:var(--surface-low);border:0;border-radius:999px;place-items:center;display:grid}.eyebrow,.label{color:var(--on-muted);letter-spacing:.1em;text-transform:uppercase;font-size:11px;font-weight:800}h1{color:var(--primary);letter-spacing:-.01em;font-size:16px;font-weight:800;line-height:1.2}h2{color:var(--on-surface);letter-spacing:-.01em;font-size:14px;font-weight:700;line-height:1.3}p{font-size:14px;line-height:1.5}.text-display{letter-spacing:-.02em;font-family:Manrope,sans-serif;font-size:28px;font-weight:800;line-height:1}.text-body{font-size:14px;line-height:1.5}.text-caption{color:var(--on-muted);font-size:12px;line-height:1.4}.text-title{font-size:14px;font-weight:700;line-height:1.3}.text-label{font-size:13px;line-height:1.5}.muted{color:var(--on-muted)}.ambient-card,.status-panel,.list-item{background:var(--surface-lowest);border-radius:16px;box-shadow:0 8px 32px #1b1b1e0a}.gradient-card{color:#fff;background:linear-gradient(135deg, var(--primary) 0%, var(--primary-container) 100%);border-radius:28px;position:relative;overflow:hidden;box-shadow:0 16px 48px #00071b29}.gradient-card:after{content:"";filter:blur(20px);background:#ffffff14;border-radius:50%;width:180px;height:180px;position:absolute;top:-72px;right:-64px}.primary-button,.secondary-button,.action-button{letter-spacing:-.01em;border:0;border-radius:16px;justify-content:center;align-items:center;gap:8px;min-height:52px;padding:0 18px;font-family:Manrope,Inter,sans-serif;font-size:14px;font-weight:700;display:inline-flex}.primary-button,.action-button{color:#fff;background:linear-gradient(135deg, var(--primary), var(--primary-container));box-shadow:0 12px 32px #00071b24}.secondary-button{width:100%;color:var(--primary);background:var(--surface-low)}.primary-button:disabled{opacity:.6}.form{gap:18px;display:grid}.field{gap:8px;display:grid}.field>span,.form label>span{color:var(--on-surface);font-size:13px;font-weight:700;line-height:1.3}.ghost-field{background:var(--surface-low);border-radius:16px 16px 6px 6px;display:grid;position:relative}.ghost-field input,.ghost-field textarea,.ghost-field select,.form input,.form textarea,.form select{width:100%;color:var(--on-surface);background:var(--surface-low);text-align:left;border:0;border-radius:16px;outline:0;padding:14px 16px;font-size:16px}select.input-field,.ghost-field select,.form select{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%2375777e' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-position:right 14px center;background-repeat:no-repeat;padding-right:40px}input[type=date],input[type=time],input[type=datetime-local]{text-align:left}.input-field{box-sizing:border-box;border:1px solid var(--outline-variant);text-align:left;width:100%;color:var(--on-surface);background:var(--surface-lowest);border-radius:14px;padding:14px 16px;font-size:16px;line-height:1.4;transition:border-color .2s,box-shadow .2s}.input-field::placeholder{color:var(--on-muted);opacity:.7}.input-field:focus{border-color:var(--secondary);box-shadow:0 0 0 3px color-mix(in srgb, var(--secondary) 18%, transparent)}.input-field:disabled{color:var(--on-muted);background:var(--surface-high)}.ghost-field:after{content:"";background:color-mix(in srgb, var(--outline-variant) 45%, transparent);border-radius:99px;height:2px}.ghost-field:focus-within:after{background:var(--secondary)}.ghost-field input:disabled,.ghost-field textarea:disabled,.form input:disabled,.form textarea:disabled{color:var(--on-muted);background:var(--surface-high)}.form textarea{resize:vertical}.form input,.form select,.form textarea,.ghost-field input,.ghost-field select,.ghost-field textarea,.input-field{min-height:52px;line-height:1.3}input[type=date],input[type=time],input[type=datetime-local]{min-height:52px}.form textarea,.ghost-field textarea,textarea.input-field{min-height:104px;line-height:1.5}.error-text{color:var(--error);font-weight:800}.success-text{color:#246b35;font-weight:800}.hint-text{color:var(--on-muted);font-size:14px}.status-pill{min-height:32px;color:var(--primary);background:var(--secondary-fixed);border-radius:12px;justify-content:center;align-items:center;padding:7px 12px;font-size:12px;font-weight:900;display:inline-flex}.status-pill.status-green{color:#166534;background:#dcfce7}.status-pill.status-yellow{color:#854d0e;background:#fef9c3}.status-pill.status-red{color:#991b1b;background:#fee2e2}.status-pill.status-blue{color:#1e40af;background:#dbeafe}.status-pill.status-purple{color:#6b21a8;background:#f3e8ff}.status-panel{gap:10px;padding:18px;display:grid}.compact-panel{padding:14px}.stats-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.stat-card{background:var(--surface-lowest);text-align:center;border-radius:16px;align-content:center;justify-items:center;gap:4px;min-height:92px;padding:14px;display:grid;box-shadow:0 8px 28px #1b1b1e0a}.stat-card strong{color:var(--primary);font-family:Manrope,sans-serif;font-size:20px;line-height:1}.stat-card span{color:var(--on-muted);font-size:11px;font-weight:600}.action-list,.list{gap:12px;display:grid}.menu-item,.list-item{background:var(--surface-lowest);border-radius:16px;justify-content:space-between;align-items:center;gap:14px;padding:16px;display:flex;box-shadow:0 8px 28px #1b1b1e0a}.menu-icon{width:48px;height:48px;color:var(--secondary);background:var(--surface-low);border-radius:999px;flex:none;place-items:center;display:grid}.list-item p,.menu-item p{color:var(--on-muted);font-size:13px;line-height:1.4}.list-item strong,.menu-item strong{font-size:15px;font-weight:700;line-height:1.3}.status-pill{font-size:12px}.stacked-item{align-items:stretch;display:grid}.section-gap{margin-top:28px}.two-column{grid-template-columns:1fr 1fr;gap:12px;display:grid}.row-actions{justify-content:space-between;align-items:center;gap:12px;display:flex}.text-button{color:var(--error);background:0 0;border:0;padding:8px 0;font-weight:900}.bottom-nav{z-index:20;width:min(430px,100%);padding:10px 14px calc(20px + env(safe-area-inset-bottom,0px));background:var(--surface);border-radius:22px 22px 0 0;grid-template-columns:repeat(5,1fr);gap:4px;display:grid;position:fixed;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 -12px 32px #1b1b1e14}.bottom-nav a{min-height:48px;color:var(--on-muted);letter-spacing:.02em;text-transform:uppercase;touch-action:manipulation;-webkit-tap-highlight-color:transparent;border-radius:12px;align-content:center;place-items:center;gap:2px;font-size:9px;font-weight:700;display:grid}.bottom-nav a.router-link-active{color:#fff;background:var(--primary)}.bottom-nav .material-symbols-outlined{font-size:20px}.step-list{gap:8px;display:grid}.step-item{min-height:44px;color:var(--on-muted);grid-template-columns:30px 1fr;align-items:center;gap:10px;display:grid}.step-item span{background:var(--surface-low);border-radius:999px;place-items:center;width:30px;height:30px;font-size:13px;font-weight:900;display:grid}.step-item.active{color:var(--secondary);font-weight:900}.step-item.active span{color:#fff;background:var(--secondary)}.login-page{padding-inline:24px;padding-top:max(44px, env(safe-area-inset-top,44px));padding-bottom:max(32px, env(safe-area-inset-bottom,32px));align-content:center;gap:44px;min-height:100svh;display:grid}.login-page:before{content:"";background:linear-gradient(180deg, var(--surface-low), transparent);pointer-events:none;height:280px;position:fixed;inset:0 0 auto}.login-page>*{position:relative}.clock-page{padding:0 0 104px}.clock-header{background:var(--surface);grid-template-columns:44px 1fr 44px;align-items:center;gap:8px;padding:18px 20px 14px;display:grid}.camera-stage{color:#fff;background:radial-gradient(circle at 50% 42%,#005fac38,#0000 30%),linear-gradient(135deg,#0f1624,#00071b);border-radius:0 0 34px 34px;place-items:center;min-height:min(430px,58svh);display:grid;position:relative;overflow:hidden}.face-guide{border:4px solid var(--secondary);background:#00071b38;border-radius:108px;place-items:center;width:min(70vw,270px);height:320px;display:grid;position:relative;box-shadow:0 0 28px #005fac6b}.face-guide:after{content:"";background:var(--secondary);height:4px;position:absolute;top:50%;left:0;right:0;box-shadow:0 0 18px #005faccc}.camera-status{min-width:240px;color:var(--on-surface);background:var(--surface-low);border-radius:999px;justify-content:center;align-items:center;gap:10px;padding:13px 18px;display:inline-flex;position:absolute;bottom:24px;left:50%;transform:translate(-50%)}.clock-content{gap:18px;padding:24px;display:grid}.leave-total{padding:24px}.leave-total strong{font-family:Manrope,sans-serif;font-size:64px;line-height:.95;display:block}.field-wrap{gap:0;display:grid}.field--error .ghost-field:after{background:var(--error)}.field-error-msg{color:var(--error);margin-top:4px;font-size:12px;font-weight:700}.field-icon{color:var(--on-muted);pointer-events:none;font-size:20px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.ghost-field:has(.field-icon) input{padding-left:44px}.btn-spinner{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.step-item.done span{color:#166534;background:#dcfce7}.camera-status--error{color:var(--error);border:1px solid #ba1a1a4d}.camera-status--done{color:#166534;border:1px solid #1665344d}.panel--error{background:#ba1a1a0d;border:1px solid #ba1a1a40}.slide-down-enter-active{transition:all .3s}.slide-down-leave-active{transition:all .2s}.slide-down-enter-from{opacity:0;transform:translateY(-12px)}.slide-down-leave-to{opacity:0;transform:translateY(-6px)}.toast-container[data-v-8b329223]{z-index:9999;pointer-events:none;flex-direction:column;gap:8px;width:min(100vw - 32px,480px);display:flex;position:fixed;bottom:90px;left:50%;transform:translate(-50%)}.toast[data-v-8b329223]{cursor:pointer;pointer-events:all;border-radius:14px;align-items:center;gap:10px;padding:12px 16px;font-size:14px;font-weight:500;display:flex;box-shadow:0 4px 24px #0000002e}.toast--success[data-v-8b329223]{color:#fff;background:#1a6835}.toast--error[data-v-8b329223]{color:#fff;background:#ba1a1a}.toast--info[data-v-8b329223]{color:#fff;background:#0f1f3d}.toast-icon[data-v-8b329223]{flex-shrink:0;font-size:20px}.toast-msg[data-v-8b329223]{line-height:1.4}.toast-enter-active[data-v-8b329223]{transition:all .3s cubic-bezier(.34,1.56,.64,1)}.toast-leave-active[data-v-8b329223]{transition:all .25s}.toast-enter-from[data-v-8b329223]{opacity:0;transform:translateY(20px)scale(.95)}.toast-leave-to[data-v-8b329223]{opacity:0;transform:translateY(-8px)scale(.96)}.slide-up-enter-active[data-v-155e0bf4],.slide-up-leave-active[data-v-155e0bf4]{transition:transform .35s cubic-bezier(.4,0,.2,1),opacity .35s}.slide-up-enter-from[data-v-155e0bf4],.slide-up-leave-to[data-v-155e0bf4]{opacity:0;transform:translateY(100%)}.v-enter-active[data-v-8bca0094],.v-leave-active[data-v-8bca0094]{transition:opacity .3s,transform .3s}.v-enter-from[data-v-8bca0094],.v-leave-to[data-v-8bca0094]{opacity:0;transform:scale(.85)}.fade-slide-enter-active[data-v-8bca0094],.fade-slide-leave-active[data-v-8bca0094]{transition:opacity .2s,transform .2s}.fade-slide-enter-from[data-v-8bca0094],.fade-slide-leave-to[data-v-8bca0094]{opacity:0;transform:translateY(4px)}
