/* AUTO-GENERATED by scripts/localize-fonts.mjs — self-hosted web fonts. */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/jetbrainsmono-400-cyrillic-ext.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/jetbrainsmono-400-cyrillic.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/jetbrainsmono-400-greek.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/jetbrainsmono-400-vietnamese.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/jetbrainsmono-400-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/jetbrainsmono-400-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/jetbrainsmono-500-cyrillic-ext.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/jetbrainsmono-500-cyrillic.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/jetbrainsmono-500-greek.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/jetbrainsmono-500-vietnamese.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/jetbrainsmono-500-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/jetbrainsmono-500-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(fonts/jetbrainsmono-700-cyrillic-ext.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(fonts/jetbrainsmono-700-cyrillic.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(fonts/jetbrainsmono-700-greek.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(fonts/jetbrainsmono-700-vietnamese.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(fonts/jetbrainsmono-700-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(fonts/jetbrainsmono-700-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/ibmplexsans-400-cyrillic-ext.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/ibmplexsans-400-cyrillic.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/ibmplexsans-400-greek.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/ibmplexsans-400-vietnamese.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/ibmplexsans-400-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/ibmplexsans-400-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/ibmplexsans-500-cyrillic-ext.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/ibmplexsans-500-cyrillic.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/ibmplexsans-500-greek.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/ibmplexsans-500-vietnamese.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/ibmplexsans-500-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/ibmplexsans-500-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/ibmplexsans-600-cyrillic-ext.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/ibmplexsans-600-cyrillic.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/ibmplexsans-600-greek.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/ibmplexsans-600-vietnamese.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/ibmplexsans-600-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 600;
  font-stretch: 100%;
  font-display: swap;
  src: url(fonts/ibmplexsans-600-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ============================================================
   UtilsWorld — stylesheet. Physical left/right replaced with
   logical inline-start/end so RTL (Arabic, Persian) works by
   flipping <html dir>. transform/background-position get explicit
   [dir=rtl] overrides since logical props don't reach them.
   ============================================================ */
:root{
  --bg:#0a0a0b; --surface:#141416; --surface-2:#1b1b1f; --surface-3:#222228;
  --line:#2a2a30; --line-2:#36363d;
  --text:#f3f1ec; --muted:#8c8c94; --faint:#5c5c64;
  --accent:#ff5e1a; --accent-2:#ff8a4d; --accent-dim:rgba(255,94,26,.13);
  --ok:#41d18a; --warn:#ffb020; --err:#ff5b5b;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --sans:'IBM Plex Sans',system-ui,-apple-system,'Segoe UI',Roboto,'Noto Sans',sans-serif;
  --r:4px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%}
html,body{height:100%}
body{
  font-family:var(--sans);background:var(--bg);color:var(--text);
  -webkit-font-smoothing:antialiased;overflow:hidden;
}
body::before{
  content:"";position:fixed;inset:0;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:44px 44px;opacity:.16;pointer-events:none;z-index:0;
}
::selection{background:var(--accent);color:#0a0a0b}
a{color:inherit;text-decoration:none}

.skip-link{position:absolute;inset-inline-start:-999px;top:0;z-index:300;background:var(--accent);color:#0a0a0b;padding:10px 16px;font-family:var(--mono);font-size:12px}
.skip-link:focus{inset-inline-start:0}

.app{position:relative;z-index:1;display:flex;height:100vh;height:100dvh}

/* ---------- brand logo (top-left of the header) ---------- */
.brand{display:flex;align-items:center;gap:9px;text-decoration:none;flex-shrink:0}
.brand .mark{
  width:28px;height:28px;border-radius:7px;background:var(--accent);display:grid;place-items:center;flex-shrink:0;
  box-shadow:0 0 0 1px rgba(255,94,26,.4),0 4px 14px rgba(255,94,26,.25);
}
.brand .name{font-family:var(--mono);font-weight:700;letter-spacing:.5px;font-size:15px;color:var(--text)}
.brand .name b{color:var(--accent)}
.nav-empty{padding:40px 14px;color:var(--faint);font-size:13px;text-align:center;display:none}

/* ---------- main ---------- */
.main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}
.topbar{
  height:58px;flex-shrink:0;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;
  padding:0 26px;background:rgba(20,20,22,.7);backdrop-filter:blur(8px);
  /* own stacking context above .scroll so the language menu overlays the cards */
  position:relative;z-index:50;
}
.topbar .brand{margin-inline-end:6px}
/* breadcrumb lives in the content above the page heading (visible on mobile) */
.crumb{font-family:var(--mono);font-size:14px;color:var(--faint);letter-spacing:.5px;line-height:1.6;margin-bottom:16px}
.crumb a{color:#58a6ff;text-decoration:underline;text-underline-offset:2px;transition:color .12s}
.crumb a:hover{color:#85c0ff}
.crumb b{color:var(--text);font-weight:500}
.topbar .spacer{flex:1}
.badge{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent);border-radius:100px;padding:4px 11px;white-space:nowrap}
@media(max-width:560px){.badge{display:none}}

/* language switcher */
.lang{position:relative}
.lang-btn{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r);color:var(--text);font-family:var(--mono);font-size:12px;padding:7px 11px;cursor:pointer}
.lang-btn:hover{border-color:var(--line-2)}
.lang-btn .flag{font-size:15px;line-height:1}
.lang-btn .chev{color:var(--faint);transition:transform .15s}
.lang-btn[aria-expanded=true] .chev{transform:rotate(180deg)}
.lang-menu{
  position:absolute;inset-inline-end:0;top:calc(100% + 8px);background:var(--surface);border:1px solid var(--line-2);
  border-radius:6px;padding:8px;display:none;grid-template-columns:repeat(2,minmax(148px,1fr));gap:8px;z-index:60;
  max-width:min(92vw,360px);box-shadow:0 16px 40px rgba(0,0,0,.55);max-height:64vh;overflow:auto;
}
.lang-menu.open{display:grid}
.lang-menu a{
  display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r);
  background:var(--surface-2);color:var(--muted);font-family:var(--mono);font-size:12.5px;white-space:nowrap;
  transition:border-color .12s,color .12s,background .12s,transform .1s;
}
.lang-menu a .flag{font-size:18px;line-height:1;flex-shrink:0}
.lang-menu a:hover{border-color:var(--accent);color:var(--text);background:var(--surface-3);transform:translateY(-1px)}
.lang-menu a.cur{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}
.lang-menu::-webkit-scrollbar{width:8px}
.lang-menu::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px}
@media(max-width:430px){.lang-menu{grid-template-columns:1fr}}

.scroll{flex:1;overflow-y:auto;padding:34px 26px 60px}
.scroll::-webkit-scrollbar{width:10px}
.scroll::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:10px}

/* ---------- home ---------- */
.home-head{max-width:1040px;margin:0 auto 34px}
.home-head h1{font-family:var(--mono);font-size:30px;font-weight:700;letter-spacing:-.5px;line-height:1.1}
.home-head h1 span{color:var(--accent)}
.home-head p{color:var(--muted);margin-top:12px;font-size:15px;max-width:560px;line-height:1.55}
.home-head .stat{font-family:var(--mono);font-size:11px;color:var(--faint);letter-spacing:1px;margin-top:16px}

/* search box — used on the home (hero) and on category pages.
   `.home-search input[type=text]` (0,2,1) outranks the generic input[type=text]
   rule below, so the icon's inline-start gap isn't clobbered. */
/* full-width: the search box matches the width of the card grid below it (which
   fills the same container), so it spans exactly the cards-per-row at any size */
.home-search{position:relative;margin:22px 0 4px}
.home-search svg{position:absolute;inset-inline-start:16px;top:50%;transform:translateY(-50%);color:var(--faint);pointer-events:none}
.home-search input[type=text]{
  width:100%;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);color:var(--text);
  font-family:var(--mono);font-size:14px;padding:14px 16px;padding-inline-start:44px;transition:border-color .15s,box-shadow .15s;
}
.home-search input::placeholder{color:var(--faint)}
.home-search input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}

/* ---------- browse by category (home) ---------- */
.browse-title{max-width:1040px;margin:4px auto 16px;font-family:var(--mono);font-size:12px;letter-spacing:2.5px;text-transform:uppercase;color:var(--faint)}
/* a grid of category cards: icon + name + tool count, links to the category page */
.cat-grid{max-width:1040px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(158px,1fr));gap:14px}
.cat-card{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;text-align:center;
  padding:26px 14px;min-height:152px;text-decoration:none;
  background:var(--surface);border:1px solid var(--line);border-radius:13px;
  transition:border-color .15s,background .15s,transform .12s,box-shadow .15s;
}
.cat-card:hover{border-color:var(--accent);background:var(--surface-2);transform:translateY(-3px);box-shadow:0 10px 26px rgba(0,0,0,.35)}
.cat-ico{font-size:30px;line-height:1}
.cat-nm{font-weight:700;font-size:15.5px;color:var(--text);line-height:1.25}
.cat-ct{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent)}

/* tool grids: home search results (hidden until you search) + category lazy grid */
.tool-results{display:none;max-width:1040px;margin:0 auto}
.tool-results.show{display:block}
.tools{max-width:1040px;margin:0 auto}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(218px,1fr));gap:14px}
.lazy:not(.expanded):not(.searching) .card-extra{display:none}  /* lazy load: rest hidden until "show all" or search */
.card.hide{display:none}
.grid-more{max-width:1040px;margin:18px auto 0;text-align:center}
.cat-search{margin:6px 0 22px}
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:6px;padding:18px;cursor:pointer;
  position:relative;overflow:hidden;transition:border-color .15s,transform .15s,background .15s;display:block;
  content-visibility:auto;contain-intrinsic-size:auto 188px;
}
.card::after{content:"";position:absolute;top:0;inset-inline-start:0;width:3px;height:0;background:var(--accent);transition:height .2s}
.card:hover{border-color:var(--line-2);background:var(--surface-2);transform:translateY(-2px)}
.card:hover::after{height:100%}
.card .glyph{
  width:38px;height:38px;border-radius:var(--r);background:var(--surface-3);border:1px solid var(--line);
  display:grid;place-items:center;margin-bottom:14px;font-family:var(--mono);font-size:15px;font-weight:500;color:var(--accent);
  transition:background .15s,color .15s;
}
.card:hover .glyph{background:var(--accent);color:#0a0a0b;border-color:var(--accent)}
.card h3{font-size:14.5px;font-weight:600;margin-bottom:5px}
.card p{color:var(--muted);font-size:12.5px;line-height:1.45}
.card .tag{font-family:var(--mono);font-size:9.5px;letter-spacing:1.5px;color:var(--faint);text-transform:uppercase;margin-top:12px;display:block}

/* ---------- tool view ---------- */
.tool{max-width:840px;margin:0 auto}
.tool-head{margin-bottom:24px;display:flex;align-items:flex-start;gap:16px}
.tool-head .glyph{
  width:46px;height:46px;border-radius:6px;flex-shrink:0;background:var(--accent);color:#0a0a0b;border:1px solid var(--accent);
  display:grid;place-items:center;font-family:var(--mono);font-size:18px;font-weight:600;box-shadow:0 8px 22px rgba(255,94,26,.22);
}
.tool-head h1{font-family:var(--mono);font-size:21px;font-weight:700;letter-spacing:-.3px}
.tool-head p{color:var(--muted);font-size:13.5px;margin-top:4px;line-height:1.5}
.th-text{flex:1;min-width:0}
/* share + download actions (top-right of the tool header) */
.tool-actions{display:flex;gap:8px;flex-shrink:0;margin-top:2px}
.tool-act{display:inline-flex;align-items:center;gap:6px;background:var(--surface-2);border:1px solid var(--line);color:var(--muted);font-family:var(--mono);font-size:12px;padding:7px 12px;border-radius:var(--r);cursor:pointer;transition:border-color .12s,color .12s}
.tool-act:hover{border-color:var(--accent);color:var(--text)}
.tool-act:disabled{opacity:.5;cursor:progress}
.tool-act svg{width:14px;height:14px;flex-shrink:0}
#dlBtn{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 45%,var(--line))}
#dlBtn:hover{background:var(--accent-dim)}

/* article / SEO content */
.article{max-width:840px;margin:44px auto 0;border-top:1px solid var(--line);padding-top:30px}
.article h2{font-family:var(--mono);font-size:15px;font-weight:600;letter-spacing:.3px;margin:0 0 12px;color:var(--text)}
.article p{color:var(--muted);font-size:14px;line-height:1.65;max-width:680px}
.faq{margin-top:14px;max-width:680px}
.faq details{border:1px solid var(--line);border-radius:var(--r);margin-bottom:8px;background:var(--surface);overflow:hidden}
.faq summary{cursor:pointer;padding:13px 16px;font-size:13.5px;font-weight:500;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:"+";color:var(--accent);font-family:var(--mono);margin-inline-end:10px;font-weight:700}
.faq details[open] summary::before{content:"–"}
.faq details[open] summary{border-bottom:1px solid var(--line)}
.faq .ans{padding:13px 16px;color:var(--muted);font-size:13.5px;line-height:1.6}
.related{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.related a{font-family:var(--mono);font-size:12px;padding:7px 12px;border:1px solid var(--line);border-radius:var(--r);color:var(--muted);background:var(--surface)}
.related a:hover{border-color:var(--accent);color:var(--accent)}

.foot{max-width:840px;margin:46px auto 0;border-top:1px solid var(--line);padding-top:22px;color:var(--faint);font-family:var(--mono);font-size:11.5px;line-height:1.7}
.foot .langs{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.foot .langs a{display:inline-flex;align-items:center;gap:6px;color:var(--muted);border:1px solid var(--line);padding:4px 10px;border-radius:var(--r);transition:.12s}
.foot .langs a .flag{font-size:13px}
.foot .langs a:hover{color:var(--accent);border-color:var(--accent)}
.foot .langs a.cur{color:var(--accent);border-color:var(--accent)}
.foot-legal{margin-top:14px;color:var(--faint)}
.foot-legal a{color:var(--muted)}
.foot-legal a:hover{color:var(--accent)}

/* ---------- static legal pages ---------- */
.legal{max-width:760px;margin:0 auto}
.legal h1{font-family:var(--mono);font-size:24px;font-weight:700;letter-spacing:-.3px;margin-bottom:6px}
.legal .legal-meta{color:var(--faint);font-family:var(--mono);font-size:12px;margin-bottom:22px}
.legal h2{font-family:var(--mono);font-size:15px;font-weight:600;color:var(--text);margin:26px 0 10px}
.legal p{color:var(--muted);font-size:14px;line-height:1.7;margin-bottom:10px}
.legal ul{color:var(--muted);font-size:14px;line-height:1.7;margin:0 0 12px;padding-inline-start:22px}
.legal li{margin-bottom:6px}
.legal a{color:var(--accent)}
.legal strong{color:var(--text)}
.legal code{font-family:var(--mono);background:var(--surface-3);padding:1px 6px;border-radius:3px;font-size:12.5px}

/* ---------- shared form bits ---------- */
label.fld{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--faint);margin-bottom:8px}
textarea,input[type=text],input[type=number],input[type=color],select{
  width:100%;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);color:var(--text);
  font-family:var(--mono);font-size:13px;padding:12px 14px;transition:border-color .15s,box-shadow .15s;resize:vertical;line-height:1.6;
}
textarea{min-height:130px}
textarea:focus,input:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}
select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%238c8c94' viewBox='0 0 16 16'%3E%3Cpath d='M8 11 3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-inline-end:36px}
[dir=rtl] select{background-position:left 14px center;padding-inline-end:14px;padding-inline-start:36px}
.row{display:flex;gap:14px;flex-wrap:wrap}
.row > *{flex:1;min-width:140px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:680px){.grid2{grid-template-columns:1fr}}

