:root{--bg: oklch(.985 .003 80);--surface: oklch(1 0 0);--surface-2: oklch(.97 .005 80);--border: oklch(.92 .004 80);--border-strong:oklch(.85 .005 80);--text: oklch(.22 .015 250);--text-muted: oklch(.52 .015 250);--text-dim: oklch(.65 .012 250);--brand: oklch(.58 .15 38);--brand-press: oklch(.5 .16 38);--brand-tint: oklch(.95 .04 38);--ok: oklch(.58 .13 145);--ok-tint: oklch(.96 .04 145);--warn: oklch(.68 .16 75);--warn-tint: oklch(.96 .06 75);--danger: oklch(.55 .18 25);--danger-tint: oklch(.96 .04 25);--line-green: oklch(.66 .18 150);--font-body: -apple-system, BlinkMacSystemFont, "PingFang TC", "Noto Sans TC", "Microsoft JhengHei", "Hiragino Sans", sans-serif;--font-num: ui-rounded, "SF Pro Rounded", "Helvetica Neue", system-ui, sans-serif;--fs-xs: 12px;--fs-sm: 13px;--fs-base: 16px;--fs-lg: 18px;--fs-xl: 22px;--fs-2xl: 28px;--fs-3xl: 36px;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-pill: 999px;--shadow-sm: 0 1px 2px oklch(.2 .015 250 / .04);--shadow-md: 0 2px 6px oklch(.2 .015 250 / .06), 0 1px 2px oklch(.2 .015 250 / .04);--shadow-lg: 0 8px 24px oklch(.2 .015 250 / .08), 0 2px 6px oklch(.2 .015 250 / .05)}*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:var(--font-body);font-size:var(--fs-base);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;overflow-x:hidden;max-width:100vw}#root{min-height:100vh}body{text-spacing-trim:space-all;hanging-punctuation:first;line-height:1.65}h1,h2,h3,h4{text-wrap:balance;margin:0;font-weight:600;letter-spacing:-.01em}p{text-wrap:pretty}button{font-family:inherit;cursor:pointer;-webkit-appearance:none}button:disabled{opacity:.5;cursor:not-allowed}input,select,textarea{font-family:inherit;font-size:var(--fs-base)}.num{font-family:var(--font-num);font-feature-settings:"tnum"}.muted{color:var(--text-muted)}.dim{color:var(--text-dim)}.divider{height:1px;background:var(--border)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--sp-4)}.card+.card{margin-top:var(--sp-3)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);min-height:44px;padding:0 var(--sp-4);border:1px solid transparent;border-radius:var(--r-md);font-size:var(--fs-base);font-weight:600;transition:background .12s ease}.btn-primary{background:var(--text);color:var(--surface)}.btn-primary:hover:not(:disabled){background:#2d343a}.btn-brand{background:var(--brand);color:#fff}.btn-brand:hover:not(:disabled){background:var(--brand-press)}.btn-line{background:var(--line-green);color:#fff}.btn-ghost{background:transparent;color:var(--text);border-color:var(--border)}.btn-ghost:hover:not(:disabled){background:var(--surface-2)}.btn-danger{background:var(--danger);color:#fff}.btn-block{width:100%}.btn-lg{min-height:56px;font-size:var(--fs-lg)}.pill{display:inline-flex;align-items:center;padding:2px var(--sp-2);border-radius:var(--r-pill);font-size:var(--fs-xs);font-weight:500;letter-spacing:.02em}.pill-ok{background:var(--ok-tint);color:var(--ok)}.pill-warn{background:var(--warn-tint);color:var(--warn)}.pill-danger{background:var(--danger-tint);color:var(--danger)}.pill-brand{background:var(--brand-tint);color:var(--brand)}.pill-mute{background:var(--surface-2);color:var(--text-muted)}.input{width:100%;min-height:44px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text);outline:none;transition:border-color .12s}.input:focus{border-color:var(--brand)}.input::placeholder{color:var(--text-dim)}.label{display:block;font-size:var(--fs-xs);color:var(--text-muted);margin-bottom:var(--sp-1);font-weight:500}.sticky-cta{position:sticky;bottom:0;background:linear-gradient(to top,var(--bg) 75%,color-mix(in oklch,var(--bg) 80%,transparent));padding:var(--sp-3) 0 calc(var(--sp-4) + env(safe-area-inset-bottom));margin:0 calc(-1 * var(--sp-3));padding-left:var(--sp-3);padding-right:var(--sp-3)}.row{display:flex;align-items:baseline;justify-content:space-between;gap:var(--sp-3);padding:var(--sp-2) 0}.row+.row{border-top:1px solid var(--border)}.row-label{color:var(--text-muted);font-size:var(--fs-sm)}.row-value{font-weight:500;text-align:right;min-width:0;word-break:break-all}.icon{width:18px;height:18px;flex-shrink:0}.icon-sm{width:14px;height:14px}.icon-lg{width:22px;height:22px}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.animate-in{animation:fade-in .2s ease-out}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#080c0f8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:var(--sp-4)}.modal-panel{background:var(--surface);border-radius:var(--r-lg);padding:var(--sp-5);max-width:480px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.shell{max-width:560px;margin:0 auto;padding:var(--sp-3);min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) var(--sp-1) var(--sp-4)}.brand{display:flex;align-items:baseline;gap:6px;font-size:var(--fs-lg);font-weight:700;letter-spacing:-.01em}.brand-mark{color:var(--brand)}.brand-version{font-size:11px;color:var(--text-dim);font-weight:500;padding:2px 6px;background:var(--surface-2);border-radius:999px}.hero-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--sp-5);box-shadow:var(--shadow-sm)}.status-row{display:flex;align-items:baseline;justify-content:space-between;padding:10px 0}.status-row+.status-row{border-top:1px dashed var(--border)}.big-num{font-family:var(--font-num);font-variant-numeric:tabular-nums;font-weight:600}.mode-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:var(--r-pill);font-size:var(--fs-sm);font-weight:600;margin-top:var(--sp-3)}.mode-tier1{background:var(--ok-tint);color:var(--ok)}.mode-tier2{background:var(--warn-tint);color:var(--warn)}.alert-warn{display:flex;gap:10px;padding:10px 12px;background:var(--warn-tint);color:var(--warn);border-radius:var(--r-sm);font-size:var(--fs-sm);margin-top:var(--sp-3);line-height:1.5}.alert-error{background:var(--danger-tint);color:var(--danger);padding:10px 12px;border-radius:var(--r-sm);font-size:var(--fs-sm)}.alert-ok{background:var(--ok-tint);color:var(--ok);padding:10px 12px;border-radius:var(--r-sm);font-size:var(--fs-sm)}.photo-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;min-height:130px;padding:var(--sp-4);background:var(--surface-2);border:1px dashed var(--border-strong);border-radius:var(--r-md);color:var(--text-muted);cursor:pointer;transition:border-color .12s,background .12s}.photo-zone:hover{border-color:var(--brand);color:var(--brand)}.photo-zone-have{background:var(--ok-tint);border:1px solid var(--ok);color:var(--ok)}.photo-preview{width:100%;max-height:240px;object-fit:cover;border-radius:var(--r-md);margin-top:var(--sp-3)}.section-title{font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:600;margin-bottom:var(--sp-3)}.punch-item{display:flex;gap:var(--sp-3);padding:var(--sp-3) 0;border-bottom:1px solid var(--border)}.punch-item:last-child{border-bottom:none}.punch-icon{width:36px;height:36px;border-radius:var(--r-pill);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:var(--fs-sm);font-weight:700}.punch-icon-in{background:var(--ok-tint);color:var(--ok)}.punch-icon-out{background:var(--brand-tint);color:var(--brand)}.tabs{display:flex;gap:4px;padding:4px;background:var(--surface-2);border-radius:var(--r-md);margin-bottom:var(--sp-3);overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{flex:1 0 auto;min-width:max-content;padding:8px 14px;background:transparent;border:none;border-radius:8px;font-size:var(--fs-sm);font-weight:500;color:var(--text-muted);white-space:nowrap}.tab.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm);font-weight:600}@media(max-width:480px){.shell{padding:var(--sp-2)}}
