@import"https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700&family=JetBrains+Mono:wght@400;500;700&display=swap";:root{--bg: #f8f9fa;--surface: #ffffff;--chat: #fafaf6;--header: #e4e0d3;--rail: #f2efe7;--rail-hover: rgba(255, 255, 255, .62);--rail-active: #ffffff;--ink: #1a1a1a;--text-2: #4a4d51;--muted: #7a7f85;--faint: #a4a89f;--border: #dadce0;--border-soft: #e8e5dc;--brand: #15a5e3;--brand-2: #1391c9;--brand-ink: #0c7ec2;--brand-wash: #e7f5fc;--green: #34a853;--green-ink: #1f7a3d;--green-wash: #e8f6ec;--amber: #e0922a;--amber-ink: #9c6312;--amber-wash: #fbf1e2;--red: #dc4c3e;--red-ink: #b8392c;--red-wash: #fdecea;--r: 8px;--r-lg: 12px;--r-sm: 6px;--sans: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--mono: "JetBrains Mono", "SF Mono", Menlo, monospace;--shadow-card: 0 1px 3px rgba(0, 0, 0, .08), 0 4px 16px rgba(0, 0, 0, .05);--shadow-pane: 0 1px 2px rgba(0, 0, 0, .06), 0 6px 20px rgba(0, 0, 0, .05);--r-2xl: 18px;--phone-w: 402px;--phone-h: 844px;--header-h: 56px;--tabbar-h: 58px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--app-top-inset: 44px;--shadow-soft: 0 1px 2px rgba(0, 0, 0, .05), 0 8px 24px rgba(0, 0, 0, .06);--shadow-device: 0 30px 70px rgba(0, 0, 0, .28), 0 8px 20px rgba(0, 0, 0, .16)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--sans);background:var(--bg);color:var(--ink);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}svg{display:block}.pace-module{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-pane);overflow:hidden}.m-head{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--border)}.m-head .mi{width:18px;height:18px;color:var(--text-2);flex:0 0 auto}.m-head h3{font-size:15px;font-weight:600;letter-spacing:.1px}.m-type{font-family:var(--mono);font-size:9.5px;font-weight:500;color:var(--muted);background:var(--bg);border:1px solid var(--border-soft);padding:2px 6px;border-radius:5px}.m-type.new{color:var(--brand-ink);background:var(--brand-wash);border-color:transparent}.m-type.sig{color:var(--green-ink);background:var(--green-wash);border-color:transparent}.m-head .tools{margin-left:auto;display:flex;align-items:center;gap:6px}.tbtn{display:flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;color:var(--text-2);padding:5px 9px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface)}.tbtn svg{width:13px;height:13px}.tbtn.spark{color:var(--brand-ink);border-color:var(--brand-wash);background:var(--brand-wash)}.seg{display:inline-flex;border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden}.seg span{font-size:11px;font-weight:600;color:var(--muted);padding:5px 9px}.seg span.on{background:var(--brand);color:#fff}.m-body{padding:18px}.row{display:grid;gap:18px}.row.two{grid-template-columns:1fr 1fr}@media (max-width: 880px){.row.two{grid-template-columns:1fr}}.addon-badge{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--amber-ink);background:var(--amber-wash);border:1px solid rgba(224,146,42,.3);padding:2px 7px;border-radius:20px}.ot{display:grid;grid-template-columns:1.25fr 1fr;gap:24px}@media (max-width: 760px){.ot{grid-template-columns:1fr}}.pace-head{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;margin-bottom:6px}.pace-head .state{font-size:23px;font-weight:700;letter-spacing:-.2px;display:flex;align-items:center;gap:9px}.pace-head .state .pp{width:11px;height:11px;border-radius:50%;flex:0 0 auto}.state.ok{color:var(--green-ink)}.state.ok .pp{background:var(--green)}.state.slip{color:var(--amber-ink)}.state.slip .pp{background:var(--amber)}.state.behind{color:var(--red-ink)}.state.behind .pp{background:var(--red)}.state.ahead{color:var(--brand-ink)}.state.ahead .pp{background:var(--brand)}.pace-head .goal{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--muted);background:var(--bg);border:1px solid var(--border-soft);padding:2px 8px;border-radius:20px}.gauge{margin:14px 0 6px}.gauge .bar{height:13px;border-radius:8px;position:relative;background:linear-gradient(90deg,#f1bdb6,#f1bdb6 24%,#f3dcb4 24%,#f3dcb4 50%,#c2e6cb 50%,#c2e6cb 86%,#cbe7f5 86%,#cbe7f5)}.gauge .mk{position:absolute;top:-5px;bottom:-5px;width:3px;background:var(--ink);border-radius:2px;box-shadow:0 0 0 3px var(--surface)}.gauge .mk:before{content:"";position:absolute;left:50%;top:-6px;transform:translate(-50%);width:9px;height:9px;border-radius:50%;background:var(--ink)}.gauge .ticks{display:flex;justify-content:space-between;font-family:var(--mono);font-size:9px;color:var(--faint);margin-top:8px;font-weight:600;letter-spacing:.04em}.gauge .ticks span.hi{color:var(--green-ink)}.reason{display:flex;gap:10px;align-items:flex-start;margin-top:16px;padding:12px 14px;border-radius:var(--r);background:var(--amber-wash);border:1px solid rgba(224,146,42,.25);font-size:12.5px;line-height:1.5;color:#6e4d18}.reason svg{width:16px;height:16px;color:var(--amber-ink);flex:0 0 auto;margin-top:1px}.reason b{color:var(--amber-ink)}.reason .g{color:var(--green-ink);font-weight:700}.brk{display:flex;flex-direction:column;gap:9px;align-self:center}.brk .bk-h{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);font-weight:700;margin-bottom:3px}.brow{display:grid;grid-template-columns:118px 1fr 42px;align-items:center;gap:11px;font-size:12px}.brow .n{color:var(--text-2);font-weight:600}.brow .n i{font-style:normal;color:var(--faint);font-family:var(--mono);font-size:9.5px;margin-left:4px}.track{height:7px;border-radius:5px;background:#eef0f2;overflow:hidden;position:relative}.track i{position:absolute;inset:0 auto 0 0;border-radius:5px;background:var(--green)}.track.am i{background:var(--amber)}.track.rd i{background:var(--red)}.track.pend{background:repeating-linear-gradient(45deg,#eef0f2,#eef0f2 5px,#e3e6e9 5px,#e3e6e9 10px)}.brow .v{font-family:var(--mono);font-size:12px;font-weight:700;text-align:right}.v.m{color:var(--faint)}.week{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.day .dh{font-family:var(--mono);font-size:10px;text-transform:uppercase;color:var(--faint);text-align:center;font-weight:600;padding-bottom:6px;border-bottom:1px solid var(--border-soft);margin-bottom:6px}.day.today .dh{color:var(--brand-ink)}.day{min-height:104px;display:flex;flex-direction:column;gap:5px}.ev{position:relative;font-size:10.5px;font-weight:600;padding:5px 7px;border-radius:6px;line-height:1.25;border-left:3px solid}.ev small{display:block;font-family:var(--mono);font-size:8.5px;font-weight:500;opacity:.85;margin-top:1px}.ev .log{position:absolute;top:4px;right:4px;font-family:var(--mono);font-size:9px;font-weight:700;width:14px;height:14px;border-radius:50%;display:grid;place-items:center;color:#fff}.log.done{background:var(--green)}.log.short{background:var(--amber)}.log.miss{background:var(--red)}.ev.chem{background:#e7f5fc;border-color:var(--brand);color:#0c5e85}.ev.cs{background:#e9f6ee;border-color:var(--green);color:#1f6b38}.ev.math{background:#f1ecfa;border-color:#8b6fc7;color:#5a3f97}.ev.exam{background:var(--red-wash);border-color:var(--red);color:var(--red-ink)}.ev.dim{opacity:.55}.ev.dim .tx{text-decoration:line-through}.ev.ghost{background:#f0faff;border:1.5px dashed var(--brand);color:var(--brand-ink)}.logkey{display:flex;gap:14px;margin-top:12px;font-size:11px;color:var(--muted);align-items:center;flex-wrap:wrap}.logkey b{font-weight:600;color:var(--text-2)}.logkey i{font-family:var(--mono);font-size:9px;font-weight:700;width:14px;height:14px;border-radius:50%;display:inline-grid;place-items:center;color:#fff;font-style:normal}.courseload-note{margin-top:14px;display:flex;gap:10px;align-items:flex-start;padding:12px 14px;border-radius:var(--r);background:var(--bg);border:1px solid var(--border-soft);font-size:12px;line-height:1.5;color:var(--text-2)}.courseload-note svg{width:16px;height:16px;color:var(--muted);flex:0 0 auto;margin-top:1px}.courseload-note b{color:var(--ink)}.courseload-note .dn{color:var(--red-ink);font-weight:700}.fc-q{display:flex;align-items:center;gap:10px;margin-bottom:13px;font-size:12px;color:var(--muted)}.fc-q b{font-family:var(--mono);color:var(--brand-ink);font-size:13px}.fc-q .qbar{flex:1;height:6px;border-radius:5px;background:#eef0f2;overflow:hidden}.fc-q .qbar i{display:block;height:100%;background:var(--brand);border-radius:5px}.flip{perspective:1100px;height:150px;margin-bottom:11px;cursor:pointer}.flip-in{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .65s cubic-bezier(.2,.8,.2,1)}.flip.flipped .flip-in{transform:rotateY(180deg)}.face{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;border-radius:10px;border:1px solid var(--border);padding:18px;display:flex;flex-direction:column;justify-content:center;background:var(--surface)}.face .ft{font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);font-weight:600;margin-bottom:8px}.face .q{font-size:16px;font-weight:500;line-height:1.35}.face .q b{color:var(--brand-ink)}.face.back{transform:rotateY(180deg);background:var(--brand-wash);border-color:#15a5e34d}.face.back .a{font-size:13.5px;font-weight:600;line-height:1.45}.face.back .a b{color:var(--brand-ink)}.fc-hint{text-align:center;font-size:10.5px;color:var(--faint)}.mhd{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);font-weight:700;margin-bottom:11px}.conc{display:grid;grid-template-columns:120px 1fr 92px;align-items:center;gap:11px;margin-bottom:11px}.conc .nm{font-size:12px;font-weight:600}.mbar{height:8px;border-radius:6px;background:#eef0f2;position:relative;overflow:hidden}.mbar i{position:absolute;left:0;top:0;bottom:0;border-radius:6px}.ig{background:var(--green)}.ia{background:var(--amber)}.ir{background:var(--red)}.conc .meta{text-align:right;font-family:var(--mono);font-size:11px;font-weight:700}.conc .meta .vl{font-size:9px;font-weight:600;display:block;margin-top:1px}.vl.up{color:var(--green-ink)}.vl.flat{color:var(--faint)}.vl.dn{color:var(--red-ink)}.effi{margin-top:6px;font-size:11px;color:var(--amber-ink);background:var(--amber-wash);border-radius:6px;padding:7px 10px;line-height:1.4}.effi b{font-weight:700}.erow{display:grid;grid-template-columns:1fr 40px;align-items:center;gap:9px;margin-bottom:10px}.erow .et{font-size:11.5px;font-weight:600}.erow .et small{display:block;color:var(--faint);font-family:var(--mono);font-size:9px;font-weight:500;margin-top:1px}.erow .epc{font-family:var(--mono);font-size:12.5px;font-weight:700;text-align:right}.erow .eb{grid-column:1 / -1;height:5px;border-radius:5px;background:#eef0f2;overflow:hidden;margin-top:-5px}.erow .eb i{display:block;height:100%;border-radius:5px}.chat{padding:18px;display:flex;flex-direction:column;gap:11px;background:var(--chat)}.card-alert{display:flex;gap:11px;align-items:flex-start;padding:12px 14px;border-radius:var(--r);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-card)}.card-alert .ic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;flex:0 0 auto}.card-alert.warn .ic{background:var(--amber-wash);color:var(--amber-ink)}.card-alert.info .ic{background:var(--brand-wash);color:var(--brand-ink)}.card-alert .ic svg{width:17px;height:17px}.card-alert .t{font-size:12.5px;line-height:1.45;color:var(--text-2)}.card-alert .t b{color:var(--ink)}.chat-tag{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--brand-ink);margin:6px 0 1px}.chat-tag .ai{width:21px;height:21px;border-radius:6px;background:linear-gradient(135deg,var(--brand),#3cc0f0);display:grid;place-items:center;flex:0 0 auto}.chat-tag .ai svg{width:12px;height:12px;color:#fff}.chat-tag .addon-badge{margin-left:auto}.paywall{display:flex;gap:9px;align-items:flex-start;padding:11px 13px;border-radius:var(--r);background:linear-gradient(180deg,#fdf6ea,#fff);border:1px solid rgba(224,146,42,.3);font-size:11.5px;line-height:1.5;color:var(--amber-ink)}.paywall b{color:var(--ink)}.paywall svg{width:15px;height:15px;flex:0 0 auto;margin-top:1px}.msg{max-width:88%;font-size:12.5px;line-height:1.5;padding:10px 13px;border-radius:14px}.msg.ai{align-self:flex-start;background:var(--surface);border:1px solid var(--border);border-bottom-left-radius:4px;box-shadow:var(--shadow-card)}.msg.me{align-self:flex-end;background:var(--brand-wash);border:1px solid rgba(21,165,227,.25);border-bottom-right-radius:4px}.msg .who{font-family:var(--mono);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;opacity:.6;margin-bottom:4px}.msg.ai .who{color:var(--brand-ink)}.msg.me .who{color:var(--muted)}.msg b{color:var(--ink)}.msg.ai b{color:var(--brand-ink)}.ladder{display:flex;gap:6px;align-self:flex-start;margin:1px 0;flex-wrap:wrap}.rung{font-family:var(--mono);font-size:8.5px;font-weight:700;padding:3px 7px;border-radius:20px;border:1px solid var(--border);color:var(--faint);background:var(--surface)}.rung.on{color:var(--brand-ink);border-color:var(--brand-wash);background:var(--brand-wash)}.escape{align-self:flex-start;display:flex;align-items:center;gap:9px;margin-top:3px;flex-wrap:wrap}.escbtn{font-size:11px;font-weight:600;padding:6px 12px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-2);cursor:pointer}.escbtn.primary{background:var(--brand);color:#fff;border-color:var(--brand)}.escape .note{font-size:10.5px;color:var(--faint);font-style:italic}.phone-page{min-height:100dvh;background:radial-gradient(120% 80% at 50% 0%,#edeef0,#e2e4e7 60%,#d7dade);display:flex;align-items:center;justify-content:center;padding:28px 16px}.phone-frame{width:var(--phone-w);max-width:100%;height:var(--phone-h);max-height:calc(100dvh - 56px);background:#111317;border-radius:44px;padding:10px;box-shadow:var(--shadow-device);position:relative}.phone-screen{position:relative;width:100%;height:100%;background:var(--bg);border-radius:36px;overflow:hidden;display:flex}.phone-frame:before{content:"";position:absolute;top:18px;left:50%;transform:translate(-50%);width:120px;height:26px;background:#111317;border-radius:16px;z-index:30}.app-root{position:relative;flex:1;min-width:0;display:flex;flex-direction:column;background:var(--bg)}.app-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.app-root.has-tabbar .app-scroll{padding-bottom:calc(var(--tabbar-h) + var(--safe-bottom))}.screen{display:flex;flex-direction:column;min-height:100%}.screen-header{position:sticky;top:0;z-index:10;background:#f8f9fadb;backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--border-soft);padding:calc(var(--app-top-inset) + 12px) 20px 12px}.screen-header.with-back{display:flex;align-items:center;gap:12px}.screen-title{font-size:26px;font-weight:700;letter-spacing:-.5px;color:var(--ink)}.screen-header.with-back .screen-title{font-size:19px}.screen-subtitle{margin-top:2px;font-size:12.5px;color:var(--muted);font-weight:500}.back-btn{flex:0 0 auto;width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--ink);font-size:18px;line-height:1;cursor:pointer;display:grid;place-items:center}.back-btn:active{transform:scale(.94)}.screen-body{flex:1;padding:16px 16px 28px;display:flex;flex-direction:column;gap:14px;animation:screen-in .26s cubic-bezier(.2,.8,.2,1)}@keyframes screen-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.mcard{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-2xl);box-shadow:var(--shadow-soft);padding:16px 18px;text-align:left;width:100%}.mcard-tappable{cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;display:flex;flex-direction:column;gap:8px}.mcard-tappable:active{transform:scale(.985);box-shadow:var(--shadow-card)}.mcard-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.mcard-eyebrow{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.04em;color:var(--muted)}.mcard-title{font-size:16px;font-weight:700;letter-spacing:-.2px;color:var(--ink);margin-top:2px}.mcard-meta{font-size:12.5px;color:var(--text-2)}.stub-note{font-size:12px;color:var(--faint);font-style:italic}.text-input{width:100%;box-sizing:border-box;font:inherit;font-size:16px;color:var(--ink);background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);padding:11px 12px}.text-input:focus{outline:none;border-color:var(--brand);background:var(--surface)}.pace-chip{flex:0 0 auto;font-size:11px;font-weight:700;letter-spacing:.02em;padding:4px 10px;border-radius:20px;white-space:nowrap}.pace-on_pace{color:var(--green-ink);background:var(--green-wash)}.pace-slipping{color:var(--amber-ink);background:var(--amber-wash)}.pace-behind{color:var(--red-ink);background:var(--red-wash)}.pace-ahead{color:var(--brand-ink);background:var(--brand-wash)}.btn-primary{width:100%;border:none;border-radius:14px;background:var(--brand);color:#fff;font-family:var(--sans);font-size:16px;font-weight:700;padding:15px 18px;cursor:pointer;box-shadow:0 4px 14px #15a5e352;transition:transform .12s ease,background .12s ease}.btn-primary:active{transform:scale(.98);background:var(--brand-2)}.btn-ghost{width:100%;border:1px solid var(--border);border-radius:14px;background:var(--surface);color:var(--text-2);font-family:var(--sans);font-size:15px;font-weight:600;padding:13px 18px;cursor:pointer;transition:transform .12s ease}.btn-ghost:active{transform:scale(.98)}.onboarding-screen{flex:1;display:flex;flex-direction:column;justify-content:space-between;padding:calc(var(--safe-top) + 48px) 24px calc(var(--safe-bottom) + 28px);background:radial-gradient(120% 60% at 50% 0%,var(--brand-wash) 0%,var(--bg) 55%)}.onboarding-hero{display:flex;flex-direction:column;gap:14px;margin-top:24px}.onboarding-mark{font-family:var(--mono);font-size:14px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--brand-ink)}.onboarding-title{font-size:30px;line-height:1.15;font-weight:700;letter-spacing:-.6px;color:var(--ink)}.onboarding-sub{font-size:15px;line-height:1.5;color:var(--text-2)}.onboarding-actions{display:flex;flex-direction:column;gap:10px}.tabbar{position:absolute;left:0;right:0;bottom:0;z-index:20;height:calc(var(--tabbar-h) + var(--safe-bottom));padding-bottom:var(--safe-bottom);display:grid;grid-template-columns:repeat(5,1fr);background:#ffffffe6;backdrop-filter:saturate(180%) blur(18px);-webkit-backdrop-filter:saturate(180%) blur(18px);border-top:1px solid var(--border-soft)}.tabbar-item{border:none;background:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--muted);padding:6px 0 4px;transition:color .15s ease,transform .12s ease}.tabbar-item.on{color:var(--brand)}.tabbar-item:active{transform:scale(.92)}.tabbar-icon{display:grid;place-items:center}.tabbar-label{font-size:10px;font-weight:600;letter-spacing:.01em}@media (max-width: 440px){:root{--app-top-inset: max(var(--safe-top), 10px)}.phone-page{padding:0;background:var(--bg);align-items:stretch}.phone-frame{width:100%;height:100dvh;max-height:none;border-radius:0;padding:0;box-shadow:none}.phone-screen{border-radius:0}.phone-frame:before{display:none}}.ds-page{min-height:100dvh;background:var(--bg)}.ds-app{display:grid;grid-template-columns:232px 1fr;height:100dvh}.ds-sidebar{display:flex;flex-direction:column;background:var(--rail);border-right:1px solid var(--border-soft);padding:22px 14px 16px}.ds-brand{display:flex;align-items:baseline;gap:7px;padding:4px 10px 22px}.ds-brand-mark{font-size:20px;font-weight:700;letter-spacing:-.4px;color:var(--ink)}.ds-brand-sub{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.04em;color:var(--brand-ink)}.ds-nav{display:flex;flex-direction:column;gap:3px}.ds-nav-item{display:flex;align-items:center;gap:12px;width:100%;border:none;background:none;cursor:pointer;padding:10px 12px;border-radius:var(--r-lg);color:var(--text-2);font-family:var(--sans);font-size:14px;font-weight:600;text-align:left;transition:background .12s ease,color .12s ease}.ds-nav-item:hover{background:var(--rail-hover);color:var(--ink)}.ds-nav-item.on{background:var(--rail-active);color:var(--brand-ink);box-shadow:var(--shadow-soft)}.ds-nav-icon{display:grid;place-items:center;width:22px;height:22px;flex:0 0 auto;color:currentColor}.ds-nav-icon svg{width:21px;height:21px}.ds-foot{margin-top:auto;padding:12px 12px 4px;border-top:1px solid var(--border-soft)}.ds-foot-school{font-size:12.5px;font-weight:700;color:var(--text-2)}.ds-foot-prog{font-size:11px;color:var(--muted);margin-top:1px}.ds-main{--app-top-inset: 6px;position:relative;overflow-y:auto;height:100dvh;background:var(--bg)}.ds-main-inner{max-width:980px;margin:0 auto;min-height:100%}.ds-main .screen-body{padding:20px 28px 40px;gap:16px}.ds-main .screen-header{padding-left:28px;padding-right:28px}.home-cards{display:flex;flex-direction:column;gap:14px}.ds-main .home-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.ds-onboarding{min-height:100dvh;display:grid;place-items:center;padding:32px 16px;background:radial-gradient(120% 60% at 50% 0%,var(--brand-wash) 0%,var(--bg) 55%)}.ds-onboarding-inner{width:460px;max-width:100%;background:var(--surface);border:1px solid var(--border-soft);border-radius:24px;box-shadow:var(--shadow-device);overflow:hidden;height:min(780px,calc(100dvh - 64px));display:flex;flex-direction:column}.ds-onboarding-inner .app-root{flex:1;min-height:0}.ob-flow{flex:1;display:flex;flex-direction:column;min-height:100%;background:radial-gradient(120% 55% at 50% 0%,var(--brand-wash) 0%,var(--bg) 48%)}.ob-top{flex:0 0 auto;padding:calc(var(--safe-top) + 16px) 22px 10px;display:flex;flex-direction:column;gap:10px}.ob-progress{display:flex;gap:6px}.ob-progress-seg{flex:1;height:5px;border-radius:5px;background:var(--border);overflow:hidden}.ob-progress-seg>i{display:block;height:100%;width:0;border-radius:5px;background:var(--brand);transition:width .4s cubic-bezier(.2,.8,.2,1)}.ob-progress-seg.filled>i{width:100%}.ob-progress-seg.active>i{width:55%}.ob-counter{display:flex;align-items:center;justify-content:space-between}.ob-counter .ob-step-label{font-family:var(--mono);font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-ink)}.ob-counter .ob-skip{border:none;background:none;font-family:var(--sans);font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;padding:2px 4px}.ob-counter .ob-skip:active{color:var(--ink)}.ob-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:8px 22px 18px}.ob-step{display:flex;flex-direction:column;gap:18px;animation:ob-step-in .3s cubic-bezier(.2,.8,.2,1)}@keyframes ob-step-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.ob-head{display:flex;flex-direction:column;gap:7px;margin-top:6px}.ob-eyebrow{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--brand-ink)}.ob-title{font-size:27px;line-height:1.14;font-weight:700;letter-spacing:-.5px;color:var(--ink)}.ob-sub{font-size:14px;line-height:1.5;color:var(--text-2)}.ob-foot{flex:0 0 auto;display:flex;gap:10px;padding:12px 22px calc(var(--safe-bottom) + 18px);background:linear-gradient(180deg,rgba(248,249,250,0),var(--bg) 38%);border-top:1px solid var(--border-soft)}.ob-foot .btn-primary,.ob-foot .btn-ghost{margin:0}.ob-back{flex:0 0 auto;width:54px;border:1px solid var(--border);border-radius:14px;background:var(--surface);color:var(--text-2);font-size:20px;cursor:pointer;transition:transform .12s ease}.ob-back:active{transform:scale(.95)}.ob-foot .ob-grow{flex:1}.ob-flow .btn-primary:disabled{background:var(--border);color:var(--faint);box-shadow:none;cursor:default}.ob-flow .btn-primary:disabled:active{transform:none;background:var(--border)}.ob-flow .btn-ghost:disabled{color:var(--faint);cursor:default}.ob-flow .btn-ghost:disabled:active{transform:none}.ob-field{display:flex;flex-direction:column;gap:6px}.ob-label{font-size:12px;font-weight:700;letter-spacing:.01em;color:var(--text-2)}.ob-input{width:100%;font-family:var(--sans);font-size:16px;font-weight:500;color:var(--ink);background:var(--surface);border:1px solid var(--border);border-radius:13px;padding:14px 15px;transition:border-color .15s ease,box-shadow .15s ease}.ob-input::placeholder{color:var(--faint);font-weight:400}.ob-input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-wash)}.ob-field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.ob-segrow{display:flex;gap:7px;flex-wrap:wrap}.ob-seg{flex:1 1 auto;min-width:70px;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text-2);font-family:var(--sans);font-size:13px;font-weight:600;padding:11px 8px;cursor:pointer;transition:all .14s ease}.ob-seg.on{border-color:var(--brand);background:var(--brand-wash);color:var(--brand-ink)}.ob-seg:active{transform:scale(.96)}.ob-welcome{flex:1;display:flex;flex-direction:column;justify-content:center;gap:22px;padding:4px 4px 20px}.ob-welcome-mark{font-family:var(--mono);font-size:13px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--brand-ink)}.ob-welcome-title{font-size:34px;line-height:1.1;font-weight:700;letter-spacing:-.8px;color:var(--ink)}.ob-welcome-sub{font-size:16px;line-height:1.55;color:var(--text-2)}.ob-pills{display:flex;flex-direction:column;gap:12px;margin-top:4px}.ob-pill{display:flex;align-items:center;gap:13px;padding:13px 15px;border-radius:var(--r-2xl);background:var(--surface);border:1px solid var(--border-soft);box-shadow:var(--shadow-soft)}.ob-pill .ob-pill-ic{flex:0 0 auto;width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:var(--brand-wash);color:var(--brand-ink)}.ob-pill .ob-pill-ic svg{width:19px;height:19px}.ob-pill .ob-pill-t{font-size:13.5px;font-weight:600;color:var(--ink);line-height:1.4}.ob-pill .ob-pill-t small{display:block;font-size:12px;font-weight:500;color:var(--muted);margin-top:1px}.ob-class-add{display:flex;gap:10px}.ob-class-add .ob-input{flex:1;text-transform:uppercase}.ob-add-btn{flex:0 0 auto;width:52px;border:none;border-radius:13px;background:var(--brand);color:#fff;font-size:26px;font-weight:400;line-height:1;cursor:pointer;box-shadow:0 4px 12px #15a5e34d;transition:transform .12s ease,background .12s ease}.ob-add-btn:active{transform:scale(.94);background:var(--brand-2)}.ob-add-btn:disabled{background:var(--border);color:var(--faint);box-shadow:none;cursor:default}.ob-class-list{display:flex;flex-direction:column;gap:9px}.ob-class-row{display:flex;align-items:center;gap:12px;padding:13px 15px;border-radius:14px;background:var(--surface);border:1px solid var(--border-soft);box-shadow:var(--shadow-soft);animation:ob-step-in .22s ease}.ob-class-code{font-family:var(--mono);font-size:14px;font-weight:700;color:var(--ink);letter-spacing:.01em}.ob-class-name{font-size:12px;color:var(--muted);margin-top:1px}.ob-class-row .ob-grow{flex:1;min-width:0}.ob-class-rm{flex:0 0 auto;width:30px;height:30px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--muted);font-size:16px;line-height:1;cursor:pointer;display:grid;place-items:center}.ob-class-rm:active{transform:scale(.9);color:var(--red-ink);border-color:var(--red)}.ob-suggest{display:flex;flex-wrap:wrap;gap:8px}.ob-suggest-chip{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--text-2);background:var(--surface);border:1px dashed var(--border);border-radius:20px;padding:7px 12px;cursor:pointer;transition:all .13s ease}.ob-suggest-chip:active{transform:scale(.95);border-style:solid;border-color:var(--brand);color:var(--brand-ink);background:var(--brand-wash)}.ob-empty{text-align:center;font-size:13px;color:var(--faint);padding:14px 0 4px}.ob-scan-tabs{display:flex;gap:7px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px}.ob-scan-tab{flex:0 0 auto;display:flex;align-items:center;gap:7px;border:1px solid var(--border);border-radius:20px;background:var(--surface);color:var(--text-2);font-family:var(--mono);font-size:12px;font-weight:700;padding:7px 12px;cursor:pointer;white-space:nowrap;transition:all .14s ease}.ob-scan-tab.on{border-color:var(--brand);background:var(--brand-wash);color:var(--brand-ink)}.ob-scan-tab .ob-dot{width:7px;height:7px;border-radius:50%;background:var(--border)}.ob-scan-tab .ob-dot.parsed,.ob-scan-tab .ob-dot.confirmed{background:var(--green)}.ob-scan-tab .ob-dot.scanning{background:var(--amber)}.ob-viewfinder{position:relative;width:100%;aspect-ratio:3 / 4;max-height:320px;border-radius:var(--r-2xl);overflow:hidden;background:repeating-linear-gradient(0deg,#15181d,#15181d 2px,#1b1f26 2px,#1b1f26 4px);display:grid;place-items:center}.ob-viewfinder:before,.ob-viewfinder:after{content:"";position:absolute;width:34px;height:34px;border:3px solid rgba(255,255,255,.85)}.ob-corner{position:absolute;width:30px;height:30px;border:3px solid var(--brand)}.ob-corner.tl{top:18px;left:18px;border-right:none;border-bottom:none;border-top-left-radius:8px}.ob-corner.tr{top:18px;right:18px;border-left:none;border-bottom:none;border-top-right-radius:8px}.ob-corner.bl{bottom:18px;left:18px;border-right:none;border-top:none;border-bottom-left-radius:8px}.ob-corner.br{bottom:18px;right:18px;border-left:none;border-top:none;border-bottom-right-radius:8px}.ob-viewfinder:before,.ob-viewfinder:after{display:none}.ob-scanline{position:absolute;left:18px;right:18px;height:2px;background:linear-gradient(90deg,transparent,var(--brand),transparent);box-shadow:0 0 12px 2px #15a5e3b3;animation:ob-scan 2.2s ease-in-out infinite}@keyframes ob-scan{0%{top:22px}50%{top:calc(100% - 24px)}to{top:22px}}.ob-viewfinder-doc{position:absolute;top:36px;right:30px;bottom:36px;left:30px;border-radius:6px;background:#ffffff0f;border:1px dashed rgba(255,255,255,.16)}.ob-viewfinder-hint{position:relative;z-index:2;font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#ffffff9e;text-align:center;padding:0 20px}.ob-viewfinder.parsing{background:radial-gradient(120% 100% at 50% 50%,#1b2733,#11141a)}.ob-parse{position:relative;z-index:3;display:flex;flex-direction:column;align-items:center;gap:14px;color:#fff}.ob-parse-ring{width:46px;height:46px;border-radius:50%;border:3px solid rgba(255,255,255,.18);border-top-color:var(--brand);animation:ob-spin .85s linear infinite}@keyframes ob-spin{to{transform:rotate(360deg)}}.ob-parse-text{font-size:13px;font-weight:600}.ob-parse-sub{font-family:var(--mono);font-size:10.5px;color:#ffffff8c}.ob-scan-actions{display:flex;gap:10px}.ob-scan-actions .btn-primary,.ob-scan-actions .btn-ghost{flex:1;font-size:14px;padding:13px 12px}.ob-confirm{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--r-2xl);box-shadow:var(--shadow-soft);overflow:hidden;animation:ob-step-in .3s ease}.ob-confirm-head{display:flex;align-items:center;gap:9px;padding:13px 16px;border-bottom:1px solid var(--border-soft);background:var(--green-wash)}.ob-confirm-head .ob-check{width:22px;height:22px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center;flex:0 0 auto}.ob-confirm-head .ob-check svg{width:13px;height:13px}.ob-confirm-head h4{font-size:13.5px;font-weight:700;color:var(--green-ink)}.ob-confirm-sec{padding:13px 16px}.ob-confirm-sec+.ob-confirm-sec{border-top:1px solid var(--border-soft)}.ob-confirm-sec h5{font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin-bottom:9px}.ob-confirm-line{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:13px;padding:5px 0}.ob-confirm-line .ob-cl-name{color:var(--text-2);font-weight:500}.ob-confirm-line .ob-cl-val{font-family:var(--mono);font-size:12.5px;font-weight:700;color:var(--ink)}.ob-confirm-actions{display:flex;gap:10px;padding:13px 16px;border-top:1px solid var(--border-soft)}.ob-confirm-actions .btn-primary,.ob-confirm-actions .btn-ghost{flex:1;font-size:14px;padding:12px}.ob-addon{display:flex;align-items:center;gap:9px;justify-content:center;font-size:11.5px;color:var(--amber-ink)}.ob-budget{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px 0 4px}.ob-budget-val{font-family:var(--mono);font-size:56px;font-weight:700;letter-spacing:-2px;color:var(--brand-ink);line-height:1}.ob-budget-unit{font-size:13px;font-weight:600;color:var(--muted)}.ob-stepper{display:flex;align-items:center;gap:16px;margin:6px 0 2px}.ob-stepper-btn{width:50px;height:50px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--brand-ink);font-size:26px;line-height:1;cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow-soft);transition:transform .12s ease}.ob-stepper-btn:active{transform:scale(.92)}.ob-stepper-btn:disabled{color:var(--faint);box-shadow:none;cursor:default}.ob-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:8px;border-radius:5px;background:var(--border);outline:none;margin:8px 0 2px}.ob-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:26px;height:26px;border-radius:50%;background:var(--brand);border:3px solid #fff;box-shadow:0 2px 8px #15a5e380;cursor:pointer}.ob-slider::-moz-range-thumb{width:26px;height:26px;border-radius:50%;background:var(--brand);border:3px solid #fff;box-shadow:0 2px 8px #15a5e380;cursor:pointer}.ob-slider-ticks{display:flex;justify-content:space-between;font-family:var(--mono);font-size:9.5px;font-weight:600;color:var(--faint)}.ob-budget-note{display:flex;gap:9px;align-items:flex-start;padding:12px 14px;border-radius:var(--r);background:var(--bg);border:1px solid var(--border-soft);font-size:12.5px;line-height:1.5;color:var(--text-2)}.ob-budget-note b{color:var(--ink)}.ob-done-hero{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding:10px 0 2px}.ob-done-badge{width:76px;height:76px;border-radius:50%;background:var(--green-wash);color:var(--green);display:grid;place-items:center;animation:ob-pop .45s cubic-bezier(.2,1.4,.4,1)}@keyframes ob-pop{0%{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}.ob-done-badge svg{width:38px;height:38px}.ob-summary{display:flex;flex-direction:column;gap:10px}.ob-summary-card{display:flex;align-items:center;gap:13px;padding:13px 15px;border-radius:14px;background:var(--surface);border:1px solid var(--border-soft);box-shadow:var(--shadow-soft)}.ob-summary-card .ob-sc-ic{flex:0 0 auto;width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:var(--brand-wash);color:var(--brand-ink)}.ob-summary-card .ob-sc-ic svg{width:18px;height:18px}.ob-sc-label{font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}.ob-sc-value{font-size:14px;font-weight:600;color:var(--ink);margin-top:1px}.ob-class-name-input{width:100%;margin-top:3px;border:none;background:transparent;font-size:12.5px;color:var(--muted);padding:1px 0}.ob-class-name-input::placeholder{color:var(--faint)}.ob-class-name-input:focus{outline:none;color:var(--ink)}.ob-cat-row{display:flex;align-items:center;gap:8px;padding:4px 0}.ob-cat-name{flex:1;min-width:0;border:1px solid var(--border-soft);border-radius:9px;background:var(--surface);padding:8px 10px;font-size:13px;color:var(--ink)}.ob-cat-name::placeholder{color:var(--faint)}.ob-cat-name:focus{outline:none;border-color:var(--brand)}.ob-cat-weight{flex:0 0 auto;display:flex;align-items:center;gap:2px;border:1px solid var(--border-soft);border-radius:9px;background:var(--surface);padding:0 8px 0 4px}.ob-cat-weight:focus-within{border-color:var(--brand)}.ob-cat-weight-input{width:44px;border:none;background:transparent;text-align:right;font-family:var(--mono);font-size:13px;font-weight:700;color:var(--ink);padding:8px 0}.ob-cat-weight-input:focus{outline:none}.ob-cat-pct{font-family:var(--mono);font-size:12px;font-weight:700;color:var(--muted)}.ob-date-input{flex:0 0 auto;width:78px;border:1px solid var(--border-soft);border-radius:9px;background:var(--surface);padding:8px 10px;font-size:13px;color:var(--ink);text-align:center}.ob-date-input::placeholder{color:var(--faint)}.ob-date-input:focus{outline:none;border-color:var(--brand)}.ob-cat-rm{flex:0 0 auto;width:26px;height:26px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--muted);font-size:17px;line-height:1;display:grid;place-items:center}.ob-cat-rm:active{background:var(--border-soft)}.ob-cat-add{width:100%;margin-top:6px;padding:8px;border:1px dashed var(--border);border-radius:10px;background:transparent;color:var(--brand-ink);font-size:12.5px;font-weight:600}.ob-cat-add:active{background:var(--border-soft)}.ob-done-alt{margin-top:18px;display:flex;flex-direction:column;align-items:center;gap:8px}.ob-alt-btn{font-size:13px;padding:10px 18px}
