:root{--bg:#fff;--fg:#0f172a;--muted:#64748b;--line:#e2e8f0;--brand:#4f46e5;--brand-dark:#4338ca;--card:#f8fafc;--surface:#fff;--error:#dc2626;--success:#16a34a;--header-bg:hsla(0,0%,100%,.9);--hero-grad:linear-gradient(180deg,#eef2ff,#fff);--radius:10px;--maxw:960px}[data-theme=dark]{--bg:#0b1120;--fg:#e2e8f0;--muted:#94a3b8;--line:#1e293b;--brand:#818cf8;--brand-dark:#6366f1;--card:#111827;--surface:#0f172a;--error:#f87171;--success:#4ade80;--header-bg:rgba(11,17,32,.9);--hero-grad:linear-gradient(180deg,#111827,#0b1120)}html{color-scheme:light}[data-theme=dark] html,html[data-theme=dark]{color-scheme:dark}*{box-sizing:border-box}body,html{margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--fg);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}a{color:var(--brand);text-decoration:none}a:hover{text-decoration:underline}.container{max-width:var(--maxw);margin:0 auto;padding:0 1.25rem}main{min-height:60vh}.site-header{border-bottom:1px solid var(--line);position:-webkit-sticky;position:sticky;top:0;background:var(--header-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10}.header-inner{display:flex;align-items:center;justify-content:space-between;height:60px;gap:1rem}.logo{font-weight:800;font-size:1.25rem;color:var(--fg);flex-shrink:0}.nav{display:flex;gap:1.1rem;font-size:.92rem;min-width:0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.nav::-webkit-scrollbar{display:none}.nav a{color:var(--muted);font-weight:500;white-space:nowrap}.nav a:hover{color:var(--brand);text-decoration:none}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--line);background:var(--surface);color:var(--fg);border-radius:8px;cursor:pointer;flex-shrink:0;transition:border-color .15s,color .15s}.theme-toggle:hover{border-color:var(--brand);color:var(--brand)}.hero{background:var(--hero-grad);padding:3rem 0 2rem;text-align:center;border-bottom:1px solid var(--line)}.hero h1{font-size:2.1rem;margin:0 0 .5rem}.lead{color:var(--muted);font-size:1.05rem;margin:.25rem 0 0}section{padding:2rem 0}h1{font-size:1.9rem;line-height:1.2;margin:.5rem 0}h2{font-size:1.3rem;margin:1.5rem 0 .75rem}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));grid-gap:1rem;gap:1rem}.card{display:flex;flex-direction:column;gap:.35rem;padding:1rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--card);transition:border-color .15s,transform .15s}.card:hover{border-color:var(--brand);text-decoration:none;transform:translateY(-2px)}.card strong{color:var(--fg)}.cat-card{align-items:flex-start}.cat-icon{display:block;color:var(--brand);margin-bottom:.15rem}.muted{color:var(--muted)}.breadcrumbs,.small{font-size:.85rem}.breadcrumbs{color:var(--muted);padding-top:1.25rem}.breadcrumbs .sep{margin:0 .4rem;opacity:.5}.tool-layout{padding-bottom:3rem}.tool-ui{margin:1.25rem 0 1rem;padding:1.25rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--card)}.prose{max-width:720px}.prose h2{font-size:1.2rem}.faq dt{font-weight:600;margin-top:.75rem}.faq dd{margin:.25rem 0 0;color:var(--muted)}.field-label{margin-bottom:.35rem}.inp,.ta{width:100%;padding:.75rem;border:1px solid var(--line);border-radius:8px;font-size:1rem;font-family:inherit;background:var(--surface)}.inp:focus,.ta:focus{outline:2px solid var(--brand);border-color:var(--brand)}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.9rem}.btn-row,.btn-set{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.75rem}.btn{padding:.55rem 1rem;border:1px solid var(--brand);background:var(--brand);color:#fff;border-radius:8px;font-weight:600;cursor:pointer;font-size:.92rem}.btn:hover{background:var(--brand-dark)}.btn-sm{padding:.3rem .6rem;border:1px solid var(--line);background:var(--surface);border-radius:6px;cursor:pointer;font-size:.8rem}.btn-sm:disabled{opacity:.4;cursor:not-allowed}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(90px,1fr));grid-gap:.75rem;gap:.75rem;margin-top:1rem}.stat{text-align:center;padding:.75rem;background:var(--surface);border:1px solid var(--line);border-radius:8px}.stat-num{display:block;font-size:1.5rem;font-weight:700;color:var(--brand)}.stat-label{font-size:.8rem;color:var(--muted)}.result-list{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}.result-row{display:flex;align-items:center;gap:.75rem;background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:.5rem .75rem}.result-label{font-weight:600;min-width:96px;font-size:.9rem}.result-val{flex:1 1;word-break:break-all}.output{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:1rem;overflow:auto;margin-top:1rem;white-space:pre-wrap}.error{color:var(--error);font-weight:500;margin-top:.75rem}.input-row{display:flex;gap:.75rem;align-items:center}.swatch{width:56px;height:44px;border-radius:8px;border:1px solid var(--line);flex-shrink:0}.site-footer{border-top:1px solid var(--line);background:var(--card);margin-top:3rem;padding:2rem 0 1.5rem}.footer-grid{display:grid;grid-template-columns:1.5fr 1fr;grid-gap:2rem;gap:2rem}.footer-grid h4{margin:0 0 .5rem;font-size:.95rem}.footer-grid ul{list-style:none;padding:0;margin:0}.footer-grid li{margin:.3rem 0}.footer-grid a{color:var(--muted)}@media (max-width:600px){.hero h1{font-size:1.6rem}.nav{font-size:.82rem;gap:.7rem}.footer-grid{grid-template-columns:1fr}}.banner{align-items:center;gap:.6rem 1rem;margin:1rem 0 1.5rem;padding:.75rem 1rem;border:1px solid var(--line);border-radius:10px;background:var(--card)}.banner,.chip-row{display:flex;flex-wrap:wrap}.chip-row{gap:.5rem}.chip{display:inline-flex;align-items:center;gap:.4rem;padding:.28rem .7rem;border-radius:999px;font-size:.82rem;font-weight:600;line-height:1;border:1px solid var(--line);background:var(--surface);color:var(--fg)}.chip .dot{width:.5rem;height:.5rem;border-radius:999px;flex-shrink:0}.chip-live{color:var(--success);border-color:color-mix(in srgb,var(--success) 35%,transparent);background:color-mix(in srgb,var(--success) 12%,transparent)}.chip-live .dot{background:var(--success)}.chip-soon{color:var(--muted)}.chip-soon .dot{background:transparent;border:1.5px solid var(--muted)}.banner-note{font-size:.85rem;color:var(--muted);margin-left:auto}.soon-heading{margin-top:2.25rem}.card-soon{position:relative;opacity:.72;cursor:default}.card-soon:hover{border-color:var(--line);transform:none}.card-soon strong{color:var(--muted)}.soon-badge{position:absolute;top:.6rem;right:.6rem;font-size:.68rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:var(--brand);background:color-mix(in srgb,var(--brand) 14%,transparent);border:1px solid color-mix(in srgb,var(--brand) 30%,transparent);padding:.12rem .45rem;border-radius:999px}@media (max-width:600px){.banner-note{margin-left:0}}.output-block{margin-top:1rem}.output-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-bottom:.4rem}.output-block .output{margin-top:0}.field{display:block;margin-bottom:.85rem}.field-label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.3rem;color:var(--fg)}.field .inp{width:100%}.result-row-hl{border-color:color-mix(in srgb,var(--brand) 45%,transparent);background:color-mix(in srgb,var(--brand) 8%,transparent)}.result-row-hl .result-val{font-weight:700;color:var(--brand)}.btn-ghost{background:transparent;color:var(--brand)}.btn-ghost:hover{background:color-mix(in srgb,var(--brand) 10%,transparent)}.soon-heading{margin-top:2rem;font-size:1.1rem;color:var(--muted)}