/* FoundSchool 2.0 — mobile-first design system */
:root {
  color-scheme: light;
  --primary: #0b57d0;
  --primary-strong: #0842a0;
  --primary-soft: #e8f0fe;
  --accent: #7c3aed;
  --accent-strong: #5b21b6;
  --profile-glow-1: rgba(124,58,237,.16);
  --profile-glow-2: rgba(11,87,208,.18);
  --profile-focus: rgba(11,87,208,.28);
  --success: #0b8f55;
  --warning: #b45309;
  --danger: #c5221f;
  --ink: #172033;
  --ink-soft: #4d5b73;
  --ink-faint: #718096;
  --surface: #ffffff;
  --surface-2: #f6f8fc;
  --surface-3: #eef2f8;
  --line: #dbe2ec;
  --line-strong: #c5cfdd;
  --shadow-1: 0 1px 2px rgba(20, 35, 60, .06), 0 4px 14px rgba(20, 35, 60, .05);
  --shadow-2: 0 12px 32px rgba(20, 35, 60, .10);
  --shadow-3: 0 24px 64px rgba(20, 35, 60, .16);
  --radius-sm: 10px;
  --radius-md: 16px;
  --radius-lg: 24px;
  --radius-xl: 32px;
  --container: 1180px;
  --header-h: 72px;
  --font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  --font-ar: "Segoe UI", Tahoma, Arial, sans-serif;
  /* Legacy aliases retained for older content/account pages */
  --text: var(--ink);
  --text-muted: var(--ink-soft);
  --text-light: var(--ink-faint);
  --border: var(--line);
  --bg: var(--surface);
  --bg-2: var(--surface-2);
  --bg-3: var(--surface-3);
  --primary-light: var(--primary-soft);
}


