:root{--ink: #0E0D0B;--ink-2: #131110;--surface: #1A1813;--surface-2: #221F18;--surface-3: #2A261D;--line: rgba(244,239,227,.08);--line-2: rgba(244,239,227,.14);--paper: #F4EFE3;--muted: #A39C8C;--faint: #6E685C;--accent-rgb: 231,178,76;--gold: rgb(var(--accent-rgb));--gold-2: #F0C76E;--gold-deep: #B98A2E;--gold-soft: rgba(var(--accent-rgb),.14);--gold-line: rgba(var(--accent-rgb),.32);--sage: #8FB089;--sage-soft: rgba(143,176,137,.14);--clay: #CD7551;--clay-soft: rgba(205,117,81,.14);--sky: #7FA8C9;--sky-soft: rgba(127,168,201,.14);--display: "Archivo", "Hanken Grotesk", system-ui, sans-serif;--ui: "Hanken Grotesk", system-ui, sans-serif;--serif: "Newsreader", Georgia, serif;--r-sm: 10px;--r: 16px;--r-lg: 22px;--r-xl: 28px;--shadow: 0 1px 0 rgba(255,255,255,.03) inset, 0 14px 30px -18px rgba(0,0,0,.8);--app-w: 440px}[data-theme=ember]{--accent-rgb:224,122,95;--gold-2:#F09A82;--gold-deep:#B85638;--ink:#100C0B;--ink-2:#160F0D;--surface:#1E1512;--surface-2:#271A16;--surface-3:#31201A;--sage:#9DB082;--sky:#C99A7F}[data-theme=jade]{--accent-rgb:79,201,162;--gold-2:#7FE3C2;--gold-deep:#2C9A7B;--ink:#08100D;--ink-2:#0C1511;--surface:#121C18;--surface-2:#18241F;--surface-3:#21302A;--sage:#9FD08C;--sky:#6FBFD0;--clay:#D98A66}[data-theme=violet]{--accent-rgb:150,144,244;--gold-2:#B6B2FF;--gold-deep:#5F5AD6;--ink:#0A0B12;--ink-2:#0E0F18;--surface:#15161F;--surface-2:#1D1E2A;--surface-3:#262738;--sage:#86C9A6;--sky:#86A6F0}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--ui);color:var(--paper);background:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font-family:inherit;color:inherit;cursor:pointer;border:none;background:none}input,textarea{font-family:inherit}.app-shell{width:100%;max-width:var(--app-w);margin:0 auto;min-height:100dvh;background:var(--ink);position:relative;display:flex;flex-direction:column}.stage{min-height:100dvh;background:radial-gradient(120% 60% at 50% -10%,rgba(var(--accent-rgb),.06),transparent 60%),var(--ink-2);display:flex;justify-content:center}.scroll{flex:1;overflow-y:auto;padding:0 18px 120px;-webkit-overflow-scrolling:touch}.scroll::-webkit-scrollbar{width:0}.num{font-family:var(--display);font-variant-numeric:tabular-nums;letter-spacing:-.02em}.eyebrow{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--faint)}.serif-i{font-family:var(--serif);font-style:italic}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;box-shadow:var(--shadow)}.card+.card{margin-top:14px}.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.card-title{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:700;letter-spacing:.02em}.card-title .ic{color:var(--gold)}.card-sub{font-size:12px;color:var(--muted)}.pill{display:inline-flex;align-items:center;gap:7px;padding:6px 11px;border-radius:999px;font-size:12px;font-weight:600;background:var(--surface-2);border:1px solid var(--line);color:var(--muted)}.grip{color:var(--faint);display:flex;cursor:grab;touch-action:none}.card.dragging{opacity:.5}.card.drag-over{outline:2px dashed var(--gold-line);outline-offset:3px}.tap{transition:transform .12s ease,background .15s ease,border-color .15s ease,color .15s ease}.tap:active{transform:scale(.96)}@keyframes pop{0%{transform:scale(.82)}60%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes pulse-ring{0%{box-shadow:0 0 0 0 var(--gold-line)}70%{box-shadow:0 0 0 7px rgba(var(--accent-rgb),0)}to{box-shadow:0 0 rgba(var(--accent-rgb),0)}}@keyframes rise{0%{transform:translateY(8px)}to{transform:none}}.rise{opacity:1}.chain{width:100%}.ch-cell{aspect-ratio:1;border-radius:4px;background:#f4efe30d;border:1px solid var(--line)}.ch-banked{background:var(--gold);border-color:var(--gold);box-shadow:0 0 0 1px var(--gold-deep) inset}.ch-repeat{background:var(--clay-soft);border-color:var(--clay)}.ch-today{background:var(--gold-soft);border-color:var(--gold);animation:pulse-ring 2.2s infinite}.bankc{display:flex;flex-direction:column}.bankc-num{font-size:64px;font-weight:800;line-height:.9;color:var(--gold)}.bankc-den{font-size:22px;font-weight:600;color:var(--muted);margin-left:8px}.bankc-lab{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-top:8px;font-weight:700}.hero{border-radius:var(--r-xl);padding:22px 20px 20px;background:radial-gradient(140% 90% at 0% 0%,rgba(var(--accent-rgb),.1),transparent 55%),var(--surface);border:1px solid var(--gold-line);position:relative;overflow:hidden}.hero-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:18px}.hero-date{font-size:13px;color:var(--muted);font-weight:600}.hero-day{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-top:2px}.hero-safe{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;white-space:nowrap;color:var(--sage);background:var(--sage-soft);border:1px solid rgba(143,176,137,.3);padding:5px 10px;border-radius:999px}.seg{display:inline-flex;background:var(--ink-2);border:1px solid var(--line);border-radius:12px;padding:3px;gap:2px}.seg-b{padding:8px 14px;border-radius:9px;font-size:13px;font-weight:600;color:var(--muted)}.seg-b.on{background:var(--surface-3);color:var(--paper);box-shadow:0 1px #ffffff0a inset}.seg-sm .seg-b{padding:5px 10px;font-size:12px}.stepper{display:inline-flex;align-items:center;gap:14px;background:var(--ink-2);border:1px solid var(--line);border-radius:12px;padding:6px 10px}.stepper button{width:30px;height:30px;border-radius:8px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;color:var(--paper)}.stepper .num{font-size:20px;font-weight:700;min-width:46px;text-align:center}.pips{display:flex;gap:9px}.pip{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 4px;border-radius:14px;border:1px solid var(--line);background:var(--surface-2)}.pip-dot{width:30px;height:30px;border-radius:50%;border:2px solid var(--line-2);display:flex;align-items:center;justify-content:center;color:transparent}.pip.on{border-color:#7fa8c966;background:var(--sky-soft)}.pip.on .pip-dot{background:var(--sky);border-color:var(--sky);color:var(--ink);animation:pop .35s ease}.pip-lab{font-size:10.5px;font-weight:600;color:var(--muted)}.pip.on .pip-lab{color:var(--paper)}.task{display:flex;align-items:center;gap:13px;padding:12px 0;border-top:1px solid var(--line)}.task:first-of-type{border-top:none}.checkbox{width:26px;height:26px;border-radius:8px;border:2px solid var(--line-2);flex:0 0 auto;display:flex;align-items:center;justify-content:center;color:transparent;background:transparent}.checkbox.on{background:var(--gold);border-color:var(--gold);color:var(--ink);animation:pop .3s ease}.checkbox.sage.on{background:var(--sage);border-color:var(--sage);color:var(--ink)}.task-ic{width:34px;height:34px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted);flex:0 0 auto}.task.on .task-ic{color:var(--gold)}.task-body{flex:1;min-width:0}.task-label{font-size:14.5px;font-weight:600}.task.on .task-label{color:var(--paper)}.task-sub{font-size:11.5px;color:var(--faint);margin-top:1px}.meter{height:6px;border-radius:999px;background:var(--line);overflow:hidden}.meter>i{display:block;height:100%;background:var(--gold);border-radius:999px;transition:width .5s ease}.todo-add{display:flex;gap:8px;margin-top:12px}.todo-add input{flex:1;background:var(--ink-2);border:1px solid var(--line);border-radius:10px;padding:10px 12px;color:var(--paper);font-size:13px;outline:none}.todo-add input:focus{border-color:var(--gold-line)}.todo-add button{width:42px;border-radius:10px;background:var(--gold);color:var(--ink);display:flex;align-items:center;justify-content:center}.todo-item{display:flex;align-items:center;gap:11px;padding:9px 0;font-size:13.5px;color:var(--muted)}.todo-item.done{color:var(--faint);text-decoration:line-through}.timer{display:flex;flex-direction:column;align-items:center;gap:14px;padding:6px 0 4px}.timer-clock{font-size:46px;font-weight:800;letter-spacing:.01em}.timer-clock.run{color:var(--gold)}.timer-btn{display:flex;align-items:center;gap:9px;padding:13px 26px;border-radius:14px;font-weight:700;font-size:15px}.timer-btn.start{background:var(--gold);color:var(--ink)}.timer-btn.stop{background:var(--clay);color:#fff}.chips{display:flex;flex-wrap:wrap;gap:7px}.chip{padding:7px 12px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap;background:var(--surface-2);border:1px solid var(--line);color:var(--muted)}.chip.on{background:var(--gold-soft);border-color:var(--gold-line);color:var(--gold-2)}.session{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-top:1px solid var(--line);font-size:13px}.session .num{color:var(--muted)}.clean-row{display:flex;align-items:center;gap:14px}.clean-check{width:54px;height:54px;border-radius:16px;border:2px solid var(--line-2);display:flex;align-items:center;justify-content:center;color:var(--faint);flex:0 0 auto}.clean-check.on{background:var(--sage);border-color:var(--sage);color:var(--ink);animation:pop .35s ease}.medals{display:flex;gap:8px;margin-top:14px}.medal{flex:1;text-align:center;padding:11px 4px;border-radius:13px;border:1px solid var(--line);background:var(--surface-2)}.medal.earned{border-color:var(--gold-line);background:var(--gold-soft)}.medal-v{font-size:15px;font-weight:800;color:var(--faint)}.medal.earned .medal-v{color:var(--gold-2)}.medal-l{font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-top:3px;font-weight:700}.weigh{display:flex;align-items:flex-end;gap:6px}.weigh-v{font-size:40px;font-weight:800}.weigh-u{font-size:15px;color:var(--muted);font-weight:600;margin-bottom:7px}.photo-slot{display:flex;align-items:center;gap:12px;padding:13px;border-radius:14px;border:1px dashed var(--line-2);background:var(--ink-2)}.photo-slot.done{border-style:solid;border-color:#8fb08966;background:var(--sage-soft)}.rating{display:flex;gap:8px}.rate-b{flex:1;aspect-ratio:1;max-height:48px;border-radius:12px;border:1px solid var(--line);background:var(--surface-2);display:flex;align-items:center;justify-content:center;color:var(--faint)}.rate-b.on{color:var(--gold);border-color:var(--gold-line);background:var(--gold-soft)}.field{margin-top:12px}.field label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);font-weight:700}.field input,.field textarea{width:100%;margin-top:6px;background:var(--ink-2);border:1px solid var(--line);border-radius:12px;padding:11px 13px;color:var(--paper);font-size:14px;outline:none;resize:none}.field input:focus,.field textarea:focus{border-color:var(--gold-line)}.week-row{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-top:1px solid var(--line)}.week-row:first-of-type{border-top:none}.week-prog{display:flex;gap:5px}.week-prog i{width:18px;height:8px;border-radius:3px;background:var(--line-2)}.week-prog i.on{background:var(--gold)}.tabbar{position:sticky;bottom:0;left:0;right:0;display:flex;background:#0e0d0bd1;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-top:1px solid var(--line);padding:10px 14px calc(14px + env(safe-area-inset-bottom,0))}.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;color:var(--faint);font-size:10.5px;font-weight:700;letter-spacing:.02em}.tab.on{color:var(--gold)}.tab .dot{width:4px;height:4px;border-radius:50%;background:var(--gold);opacity:0}.tab.on .dot{opacity:1}.topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;position:sticky;top:0;z-index:5;background:linear-gradient(var(--ink) 70%,transparent)}.topbar-mark{display:flex;align-items:baseline;gap:10px}.topbar-mark .num{font-size:22px;font-weight:800;color:var(--gold);letter-spacing:-.02em}.topbar-name{font-size:13px;font-weight:600;color:var(--muted);white-space:nowrap}.topbar-btn{width:38px;height:38px;border-radius:11px;background:var(--surface);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--paper)}.theme-pick{position:relative}.theme-dot{width:16px;height:16px;border-radius:50%;box-shadow:0 0 0 1px var(--line-2) inset}.theme-pop{position:absolute;top:46px;right:0;z-index:30;background:var(--surface-2);border:1px solid var(--line-2);border-radius:14px;padding:7px;display:flex;flex-direction:column;gap:3px;min-width:140px;box-shadow:0 18px 40px -16px #000c}.theme-swatch{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:9px;color:var(--muted);font-size:13px;font-weight:600}.theme-swatch:hover{background:var(--surface-3)}.theme-swatch.on{color:var(--paper)}.theme-swatch span{width:16px;height:16px;border-radius:50%;box-shadow:0 0 0 1px #ffffff26 inset}.theme-swatch.on em{color:var(--gold);font-style:normal}.theme-swatch em{font-style:normal}.tabview{opacity:1}.screen-head{padding:22px 2px 14px;display:flex;align-items:flex-end;justify-content:space-between}.screen-h1{font-family:var(--display);font-size:26px;font-weight:800;letter-spacing:-.02em}.screen-sub{font-size:12.5px;color:var(--muted);margin-top:3px}.lane{display:flex;align-items:center;gap:13px;padding:13px 0;border-top:1px solid var(--line)}.lane:first-of-type{border-top:none}.lane-ic{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex:0 0 auto}.lane-body{flex:1;min-width:0}.lane-top{display:flex;align-items:center;justify-content:space-between}.lane-name{font-size:14px;font-weight:700}.lane-stat{font-size:12px;color:var(--muted)}.lane-bar{height:6px;border-radius:999px;background:var(--line);margin-top:8px;overflow:hidden}.lane-bar>i{display:block;height:100%;border-radius:999px;transition:width .7s ease}.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.cal-dow{font-size:10px;text-align:center;color:var(--faint);font-weight:700;padding-bottom:4px}.cal-d{aspect-ratio:1;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;background:var(--surface-2);border:1px solid var(--line);color:var(--muted)}.cal-d.banked{background:var(--gold);color:var(--ink);border-color:var(--gold);font-weight:800}.cal-d.repeat{background:var(--clay-soft);border-color:var(--clay);color:var(--clay)}.cal-d.today{outline:2px solid var(--gold);outline-offset:1px}.cal-d.empty{background:transparent;border:none}.hrow{display:flex;gap:14px;padding:16px;border-radius:var(--r);background:var(--surface);border:1px solid var(--line)}.hrow+.hrow{margin-top:10px}.hrow-date{display:flex;flex-direction:column;align-items:center;justify-content:center;width:52px;flex:0 0 auto;border-right:1px solid var(--line);padding-right:14px}.hrow-dnum{font-family:var(--display);font-size:22px;font-weight:800;line-height:1}.hrow-dmon{font-size:10px;text-transform:uppercase;color:var(--faint);letter-spacing:.1em;font-weight:700;margin-top:3px}.hrow-body{flex:1;min-width:0}.hrow-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}.tagb{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:4px 9px;border-radius:999px;background:var(--surface-2);border:1px solid var(--line);color:var(--muted)}.badge-banked{color:var(--gold-2);background:var(--gold-soft);border-color:var(--gold-line)}.badge-repeat{color:var(--clay);background:var(--clay-soft);border-color:#cd75514d}.hrow-reflect{font-family:var(--serif);font-style:italic;font-size:13.5px;color:var(--muted);margin-top:10px;line-height:1.45}.gate{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 30px;gap:2px}.gate-mark{font-size:96px;font-weight:800;line-height:.8;color:var(--gold);text-shadow:0 0 60px rgba(var(--accent-rgb),.25)}.gate-word{font-family:var(--display);font-size:19px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-top:10px}.gate-tag{color:var(--muted);font-size:15px;margin:14px 0 30px}.gate-lock{width:100%;max-width:300px;display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line-2);border-radius:14px;padding:14px 16px}.gate-lock input{flex:1;background:none;border:none;outline:none;color:var(--paper);font-size:16px;letter-spacing:.2em}.gate-lock.shake{animation:shake .45s;border-color:var(--clay)}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-7px)}40%,80%{transform:translate(7px)}}.gate-go{width:100%;max-width:300px;margin-top:12px;background:var(--gold);color:var(--ink);font-weight:800;font-size:16px;padding:15px;border-radius:14px;display:flex;align-items:center;justify-content:center;gap:8px}.gate-hint{font-size:11.5px;color:var(--faint);margin-top:20px}.ob{flex:1;display:flex;flex-direction:column;padding:26px 22px calc(26px + env(safe-area-inset-bottom,0));overflow-y:auto}.ob-dots{display:flex;gap:7px;margin-bottom:26px}.ob-dots i{width:26px;height:4px;border-radius:99px;background:var(--line-2);transition:background .3s}.ob-dots i.on{background:var(--gold)}.ob-head{margin-bottom:22px}.ob-h1{font-family:var(--display);font-size:30px;font-weight:800;letter-spacing:-.02em;line-height:1.08;margin:8px 0 0;text-wrap:balance}.ob-p{font-size:14px;color:var(--muted);line-height:1.5;margin:12px 0 0;text-wrap:pretty}.ob-tpls{display:flex;flex-direction:column;gap:11px}.ob-tpl{text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px 66px 16px 16px;position:relative;flex:0 0 auto}.ob-tpl.on{border-color:var(--gold);background:radial-gradient(120% 100% at 100% 0%,var(--gold-soft),var(--surface) 60%)}.ob-tpl-top{display:block;margin-bottom:7px;line-height:1.5}.ob-tpl-name{font-size:16px;font-weight:700;margin-right:8px}.ob-tag{display:inline-block;vertical-align:1px;white-space:nowrap;font-size:9.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);background:var(--gold);padding:3px 7px;border-radius:6px}.ob-tag.soft{background:var(--sage-soft);color:var(--sage)}.ob-tpl-desc{font-size:12.5px;color:var(--muted);line-height:1.45;margin:0}.ob-tpl-len{position:absolute;top:16px;right:16px;font-size:15px;font-weight:800;color:var(--gold)}.ob-tpl-len span{font-size:11px;color:var(--faint);font-weight:600}.ob-tasks{display:flex;flex-direction:column}.ob-taskrow{display:flex;align-items:center;gap:13px;padding:13px 0;border-top:1px solid var(--line);text-align:left;width:100%}.ob-taskrow:first-child{border-top:none}.ob-taskbody{flex:1;display:flex;flex-direction:column}.ob-toggles{margin-top:18px;display:flex;flex-direction:column;gap:11px}.ob-toggle{display:flex;align-items:center;justify-content:space-between;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:15px;text-align:left}.ob-toggle.on{border-color:var(--gold-line)}.ob-toggle-name{display:block;font-size:14.5px;font-weight:700}.ob-toggle-sub{display:block;font-size:11.5px;color:var(--muted);margin-top:3px;line-height:1.4}.switch{width:46px;height:27px;border-radius:99px;background:var(--line-2);flex:0 0 auto;position:relative;transition:background .25s}.switch i{position:absolute;top:3px;left:3px;width:21px;height:21px;border-radius:50%;background:var(--paper);transition:transform .25s}.switch.on{background:var(--gold)}.switch.on i{transform:translate(19px);background:var(--ink)}.ob-lenwrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px}.ob-lennum{font-size:88px;font-weight:800;color:var(--gold);line-height:.8}.ob-lennum span{font-size:24px;color:var(--muted);font-weight:600}.ob-lenchips{display:flex;gap:9px}.ob-lenwrap .chip{min-width:54px;text-align:center;font-size:14px;padding:9px 14px}.ob-range{width:100%;max-width:300px;accent-color:var(--gold)}.ob-start{display:flex;flex-direction:column;gap:12px}.ob-startc{display:flex;flex-direction:column;gap:7px;align-items:flex-start;text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px}.ob-startc.on{border-color:var(--gold);background:radial-gradient(120% 100% at 100% 0%,var(--gold-soft),var(--surface) 60%)}.ob-startc-t{display:block;font-size:17px;font-weight:700}.ob-startc-s{display:block;font-size:12.5px;color:var(--muted)}.ob-summary{margin-top:18px;background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r);padding:16px}.ob-sumline{display:flex;align-items:center;justify-content:space-between;padding:8px 0;font-size:13.5px;color:var(--muted);border-top:1px solid var(--line)}.ob-sumline:first-of-type{border-top:none}.ob-sumline b{color:var(--paper);font-weight:700;flex:0 0 auto;white-space:nowrap;text-align:right;padding-left:14px}.ob-next{margin-top:20px;width:100%;background:var(--surface-3);color:var(--paper);font-weight:800;font-size:16px;padding:16px;border-radius:14px;display:flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--line-2)}.ob-next:disabled{opacity:.5}.ob-next.gold{background:var(--gold);color:var(--ink);border-color:var(--gold)}.ob-nav{display:flex;gap:10px;margin-top:20px}.ob-back{padding:16px 22px;border-radius:14px;background:var(--surface);border:1px solid var(--line);font-weight:700;color:var(--muted)}.ob-next.grow{flex:1;margin-top:0}.chal-list{display:flex;flex-direction:column;gap:12px;margin-top:8px}.chal-card{position:relative;text-align:left;width:100%;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;transition:border-color .2s,transform .12s}.chal-card:hover{border-color:var(--gold-line)}.chal-card:active{transform:scale(.99)}.chal-card.feature{background:radial-gradient(120% 100% at 100% 0%,var(--gold-soft),var(--surface) 60%);border-color:var(--gold-line)}.chal-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:8px}.chal-name{font-size:18px;font-weight:800;letter-spacing:-.01em}.chal-meta{display:flex;align-items:center;gap:7px;margin-top:3px}.chal-len{font-size:12px;color:var(--muted);font-weight:600;text-transform:capitalize}.chal-desc{font-size:13.5px;color:var(--muted);line-height:1.5;margin:0}.chal-icons{display:flex;flex-wrap:wrap;gap:6px;margin-top:13px}.chal-icons span{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--surface-2);border:1px solid var(--line);color:var(--gold)}.chal-tag{font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:5px 10px;border-radius:999px;background:var(--surface-2);border:1px solid var(--line);color:var(--muted);white-space:nowrap;flex:0 0 auto}.chal-tag.rec{background:var(--gold-soft);border-color:var(--gold-line);color:var(--gold-2)}.chal-tag.classic{background:var(--surface-2);color:var(--paper)}.bld-list{display:flex;flex-direction:column;gap:9px}.bld-empty{font-size:13px;color:var(--faint);text-align:center;padding:20px 14px;border:1px dashed var(--line-2);border-radius:14px;line-height:1.5}.bld-row{display:flex;align-items:center;gap:11px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:9px 11px}.bld-name{flex:1;min-width:0;background:none;border:none;outline:none;color:var(--paper);font-size:14.5px;font-weight:600;padding:4px 2px;border-radius:6px}.bld-name:focus{background:var(--ink-2)}.bld-tools{display:flex;align-items:center;gap:7px;flex:0 0 auto}.bld-gate{font-size:11px;font-weight:800;letter-spacing:.04em;padding:6px 10px;border-radius:9px;white-space:nowrap;border:1px solid var(--line)}.bld-gate.gold{color:var(--gold-2);background:var(--gold-soft);border-color:var(--gold-line)}.bld-gate.sage{color:var(--sage);background:var(--sage-soft);border-color:#8fb0894d}.bld-x{width:30px;height:30px;border-radius:8px;background:var(--surface-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted);flex:0 0 auto}.bld-actions{margin-top:12px}.bld-add{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;border-radius:13px;background:var(--ink-2);border:1px dashed var(--line-2);color:var(--muted);font-size:14px;font-weight:700}.bld-add.on{border-style:solid;border-color:var(--gold-line);color:var(--gold-2)}.bld-lib{margin-top:11px;background:var(--ink-2);border:1px solid var(--line);border-radius:16px;padding:14px}.bld-cats{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:12px}.bld-items{display:flex;flex-direction:column;gap:7px}.bld-item{display:flex;align-items:center;gap:11px;text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:9px 12px}.bld-item.added{opacity:.55}.bld-item-body{flex:1;min-width:0;display:flex;flex-direction:column}.bld-item-name{font-size:13.5px;font-weight:600}.bld-item-sub{font-size:11px;color:var(--faint)}.bld-custom{margin-top:18px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:16px}.bld-custom-row{display:flex;gap:8px}.bld-cinput{flex:1;min-width:0;background:var(--ink-2);border:1px solid var(--line);border-radius:11px;padding:11px 13px;color:var(--paper);font-size:14px;outline:none}.bld-cinput:focus{border-color:var(--gold-line)}.bld-cadd{width:46px;flex:0 0 auto;border-radius:11px;background:var(--gold);color:var(--ink);display:flex;align-items:center;justify-content:center}.bld-iconpick{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.bld-ic{width:38px;height:38px;border-radius:10px;background:var(--ink-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted)}.bld-ic.on{border-color:var(--gold);color:var(--gold);background:var(--gold-soft)}.bld-cgate{margin-top:12px}.bld-cgate .seg{width:100%}.bld-cgate .seg-b{flex:1;text-align:center}.bld-starters{display:flex;align-items:center;gap:7px;margin-bottom:14px;flex-wrap:wrap}.bld-starter-lab{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);font-weight:700;margin-right:2px}.path-cards{display:flex;flex-direction:column;gap:14px;flex:1}.path-card{position:relative;text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;overflow:hidden;transition:border-color .2s,transform .15s}.path-card:active{transform:scale(.99)}.path-card.feature{background:radial-gradient(130% 110% at 100% 0%,var(--gold-soft),var(--surface) 58%);border-color:var(--gold-line)}.path-card .path-badge{position:absolute;top:18px;right:18px;white-space:nowrap;font-size:9.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:4px 8px;border-radius:7px}.path-badge.classic{color:var(--muted);background:var(--surface-2);border:1px solid var(--line-2)}.path-badge.rec{color:var(--ink);background:var(--gold)}.path-num{display:flex;align-items:baseline;gap:8px;font-size:42px;font-weight:800;color:var(--gold);line-height:.9;letter-spacing:-.03em;margin-bottom:14px}.path-num span{font-size:15px;font-weight:800;letter-spacing:.12em;color:var(--muted)}.path-icons{display:flex;gap:8px;margin-bottom:16px}.path-ic{width:34px;height:34px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--gold)}.path-card.feature .path-ic{background:rgba(var(--accent-rgb),.12);border-color:var(--gold-line)}.path-title{font-size:20px;font-weight:800;letter-spacing:-.01em;margin-bottom:8px}.path-desc{font-size:13.5px;color:var(--muted);line-height:1.5;margin:0 0 18px;text-wrap:pretty}.path-go{display:inline-flex;align-items:center;gap:7px;white-space:nowrap;font-size:13.5px;font-weight:700;color:var(--muted)}.path-go.gold{color:var(--gold-2)}.path-foot{text-align:center;color:var(--faint);font-size:15px;margin:22px 0 4px}.trad-rules{display:flex;flex-direction:column}.trad-rule{display:flex;align-items:center;gap:13px;padding:13px 0;border-top:1px solid var(--line)}.trad-rule:first-child{border-top:none}.trad-rule>div{flex:1}.trad-rule-t{font-size:14.5px;font-weight:600}.trad-rule-s{font-size:11.5px;color:var(--faint);margin-top:1px}.trad-mode{display:flex;flex-direction:column;gap:10px}.trad-opt{text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:15px}.trad-opt.on{border-color:var(--gold);background:radial-gradient(120% 100% at 100% 0%,var(--gold-soft),var(--surface) 60%)}.trad-opt-h{display:block;margin-bottom:6px;line-height:1.4}.trad-opt-h b{font-size:15px;font-weight:700;margin-right:8px}.trad-tag{display:inline-block;vertical-align:2px;white-space:nowrap;font-size:9.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:3px 7px;border-radius:6px}.trad-tag.safe{color:var(--sage);background:var(--sage-soft)}.trad-tag.hard{color:var(--clay);background:var(--clay-soft)}.trad-opt p{font-size:12.5px;color:var(--muted);line-height:1.45;margin:0}.sub-head{display:flex;align-items:center;gap:12px;padding:16px 18px 12px;position:sticky;top:0;z-index:6;background:linear-gradient(var(--ink) 72%,transparent)}.sub-back{width:38px;height:38px;border-radius:11px;background:var(--surface);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--paper);flex:0 0 auto}.sub-htext{flex:1;min-width:0}.sub-title{font-family:var(--display);font-size:20px;font-weight:800;letter-spacing:-.02em;line-height:1}.sub-sub{font-size:12px;color:var(--muted);margin-top:3px}.hub-profile{display:flex;align-items:center;gap:14px;padding:4px 2px 18px}.hub-ava{width:52px;height:52px;border-radius:16px;background:var(--gold);color:var(--ink);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:24px;font-weight:800;flex:0 0 auto}.hub-pname{font-size:18px;font-weight:800;letter-spacing:-.01em}.hub-pmeta{font-size:12.5px;color:var(--muted);margin-top:2px}.hub-group-l{font-size:11px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin:18px 2px 9px}.hub-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}.hub-item{display:flex;align-items:center;gap:13px;width:100%;padding:14px 15px;border-top:1px solid var(--line);text-align:left}.hub-item:first-child{border-top:none}.hub-ic{width:36px;height:36px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--gold);flex:0 0 auto}.hub-ibody{flex:1;min-width:0}.hub-ititle{font-size:14.5px;font-weight:700}.hub-isub{font-size:11.5px;color:var(--muted);margin-top:1px}.hub-badge{font-size:11px;font-weight:800;color:var(--gold-2);background:var(--gold-soft);border:1px solid var(--gold-line);padding:3px 8px;border-radius:999px}.rules-hero{border-radius:var(--r-lg);padding:20px;border:1px solid var(--gold-line);background:radial-gradient(130% 100% at 100% 0%,var(--gold-soft),var(--surface) 60%);margin-bottom:14px}.rules-hero-t{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:800}.rules-hero-h{font-family:var(--display);font-size:24px;font-weight:800;margin:8px 0 4px}.rules-hero-s{font-size:13px;color:var(--muted);line-height:1.5}.rule-line{display:flex;align-items:center;gap:13px;padding:13px 0;border-top:1px solid var(--line)}.rule-line:first-of-type{border-top:none}.rule-line .task-ic{flex:0 0 auto}.rule-body{flex:1}.rule-t{font-size:14.5px;font-weight:600}.rule-s{font-size:11.5px;color:var(--faint);margin-top:1px}.rule-tag{font-size:10px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;padding:4px 8px;border-radius:7px;white-space:nowrap}.rule-tag.bank{color:var(--gold-2);background:var(--gold-soft);border:1px solid var(--gold-line)}.rule-tag.bonus{color:var(--sage);background:var(--sage-soft);border:1px solid rgba(143,176,137,.3)}.book{display:flex;gap:18px}.book-cover{width:104px;height:152px;border-radius:10px;flex:0 0 auto;position:relative;overflow:hidden;background:linear-gradient(150deg,var(--surface-3),var(--surface));border:1px solid var(--line-2);box-shadow:0 14px 30px -16px #000c;display:flex;flex-direction:column;justify-content:flex-end;padding:13px}.book-cover:before{content:"";position:absolute;left:0;top:0;bottom:0;width:7px;background:var(--gold);opacity:.8}.book-cover-t{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--paper);line-height:1.2}.book-info{flex:1;min-width:0;display:flex;flex-direction:column}.book-title{font-size:19px;font-weight:800;letter-spacing:-.01em}.book-author{font-size:13px;color:var(--muted);margin-top:2px}.book-prog-num{font-family:var(--display);font-size:30px;font-weight:800;color:var(--gold);margin-top:auto}.book-prog-num span{font-size:14px;color:var(--muted);font-weight:600}.book-bar{height:7px;border-radius:99px;background:var(--line);overflow:hidden;margin-top:8px}.book-bar>i{display:block;height:100%;background:var(--gold);border-radius:99px;transition:width .5s ease}.book-log{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:16px;background:var(--ink-2);border:1px solid var(--line);border-radius:14px;padding:13px 15px}.book-log>div:first-child{flex:1 1 auto;min-width:0}.past-book{display:flex;align-items:center;gap:12px;padding:12px 0;border-top:1px solid var(--line)}.past-mini{width:30px;height:42px;border-radius:5px;background:var(--surface-3);border:1px solid var(--line-2);flex:0 0 auto;position:relative}.past-mini:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--sage)}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.photo-cell{aspect-ratio:3/4;border-radius:11px;overflow:hidden;position:relative;background:var(--surface-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center}.photo-cell.filled{background:linear-gradient(150deg,var(--surface-3),var(--surface-2))}.photo-cell .pday{position:absolute;top:6px;left:7px;font-size:10px;font-weight:800;color:var(--paper);background:#00000059;padding:2px 6px;border-radius:6px}.photo-cell .pcam{color:var(--faint)}image-slot{display:block}.ms-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:11px}.ms{border-radius:var(--r);border:1px solid var(--line);background:var(--surface);padding:16px;text-align:center}.ms.earned{border-color:var(--gold-line);background:radial-gradient(120% 100% at 50% 0%,var(--gold-soft),var(--surface) 70%)}.ms-ic{width:46px;height:46px;border-radius:50%;margin:0 auto 10px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:1px solid var(--line);color:var(--faint)}.ms.earned .ms-ic{background:var(--gold);border-color:var(--gold);color:var(--ink)}.ms-t{font-size:14px;font-weight:800}.ms.locked .ms-t{color:var(--muted)}.ms-d{font-size:11.5px;color:var(--faint);margin-top:3px}.ms-lock{font-size:10px;font-weight:700;color:var(--faint);margin-top:8px}.ms.earned .ms-lock{color:var(--gold-2)}.cal-month{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.cal-nav{width:34px;height:34px;border-radius:10px;background:var(--surface);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--paper)}.cal-big{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}.cal-big .cal-dow{font-size:10px;text-align:center;color:var(--faint);font-weight:700;padding-bottom:4px}.cal-big .cbd{aspect-ratio:.82;border-radius:9px;border:1px solid var(--line);background:var(--surface-2);display:flex;flex-direction:column;align-items:center;padding:5px 0 0;position:relative;cursor:pointer}.cal-big .cbd.other{opacity:.3}.cal-big .cbd.today{border-color:var(--gold)}.cal-big .cbd.sel{background:var(--gold-soft);border-color:var(--gold-line)}.cbd-n{font-size:12px;font-weight:700}.cbd-dots{display:flex;gap:2px;margin-top:auto;margin-bottom:5px}.cbd-dots i{width:5px;height:5px;border-radius:50%}.evt-add{display:flex;gap:8px;margin:16px 0 6px}.evt-types{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.evt-type{display:inline-flex;align-items:center;gap:6px;padding:7px 11px;border-radius:999px;font-size:12px;font-weight:600;background:var(--surface-2);border:1px solid var(--line);color:var(--muted)}.evt-type.on{color:var(--paper)}.evt-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-top:1px solid var(--line)}.evt-row:first-of-type{border-top:none}.evt-dot{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex:0 0 auto}.evt-body{flex:1;min-width:0}.evt-label{font-size:14px;font-weight:600}.evt-when{font-size:11.5px;color:var(--faint);margin-top:1px}.evt-x{width:28px;height:28px;border-radius:8px;background:var(--surface-2);border:1px solid var(--line);color:var(--faint);display:flex;align-items:center;justify-content:center;flex:0 0 auto}.conn-note{font-size:12.5px;color:var(--muted);line-height:1.5;background:var(--ink-2);border:1px solid var(--line);border-radius:14px;padding:13px 15px;margin-bottom:18px;display:flex;gap:11px;align-items:flex-start}.conn-row{display:flex;align-items:center;gap:13px;padding:13px 0;border-top:1px solid var(--line)}.conn-row:first-of-type{border-top:none}.conn-logo{width:42px;height:42px;border-radius:12px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:18px}.conn-body{flex:1;min-width:0}.conn-name{font-size:14.5px;font-weight:700}.conn-desc{font-size:11.5px;color:var(--muted);margin-top:1px;line-height:1.4}.conn-btn{flex:0 0 auto;font-size:12.5px;font-weight:700;padding:8px 14px;border-radius:10px;white-space:nowrap}.conn-btn.off{background:var(--surface-2);border:1px solid var(--line-2);color:var(--paper)}.conn-btn.on{background:var(--sage-soft);border:1px solid rgba(143,176,137,.4);color:var(--sage)}.set-group{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:14px}.set-row{display:flex;align-items:center;gap:13px;padding:14px 15px;border-top:1px solid var(--line)}.set-row:first-child{border-top:none}.set-label{flex:1;min-width:0}.set-name{font-size:14px;font-weight:600}.set-sub{font-size:11.5px;color:var(--faint);margin-top:1px}.set-input{background:var(--ink-2);border:1px solid var(--line);border-radius:10px;padding:9px 12px;color:var(--paper);font-size:14px;outline:none;width:140px;text-align:right}.set-input:focus{border-color:var(--gold-line)}.set-danger{width:100%;text-align:center;padding:14px;border-radius:14px;background:var(--clay-soft);border:1px solid rgba(205,117,81,.3);color:var(--clay);font-weight:700;font-size:14px}.theme-grid{display:flex;gap:10px}.theme-chip{flex:1;padding:12px 8px;border-radius:12px;border:1px solid var(--line);background:var(--surface-2);display:flex;flex-direction:column;align-items:center;gap:8px}.theme-chip.on{border-color:var(--gold-line);background:var(--gold-soft)}.theme-chip .sw{width:26px;height:26px;border-radius:50%;box-shadow:0 0 0 1px var(--line-2) inset}.theme-chip .nm{font-size:11.5px;font-weight:700;color:var(--muted)}.theme-chip.on .nm{color:var(--paper)}.miss-list{display:flex;flex-direction:column;gap:9px}.miss-opt{display:flex;align-items:flex-start;gap:13px;width:100%;text-align:left;padding:15px;border-radius:var(--r);border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow)}.miss-ic{width:38px;height:38px;border-radius:11px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:1px solid var(--line);color:var(--muted)}.miss-body{flex:1;min-width:0;display:flex;flex-direction:column}.miss-top{display:flex;align-items:center;gap:7px 9px;flex-wrap:wrap}.miss-title{flex:1 1 100%;min-width:0;font-size:15px;font-weight:800;letter-spacing:-.01em}.miss-tag{font-size:10px;font-weight:700;letter-spacing:.02em;padding:3px 8px;border-radius:999px;border:1px solid;white-space:nowrap}.miss-desc{font-size:12px;color:var(--muted);line-height:1.5;margin-top:5px}.miss-radio{width:23px;height:23px;border-radius:50%;flex:0 0 auto;margin-top:2px;border:2px solid var(--line-2);background:var(--surface-2);display:flex;align-items:center;justify-content:center}.miss-grace{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:11px;padding-top:11px;border-top:1px solid var(--line)}.miss-grace-l{font-size:12px;color:var(--paper);font-weight:600}.miss-grace-step{display:flex;align-items:center;gap:12px}.miss-grace-step button{width:28px;height:28px;border-radius:8px;background:var(--surface-2);border:1px solid var(--line-2);color:var(--paper);display:flex;align-items:center;justify-content:center}.miss-grace-step b{font-size:17px;min-width:18px;text-align:center}.read-sessions{display:flex;flex-direction:column;gap:11px}.read-sess{display:flex;align-items:center;gap:12px}.read-sess-day{font-size:12.5px;color:var(--muted);width:74px;flex:0 0 auto}.read-sess-bar{flex:1;height:8px;border-radius:99px;background:var(--line);overflow:hidden}.read-sess-bar>i{display:block;height:100%;background:var(--gold);border-radius:99px}.read-sess-n{font-size:12.5px;font-weight:700;color:var(--paper);width:46px;text-align:right;flex:0 0 auto}.read-hl{padding:13px 0;border-top:1px solid var(--line)}.read-hl:first-of-type{border-top:none}.read-hl-q{font-family:var(--serif);font-style:italic;font-size:15px;line-height:1.5;color:var(--paper)}.read-hl-d{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);margin-top:7px}.rf{display:flex;flex-direction:column;gap:9px}.rf-row{display:flex;gap:9px}.rf-input{background:var(--ink-2);border:1px solid var(--line);border-radius:11px;padding:11px 13px;color:var(--paper);font-size:14px;outline:none;width:100%}.rf-input::placeholder{color:var(--faint)}.rf-input:focus{border-color:var(--gold-line)}.read-actions{display:flex;gap:9px;margin-top:13px}.read-btn{flex:1;padding:11px;border-radius:12px;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:7px}.read-btn.ghost{background:var(--surface-2);border:1px solid var(--line-2);color:var(--paper)}.read-btn.gold{background:var(--gold);color:var(--ink)}.read-mini{display:flex;gap:14px}.read-mini-cover{width:58px;height:84px;border-radius:8px;flex:0 0 auto;position:relative;overflow:hidden;background:linear-gradient(150deg,var(--surface-3),var(--surface));border:1px solid var(--line-2);box-shadow:0 10px 22px -14px #000c;display:flex;align-items:flex-end;padding:9px}.read-mini-cover:before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--gold);opacity:.8}.read-mini-cover span{font-family:var(--serif);font-style:italic;font-size:10.5px;line-height:1.15;color:var(--paper);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.read-mini-body{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center}.read-mini-title{font-size:15px;font-weight:800;letter-spacing:-.01em;line-height:1.15}.read-mini-author{font-size:12px;color:var(--muted);margin-top:2px}.read-mini-log{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}.read-logb{min-width:48px;padding:8px 12px;border-radius:10px;font-size:13px;font-weight:800;font-variant-numeric:tabular-nums;background:var(--surface-2);border:1px solid var(--line-2);color:var(--paper)}.read-logb.gold{background:var(--gold-soft);border-color:var(--gold-line);color:var(--gold-2)}.read-finish{border-color:var(--gold-line);background:radial-gradient(130% 100% at 100% 0%,var(--gold-soft),var(--surface) 65%)}.read-finish textarea{resize:none}.read-note{padding:12px 0;border-top:1px solid var(--line)}.read-note:first-of-type{border-top:none}.read-note-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:5px}.read-note-d{font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--faint)}.read-note-t{font-size:13.5px;color:var(--paper);line-height:1.5;text-wrap:pretty}.past-book2{padding:13px 0;border-top:1px solid var(--line)}.past-book2:first-of-type{border-top:none}.past-book2-head{display:flex;align-items:center;gap:12px}.past-take{font-family:var(--serif);font-style:italic;font-size:13.5px;color:var(--muted);line-height:1.5;margin:9px 0 0 42px;padding-left:11px;border-left:2px solid var(--gold-line);text-wrap:pretty}.td-opts{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px;flex-wrap:wrap}.td-reps{display:flex;gap:6px;flex-wrap:wrap}.td-chip{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:7px 11px;border-radius:999px;background:var(--surface-2);border:1px solid var(--line);color:var(--muted)}.td-chip.on{background:var(--gold-soft);border-color:var(--gold-line);color:var(--gold-2)}.td-chip.prio.on{background:var(--clay-soft);border-color:#cd75516b;color:var(--clay)}.td-list{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-top:14px}.td-row{display:flex;align-items:center;gap:12px;padding:13px 15px;border-top:1px solid var(--line)}.td-row:first-child{border-top:none}.td-body{flex:1;min-width:0;display:flex;align-items:center;gap:9px;flex-wrap:wrap}.td-text{font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:7px}.td-row.done .td-text{color:var(--faint);text-decoration:line-through}.td-flag{color:var(--clay);display:flex}.td-rep{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:700;letter-spacing:.02em;padding:3px 8px;border-radius:999px;color:var(--gold-2);background:var(--gold-soft);border:1px solid var(--gold-line)}.td-x{width:28px;height:28px;border-radius:8px;background:var(--surface-2);border:1px solid var(--line);color:var(--faint);display:flex;align-items:center;justify-content:center;flex:0 0 auto}.td-empty{text-align:center;color:var(--faint);font-size:13px;padding:34px 0}.td-donehead{display:flex;align-items:center;gap:10px;margin-top:18px;font-size:12.5px;font-weight:700;color:var(--muted)}.td-clear{font-size:11.5px;color:var(--clay);font-weight:700;flex:0 0 auto}.jr-th{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px}.jr-th-d{font-family:var(--display);font-size:18px;font-weight:800;letter-spacing:-.01em}.jr-th-s{font-size:12px;color:var(--muted);margin-top:2px}.jr-rate-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 0 4px}.jr-rate-l{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);font-weight:700}.jr-field label{display:flex;align-items:center;gap:6px}.jr-stars{display:inline-flex;gap:2px}.jr-tl{display:flex;flex-direction:column;gap:10px}.jr-entry{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);position:relative;padding:14px 15px 14px 19px}.jr-entry:before{content:"";position:absolute;left:0;top:14px;bottom:14px;width:3px;border-radius:99px;background:var(--gold-line)}.jr-e-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:9px}.jr-e-day{font-size:13.5px;font-weight:800;display:flex;align-items:baseline;gap:8px}.jr-e-date{font-size:11px;font-weight:600;color:var(--faint);letter-spacing:.02em}.jr-e-line{display:flex;gap:9px;font-size:13px;color:var(--paper);line-height:1.45;padding:3px 0}.jr-e-line>span:last-child{flex:1;min-width:0;color:var(--muted)}.jr-e-k{font-size:9.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;padding:3px 7px;border-radius:6px;height:fit-content;white-space:nowrap;flex:0 0 auto;margin-top:1px}.jr-e-k.win{color:var(--gold-2);background:var(--gold-soft)}.jr-e-k.imp{color:var(--clay);background:var(--clay-soft)}.jr-e-k.gr{color:var(--sage);background:var(--sage-soft)}.fp-grid{display:flex;flex-direction:column;gap:7px}.fp-row{display:grid;grid-template-columns:58px repeat(7,1fr);gap:6px;align-items:center}.fp-head{margin-bottom:1px}.fp-rl{font-size:12px;color:var(--muted);font-weight:600}.fp-col-l{text-align:center;font-size:10px;font-weight:700;color:var(--faint)}.fp-col-l.on{color:var(--sky)}.fp-cell{aspect-ratio:1;border-radius:7px;background:#f4efe30d;border:1px solid var(--line)}.fp-cell.on{background:var(--sky-soft);border-color:var(--sky)}.fp-cell.today{box-shadow:0 0 0 1.5px var(--gold-line)}.fp-cell.on.today{background:var(--sky)}.fp-quran{display:flex;gap:16px;align-items:stretch;flex-wrap:wrap}.fp-q-info{flex:1 1 180px;min-width:0;display:flex;flex-direction:column}.fp-q-surah{font-size:15px;color:var(--paper)}.fp-q-num{font-family:var(--display);font-size:30px;font-weight:800;color:var(--sky);margin-top:6px}.fp-q-num span{font-size:14px;color:var(--muted);font-weight:600}.fp-q-step{display:flex;flex-direction:column;gap:9px;justify-content:center;align-items:flex-start;background:var(--ink-2);border:1px solid var(--line);border-radius:14px;padding:13px 15px}.fp-week{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}.fp-week-l{font-size:12.5px;color:var(--muted);font-weight:600}.fp-week-dots{display:flex;gap:6px}.fp-week-dots i{width:13px;height:13px;border-radius:50%;background:var(--surface-2);border:1px solid var(--line-2)}.fp-week-dots i.on{background:var(--sky);border-color:var(--sky)}.fp-counter{width:100%;display:flex;flex-direction:column;align-items:center;gap:6px;padding:26px 0 22px;border-radius:var(--r);background:radial-gradient(120% 100% at 50% 0%,var(--sky-soft),var(--surface-2) 70%);border:1px solid var(--line)}.fp-counter-n{font-family:var(--display);font-size:62px;font-weight:800;line-height:.9;color:var(--sky)}.fp-counter-l{font-size:12px;color:var(--muted)}@keyframes sh-blink{0%,to{opacity:1}50%{opacity:0}}html,body,#root{height:100%}#root{min-height:100dvh;background:radial-gradient(120% 60% at 50% -10%,rgba(var(--accent-rgb),.06),transparent 60%),var(--ink-2);display:flex;justify-content:center}.app-shell{box-shadow:0 40px 120px -40px #000c}.landing{width:100%;min-height:100dvh;background:var(--ink);overflow-x:hidden}.landing .wrap{max-width:1180px;margin:0 auto;padding:0 28px}.landing a{color:inherit;text-decoration:none}.landing .nav{position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0e0d0bb3;border-bottom:1px solid var(--line)}.landing .nav-in{display:flex;align-items:center;justify-content:space-between;height:68px}.landing .brand{display:flex;align-items:baseline;gap:11px}.landing .brand .mk{font-family:var(--display);font-size:26px;font-weight:900;color:var(--gold);letter-spacing:-.03em}.landing .brand .nm{font-size:13px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);white-space:nowrap}.landing .nav-links{display:flex;align-items:center;gap:34px}.landing .nav-links a{font-size:14px;font-weight:600;color:var(--muted);transition:color .2s;white-space:nowrap}.landing .nav-links a:hover{color:var(--paper)}.landing .btn{display:inline-flex;align-items:center;gap:8px;font-weight:700;border-radius:12px;white-space:nowrap;transition:transform .15s,background .2s,border-color .2s;cursor:pointer}.landing .btn:active{transform:scale(.97)}.landing .btn-ghost{padding:10px 16px;font-size:14px;color:var(--paper);border:1px solid var(--line-2);background:none}.landing .btn-ghost:hover{border-color:var(--gold-line)}.landing .btn-gold{padding:12px 20px;font-size:14px;background:var(--gold);color:var(--ink);border:none}.landing .btn-gold:hover{background:var(--gold-2)}.landing .btn-lg{padding:16px 26px;font-size:16px}.landing .hero{position:relative;padding:74px 0 40px;overflow:hidden}.landing .hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(60% 50% at 18% 8%,rgba(var(--accent-rgb),.12),transparent 60%);pointer-events:none}.landing .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;position:relative}.landing .tagstrip{display:inline-flex;align-items:center;gap:9px;padding:7px 14px;border-radius:999px;border:1px solid var(--gold-line);background:var(--gold-soft);color:var(--gold-2);font-size:12.5px;font-weight:700;letter-spacing:.02em;margin-bottom:24px}.landing h1.hero-h{font-family:var(--display);font-weight:900;font-size:clamp(44px,5.6vw,76px);line-height:.98;letter-spacing:-.035em;margin:0;text-wrap:balance}.landing h1.hero-h em{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--gold);letter-spacing:-.01em}.landing .hero-p{font-size:18px;line-height:1.55;color:var(--muted);margin:26px 0 0;max-width:480px;text-wrap:pretty}.landing .hero-cta{display:flex;align-items:center;gap:14px;margin-top:34px;flex-wrap:wrap}.landing .hero-meta{display:flex;gap:26px;margin-top:34px}.landing .hm-n{font-family:var(--display);font-size:30px;font-weight:800;color:var(--paper)}.landing .hm-l{font-size:12px;color:var(--faint);font-weight:600;margin-top:2px;max-width:120px}.landing .phone{position:relative;width:330px;height:680px;margin:0 auto;background:#000;border-radius:46px;padding:13px;box-shadow:0 50px 120px -30px #000000d9,0 0 0 2px #2a2a2a,inset 0 0 0 2px #000}.landing .phone:before{content:"";position:absolute;top:24px;left:50%;transform:translate(-50%);width:108px;height:28px;background:#000;border-radius:99px;z-index:3}.landing .phone-screen{width:100%;height:100%;border-radius:34px;overflow:hidden;background:var(--ink);position:relative}.landing .floaty{animation:floaty 6s ease-in-out infinite}@keyframes floaty{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.landing section{position:relative}.landing .sec{padding:96px 0}.landing .eyebrow-c{font-size:12px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}.landing .sec-h{font-family:var(--display);font-weight:800;font-size:clamp(32px,4vw,48px);line-height:1.04;letter-spacing:-.03em;margin:16px 0 0;text-wrap:balance}.landing .sec-sub{font-size:17px;color:var(--muted);line-height:1.55;margin:18px 0 0;max-width:600px;text-wrap:pretty}.landing .center{text-align:center}.landing .center .sec-sub{margin-left:auto;margin-right:auto}.landing .bank{background:linear-gradient(180deg,var(--ink),var(--ink-2));border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.landing .bank-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-top:54px}.landing .compare{border-radius:var(--r-lg);padding:30px;border:1px solid var(--line)}.landing .compare.bad{background:var(--surface)}.landing .compare.good{background:radial-gradient(120% 100% at 100% 0%,var(--gold-soft),var(--surface) 55%);border-color:var(--gold-line)}.landing .compare h3{font-size:14px;font-weight:800;letter-spacing:.04em;margin:0 0 4px;text-transform:uppercase}.landing .compare.bad h3{color:var(--clay)}.landing .compare.good h3{color:var(--gold-2)}.landing .compare .big{font-family:var(--display);font-size:26px;font-weight:800;letter-spacing:-.02em;margin:14px 0 10px}.landing .compare p{font-size:14.5px;color:var(--muted);line-height:1.55;margin:0}.landing .mini-chain{display:grid;grid-template-columns:repeat(15,1fr);gap:4px;margin:20px 0}.landing .mini-chain i{aspect-ratio:1;border-radius:3px;background:#f4efe30f;border:1px solid var(--line)}.landing .mini-chain i.f{background:var(--gold);border-color:var(--gold)}.landing .mini-chain i.r{background:var(--clay-soft);border-color:var(--clay)}.landing .mini-chain.reset i.f{background:#f4efe30f;border-color:var(--line)}.landing .areas{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:54px}.landing .area{border-radius:var(--r);border:1px solid var(--line);background:var(--surface);padding:24px 18px;transition:transform .2s,border-color .2s}.landing .area:hover{transform:translateY(-5px);border-color:var(--gold-line)}.landing .area-ic{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.landing .area h4{font-size:16px;font-weight:800;margin:0 0 7px}.landing .area p{font-size:13px;color:var(--muted);line-height:1.5;margin:0}.landing .build-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:50px;align-items:center;margin-top:48px}.landing .steps .step{display:flex;gap:18px;padding:22px 0;border-top:1px solid var(--line)}.landing .steps .step:first-child{border-top:none}.landing .step-n{font-family:var(--display);font-size:15px;font-weight:800;color:var(--ink);background:var(--gold);width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex:0 0 auto}.landing .step h4{font-size:18px;font-weight:700;margin:4px 0 6px}.landing .step p{font-size:14.5px;color:var(--muted);line-height:1.55;margin:0}.landing .feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:54px}.landing .feat{border-radius:var(--r);border:1px solid var(--line);background:var(--surface);padding:26px;transition:border-color .2s}.landing .feat:hover{border-color:var(--line-2)}.landing .feat-ic{width:42px;height:42px;border-radius:12px;background:var(--surface-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--gold);margin-bottom:18px}.landing .feat h4{font-size:17px;font-weight:700;margin:0 0 8px}.landing .feat p{font-size:14px;color:var(--muted);line-height:1.55;margin:0}.landing .screens{display:flex;gap:30px;justify-content:center;margin-top:56px;flex-wrap:wrap}.landing .screens .phone{width:280px;height:580px}.landing .screens .phone:before{width:90px;height:24px;top:20px}.landing .screen-cap{text-align:center;margin-top:18px;font-size:13px;font-weight:600;color:var(--muted)}.landing .cta{border-radius:var(--r-xl);padding:64px;text-align:center;position:relative;overflow:hidden;background:radial-gradient(80% 120% at 50% 0%,rgba(var(--accent-rgb),.16),var(--surface) 60%);border:1px solid var(--gold-line)}.landing .stores{display:flex;gap:14px;justify-content:center;margin-top:32px;flex-wrap:wrap}.landing .store{display:flex;align-items:center;gap:12px;padding:13px 22px;border-radius:14px;background:var(--ink);border:1px solid var(--line-2);transition:border-color .2s,transform .15s;cursor:pointer}.landing .store:hover{border-color:var(--gold-line);transform:translateY(-2px)}.landing .store-sub{font-size:10.5px;color:var(--faint);font-weight:600}.landing .store-name{font-size:16px;font-weight:700}.landing footer{border-top:1px solid var(--line);padding:48px 0}.landing .foot-in{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px}.landing .foot-links{display:flex;gap:26px}.landing .foot-links a{font-size:13px;color:var(--muted);cursor:pointer}.landing .foot-links a:hover{color:var(--paper)}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100;display:flex;align-items:center;justify-content:center;padding:24px}.modal{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-lg);padding:34px;position:relative}.modal .mk{font-family:var(--display);font-size:40px;font-weight:900;color:var(--gold);line-height:1}.modal h3{font-size:22px;font-weight:800;margin:18px 0 6px;letter-spacing:-.01em}.modal>p{font-size:14px;color:var(--muted);margin:0 0 22px}.modal label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);font-weight:700}.modal input{width:100%;margin:7px 0 16px;background:var(--ink-2);border:1px solid var(--line);border-radius:12px;padding:13px 15px;color:var(--paper);font-size:15px;outline:none}.modal input:focus{border-color:var(--gold-line)}.modal .btn-gold{width:100%;justify-content:center;padding:15px;font-size:15px;display:flex;align-items:center;gap:8px;border:none;border-radius:12px;background:var(--gold);color:var(--ink);font-weight:700;cursor:pointer}.modal-x{position:absolute;top:20px;right:20px;width:34px;height:34px;border-radius:9px;background:var(--surface-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted);cursor:pointer}.modal-alt{text-align:center;font-size:13px;color:var(--muted);margin-top:18px}.modal-alt b{color:var(--gold-2);cursor:pointer}.landing .theme-row{display:flex;gap:8px;align-items:center;padding-right:6px}.landing .theme-row button{width:18px;height:18px;border-radius:50%;background:rgb(var(--sw));cursor:pointer;box-shadow:0 0 0 1px var(--line-2) inset;transition:transform .15s,box-shadow .15s;border:none}.landing .theme-row button:hover{transform:scale(1.15)}.landing .theme-row button.on{box-shadow:0 0 0 2px var(--ink),0 0 0 4px rgb(var(--sw))}.landing .phone-prev{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.landing .phone-prev .app-shell{min-height:0!important;box-shadow:none}@media (max-width: 900px){.landing .hero-grid,.landing .bank-grid,.landing .build-grid{grid-template-columns:1fr}.landing .hero-phone-col{order:-1}.landing .areas{grid-template-columns:repeat(2,1fr)}.landing .feat-grid{grid-template-columns:1fr}.landing .nav-links{display:none}.landing .cta{padding:40px 24px}}
