@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;600;700&display=swap";:root{--bg: #f4f6fb;--surface: #ffffff;--surface-2: #f8fafc;--surface-3: #eef1f8;--border: #dce1eb;--border-m: #b8c4d6;--text-1: #0f172a;--text-2: #334155;--text-3: #64748b;--text-4: #94a3b8;--primary: #1e3a5f;--primary-h: #163050;--primary-l: #2d5a8e;--primary-bg: #e8eef6;--accent: #2563eb;--accent-h: #1d4ed8;--accent-bg: #dbeafe;--accent-t: #1d4ed8;--ok-bg: #d1fae5;--ok-t: #065f46;--ok-head: #059669;--err-bg: #fee2e2;--err-t: #991b1b;--violet: #8b5cf6;--violet-bg: #ede9fe;--radius-s: 4px;--radius-m: 8px;--radius-l: 12px;--radius-xl: 16px;--shadow-s: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);--shadow-m: 0 4px 12px rgba(0,0,0,.1), 0 2px 4px rgba(0,0,0,.06);--transition: .15s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text-1);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;min-height:100vh}.app--solver{height:100vh;overflow:hidden}.app-header{background:var(--primary);padding:0 24px;height:48px;display:flex;align-items:center;flex-shrink:0;z-index:20;box-shadow:0 2px 8px #0000002e}.app-header__brand{display:flex;align-items:center;gap:8px;position:absolute;left:50%;transform:translate(-50%)}.app-header__logo{width:26px;height:26px;background:var(--accent);border-radius:5px;display:grid;place-items:center;color:#fff;font-size:12px;font-weight:800;font-family:JetBrains Mono,monospace}.app-header__title{font-size:.88rem;font-weight:700;color:#fff;letter-spacing:-.2px}.app-header__nav{display:flex;gap:6px;margin-left:auto}.btn-header-nav{padding:5px 12px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-s);color:#ffffffd9;font-size:.72rem;font-weight:600;cursor:pointer;transition:all var(--transition);font-family:Inter,sans-serif}.btn-header-nav:hover{background:#fff3;color:#fff}.app-main{flex:1;max-width:880px;width:100%;margin:0 auto;padding:32px 20px 48px}.problem-input{display:flex;flex-direction:column;gap:16px;max-width:880px}.pi-topbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px}.pi-topbar-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.pi-topbar-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.pi-label{font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3)}.counter{display:inline-flex;align-items:center;border:1.5px solid var(--border-m);border-radius:var(--radius-m);overflow:hidden;height:32px;background:var(--surface);box-shadow:var(--shadow-s)}.counter button{width:30px;height:32px;background:none;border:none;font-size:1rem;font-weight:600;cursor:pointer;color:var(--text-2);transition:all var(--transition)}.counter button:hover:not(:disabled){background:var(--primary);color:#fff}.counter button:disabled{color:var(--border-m);cursor:not-allowed}.counter span{width:34px;text-align:center;font-weight:700;font-size:.88rem;border-left:1.5px solid var(--border-m);border-right:1.5px solid var(--border-m);height:32px;line-height:32px;background:var(--surface-2);font-family:JetBrains Mono,monospace;color:var(--primary)}.type-toggle{display:inline-flex;border:1.5px solid var(--border-m);border-radius:var(--radius-m);overflow:hidden;height:32px;background:var(--surface);box-shadow:var(--shadow-s)}.type-toggle button{padding:0 16px;background:none;border:none;font-size:.75rem;font-weight:700;letter-spacing:.06em;cursor:pointer;color:var(--text-3);transition:all var(--transition);height:32px;font-family:JetBrains Mono,monospace}.type-toggle button.active{background:var(--primary);color:#fff}.type-toggle button:not(.active):hover{background:var(--surface-3);color:var(--text-1)}.pi-divider{height:1px;background:var(--border)}.pi-examples{display:flex;flex-wrap:wrap;gap:4px}.btn-example{padding:3px 10px;font-size:.72rem;font-weight:600;border:1px solid var(--border);border-radius:var(--radius-s);background:var(--surface);color:var(--text-2);cursor:pointer;transition:all var(--transition)}.btn-example:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.pi-card{background:var(--surface);border:1px solid var(--border-m);border-radius:var(--radius-l);overflow:hidden;box-shadow:var(--shadow-s)}.pi-matrix-wrap{overflow-x:auto}.pi-matrix{border-collapse:collapse;width:100%;min-width:400px}.pi-matrix thead th{background:var(--primary);color:#fff;padding:0;border-right:1px solid rgba(255,255,255,.1);border-bottom:2px solid var(--primary-h);text-align:center}.pi-matrix thead th:last-child{border-right:none}.pi-th-label{min-width:72px;width:72px}.pi-th-rel{width:64px}.pi-th-rhs{width:80px}.pi-th-var{min-width:84px}.input-varname{width:100%;padding:8px 4px;background:transparent;border:none;color:#fff;font-size:.78rem;font-weight:700;text-align:center;outline:none;font-family:JetBrains Mono,monospace}.input-varname::placeholder{color:#ffffff59}.input-varname:focus{background:#ffffff1f}.pi-th-rhs-label{display:block;padding:8px;font-size:.8rem;font-weight:700;font-style:italic;font-family:JetBrains Mono,monospace;color:#fff;text-align:center}.pi-th-rel-text{display:block;padding:8px 4px;font-size:.65rem;font-weight:600;color:#ffffff80;text-align:center;letter-spacing:.05em;text-transform:uppercase}.pi-row-obj{border-bottom:2px solid var(--border-m);background:var(--surface-2)}.pi-row-obj:hover{background:var(--surface-3)}.pi-label-obj{padding:8px 12px;font-size:.78rem;font-weight:700;color:var(--text-1);border-right:1.5px solid var(--border-m);white-space:nowrap;display:flex;align-items:center;gap:6px}.obj-badge{display:inline-block;padding:2px 6px;background:var(--primary);color:#fff;border-radius:4px;font-size:.6rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.pi-td-obj{text-align:center;padding:6px 4px;border-right:1px solid var(--border)}.pi-td-obj:last-of-type{border-right:none}.pi-td-dash{text-align:center;color:var(--text-4);font-size:1rem;border-right:1px solid var(--border);vertical-align:middle}.pi-td-dash:last-child{border-right:none}.pi-row-con{border-bottom:1px solid var(--border);transition:background var(--transition)}.pi-row-con:hover{background:var(--surface-2)}.pi-row-con:last-child{border-bottom:none}.pi-label-con{padding:6px 12px;font-size:.72rem;font-weight:700;color:var(--text-3);border-right:1.5px solid var(--border-m);background:var(--surface-2);font-family:JetBrains Mono,monospace;white-space:nowrap;text-align:center}.pi-td-con{text-align:center;padding:6px 4px;border-right:1px solid var(--border)}.pi-td-rel{text-align:center;padding:6px 4px;border-right:1px solid var(--border);border-left:1px solid var(--border)}.pi-td-rhs{text-align:center;padding:6px 8px}.input-coeff{width:66px;padding:4px;border:1.5px solid transparent;border-radius:var(--radius-s);font-size:.85rem;font-weight:600;text-align:center;color:var(--text-1);background:transparent;transition:all var(--transition);font-family:JetBrains Mono,monospace}.input-coeff:hover{border-color:var(--border-m);background:var(--surface-2)}.input-coeff:focus{outline:none;border-color:var(--accent);background:var(--accent-bg);color:var(--accent-t)}.input-coeff::placeholder{color:var(--text-4);font-weight:400;font-size:.76rem}.input-rhs{width:64px;padding:4px 6px;border:1.5px solid var(--border);border-radius:var(--radius-s);font-size:.85rem;font-weight:700;text-align:center;color:var(--text-1);background:var(--surface);transition:all var(--transition);font-family:JetBrains Mono,monospace}.input-rhs:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1f}.select-rel{padding:3px 5px;height:30px;border:1.5px solid var(--border);border-radius:var(--radius-s);font-size:.95rem;font-weight:700;color:var(--text-1);background:var(--surface);cursor:pointer;text-align:center;-webkit-appearance:none;-moz-appearance:none;appearance:none;min-width:42px;font-family:JetBrains Mono,monospace}.select-rel:focus{outline:none;border-color:var(--accent)}.pi-matrix-footer{padding:7px 12px;border-top:1px solid var(--border);display:flex;align-items:center;background:var(--surface-2)}.non-neg-note{font-size:.68rem;color:var(--text-3);font-style:italic}.error-box{padding:8px 12px;background:var(--err-bg);border:1px solid #fca5a5;border-radius:var(--radius-m);color:var(--err-t);font-size:.82rem;font-weight:600}.btn-solve{height:40px;padding:0 28px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-m);font-size:.85rem;font-weight:700;cursor:pointer;align-self:flex-start;display:flex;align-items:center;gap:8px;transition:all var(--transition);font-family:Inter,sans-serif;box-shadow:0 2px 8px #2563eb4d}.btn-solve:hover{background:var(--accent-h);transform:translateY(-1px)}.btn-solve:active{transform:translateY(0)}.solver-viewport{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:8px 14px 10px;gap:8px}.fo-bar{flex-shrink:0;display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border-m);border-radius:var(--radius-m);padding:7px 14px;font-size:.84rem;box-shadow:var(--shadow-s)}.fo-bar-label{font-size:.6rem;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:#fff;background:var(--primary);padding:2px 7px;border-radius:4px}.fo-bar-eq{font-family:Georgia,serif;font-style:italic;color:var(--text-2)}.fo-bar-divider{width:1px;height:18px;background:var(--border);flex-shrink:0}.fo-bar-current{font-size:.7rem;color:var(--text-3)}.fo-bar-val{font-weight:800;font-size:.92rem;color:var(--violet);font-family:JetBrains Mono,monospace}.fo-bar-opt{font-weight:800;font-size:.78rem;color:var(--ok-head)}.step-nav{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border-m);border-radius:var(--radius-m);padding:7px 14px;box-shadow:var(--shadow-s);gap:10px}.step-nav__center{display:flex;flex-direction:column;align-items:center;gap:3px}.step-nav__label{font-size:.68rem;color:var(--text-3);font-weight:600}.step-dots{display:flex;gap:5px;align-items:center}.sdot{width:9px;height:9px;border-radius:50%;border:2px solid var(--border-m);background:var(--surface);cursor:pointer;transition:all var(--transition);padding:0}.sdot--done{background:var(--ok-head);border-color:var(--ok-head)}.sdot--active{background:var(--accent);border-color:var(--accent);transform:scale(1.3)}.sdot:hover{border-color:var(--accent)}.btn-nav{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;background:var(--surface);color:var(--text-1);border:1.5px solid var(--border-m);border-radius:var(--radius-m);font-size:.75rem;font-weight:600;cursor:pointer;transition:all var(--transition);min-width:90px;justify-content:center;font-family:Inter,sans-serif;white-space:nowrap}.btn-nav:hover:not(:disabled){background:var(--primary);color:#fff;border-color:var(--primary)}.btn-nav:disabled{opacity:.3;cursor:not-allowed}.solver-layout{flex:1;display:flex;gap:12px;min-height:0}.solver-graph{flex:1;min-width:0;min-height:0}.solver-panel-wrap{width:290px;flex-shrink:0;overflow-y:auto;min-height:0}.graph-container{width:100%;height:100%;background:var(--surface);border:1px solid var(--border-m);border-radius:var(--radius-l);overflow:hidden;box-shadow:var(--shadow-s)}.slider-bar{flex-shrink:0;display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border-m);border-radius:var(--radius-m);padding:8px 14px;box-shadow:var(--shadow-s)}.slider-edge{font-size:.68rem;font-weight:700;color:var(--text-4);font-family:JetBrains Mono,monospace;white-space:nowrap;min-width:28px}.slider-wrap{flex:1;display:flex;flex-direction:column;gap:2px}.slider-hint{font-size:.62rem;color:var(--text-4);text-align:center}.aux-slider{width:100%;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:linear-gradient(90deg,var(--border) 0%,var(--violet-bg) 50%,var(--violet) 100%);border-radius:3px;outline:none;cursor:pointer}.aux-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--violet);border:2px solid #fff;cursor:grab;box-shadow:0 2px 6px #8b5cf666;transition:transform .1s}.aux-slider::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.15)}.aux-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--violet);border:2px solid #fff;cursor:grab;box-shadow:0 2px 6px #8b5cf666}.solution-panel{display:flex;flex-direction:column;gap:1px;background:var(--border);border:1px solid var(--border-m);border-radius:var(--radius-l);overflow:hidden;box-shadow:var(--shadow-s)}.sp-section{padding:12px 14px;background:var(--surface)}.sp-section--compact{padding:10px 12px}.sp-title-sm{font-size:.63rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);margin-bottom:6px}.sp-constraints{display:flex;flex-direction:column;gap:3px}.sp-con-row{display:flex;align-items:center;gap:6px;font-size:.78rem}.sp-con-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.sp-con-eq{font-family:JetBrains Mono,monospace;color:var(--text-1);font-size:.76rem}.sp-table{border-collapse:collapse;width:100%;font-size:.76rem;font-variant-numeric:tabular-nums}.sp-table th{padding:4px 6px;text-align:center;font-size:.6rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-3);border-bottom:1.5px solid var(--border-m);background:var(--surface-2)}.sp-table td{padding:4px 6px;text-align:center;border-bottom:1px solid var(--border);font-family:JetBrains Mono,monospace;font-size:.74rem}.sp-table tr:last-child td{border-bottom:none}.sp-td-label{text-align:left!important;font-weight:600;color:var(--text-2)}.sp-td-z{font-weight:700}.sp-row--active{background:var(--violet-bg)}.sp-row--active td{color:var(--violet);font-weight:700}.sp-banner{padding:10px 12px;border-radius:var(--radius-m);display:flex;flex-direction:column;gap:6px;font-size:.78rem;line-height:1.5}.sp-banner--ok{background:var(--ok-bg);border:1px solid #6ee7b7}.sp-banner--err{background:var(--err-bg);border:1px solid #fca5a5;color:var(--err-t)}.sp-banner-title{font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--ok-head)}.sp-result{display:flex;align-items:baseline;gap:5px}.sp-z-label{font-size:.8rem;color:var(--ok-t);font-weight:600;font-family:Georgia,serif;font-style:italic}.sp-z-value{font-size:1.1rem;font-weight:800;color:var(--text-1);font-family:JetBrains Mono,monospace}.sp-result-vars{display:flex;flex-wrap:wrap;gap:5px}.sp-var-pill{padding:2px 8px;background:var(--surface);border:1.5px solid var(--ok-head);border-radius:4px;color:var(--ok-t);font-size:.76rem;font-weight:700;font-family:JetBrains Mono,monospace}.sp-hint{font-size:.72rem;color:var(--text-4);font-style:italic;text-align:center}.sp-scroll{display:flex;flex-direction:column;gap:1px;background:var(--border)}.sp-scroll>.sp-section{background:var(--surface)}.sp-section--constraint{display:flex;flex-direction:column;gap:8px}.sp-con-header{display:flex;align-items:center;gap:8px;font-size:.82rem;font-weight:700;color:var(--text-1)}.sp-con-dot-lg{width:10px;height:10px;border-radius:3px;flex-shrink:0}.sp-con-title{font-family:JetBrains Mono,monospace;font-size:.78rem}.sp-calc-blocks{display:flex;flex-direction:column;gap:6px}.sp-calc-head{font-size:.7rem;font-weight:700;color:var(--text-2);margin-bottom:2px}.sp-calc-conclusion{padding:6px 10px;border-radius:var(--radius-s);border:1px solid;font-size:.76rem;color:var(--text-1);line-height:1.5}.sp-calc-conclusion strong{font-weight:800}.sp-badge{display:inline-block;align-self:flex-start;padding:2px 9px;border-radius:99px;background:var(--primary);color:#fff;font-size:.58rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;margin-bottom:2px}.sp-title{font-size:.95rem;font-weight:800;color:var(--text-1);letter-spacing:-.2px}.sp-title--err{color:var(--err-t)}.sp-calc{display:flex;flex-direction:column;gap:6px}.sp-calc-row{display:flex;align-items:baseline;gap:6px;font-size:.76rem}.sp-calc-label{font-weight:600;color:var(--text-3);font-size:.68rem;white-space:nowrap}.sp-calc-val{font-family:JetBrains Mono,monospace;color:var(--text-1)}.sp-calc-val--eq{font-weight:600}.sp-calc-val--z{font-weight:800;color:var(--violet);font-size:.88rem}.sp-calc-divider{height:1px;background:var(--border);margin:2px 0}.sp-calc-sub{font-size:.63rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);margin-top:2px}.sp-calc-step{padding:6px 8px;background:var(--surface-2);border-radius:var(--radius-s);border-left:3px solid var(--violet);display:flex;flex-direction:column;gap:2px}.sp-calc-formula{font-size:.74rem;color:var(--text-2);font-family:JetBrains Mono,monospace;line-height:1.5}.sp-calc-formula strong{color:var(--violet)}.sp-calc-point{font-size:.7rem;color:var(--violet);font-weight:700;font-family:JetBrains Mono,monospace;margin-top:1px}.sp-calc-match{padding:5px 8px;background:var(--violet-bg);border-radius:var(--radius-s);font-size:.74rem;color:var(--violet);line-height:1.5}.sp-calc-match strong{font-weight:800}.sp-con-row--note{margin-top:2px}.sp-con-eq--dim{color:var(--text-4);font-size:.7rem;font-style:italic}.sp-multi-note{font-size:.72rem;font-style:italic;color:var(--ok-t)}@media (max-width: 820px){.solver-layout{flex-direction:column}.solver-panel-wrap{width:100%;max-height:180px}.app-header{padding:0 12px}}@media (max-width: 560px){.pi-topbar{flex-direction:column;align-items:flex-start}.solver-viewport{padding:6px 8px 8px}}
