*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f1117;--bg2: #181c27;--bg3: #1e2333;--border: #2e3347;--text: #e8eaf0;--text2: #9ba3bf;--accent: #6c8fff;--accent-hover: #849fff;--accent2: #a78bfa;--success: #34d399;--error: #f87171;--warning: #fbbf24;--radius: 10px;--radius-sm: 6px;--shadow: 0 4px 24px rgba(0,0,0,.4);font-size:15px}body{background:var(--bg);color:var(--text);font-family:Segoe UI,Hiragino Sans,Meiryo,system-ui,sans-serif;line-height:1.6;min-height:100vh}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{background:linear-gradient(135deg,#1a1f35,#0f1117);border-bottom:1px solid var(--border);padding:16px 24px;position:sticky;top:0;z-index:100}.header-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;gap:16px}.app-title{font-size:1.5rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:10px}.title-icon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:10px;font-size:1.2rem;color:#fff}.app-subtitle{color:var(--text2);font-size:.85rem;margin-left:auto}.app-body{display:flex;flex:1;max-width:1400px;margin:0 auto;width:100%;gap:0}.sidebar{width:220px;flex-shrink:0;border-right:1px solid var(--border);padding:20px 0;position:sticky;top:73px;height:calc(100vh - 73px);overflow-y:auto;background:var(--bg2)}.sidebar-category{margin-bottom:8px}.sidebar-cat-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text2);padding:8px 16px 4px}.sidebar-item{display:flex;flex-direction:column;gap:2px;width:100%;padding:10px 16px;background:none;border:none;border-left:3px solid transparent;text-align:left;cursor:pointer;transition:all .15s;color:var(--text)}.sidebar-item:hover{background:#6c8fff14;border-left-color:var(--border)}.sidebar-item.active{background:#6c8fff26;border-left-color:var(--accent)}.sidebar-item.wip{opacity:.38;cursor:not-allowed}.sidebar-item.wip:hover{background:transparent;border-left-color:transparent}.sidebar-item-label{font-size:.9rem;font-weight:600}.sidebar-item-desc{font-size:.75rem;color:var(--text2)}.main-content{flex:1;padding:28px 32px;min-width:0}.mode-header{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.mode-title{font-size:1.4rem;font-weight:700;color:var(--text)}.mode-desc{font-size:.85rem;color:var(--text2);margin-top:4px}.calc-form{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:20px}.form-preview{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;text-align:center;margin-bottom:20px;min-height:60px;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.form-fields{display:flex;flex-direction:column;gap:14px;margin-bottom:18px}.field-group{display:flex;flex-direction:column;gap:6px}.field-group--inline{flex-direction:row;align-items:center;gap:12px}.field-label{font-size:.85rem;color:var(--text2);font-weight:500;white-space:nowrap;min-width:140px}.field-input{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:8px 12px;font-size:.95rem;outline:none;transition:border-color .15s;width:100%}.field-input--sm{max-width:120px;width:120px}.field-input--wide{max-width:100%}.field-input:focus{border-color:var(--accent)}.field-input::placeholder{color:var(--text2);opacity:.6}.field-hint{font-size:.75rem;color:var(--text2);margin-top:2px}.field-select{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:8px 12px;font-size:.9rem;outline:none;cursor:pointer;transition:border-color .15s}.field-select:focus{border-color:var(--accent)}.mode-toggle{display:flex;gap:6px;margin-bottom:18px;padding:4px;background:var(--bg3);border-radius:var(--radius-sm);width:fit-content}.toggle-btn{padding:6px 16px;border:none;border-radius:calc(var(--radius-sm) - 2px);background:none;color:var(--text2);font-size:.87rem;cursor:pointer;transition:all .15s;font-weight:500}.toggle-btn.active{background:var(--accent);color:#fff}.examples{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:14px}.examples-label{font-size:.8rem;color:var(--text2);font-weight:600}.example-btn{padding:4px 12px;border:1px solid var(--border);border-radius:20px;background:none;color:var(--text2);font-size:.8rem;cursor:pointer;transition:all .15s;font-family:Courier New,monospace}.example-btn:hover{border-color:var(--accent);color:var(--accent);background:#6c8fff14}.form-actions{display:flex;gap:10px}.btn-primary{padding:10px 28px;background:linear-gradient(135deg,var(--accent),var(--accent2));border:none;border-radius:var(--radius-sm);color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-cancel{padding:8px 20px;background:none;border:1px solid var(--error);border-radius:var(--radius-sm);color:var(--error);font-size:.87rem;cursor:pointer;transition:all .15s}.btn-cancel:hover{background:#f871711a}.computing-bar{display:flex;align-items:center;gap:12px;padding:14px 18px;background:#6c8fff14;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.error-box{display:flex;gap:14px;padding:16px 20px;background:#f8717114;border:1px solid rgba(248,113,113,.3);border-radius:var(--radius);margin-bottom:16px}.error-icon{font-size:1.3rem}.error-box strong{display:block;color:var(--error);margin-bottom:4px}.error-box p{font-size:.9rem;color:var(--text2)}.result-panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.tab-bar{display:flex;border-bottom:1px solid var(--border);background:var(--bg3)}.tab-btn{padding:12px 20px;border:none;background:none;color:var(--text2);font-size:.87rem;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;display:flex;align-items:center;gap:6px;font-weight:500}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-badge{background:var(--accent);color:#fff;border-radius:10px;padding:1px 6px;font-size:.72rem;font-weight:700}.tab-content{padding:24px;min-height:120px}.answer-box{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:24px 20px;text-align:center;font-size:1.1rem}.steps-list{list-style:none;display:flex;flex-direction:column;gap:0;counter-reset:step}.step-item{counter-increment:step;display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--border)}.step-item:last-child{border-bottom:none}.step-item:before{content:counter(step);display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--bg3);border:1px solid var(--border);border-radius:50%;font-size:.75rem;color:var(--text2);flex-shrink:0;margin-top:2px}.verify-badge{display:inline-block;padding:4px 14px;border-radius:20px;font-size:.85rem;font-weight:700;margin-bottom:16px}.verify-badge.ok{background:#34d39926;color:var(--success);border:1px solid rgba(52,211,153,.3)}.verify-badge.ng{background:#f8717126;color:var(--error);border:1px solid rgba(248,113,113,.3)}.verify-item{padding:12px 0;border-bottom:1px solid var(--border)}.verify-item:last-child{border-bottom:none}.alt-item{padding:14px 0;border-bottom:1px solid var(--border)}.alt-item:last-child{border-bottom:none}.alt-label{display:inline-block;background:#a78bfa26;color:var(--accent2);border-radius:4px;padding:2px 8px;font-size:.78rem;font-weight:600;margin-bottom:8px}.empty-msg{color:var(--text2);font-size:.9rem}.katex-block{overflow-x:auto;padding:4px 0}.katex-display{margin:0!important}.matrix-form{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.matrix-header{display:flex;gap:12px;padding:0 80px;font-size:.8rem;color:var(--text2);font-weight:600}.matrix-var{min-width:80px;text-align:center}.matrix-row{display:flex;align-items:center;gap:8px}.matrix-eq-num{font-size:.8rem;color:var(--text2);min-width:72px}.matrix-cell-group{display:flex;align-items:center;gap:6px}.matrix-input{width:70px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:6px 8px;font-size:.9rem;outline:none;text-align:center}.matrix-input:focus{border-color:var(--accent)}.matrix-eq{font-size:1.1rem;color:var(--text2);margin:0 4px}.coeffs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}.coeff-label{min-width:120px}.integral-bounds{display:flex;gap:20px;flex-wrap:wrap;margin-top:8px;padding-top:14px;border-top:1px solid var(--border)}.radio-group{display:flex;flex-direction:column;gap:8px}.radio-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.9rem;color:var(--text)}.radio-label input[type=radio]{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}@media (max-width: 768px){.app-body{flex-direction:column}.sidebar{display:flex;flex-direction:row;width:100%;height:auto;position:static;overflow-x:auto;overflow-y:hidden;padding:0;border-right:none;border-bottom:1px solid var(--border);scrollbar-width:none}.sidebar::-webkit-scrollbar{display:none}.sidebar-category{display:flex;flex-direction:row;align-items:stretch;flex-shrink:0;margin-bottom:0}.sidebar-cat-label{display:none}.sidebar-item{flex-direction:row;align-items:center;padding:10px 16px;white-space:nowrap;border-left:none;border-bottom:3px solid transparent;width:auto;flex-shrink:0}.sidebar-item:hover{background:#6c8fff14;border-left-color:transparent;border-bottom-color:var(--border)}.sidebar-item.active{border-left-color:transparent;border-bottom-color:var(--accent)}.sidebar-item.wip:hover{border-bottom-color:transparent}.sidebar-item-desc{display:none}.sidebar-item-label{font-size:.88rem}.main-content{padding:16px;min-width:0}.app-subtitle{display:none}.tab-bar{overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none}.tab-bar::-webkit-scrollbar{display:none}.tab-btn{white-space:nowrap;flex-shrink:0;padding:10px 14px;font-size:.82rem}.tab-content{padding:16px;overflow-x:hidden}.step-item{min-width:0}.verify-item,.alt-item{overflow-x:auto}.graph-wrap{flex-direction:column}.graph-info{width:100%}}.graph-tab{padding:4px 0}.graph-wrap{display:flex;flex-direction:row;align-items:flex-start;gap:20px;flex-wrap:wrap}.graph-plot-area{display:flex;flex-direction:column;gap:12px;flex:1;min-width:280px}.graph-svg{display:block;width:100%;max-width:480px;height:auto;overflow:visible}.graph-info{width:310px;flex-shrink:0;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.graph-info-section{padding:12px 14px;border-bottom:1px solid var(--border);overflow-x:auto}.graph-info-section:last-child{border-bottom:none}.graph-info-heading{font-size:.72rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px}.graph-info-line{margin-bottom:4px}.graph-info-line:last-child{margin-bottom:0}.graph-axis-label{fill:var(--text2);font-size:12px;font-style:italic;font-weight:600}.graph-controls{display:flex;align-items:center;flex-wrap:wrap;gap:10px}.graph-ctrl-group{display:flex;align-items:center;gap:4px}.graph-ctrl-label{font-size:.78rem;color:var(--text2);margin-right:2px}.graph-ctrl-btn{padding:4px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg3);color:var(--text);font-size:.82rem;cursor:pointer;transition:all .15s;white-space:nowrap}.graph-ctrl-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:#6c8fff14}.graph-ctrl-btn:disabled,.graph-ctrl-btn.disabled{opacity:.35;cursor:default}.graph-ctrl-toggle.active{background:#6c8fff33;border-color:var(--accent);color:var(--accent)}.graph-bg{fill:var(--bg3)}.graph-grid{stroke:var(--border);stroke-width:.5}.graph-axis{stroke:var(--text2);stroke-width:1.5}.graph-symm{stroke:var(--accent2);stroke-width:1.2;stroke-dasharray:5 4;opacity:.55}.graph-curve{stroke:var(--accent);stroke-width:2.5;fill:none;stroke-linejoin:round;stroke-linecap:round}.graph-ref-curve{stroke:var(--warning);stroke-width:1.5;fill:none;stroke-dasharray:6 3;opacity:.75}.graph-ref-label{fill:var(--warning);font-size:11px;font-weight:600;font-family:Segoe UI,system-ui,sans-serif;opacity:.85}.graph-root{fill:var(--success);stroke:var(--bg2);stroke-width:1.5}.graph-vertex{fill:var(--accent2);stroke:var(--bg2);stroke-width:1.5}.graph-tick{fill:var(--text2);font-size:10px;font-family:Courier New,monospace}.graph-tick-x{text-anchor:middle}.graph-tick-y{text-anchor:end}.graph-label{font-size:11px;font-family:Segoe UI,system-ui,sans-serif;font-weight:600}.graph-root-label{fill:var(--success);text-anchor:middle}.graph-vertex-label{fill:var(--accent2)}.graph-curve-label{fill:var(--accent);opacity:.85}.graph-border{stroke:var(--border);stroke-width:1}.graph-legend{display:flex;flex-wrap:wrap;gap:14px;font-size:.8rem;color:var(--text2)}.graph-legend-item{display:flex;align-items:center;gap:5px}.graph-legend-root{color:var(--success)}.graph-legend-vertex{color:var(--accent2)}.graph-legend-symm{opacity:.7}.graph-legend-ref{color:var(--warning)}.graph-legend-note{color:var(--text2);font-style:italic}.mode-title-row{display:flex;align-items:center;gap:10px}.guide-btn{display:inline-flex;align-items:center;padding:6px 14px;min-height:36px;border-radius:20px;border:1.5px solid var(--accent);background:none;color:var(--accent);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s;flex-shrink:0;white-space:nowrap}.guide-btn:hover{background:#6c8fff26}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:500;display:flex;align-items:center;justify-content:center;padding:20px}.modal-box{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);width:100%;max-width:600px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-title{font-size:1.05rem;font-weight:700;color:var(--text)}.modal-close{width:28px;height:28px;border:none;background:none;color:var(--text2);font-size:1.1rem;cursor:pointer;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all .15s}.modal-close:hover{background:#f8717126;color:var(--error)}.modal-body{overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:0}.guide-section{padding:16px 0;border-bottom:1px solid var(--border)}.guide-section:last-child{border-bottom:none}.guide-heading{font-size:.9rem;font-weight:700;color:var(--accent);margin-bottom:10px;letter-spacing:.02em}.guide-text{font-size:.87rem;color:var(--text2);margin-top:8px;line-height:1.7}.guide-note{font-size:.82rem;color:var(--text2);margin-top:10px;margin-bottom:6px;padding-left:10px;border-left:2px solid var(--border)}.guide-list{list-style:none;display:flex;flex-direction:column;gap:8px;margin:10px 0}.guide-list li{display:flex;align-items:center;gap:10px;font-size:.87rem;color:var(--text)}.guide-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:.8rem;font-weight:700;white-space:nowrap;min-width:60px;text-align:center}.guide-badge.pos{background:#34d39926;color:var(--success);border:1px solid rgba(52,211,153,.3)}.guide-badge.zero{background:#fbbf2426;color:var(--warning);border:1px solid rgba(251,191,36,.3)}.guide-badge.neg{background:#f8717126;color:var(--error);border:1px solid rgba(248,113,113,.3)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text2)}
