:root{--brand-navy:#0f172a;--brand-blue:#1a73e8;--brand-blue-hover:#1557b0;--brand-blue-soft:#e8f0fe;--brand-cyan:#0891b2;--brand-navy-deep:#14365f;--text-on-dark-muted:#cbd5e1;--surface:#fff;--surface-muted:#f8fafc;--surface-soft:#f1f5f9;--bg-primary:#f6f8fb;--bg-secondary:var(--surface);--bg-card:var(--surface);--bg-card-hover:var(--surface-soft);--bg-input:var(--surface);--bg-surface:var(--surface-soft);--bg-muted:var(--surface-muted);--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--text-inverse:#fff;--accent:var(--brand-blue);--accent-hover:var(--brand-blue-hover);--accent-muted:var(--brand-blue-soft);--accent-text:#fff;--success:#0d904f;--success-bg:#ecfdf5;--warning:#b45309;--warning-bg:#fff7ed;--danger:#dc2626;--danger-bg:#fef2f2;--info:#2563eb;--info-bg:#eff6ff;--border:#e2e8f0;--border-light:#edf2f7;--shadow:0 1px 3px #0f172a14, 0 1px 2px #0f172a0d;--shadow-lg:0 10px 24px #0f172a1f, 0 3px 8px #0f172a14;--shadow-card:0 1px 2px #0f172a0d, 0 6px 18px #0f172a0a;--accent-shadow:0 6px 16px #1a73e838;--radius-sm:8px;--radius:12px;--radius-lg:16px;--radius-xl:24px;--font:"Inter", -apple-system, BlinkMacSystemFont, "Roboto", sans-serif;--header-h:52px;--bottom-nav-h:56px;--safe-bottom:env(safe-area-inset-bottom,0px)}*,:before,:after{box-sizing:border-box;-webkit-user-select:none;user-select:none;margin:0;padding:0}input,textarea,select,[contenteditable=true]{-webkit-user-select:text;user-select:text}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;font-size:14px}body{font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100dvh;line-height:1.5;overflow-x:hidden}#root{flex-direction:column;min-height:100dvh;display:flex}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.app-header{height:var(--header-h);background:var(--bg-secondary);border-bottom:1px solid var(--border);z-index:100;box-shadow:var(--shadow);justify-content:space-between;align-items:center;width:100%;max-width:480px;margin:0 auto;padding:0 12px;display:flex;position:sticky;top:0;left:0;right:0}.header-brand{align-items:center;gap:8px;display:flex}.header-icon{border-radius:6px;width:30px;height:30px}.header-text{line-height:1.15}.header-title{color:var(--text-primary);letter-spacing:.02em;font-size:.92rem;font-weight:700}.header-version{color:var(--text-muted);letter-spacing:.02em;font-size:.6rem}.header-actions{align-items:center;gap:2px;display:flex}.header-btn{width:36px;height:36px;color:var(--text-secondary);cursor:pointer;touch-action:manipulation;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.header-btn:active{background:var(--bg-surface)}.header-btn-logout{color:var(--danger)}.header-btn-logout:active{background:var(--danger-bg)}.page{padding:16px 16px calc(var(--bottom-nav-h) + var(--safe-bottom) + 16px);flex:1;width:100%;max-width:480px;margin:0 auto;animation:.2s fadeIn}.page-header{margin-bottom:16px}.page-title{color:var(--text-primary);letter-spacing:0;font-size:1.35rem;font-weight:700}.page-subtitle{color:var(--text-secondary);margin-top:2px;font-size:.82rem}.page-topbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.page-heading{min-width:0}.page-heading-title{color:var(--text-primary);letter-spacing:0;font-size:1.4rem;font-weight:800;line-height:1.15}.page-heading-subtitle{color:var(--text-secondary);margin-top:3px;font-size:.78rem;font-weight:600}.notice{border-radius:10px;margin-bottom:12px;padding:10px 14px;font-size:.82rem;font-weight:700}.notice-error{background:var(--danger-bg);color:var(--danger)}.notice-success{background:var(--success-bg);color:var(--success);text-align:center}.stats-filter-strip{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:6px;margin-bottom:12px;padding-bottom:6px;display:flex;overflow-x:auto}.stats-filter-card{border:1px solid var(--border-light);background:var(--surface);min-width:72px;color:var(--text-primary);text-align:center;box-shadow:var(--shadow);cursor:pointer;touch-action:manipulation;border-radius:12px;flex:0 0 72px;padding:10px 8px;transition:border-color .15s,box-shadow .15s,background .15s,color .15s}.stats-filter-card-active{background:var(--brand-navy);color:var(--text-inverse);border-color:var(--brand-navy)}.stats-filter-value{font-size:1.25rem;font-weight:800;line-height:1.15}.stats-filter-label{color:currentColor;opacity:.62;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:.56rem;overflow:hidden}.active-filter-bar{background:var(--surface-soft);border:1px solid var(--border-light);border-radius:10px;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;padding:8px 12px;display:flex}.active-filter-text{color:var(--text-primary);font-size:.72rem;font-weight:700}.active-filter-clear{color:var(--text-secondary);font-family:var(--font);cursor:pointer;background:0 0;border:none;font-size:.72rem;font-weight:700}.card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-card);margin-bottom:10px;padding:14px;transition:background .15s}.card-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.card-title{color:var(--text-primary);font-size:.88rem;font-weight:600}.card-badge{text-transform:uppercase;letter-spacing:.04em;border-radius:99px;padding:3px 10px;font-size:.7rem;font-weight:600}.badge-pending{background:var(--warning-bg);color:var(--warning)}.badge-approved{background:var(--success-bg);color:var(--success)}.badge-applied{background:var(--accent-muted);color:var(--accent)}.badge-failed{background:var(--danger-bg);color:var(--danger)}.stats-row{grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:8px;margin-bottom:12px;display:grid}.stat-card{background:var(--bg-card);border-radius:var(--radius);text-align:center;box-shadow:var(--shadow);padding:12px 10px}.stat-card-tap{cursor:pointer;touch-action:manipulation;border:1.5px solid #0000;transition:border-color .15s,box-shadow .15s,transform .1s}.stat-card-tap:active{transform:scale(.96)}.stat-card-active{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-muted), var(--shadow)}.stat-value{color:var(--accent);font-size:1.4rem;font-weight:700;line-height:1.2}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:2px;font-size:.68rem}.info-row{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:9px 0;font-size:.85rem;display:flex}.info-row:last-child{border-bottom:none}.info-label{color:var(--text-secondary)}.info-value{color:var(--text-primary);text-align:right;font-weight:500}.btn{border-radius:var(--radius-sm);font-family:var(--font);cursor:pointer;touch-action:manipulation;border:none;justify-content:center;align-items:center;gap:6px;width:100%;padding:10px 18px;font-size:.88rem;font-weight:600;transition:all .15s;display:inline-flex}.btn-primary{background:var(--accent);color:var(--accent-text);box-shadow:var(--accent-shadow)}.btn-primary:active{background:var(--accent-hover);transform:scale(.98)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--bg-surface);color:var(--text-primary)}.btn-secondary:active{background:var(--bg-card-hover)}.btn-danger{background:var(--danger-bg);color:var(--danger)}.btn-sm{border-radius:20px;padding:7px 14px;font-size:.78rem}.form-group{margin-bottom:14px}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:5px;font-size:.75rem;font-weight:500;display:block}.form-input{background:var(--bg-input);border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font);appearance:none;padding:11px 14px;font-size:.92rem;transition:border-color .15s,box-shadow .15s}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted);outline:none}.form-input::placeholder{color:var(--text-muted)}select.form-input{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235f6368' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}.bottom-nav{height:calc(var(--bottom-nav-h) + var(--safe-bottom));background:var(--bg-secondary);border-top:1px solid var(--border);padding-top:6px;padding-bottom:var(--safe-bottom);z-index:100;align-items:flex-start;width:100%;max-width:480px;margin:0 auto;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{color:var(--text-muted);cursor:pointer;touch-action:manipulation;background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:2px;padding:4px 0;font-size:.62rem;font-weight:500;text-decoration:none;transition:color .15s;display:flex;position:relative}.nav-item.active{color:var(--accent)}.nav-item.active:before{content:"";background:var(--accent-muted);z-index:-1;border-radius:14px;width:48px;height:28px;position:absolute;top:-6px;left:50%;transform:translate(-50%)}.nav-icon{width:22px;height:22px}.pwa-banner{bottom:calc(var(--bottom-nav-h) + var(--safe-bottom) + 8px);background:var(--accent);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:200;align-items:center;gap:10px;padding:12px 14px;animation:.3s slideUp;display:flex;position:fixed;left:12px;right:12px}.pwa-banner-text{color:var(--text-inverse);flex:1;font-size:.82rem;font-weight:500}.pwa-banner-btn{color:var(--text-inverse);font-family:var(--font);cursor:pointer;white-space:nowrap;background:#ffffff40;border:none;border-radius:20px;padding:7px 16px;font-size:.78rem;font-weight:600}.pwa-banner-btn:active{background:#ffffff59}.pwa-banner-close{color:#ffffffb3;cursor:pointer;touch-action:manipulation;background:0 0;border:none;margin-left:-4px;padding:4px 6px;font-size:1.1rem;line-height:1}.pwa-banner-close:active{color:var(--text-inverse)}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;animation:.6s linear infinite spin}.loading-center{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:40px 0;font-size:.82rem;display:flex}.month-picker{align-items:center;gap:10px;margin-bottom:14px;display:flex}.month-picker-control{border:1px solid var(--border);background:var(--surface);height:40px;box-shadow:var(--shadow);border-radius:10px;align-items:center;display:inline-flex;overflow:hidden}.month-picker-button{background:var(--accent-muted);width:42px;height:100%;color:var(--brand-navy);cursor:pointer;touch-action:manipulation;border:none;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.month-picker-button:active{background:var(--brand-blue-soft)}.month-picker-button:disabled{background:var(--surface-muted);color:var(--border);cursor:not-allowed}.month-picker-button-prev{border-right:1px solid var(--border)}.month-picker-button-next{border-left:1px solid var(--border)}.month-picker-label{background:var(--surface-muted);min-width:88px;height:100%;color:var(--brand-navy);white-space:nowrap;justify-content:center;align-items:center;padding:0 12px;font-size:.9rem;font-weight:800;display:flex}.month-picker button{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;touch-action:manipulation;width:34px;height:34px;box-shadow:var(--shadow);border-radius:50%;justify-content:center;align-items:center;font-size:1rem;display:flex}.month-picker button:active{background:var(--bg-card-hover)}.month-current{text-align:center;color:var(--text-primary);flex:1;font-size:.92rem;font-weight:600}.login-container{background:var(--bg-primary);z-index:1;flex-direction:column;justify-content:center;align-items:center;height:100dvh;padding:24px;display:flex;position:relative;overflow:hidden}.login-container:before{content:"";z-index:-1;background:linear-gradient(135deg,#1a73e80d,#0000 64%);border-radius:50%;width:70vmin;height:70vmin;position:absolute;top:-20vh;right:-20vw}.login-container:after{content:"";z-index:-1;background:linear-gradient(135deg,#0000,#0891b20d);border-radius:50%;width:60vmin;height:60vmin;position:absolute;bottom:-20vh;left:-20vw}.login-brand{align-items:center;gap:14px;margin-bottom:20px;display:flex}.login-logo{border-radius:14px;flex-shrink:0;width:52px;height:52px}.login-title{color:var(--brand-navy);letter-spacing:.12em;margin:0;font-size:1.65rem;font-weight:800}.login-form{background:var(--surface);width:100%;max-width:360px;box-shadow:var(--shadow-lg);border:1px solid var(--border-light);border-radius:20px;padding:32px 28px}.login-error{background:var(--danger-bg);color:var(--danger);text-align:center;border:1px solid #dc262633;border-radius:8px;margin-bottom:20px;padding:10px 14px;font-size:.85rem;font-weight:500}.login-tabs{background:var(--surface-muted);border-radius:12px;gap:4px;margin-bottom:24px;padding:4px;display:flex}.login-tab{color:var(--text-muted);font-family:var(--font);cursor:pointer;touch-action:manipulation;background:0 0;border:none;border-radius:10px;flex:1;padding:10px 8px;font-size:.8rem;font-weight:600;transition:all .2s}.login-tab-active{background:var(--surface);color:var(--brand-navy);font-weight:700;box-shadow:0 1px 3px #00000014}.search-results{flex-direction:column;gap:8px;margin-top:4px;display:flex}.search-result-card{background:var(--surface-muted);border:1.5px solid var(--border-light);cursor:pointer;touch-action:manipulation;text-align:left;font-family:var(--font);border-radius:12px;align-items:center;gap:12px;width:100%;padding:12px 14px;transition:all .15s;display:flex}.search-result-card:active{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-muted);transform:scale(.98)}.search-result-avatar{background:linear-gradient(145deg, var(--accent-muted) 0%, var(--brand-blue-soft) 100%);width:40px;height:40px;color:var(--accent);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:800;display:flex}.search-result-info{flex:1;min-width:0}.search-result-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:.88rem;font-weight:700;line-height:1.3;overflow:hidden}.search-result-meta{color:var(--text-muted);margin-top:2px;font-size:.72rem}.search-result-arrow{width:18px;height:18px;color:var(--text-muted);flex-shrink:0}.search-loading{color:var(--text-muted);justify-content:center;align-items:center;gap:8px;padding:16px 0;font-size:.82rem;display:flex}.selected-employee{background:var(--accent-muted);border:1.5px solid var(--accent);border-radius:12px;align-items:center;gap:10px;margin-bottom:20px;padding:12px 14px;display:flex}.selected-employee-avatar{background:var(--accent);width:36px;height:36px;color:var(--text-inverse);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:.9rem;font-weight:800;display:flex}.selected-employee-info{flex:1;min-width:0}.selected-employee-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:.85rem;font-weight:700;line-height:1.3;overflow:hidden}.selected-employee-meta{color:var(--text-secondary);margin-top:1px;font-size:.7rem}.selected-employee-change{border:1px solid var(--accent);color:var(--accent);font-family:var(--font);cursor:pointer;touch-action:manipulation;background:0 0;border-radius:8px;flex-shrink:0;padding:5px 12px;font-size:.72rem;font-weight:700}.selected-employee-change:active{background:var(--accent);color:var(--text-inverse)}.tl{padding:0 0 20px}.tl-row{align-items:stretch;gap:10px;margin-bottom:8px;display:flex}.tl-date-col{background:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border-light);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:48px;padding:8px 0;display:flex}.tl-day{color:var(--text-primary);font-size:1.6rem;font-weight:800;line-height:1.15}.tl-dow{color:var(--text-muted);text-transform:capitalize;letter-spacing:.02em;font-size:.6rem}.tl-today .tl-date-col{background:var(--accent);border-color:var(--accent);border-radius:var(--radius-sm)}.tl-today .tl-day,.tl-today .tl-dow{color:var(--text-inverse)}.tl-today .tl-card{box-shadow:0 0 0 2px var(--accent-muted), var(--shadow)}.tl-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);border-left:3px solid var(--border);flex:1;min-width:0;padding:0;overflow:hidden}.tl-card-present{border-left-color:var(--success)}.tl-card-incomplete{border-left-color:var(--warning)}.tl-card-holiday{border-left-color:var(--info);background:var(--info-bg)}.tl-card-off{border-left-color:var(--border);opacity:.55}.tl-card-content{padding:10px 12px}.tl-card-empty{color:var(--text-muted);align-items:center;min-height:42px;font-size:.82rem;font-weight:500;display:flex}.tl-holiday-label{color:var(--danger);align-items:center;gap:5px;font-size:.82rem;font-weight:600;display:flex}.tl-card-sub{color:var(--text-muted);margin-top:2px;font-size:.68rem}.profile-page-header{margin-bottom:14px}.profile-hero{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);align-items:center;gap:14px;margin-bottom:10px;padding:16px;display:flex}.profile-avatar{background:linear-gradient(145deg, var(--accent-muted) 0%, var(--brand-blue-soft) 100%);width:58px;height:58px;color:var(--accent);letter-spacing:.03em;border-radius:18px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.25rem;font-weight:800;display:flex;box-shadow:inset 0 1px #ffffffbf}.profile-identity{flex:1;min-width:0}.profile-name{color:var(--text-primary);overflow-wrap:anywhere;font-size:1.02rem;font-weight:800;line-height:1.25}.profile-noreg{color:var(--text-muted);margin-top:3px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.72rem}.profile-chip-row{flex-wrap:wrap;gap:6px;margin-top:9px;display:flex}.profile-chip{border-radius:8px;align-items:center;gap:5px;padding:4px 8px;font-size:.68rem;font-weight:800;line-height:1;display:inline-flex}.profile-chip-label{opacity:.62;font-weight:700}.profile-chip-success{background:var(--success-bg);color:var(--success)}.profile-chip-danger{background:var(--danger-bg);color:var(--danger)}.profile-chip-blue{background:var(--accent-muted);color:var(--accent)}.profile-section{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow-card);margin-bottom:10px;padding:4px 14px}.profile-section-title{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);padding:12px 0 6px;font-size:.62rem;font-weight:800}.profile-info-row{border-bottom:1px solid var(--border-light);grid-template-columns:minmax(88px,.42fr) minmax(0,1fr);align-items:start;gap:14px;padding:10px 0;display:grid}.profile-info-row-last{border-bottom:none}.profile-info-label{color:var(--text-muted);font-size:.78rem;line-height:1.35}.profile-info-value{color:var(--text-primary);text-align:right;overflow-wrap:anywhere;font-size:.82rem;font-weight:700;line-height:1.35}.profile-security{padding:14px}.profile-security-header{justify-content:space-between;align-items:center;display:flex}.profile-security-header-open{margin-bottom:12px}.profile-security-title{color:var(--text-primary);font-size:.88rem;font-weight:800}.profile-pin-button{background:var(--bg-surface);color:var(--text-primary);font-family:var(--font);cursor:pointer;touch-action:manipulation;border:none;border-radius:9px;padding:7px 14px;font-size:.74rem;font-weight:800}.profile-pin-button:active{background:var(--bg-card-hover)}.profile-pin-message{border-radius:8px;margin-bottom:10px;padding:8px 12px;font-size:.78rem;font-weight:700}.profile-pin-message-success{background:var(--success-bg);color:var(--success)}.profile-pin-message-error{background:var(--danger-bg);color:var(--danger)}.profile-form-label{color:var(--text-secondary);font-size:.7rem}.profile-pin-actions{gap:8px;display:flex}.profile-action-button{font-family:var(--font);cursor:pointer;touch-action:manipulation;border:none;border-radius:10px;flex:1;padding:10px;font-size:.82rem;font-weight:800}.profile-action-secondary{background:var(--bg-surface);color:var(--text-secondary)}.profile-action-primary{background:var(--text-primary);color:var(--text-inverse)}.profile-action-primary:disabled{opacity:.6;cursor:not-allowed}.slip-total{color:var(--accent);text-align:center;padding:16px 0;font-size:1.5rem;font-weight:700}.slip-category{color:var(--accent);text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--accent-muted);margin-bottom:4px;padding:10px 0 4px;font-size:.78rem;font-weight:600}.pay-ledger-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow-card);margin-bottom:10px;padding:14px}.pay-ledger-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px;display:flex}.pay-ledger-title{color:var(--text-primary);font-size:.88rem;font-weight:800}.pay-ledger-subtitle{color:var(--text-muted);margin-top:2px;font-size:.72rem;font-weight:600}.pay-ledger-count{background:var(--bg-surface);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;border-radius:8px;flex-shrink:0;padding:4px 8px;font-size:.66rem;font-weight:800}.pay-ledger-list{margin-top:4px}.pay-ledger-row{grid-template-columns:4px minmax(0,1fr) auto;align-items:center;gap:10px;padding:11px 0;display:grid;position:relative}.pay-ledger-marker{border-radius:4px;width:4px;height:34px}.pay-ledger-main{min-width:0}.pay-ledger-name{color:var(--text-primary);font-size:.82rem;font-weight:800}.pay-ledger-date{color:var(--text-muted);margin-top:2px;font-size:.72rem;font-weight:600}.pay-ledger-side{flex-direction:column;align-items:flex-end;gap:4px;min-width:112px;display:flex}.pay-ledger-amount{color:var(--text-primary);font-size:.95rem;font-weight:800;line-height:1.15}.pay-ledger-status{border-radius:7px;padding:3px 7px;font-size:.62rem;font-weight:800;line-height:1}.pay-ledger-status-paid{background:var(--success-bg);color:var(--success)}.pay-ledger-status-pending{background:var(--warning-bg);color:var(--warning)}.pay-ledger-divider{background:var(--border-light);height:1px;position:absolute;bottom:0;left:14px;right:0}.overtime-tabs{background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:12px;grid-auto-columns:1fr;grid-auto-flow:column;gap:6px;margin-bottom:14px;padding:4px;display:grid}.overtime-tab{background:var(--surface-muted);min-height:36px;color:var(--text-secondary);font-family:var(--font);cursor:pointer;touch-action:manipulation;border:1px solid #0000;border-radius:9px;font-size:.8rem;font-weight:800;transition:background .15s,color .15s,box-shadow .15s,border-color .15s}.overtime-tab-active{background:var(--brand-navy);color:var(--text-inverse);border-color:var(--brand-navy);box-shadow:0 2px 8px #0f172a29}.overtime-summary-grid{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px;display:grid}.overtime-summary-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow-card);text-align:center;padding:12px 8px}.overtime-summary-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px;font-size:.6rem;font-weight:800}.overtime-summary-value{color:var(--text-primary);font-size:1.35rem;font-weight:800;line-height:1.15}.overtime-fab{right:max(18px,50vw - 222px);bottom:calc(var(--bottom-nav-h) + var(--safe-bottom) + 18px);background:var(--accent);width:54px;height:54px;color:var(--text-inverse);box-shadow:var(--accent-shadow), 0 2px 6px #0f172a24;cursor:pointer;touch-action:manipulation;z-index:120;border:none;border-radius:18px;justify-content:center;align-items:center;display:flex;position:fixed}.overtime-fab:active{transform:translateY(1px)scale(.98)}.overtime-modal{background:var(--bg-primary);z-index:320;flex-direction:column;width:100%;max-width:480px;margin:0 auto;animation:.2s slideUp;display:flex;position:fixed;inset:0}.overtime-modal-header{background:var(--bg-secondary);border-bottom:1px solid var(--border);min-height:58px;box-shadow:var(--shadow);justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.overtime-modal-title{color:var(--text-primary);font-size:1rem;font-weight:800}.overtime-modal-subtitle{color:var(--text-secondary);margin-top:1px;font-size:.74rem;font-weight:600}.overtime-modal-close{background:var(--bg-surface);width:38px;height:38px;color:var(--text-secondary);cursor:pointer;touch-action:manipulation;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.overtime-modal-body{min-height:0;padding:16px 16px calc(var(--safe-bottom) + 20px);flex:1;overflow-y:auto}.overtime-form{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:14px}.overtime-form-date{z-index:2;background:var(--bg-card);border-bottom:1px solid var(--border-light);border-radius:var(--radius) var(--radius) 0 0;margin:-14px -14px 14px;padding:14px;position:sticky;top:-16px}.overtime-form-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin:14px 0 8px;font-size:.64rem;font-weight:800}.overtime-task-input{resize:vertical;min-height:88px;line-height:1.45}.empty-state{text-align:center;color:var(--text-muted);padding:40px 20px}.empty-icon{opacity:.6;margin-bottom:8px;font-size:2.5rem}.empty-text{color:var(--text-secondary);font-size:.88rem}.info-guide{flex-direction:column;gap:10px;display:flex}.guide-item{align-items:flex-start;gap:10px;display:flex}.guide-num{background:var(--accent-muted);width:24px;height:24px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;font-size:.72rem;font-weight:700;display:flex}.guide-title{color:var(--text-primary);font-size:.85rem;font-weight:600}.guide-desc{color:var(--text-secondary);margin-top:1px;font-size:.78rem}.welcome-container{background:var(--bg-primary);z-index:1;flex-direction:column;justify-content:center;align-items:center;height:100dvh;padding:32px 24px;display:flex;position:relative;overflow:hidden}.welcome-bg-circle{z-index:-1;border-radius:50%;position:absolute}.welcome-bg-circle-1{background:radial-gradient(circle,#1a73e814 0%,#0000 70%);width:65vmin;height:65vmin;top:-15vh;right:-15vw}.welcome-bg-circle-2{background:radial-gradient(circle,#0891b20f 0%,#0000 70%);width:55vmin;height:55vmin;bottom:-12vh;left:-12vw}.welcome-brand{flex-direction:column;align-items:center;margin-bottom:48px;animation:.8s both welcomeFadeIn;display:flex}.welcome-logo{border-radius:22px;width:88px;height:88px;margin-bottom:20px;box-shadow:0 8px 32px #0f172a1f}.welcome-title{color:var(--brand-navy);letter-spacing:.15em;margin:0;font-size:2.2rem;font-weight:800;line-height:1}.welcome-tagline{color:var(--text-secondary);letter-spacing:.02em;margin-top:8px;font-size:.88rem;font-weight:500}.welcome-actions{flex-direction:column;gap:12px;width:100%;max-width:320px;animation:.8s .3s both welcomeFadeIn;display:flex}.welcome-install-btn{background:var(--accent);width:100%;color:var(--text-inverse);font-family:var(--font);cursor:pointer;box-shadow:var(--accent-shadow);touch-action:manipulation;border:none;border-radius:14px;justify-content:center;align-items:center;gap:10px;padding:14px 20px;font-size:.95rem;font-weight:700;transition:transform .15s,box-shadow .15s;display:flex}.welcome-install-btn:active{transform:scale(.97)}.welcome-installed{background:var(--success-bg);color:var(--success);border-radius:14px;justify-content:center;align-items:center;gap:10px;padding:14px 20px;font-size:.92rem;font-weight:700;display:flex}.welcome-ios-guide{background:var(--surface);border:1px solid var(--border-light);box-shadow:var(--shadow-card);border-radius:14px;flex-direction:column;gap:12px;padding:14px 16px;animation:.2s fadeIn;display:flex}.welcome-ios-step{color:var(--text-secondary);align-items:flex-start;gap:10px;font-size:.82rem;line-height:1.4;display:flex}.welcome-ios-num{background:var(--accent-muted);width:22px;height:22px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;font-size:.7rem;font-weight:700;display:flex}.welcome-continue-btn{border:1.5px solid var(--border);background:var(--surface);width:100%;color:var(--brand-navy);font-family:var(--font);cursor:pointer;touch-action:manipulation;box-shadow:var(--shadow);border-radius:14px;justify-content:center;align-items:center;gap:8px;padding:14px 20px;font-size:.92rem;font-weight:700;transition:all .15s;display:flex}.welcome-continue-btn:active{background:var(--surface-soft);transform:scale(.97)}.welcome-hint{text-align:center;color:var(--text-muted);margin-top:8px;font-size:.72rem;font-weight:500;line-height:1.4}.welcome-modal-overlay{z-index:500;-webkit-backdrop-filter:blur(8px);background:#0f172aa6;justify-content:center;align-items:center;padding:24px;animation:.3s both welcomeOverlayIn;display:flex;position:fixed;inset:0}@keyframes welcomeOverlayIn{0%{opacity:0}to{opacity:1}}.welcome-modal-card{background:var(--bg-card);border-radius:20px;flex-direction:column;align-items:center;gap:10px;width:100%;max-width:320px;padding:28px 24px 24px;animation:.4s .15s both welcomeCardIn;display:flex;box-shadow:0 16px 48px #0003}@keyframes welcomeCardIn{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.welcome-modal-icon{background:#4285f41a;border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:2px;display:flex}.welcome-modal-title{color:var(--text-primary);text-align:center;margin:0;font-size:1.05rem;font-weight:800;line-height:1.2}.welcome-modal-desc{color:var(--text-secondary);text-align:center;margin:0 0 4px;font-size:.78rem;line-height:1.5}.welcome-modal-chrome-btn{color:#fff;width:100%;font-family:var(--font);cursor:pointer;touch-action:manipulation;background:linear-gradient(135deg,#4285f4,#3367d6);border:none;border-radius:14px;justify-content:center;align-items:center;gap:8px;padding:13px 20px;font-size:.92rem;font-weight:700;transition:transform .15s;display:flex;box-shadow:0 4px 14px #4285f459}.welcome-modal-chrome-btn:active{transform:scale(.97)}.welcome-modal-copy-btn{border:1.5px solid var(--border);background:var(--bg-surface);width:100%;color:var(--text-primary);font-family:var(--font);cursor:pointer;touch-action:manipulation;border-radius:14px;justify-content:center;align-items:center;gap:7px;padding:11px 20px;font-size:.82rem;font-weight:700;transition:all .25s;display:flex}.welcome-modal-copy-btn:active{transform:scale(.97)}.welcome-modal-copy-success{background:var(--success-bg);color:var(--success);border-color:var(--success)}.welcome-modal-ios-hint{color:var(--text-muted);text-align:center;margin:4px 0 0;font-size:.72rem;line-height:1.4}@keyframes welcomeFadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.text-accent{color:var(--accent)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-muted{color:var(--text-muted)}.text-right{text-align:right}.text-center{text-align:center}.fw-600{font-weight:600}.fw-700{font-weight:700}.fs-sm{font-size:.78rem}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.gap-8{gap:8px}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-1{flex:1}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.skeleton-shimmer{background:linear-gradient(90deg, var(--surface-muted) 25%, var(--border-light) 50%, var(--surface-muted) 75%);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}