/* Language theme profiles — the complete interface changes with the selected language. */
html[data-language-profile="en"] { --primary:#0b57d0; --primary-strong:#0842a0; --primary-soft:#e8f0fe; --accent:#7c3aed; --accent-strong:#5b21b6; --profile-glow-1:rgba(124,58,237,.16); --profile-glow-2:rgba(11,87,208,.18); --profile-focus:rgba(11,87,208,.28); }
html[data-language-profile="ar"] { --primary:#0f766e; --primary-strong:#115e59; --primary-soft:#e6f6f3; --accent:#d97706; --accent-strong:#b45309; --profile-glow-1:rgba(217,119,6,.16); --profile-glow-2:rgba(15,118,110,.18); --profile-focus:rgba(15,118,110,.28); }
html[data-language-profile="pt"] { --primary:#047857; --primary-strong:#065f46; --primary-soft:#e8f7ef; --accent:#dc2626; --accent-strong:#b91c1c; --profile-glow-1:rgba(220,38,38,.14); --profile-glow-2:rgba(4,120,87,.18); --profile-focus:rgba(4,120,87,.28); }
html[data-language-profile="es"] { --primary:#c2410c; --primary-strong:#9a3412; --primary-soft:#fff0e8; --accent:#eab308; --accent-strong:#ca8a04; --profile-glow-1:rgba(234,179,8,.16); --profile-glow-2:rgba(194,65,12,.17); --profile-focus:rgba(194,65,12,.28); }
html[data-language-profile="fr"] { --primary:#1d4ed8; --primary-strong:#1e40af; --primary-soft:#eaf0ff; --accent:#e11d48; --accent-strong:#be123c; --profile-glow-1:rgba(225,29,72,.14); --profile-glow-2:rgba(29,78,216,.18); --profile-focus:rgba(29,78,216,.28); }
html[data-language-profile="ru"] { --primary:#2563eb; --primary-strong:#1d4ed8; --primary-soft:#eaf1ff; --accent:#dc2626; --accent-strong:#b91c1c; --profile-glow-1:rgba(220,38,38,.14); --profile-glow-2:rgba(37,99,235,.18); --profile-focus:rgba(37,99,235,.28); }
html[data-language-profile="it"] { --primary:#15803d; --primary-strong:#166534; --primary-soft:#e9f8ee; --accent:#dc2626; --accent-strong:#b91c1c; --profile-glow-1:rgba(220,38,38,.13); --profile-glow-2:rgba(21,128,61,.18); --profile-focus:rgba(21,128,61,.28); }
html[data-language-profile="pl"] { --primary:#be123c; --primary-strong:#9f1239; --primary-soft:#fff0f3; --accent:#64748b; --accent-strong:#475569; --profile-glow-1:rgba(100,116,139,.13); --profile-glow-2:rgba(190,18,60,.17); --profile-focus:rgba(190,18,60,.28); }
html[data-language-profile="de"] { --primary:#374151; --primary-strong:#1f2937; --primary-soft:#eef1f5; --accent:#d97706; --accent-strong:#b45309; --profile-glow-1:rgba(217,119,6,.15); --profile-glow-2:rgba(55,65,81,.15); --profile-focus:rgba(55,65,81,.28); }
html[data-language-profile="el"] { --primary:#0369a1; --primary-strong:#075985; --primary-soft:#e7f6fc; --accent:#0ea5e9; --accent-strong:#0284c7; --profile-glow-1:rgba(14,165,233,.15); --profile-glow-2:rgba(3,105,161,.18); --profile-focus:rgba(3,105,161,.28); }
html[data-language-profile="tr"] { --primary:#b91c1c; --primary-strong:#991b1b; --primary-soft:#fff0f0; --accent:#0f766e; --accent-strong:#115e59; --profile-glow-1:rgba(15,118,110,.14); --profile-glow-2:rgba(185,28,28,.17); --profile-focus:rgba(185,28,28,.28); }
html[data-language-profile="hu"] { --primary:#166534; --primary-strong:#14532d; --primary-soft:#eaf7ed; --accent:#dc2626; --accent-strong:#b91c1c; --profile-glow-1:rgba(220,38,38,.13); --profile-glow-2:rgba(22,101,52,.18); --profile-focus:rgba(22,101,52,.28); }
html[data-language-profile="uk"] { --primary:#1d4ed8; --primary-strong:#1e40af; --primary-soft:#eaf1ff; --accent:#eab308; --accent-strong:#ca8a04; --profile-glow-1:rgba(234,179,8,.16); --profile-glow-2:rgba(29,78,216,.18); --profile-focus:rgba(29,78,216,.28); }

html[data-theme="dark"][data-language-profile="en"] { --primary:#8ab4f8; --primary-strong:#aecbfa; --primary-soft:#1a3458; --accent:#c4b5fd; --accent-strong:#a78bfa; }
html[data-theme="dark"][data-language-profile="ar"] { --primary:#5eead4; --primary-strong:#99f6e4; --primary-soft:#123d3a; --accent:#fbbf24; --accent-strong:#f59e0b; }
html[data-theme="dark"][data-language-profile="pt"] { --primary:#6ee7b7; --primary-strong:#a7f3d0; --primary-soft:#123b30; --accent:#fca5a5; --accent-strong:#f87171; }
html[data-theme="dark"][data-language-profile="es"] { --primary:#fdba74; --primary-strong:#fed7aa; --primary-soft:#4a2516; --accent:#fde047; --accent-strong:#facc15; }
html[data-theme="dark"][data-language-profile="fr"] { --primary:#93c5fd; --primary-strong:#bfdbfe; --primary-soft:#172f62; --accent:#fda4af; --accent-strong:#fb7185; }
html[data-theme="dark"][data-language-profile="ru"] { --primary:#93c5fd; --primary-strong:#bfdbfe; --primary-soft:#183768; --accent:#fca5a5; --accent-strong:#f87171; }
html[data-theme="dark"][data-language-profile="it"] { --primary:#86efac; --primary-strong:#bbf7d0; --primary-soft:#173e26; --accent:#fca5a5; --accent-strong:#f87171; }
html[data-theme="dark"][data-language-profile="pl"] { --primary:#fda4af; --primary-strong:#fecdd3; --primary-soft:#4b1b2a; --accent:#cbd5e1; --accent-strong:#94a3b8; }
html[data-theme="dark"][data-language-profile="de"] { --primary:#d1d5db; --primary-strong:#f3f4f6; --primary-soft:#303744; --accent:#fbbf24; --accent-strong:#f59e0b; }
html[data-theme="dark"][data-language-profile="el"] { --primary:#7dd3fc; --primary-strong:#bae6fd; --primary-soft:#123b52; --accent:#38bdf8; --accent-strong:#0ea5e9; }
html[data-theme="dark"][data-language-profile="tr"] { --primary:#fca5a5; --primary-strong:#fecaca; --primary-soft:#4b1f1f; --accent:#5eead4; --accent-strong:#2dd4bf; }
html[data-theme="dark"][data-language-profile="hu"] { --primary:#86efac; --primary-strong:#bbf7d0; --primary-soft:#173d25; --accent:#fca5a5; --accent-strong:#f87171; }
html[data-theme="dark"][data-language-profile="uk"] { --primary:#93c5fd; --primary-strong:#bfdbfe; --primary-soft:#173264; --accent:#fde047; --accent-strong:#facc15; }

[data-theme="dark"] {
  color-scheme: dark;
  --primary: #8ab4f8;
  --primary-strong: #aecbfa;
  --primary-soft: #1a3458;
  --accent: #c4b5fd;
  --accent-strong: #a78bfa;
  --success: #5ee0a0;
  --warning: #f8b66d;
  --danger: #ff8a80;
  --ink: #edf2fb;
  --ink-soft: #bdc8da;
  --ink-faint: #8e9bb0;
  --surface: #101722;
  --surface-2: #151f2d;
  --surface-3: #1d2939;
  --line: #2b394d;
  --line-strong: #40516a;
  --shadow-1: 0 1px 2px rgba(0,0,0,.30), 0 6px 20px rgba(0,0,0,.18);
  --shadow-2: 0 16px 38px rgba(0,0,0,.28);
  --shadow-3: 0 24px 70px rgba(0,0,0,.38);
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: calc(var(--header-h) + 18px); }
body {
  margin: 0;
  min-height: 100vh;
  background: var(--surface);
  color: var(--ink);
  font: 15px/1.65 var(--font);
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}
body.rtl, [dir="rtl"] { font-family: var(--font-ar); }
body.sheet-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
button { color: inherit; }
img, svg { display: block; max-width: 100%; }
svg { fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
::selection { color: #fff; background: var(--primary); }
:focus-visible { outline: 3px solid var(--profile-focus); outline-offset: 3px; }
[hidden] { display: none !important; }

.container { width: min(100% - 40px, var(--container)); margin-inline: auto; }
.skip-link {
  position: fixed; inset-inline-start: 16px; top: 10px; z-index: 9999;
  transform: translateY(-150%); padding: 10px 16px; border-radius: 12px;
  color: #fff; background: var(--primary); font-weight: 750;
}
.skip-link:focus { transform: translateY(0); }

/* Header */
.app-header {
  position: sticky; top: 0; z-index: 800;
  height: var(--header-h); border-bottom: 1px solid rgba(197, 207, 221, .78);
  background: rgba(255,255,255,.88); backdrop-filter: blur(18px) saturate(160%);
}
[data-theme="dark"] .app-header { background: rgba(16, 23, 34, .88); border-color: rgba(64,81,106,.72); }
.app-header__inner { height: 100%; display: flex; align-items: center; gap: 22px; }
.brand { display: inline-flex; align-items: center; gap: 11px; flex: 0 0 auto; }
.brand-mark {
  display: grid; grid-template-columns: 1fr 1fr; width: 40px; height: 40px;
  overflow: hidden; border-radius: 13px; color: #fff; box-shadow: 0 8px 22px color-mix(in srgb, var(--primary) 28%, transparent);
}
.brand-mark span { display: grid; place-items: center; font-size: 14px; font-weight: 900; }
.brand-mark span:first-child { background: var(--primary); }
.brand-mark span:last-child { background: linear-gradient(145deg, var(--accent), var(--accent-strong)); }
.brand-copy { display: flex; flex-direction: column; line-height: 1.15; }
.brand-copy strong { font-size: 16px; letter-spacing: -.02em; }
.brand-copy small { margin-top: 4px; color: var(--ink-faint); font-size: 11px; white-space: nowrap; }
.header-search {
  display: flex; align-items: center; gap: 10px; width: min(300px, 28vw); min-height: 42px;
  padding: 0 12px; border: 1px solid var(--line); border-radius: 14px;
  color: var(--ink-faint); background: var(--surface-2); cursor: pointer; text-align: start;
  transition: border-color .2s ease, background .2s ease, box-shadow .2s ease;
}
.header-search:hover { border-color: var(--primary); background: var(--surface); box-shadow: var(--shadow-1); }
.header-search svg { width: 19px; height: 19px; flex: 0 0 auto; }
.header-search span { overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
kbd { margin-inline-start: auto; padding: 2px 7px; border: 1px solid var(--line); border-bottom-width: 2px; border-radius: 7px; color: var(--ink-faint); background: var(--surface); font-size: 10px; }
.desktop-nav { display: flex; align-items: center; gap: 3px; flex: 1; }
.nav-group { position: relative; }
.nav-trigger {
  display: flex; align-items: center; gap: 5px; min-height: 42px; padding: 0 10px;
  border: 0; border-radius: 11px; color: var(--ink-soft); background: transparent; cursor: pointer; font-weight: 650;
}
.nav-trigger:hover, .nav-group:focus-within .nav-trigger { color: var(--primary); background: var(--primary-soft); }
.nav-trigger svg { width: 15px; height: 15px; transition: transform .2s ease; }
.nav-group:focus-within .nav-trigger svg { transform: rotate(180deg); }
.nav-menu {
  position: absolute; top: calc(100% + 10px); inset-inline-start: 0; width: 300px; padding: 10px;
  opacity: 0; visibility: hidden; transform: translateY(-8px); border: 1px solid var(--line);
  border-radius: 18px; background: var(--surface); box-shadow: var(--shadow-3); transition: .18s ease;
}
.nav-group:hover .nav-menu, .nav-group:focus-within .nav-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.nav-menu__item { display: flex; align-items: center; gap: 10px; padding: 9px; border-radius: 11px; color: var(--ink-soft); font-size: 13px; font-weight: 650; }
.nav-menu__item:hover, .nav-menu__item.is-active { color: var(--primary); background: var(--primary-soft); }
.mini-icon, .tool-icon {
  display: grid; place-items: center; flex: 0 0 auto; overflow: hidden;
  color: var(--tool-color, var(--primary)); background: color-mix(in srgb, var(--tool-color, var(--primary)) 12%, transparent);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-weight: 800;
}
.mini-icon { width: 32px; height: 32px; border-radius: 9px; font-size: 10px; }
.nav-menu__all { display: flex; justify-content: space-between; margin-top: 6px; padding: 10px 12px; border-top: 1px solid var(--line); color: var(--primary); font-size: 12px; font-weight: 800; }
.header-actions { display: flex; align-items: center; gap: 8px; }
.icon-button, .language-button, .account-button {
  display: grid; place-items: center; min-width: 40px; height: 40px; padding: 0 10px;
  border: 1px solid var(--line); border-radius: 12px; background: var(--surface); cursor: pointer;
}
.icon-button:hover, .language-button:hover { color: var(--primary); border-color: var(--primary); }
.icon-button svg { width: 20px; height: 20px; }
.language-picker { position: relative; }
.language-button { display: flex; gap: 4px; font-size: 12px; font-weight: 800; }
.language-button svg { width: 14px; height: 14px; }
.language-menu {
  position: absolute; top: calc(100% + 9px); inset-inline-end: 0; width: 230px; max-height: 380px; padding: 8px;
  overflow: auto; opacity: 0; visibility: hidden; transform: translateY(-7px);
  border: 1px solid var(--line); border-radius: 16px; background: var(--surface); box-shadow: var(--shadow-3); transition: .18s ease;
}
.language-picker:hover .language-menu, .language-picker:focus-within .language-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.language-menu a { display: flex; align-items: center; gap: 9px; padding: 9px 10px; border-radius: 9px; color: var(--ink-soft); font-size: 13px; }
.language-menu a:hover, .language-menu a.is-current { color: var(--primary); background: var(--primary-soft); }
.account-button { width: 40px; padding: 0; color: #fff; border: 0; background: var(--primary); font-weight: 850; }
.desktop-signin { padding: 9px 12px; color: var(--primary); font-weight: 800; font-size: 13px; }

/* Home hero */
.home-hero {
  position: relative; overflow: hidden; padding: 78px 0 72px;
  background:
    radial-gradient(circle at 15% 10%, var(--profile-glow-1), transparent 30%),
    radial-gradient(circle at 86% 30%, var(--profile-glow-2), transparent 32%),
    linear-gradient(180deg, #f7faff 0%, #fff 78%);
}
[data-theme="dark"] .home-hero {
  background: radial-gradient(circle at 15% 10%, color-mix(in srgb, var(--accent) 22%, transparent), transparent 30%), radial-gradient(circle at 86% 30%, color-mix(in srgb, var(--primary) 20%, transparent), transparent 32%), linear-gradient(180deg,#111a28 0%,var(--surface) 82%);
}
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(390px, .92fr); align-items: center; gap: 80px; }
.eyebrow, .section-kicker {
  display: inline-flex; align-items: center; gap: 8px; color: var(--primary); font-size: 12px; font-weight: 850; letter-spacing: .04em; text-transform: uppercase;
}
.status-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--success); box-shadow: 0 0 0 5px rgba(11,143,85,.12); }
.hero-copy h1 { max-width: 720px; margin: 18px 0 18px; font-size: clamp(42px, 5vw, 68px); line-height: 1.05; letter-spacing: -.055em; }
.hero-copy > p { max-width: 660px; margin: 0; color: var(--ink-soft); font-size: 18px; line-height: 1.7; }
.hero-search {
  display: flex; align-items: center; gap: 12px; width: min(100%, 650px); min-height: 58px; margin-top: 30px; padding: 0 16px;
  border: 1px solid var(--line); border-radius: 18px; background: var(--surface); color: var(--ink-faint); box-shadow: var(--shadow-2); cursor: text; text-align: start;
}
.hero-search:hover { border-color: var(--primary); }
.hero-search svg { width: 23px; height: 23px; }
.hero-search span { flex: 1; }
.hero-metrics { display: flex; gap: 32px; margin-top: 26px; }
.hero-metrics div { display: flex; align-items: baseline; gap: 6px; }
.hero-metrics strong { color: var(--ink); font-size: 20px; }
.hero-metrics span { color: var(--ink-faint); font-size: 12px; }
.hero-workspace { position: relative; min-height: 430px; display: grid; place-items: center; }
.workspace-window { width: 100%; max-width: 500px; transform: rotate(1.2deg); overflow: hidden; border: 1px solid rgba(255,255,255,.72); border-radius: 26px; background: var(--surface); box-shadow: var(--shadow-3); }
.workspace-topbar { display: flex; align-items: center; gap: 6px; height: 44px; padding: 0 15px; border-bottom: 1px solid var(--line); background: var(--surface-2); }
.workspace-topbar > span { width: 9px; height: 9px; border-radius: 50%; background: #f87171; }
.workspace-topbar > span:nth-child(2) { background: #fbbf24; }
.workspace-topbar > span:nth-child(3) { background: #34d399; }
.workspace-topbar em { margin-inline-start: auto; color: var(--ink-faint); font-size: 11px; font-style: normal; }
.workspace-content { padding: 24px; }
.workspace-label { color: var(--ink-soft); font-size: 12px; font-weight: 800; }
.workspace-lines { display: grid; gap: 10px; margin-top: 15px; padding: 18px; border: 1px solid var(--line); border-radius: 16px; background: var(--surface); }
.workspace-lines i { width: 92%; height: 9px; border-radius: 10px; background: var(--surface-3); }
.workspace-lines i:nth-child(2) { width: 78%; }
.workspace-lines i:nth-child(3) { width: 86%; }
.workspace-lines i:nth-child(4) { width: 58%; }
.workspace-actions { display: flex; align-items: center; justify-content: space-between; margin-top: 14px; }
.workspace-actions b, .workspace-actions span { padding: 10px 16px; border-radius: 11px; font-size: 12px; }
.workspace-actions b { color: #fff; background: var(--primary); }
.workspace-actions span { color: var(--primary); background: var(--primary-soft); }
.workspace-result { display: flex; align-items: center; gap: 11px; margin-top: 18px; padding: 15px; border: 1px solid rgba(11,143,85,.22); border-radius: 16px; background: rgba(11,143,85,.08); }
.workspace-result > span { display: grid; place-items: center; width: 30px; height: 30px; border-radius: 50%; color: #fff; background: var(--success); font-weight: 900; }
.workspace-result div { display: flex; flex-direction: column; }
.workspace-result strong { font-size: 12px; }
.workspace-result small { color: var(--ink-faint); font-size: 10px; }
.floating-chip { position: absolute; display: grid; place-items: center; width: 64px; height: 64px; border-radius: 20px; color: #fff; font-weight: 900; box-shadow: var(--shadow-2); }
.chip-one { inset: 12% auto auto -12px; background: var(--primary); transform: rotate(-9deg); }
.chip-two { inset: auto -10px 16% auto; background: #0b8f55; transform: rotate(8deg); }
.chip-three { inset: auto auto 4% 8%; background: var(--accent); transform: rotate(-5deg); }

.trust-strip { border-block: 1px solid var(--line); background: var(--surface); }
.trust-grid { display: grid; grid-template-columns: repeat(3, 1fr); }
.trust-grid article { display: flex; align-items: center; gap: 14px; padding: 24px 28px; border-inline-end: 1px solid var(--line); }
.trust-grid article:last-child { border-inline-end: 0; }
.feature-icon { display: grid; place-items: center; flex: 0 0 auto; width: 46px; height: 46px; border-radius: 14px; color: var(--primary); background: var(--primary-soft); }
.feature-icon svg { width: 23px; height: 23px; }
.trust-grid h2 { margin: 0; font-size: 14px; }
.trust-grid p { margin: 3px 0 0; color: var(--ink-faint); font-size: 12px; }

.home-section { padding-block: 74px; }
.section-heading { display: flex; align-items: end; justify-content: space-between; gap: 20px; margin-bottom: 24px; }
.section-heading h2 { margin: 6px 0 0; font-size: clamp(27px, 3vw, 40px); line-height: 1.16; letter-spacing: -.035em; }
.section-heading > a { color: var(--primary); font-weight: 800; }
.popular-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.popular-card {
  position: relative; display: flex; flex-direction: column; min-height: 205px; padding: 20px;
  border: 1px solid var(--line); border-radius: 20px; background: var(--surface); box-shadow: var(--shadow-1);
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.popular-card:hover { transform: translateY(-5px); border-color: var(--tool-color); box-shadow: var(--shadow-2); }
.tool-icon { width: 46px; height: 46px; border-radius: 14px; font-size: 11px; }
.popular-card h3, .directory-card h3 { margin: 16px 0 7px; font-size: 15px; line-height: 1.35; }
.popular-card p, .directory-card p { margin: 0; color: var(--ink-faint); font-size: 12px; line-height: 1.55; }
.card-arrow { position: absolute; inset-inline-end: 18px; bottom: 16px; color: var(--tool-color); font-size: 20px; }

.tools-directory { padding: 76px 0 84px; background: var(--surface-2); border-block: 1px solid var(--line); }
.category-chips { display: flex; gap: 8px; margin-bottom: 24px; overflow-x: auto; scrollbar-width: none; }
.category-chips::-webkit-scrollbar { display: none; }
.category-chip { flex: 0 0 auto; padding: 9px 15px; border: 1px solid var(--line); border-radius: 999px; color: var(--ink-soft); background: var(--surface); cursor: pointer; font-size: 12px; font-weight: 750; }
.category-chip:hover, .category-chip.is-active { color: #fff; border-color: var(--primary); background: var(--primary); }
.directory-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.directory-card {
  display: grid; grid-template-columns: auto minmax(0, 1fr) auto; align-items: center; gap: 14px; min-height: 106px; padding: 16px;
  border: 1px solid var(--line); border-radius: 18px; background: var(--surface); transition: .2s ease;
}
.directory-card:hover { transform: translateY(-2px); border-color: var(--tool-color); box-shadow: var(--shadow-1); }
.directory-card h3 { margin: 0 0 4px; }
.directory-card p { display: -webkit-box; overflow: hidden; -webkit-box-orient: vertical; -webkit-line-clamp: 2; }
.directory-card > svg { width: 18px; height: 18px; color: var(--ink-faint); }
.directory-card[hidden] { display: none; }

.seo-section { display: grid; grid-template-columns: 1.15fr .85fr; gap: 70px; padding-block: 82px; }
.seo-copy h2 { max-width: 720px; margin: 8px 0 20px; font-size: clamp(28px, 3.8vw, 46px); line-height: 1.15; letter-spacing: -.04em; }
.seo-copy p { color: var(--ink-soft); font-size: 16px; line-height: 1.8; }
.compact-faq { display: grid; gap: 10px; }
.compact-faq details { border: 1px solid var(--line); border-radius: 16px; background: var(--surface); }
.compact-faq summary { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 17px 18px; cursor: pointer; list-style: none; font-weight: 750; }
.compact-faq summary::-webkit-details-marker { display: none; }
.compact-faq summary span { color: var(--primary); font-size: 20px; transition: transform .2s ease; }
.compact-faq details[open] summary span { transform: rotate(45deg); }
.compact-faq details p { margin: 0; padding: 0 18px 18px; color: var(--ink-soft); font-size: 13px; }

/* Tool pages */
.tool-shell { background: var(--surface-2); }
.tool-shell__top { position: relative; }
.breadcrumb { padding: 15px 0; }
.breadcrumb ol { display: flex; align-items: center; flex-wrap: wrap; gap: 4px; margin: 0; padding: 0; list-style: none; }
.breadcrumb li { display: flex; align-items: center; gap: 5px; color: var(--ink-faint); font-size: 12px; }
.breadcrumb a:hover { color: var(--primary); }
.breadcrumb li:last-child span { color: var(--ink-soft); }
.breadcrumb-sep { color: var(--line-strong); }
[dir="rtl"] .breadcrumb-sep { transform: scaleX(-1); }
.mobile-back { display: none; }
.tool-intro { padding: 22px 0 32px; border-bottom: 1px solid var(--line); background: var(--surface); }
.tool-intro__inner { display: flex; align-items: center; gap: 18px; }
.tool-title-icon { display: grid; place-items: center; flex: 0 0 auto; width: 72px; height: 72px; border-radius: 22px; color: var(--tool-color); background: color-mix(in srgb, var(--tool-color) 12%, var(--surface)); font: 900 13px/1 ui-monospace, monospace; box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--tool-color) 18%, transparent); }
.tool-title-copy { min-width: 0; }
.tool-meta-row { display: flex; align-items: center; gap: 10px; margin-bottom: 6px; color: var(--tool-color); font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em; }
.privacy-badge { display: inline-flex; align-items: center; gap: 6px; color: var(--success); }
.privacy-badge i { width: 6px; height: 6px; border-radius: 50%; background: var(--success); }
.tool-intro h1 { margin: 0; font-size: clamp(28px, 4vw, 46px); line-height: 1.12; letter-spacing: -.04em; }
.tool-intro p { max-width: 760px; margin: 9px 0 0; color: var(--ink-soft); font-size: 15px; }
.tool-layout { display: grid; grid-template-columns: minmax(0, 1fr) 280px; gap: 24px; padding-block: 30px 54px; }
.tool-workspace { min-width: 0; }
.workspace-panel { overflow: hidden; border: 1px solid var(--line); border-radius: 22px; background: var(--surface); box-shadow: var(--shadow-1); }
.workspace-panel__header { display: flex; align-items: center; justify-content: space-between; gap: 18px; min-height: 58px; padding: 10px 16px; border-bottom: 1px solid var(--line); background: var(--surface); }
.workspace-panel__header > div:first-child { display: flex; align-items: center; gap: 9px; }
.workspace-panel__header h2 { margin: 0; font-size: 14px; }
.panel-step { display: grid; place-items: center; width: 25px; height: 25px; border-radius: 8px; color: var(--tool-color); background: color-mix(in srgb, var(--tool-color) 12%, var(--surface)); font-size: 11px; font-weight: 900; }
.panel-actions { display: flex; align-items: center; gap: 6px; }
.text-button, .icon-text-button { display: inline-flex; align-items: center; gap: 6px; min-height: 34px; padding: 0 9px; border: 0; border-radius: 9px; color: var(--primary); background: transparent; cursor: pointer; font-size: 12px; font-weight: 750; }
.text-button:hover, .icon-text-button:hover { background: var(--primary-soft); }
.danger-text { color: var(--danger); }
.icon-text-button svg { width: 16px; height: 16px; }
.workspace-textarea { display: block; width: 100%; min-height: 210px; padding: 18px; resize: vertical; border: 0; outline: 0; color: var(--ink); background: var(--surface); font: 15px/1.75 var(--font); }
body.rtl .workspace-textarea { font-family: var(--font-ar); }
.workspace-textarea::placeholder { color: var(--ink-faint); }
.workspace-textarea:focus { background: color-mix(in srgb, var(--primary) 2%, var(--surface)); }
.secondary-input-wrap { border-top: 1px solid var(--line); }
.secondary-input-wrap > label { display: block; padding: 10px 18px 0; color: var(--ink-soft); font-size: 12px; font-weight: 800; }
.secondary-textarea { min-height: 170px; }
.option-grid { display: grid; gap: 12px; padding: 14px 16px; border-top: 1px solid var(--line); background: var(--surface-2); }
.option-grid.two-cols { grid-template-columns: repeat(2, 1fr); }
.option-grid label { display: grid; gap: 6px; color: var(--ink-soft); font-size: 11px; font-weight: 750; }
.option-grid input, .option-grid select { width: 100%; height: 42px; padding: 0 12px; border: 1px solid var(--line); border-radius: 11px; color: var(--ink); background: var(--surface); outline: 0; }
.option-grid input:focus, .option-grid select:focus { border-color: var(--primary); box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 14%, transparent); }
.live-stats { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); background: var(--surface-2); }
.live-stats div { display: flex; align-items: baseline; justify-content: center; gap: 5px; padding: 10px 8px; border-inline-end: 1px solid var(--line); }
.live-stats div:last-child { border-inline-end: 0; }
.live-stats strong { font-size: 14px; }
.live-stats span { color: var(--ink-faint); font-size: 10px; }
.tool-actionbar { display: flex; align-items: center; justify-content: center; gap: 10px; padding: 16px 0; }
.primary-action { display: inline-flex; align-items: center; justify-content: center; gap: 8px; min-width: 170px; min-height: 48px; padding: 0 20px; border: 1px solid var(--primary); border-radius: 14px; color: #fff; background: linear-gradient(135deg, var(--primary), var(--accent)); box-shadow: 0 8px 20px color-mix(in srgb, var(--primary) 24%, transparent); cursor: pointer; font-weight: 850; }
.primary-action:hover { filter: brightness(.94); transform: translateY(-1px); }
.primary-action:active { transform: translateY(1px) scale(.99); }
.primary-action svg { width: 18px; height: 18px; }
.secondary-action { color: var(--primary); border-color: var(--primary); background: var(--surface); box-shadow: none; }
.output-panel { margin-top: 0; }
.output-textarea { min-height: 210px; background: color-mix(in srgb, var(--tool-color) 2%, var(--surface)); }
.result-status { display: flex; align-items: center; gap: 7px; padding: 10px 16px; border-top: 1px solid rgba(11,143,85,.18); color: var(--success); background: rgba(11,143,85,.07); font-size: 11px; }
.result-status span { display: grid; place-items: center; width: 18px; height: 18px; border-radius: 50%; color: #fff; background: var(--success); font-size: 10px; }
.tool-sidebar { display: grid; align-content: start; gap: 16px; }
.sidebar-card { padding: 19px; border: 1px solid var(--line); border-radius: 18px; background: var(--surface); box-shadow: var(--shadow-1); }
.sidebar-card h2 { margin: 0 0 14px; font-size: 14px; }
.sidebar-card ul { display: grid; gap: 11px; margin: 0; padding: 0; list-style: none; }
.sidebar-card li { display: flex; align-items: start; gap: 8px; color: var(--ink-soft); font-size: 12px; }
.sidebar-card li span { color: var(--success); font-weight: 900; }
.ad-unit { display: grid; place-items: center; min-height: 120px; border: 1px dashed var(--line-strong); border-radius: 16px; color: var(--ink-faint); background: var(--surface-2); font-size: 10px; text-transform: uppercase; letter-spacing: .12em; }
.tool-content { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 18px; padding-bottom: 76px; }
.content-card { padding: 24px; border: 1px solid var(--line); border-radius: 20px; background: var(--surface); }
.content-card h2 { margin: 0 0 14px; font-size: 20px; }
.content-card p { margin: 0 0 12px; color: var(--ink-soft); line-height: 1.8; }
.content-card p:last-child { margin-bottom: 0; }
.related-section { grid-column: 1 / -1; padding-top: 16px; }
.related-grid { grid-template-columns: repeat(4, 1fr); }

/* Generic legacy page support */
.tool-hero { padding: 44px 0 34px; border-bottom: 1px solid var(--line); background: var(--surface-2); }
.tool-hero h1 { margin: 0; font-size: clamp(30px, 4vw, 48px); letter-spacing: -.04em; }
.tool-hero p { max-width: 760px; margin: 10px 0 0; color: var(--ink-soft); }
.tool-page { padding: 34px 0 70px; }
.tools-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.tool-card { display: flex; gap: 12px; padding: 17px; border: 1px solid var(--line); border-radius: 17px; background: var(--surface); box-shadow: var(--shadow-1); }
.tc-icon { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 12px; flex: 0 0 auto; font: 800 10px/1 ui-monospace, monospace; }
.tc-title { font-weight: 750; }
.tc-desc { margin-top: 4px; color: var(--ink-faint); font-size: 12px; }
.card { padding: 22px; border: 1px solid var(--line); border-radius: 18px; background: var(--surface); box-shadow: var(--shadow-1); }
input[type="text"], input[type="email"], input[type="password"], input[type="number"], textarea, select { color: var(--ink); background: var(--surface); }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 7px; min-height: 42px; padding: 0 15px; border: 1px solid transparent; border-radius: 11px; cursor: pointer; font-weight: 750; }
.btn-primary { color: #fff; background: var(--primary); }
.btn-outline { color: var(--primary); border-color: var(--line); background: var(--surface); }
.btn-danger { color: #fff; background: var(--danger); }
.btn-success { color: #fff; background: var(--success); }
.btn-sm { min-height: 34px; padding-inline: 10px; font-size: 12px; }
.badge { display: inline-flex; padding: 4px 9px; border-radius: 999px; background: var(--primary-soft); color: var(--primary); font-size: 11px; font-weight: 800; }

/* Footer */
.site-footer { padding: 60px 0 20px; border-top: 1px solid var(--line); background: var(--surface-2); }
.footer-layout { display: grid; grid-template-columns: 1.5fr repeat(3, 1fr); gap: 56px; }
.footer-brand p { max-width: 340px; margin: 18px 0; color: var(--ink-soft); font-size: 13px; }
.install-button { display: inline-flex; align-items: center; gap: 8px; min-height: 42px; padding: 0 14px; border: 1px solid var(--primary); border-radius: 12px; color: #fff; background: var(--primary); cursor: pointer; font-weight: 800; }
.install-button svg { width: 18px; height: 18px; }
.footer-column { display: flex; flex-direction: column; gap: 9px; }
.footer-column h2 { margin: 0 0 4px; font-size: 13px; }
.footer-column a { color: var(--ink-soft); font-size: 12px; }
.footer-column a:hover { color: var(--primary); }
.footer-bottom { display: flex; justify-content: space-between; gap: 20px; margin-top: 42px; padding-top: 18px; border-top: 1px solid var(--line); color: var(--ink-faint); font-size: 11px; }
.mobile-tabbar, .app-sheet, .sheet-backdrop { display: none; }
.network-status { position: fixed; inset-inline: 50%; bottom: 20px; z-index: 2000; transform: translateX(-50%); padding: 9px 14px; border-radius: 999px; color: #fff; background: var(--danger); box-shadow: var(--shadow-2); font-size: 12px; font-weight: 800; }
.toast { position: fixed; inset-inline-start: 50%; bottom: 24px; z-index: 2200; transform: translate(-50%, 100px); opacity: 0; padding: 11px 17px; border-radius: 999px; color: #fff; background: #182235; box-shadow: var(--shadow-3); font-size: 12px; font-weight: 750; transition: .24s ease; pointer-events: none; }
.toast.show { transform: translate(-50%, 0); opacity: 1; }
[dir="rtl"] .toast { transform: translate(50%, 100px); }
[dir="rtl"] .toast.show { transform: translate(50%, 0); }

@media (max-width: 1100px) {
  .desktop-nav { display: none; }
  .header-search { margin-inline-start: auto; width: min(380px, 45vw); }
  .hero-grid { gap: 45px; }
  .popular-grid { grid-template-columns: repeat(2, 1fr); }
  .directory-grid { grid-template-columns: repeat(2, 1fr); }
  .tool-layout { grid-template-columns: minmax(0,1fr) 240px; }
  .footer-layout { grid-template-columns: 1.4fr repeat(3, 1fr); gap: 28px; }
}

@media (max-width: 820px) {
  .hero-grid { grid-template-columns: 1fr; }
  .hero-workspace { display: none; }
  .trust-grid { grid-template-columns: 1fr; }
  .trust-grid article { border-inline-end: 0; border-bottom: 1px solid var(--line); }
  .trust-grid article:last-child { border-bottom: 0; }
  .seo-section { grid-template-columns: 1fr; gap: 38px; }
  .tool-layout { grid-template-columns: 1fr; }
  .tool-sidebar { display: none; }
  .tool-content { grid-template-columns: 1fr; }
  .related-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-layout { grid-template-columns: repeat(2, 1fr); }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; transition-duration: .01ms !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; }
}

.nav-group.is-open .nav-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.is-pressed { opacity: .74; }

@media (min-width: 769px) {
  .sheet-backdrop {
    position: fixed; inset: 0; z-index: 1400; display: block;
    opacity: 0; background: rgba(8,15,28,.48); backdrop-filter: blur(3px); transition: opacity .2s ease;
  }
  .sheet-backdrop.is-open { opacity: 1; }
  .app-sheet {
    position: fixed; top: 10vh; inset-inline-start: 50%; z-index: 1500; display: block;
    width: min(680px, calc(100vw - 40px)); max-height: 76vh; overflow: hidden;
    transform: translate(-50%, -18px) scale(.98); opacity: 0;
    border: 1px solid var(--line); border-radius: 24px; background: var(--surface); box-shadow: var(--shadow-3);
    transition: transform .22s ease, opacity .22s ease;
  }
  [dir="rtl"] .app-sheet { transform: translate(50%, -18px) scale(.98); }
  .app-sheet.is-open { transform: translate(-50%, 0) scale(1); opacity: 1; }
  [dir="rtl"] .app-sheet.is-open { transform: translate(50%, 0) scale(1); }
  .sheet-handle { display: none; }
  .sheet-header, .sheet-title-row { display: flex; align-items: center; gap: 10px; padding: 16px; border-bottom: 1px solid var(--line); }
  .sheet-title-row { justify-content: space-between; }
  .sheet-title-row h2 { margin: 0; font-size: 20px; }
  .sheet-search-field { display: flex; align-items: center; gap: 10px; flex: 1; min-height: 48px; padding: 0 13px; border: 1px solid var(--line); border-radius: 14px; background: var(--surface-2); }
  .sheet-search-field svg { width: 20px; height: 20px; color: var(--ink-faint); }
  .sheet-search-field input { width: 100%; border: 0; outline: 0; background: transparent; font-size: 16px; }
  .sheet-close { display: grid; place-items: center; width: 42px; height: 42px; border: 0; border-radius: 12px; background: var(--surface-2); cursor: pointer; font-size: 24px; }
  .search-results { max-height: calc(76vh - 82px); overflow-y: auto; padding: 8px 14px 16px; }
  .search-result-item { display: grid; grid-template-columns: auto minmax(0,1fr) auto; align-items: center; gap: 12px; min-height: 70px; padding: 10px; border-bottom: 1px solid var(--line); }
  .search-result-item:last-child { border-bottom: 0; }
  .search-result-item strong { display: block; font-size: 14px; }
  .search-result-item small { display: block; overflow: hidden; color: var(--ink-faint); font-size: 11px; white-space: nowrap; text-overflow: ellipsis; }
  .search-result-item > svg { width: 17px; height: 17px; color: var(--ink-faint); }
  .search-empty { padding: 52px 20px; text-align: center; color: var(--ink-faint); }
  .more-sheet { width: min(520px, calc(100vw - 40px)); }
  .more-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 12px; padding: 16px; }
  .more-grid a, .more-grid button { display: flex; align-items: center; gap: 10px; min-height: 58px; padding: 12px; border: 1px solid var(--line); border-radius: 14px; background: var(--surface-2); cursor: pointer; font-weight: 750; }
  .more-grid svg { width: 22px; height: 22px; color: var(--primary); }
  .sheet-languages { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; padding: 0 16px 18px; }
  .sheet-languages a { display:flex; align-items:center; gap:7px; padding: 9px; border: 1px solid var(--line); border-radius: 10px; color: var(--ink-soft); font-size: 11px; }
  .sheet-languages a.is-current { color: var(--primary); border-color: var(--primary); background: var(--primary-soft); }
}

/* Compatibility layer for account, article and AI pages not yet migrated to the workspace shell */
.tool-box, .auth-card, .dashboard-card, .article-card, .content-card {
  border: 1px solid var(--line); border-radius: var(--radius-lg); background: var(--surface); box-shadow: var(--shadow-1);
}
.tool-box { overflow: hidden; margin-block: 22px; }
.tool-box-header { display:flex; align-items:center; justify-content:space-between; gap:16px; padding:18px 20px; border-bottom:1px solid var(--line); background:var(--surface-2); }
.tool-box-title { margin:0; font-size:18px; line-height:1.3; }
.tool-textarea, textarea.tool-input, input.tool-input, select.tool-input {
  width:100%; min-height:170px; padding:16px; border:1px solid var(--line); border-radius:14px; color:var(--ink); background:var(--surface); resize:vertical;
}
.tool-textarea:focus, textarea.tool-input:focus, input.tool-input:focus, select.tool-input:focus { border-color:var(--primary); outline:3px solid color-mix(in srgb, var(--primary) 18%, transparent); }
.stats-bar { display:flex; flex-wrap:wrap; gap:10px; padding:14px 18px; border-top:1px solid var(--line); background:var(--surface-2); }
.stat-item { display:inline-flex; align-items:center; gap:6px; color:var(--ink-soft); font-size:13px; }
.stat-item strong { color:var(--ink); }
.tool-buttons { display:flex; flex-wrap:wrap; gap:10px; padding:16px 18px; }
.faq-list { display:grid; gap:10px; }
.faq-item { border:1px solid var(--line); border-radius:14px; overflow:hidden; background:var(--surface); }
.faq-q { width:100%; display:flex; justify-content:space-between; gap:14px; padding:15px 17px; border:0; background:transparent; text-align:start; cursor:pointer; font-weight:750; }
.faq-a { padding:0 17px 16px; color:var(--ink-soft); }
.page-header { padding:38px 0 22px; }
.page-title { margin:0 0 8px; font-size:clamp(28px, 5vw, 48px); line-height:1.12; letter-spacing:-.035em; }
.page-subtitle { max-width:760px; margin:0; color:var(--ink-soft); }
.prose { color:var(--ink-soft); }
.prose h2, .prose h3 { color:var(--ink); line-height:1.25; }
.prose a { color:var(--primary); text-decoration:underline; text-underline-offset:3px; }
@media (max-width: 700px) {
  .tool-box { border-radius:18px; margin-block:14px; }
  .tool-box-header, .tool-buttons { padding-inline:14px; }
  .page-header { padding-top:24px; }
}

/* Optional manual AdSense units. Auto ads do not require these containers. */
.ad-wrap{width:100%;margin:20px auto;text-align:center;overflow:hidden}
.ad-label{display:block;margin-bottom:6px;color:var(--text-muted);font-size:10px;letter-spacing:.04em}
.ad-wrap .adsbygoogle{min-width:0;max-width:100%}

/* Category quick tools — compact switcher below every input area */
.category-quick-tools {
  position: relative;
  margin-top: 12px;
  padding: 14px;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--tool-color, var(--primary)) 18%, var(--line));
  border-radius: 18px;
  background:
    radial-gradient(circle at 0 0, color-mix(in srgb, var(--tool-color, var(--primary)) 10%, transparent), transparent 42%),
    var(--surface);
  box-shadow: 0 10px 24px rgba(30, 52, 82, .055);
}
.category-quick-tools::after {
  content: "";
  position: absolute;
  inset-inline-end: -42px;
  top: -58px;
  width: 150px;
  height: 150px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--tool-color, var(--primary)) 7%, transparent);
  pointer-events: none;
}
.quick-tools__heading { position: relative; z-index: 1; display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 11px; }
.quick-tools__title-row { display: flex; align-items: center; gap: 10px; min-width: 0; }
.quick-tools__spark { display: grid; place-items: center; flex: 0 0 auto; width: 34px; height: 34px; border-radius: 11px; color: var(--tool-color, var(--primary)); background: color-mix(in srgb, var(--tool-color, var(--primary)) 11%, var(--surface)); }
.quick-tools__spark svg { width: 18px; height: 18px; }
.quick-tools__spark path { fill: none; stroke: currentColor; stroke-width: 1.7; stroke-linecap: round; }
.quick-tools__eyebrow { display: block; margin-bottom: 1px; color: var(--tool-color, var(--primary)); font-size: 9px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; }
.quick-tools__heading h2 { margin: 0; font-size: 14px; line-height: 1.25; }
.quick-tools__heading p { max-width: 320px; margin: 0; color: var(--ink-faint); font-size: 10px; line-height: 1.45; text-align: end; }
.quick-tools__category { flex: 0 0 auto; padding: 5px 8px; border: 1px solid color-mix(in srgb, var(--tool-color, var(--primary)) 17%, var(--line)); border-radius: 999px; color: var(--ink-soft); background: color-mix(in srgb, var(--tool-color, var(--primary)) 5%, var(--surface)); font-size: 9px; font-weight: 800; }
.quick-tools__rail {
  position: relative;
  z-index: 1;
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 1px 1px 4px;
  scroll-snap-type: x proximity;
  scrollbar-width: thin;
  scrollbar-color: color-mix(in srgb, var(--tool-color, var(--primary)) 22%, var(--line)) transparent;
}
.quick-tools__rail::-webkit-scrollbar { height: 4px; }
.quick-tools__rail::-webkit-scrollbar-thumb { border-radius: 999px; background: color-mix(in srgb, var(--tool-color, var(--primary)) 22%, var(--line)); }
.quick-tool-chip {
  display: grid;
  grid-template-columns: auto minmax(0,1fr) auto;
  align-items: center;
  gap: 9px;
  flex: 1 0 150px;
  max-width: 220px;
  min-height: 54px;
  padding: 8px 9px;
  border: 1px solid var(--line);
  border-radius: 13px;
  color: var(--ink);
  background: color-mix(in srgb, var(--surface) 96%, var(--quick-color));
  box-shadow: 0 2px 9px rgba(30, 52, 82, .035);
  scroll-snap-align: start;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
.quick-tool-chip:hover { transform: translateY(-2px); border-color: color-mix(in srgb, var(--quick-color) 45%, var(--line)); background: color-mix(in srgb, var(--quick-color) 5%, var(--surface)); box-shadow: 0 8px 16px rgba(30,52,82,.08); }
.quick-tool-chip:active { transform: translateY(0) scale(.985); }
.quick-tool-chip__icon { display: grid; place-items: center; width: 34px; height: 34px; border-radius: 10px; color: var(--quick-color); background: color-mix(in srgb, var(--quick-color) 11%, var(--surface)); font: 900 9px/1 ui-monospace, monospace; }
.quick-tool-chip__copy { min-width: 0; }
.quick-tool-chip__copy strong { display: -webkit-box; overflow: hidden; -webkit-box-orient: vertical; -webkit-line-clamp: 2; font-size: 11px; line-height: 1.25; }
.quick-tool-chip__copy small { display: block; overflow: hidden; margin-top: 2px; color: var(--ink-faint); font-size: 8.5px; white-space: nowrap; text-overflow: ellipsis; }
.quick-tool-chip__arrow { width: 15px; height: 15px; color: var(--ink-faint); }
[dir="rtl"] .quick-tool-chip__arrow { transform: scaleX(-1); }
.quick-tool-chip[hidden] { display: none !important; }

/* The AI pages use the legacy two-column shell; keep the quick switcher compact there. */
.tool-shell .category-quick-tools, .tool-page .category-quick-tools { --tool-color: var(--primary); margin-top: 10px; }


/* In-app navigation feedback for Android wrappers. */
html.fs-app-navigating::before {
  content: ""; position: fixed; z-index: 10050; inset: 0 auto auto 0; height: 3px; width: 42%;
  background: linear-gradient(90deg, var(--primary), var(--accent));
  box-shadow: 0 1px 10px color-mix(in srgb, var(--primary) 45%, transparent);
  animation: fs-app-progress 1s ease-in-out infinite;
}
html.fs-app-navigating body { cursor: progress; }
@keyframes fs-app-progress { 0% { transform: translateX(-110%); } 55% { transform: translateX(95vw); } 100% { transform: translateX(240vw); } }
@media (prefers-reduced-motion: reduce) { html.fs-app-navigating::before { animation-duration: 2.2s; } }

.language-swatch {
  width: 10px; height: 10px; flex: 0 0 auto; border-radius: 50%;
  background: var(--lang-profile-color, var(--primary));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--lang-profile-color, var(--primary)) 14%, transparent);
}
