:root{--bg: #020617;--bg-card: rgba(15, 23, 42, .96);--accent: #38bdf8;--accent-soft: rgba(56, 189, 248, .15);--border-subtle: rgba(148, 163, 184, .3);--text-primary: #e5e7eb;--text-muted: #9ca3af;--danger: #f97316;--success: #22c55e}*{box-sizing:border-box}body{margin:0;height:100vh;height:100dvh;overflow:hidden;font-family:system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text-primary);display:flex;flex-direction:column;position:relative}body:before{content:"";position:fixed;inset:0;background:radial-gradient(circle at top left,#1d4ed8 0,transparent 55%),radial-gradient(circle at bottom right,#0f766e 0,transparent 55%),var(--bg);z-index:-1;pointer-events:none}@media(max-width:1024px){body{height:100vh;height:100dvh;overflow:hidden}}input[type=text]{flex:1;padding:10px 14px;background:#0f172ae6;border:1px solid var(--border-subtle);border-radius:6px;color:var(--text-primary);font-size:1rem;font-family:Courier New,monospace}input[type=text]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}button{padding:10px 20px;background:var(--accent);color:#000;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.9rem}button:hover{background:#0ea5e9;transform:translateY(-2px);box-shadow:0 4px 12px #38bdf84d}button.secondary{background:#94a3b833;color:var(--text-primary)}button.secondary:hover{background:#94a3b84d}.placeholder{color:var(--text-muted);text-align:center;padding:20px;font-style:italic;font-size:.85rem}.error-message{color:var(--danger);margin-top:8px;padding:8px;background:#f973161a;border-radius:4px;display:none;font-size:.85rem}.error-message.show{display:block}.measure-span{font:1.3rem Courier New,monospace;visibility:hidden;position:absolute;white-space:pre}.app-header{text-align:center;padding:15px 20px;background:var(--bg-card);border-bottom:1px solid var(--border-subtle);flex-shrink:0}.app-header-content{display:flex;align-items:center;justify-content:space-between;max-width:1400px;margin:0 auto}.app-header h1{margin:0;font-size:1.8rem;background:linear-gradient(135deg,#38bdf8,#22c55e);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.app-header .subtitle{color:var(--text-muted);font-size:.9rem;margin:0}.app-header .version-badge{display:inline-block;background:var(--accent-soft);color:var(--accent);padding:2px 8px;border-radius:10px;font-size:.75rem;margin-left:10px;border:1px solid var(--accent)}.app-layout{display:grid;grid-template-columns:300px 1fr 350px;grid-template-areas:"commands expression history";gap:0;height:calc(100vh - 80px);overflow:hidden}.left-panel{grid-area:commands;background:var(--bg-card);border-right:1px solid var(--border-subtle);padding:20px;overflow-y:auto;display:flex;flex-direction:column}.left-panel h3{margin:0 0 15px;color:var(--accent);font-size:1rem}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.panel-header h3{margin:0}.panel-toggle{display:none;padding:6px 12px;font-size:.8rem;border-radius:999px}.collapsible-panel.collapsed .panel-content{display:none}.commands-list{flex:1;overflow-y:auto}.center-panel{grid-area:expression;display:flex;flex-direction:column;overflow:hidden}.input-section{padding:15px 20px;background:var(--bg-card);border-bottom:1px solid var(--border-subtle);flex-shrink:0}.input-group{display:flex;gap:10px;margin-bottom:15px}.expression-section{flex:1;padding:20px;overflow-y:auto;display:flex;flex-direction:column;align-items:flex-start}.right-panel{grid-area:history;background:var(--bg-card);border-left:1px solid var(--border-subtle);display:flex;flex-direction:column;overflow:hidden}.history-section{flex:1;padding:15px;overflow-y:auto}.history-section h3{margin:0 0 12px;font-size:.95rem;color:var(--success)}@media(max-width:1024px){.app-layout{display:flex;flex-direction:column;height:calc(100vh - 60px);height:calc(100dvh - 60px);overflow:hidden}.center-panel{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;order:1}.expression-section{flex:1;min-height:0;overflow-y:auto}.right-panel{flex:0 0 auto;max-height:25vh;min-height:80px;border:none;border-top:1px solid var(--border-subtle);order:2}.history-section{flex:1;min-height:0;overflow-y:auto;padding:10px 12px}.history-section h3{font-size:.85rem;margin-bottom:8px}.left-panel{flex:0 0 auto;max-height:30vh;min-height:60px;border:none;border-top:1px solid var(--border-subtle);padding:10px 16px;overflow:hidden;display:flex;flex-direction:column;order:3}.left-panel .commands-list{flex:1;min-height:0;overflow-y:auto}.panel-toggle{display:inline-flex;align-items:center;justify-content:center}.collapsible-panel.collapsed{flex:0 0 auto;max-height:none;min-height:0}.collapsible-panel.collapsed .panel-content{display:none}}@media(max-width:640px){.app-header{padding:8px 12px}.app-header h1{font-size:1.2rem}.input-section{padding:10px 12px}.input-group{flex-direction:column;gap:8px;margin-bottom:10px}.input-group button,.input-group input[type=text]{width:100%}.expression-section{padding:12px}.expression-text{font-size:1rem;white-space:pre-wrap;word-break:break-word;padding:10px}}.expression-display{background:#0f172a99;border:1px solid var(--border-subtle);border-radius:8px;padding:20px;flex:1;display:flex;align-items:flex-start;justify-content:center}.expression-text{font-family:Courier New,monospace;font-size:1.3rem;padding:15px;background:#0f172a99;border-radius:6px;position:relative;border:2px solid var(--border-subtle);transition:border-color .2s;white-space:pre;min-width:100%}.expr-node{display:inline-block;position:relative}.expr-power{display:inline-flex;align-items:flex-start}.expr-sup{font-size:.75em;line-height:1;margin-left:2px}.expr-nth-root{display:inline-flex;align-items:flex-start}.expr-root-index{font-size:.6em;line-height:1;margin-right:2px}.expr-root-symbol{margin-right:2px}.expression-text:hover{border-color:var(--accent)}.token{display:inline-block;position:relative;cursor:help;padding:2px 1px;border-radius:3px;transition:all .2s;color:var(--token-color, currentColor)}.token:hover,.token.token-hover{transform:translateY(-2px);filter:brightness(1.5);text-shadow:0 0 1px currentColor,0 0 1px currentColor}.token.token-operator-highlight{transform:translateY(-3px) scale(1.15);filter:brightness(1.5) drop-shadow(0 0 4px currentColor);z-index:10;position:relative;box-shadow:0 0 0 1px #27ae60}.token.token-operand-left{transform:translateY(-2px);filter:brightness(1.3);text-shadow:0 0 .5px currentColor,0 0 .5px currentColor;border-radius:0;box-shadow:0 0 0 100px #ffbf0033 inset}.token.token-operand-right{transform:translateY(-2px);filter:brightness(1.3);text-shadow:0 0 .5px currentColor,0 0 .5px currentColor;border-radius:0;box-shadow:0 0 0 100px #f0e3 inset}.token-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-5px);background:#000000e6;color:#fff;padding:4px 8px;border-radius:4px;font-size:.75rem;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s;z-index:1000}.token:hover .token-tooltip{opacity:1}.token-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#000000e6}.expression-highlight{position:absolute;top:0;background:var(--accent-soft);border-radius:3px;pointer-events:none;opacity:0;transition:opacity .2s;height:1.5em;margin-top:20px;display:none}.expression-highlight.active{opacity:0}.expression-ranges{position:absolute;top:100%;left:0;right:0;height:auto;min-height:50px;pointer-events:none}.expression-range{position:absolute;height:16px;border:2px solid;border-top:none;border-radius:0 0 4px 4px;cursor:pointer;transition:all .2s;pointer-events:auto;opacity:.7;overflow:visible}.expression-range:hover{opacity:1;transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.frame-label{font-family:Courier New,monospace;font-size:.65rem;color:inherit;white-space:nowrap;padding:0 4px;opacity:.8;pointer-events:none;bottom:2px;position:absolute}.frame-label-left{text-align:left}.frame-label-center{left:0;width:auto;text-align:center}.frame-label-container{position:absolute;bottom:2px;left:0;width:100%;height:auto;pointer-events:none}.expression-range:hover .frame-label{opacity:1;font-weight:700}.expression-range.active{opacity:1;border-width:3px}.expression-range.level-0{border-color:#3498db}.expression-range.level-1{border-color:#9b59b6}.expression-range.level-2{border-color:#27ae60}.expression-range.level-3{border-color:#e67e22}.expression-range.level-4{border-color:#e74c3c}.expression-range.level-5{border-color:#1abc9c}.expression-range.level-6{border-color:#f39c12}.expression-range.level-7{border-color:#95a5a6}.command-item{padding:10px;background:#94a3b80d;border:1px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s;margin-bottom:6px}.command-item:hover{background:var(--accent-soft);border-color:var(--accent);transform:translate(4px)}.command-name{font-weight:600;margin-bottom:3px;font-size:.9rem}.command-preview{font-size:.8rem;color:var(--text-muted);font-family:Courier New,monospace}.command-description{font-size:.78rem;color:var(--text-muted);margin-bottom:6px}.command-assumptions{margin-top:6px;display:flex;flex-direction:column;gap:4px;font-size:.75rem;color:var(--text-muted)}.command-assumption{display:flex;align-items:center;gap:6px}.command-selection{background:var(--accent-soft);border:1px solid var(--accent);border-radius:6px;padding:8px 12px;margin-bottom:15px;color:var(--accent);font-family:Courier New,monospace;word-break:break-all}.command-preview mark.preview-changed{background:#22c55e4d;color:var(--success);padding:1px 2px;border-radius:2px;font-weight:600}.command-preview mark.preview-deleted{background:#ef44444d;color:#ef4444;padding:1px 4px;border-radius:2px;font-size:.7em}.command-category-first{margin-top:0;border-top:none}.history-item{padding:10px;background:#94a3b80d;border-left:3px solid var(--accent);border-radius:4px;margin-bottom:8px;cursor:pointer;transition:all .2s}.history-item:hover{background:var(--accent-soft);transform:translate(4px)}.history-item.active{background:var(--accent-soft);border-left-color:var(--success)}.history-expression{font-family:Courier New,monospace;margin-bottom:4px;font-weight:600;font-size:.9rem}.history-rule{font-size:.8rem;color:var(--text-muted)}.history-assumptions{font-size:.75rem;color:var(--text-muted);margin-top:4px}.utility-menu{position:relative;display:flex;align-items:center}.utility-menu-button{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#94a3b826;border:1px solid var(--border-subtle);border-radius:8px;color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:all .2s}.utility-menu-button:hover{background:#94a3b840;border-color:var(--accent)}.utility-menu-button.active{background:var(--accent-soft);border-color:var(--accent)}.utility-menu-icon{font-size:1rem}.utility-menu-arrow{font-size:.7rem;opacity:.7;transition:transform .2s}.utility-menu-button.active .utility-menu-arrow{transform:rotate(180deg)}.utility-menu-dropdown{position:absolute;top:100%;right:0;margin-top:6px;min-width:200px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:8px;box-shadow:0 10px 30px #0006;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s;z-index:1000}.utility-menu-dropdown.visible{opacity:1;visibility:visible;transform:translateY(0)}.utility-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;background:none;border:none;color:var(--text-primary);font-size:.9rem;text-align:left;cursor:pointer;transition:all .15s}.utility-menu-item:first-child{border-radius:7px 7px 0 0}.utility-menu-item:last-child{border-radius:0 0 7px 7px}.utility-menu-item:hover{background:var(--accent-soft);color:var(--accent)}.utility-item-icon{font-size:1.1rem}.floating-panel{position:fixed;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:12px;box-shadow:0 20px 50px #00000080;opacity:0;visibility:hidden;transform:translateY(-15px) scale(.95);transition:all .25s cubic-bezier(.4,0,.2,1);z-index:1001;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.floating-panel.visible{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.floating-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:#94a3b814;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.floating-panel-header h4{margin:0;font-size:1rem;font-weight:600;color:var(--accent)}.floating-panel-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:#94a3b81a;border:none;border-radius:6px;color:var(--text-muted);font-size:1.2rem;cursor:pointer;transition:all .15s}.floating-panel-close:hover{background:#ef444433;color:#ef4444}.floating-panel-content{padding:18px;overflow-y:auto;flex:1}.tool-input-group{margin-bottom:16px}.tool-input-group label{display:block;margin-bottom:8px;font-size:.85rem;color:var(--text-muted);font-weight:500}.tool-input-row{display:flex;gap:10px;align-items:center}.tool-input-row input[type=text]{flex:1;min-width:0}.tool-calculate-btn{flex-shrink:0;padding:10px 16px;white-space:nowrap}.fraction-input-row{display:flex;gap:8px;align-items:center}.fraction-visual-input{display:flex;align-items:center;gap:12px;margin-bottom:12px}.fraction-whole{width:70px!important;flex:0 0 auto!important;text-align:center;font-size:1.3rem!important;padding:12px 8px!important}.fraction-vertical{display:flex;flex-direction:column;align-items:center;gap:4px}.fraction-vertical .fraction-numerator,.fraction-vertical .fraction-denominator{width:100px!important;text-align:center;padding:8px!important;font-size:1rem!important}.fraction-line{width:100%;height:3px;background:var(--accent);min-width:100px;border-radius:2px;margin:2px 0}.fraction-convert-btn{width:100%}.fraction-numerator,.fraction-denominator{width:90px!important;flex:0 0 auto!important;text-align:center}.fraction-divider{font-size:1.4rem;color:var(--text-muted);font-weight:300}.tool-error{padding:10px 12px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:6px;color:#ef4444;font-size:.85rem;margin-bottom:14px;display:none}.tool-error.visible{display:block}.tool-result{display:flex;flex-direction:column;gap:12px}.result-section{background:#94a3b80f;border-radius:8px;padding:12px 14px}.result-label{font-size:.78rem;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.3px}.result-value{font-family:Courier New,monospace;font-size:1.05rem;color:var(--text-primary);word-break:break-word}.result-prime{color:var(--accent);font-weight:600}.result-decimal{color:var(--success)}.result-simplified{color:var(--accent)}.result-mixed{color:#a78bfa}.result-pairs,.result-divisors{font-size:.9rem;line-height:1.5}.result-note{font-size:.8rem;color:var(--text-muted);padding:8px 12px;background:#94a3b80f;border-radius:6px;border-left:3px solid var(--accent)}.tool-hint{font-size:.75rem;color:var(--text-muted);margin-top:6px}.result-lcm{color:var(--success);font-weight:600;font-size:1.1rem}.result-lcm-main{background:#22c55e14;border:1px solid rgba(34,197,94,.2)}.result-gcd{color:var(--text-muted);font-size:.9rem}.multiplier-row{padding:4px 0;border-bottom:1px solid rgba(148,163,184,.1)}.multiplier-row:last-child{border-bottom:none}.multiplier-value{color:var(--accent);font-weight:600}@media(max-width:640px){.floating-panel{left:10px!important;right:10px!important;width:auto!important;max-width:none}.fraction-input-row{flex-wrap:wrap}.fraction-numerator,.fraction-denominator{width:70px!important}.tool-input-row{flex-wrap:wrap}.tool-input-row input[type=text]{width:100%;flex:1 1 100%}.tool-input-row .tool-calculate-btn,.fraction-input-row .tool-calculate-btn{width:100%;margin-top:8px}}
