@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&display=swap";:root{--bg-primary:#0d1117;--bg-secondary:#151b23;--bg-tertiary:#1c2333;--bg-input:#0a0e14;--bg-surface:#131921;--border:#252d38;--border-subtle:#1e2530;--border-focus:#f59e0b;--text-primary:#e2e8f0;--text-secondary:#8b949e;--text-muted:#5c6370;--text-dim:#3e4452;--accent:#f59e0b;--accent-dim:#f59e0b1f;--accent-glow:#f59e0b40;--accent-hover:#d97706;--accent-bright:#fbbf24;--match-primary:#f59e0b4d;--match-primary-border:#f59e0b99;--match-alt-1:#fbbf2440;--match-alt-2:#d9770640;--success:#22c55e;--success-dim:#22c55e1f;--success-border:#22c55e59;--error:#ef4444;--error-dim:#ef44441a;--error-border:#ef444459;--warning:#eab308;--syn-keyword:#c678dd;--syn-string:#98c379;--syn-number:#d19a66;--syn-comment:#5c6370;--syn-function:#61afef;--syn-operator:#56b6c2;--font-mono:"JetBrains Mono", "SF Mono", "Cascadia Code", "Fira Code", "Consolas", "Monaco", monospace;--radius:4px;--radius-md:6px;--radius-lg:8px;--header-height:44px;--resize-handle:6px;font-family:var(--font-mono);color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.5}*,:before,:after{box-sizing:border-box}body{background:var(--bg-primary);margin:0}#root{min-height:100vh}h1,h2,h3,h4,h5{color:var(--text-primary);font-family:var(--font-mono);margin:0;font-weight:600}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-bright)}code,pre{font-family:var(--font-mono);font-size:.9em}::selection{background:var(--accent-glow);color:var(--text-primary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes matchPulse{0%{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 8px 2px var(--accent-glow)}to{box-shadow:0 0 0 0 var(--accent-glow)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes cursorBlink{0%,50%{opacity:1}51%,to{opacity:0}}@keyframes copySuccess{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.loading{min-height:100vh;color:var(--text-muted);font-size:.9rem;font-family:var(--font-mono);justify-content:center;align-items:center;display:flex}.loading:after{content:"...";animation:1s infinite cursorBlink}.landing-page{background:var(--bg-primary);flex-direction:column;min-height:100vh;display:flex}.landing-header{border-bottom:1px solid var(--border);background:var(--bg-secondary)}.landing-nav{max-width:1100px;height:var(--header-height);justify-content:space-between;align-items:center;margin:0 auto;padding:0 24px;display:flex}.logo{font-family:var(--font-mono);color:var(--accent);letter-spacing:-.5px;align-items:center;gap:8px;font-size:1rem;font-weight:700;text-decoration:none;display:flex}.logo:hover{color:var(--accent-bright);text-decoration:none}.logo-slash{color:var(--text-muted);font-weight:400}.nav-link{font-size:.8rem;font-family:var(--font-mono);border:1px solid var(--accent);border-radius:var(--radius);color:var(--accent);padding:6px 16px;transition:all .15s}.nav-link:hover{background:var(--accent);color:var(--bg-primary);text-decoration:none}.hero{text-align:center;max-width:780px;margin:0 auto;padding:72px 24px 48px}.hero-title{letter-spacing:-1px;font-size:2.5rem;font-weight:700;line-height:1.2;font-family:var(--font-mono);margin-bottom:16px}.hero-accent{color:var(--accent);text-shadow:0 0 40px var(--accent-glow)}.hero-subtitle{color:var(--text-secondary);max-width:560px;margin-bottom:40px;margin-left:auto;margin-right:auto;font-size:.95rem;line-height:1.7}.hero-demo{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:left;box-shadow:0 4px 24px #0000004d, 0 0 0 1px var(--border-subtle);margin-bottom:32px;overflow:hidden}.demo-titlebar{background:var(--bg-tertiary);border-bottom:1px solid var(--border);color:var(--text-muted);align-items:center;gap:8px;padding:10px 16px;font-size:.75rem;display:flex}.demo-dots{gap:6px;display:flex}.demo-dot{background:var(--border);border-radius:50%;width:10px;height:10px}.demo-dot.red{background:#ff5f57}.demo-dot.yellow{background:#febc2e}.demo-dot.green{background:#28c840}.demo-body{padding:16px 20px}.demo-input-row{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:0;margin-bottom:12px;padding:0 12px;transition:border-color .15s;display:flex}.demo-input-row:focus-within{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-dim)}.regex-delimiter{font-family:var(--font-mono);color:var(--accent);-webkit-user-select:none;user-select:none;font-size:1.1rem;font-weight:600}.demo-pattern-input{font-family:var(--font-mono);color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;padding:10px 8px;font-size:.95rem}.demo-flags-input{width:32px;font-family:var(--font-mono);color:var(--accent);text-align:center;background:0 0;border:none;outline:none;font-size:.85rem}.demo-result{margin-bottom:8px}.demo-text{font-family:var(--font-mono);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);white-space:pre-wrap;word-break:break-word;padding:12px 16px;font-size:.85rem;line-height:2}.demo-text-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);width:100%;font-family:var(--font-mono);color:var(--text-primary);resize:vertical;outline:none;margin-top:8px;padding:10px 12px;font-size:.85rem;transition:border-color .15s}.demo-text-input:focus{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-dim)}.demo-match-count{color:var(--accent);font-size:.8rem;font-family:var(--font-mono);align-items:center;gap:6px;margin-top:8px;display:flex}.demo-match-count:before{content:"";background:var(--accent);border-radius:50%;width:6px;height:6px;display:inline-block}.cta-button{background:var(--accent);color:var(--bg-primary);font-size:.9rem;font-weight:700;font-family:var(--font-mono);border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:8px;padding:12px 32px;text-decoration:none;transition:all .15s;display:inline-flex}.cta-button:hover{background:var(--accent-hover);text-decoration:none;transform:translateY(-1px);box-shadow:0 4px 16px #f59e0b40}.cta-arrow{font-size:1.1em;transition:transform .15s}.cta-button:hover .cta-arrow{transform:translate(2px)}.features{max-width:1000px;margin:0 auto;padding:64px 24px 80px}.features-title{text-align:center;color:var(--text-primary);margin-bottom:12px;font-size:1.3rem}.features-subtitle{text-align:center;color:var(--text-muted);margin-bottom:40px;font-size:.85rem}.feature-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;display:grid}.feature-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px;transition:all .2s}.feature-card:hover{border-color:var(--accent);box-shadow:0 0 16px var(--accent-dim);transform:translateY(-2px)}.feature-icon{font-family:var(--font-mono);color:var(--accent);background:var(--accent-dim);border-radius:var(--radius);border:1px solid #f59e0b33;justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:12px;font-size:.85rem;font-weight:700;display:flex}.feature-card h3{margin-bottom:8px;font-size:.95rem;font-weight:600}.feature-card p{color:var(--text-secondary);margin:0;font-size:.8rem;line-height:1.6}.landing-footer{border-top:1px solid var(--border);text-align:center;color:var(--text-dim);margin-top:auto;padding:20px 24px;font-size:.75rem}.landing-footer p{margin:0}.app-page{background:var(--bg-primary);flex-direction:column;min-height:100vh;display:flex}.app-header{height:var(--header-height);border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0;align-items:center;gap:12px;padding:0 16px;display:flex}.app-header-subtitle{color:var(--text-dim);font-size:.75rem;font-family:var(--font-mono)}.app-header-separator{background:var(--border);width:1px;height:16px}.app-header-status{color:var(--text-muted);font-size:.75rem;font-family:var(--font-mono);align-items:center;gap:6px;margin-left:auto;display:flex}.status-dot{background:var(--success);border-radius:50%;width:6px;height:6px}.app-layout{flex-direction:column;flex:1;display:flex;overflow:hidden}.app-top-pane{border-bottom:1px solid var(--border);min-height:320px;display:flex;position:relative}.pane{flex:1;padding:16px;overflow-y:auto}.pane-left{border-right:1px solid var(--border);position:relative}.pane-left:after{content:"";width:var(--resize-handle);cursor:col-resize;z-index:10;height:100%;position:absolute;top:0;right:-3px}.pane-left:after:hover{background:var(--accent-dim)}.pane-title{text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);align-items:center;gap:8px;margin-bottom:14px;font-size:.7rem;font-weight:600;display:flex}.pane-title:before{content:"";background:var(--accent);border-radius:2px;width:3px;height:12px}.app-bottom-pane{flex-direction:column;flex:1;min-height:280px;display:flex}.tab-bar{border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0;display:flex}.tab-btn{color:var(--text-muted);font-size:.8rem;font-family:var(--font-mono);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 20px;transition:all .15s;position:relative}.tab-btn:hover{color:var(--text-secondary);background:var(--bg-tertiary)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent);background:var(--bg-primary)}.tab-content{flex:1;padding:16px;overflow-y:auto}.regex-builder{flex-direction:column;gap:16px;display:flex}.builder-input-row{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:0;padding:0 12px;transition:all .15s;display:flex}.builder-input-row:focus-within{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-dim), 0 0 16px var(--accent-dim)}.regex-input{font-family:var(--font-mono);color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;padding:10px 8px;font-size:1rem}.regex-input::placeholder{color:var(--text-dim)}.regex-input-error{border-color:var(--error)!important;box-shadow:0 0 0 1px var(--error-dim)!important}.regex-flags-display{font-family:var(--font-mono);color:var(--accent);min-width:28px;font-size:.95rem;font-weight:600}.regex-error{color:var(--error);font-size:.8rem;font-family:var(--font-mono);background:var(--error-dim);border:1px solid var(--error-border);border-radius:var(--radius);padding:8px 12px;animation:.15s slideDown}.builder-flags{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.builder-label{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);font-size:.7rem;font-weight:600;font-family:var(--font-mono)}.flag-toggle{cursor:pointer;align-items:center;gap:4px;font-size:.8rem;display:flex}.flag-toggle input[type=checkbox]{accent-color:var(--accent);width:14px;height:14px}.flag-label{font-family:var(--font-mono);color:var(--accent);font-size:.85rem;font-weight:700}.flag-desc{color:var(--text-muted);font-size:.75rem}.builder-section{flex-direction:column;gap:6px;display:flex}.snippet-buttons{flex-wrap:wrap;gap:4px;display:flex}.snippet-btn{font-family:var(--font-mono);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;padding:4px 8px;font-size:.8rem;font-weight:500;transition:all .12s}.snippet-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);transform:translateY(-1px)}.snippet-btn:active{transform:translateY(0)}.match-tester{flex-direction:column;gap:12px;display:flex}.tester-header{justify-content:space-between;align-items:center;display:flex}.tester-header h3{color:var(--text-secondary);font-size:.85rem;font-weight:500}.match-count{font-family:var(--font-mono);color:var(--accent);background:var(--accent-dim);border:1px solid #f59e0b33;border-radius:12px;padding:3px 10px;font-size:.75rem;font-weight:600;animation:.2s fadeIn}.tester-area,.tester-input-wrapper{position:relative}.tester-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);width:100%;min-height:140px;font-family:var(--font-mono);color:var(--text-primary);resize:vertical;outline:none;padding:12px;font-size:.85rem;line-height:1.8;transition:border-color .15s}.tester-input::placeholder{color:var(--text-dim)}.tester-input:focus{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-dim)}.tester-highlight-overlay{font-family:var(--font-mono);white-space:pre-wrap;word-break:break-word;pointer-events:none;color:#0000;padding:12px;font-size:.85rem;line-height:1.8;position:absolute;top:1px;left:1px;right:1px}.match-highlight{color:var(--text-primary);background:var(--match-primary);box-shadow:0 0 6px var(--accent-glow);border-bottom:2px solid var(--accent);border-radius:2px;animation:.2s fadeIn}.match-details{border-top:1px solid var(--border);padding-top:12px;animation:.2s fadeIn}.match-details h4{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;font-size:.7rem;font-weight:600}.match-list{flex-direction:column;gap:3px;max-height:200px;display:flex;overflow-y:auto}.match-item{border-radius:var(--radius);background:var(--bg-tertiary);border:1px solid #0000;align-items:center;gap:10px;padding:4px 8px;font-size:.8rem;transition:border-color .1s;display:flex}.match-item:hover{border-color:var(--border)}.match-index{color:var(--text-dim);font-family:var(--font-mono);min-width:28px;font-size:.75rem}.match-value{font-family:var(--font-mono);color:var(--accent);background:var(--accent-dim);border-radius:3px;padding:1px 6px;font-weight:500}.match-position{color:var(--text-dim);font-size:.75rem}.match-groups{color:var(--text-secondary);font-size:.75rem}.group-value{background:var(--bg-secondary);color:var(--syn-string);border-radius:2px;margin-left:4px;padding:1px 5px}.match-overflow{color:var(--text-dim);font-size:.75rem;font-style:italic}.pattern-library{flex-direction:column;gap:14px;display:flex}.library-search{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:360px;font-size:.8rem;font-family:var(--font-mono);color:var(--text-primary);outline:none;padding:8px 12px;transition:border-color .15s}.library-search::placeholder{color:var(--text-dim)}.library-search:focus{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-dim)}.category-tabs{flex-wrap:wrap;gap:4px;display:flex}.category-tab{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:.7rem;font-family:var(--font-mono);cursor:pointer;background:0 0;padding:3px 10px;font-weight:500;transition:all .12s}.category-tab:hover{border-color:var(--accent);color:var(--text-secondary)}.category-tab.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent);font-weight:600}.pattern-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;display:grid}.pattern-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);flex-direction:column;gap:6px;padding:14px;transition:all .15s;display:flex}.pattern-card:hover{border-color:var(--accent);box-shadow:0 0 12px var(--accent-dim)}.pattern-card-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.pattern-card-header h4{font-size:.85rem;font-weight:600}.pattern-category-badge{border-radius:var(--radius);background:var(--accent-dim);color:var(--accent);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;padding:2px 6px;font-size:.6rem;font-weight:600}.pattern-desc{color:var(--text-muted);margin:0;font-size:.75rem;line-height:1.4}.pattern-regex{font-family:var(--font-mono);color:var(--accent);background:var(--bg-input);border-radius:var(--radius);border:1px solid var(--border);word-break:break-all;padding:6px 10px;font-size:.75rem;line-height:1.4;overflow-x:auto}.pattern-example{color:var(--text-dim);font-size:.7rem}.example-label{color:var(--text-muted);font-weight:600}.pattern-example code{color:var(--syn-string)}.pattern-actions{gap:6px;margin-top:4px;display:flex}.action-btn{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-tertiary);color:var(--text-secondary);font-size:.75rem;font-family:var(--font-mono);cursor:pointer;padding:5px 12px;font-weight:500;transition:all .12s}.action-btn:hover{border-color:var(--accent);color:var(--text-primary)}.action-btn.primary{background:var(--accent);color:var(--bg-primary);border-color:var(--accent);font-weight:700}.action-btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.action-btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.action-btn.copied{background:var(--success);border-color:var(--success);color:var(--bg-primary);animation:.2s copySuccess}.test-suite{flex-direction:column;gap:14px;display:flex}.suite-header{justify-content:space-between;align-items:center;display:flex}.suite-header h3{font-size:.9rem;font-weight:600}.suite-actions{gap:6px;display:flex}.suite-summary{border-radius:var(--radius);font-family:var(--font-mono);gap:16px;padding:8px 14px;font-size:.8rem;animation:.2s slideDown;display:flex}.suite-summary.all-passed{background:var(--success-dim);border:1px solid var(--success-border)}.suite-summary.has-failures{background:var(--error-dim);border:1px solid var(--error-border)}.summary-total{color:var(--text-secondary)}.summary-passed{color:var(--success);font-weight:600}.summary-failed{color:var(--error);font-weight:600}.test-cases{flex-direction:column;gap:8px;display:flex}.test-case{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;transition:all .15s;animation:.2s fadeIn}.test-case.test-passed{border-color:var(--success-border);border-left:3px solid var(--success)}.test-case.test-failed{border-color:var(--error-border);border-left:3px solid var(--error)}.test-case-header{align-items:center;gap:8px;margin-bottom:10px;display:flex}.test-number{font-family:var(--font-mono);color:var(--text-muted);font-size:.8rem;font-weight:600}.test-badge{font-family:var(--font-mono);border-radius:var(--radius);letter-spacing:.5px;padding:2px 8px;font-size:.7rem;font-weight:700}.badge-pass{background:var(--success-dim);color:var(--success);border:1px solid var(--success-border)}.badge-fail{background:var(--error-dim);color:var(--error);border:1px solid var(--error-border)}.remove-btn{color:var(--text-dim);cursor:pointer;font-size:.85rem;font-family:var(--font-mono);border-radius:var(--radius);background:0 0;border:none;margin-left:auto;padding:2px 6px;transition:all .1s}.remove-btn:hover{color:var(--error);background:var(--error-dim)}.test-fields{flex-direction:column;gap:8px;display:flex}.test-field{flex-direction:column;gap:4px;display:flex}.test-field span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.7rem;font-weight:600}.test-field input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-mono);color:var(--text-primary);outline:none;padding:7px 10px;font-size:.8rem;transition:border-color .15s}.test-field input::placeholder{color:var(--text-dim)}.test-field input:focus{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-dim)}.test-toggle{cursor:pointer;color:var(--text-secondary);align-items:center;gap:6px;font-size:.8rem;display:flex}.test-toggle input{accent-color:var(--accent)}.test-diff{background:var(--error-dim);border:1px solid var(--error-border);border-radius:var(--radius);font-family:var(--font-mono);color:var(--error);margin-top:8px;padding:6px 10px;font-size:.75rem;animation:.15s slideDown}.share-export{flex-direction:column;gap:20px;display:flex}.share-export h3{margin-bottom:4px;font-size:.9rem;font-weight:600}.export-formats{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px;display:grid}.export-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;transition:border-color .15s}.export-card:hover{border-color:var(--border)}.export-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.export-lang{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:600}.copy-btn{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-tertiary);color:var(--text-secondary);font-size:.7rem;font-family:var(--font-mono);cursor:pointer;padding:3px 10px;font-weight:500;transition:all .12s}.copy-btn:hover{border-color:var(--accent);color:var(--accent)}.copy-btn.copied{background:var(--success);border-color:var(--success);color:var(--bg-primary)}.export-code{font-family:var(--font-mono);color:var(--accent);background:var(--bg-input);border-radius:var(--radius);border:1px solid var(--border);word-break:break-all;white-space:pre-wrap;padding:8px 10px;font-size:.78rem;line-height:1.5;display:block}.share-section{border-top:1px solid var(--border);padding-top:16px}.share-url-row{gap:8px;display:flex}.share-url-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-mono);color:var(--text-muted);outline:none;flex:1;padding:8px 12px;font-size:.75rem;transition:border-color .15s}.share-url-input:focus{border-color:var(--accent)}.empty-state{text-align:center;color:var(--text-dim);font-size:.8rem;font-family:var(--font-mono);padding:40px 16px}@media (width<=768px){:root{font-size:13px}.hero-title{font-size:1.8rem}.hero{padding:40px 16px 32px}.app-top-pane{flex-direction:column}.pane-left{border-right:none;border-bottom:1px solid var(--border);min-height:auto}.pane-left:after{display:none}.feature-grid,.pattern-grid,.export-formats{grid-template-columns:1fr}.tab-btn{padding:8px 12px;font-size:.75rem}.landing-nav{padding:0 16px}.builder-flags{gap:8px}.flag-desc,.app-header-status{display:none}.share-url-row{flex-direction:column}}@media (width<=480px){.hero-title{font-size:1.5rem}.hero-subtitle{font-size:.85rem}.cta-button{justify-content:center;width:100%}.suite-actions{flex-direction:column}}