.btn{
  font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.3px;background:var(--surface-2);color:var(--text);
  border:1px solid var(--line);border-radius:var(--r);padding:9px 14px;cursor:pointer;transition:background .12s,border-color .12s,transform .08s;
}
.btn:hover{background:var(--surface-3);border-color:var(--line-2)}
.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--accent);color:#0a0a0b;border-color:var(--accent);font-weight:700}
.btn.primary:hover{background:var(--accent-2)}
.btn.sm{padding:6px 10px;font-size:11px}
.btn-row{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0}

.out{background:var(--bg);border:1px solid var(--line);border-radius:var(--r);padding:14px;font-family:var(--mono);font-size:13px;white-space:pre-wrap;word-break:break-word;line-height:1.65;min-height:54px;position:relative}
.out.empty{color:var(--faint)}
.copy-btn{position:absolute;top:8px;inset-inline-end:8px}
#md-prev{white-space:normal}
#md-prev h1,#md-prev h2,#md-prev h3{font-family:var(--sans);margin:.4em 0}
#md-prev ul,#md-prev ol{padding-inline-start:22px}
#md-prev blockquote{border-inline-start:3px solid var(--accent);padding-inline-start:12px;color:var(--muted)}
#md-prev code{background:var(--surface-3);padding:1px 5px;border-radius:3px}
mark{background:var(--accent);color:#0a0a0b;border-radius:2px}

.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px;margin-top:16px}
.stat-box{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:14px}
.stat-box .v{font-family:var(--mono);font-size:24px;font-weight:700;color:var(--accent);line-height:1}
.stat-box .k{font-family:var(--mono);font-size:10px;letter-spacing:1px;color:var(--faint);text-transform:uppercase;margin-top:8px}

