@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600&family=Nunito:wght@400;500;600;700&family=Poppins:wght@300;400;500;600&family=JetBrains+Mono:wght@400;500&display=swap";:root{--body-bg: linear-gradient(160deg, #1a1028 0%, #2a1f38 55%, #1e1e2e 100%);--bg: #1a1028;--paper: #241835;--soft: #2e2245;--softer: #1e1530;--ink: #f0e8ff;--ink-soft: #b8a8d4;--ink-faint: #7a6a90;--rule: rgba(180, 150, 255, .12);--shadow: rgba(0, 0, 0, .45);--accent-warm: #ff9966;--accent-leaf: #7abf9e;--accent-leaf-pale: #5a9e7e;--accent-sky: #89b4d4;--accent-rose: #d4a0c0;--font-serif: "Fraunces", Georgia, serif;--font-sans: "Poppins", "Nunito", -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-pill: 999px}[data-theme=light]{--body-bg: #fdf8f0;--bg: #fdf8f0;--paper: #ffffff;--soft: #f5ede0;--softer: #faf3e7;--ink: #2d2a26;--ink-soft: #5d574e;--ink-faint: #8a8278;--rule: #e8dcc8;--shadow: rgba(120, 90, 50, .08);--accent-warm: #c97b5e;--accent-leaf: #7a9471;--accent-leaf-pale: #a3b89c;--accent-sky: #6b8aa8;--accent-rose: #b87d7d;--font-sans: "Nunito", -apple-system, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--body-bg);background-attachment:fixed;color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased;min-height:100vh}.app-shell{max-width:620px;margin:0 auto;padding:20px 18px 60px}.header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.back-link{font-size:12px;color:var(--ink-faint);text-decoration:none;border-bottom:1px dotted var(--ink-faint);transition:color .2s,border-color .2s}.back-link:hover{color:var(--accent-warm);border-color:var(--accent-warm)}.theme-btn{background:var(--soft);border:1px solid var(--rule);color:var(--ink-soft);font-size:14px;padding:4px 10px;border-radius:var(--radius-pill);cursor:pointer;font-family:inherit;transition:background .2s;line-height:1}.theme-btn:hover{background:var(--rule)}header{margin-bottom:18px;text-align:center}header h1{font-family:var(--font-serif);font-weight:500;font-size:28px;letter-spacing:-.01em;color:var(--ink)}header .subtitle{font-size:13px;color:var(--ink-faint);font-style:italic}header .stats{font-size:11px;color:var(--ink-faint);margin-top:6px}.mode-nav{display:flex;gap:4px;margin-bottom:18px;background:var(--paper);padding:4px;border-radius:var(--radius-lg);border:1px solid var(--rule)}.mode-btn{flex:1;padding:8px 4px;background:transparent;border:none;font-family:inherit;font-size:12px;font-weight:600;color:var(--ink-soft);cursor:pointer;border-radius:var(--radius-md);letter-spacing:.04em;text-transform:uppercase;transition:background .15s,color .15s}.mode-btn.active{background:var(--accent-warm);color:#fff}.mode-btn:not(.active):hover{background:var(--soft);color:var(--ink)}.filters{display:flex;gap:4px;margin-bottom:8px;background:var(--paper);padding:4px;border-radius:var(--radius-lg);border:1px solid var(--rule);flex-wrap:wrap}.filter-btn{flex:1;min-width:60px;padding:6px 4px;background:transparent;border:none;font-family:inherit;font-size:11px;font-weight:500;color:var(--ink-soft);cursor:pointer;border-radius:var(--radius-md);white-space:nowrap;transition:background .15s;display:flex;flex-direction:column;align-items:center;gap:2px;line-height:1.2}.filter-btn.active{background:var(--soft);color:var(--ink)}.filter-sub{font-size:9px;font-weight:400;color:var(--ink-faint);letter-spacing:.03em}.filter-btn.active .filter-sub{color:var(--ink-soft)}.search{width:100%;padding:10px 14px;border:1px solid var(--rule);border-radius:var(--radius-md);font-family:inherit;font-size:14px;background:var(--paper);color:var(--ink);margin-bottom:8px}.search::placeholder{color:var(--ink-faint)}.search:focus{outline:2px solid var(--accent-warm)}.cat-filter{display:flex;gap:4px;margin-bottom:14px;flex-wrap:wrap;justify-content:center}.cat-pill{font-family:var(--font-mono);font-size:10.5px;padding:3px 9px;border:1px solid var(--rule);background:var(--paper);color:var(--ink-soft);cursor:pointer;border-radius:var(--radius-pill);letter-spacing:.04em;transition:background .15s}.cat-pill.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}.legend{font-size:11px;color:var(--ink-faint);margin-bottom:12px;text-align:center;line-height:1.7}.legend-item{display:inline-block;margin:0 6px}.legend-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px;vertical-align:middle}.helper-text{font-size:12px;color:var(--ink-faint);margin-bottom:14px;text-align:center;font-style:italic}.card{background:var(--paper);border-radius:var(--radius-lg);padding:16px 18px;margin-bottom:12px;box-shadow:0 2px 8px var(--shadow);border:1px solid var(--rule);transition:box-shadow .3s;position:relative}.card.flash{box-shadow:0 0 0 3px var(--accent-warm),0 4px 12px var(--shadow)}@keyframes linkTargetGlow{0%,25%{box-shadow:0 0 0 3px var(--accent-warm),0 0 28px #ff996673}to{box-shadow:0 2px 8px var(--shadow)}}.card.link-target{animation:linkTargetGlow 2.5s ease-out forwards;scroll-margin-top:24px}.card-tier-strip{position:absolute;left:0;top:14px;bottom:14px;width:3px;border-radius:0 2px 2px 0}.tier-0 .card-tier-strip{background:var(--accent-leaf-pale)}.tier-1 .card-tier-strip{background:var(--accent-leaf)}.tier-2 .card-tier-strip{background:var(--accent-warm)}.tier-3 .card-tier-strip{background:var(--accent-rose)}.card-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.card-tier-label{font-size:10.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.tier-0 .card-tier-label{color:var(--accent-leaf-pale)}.tier-1 .card-tier-label{color:var(--accent-leaf)}.tier-2 .card-tier-label{color:var(--accent-warm)}.tier-3 .card-tier-label{color:var(--accent-rose)}.card-meta-right{display:flex;gap:6px;align-items:center}.card-id{font-family:var(--font-mono);font-size:10px;color:var(--ink-faint);background:var(--softer);padding:2px 7px;border-radius:var(--radius-sm)}.python-badge{font-size:9.5px;font-weight:600;letter-spacing:.05em;color:var(--accent-sky);background:#6b8aa826;padding:2px 7px;border-radius:var(--radius-sm)}.technical{font-size:11px;color:var(--ink-faint);margin-top:4px;font-family:var(--font-mono)}.front{font-family:var(--font-serif);font-weight:400;font-size:16.5px;line-height:1.45;color:var(--ink)}.front-style-question{font-style:italic}.front-style-term{font-weight:500}.front-style-imperative{font-weight:400}.front-style-scenario{font-style:italic;line-height:1.5}.reveal-btn{width:100%;margin-top:12px;padding:9px;background:var(--soft);color:var(--ink);border:none;border-radius:var(--radius-md);font-family:inherit;font-size:12.5px;font-weight:600;cursor:pointer;transition:background .15s}.reveal-btn:hover{background:var(--rule)}.card-back{margin-top:12px;padding-top:12px;border-top:1px solid var(--rule);animation:fadeIn .25s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.hidden{display:none}pre{font-family:var(--font-mono);font-size:12.5px;background:var(--softer);padding:10px 12px;border-radius:var(--radius-md);overflow-x:auto;line-height:1.55;border:1px solid var(--rule);margin:8px 0;color:var(--ink)}.explanation{font-size:14px;color:var(--ink);line-height:1.55;margin-bottom:4px}.explanation code,.technique-gist code,.insight code,.gotcha code,.metaphor code,.mnemonic code{font-family:var(--font-mono);font-size:12.5px;background:var(--softer);padding:1px 5px;border-radius:4px;color:var(--accent-warm)}.technique-name{font-family:var(--font-serif);font-weight:500;font-size:15px;margin-bottom:6px;color:var(--ink)}.technique-gist{font-size:13.5px;color:var(--ink-soft);margin-bottom:10px;line-height:1.5}.annotation-label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:5px;opacity:.65}.metaphor{font-size:13px;color:var(--ink-soft);background:linear-gradient(to right,var(--softer),transparent);padding:9px 12px 9px 14px;border-radius:var(--radius-md);border-left:3px solid var(--accent-sky);line-height:1.5;margin:10px 0}.insight{font-size:13px;color:var(--ink-soft);background:var(--softer);padding:9px 12px;border-radius:var(--radius-md);border-left:3px solid var(--accent-leaf);line-height:1.5;margin:10px 0}.mnemonic{font-size:13px;color:var(--ink-soft);background:var(--softer);padding:9px 12px;border-radius:var(--radius-md);border-left:3px solid var(--accent-warm);line-height:1.5;margin:10px 0;font-style:italic}.gotcha{font-size:13px;color:var(--ink-soft);background:#b87d7d1a;padding:9px 12px;border-radius:var(--radius-md);border-left:3px solid var(--accent-rose);line-height:1.5;margin:10px 0}.pythonic-toggle{margin-top:8px;font-size:12px;color:var(--accent-warm);cursor:pointer;border-bottom:1px dotted var(--accent-warm);-webkit-user-select:none;user-select:none;display:inline-block}.pythonic-block{margin-top:8px;display:none}.pythonic-block.open{display:block}.pythonic-note{font-size:12px;color:var(--ink-soft);margin-bottom:6px;font-style:italic}.expand-btn{margin-top:12px;background:none;border:none;color:var(--accent-warm);font-family:inherit;font-size:12.5px;font-weight:600;cursor:pointer;padding:4px 0;border-bottom:1px dotted var(--accent-warm)}.deep-layer{margin-top:14px;display:none;animation:fadeIn .3s}.deep-layer.open{display:block}.back-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:6px;margin-top:12px}.hints{list-style:none}.hints li{font-size:12.5px;color:var(--ink-soft);padding:5px 0 5px 22px;position:relative;line-height:1.5}.hints li:before{content:"→";position:absolute;left:4px;color:var(--accent-warm);font-weight:600}.card-link{color:var(--accent-warm);text-decoration:none;border-bottom:1px dotted var(--accent-warm);cursor:pointer;font-weight:500;position:relative}.card-link:hover{color:var(--accent-rose)}.card-link:after{content:attr(data-id);position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-4px);background:var(--ink);color:var(--bg);padding:3px 8px;border-radius:4px;font-family:var(--font-mono);font-size:10px;white-space:nowrap;opacity:0;pointer-events:none;z-index:10;transition:opacity .2s}.card-link:hover:after{opacity:1}.link-row{font-size:13px;line-height:1.6;margin-bottom:6px}.anchor-problems{list-style:none}.anchor-problems li{padding:3px 0;font-size:12.5px}.anchor-problems a{color:var(--accent-sky);text-decoration:none;border-bottom:1px dotted var(--accent-sky)}.lc-num{font-family:var(--font-mono);font-size:11px;color:var(--ink-faint);margin-right:6px}.empty-state{text-align:center;padding:40px 20px;color:var(--ink-faint);font-style:italic}.loading{text-align:center;padding:60px 20px;color:var(--ink-faint)}footer{margin-top:32px;text-align:center;font-size:11.5px;color:var(--ink-faint);font-style:italic}.drill-setup{text-align:center;padding:20px 0}.drill-setup h2{font-family:var(--font-serif);font-size:22px;font-weight:500;margin-bottom:8px;color:var(--ink)}.drill-setup p{font-size:14px;color:var(--ink-soft);margin-bottom:20px;line-height:1.6}.drill-filters{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;margin-bottom:20px}.drill-filter-btn{padding:6px 14px;border:1px solid var(--rule);background:var(--paper);color:var(--ink-soft);border-radius:var(--radius-pill);font-family:inherit;font-size:12px;cursor:pointer;transition:all .15s;display:inline-flex;flex-direction:column;align-items:center;gap:1px;line-height:1.2}.drill-filter-btn.active{background:var(--accent-warm);border-color:var(--accent-warm);color:#fff}.drill-filter-btn.active .filter-sub{color:#ffffffbf}.queue-summary{font-size:13px;color:var(--ink-faint);margin-bottom:20px}.queue-summary strong{color:var(--accent-warm)}.start-btn{display:inline-block;padding:12px 32px;background:var(--accent-warm);color:#fff;border:none;border-radius:var(--radius-md);font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s}.start-btn:hover{opacity:.85}.start-btn:disabled{opacity:.4;cursor:not-allowed}.drill-progress{display:flex;align-items:center;gap:10px;margin-bottom:16px}.drill-progress-bar{flex:1;height:4px;background:var(--soft);border-radius:2px;overflow:hidden}.drill-progress-fill{height:100%;background:var(--accent-warm);border-radius:2px;transition:width .4s ease}.drill-progress-label{font-size:11px;color:var(--ink-faint);white-space:nowrap;font-family:var(--font-mono)}.rating-row{display:flex;gap:8px;margin-top:14px;animation:fadeIn .25s}.rating-btn{flex:1;padding:10px 6px;border:none;border-radius:var(--radius-md);font-family:inherit;font-size:12px;font-weight:700;cursor:pointer;transition:opacity .15s,transform .1s;letter-spacing:.03em}.rating-btn:hover{opacity:.85;transform:translateY(-1px)}.rating-btn:active{transform:translateY(0)}.rating-btn.no{background:#d4505026;color:#e57373;border:1px solid rgba(212,80,80,.3)}.rating-btn.almost{background:#ff996626;color:var(--accent-warm);border:1px solid rgba(255,153,102,.3)}.rating-btn.got-it{background:#7abf9e26;color:var(--accent-leaf);border:1px solid rgba(122,191,158,.3)}.drill-done{text-align:center;padding:40px 20px}.drill-done h2{font-family:var(--font-serif);font-size:24px;font-weight:500;margin-bottom:12px;color:var(--ink)}.drill-score-row{display:flex;justify-content:center;gap:20px;margin:20px 0}.drill-score-item{text-align:center}.drill-score-num{font-family:var(--font-mono);font-size:28px;font-weight:500;line-height:1}.drill-score-num.good{color:var(--accent-leaf)}.drill-score-num.ok{color:var(--accent-warm)}.drill-score-num.bad{color:#e57373}.drill-score-label{font-size:11px;color:var(--ink-faint);margin-top:4px;text-transform:uppercase;letter-spacing:.06em}.quiz-setup{text-align:center;padding:20px 0}.quiz-setup h2{font-family:var(--font-serif);font-size:22px;font-weight:500;margin-bottom:16px;color:var(--ink)}.quiz-mode-picker{display:flex;gap:10px;justify-content:center;margin-bottom:20px;flex-wrap:wrap}.quiz-mode-card{padding:16px 20px;background:var(--paper);border:2px solid var(--rule);border-radius:var(--radius-lg);cursor:pointer;text-align:left;max-width:220px;transition:border-color .15s,box-shadow .15s}.quiz-mode-card:hover{border-color:var(--accent-warm)}.quiz-mode-card.selected{border-color:var(--accent-warm);box-shadow:0 0 0 3px #ff996626}.quiz-mode-card h3{font-size:14px;font-weight:600;margin-bottom:6px;color:var(--ink)}.quiz-mode-card p{font-size:12px;color:var(--ink-soft);line-height:1.5}.quiz-progress{display:flex;align-items:center;gap:10px;margin-bottom:16px}.quiz-progress-bar{flex:1;height:4px;background:var(--soft);border-radius:2px;overflow:hidden}.quiz-progress-fill{height:100%;background:var(--accent-rose);border-radius:2px;transition:width .4s ease}.quiz-progress-label{font-size:11px;color:var(--ink-faint);white-space:nowrap;font-family:var(--font-mono)}.quiz-question{font-family:var(--font-serif);font-size:15.5px;line-height:1.5;color:var(--ink-soft);font-style:italic;margin-bottom:16px;padding:14px 16px;background:var(--softer);border-radius:var(--radius-md);border-left:3px solid var(--accent-rose)}.quiz-options{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.quiz-option{padding:12px 16px;background:var(--paper);border:1.5px solid var(--rule);border-radius:var(--radius-md);font-family:inherit;font-size:13px;color:var(--ink);cursor:pointer;text-align:left;line-height:1.4;transition:border-color .15s,background .15s;width:100%}.quiz-option:hover:not(:disabled){border-color:var(--accent-warm);background:var(--soft)}.quiz-option.correct{border-color:var(--accent-leaf);background:#7abf9e1a;color:var(--accent-leaf)}.quiz-option.wrong{border-color:#e57373;background:#e5737314;color:#e57373}.quiz-option code{font-family:var(--font-mono);font-size:11.5px;display:block;margin-top:4px;color:inherit;white-space:pre-wrap}.quiz-result{padding:12px 14px;border-radius:var(--radius-md);margin-bottom:14px;font-size:13px;line-height:1.5;animation:fadeIn .25s}.quiz-result.correct-result{background:#7abf9e1f;border:1px solid rgba(122,191,158,.3);color:var(--accent-leaf)}.quiz-result.wrong-result{background:#e5737314;border:1px solid rgba(229,115,115,.25);color:var(--ink-soft)}.quiz-result strong{display:block;margin-bottom:4px;font-size:14px}.quiz-result .distractor-notes{margin-top:8px;font-size:12px;color:var(--ink-faint)}.quiz-result .distractor-notes p{margin-top:4px}.next-btn{width:100%;padding:11px;background:var(--accent-warm);color:#fff;border:none;border-radius:var(--radius-md);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s}.next-btn:hover{opacity:.85}.quiz-done{text-align:center;padding:40px 20px}.quiz-done h2{font-family:var(--font-serif);font-size:24px;font-weight:500;margin-bottom:8px;color:var(--ink)}.quiz-accuracy{font-size:48px;font-family:var(--font-mono);font-weight:500;color:var(--accent-warm);margin:16px 0 4px}.quiz-accuracy-label{font-size:12px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em}.drill-answer-input{width:100%;margin-top:12px;padding:10px 12px;background:var(--softer);border:1px solid var(--rule);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:13px;color:var(--ink);resize:vertical;min-height:80px;line-height:1.55;transition:border-color .15s}.drill-answer-input::placeholder{color:var(--ink-faint);font-style:italic;font-family:var(--font-sans)}.drill-answer-input:focus{outline:none;border-color:var(--accent-warm)}.drill-user-answer{background:var(--softer);border:1px solid var(--rule);border-radius:var(--radius-md);padding:10px 12px;margin-bottom:10px;font-family:var(--font-mono);font-size:12.5px;color:var(--ink-soft);white-space:pre-wrap;line-height:1.55}.autograde{padding:10px 12px;border-radius:var(--radius-md);margin-bottom:12px;border:1px solid var(--rule);background:var(--soft);animation:fadeIn .2s}.autograde-header{display:flex;align-items:baseline;gap:8px;margin-bottom:6px}.autograde-pct{font-family:var(--font-mono);font-size:20px;font-weight:600;color:var(--accent-warm)}.autograde-sub{font-size:11px;color:var(--ink-faint)}.autograde-missed-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:5px}.autograde-terms{display:flex;flex-wrap:wrap;gap:4px}.autograde-term{font-family:var(--font-mono);font-size:11px;padding:2px 7px;border-radius:var(--radius-pill);background:#e573731f;color:#e57373;border:1px solid rgba(229,115,115,.25)}.autograde-perfect{font-size:12px;color:var(--accent-leaf);font-weight:600}.scroll-to-top{position:fixed;top:50%;left:calc(50% - 380px);transform:translateY(-50%) translate(-8px);width:44px;height:54px;background:var(--paper);border:1px solid var(--rule);border-radius:var(--radius-pill);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;opacity:0;pointer-events:none;transition:opacity .35s ease,transform .35s ease,background .2s;box-shadow:0 4px 16px var(--shadow);z-index:100}.scroll-to-top.visible{opacity:.85;transform:translateY(-50%) translate(0);pointer-events:auto;animation:scrollFloatArrow 3s ease-in-out infinite}.scroll-to-top:hover{opacity:1;background:var(--soft)}.scroll-to-top:focus-visible{outline:2px solid var(--accent-warm);outline-offset:3px}@keyframes scrollFloatArrow{0%,to{transform:translateY(calc(-50% + 0px))}50%{transform:translateY(calc(-50% - 4px))}}@media (max-width: 1024px){.scroll-to-top{top:auto;left:auto;bottom:24px;right:24px;transform:translateY(8px)}.scroll-to-top.visible{transform:translateY(0)}@keyframes scrollFloatArrow{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}}@media (max-width: 480px){.scroll-to-top{bottom:16px;right:16px;width:38px;height:46px}.scroll-to-top svg{width:24px;height:32px}}.onboarding-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .25s;overflow-y:auto}.onboarding-modal{background:var(--paper);border:1px solid var(--rule);border-radius:var(--radius-lg);padding:28px 30px;max-width:540px;width:100%;max-height:calc(100vh - 40px);overflow-y:auto;box-shadow:0 12px 40px var(--shadow);color:var(--ink)}.onboarding-modal h2{font-family:var(--font-serif);font-size:24px;font-weight:500;margin-bottom:8px;color:var(--ink)}.onboarding-lede{font-size:14px;color:var(--ink-soft);margin-bottom:20px;line-height:1.6}.onboarding-tiers{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.ob-tier{display:flex;gap:12px;align-items:stretch;padding:10px 12px;background:var(--softer);border-radius:var(--radius-md);border:1px solid var(--rule)}.ob-tier-strip{flex:0 0 4px;border-radius:2px}.ob-tier strong{font-size:13px;color:var(--ink);display:block;margin-bottom:2px}.ob-tier p{font-size:12.5px;color:var(--ink-soft);line-height:1.45}.onboarding-modes{margin-bottom:16px}.onboarding-modes strong{display:block;font-size:13px;margin-bottom:6px;color:var(--ink)}.onboarding-modes ul{list-style:none;font-size:13px;color:var(--ink-soft);line-height:1.7}.onboarding-modes b{color:var(--accent-warm);font-weight:600}.onboarding-card-id{font-size:12px;color:var(--ink-faint);margin-bottom:18px;line-height:1.5}.onboarding-card-id code{font-family:var(--font-mono);font-size:11px;background:var(--softer);padding:1px 5px;border-radius:4px;color:var(--accent-warm)}.onboarding-dismiss{width:100%;margin-top:4px}.onboarding-amy{margin-top:14px;text-align:center;font-family:var(--font-serif);font-size:12px;font-style:italic;color:var(--accent-rose);letter-spacing:.04em;opacity:.75}.ws-home{padding:8px 0}.ws-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.ws-header-row h2{font-family:var(--font-serif);font-size:22px;font-weight:500;color:var(--ink)}.ws-new-btn{padding:8px 16px;font-size:13px}.ws-lede{font-size:13px;color:var(--ink-soft);margin-bottom:18px;line-height:1.6}.ws-list{list-style:none;display:flex;flex-direction:column;gap:8px}.ws-list-item{background:var(--paper);border:1px solid var(--rule);border-radius:var(--radius-md);padding:12px 14px}.ws-list-name{font-family:var(--font-serif);font-size:15px;font-weight:500;color:var(--ink)}.ws-list-meta{font-size:11px;color:var(--ink-faint);margin-top:2px}.ws-list-actions{margin-top:8px;display:flex;gap:6px;flex-wrap:wrap}.ws-list-actions button{font-family:inherit;font-size:11.5px;padding:4px 10px;border:1px solid var(--rule);background:var(--soft);color:var(--ink);border-radius:var(--radius-sm);cursor:pointer}.ws-list-actions button:hover{background:var(--rule)}.ws-list-actions .ws-delete:hover{background:#e5737326;color:#e57373;border-color:#e573734d}.ws-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:14px}.ws-back-btn{font-family:inherit;font-size:12px;padding:6px 10px;background:var(--soft);border:1px solid var(--rule);color:var(--ink-soft);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap}.ws-back-btn:hover{background:var(--rule)}.ws-name-input{flex:1;font-family:var(--font-serif);font-size:16px;padding:8px 12px;background:var(--paper);border:1px solid var(--rule);border-radius:var(--radius-md);color:var(--ink)}.ws-name-input:focus{outline:2px solid var(--accent-warm)}.ws-save-btn{padding:8px 16px;font-size:13px}.ws-field-label{display:block;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin:14px 0 6px}.ws-problem,.ws-notes,.ws-code{width:100%;padding:10px 12px;background:var(--softer);border:1px solid var(--rule);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:13px;color:var(--ink);resize:vertical;line-height:1.55;transition:border-color .15s}.ws-problem,.ws-notes{font-family:var(--font-sans)}.ws-problem:focus,.ws-notes:focus,.ws-code:focus{outline:none;border-color:var(--accent-warm)}.ws-step{margin-top:14px;padding:14px;background:var(--paper);border:1px solid var(--rule);border-radius:var(--radius-lg)}.ws-step header{display:flex;align-items:center;gap:8px;margin-bottom:10px;font-family:var(--font-serif);font-size:15px;font-weight:500;color:var(--ink)}.ws-step-num{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--accent-warm);color:#fff;border-radius:50%;font-size:12px;font-weight:600;font-family:var(--font-mono)}.ws-tier-tag{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;font-weight:600;padding:2px 6px;border-radius:var(--radius-sm);margin-left:auto}.ws-tier-tag.t1{background:#7abf9e2e;color:var(--accent-leaf)}.ws-tier-tag.t2{background:#ff99662e;color:var(--accent-warm)}.ws-tier-tag.t3{background:#d4a0c02e;color:var(--accent-rose)}.ws-typeahead{width:100%;padding:8px 12px;background:var(--softer);border:1px solid var(--rule);border-radius:var(--radius-md);font-family:inherit;font-size:13px;color:var(--ink)}.ws-typeahead:focus{outline:2px solid var(--accent-warm)}.ws-typeahead-results{display:flex;flex-direction:column;gap:4px;margin-top:4px}.ws-typeahead-results:empty{display:none}.ws-typeahead-result{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:var(--softer);border:1px solid var(--rule);border-radius:var(--radius-sm);font-family:inherit;font-size:12.5px;color:var(--ink);cursor:pointer;text-align:left}.ws-typeahead-result:hover{background:var(--soft);border-color:var(--accent-warm)}.ws-typeahead-front{flex:1;line-height:1.4}.ws-typeahead-id{font-family:var(--font-mono);font-size:10px;color:var(--ink-faint);margin-left:8px;white-space:nowrap}.ws-suggested{margin-bottom:10px}.ws-suggested-label{display:block;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);margin-bottom:5px}.ws-suggested-row{display:flex;flex-wrap:wrap;gap:4px}.ws-suggested-chip{font-family:inherit;font-size:11.5px;padding:4px 10px;background:var(--softer);border:1px dashed var(--rule);color:var(--ink-soft);border-radius:var(--radius-pill);cursor:pointer}.ws-suggested-chip:hover{background:var(--soft)}.ws-suggested-chip.picked{background:#ff996626;border-color:var(--accent-warm);color:var(--accent-warm);border-style:solid}.ws-pick,.ws-picks{display:flex;flex-direction:column;gap:6px;margin-top:8px}.ws-pick:empty,.ws-picks:empty{display:none}.ws-pick-card{background:var(--softer);border:1px solid var(--rule);border-radius:var(--radius-md);padding:10px 12px}.ws-pick-head{display:flex;align-items:center;gap:8px;margin-bottom:4px}.ws-pick-name{flex:1;font-size:13px;font-weight:500;color:var(--ink);line-height:1.4}.ws-pick-id{font-family:var(--font-mono);font-size:10px;color:var(--ink-faint)}.ws-pick-remove{background:transparent;border:none;color:var(--ink-faint);font-size:18px;line-height:1;cursor:pointer;padding:0 4px}.ws-pick-remove:hover{color:#e57373}.ws-pick-gist{font-size:12.5px;color:var(--ink-soft);line-height:1.5}.ws-pick-code{font-family:var(--font-mono);font-size:11.5px;background:var(--bg);padding:8px 10px;border-radius:var(--radius-sm);margin-top:6px;overflow-x:auto;line-height:1.55;color:var(--ink)}.ws-bottom-actions{display:flex;gap:8px;margin-top:16px}.ws-export-btn{flex:1;padding:10px;background:var(--soft);border:1px solid var(--rule);color:var(--ink);border-radius:var(--radius-md);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer}.ws-export-btn:hover{background:var(--rule)}.ws-save-btn-2{flex:1}
