:root{--bg-main: #18181b;--bg-elevated: #27272a;--text-primary: #fafafa;--text-sub: #71717a;--error: #f43f5e;--error-extra: #4c1019;--accent: #d4b87a;--cursor-color: #528bff;--hand-fill: #353c4e;--hand-outline: #6b7895;--key-fill: rgba(30, 33, 42, .35);--key-stroke: rgba(90, 100, 120, .4);--key-active-fill: rgba(160, 170, 195, .4);--key-active-stroke: rgba(160, 170, 195, .6);--key-pressed-fill: rgba(100, 115, 140, .3);--key-active-text: #fff;--option-group-bg: rgba(255, 255, 255, .012);--option-btn-active-bg: rgba(255, 255, 255, .04);--font-mono: "Roboto Mono", "Courier New", monospace;--text-font-size: 28px;--text-line-height: 1.75;--cursor-move-duration: .1s;--cursor-move-easing: cubic-bezier(.2, 0, 0, 1);--hand-move-duration: .2s;--hand-move-easing: cubic-bezier(.25, .8, .25, 1)}html[data-theme-kind=light]{--key-fill: rgba(0, 0, 0, .06);--key-stroke: rgba(0, 0, 0, .22);--key-active-fill: rgba(0, 0, 0, .18);--key-active-stroke: rgba(0, 0, 0, .4);--key-pressed-fill: rgba(0, 0, 0, .1);--key-active-text: #000;--option-group-bg: rgba(0, 0, 0, .04);--option-btn-active-bg: rgba(0, 0, 0, .09)}html[data-theme=bright]{--hand-fill: #8a8680;--hand-outline: #54524e}html[data-theme=solarized-light]{--hand-fill: #93a1a1;--hand-outline: #586e75}html[data-theme=nord]{--hand-fill: #434c5e;--hand-outline: #81a1c1}html[data-theme=synthwave]{--hand-fill: #3a2748;--hand-outline: #b371d6;--key-fill: rgba(255, 126, 219, .05);--key-stroke: rgba(255, 126, 219, .22);--key-active-fill: rgba(255, 126, 219, .22);--key-active-stroke: rgba(255, 126, 219, .5);--key-pressed-fill: rgba(255, 126, 219, .14);--key-active-text: #f4f4f5}html[data-theme=gruvbox-dark]{--hand-fill: #4a3e2c;--hand-outline: #a89672;--key-fill: rgba(235, 219, 178, .05);--key-stroke: rgba(235, 219, 178, .22);--key-active-fill: rgba(235, 219, 178, .22);--key-active-stroke: rgba(235, 219, 178, .5);--key-pressed-fill: rgba(235, 219, 178, .14);--key-active-text: #fbf1c7}html[data-theme=terminal-green]{--hand-fill: #1e3a25;--hand-outline: #4a8550;--key-fill: rgba(57, 255, 20, .05);--key-stroke: rgba(57, 255, 20, .22);--key-active-fill: rgba(57, 255, 20, .22);--key-active-stroke: rgba(57, 255, 20, .5);--key-pressed-fill: rgba(57, 255, 20, .14)}html[data-theme=onyx]{--hand-fill: #2c3038;--hand-outline: #6e7686;--key-fill: rgba(160, 175, 200, .03);--key-stroke: rgba(160, 175, 200, .18);--key-active-fill: rgba(160, 175, 200, .22);--key-active-stroke: rgba(160, 175, 200, .42);--key-pressed-fill: rgba(160, 175, 200, .12)}html[data-theme=carbon]{--hand-fill: #2e2e2e;--hand-outline: #5a5a5a;--key-fill: rgba(255, 255, 255, .035);--key-stroke: rgba(255, 255, 255, .18);--key-active-fill: rgba(120, 169, 255, .22);--key-active-stroke: rgba(120, 169, 255, .5);--key-pressed-fill: rgba(255, 255, 255, .12)}html[data-theme=cobalt]{--hand-fill: #033a5e;--hand-outline: #4a90c0;--key-fill: rgba(255, 198, 0, .04);--key-stroke: rgba(255, 198, 0, .24);--key-active-fill: rgba(255, 198, 0, .24);--key-active-stroke: rgba(255, 198, 0, .55);--key-pressed-fill: rgba(255, 198, 0, .14);--key-active-text: #e1f5fe}html[data-theme=graphite]{--hand-fill: #3a3e46;--hand-outline: #7c828e;--key-fill: rgba(255, 255, 255, .025);--key-stroke: rgba(170, 180, 195, .22);--key-active-fill: rgba(180, 188, 200, .28);--key-active-stroke: rgba(180, 188, 200, .5);--key-pressed-fill: rgba(150, 160, 175, .22)}html[data-theme=gray]{--hand-fill: #525252;--hand-outline: #9a9a9a;--key-fill: rgba(255, 255, 255, .05);--key-stroke: rgba(255, 255, 255, .22);--key-active-fill: rgba(255, 255, 255, .28);--key-active-stroke: rgba(255, 255, 255, .5);--key-pressed-fill: rgba(255, 255, 255, .18)}html[data-theme=dark-gray]{--hand-fill: #323232;--hand-outline: #707070;--key-fill: rgba(255, 255, 255, .04);--key-stroke: rgba(255, 255, 255, .18);--key-active-fill: rgba(255, 255, 255, .22);--key-active-stroke: rgba(255, 255, 255, .42);--key-pressed-fill: rgba(255, 255, 255, .14)}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg-main);color:var(--text-primary);font-family:var(--font-mono);min-height:100vh;display:flex;flex-direction:column;align-items:center;user-select:none;-webkit-user-select:none}#app{width:100%;max-width:960px;padding:30px 40px;display:flex;flex-direction:column;gap:20px}.brand-footer{margin-top:auto;padding:16px 40px 20px;width:100%;text-align:center;font-size:11px;letter-spacing:1px;color:var(--text-secondary, #555);opacity:.55;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:.5em}.brand-footer a{color:inherit;text-decoration:none;transition:color .15s,opacity .15s}.brand-footer a:hover{color:var(--accent);opacity:1}.brand-footer .sep{opacity:.5}header{display:flex;align-items:baseline;justify-content:space-between;width:100%}header h1{font-size:1.25rem;font-weight:700;color:var(--accent);letter-spacing:.5px;margin:0}header h1.brand-h1{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-sub)}header h1.brand-h1 .brand-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-sub);text-decoration:none;transition:color .15s}header h1.brand-h1 .brand-link:hover{color:var(--accent)}header h1.brand-h1 .brand-sep{color:var(--text-sub);opacity:.4;margin:0 .5rem;font-weight:400}header h1.brand-h1 .page-name{color:var(--text-main)}.auth-page{position:relative;width:100%;min-height:calc(100vh - 80px);align-items:center!important;align-self:stretch;padding:1rem!important}.auth-home{position:absolute;top:1.25rem;left:1.75rem;display:inline-flex;align-items:center;gap:.5rem;color:var(--text-sub);text-decoration:none;font-size:.95rem;font-weight:600;letter-spacing:.3px;transition:color .15s;z-index:1}.auth-home:hover{color:var(--accent)}.auth-card{padding:2rem 1.75rem}.auth-card h1{font-size:1.4rem!important;letter-spacing:.5px}.stats-link{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;color:var(--text-sub);text-decoration:none;transition:color .15s ease,background-color .15s ease}.stats-link:hover{color:var(--accent);background:var(--option-btn-active-bg)}.header-actions{display:flex;align-items:center;gap:6px}.header-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;border:none;background:transparent;color:var(--text-sub);font-size:16px;cursor:pointer;transition:color .15s ease,background-color .15s ease}.header-btn:hover{color:var(--accent);background:var(--option-btn-active-bg)}.header-btn.active{color:var(--text-primary);background:var(--option-btn-active-bg)}#live-stats{display:flex;gap:24px;font-size:14px;color:var(--text-sub);opacity:0;transition:opacity .3s ease;height:20px}#live-stats.visible{opacity:1}#live-stats .stat-value{color:var(--accent);font-weight:500}#live-stats .live-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;background:none;border:none;padding:0;color:inherit;font:inherit;display:inline-flex;align-items:baseline;gap:4px}.text-area-wrap{position:relative}#text-container{position:relative;padding:20px 0;height:200px;overflow:hidden;scroll-behavior:smooth;-webkit-mask-image:linear-gradient(to bottom,black 0%,black 72%,transparent 100%);mask-image:linear-gradient(to bottom,black 0%,black 72%,transparent 100%)}#text-display{font-size:var(--text-font-size);line-height:var(--text-line-height);color:var(--text-sub);position:relative;transition:filter .3s ease,opacity .3s ease}#text-container.unfocused #text-display{filter:blur(7px);opacity:.22}#text-container.unfocused #cursor{visibility:hidden}#text-display .word{display:inline-flex;align-items:baseline;margin-right:.5ch}#text-display.code-mode{tab-size:4;-moz-tab-size:4}#text-display.code-mode .word.line{display:block;margin-right:0;white-space:pre-wrap;overflow-wrap:break-word}#text-display.show-line-end .word.line .char:last-child{white-space:nowrap}.icon-return{display:inline-block;width:.85em;height:.85em;vertical-align:-.1em;background-color:currentColor;-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='9 10 4 15 9 20'/><path d='M20 4v7a4 4 0 0 1-4 4H4'/></svg>");mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='9 10 4 15 9 20'/><path d='M20 4v7a4 4 0 0 1-4 4H4'/></svg>");-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-position:center;mask-position:center;-webkit-user-select:none;user-select:none}#text-display.show-line-end .word.line .char:last-child:after{content:"";display:inline-block;width:.85em;height:.85em;margin-left:.45ch;vertical-align:-.08em;background-color:var(--accent);opacity:.55;-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='9 10 4 15 9 20'/><path d='M20 4v7a4 4 0 0 1-4 4H4'/></svg>");mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='9 10 4 15 9 20'/><path d='M20 4v7a4 4 0 0 1-4 4H4'/></svg>");-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-position:center;mask-position:center;-webkit-user-select:none;user-select:none}#text-display.code-mode .word.line.word-error{border-bottom:none}#text-display .char.tab{color:#64666973}#text-display .char.whitespace.incorrect{background:#ca475452;border-radius:2px}#text-display .char{position:relative;transition:color .05s}#text-display .char.correct{color:var(--text-primary)}#text-display .char.incorrect{color:var(--error)}#text-display .char.extra{color:var(--error-extra)}#text-display .word.word-error{border-bottom:2px solid var(--error)}#text-display.blind .char.correct,#text-display.blind .char.incorrect,#text-display.blind .char.extra{color:var(--text-primary);text-decoration:none}#text-display.blind .char.whitespace.incorrect{background:transparent}#text-display.blind .word.word-error{border-bottom:none}#text-display .char-below{position:absolute;left:50%;top:100%;transform:translate(-50%,-2px);font-size:.55em;line-height:1;color:var(--error);pointer-events:none;white-space:pre}#text-display.blind .char-below{display:none}#cursor{position:absolute;width:3px;height:calc(var(--text-font-size) * 1.25);background:var(--cursor-color);top:0;left:0;pointer-events:none;z-index:10;transition:transform var(--cursor-move-duration) var(--cursor-move-easing);animation:blink 1s ease-in-out infinite;border-radius:1px}#cursor.no-transition{transition:none!important}#cursor.typing{animation:none;opacity:1}#text-container.caret-block #cursor{width:1ch;opacity:.55;border-radius:2px}#text-container.caret-underline #cursor{width:1ch;background:transparent;border-radius:0;box-shadow:none;background-image:linear-gradient(var(--cursor-color),var(--cursor-color));background-repeat:no-repeat;background-position:bottom;background-size:100% 3px}#text-container.caret-off #cursor{visibility:hidden}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}#focus-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:20;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .25s ease;background:none;border:none;padding:0;color:inherit;font:inherit}#focus-overlay.visible{opacity:1;pointer-events:auto}#focus-overlay span{color:var(--text-primary);font-family:var(--font-mono);font-size:18px;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;opacity:.92}#options-bar{display:flex;align-items:center;justify-content:center;padding:8px 0}#options-bar:before,#options-bar:after{content:"";flex:1 1 0;transition:flex-grow .38s cubic-bezier(.4,0,.2,1)}#options-bar.collapsed:after{flex-grow:0}.options-panel-wrap{display:grid;grid-template-columns:1fr;margin-right:10px;overflow-x:clip;overflow-y:visible;transition:grid-template-columns .38s cubic-bezier(.4,0,.2,1),margin-right .38s cubic-bezier(.4,0,.2,1)}.options-panel-wrap.collapsed{grid-template-columns:0fr;margin-right:0}.options-panel-wrap.menu-open{overflow:visible}.options-panel{display:flex;align-items:center;gap:10px;min-width:0;justify-self:end;width:max-content;transform-origin:right center;transition:opacity .38s cubic-bezier(.4,0,.2,1),transform .38s cubic-bezier(.4,0,.2,1)}.options-panel-wrap.collapsed .options-panel{opacity:0;transform:scaleX(.85);pointer-events:none}@media (max-width: 720px){.options-panel-wrap{min-width:0;flex:1 1 auto;grid-template-columns:1fr;max-height:200px;overflow:hidden;transition:max-height .38s cubic-bezier(.4,0,.2,1),margin-right .38s cubic-bezier(.4,0,.2,1)}.options-panel-wrap.collapsed{grid-template-columns:1fr;max-height:0}.options-panel{flex-wrap:wrap;justify-content:center;row-gap:6px;width:auto;max-width:100%;justify-self:stretch}}.options-actions{gap:2px}.options-actions #refresh-btn,.options-actions #toggle-options-btn{width:28px;height:28px;padding:0;border-radius:5px;color:var(--text-sub);opacity:.8;font-size:14px}.options-actions #refresh-btn:hover,.options-actions #toggle-options-btn:hover{color:var(--text-primary);opacity:1}.option-group{display:flex;align-items:center;gap:2px;background:var(--option-group-bg);border-radius:7px;padding:3px 4px}.option-btn{background:none;border:none;color:var(--text-sub);font-family:var(--font-mono);font-size:13px;padding:5px 11px;border-radius:5px;cursor:pointer;transition:color .15s,background .15s;outline:none}.option-btn:hover{color:var(--text-primary)}.option-btn.active{color:var(--text-primary);background:var(--option-btn-active-bg);font-weight:600}.option-icon-btn{width:28px;padding:5px 0;display:inline-flex;align-items:center;justify-content:center;font-size:14px}.option-btn.disabled,.option-group.disabled .option-btn{opacity:.35;cursor:not-allowed;pointer-events:none}.lang-dropdown{position:relative}.lang-trigger .caret{font-size:10px;margin-left:4px;opacity:.7}.lang-menu{position:absolute;top:calc(100% + 4px);left:50%;transform:translate(-50%);z-index:50;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:2px;background:var(--bg-elevated);border:1px solid rgba(255,255,255,.08);border-radius:7px;padding:4px;width:max-content;box-shadow:0 6px 20px #00000059}.lang-menu .option-btn{text-align:left;white-space:nowrap;color:var(--text-sub)}.lang-menu .option-btn:hover{color:var(--text-primary);background:var(--option-btn-active-bg)}.lang-menu .option-btn.active{color:var(--text-primary);background:var(--option-btn-active-bg);font-weight:600}#refresh-btn,#toggle-options-btn{background:none;border:none;color:var(--text-sub);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;outline:none;transition:color .2s ease,opacity .2s ease}#results{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-main);display:none;flex-direction:column;align-items:center;justify-content:center;gap:32px;z-index:50;padding:40px}#results.visible{display:flex}.results-card{display:grid;grid-template-columns:auto 1px 1.5fr;gap:48px;align-items:center;padding:40px 56px;border:1px solid rgba(82,139,255,.22);border-radius:14px;background:#ffffff04;box-shadow:0 8px 40px #528bff14,inset 0 0 0 1px #ffffff04;max-width:980px;width:100%}.results-left{display:flex;flex-direction:column;gap:36px;padding-right:12px}.results-divider{width:1px;height:100%;background:linear-gradient(to bottom,transparent 0%,rgba(255,255,255,.08) 20%,rgba(255,255,255,.08) 80%,transparent 100%)}.results-right{display:grid;grid-template-columns:1fr 1fr 1fr;gap:30px 44px;padding-left:12px}.stat-primary .label{font-size:18px;color:var(--text-sub);font-weight:400;letter-spacing:.5px;margin-bottom:4px;text-transform:lowercase}.stat-primary .value{font-size:92px;font-weight:700;color:var(--accent);line-height:.92;letter-spacing:-3px;font-variant-numeric:tabular-nums}.stat-small .label{font-size:13px;color:var(--text-sub);letter-spacing:.5px;margin-bottom:6px;text-transform:lowercase}.stat-small .value{font-size:26px;font-weight:500;color:var(--text-primary);line-height:1;font-variant-numeric:tabular-nums}.stat-small .value.chars{display:flex;align-items:baseline;gap:2px}.stat-small .value .c-correct{color:var(--text-primary)}.stat-small .value .c-incorrect{color:var(--error)}.stat-small .value .c-extra{color:var(--error-extra)}.stat-small .value .c-missed{color:var(--accent)}.stat-small .value .c-sep{color:var(--text-sub);opacity:.35;margin:0 2px;font-weight:300}.results-keyboard-section{display:flex;flex-direction:column;align-items:center;gap:14px;width:100%;max-width:980px}.results-keyboard-section .kb-label{font-size:12px;color:var(--text-sub);letter-spacing:2px;text-transform:uppercase;opacity:.75}#keyboard-container{display:flex;justify-content:center;padding:8px 0 0;transition:margin-top .38s cubic-bezier(.4,0,.2,1)}#keyboard-container svg{width:100%;max-width:640px}.key rect{fill:var(--key-fill);stroke:var(--key-stroke);transition:fill .1s ease,stroke .1s ease}.key text{transition:fill .1s ease,opacity .1s ease}.hand-paths{fill:var(--hand-fill)}.hand-group feFlood{flood-color:var(--hand-outline)}.key.active rect{fill:var(--key-active-fill)!important;stroke:var(--key-active-stroke)!important}.key.active text{fill:var(--key-active-text)!important;opacity:1!important}.key.pressed rect{fill:var(--key-pressed-fill)!important}.key.mod:not(.active) rect{fill:var(--key-active-fill)!important;stroke:var(--key-active-stroke)!important;stroke-width:1.2!important;fill-opacity:.7}.key.mod:not(.active) text{fill:var(--key-active-text)!important;opacity:1!important}.hand-group{pointer-events:none;transition:transform var(--hand-move-duration) var(--hand-move-easing);transform-box:fill-box}#keyboard-container.display-keys .hand-group,#keyboard-container.display-off .hand-group,#keyboard-container.display-off{display:none}.settings-trigger{font-size:15px;line-height:1;padding:5px 10px}.settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:100;display:flex;align-items:center;justify-content:center;padding:40px 20px}.settings-panel{background:var(--bg-elevated);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:24px 28px 28px;width:100%;max-width:720px;height:auto;max-height:calc(100vh - 80px);overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;color:var(--text-primary);font-family:var(--font-mono)}.settings-panel--main{height:min(820px,calc(100vh - 80px))}.settings-body{display:grid;grid-template-columns:140px 1fr;gap:24px;min-height:0;flex:1}.settings-nav{display:flex;flex-direction:column;gap:2px;border-right:1px solid rgba(255,255,255,.06);padding-right:16px}.settings-nav-item{background:transparent;border:none;color:var(--text-sub);font-family:var(--font-mono);font-size:12px;letter-spacing:1.5px;text-transform:uppercase;text-align:left;padding:8px 10px;border-radius:6px;cursor:pointer;transition:color .15s,background .15s}.settings-nav-item:hover{color:var(--text-primary)}.settings-nav-item.active{color:var(--text-primary);background:#ffffff0a;border-left:2px solid var(--accent);padding-left:8px}.settings-nav-contact{margin-top:auto;display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;color:var(--text-sub);text-decoration:none;font-family:var(--font-mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;opacity:.7;transition:color .15s,opacity .15s,background .15s}.settings-nav-contact:hover{color:var(--accent);opacity:1;background:#ffffff08}.settings-nav-contact svg{flex-shrink:0}.settings-content{min-height:0;overflow-y:auto;display:flex;flex-direction:column;scrollbar-gutter:stable;padding-right:14px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.18) transparent}.settings-content::-webkit-scrollbar{width:8px}.settings-content::-webkit-scrollbar-track{background:transparent}.settings-content::-webkit-scrollbar-thumb{background:#ffffff24;border-radius:4px}.settings-content::-webkit-scrollbar-thumb:hover{background:#ffffff3d}.settings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}.settings-header h2{font-size:14px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--text-sub)}.settings-close{background:none;border:none;color:var(--text-sub);font-size:26px;line-height:1;width:32px;height:32px;border-radius:6px;cursor:pointer;font-family:var(--font-mono);transition:color .15s,background .15s}.settings-close:hover{color:var(--text-primary);background:#ffffff0a}.settings-section-label{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--text-sub);margin-bottom:12px}.settings-section-label-spaced{margin-top:22px}.vim-ignore-empty{color:var(--text-sub);font-size:13px;font-style:italic;margin:0}.vim-ignore-list{list-style:none;padding:0;margin:0 0 12px;display:flex;flex-wrap:wrap;gap:6px}.vim-ignore-row{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border:1px solid var(--border);border-radius:4px;background:var(--bg-main);font-size:13px}.vim-ignore-row code{font-family:inherit;color:var(--text-main)}.vim-ignore-remove{background:none;border:none;color:var(--text-sub);cursor:pointer;padding:0;font-size:16px;line-height:1}.vim-ignore-remove:hover{color:var(--text-main)}.vim-ignore-clear{margin-top:4px}.rules-list{display:flex;flex-direction:column;gap:22px}.rule-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:24px;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.05)}.rule-row:last-child{border-bottom:none;padding-bottom:0}.rule-name{font-family:var(--font-mono);font-size:14px;color:var(--text-primary);margin-bottom:6px}.rule-description{font-family:var(--font-mono);font-size:11px;line-height:1.55;color:var(--text-sub);max-width:520px}.rule-toggle{display:flex;gap:6px;flex-shrink:0}.rule-toggle-btn{min-width:56px;padding:8px 14px;border:none;border-radius:6px;background:#ffffff0d;color:var(--text-sub);font-family:var(--font-mono);font-size:12px;cursor:pointer;transition:background .15s,color .15s}.rule-toggle-btn:hover{color:var(--text-primary)}.rule-toggle-btn.active{background:var(--accent);color:var(--bg-main)}.injection-intro{font-size:12px;line-height:1.55;color:var(--text-sub);max-width:640px;margin:2px 0 12px}.settings-modal-open-btn{display:inline-flex!important;align-items:center;gap:.6rem;background:transparent;border:1px solid var(--card-border, rgba(255, 255, 255, .14));color:var(--text-primary);font-family:var(--font-mono);font-size:13px;padding:.55rem .9rem;border-radius:7px;cursor:pointer;transition:color .15s,background .15s,border-color .15s}.settings-modal-open-btn:after{content:"›";margin-left:auto;color:var(--text-sub);font-size:1rem;line-height:1}.settings-modal-open-btn:hover{border-color:var(--text-sub);background:#ffffff0a}.settings-modal-open-btn:hover:after{color:var(--text-primary)}.settings-modal-open-btn .count-badge{min-width:1.5rem;padding:.05rem .4rem;border-radius:999px;background:#ffffff12;color:var(--text-sub);font-size:11px;font-weight:600;font-variant-numeric:tabular-nums;text-align:center}.settings-modal-open-btn .count-badge.active{background:color-mix(in srgb,var(--accent) 22%,transparent);color:var(--accent)}.injection-tabs{display:flex;gap:4px;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.06)}.injection-tab{border:none;background:transparent;color:var(--text-sub);font-family:var(--font-mono);font-size:12px;padding:6px 14px;border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.injection-tab:hover{color:var(--text-primary)}.injection-tab.active{background:var(--accent);color:var(--bg-main)}.injection-group{margin-bottom:4px}.injection-group-sub{display:block;font-size:11px;color:var(--text-sub);opacity:.8;margin:0 0 12px;max-width:640px;line-height:1.5}.injection-group .rules-list{gap:16px}.injection-group .rule-toggle-btn{min-width:48px;padding:6px 10px}.rules-footer{display:flex;justify-content:flex-end;margin-top:auto;padding:24px 0 4px;border-top:1px solid rgba(255,255,255,.06);position:sticky;bottom:0;background:linear-gradient(to bottom,transparent 0%,var(--bg-elevated) 18%,var(--bg-elevated) 100%);z-index:5}.rules-reset-btn{border:1px solid rgba(202,71,84,.35);background:transparent;color:var(--error);font-family:var(--font-mono);font-size:12px;padding:8px 16px;border-radius:6px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.rules-reset-btn:hover{background:#ca47541a;border-color:#ca475499}.theme-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.theme-swatch{display:flex;align-items:center;gap:12px;padding:10px 12px;background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:8px;cursor:pointer;font-family:var(--font-mono);color:var(--text-primary);opacity:.7;text-align:left;transition:opacity .15s,border-color .15s,background .15s}.theme-swatch:hover{opacity:1;border-color:#ffffff24}.theme-swatch.active{opacity:1;border-color:var(--accent);background:#ffffff09}.theme-swatch-preview{display:flex;align-items:center;gap:4px;padding:7px 9px;border-radius:5px;border:1px solid rgba(255,255,255,.05);flex-shrink:0}.theme-swatch-preview .dot{display:inline-block;width:8px;height:8px;border-radius:50%}.theme-swatch-name{font-size:13px;font-weight:500}.language-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:12px}.language-btn{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 12px;background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:8px;cursor:pointer;font-family:var(--font-mono);color:var(--text-primary);opacity:.7;text-align:left;transition:opacity .15s,border-color .15s,background .15s}.language-btn:hover{opacity:1;border-color:#ffffff24}.language-btn.active{opacity:1;border-color:var(--accent);background:#ffffff09}.language-native{font-size:13px;font-weight:500}.language-english{font-size:11px;color:var(--text-sub)}.layout-list{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.layout-row{display:flex;align-items:center;gap:6px;padding:6px 10px;background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:6px;transition:border-color .15s}.layout-row.active{border-color:var(--accent)}.layout-name-btn{flex:1;background:transparent;border:none;color:var(--text-primary);font-family:var(--font-mono);font-size:13px;text-align:left;cursor:pointer;display:flex;align-items:center;gap:8px;padding:0}.layout-sub{color:var(--text-sub);font-size:11px;opacity:.7}.dot-indicator{display:inline-block;width:8px;height:8px;border-radius:50%;background:#ffffff1f;flex-shrink:0}.dot-indicator.on{background:var(--accent)}.layout-action{background:transparent;border:1px solid rgba(255,255,255,.1);color:var(--text-sub);border-radius:4px;width:22px;height:22px;cursor:pointer;font-family:var(--font-mono);font-size:12px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;padding:0}.layout-action-text{width:auto;min-width:22px;padding:0 8px;white-space:nowrap}.confirm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:120;display:flex;align-items:center;justify-content:center;padding:20px}.confirm-panel{position:relative;background:var(--bg-elevated);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:28px 32px 22px;width:100%;max-width:440px;box-shadow:0 20px 60px #0009;font-family:var(--font-mono);text-align:center}.confirm-close{position:absolute;top:10px;right:12px;background:transparent;border:none;color:var(--text-sub);font-size:20px;line-height:1;width:28px;height:28px;border-radius:6px;cursor:pointer;transition:color .15s,background .15s}.confirm-close:hover{color:var(--text-primary);background:var(--option-btn-active-bg)}.confirm-title{font-size:13px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--text-sub);margin:0 0 14px}.confirm-body{font-size:13px;line-height:1.55;color:var(--text-primary);margin:0 0 14px}.confirm-actions{display:flex;gap:10px;justify-content:center;margin-top:14px}.confirm-btn{background:transparent;border:1px solid rgba(255,255,255,.12);color:var(--text-sub);font-family:var(--font-mono);font-size:13px;padding:8px 18px;border-radius:6px;cursor:pointer;transition:color .15s,border-color .15s,background .15s}.confirm-btn:hover{color:var(--text-primary);border-color:#ffffff40}.confirm-btn-primary{background:var(--accent);color:var(--bg-main);border-color:var(--accent);font-weight:600}.confirm-btn-primary:hover{color:var(--bg-main);filter:brightness(1.1);border-color:var(--accent)}.confirm-destroy-link{background:none;border:none;color:var(--text-sub);font-family:var(--font-mono);font-size:11px;opacity:.5;cursor:pointer;padding:4px 8px;text-decoration:underline;text-decoration-color:#e06c7559;text-underline-offset:3px;transition:color .15s,opacity .15s}.confirm-destroy-link:hover{color:#e06c75;opacity:1}.layout-action:hover{color:var(--text-primary)}.layout-action-confirm{color:var(--accent)}.layout-action-confirm:hover{color:var(--accent);filter:brightness(1.1)}.layout-action-danger{color:#e06c75;border-color:#e06c7566}.layout-action-danger:hover{color:#ff8088}.viewer-panel{max-width:960px}.viewer-header-actions{display:flex;align-items:center;gap:4px}.viewer-settings-btn{display:inline-flex;align-items:center;justify-content:center}.viewer-body{display:flex!important;flex-direction:column;gap:12px;padding:4px 0 0;grid-template-columns:none!important}.viewer-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.viewer-layers{display:flex;gap:6px;flex-wrap:wrap}.viewer-layer-btn{text-transform:lowercase;cursor:pointer}.viewer-shift-btn{cursor:pointer}.viewer-toggles{display:flex;gap:6px}.viewer-glyph{font-size:1.35em;line-height:1;font-weight:700;display:inline-block;vertical-align:-.08em;margin-right:2px}.viewer-preview{display:flex;align-items:center;justify-content:center;padding:12px 0;min-height:300px}.viewer-preview .layout-preview-svg{max-width:840px;max-height:300px}.viewer-preview .preview-key-mod{fill:var(--key-active-fill);stroke:var(--key-active-stroke);stroke-width:1.2;stroke-dasharray:none;fill-opacity:.7}.viewer-combos-btn{margin-left:8px}.viewer-combo-list{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;max-height:140px;overflow-y:auto;padding:4px 2px}.viewer-combo-item{min-width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-secondary, rgba(255, 255, 255, .04));border:1px solid rgba(255,255,255,.08);border-radius:4px;color:var(--text-primary);font-family:var(--font-mono);font-size:13px;padding:0 8px;white-space:nowrap;cursor:pointer}.viewer-combo-item:hover{border-color:#fff3}.viewer-combo-item.active{background:var(--accent);color:var(--bg-main);border-color:var(--accent)}.viewer-hint{color:var(--text-sub);font-size:12px;text-align:center;margin:4px 0 0;line-height:1.5;min-height:1.5em}.viewer-hint-hidden{visibility:hidden}.viewer-hint code{background:#ffffff0f;padding:1px 5px;border-radius:3px;font-size:11px}.viewer-hint-link{background:none;border:none;color:var(--accent);font-family:var(--font-mono);font-size:12px;padding:0;cursor:pointer;text-decoration:underline}.viewer-hint-link:hover{filter:brightness(1.15)}.layout-confirm-msg{flex:1;font-family:var(--font-mono);font-size:12px;color:var(--text-sub);padding:0 8px}.layout-rename-input{flex:1;background:#ffffff0a;border:1px solid rgba(255,255,255,.12);border-radius:4px;color:var(--text-primary);font-family:var(--font-mono);font-size:13px;padding:4px 8px;outline:none}.layout-rename-input:focus{border-color:#ffffff40}.layout-upload{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.layout-upload-label{color:var(--text-sub);font-size:12px;display:flex;align-items:center;gap:6px}.settings-template-dropdown .lang-trigger{font-size:12px;padding:5px 10px}.layout-preview-wrap{background:#0003;border:1px solid rgba(255,255,255,.05);border-radius:8px;padding:10px 12px;margin-bottom:12px;display:flex;justify-content:center;align-items:center}.layout-preview-wrap-sub{margin-top:10px;margin-bottom:4px}.layout-preview-svg{width:100%;max-width:440px;height:auto}.preview-key{fill:var(--key-fill);stroke:var(--key-stroke);stroke-width:1}.preview-key-mod{stroke:var(--accent);stroke-width:1.5;stroke-dasharray:2 2}.preview-key-selected{fill:var(--accent);stroke:var(--accent);stroke-width:1.5}.resolve-preview{display:flex;flex-direction:column;align-items:center;gap:6px}.resolve-preview-layer{font-family:var(--font-mono);font-size:11px;color:var(--text-sub);text-transform:lowercase}.resolve-preview-layer strong{color:var(--accent);font-weight:500}.resolve-list{display:flex;flex-direction:column;gap:6px;margin-top:12px;max-height:260px;overflow-y:auto;padding-right:4px}.resolve-row{display:flex;align-items:center;gap:14px;padding:6px 8px;border-radius:6px;background:#ffffff05}.resolve-row:hover{background:#ffffff0d}.resolve-char{font-family:var(--font-mono);font-size:20px;color:var(--text-primary);min-width:28px;text-align:center}.resolve-candidates{display:flex;flex-wrap:wrap;gap:6px;flex:1}.resolve-candidate{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 10px;min-width:48px;cursor:pointer}.resolve-candidate.active{background:var(--accent);color:var(--bg-main)}.resolve-candidate-label{font-family:var(--font-mono);font-size:13px;display:inline-flex;align-items:center;gap:3px}.resolve-shift-badge{font-size:13px;font-weight:600;color:var(--accent)}.resolve-candidate.active .resolve-shift-badge{color:var(--bg-main)}.resolve-candidate-sub{font-size:10px;opacity:.7}.resolve-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:14px}.resolve-save{background:var(--accent);color:var(--bg-main);cursor:pointer}.layout-upload-btn{cursor:pointer}.layout-upload-error{margin-top:8px;color:#e06c75;font-size:12px;font-family:var(--font-mono);text-align:center}.layout-upload-notice{margin-bottom:12px;padding:8px 12px;background:#d4b87a14;border:1px solid rgba(212,184,122,.3);border-radius:4px;color:var(--accent);font-size:12px;font-family:var(--font-mono)}.layout-add-btn{margin-top:6px;cursor:pointer}.layout-add-hint{margin:20px 0 4px}.settings-back-btn{background:none;border:none;color:var(--text-secondary);font-family:var(--font-mono);font-size:12px;padding:0;cursor:pointer;margin-bottom:4px}.settings-back-btn:hover{color:var(--text-primary)}.add-layout-intro{color:var(--text-sub);font-family:var(--font-mono);font-size:12px;line-height:1.5;margin:6px 0 14px}.add-layout-intro code{font-family:var(--font-mono);color:var(--text-primary);background:#ffffff0d;padding:1px 5px;border-radius:4px}.layout-preview-hero{padding:16px 18px;margin-bottom:18px}.add-layout-toolbar{display:flex;justify-content:center;margin-top:4px}.add-layout-group{gap:6px}.add-layout-trigger{display:inline-flex;align-items:center;gap:6px;color:var(--text-primary);border:1px solid rgba(255,255,255,.14);background:#ffffff08;transition:color .15s,background .15s,border-color .15s}.add-layout-trigger:hover{background:#ffffff0f;border-color:#ffffff38}.add-layout-trigger .caret{opacity:.8}.lang-dropdown--up .lang-menu{top:auto;bottom:calc(100% + 4px)}.layout-upload-btn--action{display:inline-flex;align-items:center;gap:6px;color:var(--text-primary);border:1px solid color-mix(in srgb,var(--accent) 40%,transparent);background:color-mix(in srgb,var(--accent) 6%,transparent);transition:color .15s,background .15s,border-color .15s}.layout-upload-btn--action:before{content:"↑";opacity:.8}.layout-upload-btn--action:hover{background:color-mix(in srgb,var(--accent) 12%,transparent);border-color:color-mix(in srgb,var(--accent) 70%,transparent)}.add-layout-hint{color:var(--text-sub);font-size:11px;font-family:var(--font-mono);text-align:center;margin-top:10px}.tip.svelte-7l2cab{position:fixed;left:-9999px;top:-9999px;min-width:220px;max-width:min(360px,calc(100vw - 20px));background:var(--bg-elevated);color:var(--text-primary);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:.75rem .9rem;font-family:var(--font-mono);font-size:.8rem;line-height:1.5;box-shadow:0 10px 28px #0000008c;z-index:1000;pointer-events:none;animation:svelte-7l2cab-tip-in .12s ease-out}.tip-title.svelte-7l2cab{color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;margin-bottom:.35rem}.tip-body.svelte-7l2cab{color:var(--text-sub);overflow-wrap:break-word;white-space:pre-line}@keyframes svelte-7l2cab-tip-in{0%{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}.modal-backdrop.svelte-1qgj42l{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1100;padding:1rem}.modal-panel.svelte-1qgj42l{background:var(--bg-elevated, #2a2a2a);border:1px solid var(--card-border, rgba(255, 255, 255, .08));border-radius:12px;padding:2.2rem 2.25rem 1.4rem;width:min(560px,96vw);display:flex;flex-direction:column;align-items:center;gap:.9rem;box-shadow:0 18px 48px #00000080}.icon-wrap.svelte-1qgj42l{position:relative;display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;margin-bottom:.1rem;color:var(--accent)}.check.svelte-1qgj42l{filter:drop-shadow(0 0 12px var(--accent));animation:svelte-1qgj42l-pop .45s ease-out both}.sparkle.svelte-1qgj42l{position:absolute;color:var(--accent);opacity:.85;animation:svelte-1qgj42l-twinkle 1.6s ease-in-out infinite}.sparkle-a.svelte-1qgj42l{top:-4px;right:-6px;animation-delay:.1s}.sparkle-b.svelte-1qgj42l{bottom:0;left:-8px;animation-delay:.7s}@keyframes svelte-1qgj42l-pop{0%{transform:scale(.5);opacity:0}60%{transform:scale(1.08);opacity:1}to{transform:scale(1);opacity:1}}@keyframes svelte-1qgj42l-twinkle{0%,to{opacity:.3;transform:scale(.85)}50%{opacity:1;transform:scale(1.1)}}.title.svelte-1qgj42l{margin:.2rem 0 0;color:var(--text-main);font-size:1.2rem;text-align:center;letter-spacing:.01em}.body.svelte-1qgj42l{margin:0 0 .4rem;color:var(--text-sub);font-size:.9rem;line-height:1.5;text-align:center;max-width:28rem}.buttons.svelte-1qgj42l{display:flex;gap:.6rem;width:100%;justify-content:center;flex-wrap:wrap;margin-top:.2rem}.buttons.svelte-1qgj42l button:where(.svelte-1qgj42l){min-width:7rem;padding:.7rem 1.4rem;border-radius:6px;font:inherit;font-size:.92rem;font-weight:600;letter-spacing:.02em;white-space:nowrap;cursor:pointer;transition:filter .15s,border-color .15s,background .15s,color .15s}.primary.svelte-1qgj42l{background:var(--accent);color:var(--bg-main);border:1px solid var(--accent)}.primary.svelte-1qgj42l:hover{filter:brightness(1.1)}.secondary.svelte-1qgj42l{background:transparent;color:var(--text-sub);border:1px solid var(--card-border, rgba(255, 255, 255, .15));font-weight:500}.secondary.svelte-1qgj42l:hover{color:var(--text-main);border-color:var(--text-sub)}.reset-link.svelte-1qgj42l{margin-top:.4rem;padding:.2rem .4rem;background:none;border:none;color:var(--text-sub);font:inherit;font-size:.75rem;cursor:pointer;opacity:.45;text-decoration:underline;transition:opacity .15s}.reset-link.svelte-1qgj42l:hover{opacity:.85}.reset-link.svelte-1qgj42l:disabled{cursor:default;opacity:.3}.modal-backdrop.svelte-1iyntpn{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1100;padding:1rem}.modal-panel.svelte-1iyntpn{background:var(--bg-elevated, #2a2a2a);border:1px solid var(--card-border, rgba(255, 255, 255, .08));border-radius:12px;padding:2.2rem 2.25rem 1.6rem;width:min(480px,96vw);display:flex;flex-direction:column;align-items:center;gap:.9rem;box-shadow:0 18px 48px #00000080}.icon-wrap.svelte-1iyntpn{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;color:var(--accent);margin-bottom:.1rem}.title.svelte-1iyntpn{margin:.1rem 0 0;color:var(--text-main);font-size:1.2rem;text-align:center}.body.svelte-1iyntpn{margin:0 0 .4rem;color:var(--text-sub);font-size:.9rem;line-height:1.5;text-align:center;max-width:28rem}.categories.svelte-1iyntpn{list-style:none;padding:0;margin:0 0 .4rem;display:flex;flex-direction:column;gap:.35rem;align-self:stretch}.categories.svelte-1iyntpn li:where(.svelte-1iyntpn){color:var(--text-main);font-size:.88rem;padding:.45rem .7rem;border:1px solid var(--card-border, rgba(255, 255, 255, .08));border-radius:6px;background:color-mix(in srgb,var(--accent) 4%,transparent)}.buttons.svelte-1iyntpn{display:flex;gap:.6rem;width:100%;justify-content:center;flex-wrap:wrap;margin-top:.2rem}.buttons.svelte-1iyntpn button:where(.svelte-1iyntpn){min-width:10rem;padding:.7rem 1.4rem;border-radius:6px;font:inherit;font-size:.92rem;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:filter .15s,border-color .15s,background .15s,color .15s}.primary.svelte-1iyntpn{background:var(--accent);color:var(--bg-main);border:1px solid var(--accent)}.primary.svelte-1iyntpn:hover{filter:brightness(1.1)}.primary.svelte-1iyntpn:disabled{opacity:.6;cursor:default}.secondary.svelte-1iyntpn{background:transparent;color:var(--text-sub);border:1px solid var(--card-border, rgba(255, 255, 255, .15));font-weight:500}.secondary.svelte-1iyntpn:hover{color:var(--text-main);border-color:var(--text-sub)}.secondary.svelte-1iyntpn:disabled{opacity:.6;cursor:default}.hint.svelte-1iyntpn{margin:.3rem 0 0;color:var(--text-sub);font-size:.72rem;opacity:.55;text-align:center;max-width:24rem;line-height:1.4}
