:root{--bg: #f6f7fb;--card: #ffffff;--text: #0f172a;--muted: #64748b;--border: #e5e7eb;--btn: #ffffff;--btn-border: #e5e7eb;--btn-hover: #f1f5f9;--accent: #4f46e5;--accent-weak: #eef2ff;--success: #22c55e;--danger: #ef4444}.dark{--bg: #0d1220;--card: #0f172a;--text: #e5e7eb;--muted: #9aa4b6;--border: #243047;--btn: #121a2b;--btn-border: #243047;--btn-hover: #162236;--accent: #5da2ff;--accent-weak: #0c1e3a}*{box-sizing:border-box}html,body,#root{min-height:100dvh;height:auto;overflow-x:hidden;overflow-y:auto}body{margin:0;background:#eef2ff;color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,"Apple Color Emoji","Segoe UI Emoji";-webkit-text-size-adjust:100%}.gp-title,.task .title,.xp-name,.empty{overflow-wrap:anywhere;word-break:break-word}.app-root{min-height:100dvh;display:grid;place-items:start center;padding:40px 20px max(80px,env(safe-area-inset-bottom) + 24px);position:relative;z-index:100;isolation:isolate}.global-player.is-playing~.app-root{z-index:1}.card{width:100%;max-width:880px;background:var(--card);border:1px solid var(--border);border-radius:20px;box-shadow:0 10px 26px #0000001f;padding:16px;position:relative;z-index:2}.header{display:grid;gap:12px}.header-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.brand-left{display:flex;align-items:center;gap:12px}.header .brand{display:flex;align-items:center;gap:10px;margin-bottom:8px}.header .logo{font-size:22px}.header h1{margin:0;font-size:22px;letter-spacing:.2px}.header .row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.stats{margin:5px 1% 0;display:grid;grid-template-columns:repeat(3,1fr);column-gap:3px;align-items:start}.stat{text-align:center}.stat .label{color:var(--muted);font-size:12px}.stat .value{font-weight:600}.origin-banner{margin-top:8px;padding:8px 12px;border:1px dashed var(--border);border-radius:10px;background:#00000005}.bar{width:100%;height:10px;appearance:none;margin-top:6px;border-radius:8px}.bar::-webkit-progress-bar{background:var(--accent-weak);border-radius:8px}.bar::-webkit-progress-value{background:linear-gradient(90deg,var(--success),#16a34a);border-radius:8px}.progress-shell{width:100%;height:10px;border-radius:999px;background:var(--accent-weak);overflow:hidden;margin-top:6px}.progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--success),#16a34a);transition:width .45s ease}input,textarea,select{font:inherit;min-width:0;color:var(--text)}input[type=text],input[type=number],input[type=date],input[type=time],textarea,select{width:100%;height:40px;padding:0 12px;border:1px solid var(--border);border-radius:10px;background:#fff;outline:none}textarea{height:auto;padding:8px 12px}input:focus,textarea:focus{border-color:#c7d2fe;box-shadow:0 0 0 4px #3b82f61f}::placeholder{color:color-mix(in srgb,var(--muted) 80%,transparent)}input[type=file]{font:inherit;color:var(--text)}input[type=file]::file-selector-button{background:var(--accent);color:#fff;border:1px solid var(--accent);border-radius:10px;padding:8px 12px;height:40px;cursor:pointer;transition:filter .15s ease,transform .02s ease}input[type=file]::file-selector-button:hover{filter:brightness(1.05)}input[type=file]::file-selector-button:active{transform:translateY(1px)}.btn,.tab{background:var(--btn);color:var(--text);border:1px solid var(--btn-border);border-radius:10px;padding:8px 12px;height:40px;cursor:pointer}.btn:hover,.tab:hover{background:var(--btn-hover)}.btn.primary,.tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.btn:disabled{opacity:.6;cursor:not-allowed}.icon-btn{background:var(--btn);color:var(--text);border:1px solid var(--btn-border);border-radius:8px;height:36px;width:36px;cursor:pointer}.icon-btn:hover{background:var(--btn-hover)}.icon-btn.sm{background:transparent;color:var(--muted);border:1px solid var(--btn-border);border-radius:8px;width:24px;height:24px;padding:0;display:inline-flex;align-items:center;justify-content:center}.icon-btn.sm:hover{background:var(--btn-hover);color:var(--text)}.add{display:flex;gap:8px;align-items:center;margin-top:12px;flex-wrap:wrap}.add .titleInput{flex:1 1 360px;font-size:1.1rem;padding:10px 14px;background:#fff;border:1px solid var(--border);border-radius:12px}.add .xpGroup,.add .dueGroup{display:flex;align-items:center;gap:6px}.add .xpLabel,.xpLabel{font-size:11px;color:var(--muted);margin-left:2px}.add .xpInput,.xpInput,.xp-chip-input{width:56px;text-align:center;padding:0 8px;height:38px;border:1px solid var(--border);border-radius:8px;-moz-appearance:textfield}.add .xpInput::-webkit-outer-spin-button,.add .xpInput::-webkit-inner-spin-button,.xp-chip-input::-webkit-outer-spin-button,.xp-chip-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.xp-chip-input{height:32px}.add .xpMeter{width:80px;height:6px;border-radius:999px;background:#e5e7eb;overflow:hidden}.add .xpMeter>div{height:100%;background:linear-gradient(90deg,#60a5fa,#f59e0b);border-radius:999px;transition:width .2s ease}.add .dueInput{width:56px;text-align:center;height:38px;border:1px solid var(--border);border-radius:8px;padding:0 8px}.add .dueSelect{min-width:56px;height:38px;border:1px solid var(--border);border-radius:8px;padding:0 8px}.add .aiBtn{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center}.add .addBtn{font-weight:600}.add .addBtn.gamified{font-weight:700;color:#fff;border-color:transparent;transition:transform .08s ease,box-shadow .15s ease;box-shadow:0 6px 18px #00000026}.add .addBtn.gamified:hover{transform:translateY(-1px);box-shadow:0 10px 24px #0003}.add .addBtn.gamified:active{transform:translateY(0);box-shadow:0 6px 18px #00000026}.metaRow{display:flex;align-items:center;justify-content:space-between;margin-top:12px;color:var(--muted);font-size:14px}.metaRow>div:not(.actions):not(.fixed-meta){display:none}.actions{display:flex;gap:8px}.list{margin-top:10px;display:grid;gap:8px}.empty{text-align:center;color:var(--muted);padding:20px 0}.task{display:flex;gap:10px;align-items:center;padding:10px;border:1px solid var(--border);border-radius:14px;background:var(--card)}.task input[type=checkbox]{width:18px;height:18px}.task .title{flex:1}.task .xp{font-size:12px;color:#475569}.task .icon{background:transparent;border:0;cursor:pointer;font-size:18px}.task.done{opacity:.85;text-decoration:line-through;color:var(--muted)}.task.drag-over{outline:2px dashed var(--accent-weak, #93c5fd);outline-offset:2px}.task[draggable=true]{cursor:grab}.task[draggable=true]:active{cursor:grabbing}.task.reorder-mode{cursor:grabbing;-webkit-user-select:none;user-select:none}.task.reorder-src{outline:2px solid var(--accent-weak, #93c5fd);outline-offset:2px}.task .xp-meta,.task .xp-breakdown,.task .xp-split,.task .xp-branches,.task .wisdom-breakdown{display:none!important}.milestone-list{margin-top:6px;display:grid;gap:4px}.milestone-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}.milestone-item input{margin:0}.milestone-title{flex:1;color:var(--text)}.milestone-item.done .milestone-title{text-decoration:line-through;color:var(--muted)}.milestone-weight{font-size:11px;color:var(--muted)}.subadd{padding:6px 2px}.deadline{font-size:12px;color:var(--muted);margin-top:2px}.deadline.overdue{color:var(--danger);font-weight:600}.badge{padding:6px 10px;border-radius:999px;background:#f1f5f9;color:#334155;border:1px solid #e2e8f0;font-size:12px}.badge.on{background:#e0f2fe;color:#0369a1;border-color:#bae6fd}.sync-badge{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;border:1px solid var(--border);background:var(--btn);color:var(--muted);font-size:12px;cursor:pointer}.sync-badge:hover{background:var(--btn-hover)}.sync-badge .mono{font-variant-numeric:tabular-nums}.sync-dot{width:8px;height:8px;border-radius:999px;display:inline-block}.symbols{position:fixed;top:8px;left:50%;transform:translate(-50%);display:flex;flex-wrap:wrap;gap:4px;font-size:22px;pointer-events:none;max-width:80%;z-index:2147483647}.toast{position:fixed;top:20%;left:50%;transform:translate(-50%);background:#111827;color:#fff;padding:8px 14px;border-radius:999px;box-shadow:0 10px 20px #0003;font-weight:700;animation:fadeUp .9s ease both;z-index:9999}@keyframes fadeUp{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}.global-player{position:sticky;top:0;z-index:40;background:var(--card);color:var(--text);border-bottom:1px solid var(--border);display:grid;grid-template-columns:1fr auto auto auto;gap:10px;padding:10px 12px}.global-player:not(.is-playing){z-index:1}.global-player.is-playing{z-index:800}.global-player .gp-title{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;font-weight:500}.global-player .gp-controls{display:flex;gap:6px;align-items:center}.global-player .gp-vol input{width:120px}.global-player .gp-view iframe,.global-player .gp-view audio{width:320px;height:60px;border:0}.global-player .gp-view iframe{border-radius:8px;background:#000}.global-player .gp-view audio{height:32px}.modal-backdrop{position:fixed;inset:0;background:#00000059;display:grid;place-items:center;z-index:50}.modal{width:min(840px,92vw);max-height:min(92vh,760px);overflow:auto;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:12px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.modal-tabs{display:flex;gap:8px;margin-bottom:12px}.modal-body{display:grid;gap:10px}.modal .hint{color:var(--muted);font-size:12px}.modal .mono{font-variant-numeric:tabular-nums}.row-sb{display:flex;align-items:center;justify-content:space-between}.xp-overview{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px;margin-top:12px}.xp-pill{display:flex;gap:10px;align-items:center;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:10px}.xp-ico{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;color:#fff;font-size:18px}.xp-info{flex:1}.xp-name{font-weight:600;letter-spacing:.2px}.xp-meta{display:flex;gap:10px;color:var(--muted);font-size:12px}.xp-bar{height:6px;border-radius:999px;background:#e5e7eb;overflow:hidden;margin-top:6px}.xp-bar>div{height:100%;border-radius:999px;transition:width .45s ease}.sf-forest{display:grid;gap:12px}.sf-card{border:1px solid var(--border);border-radius:16px;padding:12px;background:var(--card)}.sf-head{display:grid;grid-template-columns:1fr auto;align-items:center;gap:10px;margin-bottom:8px}.sf-head-left{display:flex;align-items:center;gap:8px}.sf-dot{width:12px;height:12px;border-radius:999px}.sf-title{margin:0;font-size:16px}.sf-meter-wrap{display:grid;gap:4px}.sf-meter{width:240px;height:8px;background:var(--accent-weak);border-radius:999px;overflow:hidden;border:1px solid var(--border)}.sf-meter-fill{height:100%;border-radius:999px;transition:width .35s ease}.sf-meter-caption{font-size:12px;color:var(--muted)}.sf-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.sf-grid>*{min-width:0}.sf-row{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));position:relative}.sf-node{position:relative;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:10px;transition:transform .15s ease,box-shadow .2s ease,border-color .2s ease;overflow:hidden}.sf-node .sf-node-chip{position:absolute;top:-6px;left:-6px;width:14px;height:14px;border-radius:999px;box-shadow:0 2px 10px #00000026}.sf-node-title{font-weight:700}.sf-node-req{font-size:12px;color:var(--muted);margin-top:2px}.sf-node-status{font-size:12px;margin-top:6px}.sf-node.locked{opacity:.65}.sf-node.unlocked{border-color:#a7f3d0;box-shadow:0 0 0 3px #10b9811f}.sf-node.owned{border-color:#93c5fd;box-shadow:0 0 0 3px #3b82f626;transform:translateY(-1px)}.sf-conn{position:absolute;inset:auto 0 0;height:60px;width:100%;pointer-events:none}.sf-badge{display:flex;gap:8px;align-items:center;border:1.5px solid;border-radius:12px;padding:8px;background:var(--card)}.sf-ico{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;color:#fff;font-size:18px}.sf-name{font-weight:700;line-height:1}.sf-level{font-size:12px;color:var(--muted)}.sf-bar{margin-top:8px;height:8px;border-radius:6px;background:var(--accent-weak);overflow:hidden;border:1px solid var(--border)}.sf-bar-fill{height:100%;border-radius:6px}.sf-traits{margin-top:8px;display:flex;gap:6px;flex-wrap:wrap}.sf-chip{padding:4px 8px;border-radius:999px;border:1px dashed var(--border);font-size:12px;color:var(--muted);background:transparent}.sf-chip.on{border-style:solid;color:#0b1220;background:#a7f3d0;border-color:#34d399}.top-achievements{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.add-task-bar .dueWrap>.btn,.add-task-bar .repeatWrap>.btn,.add-task-bar .xpGroup .btn[title="Allocate branches"]{display:none}.ach-pill{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:16px;background:linear-gradient(180deg,var(--card),rgba(0,0,0,.02));border:1px solid color-mix(in srgb,var(--border) 80%,transparent);font-size:13px;box-shadow:0 3px 10px #0f172a14;position:relative;overflow:visible;z-index:0}.ach-pill:after{content:"";position:absolute;inset:-4px;border-radius:inherit;opacity:0;pointer-events:none;transform:scale(.98);transition:opacity .25s ease,transform .25s ease;z-index:-1;background:var(--accent)}.ach-pill:hover:after{transform:scale(1.02)}.ach-pill-icon{font-size:16px;line-height:1}.ach-pill-label{font-weight:600}.ach-pill-tier{font-size:12px;color:var(--muted);margin-left:8px;padding-left:8px;border-left:1px solid var(--border)}.ach-hall .tab,.achievements .tab,.ach-tabs .tab,.achievements-hall .tab{height:34px;padding:0 10px;font-size:13px;line-height:1}.ach-hall .tab.active,.achievements .tab.active,.ach-tabs .tab.active,.achievements-hall .tab.active{height:34px;padding:0 10px}.tab-page,.tavern-page,.story-page,.tasks-page{min-height:100dvh;display:grid;align-content:start}body{scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--muted) 40%,transparent) transparent}body::-webkit-scrollbar{width:8px}body::-webkit-scrollbar-track{background:transparent}body::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--muted) 35%,transparent);border-radius:8px}body::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--muted) 55%,transparent)}.challenge-list{max-height:min(40vh,260px)}.tavern-grid{display:grid;grid-template-columns:260px 1fr 260px;gap:12px;align-items:start}.tavern-grid>*{min-width:0}.tavern-col{display:grid;gap:12px;align-self:start}.tavern-col-mid{align-content:start}.music-tab{display:grid;gap:12px}.tavern-queue-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center;width:100%;max-width:100%;overflow:hidden}.tavern-queue-row .queue-title{flex:1 1 200px;min-width:0;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:break-word;overflow-wrap:anywhere}.lists-toolbar{display:grid;grid-template-columns:1fr auto;align-items:start;gap:8px;margin:16px 0 8px}.lists-toolbar__chips{display:flex;gap:6px;flex-wrap:wrap;min-width:0}.lists-toolbar__chips .btn{flex:0 1 auto}.lists-toolbar__menu{align-self:start}.lists-toolbar__menu .btn{white-space:nowrap}.journal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.social-panel{display:grid;gap:12px}.social-search-row input{min-width:0}.social-row,.social-request{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.social-row-main{flex:1 1 200px;min-width:0}.social-row-main b{display:block;overflow-wrap:anywhere}.social-row-actions{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.dark body{background:var(--bg);color:var(--text)}.dark .card{background:var(--card);border-color:var(--border);box-shadow:0 8px 22px #00000059}.dark .progress-shell,.dark .bar::-webkit-progress-bar{background:#5da2ff2e}.dark .bar::-webkit-progress-value{background:linear-gradient(90deg,#22c55e,#16a34a)}.dark .badge{background:#0f1b2c;color:#c7d2fe;border-color:#203052}.dark .badge.on{background:#0d2748;color:#9ec8ff;border-color:#1f3b63}.dark .origin-banner{background:#ffffff08}.dark input,.dark textarea,.dark select{background:#0e1730;border-color:#2a3752}.dark .add input,.dark .add select{background:#0f172a}.dark .sf-meter{background:#0b2130;border-color:#132133}.dark .sf-node{background:#0f172a}.dark .sf-chip.on{color:#e7ffee;background:#065f46;border-color:#34d399}.dark .ach-pill{background:linear-gradient(180deg,#0f172aeb,#0f172ac7);border-color:#94a3b859;box-shadow:0 10px 24px #080d1e8c}.dark .ach-pill-tier{border-color:#94a3b840;color:#cbd5e1bf}@media (max-width: 900px){#root{padding:12px 0 0}:root{--card-max: 880px;--gutter: 12px}.app-root{padding-left:calc(var(--gutter) + env(safe-area-inset-left,0px))!important;padding-right:calc(var(--gutter) + env(safe-area-inset-right,0px))!important;padding-top:clamp(1.25rem,5vw,2.5rem);padding-bottom:max(80px,env(safe-area-inset-bottom) + 20px);box-sizing:border-box}.card{width:100%;max-width:min(var(--card-max),100%);min-height:80dvh;margin-inline:auto;padding:clamp(.75rem,3vw,1rem);border-radius:16px;background:color-mix(in srgb,var(--card) 92%,transparent)}.top-tabs{width:100%;max-width:min(var(--card-max),100%);margin-inline:auto;box-sizing:border-box;padding-inline:8px}.global-player .gp-view iframe,.global-player .gp-view audio{width:100%!important;max-width:100%!important}.header h1,.header .logo{font-size:clamp(1.125rem,4vw,1.375rem)}.stats{grid-template-columns:repeat(3,1fr);gap:clamp(2px,1vw,3px);margin:clamp(.25rem,1vw,.3125rem) 1% 0}.stat .label{font-size:clamp(10px,2.5vw,12px)}.stat .value{font-size:clamp(.875rem,3vw,1rem)}.add{flex-direction:column;align-items:stretch;gap:clamp(.5rem,2vw,.75rem)}.add .titleInput{flex:1 1 100%;font-size:clamp(1rem,3.5vw,1.1rem);padding:clamp(8px,2vw,10px) clamp(10px,2.5vw,14px)}.add .xpGroup,.add .dueGroup{flex-direction:row;justify-content:space-between;width:100%}.add .xpInput,.add .dueInput{width:clamp(48px,12vw,56px)}.add .xpMeter{flex:1;min-width:60px}.btn,.tab,input[type=text],input[type=number],textarea{height:clamp(36px,10vw,40px);padding:0 clamp(10px,2.5vw,12px);font-size:clamp(.875rem,3vw,1rem)}.task{padding:clamp(8px,2vw,10px);gap:clamp(6px,2vw,10px)}.task .title{font-size:clamp(.875rem,3.5vw,1rem)}.task .xp{font-size:clamp(10px,2.5vw,12px)}.sf-meter{width:100%;max-width:240px}.sf-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.sf-row{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.xp-overview{grid-template-columns:1fr}.global-player{grid-template-columns:1fr;gap:clamp(6px,2vw,10px);padding:clamp(8px,2vw,10px)}.modal{width:95vw;padding:clamp(10px,2.5vw,12px)}.metaRow{flex-direction:column;align-items:flex-start;gap:8px}.actions{width:100%;justify-content:space-between}.tavern-grid,.tavern-col{grid-template-columns:1fr}.music-tab{padding:clamp(.75rem,3vw,1rem)}.tavern-queue-row{align-items:flex-start;width:100%;max-width:100%;overflow:hidden}.tavern-queue-row .queue-title{width:100%;white-space:normal;text-overflow:clip;overflow:hidden;-webkit-line-clamp:2;-webkit-box-orient:vertical}.lists-toolbar{grid-template-columns:1fr}.lists-toolbar__menu{justify-self:end}.journal-grid{grid-template-columns:1fr}.social-row,.social-request{align-items:flex-start}.social-row-actions{width:100%;justify-content:flex-start}.social-search-row{align-items:stretch}.ach-hall .tab,.achievements .tab,.ach-tabs .tab,.achievements-hall .tab{height:32px;font-size:12px;padding:0 8px}}@media (max-width: 720px){.global-player{grid-template-columns:1fr auto;grid-auto-rows:auto}.global-player .gp-view{grid-column:1 / -1}}@media (max-width: 600px){.task .title-main{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.milestone-item{flex-wrap:wrap;gap:6px}.milestone-item>*{min-width:0;max-width:100%}.milestone-title{min-width:0;flex:1 1 100%;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:break-word}}.is-touch .add .xpInput,.is-touch .add .dueInput,.is-touch .add .dueSelect,.is-touch .xp-chip-input{min-height:44px}.is-touch .add .aiBtn{width:44px;height:44px}.is-touch .ach-pill{font-size:clamp(12px,3vw,13px)}.is-touch .ach-pill-icon{font-size:clamp(16px,3.8vw,18px);line-height:1}.is-touch .xp-ico,.is-touch .sf-ico{width:clamp(36px,10vw,44px);height:clamp(36px,10vw,44px)}.is-touch .awards-grid{display:grid!important;grid-template-columns:1fr 1fr;gap:6px}.is-touch .awards-grid>*{min-width:0}.dark .xp-bar{background:#223049}.ach-controls select,.ach-controls input[type=search]{height:32px;padding:0 10px;font-size:13px;line-height:1;width:auto;min-width:120px}@media (max-width: 600px){.ach-controls select,.ach-controls input[type=search]{height:30px;font-size:12px;padding:0 8px;min-width:100px}}.global-player.is-playing~.app-root .symbols{z-index:10}.is-touch .btn,.is-touch .tab,.is-touch input[type=text],.is-touch input[type=number],.is-touch textarea,.is-touch select{min-height:44px;padding-block:10px}.is-touch .icon-btn{min-width:44px;min-height:44px}.is-touch .icon-btn.sm{min-width:36px;min-height:36px}.is-touch .task input[type=checkbox]{width:22px;height:22px}.immersive-toggle{display:none}@media (max-width: 900px){html,body{overflow-y:auto;overflow-x:hidden;-ms-overflow-style:none;scrollbar-width:none}html::-webkit-scrollbar,body::-webkit-scrollbar{width:0;height:0}.theme-stage,.stage{position:absolute!important;inset:0!important;z-index:-1!important;pointer-events:none!important}.theme-stage *,.stage *{z-index:-1!important;pointer-events:none!important}.app-root{position:relative;z-index:100;isolation:isolate;padding-left:calc(var(--gutter) + env(safe-area-inset-left,0px))!important;padding-right:calc(var(--gutter) + env(safe-area-inset-right,0px))!important;box-sizing:border-box}:root{--gutter: 12px;--card-max: 880px}#root{padding-left:0!important;padding-right:0!important;padding-block-start:calc(12px + env(safe-area-inset-top,0px));box-sizing:border-box}.card{position:relative;width:100%;max-width:var(--card-max);margin-inline:auto;overflow:visible!important;z-index:20}.header,.header-top,.brand-left,.char-wrap{overflow:visible!important}.top-tabs{position:relative;z-index:2000!important;display:flex;flex-wrap:wrap;justify-content:center;gap:10px 12px;margin:8px auto 10px;width:100%!important;max-width:min(var(--card-max),100%)!important;box-sizing:border-box!important;padding-inline:8px;pointer-events:auto!important;-webkit-tap-highlight-color:transparent}.top-tabs .tab{height:34px;line-height:34px;padding:0 12px;font-size:13px;flex:0 1 clamp(120px,30%,180px);text-align:center;min-width:0;touch-action:manipulation}.card .sf-forest,.card .sf-card,.card .sf-grid{max-width:100%}.sf-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.modal,.modal-body,.modal-tabs{max-width:100%;overflow:hidden}.modal *,.settings *,.settings-panel *,.settings-grid *{max-width:100%;min-width:0;overflow-wrap:anywhere;word-break:break-word}.settings-grid{display:grid;grid-template-columns:1fr;gap:10px}.challenge-list{max-height:min(50vh,360px)!important;overflow-y:auto;overflow-x:hidden}.challenge-list>*{min-width:0;max-width:100%}.challenge-card,.challenge-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px}.challenge-card .title,.challenge-row .title{min-width:0;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.app-root .card{max-width:100%!important}}@media (max-width: 900px){.is-touch .immersive-toggle{display:inline-grid;place-items:center;width:28px;height:28px}html:has(body.is-immersive){height:100dvh;overflow:hidden}body.is-immersive{overflow:hidden;overscroll-behavior:none}body.is-immersive .theme-stage,body.is-immersive .stage,body.is-immersive .stage-on{display:none!important}body.is-immersive .app-root{padding:0!important;place-items:stretch;min-height:100dvh;z-index:100}body.is-immersive .card{position:fixed;inset:0;width:100vw;height:100dvh;margin:0;border:0;border-radius:0;box-shadow:none;padding:clamp(10px,2.5vw,14px);z-index:1000;overflow-y:auto!important;overflow-x:visible!important;-webkit-overflow-scrolling:touch;touch-action:pan-y;overscroll-behavior-y:contain}body.is-immersive .immersive-toggle{position:fixed;top:calc(env(safe-area-inset-top,0px) + 10px);right:calc(env(safe-area-inset-right,0px) + 10px);z-index:1200;background:#00000073;color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.15);border-radius:8px}body.is-immersive .top-tabs{display:none!important}}@media (max-width: 600px){.xp-overview{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.xp-overview .xp-pill{padding:8px}.xp-overview .xp-ico{width:30px;height:30px}.xp-overview .xp-name{font-size:clamp(11px,3vw,12px)}.xp-overview .xp-bar{height:4px}.xp-overview .xp-meta{font-size:11px}}@media (max-width: 480px){.sf-grid{grid-template-columns:1fr}}@media (max-width: 600px){.subtask-list{overflow-x:visible!important;overflow-y:visible!important}.subtask-list .task .menuWrap{position:relative;z-index:300}.subtask-list .task .task-menu{z-index:4000!important}.task .title{display:block!important;overflow:visible!important}.task .title-main{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}}@media (max-width: 900px){.global-player:not(.is-playing):not([data-playing=true]){display:none!important}}@media (max-width: 900px){.modal{max-width:100%!important;overflow-y:auto!important;overflow-x:hidden!important;max-height:min(92dvh,760px)!important;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y}.modal-body,.modal-tabs{max-width:100%!important;overflow:hidden!important}.modal-backdrop{overscroll-behavior:contain;touch-action:none}}@media (max-width: 900px){body.is-immersive .global-player{transform:translateY(-200%)!important;opacity:0!important;pointer-events:none!important}}@media (max-width: 900px){.char-wrap{--badge-left: -6px;--badge-top: 120%;--badge-tx: var(--badge-left);--badge-ty: -50%;--badge-rot: -90deg;--badge-scale: .9;--badge-z: 3000;position:relative;z-index:200}.char-wrap .tier-banner{position:absolute!important;left:max(0px,var(--badge-left))!important;top:var(--badge-top)!important;transform:translate(var(--badge-tx, var(--badge-left)),var(--badge-ty)) rotate(var(--badge-rot)) scale(var(--badge-scale))!important;transform-origin:left center!important;z-index:var(--badge-z)!important;pointer-events:none!important;filter:drop-shadow(0 8px 22px rgba(0,0,0,.22))}}@media (max-width: 900px){.card{width:100%!important;max-width:min(var(--card-max),100%)!important}.top-tabs{width:100%!important;max-width:min(var(--card-max),100%)!important;box-sizing:border-box!important}}.app-root .card{margin-inline:auto!important}@media (max-width: 480px){:root{--gutter: 8px}#root,.app-root{padding-left:calc(var(--gutter) + env(safe-area-inset-left,0px))!important;padding-right:calc(var(--gutter) + env(safe-area-inset-right,0px))!important;box-sizing:border-box}.app-root .card,.card{width:100%!important;max-width:100%!important;margin-inline:auto!important}.top-tabs{width:100%!important;max-width:100%!important;margin-inline:auto!important;justify-content:center!important}}@media (max-width: 480px){.subtasks,.subtask-list,.child-list,.milestone-list{max-width:100%!important;overflow-x:hidden!important}.subtask-row,.child-row,.milestone-item{display:flex;flex-wrap:wrap;gap:6px;align-items:center;box-sizing:border-box;max-width:100%}.subtask-row>*,.child-row>*,.milestone-item>*{min-width:0!important;max-width:100%!important}.subtask-title,.child-title,.milestone-title{flex:1 1 100%;min-width:0;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:break-word}.subtask-actions,.child-actions,.milestone-actions{flex:0 0 auto;display:inline-flex;gap:6px;max-width:100%}.xp-chip-input,.xpInput,.dueInput,.dueSelect{width:auto!important;min-width:clamp(44px,18vw,56px);max-width:30vw;text-align:center}.subtask-editor,.child-editor,.milestone-edit{width:100%!important;max-width:100%!important}.top-tabs{width:100%!important;max-width:100%!important;margin-inline:auto!important;justify-content:center!important;box-sizing:border-box!important}.list:not(.challenge-list)>.task{flex-wrap:wrap;align-items:flex-start}.list:not(.challenge-list)>.task>.title{flex:1 1 100%;min-width:0!important}.list:not(.challenge-list)>.task>.subtask-list{flex:1 1 100%;min-width:0!important;width:100%;order:10;margin-top:8px!important}}@media (max-width: 600px){.subtask-list .task{flex-wrap:wrap;align-items:flex-start;max-width:100%;box-sizing:border-box;margin-left:0!important;padding-left:16px;position:relative;overflow:visible!important}.subtask-list .task>*{min-width:0!important;max-width:100%}.subtask-list .task .title{flex:1 1 160px;min-width:0!important;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:break-word}}@media (max-width: 600px){.list:not(.challenge-list)>.task{flex-wrap:wrap;align-items:flex-start}.list:not(.challenge-list)>.task>.title{flex:1 1 100%;min-width:0!important}.list:not(.challenge-list)>.task>.subtask-list{flex:1 1 100%;min-width:0!important;order:10;margin-top:6px!important}.subtask-list .task{display:grid;grid-template-columns:auto 1fr auto;grid-template-areas:"chk xp menu" "title title title";align-items:center;row-gap:4px;column-gap:8px}.subtask-list .task>*{min-width:0}.subtask-list .task input[type=checkbox]{grid-area:chk}.subtask-list .task .xp{grid-area:xp}.subtask-list .task .menuWrap{grid-area:menu;justify-self:end}.subtask-list .task .title{grid-area:title;font-size:.85rem;min-width:0!important;display:block;overflow:visible;text-overflow:clip;-webkit-line-clamp:unset;-webkit-box-orient:unset;white-space:normal;word-break:break-word;overflow-wrap:anywhere;margin-top:2px}.subtask-list .task .title-main{display:block;overflow:visible;text-overflow:clip;-webkit-line-clamp:unset;-webkit-box-orient:unset;white-space:normal;word-break:break-word;overflow-wrap:anywhere}}.global-player.is-playing~.app-root{z-index:1!important}:root[data-skin=fairy] body,:root[data-skin=fairy] .app-root{font-family:Quicksand,Comfortaa,Segoe UI,system-ui,sans-serif}:root[data-skin=forest] body,:root[data-skin=forest] .app-root{font-family:Palatino,Palatino Linotype,Book Antiqua,Georgia,serif}:root[data-skin=warrior] body,:root[data-skin=warrior] .app-root{font-family:Cinzel,Times New Roman,Times,serif}:root[data-skin=scholar] body,:root[data-skin=scholar] .app-root{font-family:Cormorant Garamond,Garamond,Times New Roman,serif}:root[data-skin=witch] body,:root[data-skin=witch] .app-root{font-family:Cinzel,Philosopher,Georgia,serif}:root[data-skin=desert] body,:root[data-skin=desert] .app-root{font-family:Papyrus,Segoe UI,system-ui,sans-serif}:root[data-skin=artisan] body,:root[data-skin=artisan] .app-root{font-family:Lobster,Segoe UI,system-ui,cursive}.char-wrap{position:relative;display:grid;place-items:center}.tier-banner{position:absolute;top:-36px;left:-30px;z-index:3;display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;background:#0f172ae0;box-shadow:0 12px 24px #0f172a59;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#f8fafc;font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.tier-icon{font-size:13px;line-height:1;color:#facc15}.tier-label{letter-spacing:.08em}.tier-sep{width:1px;height:16px;background:#f8fafc33}.tier-rank{font-size:11px;font-weight:500;color:#e2e8f0cc;min-width:56px;text-align:center;display:inline-grid;align-items:center;justify-items:center;letter-spacing:.12em;line-height:1.1}.tier-rank .tier-word{display:block}.tier-rank .tier-num{display:block;font-weight:700;margin-top:2px}.char-badge{width:92px;height:92px;border-radius:50%;position:relative;display:grid;place-items:center;box-shadow:0 10px 28px #0000002e,inset 0 0 0 2px #fff9;overflow:hidden}.char-glow{position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,#fff7,transparent 60%)}.char-emoji{font-size:38px;transform:translateY(2px)}.char-level{position:absolute;bottom:-10px;background:#111827;color:#fff;padding:2px 8px;font-size:12px;border-radius:999px;box-shadow:0 6px 14px #00000040}.celebrate .char-badge{animation:hop .8s ease-in-out 2}@keyframes hop{0%{transform:translateY(0) scale(1)}30%{transform:translateY(-10px) scale(1.05)}60%{transform:translateY(0) scale(1)}to{transform:translateY(-6px) scale(1.03)}}.confetti{position:absolute;inset:-10px;pointer-events:none;overflow:hidden}.confetti span{--i: 0;position:absolute;top:0;left:50%;width:6px;height:10px;background:hsl(calc(var(--i)*15),90%,60%);transform:translate(calc((var(--i) - 12) * 6px)) rotate(0);animation:drop 1.2s ease-out forwards;border-radius:2px}@keyframes drop{0%{opacity:0;transform:translateY(-10px) translate(0) rotate(0)}20%{opacity:1}to{opacity:0;transform:translateY(120px) translate(calc((var(--i) - 12) * 10px)) rotate(240deg)}}.xp-pill{position:relative}.xp-pill .xp-bar{position:relative;overflow:hidden}.xp-bar-fill{height:100%;border-radius:999px}.xp-bar-fill.pulse{box-shadow:0 0 12px currentColor}.xp-pill.xp-branch-pulse{box-shadow:0 14px 32px #0f172a1f}.xp-pill.xp-branch-pulse:after{content:"";position:absolute;inset:6px;border-radius:18px;border:1px solid color-mix(in srgb,var(--accent) 35%,transparent);opacity:0;animation:xpBranchGlow 1.2s ease-out forwards;pointer-events:none}.xp-branch-overlay{position:absolute;right:0;top:-18px;font-size:11px;color:var(--text);padding:2px 8px;background:color-mix(in srgb,var(--card) 85%,transparent);border-radius:999px;border:1px solid color-mix(in srgb,var(--border) 65%,transparent);box-shadow:0 8px 18px #0f172a2e;opacity:0;transform:translateY(-6px);animation:xpBranchOverlay .9s ease forwards}.xp-branch-sheen{position:absolute;inset:0;border-radius:999px;background:linear-gradient(110deg,transparent,rgba(255,255,255,.65),transparent);animation:xpBranchSheen .8s ease-out forwards;pointer-events:none}@keyframes xpBranchGlow{0%{opacity:.8;transform:scale(.98)}to{opacity:0;transform:scale(1.04)}}@keyframes xpBranchOverlay{0%{opacity:0;transform:translateY(-4px)}20%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-4px)}}@keyframes xpBranchSheen{0%{opacity:.7;transform:translate(-60%)}to{opacity:0;transform:translate(120%)}}.xp-hud-stats{margin-top:0;row-gap:4px}.xp-hud-shell{position:relative;overflow:visible;isolation:isolate;height:10px;border-radius:999px}.xp-hud-shell.pulse:after{content:"";position:absolute;inset:-3px;border-radius:999px;border:2px solid color-mix(in srgb,var(--accent) 35%,transparent);opacity:0;animation:xpHudGlow .8s ease-out forwards;pointer-events:none}@keyframes xpHudGlow{0%{opacity:.9;transform:scaleX(1)}to{opacity:0;transform:scaleX(1.05)}}.xp-hud-overlay{position:absolute;left:12px;right:12px;bottom:calc(100% + 6px);display:flex;align-items:center;gap:10px;justify-content:flex-start;font-size:12px;color:var(--text);padding:4px 10px;border-radius:999px;background:color-mix(in srgb,var(--card) 75%,transparent);border:1px solid color-mix(in srgb,var(--border) 60%,transparent);box-shadow:0 10px 26px #0f172a1f;opacity:0;transform:translateY(4px);transition:opacity .25s ease,transform .25s ease;pointer-events:none}.xp-hud-overlay.visible{opacity:1;transform:translateY(0)}.xp-hud-overlay .badge{height:auto;padding:2px 8px;border-radius:999px;font-size:11px;background:color-mix(in srgb,var(--accent-weak) 60%,transparent);border-color:color-mix(in srgb,var(--accent) 25%,transparent);color:color-mix(in srgb,var(--accent) 80%,var(--text))}.xp-pulse-wave{position:absolute;inset:2px;border-radius:999px;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.7) 45%,transparent 70%);opacity:0;pointer-events:none;animation:xpPulseSweep .8s ease-out forwards;mix-blend-mode:screen}@keyframes xpPulseSweep{0%{opacity:.8;transform:translate(-40%)}to{opacity:0;transform:translate(130%)}}.add.addTaskBar{display:grid;grid-template-columns:1fr minmax(120px,1fr) minmax(96px,auto) minmax(96px,auto) minmax(44px,auto) minmax(44px,auto) minmax(88px,auto);grid-template-areas:"title xp due repeat ai tools add" "notes notes notes notes notes notes notes";gap:10px;align-items:center;--xp-input-width: clamp(70px, 18vw, 90px)}.add.addTaskBar>input.titleInput{grid-area:title}.add.addTaskBar>.xpGroup{grid-area:xp}.add.addTaskBar>.dueWrap{grid-area:due}.add.addTaskBar>.repeatWrap{grid-area:repeat}.add.addTaskBar>.toolsWrap{grid-area:tools}.add.addTaskBar>.aiBtn{grid-area:ai}.add.addTaskBar>.addBtn{grid-area:add}.add.addTaskBar>.notesWrap{grid-area:notes}.add.addTaskBar .titleInput,.add.addTaskBar .xpInput,.add.addTaskBar textarea{width:100%;border:1px solid var(--border, #e5e7eb);background:var(--surface, #fff);color:var(--text, #111827);border-radius:12px;padding:10px 12px;outline:none}.add.addTaskBar .titleInput::placeholder,.add.addTaskBar textarea::placeholder{opacity:.6}.add.addTaskBar .xpGroup .xpInput{width:var(--xp-input-width);min-width:60px}.add.addTaskBar .btn{border:1px solid var(--border);background:var(--card);color:var(--text);border-radius:12px;padding:8px 12px;cursor:pointer}.add.addTaskBar .btn.primary{background:var(--primary, #4461ff);color:#fff;border-color:transparent}.add.addTaskBar .btn:disabled{opacity:.55;cursor:not-allowed}.add.addTaskBar .xpLabel{font-size:12px;opacity:.7;margin-right:6px}.add.addTaskBar .hint{opacity:.7;font-size:12px}.add.addTaskBar .mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace}.xp-pill{display:grid;grid-template-columns:34px 1fr;gap:10px;border:1px solid var(--border);border-radius:12px;background:var(--card)}.xp-ico{display:grid;place-items:center;width:34px;height:34px;border-radius:10px;color:#fff;font-weight:700}.xp-info .xp-name{font-weight:700}.xp-chip-input{border:1px solid var(--border, #e5e7eb);border-radius:10px;padding:6px 8px}.chip{border:1px solid currentColor;border-radius:999px;padding:1px 8px;font-size:12px}.row-sb{display:flex;justify-content:space-between;align-items:center}.repeat-card{border:1px dashed var(--border);border-radius:12px;padding:10px;background:var(--surface, #f9fafb)}.weekday-row{display:flex;gap:6px;flex-wrap:wrap}.weekday-chip{border:1px solid var(--border);background:var(--card);color:var(--text);border-radius:10px;padding:6px 10px;min-width:42px;text-align:center;cursor:pointer}.weekday-chip.active{background:var(--primary, #4461ff);border-color:var(--primary, #4461ff);color:#fff}.mini-cal{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;padding:6px;border:1px solid var(--border);border-radius:10px;background:var(--card)}.mini-cal-head{font-size:11px;text-align:center;opacity:.7}.mini-cal-cell{border:1px solid var(--border);border-radius:10px;padding:6px 4px;background:var(--surface, #fff);cursor:pointer;text-align:center}.mini-cal-cell.active{background:var(--primary, #4461ff);color:#fff;border-color:transparent;box-shadow:0 6px 16px #0000001f}.mini-cal-cell.empty{border:none;background:transparent;cursor:default}.modal-backdrop{position:fixed;inset:0;background:#02061773;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{width:min(92vw,900px);background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 50px #0000002e;padding:14px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.icon-btn{background:transparent;border:none;cursor:pointer;font-size:18px;line-height:18px;padding:6px 8px;border-radius:8px}.icon-btn:hover{background:#0000000f}@media (max-width: 860px){.add.addTaskBar{grid-template-columns:1fr minmax(120px,1fr) minmax(44px,auto) minmax(44px,auto) minmax(88px,auto);grid-template-areas:"title title title add add" "xp    xp    ai    tools add" "due   repeat repeat repeat repeat" "notes notes  notes notes  notes"}.add.addTaskBar .xpGroup{flex-wrap:wrap;min-width:0}}@media (max-width: 600px){.add.addTaskBar{grid-template-columns:1fr auto;grid-template-areas:"title add" "xp    add" "ai    tools" "due   repeat" "notes notes";align-items:flex-start;--xp-input-width: clamp(78px, 42vw, 150px)}.add.addTaskBar .titleInput{min-width:0}.add.addTaskBar>.addBtn{align-self:stretch;min-height:100%}.add.addTaskBar>.aiBtn{justify-self:flex-start}.add.addTaskBar>.toolsWrap{justify-self:flex-end}.add.addTaskBar .xpGroup{flex-wrap:wrap;gap:8px}.add.addTaskBar .xpGroup .xpInput{width:var(--xp-input-width);flex:1 1 var(--xp-input-width)}.add.addTaskBar .xpGroup .btn{padding:7px 10px}}@media (max-width: 420px){.add.addTaskBar{grid-template-columns:1fr;grid-template-areas:"title" "xp" "add" "ai" "tools" "due" "repeat" "notes";--xp-input-width: clamp(82px, 56vw, 180px)}.add.addTaskBar>.addBtn,.add.addTaskBar .btn{width:100%;text-align:center}.add.addTaskBar .xpGroup{justify-content:flex-start}}.tn-wrap{position:relative;display:inline-block}.tn-btn{position:relative}.tn-dot{position:absolute;top:-2px;right:-2px;width:8px;height:8px;border-radius:999px;background:#22c55e;border:2px solid var(--card,#fff)}.tn-count{position:absolute;top:-6px;right:-6px;background:#0f172a;color:#fff;border-radius:999px;font-size:10px;padding:0 4px;line-height:14px;border:2px solid var(--card)}.tn-pop{position:absolute;right:0;top:110%;z-index:60;min-width:260px;max-width:min(420px,92vw);background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 26px #00000029;padding:10px;display:grid;gap:8px}.tn-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.tn-input{display:grid;gap:6px}.tn-input textarea{width:100%;min-height:64px;resize:vertical;border:1px solid var(--border);border-radius:10px;padding:8px 10px;background:#fff;color:var(--text)}.dark .tn-input textarea{background:#0f172a}.tn-actions{display:flex;gap:6px;justify-content:flex-end}.tn-list{display:grid;gap:8px;max-height:260px;overflow:auto}.tn-note{border:1px solid var(--border);border-radius:10px;padding:8px;background:color-mix(in srgb,var(--card) 96%,transparent)}.tn-note-head{display:flex;align-items:center;justify-content:space-between;gap:6px;font-size:12px;color:var(--muted)}.tn-note-body{white-space:pre-wrap;word-break:break-word;margin-top:4px}.tn-note-edit textarea{width:100%;min-height:60px;resize:vertical}.tn-chip{font-size:11px;color:var(--muted)}.tn-pin{color:#f59e0b}.tn-empty{color:var(--muted);font-size:12px;text-align:center;padding:6px 0}.inbox-lib{display:grid;gap:12px}.inbox-row{display:flex;align-items:flex-start;gap:12px;flex-wrap:wrap}.inbox-col{flex:1 1 360px;min-width:280px}.tpl-editor,.tpl-list,.inbox-notes{border:1px solid var(--border);border-radius:12px;padding:10px;background:var(--card)}.tpl-editor .row{display:flex;gap:8px;flex-wrap:wrap}.tpl-editor input[type=text],.tpl-editor input[type=number],.tpl-editor select,.tpl-editor textarea{height:36px;padding:0 10px;border:1px solid var(--border);border-radius:8px}.tpl-editor textarea{min-height:64px;resize:vertical;padding:8px 10px;height:auto}.tpl-editor .actions{display:flex;gap:8px;justify-content:flex-end}.tpl-card{border:1px solid var(--border);border-radius:10px;padding:8px;display:grid;gap:6px;background:color-mix(in srgb,var(--card) 96%,transparent)}.tpl-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.tpl-card-title{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tpl-card-meta{font-size:12px;color:var(--muted);display:flex;gap:8px;align-items:center}.tpl-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:8px}.tpl-actions{display:flex;gap:6px;flex-wrap:wrap}.inbox-notes .n-input textarea{width:100%;min-height:64px;resize:vertical;padding:8px 10px;border:1px solid var(--border);border-radius:10px}.inbox-notes .n-actions{display:flex;gap:6px;justify-content:flex-end}.inbox-notes .n-list{display:grid;gap:8px;max-height:240px;overflow:auto}.inbox-notes .n-item{border:1px solid var(--border);border-radius:10px;padding:8px}.inbox-notes .n-head{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:12px;color:var(--muted)}.mono{font-variant-numeric:tabular-nums}.xp-micro{position:absolute;z-index:2000;transition:opacity .22s ease,transform .22s ease;pointer-events:none}.xp-micro-card{min-width:200px;max-width:280px;padding:10px 12px;border-radius:14px;background:linear-gradient(145deg,color-mix(in srgb,var(--card) 88%,transparent),color-mix(in srgb,var(--card) 92%,transparent));border:1px solid color-mix(in srgb,var(--border) 65%,transparent);box-shadow:0 14px 32px #0f172a38,inset 0 1px #fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:auto}.xp-micro-head{display:flex;align-items:center;gap:8px;justify-content:space-between;font-size:12px;color:var(--text)}.xp-micro-head .badge{background:color-mix(in srgb,var(--accent-weak) 60%,transparent);border-color:color-mix(in srgb,var(--accent) 30%,transparent);color:color-mix(in srgb,var(--accent) 80%,var(--text));height:auto;padding:2px 8px;border-radius:999px;font-size:11px}.xp-micro-bar{position:relative;margin-top:8px;height:12px;border-radius:999px;background:color-mix(in srgb,var(--accent-weak) 88%,transparent);overflow:hidden;border:1px solid color-mix(in srgb,var(--border) 70%,transparent);box-shadow:inset 0 1px #ffffff47}.xp-micro-bar-fill{position:absolute;inset:0;width:0%;background:#22c55e;transition:width .48s cubic-bezier(.16,1,.3,1);border-radius:0}.xp-micro-bar-delta{position:absolute;top:0;bottom:0;background:#119044;opacity:.85;pointer-events:none;border-radius:0 999px 999px 0;border-left:2px solid #0e6b32;transition:width .48s cubic-bezier(.16,1,.3,1)}.xp-micro-bar-caption{position:absolute;right:6px;bottom:100%;font-size:11px;color:var(--muted);margin-bottom:4px}.xp-micro-branches{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.xp-micro-branch{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:10px;border:1px solid var(--border);font-size:11px;color:var(--text);background:color-mix(in srgb,var(--card) 90%,transparent)}.xp-micro-branch .dot{width:8px;height:8px;border-radius:999px;background:var(--accent)}.calendar-root{--hour-h: 44px;--col-gap: 8px;--grid-border: var(--border);position:relative}.calendar-header{display:flex;align-items:center;gap:8px;justify-content:space-between;margin:8px 0 12px;flex-wrap:wrap}.calendar-header .left,.calendar-header .right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.calendar-view-toggle button{padding:6px 10px}.week-grid{display:grid;grid-template-columns:52px repeat(7,1fr);gap:var(--col-gap)}.week-grid .hour-col{color:var(--muted);font-size:12px;text-align:right;padding-right:6px}.week-grid .day-col{position:relative;border:1px solid var(--grid-border);border-radius:10px;background:var(--card);overflow:hidden}.week-grid .day-col .hours{position:relative}.week-grid .day-col .hour-line{position:absolute;left:0;right:0;height:1px;background:var(--border);opacity:.5}.week-grid .day-col .half-line{position:absolute;left:0;right:0;height:1px;background:var(--border);opacity:.3}.week-grid .day-col .now-line{position:absolute;left:0;right:0;height:2px;background:#22c55e;opacity:.9}.allday-row{display:grid;grid-template-columns:52px repeat(7,1fr);gap:var(--col-gap);margin-bottom:10px}.allday-row .allday-cell{min-height:30px;border:1px dashed var(--grid-border);border-radius:10px;background:var(--card);padding:4px}.allday-chip{display:inline-block;padding:2px 6px;margin:2px;border-radius:6px;background:var(--border);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.event{position:absolute;left:2px;right:2px;border-radius:8px;color:#fff;padding:4px 6px;font-size:12px;box-shadow:0 4px 10px #0000002e;cursor:grab;-webkit-user-select:none;user-select:none}.event.done{opacity:.6;text-decoration:line-through}.event .title{font-weight:600;font-size:12px}.event .time{font-size:11px;opacity:.9}.event .handle{position:absolute;left:0;right:0;height:6px;cursor:ns-resize}.event .handle.top{top:-2px}.event .handle.bot{bottom:-2px}.calendar-month{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.calendar-month .cell{min-height:100px;border:1px solid var(--grid-border);border-radius:10px;background:var(--card);padding:6px;position:relative}.calendar-month .cell .date{position:absolute;top:6px;right:8px;font-size:11px;color:var(--muted)}.calendar-empty{color:var(--muted);font-size:14px;padding:10px}.cc-editor{position:absolute;z-index:50;background:var(--card);border:1px solid var(--border);border-radius:18px;padding:12px;box-shadow:0 14px 40px #0000002e;width:min(320px,92vw)}.cc-editor .cc-title{width:100%;box-sizing:border-box;margin-bottom:8px;font-size:14px;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:var(--bg, var(--card))}.cc-editor .cc-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.cc-editor .cc-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px}.cc-editor .cc-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:10px}.cc-editor .chip{padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:var(--card);cursor:pointer;font-size:12px;color:var(--text)}.cc-editor .chip:hover{background:#0000000d}.cc-editor .btn.primary{background:#605cff;color:#fff}.cc-editor select,.cc-editor input[type=time],.cc-editor input[type=date],.cc-editor input[type=datetime-local]{width:100%;box-sizing:border-box;padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:var(--bg, var(--card))}.cc-colors{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.cc-color{width:18px;height:18px;border-radius:999px;border:2px solid #fff;box-shadow:0 1px 4px #00000040;cursor:pointer}.cc-color.sel{outline:2px solid #2b2b2b}.ach-pill{transition:box-shadow .3s ease}.ach-pill[data-ach-type=generic],.ach-pill[data-ach-type=productivity],.ach-pill[data-ach-type=meta],.ach-pill[data-ach-type=time],.ach-pill[data-ach-type=evergreen],.ach-pill[data-ach-type=weekly]{box-shadow:0 0 8px #ffd70066,0 0 16px #ffd7004d,0 0 24px #ffd70033}.ach-pill[data-ach-type=learning],.ach-pill[data-ach-type=wisdom]{box-shadow:0 0 8px #8b5cf680,0 0 16px #8b5cf659,0 0 24px #8b5cf633}.ach-pill[data-ach-type=health]{box-shadow:0 0 8px #22c55e80,0 0 16px #22c55e59,0 0 24px #22c55e33}.ach-pill[data-ach-type=strength]{box-shadow:0 0 8px #ef444480,0 0 16px #ef444459,0 0 24px #ef444433}.ach-pill[data-ach-type=social]{box-shadow:0 0 8px #fb923c80,0 0 16px #fb923c59,0 0 24px #fb923c33}.ach-pill[data-ach-type=trade]{box-shadow:0 0 8px #06b6d480,0 0 16px #06b6d459,0 0 24px #06b6d433}.ach-pill[data-ach-type=athletics]{box-shadow:0 0 8px #10b98180,0 0 16px #10b98159,0 0 24px #10b98133}.ach-pill[data-ach-type=journal]{box-shadow:0 2px 8px #0003,0 6px 18px #00000029,inset 0 0 0 1px #0000000f}.ach-pill:hover{transform:translateY(-2px)}.ach-pill[data-ach-type=generic]:hover,.ach-pill[data-ach-type=productivity]:hover,.ach-pill[data-ach-type=meta]:hover,.ach-pill[data-ach-type=time]:hover,.ach-pill[data-ach-type=evergreen]:hover,.ach-pill[data-ach-type=weekly]:hover{box-shadow:0 0 12px #ffd70099,0 0 20px #ffd70066,0 0 32px #ffd7004d}.ach-pill[data-ach-type=learning]:hover,.ach-pill[data-ach-type=wisdom]:hover{box-shadow:0 0 12px #8b5cf6b3,0 0 20px #8b5cf680,0 0 32px #8b5cf64d}.ach-pill[data-ach-type=health]:hover{box-shadow:0 0 12px #22c55eb3,0 0 20px #22c55e80,0 0 32px #22c55e4d}.ach-pill[data-ach-type=strength]:hover{box-shadow:0 0 12px #ef4444b3,0 0 20px #ef444480,0 0 32px #ef44444d}.ach-pill[data-ach-type=social]:hover{box-shadow:0 0 12px #fb923cb3,0 0 20px #fb923c80,0 0 32px #fb923c4d}.ach-pill[data-ach-type=trade]:hover{box-shadow:0 0 12px #06b6d4b3,0 0 20px #06b6d480,0 0 32px #06b6d44d}.ach-pill[data-ach-type=athletics]:hover{box-shadow:0 0 12px #10b981b3,0 0 20px #10b98180,0 0 32px #10b9814d}.ach-pill[data-ach-type=journal]:hover{box-shadow:0 4px 14px #00000047,0 10px 28px #00000038,inset 0 0 0 1px #00000014}
