:root{--accent:oklch(60% 0.104 184.7);--accent-hover:oklch(51.1% 0.086 186.4);--accent-light:oklch(95.3% 0.05 180.8);--accent-muted:oklch(60% 0.104 184.7 / 10%);--font-display:'DM Serif Display',serif;--font-body:'DM Sans',sans-serif;--font-mono:'DM Mono',monospace;--header-height:57px;--radius:10px;--radius-btn:7px;--transition:0.18s ease;--shadow:0 2px 16px oklch(0% 0 0 / 7%);--icon-size:1.1em;--icon-gap:0.3rem;--break-md:768px;--break-sm:640px;--break-lg:1024px;--coffee-amber:oklch(66.6% 0.157 58.3);--coffee-amber-deep:oklch(55.5% 0.146 49);--text-on-accent:oklch(99% 0.005 180);--overlay-bg:oklch(5% 0 0 / 65%)}[data-theme=light]{--border-color:oklch(92.8% 0.006 264.5);--card-bg:oklch(100% 0 0);--sidebar-bg:oklch(98.4% 0.003 247.9);--text-muted:oklch(55.1% 0.023 264.4);--bg:oklch(98.4% 0.003 247.9);--text:oklch(21% 0.032 264.7);--error-bg:oklch(97.1% 0.013 17.4);--error-color:oklch(57.7% 0.215 27.3);--error-border:oklch(88.5% 0.059 18.3);--text-on-error:oklch(99% 0.005 25);--status-ready-bg:oklch(96.2% 0.043 156.7);--status-ready-color:oklch(52.7% 0.137 150.1);--status-pending-bg:oklch(97.3% 0.069 103.2);--status-pending-color:oklch(47.3% 0.125 46.2);--status-pending-border:oklch(92.4% 0.115 95.7);--status-pending-accent:oklch(83.7% 0.164 84.4);--status-converting-bg:oklch(93.2% 0.032 255.6);--status-converting-color:oklch(37.9% 0.138 265.5);--status-error-bg:oklch(93.6% 0.031 17.7);--status-error-color:oklch(50.5% 0.19 27.5);--status-error-border:oklch(80.8% 0.103 19.6);--hero-bg:oklch(98.4% 0.014 180.7);--stats-bg:oklch(100% 0 0);--badge-bg:oklch(98.2% 0.018 155.8);--formula-bg:oklch(98.4% 0.003 247.9);--code-bg:oklch(98.4% 0.003 247.9);--code-color:oklch(27.8% 0.03 256.8);--highlight-bg:oklch(60% 0.104 184.7 / 18%);--match-bg:oklch(97.3% 0.069 103.2);--match-color:oklch(47.6% 0.103 61.9);--input-bg:oklch(98.4% 0.003 247.9);--diff-add-bg:oklch(96.2% 0.043 156.7);--diff-add-color:oklch(52.7% 0.137 150.1);--diff-rem-bg:oklch(93.6% 0.031 17.7);--diff-rem-color:oklch(50.5% 0.19 27.5);--fr-match-bg:oklch(90.5% 0.166 98.1 / 50%);--syntax-amber:oklch(76.9% 0.165 70.1);--syntax-violet:oklch(60.6% 0.219 292.7);--syntax-green:oklch(62.7% 0.17 149.2);--syntax-blue:oklch(68.5% 0.148 237.3);--syntax-green-code:oklch(69.6% 0.149 162.5);--badge-current-bg:oklch(94.3% 0.028 294.6);--badge-current-border:oklch(54.1% 0.247 293);--badge-current-color:oklch(54.1% 0.247 293);--badge-peer-bg:oklch(94.3% 0.028 294.6);--badge-peer-color:oklch(49.1% 0.241 292.6)}[data-theme=dark]{--border-color:oklch(33.5% 0.033 260.9);--card-bg:oklch(27.8% 0.03 256.8);--sidebar-bg:oklch(24.3% 0.025 264);--text-muted:oklch(71.4% 0.019 261.3);--bg:oklch(21% 0.032 264.7);--text:oklch(96.7% 0.003 264.5);--error-bg:oklch(23% 0.039 20.5);--error-color:oklch(71.1% 0.166 22.2);--error-border:oklch(39.6% 0.133 25.7);--text-on-error:oklch(15% 0.01 25);--status-ready-bg:oklch(39.3% 0.09 152.5);--status-ready-color:oklch(80% 0.182 151.7);--status-pending-bg:oklch(28.6% 0.064 53.8);--status-pending-color:oklch(83.7% 0.164 84.4);--status-pending-border:oklch(41.4% 0.105 45.9);--status-converting-bg:oklch(28.2% 0.087 267.9);--status-converting-color:oklch(80.9% 0.096 251.8);--status-error-bg:oklch(25.8% 0.089 26);--status-error-color:oklch(71.1% 0.166 22.2);--status-error-border:oklch(44.4% 0.161 26.9);--hero-bg:oklch(22.3% 0.024 186.4);--stats-bg:oklch(24.3% 0.025 264);--badge-bg:oklch(32% 0.044 167);--formula-bg:oklch(24.3% 0.025 264);--code-bg:oklch(21% 0.032 264.7);--code-color:oklch(92.8% 0.006 264.5);--highlight-bg:oklch(60% 0.104 184.7 / 30%);--match-bg:oklch(28.6% 0.064 53.8);--match-color:oklch(83.7% 0.164 84.4);--input-bg:oklch(21% 0.032 264.7);--diff-add-bg:oklch(39.3% 0.09 152.5);--diff-add-color:oklch(80% 0.182 151.7);--diff-rem-bg:oklch(25.8% 0.089 26);--diff-rem-color:oklch(71.1% 0.166 22.2);--fr-match-bg:oklch(55.1% 0.122 65.2 / 45%);--syntax-amber:oklch(83.7% 0.164 84.4);--syntax-violet:oklch(81.1% 0.101 293.6);--syntax-green:oklch(80% 0.182 151.7);--syntax-blue:oklch(75.4% 0.139 232.7);--syntax-green-code:oklch(77.3% 0.153 163.2);--badge-current-bg:oklch(28.3% 0.135 291.1);--badge-current-border:oklch(70.9% 0.159 293.5);--badge-current-color:oklch(70.9% 0.159 293.5);--badge-peer-bg:oklch(28.3% 0.135 291.1);--badge-peer-color:oklch(70.9% 0.159 293.5)}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--border-color:oklch(33.5% 0.033 260.9);--card-bg:oklch(27.8% 0.03 256.8);--sidebar-bg:oklch(24.3% 0.025 264);--text-muted:oklch(71.4% 0.019 261.3);--bg:oklch(21% 0.032 264.7);--text:oklch(96.7% 0.003 264.5);--error-bg:oklch(23% 0.039 20.5);--error-color:oklch(71.1% 0.166 22.2);--error-border:oklch(39.6% 0.133 25.7);--text-on-error:oklch(15% 0.01 25);--status-ready-bg:oklch(39.3% 0.09 152.5);--status-ready-color:oklch(80% 0.182 151.7);--status-pending-bg:oklch(28.6% 0.064 53.8);--status-pending-color:oklch(83.7% 0.164 84.4);--status-pending-border:oklch(41.4% 0.105 45.9);--status-converting-bg:oklch(28.2% 0.087 267.9);--status-converting-color:oklch(80.9% 0.096 251.8);--status-error-bg:oklch(25.8% 0.089 26);--status-error-color:oklch(71.1% 0.166 22.2);--status-error-border:oklch(44.4% 0.161 26.9);--hero-bg:oklch(22.3% 0.024 186.4);--stats-bg:oklch(24.3% 0.025 264);--badge-bg:oklch(32% 0.044 167);--formula-bg:oklch(24.3% 0.025 264);--code-bg:oklch(21% 0.032 264.7);--code-color:oklch(92.8% 0.006 264.5);--highlight-bg:oklch(60% 0.104 184.7 / 30%);--match-bg:oklch(28.6% 0.064 53.8);--match-color:oklch(83.7% 0.164 84.4);--input-bg:oklch(21% 0.032 264.7);--diff-add-bg:oklch(39.3% 0.09 152.5);--diff-add-color:oklch(80% 0.182 151.7);--diff-rem-bg:oklch(25.8% 0.089 26);--diff-rem-color:oklch(71.1% 0.166 22.2);--fr-match-bg:oklch(55.1% 0.122 65.2 / 45%);--syntax-amber:oklch(83.7% 0.164 84.4);--syntax-violet:oklch(81.1% 0.101 293.6);--syntax-green:oklch(80% 0.182 151.7);--syntax-blue:oklch(75.4% 0.139 232.7);--syntax-green-code:oklch(77.3% 0.153 163.2);--badge-current-bg:oklch(28.3% 0.135 291.1);--badge-current-border:oklch(70.9% 0.159 293.5);--badge-current-color:oklch(70.9% 0.159 293.5);--badge-peer-bg:oklch(28.3% 0.135 291.1);--badge-peer-color:oklch(70.9% 0.159 293.5)}}*,::after,::before{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);font-size:1rem;line-height:1.5;color:var(--text);background:var(--bg);min-height:100vh;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6{line-height:1.25}a{color:inherit;text-decoration:none}code{font-family:var(--font-mono);font-size:.88em}img,svg{display:block;max-width:100%}ol,ul{list-style:none}button,input,select,textarea{font:inherit;color:inherit;border:none;background:0 0}button{cursor:pointer}input[type=checkbox]{accent-color:var(--accent);cursor:pointer}textarea{font-family:var(--font-mono);font-size:.82rem;background:var(--code-bg);color:var(--code-color);border:1px solid var(--border-color);border-radius:var(--radius);padding:.65rem .85rem;resize:vertical;line-height:1.5}textarea:focus{border-color:var(--accent)}textarea:focus:not(:focus-visible){outline:0}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1.25rem}.main-layout{flex:1;display:grid;align-items:start}dialog{border:none;border-radius:var(--radius);background:var(--card-bg);color:var(--text);padding:0;max-width:640px;width:90vw;max-height:85vh;overflow-y:auto;place-self:center}dialog::backdrop{background:oklch(0 0 0 / 55%)}dialog article{padding:1.5rem}dialog header{display:flex;align-items:center;justify-content:space-between;padding-bottom:1rem;margin-bottom:1rem;border-bottom:1px solid var(--border-color)}dialog header h2{font-family:var(--font-display);font-size:1.3rem;margin:0}dialog header button[aria-label=Close]{background:0 0;border:1px solid var(--border-color);border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;cursor:pointer;color:var(--text-muted);transition:var(--transition)}dialog header button[aria-label=Close]::before{content:"✕"}dialog header button[aria-label=Close]:hover{border-color:var(--accent);color:var(--accent)}*{scrollbar-width:thin;scrollbar-color:var(--border-color) transparent}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::-webkit-scrollbar-corner{background:0 0}::-webkit-resizer{background:linear-gradient(135deg,transparent 40%,var(--border-color) 40%,var(--border-color) 50%,transparent 50%,transparent 70%,var(--border-color) 70%,var(--border-color) 80%,transparent 80%)}.skip-link{position:absolute;top:-100%;left:0;padding:.5rem 1rem;background:var(--card-bg);color:var(--accent);font-family:var(--font-body);font-size:.875rem;font-weight:600;border-radius:0 0 var(--radius) 0;border:1px solid var(--border-color);z-index:9999;transition:top .15s;text-decoration:none}.skip-link:focus-visible{top:0;outline:0}@media (prefers-reduced-motion:reduce){*,::after,::before{animation-duration:0s!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-property:color,background-color,border-color,outline-color,opacity,fill,stroke,box-shadow!important;transition-duration:.18s!important}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.js-hidden{display:none}.act-btn,.btn,.case-btn,.clear-btn,.copy-btn,.curr-refresh-btn,.enc-btn,.fetch-btn,.fmt-btn,.format-btn,.harmony-btn,.primary-btn,.quality-btn,.secondary-btn,.sort-btn,.tool-btn,.tu-btn{background:var(--bg);border:1px solid var(--border-color);border-radius:var(--radius-btn);padding:.45rem 1rem;font-size:.82rem;font-weight:500;cursor:pointer;transition:var(--transition);color:var(--text);margin:0;white-space:nowrap;line-height:1;min-height:44px;box-sizing:border-box;display:inline-flex;align-items:center}.tl-icon{display:inline-flex;align-items:center;justify-content:center;margin-right:var(--icon-gap);font-size:var(--icon-size);line-height:1}.act-btn:hover,.case-btn:hover,.copy-btn:hover,.enc-btn:hover,.fmt-btn:hover,.format-btn:hover,.harmony-btn:hover,.quality-btn:hover,.sort-btn:hover,.tool-btn:hover,.tu-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-muted)}.act-btn.primary,.btn.primary,.case-btn.active,.format-btn.active,.harmony-btn.active,.primary-btn,.quality-btn.active,.tool-btn.primary,.tu-btn.active{background:var(--accent);border-color:var(--accent);color:var(--text-on-accent)}.act-btn.primary:hover,.btn.primary:hover,.primary-btn:hover,.tool-btn.primary:hover{background:var(--accent-hover)}.act-btn.copied,.copy-btn.copied{border-color:var(--accent);color:var(--accent);background:var(--accent-muted)}.act-btn.small,.btn.small,.tool-btn.small{font-size:.76rem;padding:.35rem .85rem}.field-label,.label,.option-label,.panel-subtitle,.setting-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);display:block;margin-bottom:.3rem}.pane-label{height:40px;display:flex;align-items:center;justify-content:space-between;margin-bottom:.3rem}.pane-label-text{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.pane-actions{display:flex;align-items:center;gap:.4rem}.action-row{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 0;flex-wrap:wrap}.label-hint,.pane-hint{font-weight:400;text-transform:none;letter-spacing:0;opacity:.7}.color-field,.fr-input,.input-field,.txt-area{font-family:var(--font-mono);font-size:.82rem;background:var(--bg);border:1px solid var(--border-color);border-radius:var(--radius-btn);padding:.45rem .75rem;color:var(--text);width:100%;min-width:0;transition:border-color var(--transition);margin:0;min-height:unset;display:block}.color-field:focus,.fr-input:focus,.input-field:focus,.txt-area:focus{border-color:var(--accent)}.color-field:focus:not(:focus-visible),.fr-input:focus:not(:focus-visible),.input-field:focus:not(:focus-visible),.txt-area:focus:not(:focus-visible){outline:0;box-shadow:none}.txt-area{font-family:var(--font-mono);resize:vertical;min-height:180px}.txt-area.tall{min-height:260px}.color-field[readonly],.input-field[readonly]{background:var(--formula-bg);color:var(--accent);cursor:default;border-color:var(--border-color)}select.color-field,select.input-field{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b7280' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.25rem;cursor:pointer}.field-group,.form-group,.input-group{display:flex;flex-direction:column;gap:.5rem}.split-pane{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.pane{display:flex;flex-direction:column}.pane.mb{margin-bottom:1rem}.pane-layout{display:flex;margin-top:-1rem;margin-bottom:1rem;justify-content:end}.pane-status{display:flex;margin-bottom:.75rem;justify-content:flex-end}.badge,.img-status,.status-badge,.verify-badge,.wcag-badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.72rem;font-weight:700;padding:.2rem .6rem;border-radius:20px;letter-spacing:.02em;white-space:nowrap}.badge.valid,.img-status.ready,.status-badge.valid,.verify-badge.valid,.wcag-badge.pass{background:var(--status-ready-bg);color:var(--status-ready-color)}.badge.invalid,.img-status.error,.status-badge.invalid,.verify-badge.invalid,.wcag-badge.fail{background:var(--status-error-bg);color:var(--status-error-color)}.badge.warning,.img-status.pending,.status-badge.warning,.verify-badge.warning{background:var(--status-pending-bg);color:var(--status-pending-color)}.error-bar,.error-message{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem 1rem;background:var(--error-bg);border:1px solid var(--error-border);border-radius:var(--radius);font-size:.875rem;color:var(--error-color);margin-bottom:1rem}.field-row,.row-label{display:flex;align-items:center;gap:.5rem;min-width:0}.field-row .field-label{min-width:52px;margin:0;flex-shrink:0}.clear-btn,.copy-btn,.icon-btn,.swap-btn{background:var(--bg);border:1px solid var(--border-color);width:auto;height:auto;min-width:44px;min-height:44px;padding:.4rem .6rem;display:flex;align-items:center;justify-content:center;gap:.35rem;cursor:pointer;transition:var(--transition);font-size:.9rem;flex-shrink:0;margin:0;border-radius:var(--radius-btn);white-space:nowrap}.clear-btn.circular,.copy-btn.circular,.icon-btn.circular,.swap-btn.circular{border-radius:50%;width:44px;height:44px;min-width:44px;min-height:44px;padding:0}.clear-btn:hover,.copy-btn:hover,.icon-btn:hover,.swap-btn:hover{border-color:var(--accent);color:var(--accent)}.swap-btn{background:var(--accent-muted);border-color:var(--accent);color:var(--accent);will-change:transform}.swap-btn:hover{background:var(--accent);color:var(--text-on-accent);transform:rotate(180deg)}.sub-tabs,.tabs,.tool-tabs{display:flex;gap:.5rem;margin-bottom:0;border-bottom:2px solid var(--border-color);padding-bottom:0}.sub-tab,.tab,.tool-tab{background:0 0;border:1px solid var(--border-color);border-bottom:none;border-radius:6px 6px 0 0;padding:.65rem 1.2rem;font-size:.85rem;font-weight:600;cursor:pointer;color:var(--text-muted);transition:color var(--transition),background-color var(--transition),border-color var(--transition);margin:0}.sub-tab:hover,.tab:hover,.tool-tab:hover{color:var(--accent);background:var(--accent-muted);border-color:var(--accent)}.sub-tab.active,.tab.active,.tool-tab.active{color:var(--accent);background:var(--accent-muted);border-color:var(--accent);font-weight:700}.category-badge,.content-icon,.page-icon,.panel-icon{display:inline-grid;place-items:center;width:2.8rem;height:2.8rem;font-size:1.6rem;font-family:var(--font-body);background:var(--accent-muted);border:1px solid var(--border-color);border-radius:12px;padding:0;flex-shrink:0;line-height:1}@media (max-width:768px){.pane-label{height:auto;flex-wrap:wrap;gap:.4rem;padding-bottom:.4rem}.pane-actions{flex-wrap:wrap}.split-pane{grid-template-columns:1fr}.txt-area{min-height:140px}.txt-area.tall{min-height:180px}.action-row{padding:.5rem 0}}@media (max-width:480px){.action-row .tool-btn{flex:1;justify-content:center}.act-btn,.btn,.case-btn,.enc-btn,.fmt-btn,.format-btn,.sort-btn,.tool-btn{font-size:.78rem;padding:.4rem .75rem}}.site-header{border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100;backdrop-filter:blur(12px);background:color-mix(in srgb,var(--bg) 90%,transparent)}.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}.logo{display:flex;align-items:center;gap:.45rem;text-decoration:none;font-weight:600}.logo-icon-wrap{background-color:var(--accent);border-radius:5px}.header-nav{display:flex;gap:1.5rem;margin-left:auto;margin-right:1.5rem}.header-nav a{font-size:.875rem;font-weight:500;color:var(--text-muted);transition:color var(--transition)}.header-nav a:hover{color:var(--accent)}.header-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.color-btn,.theme-toggle{background:0 0;border:2px solid var(--border-color);border-radius:50%;width:44px;height:44px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:var(--transition);padding:0 0 1px 1px;margin:0 0 0 auto;flex-shrink:0}.color-btn:hover,.theme-toggle:hover{border-color:var(--accent);background:var(--accent-muted)}.color-scheme-selector{position:relative}[data-theme=dark] .color-btn{color:var(--accent)}[data-theme=dark] .color-btn:hover{opacity:.8}.color-scheme-panel{position:fixed;display:none;flex-wrap:wrap;gap:.75rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius);padding:1rem;z-index:200;box-shadow:0 4px 12px oklch(0 0 0 / 15%);min-width:220px;max-width:calc(100vw - 16px)}[data-theme=dark] .color-scheme-panel{box-shadow:0 4px 12px oklch(0 0 0 / 50%)}.color-option{background:var(--accent);border:3px solid transparent;border-radius:50%;width:44px;height:44px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:0;transition:var(--transition);padding:0;margin:0;flex-shrink:0}.color-option:focus-visible,.color-option:hover{box-shadow:0 0 0 3px var(--text)}.color-option.active{border-color:var(--text)}@media (max-width:680px){.header-inner{flex-wrap:wrap;padding:.65rem 0 0;gap:0;align-items:center}.logo{flex:1;padding-bottom:.65rem}.header-actions{padding-bottom:.65rem;flex-shrink:0}.header-nav{width:100%;order:3;margin:0;padding:.5rem 0;border-top:1px solid var(--border-color);gap:0;justify-content:space-around}.header-nav a{font-size:.82rem;padding:.25rem .5rem}}.site-footer{border-top:1px solid var(--border-color)}.site-footer p{font-size:.8rem;color:var(--text-muted);text-align:center;margin:0}.footer-inner{display:flex;gap:3rem}.footer-brand{flex:1}.footer-brand p{font-size:.82rem;text-align:left;color:var(--text-muted);margin:.25rem 0 0}.footer-links{display:flex;flex-direction:column;gap:.5rem}.footer-links strong{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.25rem}.footer-links a{font-size:.85rem;color:var(--text-muted);transition:color var(--transition)}.footer-links a:hover{color:var(--accent)}.footer-bottom{border-top:1px solid var(--border-color);padding-top:1.25rem}.footer-bottom p{font-size:.78rem;color:var(--text-muted);text-align:center;margin:0}.site-header{border-bottom:1px solid var(--border-color)}.header-inner{padding:.75rem 0}.logo-text{font-family:var(--font-display);color:var(--accent);letter-spacing:-.02em;font-size:1.3rem}.logo-icon{color:var(--accent);font-size:1.25rem}.ht-nav{display:grid;grid-template-columns:250px 1fr;align-items:center;background:var(--sidebar-bg);border-bottom:1px solid var(--border-color);min-height:50px}.ht-nav-logo{width:250px;flex-shrink:0;display:flex;align-items:center;gap:.5rem;text-decoration:none;color:var(--text);padding:0 1.25rem;font-size:.95rem;font-weight:600;white-space:nowrap}.ht-nav-inner{display:flex;align-items:stretch;overflow-x:auto;scrollbar-width:none}.ht-nav-inner::-webkit-scrollbar{display:none}.ht-nav .color-btn,.ht-nav .theme-toggle{width:44px;height:44px}.ht-tab{display:inline-flex;align-items:center;gap:.35rem;padding:.65rem 1rem;min-height:50px;font-size:.8rem;font-weight:500;font-family:var(--font-body);color:var(--text-muted);text-decoration:none;background:0 0;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s;margin-bottom:-1px;border-radius:0;flex-shrink:0}.ht-tab:hover{color:var(--accent)}.ht-tab:focus:not(:focus-visible){outline:0}.ht-tab:focus-visible{outline:0;background:var(--accent-muted);border-bottom-color:var(--accent);color:var(--accent)}.ht-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600;background:0 0}.ht-banner{padding:1rem 0;border-bottom:1px solid var(--border-color)}.ht-banner-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}.ht-banner h1{font-family:var(--font-display);font-size:1.75rem;letter-spacing:-.025em;line-height:1.2;margin:0 0 .2rem;color:var(--text);text-wrap:balance}.ht-banner p{font-size:.9rem;color:var(--text-muted);margin:0;line-height:1.55}.ht-banner-icon{width:2.75rem;height:2.75rem;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.4rem;background:var(--accent-muted);border:1px solid var(--border-color);border-radius:8px;line-height:1}.toolbar{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap;margin-bottom:1rem}.converter-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius);padding:1.75rem;margin-bottom:1.5rem}.sub-tabs{display:flex;gap:0;border-bottom:2px solid var(--border-color);margin-bottom:1.5rem}.sub-tab{background:0 0;border:none;border-bottom:2px solid transparent;border-radius:0;padding:.5rem 1rem;min-height:44px;font-size:.8rem;font-weight:500;color:var(--text-muted);cursor:pointer;margin-bottom:-2px;transition:color .15s,border-color .15s}.sub-tab:hover{color:var(--accent)}.sub-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600;background:0 0;outline:0;box-shadow:none}.sub-tab:focus:not(:focus-visible){outline:0;box-shadow:none}.sub-tab:focus-visible{outline:0;box-shadow:none;background:var(--accent-muted);border-bottom-color:var(--accent);color:var(--accent)}.site-footer{border-top:1px solid var(--border-color);padding:1.25rem 0;margin-top:auto}.footer-row{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}.footer-brand-sm{display:flex;align-items:center;gap:.4rem;font-family:var(--font-display);font-size:1rem;color:var(--accent);text-decoration:none;flex-shrink:0}.footer-copy{font-size:.77rem;color:var(--text-muted);margin:0;text-align:center}.support-link{display:flex;align-items:center;justify-content:center;gap:.35rem;margin-top:.5rem;font-size:.77rem;font-weight:600;color:var(--text-muted);text-decoration:none;transition:color var(--transition)}.support-link:hover{color:var(--accent)}.footer-links-sm{display:flex;gap:1.25rem;flex-shrink:0}.footer-links-sm a{font-size:.77rem;color:var(--text-muted);text-decoration:none;transition:color .15s}.footer-links-sm a:hover{color:var(--accent)}.ht-sidebar .main-layout,.ht-simple .main-layout{gap:1.75rem;padding-top:1.5rem;padding-bottom:0}.ht-sidebar .tool-main,.ht-simple .tool-main{padding:0 0 2rem;min-width:0}.ht-simple .footer-copy{margin-bottom:1rem}.ht-nav-container{display:flex;align-items:center;justify-content:space-between;padding-top:0;padding-bottom:0;min-height:50px}.ht-simple .sidebar{display:none}.ht-sidebar-body{display:grid;grid-template-columns:250px 1fr;min-height:calc(100vh - 50px)}.ht-sidebar-content{min-width:0;display:flex;flex-direction:column}.ht-sidebar .sidebar{background:var(--sidebar-bg);border-right:1px solid var(--border-color);overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.ht-sidebar .sidebar-label{font-size:.62rem;font-weight:700;letter-spacing:.11em;text-transform:uppercase;color:var(--text-muted);margin:0 0 .5rem;padding-left:.5rem;font-family:var(--font-body)}.ht-sidebar .sidebar ul{list-style:none;display:flex;flex-direction:column;gap:1px}.ht-sidebar .sidebar a,.ht-sidebar .tool-link,.ht-sidebar .tool-tab{display:flex;align-items:center;gap:0;padding:.42rem .5rem;border-radius:6px;font-size:.79rem;font-weight:500;font-family:var(--font-body);color:var(--text-muted);text-decoration:none;cursor:pointer;transition:var(--transition);line-height:1.3;white-space:nowrap;background:0 0;border:none;width:100%;text-align:left;border-bottom:none}.ht-sidebar .tl-icon{display:inline-flex;align-items:center;justify-content:center;width:1.75rem;flex-shrink:0;font-size:.8rem}.ht-sidebar .sidebar a:hover,.ht-sidebar .tool-link:hover,.ht-sidebar .tool-tab:hover{color:var(--accent);background:var(--accent-muted)}.ht-sidebar .tool-link:focus:not(:focus-visible),.ht-sidebar .tool-tab:focus:not(:focus-visible){outline:0}.ht-sidebar .tool-link.active,.ht-sidebar .tool-tab.active{background:var(--accent);color:var(--text-on-accent);border-bottom:none;font-weight:600}.ht-sidebar .sidebar-divider{border:none;border-top:1px solid var(--border-color);margin:.875rem 0}.ht-sidebar .tool-tabs{display:flex;flex-direction:column;gap:1px;border-bottom:none;margin-bottom:0;padding-bottom:0}.ht-sidebar .tool-tab{display:flex;width:100%;text-align:left;padding:.42rem .5rem;border-radius:6px;font-family:var(--font-body);font-size:.79rem;border-bottom:none;margin-bottom:0;background:0 0;border:none}.ht-nav-tab{font-size:.85rem;font-weight:500;color:var(--text-muted);text-decoration:none;padding:.35rem .75rem;border-radius:6px;transition:var(--transition)}.ht-nav-tab:hover{color:var(--text);background:var(--accent-muted)}.ht-nav-tab--active{color:var(--accent);font-weight:600}.blog-footer-inner{display:flex;gap:3rem;padding:2.5rem 0;flex-wrap:wrap}.blog-footer-brand{flex:1;min-width:160px}.blog-footer-brand p{font-size:.85rem;color:var(--text-muted);margin:.35rem 0 0}.blog-footer-links{display:flex;flex-direction:column;gap:.5rem;font-size:.85rem}.blog-footer-links strong{color:var(--text);font-weight:600;margin-bottom:.15rem}.blog-footer-links a{color:var(--text-muted);text-decoration:none}.blog-footer-links a:hover{color:var(--accent)}.ht-tab--my-tools{margin-left:.5rem;color:var(--accent)!important;border-color:var(--accent)!important;background:var(--accent-muted)}.ht-tab--my-tools:hover{background:var(--accent)!important;color:var(--text-on-accent)!important}@media (max-width:1024px){.ht-nav{grid-template-columns:auto 1fr auto}.ht-nav-logo{width:auto;padding:0 1rem}.ht-sidebar-body{grid-template-columns:220px 1fr}}@media (max-width:768px){.ht-nav{display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;min-height:auto;position:relative}.ht-nav-logo{flex:1;width:auto;padding:.5rem 0;justify-content:center}.ht-nav-container .header-actions .sidebar-toggle{display:flex;position:absolute;top:.4rem;left:.75rem;margin:0}.ht-nav-container .header-actions .theme-toggle{position:absolute;top:.4rem;right:3.5rem}.ht-nav-container .header-actions .color-scheme-selector{position:absolute;top:.4rem;right:.75rem}.ht-nav-container .header-actions{position:static;flex-shrink:0;gap:0;padding:0;width:0;overflow:visible}.ht-nav-container{order:3;width:100%;padding-left:0;padding-right:0;border-top:1px solid var(--border-color);justify-content:flex-start;position:static}.ht-nav-inner{flex:1;padding-left:.5rem;padding-right:.5rem}.ht-sidebar-body{grid-template-columns:1fr;min-height:calc(100vh - 82px)}.ht-sidebar .sidebar{display:none;position:fixed;top:0;left:0;width:280px;height:100vh;z-index:200;box-shadow:4px 0 24px oklch(0 0 0 / 18%)}.ht-sidebar .sidebar.open{display:flex}.sidebar-overlay{display:none;position:fixed;inset:0;background:oklch(0 0 0 / 40%);z-index:199}.sidebar-overlay.open{display:block}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:0 0;border:1px solid var(--border-color);border-radius:6px;cursor:pointer;color:var(--text-muted);font-size:1.1rem;flex-shrink:0;margin-left:.5rem;transition:var(--transition)}.sidebar-toggle:hover{color:var(--accent);border-color:var(--accent)}.ht-banner h1{font-size:1.35rem}.ht-banner p{font-size:.8rem}.ht-simple .main-layout{padding-top:1rem}}@media (max-width:480px){.container{padding:0 .875rem}.ht-tab{padding:.65rem;font-size:.75rem;min-height:44px}.ht-banner h1{font-size:1.1rem}.ht-banner p{font-size:.75rem}.blog-nav{grid-template-columns:1fr}.blog-nav-link--next{text-align:left}}.sidebar-toggle{display:none}@media (max-width:768px){.sidebar-toggle{display:flex}.ht-banner-icon{display:none}.ht-banner .container{padding-top:.75rem;padding-bottom:.75rem}.blog-footer-inner{flex-direction:column;gap:1.5rem;padding:1.5rem 0}.ht-tab--my-tools{padding-left:.65rem;padding-right:.65rem}}[data-color=red]{--accent:oklch(44.4% 0.161 26.9);--accent-hover:oklch(57.7% 0.215 27.3);--accent-light:oklch(93.6% 0.031 17.7);--accent-muted:oklch(63.7% 0.208 25.3 / 10%);--hero-bg:oklch(97.1% 0.013 17.4)}[data-theme=dark][data-color=red]{--accent:oklch(71.1% 0.166 22.2);--accent-hover:oklch(63.7% 0.208 25.3);--accent-light:oklch(15.5% 0.039 22.8);--accent-muted:oklch(71.1% 0.166 22.2 / 15%);--hero-bg:oklch(15.5% 0.039 22.8)}[data-color=teal]{--accent:oklch(60% 0.104 184.7);--accent-hover:oklch(51.1% 0.086 186.4);--accent-light:oklch(95.3% 0.05 180.8);--accent-muted:oklch(60% 0.104 184.7 / 10%);--hero-bg:oklch(98.2% 0.018 155.8)}[data-theme=dark][data-color=teal]{--hero-bg:oklch(22.3% 0.024 186.4)}[data-color=blue]{--accent:oklch(42.4% 0.181 265.6);--accent-hover:oklch(48.8% 0.217 264.4);--accent-light:oklch(93.2% 0.032 255.6);--accent-muted:oklch(62.3% 0.188 259.8 / 10%);--hero-bg:oklch(97% 0.014 254.6)}[data-theme=dark][data-color=blue]{--accent:oklch(71.4% 0.143 254.6);--accent-hover:oklch(62.3% 0.188 259.8);--accent-light:oklch(18.3% 0.066 265.7);--accent-muted:oklch(71.4% 0.143 254.6 / 15%);--hero-bg:oklch(18.3% 0.066 265.7)}[data-color=purple]{--accent:oklch(49.1% 0.241 292.6);--accent-hover:oklch(55.8% 0.252 302.3);--accent-light:oklch(94.6% 0.033 307.2);--accent-muted:oklch(62.7% 0.233 304.3 / 10%);--hero-bg:oklch(97.7% 0.014 308.3)}[data-theme=dark][data-color=purple]{--accent:oklch(70.9% 0.159 293.5);--accent-hover:oklch(60.6% 0.219 292.7);--accent-light:oklch(18% 0.071 282.9);--accent-muted:oklch(70.9% 0.159 293.5 / 15%);--hero-bg:oklch(18% 0.071 282.9)}[data-color=orange]{--accent:oklch(55.5% 0.146 49);--accent-hover:oklch(64.6% 0.194 41.1);--accent-light:oklch(95.4% 0.037 75.2);--accent-muted:oklch(70.5% 0.187 47.6 / 10%);--hero-bg:oklch(98% 0.016 73.7)}[data-theme=dark][data-color=orange]{--accent:oklch(75.8% 0.159 55.9);--accent-hover:oklch(70.5% 0.187 47.6);--accent-light:oklch(16.8% 0.031 41.1);--accent-muted:oklch(75.8% 0.159 55.9 / 15%);--hero-bg:oklch(16.8% 0.031 41.1)}#privacyModal .modal-content section{margin-bottom:1.5rem}#privacyModal .modal-content section:last-child{margin-bottom:0}#privacyModal h3{font-size:1.1rem;font-weight:600;margin:1.5rem 0 .75rem;color:var(--accent)}#privacyModal h4{font-size:1rem;font-weight:600;margin:1rem 0 .5rem}#privacyModal p{margin-bottom:.75rem;line-height:1.6}#privacyModal ul{margin-left:1.5rem;margin-bottom:.75rem;list-style:disc}#privacyModal li{margin-bottom:.4rem}#privacyModal code{background:var(--accent-muted);padding:.15em .4em;border-radius:4px;font-size:.9em}#privacyModal .last-updated{color:var(--text-muted);font-size:.875rem;margin-bottom:1.5rem}.blog-page{display:flex;flex-direction:column;min-height:100vh}.blog-page .article-main,.blog-page .blog-main{flex:1}.blog-hero{padding:3.5rem 0 2rem;border-bottom:1px solid var(--border-color)}.blog-hero-title{font-family:var(--font-display);font-size:3rem;letter-spacing:-.02em;margin:0 0 .5rem}.blog-hero-sub{font-size:1rem;color:var(--text-muted);margin:0}.blog-main{padding:2.5rem 0 4rem}.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem}.blog-card{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius);padding:1.5rem;text-decoration:none;color:inherit;transition:border-color var(--transition),transform var(--transition);position:relative}.blog-card::after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:0 4px 16px oklch(0 0 0 / 8%);opacity:0;transition:opacity var(--transition);pointer-events:none}.blog-card:hover{border-color:var(--accent)}.blog-card:hover::after{opacity:1}.blog-card-body{flex:1;min-width:0}.blog-card-meta{display:flex;align-items:center;gap:.65rem;font-size:.75rem;color:var(--text-muted);margin-bottom:.6rem}.blog-card-read{color:var(--accent);font-weight:500}.blog-card-title{font-family:var(--font-display);font-size:1.2rem;font-weight:400;letter-spacing:-.01em;margin:0 0 .5rem;line-height:1.3}.blog-card-desc{font-size:.875rem;color:var(--text-muted);margin:0 0 .75rem;line-height:1.6}.blog-card-tags{display:flex;flex-wrap:wrap;gap:.35rem}.blog-card-arrow{color:var(--text-muted);font-size:1.1rem;flex-shrink:0;transition:transform var(--transition),color var(--transition);margin-top:.15rem}.blog-card:hover .blog-card-arrow{transform:translateX(3px);color:var(--accent)}.blog-tag{display:inline-block;background:var(--accent-muted);color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);border-radius:20px;padding:.15rem .6rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.article-main{padding:3rem 0 6rem}.article-container{max-width:680px;align-self:start}.article-breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-muted);margin-bottom:2.5rem}.article-breadcrumb a{color:var(--accent);text-decoration:none}.article-breadcrumb a:hover{text-decoration:underline}.article-header{margin-bottom:3.5rem;padding-bottom:2.5rem;border-bottom:2px solid var(--border-color)}.article-meta{display:flex;align-items:center;gap:.5rem;font-size:.78rem;font-family:var(--font-mono);color:var(--text-muted);margin-bottom:1.25rem;text-transform:uppercase;letter-spacing:.05em}.article-meta-sep{opacity:.3}.article-title{font-family:var(--font-display);font-size:3rem;letter-spacing:-.03em;line-height:1.05;margin:0 0 1.25rem}.article-desc{font-size:1.2rem;color:var(--text-muted);margin:0 0 1.5rem;line-height:1.6;font-style:italic}.article-tags{display:flex;flex-wrap:wrap;gap:.35rem}.article-body{font-size:1.075rem;line-height:1.85;color:var(--text)}.article-body h2{font-family:var(--font-display);font-size:1.9rem;font-weight:400;letter-spacing:-.02em;line-height:1.15;margin:3.5rem 0 1rem;color:var(--text)}.article-body h3{font-size:1.05rem;font-weight:700;letter-spacing:.01em;text-transform:uppercase;margin:2.5rem 0 .75rem;color:var(--accent)}.article-body h4{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin:2rem 0 .5rem}.article-body p{margin:0 0 1.5rem}.article-body p>strong:first-child{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:.2rem}.article-body ol,.article-body ul{margin:0 0 1.5rem;padding-left:1.5rem}.article-body li{margin-bottom:.5rem;line-height:1.7}.article-body a{color:var(--accent);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;transition:color var(--transition)}.article-body a:hover{color:var(--accent-hover)}.article-body code{font-family:var(--font-mono);font-size:.83em;background:var(--code-bg);border:1px solid var(--border-color);border-radius:4px;padding:.15em .4em;color:var(--accent)}.article-body pre{background:var(--code-bg);border:1px solid var(--border-color);border-radius:var(--radius);margin:0 0 2rem;overflow-x:auto}.article-body pre[data-lang]::before{content:attr(data-lang);display:block;padding:.4rem 1rem;font-size:.68rem;font-family:var(--font-mono);font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);border-bottom:1px solid var(--border-color);background:oklch(0 0 0 / 4%)}.article-body pre code{display:block;padding:1.25rem;font-size:.875rem;background:0 0;border:none;color:var(--text);line-height:1.7}.article-body blockquote{margin:2.5rem 0;padding:1.25rem 1.5rem;border-radius:var(--radius);background:var(--accent-muted)}.article-body blockquote p{font-family:var(--font-display);font-size:1.4rem;font-style:italic;line-height:1.5;letter-spacing:-.01em;color:var(--text);margin:0}.article-body hr{border:none;margin:3.5rem auto;width:4rem;height:3px;background:var(--accent);border-radius:2px;opacity:.4}.article-body img{display:block;max-width:100%;border-radius:var(--radius);border:1px solid var(--border-color);margin:2.5rem auto}.article-body img+em{display:block;text-align:center;font-size:.82rem;color:var(--text-muted);margin-top:-1.75rem;margin-bottom:2.5rem;font-style:italic}.article-body table{width:100%;border-collapse:collapse;margin:0 0 2rem;font-size:.9rem}.article-body th{text-align:left;font-weight:700;font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);padding:.6rem .75rem;border-bottom:2px solid var(--border-color)}.article-body td{padding:.75rem;border-bottom:1px solid var(--border-color);vertical-align:top;line-height:1.5}.article-body tr:last-child td{border-bottom:none}.blog-nav{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:4rem 0 1.5rem;padding-top:2.5rem;border-top:1px solid var(--border-color)}.blog-nav-link{display:flex;flex-direction:column;gap:.25rem;padding:1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius);text-decoration:none;color:inherit;transition:border-color var(--transition)}.blog-nav-link:hover{border-color:var(--accent)}.blog-nav-link--next{text-align:right}.blog-nav-dir{font-size:.7rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--accent);font-weight:600}.blog-nav-title{font-size:.9rem;font-weight:500;line-height:1.4}.article-back{margin-top:1.5rem;text-align:center}@media (max-width:768px){.blog-hero-title{font-size:2.25rem}.article-title{font-size:2.1rem}.article-body{font-size:1rem}.article-desc{font-size:1.05rem}.blog-grid,.blog-nav{grid-template-columns:1fr}.blog-nav-link--next{text-align:left}}.article-layout{display:grid;grid-template-columns:1fr;gap:0;max-width:1100px}.article-toc{display:none}.toc-inner{position:sticky;top:5rem}.toc-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin:0 0 .75rem;padding:0}.toc-list{list-style:none;padding:0;margin:0;border-left:1px solid var(--border-color)}.toc-link{display:block;padding:.3rem .75rem .3rem .9rem;font-size:.8rem;line-height:1.4;color:var(--text-muted);text-decoration:none;border-radius:4px;transition:color var(--transition),background var(--transition)}.toc-link:hover{color:var(--text)}.toc-link.active{color:var(--accent);background:var(--accent-muted);font-weight:500}.blog-page .footer-inner{display:grid;grid-template-columns:3fr 1fr;gap:2rem;padding:.5rem 0 1.75rem}.footer-links{display:flex;flex-direction:column;gap:.35rem;text-align:right}@media (min-width:1100px){.article-layout{grid-template-columns:200px 1fr;gap:4rem}.article-toc{display:block;padding-top:7.5rem}}.blog-page .ht-nav{display:block}.blog-page .ht-nav-logo{width:auto;padding:0;margin-right:.75rem}.blog-page .ht-nav-container .header-actions{margin-left:auto}@media (max-width:768px){.blog-page .ht-nav-container{flex-wrap:wrap;order:0;border-top:none;padding:0 1.25rem}.blog-page .ht-nav-logo{flex:1;justify-content:flex-start;padding:.4rem 0}.blog-page .ht-nav-container .header-actions{order:2;width:auto;gap:.5rem;padding:.4rem 0;margin-left:auto}.blog-page .ht-nav-container .header-actions .color-scheme-selector,.blog-page .ht-nav-container .header-actions .theme-toggle{position:static}.blog-page .ht-nav-inner{order:3;width:100%;border-top:1px solid var(--border-color);padding-left:0}}@media (max-width:480px){.blog-page .ht-nav-container{padding:0 .875rem}}