:root,[data-palette=craft]{--bg: #efe9da;--bg-paper: #f5f0e2;--bg-elev: #fbf7ea;--bg-sunken: #e5ddc8;--ink: #1e2014;--ink-2: #3a3a2b;--muted: #6e6b5d;--muted-2: #9a9684;--line: #d6cfb8;--line-soft: #e3dcc4;--olive: #5e6a33;--olive-2: #4a5527;--moss: #859057;--accent: #b45a2d;--accent-soft: #e0b69a;--positive: #5e6a33;--warning: #a26410;--bg-noise-opacity: .55;--hero-overlay: rgba(94, 106, 51, .07);--paper-grain-fg: rgba(31, 33, 21, .04);--paper-grain-blend: multiply;--hint-pulse-from: rgba(94, 106, 51, .22);--hint-pulse-to: rgba(94, 106, 51, 0);--modal-back: rgba(20, 22, 14, .45)}[data-palette=khaki]{--bg: #20221a;--bg-paper: #272a1f;--bg-elev: #2d3024;--bg-sunken: #1a1c15;--ink: #ece7d2;--ink-2: #c8c3ad;--muted: #9b9883;--muted-2: #6e6b5c;--line: #3a3d2f;--line-soft: #2f3225;--olive: #bfb672;--olive-2: #d6cc85;--moss: #8d935a;--accent: #d6953c;--accent-soft: #5a4624;--positive: #bfb672;--warning: #d6953c;--bg-noise-opacity: .4;--hero-overlay: rgba(191, 182, 114, .08);--paper-grain-fg: rgba(236, 231, 210, .03);--paper-grain-blend: screen;--hint-pulse-from: rgba(191, 182, 114, .3);--hint-pulse-to: rgba(191, 182, 114, 0);--modal-back: rgba(0, 0, 0, .55)}:root{--pad-card: 28px;--pad-card-y: 24px;--gap-section: 28px;--row-h: 56px;--radius-card: 14px;--radius-card-hero: 18px;--radius-modal: 16px;--radius-btn: 8px;--radius-btn-lg: 10px;--radius-pill: 999px;--main-max-width: 1440px}.serif{font-family:Newsreader,Times New Roman,serif;font-weight:400;letter-spacing:-.01em}.mono{font-family:JetBrains Mono,ui-monospace,monospace;font-feature-settings:"tnum","zero"}.eyebrow{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:500}.h-display{font-family:Newsreader,serif;font-size:clamp(72px,11vw,180px);line-height:.92;letter-spacing:-.03em;font-weight:300}.h1{font-family:Newsreader,serif;font-size:clamp(36px,4vw,52px);line-height:1.04;letter-spacing:-.02em;font-weight:400;margin:0}.h2{font-family:Newsreader,serif;font-size:clamp(26px,2.4vw,34px);line-height:1.1;letter-spacing:-.015em;font-weight:400;margin:0}.h3{font-family:Newsreader,serif;font-size:22px;line-height:1.2;font-weight:400;margin:0}.num-big{font-family:Newsreader,serif;font-weight:300;font-feature-settings:"tnum";line-height:.92;letter-spacing:-.04em}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;overflow-x:hidden}body{font-family:Geist,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--ink);min-height:100vh;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;font-feature-settings:"ss01","ss02";position:relative}#root{position:relative;z-index:2;min-height:100vh}button{font-family:inherit}a{color:inherit}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1;background-image:radial-gradient(var(--paper-grain-fg) 1px,transparent 1px),radial-gradient(var(--paper-grain-fg) 1px,transparent 1px);background-size:3px 3px,7px 7px;background-position:0 0,2px 2px;opacity:var(--bg-noise-opacity);mix-blend-mode:var(--paper-grain-blend)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--line);border-radius:var(--radius-pill)}::-webkit-scrollbar-thumb:hover{background:var(--muted-2)}.app-shell{min-height:100vh;display:grid;grid-template-rows:auto 1fr;overflow-x:clip;min-width:0;max-width:100vw}.main{padding:40px 40px 80px;max-width:var(--main-max-width);margin:0 auto;width:100%;min-width:0;overflow-x:clip}.main>.grid,.main>.grid>*{min-width:0}.main>.grid>*:not(.month-strip-wrap){max-width:100%}.foot-note{margin-top:60px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;font-size:12px;color:var(--muted);font-family:JetBrains Mono,monospace;letter-spacing:.06em}.section-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}.section-head h2{margin:0}.loading-screen{display:grid;place-items:center;min-height:100vh;color:var(--muted);font-family:JetBrains Mono,monospace;font-size:12px;letter-spacing:.14em;text-transform:uppercase}.topbar{display:flex;align-items:center;justify-content:space-between;padding:18px 40px;border-bottom:1px solid var(--line);background:var(--bg);position:sticky;top:0;z-index:50}.topbar-brand{display:flex;align-items:center;gap:22px}.topbar-logo{display:flex;align-items:baseline;gap:10px;font-family:Newsreader,serif;font-size:22px;font-weight:500;letter-spacing:-.01em;color:var(--ink);background:transparent;border:0;padding:0;cursor:pointer}.topbar-logo .dot{width:8px;height:8px;border-radius:50%;background:var(--olive);display:inline-block}.topbar-logo small{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:400;margin-left:6px}.topbar-nav{display:flex;gap:4px;background:var(--bg-sunken);padding:4px;border-radius:var(--radius-pill)}.topbar-nav button,.topbar-nav a{border:0;background:transparent;color:var(--muted);font-family:Geist,sans-serif;font-size:13px;font-weight:500;padding:8px 18px;border-radius:var(--radius-pill);cursor:pointer;transition:all .15s;text-decoration:none;display:inline-block}.topbar-nav button:hover,.topbar-nav a:hover{color:var(--ink)}.topbar-nav button.active,.topbar-nav a.active{background:var(--ink);color:var(--bg-paper)}.topbar-meta{display:flex;align-items:center;gap:14px;font-size:12px;color:var(--muted)}.topbar-meta .pill{font-family:JetBrains Mono,monospace;font-size:11px;padding:6px 12px;border:1px solid var(--line);border-radius:var(--radius-pill);color:var(--ink-2);background:var(--bg-elev)}.palette-switch{display:flex;align-items:center;gap:2px;padding:3px;border-radius:var(--radius-pill);background:var(--bg-sunken);border:1px solid var(--line-soft)}.palette-switch-opt{display:inline-flex;align-items:center;gap:6px;padding:4px 10px 4px 5px;border:0;border-radius:var(--radius-pill);background:transparent;color:var(--muted);font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.08em;text-transform:lowercase;cursor:pointer;transition:background .15s,color .15s}.palette-switch-opt:hover{color:var(--ink-2)}.palette-switch-opt.active{background:var(--bg-elev);color:var(--ink);box-shadow:0 1px 2px #0000000f}.palette-switch-sw{width:14px;height:14px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);flex:none}.palette-switch-sw>span{width:6px;height:6px;border-radius:50%;display:block}.palette-switch-lbl{white-space:nowrap}.bottom-nav{display:none}.bn-btn{flex:1 1 0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:transparent;border:0;color:var(--muted);font-family:Geist,sans-serif;font-size:10px;letter-spacing:.02em;padding:8px 4px;cursor:pointer;transition:color .15s;-webkit-tap-highlight-color:transparent;text-decoration:none}.bn-btn:hover{color:var(--ink-2)}.bn-btn.active{color:var(--olive)}.bn-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:28px;border-radius:var(--radius-pill);transition:background .15s}.bn-btn.active .bn-icon{background:var(--accent-soft);color:var(--olive)}[data-palette=khaki] .bn-btn.active .bn-icon{background:var(--olive);color:var(--bg)}.bn-label{line-height:1}.hero{display:grid;grid-template-columns:1.4fr 1fr;gap:28px;align-items:stretch}.hero-counter{background:var(--bg-paper);border:1px solid var(--line);border-radius:var(--radius-card-hero);padding:36px 40px 32px;position:relative;overflow:hidden;display:grid;grid-template-rows:auto 1fr auto}.hero-counter:after{content:"";position:absolute;inset:auto -10% -80% auto;width:480px;height:480px;background:radial-gradient(circle,var(--hero-overlay),transparent 60%);pointer-events:none}.hero-counter .big{font-size:clamp(110px,13vw,200px);display:flex;align-items:baseline;gap:18px;color:var(--ink)}.hero-counter .big .unit{font-size:24px;font-family:JetBrains Mono,monospace;font-weight:400;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}.hero-sub-stats{margin-top:18px;display:flex;gap:28px;align-items:baseline;flex-wrap:wrap}.card{background:var(--bg-paper);border:1px solid var(--line);border-radius:var(--radius-card);padding:var(--pad-card-y) var(--pad-card);position:relative}.card.elev{background:var(--bg-elev)}.card.sunken{background:var(--bg-sunken);border-color:var(--line-soft)}.card.flat{background:transparent;border:1px solid var(--line)}.card-title{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;display:flex;justify-content:space-between;align-items:center}.btn{border:1px solid var(--line);background:var(--bg-elev);color:var(--ink);font-family:Geist,sans-serif;font-size:13px;font-weight:500;padding:10px 18px;border-radius:var(--radius-btn);cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all .15s;text-decoration:none;white-space:nowrap}.btn:hover{border-color:var(--ink-2)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:var(--ink);color:var(--bg-paper);border-color:var(--ink)}.btn.primary:hover{background:var(--olive-2);border-color:var(--olive-2)}.btn.olive{background:var(--olive);color:#fff;border-color:var(--olive)}[data-palette=khaki] .btn.olive{color:var(--bg)}.btn.olive:hover{background:var(--olive-2)}.btn.ghost{background:transparent;border-color:transparent;color:var(--muted)}.btn.ghost:hover{color:var(--ink);background:var(--bg-sunken)}.btn.danger{background:transparent;border-color:var(--accent);color:var(--accent)}.btn.danger:hover{background:var(--accent);color:#fff}.btn.sm{padding:6px 12px;font-size:12px}.btn.lg{padding:14px 24px;font-size:14px;border-radius:var(--radius-btn-lg)}.btn.icon{padding:8px}.btn.full{width:100%;justify-content:center}.input,.select,.textarea{width:100%;background:var(--bg-elev);border:1px solid var(--line);color:var(--ink);font-family:Geist,sans-serif;font-size:14px;padding:11px 14px;border-radius:var(--radius-btn);outline:none;transition:all .15s}.input:focus,.select:focus,.textarea:focus{border-color:var(--olive);box-shadow:0 0 0 3px var(--hero-overlay)}.input:disabled{opacity:.6;cursor:not-allowed}.input.lg{font-size:22px;padding:16px 18px;font-family:Newsreader,serif;font-weight:400}.input.num{font-family:JetBrains Mono,monospace}.label{display:block;font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}.field{margin-bottom:18px}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field-hint{font-size:12px;color:var(--muted);margin-top:6px}.field-error{font-size:12px;color:var(--accent);margin-top:6px}.stat .stat-label{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}.stat .stat-val{font-family:JetBrains Mono,monospace;font-size:22px;font-weight:500;letter-spacing:-.01em;color:var(--ink)}.stat .stat-val.serif{font-family:Newsreader,serif;font-size:30px;font-weight:400}.stat .stat-sub{font-size:12px;color:var(--muted);margin-top:4px}.progress{height:4px;background:var(--bg-sunken);border-radius:var(--radius-pill);overflow:hidden;position:relative}.progress-fill{position:absolute;inset:0 auto 0 0;background:var(--olive);border-radius:var(--radius-pill);transition:width .4s ease;z-index:2}.progress-fill.secondary{background:var(--olive);opacity:.35;z-index:1}.progress.thick{height:8px}.mini-bar{height:6px;background:var(--bg-sunken);border-radius:var(--radius-pill);overflow:hidden;display:flex}.mini-bar>span{display:block;height:100%}.bar-stack{display:grid;grid-template-columns:1fr;gap:10px}.bar-stack .row{display:grid;grid-template-columns:160px 1fr 80px;align-items:center;gap:14px;font-size:13px}.bar-stack .row .name{color:var(--ink-2)}.bar-stack .row .num{font-family:JetBrains Mono,monospace;text-align:right}.tag{display:inline-flex;align-items:center;gap:6px;font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;padding:4px 10px;border:1px solid var(--line);border-radius:var(--radius-pill);color:var(--muted);background:var(--bg-elev)}.tag.on{color:var(--olive);border-color:var(--olive)}.tag.warn{color:var(--accent);border-color:var(--accent)}.check{display:inline-flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none;background:transparent;border:0;padding:0;color:inherit;font:inherit}.check-box{width:22px;height:22px;border:1.5px solid var(--line);border-radius:6px;background:var(--bg-elev);display:inline-flex;align-items:center;justify-content:center;transition:all .15s;flex:none}.check.on .check-box{background:var(--olive);border-color:var(--olive)}.check.on .check-box:after{content:"";width:6px;height:11px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg) translateY(-1px)}[data-palette=khaki] .check.on .check-box:after{border-color:var(--bg)}.toggle{width:38px;height:22px;background:var(--bg-sunken);border-radius:var(--radius-pill);position:relative;cursor:pointer;transition:all .2s;border:1px solid var(--line);flex:none;padding:0}.toggle:after{content:"";position:absolute;width:16px;height:16px;background:var(--bg-paper);border-radius:50%;top:2px;left:2px;transition:all .2s;box-shadow:0 1px 2px #0000001a}.toggle.on{background:var(--olive);border-color:var(--olive)}.toggle.on:after{left:calc(100% - 18px)}.loan-list{display:grid;gap:14px}.loan-row{background:var(--bg-paper);border:1px solid var(--line);border-radius:12px;padding:18px 22px;display:grid;grid-template-columns:6px minmax(180px,1.3fr) minmax(180px,1.2fr) minmax(140px,.9fr) minmax(170px,.9fr) auto;gap:20px;align-items:center;transition:all .15s}.loan-row:hover{border-color:var(--ink-2)}.loan-row.paid{opacity:.55}.loan-row .accent-line{width:4px;height:36px;border-radius:4px;background:var(--olive);opacity:.35}.loan-row.high .accent-line{background:var(--accent);opacity:.6}.loan-name{font-family:Newsreader,serif;font-size:19px;font-weight:500;color:var(--ink)}.loan-name a{color:inherit;text-decoration:none;border-bottom:1px dotted var(--line)}.loan-name a:hover{border-bottom-color:var(--olive)}.loan-meta{font-size:12px;color:var(--muted);margin-top:2px}.loan-num{font-family:JetBrains Mono,monospace;font-size:14px}.loan-num-big{font-family:JetBrains Mono,monospace;font-size:18px;font-weight:500}.loan-actions{display:flex;gap:6px}.month-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.month-cell{background:var(--bg-elev);border:1px solid var(--line);border-radius:8px;padding:12px 10px;cursor:pointer;transition:all .15s;position:relative;min-height:80px;text-align:left;font:inherit;color:inherit}.month-cell:hover{border-color:var(--olive)}.month-cell .m-label{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.month-cell .m-num{font-family:Newsreader,serif;font-size:22px;font-weight:400;margin-top:4px}.month-cell.current{background:var(--ink);color:var(--bg-paper);border-color:var(--ink)}.month-cell.current .m-label{color:var(--muted-2)}.month-cell.adj{border-color:var(--accent);background:var(--bg-elev);color:var(--ink)}.month-cell .adj-tag{position:absolute;top:8px;right:8px;font-family:JetBrains Mono,monospace;font-size:9px;color:var(--accent);letter-spacing:.1em}.hint-mark-wrap{position:relative;top:-.35em;display:inline-flex;align-items:center;margin-left:10px;vertical-align:baseline}.hint-mark{width:22px;height:22px;border-radius:50%;border:1px dashed var(--olive);background:var(--bg-elev);color:var(--olive);font-family:Newsreader,serif;font-size:14px;font-style:italic;font-weight:500;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0;animation:hint-pulse 2.4s ease-in-out infinite;transition:transform .15s,background .15s,color .15s,border-color .15s}.hint-mark:hover,.hint-mark.open{background:var(--olive);color:var(--bg-paper);border-style:solid;animation:none}.hint-mark:hover{transform:scale(1.06)}@keyframes hint-pulse{0%,to{box-shadow:0 0 0 0 var(--hint-pulse-from)}50%{box-shadow:0 0 0 6px var(--hint-pulse-to)}}.hint-pop{z-index:60;width:320px;background:var(--bg-elev);border:1px solid var(--line);border-radius:12px;padding:16px 18px 18px;box-shadow:0 14px 30px -10px #0000002e,0 2px 6px #0000000f;animation:hint-pop-in .16s ease-out}.hint-pop-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.hint-pop-eyebrow{font-family:JetBrains Mono,monospace;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--olive)}.hint-pop-x{width:22px;height:22px;border:0;background:transparent;color:var(--muted);font-size:18px;line-height:1;cursor:pointer;padding:0;border-radius:4px}.hint-pop-x:hover{color:var(--ink);background:var(--bg-sunken)}.hint-pop-title{font-family:Newsreader,serif;font-size:18px;font-weight:500;color:var(--ink);line-height:1.25;margin-bottom:8px}.hint-pop-body{margin:0;font-size:13px;line-height:1.6;color:var(--ink-2)}@keyframes hint-pop-in{0%{opacity:0}to{opacity:1}}.modal-back{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--modal-back);z-index:100;display:grid;place-items:center;padding:40px;animation:modal-fadein .2s}@keyframes modal-fadein{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-paper);border:1px solid var(--line);border-radius:var(--radius-modal);width:100%;max-width:560px;max-height:86vh;overflow:auto;position:relative;animation:modalIn .25s cubic-bezier(.4,0,.2,1)}.modal.lg{max-width:720px}@keyframes modalIn{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-head{display:flex;justify-content:space-between;align-items:flex-start;padding:28px 28px 18px;border-bottom:1px solid var(--line-soft)}.modal-head h2{margin:0}.modal-body{padding:24px 28px}.modal-foot{padding:18px 28px;border-top:1px solid var(--line-soft);display:flex;justify-content:space-between;gap:10px}.modal-close{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:0;background:transparent;color:var(--muted);cursor:pointer;border-radius:6px;padding:0}.modal-close:hover{color:var(--ink);background:var(--bg-sunken)}.chart-wrap{position:relative;height:360px;padding:24px 0}.chart-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.chart-svg{width:100%;height:320px;overflow:visible;display:block}.chart-grid-line{stroke:var(--line);stroke-dasharray:3 4}.chart-axis-label{font-family:JetBrains Mono,monospace;font-size:10px;fill:var(--muted);letter-spacing:.08em}.chart-legend{display:flex;gap:18px;margin-bottom:10px}.chart-legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}.chart-legend-item .dot{width:14px;height:2px;border-radius:2px}.strat-pick{display:grid;grid-template-columns:1fr 1fr;gap:16px}.strat-card{border:1.5px solid var(--line);background:var(--bg-paper);border-radius:14px;padding:22px 24px;cursor:pointer;transition:all .2s;position:relative;text-align:left;font:inherit;color:inherit;width:100%}.strat-card.active{border-color:var(--olive);background:var(--bg-elev)}.strat-card.active:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border:2px solid var(--olive);border-radius:14px;pointer-events:none}.strat-card .picker{position:absolute;top:18px;right:18px;width:20px;height:20px;border-radius:50%;border:1.5px solid var(--line)}.strat-card.active .picker{background:var(--olive);border-color:var(--olive);box-shadow:inset 0 0 0 4px var(--bg-elev)}.strat-title{font-family:Newsreader,serif;font-size:24px;font-weight:500;margin:0 0 8px;color:var(--ink)}.strat-desc{margin:0;font-size:13px;color:var(--muted);line-height:1.5;padding-right:32px}.extra-slider-wrap{display:grid;gap:14px}.extra-slider{width:100%;height:28px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:transparent;cursor:pointer;--val: 0%}.extra-slider:focus{outline:none}.extra-slider::-webkit-slider-runnable-track{height:8px;border-radius:var(--radius-pill);background:linear-gradient(to right,var(--olive) 0%,var(--olive) var(--val),var(--line) var(--val),var(--line) 100%);border:1px solid var(--line-soft)}.extra-slider::-moz-range-track{height:8px;border-radius:var(--radius-pill);background:var(--line);border:1px solid var(--line-soft)}.extra-slider::-moz-range-progress{height:8px;background:var(--olive);border-radius:var(--radius-pill)}.extra-slider::-webkit-slider-thumb{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:22px;height:22px;background:var(--bg-paper);border:2px solid var(--olive);border-radius:50%;margin-top:-8px;box-shadow:0 2px 6px #0000002e;transition:transform .1s}.extra-slider::-webkit-slider-thumb:hover,.extra-slider:focus::-webkit-slider-thumb{transform:scale(1.08);background:var(--olive)}.extra-slider::-moz-range-thumb{width:22px;height:22px;background:var(--bg-paper);border:2px solid var(--olive);border-radius:50%;box-shadow:0 2px 6px #0000002e}.onb{min-height:100vh;display:grid;grid-template-rows:auto 1fr auto;position:relative}.onb-progress{padding:24px 40px;display:flex;align-items:center;gap:18px}.onb-progress-track{flex:1;height:2px;background:var(--bg-sunken);position:relative;border-radius:2px}.onb-progress-fill{position:absolute;inset:0 auto 0 0;background:var(--ink);border-radius:2px;transition:width .4s cubic-bezier(.4,0,.2,1)}.onb-progress-count{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.18em;color:var(--muted)}.onb-stage{display:grid;place-items:center;padding:20px 40px}.onb-body{max-width:720px;width:100%;animation:fadeUp .5s ease}.onb-body .sub{margin-top:12px;font-size:16px;color:var(--muted);line-height:1.5}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.onb-foot{padding:24px 40px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);background:var(--bg)}.onb-foot>div{display:flex;gap:8px;align-items:center}.num-list{display:grid;gap:12px;margin:24px 0}.num-list .item{display:grid;grid-template-columns:28px 1fr;gap:14px;align-items:baseline}.num-list .n{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--muted);letter-spacing:.1em}.num-list .t{font-family:Newsreader,serif;font-size:22px;font-weight:400}.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:24px}.choice{border:1.5px solid var(--line);background:var(--bg-paper);border-radius:12px;padding:22px;cursor:pointer;text-align:left;font-family:inherit;color:var(--ink);transition:all .15s;position:relative}.choice:hover{border-color:var(--olive)}.choice.active{border-color:var(--olive);background:var(--bg-elev);box-shadow:inset 0 0 0 1px var(--olive)}.choice h4{font-family:Newsreader,serif;font-weight:500;font-size:22px;margin:0 0 6px;letter-spacing:-.01em}.choice p{margin:0;font-size:13px;color:var(--muted);line-height:1.5}.io-row{display:grid;grid-template-columns:1fr auto auto auto;gap:14px;align-items:center;padding:14px 16px;border:1px solid var(--line);border-radius:10px;background:var(--bg-elev);margin-bottom:8px}.io-name{font-size:14px;color:var(--ink)}.io-meta{font-size:12px;color:var(--muted);margin-top:2px}.io-amount{font-family:JetBrains Mono,monospace;font-size:14px;font-weight:500}.aside{font-family:Newsreader,serif;font-style:italic;font-size:15px;color:var(--muted);border-left:2px solid var(--olive);padding-left:14px;margin:14px 0}.grid{display:grid;gap:var(--gap-section)}.row-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap-section)}.row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap-section)}.row-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.stack{display:grid;gap:14px}.stack-lg{display:grid;gap:var(--gap-section)}.inline{display:inline-flex;align-items:center;gap:8px}.spread{display:flex;justify-content:space-between;align-items:center;gap:12px}.divider{height:1px;background:var(--line-soft);margin:18px 0}.text-muted{color:var(--muted)}.text-accent{color:var(--accent)}.text-positive{color:var(--positive)}.text-right{text-align:right}@media(max-width:1280px){.app-shell{min-width:0}.main{padding:32px 28px 64px}.topbar{padding:16px 28px}.hero-counter{padding:30px 30px 26px}.hero-counter .big{font-size:clamp(90px,11vw,160px)}.row-4{gap:12px}.loan-row{grid-template-columns:6px minmax(160px,1.3fr) minmax(150px,1fr) minmax(120px,.8fr) minmax(150px,.8fr) auto;gap:14px;padding:16px 18px}.month-strip{gap:5px}.month-cell{padding:10px 8px;min-height:72px}.month-cell .m-num{font-size:19px}}@media(max-width:1024px){.main{padding:28px 24px 64px}.topbar{padding:14px 24px;gap:14px}.topbar-meta .pill:first-child{display:none}.topbar-nav button,.topbar-nav a{padding:7px 14px;font-size:12px}.hero{grid-template-columns:1fr;gap:16px}.hero-counter{padding:32px 32px 28px}.hero-counter .big{font-size:clamp(96px,14vw,140px)}.hero-counter .big .unit{font-size:20px}.hero-counter:after{width:360px;height:360px}.row-4{grid-template-columns:repeat(2,1fr);gap:14px}.row-3{grid-template-columns:1fr 1fr}.month-strip{grid-template-columns:repeat(4,1fr)}.loan-row{grid-template-columns:6px 1.4fr 1fr 1fr;grid-template-areas:"line name balance payment" "line check actions actions";gap:14px 18px;row-gap:10px}.loan-row>.accent-line{grid-area:line;height:auto}.loan-row>*:nth-child(2){grid-area:name}.loan-row>*:nth-child(3){grid-area:balance}.loan-row>*:nth-child(4){grid-area:payment}.loan-row>*:nth-child(5){grid-area:check;align-self:center}.loan-row>.loan-actions{grid-area:actions;justify-content:flex-end}.strat-pick{gap:12px}.strat-card{padding:18px}.onb-progress,.onb-stage,.onb-foot{padding:20px 28px}.onb-body{max-width:640px}.choice-grid{grid-template-columns:1fr}}@media(max-width:768px){body{font-size:14px}.topbar{padding:12px 16px;gap:10px;flex-wrap:nowrap;justify-content:space-between}.topbar-brand{gap:10px;min-width:0}.topbar-logo{font-size:17px;gap:8px}.topbar-logo small,.topbar-nav,.topbar-meta{display:none}.palette-switch{padding:2px}.palette-switch-opt{padding:4px 6px}.palette-switch-lbl{display:none}.bottom-nav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:90;background:var(--bg-paper);border-top:1px solid var(--line);padding:6px 4px;padding-bottom:calc(6px + env(safe-area-inset-bottom,0px));box-shadow:0 -2px 12px #0000000a}.main{padding:18px 16px 92px}.foot-note{display:none}.hero{gap:12px}.hero-counter{border-radius:14px;padding:22px 20px 20px}.hero-counter:after{width:280px;height:280px;inset:auto -10% -100% auto}.hero-counter .big{font-size:clamp(76px,22vw,112px);gap:8px}.hero-counter .big .unit{font-size:14px;letter-spacing:.06em}.hero-sub-stats{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}.hero-sub-stats>div:nth-child(3){grid-column:1 / -1}.hero>.card{padding:22px 20px!important;border-radius:14px}.hero>.card .num-big{font-size:38px!important}.card{padding:20px 16px}.row-4{grid-template-columns:1fr 1fr;gap:10px}.stat .stat-val.serif{font-size:22px}.stat .stat-val{font-size:18px}.bar-stack .row{grid-template-columns:1fr auto;grid-template-areas:"name num" "bar bar";gap:4px 10px}.bar-stack .row .name{grid-area:name;font-size:12px}.bar-stack .row .num{grid-area:num;font-size:12px}.bar-stack .row .mini-bar{grid-area:bar;height:5px}.section-head{flex-wrap:wrap;gap:8px;align-items:center}.section-head h2{font-size:22px!important}.h2{font-size:22px}.h1{font-size:32px!important;line-height:1.1}.num-big{letter-spacing:-.02em}.loan-list{gap:10px}.loan-row{grid-template-columns:4px 1fr;grid-template-areas:"line name" "line balance" "line payment" "line check" "line actions";gap:12px;padding:14px 16px 14px 12px}.loan-row>.accent-line{grid-area:line;width:3px}.loan-row>*:nth-child(2){grid-area:name}.loan-row>*:nth-child(3){grid-area:balance}.loan-row>*:nth-child(4){grid-area:payment}.loan-row>*:nth-child(5){grid-area:check;margin-top:4px}.loan-row>.loan-actions{grid-area:actions;flex-wrap:wrap;margin-top:4px;gap:6px}.loan-row .btn.sm{padding:8px 14px;font-size:13px}.loan-name{font-size:17px}.month-strip{display:flex;grid-template-columns:none;overflow-x:auto;scroll-snap-type:x mandatory;gap:8px;padding:4px 16px 12px;margin:0 -16px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.month-strip::-webkit-scrollbar{display:none}.month-cell{flex:0 0 32%;min-width:110px;scroll-snap-align:center;padding:14px 10px}.month-cell .m-num{font-size:20px}.modal-back{padding:0;align-items:flex-end;place-items:stretch end}.modal{border-radius:18px 18px 0 0;max-width:100%;width:100%;max-height:90vh;animation:modalIn-sheet .28s cubic-bezier(.4,0,.2,1)}@keyframes modalIn-sheet{0%{opacity:.6;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.modal:before{content:"";position:absolute;left:50%;top:8px;transform:translate(-50%);width:36px;height:4px;background:var(--muted-2);opacity:.5;border-radius:2px;z-index:1}.modal-head{padding:26px 20px 14px}.modal-body{padding:16px 20px}.modal-foot{padding:14px 20px;flex-direction:column-reverse;gap:8px}.modal-foot>*{width:100%;justify-content:center}.hint-pop{left:12px!important;right:12px!important;top:auto!important;bottom:calc(80px + env(safe-area-inset-bottom,0px))!important;width:auto!important;transform:none!important;max-width:none;border-radius:14px;box-shadow:0 -8px 30px -10px #00000040,0 0 0 1px var(--line);animation:hint-sheet-in .22s cubic-bezier(.4,0,.2,1)!important}@keyframes hint-sheet-in{0%{opacity:.4;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.hint-pop-title{font-size:17px}.hint-mark{width:20px;height:20px;font-size:13px}.hint-mark-wrap{margin-left:8px;top:-.3em}.strat-pick{grid-template-columns:1fr;gap:10px}.strat-card{padding:18px 16px}.strat-card .picker{top:14px;right:14px}.chart-svg{min-width:560px}.chart-legend{flex-wrap:wrap;gap:10px;font-size:11px}.onb{grid-template-rows:auto 1fr auto;min-height:100dvh}.onb-progress{padding:12px 16px;gap:10px}.onb-progress .topbar-logo{min-width:0!important;font-size:16px}.onb-stage{padding:24px 16px 4px;align-items:flex-start}.onb-body{max-width:100%}.onb-body .h1{font-size:32px!important;max-width:100%!important}.onb-foot{padding:14px 16px;padding-bottom:calc(14px + env(safe-area-inset-bottom,0px));flex-direction:column;align-items:stretch;gap:10px}.onb-foot>div{width:100%;justify-content:space-between}.onb-foot .btn.lg{width:100%;justify-content:center}.choice-grid,.field-row{grid-template-columns:1fr}.topbar-nav{overflow-x:auto;flex-wrap:nowrap;white-space:nowrap;scrollbar-width:none;max-width:100%}.topbar-nav::-webkit-scrollbar{display:none}.row-2,.row-3{grid-template-columns:1fr;gap:14px}.io-row{grid-template-columns:1fr auto;padding:14px;gap:8px 12px}.input,.select,.textarea{padding:12px 14px;font-size:15px}.input.lg{font-size:22px;padding:14px 16px}.btn{padding:11px 16px}.btn.sm{padding:8px 12px}.btn.lg{padding:14px 20px}}@media(max-width:380px){.month-cell{flex:0 0 42%;min-width:130px}.hero-counter .big{font-size:clamp(68px,24vw,96px)}.hero-sub-stats{gap:10px}.row-4{grid-template-columns:1fr}}