.check{display:flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12.5px;color:var(--muted);cursor:pointer;user-select:none;padding:7px 0}
.check input{appearance:none;width:18px;height:18px;border:1px solid var(--line-2);border-radius:3px;background:var(--surface);cursor:pointer;position:relative;flex-shrink:0;transition:.12s}
.check input:checked{background:var(--accent);border-color:var(--accent)}
.check input:checked::after{content:"✓";position:absolute;inset:0;display:grid;place-items:center;color:#0a0a0b;font-size:12px;font-weight:700}

input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:5px;background:var(--surface-3);border-radius:5px;outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--accent);cursor:pointer;box-shadow:0 0 0 4px var(--accent-dim)}
input[type=range]::-moz-range-thumb{width:18px;height:18px;border:none;border-radius:50%;background:var(--accent);cursor:pointer}

.note{font-family:var(--mono);font-size:11.5px;color:var(--faint);margin-top:10px;line-height:1.5}
.err-msg{color:var(--err);font-family:var(--mono);font-size:12.5px;margin-top:10px}
.ok-msg{color:var(--ok);font-family:var(--mono);font-size:12.5px;margin-top:10px}

.diff-line{font-family:var(--mono);font-size:12.5px;padding:2px 10px;white-space:pre-wrap;word-break:break-word}
.diff-line.add{background:rgba(65,209,138,.12);color:#9be9c2;border-inline-start:3px solid var(--ok)}
.diff-line.del{background:rgba(255,91,91,.1);color:#ffb3b3;border-inline-start:3px solid var(--err)}
.diff-line.eq{color:var(--muted);border-inline-start:3px solid transparent}

.drop{border:1px dashed var(--line-2);border-radius:6px;padding:30px;text-align:center;color:var(--muted);cursor:pointer;transition:.15s;font-size:13px}
.drop:hover,.drop.over{border-color:var(--accent);background:var(--accent-dim);color:var(--text)}
/* PDF tools: queued-file list + hints */
.muted-msg{color:var(--muted);font-family:var(--mono);font-size:12.5px;margin-top:10px}
.hint{color:var(--faint);font-size:11.5px;margin-top:5px}
.pdf-list{margin-top:12px;display:flex;flex-direction:column;gap:6px}
.pdf-list:empty{display:none}
.pdf-item{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:9px 12px}
.pdf-name{flex:1;min-width:0;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pdf-ops{display:flex;gap:4px;flex-shrink:0}
.pdf-ops button{background:var(--surface-2);border:1px solid var(--line);color:var(--muted);border-radius:5px;width:26px;height:26px;cursor:pointer;font-size:13px;line-height:1;transition:border-color .12s,color .12s}
.pdf-ops button:hover{border-color:var(--accent);color:var(--text)}
/* progress bar (OCR + other long tasks) */
.prog{height:7px;background:var(--surface-3);border:1px solid var(--line);border-radius:100px;overflow:hidden}
.prog-bar{height:100%;width:0;background:var(--accent);transition:width .2s}
.img-preview{max-width:100%;border:1px solid var(--line);border-radius:var(--r);margin-top:14px;display:block}
#q-out{margin-top:18px;display:inline-block;padding:14px;background:#fff;border-radius:6px}

.toast{
  position:fixed;bottom:26px;inset-inline-start:50%;transform:translateX(-50%) translateY(20px);
  background:var(--accent);color:#0a0a0b;font-family:var(--mono);font-size:12.5px;font-weight:600;
  padding:11px 20px;border-radius:var(--r);box-shadow:0 10px 30px rgba(0,0,0,.4);opacity:0;pointer-events:none;transition:.25s;z-index:200;letter-spacing:.3px;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* language suggestion banner */
.lang-banner{
  position:fixed;inset-block-end:0;inset-inline:0;z-index:120;background:var(--surface-2);border-top:1px solid var(--line-2);
  display:none;align-items:center;gap:14px;flex-wrap:wrap;padding:12px 20px;padding-bottom:max(12px,env(safe-area-inset-bottom));
  font-family:var(--mono);font-size:13px;box-shadow:0 -8px 30px rgba(0,0,0,.4);
}
.lang-banner.show{display:flex}
.lang-banner .grow{flex:1}
.lang-banner .btn{white-space:nowrap}

/* ---- tablet / mobile: tighten the shell + roomier tap targets ---- */
@media(max-width:860px){
  .topbar{padding:0 16px;gap:10px}
  .scroll{padding:26px 18px 60px}
  .home-head h1{font-size:25px}
  .btn{padding:11px 15px}
  .btn.sm{padding:8px 11px}
  .check{padding:9px 0}
  .pill{padding:7px 12px}
}
/* ---- phones: trim the topbar, scale the hero, tighten category cards ---- */
@media(max-width:600px){
  .lang-btn .lname{display:none}        /* keep just the flag + chevron */
  .lang-btn{padding:8px 10px}
  .tool-head{gap:12px}
  .tool-head .glyph{width:40px;height:40px;font-size:16px}
  .tool-head h1{font-size:18px}
  .tool-act{padding:8px 10px}
  .tool-act .lbl{display:none}          /* icons only on phones */
  .article,.foot,.tool,.home-head,.browse-title,.cat-grid,.tool-results,.tools,.grid-more{max-width:100%}
  .cat-grid{grid-template-columns:repeat(auto-fill,minmax(142px,1fr));gap:11px}
  .cat-card{min-height:126px;padding:20px 12px;gap:8px}
  .cat-ico{font-size:26px}
  .cat-nm{font-size:14.5px}
  .grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:11px}
}
@media(max-width:480px){
  .home-head h1{font-size:21px}
  .home-head p{font-size:14px}
  .home-search input{font-size:13px}
  .scroll{padding:22px 14px 64px}
  .stats{grid-template-columns:1fr 1fr}
  .lang-menu{inset-inline-end:0;max-width:min(94vw,340px)}
  .grid{grid-template-columns:1fr 1fr}     /* two compact tool cards per row */
  .card{padding:13px}
  .card p{display:none}                     /* keep phone cards compact: name + glyph */
}
