:root{--bg:#f5f5f7;--surface:#ffffff;--surface-elevated:#ffffff;--surface-muted:#f2f2f7;--text:#1d1d1f;--muted:#6e6e73;--accent:#0071e3;--accent-soft:#2997ff;--accent-pop:#0077ed;--accent-mint:#34c759;--accent-violet:#5856d6;--border:#d2d2d7;--radius:14px;--tool-btn-size:38px;--shadow-accent:0 4px 14px rgba(0,113,227,0.2);--shadow-card:0 1px 2px rgba(0,0,0,0.04),0 8px 24px rgba(0,0,0,0.06);--grid-line:rgba(0,0,0,0.04);--card:var(--surface);--input:var(--surface)}.meme-tool-page{display:grid;grid-gap:1.15rem;gap:1.15rem;max-width:1120px;margin:0 auto}.tool-help{margin-top:1.1rem;border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:var(--shadow-card);padding:clamp(.8rem,2.4vw,1.1rem);display:grid;grid-gap:.7rem;gap:.7rem}.tool-help h2{margin:0;font-size:1.02rem}.tool-help>p{margin:0;color:var(--muted);font-size:.9rem}.tool-help__cols{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.8rem;gap:.8rem}.tool-help__card{border:1px solid var(--border);border-radius:10px;background:var(--surface);padding:.7rem .85rem;box-shadow:0 1px 2px rgba(0,0,0,.03)}.tool-help__card:first-child{border-left:3px solid #0071e3}.tool-help__card:last-child{border-left:3px solid #34c759}.tool-help__card h3{margin:0 0 .45rem;font-size:.9rem}.tool-help__card ol,.tool-help__card ul{margin:0;padding-left:1rem;display:grid;grid-gap:.35rem;gap:.35rem;color:var(--muted);font-size:.84rem}.meme-tool-head h1{margin:0;font-size:clamp(1.4rem,2.8vw,2rem)}.meme-tool-head p{margin:.45rem 0 0;color:var(--muted)}.meme-tool-layout{display:grid;grid-template-columns:minmax(320px,400px) minmax(0,1fr);grid-gap:clamp(.9rem,2vw,1.25rem);gap:clamp(.9rem,2vw,1.25rem);align-items:start}.meme-tool-panel,.meme-tool-preview-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:clamp(.85rem,2.3vw,1.1rem);box-shadow:var(--shadow-card);transition:border-color .2s ease,box-shadow .2s ease}.meme-tool-panel:hover,.meme-tool-preview-card:hover{border-color:color-mix(in srgb,#ea580c 35%,var(--border));box-shadow:0 10px 26px color-mix(in srgb,#ea580c 10%,rgba(0,0,0,.06))}.meme-tool-panel h2,.meme-tool-preview-card h2{margin:0 0 .95rem;font-size:1rem}.meme-tool-field{display:grid;grid-gap:.38rem;gap:.38rem;margin-bottom:.82rem}.meme-tool-field span{color:var(--muted);font-size:.84rem}.meme-tool-field input,.meme-tool-field select{width:100%;min-width:0;height:2.5rem;border:1px solid var(--border);border-radius:10px;background:var(--bg);color:var(--text);padding:0 .75rem;font:inherit;transition:border-color .18s ease,box-shadow .18s ease,background-color .2s ease}.meme-tool-field input[type=file]{padding:.35rem .45rem;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.meme-tool-field input[type=file]::file-selector-button{margin-right:.55rem;border:1px solid var(--border);border-radius:8px;background:color-mix(in srgb,var(--surface) 95%,var(--bg));color:var(--text);height:1.7rem;padding:0 .6rem;font:inherit;font-size:.8rem;cursor:pointer}.meme-tool-field input[type=file]::-webkit-file-upload-button{margin-right:.55rem;border:1px solid var(--border);border-radius:8px;background:color-mix(in srgb,var(--surface) 95%,var(--bg));color:var(--text);height:1.7rem;padding:0 .6rem;font:inherit;font-size:.8rem;cursor:pointer}.meme-tool-field input[type=range]{padding:0}.meme-tool-field input[type=color]{padding:.2rem;border-radius:10px;cursor:pointer}.meme-tool-floating-panel{border:1px solid var(--border);border-radius:14px;padding:.7rem;margin-bottom:.82rem;background:var(--surface-muted)}.meme-tool-floating-panel h3{margin:0 0 .65rem;font-size:.84rem;letter-spacing:-.01em}.meme-tool-btn:focus-visible,.meme-tool-field input:focus-visible,.meme-tool-field select:focus-visible,.meme-tool-template-item:focus-visible,.meme-tool-template-refresh:focus-visible{outline:none;border-color:color-mix(in srgb,var(--accent) 78%,var(--border));box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 20%,transparent)}.meme-tool-check{display:inline-flex;align-items:center;gap:.45rem;margin-bottom:.8rem;color:var(--muted);font-size:.9rem}.meme-tool-template-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin:.25rem 0 .5rem}.meme-tool-template-head strong{font-size:.88rem}.meme-tool-template-refresh{border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);height:2rem;padding:0 .75rem;font:inherit;font-size:.82rem;cursor:pointer}.meme-tool-template-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.5rem;gap:.5rem;max-height:260px;overflow:auto;border:1px solid var(--border);border-radius:10px;padding:.5rem;margin-bottom:.95rem;background:color-mix(in srgb,var(--surface) 93%,var(--bg))}.meme-tool-template-item{border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);padding:.35rem;display:grid;grid-gap:.25rem;gap:.25rem;text-align:left;cursor:pointer;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.meme-tool-template-item img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:6px;display:block}.meme-tool-template-item span{font-size:.74rem;line-height:1.2;display:-webkit-box;line-clamp:2;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}.meme-tool-template-item:hover{border-color:color-mix(in srgb,var(--accent) 65%,var(--border));transform:translateY(-1px);box-shadow:0 8px 14px color-mix(in srgb,var(--accent) 10%,transparent)}.meme-tool-template-empty{margin:.2rem;color:var(--muted);font-size:.8rem}.meme-tool-btn-row{display:grid;grid-gap:.6rem;gap:.6rem;margin-top:.45rem}.meme-tool-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border:1px solid color-mix(in srgb,var(--accent) 85%,#ffffff);border-radius:10px;height:2.6rem;background:var(--accent);color:#ffffff;font:inherit;font-weight:600;cursor:pointer}.meme-tool-btn--gradient{background:linear-gradient(135deg,#2563eb,#3b82f6)}.meme-tool-btn:hover{filter:brightness(.95)}.meme-tool-btn:disabled{cursor:not-allowed;opacity:.72}.meme-tool-btn svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.meme-tool-btn--ghost{background:color-mix(in srgb,var(--surface) 88%,var(--bg));color:var(--accent)}.meme-tool-note{margin:.8rem 0 0;border:1px solid var(--border);border-radius:10px;padding:.65rem .75rem;font-size:.86rem;color:var(--muted);background:color-mix(in srgb,var(--surface) 93%,var(--bg))}.meme-tool-pos-note{margin:-.2rem 0 .65rem;color:var(--muted);font-size:.78rem}.meme-tool-drag-options{display:grid;grid-gap:.35rem;gap:.35rem;margin:.15rem 0 .35rem}.meme-tool-drag-options>span{color:var(--muted);font-size:.8rem}.meme-tool-axis-group{display:flex;flex-wrap:wrap;gap:.35rem}.meme-tool-axis-btn{border:1px solid var(--border);border-radius:8px;height:1.95rem;padding:0 .6rem;font:inherit;font-size:.78rem;background:var(--bg);color:var(--text);cursor:pointer}.meme-tool-axis-btn.is-active{border-color:color-mix(in srgb,var(--accent) 78%,var(--border));background:color-mix(in srgb,var(--accent) 14%,var(--bg));color:color-mix(in srgb,var(--accent) 88%,#0f172a);font-weight:600}.meme-tool-axis-btn--reset{margin-left:auto}.meme-tool-canvas-wrap{position:relative;width:100%;border-radius:14px;border:1px solid color-mix(in srgb,var(--border) 85%,#ffffff);background-image:linear-gradient(45deg,#eef2ff 25%,transparent 0),linear-gradient(-45deg,#eef2ff 25%,transparent 0),linear-gradient(45deg,transparent 75%,#eef2ff 0),linear-gradient(-45deg,transparent 75%,#eef2ff 0);background-size:22px 22px;background-position:0 0,0 11px,11px -11px,-11px 0;overflow:hidden;aspect-ratio:1/1;isolation:isolate}.meme-tool-canvas{display:block;width:100%;height:100%;transform:translateZ(0);image-rendering:auto}.meme-tool-loading{position:absolute;inset:0;display:grid;place-items:center;background:color-mix(in srgb,var(--surface) 66%,#ffffff);font-weight:700;color:var(--accent);animation:memePulse .9s ease-in-out infinite alternate;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.meme-tool-drag-handle{position:absolute;z-index:2;width:20px;height:20px;border-radius:999px;border:2px solid #ffffff;background:color-mix(in srgb,var(--accent) 85%,#ffffff);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 55%,#0f172a),0 4px 10px color-mix(in srgb,#0f172a 25%,transparent);transform:translate(-50%,-50%);cursor:-webkit-grab;cursor:grab;touch-action:none}.meme-tool-drag-handle.is-active{cursor:-webkit-grabbing;cursor:grabbing;scale:1.08}.meme-tool-dim{margin:.6rem 0 0;color:var(--muted);font-size:.85rem}@keyframes memePulse{0%{opacity:.65}to{opacity:1}}@media (max-width:880px){.meme-tool-layout,.tool-help__cols{grid-template-columns:1fr}.meme-tool-preview-card{order:-1}.meme-tool-template-grid{grid-template-columns:repeat(3,minmax(0,1fr));max-height:220px}.meme-tool-drag-handle{width:18px;height:18px}}@media (max-width:620px){.meme-tool-page{gap:.95rem}.meme-tool-panel,.meme-tool-preview-card{border-radius:12px;padding:.8rem}.meme-tool-field{margin-bottom:.7rem}.meme-tool-btn{height:2.5rem;font-size:.86rem}.meme-tool-template-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}*,:after,:before{box-sizing:border-box}html{color-scheme:light}.skip-link{position:absolute;left:-9999px;top:.75rem;z-index:100;padding:.5rem .85rem;border-radius:8px;background:var(--surface);color:var(--text);border:1px solid var(--border);font-weight:600;font-size:.88rem;text-decoration:none;box-shadow:0 4px 16px color-mix(in srgb,#0f172a 12%,transparent)}.skip-link:focus-visible{left:.75rem;outline:2px solid color-mix(in srgb,var(--accent) 55%,transparent);outline-offset:2px}.admin-menu__trigger:focus-visible,.ai-chatbot-icon-btn:focus-visible,.ai-chatbot-send:focus-visible,.ai-chatbot-trigger:focus-visible,.archive-link:focus-visible,.back-to-top-btn:focus-visible,.compare-tool-merge__title-toggle:focus-visible,.hero__btn:focus-visible,.lang-toggle:focus-visible,.site-footer__nav a:focus-visible,.site-header__login-pill:focus-visible,.site-menu-btn:focus-visible,.site-mobile-nav a:focus-visible,.site-mobile-nav__trigger:focus-visible,.site-nav__link:focus-visible,.theme-toggle:focus-visible{outline:2px solid color-mix(in srgb,var(--accent) 55%,transparent);outline-offset:2px}body{position:relative;margin:0;min-height:100vh;font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.65;font-optical-sizing:auto;transition:background .3s ease,color .3s ease}h1,h2,h3{letter-spacing:-.02em;font-variation-settings:"wght" 700;text-wrap:balance}body:after,body:before{display:none}.site-footer,.site-header,.site-main{position:relative;z-index:1}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.site-header{position:-webkit-sticky;position:sticky;top:1rem;z-index:50;width:calc(100% - 2rem);max-width:1160px;margin:1rem auto 0;border-radius:14px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-card);transition:background .3s ease,border-color .3s ease,box-shadow .3s ease}.site-header__inner{margin:0;padding:.72rem clamp(.9rem,3vw,1.35rem);display:flex;align-items:center;justify-content:space-between;gap:1rem}.site-logo{font-weight:700;font-size:1.1rem;color:var(--text);display:inline-flex;align-items:center;gap:.55rem}.site-logo__image{border-radius:0;box-shadow:none;background:transparent}.site-nav{display:flex;align-items:center;gap:1.05rem;font-size:.92rem;font-weight:500}.site-nav a{color:var(--muted);transition:color .3s ease}.site-nav a:hover{color:var(--text);text-decoration:none}.site-nav-tools{position:relative}.site-nav-tools__trigger{display:inline-flex;align-items:center;gap:.25rem;color:var(--muted);border:0;background:transparent;font:inherit;cursor:pointer}.site-nav__link{position:relative;padding:.25rem .1rem}.site-nav__link.is-active{color:var(--accent)}.site-nav__link.is-active:after{content:"";position:absolute;left:50%;bottom:-.38rem;width:6px;height:6px;border-radius:999px;background:var(--accent);transform:translateX(-50%)}.site-nav-tools__menu{position:absolute;top:calc(100% + 8px);left:0;min-width:430px;padding:.45rem;border:1px solid var(--border);border-radius:10px;background:color-mix(in srgb,var(--surface) 94%,var(--bg));box-shadow:0 12px 24px color-mix(in srgb,#000 12%,transparent);display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.45rem;gap:.45rem;opacity:0;visibility:hidden;transform:translateY(-4px);transition:opacity .16s ease,transform .16s ease,visibility .16s ease;z-index:55}.site-nav-tools__menu.is-open{opacity:1;visibility:visible;transform:translateY(0)}.site-nav-tools:focus-within .site-nav-tools__menu,.site-nav-tools:hover .site-nav-tools__menu{opacity:1;visibility:visible;transform:translateY(0)}.site-nav-tools__item .icon-badge{transform:none}.site-nav-tools__item{display:inline-flex;align-items:center;gap:.42rem;color:var(--text);border-radius:7px;padding:.45rem .55rem;font-size:.86rem}.site-nav-tools__item:hover{text-decoration:none;background:color-mix(in srgb,var(--accent) 10%,var(--surface))}.site-nav-tools__group{display:grid;grid-gap:.2rem;gap:.2rem}.site-nav-tools__group-title{margin:0;padding:.25rem .55rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.theme-toggle{width:32px;height:32px;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--muted);display:grid;place-items:center;transition:color .3s ease,border-color .3s ease,background .3s ease,transform .3s ease}.theme-toggle:hover:not(:disabled){color:var(--text);border-color:var(--accent-soft);background:color-mix(in srgb,var(--accent-soft) 24%,var(--surface))}.theme-toggle:disabled{opacity:.7}.theme-toggle.is-rotating{transform:rotate(180deg)}.site-main{max-width:1160px;margin:0 auto;padding:clamp(1.15rem,4vw,2.2rem) clamp(.9rem,3vw,1.35rem) clamp(2.4rem,6vw,4rem)}.hero{margin-bottom:1.35rem;padding:clamp(1rem,3.8vw,1.45rem);border:1px solid var(--border);border-radius:calc(var(--radius) + 2px);background:var(--surface);box-shadow:var(--shadow-card)}.hero__badge{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:999px;padding:.26rem .6rem;font-size:.75rem;color:var(--accent);background:var(--surface-muted)}.hero h1{font-size:clamp(2rem,4vw,2.8rem);font-weight:800;letter-spacing:-.02em;margin:.8rem 0 .5rem}.hero p{margin:0;color:var(--muted);max-width:56ch}.hero-focus-row{margin-top:.85rem;display:flex;flex-wrap:wrap;justify-content:center;gap:.45rem}.hero-focus-pill .icon-badge{transform:none}.hero-focus-pill{display:inline-flex;align-items:center;gap:.35rem;border-radius:999px;padding:.3rem .62rem;font-size:.76rem;font-weight:600;border:1px solid var(--border);background:var(--surface-muted);color:var(--text)}.hero__actions{margin-top:1rem;display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center}.hero__btn{display:inline-flex;align-items:center;border-radius:10px;padding:.5rem .85rem;border:1px solid var(--border);font-size:.88rem;text-decoration:none;transition:transform .2s ease,filter .2s ease,border-color .2s ease,box-shadow .2s ease;font-weight:700}.hero__btn:hover{text-decoration:none;transform:translateY(-1px);box-shadow:0 6px 18px color-mix(in oklab,var(--accent),transparent 78%)}.hero__btn--primary{color:#fff;border-color:transparent;background:var(--accent);box-shadow:var(--shadow-accent)}.hero__btn--ghost{color:var(--text);border-color:var(--border);background:var(--surface)}.layout-grid{display:grid;grid-template-columns:1fr;grid-gap:2rem;gap:2rem}@media (min-width:880px){.layout-grid{grid-template-columns:minmax(0,1fr) 160px;align-items:start}}.post-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1rem}.post-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.35rem;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;box-shadow:var(--shadow-card)}.post-card:hover{transform:translateY(-2px);border-color:#c7c7cc;box-shadow:0 10px 28px rgba(0,0,0,.08)}.post-card h2{margin:0 0 .35rem;font-size:1.15rem}.post-card time{font-size:.8rem;color:var(--muted)}.post-card__meta{margin:0;display:inline-flex;align-items:center;gap:.38rem;color:var(--muted);font-size:.82rem}.post-card p{margin:.5rem 0 0;color:var(--muted);font-size:.95rem}.home-post-bento{margin-top:1.1rem;display:grid;grid-gap:.75rem;gap:.75rem;padding:clamp(.95rem,3.2vw,1.25rem);border:1px solid var(--border);border-radius:calc(var(--radius) + 2px);background:var(--surface);box-shadow:var(--shadow-card)}.home-post-bento__head{display:flex;justify-content:space-between;align-items:center;gap:.6rem}.home-post-bento__head h2{margin:0}.home-post-bento__grid{display:grid;grid-gap:.85rem;gap:.85rem;grid-template-columns:repeat(4,minmax(0,1fr));grid-auto-rows:minmax(132px,auto)}.home-post-bento__item{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:var(--surface-muted);box-shadow:0 1px 2px rgba(0,0,0,.04);transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.home-post-bento__item--featured{grid-column:span 2;grid-row:span 2}.home-post-bento__item--wide{grid-column:span 2}.home-post-bento__item:hover{transform:translateY(-2px);border-color:#c7c7cc;box-shadow:0 10px 24px rgba(0,0,0,.08)}.home-post-bento__link{position:relative;display:block;width:100%;aspect-ratio:4/3;min-height:180px;text-decoration:none;color:inherit}.home-post-bento__item--featured .home-post-bento__link{aspect-ratio:16/9;min-height:clamp(240px,34vw,360px)}.home-post-bento__image{width:100%;height:100%;object-fit:cover;filter:brightness(.66);transform:scale(1);transition:transform .24s ease,filter .24s ease;opacity:0}.home-post-bento__image.is-loaded{opacity:1}.home-post-bento__image-skeleton{position:absolute;inset:0;background:linear-gradient(110deg,color-mix(in srgb,var(--surface) 88%,var(--bg)) 25%,#ffffff 50%,color-mix(in srgb,var(--surface) 88%,var(--bg)) 75%);background-size:200% 100%;animation:bentoSkeleton 1.2s ease-in-out infinite;z-index:1}.home-post-bento__item:hover .home-post-bento__image{transform:scale(1.02);filter:brightness(.7)}.home-post-bento__image--fallback{display:grid;place-items:center;background:linear-gradient(160deg,#1d1d1f,#3a3a3c);color:#f5f5f7}.home-post-bento__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.62));z-index:2}.home-post-bento__content{position:absolute;left:.8rem;right:.8rem;bottom:.7rem;color:#f8fafc;display:grid;grid-gap:.3rem;gap:.3rem;z-index:3}.home-post-bento__content h3{margin:0;font-size:.95rem}.home-post-bento__item--featured .home-post-bento__content{left:1rem;right:1rem;bottom:.9rem}.home-post-bento__item--featured .home-post-bento__content h3{font-size:1.12rem}.home-post-bento__content p{margin:0;color:rgba(248,250,252,.88);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:.82rem}.home-post-bento__item--featured .home-post-bento__content p{font-size:.88rem}@keyframes bentoSkeleton{0%{background-position:180% 0}to{background-position:-20% 0}}@media (max-width:1024px){.home-post-bento__grid{grid-template-columns:repeat(2,minmax(0,1fr))}.home-post-bento__item--wide{grid-column:auto}}.breadcrumbs{font-size:.85rem;color:var(--muted);margin-bottom:.75rem}.breadcrumbs ol{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.35rem}.breadcrumbs li:not(:last-child):after{content:"/";margin-left:.35rem;color:var(--border)}.prose{font-size:1.02rem}.prose :is(h2,h3,h4)[id]{scroll-margin-top:5.5rem}.article-toc__list a{scroll-margin-top:5.5rem}.prose img{max-width:100%;height:auto;border-radius:8px}.article-toc{margin:0 0 1rem;padding:.85rem .95rem;border-radius:12px;border:1px solid color-mix(in oklab,var(--border),transparent 8%);background:color-mix(in oklab,var(--surface),transparent 2%)}.article-toc__title{margin:0 0 .45rem;font-weight:700;font-size:.9rem}.article-toc__list{margin:0;padding-left:1rem;display:grid;grid-gap:.3rem;gap:.3rem}.article-toc__list li.is-sub{margin-left:.7rem;list-style-type:circle}.article-inline-ad{margin:1.2rem 0}.ads-placeholder,.ads-slot{min-height:120px;border:1px dashed var(--border);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.8rem;background:color-mix(in srgb,var(--surface) 85%,var(--bg))}.ads-sidebar .ads-placeholder,.ads-sidebar .ads-slot{min-height:250px}.page-bottom-ad{margin-top:1.2rem}.pagination{margin-top:2rem;display:flex;gap:1rem;align-items:center;font-size:.95rem}.pagination a{padding:.4rem .85rem;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.pagination span{color:var(--muted)}.ai-page-container{min-width:0}.ai-container{background:var(--surface);padding:1rem}.ai-container,.ai-top-panel{border:1px solid var(--border);border-radius:var(--radius)}.ai-top-panel{padding:.8rem;margin-bottom:.8rem;background:color-mix(in srgb,var(--surface) 84%,var(--bg))}.ai-upload{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}.ai-db-list{display:grid;grid-gap:.7rem;gap:.7rem}.ai-db-card{border:1px solid var(--border);border-radius:var(--radius);padding:.7rem .8rem;background:color-mix(in srgb,var(--surface) 86%,var(--bg))}.ai-delete-btn{margin-top:.35rem;background:#8f5454}.ai-success{color:#3b6b54;margin:.6rem 0 0}.ai-error{color:#a34c4c;margin:.6rem 0 0}.ai-input{flex:1 1;min-width:0;padding:.62rem .75rem;border:1px solid var(--border);border-radius:10px;font-size:.95rem;background:#fff;color:var(--text)}.ai-input:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-soft) 35%,transparent)}.ai-chatbot-input:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-soft) 35%,transparent)}.ai-bubble-row{display:flex;margin-bottom:.7rem}.ai-bubble-row.left{justify-content:flex-start}.ai-bubble-row.right{justify-content:flex-end}.ai-bubble{max-width:84%;border-radius:14px;padding:.65rem .8rem;border:1px solid var(--border)}.ai-bubble.assistant{background:color-mix(in srgb,var(--surface) 74%,var(--bg))}.ai-bubble.user{color:#fff;border-color:var(--accent);background:linear-gradient(135deg,#3d7ff0,#204a96)}.ai-bubble .ai-role{margin:0 0 .2rem;font-size:.75rem;opacity:.85}.ai-bubble p{margin:0;white-space:pre-wrap}.ai-typing-dots{display:inline-flex;align-items:center;gap:6px}.ai-typing-dots span{width:6px;height:6px;border-radius:999px;background:var(--muted);animation:aiDotPulse 1.1s ease-in-out infinite}.ai-typing-dots span:nth-child(2){animation-delay:.15s}.ai-typing-dots span:nth-child(3){animation-delay:.3s}@keyframes aiDotPulse{0%,80%,to{transform:scale(.75);opacity:.4}40%{transform:scale(1);opacity:1}}.ai-float-root{position:fixed;right:clamp(10px,2vw,18px);bottom:clamp(10px,2.2vw,18px);z-index:70}.ai-float-button{width:clamp(44px,3.2vw,52px);height:clamp(44px,3.2vw,52px);border:0;border-radius:999px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#3d7ff0,#204a96);box-shadow:0 10px 28px rgba(37,46,40,.32);transition:transform .22s ease,box-shadow .22s ease,filter .22s ease}.ai-float-button:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 14px 30px rgba(37,46,40,.36);filter:brightness(1.05)}.ai-float-panel{position:absolute;right:0;bottom:66px;width:clamp(280px,32vw,360px);max-width:calc(100vw - 16px);background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:.62rem;box-shadow:0 16px 38px rgba(44,42,38,.18);transform-origin:bottom right;transition:opacity .22s ease,transform .22s ease,visibility .22s ease}.ai-float-panel.open{opacity:1;visibility:visible;pointer-events:auto;transform:scale(1) translateY(0)}.ai-float-panel.closed{opacity:0;visibility:hidden;pointer-events:none;transform:scale(.96) translateY(10px)}.ai-float-header{display:flex;justify-content:space-between;gap:.5rem;margin-bottom:.52rem}.ai-float-header strong{display:block;font-size:clamp(.82rem,.9vw,.92rem)}.ai-float-header p{margin:.15rem 0 0;font-size:clamp(.7rem,.75vw,.78rem);color:var(--muted)}.ai-float-actions{display:flex;align-items:center;gap:.35rem}.ai-icon-btn{width:34px;min-width:34px;height:34px;border-radius:999px;border:1px solid var(--border);background:#fff;display:grid;place-items:center;color:var(--muted);font-size:.68rem;font-weight:700;transition:color .2s ease,border-color .2s ease,background .2s ease}.ai-icon-btn:hover{color:var(--text);border-color:var(--accent-soft);background:color-mix(in srgb,var(--accent-soft) 25%,#fff);text-decoration:none}.ai-float-messages{border:1px solid var(--border);border-radius:12px;padding:.58rem;min-height:clamp(170px,30vh,250px);max-height:min(42vh,340px);overflow-y:auto;background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(238,243,255,.94))}.ai-float-panel .ai-bubble{max-width:88%;font-size:clamp(.8rem,.84vw,.9rem);padding:.5rem .62rem}.ai-float-panel .ai-bubble .ai-role{font-size:.68rem}.ai-float-form{margin-top:.48rem;display:grid;grid-template-columns:1fr auto;grid-gap:.4rem;gap:.4rem}.ai-float-panel .ai-input{padding:.48rem .6rem;font-size:clamp(.8rem,.84vw,.88rem)}.ai-float-form button{width:34px;min-width:34px;height:34px;border-radius:10px;border:1px solid transparent;background:linear-gradient(135deg,#3d7ff0,#204a96);color:#fff;display:grid;place-items:center;transition:transform .2s ease,filter .2s ease}.ai-float-form button:hover:not(:disabled){transform:translateY(-1px);filter:brightness(1.04)}.ai-float-form button:disabled{opacity:.6}@media (max-width:768px){.ai-float-panel{width:min(92vw,340px)}.ai-float-messages{min-height:170px;max-height:38vh}}@media (max-width:480px){.ai-float-root{right:8px;bottom:8px}.ai-float-panel{width:calc(100vw - 12px);right:-2px;bottom:56px;padding:.52rem;border-radius:12px}.ai-float-button{width:42px;height:42px}.ai-float-messages{min-height:160px;max-height:36vh}.ai-float-header p{display:none}}html[data-theme=light]{color-scheme:light}html[data-theme=dark]{color-scheme:dark;--bg:#000000;--surface:#1c1c1e;--surface-elevated:#2c2c2e;--surface-muted:#3a3a3c;--text:#f5f5f7;--muted:#b8b8bd;--accent:#0a84ff;--accent-soft:#64d2ff;--accent-pop:#0a84ff;--accent-mint:#30d158;--accent-violet:#bf5af2;--border:#48484a;--shadow-accent:0 4px 18px rgba(10,132,255,0.35);--shadow-card:0 1px 0 rgba(255,255,255,0.06),0 8px 28px rgba(0,0,0,0.55);--card:var(--surface);--input:#2c2c2e}html[data-theme=dark] body{background:var(--bg)}html[data-theme=dark] .site-header{background:var(--surface);border-color:var(--border);box-shadow:var(--shadow-card)}html[data-theme=dark] .icon-badge{background:#3a3a3c;border-color:#636366;box-shadow:0 1px 0 rgba(255,255,255,.08)}html[data-theme=dark] .tool-page-header--sky,html[data-theme=dark] .tools-bento__card--sky,html[data-theme=dark] .v-feature-card--sky{--card-accent:#38bdf8;--card-tint:#0f2a3d}html[data-theme=dark] .tool-page-header--blue,html[data-theme=dark] .tools-bento__card--blue,html[data-theme=dark] .v-feature-card--blue{--card-accent:#60a5fa;--card-tint:#0f2440}html[data-theme=dark] .tool-page-header--cyan,html[data-theme=dark] .tools-bento__card--cyan,html[data-theme=dark] .v-feature-card--cyan{--card-accent:#22d3ee;--card-tint:#0a2e36}html[data-theme=dark] .tool-page-header--indigo,html[data-theme=dark] .tools-bento__card--indigo,html[data-theme=dark] .v-feature-card--indigo{--card-accent:#a5b4fc;--card-tint:#1a1840}html[data-theme=dark] .tool-page-header--violet,html[data-theme=dark] .tools-bento__card--violet,html[data-theme=dark] .v-feature-card--violet{--card-accent:#c4b5fd;--card-tint:#261540}html[data-theme=dark] .tool-page-header--amber,html[data-theme=dark] .tools-bento__card--amber,html[data-theme=dark] .v-feature-card--amber{--card-accent:#fbbf24;--card-tint:#3a2808}html[data-theme=dark] .tool-page-header--rose,html[data-theme=dark] .tools-bento__card--rose,html[data-theme=dark] .v-feature-card--rose{--card-accent:#fb7185;--card-tint:#3a1020}html[data-theme=dark] .tool-page-header--teal,html[data-theme=dark] .tools-bento__card--teal,html[data-theme=dark] .v-feature-card--teal{--card-accent:#2dd4bf;--card-tint:#0a2e28}html[data-theme=dark] .tool-page-header--orange,html[data-theme=dark] .tools-bento__card--orange,html[data-theme=dark] .v-feature-card--orange{--card-accent:#fb923c;--card-tint:#3a1f08}html[data-theme=dark] .tool-page-header,html[data-theme=dark] .v-feature-card{background:color-mix(in srgb,var(--card-tint) 48%,var(--surface));border-color:color-mix(in srgb,var(--card-accent) 32%,var(--border))}html[data-theme=dark] .tools-bento__card{background-color:color-mix(in srgb,var(--card-tint) 42%,var(--surface));border-color:color-mix(in srgb,var(--card-accent) 32%,var(--border))}html[data-theme=dark] .tools-bento__tag{color:var(--card-accent);border-color:color-mix(in srgb,var(--card-accent) 45%,var(--border));background:color-mix(in srgb,var(--card-tint) 70%,var(--surface))}html[data-theme=dark] .tool-page-header__back,html[data-theme=dark] .tools-bento__cta{color:var(--card-accent)}html[data-theme=dark] .home-post-bento__item,html[data-theme=dark] .meme-tool-panel,html[data-theme=dark] .meme-tool-preview-card,html[data-theme=dark] .post-card{background:var(--surface);border-color:var(--border);box-shadow:var(--shadow-card)}html[data-theme=dark] .tool-pill{border-color:color-mix(in oklab,var(--border),transparent 15%);background:color-mix(in oklab,var(--surface),transparent 12%)}html[data-theme=dark] .action-btn--primary{background:var(--accent);border-color:transparent;color:#fff}html[data-theme=dark] .archive-link,html[data-theme=dark] .hero-focus-pill,html[data-theme=dark] .hero-stats>div,html[data-theme=dark] .home-post-bento{background:var(--surface-muted);border-color:var(--border);color:var(--text)}html[data-theme=dark] .hero-stats strong{color:var(--text)}html[data-theme=dark] .archive-link{color:var(--accent)}html[data-theme=dark] .ads-placeholder,html[data-theme=dark] .ads-slot{background:rgba(26,35,51,.45)}html[data-theme=dark] .article-toc{border-color:color-mix(in oklab,var(--border),transparent 18%);background:color-mix(in oklab,var(--surface),transparent 10%)}.mobile-sticky-ad{position:fixed;left:.6rem;right:.6rem;bottom:max(.4rem,env(safe-area-inset-bottom));z-index:65;display:none;padding:.45rem .45rem .35rem;border-radius:12px;border:1px solid color-mix(in oklab,var(--border),transparent 12%);background:color-mix(in oklab,var(--surface),transparent 8%);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 10px 24px color-mix(in oklab,#020617,transparent 82%)}.mobile-sticky-ad__close{position:absolute;top:-10px;right:-6px;width:24px;height:24px;border-radius:999px;border:1px solid color-mix(in oklab,var(--border),transparent 8%);background:color-mix(in oklab,var(--surface),transparent 0%);color:var(--muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.mobile-sticky-ad__slot.ads-placeholder,.mobile-sticky-ad__slot.ads-slot{min-height:52px;border-style:solid}@media (max-width:767px){.has-mobile-sticky-ad .site-main{padding-bottom:5.5rem}.mobile-sticky-ad{display:block}}html[data-theme=dark] .ai-icon-btn,html[data-theme=dark] .ai-input{background:#141d2c;color:var(--text);border-color:var(--border)}html[data-theme=dark] .ai-icon-btn:hover{background:#1f2b40}html[data-theme=dark] .ai-bubble.assistant{background:#1c273a;border-color:#2a3650}html[data-theme=dark] .ai-bubble.user,html[data-theme=dark] .ai-float-button,html[data-theme=dark] .ai-float-form button{background:linear-gradient(135deg,#5f92ff,#2f5fc4);border-color:#4c7de0}html[data-theme=dark] .ai-float-panel{background:var(--surface)}html[data-theme=dark] .ai-float-messages{background:var(--surface-muted)}.archive-link-wrap{margin-top:1.25rem}.archive-link{display:inline-flex;align-items:center;gap:.25rem;padding:.45rem .8rem;border-radius:999px;border:1px solid var(--border);color:var(--accent);font-size:.88rem;font-weight:600;background:var(--surface-muted);transition:color .2s ease,transform .2s ease,border-color .2s ease,box-shadow .2s ease}.archive-link:hover{color:var(--text);text-decoration:none;transform:translateX(2px);border-color:#c7c7cc;box-shadow:0 6px 16px rgba(0,0,0,.06)}.site-footer{border-top:1px solid var(--border);margin-top:2rem;padding:1.6rem 1.25rem;background:var(--surface)}.site-footer__inner{max-width:1100px;margin:0 auto;display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.site-footer__brand{margin:0;font-weight:700}.site-footer__copyright,.site-footer__muted{margin:.35rem 0 0;color:var(--muted);font-size:.86rem}.site-footer__copyright{max-width:1100px;margin:1rem auto 0;padding-top:.8rem;border-top:1px solid var(--border)}.site-footer__nav{display:flex;gap:.9rem;align-items:center;flex-wrap:wrap}.site-footer__nav a{color:var(--muted);font-size:.88rem}.site-footer__nav a:hover{color:var(--text);text-decoration:none}@media (max-width:700px){.site-footer__inner{flex-direction:column}}.ai-float-button{box-shadow:0 12px 32px color-mix(in srgb,var(--accent) 28%,transparent)}.ai-float-panel{border-radius:16px;border-color:color-mix(in srgb,var(--border) 80%,transparent);box-shadow:0 18px 44px color-mix(in srgb,#0b1324 16%,transparent)}.ai-float-messages{border-radius:14px}.ai-float-panel .ai-bubble.assistant{background:var(--surface-muted)}.ai-float-form button{border-radius:11px}html[data-theme=dark] .ai-float-panel .ai-bubble.assistant{background:var(--surface-muted)}:root{--font:var(--font-plus-jakarta),"Plus Jakarta Sans",ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif}.site-header__actions{display:flex;align-items:center;gap:.55rem;flex-shrink:0}.lang-toggle{height:32px;min-width:38px;border-radius:999px;border:1px solid var(--border);background:var(--surface-muted);color:var(--text);font-size:.76rem;font-weight:700;padding:0 .55rem;cursor:pointer;transition:border-color .3s ease,color .3s ease,background .3s ease}.lang-toggle:hover{border-color:var(--accent)}.site-header__login{display:inline-flex;align-items:center;justify-content:center;height:32px;padding:0 .75rem;border-radius:8px;border:1px solid var(--border);color:var(--text);font-size:.82rem;text-decoration:none}.site-header__login:hover{text-decoration:none;border-color:var(--accent)}.site-header__login--danger{background:color-mix(in srgb,#ef4444 10%,var(--surface));border-color:color-mix(in srgb,#ef4444 35%,var(--border))}.site-header__login-pill{display:inline-flex;align-items:center;gap:.36rem;height:34px;padding:0 .78rem;border-radius:999px;border:1px solid var(--border);background:var(--surface-muted);color:var(--text);font-size:.82rem;font-weight:600;text-decoration:none;transition:transform .3s ease,border-color .3s ease,background .3s ease,box-shadow .3s ease}.site-header__login-pill:hover{text-decoration:none;transform:translateY(-1px);border-color:#c7c7cc;background:var(--surface);box-shadow:0 6px 16px rgba(0,0,0,.06)}.site-nav--desktop{display:none}.site-header__cta{display:none;align-items:center;justify-content:center;height:34px;padding:0 .8rem;border-radius:9px;border:1px solid transparent;color:#fff;background:var(--accent);font-size:.84rem;font-weight:600;text-decoration:none}.site-header__cta:hover{text-decoration:none;filter:brightness(1.04)}.site-menu-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--border);background:var(--surface-muted);color:var(--text);display:grid;place-items:center}.site-mobile-nav{display:grid;grid-gap:.6rem;gap:.6rem;padding:.85rem 1.25rem 1rem;border-top:1px solid rgba(226,232,240,.3);background:transparent}.site-mobile-nav a .icon-badge,.site-mobile-nav__panel a .icon-badge{transform:none}.site-mobile-nav a{display:inline-flex;align-items:center;gap:.45rem;color:var(--muted);font-size:.9rem;transition:color .3s ease}.site-mobile-nav a.is-active{color:var(--accent)}.site-mobile-nav .site-header__cta{display:inline-flex}.site-mobile-nav__group{display:grid;grid-gap:.3rem;gap:.3rem}.site-mobile-nav__accordion{display:grid;grid-gap:.25rem;gap:.25rem}.site-mobile-nav__trigger{width:100%;border:0;background:transparent;color:var(--muted);display:flex;align-items:center;justify-content:space-between;font:inherit;font-size:.9rem;font-weight:500;padding:.1rem 0;cursor:pointer;transition:color .3s ease}.site-mobile-nav__trigger.is-active{color:var(--accent)}.site-mobile-nav__trigger svg{transition:transform .3s ease}.site-mobile-nav__accordion .site-mobile-nav__trigger[aria-expanded=true] svg,.site-mobile-nav__accordion:hover .site-mobile-nav__trigger svg,.site-mobile-nav__trigger[aria-expanded=true] svg{transform:rotate(180deg)}.site-mobile-nav__panel{display:grid;grid-gap:.35rem;gap:.35rem;max-height:0;opacity:0;overflow:hidden;transform:translateY(-4px);transition:max-height .3s ease,opacity .25s ease,transform .25s ease}.site-mobile-nav__accordion .site-mobile-nav__panel.is-open,.site-mobile-nav__accordion:hover .site-mobile-nav__panel,.site-mobile-nav__panel.is-open{max-height:560px;opacity:1;transform:translateY(0)}.site-mobile-nav__group-title{margin:0;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.hero--vercel{position:relative;overflow:hidden;text-align:center;padding:clamp(1rem,3.6vw,1.75rem) clamp(1rem,3.6vw,1.6rem) clamp(1.2rem,3.8vw,1.95rem)}.hero--vercel:before,.hero-orb{display:none}.hero--vercel>*{position:relative;z-index:1}.hero--vercel h1 span,.hero__badge svg{color:var(--accent)}.hero-stats{margin-top:1.5rem;padding-top:1.15rem;border-top:1px solid var(--border);display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:.75rem;gap:.75rem}.hero-stats>div{padding:.72rem .55rem;border-radius:12px;border:1px solid var(--border);background:var(--surface-muted)}.hero-stats strong{display:block;font-size:clamp(1.15rem,2.4vw,1.7rem);color:var(--text)}.hero-stats span{color:var(--muted);font-size:.8rem}.v-section{margin:0 0 1.4rem;padding:clamp(.95rem,3.2vw,1.25rem);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-card)}.v-section__head{text-align:center;max-width:640px;margin:0 auto}.v-section__head h2{margin:0;font-size:clamp(1.45rem,3.2vw,2rem);letter-spacing:-.02em}.v-section__head p{margin:.5rem 0 0;color:var(--muted)}.icon-badge{display:grid;place-items:center;flex-shrink:0;border-radius:14px;background:#ffffff;border:1px solid var(--border);box-shadow:0 1px 3px rgba(0,0,0,.06);transform:rotate(var(--icon-tilt,0deg));transition:transform .4s cubic-bezier(.34,1.45,.64,1),box-shadow .25s ease}.icon-badge__art{width:30px;height:30px;display:block}.icon-badge--sm{width:28px;height:28px;border-radius:9px;box-shadow:0 1px 2px rgba(0,0,0,.05)}.icon-badge--sm .icon-badge__art{width:17px;height:17px}.icon-badge--md{width:52px;height:52px}.icon-badge--lg{width:60px;height:60px;border-radius:16px}.icon-badge--lg .icon-badge__art{width:34px;height:34px}.v-features-grid{margin-top:1rem;display:grid;grid-gap:clamp(.65rem,2vw,.85rem);gap:clamp(.65rem,2vw,.85rem);grid-template-columns:repeat(1,minmax(0,1fr))}.v-feature-card{position:relative;display:flex;flex-direction:column;border:1px solid var(--border);border-radius:calc(var(--radius) + 2px);background:color-mix(in srgb,var(--card-tint,var(--surface-muted)) 22%,var(--surface));padding:clamp(.85rem,2.6vw,1rem);box-shadow:var(--shadow-card);overflow:hidden;transition:transform .28s cubic-bezier(.22,1,.36,1),border-color .25s ease,box-shadow .25s ease}.v-feature-card:before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:3px;border-radius:0 4px 4px 0;background:var(--card-accent,var(--accent))}.v-feature-card--sky{--card-accent:#0284c7;--card-tint:#e8f4fc}.v-feature-card--blue{--card-accent:#0071e3;--card-tint:#e8f0ff}.v-feature-card--cyan{--card-accent:#0891b2;--card-tint:#e6fafc}.v-feature-card--indigo{--card-accent:#5856d6;--card-tint:#eeeeff}.v-feature-card--violet{--card-accent:#7c3aed;--card-tint:#f3ecff}.v-feature-card--amber{--card-accent:#d97706;--card-tint:#fff8e8}.v-feature-card--rose{--card-accent:#e11d48;--card-tint:#fff0f3}.v-feature-card--teal{--card-accent:#0d9488;--card-tint:#e6faf5}.v-feature-card--orange{--card-accent:#ea580c;--card-tint:#fff4e8}.v-feature-card--link{color:inherit;text-decoration:none}.v-feature-card:hover{transform:translateY(-3px);border-color:color-mix(in srgb,var(--card-accent) 35%,var(--border));box-shadow:0 14px 32px color-mix(in srgb,var(--card-accent) 14%,rgba(0,0,0,.08))}.v-feature-card:hover .icon-badge{transform:rotate(0deg) scale(1.08);box-shadow:0 8px 22px rgba(0,0,0,.1)}.v-feature-card__icon{margin-bottom:.65rem}.v-feature-card h3{margin:0;font-size:1rem;padding-right:1.5rem}.v-feature-card p{margin:.35rem 0 0;color:var(--muted);font-size:.87rem;line-height:1.45;flex:1 1}.v-feature-card__arrow{position:absolute;right:.85rem;top:.85rem;color:var(--card-accent,var(--accent));opacity:.45;transition:transform .28s ease,opacity .28s ease}.v-feature-card:hover .v-feature-card__arrow{opacity:1;transform:translate(3px,-2px)}@media (min-width:880px){.v-features-grid{grid-template-columns:repeat(6,minmax(0,1fr));grid-auto-flow:dense}.v-feature-card{grid-column:span 2;min-height:148px}.v-feature-card.is-wide{grid-column:span 3;min-height:156px}}.tools-hub{grid-gap:clamp(1.25rem,3vw,1.85rem);gap:clamp(1.25rem,3vw,1.85rem)}.tools-hub,.tools-hub__hero{display:grid;position:relative}.tools-hub__hero{grid-template-columns:minmax(0,1.4fr) minmax(220px,.75fr);grid-gap:clamp(1rem,3vw,1.5rem);gap:clamp(1rem,3vw,1.5rem);align-items:stretch;padding:clamp(1.1rem,3.2vw,1.65rem);border:1px solid var(--border);border-radius:calc(var(--radius) + 2px);background:var(--surface);box-shadow:var(--shadow-card);overflow:hidden}.tools-hub__hero:after,.tools-hub__hero:before{display:none}.tools-hub__hero-copy{position:relative;z-index:1}.tools-hub__eyebrow{margin:0;display:inline-flex;align-items:center;gap:.45rem;font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}.tools-hub__eyebrow-dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}.tools-hub__count{margin-left:.15rem;padding:.12rem .45rem;border-radius:999px;border:1px solid var(--border);background:var(--surface-muted);letter-spacing:.04em}.tools-hub__hero h1{margin:.55rem 0 0;font-size:clamp(2.1rem,5vw,3.35rem);line-height:1.02;max-width:20ch}.tools-hub__lead{margin:.75rem 0 0;max-width:48ch;color:var(--muted);font-size:clamp(.95rem,2vw,1.05rem)}.tools-hub__hero-panel{position:relative;z-index:1;align-self:end;padding:.85rem .95rem;border-radius:12px;border:1px solid var(--border);background:var(--surface-muted)}.tools-hub__panel-label{margin:0 0 .55rem;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600}.tools-hub__hero-panel ul{margin:0;padding:0;list-style:none;display:grid;grid-gap:.45rem;gap:.45rem}.tools-hub__hero-panel li{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;font-size:.82rem;color:var(--muted)}.tools-hub__hero-panel strong{font-size:1.15rem;color:var(--accent)}.tools-bento{display:grid;width:100%;grid-gap:1rem;gap:1rem;grid-template-columns:repeat(12,minmax(0,1fr));grid-template-rows:repeat(4,minmax(5.75rem,auto))}.tools-bento__layout-hero{grid-column:1/7;grid-row:1/3}.tools-bento__layout-unit{grid-column:7/10;grid-row:1/2}.tools-bento__layout-code-tall{grid-column:10/13;grid-row:1/3}.tools-bento__layout-color{grid-column:7/10;grid-row:2/3}.tools-bento__layout-security{grid-column:1/4;grid-row:3/5}.tools-bento__layout-image{grid-column:4/7;grid-row:3/4}.tools-bento__layout-cheat{grid-column:7/10;grid-row:3/4}.tools-bento__layout-validator{grid-column:10/13;grid-row:3/4}.tools-bento__layout-banner{grid-column:1/13;grid-row:4/5}.tools-bento__layout-home-meme{grid-column:1/8;grid-row:4/5}.tools-bento__layout-home-game{grid-column:8/13;grid-row:4/5}.tools-bento--feature{grid-template-rows:repeat(2,minmax(6.25rem,auto))}.tools-bento__layout-hub-game{grid-column:1/7;grid-row:1/3}.tools-bento__layout-hub-tools{grid-column:7/13;grid-row:1/3}.tools-bento--game{grid-template-rows:repeat(2,minmax(6.25rem,auto))}.tools-bento__layout-game-hero{grid-column:1/13;grid-row:1/3}.tools-bento__layout-game-hero .tools-bento__head,.tools-bento__layout-hub-game .tools-bento__head,.tools-bento__layout-hub-tools .tools-bento__head{flex-direction:column;align-items:flex-start}.tools-bento__card{--bento-watermark-opacity:0.13;position:relative;display:flex;flex-direction:column;min-height:0;padding:clamp(.9rem,2.4vw,1.15rem);border-radius:calc(var(--radius) + 4px);border:1px solid color-mix(in srgb,var(--card-accent,var(--border)) 14%,var(--border));background-color:color-mix(in srgb,var(--card-tint,var(--surface-muted)) 20%,var(--surface));background-image:radial-gradient(ellipse 85% 70% at 100% 0,color-mix(in srgb,var(--card-accent) 14%,transparent),transparent 58%),radial-gradient(ellipse 55% 45% at 0 100%,color-mix(in srgb,var(--card-tint,var(--surface-muted)) 55%,transparent),transparent 52%),linear-gradient(168deg,color-mix(in srgb,var(--card-tint,var(--surface-muted)) 38%,var(--surface)) 0,var(--surface) 48%,color-mix(in srgb,var(--card-tint,var(--surface-muted)) 18%,var(--surface)) 100%);color:inherit;text-decoration:none;overflow:hidden;box-shadow:var(--shadow-card),inset 0 1px 0 color-mix(in srgb,#fff 55%,transparent);transition:transform .28s cubic-bezier(.22,1,.36,1),border-color .25s ease,box-shadow .25s ease;animation:toolsCardIn .45s cubic-bezier(.22,1,.36,1) both;isolation:isolate}.tools-bento__texture{position:absolute;inset:-8%;z-index:0;pointer-events:none;opacity:.55;background-image:radial-gradient(circle at 1px 1px,color-mix(in srgb,var(--card-accent) 11%,transparent) .65px,transparent 0),linear-gradient(var(--tex-angle,118deg),transparent 0,color-mix(in srgb,var(--card-accent) 5%,transparent) 48%,transparent 100%);background-size:var(--tex-dot-size,14px) var(--tex-dot-size,14px),100% 100%;background-position:var(--tex-offset,0 0),0 0;transform:rotate(var(--tex-rotate,0deg)) scale(var(--tex-scale,1));transform-origin:var(--tex-origin,80% 20%);-webkit-mask-image:linear-gradient(var(--tex-mask-angle,135deg),rgba(0,0,0,.38) 0,transparent 64%);mask-image:linear-gradient(var(--tex-mask-angle,135deg),rgba(0,0,0,.38) 0,transparent 64%)}.tools-bento__card:after,.tools-bento__card:before{z-index:1;pointer-events:none}.tools-bento__card:before{content:"";position:absolute;left:0;top:14px;bottom:14px;width:3px;border-radius:0 4px 4px 0;background:var(--card-accent,var(--accent));box-shadow:0 0 12px color-mix(in srgb,var(--card-accent) 35%,transparent)}.tools-bento__card:after{content:"";position:absolute;top:var(--blob-t,auto);right:var(--blob-r,-32px);bottom:var(--blob-b,-36px);left:var(--blob-l,auto);width:clamp(88px,var(--blob-size,36%),148px);height:clamp(88px,var(--blob-size,36%),148px);border-radius:50%;background:radial-gradient(circle at var(--blob-glow-x,35%) var(--blob-glow-y,35%),color-mix(in srgb,var(--card-accent) 22%,transparent),color-mix(in srgb,var(--card-tint,var(--surface-muted)) 40%,transparent) 55%,transparent 72%);opacity:.9}.tools-bento__watermark{position:absolute;top:var(--wm-top,auto);right:var(--wm-right,.15rem);bottom:var(--wm-bottom,.1rem);left:var(--wm-left,auto);z-index:0;display:flex;align-items:center;justify-content:center;width:clamp(68px,30%,132px);height:clamp(68px,30%,132px);opacity:var(--bento-watermark-opacity);transform:rotate(var(--wm-rotate,-14deg)) scale(var(--wm-scale,1));transform-origin:center;pointer-events:none;transition:opacity .28s ease,transform .35s cubic-bezier(.22,1,.36,1);filter:saturate(1.05)}.tools-bento__watermark-art{width:100%;height:100%;display:block}.tools-bento__card.is-featured{--bento-watermark-opacity:0.17}.tools-bento__layout-game-hero .tools-bento__watermark,.tools-bento__layout-hero .tools-bento__watermark,.tools-bento__layout-hub-game .tools-bento__watermark,.tools-bento__layout-hub-tools .tools-bento__watermark{width:clamp(96px,38%,156px);height:clamp(96px,38%,156px);--bento-watermark-opacity:0.16}.tools-bento__card>:not(.tools-bento__texture):not(.tools-bento__watermark){position:relative;z-index:2}.tools-bento__card:hover{--bento-watermark-opacity:0.19}.tools-bento__card:hover .tools-bento__watermark{transform:rotate(var(--wm-rotate,-14deg)) scale(calc(var(--wm-scale, 1) * 1.05))}.tools-bento__card:hover .tools-bento__texture{opacity:.68}.tools-bento__card.is-featured .tools-bento__tag:before{content:"★ "}html[data-theme=dark] .tools-bento__card{box-shadow:var(--shadow-card),inset 0 1px 0 color-mix(in srgb,#fff 8%,transparent)}html[data-theme=dark] .tools-bento__texture{opacity:.42;background-image:radial-gradient(circle at 1px 1px,color-mix(in srgb,var(--card-accent) 16%,transparent) .65px,transparent 0),linear-gradient(118deg,transparent 0,color-mix(in srgb,var(--card-accent) 8%,transparent) 48%,transparent 100%)}html[data-theme=dark] .tools-bento__watermark{--bento-watermark-opacity:0.2}html[data-theme=dark] .tools-bento__card.is-featured,html[data-theme=dark] .tools-bento__layout-game-hero .tools-bento__watermark,html[data-theme=dark] .tools-bento__layout-hero .tools-bento__watermark,html[data-theme=dark] .tools-bento__layout-hub-game .tools-bento__watermark,html[data-theme=dark] .tools-bento__layout-hub-tools .tools-bento__watermark{--bento-watermark-opacity:0.24}html[data-theme=dark] .tools-bento__card:hover{--bento-watermark-opacity:0.28}.tools-bento__layout-banner .tools-bento__head{flex-direction:row;align-items:center}.tools-bento__decor--0{--wm-right:-0.6rem;--wm-bottom:-0.45rem;--wm-rotate:-22deg;--tex-angle:102deg;--tex-offset:6px 12px;--tex-mask-angle:128deg;--blob-r:-34px;--blob-b:-38px}.tools-bento__decor--1{--wm-right:8%;--wm-top:22%;--wm-bottom:auto;--wm-rotate:16deg;--wm-scale:0.92;--tex-angle:156deg;--tex-offset:18px 4px;--tex-rotate:4deg;--tex-origin:20% 80%;--blob-l:-24px;--blob-b:12%;--blob-r:auto}.tools-bento__decor--2{--wm-left:-0.75rem;--wm-bottom:18%;--wm-right:auto;--wm-rotate:11deg;--tex-angle:72deg;--tex-dot-size:12px;--tex-offset:0 22px;--tex-mask-angle:200deg;--blob-t:-20px;--blob-r:18%;--blob-b:auto}.tools-bento__decor--3{--wm-right:2%;--wm-bottom:32%;--wm-rotate:-8deg;--wm-scale:1.08;--tex-angle:132deg;--tex-offset:24px 16px;--tex-scale:1.06;--blob-l:-30px;--blob-t:-28px;--blob-r:auto;--blob-b:auto}.tools-bento__decor--4{--wm-right:-1rem;--wm-top:8%;--wm-bottom:auto;--wm-rotate:-15deg;--tex-angle:94deg;--tex-offset:10px 28px;--tex-rotate:-6deg;--blob-r:10%;--blob-t:-32px;--blob-b:auto}.tools-bento__decor--5{--wm-left:6%;--wm-top:12%;--wm-right:auto;--wm-bottom:auto;--wm-rotate:20deg;--wm-scale:0.88;--tex-angle:168deg;--tex-offset:32px 8px;--tex-mask-angle:112deg;--blob-b:-42px;--blob-l:22%;--blob-r:auto}.tools-bento__decor--6{--wm-right:14%;--wm-bottom:-0.85rem;--wm-rotate:7deg;--tex-angle:118deg;--tex-dot-size:16px;--tex-offset:4px 34px;--tex-origin:60% 40%;--blob-r:-40px;--blob-b:8%;--blob-size:32%}.tools-bento__decor--7{--wm-right:auto;--wm-left:-0.5rem;--wm-top:28%;--wm-bottom:auto;--wm-rotate:-18deg;--wm-scale:1.05;--tex-angle:86deg;--tex-offset:22px 0;--tex-rotate:8deg;--tex-mask-angle:148deg;--blob-t:42%;--blob-r:-28px;--blob-b:auto}.tools-bento__decor--8{--wm-right:-0.25rem;--wm-bottom:42%;--wm-rotate:24deg;--tex-angle:142deg;--tex-offset:14px 20px;--tex-scale:0.94;--blob-l:auto;--blob-r:-36px;--blob-t:-24px;--blob-b:auto;--blob-glow-x:60%;--blob-glow-y:40%}.tools-bento__decor--9{--wm-right:20%;--wm-bottom:-0.5rem;--wm-rotate:-11deg;--wm-scale:0.9;--tex-angle:108deg;--tex-offset:28px 14px;--tex-rotate:-3deg;--tex-origin:90% 70%;--blob-b:-44px;--blob-l:-20px;--blob-r:auto}.tools-bento__decor--10{--wm-right:4%;--wm-top:38%;--wm-bottom:auto;--wm-rotate:13deg;--tex-angle:124deg;--tex-dot-size:13px;--tex-offset:8px 26px;--tex-mask-angle:168deg;--blob-r:6%;--blob-b:-30px;--blob-size:34%}.tools-bento__decor--11{--wm-left:12%;--wm-bottom:-0.35rem;--wm-right:auto;--wm-rotate:-25deg;--wm-scale:1.1;--tex-angle:76deg;--tex-offset:36px 6px;--tex-rotate:5deg;--tex-origin:30% 60%;--blob-t:-18px;--blob-l:8%;--blob-r:auto;--blob-b:auto;--blob-size:38%}.tools-bento__card--sky{--card-accent:#0284c7;--card-tint:#e8f4fc}.tools-bento__card--blue{--card-accent:#0071e3;--card-tint:#e8f0ff}.tools-bento__card--cyan{--card-accent:#0891b2;--card-tint:#e6fafc}.tools-bento__card--indigo{--card-accent:#5856d6;--card-tint:#eeeeff}.tools-bento__card--violet{--card-accent:#7c3aed;--card-tint:#f3ecff}.tools-bento__card--amber{--card-accent:#d97706;--card-tint:#fff8e8}.tools-bento__card--rose{--card-accent:#e11d48;--card-tint:#fff0f3}.tools-bento__card--teal{--card-accent:#0d9488;--card-tint:#e6faf5}.tools-bento__card--orange{--card-accent:#ea580c;--card-tint:#fff4e8}.tools-bento__card:hover{transform:translateY(-3px);border-color:color-mix(in srgb,var(--card-accent) 38%,var(--border));box-shadow:0 16px 36px color-mix(in srgb,var(--card-accent) 16%,rgba(0,0,0,.08)),inset 0 1px 0 color-mix(in srgb,#fff 55%,transparent);text-decoration:none}.tools-bento__card:hover .icon-badge{transform:rotate(0deg) scale(1.1);box-shadow:0 10px 24px rgba(0,0,0,.12)}.tools-bento__card-top{display:flex;align-items:center;justify-content:flex-start;gap:.5rem}.tools-bento__tag{font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:.22rem .55rem;border-radius:999px;border:1px solid color-mix(in srgb,var(--card-accent) 28%,var(--border));color:var(--card-accent);background:color-mix(in srgb,var(--card-tint) 55%,var(--surface))}.tools-bento__icon{flex-shrink:0}.tools-bento__head{display:flex;align-items:flex-start;gap:.75rem;flex:1 1;min-height:0;margin-top:.6rem}.tools-bento__head .tools-bento__icon{margin-top:.1rem}.tools-bento__head-copy{min-width:0;flex:1 1;padding-right:.35rem}.tools-bento__layout-banner .tools-bento__head-copy,.tools-bento__layout-code-tall .tools-bento__head-copy,.tools-bento__layout-hero .tools-bento__head-copy{padding-right:1.25rem}.tools-bento__title{margin:0;font-size:clamp(1rem,2vw,1.12rem);line-height:1.2}.tools-bento__desc{margin:.35rem 0 0;color:var(--muted);font-size:.86rem;line-height:1.45;flex:1 1}.tools-bento__desc,.tools-bento__detail{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.tools-bento__detail{margin:.45rem 0 0;padding-right:.5rem;color:color-mix(in srgb,var(--muted) 88%,var(--text));font-size:.8rem;line-height:1.5}.tools-bento__cta{margin-top:auto;padding-top:.75rem;display:inline-flex;align-items:center;gap:.3rem;font-size:.8rem;font-weight:600;color:var(--card-accent,var(--accent));transition:gap .25s ease}.tools-bento__card:hover .tools-bento__cta{gap:.45rem}@keyframes toolsCardIn{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}html[data-theme=dark] .hero,html[data-theme=dark] .tool-card,html[data-theme=dark] .tools-hub__hero,html[data-theme=dark] .tools-hub__hero-panel,html[data-theme=dark] .v-section{background:var(--surface);border-color:var(--border);box-shadow:var(--shadow-card)}html[data-theme=dark] .tools-hub__hero-panel{background:var(--surface-muted)}html[data-theme=dark] .compare-tool-card:focus-within,html[data-theme=dark] .compare-tool-card:hover,html[data-theme=dark] .hero:hover,html[data-theme=dark] .post-card:hover,html[data-theme=dark] .tools-bento__card:hover,html[data-theme=dark] .v-feature-card:hover,html[data-theme=dark] .v-section:hover{border-color:color-mix(in srgb,var(--card-accent,var(--accent)) 42%,var(--border));box-shadow:0 12px 32px rgba(0,0,0,.45)}html[data-theme=dark] .v-feature-card:hover{box-shadow:0 14px 36px color-mix(in srgb,var(--card-accent) 22%,rgba(0,0,0,.5))}html[data-theme=dark] .tools-bento__card:hover{box-shadow:0 16px 40px color-mix(in srgb,var(--card-accent) 24%,rgba(0,0,0,.5))}html[data-theme=dark] .compare-tool-result{background:var(--surface-muted);border-color:var(--border);color:var(--text)}html[data-theme=dark] .compare-tool-card{background:var(--surface-elevated);border-color:var(--border)}html[data-theme=dark] .compare-tool-card textarea,html[data-theme=dark] .compare-tool-merge textarea,html[data-theme=dark] .formatter-tool-field select{background:var(--input);border-color:var(--border);color:var(--text)}html[data-theme=dark] .compare-tool-merge,html[data-theme=dark] .security-tool-tab{background:var(--surface-elevated);border-color:var(--border)}html[data-theme=dark] .security-tool-tab{color:var(--muted)}html[data-theme=dark] .security-tool-tab.is-active{color:var(--accent-soft);border-color:color-mix(in srgb,var(--accent) 55%,var(--border));background:color-mix(in srgb,var(--accent) 18%,var(--surface-elevated))}html[data-theme=dark] .tool-help__card:first-child{border-left-color:#60a5fa}html[data-theme=dark] .tool-help__card:last-child{border-left-color:#34d399}html[data-theme=dark] .hero,html[data-theme=dark] .v-section{background:var(--surface);border-color:var(--border)}html[data-theme=dark] .hero-focus-pill{color:var(--text)}html[data-theme=dark] .v-feature-card__arrow{color:var(--card-accent);opacity:.65}html[data-theme=dark] .v-feature-card:hover .v-feature-card__arrow{opacity:1}html[data-theme=dark] .archive-link:hover,html[data-theme=dark] .home-post-bento__item:hover,html[data-theme=dark] .security-tool-tab:hover,html[data-theme=dark] .site-header__login-pill:hover{border-color:color-mix(in srgb,var(--accent) 40%,var(--border))}html[data-theme=dark] .tools-bento__index{color:color-mix(in srgb,var(--card-accent,var(--accent-soft)) 75%,var(--muted))}html[data-theme=dark] .compare-tool-icon-btn,html[data-theme=dark] .compare-tool-merge__actions button{background:var(--surface-muted);border-color:var(--border);color:var(--text)}html[data-theme=dark] .compare-tool-merge__actions button:hover{border-color:var(--accent-soft)}@media (max-width:1024px){.tools-bento{grid-template-columns:repeat(6,minmax(0,1fr));grid-template-rows:repeat(5,minmax(5.5rem,auto))}.tools-bento__layout-hero{grid-column:1/5;grid-row:1/3}.tools-bento__layout-unit{grid-column:5/7;grid-row:1/2}.tools-bento__layout-code-tall{grid-column:5/7;grid-row:2/4}.tools-bento__layout-color{grid-column:1/3;grid-row:3/4}.tools-bento__layout-security{grid-column:1/3;grid-row:4/6}.tools-bento__layout-image{grid-column:3/5;grid-row:3/4}.tools-bento__layout-cheat{grid-column:5/7;grid-row:3/4}.tools-bento__layout-validator{grid-column:3/5;grid-row:4/5}.tools-bento__layout-banner{grid-column:1/7;grid-row:5/6}.tools-bento--home .tools-bento__layout-home-meme{grid-column:1/4;grid-row:5/6}.tools-bento--home .tools-bento__layout-home-game{grid-column:4/7;grid-row:5/6}.tools-bento--feature .tools-bento__layout-hub-game{grid-column:1/7;grid-row:1/3}.tools-bento--feature .tools-bento__layout-hub-tools{grid-column:1/7;grid-row:3/5}.tools-bento--game .tools-bento__layout-game-hero{grid-column:1/7;grid-row:1/3}}@media (max-width:960px){.tools-hub__hero{grid-template-columns:1fr}}@media (max-width:560px){.tools-bento{grid-template-columns:1fr;grid-template-rows:none;grid-auto-rows:auto}.tools-bento [class*=tools-bento__layout-]{grid-column:1/-1;grid-row:auto}.tools-bento__layout-banner .tools-bento__head,.tools-bento__layout-code-tall .tools-bento__head,.tools-bento__layout-game-hero .tools-bento__head,.tools-bento__layout-hero .tools-bento__head,.tools-bento__layout-hub-game .tools-bento__head,.tools-bento__layout-hub-tools .tools-bento__head{flex-direction:row;align-items:flex-start}.tools-bento__card{min-height:0}.tools-bento__desc{-webkit-line-clamp:4;line-clamp:4}}@media (prefers-reduced-motion:reduce){.tools-bento__card{animation:none;transform:none}.tools-bento__card:hover,.tools-bento__card:hover .icon-badge,.tools-bento__card:hover .tools-bento__watermark,.v-feature-card:hover,.v-feature-card:hover .icon-badge{transform:none}}.compare-tool-page,.meme-tool-page{display:grid;grid-gap:1rem;gap:1rem}.tool-page-header{padding:clamp(.95rem,2.8vw,1.2rem);border:1px solid var(--border);border-radius:calc(var(--radius) + 2px);background:color-mix(in srgb,var(--card-tint,var(--surface-muted)) 28%,var(--surface));box-shadow:var(--shadow-card);position:relative;overflow:hidden}.tool-page-header:before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:3px;border-radius:0 4px 4px 0;background:var(--card-accent,var(--accent))}.tool-page-header--sky{--card-accent:#0284c7;--card-tint:#e8f4fc}.tool-page-header--blue{--card-accent:#0071e3;--card-tint:#e8f0ff}.tool-page-header--cyan{--card-accent:#0891b2;--card-tint:#e6fafc}.tool-page-header--indigo{--card-accent:#5856d6;--card-tint:#eeeeff}.tool-page-header--violet{--card-accent:#7c3aed;--card-tint:#f3ecff}.tool-page-header--amber{--card-accent:#d97706;--card-tint:#fff8e8}.tool-page-header--rose{--card-accent:#e11d48;--card-tint:#fff0f3}.tool-page-header--teal{--card-accent:#0d9488;--card-tint:#e6faf5}.tool-page-header--orange{--card-accent:#ea580c;--card-tint:#fff4e8}.tool-page-header__back{display:inline-flex;align-items:center;gap:.3rem;margin-bottom:.75rem;font-size:.8rem;font-weight:600;color:var(--card-accent,var(--accent));text-decoration:none;transition:gap .2s ease,opacity .2s ease}.tool-page-header__back:hover{text-decoration:none;gap:.42rem;opacity:.85}.tool-page-header__row{display:flex;align-items:flex-start;gap:clamp(.75rem,2.5vw,1rem)}.tool-page-header__copy h1{margin:0;font-size:clamp(1.35rem,2.8vw,1.85rem);letter-spacing:-.02em}.tool-page-header__copy p{margin:.4rem 0 0;color:var(--muted);font-size:.92rem;line-height:1.5;max-width:58ch}.compare-tool-page__header h1{margin:0;font-size:clamp(1.45rem,3vw,2rem)}.compare-tool-page__header p{margin:.45rem 0 0;color:var(--muted)}.compare-tool-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:1rem;gap:1rem}.compare-tool-card{display:grid;grid-gap:.55rem;gap:.55rem;border:1px solid var(--border);border-radius:12px;background:var(--surface);padding:.85rem;box-shadow:0 1px 2px rgba(0,0,0,.03);transition:border-color .2s ease,box-shadow .2s ease}.compare-tool-card:focus-within,.compare-tool-card:hover{border-color:color-mix(in srgb,var(--accent) 35%,var(--border));box-shadow:0 8px 22px rgba(0,0,0,.06)}.compare-tool-card span{font-size:.9rem;color:var(--muted)}.compare-tool-card textarea{width:100%;min-height:320px;resize:vertical;background:var(--bg);color:var(--text);padding:.85rem;font:inherit;font-size:.84rem;line-height:1.4;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.compare-tool-card textarea,.compare-tool-result{border:1px solid var(--border);border-radius:10px}.compare-tool-result{margin:0;background:var(--surface-muted);padding:.75rem .85rem;font-size:.9rem;line-height:1.45}.compare-tool-options{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}.compare-tool-options label{display:inline-flex;align-items:center;gap:.45rem;color:var(--muted);font-size:.9rem}.compare-tool-btn{display:inline-flex;align-items:center;justify-content:center;height:var(--tool-btn-size);border:1px solid var(--border);background:var(--accent);color:#fff;border-radius:10px;padding:0 .95rem;line-height:1;font:inherit;cursor:pointer}.compare-tool-btn:hover{filter:brightness(.95)}.compare-tool-btn--icon,.compare-tool-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:var(--tool-btn-size);height:var(--tool-btn-size);padding:0}.compare-tool-icon-btn{min-width:var(--tool-btn-size);border:1px solid var(--border);border-radius:10px;background:var(--bg);color:var(--text);cursor:pointer}.compare-tool-icon-btn:hover{border-color:var(--accent);color:var(--accent)}.compare-tool-icon-btn--mini{width:28px;min-width:28px;height:28px;border-radius:8px}.compare-tool-diff{border:1px solid var(--border);border-radius:12px;background:color-mix(in srgb,var(--surface) 92%,var(--bg));padding:.9rem}.compare-tool-input-bottom{display:grid;grid-gap:.7rem;gap:.7rem}.compare-tool-diff h2,.compare-tool-input-bottom h2{margin:0;font-size:1rem}.compare-tool-diff__titlebar{display:flex;align-items:center;justify-content:space-between;gap:.8rem;margin-bottom:.7rem;position:-webkit-sticky;position:sticky;top:70px;z-index:5;padding:.55rem .6rem;border:1px solid var(--border);border-radius:10px;background:color-mix(in srgb,var(--surface) 96%,var(--bg));-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.compare-tool-diff__nav{display:inline-flex;align-items:center;gap:.45rem;color:var(--muted);font-size:.84rem}.compare-tool-diff__nav button{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:8px;padding:.28rem .55rem;font:inherit;cursor:pointer}.compare-tool-diff__nav button:disabled{opacity:.5;cursor:not-allowed}.compare-tool-diff__table{display:grid;grid-gap:.35rem;gap:.35rem;width:100%}.compare-tool-diff__head,.compare-tool-diff__row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) fit-content(96px);grid-gap:.6rem;gap:.6rem;align-items:start;width:100%}.compare-tool-diff__head{color:var(--muted);font-size:.82rem;padding:0 .4rem}.compare-tool-diff__head-resolve{text-align:center;font-weight:500;white-space:nowrap}.compare-tool-diff__head-resolve--done{color:color-mix(in srgb,#22c55e 75%,var(--muted))}.compare-tool-diff__row{border:1px solid var(--border);border-radius:10px;padding:.5rem .6rem;font-size:.78rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;line-height:1.4;cursor:pointer;align-items:stretch}.compare-tool-diff__row.is-same{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.compare-tool-diff__row.is-same>:last-child{display:none}.compare-tool-diff__row>span{border:1px solid transparent;border-radius:8px;padding:.32rem .45rem;white-space:pre-wrap;word-break:break-word}.compare-tool-cell{display:grid;grid-template-columns:42px minmax(0,1fr);align-items:stretch;border:1px solid transparent;border-radius:8px;overflow:hidden}.compare-tool-cell__line{display:flex;align-items:center;justify-content:center;align-self:stretch;height:100%;padding:.24rem .2rem;white-space:nowrap;text-align:center;color:color-mix(in srgb,var(--muted) 75%,var(--text));background:color-mix(in srgb,var(--border) 38%,var(--surface));border-right:1px solid color-mix(in srgb,var(--border) 90%,var(--bg));-webkit-user-select:none;-moz-user-select:none;user-select:none;font-size:.72rem;line-height:1.35;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;box-sizing:border-box}.compare-tool-cell__text{display:block;padding:.24rem .42rem;white-space:pre-wrap;word-break:break-word;border-left:1px solid color-mix(in srgb,var(--border) 70%,transparent)}.compare-tool-empty-line{display:inline-block;min-height:1.15em;min-width:.35rem;vertical-align:top}.compare-tool-diff__actions{display:flex;gap:.4rem;justify-content:center;align-items:center;min-height:100%;flex-wrap:wrap}.compare-tool-diff__actions button{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:8px;padding:.22rem .5rem;font:inherit;font-size:.76rem;cursor:pointer;white-space:nowrap}.compare-tool-diff__actions button:hover{border-color:var(--accent)}.compare-tool-diff__actions--icons{gap:.28rem;justify-content:flex-end;flex-wrap:nowrap}.compare-tool-diff__actions .compare-tool-diff__icon-btn{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;min-width:2rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);cursor:pointer;flex-shrink:0;font-size:0;white-space:nowrap}.compare-tool-diff__actions .compare-tool-diff__icon-btn:hover{border-color:var(--accent);color:var(--accent)}.compare-tool-diff__resolved{display:inline-flex;align-items:center;justify-content:center;min-width:1.65rem;height:1.65rem;font-size:.72rem;font-weight:600;color:var(--muted);border:1px solid var(--border);border-radius:6px;padding:0 .35rem;background:color-mix(in srgb,var(--surface) 92%,var(--bg))}.compare-tool-diff__row.is-same{background:color-mix(in srgb,var(--surface) 96%,var(--bg));cursor:default}.compare-tool-diff__row.is-same>span:first-child,.compare-tool-diff__row.is-same>span:nth-child(2){background:var(--bg);border-color:var(--border)}.compare-tool-diff__row.is-different,.compare-tool-diff__row.is-left-only,.compare-tool-diff__row.is-right-only{background:color-mix(in srgb,#ef4444 9%,var(--surface))}.compare-tool-diff__row.is-different>span:first-child,.compare-tool-diff__row.is-different>span:nth-child(2),.compare-tool-diff__row.is-left-only>span:first-child,.compare-tool-diff__row.is-right-only>span:nth-child(2){background:color-mix(in srgb,#ef4444 11%,var(--surface));border-color:color-mix(in srgb,#ef4444 28%,var(--border))}.compare-tool-diff__row.is-same .compare-tool-cell:first-child,.compare-tool-diff__row.is-same .compare-tool-cell:nth-child(2){background:var(--bg);border-color:var(--border)}.compare-tool-diff__row.is-different .compare-tool-cell:first-child,.compare-tool-diff__row.is-different .compare-tool-cell:nth-child(2),.compare-tool-diff__row.is-left-only .compare-tool-cell:first-child,.compare-tool-diff__row.is-right-only .compare-tool-cell:nth-child(2){background:color-mix(in srgb,#ef4444 11%,var(--surface));border-color:color-mix(in srgb,#ef4444 28%,var(--border))}.compare-tool-diff__row.is-active{outline:2px solid color-mix(in srgb,var(--accent) 45%,transparent);outline-offset:1px}.compare-tool-highlight{background:color-mix(in srgb,#f59e0b 42%,var(--surface));color:inherit;border-radius:4px;padding:0 .1rem}.compare-tool-cell.is-merged{background:color-mix(in srgb,var(--muted) 10%,var(--bg))!important;border-color:color-mix(in srgb,#22c55e 42%,var(--border))!important}.compare-tool-merge{border:1px solid var(--border);border-radius:12px;background:var(--surface);padding:.9rem;box-shadow:var(--shadow-card)}.compare-tool-merge--sticky{position:-webkit-sticky;position:sticky;bottom:12px;z-index:8;box-shadow:0 12px 24px color-mix(in srgb,#0f172a 8%,transparent)}.compare-tool-cell--same-stack{display:block;padding:0;align-self:stretch;overflow:hidden}.compare-tool-same-lines{display:flex;flex-direction:column;min-height:0}.compare-tool-same-line{display:grid;grid-template-columns:42px minmax(0,1fr);align-items:stretch;min-height:0}.compare-tool-same-line>.compare-tool-cell__line,.compare-tool-same-line>.compare-tool-cell__text{min-height:100%}.compare-tool-diff__row.is-different .compare-tool-cell__text,.compare-tool-diff__row.is-left-only .compare-tool-cell__text,.compare-tool-diff__row.is-right-only .compare-tool-cell__text{white-space:pre-wrap;overflow:visible}.compare-tool-same-line:not(:last-child){border-bottom:1px solid color-mix(in srgb,var(--border) 88%,var(--bg))}.compare-tool-diff__row.is-same .compare-tool-cell--same-stack{background:var(--bg);border-color:var(--border)}html[data-theme=dark] .compare-tool-merge--sticky{box-shadow:0 12px 28px color-mix(in srgb,#000 55%,transparent)}html[data-theme=dark] .compare-tool-highlight{background:color-mix(in srgb,#f59e0b 35%,var(--surface));color:var(--text)}html[data-theme=dark] .compare-tool-cell__line{background:color-mix(in srgb,var(--surface) 55%,#0a0f18);color:color-mix(in srgb,var(--muted) 85%,var(--text))}html[data-theme=dark] .compare-tool-diff__row.is-same .compare-tool-same-line:not(:last-child){border-bottom-color:var(--border)}html[data-theme=dark] .compare-tool-diff__row.is-different,html[data-theme=dark] .compare-tool-diff__row.is-left-only,html[data-theme=dark] .compare-tool-diff__row.is-right-only{background:color-mix(in srgb,#f87171 10%,var(--surface))}html[data-theme=dark] .compare-tool-diff__row.is-different .compare-tool-cell:first-child,html[data-theme=dark] .compare-tool-diff__row.is-different .compare-tool-cell:nth-child(2),html[data-theme=dark] .compare-tool-diff__row.is-left-only .compare-tool-cell:first-child,html[data-theme=dark] .compare-tool-diff__row.is-right-only .compare-tool-cell:nth-child(2){background:color-mix(in srgb,#f87171 12%,var(--surface));border-color:color-mix(in srgb,#f87171 30%,var(--border))}html[data-theme=dark] .compare-tool-diff__head-resolve--done{color:color-mix(in srgb,#4ade80 82%,var(--text))}.compare-tool-merge h2{margin:0 0 .7rem;font-size:1rem}.compare-tool-merge__head{display:flex;justify-content:space-between;align-items:center;gap:.6rem;margin-bottom:.7rem}.compare-tool-merge__head h2{margin:0}.compare-tool-merge__title-row{display:inline-flex;align-items:center;gap:.4rem}.compare-tool-merge__title-toggle{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;cursor:pointer;border:1px dashed color-mix(in srgb,var(--accent) 40%,var(--border));border-radius:8px;background:color-mix(in srgb,var(--accent) 8%,var(--surface));color:var(--text)}.compare-tool-merge__title-toggle svg.is-expanded{transform:rotate(180deg)}.compare-tool-merge__head--merged{align-items:center}.compare-tool-merge__actions{display:flex;gap:.45rem;flex-wrap:wrap}.compare-tool-merge__actions button{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:8px;height:var(--tool-btn-size);padding:0 .65rem;line-height:1;font:inherit;font-size:.82rem;cursor:pointer}.compare-tool-merge__actions button:hover{border-color:var(--accent)}.compare-tool-merge__actions .compare-tool-icon-btn{width:var(--tool-btn-size);height:var(--tool-btn-size)}.back-to-top-btn,.compare-tool-merge__actions .compare-tool-icon-btn{display:inline-flex;align-items:center;justify-content:center;padding:0}.back-to-top-btn{position:fixed;right:16px;bottom:88px;z-index:30;width:38px;height:38px;min-width:38px;border:1px solid var(--border);border-radius:999px;background:color-mix(in srgb,var(--surface) 92%,var(--bg));color:var(--text);box-shadow:0 6px 18px color-mix(in srgb,#0f172a 16%,transparent);cursor:pointer}.back-to-top-btn:hover{border-color:var(--accent);color:var(--accent)}.action-btn{display:inline-flex;align-items:center;justify-content:center;height:var(--tool-btn-size);min-height:var(--tool-btn-size);padding:0 .78rem;gap:.36rem;border-radius:12px;border:1px solid color-mix(in srgb,var(--border) 92%,transparent);background:color-mix(in srgb,var(--surface) 94%,var(--bg));color:var(--text);font:inherit;font-size:.9rem;font-weight:600;cursor:pointer;transition:border-color .16s ease,transform .16s ease,background .16s ease,box-shadow .16s ease}.action-btn:hover{border-color:color-mix(in srgb,var(--accent) 55%,var(--border));transform:translateY(-1px);box-shadow:0 7px 18px color-mix(in oklab,var(--accent),transparent 84%)}.action-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.action-btn--ghost{background:transparent}.action-btn--primary{border-color:transparent;background:var(--accent);color:#fff}.action-btn__icon{display:inline-flex;align-items:center}.compare-tool-btn>.action-btn,label.compare-tool-btn>.action-btn{background:transparent;border:none;box-shadow:none;color:inherit;min-height:0;height:100%;align-self:stretch;padding:0 .6rem;transform:none}.compare-tool-btn>.action-btn:hover,label.compare-tool-btn>.action-btn:hover{transform:none;border:none}.compare-tool-merge__actions button:has(>.action-btn){padding:0;border:none;background:transparent;height:auto;line-height:inherit}.compare-tool-merge__actions button:has(>.action-btn):hover{border:none}.compare-tool-merge textarea{width:100%;min-height:180px;max-height:240px;resize:vertical;border:1px solid var(--border);border-radius:10px;background:var(--bg);color:var(--text);padding:.85rem;font:inherit;font-size:.75rem;line-height:1.35;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.compare-tool-merge__notice{margin:.5rem 0 0;color:var(--muted);font-size:.85rem}.formatter-tool-field{display:inline-flex;align-items:center;gap:.45rem;color:var(--muted);font-size:.9rem}.formatter-tool-field select{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:8px;padding:.28rem .55rem;font:inherit;cursor:pointer}.formatter-tool-result--success{border-color:color-mix(in srgb,#22c55e 34%,var(--border));background:color-mix(in srgb,#22c55e 9%,var(--surface))}.formatter-tool-result--error{border-color:color-mix(in srgb,#ef4444 34%,var(--border));background:color-mix(in srgb,#ef4444 9%,var(--surface))}html[data-theme=dark] .compare-tool-result.formatter-tool-result--success,html[data-theme=dark] .formatter-tool-result--success{border-color:color-mix(in srgb,#34d399 50%,var(--border));background:color-mix(in srgb,#22c55e 20%,var(--surface-muted));color:#d1fae5}html[data-theme=dark] .compare-tool-result.formatter-tool-result--error,html[data-theme=dark] .formatter-tool-result--error{border-color:color-mix(in srgb,#f87171 50%,var(--border));background:color-mix(in srgb,#ef4444 20%,var(--surface-muted));color:#fecaca}.formatter-tool-actions--sticky{position:-webkit-sticky;position:sticky;top:70px;z-index:7;padding:.65rem .8rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.formatter-tool-actions--sticky .compare-tool-merge__head{margin-bottom:0}.formatter-tool-actions--sticky .compare-tool-merge__head h2{font-size:.92rem}@media (max-width:900px){.formatter-tool-actions--sticky{padding:.55rem .7rem}}html[data-theme=dark] .formatter-tool-actions--sticky{box-shadow:0 10px 24px color-mix(in srgb,#000 45%,transparent)}.color-tool-swatch{width:44px;height:32px;padding:2px;cursor:pointer}.color-tool-input,.color-tool-swatch{border:1px solid var(--border);border-radius:8px;background:var(--bg)}.color-tool-input{color:var(--text);padding:.4rem .6rem;font:inherit;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;min-width:120px}.color-tool-rgb-fields{display:inline-flex;gap:.45rem;align-items:center}.color-tool-rgb-input{min-width:70px;width:78px}.color-tool-unit{font-style:normal;font-size:.78rem;color:var(--muted)}.color-tool-upload-btn{display:inline-flex;align-items:center;justify-content:center}.color-tool-image{width:100%;max-height:320px;object-fit:contain;border:1px solid var(--border);border-radius:10px;background:color-mix(in srgb,var(--surface) 92%,var(--bg));cursor:crosshair}.color-tool-image-wrap{position:relative}.color-tool-zoom-panel{position:absolute;top:10px;right:10px;border:1px solid var(--border);border-radius:10px;background:color-mix(in srgb,var(--surface) 92%,var(--bg));padding:.45rem;display:grid;grid-gap:.35rem;gap:.35rem;box-shadow:0 8px 16px color-mix(in srgb,#0f172a 12%,transparent)}.color-tool-zoom-head{display:flex;align-items:center;gap:.45rem;font-size:.72rem}.color-tool-zoom-color{width:14px;height:14px;border-radius:4px;border:1px solid color-mix(in srgb,var(--border) 90%,#000)}.color-tool-zoom-head code{font-size:.72rem}.color-tool-zoom-head small{color:var(--muted)}.color-tool-zoom-canvas{width:132px;height:132px;border:1px solid var(--border);border-radius:8px;image-rendering:pixelated;background:var(--bg)}.color-tool-canvas{display:none}.validator-tool-result{margin:0;border:1px solid var(--border);border-radius:10px;background:var(--bg);color:var(--text);padding:.7rem .8rem;min-height:54px;white-space:pre-wrap;word-break:break-word;font-size:.84rem;line-height:1.45;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.validator-tool-badge{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:999px;padding:.38rem .72rem;font-size:.86rem;background:color-mix(in srgb,var(--surface) 90%,var(--bg));color:var(--text)}.validator-tool-badge.is-success{border-color:color-mix(in srgb,#22c55e 35%,var(--border));background:color-mix(in srgb,#22c55e 11%,var(--surface))}.validator-tool-badge.is-error{border-color:color-mix(in srgb,#ef4444 35%,var(--border));background:color-mix(in srgb,#ef4444 11%,var(--surface))}.unit-tool-grid{display:grid;grid-gap:.8rem;gap:.8rem}.unit-tool-fields{display:grid;grid-gap:.5rem;gap:.5rem;grid-template-columns:repeat(2,minmax(0,1fr))}.unit-tool-fields input,.unit-tool-fields select{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:8px;padding:.4rem .58rem;font:inherit}.unit-tool-result{margin:0;border:1px solid var(--border);border-radius:8px;background:color-mix(in srgb,var(--surface) 92%,var(--bg));padding:.45rem .58rem;font-size:.84rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.security-tool-textarea{width:100%;min-height:110px;border:1px solid var(--border);border-radius:10px;background:var(--bg);color:var(--text);padding:.75rem .85rem;font:inherit;line-height:1.4;resize:vertical;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.security-strength-wrap{display:grid;grid-gap:.45rem;gap:.45rem}.security-strength-track{width:100%;height:8px;border-radius:999px;background:color-mix(in srgb,var(--border) 72%,var(--surface));overflow:hidden}.security-strength-fill{height:100%;width:0;transition:width .18s ease;background:color-mix(in srgb,var(--muted) 75%,var(--border))}.security-strength-fill.is-weak{background:#ef4444}.security-strength-fill.is-medium{background:#f59e0b}.security-strength-fill.is-strong{background:#22c55e}.security-tool-tabs{display:flex;flex-wrap:wrap;gap:.45rem}.security-tool-tab{border:1px solid var(--border);background:var(--surface);color:var(--muted);border-radius:999px;padding:.42rem .8rem;font:inherit;font-size:.86rem;font-weight:600;cursor:pointer;transition:transform .2s ease,border-color .2s ease,background .2s ease,color .2s ease}.security-tool-tab:hover{border-color:#c7c7cc;color:var(--text);transform:translateY(-1px)}.security-tool-tab.is-active{border-color:color-mix(in srgb,var(--accent) 55%,var(--border));background:color-mix(in srgb,var(--accent) 12%,var(--surface));color:var(--accent);box-shadow:0 4px 14px color-mix(in srgb,var(--accent) 14%,transparent)}.image-tool-upload-btn{display:inline-flex;align-items:center;justify-content:center}.compare-tool-btn.is-disabled{pointer-events:none;opacity:.5}.image-tool-preview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.75rem;gap:.75rem}.image-tool-preview{width:100%;max-height:260px;object-fit:contain;border:1px solid var(--border);border-radius:10px;background:color-mix(in srgb,var(--surface) 92%,var(--bg))}.image-tool-crop-wrap{position:relative;display:inline-block;width:100%;cursor:crosshair;-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:none}.image-tool-crop-wrap .image-tool-preview{margin:0}.image-tool-crop-selection{position:absolute;border:2px solid color-mix(in srgb,var(--accent) 72%,#fff);background:color-mix(in srgb,var(--accent) 24%,transparent);box-shadow:inset 0 0 0 9999px color-mix(in srgb,#000 24%,transparent);pointer-events:auto}.image-tool-crop-handle{position:absolute;width:12px;height:12px;border:2px solid #fff;border-radius:999px;background:var(--accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 45%,#000);padding:0}.image-tool-crop-handle.is-nw{left:-7px;top:-7px;cursor:nwse-resize}.image-tool-crop-handle.is-ne{right:-7px;top:-7px;cursor:nesw-resize}.image-tool-crop-handle.is-sw{left:-7px;bottom:-7px;cursor:nesw-resize}.image-tool-crop-handle.is-se{right:-7px;bottom:-7px;cursor:nwse-resize}.image-tool-crop-controls{grid-template-columns:repeat(3,minmax(0,1fr));align-items:start}.image-tool-crop-controls label{display:inline-flex;align-items:center;gap:.4rem;min-height:38px}.image-tool-hidden-canvas{display:none}.cheatsheet-table-wrap{overflow:auto;border:1px solid var(--border);border-radius:12px}.cheatsheet-table{width:100%;border-collapse:collapse;min-width:720px;background:color-mix(in srgb,var(--surface) 92%,var(--bg))}.cheatsheet-table td,.cheatsheet-table th{border-bottom:1px solid var(--border);padding:.72rem .8rem;text-align:left;vertical-align:top;color:var(--text)}.cheatsheet-table th{position:-webkit-sticky;position:sticky;top:0;z-index:1;font-weight:600;background:color-mix(in srgb,var(--surface) 96%,var(--bg))}.cheatsheet-table tbody tr:hover{background:color-mix(in srgb,var(--accent) 8%,var(--surface))}.cheatsheet-table code{font-size:.85rem}.cheatsheet-toolbar{justify-content:space-between}.cheatsheet-search-field{flex:1 1;min-width:260px;max-width:640px;border:1px solid var(--border);border-radius:10px;background:color-mix(in srgb,var(--surface) 92%,var(--bg));padding:.2rem .55rem;gap:.45rem}.cheatsheet-search-field svg{color:var(--muted);flex-shrink:0}.cheatsheet-search-field input{width:100%;border:none;outline:none;background:transparent;color:var(--text);min-height:34px;font-size:.92rem}.cheatsheet-search-field input:focus-visible{outline:2px solid color-mix(in srgb,var(--accent) 45%,transparent);outline-offset:1px}.cheatsheet-download-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;padding:0}@media (max-width:900px){.image-tool-crop-controls,.image-tool-preview-grid,.unit-tool-fields{grid-template-columns:1fr}}@media (max-width:700px){.compare-tool-merge__head{flex-direction:column;align-items:flex-start}.compare-tool-merge__actions{width:100%}.compare-tool-merge__actions .compare-tool-btn,.compare-tool-merge__actions a.compare-tool-btn,.compare-tool-merge__actions button{min-height:34px}.compare-tool-merge__head--merged{flex-direction:row;align-items:center;justify-content:space-between;width:100%}.compare-tool-merge__head--merged .compare-tool-merge__actions{width:auto;flex-wrap:nowrap;overflow-x:auto}.cheatsheet-toolbar{align-items:stretch}.cheatsheet-search-field{max-width:none;width:100%}}.color-tool-codes{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:.75rem;gap:.75rem}.color-tool-code{border:1px solid var(--border);border-radius:10px;background:color-mix(in srgb,var(--surface) 92%,var(--bg));color:var(--text);padding:.7rem .8rem;text-align:left;display:grid;grid-gap:.25rem;gap:.25rem;cursor:pointer}.color-tool-code strong{font-size:.78rem;color:var(--muted)}.color-tool-code span{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.88rem}.color-tool-code:hover{border-color:var(--accent)}.color-tool-palette{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-gap:.6rem;gap:.6rem}.color-tool-shade{border:1px solid color-mix(in srgb,var(--border) 90%,#000);border-radius:10px;min-height:90px;padding:.45rem;display:flex;flex-direction:column;justify-content:space-between;text-align:left;cursor:pointer;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.35)}.color-tool-shade span{font-size:.74rem;font-weight:600}.color-tool-shade code{font-size:.7rem;background:color-mix(in srgb,#000 32%,transparent);border-radius:6px;padding:.12rem .28rem;width:-moz-fit-content;width:fit-content}@media (max-width:900px){.color-tool-rgb-fields{width:100%;justify-content:flex-start;flex-wrap:wrap}.color-tool-zoom-panel{position:static;margin-top:.55rem;width:-moz-fit-content;width:fit-content}.color-tool-codes{grid-template-columns:1fr}.color-tool-palette{grid-template-columns:repeat(2,minmax(0,1fr))}}.v-dummy{min-height:120px}.site-footer__social{margin-top:.75rem;display:flex;gap:.5rem}.site-footer__social a{width:32px;height:32px;border-radius:999px;border:1px solid var(--border);display:grid;place-items:center;color:var(--muted)}.site-footer__social a:hover{color:var(--text);text-decoration:none}@media (min-width:768px){.site-nav--desktop{display:flex}.site-header__cta{display:inline-flex}.site-menu-btn,.site-mobile-nav{display:none}.v-features-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.v-feature-card{grid-column:span 1;min-height:140px}.v-feature-card.is-wide{grid-column:span 2}}@media (max-width:767px){.site-header{width:calc(100% - 1rem);margin:.75rem auto 0;top:.75rem;border-radius:16px}.site-header__actions{gap:.4rem}.site-header__login-pill{display:none}.site-main{padding-top:1rem}.hero{border-radius:14px;margin-bottom:1rem}.hero__actions{display:grid;grid-template-columns:1fr;width:100%}.hero-focus-row{justify-content:flex-start}.hero__btn{width:100%;justify-content:center;min-height:40px}.v-section{margin-bottom:1rem}.v-section__head{text-align:left}.v-section__head p{margin-top:.4rem}.v-features-grid{gap:.62rem}.v-feature-card{border-radius:12px;min-height:0}.v-feature-card,.v-feature-card.is-wide{grid-column:span 1}.home-post-bento__grid{grid-template-columns:1fr;grid-auto-rows:minmax(180px,auto)}.home-post-bento__item--featured{grid-column:auto;grid-row:auto}.home-post-bento__item--wide{grid-column:auto}.home-post-bento__link{aspect-ratio:4/3;min-height:180px}.home-post-bento__item--featured .home-post-bento__link{aspect-ratio:4/3;min-height:200px}.tool-card{padding:.85rem;border-radius:12px}.tool-field{margin-bottom:.65rem}.action-btn{min-height:40px;padding-inline:.75rem}}@media (max-width:900px){.compare-tool-grid{grid-template-columns:1fr}.compare-tool-diff{overflow-x:auto}.compare-tool-diff__table{min-width:760px;width:max-content}.compare-tool-diff__head,.compare-tool-diff__row{width:100%;grid-template-columns:minmax(260px,1fr) minmax(260px,1fr) fit-content(120px)}.compare-tool-diff__titlebar{flex-direction:column;align-items:flex-start}.compare-tool-merge--sticky{bottom:8px}}.ai-chatbot-root{position:fixed;z-index:60}.ai-chatbot-trigger{position:relative;display:flex;align-items:center;justify-content:center;border:0;border-radius:999px;color:#fff;background:var(--accent);box-shadow:0 14px 28px color-mix(in srgb,var(--accent) 36%,transparent);transition:transform .3s ease,box-shadow .3s ease,opacity .3s ease}.ai-chatbot-trigger:hover{transform:scale(1.05);box-shadow:0 18px 32px color-mix(in srgb,var(--accent) 40%,transparent)}.ai-chatbot-trigger.is-open{transform:rotate(90deg) scale(0);opacity:0;pointer-events:none}.ai-chatbot-trigger__pulse{position:absolute;inset:0;border-radius:999px;background:color-mix(in srgb,var(--accent) 30%,transparent);animation:aiChatbotPing 1.8s cubic-bezier(0,0,.2,1) infinite;z-index:-1}@keyframes aiChatbotPing{0%{transform:scale(1);opacity:.65}80%,to{transform:scale(1.45);opacity:0}}.ai-chatbot-panel{position:fixed;z-index:60;max-width:390px;transform-origin:bottom right;transition:transform .3s ease,opacity .3s ease}.ai-chatbot-panel.open{transform:scale(1);opacity:1;pointer-events:auto}.ai-chatbot-panel.closed{transform:scale(.95);opacity:0;pointer-events:none}.ai-chatbot-panel{overflow:hidden;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 92%,#fff);box-shadow:0 22px 40px color-mix(in srgb,#0f172a 20%,transparent)}.ai-chatbot-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--accent-soft) 12%,var(--surface))}.ai-chatbot-title-wrap{display:flex;align-items:center;gap:.6rem}.ai-chatbot-title-icon{display:grid;place-items:center;width:38px;height:38px;border-radius:999px;color:#fff;background:var(--accent)}.ai-chatbot-title-wrap h3{margin:0;font-size:.95rem}.ai-chatbot-title-wrap p{margin:0;font-size:.75rem;color:var(--muted)}.ai-chatbot-icon-btn{width:30px;height:30px;border-radius:999px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 90%,#fff);color:var(--muted);display:grid;place-items:center}.ai-chatbot-messages{overflow-y:auto;padding:.75rem;display:flex;flex-direction:column;gap:.65rem}.ai-chatbot-row{display:flex;gap:.45rem}.ai-chatbot-row.user{flex-direction:row-reverse}.ai-chatbot-avatar{width:28px;height:28px;border-radius:999px;display:grid;place-items:center;flex-shrink:0}.ai-chatbot-row.assistant .ai-chatbot-avatar{background:var(--accent);color:#fff}.ai-chatbot-row.user .ai-chatbot-avatar{background:color-mix(in srgb,var(--accent-soft) 30%,#fff);color:var(--text)}.ai-chatbot-bubble{max-width:78%;border-radius:14px;padding:.5rem .7rem;font-size:.86rem;line-height:1.45}.ai-chatbot-row.assistant .ai-chatbot-bubble{border-top-left-radius:6px;background:color-mix(in srgb,var(--surface) 86%,#fff)}.ai-chatbot-row.user .ai-chatbot-bubble{border-top-right-radius:6px;color:#fff;background:var(--accent)}.ai-chatbot-bubble--typing{display:inline-flex;align-items:center;gap:4px;min-height:32px}.ai-chatbot-bubble--typing span{width:7px;height:7px;border-radius:999px;background:var(--muted);animation:aiDotBounce .9s ease-in-out infinite}.ai-chatbot-bubble--typing span:nth-child(2){animation-delay:.12s}.ai-chatbot-bubble--typing span:nth-child(3){animation-delay:.24s}@keyframes aiDotBounce{0%,80%,to{transform:translateY(0);opacity:.45}40%{transform:translateY(-3px);opacity:1}}.ai-chatbot-input-wrap{border-top:1px solid var(--border);padding:.75rem;display:flex;gap:.5rem}.ai-chatbot-input{flex:1 1;height:38px;border-radius:999px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 86%,#fff);color:var(--text);padding:0 .85rem}.ai-chatbot-send{width:38px;height:38px;border-radius:999px;border:0;color:#fff;background:var(--accent);display:grid;place-items:center}.ai-chatbot-send:disabled{opacity:.58}@media (max-width:640px){.ai-chatbot-panel,.ai-chatbot-root{right:12px;bottom:12px}.ai-chatbot-panel{width:calc(100vw - 24px);max-width:360px}}html[data-theme=dark] .ai-chatbot-panel{background:rgba(26,35,51,.95);border-color:#2a3650}html[data-theme=dark] .ai-chatbot-header{background:rgba(37,54,82,.45)}html[data-theme=dark] .ai-chatbot-row.assistant .ai-chatbot-bubble{background:#1f2c43}html[data-theme=dark] .ai-chatbot-row.user .ai-chatbot-bubble,html[data-theme=dark] .ai-chatbot-send,html[data-theme=dark] .ai-chatbot-title-icon,html[data-theme=dark] .ai-chatbot-trigger{background:#5f92ff}.ai-chatbot-root{right:24px;bottom:24px}.ai-chatbot-trigger{width:56px;height:56px;border-radius:9999px;box-shadow:0 10px 25px rgba(2,8,23,.2)}.ai-chatbot-panel{width:calc(100vw - 48px);max-width:384px;right:24px;bottom:24px;border-radius:16px}.ai-chatbot-header{padding:12px 16px;background:color-mix(in srgb,var(--accent) 8%,transparent)}.ai-chatbot-title-icon{width:40px;height:40px}.ai-chatbot-icon-btn{width:32px;height:32px}.ai-chatbot-messages{height:320px;padding:16px;gap:14px}.ai-chatbot-row{gap:8px}.ai-chatbot-avatar{width:32px;height:32px}.ai-chatbot-bubble{max-width:75%;border-radius:16px;padding:10px 14px;font-size:14px}.ai-chatbot-row.assistant .ai-chatbot-bubble{border-top-left-radius:8px}.ai-chatbot-row.user .ai-chatbot-bubble{border-top-right-radius:8px}.ai-chatbot-bubble--typing span{width:8px;height:8px}.ai-chatbot-input-wrap{padding:16px;gap:8px}.ai-chatbot-input,.ai-chatbot-send{height:40px;border-radius:9999px}.ai-chatbot-send{width:40px}@media (max-width:640px){.ai-chatbot-panel,.ai-chatbot-root{right:24px;bottom:24px}.ai-chatbot-panel{width:calc(100vw - 48px);max-width:384px}}.admin-page{display:grid;grid-gap:1rem;gap:1rem}.admin-page h1{margin:0}.admin-subtitle{margin:0;color:var(--muted)}.admin-grid{display:grid;grid-gap:1rem;gap:1rem;grid-template-columns:1fr}.admin-card{background:color-mix(in srgb,var(--surface) 90%,#fff);border:1px solid var(--border);border-radius:12px;padding:1rem;display:grid;grid-gap:.55rem;gap:.55rem}.admin-card h2{margin:0 0 .35rem}.admin-card input,.admin-card select,.admin-card textarea{width:100%;border:1px solid var(--border);border-radius:10px;padding:.55rem .65rem;background:color-mix(in srgb,var(--surface) 88%,#fff);color:var(--text)}.admin-card button{border:1px solid transparent;border-radius:10px;padding:.5rem .75rem;background:var(--accent);color:#fff}.admin-password-field{position:relative}.admin-password-field input{padding-right:2.25rem!important}.admin-password-toggle{position:absolute;right:.35rem;top:50%;transform:translateY(-50%);width:28px!important;height:28px!important;border-radius:8px!important;border:1px solid var(--border)!important;background:color-mix(in srgb,var(--surface) 90%,#fff)!important;color:var(--text)!important;display:inline-flex;align-items:center;justify-content:center;padding:0!important}.admin-actions,.admin-connect__row,.admin-post-list__actions{display:flex;gap:.5rem;align-items:center}.admin-row-2{display:grid;grid-template-columns:1fr;grid-gap:.55rem;gap:.55rem}.admin-publish-panel{border:1px solid var(--border);border-radius:12px;padding:.72rem;display:grid;grid-template-columns:1fr;grid-gap:.65rem;gap:.65rem;background:color-mix(in srgb,var(--surface) 90%,#fff)}.admin-status-switch{display:grid;grid-template-columns:1fr 1fr;grid-gap:.45rem;gap:.45rem}.admin-status-switch__btn{border:1px solid var(--border);border-radius:10px;padding:.5rem .6rem;background:#ffffff;color:#111827;font-weight:600}.admin-status-switch__btn.active{border-color:#2563eb;background:#2563eb;color:#fff}.admin-card .admin-status-switch__btn{background:#ffffff!important;color:#111827!important;border-color:#d1d5db!important}.admin-card .admin-status-switch__btn.active{background:#2563eb!important;color:#ffffff!important;border-color:#2563eb!important}html:not([data-theme=dark]) .admin-card .admin-status-switch__btn{background:#ffffff!important;color:#111827!important;border-color:#d1d5db!important}html:not([data-theme=dark]) .admin-card .admin-status-switch__btn.active{background:#2563eb!important;color:#ffffff!important;border-color:#2563eb!important}.admin-editor-tools{display:flex;gap:.45rem;flex-wrap:wrap}.admin-paste-options{display:flex;gap:.65rem;align-items:flex-end;flex-wrap:wrap}.admin-paste-options label{display:grid;grid-gap:.35rem;gap:.35rem;font-size:.84rem}.admin-paste-options__toggle{display:inline-flex!important;align-items:center;gap:.45rem!important;padding-bottom:.25rem}.admin-paste-options__toggle input{width:auto!important}.admin-html-preview{border:1px dashed var(--border);border-radius:10px;padding:.55rem .65rem;background:color-mix(in srgb,var(--surface) 90%,#fff)}.admin-html-preview summary{cursor:pointer;color:var(--muted);font-size:.86rem}.admin-content-preview{margin-top:.5rem}.admin-preview-tools{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.6rem}.admin-content-preview--editable{min-height:180px;border:1px solid color-mix(in srgb,var(--border) 88%,var(--bg));border-radius:10px;padding:.75rem .8rem;background:color-mix(in srgb,var(--surface) 94%,#fff);cursor:text}.admin-content-preview--editable:focus{outline:2px solid color-mix(in srgb,var(--accent) 32%,transparent);outline-offset:1px}.admin-btn-secondary{background:color-mix(in srgb,var(--surface) 84%,#fff)!important;color:var(--text)!important;border-color:var(--border)!important}.admin-action-btn--primary{min-width:148px}.admin-action-btn--secondary{min-width:124px}.admin-btn-danger{background:#a64040!important}.admin-post-list{list-style:none;margin:0;padding:0;display:grid;grid-gap:.55rem;gap:.55rem}.admin-post-list li{display:flex;justify-content:space-between;gap:.7rem;align-items:center;border:1px solid var(--border);border-radius:10px;padding:.55rem}.admin-post-list p{margin:.2rem 0 0;color:var(--muted);font-size:.82rem}.admin-post-list--cards{grid-template-columns:1fr;gap:.7rem}.admin-post-list--cards li{display:grid;grid-template-columns:72px minmax(0,1fr) auto;align-items:center;grid-gap:.7rem;gap:.7rem;min-height:76px}.admin-post-card__thumb{width:72px;height:56px;border-radius:10px;overflow:hidden;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 88%,#fff);display:flex;align-items:center;justify-content:center}.admin-post-card__thumb img{width:100%;height:100%;object-fit:cover;display:block}.admin-post-card__thumb-fallback{display:inline-flex;color:var(--muted)}.admin-post-card__body{min-width:0}.admin-post-card__body strong{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.admin-user-meta{margin-top:.35rem;display:inline-flex;gap:.35rem;flex-wrap:wrap}.admin-user-badge{display:inline-flex;align-items:center;padding:.12rem .45rem;border-radius:999px;border:1px solid var(--border);font-size:.72rem;color:var(--muted);background:color-mix(in srgb,var(--surface) 88%,#fff)}.admin-user-badge--active{color:#166534;border-color:color-mix(in srgb,#22c55e 50%,var(--border));background:color-mix(in srgb,#22c55e 16%,#fff)}.admin-user-badge--inactive{color:#9f1239;border-color:color-mix(in srgb,#f43f5e 48%,var(--border));background:color-mix(in srgb,#f43f5e 14%,#fff)}.admin-empty{color:var(--muted)}.admin-error,.admin-notice{margin:0;padding:.6rem .75rem;border-radius:10px;border:1px solid var(--border)}.admin-error{color:#a64040;background:color-mix(in srgb,#a64040 10%,transparent)}.admin-notice{color:#2f6f49;background:color-mix(in srgb,#2f6f49 10%,transparent)}@media (min-width:1000px){.admin-grid{grid-template-columns:minmax(0,1fr) minmax(300px,360px)}.admin-publish-panel,.admin-row-2{grid-template-columns:1fr 1fr}.admin-publish-panel{align-items:flex-end}}.site-header__cta--ghost{border-color:var(--border);background:color-mix(in srgb,var(--surface) 88%,#fff);color:var(--text)}.site-header__cta--danger{color:#b42323;border-color:color-mix(in srgb,#ef4444 45%,var(--border));background:color-mix(in srgb,#ef4444 10%,transparent)}.admin-login-page{min-height:70vh;display:grid;place-items:center}.admin-login-card{width:min(100%,460px)}.admin-dashboard{display:grid;grid-template-columns:1fr;grid-gap:1rem;gap:1rem}.admin-sidebar{align-content:start;gap:.6rem;transition:padding .22s ease,gap .22s ease;overflow-x:hidden}.admin-sidebar h2{margin:0 0 .3rem}.admin-card__title-row,.admin-sidebar__header{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.admin-sidebar__link{width:100%;border:1px solid var(--border);border-radius:10px;padding:.52rem .7rem;background:#fff;color:#111827;text-align:left;transition:background .2s ease,border-color .2s ease,padding .2s ease}.admin-sidebar__toggle{justify-content:flex-start}.admin-sidebar__mini-avatar{width:20px;height:20px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#3d7ff0,#204a96)}.admin-sidebar__mini-avatar--image{object-fit:cover;background:none}.admin-sidebar__link.active{border-color:#2563eb;background:#2563eb;color:#fff}.admin-sidebar__link.active svg{color:#fff}.admin-sidebar__link:not(.active) svg{color:#111827}.admin-content{min-width:0;display:grid;grid-gap:.8rem;gap:.8rem}@media (min-width:960px){.admin-dashboard{grid-template-columns:228px minmax(0,1fr);align-items:start}.admin-dashboard--nav-minimized{grid-template-columns:84px minmax(0,1fr)}.admin-sidebar{position:-webkit-sticky;position:sticky;top:84px;max-height:calc(100vh - 96px);overflow:auto}.admin-grid--editor-only{grid-template-columns:1fr!important}}.admin-card{background:color-mix(in srgb,var(--surface) 88%,#fff);box-shadow:0 12px 28px color-mix(in srgb,#0f172a 8%,transparent)}.admin-sidebar{background:color-mix(in srgb,var(--surface) 84%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.admin-sidebar__link{display:inline-flex;align-items:center;gap:.45rem}.admin-sidebar__actions{margin-top:.2rem;display:flex;flex-wrap:wrap;gap:.5rem}.admin-sidebar--icons .admin-sidebar__link{justify-content:center;padding:.52rem}.admin-sidebar--icons .admin-sidebar__link span:not(.admin-sidebar__mini-avatar){display:none}.admin-sidebar--icons .admin-sidebar__actions{justify-content:center;gap:.4rem}.admin-icon-btn{width:36px;height:36px;border:1px solid var(--border);border-radius:10px;background:color-mix(in srgb,var(--surface) 88%,#fff);color:var(--text);display:inline-flex;align-items:center;justify-content:center;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.admin-icon-btn:hover{transform:translateY(-1px);border-color:color-mix(in srgb,var(--accent-soft) 65%,var(--border));box-shadow:0 8px 18px color-mix(in srgb,var(--accent) 10%,transparent)}.admin-icon-btn--with-text{width:auto;padding:0 .7rem;gap:.4rem}.admin-icon-btn--danger,.admin-icon-btn--success{color:#f8fafc}.admin-sidebar__actions .admin-icon-btn--danger,.admin-sidebar__actions .admin-icon-btn--danger svg{color:#f8fafc!important;background:#dc2626!important;border-color:#dc2626!important}.admin-sidebar__actions .admin-icon-btn--success,.admin-sidebar__actions .admin-icon-btn--success svg{color:#f8fafc!important;background:#16a34a!important;border-color:#16a34a!important}html:not([data-theme=dark]) .admin-sidebar__link{background:#ffffff!important;color:#111827!important;border-color:#d1d5db}html:not([data-theme=dark]) .admin-sidebar__link svg{color:#111827!important}html:not([data-theme=dark]) .admin-sidebar__link.active{background:#2563eb!important;color:#ffffff!important;border-color:#2563eb!important}html:not([data-theme=dark]) .admin-sidebar__link.active svg{color:#ffffff!important}.admin-profile-card{text-align:center;justify-items:center}.admin-profile-avatar{width:56px;height:56px;border-radius:999px;display:grid;place-items:center;font-weight:700;color:#fff;background:linear-gradient(135deg,#3d7ff0,#204a96);margin-bottom:.35rem}.admin-profile-avatar--image{object-fit:cover}.admin-profile-card h2{margin:0}.admin-post-list__actions{display:flex;gap:.4rem}.admin-post-list__actions .admin-icon-btn--danger{background:#dc2626!important;border-color:#dc2626!important;color:#f8fafc!important}.admin-post-list__actions .admin-icon-btn--danger svg{color:#f8fafc!important}.admin-post-list__header-actions{display:inline-flex;gap:.45rem;align-items:center}.admin-user-search{width:180px;border:1px solid var(--border);border-radius:10px;padding:.46rem .58rem;background:color-mix(in srgb,var(--surface) 90%,#fff);color:var(--text)}.admin-grid--users{grid-template-columns:1fr}.admin-user-form-card,.admin-user-list-card{align-content:start}.admin-user-list__title-row{align-items:center}.admin-user-list__header-actions{flex-wrap:nowrap;justify-content:flex-end;width:100%;max-width:280px}.admin-checkbox-row{display:inline-flex!important;align-items:center;gap:.5rem!important;margin-top:0;padding:0;border:0;background:transparent}.admin-checkbox-row input[type=checkbox]{width:auto!important}.admin-user-controls{display:grid;grid-gap:.75rem;gap:.75rem}.admin-user-active-field{display:inline-flex;align-items:center;gap:.5rem}html[data-theme=dark] .admin-card{background:rgba(26,35,51,.86);border-color:#2a3650}html[data-theme=dark] .admin-icon-btn,html[data-theme=dark] .admin-sidebar__link{background:rgba(20,29,44,.78);border-color:#2a3650}html[data-theme=dark] .admin-sidebar__link,html[data-theme=dark] .admin-sidebar__link:not(.active) svg{color:#cbd5e1}html[data-theme=dark] .admin-sidebar__link.active{background:#2563eb;border-color:#2563eb;color:#fff}html[data-theme=dark] .admin-sidebar__actions .admin-icon-btn--danger,html[data-theme=dark] .admin-sidebar__actions .admin-icon-btn--danger svg,html[data-theme=dark] .admin-sidebar__actions .admin-icon-btn--success,html[data-theme=dark] .admin-sidebar__actions .admin-icon-btn--success svg{color:#e5e7eb!important}@media (min-width:1100px){.admin-grid--users{grid-template-columns:minmax(360px,430px) minmax(0,1fr);align-items:start}.admin-user-search{width:100%;min-width:0}}html[data-theme=dark] .admin-status-switch__btn{background:rgba(20,29,44,.78);color:#cbd5e1;border-color:#2a3650}html[data-theme=dark] .admin-status-switch__btn.active{background:#2563eb;color:#fff;border-color:#2563eb}html[data-theme=dark] .admin-card .admin-status-switch__btn{background:rgba(20,29,44,.78)!important;color:#cbd5e1!important;border-color:#2a3650!important}html[data-theme=dark] .admin-card .admin-status-switch__btn.active{background:#2563eb!important;color:#ffffff!important;border-color:#2563eb!important}.admin-menu{position:relative}.admin-menu__trigger{width:34px;height:34px;border:1px solid color-mix(in srgb,var(--accent) 30%,var(--border));border-radius:999px;background:color-mix(in srgb,var(--surface) 88%,transparent);color:var(--text);display:inline-flex;align-items:center;justify-content:center;transition:transform .3s ease,border-color .3s ease,background .3s ease}.admin-menu__trigger:hover{transform:translateY(-1px);border-color:color-mix(in srgb,var(--accent) 65%,var(--border));background:color-mix(in srgb,var(--accent) 10%,var(--surface))}.admin-menu__dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:170px;padding:.4rem;border:1px solid var(--border);border-radius:14px;background:color-mix(in srgb,var(--surface) 94%,transparent);box-shadow:0 16px 30px color-mix(in srgb,#0f172a 14%,transparent);opacity:0;visibility:hidden;transform:translateY(-4px);transition:opacity .18s ease,transform .18s ease,visibility .18s ease;z-index:80}.admin-menu.open .admin-menu__dropdown{opacity:1;visibility:visible;transform:translateY(0)}.admin-menu__item{width:100%;border:0;background:transparent;color:var(--text);border-radius:10px;padding:.42rem .5rem;display:inline-flex;gap:.45rem;align-items:center;text-decoration:none;font-size:.86rem}.admin-menu__item:hover{text-decoration:none;background:color-mix(in srgb,var(--accent-soft) 22%,#fff)}.admin-menu__item--danger{color:#b42323}@media (max-width:767px){.admin-sidebar__toggle{display:none}.admin-dashboard--nav-minimized{grid-template-columns:1fr}.admin-sidebar--icons .admin-sidebar__link{justify-content:flex-start;padding:.52rem .7rem}.admin-sidebar--icons .admin-sidebar__link span{display:inline}.admin-sidebar--icons .admin-sidebar__actions,.admin-sidebar--icons .admin-sidebar__toggle{justify-content:flex-start}.admin-menu{display:none}}.billiard-landing-grid{display:grid;grid-gap:1rem;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.billiard-room-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.55rem;gap:.55rem;margin:0 0 .9rem}.billiard-room-tab{height:var(--tool-btn-size);border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--muted);font:inherit;font-size:.9rem;font-weight:600;cursor:pointer;transition:transform .2s ease,border-color .2s ease,color .2s ease,background .2s ease}.billiard-room-tab:hover{color:var(--text);transform:translateY(-1px)}.billiard-room-tab.active{border-color:color-mix(in srgb,var(--accent) 55%,var(--border));background:color-mix(in srgb,var(--accent) 12%,var(--surface));color:var(--accent);box-shadow:0 4px 14px color-mix(in srgb,var(--accent) 14%,transparent)}.tool-card{border:1px solid var(--border);border-radius:14px;padding:1rem;background:var(--surface);box-shadow:var(--shadow-card)}.tool-field{display:grid;grid-gap:.4rem;gap:.4rem;margin-bottom:.8rem}.tool-field input,.tool-field select{width:100%;border:1px solid color-mix(in oklab,var(--border),transparent 16%);background:var(--input);border-radius:10px;padding:.65rem .75rem}.tool-helper-text{gap:.4rem;opacity:.84;font-size:.9rem}.tool-helper-text,.tool-pill{display:inline-flex;align-items:center}.tool-pill{border-radius:999px;border:1px solid color-mix(in oklab,var(--border),transparent 10%);padding:.35rem .65rem;background:color-mix(in oklab,var(--card),transparent 5%);font-size:.82rem}.tool-success{margin:.8rem 0;border:1px solid color-mix(in oklab,#10b981,transparent 35%);background:color-mix(in oklab,#10b981,transparent 88%);border-radius:12px;padding:.7rem .8rem;display:inline-flex;align-items:center;gap:.45rem}.billiard-landing-row,.billiard-room-head,.billiard-status-row{display:flex;gap:.65rem;flex-wrap:wrap;align-items:center;justify-content:space-between}.billiard-mode-hint{margin:.2rem 0 .75rem;font-size:.9rem;opacity:.86}.billiard-mode-chips{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:.5rem;gap:.5rem;margin:0 0 .75rem}.billiard-mode-chips--2{grid-template-columns:repeat(2,minmax(0,1fr));margin:0}.billiard-mode-chip{height:var(--tool-btn-size);border:1px solid color-mix(in oklab,var(--border),transparent 12%);border-radius:10px;background:color-mix(in oklab,var(--card),transparent 2%);color:var(--text);font:inherit;font-size:.88rem;font-weight:600;cursor:pointer;transition:border-color .16s ease,background .16s ease,transform .16s ease}.billiard-mode-chip:hover{transform:translateY(-1px);border-color:color-mix(in oklab,var(--accent),transparent 35%)}.billiard-mode-chip.active{border-color:color-mix(in oklab,var(--accent),transparent 20%);background:color-mix(in oklab,var(--accent),transparent 86%)}.billiard-pro-toggle{height:var(--tool-btn-size);border:1px solid color-mix(in oklab,var(--border),transparent 12%);border-radius:10px;background:color-mix(in oklab,var(--card),transparent 2%);color:var(--text);display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:0 .75rem;cursor:pointer;font:inherit;font-size:.88rem;font-weight:700}.billiard-pro-toggle.active{border-color:color-mix(in oklab,#d97706,transparent 18%);background:color-mix(in oklab,#d97706,transparent 86%)}.billiard-rules-grid{display:grid;grid-gap:.55rem;gap:.55rem;margin:0 0 .8rem}.billiard-rule-chip{width:100%;text-align:left;border:1px solid color-mix(in oklab,var(--border),transparent 15%);border-radius:10px;padding:.55rem .65rem;background:color-mix(in oklab,var(--card),transparent 2%);color:var(--text);cursor:pointer;transition:border-color .16s ease,background .16s ease,transform .16s ease}.billiard-rule-chip:hover{transform:translateY(-1px);border-color:color-mix(in oklab,var(--accent),transparent 35%)}.billiard-rule-chip.active{border-color:color-mix(in oklab,var(--accent),transparent 24%);background:color-mix(in oklab,var(--accent),transparent 88%)}.billiard-rule-chip strong{display:block;font-size:.92rem}.billiard-rule-chip__head{display:inline-flex;align-items:center;gap:.42rem}.billiard-rule-chip__head svg{opacity:.85}.billiard-rule-chip span{display:block;font-size:.8rem;opacity:.82;margin-top:.15rem}.billiard-rule-card{display:grid;grid-template-columns:auto 1fr;grid-gap:.55rem;gap:.55rem;align-items:start;border:1px solid color-mix(in oklab,var(--border),transparent 15%);border-radius:10px;padding:.55rem .65rem;background:color-mix(in oklab,var(--card),transparent 2%)}.billiard-rule-card input[type=checkbox]{margin-top:.24rem}.billiard-rule-card strong{display:block;font-size:.92rem}.billiard-rule-card span{display:block;font-size:.8rem;opacity:.8}.billiard-grid{display:grid;grid-template-columns:repeat(var(--billiard-cols,8),62px);justify-content:center;grid-gap:.36rem;gap:.36rem;margin:.45rem 0;padding:.7rem;border-radius:16px;border:1px solid color-mix(in oklab,var(--border),transparent 18%);background:color-mix(in oklab,var(--card),transparent 4%);box-shadow:inset 0 0 0 1px #ffffff12}.billiard-grid--bottom{margin-top:0}.billiard-ball{width:62px;height:62px;border-radius:14px;border:1px solid #ffffff26;background:color-mix(in oklab,#052e16,transparent 66%);display:inline-flex;align-items:center;justify-content:center;padding:.25rem;transition:transform .15s ease,border-color .15s ease}.billiard-ball:hover{transform:translateY(-1px) scale(1.02);border-color:color-mix(in oklab,var(--accent),transparent 35%)}.billiard-ball.is-dropped{opacity:.4;filter:grayscale(.35)}.billiard-ball-svg{width:46px;height:46px;display:block;filter:drop-shadow(0 2px 2px color-mix(in oklab,#020617,transparent 85%))}.billiard-player-list{display:grid;grid-gap:.65rem;gap:.65rem;margin-top:.9rem}.billiard-hand{display:flex;gap:.35rem;flex-wrap:wrap}.billiard-hand-pill{width:32px;height:32px;border:1px solid color-mix(in oklab,var(--border),transparent 14%);border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:color-mix(in oklab,var(--card),transparent 4%);padding:0;cursor:default}.billiard-hand-pill .billiard-ball-svg{width:26px;height:26px;filter:none}.billiard-hand-pill.is-crossed{opacity:.48;filter:grayscale(.45)}.billiard-hand-pill.is-clickable{cursor:pointer}.billiard-hand-pill--masked{border-color:transparent}.billiard-hand-pill--masked.is-in{background:color-mix(in oklab,#16a34a,transparent 76%);color:#14532d}.billiard-hand-pill--masked.is-out{background:color-mix(in oklab,#dc2626,transparent 80%);color:#7f1d1d}.billiard-hand-pill__dot{width:9px;height:9px;border-radius:999px;background:currentColor;opacity:.9}.billiard-penalty-row{display:flex;align-items:center;flex-wrap:wrap;gap:.45rem;margin-top:.4rem}.billiard-foul-actions{width:100%;margin-top:.3rem}.billiard-modal-overlay{position:fixed;inset:0;background:color-mix(in oklab,#020617,transparent 55%);overscroll-behavior:contain;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:70}.billiard-modal{width:min(420px,100%);border:1px solid var(--border);border-radius:14px;background:var(--card);box-shadow:0 20px 45px #0206173d;padding:1rem;text-align:center}.billiard-modal h3{margin:0}.billiard-modal p{margin:.45rem 0 0}.billiard-team-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.7rem;gap:.7rem}.billiard-leaderboard-list{display:grid;grid-template-columns:1fr;grid-gap:.45rem;gap:.45rem}.billiard-team-grid ul{margin:.25rem 0 0;padding-left:1rem}.billiard-pro-badge{display:inline-flex;align-items:center;gap:.22rem;margin-left:.4rem;font-size:.76rem;font-weight:700;color:#d97706}.billiard-ready-row{flex-wrap:wrap;align-items:center;gap:.5rem}.billiard-ready-pill{display:inline-flex;align-items:center;gap:.35rem;padding:.28rem .65rem;border-radius:999px;font-size:.8rem;font-weight:600;border:1px solid color-mix(in oklab,var(--foreground),transparent 88%)}.billiard-ready-pill--yes{color:#15803d;background:color-mix(in oklab,#22c55e,transparent 88%);border-color:color-mix(in oklab,#22c55e,transparent 55%)}.billiard-ready-pill--no{color:#b45309;background:color-mix(in oklab,#f97316,transparent 90%);border-color:color-mix(in oklab,#f97316,transparent 50%)}.billiard-ready-pill--host{color:var(--accent-foreground,#0f172a);background:color-mix(in oklab,var(--accent),transparent 82%);border-color:color-mix(in oklab,var(--accent),transparent 45%)}.billiard-ready-toggle{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .75rem;border-radius:.5rem;font-size:.82rem;font-weight:600;cursor:pointer;border:1px solid color-mix(in oklab,var(--foreground),transparent 82%);background:color-mix(in oklab,var(--background),transparent 0%);color:var(--foreground)}.billiard-ready-toggle:hover{border-color:color-mix(in oklab,var(--accent),transparent 40%)}.billiard-ready-toggle.is-active{color:#15803d;background:color-mix(in oklab,#22c55e,transparent 88%);border-color:color-mix(in oklab,#22c55e,transparent 45%)}.action-btn.active{border-color:color-mix(in oklab,var(--accent),transparent 20%);background:color-mix(in oklab,var(--accent),transparent 86%)}.action-btn--danger{border-color:color-mix(in oklab,#ef4444,transparent 35%);color:#ef4444;background:color-mix(in oklab,#ef4444,transparent 92%)}.compare-tool-icon-btn--foul{border-color:color-mix(in oklab,#eab308,transparent 35%);color:#ca8a04;background:color-mix(in oklab,#eab308,transparent 90%)}.v-section--billiard-room{--br-gap:clamp(0.85rem,3.5vw,1.25rem);--br-r:20px;margin-bottom:1.5rem;padding:clamp(.9rem,3.2vw,1.35rem);border:1px solid color-mix(in oklab,#2dd4bf,transparent 72%);border-radius:var(--br-r);background:radial-gradient(ellipse 85% 55% at 15% -10%,color-mix(in oklab,#fbbf24,transparent 82%),transparent 50%),radial-gradient(ellipse 70% 45% at 100% 0,color-mix(in oklab,#a855f7,transparent 88%),transparent 45%),linear-gradient(168deg,color-mix(in oklab,#0f766e,transparent 88%) 0,color-mix(in oklab,var(--surface),transparent 4%) 38%,color-mix(in oklab,#1e3a5f,transparent 92%) 100%);box-shadow:0 8px 28px color-mix(in oklab,#020617,transparent 86%),inset 0 1px 0 color-mix(in oklab,#fff,transparent 88%)}.v-section--billiard-room .billiard-room-stack{display:flex;flex-direction:column;gap:var(--br-gap)}.v-section--billiard-room .billiard-room-loading{margin:0;padding:.5rem 0;font-size:.95rem;opacity:.86}.v-section--billiard-room .billiard-room-head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.65rem .85rem;padding:.65rem .85rem;border-radius:16px;background:color-mix(in oklab,var(--card),transparent 8%);border:1px solid color-mix(in oklab,#14b8a6,transparent 62%);box-shadow:0 2px 12px color-mix(in oklab,#020617,transparent 92%)}.v-section--billiard-room .billiard-room-head h1{margin:0;font-size:clamp(1.05rem,4.2vw,1.35rem);font-weight:800;letter-spacing:.04em;color:color-mix(in oklab,var(--text),transparent 6%);text-shadow:0 2px 14px color-mix(in oklab,#14b8a6,transparent 55%)}.v-section--billiard-room .billiard-room-head .billiard-penalty-row{margin-top:0}.v-section--billiard-room .billiard-room-surface.tool-card{margin-bottom:0;border-radius:16px;border:1px solid color-mix(in oklab,#2dd4bf,transparent 70%);background:color-mix(in oklab,var(--card),transparent 2%);box-shadow:0 4px 18px color-mix(in oklab,#020617,transparent 90%);padding:clamp(.85rem,3vw,1.05rem)}.v-section--billiard-room .billiard-room-name-card .tool-field{margin-bottom:0}.v-section--billiard-room .billiard-room-name-field{min-width:min(100%,320px);width:100%;flex:1 1}.v-section--billiard-room .billiard-room-name-row{margin-top:0;width:100%}.v-section--billiard-room .billiard-room-name-field input{border-radius:12px;border-color:color-mix(in oklab,#2dd4bf,transparent 58%)}.v-section--billiard-room .billiard-room-error{margin:0;padding:.55rem .65rem;border-radius:12px;background:color-mix(in oklab,#f97316,transparent 88%);border:1px solid color-mix(in oklab,#ea580c,transparent 55%)}.v-section--billiard-room .billiard-status-row{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem .5rem;padding:.6rem .75rem;border-radius:14px;justify-content:flex-start;background:color-mix(in oklab,var(--card),transparent 6%);border:1px dashed color-mix(in oklab,#34d399,transparent 45%);margin:0}.v-section--billiard-room .billiard-status-row .tool-pill{font-size:clamp(.72rem,2.8vw,.82rem);padding:.32rem .55rem;border-color:color-mix(in oklab,#14b8a6,transparent 55%);background:color-mix(in oklab,#14b8a6,transparent 91%)}.v-section--billiard-room .billiard-room-action-row{margin-top:0}.v-section--billiard-room .billiard-room-action-row .action-btn{width:100%;max-width:320px;justify-content:center}.v-section--billiard-room .billiard-room-winner-banner{margin:0;border-radius:14px;border-width:2px;font-weight:600}.v-section--billiard-room .billiard-room-leaderboard-title{margin:0 0 .55rem;font-size:1.02rem;font-weight:800;letter-spacing:.02em;color:color-mix(in oklab,#0d9488,transparent 12%)}.v-section--billiard-room .billiard-leaderboard-list{gap:.5rem}.v-section--billiard-room .billiard-room-lb-row{justify-content:space-between;width:100%;gap:.5rem;border-radius:12px;border-color:color-mix(in oklab,#a855f7,transparent 65%);background:color-mix(in oklab,#a855f7,transparent 92%);padding:.42rem .7rem}.v-section--billiard-room .billiard-room-table{margin:0;overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%;justify-content:center;border-width:2px;border-color:color-mix(in oklab,#22c55e,transparent 42%);background:radial-gradient(ellipse 100% 70% at 50% 35%,color-mix(in oklab,#4ade80,transparent 78%),transparent 55%),radial-gradient(ellipse 80% 90% at 50% 100%,#052e16b8,#0c1f14);box-shadow:inset 0 0 40px color-mix(in oklab,#020617,transparent 55%),0 6px 20px color-mix(in oklab,#020617,transparent 88%)}.v-section--billiard-room .billiard-room-claim-row{display:flex;flex-wrap:wrap;gap:.55rem;margin:0}.v-section--billiard-room .billiard-room-claim-btn{flex:1 1 auto;min-width:min(100%,200px);justify-content:center;border-radius:14px;font-weight:800;letter-spacing:.06em;box-shadow:0 4px 0 color-mix(in oklab,#047857,transparent 35%)}.v-section--billiard-room .billiard-player-list.billiard-room-player-list{margin-top:0;gap:var(--br-gap)}.v-section--billiard-room .billiard-room-player-card .billiard-room-player-title{margin:0 0 .55rem;font-size:clamp(.95rem,3.5vw,1.06rem);font-weight:800;line-height:1.35;flex-wrap:wrap;display:flex;align-items:center;gap:.35rem}.v-section--billiard-room .billiard-room-opponent-pill{margin-left:0}.v-section--billiard-room .billiard-room-player-card .billiard-hand{gap:.45rem;row-gap:.5rem}.v-section--billiard-room .billiard-modal-overlay--room{padding:max(.75rem,env(safe-area-inset-bottom,0));align-items:flex-end}@media (min-width:540px){.v-section--billiard-room .billiard-modal-overlay--room{align-items:center}}.v-section--billiard-room .billiard-modal--room{border-radius:20px;padding:1.35rem 1.15rem;border:2px solid color-mix(in oklab,#fbbf24,transparent 35%);background:linear-gradient(165deg,color-mix(in oklab,var(--card),transparent 0%),color-mix(in oklab,#fbbf24,transparent 90%));box-shadow:0 24px 48px color-mix(in oklab,#020617,transparent 65%)}.v-section--billiard-room .billiard-modal--room h3{font-size:1.2rem;font-weight:900;letter-spacing:.03em;color:color-mix(in oklab,#b45309,transparent 15%)}.v-section--billiard-room .billiard-modal--room p{font-size:1rem}@media (max-width:700px){.v-section--billiard-room .billiard-grid{grid-template-columns:repeat(5,44px);gap:.3rem;padding:.55rem}.v-section--billiard-room .billiard-ball{width:44px;height:44px}.v-section--billiard-room .billiard-ball-svg{width:32px;height:32px}.v-section--billiard-room .billiard-room-head{flex-direction:column;align-items:stretch}.v-section--billiard-room .billiard-room-head .billiard-penalty-row{justify-content:flex-end}.v-section--billiard-room .billiard-room-action-row .action-btn{max-width:none}.v-section--billiard-room .billiard-hand-pill{width:36px;height:36px}.v-section--billiard-room .billiard-hand-pill .billiard-ball-svg{width:28px;height:28px}}.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}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}html{scroll-behavior:auto}.theme-toggle.is-rotating{transform:none}.tools-bento__card,.tools-hub__eyebrow-dot{animation:none}.tools-bento__card:hover{transform:none}}