:root{--size-unit:16;--size-container-ideal:1600;--size-container-min:992px;--size-container-max:1600px;--size-container:clamp(var(--size-container-min), 100vw, var(--size-container-max));--size-font:calc(var(--size-container) / (var(--size-container-ideal) / var(--size-unit)))}@media (width<=991px){:root{--size-container-ideal:950;--size-container-min:768px;--size-container-max:991px}}@media (width<=767px){:root{--size-container-ideal:640;--size-container-min:480px;--size-container-max:767px}}@media (width<=479px){:root{--size-container-ideal:390;--size-container-min:320px;--size-container-max:479px}}html,body{font-size:var(--size-font)}*,:before,:after{box-sizing:border-box}:root{--space-0-125:.125rem;--space-0-25:.25rem;--space-0-5:.5rem;--space-0-75:.75rem;--space-1:1rem;--space-1-25:1.25rem;--space-1-5:1.5rem;--space-2:2rem;--space-2-5:2.5rem;--space-3:3rem;--space-3-5:3.5rem;--space-4:4rem;--space-4-5:4.5rem;--space-5:5rem;--space-5-5:5.5rem;--space-6:6rem;--space-6-5:6.5rem;--space-7:7rem;--space-7-5:7.5rem;--space-8:8rem;--space-8-5:8.5rem;--space-9:9rem;--space-9-5:9.5rem;--space-10:10rem;--space-11:11rem;--space-12:12rem;--space-13:13rem;--space-14:14rem;--space-15:15rem;--space-16:16rem;--font-family-sans:"Neue Montreal", system-ui, sans-serif;--font-family-heading:"Neue Montreal", system-ui, sans-serif;--font-family-mono:ui-monospace, "SF Mono", SFMono-Regular, Menlo, Consolas, monospace;--font-weight-regular:400;--font-weight-medium:500;--font-size-display:7rem;--font-size-h1:5rem;--font-size-h2:4rem;--font-size-h3:3rem;--font-size-h4:2rem;--font-size-h5:1.5rem;--font-size-h6:1rem;--font-size-text-large:1.25rem;--font-size-text-main:1rem;--font-size-text-small:.875rem;--line-height-display:.95;--line-height-tight:1.05;--line-height-snug:1.2;--line-height-base:1.5;--letter-spacing-display:-.04em;--letter-spacing-tight:-.03em;--letter-spacing-snug:-.01em;--letter-spacing-normal:0em;--letter-spacing-caps:.06em;--letter-spacing-caps-wide:.22em;--layout-row-top:16vh;--layout-row-bot:16vh;--layout-col-left:14%;--layout-col-right:14%}@media (width<=991px){:root{--font-size-display:5.5rem;--font-size-h1:4rem;--font-size-h2:3.25rem;--font-size-h3:2.5rem;--font-size-h4:1.75rem;--font-size-h5:1.375rem}}@media (width<=767px){:root{--font-size-display:3.75rem;--font-size-h1:3rem;--font-size-h2:2.5rem;--font-size-h3:2rem;--font-size-h4:1.5rem;--font-size-h5:1.25rem;--font-size-text-large:1.125rem;--layout-row-top:14vh;--layout-row-bot:14vh}}:root{--color-klein:#0004eb;--color-cream:#f4efe4}:root,.dark{--color-bg:radial-gradient(circle at 18% 24%, #0000004d, transparent 45%), radial-gradient(circle at 82% 72%, #00000038, transparent 50%), radial-gradient(circle at 55% 45%, #00000024, transparent 60%), var(--color-klein);--color-bg-solid:var(--color-klein);--color-fg:var(--color-cream);--color-fg-muted:#f4efe49e;--color-fg-soft:#f4efe473;--color-rule:var(--color-cream)}.light{--color-bg:var(--color-cream);--color-bg-solid:var(--color-cream);--color-fg:var(--color-klein);--color-fg-muted:#0004eb9e;--color-fg-soft:#0004eb6b;--color-rule:var(--color-klein)}html,body{background:var(--color-bg);color:var(--color-fg);transition:color .24s}@font-face{font-family:Neue Montreal;src:url(/fonts/NeueMontreal-Light.woff2)format("woff2");font-weight:300;font-style:normal;font-display:swap}@font-face{font-family:Neue Montreal;src:url(/fonts/NeueMontreal-Regular.woff2)format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Neue Montreal;src:url(/fonts/NeueMontreal-Italic.woff2)format("woff2");font-weight:400;font-style:italic;font-display:swap}@font-face{font-family:Neue Montreal;src:url(/fonts/NeueMontreal-Medium.woff2)format("woff2");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:Neue Montreal;src:url(/fonts/NeueMontreal-Bold.woff2)format("woff2");font-weight:700;font-style:normal;font-display:swap}html,body{height:100%;overflow:hidden}html{font-family:var(--font-family-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.font-mono{font-family:var(--font-family-mono)}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-heading)}h1{font-size:var(--font-size-h1);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);font-weight:var(--font-weight-medium)}h2{font-size:var(--font-size-h2);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);font-weight:var(--font-weight-medium)}h3{font-size:var(--font-size-h3);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);font-weight:var(--font-weight-medium)}h4{font-size:var(--font-size-h4);line-height:var(--line-height-snug);letter-spacing:var(--letter-spacing-tight);font-weight:var(--font-weight-medium)}h5{font-size:var(--font-size-h5);line-height:var(--line-height-snug);letter-spacing:var(--letter-spacing-tight);font-weight:var(--font-weight-medium)}h6{font-size:var(--font-size-h6);line-height:var(--line-height-snug);letter-spacing:var(--letter-spacing-tight);font-weight:var(--font-weight-medium)}body,p{font-size:var(--font-size-text-main);line-height:var(--line-height-snug);letter-spacing:var(--letter-spacing-snug);font-weight:var(--font-weight-regular)}body{margin:0}.text-display,.text-h1,.text-h2,.text-h3,.text-h4,.text-h5,.text-h6{font-family:var(--font-family-heading)}.text-display{font-size:var(--font-size-display);line-height:var(--line-height-display);letter-spacing:var(--letter-spacing-display);font-weight:var(--font-weight-medium)}.text-h1{font-size:var(--font-size-h1);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);font-weight:var(--font-weight-medium)}.text-h2{font-size:var(--font-size-h2);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);font-weight:var(--font-weight-medium)}.text-h3{font-size:var(--font-size-h3);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);font-weight:var(--font-weight-medium)}.text-h4{font-size:var(--font-size-h4);line-height:var(--line-height-snug);letter-spacing:var(--letter-spacing-tight);font-weight:var(--font-weight-medium)}.text-h5{font-size:var(--font-size-h5);line-height:var(--line-height-snug);letter-spacing:var(--letter-spacing-tight);font-weight:var(--font-weight-medium)}.text-h6{font-size:var(--font-size-h6);line-height:var(--line-height-snug);letter-spacing:var(--letter-spacing-tight);font-weight:var(--font-weight-medium)}.text-large{font-size:var(--font-size-text-large);line-height:var(--line-height-snug);letter-spacing:var(--letter-spacing-snug)}.text-main{font-size:var(--font-size-text-main);line-height:var(--line-height-snug);letter-spacing:var(--letter-spacing-snug)}.text-small{font-size:var(--font-size-text-small);line-height:var(--line-height-snug);letter-spacing:var(--letter-spacing-snug)}.text-caps{text-transform:uppercase;letter-spacing:var(--letter-spacing-caps)}:root{--klein:#0004eb;--cream:#f4efe4;--bg:#f4efe4;--page-bg:var(--cream);--s1:#f4efe4;--s2:#0004eb0f;--s3:#0004eb1a;--s4:#0004eb24;--b1:#0004eb33;--b2:#0004eb52;--b3:#0004eb75;--t1:#0004eb;--t2:#0004ebd9;--t3:#0004ebb3;--t4:#0004eb8c;--ed-bg:#f4efe4;--ed-2:#ece5d0;--ed-b:#0004eb38;--ed-t1:#0004eb;--ed-t3:#0004eb6b;--accent:#0004eb;--accent-hover:#0a10ff;--accent-2:#0004ebd9;--accent-dark:#0003c4;--accent-dim:#0004eb2e;--accent-text:#f4efe4;--green:#0a7a4a;--red:#c2362c;--yellow:#a06b1a;--purple:#0004eb;--purple-dim:#0004eb2e;--purple-border:#0004eb75;--font-ui:"Neue Montreal", system-ui, sans-serif;--font-code:ui-monospace, "SF Mono", SFMono-Regular, Menlo, Consolas, monospace;--sw:272px;--logo-text:#0004eb;--syn-keyword:#0004eb;--syn-string:#8a4b00;--syn-comment:#0004eb6b;--syn-fn:#0a3aa6;--syn-num:#a04018;--syn-attr:#5a2880;--syn-string-2:#4a6d18;--syn-op:#0004ebc7}[data-theme=dark]{--bg:#0004eb;--s1:#0004eb;--s2:#f4efe41a;--s3:#f4efe429;--s4:#f4efe438;--b1:#f4efe438;--b2:#f4efe45c;--b3:#f4efe480;--t1:#f4efe4;--t2:#f4efe4e0;--t3:#f4efe4b8;--t4:#f4efe48c;--ed-bg:#f4efe4;--ed-2:#ece5d0;--ed-b:#0004eb38;--ed-t1:#0004eb;--ed-t3:#0004eb6b;--accent:#f4efe4;--accent-hover:#fff;--accent-2:#f4efe4d9;--accent-dark:#fff;--accent-dim:#f4efe433;--accent-text:#0004eb;--green:#6cd8a3;--red:#ff8a7a;--yellow:#f0c977;--purple:#f4efe4;--purple-dim:#f4efe433;--purple-border:#f4efe480;--logo-text:#f4efe4;--syn-keyword:#0004eb;--syn-string:#8a4b00;--syn-comment:#0004eb6b;--syn-fn:#0a3aa6;--syn-num:#a04018;--syn-attr:#5a2880;--syn-string-2:#4a6d18;--syn-op:#0004ebc7}[data-theme=dark] .editor-pane{--bg:#f4efe4;--s1:#ece5d0;--s2:#0004eb1a;--s3:#0004eb29;--b1:#0004eb33;--b2:#0004eb52;--b3:#0004eb75;--t1:#0004eb;--t2:#0004ebd9;--t3:#0004ebb3;--t4:#0004eb8c;--accent:#0004eb;--accent-hover:#0a10ff;--accent-2:#0004ebd9;--accent-dim:#0004eb2e;--accent-text:#f4efe4}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{min-height:100%;font-family:var(--font-ui);background:var(--page-bg,var(--bg));color:var(--t1);-webkit-font-smoothing:antialiased}button,a{cursor:pointer;font:inherit;color:inherit;background:0 0;border:0;text-decoration:none}button[disabled]{cursor:not-allowed}svg{flex-shrink:0;display:block}#root{min-height:100%}.app{height:100svh;display:flex;position:relative;overflow:hidden}.sidebar{width:var(--sw);border-right:1px solid var(--b1);background:0 0;flex-direction:column;flex-shrink:0;transition:width .22s,border-color .22s;display:flex;overflow:hidden auto}.sidebar--closed{border-right-color:#0000;width:0!important}.brand{border-bottom:1px solid var(--b1);min-width:var(--sw);flex-shrink:0;align-items:center;gap:8px;height:72px;padding:20px 24px;display:flex;position:relative}.brand:after{content:"";background:var(--accent-dim);opacity:.5;pointer-events:none;height:1px;position:absolute;bottom:0;left:0;right:0}.brand a{opacity:.92;line-height:0;transition:opacity .12s}.brand a:hover{opacity:1}.brand-actions{flex-shrink:0;align-items:center;gap:4px;margin-left:auto;display:flex}.btn-icon{width:28px;height:28px;color:var(--t4);border:1px solid #0000;border-radius:6px;justify-content:center;align-items:center;transition:all .12s;display:flex}.btn-icon:hover{color:var(--t2);background:var(--s2);border-color:var(--b1)}.cl-userButtonAvatarBox{filter:grayscale()opacity(.55)!important;width:22px!important;height:22px!important;transition:filter .15s!important}.cl-userButtonTrigger{border:1px solid #0000!important;border-radius:6px!important;outline:none!important;padding:3px!important;transition:all .12s!important}.cl-userButtonTrigger:hover{border-color:var(--b1)!important;background:var(--s2)!important}.cl-userButtonTrigger:hover .cl-userButtonAvatarBox{filter:grayscale(0)opacity()!important}.cl-userButtonTrigger:focus-visible{box-shadow:0 0 0 2px var(--accent)!important}.sidebar-toggle{top:50%;left:calc(var(--sw) - 1px);background:var(--s1);border:1px solid var(--b1);width:16px;height:44px;color:var(--t4);cursor:pointer;z-index:100;border-left:none;border-radius:0 6px 6px 0;justify-content:center;align-items:center;transition:left .22s,color .12s,background .12s;display:flex;position:absolute;transform:translateY(-50%)}.sidebar-toggle:hover{color:var(--t1);background:var(--s2)}.sidebar-toggle:not(.open){left:0}.slabel{font-family:var(--font-code);letter-spacing:.06em;text-transform:uppercase;color:var(--t4);border-left:2px solid #0000;flex-shrink:0;padding:20px 24px 8px;font-size:11px;font-weight:400}.stats-wrap .slabel{border-left-color:var(--accent);background:var(--accent-dim)}.nav{border-bottom:1px solid var(--b1);flex-shrink:0}.tab{width:100%;height:48px;color:var(--t3);cursor:pointer;text-align:left;letter-spacing:-.01em;background:0 0;border:none;border-left:2px solid #0000;align-items:center;padding:0 24px;font-size:14px;font-weight:400;transition:color .1s,background .1s,border-color .1s;display:flex}.tab:hover{color:var(--t1);background:var(--s2)}.tab.is-active{color:var(--accent-text);background:var(--accent);border-left-color:var(--accent);font-weight:500}.tab-key{font-size:10px;font-family:var(--font-code);color:var(--t4);margin-left:auto}.tab.is-active .tab-key{color:var(--accent-text);opacity:.55}.tab-dirty{background:var(--yellow);border-radius:50%;flex-shrink:0;width:5px;height:5px;margin:0 8px 0 6px}.stats-wrap{border-bottom:1px solid var(--b1);flex-shrink:0;display:none}.stats-wrap.visible{display:block}.stats-grid{grid-template-columns:1fr 1fr;display:grid}.stat{border-right:1px solid var(--b1);border-bottom:1px solid var(--b1);padding:12px 20px 10px;transition:background .2s}.stat:nth-child(2n){border-right:none}.stat:nth-child(n+3){border-bottom:none}.stat.lit{background:var(--s2)}.stat-num{letter-spacing:-.04em;color:var(--t4);font-variant-numeric:tabular-nums;font-size:22px;font-weight:500;line-height:1;transition:color .25s}.stat.lit .stat-num{color:var(--accent)}.stat-lbl{letter-spacing:.1em;text-transform:uppercase;color:var(--t4);margin-top:3px;font-size:10px;font-weight:500}.warnings-wrap{border-bottom:1px solid var(--b1);flex-shrink:0;display:none}.warnings-wrap.visible{display:block}.warnings-list{padding:4px 20px 12px;list-style:none}.warnings-list li{color:var(--yellow);padding:2px 0 2px 14px;font-size:11px;line-height:1.65;position:relative}.warnings-list li:before{content:"→";opacity:.7;position:absolute;left:0}.warn-lbl{color:var(--yellow)!important}.conv-history{border-bottom:1px solid var(--b1);flex-shrink:0}.conv-hist-item{width:100%;color:var(--t3);text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:7px 20px;font-size:11px;transition:background .1s,color .1s;display:flex}.conv-hist-item:hover{background:var(--s2);color:var(--t1)}.conv-hist-label{text-overflow:ellipsis;white-space:nowrap;font-family:var(--font-code);flex:1;overflow:hidden}.conv-hist-meta{color:var(--t4);flex-shrink:0;font-size:10px}.desc{color:var(--t3);border-bottom:1px solid var(--b1);flex-shrink:0;padding:16px 24px 22px;font-size:13px;line-height:1.75}.kbd-hint{color:var(--t3);font-size:11px;font-family:var(--font-code);align-items:center;gap:6px;margin-top:10px;display:flex}kbd{background:var(--s3);border:1px solid var(--b2);font-family:var(--font-code);color:var(--t2);border-radius:3px;padding:2px 6px;font-size:10px}.decode-sidebar-info{border-bottom:1px solid var(--b1);flex-shrink:0;padding:14px 20px}.decode-sidebar-desc{color:var(--t3);font-size:12px;line-height:1.7}.decode-sidebar-desc kbd{display:inline-block}.decode-sidebar-hint{color:var(--t4);background:var(--s2);border:1px solid var(--b1);border-radius:7px;align-items:flex-start;gap:8px;padding:10px 12px;font-size:11px;line-height:1.6;display:flex}.decode-sidebar-hint svg{flex-shrink:0;margin-top:1px}.ai-trigger-wrap{border-bottom:1px solid var(--b1);flex-shrink:0;padding:16px 20px}.btn-ai-trigger{border:1px solid var(--accent);width:100%;height:44px;color:var(--accent);font-family:var(--font-ui);cursor:pointer;letter-spacing:-.01em;background:0 0;border-radius:2px;align-items:center;gap:8px;padding:0 16px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.btn-ai-trigger:hover{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.btn-ai-trigger:active{transform:translateY(1px)}.ai-js-badge{letter-spacing:.08em;text-transform:uppercase;color:var(--purple);background:var(--purple-dim);border:1px solid var(--purple-border);border-radius:100px;margin-left:auto;padding:2px 7px;font-size:9px;font-weight:600}.actions{border-top:1px solid var(--b1);background:0 0;flex-direction:column;flex-shrink:0;gap:10px;margin-top:auto;padding:20px;display:flex;position:sticky;bottom:0}.btn-convert{background:var(--accent);width:100%;height:48px;color:var(--accent-text);font-family:var(--font-ui);letter-spacing:-.01em;border:1px solid var(--accent);cursor:pointer;border-radius:2px;justify-content:center;align-items:center;gap:10px;font-size:14px;font-weight:500;transition:background .18s,transform 80ms;display:flex}.btn-convert:hover:not(:disabled){background:var(--accent-hover)}.btn-convert:active:not(:disabled){transform:translateY(1px)}.btn-convert:disabled{opacity:.35;cursor:not-allowed}.btn-shortcut{font-family:var(--font-code);color:#f4efe480;margin-left:2px;font-size:11px}.btn-row{grid-template-columns:1fr 1fr;gap:8px;display:grid}.btn-sec{width:100%;height:40px;font-family:var(--font-ui);color:var(--accent);border:1px solid var(--accent);cursor:pointer;letter-spacing:-.01em;background:0 0;border-radius:2px;justify-content:center;align-items:center;gap:8px;padding:0 14px;font-size:13px;font-weight:500;transition:background .15s,color .15s;display:flex}.btn-sec span{text-align:center;flex:1}.btn-sec:hover:not(:disabled){background:var(--accent);color:var(--accent-text)}.btn-sec:disabled{opacity:.3;cursor:not-allowed}.btn-sec.copy:hover:not(:disabled){background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.btn-sec.danger{color:var(--red);border-color:#c2362c80}.btn-sec.danger:hover:not(:disabled){background:var(--red);color:var(--cream);border-color:var(--red)}.btn-tut{display:none!important}.mode-switcher{border-bottom:1px solid var(--b1);background:0 0;flex-shrink:0;align-items:center;gap:4px;padding:16px 20px;display:flex}.mode-btn{height:40px;font-family:var(--font-ui);color:var(--t3);cursor:pointer;letter-spacing:-.01em;background:0 0;border:1px solid #0000;border-radius:2px;justify-content:center;align-items:center;gap:8px;padding:0 20px;font-size:14px;font-weight:500;transition:all .14s;display:inline-flex}.mode-btn:hover{color:var(--t1);background:var(--s2)}.mode-btn.is-active{color:var(--accent-text);background:var(--accent);border-color:var(--accent)}.mode-btn svg{opacity:.7}.mode-btn.is-active svg{opacity:1}.editor-pane{background:0 0;flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.topbar{border-bottom:1px solid var(--b1);background:0 0;flex-shrink:0;align-items:stretch;height:52px;display:flex}.topbar-tabs{align-items:stretch;display:flex}.topbar-tab{letter-spacing:.04em;text-transform:uppercase;height:100%;color:var(--t4);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;padding:0 18px;font-size:12px;font-weight:500;transition:color .1s,border-color .1s;display:flex;position:relative;top:1px}.topbar-tab:hover{color:var(--t2)}.topbar-tab.is-active{color:var(--t1);border-bottom-color:var(--accent)}.topbar-dirty{background:var(--yellow);border-radius:50%;flex-shrink:0;width:5px;height:5px}.topbar-right{align-items:center;gap:14px;margin-left:auto;padding:0 18px;display:flex}.status-pill{color:var(--t3);font-size:11px;font-family:var(--font-code);align-items:center;gap:6px;display:flex}.sdot{background:var(--t4);border-radius:50%;flex-shrink:0;width:6px;height:6px;transition:background .2s}.sdot.ready{background:var(--green)}.sdot.dirty{background:var(--yellow)}.sdot.error{background:var(--red)}.char-ct{font-size:10.5px;font-family:var(--font-code);color:var(--t4)}.editor-area{flex:1;position:relative;overflow:hidden}.editor-wrap{position:absolute;inset:0}.editor-wrap.hidden{display:none}textarea.code{resize:none;tab-size:2;width:100%;height:100%;font-size:13px;font-family:var(--font-code);color:var(--ed-t1);caret-color:var(--accent);background:0 0;border:none;outline:none;padding:24px 28px;font-weight:400;line-height:1.85}textarea.code::placeholder{color:var(--ed-t3);font-family:var(--font-ui);font-size:13px}.cm-host{width:100%;height:100%}.cm-host .cm-editor{height:100%}.cm-host .cm-editor.cm-focused{outline:none}.empty{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;transition:opacity .15s;display:flex;position:absolute;inset:0}.empty-icon{border:1px solid var(--b2);width:40px;height:40px;color:var(--t4);background:var(--s2);border-radius:8px;justify-content:center;align-items:center;margin-bottom:14px;display:flex}.empty-title{color:var(--t2);font-size:14px;font-weight:500}.empty-sub{color:var(--t4);margin-top:4px;font-size:12px}.statusbar{background:var(--ed-2);border-top:1px solid var(--ed-b);flex-shrink:0;align-items:center;gap:14px;height:24px;padding:0 18px;display:flex}.sb{font-size:10.5px;font-family:var(--font-code);color:var(--t4);letter-spacing:.03em;white-space:nowrap}.sb.active{color:var(--t3)}.sb-sep{background:var(--b2);flex-shrink:0;width:1px;height:10px}.sb-r{margin-left:auto}.decode-pane{background:var(--ed-bg);flex-direction:column;flex:1;display:flex;overflow:hidden}.decode-waiting{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:22px;padding:48px 40px;display:flex}.decode-waiting-icon{background:var(--accent-dim);width:64px;height:64px;box-shadow:0 0 0 1px var(--accent-dim), 0 4px 16px var(--accent-dim);color:var(--accent);border:1px solid #0000;border-radius:16px;justify-content:center;align-items:center;animation:2s ease-in-out infinite decode-pulse;display:flex}@keyframes decode-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.95)}}.decode-waiting-title{color:var(--t1);font-size:16px;font-weight:600;font-family:var(--font-ui);letter-spacing:-.02em}.decode-waiting-title kbd{background:var(--s2);border:1px solid var(--b2);font-size:14px;font-family:var(--font-code);color:var(--accent);border-radius:5px;padding:1px 8px;font-weight:600;display:inline-block}.decode-waiting-steps{text-align:left;background:var(--s2);border:1px solid var(--b1);border-radius:10px;flex-direction:column;gap:12px;width:100%;min-width:280px;max-width:380px;padding:18px 22px;display:flex}.decode-step{color:var(--t2);font-size:13px;font-family:var(--font-ui);align-items:center;gap:12px;display:flex}.decode-step kbd{background:var(--bg);border:1px solid var(--b2);font-size:11px;font-family:var(--font-code);color:var(--t1);border-radius:4px;padding:0 6px;display:inline-block}.decode-step-num{background:var(--accent);width:22px;height:22px;color:var(--bg);font-size:11px;font-weight:700;font-family:var(--font-ui);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.decode-waiting-hint{color:var(--t4);font-size:11px;font-family:var(--font-ui)}.decode-err-wrap{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:40px 32px;display:flex}.decode-err{color:#b91c1c;width:100%;max-width:480px;font-size:12px;font-family:var(--font-ui);background:#d940300f;border:1px solid #d9403033;border-radius:8px;align-items:flex-start;gap:10px;padding:14px 16px;display:flex}.decode-err pre{white-space:pre-wrap;font-family:inherit;line-height:1.6}[data-theme=dark] .decode-err{color:#fca5a5;background:#e0504014;border-color:#e0504040}.decode-retry{background:var(--s2);border:1px solid var(--b2);color:var(--t2);font-size:12px;font-family:var(--font-ui);cursor:pointer;border-radius:7px;padding:8px 20px;font-weight:500;transition:all .1s}.decode-retry:hover{background:var(--b1);color:var(--t1)}.decode-retry--inline{padding:5px 12px;font-size:11px}.decode-pane--result{flex-direction:column;display:flex}.decode-out-bar{background:var(--ed-2);border-bottom:1px solid var(--ed-b);flex-shrink:0;align-items:center;gap:8px;height:44px;padding:0 14px;display:flex}.decode-out-tabs{gap:0;display:flex}.decode-out-tab{height:44px;font-size:12px;font-weight:500;font-family:var(--font-ui);letter-spacing:.04em;text-transform:uppercase;color:var(--t4);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;padding:0 14px;transition:color .1s;display:flex;position:relative;top:1px}.decode-out-tab:hover{color:var(--t2)}.decode-out-tab.is-active{color:var(--accent);border-bottom-color:var(--accent)}.decode-none-badge{background:var(--b1);color:var(--t4);text-transform:none;letter-spacing:0;border-radius:10px;padding:1px 5px;font-size:9px;font-weight:400}.decode-out-meta{color:var(--t4);font-size:10.5px;font-family:var(--font-code);white-space:nowrap;margin-left:auto}.decode-copy-btn{border:1px solid var(--b1);color:var(--t2);font-size:11px;font-family:var(--font-ui);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;flex-shrink:0;align-items:center;gap:5px;padding:5px 12px;transition:all .1s;display:flex}.decode-copy-btn:hover{background:var(--accent-dim);border-color:var(--accent-dim);color:var(--accent)}.decode-output-pre{font-family:var(--font-code);color:var(--ed-t1);white-space:pre;background:var(--ed-bg);flex:1;margin:0;padding:20px 28px;font-size:13px;line-height:1.85;overflow:auto}.decode-preview-tab{border-left:1px solid var(--ed-b);color:var(--t4);gap:6px;margin-left:4px;padding-left:16px}.decode-preview-tab:hover{color:var(--green)}.decode-preview-tab.is-active{color:var(--green);border-bottom-color:var(--green)}.decode-live-badge{letter-spacing:.07em;text-transform:uppercase;color:var(--green);background:#34d3991f;border:1px solid #34d39940;border-radius:100px;padding:1px 5px;font-size:8.5px;font-weight:700;line-height:1}.decode-preview-wrap{background:#fff;flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.decode-preview-wrap--fullscreen{z-index:2000;border-radius:0;position:fixed;inset:0;overflow:hidden}.decode-preview-libs{background:var(--ed-2);border-bottom:1px solid var(--ed-b);height:30px;font-size:10px;font-family:var(--font-ui);color:var(--t4);flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:0 14px;display:flex}.decode-preview-libs-left{align-items:center;gap:5px;min-width:0;display:flex;overflow:hidden}.decode-preview-libs-right{flex-shrink:0;align-items:center;gap:5px;font-size:10px;display:flex}.decode-preview-lib-badge{color:var(--green);white-space:nowrap;letter-spacing:.02em;background:#34d3991a;border:1px solid #34d39933;border-radius:100px;padding:1px 6px;font-size:9px;font-weight:600}.decode-cdn-list{flex-direction:column;gap:4px;display:flex}.decode-cdn-item{background:var(--bg);border:1px solid var(--b1);border-radius:6px;align-items:center;gap:6px;padding:5px 8px;display:flex}.decode-cdn-type-badge{white-space:nowrap;letter-spacing:.05em;text-transform:uppercase;border-radius:100px;flex-shrink:0;padding:1px 5px;font-size:9px;font-weight:700}.decode-cdn-type-badge--js{color:#3b82f6;background:#3b82f61a;border:1px solid #3b82f633}.decode-cdn-type-badge--css{color:#8b5cf6;background:#8b5cf61a;border:1px solid #8b5cf633}.decode-cdn-url{text-overflow:ellipsis;white-space:nowrap;color:var(--t2);font-size:10.5px;font-family:var(--font-code);flex:1;overflow:hidden}.decode-cdn-remove{width:16px;height:16px;color:var(--t4);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:16px;line-height:1;transition:color .1s,background .1s;display:flex}.decode-cdn-remove:hover{color:#ef4444;background:#ef44441a}.decode-cdn-custom-badge{background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent-dim);white-space:nowrap;letter-spacing:.02em;border-radius:100px;padding:1px 6px;font-size:9px;font-weight:600}.decode-preview-expand-btn{border:1px solid var(--b1);color:var(--t3);font-size:10px;font-family:var(--font-ui);cursor:pointer;white-space:nowrap;background:0 0;border-radius:5px;align-items:center;gap:4px;padding:3px 8px;transition:all .12s;display:flex}.decode-preview-expand-btn:hover{background:var(--s2);color:var(--t1);border-color:var(--b2)}.decode-preview-wrap:after{content:"";pointer-events:none;box-shadow:inset 0 0 0 1px var(--ed-b);z-index:1;position:absolute;inset:0}.decode-preview-frame{background:#fff;border:none;flex:1;width:100%;min-height:0;display:block}.decode-send-btn{font-size:10px;font-weight:600;font-family:var(--font-ui);color:var(--bg);cursor:pointer;background:var(--accent);white-space:nowrap;border:none;border-radius:5px;align-items:center;gap:5px;padding:4px 10px;transition:opacity .12s;display:flex}.decode-send-btn:hover{opacity:.85}.preview-errors{border-top:1px solid var(--ed-b);background:var(--s1);flex-shrink:0}.preview-errors-header{cursor:pointer;-webkit-user-select:none;user-select:none;font-size:10px;font-family:var(--font-ui);color:var(--t3);align-items:center;gap:6px;padding:5px 14px;transition:background .1s;display:flex}.preview-errors-header:hover{background:var(--s2)}.preview-errors-header svg{flex-shrink:0;transition:transform .15s}.preview-errors-header.is-open svg{transform:rotate(90deg)}.preview-errors-badge{letter-spacing:.02em;border-radius:100px;padding:1px 6px;font-size:9px;font-weight:700;line-height:1.2}.preview-errors-badge--error{color:#ef4444;background:#ef444426;border:1px solid #ef444440}.preview-errors-badge--warn{color:#eab308;background:#eab30826;border:1px solid #eab30840}.preview-errors-body{border-top:1px solid var(--ed-b);max-height:200px;overflow-y:auto}.preview-error-item{font-size:11px;font-family:var(--font-code);color:var(--t2);border-bottom:1px solid var(--ed-b);align-items:flex-start;gap:8px;padding:6px 14px;line-height:1.4;display:flex}.preview-error-item:last-child{border-bottom:none}.preview-error-icon{flex-shrink:0;width:14px;height:14px;margin-top:1px}.preview-error-icon--error{color:#ef4444}.preview-error-icon--warn{color:#eab308}.preview-error-msg{word-break:break-word;flex:1}.preview-error-fix{font-size:9px;font-weight:600;font-family:var(--font-ui);color:var(--bg);cursor:pointer;background:var(--accent);white-space:nowrap;border:none;border-radius:4px;flex-shrink:0;align-items:center;gap:3px;padding:2px 8px;transition:opacity .12s;display:flex}.preview-error-fix:hover{opacity:.85}.preview-error-fix:disabled{opacity:.5;cursor:not-allowed}.preview-error-fix .preview-fix-spinner{border:1.5px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:10px;height:10px;animation:.6s linear infinite spin;display:none}.preview-error-fix.is-loading .preview-fix-spinner{display:inline-block}.preview-error-fix.is-loading .preview-fix-label{display:none}.preview-errors-clear{font-size:9px;font-family:var(--font-ui);color:var(--t4);border:1px solid var(--b1);cursor:pointer;background:0 0;border-radius:4px;align-items:center;margin-left:auto;padding:2px 6px;display:flex}.preview-errors-clear:hover{color:var(--t2);border-color:var(--b2)}.preview-errors-toolbar{align-items:center;gap:0;display:flex}.preview-errors-fix-btn{font-size:10px;font-weight:600;font-family:var(--font-ui);color:#fff;cursor:pointer;white-space:nowrap;background:#6366f1;border:none;border-radius:4px;margin-left:auto;margin-right:8px;padding:3px 10px;transition:background .15s}.preview-errors-fix-btn:hover{background:#4f46e5}.preview-errors-fix-btn:disabled{opacity:.6;cursor:not-allowed}.build-pane{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.build-cdn-toggle{font-size:10px;font-weight:500;font-family:var(--font-ui);color:var(--t3);border:1px solid var(--b1);cursor:pointer;white-space:nowrap;background:0 0;border-radius:5px;align-items:center;gap:4px;padding:3px 8px;transition:all .12s;display:flex}.build-cdn-toggle:hover,.build-cdn-toggle.is-active{background:var(--s2);color:var(--t1);border-color:var(--b2)}.build-cdn-bar{background:var(--s1);border-bottom:1px solid var(--ed-b);flex-direction:column;flex-shrink:0;gap:6px;padding:8px 14px;display:flex}.build-cdn-input-row{gap:6px;display:flex}.build-cdn-input{font-size:11px;font-family:var(--font-code);background:var(--bg);color:var(--t1);border:1px solid var(--b1);border-radius:5px;outline:none;flex:1;padding:5px 10px}.build-cdn-input:focus{border-color:var(--accent)}.build-cdn-add{font-size:10px;font-weight:600;font-family:var(--font-ui);color:var(--bg);cursor:pointer;background:var(--accent);border:none;border-radius:5px;padding:5px 12px}.build-cdn-add:hover{opacity:.85}.build-cdn-list{flex-direction:column;gap:3px;display:flex}.build-cdn-item{background:var(--bg);border:1px solid var(--b1);border-radius:5px;align-items:center;gap:6px;padding:3px 6px;font-size:10px;display:flex}@keyframes spin{to{transform:rotate(360deg)}}@keyframes ai-spin{to{transform:rotate(360deg)}}@keyframes numIn{0%{opacity:0;transform:translateY(3px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.spinner{border:1.5px solid #ffffff38;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.5s linear infinite spin;display:none}.btn-convert.loading .spinner{display:block}.btn-convert.loading .btn-lbl,.btn-convert.loading .btn-arr,.btn-convert.loading .btn-shortcut{display:none}.stat-num.pop{animation:.2s forwards numIn}.ai-modal-overlay{z-index:1100;opacity:0;visibility:hidden;background:#15131380;justify-content:center;align-items:center;padding:24px;transition:opacity .18s,visibility .18s;display:flex;position:fixed;inset:0}[data-theme=dark] .ai-modal-overlay{background:#000000ad}.ai-modal-overlay.show{opacity:1;visibility:visible}.ai-modal{background:var(--s1);border:1px solid var(--b2);border-radius:12px;flex-direction:column;width:100%;max-width:560px;transition:transform .18s;display:flex;overflow:hidden;transform:translateY(12px)scale(.98);box-shadow:0 16px 56px #0000002e}.ai-modal--mapping{max-width:780px}.ai-modal--simple{max-width:480px}.ai-modal-overlay.show .ai-modal{transform:translateY(0)scale(1)}.ai-modal-header{border-bottom:1px solid var(--b1);align-items:center;padding:18px 20px 16px;display:flex}.ai-modal-title{color:var(--purple);letter-spacing:.01em;flex:1;align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.ai-modal-close{width:30px;height:30px;color:var(--t4);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;transition:all .12s;display:flex}.ai-modal-close:hover{color:var(--t1);background:var(--s3)}.ai-modal-steps{font-size:11px;font-family:var(--font-ui);color:var(--t4);flex:1;justify-content:center;align-items:center;gap:6px;display:flex}.ai-step{color:var(--t4)}.ai-step.active{color:var(--purple);font-weight:600}.ai-step.done{color:var(--t3)}.ai-modal-loading{color:var(--t3);font-size:13px;font-family:var(--font-ui);justify-content:center;align-items:center;gap:12px;padding:56px 20px;display:flex}.ai-modal-spinner{border:2px solid var(--b2);border-top-color:var(--purple);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.7s linear infinite ai-spin}.ai-tips-panel{border-bottom:1px solid var(--b1);flex-shrink:0}.ai-tips-toggle{width:100%;font-size:11px;font-weight:500;font-family:var(--font-ui);color:var(--t3);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:7px;padding:10px 20px;transition:color .12s;display:flex}.ai-tips-toggle:hover{color:var(--t1)}.tips-chevron{color:var(--t4);flex-shrink:0;transition:transform .2s}.tips-chevron.open{transform:rotate(180deg)}.ai-tips-body{background:var(--s2);border-top:1px solid var(--b1);flex-direction:column;gap:10px;padding:4px 20px 14px;display:flex}.ai-tip{color:var(--t3);font-size:11.5px;line-height:1.65;font-family:var(--font-ui);align-items:flex-start;gap:10px;display:flex}.ai-tip-icon{background:var(--purple-dim);width:18px;height:18px;color:var(--purple);font-size:10px;font-weight:700;font-family:var(--font-ui);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;display:flex}.ai-tip strong{color:var(--t2);font-weight:600}.ai-tip code{font-family:var(--font-code);background:var(--s3);border:1px solid var(--b2);color:var(--t2);border-radius:3px;padding:0 4px;font-size:10.5px}.ai-simple-body{flex-direction:column;gap:12px;padding:20px 22px 16px;display:flex}.ai-simple-label{color:var(--t2);font-size:13px;font-weight:500;font-family:var(--font-ui);letter-spacing:-.01em}.ai-simple-input{background:var(--ed-bg);border:1px solid var(--b2);width:100%;font-size:13px;font-family:var(--font-ui);color:var(--t1);resize:none;box-sizing:border-box;border-radius:8px;outline:none;padding:10px 12px;line-height:1.6;transition:border-color .15s,box-shadow .15s}.ai-simple-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.ai-simple-input::placeholder{color:var(--ed-t3)}.ai-simple-input:disabled{opacity:.5}.ai-simple-error{color:var(--red);font-size:11.5px;font-family:var(--font-ui);margin-top:-4px}.ai-simple-chips{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.ai-simple-chips-label{color:var(--t4);font-size:10px;font-weight:600;font-family:var(--font-ui);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}.ai-simple-chip{background:var(--s2);border:1px solid var(--b1);color:var(--t3);font-size:11px;font-weight:500;font-family:var(--font-ui);cursor:pointer;white-space:nowrap;border-radius:100px;padding:3px 10px;transition:all .12s}.ai-simple-chip:hover:not(:disabled){background:var(--accent-dim);border-color:var(--accent-dim);color:var(--accent)}.ai-simple-chip.selected{background:var(--accent);color:var(--bg);border-color:#0000}.ai-simple-chip:disabled{opacity:.4;cursor:not-allowed}.ai-simple-note{color:var(--t4);font-size:11px;font-family:var(--font-ui);background:var(--s2);border:1px solid var(--b1);border-radius:7px;gap:7px;padding:8px 10px;line-height:1.6;display:flex}.ai-simple-usage{font-size:10.5px;font-family:var(--font-code);text-align:right}.ai-modal-body{flex-direction:column;gap:10px;padding:18px 20px 16px;display:flex}.ai-modal-input{background:var(--s2);border:1px solid var(--b2);width:100%;height:42px;font-family:var(--font-ui);color:var(--t1);border-radius:8px;outline:none;padding:0 14px;font-size:13px;transition:border-color .12s}.ai-modal-input:focus{border-color:var(--purple);background:var(--s1)}.ai-modal-input::placeholder{color:var(--t4)}.ai-history{flex-wrap:wrap;gap:5px;display:flex}.ai-hist-btn{font-size:11px;font-family:var(--font-ui);background:var(--s2);border:1px solid var(--b1);color:var(--t3);cursor:pointer;white-space:nowrap;text-overflow:ellipsis;border-radius:100px;max-width:200px;padding:4px 10px;transition:all .1s;overflow:hidden}.ai-hist-btn:hover{color:var(--t1);background:var(--s3);border-color:var(--b2)}.ai-status{font-size:11px;font-family:var(--font-code);color:var(--t4);padding:2px 0}.ai-status.running{color:var(--purple)}.ai-status.err{color:var(--red)}.ai-modal-footer{border-top:1px solid var(--b1);justify-content:flex-end;align-items:center;gap:8px;padding:12px 20px 16px;display:flex}.ai-modal--simple .ai-modal-footer{padding:14px 22px 18px}.btn-ai-modal-cancel{border:1px solid var(--b2);height:38px;color:var(--t3);font-family:var(--font-ui);cursor:pointer;background:0 0;border-radius:7px;padding:0 18px;font-size:12px;transition:all .1s}.btn-ai-modal-cancel:hover{color:var(--t1);border-color:var(--b3);background:var(--s3)}.btn-ai-run{background:var(--accent);height:38px;color:var(--bg);font-family:var(--font-ui);cursor:pointer;letter-spacing:.01em;border:none;border-radius:7px;justify-content:center;align-items:center;gap:7px;padding:0 20px;font-size:12px;font-weight:600;transition:opacity .12s,transform 80ms,filter .12s;display:flex}.btn-ai-run:hover:not(:disabled){filter:brightness(1.12)}.btn-ai-run:active:not(:disabled){transform:translateY(1px)}.btn-ai-run:disabled{opacity:.35;cursor:not-allowed}.ai-run-spinner{border:1.5px solid #ffffff4d;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:12px;height:12px;animation:.5s linear infinite spin;display:none}.btn-ai-run.loading .ai-run-spinner{display:block}.btn-ai-run.loading .ai-run-lbl,.btn-ai-run.loading .ai-run-icon,.btn-ai-run.loading .ai-run-shortcut{display:none}.ai-run-shortcut{font-family:var(--font-code);color:#ffffff61;margin-left:6px;font-size:10px}.ai-quickstart-bar{border-bottom:1px solid var(--b1);background:var(--s2);flex-shrink:0;align-items:center;gap:10px;padding:10px 20px;display:flex}.ai-style-label{letter-spacing:.08em;text-transform:uppercase;color:var(--t4);white-space:nowrap;font-size:10px;font-weight:600;font-family:var(--font-ui);flex-shrink:0}.ai-style-dropdown-wrap{flex:1;min-width:0;position:relative}.ai-style-trigger{background:var(--s1);border:1px solid var(--b2);width:100%;height:32px;font-family:var(--font-ui);color:var(--t1);cursor:pointer;text-align:left;border-radius:7px;align-items:center;gap:8px;padding:0 10px;font-size:12px;transition:border-color .12s;display:flex}.ai-style-trigger:hover,.ai-style-trigger.open{border-color:var(--purple)}.ai-style-trigger-name{white-space:nowrap;flex-shrink:0;font-weight:500}.ai-style-trigger-example{font-family:var(--font-code);color:var(--t4);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:10.5px;overflow:hidden}.ai-style-chevron{color:var(--t4);flex-shrink:0;margin-left:auto;transition:transform .18s}.ai-style-trigger.open .ai-style-chevron{transform:rotate(180deg)}.ai-style-menu{background:var(--s1);border:1px solid var(--b2);z-index:200;border-radius:8px;max-height:260px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto;box-shadow:0 8px 32px #00000024}.ai-style-menu::-webkit-scrollbar{width:4px}.ai-style-menu::-webkit-scrollbar-track{background:0 0}.ai-style-menu::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px}.ai-style-option{width:100%;font-family:var(--font-ui);color:var(--t2);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:8px 12px;font-size:12px;transition:background .1s;display:flex}.ai-style-option:hover{background:var(--s2)}.ai-style-option.selected{background:var(--purple-dim);color:var(--purple)}.ai-style-option-name{white-space:nowrap;flex-shrink:0;min-width:110px;font-weight:500}.ai-style-option-example{font-family:var(--font-code);color:var(--t4);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:10.5px;overflow:hidden}.ai-style-option.selected .ai-style-option-example{color:var(--purple);opacity:.65}.ai-mapping-tabs{border-bottom:1px solid var(--b1);flex-shrink:0;display:flex}.ai-mapping-tab{font-size:11px;font-weight:600;font-family:var(--font-ui);color:var(--t4);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-1px;padding:9px 16px;transition:color .12s,border-color .12s}.ai-mapping-tab:hover{color:var(--t2)}.ai-mapping-tab.active{color:var(--purple);border-bottom-color:var(--purple)}.ai-mapping-tab-badge{background:var(--s3);min-width:16px;height:16px;color:var(--t4);vertical-align:middle;border-radius:8px;justify-content:center;align-items:center;margin-left:5px;padding:0 4px;font-size:9px;font-weight:700;display:inline-flex}.ai-mapping-tab.active .ai-mapping-tab-badge{background:var(--accent-dim);color:var(--purple)}.ai-anchor-intro{color:var(--t3);font-size:12px;font-family:var(--font-ui);flex-shrink:0;padding:14px 24px 8px;line-height:1.6}.ai-anchor-rows{flex-direction:column;flex-shrink:0;max-height:420px;padding:0 0 8px;display:flex;overflow-y:auto}.ai-anchor-rows::-webkit-scrollbar{width:4px}.ai-anchor-rows::-webkit-scrollbar-track{background:0 0}.ai-anchor-rows::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px}.ai-anchor-row{align-items:center;gap:14px;padding:12px 24px;transition:background .1s;display:flex}.ai-anchor-row:hover{background:var(--s2)}.ai-anchor-left{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.ai-anchor-label-row{align-items:center;gap:7px;display:flex}.ai-anchor-badge{background:var(--purple);width:18px;height:18px;color:var(--bg);font-size:9px;font-weight:700;font-family:var(--font-ui);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.ai-anchor-label{letter-spacing:.06em;text-transform:uppercase;color:var(--t3);font-size:10px;font-weight:600;font-family:var(--font-ui)}.ai-anchor-original{font-family:var(--font-code);color:var(--t1);background:var(--s3);border:1px solid var(--b2);text-overflow:ellipsis;white-space:nowrap;border-radius:5px;max-width:100%;padding:4px 10px;font-size:12.5px;font-weight:500;display:inline-block;overflow:hidden}.ai-anchor-desc{color:var(--t4);font-size:10.5px;font-family:var(--font-ui);margin-top:1px}.ai-anchor-arrow{color:var(--t4);flex-shrink:0;align-items:center;display:flex}.ai-anchor-right{flex:1;min-width:0}.ai-anchor-input{background:var(--s2);border:1px solid var(--b2);width:100%;height:38px;font-family:var(--font-code);color:var(--t1);border-radius:8px;outline:none;padding:0 14px;font-size:12.5px;transition:border-color .12s,background .12s}.ai-anchor-input:focus{border-color:var(--purple);background:var(--s1)}.ai-anchor-input::placeholder{color:var(--t4);font-style:italic}.ai-ex-pane{flex-direction:column;gap:22px;padding:20px 24px 6px;display:flex}.ai-ex-step{flex-direction:column;gap:10px;display:flex}.ai-ex-step-head{font-family:var(--font-ui);color:var(--t1);flex-wrap:wrap;align-items:center;gap:10px;font-size:13px;font-weight:600;display:flex}.ai-ex-step-num{background:var(--t1);width:22px;height:22px;color:var(--bg);font-family:var(--font-code);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:600;display:inline-flex}.ai-ex-step-meta{color:var(--t4);font-size:10.5px;font-weight:400}.ai-ex-hint{font-family:var(--font-ui);color:var(--t3);margin-top:-2px;font-size:11.5px;line-height:1.5}.ai-ex-hint strong{color:var(--t1);font-weight:600}.ai-fam{background:var(--s1);border:1px solid var(--b1);border-radius:8px;flex-direction:column;gap:6px;padding:12px;display:flex}.ai-fam-row{align-items:center;gap:10px;display:flex}.ai-fam-row.is-root .ai-fam-orig{color:var(--t1);font-weight:600}.ai-fam-row.is-root .ai-anchor-input{border-color:var(--purple)}.ai-fam-orig-col{flex:0 0 38%;align-items:center;gap:6px;min-width:0;display:inline-flex}.ai-fam-tree{color:var(--t4);font-family:var(--font-code);flex-shrink:0;padding-left:4px;font-size:13px;line-height:1}.ai-fam-orig{font-family:var(--font-code);color:var(--t2);background:var(--bg);border:1px solid var(--b1);text-overflow:ellipsis;white-space:nowrap;border-radius:4px;flex:1;min-width:0;padding:6px 10px;font-size:11.5px;overflow:hidden}.ai-fam-tag{font-family:var(--font-code);text-transform:uppercase;letter-spacing:.08em;background:var(--purple);color:#fff;border-radius:3px;flex-shrink:0;padding:2px 6px;font-size:9px;font-weight:600}.ai-fam-arrow{color:var(--t4);flex-shrink:0;font-size:12px}.ai-fam-row .ai-anchor-input{flex:1;height:34px}.ai-anchor-input.is-suggested{color:var(--t3);font-style:italic}.ai-anchor-input.is-suggested:focus{color:var(--t1);font-style:normal}.ai-helpers{flex-wrap:wrap;align-items:center;gap:6px;padding:2px 0;display:flex}.ai-helpers-label{font-family:var(--font-ui);color:var(--t3);margin-right:2px;font-size:11px}.ai-helpers-sep{color:var(--b2);margin:0 2px}.ai-helper-chip{font-family:var(--font-ui);color:var(--t2);background:var(--bg);border:1px solid var(--b1);cursor:pointer;border-radius:4px;align-items:center;gap:4px;padding:5px 10px;font-size:11px;font-weight:500;transition:border-color .12s,background .12s,color .12s;display:inline-flex}.ai-helper-chip:hover{border-color:var(--t3);color:var(--t1)}.ai-helper-chip.is-on{background:var(--t1);color:var(--bg);border-color:var(--t1)}.ai-helper-chip.is-primary{background:var(--purple);color:#fff;border-color:var(--purple)}.ai-helper-chip:disabled{opacity:.4;cursor:not-allowed}.ai-helper-chip code{font-family:var(--font-code);background:#ffffff1f;border-radius:2px;padding:0 4px;font-size:10.5px}.ai-helper-chip:not(.is-on) code{background:var(--s3);color:var(--t1)}.ai-helper-prefix{background:var(--bg);border:1px solid var(--b2);width:110px;height:26px;font-family:var(--font-code);color:var(--t1);border-radius:4px;outline:none;padding:0 8px;font-size:11px}.ai-helper-prefix:focus{border-color:var(--purple)}.ai-helper-prefix::placeholder{color:var(--t4)}.ai-other-fams{font-family:var(--font-ui);color:var(--t4);flex-wrap:wrap;align-items:baseline;gap:8px;padding:4px 0 0;font-size:11px;display:flex}.ai-other-fams-lbl{color:var(--t3)}.ai-other-fams-list{flex-wrap:wrap;align-items:center;gap:6px;display:inline-flex}.ai-other-fams-list code{font-family:var(--font-code);background:var(--s2);border:1px solid var(--b1);color:var(--t3);border-radius:3px;padding:1px 6px;font-size:10.5px}.ai-other-fams-more{color:var(--t4)}.ai-dataattrs-section{border-top:1px solid var(--b1);flex-shrink:0}.ai-dataattrs-toggle{width:100%;font-size:11px;font-family:var(--font-ui);color:var(--t4);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:7px;padding:9px 20px;transition:color .12s;display:flex}.ai-dataattrs-toggle:hover{color:var(--t2)}.ai-dataattrs-note{color:var(--t4);opacity:.7;margin-left:2px;font-size:10px}.ai-dataattrs-list{flex-wrap:wrap;gap:5px;padding:4px 20px 12px;display:flex}.ai-dataattrs-list--preview{flex-direction:column;gap:2px}.ai-dataattr-row{align-items:center;gap:8px;display:flex}.ai-mapping-col-headers{border-bottom:1px solid var(--b1);align-items:center;padding:10px 20px 8px;display:flex}.ai-mapping-col-headers--check{gap:8px}.ai-col-lbl{letter-spacing:.08em;text-transform:uppercase;color:var(--t4);font-size:10px;font-weight:600;font-family:var(--font-ui);flex:1}.ai-col-lbl--right{padding-left:36px}.ai-col-hint{text-transform:none;letter-spacing:0;color:var(--t4);opacity:.7;margin-left:6px;font-size:10px;font-weight:400}.ai-mapping-scroll{flex:1;max-height:320px;padding:6px 0;overflow-y:auto}.ai-mapping-scroll::-webkit-scrollbar{width:4px}.ai-mapping-scroll::-webkit-scrollbar-track{background:0 0}.ai-mapping-scroll::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px}.ai-mapping-row{align-items:center;gap:10px;padding:5px 20px;transition:background .1s,opacity .15s;display:flex}.ai-mapping-row:hover{background:var(--s2)}.ai-mapping-row--unchecked{opacity:.4}.ai-mapping-row--unchecked:hover{opacity:.65}.ai-mapping-original,.ai-mapping-new{flex:1;min-width:0}.ai-mapping-arrow{color:var(--t4);flex-shrink:0;justify-content:center;align-items:center;width:16px;display:flex}.ai-class-pill{text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-family:var(--font-code);color:var(--t2);background:var(--s3);border:1px solid var(--b2);border-radius:4px;padding:2px 7px;font-size:11.5px;display:inline-block;overflow:hidden}.ai-class-pill--data{color:var(--yellow,#d4a520);background:#d4a52014;border-color:#d4a52033}[data-theme=dark] .ai-class-pill--data{color:#e8c060;background:#e8c06014;border-color:#e8c0602e}.ai-mapping-input{background:var(--s2);border:1px solid var(--b2);width:100%;height:30px;font-family:var(--font-code);color:var(--t1);border-radius:6px;outline:none;padding:0 10px;font-size:11.5px;transition:border-color .12s,background .12s}.ai-mapping-input:focus{border-color:var(--purple);background:var(--s1)}.ai-mapping-input::placeholder{color:var(--t4)}.ai-mapping-input--suggested{border-color:var(--accent-dim);background:var(--purple-dim,var(--accent-dim))}.ai-mapping-input--suggested:focus{border-color:var(--purple)}[data-theme=dark] .ai-mapping-input--suggested{background:var(--accent-dim)}.ai-mapping-input--muted{opacity:.4;cursor:not-allowed;background:var(--s2)!important;border-color:var(--b1)!important}.ai-row-check{cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;display:inline-flex}.ai-row-check-input{opacity:0;pointer-events:none;width:0;height:0;position:absolute}.ai-row-check-box{border:1.5px solid var(--b2);background:var(--s2);border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;width:14px;height:14px;transition:border-color .12s,background .12s;display:flex}.ai-row-check:hover .ai-row-check-box{border-color:var(--purple)}.ai-row-check-input:checked+.ai-row-check-box{background:var(--purple);border-color:var(--purple)}.ai-row-check-input:checked+.ai-row-check-box:after{content:"";border-bottom:1.5px solid #fff;border-left:1.5px solid #fff;width:7px;height:4px;display:block;transform:translateY(-1px)rotate(-45deg)}.ai-select-all{flex-shrink:0}.ai-mapping-status{font-size:11px;font-family:var(--font-code);color:var(--t3);border-top:1px solid var(--b1);flex-shrink:0;padding:8px 20px}.ai-mapping-status.err{color:var(--red)}.ai-mapping-status.running{color:var(--purple)}.ai-modal-footer--mapping{border-top:1px solid var(--b1);flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:12px 20px;display:flex}.ai-map-count{font-size:11px;font-family:var(--font-code);color:var(--t4);flex-shrink:0}.ai-footer-btns{align-items:center;gap:8px;display:flex}.btn-ai-fill{background:var(--s2);border:1px solid var(--b2);height:32px;font-family:var(--font-ui);color:var(--t2);cursor:pointer;border-radius:7px;align-items:center;gap:5px;padding:0 13px;font-size:12px;font-weight:500;transition:all .12s;display:inline-flex}.btn-ai-fill:hover:not(:disabled){background:var(--s3);color:var(--t1)}.btn-ai-fill:disabled{opacity:.45;cursor:not-allowed}.btn-undo-rename{border:1px dashed var(--b2);width:100%;font-family:var(--font-ui);color:var(--t4);cursor:pointer;text-align:left;background:0 0;border-radius:7px;align-items:center;gap:7px;margin-top:5px;padding:7px 14px;font-size:11.5px;transition:all .12s;display:flex}.btn-undo-rename:hover{color:var(--t2);border-color:var(--b2);background:var(--s2);border-style:solid}.btn-undo-rename svg{flex-shrink:0}.btn-undo-label{white-space:nowrap;flex-shrink:0;font-weight:500}.btn-undo-meta{color:var(--t4);font-size:10.5px;font-family:var(--font-code);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.btn-undo-count{background:var(--s3);border:1px solid var(--b2);color:var(--t4);font-size:10px;font-weight:600;font-family:var(--font-code);border-radius:100px;flex-shrink:0;margin-left:auto;padding:1px 6px}.diff-overlay{z-index:1000;opacity:0;visibility:hidden;background:#15131373;flex-direction:column;transition:opacity .2s,visibility .2s;display:flex;position:fixed;inset:0}[data-theme=dark] .diff-overlay{background:#000000a6}.diff-overlay.show{opacity:1;visibility:visible}.diff-modal{background:var(--s1);border:1px solid var(--b2);border-radius:10px;flex-direction:column;flex:1;margin:24px;transition:transform .2s;display:flex;overflow:hidden;transform:translateY(10px);box-shadow:0 8px 40px #00000024}.diff-overlay.show .diff-modal{transform:translateY(0)}.diff-header{border-bottom:1px solid var(--b1);flex-shrink:0;align-items:center;gap:12px;height:52px;padding:0 22px;display:flex}.diff-title{color:var(--t1);white-space:nowrap;font-size:13px;font-weight:500}.diff-title em{color:var(--purple);font-style:normal}.diff-subtitle{font-size:11px;font-family:var(--font-code);color:var(--t3);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.diff-legend{flex-shrink:0;align-items:center;gap:8px;display:flex}.diff-legend-item{letter-spacing:.06em;text-transform:uppercase;border-radius:100px;padding:2px 8px;font-size:10px;font-weight:500}.diff-legend-item.del{color:#b83020;background:#d940301f}.diff-legend-item.add{background:var(--accent-dim);color:var(--accent)}[data-theme=dark] .diff-legend-item.del{color:#e07060;background:#e050402e}[data-theme=dark] .diff-legend-item.add{background:var(--accent-dim);color:var(--accent)}.diff-header-btns{flex-shrink:0;gap:8px;display:flex}.btn-diff-reject{border:1px solid var(--b2);height:34px;color:var(--t3);font-family:var(--font-ui);cursor:pointer;background:0 0;border-radius:6px;padding:0 18px;font-size:12px;transition:all .1s}.btn-diff-reject:hover{color:var(--red);background:#d940300d;border-color:#d9403047}.btn-diff-accept{background:var(--purple);height:34px;color:var(--bg);font-family:var(--font-ui);cursor:pointer;border:none;border-radius:6px;align-items:center;gap:6px;padding:0 18px;font-size:12px;font-weight:500;transition:opacity .12s,transform 80ms;display:flex}.btn-diff-accept:hover{opacity:.88}.btn-diff-accept:active{transform:translateY(1px)}.diff-tabs{background:var(--s2);border-bottom:1px solid var(--b1);flex-shrink:0;align-items:stretch;height:38px;display:flex}.diff-tab{letter-spacing:.06em;text-transform:uppercase;color:var(--t3);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;padding:0 20px;font-size:11px;font-weight:500;transition:color .1s,border-color .1s;display:flex;position:relative;top:1px}.diff-tab:hover{color:var(--t2)}.diff-tab.is-active{color:var(--t1);border-bottom-color:var(--purple)}.diff-body{flex:1;display:flex;overflow:hidden}.diff-col{border-right:1px solid var(--b1);flex-direction:column;flex:1;display:flex;overflow:hidden}.diff-col:last-child{border-right:none}.diff-col-head{background:var(--s2);border-bottom:1px solid var(--b1);letter-spacing:.1em;text-transform:uppercase;flex-shrink:0;align-items:center;height:30px;padding:0 18px;font-size:10px;font-weight:500;display:flex}.diff-col-head.before{color:var(--t4)}.diff-col-head.after{color:var(--purple)}.diff-panel{flex:1;display:none;overflow:hidden}.diff-panel.is-active{display:flex}.diff-code{white-space:pre;width:100%;font-family:var(--font-code);-webkit-font-smoothing:antialiased;border:none;outline:none;flex:1;padding:18px 20px;font-size:12px;line-height:1.8;overflow:auto}.diff-code.before{background:var(--ed-bg);color:var(--t3)}.diff-code.after{color:#4a3fa0;background:#f7f5ff}[data-theme=dark] .diff-code.after{color:#a898f0;background:#1a1830}.dhl-del{background:#d940300e;border-left:2px solid #d940304d;margin-left:-8px;padding-left:6px;display:block}.dhl-add{background:var(--accent-dim);border-left:2px solid var(--accent);margin-left:-8px;padding-left:6px;display:block}.dhl-pad{color:#0000;-webkit-user-select:none;user-select:none;background:repeating-linear-gradient(45deg,#0000,#0000 4px,#00000006 4px 8px);display:block}.dhm-del{color:#b83020;background:#d9403029;border-radius:2px;padding:0 1px;font-weight:500}.dhm-add{background:var(--accent-dim);color:var(--accent-dark);border-radius:2px;padding:0 1px;font-weight:600}[data-theme=dark] .dhl-del{background:#e0504014;border-left-color:#e0504059}[data-theme=dark] .dhl-add{background:var(--accent-dim);border-left-color:var(--accent)}[data-theme=dark] .dhm-del{color:#e07868;background:#e0504038}[data-theme=dark] .dhm-add{background:var(--accent-dim);color:var(--accent)}.diff-refine{border-top:1px solid var(--b1);background:var(--s2);flex-direction:column;flex-shrink:0;gap:7px;padding:10px 16px 12px;display:flex}.diff-refine-label{letter-spacing:.07em;text-transform:uppercase;color:var(--purple);align-items:center;gap:6px;font-size:10px;font-weight:600;display:flex}.diff-refine-row{align-items:center;gap:8px;display:flex}.diff-refine-input{background:var(--s1);border:1px solid var(--b2);height:34px;font-family:var(--font-ui);color:var(--t1);border-radius:6px;outline:none;flex:1;padding:0 12px;font-size:12px;transition:border-color .1s}.diff-refine-input::placeholder{color:var(--t4)}.diff-refine-input:focus{border-color:var(--purple)}.diff-refine-input:disabled{opacity:.5;cursor:not-allowed}.btn-diff-refine{background:var(--accent);height:34px;color:var(--bg);font-family:var(--font-ui);cursor:pointer;white-space:nowrap;border:none;border-radius:6px;justify-content:center;align-items:center;gap:6px;padding:0 16px;font-size:12px;font-weight:500;transition:opacity .12s,transform 80ms,filter .12s;display:flex}.btn-diff-refine:hover:not(:disabled){filter:brightness(1.12)}.btn-diff-refine:active:not(:disabled){transform:translateY(1px)}.btn-diff-refine:disabled{opacity:.4;cursor:not-allowed}.diff-refine-spinner{border:1.5px solid #ffffff4d;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:11px;height:11px;animation:.5s linear infinite spin;display:none}.btn-diff-refine.loading .diff-refine-spinner{display:block}.btn-diff-refine.loading .diff-refine-lbl{opacity:.6}.diff-refine-err{font-size:11px;font-family:var(--font-code);color:var(--red)}.shortcuts-overlay{z-index:2000;background:#15131366;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}[data-theme=dark] .shortcuts-overlay{background:#0009}.shortcuts-modal{background:var(--s1);border:1px solid var(--b2);border-radius:12px;width:90%;min-width:320px;max-width:400px;padding:24px;animation:.15s slideUp;box-shadow:0 12px 48px #00000024}.shortcuts-title{color:var(--t1);margin-bottom:16px;font-size:13px;font-weight:600}.shortcuts-list{flex-direction:column;gap:8px;margin-bottom:20px;display:flex}.shortcut-row{align-items:center;gap:12px;display:flex}.shortcut-key{font-family:var(--font-code);color:var(--t2);background:var(--s3);border:1px solid var(--b2);white-space:nowrap;text-align:center;border-radius:5px;flex-shrink:0;min-width:100px;padding:3px 10px;font-size:11px}.shortcut-label{color:var(--t3);font-size:12px}.shortcuts-close{background:var(--s2);border:1px solid var(--b2);width:100%;height:36px;color:var(--t2);cursor:pointer;border-radius:6px;font-size:12px;font-weight:500;transition:all .1s;display:block}.shortcuts-close:hover{background:var(--s3);color:var(--t1)}.toast{bottom:32px;left:calc(var(--sw) / 2);opacity:0;visibility:hidden;background:var(--s1);color:var(--t1);border:1px solid var(--b2);white-space:nowrap;z-index:9999;pointer-events:none;border-radius:8px;align-items:center;gap:9px;padding:9px 18px 9px 12px;font-size:12.5px;font-weight:400;transition:opacity .18s,transform .18s,visibility .18s;display:flex;position:fixed;transform:translate(-50%)translateY(8px);box-shadow:0 4px 20px #0000001a}.toast.show{opacity:1;visibility:visible;transform:translate(-50%)translateY(0)}.toast-bar{border-radius:1px;flex-shrink:0;width:2px;height:16px}.toast-bar.success{background:var(--green)}.toast-bar.info{background:var(--accent)}.toast-bar.error{background:var(--red)}.js-refine-overlay{z-index:10;background:var(--ed-bg);opacity:.92;color:var(--t3);font-size:13px;font-family:var(--font-ui);flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex;position:absolute;inset:0}.js-refine-spinner{border:2px solid var(--b2);border-top-color:var(--accent);border-radius:50%;width:18px;height:18px;animation:.6s linear infinite spin}.js-tab-spinner{border:1.5px solid var(--b2);border-top-color:var(--accent);vertical-align:middle;border-radius:50%;width:10px;height:10px;margin-left:5px;animation:.6s linear infinite spin;display:inline-block}.ai-cleaned-badge{color:var(--accent);vertical-align:middle;justify-content:center;align-items:center;margin-left:5px;font-size:9px;font-weight:700;display:inline-flex}.sidebar ::-webkit-scrollbar{width:4px}.sidebar ::-webkit-scrollbar-track{background:0 0}.sidebar ::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px}textarea.code::-webkit-scrollbar{width:5px}.diff-code::-webkit-scrollbar{width:5px}.decode-output-pre::-webkit-scrollbar{width:5px}textarea.code::-webkit-scrollbar-track{background:0 0}.diff-code::-webkit-scrollbar-track{background:0 0}.decode-output-pre::-webkit-scrollbar-track{background:0 0}textarea.code::-webkit-scrollbar-thumb{background:var(--b3);border-radius:2px}.diff-code::-webkit-scrollbar-thumb{background:var(--b3);border-radius:2px}.decode-output-pre::-webkit-scrollbar-thumb{background:var(--b3);border-radius:2px}@media (width<=640px){:root{--sw:100%}.app{flex-direction:column}.sidebar{border-right:none;border-bottom:1px solid var(--b1);width:100%;max-height:280px}.sidebar--closed{max-height:0;width:100%!important}.desc,.stats-wrap{display:none!important}.actions{flex-direction:row;padding:8px 10px 12px}.btn-convert{flex:1;height:40px}.statusbar{display:none}.diff-modal{border-radius:0;margin:0}.sidebar-toggle{display:none}.mode-switcher{padding:6px 8px}.decode-waiting{padding:32px 20px}.decode-waiting-steps{min-width:unset}}.sidebar-footer{border-top:1px solid var(--b1);flex-shrink:0;align-items:center;gap:8px;margin-top:auto;padding:10px 16px 14px;display:flex}.sidebar-footer-link{font-family:var(--font-ui);color:var(--t4);font-size:11px;text-decoration:none;transition:color .1s}.sidebar-footer-link:hover{color:var(--t2)}.sidebar-footer-sep{background:var(--b2);border-radius:50%;flex-shrink:0;width:3px;height:3px}.sp-wrap{background:var(--bg);min-height:100svh;color:var(--t1);font-family:var(--font-ui);flex-direction:column;display:flex}.sp-nav{background:var(--s1);border-bottom:1px solid var(--b1);z-index:100;flex-shrink:0;align-items:center;gap:12px;height:52px;padding:0 24px;display:flex;position:sticky;top:0}.sp-nav-logo{align-items:center;text-decoration:none;display:flex}.sp-nav-links{align-items:center;gap:4px;margin-left:8px;display:flex}.sp-nav-link{color:var(--t3);border-radius:6px;padding:5px 10px;font-size:13px;text-decoration:none;transition:color .1s,background .1s}.sp-nav-link:hover{color:var(--t1);background:var(--s2)}.sp-nav-right{align-items:center;gap:8px;margin-left:auto;display:flex}.sp-dark-toggle{color:var(--t3)}.sp-nav-back{background:var(--s2);border:1px solid var(--b1);height:32px;color:var(--t2);border-radius:7px;align-items:center;gap:6px;padding:0 12px;font-size:12px;font-weight:500;text-decoration:none;transition:all .1s;display:flex}.sp-nav-back:hover{background:var(--s3);border-color:var(--b2);color:var(--t1)}.sp-footer{color:var(--t4);border-top:1px solid var(--b1);justify-content:center;align-items:center;gap:8px;margin-top:auto;padding:20px 24px;font-size:11.5px;display:flex}.sp-footer-sep{color:var(--b2)}.sp-footer-link{color:var(--t4);text-decoration:none;transition:color .1s}.sp-footer-link:hover{color:var(--t2)}.docs-layout{flex:1;align-items:flex-start;gap:56px;width:100%;max-width:1100px;margin:0 auto;padding:48px 24px 64px;display:flex}.docs-toc{flex-shrink:0;width:196px;max-height:calc(100svh - 80px);position:sticky;top:72px;overflow-y:auto}.docs-toc-label{letter-spacing:.1em;text-transform:uppercase;color:var(--t4);margin-bottom:10px;padding:0 2px;font-size:10px;font-weight:700}.docs-toc-item{text-align:left;width:100%;font-family:var(--font-ui);color:var(--t3);cursor:pointer;background:0 0;border:none;border-left:2px solid #0000;border-radius:6px;margin-bottom:1px;padding:5px 10px;font-size:12.5px;transition:color .1s,background .1s;display:block}.docs-toc-item:hover{color:var(--t1);background:var(--s2)}.docs-toc-item.active{color:var(--accent);border-left-color:var(--accent);background:var(--accent-dim)}.docs-main{flex:1;min-width:0}.docs-section{margin-top:-20px;padding-top:64px}.docs-section:first-child{margin-top:0;padding-top:0}.docs-badge{color:var(--yellow);letter-spacing:.08em;text-transform:uppercase;background:#9a70201f;border:1px solid #9a702038;border-radius:100px;margin-bottom:14px;padding:3px 10px;font-size:10px;font-weight:700;display:inline-block}[data-theme=dark] .docs-badge{color:#e8c060;background:#e8c0601a;border-color:#e8c06033}.docs-h1{letter-spacing:-.03em;color:var(--t1);margin:0 0 14px;font-size:30px;font-weight:700;line-height:1.15}.docs-h2{letter-spacing:-.02em;color:var(--t1);margin:0 0 12px;font-size:20px;font-weight:600;line-height:1.2}.docs-h3{color:var(--t1);margin:24px 0 8px;font-size:14px;font-weight:600}.docs-lead{color:var(--t2);margin:0 0 20px;font-size:15px;line-height:1.65}.docs-main p{color:var(--t2);margin:0 0 14px;font-size:14px;line-height:1.7}.docs-link{color:var(--accent);text-decoration:none}.docs-link:hover{text-decoration:underline}.docs-callout{border-radius:8px;margin:0 0 20px;padding:13px 16px;font-size:13.5px;line-height:1.6}.docs-callout--warn{color:var(--t2);background:#9a702014;border:1px solid #9a702033}.docs-callout--info{background:var(--accent-dim);border:1px solid var(--accent-dim);color:var(--t2)}[data-theme=dark] .docs-callout--warn{background:#e8c06012;border-color:#e8c0602e}[data-theme=dark] .docs-callout--info{background:var(--accent-dim);border-color:var(--accent-dim)}.docs-code{font-family:var(--font-code);background:var(--s3);border:1px solid var(--b2);color:var(--t2);border-radius:4px;padding:1px 6px;font-size:.88em}.docs-steps{flex-direction:column;gap:2px;margin:0 0 20px;display:flex}.docs-step{border-bottom:1px solid var(--b1);align-items:flex-start;gap:14px;padding:12px 0;display:flex}.docs-step:last-child{border-bottom:none}.docs-step-num{background:var(--accent-dim);border:1px solid var(--accent-dim);width:24px;height:24px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;font-size:11px;font-weight:700;display:flex}.docs-step-body{color:var(--t2);flex:1;font-size:13.5px;line-height:1.65}.docs-step-body strong{color:var(--t1)}.docs-kbd{background:var(--s2);border:1px solid var(--b2);font-family:var(--font-code);color:var(--t2);border-bottom-width:2px;border-radius:5px;padding:2px 7px;font-size:11px;display:inline-block}.docs-list{margin:0 0 20px;padding-left:20px}.docs-list li{color:var(--t2);margin-bottom:8px;font-size:13.5px;line-height:1.7}.docs-list li strong{color:var(--t1)}.docs-table-wrap{border:1px solid var(--b1);border-radius:8px;margin:0 0 20px;overflow-x:auto}.docs-table{border-collapse:collapse;width:100%;font-size:13px}.docs-table thead{background:var(--s2)}.docs-table th{text-align:left;letter-spacing:.08em;text-transform:uppercase;color:var(--t4);border-bottom:1px solid var(--b1);white-space:nowrap;padding:10px 14px;font-size:10px;font-weight:700}.docs-table td{border-bottom:1px solid var(--b1);color:var(--t2);vertical-align:middle;padding:9px 14px}.docs-table tr:last-child td{border-bottom:none}.docs-table tr:hover td{background:var(--s2)}.docs-td-muted{color:var(--t3)!important;font-size:12px!important}.docs-wf-badge{background:var(--purple-dim);border:1px solid var(--purple-border);color:var(--purple);white-space:nowrap;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.docs-tier-badge{background:var(--accent-dim);border:1px solid var(--accent-dim);color:var(--accent);letter-spacing:.02em;vertical-align:middle;border-radius:100px;margin-left:8px;padding:2px 9px;font-size:11px;font-weight:600;display:inline-block}@media (width<=768px){.docs-layout{gap:0;padding:28px 16px 48px}.docs-toc{display:none}}.feedback-layout{flex:1;justify-content:center;align-items:flex-start;padding:48px 24px 64px;display:flex}.feedback-card{background:var(--s1);border:1px solid var(--b1);border-radius:12px;width:100%;max-width:560px;overflow:hidden}.feedback-header{padding:28px 28px 0}.feedback-title{letter-spacing:-.025em;color:var(--t1);margin:0 0 6px;font-size:22px;font-weight:700}.feedback-subtitle{color:var(--t3);margin:0;font-size:13.5px;line-height:1.5}.feedback-types{gap:6px;padding:18px 28px 0;display:flex}.feedback-type-btn{background:var(--s2);border:1px solid var(--b1);height:34px;font-family:var(--font-ui);color:var(--t3);cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;gap:7px;padding:0 14px;font-size:12.5px;transition:all .1s;display:flex}.feedback-type-btn:hover{color:var(--t1);border-color:var(--b2);background:var(--s3)}.feedback-type-btn.active{color:var(--accent);border-color:var(--accent-dim);background:var(--accent-dim)}.feedback-form{flex-direction:column;gap:14px;padding:18px 28px 24px;display:flex}.feedback-row{gap:12px;display:flex}.feedback-row .feedback-field{flex:1}.feedback-field{flex-direction:column;gap:5px;display:flex}.feedback-label{color:var(--t3);letter-spacing:.02em;font-size:11.5px;font-weight:600}.feedback-input{background:var(--s2);border:1px solid var(--b2);height:38px;font-family:var(--font-ui);color:var(--t1);border-radius:7px;outline:none;padding:0 12px;font-size:13px;transition:border-color .12s,background .12s}.feedback-input:focus{border-color:var(--accent);background:var(--s1)}.feedback-input::placeholder{color:var(--t4)}.feedback-textarea{resize:vertical;background:var(--s2);border:1px solid var(--b2);min-height:120px;font-family:var(--font-ui);color:var(--t1);border-radius:7px;outline:none;padding:10px 12px;font-size:13px;line-height:1.6;transition:border-color .12s,background .12s}.feedback-textarea:focus{border-color:var(--accent);background:var(--s1)}.feedback-textarea::placeholder{color:var(--t4)}.feedback-error{color:var(--red);background:#d9403012;border:1px solid #d9403033;border-radius:7px;align-items:center;gap:7px;padding:10px 13px;font-size:12.5px;display:flex}.feedback-btn-submit{background:var(--accent);width:100%;height:42px;color:var(--bg);font-family:var(--font-ui);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;font-size:13px;font-weight:600;transition:opacity .12s,transform 80ms;display:flex}.feedback-btn-submit:hover:not(:disabled){opacity:.9}.feedback-btn-submit:active:not(:disabled){transform:translateY(1px)}.feedback-btn-submit:disabled{opacity:.5;cursor:not-allowed}.feedback-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.5s linear infinite spin}.feedback-success{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:48px 28px;display:flex}.feedback-success-icon{color:var(--green);margin-bottom:4px}.feedback-success-title{letter-spacing:-.02em;color:var(--t1);margin:0;font-size:20px;font-weight:700}.feedback-success-sub{color:var(--t3);max-width:340px;margin:0;font-size:13.5px;line-height:1.5}.feedback-success-actions{gap:10px;margin-top:8px;display:flex}.feedback-btn-secondary{background:var(--s2);border:1px solid var(--b2);height:38px;color:var(--t2);font-family:var(--font-ui);cursor:pointer;border-radius:8px;padding:0 20px;font-size:13px;transition:all .1s}.feedback-btn-secondary:hover{background:var(--s3);color:var(--t1)}.feedback-btn-primary{background:var(--accent);height:38px;color:var(--bg);font-family:var(--font-ui);border-radius:8px;justify-content:center;align-items:center;padding:0 20px;font-size:13px;font-weight:600;text-decoration:none;transition:opacity .1s;display:flex}.feedback-btn-primary:hover{opacity:.88}@media (width<=640px){.feedback-layout{padding:24px 16px 48px}.feedback-card{border-radius:10px}.feedback-header{padding:22px 20px 0}.feedback-types{flex-wrap:wrap;padding:14px 20px 0}.feedback-form{padding:16px 20px 20px}.feedback-row{flex-direction:column}}.terms-layout{flex:1;justify-content:center;padding:48px 24px 64px;display:flex}.terms-content{width:100%;max-width:720px}.terms-meta{color:var(--t4);margin-bottom:16px;font-size:11.5px}.terms-content .docs-h2{border-top:1px solid var(--b1);margin-top:36px;padding-top:28px;font-size:16px}.terms-content .docs-h2:first-of-type{margin-top:28px}.terms-content p{color:var(--t2);margin:0 0 14px;font-size:14px;line-height:1.75}.terms-content .docs-list{margin-bottom:14px}@media (width<=640px){.terms-layout{padding:28px 16px 48px}}*,:before,:after{border-radius:0!important}.rd-spinner,.feedback-spinner,[class*=spinner],.sdot,.tab-dirty,.topbar-dirty,.dot,.status-dot,.step-num,.step-number,[class*=step-num],[class*=-avatar],.cl-userButtonAvatarBox,.cl-userButtonAvatarImage,.cl-avatarBox,[class*=cl-avatar]{border-radius:50%!important}:root{--rd-rule-w:1px;--rd-rule-color:var(--color-rule);--rd-rule-soft:#0004eb38;--rd-marker-bg:var(--color-bg-solid);--rd-card-radius:.125rem;--rd-edge-tick:.5rem}.dark{--rd-rule-soft:#f4efe438}.rd-page{background:var(--color-bg);width:100%;height:100vh;color:var(--color-fg);font-family:var(--font-family-sans);position:relative;overflow:hidden auto}.rd-page::-webkit-scrollbar{width:.5rem}.rd-page::-webkit-scrollbar-track{background:0 0}.rd-page::-webkit-scrollbar-thumb{background:var(--rd-rule-soft);border-radius:999px}.rd-grid{pointer-events:none;z-index:0;position:absolute;inset:0}.rd-grid:before,.rd-grid:after{content:"";border-left:var(--rd-rule-w) dashed var(--rd-rule-soft);width:0;position:absolute;top:0;bottom:0}.rd-grid:before{left:var(--layout-col-left)}.rd-grid:after{right:var(--layout-col-right)}.rd-grid-ticks{width:var(--rd-edge-tick);background-image:linear-gradient(to bottom, var(--rd-rule-soft) 0, var(--rd-rule-soft) var(--rd-rule-w), transparent var(--rd-rule-w), transparent var(--space-1-5));background-size:100% var(--space-1-5);background-repeat:repeat-y;position:absolute;top:0;bottom:0}.rd-grid-ticks.left{left:0}.rd-grid-ticks.right{right:0;transform:scaleX(-1)}.rd-rule{border-top:var(--rd-rule-w) dashed var(--rd-rule-soft);height:0;position:relative}.rd-container{z-index:1;width:100%;max-width:var(--size-container-max);padding-left:var(--layout-col-left);padding-right:var(--layout-col-right);margin:0 auto;position:relative}.rd-container-wide{z-index:1;width:100%;padding-left:var(--layout-col-left);padding-right:var(--layout-col-right);position:relative}.rd-marker{top:calc(var(--space-2-5) * -1);align-items:center;gap:var(--space-0-25);padding:var(--space-0-25) var(--space-0-5);background:var(--color-bg-solid);border:var(--rd-rule-w) solid var(--rd-rule-soft);border-radius:var(--rd-card-radius);font-family:var(--font-family-mono);font-size:var(--font-size-text-small);letter-spacing:var(--letter-spacing-normal);color:var(--color-fg-muted);white-space:nowrap;z-index:2;display:inline-flex;position:absolute}.rd-marker.left{left:calc(var(--space-1) * -1)}.rd-marker.right{right:calc(var(--space-1) * -1)}.rd-marker.center{left:50%;transform:translate(-50%)}.rd-eyebrow{align-items:center;gap:var(--space-0-5);font-family:var(--font-family-mono);font-size:var(--font-size-text-small);letter-spacing:var(--letter-spacing-caps);text-transform:uppercase;color:var(--color-fg-muted);margin:0 0 var(--space-1-5);display:inline-flex}.rd-eyebrow:before{content:"//";opacity:.55}.rd-display{font-family:var(--font-family-heading);font-size:var(--font-size-display);line-height:var(--line-height-display);letter-spacing:var(--letter-spacing-display);font-weight:var(--font-weight-medium);text-transform:uppercase;color:var(--color-fg);margin:0}.rd-h1{font-family:var(--font-family-heading);font-size:var(--font-size-h1);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);font-weight:var(--font-weight-medium);text-transform:uppercase;color:var(--color-fg);margin:0}.rd-h2{font-family:var(--font-family-heading);font-size:var(--font-size-h2);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);font-weight:var(--font-weight-medium);text-transform:uppercase;margin:0 0 var(--space-1-5);color:var(--color-fg)}.rd-h3{font-family:var(--font-family-heading);font-size:var(--font-size-h3);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);font-weight:var(--font-weight-medium);text-transform:uppercase;margin:0 0 var(--space-1);color:var(--color-fg)}.rd-h4{font-family:var(--font-family-heading);font-size:var(--font-size-h4);line-height:var(--line-height-snug);letter-spacing:var(--letter-spacing-tight);font-weight:var(--font-weight-medium);margin:0 0 var(--space-0-75);color:var(--color-fg)}.rd-h-marker{margin-right:var(--space-0-5);color:var(--color-fg-soft);display:inline-block}.rd-lead{font-size:var(--font-size-text-large);line-height:var(--line-height-snug);letter-spacing:var(--letter-spacing-snug);color:var(--color-fg-muted);margin:0 0 var(--space-2);max-width:42em}.rd-prose p{color:var(--color-fg-muted);margin:0 0 var(--space-1);max-width:42em}.rd-prose ul,.rd-prose ol{color:var(--color-fg-muted);margin:0 0 var(--space-1-5);padding-left:var(--space-1-5);max-width:42em}.rd-prose li{margin:var(--space-0-25) 0}.rd-prose a{color:var(--color-fg);text-underline-offset:.2em;text-decoration:underline}.rd-prose code{font-family:var(--font-family-mono);background:var(--rd-rule-soft);border-radius:var(--rd-card-radius);padding:.1em .4em;font-size:.9em}.rd-btn{align-items:center;gap:var(--space-0-5);padding:var(--space-0-75) var(--space-1-5);font-family:var(--font-family-sans);font-size:var(--font-size-text-main);font-weight:var(--font-weight-medium);letter-spacing:var(--letter-spacing-snug);border:var(--rd-rule-w) solid transparent;border-radius:var(--rd-card-radius);cursor:pointer;white-space:nowrap;line-height:1;text-decoration:none;transition:transform .12s,background .18s,color .18s,border-color .18s;display:inline-flex}.rd-btn:active{transform:translateY(1px)}.rd-btn-primary{background:var(--color-fg);color:var(--color-bg-solid);border-color:var(--color-fg)}.rd-btn-primary:hover{background:var(--color-fg-muted)}.rd-btn-secondary{color:var(--color-fg);border-color:var(--color-fg);background:0 0}.rd-btn-secondary:hover{background:var(--color-fg);color:var(--color-bg-solid)}.rd-btn-ghost{color:var(--color-fg-muted);padding:var(--space-0-5) var(--space-0-75);background:0 0;border-color:#0000}.rd-btn-ghost:hover{color:var(--color-fg)}.rd-btn-large{padding:var(--space-1) var(--space-2);font-size:var(--font-size-text-large)}.rd-nav{z-index:20;padding:var(--space-1) var(--layout-col-left);background:var(--color-bg-solid);border-bottom:var(--rd-rule-w) solid var(--rd-rule-soft);justify-content:space-between;align-items:center;transition:border-color .2s;display:flex;position:sticky;top:0}.rd-nav.scrolled{border-bottom-color:var(--color-fg)}.rd-nav-logo{color:var(--color-fg);align-items:center;display:inline-flex}.rd-nav-links{align-items:center;gap:var(--space-2);display:inline-flex}.rd-nav-link{font-family:var(--font-family-sans);font-size:var(--font-size-text-main);color:var(--color-fg);letter-spacing:var(--letter-spacing-snug);text-decoration:none}.rd-nav-link:hover{color:var(--color-fg-muted)}.rd-nav-right{align-items:center;gap:var(--space-0-75);display:inline-flex}.rd-hero{padding:var(--space-6) 0 var(--space-5);text-align:center;position:relative}.rd-hero-eyebrow{align-items:center;gap:var(--space-0-5);margin-bottom:var(--space-2);font-family:var(--font-family-mono);font-size:var(--font-size-text-small);text-transform:uppercase;letter-spacing:var(--letter-spacing-caps);color:var(--color-fg-muted);display:inline-flex}.rd-hero-eyebrow:before,.rd-hero-eyebrow:after{content:"";width:var(--space-2);border-top:var(--rd-rule-w) solid var(--rd-rule-soft);height:0;display:inline-block}.rd-hero-display{margin-bottom:var(--space-1-5)}.rd-hero-display .accent{color:var(--color-fg-muted)}.rd-hero-sub{margin:0 auto var(--space-2-5);max-width:36em;font-size:var(--font-size-text-large);color:var(--color-fg-muted);line-height:var(--line-height-snug)}.rd-hero-cta{gap:var(--space-1);display:inline-flex}.rd-hero-foot{margin-top:var(--space-1);font-family:var(--font-family-mono);font-size:var(--font-size-text-small);color:var(--color-fg-soft);text-transform:uppercase;letter-spacing:var(--letter-spacing-caps)}.rd-section{padding-top:var(--space-5);padding-bottom:var(--space-5);position:relative}.rd-section-inner{position:relative}.rd-tile-strip{gap:var(--space-1);display:flex;overflow:hidden}.rd-tile{aspect-ratio:4/3;border:var(--rd-rule-w) solid var(--rd-rule-soft);border-radius:var(--rd-card-radius);background:var(--color-bg-solid);color:var(--color-fg-soft);font-family:var(--font-family-mono);font-size:var(--font-size-text-small);text-transform:uppercase;letter-spacing:var(--letter-spacing-caps);flex:1 0 16rem;justify-content:center;align-items:center;display:flex}.rd-feature-row{align-items:center;gap:var(--space-4);padding:var(--space-4) 0;border-top:var(--rd-rule-w) dashed var(--rd-rule-soft);grid-template-columns:1fr 1fr;display:grid;position:relative}.rd-feature-row:last-child{border-bottom:var(--rd-rule-w) dashed var(--rd-rule-soft)}.rd-feature-row.reverse>.rd-feature-text{order:2}.rd-feature-row.reverse>.rd-feature-media{order:1}.rd-feature-text{padding:var(--space-2) 0}.rd-feature-text .rd-eyebrow{margin-bottom:var(--space-1)}.rd-feature-text p{margin:0 0 var(--space-1-5);color:var(--color-fg-muted);font-size:var(--font-size-text-main);max-width:28em}.rd-feature-link{align-items:center;gap:var(--space-0-5);color:var(--color-fg);font-family:var(--font-family-mono);font-size:var(--font-size-text-small);text-transform:uppercase;letter-spacing:var(--letter-spacing-caps);text-decoration:none;display:inline-flex}.rd-feature-link:after{content:"→";transition:transform .15s}.rd-feature-link:hover:after{transform:translate(.25em)}.rd-feature-media{aspect-ratio:4/3;border:var(--rd-rule-w) solid var(--rd-rule-soft);border-radius:var(--rd-card-radius);background:linear-gradient(135deg, transparent 49%, var(--rd-rule-soft) 49.5%, var(--rd-rule-soft) 50.5%, transparent 51%), var(--color-bg-solid);color:var(--color-fg-soft);font-family:var(--font-family-mono);font-size:var(--font-size-text-small);text-transform:uppercase;letter-spacing:var(--letter-spacing-caps);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.rd-card-grid{gap:var(--space-1);grid-template-columns:repeat(auto-fit,minmax(15rem,1fr));display:grid}.rd-card{gap:var(--space-0-75);padding:var(--space-1-5);border:var(--rd-rule-w) solid var(--rd-rule-soft);border-radius:var(--rd-card-radius);background:0 0;flex-direction:column;display:flex}.rd-card-media{aspect-ratio:16/10;border-radius:var(--rd-card-radius);background:linear-gradient(135deg, transparent 49%, var(--rd-rule-soft) 49.5%, var(--rd-rule-soft) 50.5%, transparent 51%), var(--color-bg-solid);margin:calc(var(--space-1-5) * -1) calc(var(--space-1-5) * -1) 0;border-radius:var(--rd-card-radius) var(--rd-card-radius) 0 0;border-bottom:var(--rd-rule-w) solid var(--rd-rule-soft)}.rd-card-eyebrow{font-family:var(--font-family-mono);font-size:var(--font-size-text-small);text-transform:uppercase;letter-spacing:var(--letter-spacing-caps);color:var(--color-fg-soft);margin:var(--space-0-5) 0 0}.rd-card-title{font-family:var(--font-family-heading);font-size:var(--font-size-h5);line-height:var(--line-height-snug);letter-spacing:var(--letter-spacing-tight);font-weight:var(--font-weight-medium);text-transform:uppercase;color:var(--color-fg);margin:0}.rd-card-body{font-size:var(--font-size-text-main);color:var(--color-fg-muted);line-height:var(--line-height-snug);margin:0}.rd-stat{padding:var(--space-4) 0;text-align:center}.rd-stat-eyebrow{justify-content:center;display:inline-flex}.rd-stat-number{font-family:var(--font-family-heading);font-size:var(--font-size-display);line-height:var(--line-height-display);letter-spacing:var(--letter-spacing-display);font-weight:var(--font-weight-medium);margin:var(--space-1) 0 var(--space-0-5)}.rd-stat-cap{font-size:var(--font-size-text-main);color:var(--color-fg-muted)}.rd-strip{padding:var(--space-2) 0;text-align:center;border-top:var(--rd-rule-w) dashed var(--rd-rule-soft);border-bottom:var(--rd-rule-w) dashed var(--rd-rule-soft)}.rd-strip-caption{font-family:var(--font-family-mono);font-size:var(--font-size-text-small);text-transform:uppercase;letter-spacing:var(--letter-spacing-caps);color:var(--color-fg-muted);margin-bottom:var(--space-1)}.rd-strip-row{justify-content:space-around;align-items:center;gap:var(--space-3);font-family:var(--font-family-heading);font-size:var(--font-size-h5);font-weight:var(--font-weight-medium);color:var(--color-fg-soft);flex-wrap:wrap;display:flex}.rd-quote{padding:var(--space-4) 0;position:relative}.rd-quote-body{font-family:var(--font-family-mono);font-style:italic;font-size:var(--font-size-h4);line-height:var(--line-height-snug);color:var(--color-fg);max-width:36em;margin:var(--space-2) 0 var(--space-2)}.rd-quote-author{align-items:center;gap:var(--space-0-75);display:flex}.rd-quote-avatar{width:var(--space-3);height:var(--space-3);background:var(--rd-rule-soft);border:var(--rd-rule-w) solid var(--rd-rule-soft);border-radius:999px}.rd-quote-name{font-size:var(--font-size-text-main);font-weight:var(--font-weight-medium);color:var(--color-fg)}.rd-quote-role{font-family:var(--font-family-mono);font-size:var(--font-size-text-small);color:var(--color-fg-muted)}.rd-invert{background:var(--color-klein);color:var(--color-cream);padding:var(--space-5) 0;margin:var(--space-4) 0;--color-fg:var(--color-cream);--color-fg-muted:#f4efe4b3;--color-fg-soft:#f4efe480;--color-bg-solid:var(--color-klein);--rd-rule-soft:#f4efe43d;position:relative}.rd-footer{padding-top:var(--space-4);border-top:var(--rd-rule-w) dashed var(--rd-rule-soft);position:relative}.rd-footer-cols{gap:var(--space-3);padding-bottom:var(--space-4);grid-template-columns:repeat(4,1fr);display:grid}.rd-footer-col h6{font-family:var(--font-family-mono);font-size:var(--font-size-text-small);text-transform:uppercase;letter-spacing:var(--letter-spacing-caps);color:var(--color-fg-muted);font-weight:var(--font-weight-regular);margin:0 0 var(--space-1)}.rd-footer-col a{color:var(--color-fg);font-size:var(--font-size-text-main);margin:var(--space-0-25) 0;text-decoration:none;display:block}.rd-footer-col a:hover{color:var(--color-fg-muted)}.rd-footer-wordmark{height:var(--space-9);color:var(--color-fg-soft);border-top:var(--rd-rule-w) dashed var(--rd-rule-soft);padding-top:var(--space-2);justify-content:center;align-items:flex-end;display:flex}.rd-footer-wordmark svg{width:auto;height:100%}.rd-footer-bottom{padding:var(--space-1-5) 0;border-top:var(--rd-rule-w) dashed var(--rd-rule-soft);font-family:var(--font-family-mono);font-size:var(--font-size-text-small);color:var(--color-fg-muted);text-transform:uppercase;letter-spacing:var(--letter-spacing-caps);justify-content:space-between;align-items:center;display:flex}.rd-float-cta{right:var(--space-2);bottom:var(--space-2);z-index:30;align-items:center;gap:var(--space-0-5);padding:var(--space-0-75) var(--space-1-25);background:var(--color-klein);color:var(--color-cream);border:var(--rd-rule-w) solid var(--color-klein);font-family:var(--font-family-sans);font-size:var(--font-size-text-small);font-weight:var(--font-weight-medium);letter-spacing:var(--letter-spacing-snug);border-radius:999px;text-decoration:none;transition:transform .12s;display:inline-flex;position:fixed;box-shadow:0 .5rem 1.5rem #0004eb2e}.rd-float-cta:hover{transform:translateY(-1px)}.dark .rd-float-cta{background:var(--color-cream);color:var(--color-klein);border-color:var(--color-cream)}.rd-form{gap:var(--space-1-25);flex-direction:column;display:flex}.rd-form-row{gap:var(--space-1);grid-template-columns:1fr 1fr;display:grid}.rd-field{gap:var(--space-0-25);flex-direction:column;display:flex}.rd-label{font-family:var(--font-family-mono);font-size:var(--font-size-text-small);text-transform:uppercase;letter-spacing:var(--letter-spacing-caps);color:var(--color-fg-muted)}.rd-input,.rd-textarea{font-family:var(--font-family-sans);font-size:var(--font-size-text-main);color:var(--color-fg);padding:var(--space-0-75) var(--space-1);border:var(--rd-rule-w) solid var(--rd-rule-soft);border-radius:var(--rd-card-radius);background:0 0;outline:none;width:100%;transition:border-color .15s}.rd-input:focus,.rd-textarea:focus{border-color:var(--color-fg)}.rd-textarea{resize:vertical;min-height:var(--space-8);line-height:var(--line-height-snug)}.rd-input::placeholder,.rd-textarea::placeholder{color:var(--color-fg-soft)}.rd-pills{gap:var(--space-0-5);flex-wrap:wrap;display:flex}.rd-pill{align-items:center;gap:var(--space-0-5);padding:var(--space-0-5) var(--space-1);border:var(--rd-rule-w) solid var(--rd-rule-soft);color:var(--color-fg-muted);font-family:var(--font-family-mono);font-size:var(--font-size-text-small);text-transform:uppercase;letter-spacing:var(--letter-spacing-caps);cursor:pointer;background:0 0;border-radius:999px;transition:all .15s;display:inline-flex}.rd-pill:hover{color:var(--color-fg);border-color:var(--color-fg-muted)}.rd-pill.active{background:var(--color-fg);color:var(--color-bg-solid);border-color:var(--color-fg)}.rd-docs{gap:var(--space-3);padding-top:var(--space-3);padding-bottom:var(--space-6);grid-template-columns:14rem 1fr;display:grid}.rd-docs-toc{top:var(--space-5);border-left:var(--rd-rule-w) dashed var(--rd-rule-soft);padding-left:var(--space-1);align-self:start;position:sticky}.rd-docs-toc h6{font-family:var(--font-family-mono);font-size:var(--font-size-text-small);text-transform:uppercase;letter-spacing:var(--letter-spacing-caps);color:var(--color-fg-muted);font-weight:var(--font-weight-regular);margin:0 0 var(--space-0-75)}.rd-docs-toc a{font-size:var(--font-size-text-main);color:var(--color-fg-muted);padding:var(--space-0-25) 0;text-decoration:none;transition:color .15s;display:block}.rd-docs-toc a:hover,.rd-docs-toc a.active{color:var(--color-fg)}.rd-docs-content section{padding:var(--space-3) 0;border-top:var(--rd-rule-w) dashed var(--rd-rule-soft)}.rd-docs-content section:first-child{border-top:0;padding-top:0}.rd-table{border-collapse:collapse;width:100%;margin:var(--space-1) 0 var(--space-2);font-size:var(--font-size-text-main)}.rd-table th,.rd-table td{text-align:left;padding:var(--space-0-75) var(--space-1);border-bottom:var(--rd-rule-w) dashed var(--rd-rule-soft);color:var(--color-fg-muted)}.rd-table th{font-family:var(--font-family-mono);font-size:var(--font-size-text-small);text-transform:uppercase;letter-spacing:var(--letter-spacing-caps);color:var(--color-fg);font-weight:var(--font-weight-regular)}.rd-table td:first-child code,.rd-table td:nth-child(2){font-family:var(--font-family-mono);color:var(--color-fg)}.rd-kbd-list{gap:var(--space-0-5) var(--space-2);grid-template-columns:max-content 1fr;display:grid}.rd-kbd{font-family:var(--font-family-mono);font-size:var(--font-size-text-small);padding:var(--space-0-25) var(--space-0-5);border:var(--rd-rule-w) solid var(--rd-rule-soft);border-radius:var(--rd-card-radius);color:var(--color-fg);display:inline-block}.rd-alert{align-items:center;gap:var(--space-0-5);padding:var(--space-0-75) var(--space-1);border:var(--rd-rule-w) solid var(--rd-rule-soft);border-radius:var(--rd-card-radius);font-family:var(--font-family-mono);font-size:var(--font-size-text-small);color:var(--color-fg-muted);display:inline-flex}.rd-alert.error{color:#ff6b6b;border-color:#ff6b6b80}.rd-spinner{border:2px solid;border-right-color:#0000;border-radius:999px;width:.875rem;height:.875rem;animation:.7s linear infinite rd-spin}@keyframes rd-spin{to{transform:rotate(360deg)}}@media (width<=991px){.rd-footer-cols{grid-template-columns:repeat(2,1fr)}.rd-docs{grid-template-columns:1fr}.rd-docs-toc{display:none}}.rd-auth-card{position:relative}@media (width<=991px){.rd-auth-grid{gap:var(--space-2-5)!important;grid-template-columns:1fr!important}}@media (width<=767px){.rd-feature-row{gap:var(--space-2);grid-template-columns:1fr}.rd-feature-row.reverse>.rd-feature-text,.rd-feature-row.reverse>.rd-feature-media{order:unset}.rd-form-row{grid-template-columns:1fr}.rd-nav{padding:var(--space-0-75) var(--space-1)}.rd-nav-links{display:none}.rd-container,.rd-container-wide{padding-left:var(--space-1);padding-right:var(--space-1)}.rd-marker.left,.rd-marker.right{display:none}.rd-float-cta{right:var(--space-1);bottom:var(--space-1)}}.rd-auth-card .cl-rootBox,.rd-auth-card .cl-cardBox,.rd-auth-card .cl-card,.rd-auth-card .cl-main,.rd-auth-card .cl-internal-1k4nh2v,.rd-auth-card [class^=cl-][class*=cardBox],.rd-auth-card [class^=cl-][class*=card\ ]{box-shadow:none!important;background:0 0!important;border:0!important;border-radius:0!important;width:100%!important;min-width:0!important;max-width:100%!important;padding:0!important}.rd-auth-card .cl-form,.rd-auth-card .cl-formFieldRow,.rd-auth-card .cl-formField,.rd-auth-card .cl-socialButtons,.rd-auth-card .cl-socialButtonsRoot,.rd-auth-card .cl-formFieldInputGroup,.rd-auth-card [class^=cl-internal]{min-width:0!important;max-width:100%!important}.rd-auth-card .cl-formFieldInput,.rd-auth-card .cl-socialButtonsBlockButton,.rd-auth-card .cl-formButtonPrimary{box-sizing:border-box!important;width:100%!important;min-width:0!important}@media (width<=479px){.rd-auth-card .cl-formFieldRow{gap:var(--space-1)!important;flex-wrap:wrap!important}.rd-auth-card .cl-formFieldRow>*{flex:100%!important}}.rd-auth-card .cl-header{display:none!important}.rd-auth-card .cl-form,.rd-auth-card .cl-socialButtons{gap:var(--space-1)!important;flex-direction:column!important;margin:0!important;padding:0!important;display:flex!important}.rd-auth-card [class^=cl-internal],.rd-auth-card .cl-formFieldRow,.rd-auth-card .cl-formField,.rd-auth-card .cl-socialButtonsRoot,.rd-auth-card .cl-actionCard{box-shadow:none!important;background:0 0!important;border:0!important;padding:0!important}.rd-auth-card .cl-socialButtonsBlockButton{border:var(--rd-rule-w) solid var(--rd-rule-soft)!important;border-radius:var(--rd-card-radius)!important;color:var(--color-fg)!important;font-family:var(--font-family-sans)!important;font-weight:var(--font-weight-medium)!important;font-size:var(--font-size-text-main)!important;text-transform:none!important;padding:var(--space-0-75) var(--space-1)!important;box-shadow:none!important;background:0 0!important;transition:background .15s,border-color .15s!important}.rd-auth-card .cl-socialButtonsBlockButton:hover{border-color:var(--color-fg-muted)!important;background:#0004eb0f!important}.rd-auth-card .cl-socialButtonsBlockButton__providerIcon~.cl-internal-tag,.rd-auth-card [class*=badge],.rd-auth-card .cl-badge,.rd-auth-card .cl-formFieldHintText,.rd-auth-card .cl-formFieldLabelRow>[class*=tag],.rd-auth-card .cl-formFieldLabelRow>[class*=Tag],.rd-auth-card .cl-lastAuthenticationStrategyBadge{display:none!important}.rd-auth-card .cl-dividerRow{align-items:center!important;gap:var(--space-0-75)!important;margin:var(--space-0-5) 0!important;display:flex!important}.rd-auth-card .cl-dividerLine{border-top:var(--rd-rule-w) dashed var(--rd-rule-soft)!important;background:0 0!important;flex:1!important;height:0!important}.rd-auth-card .cl-dividerText{font-family:var(--font-family-mono)!important;font-size:var(--font-size-text-small)!important;text-transform:uppercase!important;letter-spacing:var(--letter-spacing-caps)!important;color:var(--color-fg-muted)!important}.rd-auth-card .cl-formFieldLabel,.rd-auth-card .cl-formFieldLabelRow{font-family:var(--font-family-mono)!important;font-size:var(--font-size-text-small)!important;text-transform:uppercase!important;letter-spacing:var(--letter-spacing-caps)!important;color:var(--color-fg-muted)!important;font-weight:var(--font-weight-regular)!important;margin:0 0 var(--space-0-25)!important}.rd-auth-card .cl-formFieldLabelRow__optional,.rd-auth-card .cl-formFieldLabelRow>*{font-weight:var(--font-weight-regular)!important}.rd-auth-card .cl-formFieldInput{border:var(--rd-rule-w) solid var(--rd-rule-soft)!important;border-radius:var(--rd-card-radius)!important;color:var(--color-fg)!important;padding:var(--space-0-75) var(--space-1)!important;font-family:var(--font-family-sans)!important;font-size:var(--font-size-text-main)!important;box-shadow:none!important;background:0 0!important;outline:none!important;transition:border-color .15s!important}.rd-auth-card .cl-formFieldInput:focus{border-color:var(--color-fg)!important}.rd-auth-card .cl-formButtonPrimary{background:var(--color-fg)!important;color:var(--color-bg-solid)!important;border:var(--rd-rule-w) solid var(--color-fg)!important;border-radius:var(--rd-card-radius)!important;padding:var(--space-0-75) var(--space-1-5)!important;font-family:var(--font-family-sans)!important;font-weight:var(--font-weight-medium)!important;font-size:var(--font-size-text-main)!important;text-transform:none!important;letter-spacing:var(--letter-spacing-snug)!important;box-shadow:none!important;height:auto!important;margin-top:var(--space-0-5)!important;background-image:none!important;transition:background .15s!important}.rd-auth-card .cl-formButtonPrimary:hover{background:var(--color-fg-muted)!important}.rd-auth-card .cl-formButtonPrimary:after{display:none!important}.rd-auth-card .cl-footer,.rd-auth-card .cl-footerActionText,.rd-auth-card .cl-footerAction{background:0 0!important;border:0!important;margin:0!important;padding:0!important}.rd-auth-card .cl-footer{padding-top:var(--space-1)!important;margin-top:var(--space-1)!important;border-top:var(--rd-rule-w) dashed var(--rd-rule-soft)!important;justify-content:center!important;display:flex!important}.rd-auth-card .cl-footerActionText{color:var(--color-fg-muted)!important;font-size:var(--font-size-text-small)!important}.rd-auth-card .cl-footerActionLink{color:var(--color-fg)!important;font-weight:var(--font-weight-medium)!important;text-underline-offset:.2em!important;margin-left:var(--space-0-5)!important;text-decoration:underline!important}.rd-auth-card .cl-internal-segmented-control,.rd-auth-card [class*=segmentedControl],.rd-auth-card .cl-internal-12u1lvz,.rd-auth-card [class*=poweredBy],.rd-auth-card .cl-internal-1dauvpw,.rd-auth-card [class*=developmentMode],.rd-auth-card a[href*=clerk\.com]{display:none!important}.cl-root{--fg:var(--color-fg);--fg-muted:var(--color-fg-muted);--fg-soft:var(--color-fg-soft);--bg:var(--color-bg-solid);--rule-subtle:#0004eb24;--rule-medium:#0004eb47;--rule-strong:#0004eb8c;--font-sans:var(--font-family-sans);--font-mono:var(--font-family-mono);--w-medium:var(--font-weight-medium);--tr-tight:var(--letter-spacing-tight);--tr-snug:var(--letter-spacing-snug);--tr-caps:var(--letter-spacing-caps);--success:#2f7d3a;--warn:#b87a00;--error:#c0392b}.cl-root,.cl-root *,.cl-root :before,.cl-root :after{box-sizing:border-box}.cl-root{--chrome-bg:#f4efe4;--chrome-rule:#0004eb52;--chrome-lip:#e8dec5a6;--editor-bg:#f4efe4;--editor-canvas:#f4efe4;background:var(--chrome-bg);width:100%;height:100vh;color:var(--fg);font-family:var(--font-sans);grid-template-columns:320px 1fr;font-size:14px;line-height:1.4;display:grid;overflow:hidden}.cl-sidebar{--pad-x:var(--space-2);z-index:1;border-right:1px solid var(--chrome-rule);width:320px;height:100vh;box-shadow:inset -1px 0 0 var(--chrome-lip);padding:0 var(--pad-x) var(--space-1-5);gap:var(--space-1-5);background:var(--chrome-bg);flex-direction:column;display:flex;overflow-y:auto}.cl-sidebar-logo{height:58px;color:var(--fg);flex-shrink:0;align-items:center;text-decoration:none;display:inline-flex}.cl-sidebar-logo svg{width:auto;height:22px;display:block}.cl-pageid{flex-direction:column;gap:4px;padding-bottom:4px;display:flex}.cl-pageid-title{font-family:var(--font-sans);font-weight:var(--w-medium);letter-spacing:var(--tr-tight);text-transform:uppercase;color:var(--fg);word-break:break-word;margin:0;font-size:18px;line-height:1.1}.cl-pageid-url{font-family:var(--font-mono);color:var(--fg-soft);white-space:nowrap;text-overflow:ellipsis;font-size:11px;text-decoration:none;overflow:hidden}a.cl-pageid-url:hover{color:var(--fg);text-decoration:underline}.cl-primary{width:100%;font-family:var(--font-sans);font-size:13px;font-weight:var(--w-medium);letter-spacing:var(--tr-snug);background:var(--fg);color:var(--bg);border:1px solid var(--fg);cursor:pointer;border-radius:0;justify-content:center;align-items:center;gap:8px;padding:12px 14px;transition:background .15s,color .15s;display:inline-flex}.cl-primary:hover:not(:disabled){background:var(--fg-muted);border-color:var(--fg-muted)}.cl-primary:disabled{opacity:.45;cursor:not-allowed}.cl-secrow{gap:6px;display:flex}.cl-secbtn{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--tr-caps);color:var(--fg-muted);border:1px solid var(--rule-medium);cursor:pointer;background:0 0;border-radius:0;flex:1;justify-content:center;align-items:center;gap:6px;padding:8px 10px;font-size:10.5px;transition:border-color .15s,color .15s;display:inline-flex}.cl-secbtn:hover:not(:disabled){color:var(--fg);border-color:var(--rule-strong)}.cl-secbtn:disabled{opacity:.4;cursor:not-allowed}.cl-meta{flex-direction:column;gap:0;margin:0;padding:0;display:flex}.cl-meta-row{border-top:1px solid var(--rule-subtle);font-family:var(--font-mono);grid-template-columns:64px 1fr;align-items:baseline;gap:12px;padding:8px 0;font-size:11px;display:grid}.cl-meta-row:last-child{border-bottom:1px solid var(--rule-subtle)}.cl-meta dt{color:var(--fg-soft);text-transform:uppercase;letter-spacing:var(--tr-caps);margin:0;font-size:10px}.cl-meta dd{color:var(--fg);word-break:break-all;flex-wrap:wrap;align-items:baseline;gap:6px;margin:0;display:inline-flex}.cl-meta-sep{color:var(--fg-soft)}.cl-meta-libs{flex-wrap:wrap;gap:4px;display:flex}.cl-group{flex-direction:column;gap:10px;display:flex}.cl-group-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--tr-caps);color:var(--fg-soft);margin:0;font-size:10.5px}.cl-group-label:before{content:"// ";opacity:.55}.cl-vpill{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--tr-caps);color:var(--fg);border:1px solid var(--rule-medium);cursor:pointer;background:0 0;border-radius:0;justify-content:space-between;align-items:center;padding:6px 12px;font-size:12px;text-decoration:none;transition:border-color .15s,background .15s,color .15s;display:flex}.cl-vpill:hover:not(:disabled){border-color:var(--rule-strong)}.cl-vpill:disabled{opacity:.4;cursor:not-allowed}.cl-vpill .cl-vpill-size{font-family:var(--font-mono);color:var(--fg-soft);letter-spacing:0;text-transform:none;font-size:11px}.cl-vpill.active{background:var(--fg);color:var(--bg);border-color:var(--fg)}.cl-vpill.active .cl-vpill-size{color:#f4efe4a6}.cl-vpill .cl-vpill-num{font-family:var(--font-mono);color:var(--fg-soft);font-size:10px}.cl-vpill.active .cl-vpill-num{color:#f4efe4a6}.cl-act-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.cl-act{min-height:62px;font-family:var(--font-sans);font-size:12.5px;font-weight:var(--w-medium);letter-spacing:var(--tr-snug);border:1px solid var(--fg);background:var(--editor-bg);color:var(--fg);cursor:pointer;text-align:left;border-radius:0;flex-direction:column;justify-content:space-between;align-items:flex-start;gap:10px;padding:10px 11px 9px;line-height:1.15;text-decoration:none;transition:background .15s,color .15s;display:flex}.cl-act:hover:not(:disabled){background:var(--fg);color:var(--bg)}.cl-act:disabled{opacity:.5;cursor:not-allowed}.cl-act.primary{background:var(--fg);color:var(--bg)}.cl-act.primary:hover:not(:disabled){background:var(--fg-muted)}.cl-act-label{font-family:var(--font-sans);font-weight:var(--w-medium);letter-spacing:var(--tr-snug);text-transform:none}.cl-cap{border:1px solid var(--rule-subtle);background:var(--editor-bg);flex-direction:column;gap:8px;padding:9px 12px 10px;display:flex}.cl-cap-row{justify-content:space-between;gap:var(--space-0-5);font-family:var(--font-mono);color:var(--fg-soft);text-transform:uppercase;letter-spacing:var(--tr-caps);font-size:11px;display:flex}.cl-cap-row .k{color:var(--fg-soft)}.cl-cap-row .v{color:var(--fg);text-align:right;word-break:break-all}.cl-libs{flex-wrap:wrap;gap:6px;display:flex}.cl-lib{border:1px solid var(--rule-medium);font-family:var(--font-mono);color:var(--fg);text-transform:uppercase;letter-spacing:var(--tr-caps);padding:3px 8px;font-size:10.5px;display:inline-block}.cl-sizes{background:var(--rule-subtle);border:1px solid var(--rule-subtle);grid-template-columns:repeat(3,1fr);gap:1px;display:grid}.cl-sizes>div{background:var(--bg);flex-direction:column;gap:1px;padding:5px 10px;display:flex}.cl-sizes .k{font-family:var(--font-mono);color:var(--fg-soft);text-transform:uppercase;letter-spacing:var(--tr-caps);font-size:10px}.cl-sizes .v{font-family:var(--font-mono);color:var(--fg);font-size:12px}.cl-setting{justify-content:space-between;align-items:center;gap:var(--space-0-75);font-family:var(--font-mono);color:var(--fg-muted);text-transform:uppercase;letter-spacing:var(--tr-caps);font-size:11px;display:flex}.cl-toggle{border:1px solid var(--rule-medium);display:inline-flex}.cl-toggle button,.cl-toggle span{font-family:var(--font-mono);color:var(--fg-muted);text-transform:uppercase;letter-spacing:var(--tr-caps);cursor:pointer;background:0 0;border:0;padding:4px 10px;font-size:10.5px;display:inline-block}.cl-toggle span.on,.cl-toggle button.on{background:var(--fg);color:var(--bg)}.cl-toggle button:disabled{opacity:.4;cursor:not-allowed}.cl-status{border-top:1px dashed var(--rule-subtle);flex-direction:column;gap:6px;margin-top:auto;padding-top:10px;display:flex}.cl-status-line{font-family:var(--font-mono);color:var(--fg-muted);text-transform:uppercase;letter-spacing:var(--tr-caps);align-items:center;gap:8px;font-size:11px;display:inline-flex}.cl-status-dot{background:var(--success);border-radius:999px;flex-shrink:0;width:7px;height:7px}.cl-status-dot.warn{background:var(--warn)}.cl-status-dot.error{background:var(--error)}.cl-foot{font-family:var(--font-mono);color:var(--fg-soft);text-transform:uppercase;letter-spacing:var(--tr-caps);padding-top:var(--space-0-5);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:6px;font-size:10px;display:flex}.cl-foot a{color:var(--fg-soft);text-decoration:none}.cl-foot a:hover{color:var(--fg)}.cl-foot-links{flex-wrap:wrap;gap:10px;display:inline-flex}.cl-main{z-index:1;background:var(--editor-canvas);flex-direction:column;height:100vh;display:flex;overflow:hidden}.cl-topbar{padding:0 var(--space-2);background:var(--chrome-bg);border-bottom:1px solid #0a0a0a29;flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;min-height:68px;display:flex}.cl-topbar-left,.cl-topbar-right,.cl-topbar-mid{flex-wrap:wrap;align-items:center;gap:14px;display:inline-flex}.cl-htabs{flex-wrap:wrap;align-items:center;gap:6px;display:inline-flex}.cl-htab{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--tr-caps);color:var(--fg);border:1px solid var(--rule-medium);cursor:pointer;background:0 0;border-radius:0;align-items:center;gap:8px;padding:7px 12px;font-size:11.5px;transition:border-color .15s,background .15s,color .15s;display:inline-flex}.cl-htab:hover:not(:disabled){border-color:var(--rule-strong)}.cl-htab:disabled{opacity:.4;cursor:not-allowed}.cl-htab-num{font-family:var(--font-mono);color:var(--fg-soft);font-size:10px}.cl-htab-size{font-family:var(--font-mono);color:var(--fg-soft);letter-spacing:0;text-transform:none;font-size:10.5px}.cl-htab.active{background:var(--fg);color:var(--bg);border-color:var(--fg)}.cl-htab.active .cl-htab-num,.cl-htab.active .cl-htab-size{color:#f4efe4a6}.cl-tb-eyebrow{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--tr-caps);color:var(--fg);font-size:11px}.cl-tb-eyebrow:before{content:"// ";opacity:.55}.cl-tb-meta{font-family:var(--font-mono);color:var(--fg-soft);text-transform:uppercase;letter-spacing:var(--tr-caps);font-size:11px}.cl-tb-btn{border:1px solid var(--rule-medium);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--tr-caps);color:var(--fg-muted);cursor:pointer;background:0 0;align-items:center;gap:6px;padding:6px 10px;font-size:10.5px;display:inline-flex}.cl-tb-btn:hover:not(:disabled){color:var(--fg);border-color:var(--rule-strong)}.cl-tb-btn:disabled{opacity:.4;cursor:not-allowed}.cl-tb-seg{border:1px solid var(--rule-medium);display:inline-flex}.cl-tb-seg>*{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--tr-caps);color:var(--fg-muted);cursor:pointer;background:0 0;border:0;padding:6px 10px;font-size:10.5px}.cl-tb-seg .on{background:var(--fg);color:var(--bg)}.cl-prevbody{padding:var(--space-1-5);background:0 0;flex:1;justify-content:center;align-items:stretch;display:flex;position:relative;overflow:hidden}.cl-prevframe{border:1px solid var(--rule-medium);background:#fff;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.cl-prevframe iframe{background:#fff;border:0;flex:1;width:100%;height:100%;display:block}.cl-prevframe-meta{font-family:var(--font-mono);color:var(--fg-soft);text-transform:uppercase;letter-spacing:var(--tr-caps);z-index:3;border:1px solid var(--rule-subtle);pointer-events:none;background:#f4efe4d9;padding:2px 6px;font-size:10px;position:absolute;top:8px;right:10px}.cl-codebody{padding:var(--space-1-5);gap:var(--space-1);background:0 0;flex-direction:column;flex:1;display:flex;overflow:auto}.cl-empty{padding:var(--space-3) var(--space-5);flex-direction:column;flex:1;justify-content:center;display:flex;position:relative;overflow:auto}.cl-empty-eyebrow{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--tr-caps);color:var(--fg-muted);margin-bottom:var(--space-1-5);font-size:12px}.cl-empty-eyebrow:before{content:"// ";opacity:.55}.cl-empty-h{font-family:var(--font-sans);font-weight:var(--w-medium);letter-spacing:var(--tr-tight);text-transform:uppercase;color:var(--fg);margin:0 0 var(--space-1);max-width:18em;font-size:38px;line-height:1.05}.cl-empty-sub{font-family:var(--font-sans);color:var(--fg-muted);margin:0 0 var(--space-3);max-width:42em;font-size:16px;line-height:1.4}.cl-steps{background:var(--rule-medium);border:1px solid var(--rule-medium);grid-template-columns:repeat(3,1fr);gap:1px;max-width:920px;display:grid}.cl-step{background:var(--bg);padding:var(--space-2);gap:var(--space-0-75);flex-direction:column;min-height:200px;display:flex}.cl-step-marker{background:var(--bg);border:1px solid var(--rule-medium);font-family:var(--font-mono);color:var(--fg-muted);text-transform:uppercase;letter-spacing:var(--tr-caps);align-self:flex-start;align-items:center;padding:3px 8px;font-size:10.5px;display:inline-flex}.cl-step-marker:before{content:"(  "}.cl-step-marker:after{content:" )"}.cl-step-h{font-family:var(--font-sans);font-weight:var(--w-medium);text-transform:uppercase;letter-spacing:var(--tr-tight);color:var(--fg);margin:0;font-size:20px;line-height:1.1}.cl-step-body{font-family:var(--font-sans);color:var(--fg-muted);margin:0;font-size:13px;line-height:1.5}.cl-step-link{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--tr-caps);color:var(--fg);align-items:center;gap:6px;margin-top:auto;font-size:11px;text-decoration:none;display:inline-flex}.cl-step-link:after{content:"→"}.cl-empty-foot{margin-top:var(--space-3);font-family:var(--font-mono);color:var(--fg-soft);text-transform:uppercase;letter-spacing:var(--tr-caps);font-size:11px}.cl-empty-foot a{color:var(--fg);border-bottom:1px solid var(--rule-medium);padding-bottom:2px;text-decoration:none}.cl-corner{background:var(--bg);border:1px solid var(--rule-medium);font-family:var(--font-mono);color:var(--fg-muted);text-transform:uppercase;letter-spacing:var(--tr-caps);z-index:2;padding:3px 8px;font-size:10.5px;position:absolute;top:60px;left:32px}.cl-corner:before{content:"(  "}.cl-corner:after{content:" )"}.cl-spinner{border:1.5px solid var(--rule-medium);border-top-color:var(--fg);border-radius:999px;width:10px;height:10px;animation:.7s linear infinite cl-spin;display:inline-block}@keyframes cl-spin{to{transform:rotate(360deg)}}.ff-app-root .cl-sidebar{padding-top:0}.ff-app-root .cl-sidebar-logo{height:68px;margin:0 calc(-1 * var(--space-2)) var(--space-1-5);padding:0 var(--space-2);border-bottom:1px solid var(--chrome-rule);box-shadow:inset 0 -1px 0 var(--chrome-lip);flex-shrink:0;align-items:center;display:flex}.ff-app-root{--editor-canvas:radial-gradient(circle at 18% 24%, #0004eb24, transparent 45%), radial-gradient(circle at 82% 72%, #0004eb1a, transparent 50%), radial-gradient(circle at 55% 45%, #0004eb0f, transparent 60%), #f4efe4}.ff-app-root .cl-sidebar{gap:var(--space-1-25)}.ff-eyebrow{font-family:var(--font-mono);letter-spacing:var(--tr-caps);text-transform:uppercase;color:var(--fg-soft);align-items:center;gap:6px;font-size:10.5px;display:inline-flex}.ff-eyebrow-prefix{opacity:.55}.ff-group{flex-direction:column;gap:8px;display:flex}.ff-group-label{font-family:var(--font-mono);letter-spacing:var(--tr-caps);text-transform:uppercase;color:var(--fg-soft);margin:0;font-size:10.5px}.ff-group-label:before{content:"// ";opacity:.55}.ff-seg{border:1px solid var(--rule-medium);grid-template-columns:1fr 1fr 1fr;display:grid}.ff-seg-btn{appearance:none;border:0;border-right:1px solid var(--rule-medium);font-family:var(--font-mono);font-size:10px;font-weight:var(--w-medium);letter-spacing:var(--tr-caps);text-transform:uppercase;color:var(--fg-soft);cursor:pointer;background:0 0;padding:9px 6px;transition:color .15s,background .15s}.ff-seg-btn:last-child{border-right:0}.ff-seg-btn:hover:not(.is-on){color:var(--fg);background:#0004eb0f}.ff-seg-btn.is-on{background:var(--fg);color:var(--bg)}.cl-primary[disabled]{opacity:.55;cursor:not-allowed}.ff-kbd-inline{min-width:28px;height:18px;font-family:var(--font-mono);color:#f4efe4d9;background:0 0;border:1px solid #f4efe473;justify-content:center;align-items:center;margin-left:auto;padding:0 5px;font-size:10px;display:inline-flex}.ff-kbd-inverse{color:var(--fg-soft);border-color:var(--rule-medium)}.ff-spinner{border:2px solid;border-right-color:#0000;border-radius:50%;width:13px;height:13px;animation:.7s linear infinite ff-spin}@keyframes ff-spin{to{transform:rotate(360deg)}}.ff-link-cta{border:1px solid var(--rule-medium);color:var(--fg);font-family:var(--font-mono);font-size:10.5px;font-weight:var(--w-medium);letter-spacing:var(--tr-caps);text-transform:uppercase;cursor:pointer;background:0 0;align-items:center;gap:8px;padding:9px 12px;text-decoration:none;transition:border-color .15s,color .15s,background .15s;display:inline-flex}.ff-link-cta:hover{border-color:var(--rule-strong);background:#0004eb0a}.ff-link-undo{font-family:var(--font-mono);letter-spacing:var(--tr-caps);text-transform:uppercase;color:var(--fg-soft);text-underline-offset:3px;text-decoration:underline;-webkit-text-decoration-color:var(--rule-subtle);text-decoration-color:var(--rule-subtle);cursor:pointer;background:0 0;border:0;align-items:center;gap:6px;padding:4px 0;font-size:10px;display:inline-flex}.ff-link-undo:hover{color:var(--fg);-webkit-text-decoration-color:var(--fg);text-decoration-color:var(--fg)}.ff-ai-status{border:1px solid var(--rule-subtle);font-family:var(--font-mono);color:var(--fg-muted);text-overflow:ellipsis;white-space:nowrap;padding:8px 10px;font-size:10.5px;overflow:hidden}.ff-warnings{flex-direction:column;gap:6px;display:flex}.ff-warnings ul{font-family:var(--font-mono);color:var(--fg-muted);margin:0;padding-left:16px;font-size:11px;line-height:1.5}.ff-warnings li{margin-bottom:4px}.ff-stats{border:1px solid var(--rule-medium);background:var(--bg);grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr;display:grid}.ff-stat{flex-direction:column;gap:4px;min-height:56px;padding:12px 14px 10px;display:flex}.ff-stat:first-child,.ff-stat:nth-child(3){border-right:1px solid var(--rule-medium)}.ff-stat:first-child,.ff-stat:nth-child(2){border-bottom:1px solid var(--rule-medium)}.ff-stat-val{font-family:var(--font-mono);font-size:22px;font-weight:var(--w-medium);color:var(--fg);letter-spacing:-.02em;line-height:1}.ff-stat-lbl{font-family:var(--font-mono);letter-spacing:var(--tr-caps);text-transform:uppercase;color:var(--fg-soft);font-size:9.5px}.ff-usage-line{border-bottom:1px solid var(--rule-subtle);font-family:var(--font-mono);letter-spacing:var(--tr-caps);text-transform:uppercase;color:var(--fg-soft);justify-content:space-between;align-items:center;gap:8px;padding-bottom:6px;font-size:10px;display:flex}.ff-usage-line.is-over{color:#c2362c}.ff-usage-cta{font-family:var(--font-mono);letter-spacing:var(--tr-caps);text-transform:uppercase;color:var(--fg);text-underline-offset:3px;font-size:10.5px;font-weight:var(--w-medium);text-decoration:underline}.ff-foot-shortcuts{appearance:none;font-family:var(--font-mono);letter-spacing:var(--tr-caps);text-transform:uppercase;color:var(--fg-soft);cursor:pointer;background:0 0;border:0;align-items:center;gap:6px;padding:0;font-size:10px;display:inline-flex}.ff-foot-shortcuts:hover{color:var(--fg)}.ff-account{border-top:1px solid var(--rule-subtle);font-family:var(--font-mono);color:var(--fg-soft);align-items:center;gap:8px;margin-top:8px;padding-top:8px;font-size:10px;display:inline-flex}.ff-account-email{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.ff-app-main .editor-pane{background:0 0;flex-direction:column;height:100%;display:flex}.ff-app-main .topbar{background:var(--chrome-bg);border-bottom:1px solid var(--chrome-rule);height:68px;box-shadow:inset 0 -1px 0 var(--chrome-lip);padding:0 var(--space-2);align-items:center;gap:var(--space-1-5);flex-shrink:0;display:flex}.ff-app-main .topbar-tabs{align-items:center;gap:6px;display:inline-flex}.ff-app-main .topbar-tab{appearance:none;border:1px solid var(--rule-medium);color:var(--fg);font-family:var(--font-mono);font-size:11.5px;font-weight:var(--w-medium);letter-spacing:var(--tr-caps);text-transform:uppercase;cursor:pointer;background:0 0;border-radius:0;align-items:center;gap:6px;padding:7px 12px;transition:border-color .15s,background .15s,color .15s;display:inline-flex}.ff-app-main .topbar-tab:hover:not(.is-active){border-color:var(--rule-strong)}.ff-app-main .topbar-tab.is-active{background:var(--fg);color:var(--bg);border-color:var(--fg)}.ff-app-main .topbar-dirty{opacity:.65;background:currentColor;border-radius:0;width:6px;height:6px}.ff-app-main .topbar-right{align-items:center;gap:var(--space-1);margin-left:auto;padding:0;display:inline-flex}.ff-app-main .decode-out-bar{background:var(--chrome-bg);border-bottom:1px solid var(--chrome-rule);height:68px;box-shadow:inset 0 -1px 0 var(--chrome-lip);padding:0 var(--space-2);align-items:center;gap:var(--space-1-5);flex-shrink:0;display:flex}.ff-app-main .decode-out-tabs{align-items:center;gap:6px;display:inline-flex}.ff-app-main .decode-out-tab{appearance:none;border:1px solid var(--rule-medium);height:auto;color:var(--fg);font-family:var(--font-mono);font-size:11.5px;font-weight:var(--w-medium);letter-spacing:var(--tr-caps);text-transform:uppercase;cursor:pointer;background:0 0;border-radius:0;align-items:center;gap:6px;padding:7px 12px;transition:border-color .15s,background .15s,color .15s;display:inline-flex;top:0}.ff-app-main .decode-out-tab:hover:not(.is-active){color:var(--fg);border-color:var(--rule-strong)}.ff-app-main .decode-out-tab.is-active{background:var(--fg);color:var(--bg);border-color:var(--fg)}.ff-app-main .status-pill{font-family:var(--font-mono);letter-spacing:var(--tr-caps);text-transform:uppercase;color:var(--fg-muted);align-items:center;gap:6px;font-size:10.5px;display:inline-flex}.ff-app-main .status-pill .sdot{background:var(--fg-soft);border-radius:999px;width:7px;height:7px}.ff-app-main .status-pill .sdot.ready{background:var(--success)}.ff-app-main .status-pill .sdot.dirty{background:var(--warn)}.ff-app-main .status-pill .sdot.error{background:var(--error)}.ff-app-main .char-ct{font-family:var(--font-mono);color:var(--fg-soft);letter-spacing:0;font-size:10.5px}.ff-app-main .editor-area{background:0 0;flex:1;min-height:0;position:relative;overflow:hidden}.ff-app-main .editor-wrap{flex-direction:column;display:flex;position:absolute;inset:0}.ff-app-main .editor-wrap.hidden{display:none}.ff-app-main .empty{pointer-events:none;z-index:1;color:var(--fg-soft);flex-direction:column;justify-content:center;align-items:center;gap:6px;display:flex;position:absolute;inset:0}.ff-app-main .empty-icon{border:1px solid var(--rule-medium);width:40px;height:40px;color:var(--fg-soft);background:0 0;border-radius:0;justify-content:center;align-items:center;margin-bottom:4px;display:inline-flex}.ff-app-main .empty-title{font-family:var(--font-sans);font-weight:var(--w-medium);color:var(--fg);font-size:14px}.ff-app-main .empty-sub{font-family:var(--font-mono);color:var(--fg-soft);letter-spacing:0;font-size:11px}.ff-app-main .statusbar{background:var(--chrome-bg);border-top:1px solid var(--chrome-rule);height:32px;box-shadow:inset 0 1px 0 var(--chrome-lip);padding:0 var(--space-2);align-items:center;gap:var(--space-1);font-family:var(--font-mono);letter-spacing:var(--tr-caps);text-transform:uppercase;color:var(--fg-soft);flex-shrink:0;font-size:10px;display:flex}.ff-app-main .statusbar .sb{color:var(--fg-soft)}.ff-app-main .statusbar .sb.active{color:var(--fg);font-weight:var(--w-medium)}.ff-app-main .statusbar .sb-sep{background:var(--rule-subtle);width:1px;height:11px}.ff-app-main .statusbar .sb-r{color:var(--fg-muted);margin-left:auto}.ff-app-main .cm-host,.ff-app-main .cm-host .cm-editor,.ff-app-main .cm-host .cm-scroller,.ff-app-main .cm-host .cm-gutters{background:#f4efe4!important}.ff-app-main .cm-host .cm-activeLine{background-color:#0004eb0a!important}.ff-app-main .cm-host .cm-activeLineGutter{background-color:#0000!important}.ff-app-main .cm-host .cm-lineNumbers .cm-gutterElement{color:var(--fg-soft)}.ff-app-main .cm-host .cm-selectionBackground,.ff-app-main .cm-host.cm-focused .cm-selectionBackground{background-color:#0004eb2e!important}
