.vfm--fixed{position:fixed}.vfm--absolute{position:absolute}.vfm--inset{top:0;right:0;bottom:0;left:0}.vfm--overlay{z-index:-1;background-color:#00000080}.vfm--prevent-none{pointer-events:none}.vfm--prevent-auto{pointer-events:auto}.vfm--outline-none:focus{outline:none}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-out{0%{opacity:1}to{opacity:0}}.vfm-fade-enter-active{animation:fade-in .3s ease}.vfm-fade-leave-active{animation:fade-out .3s ease}.vfm-bounce-back{transition-property:transform;transition-duration:.3s}.vfm-slide-up-enter-active,.vfm-slide-up-leave-active,.vfm-slide-down-enter-active,.vfm-slide-down-leave-active{transition:transform .3s ease}.vfm-slide-down-enter-from,.vfm-slide-down-leave-to{transform:translateY(100vh)!important}.vfm-slide-up-enter-from,.vfm-slide-up-leave-to{transform:translateY(-100vh)!important}.vfm-slide-right-enter-active,.vfm-slide-right-leave-active,.vfm-slide-left-enter-active,.vfm-slide-left-leave-active{transition:transform .3s ease}.vfm-slide-right-enter-from,.vfm-slide-right-leave-to{transform:translate(100vw)!important}.vfm-slide-left-enter-from,.vfm-slide-left-leave-to{transform:translate(-100vw)!important}.vfm-swipe-banner-back,.vfm-swipe-banner-forward{position:fixed;top:0;bottom:0;width:27px;z-index:10}.vfm-swipe-banner-back{left:0}.vfm-swipe-banner-forward{right:0}:root{--bg: #f4f7fb;--surface: #ffffff;--primary: #163e73;--text: #1b3559;--muted: #67809f;--line: #d8e4f7;--danger: #dc2626}*{box-sizing:border-box}body{margin:0;font-family:Inter,Segoe UI,sans-serif;background:var(--bg);color:var(--text)}.app-shell{min-height:100vh}.app-main{padding:16px}.app-main.authed{padding-bottom:108px}.topbar{position:sticky;top:0;z-index:10;display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f4f7fbeb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-bottom:1px solid var(--line)}.topbar-logo{height:44px;width:auto;display:block}.top-actions{display:flex;align-items:center;gap:8px}.icon-btn{width:40px;height:40px;padding:0;border:1px solid var(--line);border-radius:12px;background:#fff;color:var(--primary);display:inline-flex;align-items:center;justify-content:center;line-height:1;position:relative}.project-detail-head .icon-btn .app-icon{width:22px;height:22px;margin:0;display:block}.project-detail-head .icon-btn{width:44px;height:44px;border-radius:999px;border-color:transparent;background:#163e7314}.badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;border-radius:999px;background:#ef4444;color:#fff;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;padding:0 5px}.page{max-width:640px;margin:0 auto}.page-head{display:flex;justify-content:space-between;align-items:flex-start;flex-direction:column;gap:8px;margin-bottom:12px}h1,h2,h3{margin:0;color:var(--primary)}.panel{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:12px;margin-bottom:12px}.running-now{position:relative;display:grid;gap:8px;align-content:start;padding-right:150px}.running-now-label{color:var(--muted);font-weight:800;font-size:16px;line-height:1}.running-now-task{color:var(--primary);font-size:20px;line-height:1.2;white-space:normal;overflow:hidden;text-overflow:ellipsis}.running-now-time{position:absolute;top:12px;right:12px;width:fit-content;min-width:92px;border-radius:999px;background:#163e73;color:#fff;padding:4px 10px;font-size:15px;font-weight:800}.running-now-sub{font-size:13px}.row-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-start}.app-grid{display:flex;gap:14px;overflow-x:auto;padding:4px 2px 8px;scrollbar-width:none}.app-grid::-webkit-scrollbar{display:none}.app-grid-item{border:0;border-radius:0;background:transparent;color:var(--text);padding:0;display:grid;gap:8px;justify-items:center;font-weight:700;min-width:88px}.app-grid-icon{width:66px;height:66px;border-radius:999px;border:3px solid #fff;background:radial-gradient(circle at 30% 30%,#2b5d9e,#163e73 55%,#102f58);box-shadow:0 8px 16px #163e7347;display:inline-flex;align-items:center;justify-content:center}.app-grid-icon .app-icon{width:30px;height:30px;color:#fff}.app-grid-label{font-size:14px;line-height:1.2;text-align:center;color:#1f3355;max-width:92px;word-break:break-word}.menu-item-btn{width:100%;text-align:left;height:44px;border-radius:12px;border:1px solid var(--line);background:#fff;color:var(--text);padding:0 12px;font-weight:700;margin-bottom:8px}.menu-item-btn.danger{color:#fff;border-color:#b91c1c;background:#b91c1c}.menu-item-btn.danger:hover{border-color:#991b1b;background:#991b1b}.me-vfm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f1c395c}.me-vfm-content{position:fixed;left:0;right:0;bottom:0}.me-fade-enter-active,.me-fade-leave-active{transition:opacity .22s ease}.me-fade-enter-from,.me-fade-leave-to{opacity:0}.me-sheet-slide-up-enter-active,.me-sheet-slide-up-leave-active{transition:transform .28s cubic-bezier(.2,.8,.2,1),opacity .22s ease}.me-sheet-slide-up-enter-from,.me-sheet-slide-up-leave-to{transform:translate3d(0,100%,0);opacity:.96}.me-sheet{background:#fff;border-radius:24px 24px 0 0;border-top:1px solid var(--line);padding:10px 16px calc(18px + env(safe-area-inset-bottom));box-shadow:0 -12px 28px #0d244a29;max-height:88vh;overflow:auto}.me-sheet-handle{width:42px;height:5px;border-radius:999px;background:#d5e1f5;margin:2px auto 10px}.me-sheet-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px}.me-sheet-subtitle{margin:4px 0 0;font-size:13px}.me-sheet-close{height:34px;padding:0 12px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--text);font-weight:700}.me-sheet-list{border:1px solid var(--line);border-radius:14px;overflow:hidden}.me-sheet-row{display:flex;justify-content:space-between;gap:10px;padding:11px 12px;border-bottom:1px solid #e3ebf8}.me-sheet-row:last-child{border-bottom:0}.me-sheet-row span{color:var(--muted);font-size:13px}.me-sheet-row strong{color:var(--text);text-align:right}.me-sheet-content{display:grid;gap:10px}.me-sheet-content p{margin:0;color:var(--text);line-height:1.45}.me-sheet-content h4{margin:2px 0 0;color:var(--primary);font-size:15px}.me-sheet-content ul{margin:0;padding-left:18px;display:grid;gap:6px;color:var(--text)}.form-grid{display:grid;gap:8px}.grid-2{display:grid;grid-template-columns:1fr;gap:10px}.grid-3{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:10px}.login-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:18px 0}.login-brand{margin-bottom:14px;display:flex;justify-content:center}.login-card{width:min(440px,100%);background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:14px;display:grid;gap:8px}.login-logo{width:150px;height:auto;display:block;margin:0 auto}.login-divider{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px;font-weight:700;margin-top:2px}.login-divider:before,.login-divider:after{content:"";height:1px;background:var(--line);flex:1}.google-btn-wrap{display:flex;justify-content:center;min-height:0;height:0;overflow:hidden}.google-login-btn{width:100%;height:44px;border-radius:12px;border:1px solid #d8e4f7;background:#fff;color:#1b3559;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:800}.google-login-icon{width:20px;height:20px;border-radius:999px;background:#fff;border:1px solid #d8e4f7;display:inline-flex;align-items:center;justify-content:center;color:#1b3559;font-size:12px;font-weight:900}.splash-wrap{min-height:100vh;display:grid;place-items:center;align-content:center;gap:10px}.splash-logo{width:min(220px,56vw);height:auto}.splash-text{margin:0;color:var(--muted);font-weight:700;letter-spacing:.2px}.onboarding-wrap{min-height:100vh;display:flex;flex-direction:column;justify-content:flex-start;gap:14px;padding:14px 0 96px;width:calc(100% + 32px);max-width:none;margin:-16px -16px 0;position:relative;overflow:hidden}.onboarding-skip-top{position:fixed;top:14px;right:16px;z-index:4;border:0;background:#ffffffc7;color:#163e73;font-size:14px;font-weight:800;padding:6px 10px;border-radius:12px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.onboarding-bg-video{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0}.onboarding-bg-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0a193052,#0a193038 38%,#f4f7fbb3 75%,#f4f7fbeb);z-index:1}.onboarding-content{flex:1 1 auto;display:flex;flex-direction:column;justify-content:flex-end;gap:10px;position:relative;z-index:2}.onboarding-hero{position:fixed;left:14px;top:calc(12px + env(safe-area-inset-top));transform:none;width:auto;display:block;pointer-events:none;z-index:3}.onboarding-logo{width:min(124px,34vw);height:auto}.onboarding-card{background:#fff;border:1px solid #d3e0f5;border-bottom:none;border-radius:28px 28px 0 0;padding:16px 18px 18px;display:grid;gap:10px;box-shadow:0 -10px 26px #112b5414;margin-left:0;margin-right:0;min-height:300px;position:relative;z-index:2;margin-bottom:0}.onboarding-card:before{content:"";width:42px;height:5px;border-radius:999px;background:#d5e1f5;justify-self:center;margin-bottom:4px}.onboarding-card h1{margin:0;font-size:22px;line-height:1.28;letter-spacing:.1px}.onboarding-card .muted{margin:0;font-size:14px;line-height:1.45}.onboarding-features{display:grid;gap:8px}.onboarding-feature{display:flex;align-items:center;gap:10px;background:#f5f8fd;border:1px solid #d9e5f7;border-radius:14px;padding:10px 12px}.onboarding-feature-icon{width:22px;height:22px;border-radius:999px;background:#163e73;color:#fff;font-size:12px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.onboarding-feature-text{font-size:14px;line-height:1.35;color:var(--text)}.onboarding-dots{display:flex;justify-content:center;gap:8px}.onboarding-dot{width:8px;height:8px;border-radius:999px;border:0;background:#c7d6ee;padding:0}.onboarding-dot.active{width:20px;background:var(--primary)}.onboarding-footer{position:fixed;left:0;right:0;bottom:0;padding:4px 0 calc(10px + env(safe-area-inset-bottom));background:#fff;border-top:1px solid #d3e0f5;min-height:96px;display:grid;align-content:end;z-index:3;box-shadow:0 -10px 20px #112b540f}.onboarding-footer .onboarding-dots{margin-bottom:6px}.onboarding-actions{max-width:none;margin:0 auto;width:100%;display:flex;justify-content:space-between;gap:8px;padding:0 16px}.onboarding-actions .btn{flex:1 1 0;height:48px;border-radius:18px;font-size:16px;white-space:nowrap;padding:0 12px;font-weight:800}.onboarding-actions .btn:disabled{opacity:.55;cursor:not-allowed}label{font-size:13px;color:var(--muted)}input{height:44px;border:1px solid #b8d0f1;border-radius:12px;padding:0 12px;font-size:16px}select{height:44px;border:1px solid #b8d0f1;border-radius:12px;padding:0 12px;font-size:16px;background:#fff}textarea{border:1px solid #b8d0f1;border-radius:12px;padding:10px 12px;font-size:15px;resize:vertical;min-height:72px}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px}.card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:12px}.card.clickable{cursor:pointer}.card-title{font-weight:800;color:var(--primary);margin-bottom:8px}.kv{display:flex;justify-content:space-between;gap:10px;padding:4px 0}.kv span{color:var(--muted);font-size:13px}.kv strong{text-align:right;font-weight:700}.project-layout{display:grid;grid-template-columns:minmax(0,4fr) minmax(74px,1fr);gap:12px;align-items:flex-start}.project-main{min-width:0}.project-line{display:grid;gap:2px;margin-bottom:6px}.project-line span{color:var(--muted);font-size:13px}.project-line strong{color:var(--text);font-weight:800;text-align:left}.project-progress{display:grid;justify-self:end;justify-items:center;align-content:start;gap:6px}.progress-ring{width:64px;height:64px;border-radius:999px;padding:6px}.progress-ring-inner{width:100%;height:100%;border-radius:999px;display:grid;place-items:center;font-size:12px;font-weight:900;color:var(--primary);background:#fff}.bottom-nav{position:fixed;left:0;right:0;bottom:0;background:#fff;border-top:1px solid var(--line);border-radius:18px 18px 0 0;box-shadow:0 -6px 16px #0d244a1a;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));overflow:visible;padding:8px 12px calc(8px + env(safe-area-inset-bottom));z-index:50}.bottom-nav:before{content:"";position:absolute;left:50%;top:-22px;width:88px;height:44px;transform:translate(-50%);border-radius:44px 44px 0 0;background:#fff;border:1px solid #dbe7f9;border-bottom:0;box-shadow:0 -2px 10px #0d244a12;z-index:0}.global-timer-bar{position:fixed;left:12px;right:12px;bottom:84px;border:1px solid #bfd4f0;border-radius:14px;background:#fff;box-shadow:0 8px 24px #0d244a1f;padding:10px;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:10px}.timer-main{min-width:0}.timer-title{font-size:13px;font-weight:800;color:var(--primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.timer-time{font-size:20px;font-weight:900;color:var(--text)}.timer-error{margin:4px 0 0;color:var(--danger);font-size:12px}.timer-actions{display:flex;gap:8px}.nav-item{text-align:center;text-decoration:none;color:var(--muted);padding:8px 8px 6px;font-weight:700;font-size:14px;display:flex;flex-direction:column;gap:6px;align-items:center;justify-content:center;position:relative;z-index:1}.nav-item.active{color:var(--primary)}.nav-item.is-plus{padding-top:0}.nav-plus-circle{width:56px;height:56px;border-radius:999px;background:var(--primary);color:#fff;border:3px solid #fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 6px 14px #163e734d;transform:translateY(-14px);position:relative;z-index:2}.nav-plus-circle .app-icon{width:24px;height:24px}.app-icon{width:24px;height:24px;flex:0 0 auto}.nav-item .app-icon{width:24px;height:24px}.btn{height:40px;border:1px solid #b8d0f1;border-radius:12px;padding:0 14px;background:#fff;color:var(--text);font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:6px}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn.ghost{background:transparent}.btn.danger{background:#fee2e2;border-color:#fecaca;color:#b91c1c}.btn .app-icon{width:16px;height:16px}.task-panel{margin-top:12px;background:transparent;border:0;padding:0}.task-list{display:grid;gap:10px;margin-top:10px}.task-item{border:1px solid var(--line);border-radius:12px;padding:10px;display:flex;align-items:center;justify-content:space-between;gap:10px}.task-left{display:grid;gap:6px;min-width:0}.task-title{font-weight:800;color:var(--primary)}.estimate-row{display:flex;align-items:center;gap:8px}.estimate-row label{min-width:96px;font-size:12px}.estimate-row input{width:120px;height:36px}.project-detail-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}.project-task-item{display:grid;grid-template-columns:minmax(0,4fr) minmax(68px,1fr);align-items:stretch;gap:10px}.task-panel .project-task-item{background:#fff;box-shadow:0 6px 16px #112b5414}.session-panel{background:transparent;border:0;padding:0}.seession-panel h3{margin-bottom:10px}.session-panel .task-item{background:#fff;box-shadow:0 6px 16px #112b5414;padding:12px 12px 24px;gap:12px}.session-panel .task-item .meta-chip{margin-top:10px;margin-bottom:8px;align-self:flex-start}.project-task-main{min-width:0}.task-meta-chips{display:flex;flex-wrap:wrap;gap:6px}.meta-chip{height:24px;border-radius:999px;padding:0 10px;display:inline-flex;align-items:center;font-size:12px;font-weight:800;border:1px solid transparent}.status-review{background:#c2410c;color:#fff;border-color:#c2410c}.status-todo{background:#1d4ed8;color:#fff;border-color:#1d4ed8}.status-progress{background:#0e7490;color:#fff;border-color:#0e7490}.status-done{background:#15803d;color:#fff;border-color:#15803d}.status-blocked{background:#b91c1c;color:#fff;border-color:#b91c1c}.status-cancel{background:#475569;color:#fff;border-color:#475569}.status-default{background:#334155;color:#fff;border-color:#334155}.priority-high{background:#be123c;color:#fff;border-color:#be123c}.priority-medium{background:#854d0e;color:#fff;border-color:#854d0e}.priority-low{background:#047857;color:#fff;border-color:#047857}.priority-default{background:#334155;color:#fff;border-color:#334155}.estimate-full{display:grid;gap:6px}.estimate-full label{min-width:0}.estimate-full input{width:100%}.task-play-circle{width:72px;height:72px;border-radius:999px;border:1px solid #b8d0f1;background:#163e73;color:#fff;display:inline-flex;align-items:center;justify-content:center;align-self:center;justify-self:center}.task-play-circle.is-running{background:#b91c1c;border-color:#ef4444}.task-play-circle .app-icon{width:28px;height:28px}.glyph-play{width:0;height:0;border-top:12px solid transparent;border-bottom:12px solid transparent;border-left:18px solid #fff;margin-left:3px}.glyph-stop{width:17px;height:17px;border-radius:3px;background:#fff}.chips{display:flex;flex-wrap:wrap;gap:6px}.chip{height:32px;border-radius:999px;border:1px solid #c7d6ee;padding:0 10px;background:#fff;color:var(--text);font-weight:700;font-size:12px}.chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.check-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}.check-row input{width:16px;height:16px}.muted{color:var(--muted)}.error{color:var(--danger);margin:4px 0}@media (min-width: 900px){.app-main.authed{padding-bottom:132px}.bottom-nav{top:auto;bottom:10px;left:50%;right:auto;width:min(560px,calc(100% - 28px));border-radius:22px;transform:translate(-50%);border:1px solid #d6e3f7;box-shadow:0 14px 30px #0d244a24;padding:10px 14px calc(10px + env(safe-area-inset-bottom))}.app-main.authed{margin-left:0}.global-timer-bar{left:50%;right:auto;width:min(980px,calc(100% - 32px));transform:translate(-50%);bottom:102px}}@media (max-width: 700px){.running-now{padding-right:126px}.running-now-label{font-size:14px}.running-now-task{font-size:18px;white-space:normal}.running-now-time{top:10px;right:10px;font-size:14px;min-width:84px}.onboarding-hero{left:12px;top:calc(10px + env(safe-area-inset-top))}.onboarding-logo{width:min(112px,32vw)}.login-wrap{padding:12px 0}.login-card{padding:12px;border-radius:16px}.grid-2,.grid-3{grid-template-columns:1fr}.page-head{align-items:flex-start;gap:8px;flex-direction:column}.row-actions{justify-content:flex-start}.task-item{flex-direction:column;align-items:stretch}.project-task-item{grid-template-columns:minmax(0,4fr) minmax(60px,1fr)}.task-play-circle{width:64px;height:64px}.task-play-circle .app-icon{width:24px;height:24px}.glyph-play{border-top-width:10px;border-bottom-width:10px;border-left-width:15px}.glyph-stop{width:15px;height:15px}.project-layout{grid-template-columns:minmax(0,4fr) minmax(64px,1fr)}.session-panel .task-item{padding:12px 12px 26px}.app-grid-icon{width:62px;height:62px}.app-grid-icon .app-icon{width:28px;height:28px}.app-grid-label{font-size:13px;max-width:84px}.progress-ring{width:56px;height:56px;padding:5px}.progress-ring-inner{font-size:11px}.global-timer-bar{flex-direction:column;align-items:stretch}.timer-actions{justify-content:flex-end}}
