:root{--bg:#f9fafb;--text:#111827;--muted:#6b7280;--card:#fff;--border:#e5e7eb;--brand:#2563eb;--brand-ink:#111827;--warn-bg:#fffbeb;--radius:14px;--shadow-soft:0 6px 20px rgba(0,0,0,.06);--shadow-hover:0 10px 28px rgba(0,0,0,.1);--shadow-card:0 10px 30px rgba(0,0,0,.08);--container-w:720px}*{box-sizing:border-box}body,html{padding:0;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;background:var(--bg);color:var(--text)}hr{border:0;border-top:1px solid #eee;margin:16px 0}.page{min-height:100vh;background:var(--bg)}.container{max-width:var(--container-w);margin:0 auto;padding:16px}.grid{display:grid;grid-gap:10px;gap:10px}.grid.two{grid-template-columns:1fr 1fr}.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.h1{font-size:22px;font-weight:800}.h2{font-size:18px;font-weight:700}.note{font-size:12px;color:var(--muted)}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin:10px 0;box-shadow:var(--shadow-soft);transition:box-shadow .18s ease,transform .18s ease;will-change:transform}.card:hover{box-shadow:var(--shadow-hover)}.card.home-stat{border-top:3px solid rgba(37,99,235,.35);padding-top:10px}.alert{padding:10px;background:#fef3c7;border:1px solid #fde68a;border-radius:10px}.badge{background:#ecfdf5;color:#065f46;padding:4px 8px;border-radius:999px;font-size:12px;font-weight:700}.install{margin:12px 0;padding:10px;border:1px dashed #9ca3af;border-radius:12px;background:#f9fafb}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--brand-ink);background:var(--brand-ink);color:#fff;padding:10px 14px;border-radius:12px;cursor:pointer;font-weight:600;transition:transform .12s ease,box-shadow .12s ease,background .15s ease,border-color .15s ease}.btn:active{transform:scale(.98)}.btn.secondary{background:var(--card);color:var(--text);border-color:var(--text)}.btn-primary{background:var(--brand);border-color:#1d4ed8;color:#fff}.btn-primary:hover{background:#1d4ed8}.btn.btn-danger{background:#dc2626;border-color:#b91c1c;color:#fff}.btn.btn-danger:hover{background:#b91c1c}.field-input,.input,input[type=email],input[type=password],input[type=text]{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:#fff;color:var(--text);font-size:14px}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:12px;color:var(--muted)}.field-hint{font-size:12px;color:#b91c1c;margin-top:4px}.field-input.field-error{border-color:#fca5a5;background:#fff7f7}.iconbtn{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:6px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text);transition:transform .15s ease}.iconbtn:hover{transform:translateY(-1px)}.appbar{position:-webkit-sticky;position:sticky;top:0;z-index:50;height:56px;background:var(--card);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px}.appbar-title{font-weight:800;font-size:18px}.appbar-actions{display:flex;gap:8px}.tabbar{z-index:50;align-items:stretch;justify-content:space-between;background:var(--card);border-top:1px solid var(--border);box-shadow:var(--shadow-soft)}.tab-item,.tab-item:visited{flex:1 1;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:11px;line-height:1;color:var(--muted);text-decoration:none!important;-webkit-tap-highlight-color:transparent;border-radius:12px;padding:8px 6px 12px;position:relative;overflow:hidden;z-index:0;transition:color .2s ease,font-weight .2s ease}.tab-item svg{width:22px;height:22px;transition:color .2s ease,stroke .2s ease}.tab-item:before{inset:4px 6px 12px;border-radius:12px;transform:scale(.95);z-index:-1}.tab-item:after,.tab-item:before{content:"";position:absolute;background:transparent;opacity:0;transition:opacity .2s ease,transform .2s ease,background .2s ease}.tab-item:after{left:24%;right:24%;bottom:6px;height:3px;border-radius:999px;transform:translateY(4px)}.tab-item.active{color:var(--brand-ink);font-weight:700}.tab-item.active:before{opacity:1;transform:scale(1);background:linear-gradient(135deg,rgba(14,165,233,.18),rgba(14,165,233,.08))}.tab-item.active:after{opacity:1;transform:translateY(0);background:var(--brand)}.tab-item.active svg{color:currentColor;stroke:currentColor}.tab-item:active{transform:translateY(1px)}@media (max-width:360px){.tab-item span{font-size:10px}}.home-hero{background:linear-gradient(135deg,#0ea5e9,#22d3ee);color:#fff;padding:18px 16px 12px}.home-hero-inner{max-width:var(--container-w);margin:0 auto}.home-hero-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.home-hello{font-size:22px;font-weight:900;letter-spacing:.2px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.25)}.home-sub{opacity:.95;margin-top:4px}.home-actions{display:flex;gap:8px;margin-top:10px}.home-primary{background:var(--brand-ink);border-color:var(--brand-ink)}.home-row{display:flex;align-items:center;justify-content:space-between;transition:background-color .15s ease,transform .15s ease}.home-row:hover{background:rgba(37,99,235,.06)}.home-row:active{transform:translateY(1px)}.home-row-left{display:flex;flex-direction:column}.home-row-right{text-align:right}.home-row-date{font-weight:700}.avatar-circle,.home-row-amt{font-weight:800}.avatar-circle{width:40px;height:40px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:var(--brand);color:#fff;box-shadow:var(--shadow-soft)}.avatar,.avatar-circle,.avatar-circle *{text-decoration:none!important}.fab-wrap{position:fixed;right:max(16px,env(safe-area-inset-right));bottom:calc(var(--tabbar-h) + max(16px, env(safe-area-inset-bottom)) + 12px);z-index:10001}.fab{width:56px;aspect-ratio:1/1;border-radius:50%;border:none;padding:0;display:flex;align-items:center;justify-content:center;background:var(--brand);color:#fff;box-shadow:0 6px 16px rgba(0,0,0,.2);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}.fab:hover{transform:translateY(-1px) scale(1.03);background:#1d4ed8}.fab:active{transform:translateY(0) scale(.98)}.cal-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin:12px 0}.cal-title{font-weight:800;font-size:18px}.cal-controls{display:flex;gap:6px;align-items:center}.cal-btn,.cal-tab{border:1px solid var(--border);background:var(--card);padding:6px 10px;border-radius:10px;cursor:pointer;font-weight:600;font-size:12px}.cal-tabs{display:flex;gap:6px}.cal-tab{border-radius:999px}.cal-tab.active{background:var(--text);color:var(--bg);border-color:var(--text)}.cal-grid{display:grid;grid-gap:8px;gap:8px}.cal-month,.cal-week{grid-template-columns:repeat(7,1fr)}.cal-day{grid-template-columns:1fr}.cal-cell{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:8px;min-height:92px;display:flex;flex-direction:column}.cal-cell-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:12px;color:var(--muted)}.cal-cell-today{color:#0ea5e9;font-weight:800}.cal-shift{border:1px solid var(--border);border-radius:10px;padding:6px;font-size:12px;margin-bottom:6px;background:#f9fafb;transition:transform .12s ease,box-shadow .12s ease}.cal-shift:active{transform:scale(.98)}.cal-more{font-size:11px;color:var(--muted)}.auth-card{max-width:520px;margin:12px auto;padding:0;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-card)}.auth-card,.auth-tabs{background:var(--card)}.auth-tabs{display:flex;gap:6px;padding:10px;border-bottom:1px solid var(--border);border-top-left-radius:16px;border-top-right-radius:16px}.auth-tab{flex:1 1;text-align:center;padding:10px 12px;border-radius:999px;cursor:pointer;border:1px solid var(--border);background:#fff;font-weight:700}.auth-tab.active{background:var(--text);color:var(--bg);border-color:var(--text)}.auth-head{padding:16px 16px 0}.auth-form{display:grid;grid-gap:12px;gap:12px;padding:16px}.auth-alert{margin:8px 16px 16px;padding:10px 12px;border-radius:12px;border:1px solid var(--border)}.auth-alert.ok{background:#ecfeff;border-color:#a5f3fc}.auth-alert.error{background:#fee2e2;border-color:#fecaca}.auth-foot{padding:0 16px 16px;display:flex;justify-content:center;gap:8px}.linkbtn{background:transparent;border:0;color:var(--text);text-decoration:underline;cursor:pointer}.pw-help{list-style:none;margin:6px 0 0;padding:0;font-size:12px}.pw-help li{margin:2px 0}.pw-help li.ok{color:#16a34a}.pw-help li.bad{color:#b91c1c}footer{color:var(--muted);font-size:12px;padding:16px;text-align:center}.profile-card{display:grid;grid-gap:12px;gap:12px}.profile-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.chip{font-size:12px;font-weight:700;padding:4px 8px;border-radius:999px}.chip-warn{background:#fffbeb;color:#713f12;border:1px solid #fde68a}.profile-card-body{display:grid;grid-template-columns:140px 1fr;grid-gap:16px;gap:16px;align-items:start}@media (max-width:560px){.profile-card-body{grid-template-columns:1fr}}.avatar-stack{display:grid;grid-gap:8px;gap:8px;justify-items:center}.avatar-wrap-lg{width:112px;height:112px;background:#eef2ff;box-shadow:var(--shadow-soft)}.avatar-fallback-lg{font-weight:800;font-size:28px}.avatar-img{width:100%;height:100%;object-fit:cover;display:block}.avatar-change{position:absolute;right:6px;bottom:6px;padding:6px 8px;font-size:12px;border-radius:999px;-webkit-backdrop-filter:saturate(140%) blur(6px);backdrop-filter:saturate(140%) blur(6px)}.profile-name{display:grid;grid-gap:6px;gap:6px}.profile-name-edit{display:grid;grid-gap:10px;gap:10px}.profile-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}.avatar-wrap-lg{width:96px;height:96px;border-radius:999px;overflow:hidden;position:relative;cursor:pointer;background:#f3f4f6;display:flex;align-items:center;justify-content:center}.avatar-wrap-lg img{width:100%;height:100%;object-fit:cover;display:block}.avatar-fallback-lg{font-size:32px;font-weight:700;color:#374151}.avatar-overlay{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.5);color:#fff;font-size:13px;text-align:center;padding:4px 0;opacity:0;transition:opacity .2s ease}.avatar-wrap-lg:hover .avatar-overlay{opacity:1}.fab-scrim{position:fixed;inset:0;background:transparent;border:0;padding:0;margin:0;cursor:default;z-index:10001}.fab-menu{position:absolute;right:0;bottom:64px;display:grid;grid-gap:8px;gap:8px;justify-items:end;z-index:10002;opacity:0;transform:translateY(6px) scale(.98);pointer-events:none;transition:opacity .14s ease,transform .14s ease}.fab-menu.open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.fab-menu-item{display:inline-flex;align-items:center;gap:10px;background:#0f172a;color:#fff;border:1px solid hsla(0,0%,100%,.06);border-radius:9999px;padding:10px 14px 10px 12px;box-shadow:0 10px 24px rgba(0,0,0,.25);cursor:pointer;transform:translateY(2px);transition:transform .12s ease,background .12s ease,box-shadow .12s ease}.fab-menu-item:hover{background:#0b1222;transform:translateY(0);box-shadow:0 14px 30px rgba(0,0,0,.28)}.fab-menu-icon{width:28px;height:28px;border-radius:9999px;display:inline-flex;align-items:center;justify-content:center;background:hsla(0,0%,100%,.12);-webkit-backdrop-filter:saturate(140%) blur(2px);backdrop-filter:saturate(140%) blur(2px);flex:0 0 auto}.fab-menu-label{font-size:14px;font-weight:700;letter-spacing:.2px;white-space:nowrap}.fab{will-change:transform,box-shadow;transition:transform .14s ease,box-shadow .14s ease,background .14s ease}.fab.open .fab-icon{transform:rotate(45deg);transition:transform .16s ease}@media (prefers-reduced-motion:reduce){.fab,.fab .fab-icon,.fab-menu,.fab-menu-item{transition:none!important}}.field-with-icon{position:relative;display:flex;align-items:center}.field-input{width:100%;padding-right:40px;font-size:16px}.field-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:transparent;border:0;padding:0;margin:0;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;color:#6b7280;cursor:pointer}.field-icon:hover{color:#111827}.field-icon:focus-visible{outline:2px solid #2563eb;outline-offset:2px;border-radius:6px}.field-icon svg{pointer-events:none}.modal-backdrop{z-index:1000;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}.modal-card{width:min(640px,92vw);color:var(--text,#111827);transform:translateY(6px) scale(.985);opacity:0;animation:modal-in .14s ease forwards}@keyframes modal-in{to{transform:translateY(0) scale(1);opacity:1}}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:8px;border-bottom:1px solid var(--border,#e5e7eb);background:#fff}.modal-title{font-size:18px;font-weight:800;line-height:1.15}.modal-body{flex:1 1 auto;display:grid;grid-gap:12px;gap:12px}.modal-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:14px}.modal-note{font-size:12px;color:var(--muted,#6b7280)}.modal-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}.modal-card .field-input,.modal-card .input,.modal-card select,.modal-card textarea{background:#fff;color:var(--text,#111827);border:1px solid var(--border,#e5e7eb);border-radius:12px}.modal-card .field-label{color:var(--muted,#6b7280)}.modal-card .btn.secondary{background:#fff;color:var(--text,#111827);border:1px solid var(--text,#111827)}.modal-card .btn.btn-danger{background:#dc2626;border-color:#b91c1c;color:#fff}.modal-card .btn.btn-danger:hover{background:#b91c1c}.modal-card .btn.btn-primary{background:#2563eb;border-color:#1d4ed8;color:#fff}.modal-card .btn.btn-primary:hover{background:#1d4ed8}.modal-card .cal-btn,.modal-close{color:var(--text,#111827);padding:6px 10px;cursor:pointer}.modal-card .cal-btn,.modal-card .cal-shift,.modal-close{border:1px solid var(--border,#e5e7eb);background:#fff;border-radius:10px}.modal-card .cal-shift{color:#111827;padding:8px;font-size:13px;margin-bottom:6px}.modal-card .cal-shift .note{color:var(--muted,#6b7280)}@media (max-width:420px){.modal-card{width:100%;max-width:520px;border-radius:14px}.modal-body{padding:14px}.modal-actions{padding:10px 14px}}.cal-add-btn{width:20px;height:20px;border-radius:50%;border:none;background:#2563eb;color:#fff;font-size:14px;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease;position:absolute;top:6px;right:6px;z-index:2}.cal-add-btn:hover{background:#1d4ed8}.field-changed{outline:2px solid #fca5a5;outline-offset:2px}.settings-actions{position:-webkit-sticky;position:sticky;bottom:0;display:flex;gap:8px;justify-content:flex-end;background:var(--card,#fff);border-top:1px solid var(--border,#e5e7eb);padding:12px 16px;border-bottom-left-radius:16px;border-bottom-right-radius:16px}.modal-inline-confirm{position:fixed;inset:0;background:rgba(0,0,0,.35);display:flex;align-items:center;justify-content:center;z-index:110}.confirm-card{width:min(420px,92vw);background:#fff;color:#111827;border:1px solid #e5e7eb;border-radius:14px;box-shadow:0 12px 38px rgba(0,0,0,.18);padding:16px}.toast{position:fixed;left:50%;bottom:calc(16px + env(safe-area-inset-bottom));transform:translateX(-50%) translateY(10px);opacity:0;padding:10px 14px;border-radius:12px;color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0;box-shadow:0 6px 20px rgba(0,0,0,.12);z-index:9999;transition:opacity .22s ease,transform .22s ease;font-weight:700}.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}.modal-backdrop{z-index:9999;background:transparent}.modal-card{border-radius:12px;padding:16px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 8px 24px rgba(0,0,0,.2)}html.keyboard-open .tabbar{display:none}.tabbar{justify-content:space-around;height:64px;padding:6px 8px calc(6px + env(safe-area-inset-bottom));background:var(--card,#fff);border-top:1px solid var(--border,#e5e7eb);box-shadow:0 -2px 6px rgba(0,0,0,.05);transform:translateZ(0)}.tab-item,.tabbar{display:flex;align-items:center}.tab-item{flex:1 1;text-align:center;font-size:12px;color:var(--text-muted,#666);flex-direction:column;gap:2px}.tab-item.active{color:var(--primary,#0ea5e9);font-weight:600}.page{padding-bottom:calc(72px + env(safe-area-inset-bottom))}body,html{height:100%}body{overflow:hidden;overscroll-behavior:none;touch-action:manipulation}.app-viewport{position:fixed;inset:0;height:100dvh;width:100%;overflow:hidden;background:var(--bg,#f9fafb)}.page{height:100%;overflow:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding-bottom:calc(72px + env(safe-area-inset-bottom, 0px))}.tabbar{bottom:calc(env(safe-area-inset-bottom, 0px) + var(--vv-offset, 0px))}.container{overflow:visible}.tabbar{height:var(--tabbar-h);padding-bottom:env(safe-area-inset-bottom)}.container,.page{padding-bottom:calc(var(--tabbar-h) + env(safe-area-inset-bottom))}.tabbar{z-index:1000}.modal-backdrop{z-index:2000;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;padding:16px}.modal-card{width:min(560px,92vw);max-height:calc(100vh - 48px);border:1px solid #e5e7eb;box-shadow:0 18px 50px rgba(0,0,0,.22)}.modal-head{padding:14px 16px;border-bottom:1px solid #f1f5f9}.modal-actions{border-top:1px solid #f1f5f9}body.modal-open{overflow:hidden;touch-action:none}.modal-body{max-height:calc(100dvh - var(--tabbar-h) - 32px);padding-bottom:max(16px,env(safe-area-inset-bottom))}.modal-backdrop{position:fixed;inset:0;height:100dvh}:root{--tabbar-h:64px;--safe-bottom:env(safe-area-inset-bottom,0px)}.tabbar{position:fixed;left:0;right:0;bottom:0;height:calc(var(--tabbar-h) + var(--safe-bottom));padding-bottom:var(--safe-bottom);z-index:1000!important;transform:none!important}.modal-backdrop{position:fixed!important;inset:0!important;height:100dvh!important;z-index:10000!important;display:grid!important;place-items:center!important;background:rgba(0,0,0,.45)!important}.modal-card{position:fixed!important;z-index:10001!important;max-width:640px;width:calc(100vw - 32px);max-height:calc(100dvh - 24px);overflow:hidden;display:flex;flex-direction:column;background:#fff;border:1px solid var(--border,#e5e7eb);border-radius:16px;box-shadow:0 18px 50px rgba(0,0,0,.18)}.modal-body{overflow:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:16px;padding-bottom:calc(var(--tabbar-h) + var(--safe-bottom) + 80px);max-height:calc(100dvh - 140px)}.modal-actions{position:-webkit-sticky;position:sticky;bottom:0;z-index:1;background:#fff;border-top:1px solid var(--border,#e5e7eb);padding:12px 16px}.container,.page,.scroll-area,main{padding-bottom:calc(var(--tabbar-h) + var(--safe-bottom))!important}#__next,body,html{min-height:100dvh}