.p1.layout-split{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:20px}@media (max-width: 1080px){.p1.layout-split{grid-template-columns:1fr}}.p1-sol-nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.p1-sol-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;text-align:left;font-family:inherit;transition:all .1s ease;display:flex;flex-direction:column;gap:2px}.p1-sol-btn:hover{border-color:var(--accent);color:var(--text-strong)}.p1-sol-btn.active{background:var(--accent-bg);border-color:var(--accent);color:var(--text-strong)}.p1-sol-btn-id{font-weight:600;font-size:13px}.p1-sol-btn-tag{font-size:11px;color:var(--muted)}.p1-sol-btn.active .p1-sol-btn-tag{color:var(--accent-strong)}.p1-sol-detail h3{margin:20px 0 10px;font-size:17px;font-weight:600}.p1-sol-meta{display:flex;gap:8px;flex-wrap:wrap}.meta-pill{background:var(--code-bg);border:1px solid var(--code-border);padding:4px 10px;border-radius:4px;font-size:12px;color:var(--muted);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.meta-pill strong{color:var(--text-strong);font-weight:600;margin-left:4px}.p1-sol-explanation{font-size:14px;line-height:1.65;margin:0}.p1-sol-code{background:var(--code-bg);border:1px solid var(--code-border);border-radius:var(--radius-sm);padding:14px 16px;overflow:auto;font-size:12.5px;line-height:1.55;margin:0;max-height:520px}.p1-input-row{margin-bottom:10px}.p1-input{width:100%;background:var(--code-bg);border:1px solid var(--border);color:var(--text-strong);padding:10px 12px;border-radius:var(--radius-sm);font-size:14px}.p1-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-bg)}.p1-button-row{display:flex;gap:8px}.p1-input-hint{font-size:11.5px;color:var(--muted);margin:6px 2px 10px}.p1-input-hint code{background:var(--code-bg);border:1px solid var(--code-border);padding:0 4px;border-radius:3px;font-size:11px;color:var(--text)}.p1-input-hint strong{color:var(--text-strong);font-weight:600}.p1-result-warning{margin-top:8px;padding:6px 10px;background:#f0b6571a;border-left:2px solid var(--warn);border-radius:0 4px 4px 0;font-size:11.5px;color:var(--warn)}.p1-result{background:var(--code-bg);border:1px solid var(--code-border);border-radius:var(--radius-sm);padding:14px 16px;min-height:64px;font-size:13px;word-break:break-all}.p1-result.ok{border-color:var(--pass)}.p1-result.error{border-color:var(--fail)}.p1-result-placeholder{color:var(--muted);font-style:italic}.p1-result-value{font-size:15px;font-weight:600;color:var(--text-strong)}.p1-result.error .p1-result-value{color:var(--fail)}.p1-result-meta{color:var(--muted);font-size:11.5px;margin-top:6px}.p1-test-summary{font-size:13px;color:var(--muted);margin-bottom:8px}.p1-test-summary.all-pass{color:var(--pass);font-weight:600}.p1-test-summary.some-fail{color:var(--fail);font-weight:600}.p1-test-list{list-style:none;padding:0;margin:0;max-height:320px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-sm)}.p1-test-item{display:grid;grid-template-columns:22px minmax(0,1fr);grid-template-rows:auto auto;column-gap:6px;row-gap:2px;padding:8px 12px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;border-bottom:1px solid var(--border)}.p1-test-item:last-child{border-bottom:none}.p1-test-item.pass .p1-test-mark{color:var(--pass);font-weight:700}.p1-test-item.fail .p1-test-mark{color:var(--fail);font-weight:700}.p1-test-mark{grid-row:1 / span 2;font-size:14px}.p1-test-label{color:var(--text-strong);font-weight:600}.p1-test-expected{color:var(--muted);font-size:11px}.p1-test-expected code{background:var(--code-bg);padding:1px 5px;border-radius:3px;border:1px solid var(--code-border);font-size:11px;color:var(--text)}.p2-wrap{display:flex;justify-content:center;padding:16px 0 48px}.p2-card{width:100%;max-width:480px;background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:22px;box-shadow:var(--shadow-2);display:flex;flex-direction:column;gap:8px}.p2-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:10px;flex-wrap:wrap}.p2-title{margin:0;font-size:18px;font-weight:600;color:var(--text-strong)}.p2-slip{display:flex;align-items:center;gap:4px;background:var(--panel-2);padding:4px;border-radius:8px;border:1px solid var(--border)}.p2-slip-label{font-size:11px;color:var(--muted);padding:0 6px;letter-spacing:.4px;text-transform:uppercase}.p2-slip-btn{background:transparent;border:none;color:var(--muted);font:inherit;font-size:12px;font-weight:600;padding:5px 9px;border-radius:5px;cursor:pointer}.p2-slip-btn:hover{color:var(--text)}.p2-slip-btn.active{background:var(--accent-bg);color:var(--text-strong)}.p2-slip-input{width:60px;background:var(--code-bg);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:4px 6px;font-size:12px;text-align:right}.p2-slip-input:focus{outline:none;border-color:var(--accent)}.p2-slip-input::-webkit-outer-spin-button,.p2-slip-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.p2-leg{background:var(--panel-2);border:1px solid var(--border);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:8px;transition:border-color .1s ease}.p2-leg:focus-within{border-color:var(--accent)}.p2-leg-head{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--muted)}.p2-balance{display:inline-flex;align-items:center;gap:6px}.p2-max{background:var(--accent-bg);color:var(--accent-strong);border:none;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:700;cursor:pointer;font-family:inherit}.p2-max:hover{background:var(--accent);color:#0a0f1a}.p2-max:disabled{opacity:.4;cursor:not-allowed}.p2-leg-body{display:flex;align-items:center;gap:10px}.p2-amount{flex:1;min-width:0;background:transparent;border:none;color:var(--text-strong);font-size:26px;font-weight:500;padding:4px 0;letter-spacing:-.02em}.p2-amount:focus{outline:none}.p2-amount.readonly{cursor:default}.p2-amount::placeholder{color:var(--muted);opacity:.4}.p2-leg-foot{font-size:11px;color:var(--muted)}.p2-flip-row{display:flex;justify-content:center;margin:-10px 0;position:relative;z-index:2}.p2-flip{background:var(--panel);border:3px solid var(--bg);color:var(--text);width:36px;height:36px;border-radius:10px;cursor:pointer;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.p2-flip:hover:not(:disabled){background:var(--accent-bg);color:var(--accent-strong);transform:rotate(180deg)}.p2-flip:disabled{opacity:.5;cursor:not-allowed}.p2-summary{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:6px;margin-top:4px}.p2-summary-row{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--muted)}.p2-summary-value{color:var(--text)}.p2-validation{color:var(--warn);font-size:12.5px;padding:8px 12px;background:#f0b65714;border:1px solid rgba(240,182,87,.3);border-radius:8px}.p2-submit{width:100%;padding:14px;font-size:15px;border-radius:10px;margin-top:4px}.ts{position:relative;flex-shrink:0}.ts-trigger{display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--border);color:var(--text-strong);padding:6px 10px 6px 8px;border-radius:999px;cursor:pointer;font:inherit;font-weight:600;transition:all .1s ease}.ts-trigger:hover{border-color:var(--accent)}.ts-trigger.placeholder{color:var(--muted);font-weight:500}.ts-trigger-symbol{font-size:14px}.ts-trigger-caret{font-size:9px;color:var(--muted);margin-left:2px}.ts-panel{position:absolute;top:calc(100% + 6px);right:0;width:320px;background:var(--panel);border:1px solid var(--border-strong);border-radius:10px;box-shadow:var(--shadow-2);z-index:10;overflow:hidden;display:flex;flex-direction:column;max-height:380px}.ts-search-row{padding:10px;border-bottom:1px solid var(--border)}.ts-search{width:100%;background:var(--code-bg);border:1px solid var(--border);color:var(--text);padding:8px 10px;border-radius:6px;font-size:13px;font-family:inherit}.ts-search:focus{outline:none;border-color:var(--accent)}.ts-list{list-style:none;padding:6px;margin:0;overflow-y:auto}.ts-option{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;background:transparent;border:none;border-radius:6px;cursor:pointer;color:var(--text);font:inherit;text-align:left}.ts-option:hover:not(.disabled){background:var(--panel-2)}.ts-option.selected{background:var(--accent-bg)}.ts-option.disabled{opacity:.35;cursor:not-allowed}.ts-option-main{display:flex;flex-direction:column;flex:1;min-width:0}.ts-option-symbol{font-weight:600;color:var(--text-strong);font-size:13px}.ts-option-balance{font-size:11px;color:var(--muted);margin-top:1px}.ts-option-price{font-size:12px;color:var(--muted)}.ts-empty{padding:16px;text-align:center;color:var(--muted);font-size:13px}.token-icon{border-radius:50%;background:var(--panel-2)}.token-fallback{border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:700;text-transform:uppercase;flex-shrink:0}.p2-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;gap:12px;color:var(--muted)}.p2-state .spinner{color:var(--accent)}.p2-state.error code{background:var(--code-bg);border:1px solid var(--code-border);padding:8px 12px;border-radius:6px;font-size:12px;color:var(--fail);max-width:600px;word-break:break-all}.p3{display:flex;flex-direction:column;gap:20px}.p3-section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px;flex-wrap:wrap}.p3-section-head h2{text-transform:none;letter-spacing:0;font-size:16px;color:var(--text-strong);margin:0 0 4px}.p3-section-blurb{margin:0;font-size:12.5px;color:var(--muted);max-width:720px}.p3-section-blurb code{background:var(--code-bg);border:1px solid var(--code-border);padding:0 4px;border-radius:3px;font-size:11.5px;color:var(--text)}.p3-filter,.p3-layout-toggle{display:flex;gap:4px;background:var(--panel-2);padding:4px;border-radius:8px;border:1px solid var(--border);flex-wrap:wrap}.p3-filter-btn{background:transparent;border:none;color:var(--muted);font:inherit;font-size:12px;font-weight:600;padding:5px 10px;border-radius:5px;cursor:pointer}.p3-filter-btn:hover{color:var(--text)}.p3-filter-btn.active{background:var(--accent-bg);color:var(--text-strong)}.p3-issue-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:12px}.p3-issue{background:var(--panel-2);border:1px solid var(--border);border-left:3px solid var(--border-strong);border-radius:8px;padding:14px 16px;display:flex;flex-direction:column;gap:6px}.p3-issue.sev-bug{border-left-color:var(--fail)}.p3-issue.sev-perf{border-left-color:var(--warn)}.p3-issue.sev-anti-pattern{border-left-color:var(--accent)}.p3-issue.sev-style{border-left-color:var(--muted)}.p3-issue-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.p3-issue-num{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-weight:700;color:var(--muted);font-size:12px}.p3-sev-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 7px;border-radius:3px;background:var(--code-bg);color:var(--muted)}.p3-sev-badge.sev-bug{background:#ff686829;color:var(--fail)}.p3-sev-badge.sev-perf{background:#f0b65729;color:var(--warn)}.p3-sev-badge.sev-anti-pattern{background:var(--accent-bg);color:var(--accent-strong)}.p3-issue-title{margin:0;font-size:13.5px;font-weight:600;color:var(--text-strong);flex:1;min-width:200px}.p3-issue-body{margin:0;font-size:12.5px;line-height:1.6;color:var(--text)}.p3-code-grid{display:grid;gap:16px}.p3-code-grid.split{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.p3-code-grid.stacked{grid-template-columns:1fr}@media (max-width: 1080px){.p3-code-grid.split{grid-template-columns:1fr}}.p3-code-block{display:flex;flex-direction:column;background:var(--code-bg);border:1px solid var(--code-border);border-radius:8px;overflow:hidden;min-width:0}.p3-code-block.original{border-color:#ff68684d}.p3-code-block.refactored{border-color:#44c4664d}.p3-code-label{padding:8px 14px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);border-bottom:1px solid var(--code-border);background:var(--panel-2)}.p3-code-block.original .p3-code-label{color:var(--fail)}.p3-code-block.refactored .p3-code-label{color:var(--pass)}.p3-code{margin:0;padding:14px 16px;overflow:auto;font-size:12px;line-height:1.55;max-height:520px}.p3-demo{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:8px}.p3-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--panel);border:1px solid var(--border);border-radius:8px;gap:16px}.p3-row-main{display:flex;flex-direction:column;gap:2px}.p3-row-symbol{font-size:14px;font-weight:600;color:var(--text-strong)}.p3-row-chain{font-size:11px;color:var(--muted)}.p3-row-numbers{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.p3-row-amount{font-size:13px;color:var(--text)}.p3-row-amount-raw{color:var(--muted);font-size:11px}.p3-row-usd{font-size:12px;color:var(--muted)}:root{color-scheme:dark;--bg: #0b0f17;--bg-elev: #111827;--panel: #161e2e;--panel-2: #1c2638;--border: #2a3447;--border-strong: #3a465e;--text: #e6edf6;--text-strong: #f3f7fd;--muted: #95a3b8;--accent: #6aa7ff;--accent-strong: #88baff;--accent-bg: rgba(106, 167, 255, .14);--pass: #44c466;--fail: #ff6868;--warn: #f0b657;--code-bg: #060a13;--code-border: #1f2a3d;--shadow-1: 0 1px 2px rgba(0, 0, 0, .4);--shadow-2: 0 8px 24px rgba(0, 0, 0, .35);--radius: 10px;--radius-sm: 6px}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;background:var(--bg);color:var(--text);min-height:100vh}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Inter,Oxygen,Ubuntu,Cantarell,sans-serif;font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased}code,pre,.mono{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,monospace}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-strong);text-decoration:underline}.app{max-width:1400px;margin:0 auto;padding:28px 32px 48px}.app-header{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border)}.app-title{display:flex;align-items:baseline;gap:12px;margin-bottom:16px}.app-title h1{margin:0;font-size:22px;font-weight:600;color:var(--text-strong)}.app-title-tag{font-size:11px;font-weight:700;letter-spacing:1.5px;color:var(--accent);background:var(--accent-bg);padding:4px 8px;border-radius:4px;text-transform:uppercase}.app-tabs{display:flex;gap:4px;margin-bottom:10px;flex-wrap:wrap}.app-tab{padding:9px 14px;border-radius:6px;font-size:13px;color:var(--muted);font-weight:500;border:1px solid transparent;transition:all .1s ease}.app-tab:hover{color:var(--text);background:var(--panel);text-decoration:none}.app-tab.active{color:var(--text-strong);background:var(--accent-bg);border-color:var(--accent)}.app-subtitle{margin:0;color:var(--muted);font-size:13px}.app-main{min-height:60vh}.app-footer{margin-top:32px;padding-top:16px;border-top:1px solid var(--border);color:var(--muted);font-size:12px}.app-footer code{background:var(--code-bg);border:1px solid var(--code-border);padding:1px 6px;border-radius:4px;font-size:11.5px}.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:20px;min-width:0}.panel h2,.panel h3{color:var(--text-strong);margin:0 0 10px}.panel h2{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}.panel h2:not(:first-child){margin-top:22px}.btn{border:none;padding:10px 18px;border-radius:var(--radius-sm);font-weight:600;font-family:inherit;font-size:13px;cursor:pointer;transition:all .1s ease;display:inline-flex;align-items:center;justify-content:center;gap:6px}.btn:disabled{cursor:not-allowed;opacity:.55}.btn-primary{background:var(--accent);color:#0a0f1a}.btn-primary:not(:disabled):hover{background:var(--accent-strong)}.btn-secondary{background:transparent;border:1px solid var(--border-strong);color:var(--text)}.btn-secondary:not(:disabled):hover{border-color:var(--accent);color:var(--text-strong)}.btn-ghost{background:transparent;color:var(--muted);padding:6px 10px}.btn-ghost:hover{color:var(--text);background:var(--panel-2)}.spinner{width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--panel);border:1px solid var(--border-strong);padding:12px 18px;border-radius:8px;box-shadow:var(--shadow-2);font-size:13px;display:flex;align-items:center;gap:10px;animation:toast-in .2s ease;z-index:9999}.toast.toast-success{border-color:var(--pass)}.toast.toast-error{border-color:var(--fail)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}
