: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;--tabbar-h:64px;--safe-bottom:env(safe-area-inset-bottom,0px)}*{box-sizing:border-box}body,html{padding:0;margin:0;min-height:100dvh}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}body.modal-open{overflow:hidden;touch-action:none}.page{min-height:100dvh;height:100%;overflow:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;background:var(--bg);padding-bottom:calc(var(--tabbar-h) + var(--safe-bottom))}.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=date],input[type=email],input[type=password],input[type=text],select,textarea{width:100%;min-width:0;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;min-width:0}.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)}.field-with-icon{position:relative;display:flex;align-items:center}.field-with-icon .field-input{padding-right:40px;font-size:16px}.field-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:transparent;border: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}.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{position:fixed;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:stretch;justify-content:space-between;background:var(--card);border-top:1px solid var(--border);box-shadow:var(--shadow-soft);height:var(--tabbar-h);padding:6px 8px calc(6px + var(--safe-bottom))}.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 svg{color:currentColor;stroke:currentColor}.tab-item:active{transform:translateY(1px)}@media (max-width:360px){.tab-item span{font-size:10px}}html.keyboard-open .tabbar{display:none}.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}.avatar-stack{display:grid;grid-gap:8px;gap:8px;justify-items:center}.avatar-wrap-lg{width:96px;height:96px;border-radius:50%;overflow:hidden;background:var(--bg-muted,#f3f3f3)}.avatar-fallback-lg{font-weight:800;color:#374151;font-size:28px}.avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.avatar-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.55);color:#fff;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;border-radius:999px;opacity:0;transition:opacity .25s ease;z-index:4;text-transform:uppercase;letter-spacing:.5px}.avatar-wrap-lg:hover .avatar-overlay{opacity:1}.fab-wrap{position:fixed;right:max(16px,env(safe-area-inset-right));bottom:calc(var(--tabbar-h) + max(16px, var(--safe-bottom)) + 12px);z-index:1001}.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;will-change:transform,box-shadow}.fab:hover{transform:translateY(-1px) scale(1.03);background:#1d4ed8}.fab:active{transform:translateY(0) scale(.98)}.fab.open .fab-icon{transform:rotate(45deg);transition:transform .16s ease}.fab-scrim{position:fixed;inset:0;background:transparent;border:0;padding:0;margin:0;cursor:default;z-index:1001}.fab-menu{position:absolute;right:0;bottom:64px;display:grid;grid-gap:8px;gap:8px;justify-items:end;z-index:1002;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}@media (prefers-reduced-motion:reduce){.fab,.fab .fab-icon,.fab-menu,.fab-menu-item{transition:none!important}}.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)}.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}.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}}.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}.modal-backdrop{position:fixed;inset:0;height:100dvh;z-index:10000;display:grid;place-items:center;padding:16px;background:rgba(0,0,0,.45)}.modal-card{position:fixed;z-index:10001;max-width:640px;width:calc(100vw - 32px);max-height:calc(100dvh - 24px);display:flex;flex-direction:column;overflow:hidden;background:#fff;color:var(--text);border:1px solid var(--border);border-radius:16px;box-shadow:0 18px 50px rgba(0,0,0,.18);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;padding:14px 16px;border-bottom:1px solid var(--border);background:#fff}.modal-title{font-size:18px;font-weight:800;line-height:1.15}.modal-body{flex:1 1 auto;padding:16px;display:grid;grid-gap:12px;gap:12px;overflow:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding-bottom:calc(var(--tabbar-h) + var(--safe-bottom) + 80px)}.modal-actions{position:-webkit-sticky;position:sticky;bottom:0;z-index:1;display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border);background:#fff;justify-content:flex-end;flex-wrap:wrap}.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{bottom:calc(16px + var(--safe-bottom));transform:translateX(-50%) translateY(10px);padding:10px 14px;border-radius:12px;color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0;box-shadow:0 6px 20px rgba(0,0,0,.12);transition:opacity .22s ease,transform .22s ease;font-weight:700}.settings-actions{position:-webkit-sticky;position:sticky;bottom:0;display:flex;gap:8px;justify-content:flex-end;background:var(--card);border-top:1px solid var(--border);padding:12px 16px;border-bottom-left-radius:16px;border-bottom-right-radius:16px}.field-changed{outline:2px solid #fca5a5;outline-offset:2px}.container,.scroll-area,main{padding-bottom:calc(var(--tabbar-h) + var(--safe-bottom))}.avatar-wrap-lg{position:relative;width:112px;height:112px;border-radius:999px;background:#eef2ff;box-shadow:var(--shadow-soft);justify-content:center;cursor:pointer;overflow:visible}.avatar-wrap-lg,.badge-tier{display:flex;align-items:center}.badge-tier{z-index:6;position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);gap:4px;padding:4px 10px;border-radius:9999px;font-size:12px;font-weight:600;color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 4px 8px rgba(0,0,0,.25);z-index:5;pointer-events:none}.badge-tier.pro{background:linear-gradient(90deg,#fbbf24,#f59e0b)}.badge-tier.founder{background:linear-gradient(90deg,#8b5cf6,#3b82f6)}@keyframes shimmer{0%{background-position:-100% 0}to{background-position:200% 0}}.badge-tier.pro{background:linear-gradient(90deg,#f59e0b,#fbbf24,#f59e0b);background-size:200% 100%}.badge-tier.founder,.badge-tier.pro{animation:shimmer 3s linear infinite}.badge-tier.founder{background:linear-gradient(90deg,#8b5cf6,#3b82f6,#8b5cf6);background-size:200% 100%}.crown-icon{width:14px;height:14px}.badge-tier-header{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:700;color:#fff;white-space:nowrap;background:linear-gradient(90deg,#f59e0b,#fbbf24,#f59e0b);box-shadow:0 2px 6px rgba(0,0,0,.2);animation:shimmer 3s linear infinite;background-size:200% 100%}.badge-tier-header.founder{background:linear-gradient(90deg,#8b5cf6,#3b82f6,#8b5cf6);animation:shimmer 3s linear infinite;background-size:200% 100%}input,select,textarea{font-size:16px!important;touch-action:manipulation;-webkit-text-size-adjust:100%}.btn:disabled,.btn[disabled]{opacity:.6;cursor:not-allowed;background-color:#e5e7eb;color:#6b7280;border-color:#d1d5db;box-shadow:none}.ts-pro-card{border-radius:18px;background:linear-gradient(135deg,#7e22ce,#3b82f6,#ec4899);background-size:300% 300%;animation:tsGradientShift 6s ease infinite;border:none;box-shadow:0 4px 14px rgba(0,0,0,.15);overflow:hidden;transition:all .3s ease}@keyframes tsGradientShift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.ts-pro-header{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px;border:0;background:transparent;color:#fff;font-weight:800;font-size:17px;cursor:pointer;text-shadow:0 1px 2px rgba(0,0,0,.25)}.ts-pro-header:hover{filter:brightness(1.05)}.ts-pro-left{display:flex;align-items:center;gap:12px}.ts-pro-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:linear-gradient(90deg,#facc15,#fbbf24);color:#fff;font-weight:800;font-size:13px;box-shadow:inset 0 1px 1px hsla(0,0%,100%,.35),0 1px 2px rgba(0,0,0,.2)}.ts-pro-crown{width:14px;height:14px;display:block;color:#fff}.ts-pro-title{color:#fff}.ts-pro-arrow{transition:transform .18s ease;color:hsla(0,0%,100%,.8)}.ts-pro-arrow.open{transform:rotate(180deg)}.ts-pro-content{min-height:0;background:#fffef8;border-top:1px solid hsla(0,0%,100%,.3)}.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(20px);opacity:0;transition:all .3s ease;padding:10px 18px;border-radius:10px;font-size:14px;font-weight:500;color:#fff;z-index:9999}.toast.show{transform:translateX(-50%) translateY(0);opacity:1}.toast-success{background:#16a34a}.toast-error{background:#dc2626}