/* ==========================================================================
   NakonRent — elevated editorial system
   Libre Caslon display · Inter body · JetBrains Mono data.
   Cool paper / ink / bronze. Hairlines, editorial shadow, generous rhythm.
   Logical properties throughout for RTL. Risk palette reserved for risk.
   ========================================================================== */

:root {
  color-scheme: light;

  /* layout */
  --max: 1280px;
  --gutter: clamp(20px, 4vw, 56px);
  --col-gap: 24px;
  --section-y: clamp(64px, 8vw, 120px);

  /* radius */
  --r-xs: 2px;
  --r-sm: 4px;
  --r-md: 8px;
  --r-pill: 999px;

  /* type */
  --font-display: "Libre Caslon Text", "Iowan Old Style", "Palatino Linotype", Georgia, serif;
  --font-body: Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, "SFMono-Regular", Consolas, monospace;

  /* surfaces — cool paper */
  --bg: #f7f9fb;
  --surface: #ffffff;
  --surface-2: #f2f4f6;
  --surface-3: #eceef0;

  /* ink */
  --ink: #191c1e;
  --ink-2: #45464d;
  --ink-3: #76777d;

  /* lines */
  --line: rgba(25, 28, 30, 0.10);
  --line-strong: #c6c6cd;

  /* accent — bronze */
  --accent: #725b26;
  --accent-strong: #594410;
  --accent-tint: rgba(114, 91, 38, 0.10);

  /* risk semaphore (risk only) */
  --risk: #ba1a1a;
  --risk-tint: #f6e3e1;
  --warn: #b45309;
  --warn-tint: #f6ecdb;
  --fair: #1e7a52;
  --fair-tint: #e3f0e8;

  /* dark editorial break (the "features" section) */
  --panel: #21262a;
  --panel-ink: #eef1f3;
  --panel-ink-2: #aab2b8;
  --panel-line: rgba(255, 255, 255, 0.12);

  /* legacy tokens consumed by the 3D scene */
  --surface-soft: #f2f4f6;
  --ink-variant: #45464d;
  --burgundy: #725b26;
  --gold: #8a6f30;

  /* effects */
  --shadow-edit: 0 30px 60px -12px rgba(20, 24, 28, 0.10), 0 18px 36px -18px rgba(20, 24, 28, 0.12);
  --shadow-sm: 0 1px 2px rgba(20, 24, 28, 0.05), 0 8px 24px -12px rgba(20, 24, 28, 0.10);
  --ring: 0 0 0 2px var(--bg), 0 0 0 4px var(--accent);
  --ease: cubic-bezier(0.16, 1, 0.3, 1);

  --on-accent: #ffffff;
}

[data-theme="dark"] {
  color-scheme: dark;
  --bg: #131618;
  --surface: #1b1f22;
  --surface-2: #1f2427;
  --surface-3: #262b2f;
  --ink: #eceef0;
  --ink-2: #b7bcc0;
  --ink-3: #868c91;
  --line: rgba(255, 255, 255, 0.12);
  --line-strong: #3a4045;
  --accent: #e2c383;
  --accent-strong: #efce8e;
  --accent-tint: rgba(226, 195, 131, 0.12);
  --risk: #f0867d;
  --risk-tint: #2b1714;
  --warn: #e2a85c;
  --warn-tint: #281c10;
  --fair: #6acb93;
  --fair-tint: #11241a;
  --panel: #0d0f11;
  --panel-ink: #eef1f3;
  --panel-ink-2: #9aa1a7;
  --panel-line: rgba(255, 255, 255, 0.10);
  --surface-soft: #1f2427;
  --ink-variant: #b7bcc0;
  --burgundy: #e2c383;
  --gold: #d2a85a;
  --shadow-edit: 0 34px 70px -16px rgba(0, 0, 0, 0.55), 0 18px 40px -22px rgba(0, 0, 0, 0.6);
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.4), 0 10px 28px -14px rgba(0, 0, 0, 0.55);
  --on-accent: #221c0a;
}

/* ========================= base ========================= */

*, *::before, *::after { box-sizing: border-box; }

html {
  min-width: 320px;
  scroll-behavior: smooth;
  scroll-padding-top: 110px;
  background: var(--bg);
  color: var(--ink);
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  overflow-x: hidden;
  background: var(--bg);
  color: var(--ink-2);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  font-weight: 400;
  font-variant-numeric: tabular-nums;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 400;
  color: var(--ink);
  letter-spacing: 0;
  line-height: 1.05;
  text-wrap: balance;
}

p { margin: 0; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; }
img, svg, canvas { display: block; max-width: 100%; }

::selection { background: var(--accent-tint); color: var(--ink); }
:focus-visible { outline: 0; box-shadow: var(--ring); border-radius: var(--r-xs); }

i, em, .italic { font-style: italic; }

/* RTL display fonts */
:root[lang="he"] h1, :root[lang="he"] h2, :root[lang="he"] h3, :root[lang="he"] h4 {
  font-family: "Frank Ruhl Libre", "Narkisim", "David", Georgia, serif; letter-spacing: 0;
}
:root[lang="ar"] h1, :root[lang="ar"] h2, :root[lang="ar"] h3, :root[lang="ar"] h4 {
  font-family: "Tajawal", "Traditional Arabic", Georgia, serif; letter-spacing: 0;
}

/* ========================= scaffolding ========================= */

.shell { width: 100%; max-width: var(--max); margin-inline: auto; padding-inline: var(--gutter); }

.section { position: relative; padding-block: var(--section-y); }
.section--hairline { border-top: 0.5px solid var(--line); }

.kicker {
  display: inline-flex; align-items: center; gap: 12px;
  margin: 0 0 28px;
  font-family: var(--font-mono);
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.34em; text-transform: uppercase;
  color: var(--accent);
}
.kicker::before { content: ""; width: 28px; height: 0.5px; background: currentColor; opacity: 0.7; }

.eyebrow {
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--ink-3);
}

.section__head { max-width: 760px; }
.section__title { font-size: 3rem; }
.section__intro {
  margin-block-start: 24px; max-width: 56ch;
  font-size: 1.08rem; color: var(--ink-2); line-height: 1.6;
}

.hairline { height: 0.5px; background: var(--line); border: 0; }

/* ========================= buttons ========================= */

.nr-button {
  --_bg: transparent; --_fg: var(--ink); --_bd: var(--line-strong);
  display: inline-flex; align-items: center; justify-content: center; gap: 12px;
  min-height: 56px; padding-inline: 32px;
  border: 0.5px solid var(--_bd); border-radius: var(--r-sm);
  background: var(--_bg); color: var(--_fg);
  font-family: var(--font-body); font-size: 14px; font-weight: 600; letter-spacing: 0.01em;
  cursor: pointer; text-align: center;
  transition: transform 200ms var(--ease), box-shadow 200ms var(--ease), background-color 200ms var(--ease), color 200ms var(--ease), border-color 200ms var(--ease);
}
.nr-button:hover { transform: translateY(-2px); }
.nr-button:active { transform: translateY(0); }
.nr-button--primary { --_bg: var(--ink); --_fg: var(--bg); --_bd: var(--ink); box-shadow: var(--shadow-sm); }
.nr-button--primary:hover { box-shadow: var(--shadow-edit); }
.nr-button--ghost { --_bg: var(--surface); }
.nr-button--ghost:hover { border-color: var(--ink); }
.nr-button__icon { width: 18px; height: 18px; flex: none; }

.text-link {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-2); border-bottom: 1px solid transparent; padding-block-end: 4px;
  transition: color 160ms var(--ease), border-color 160ms var(--ease);
}
.text-link:hover { color: var(--ink); border-color: var(--accent); }
.text-link__arrow { transition: transform 200ms var(--ease); }
.text-link:hover .text-link__arrow { transform: translateX(4px); }
[dir="rtl"] .text-link:hover .text-link__arrow { transform: translateX(-4px); }

/* ========================= header ========================= */

.site-header {
  position: fixed; inset-block-start: 0; inset-inline: 0; z-index: 60;
  height: 72px; display: flex; align-items: center;
  transition: background-color 300ms var(--ease), border-color 300ms var(--ease), backdrop-filter 300ms var(--ease);
  border-bottom: 0.5px solid var(--line);
  background: color-mix(in srgb, var(--bg) 76%, transparent);
  backdrop-filter: saturate(1.2) blur(14px);
  -webkit-backdrop-filter: saturate(1.2) blur(14px);
}
.site-header[data-scrolled] {
  background: color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter: saturate(1.2) blur(16px);
  -webkit-backdrop-filter: saturate(1.2) blur(16px);
  border-bottom-color: var(--line);
  height: 64px;
}
.site-header__inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; width: 100%; }
.header-left { display: flex; align-items: center; gap: clamp(20px, 3vw, 40px); min-width: 0; }
.brand {
  font-family: var(--font-display); font-size: 21px; font-weight: 700; letter-spacing: 0; color: var(--ink);
}
.site-nav { display: flex; align-items: center; gap: 22px; }
.site-nav a {
  position: relative; display: inline-flex; align-items: center; min-height: 36px;
  font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-2); transition: color 160ms var(--ease);
}
.site-nav a::after {
  content: ""; position: absolute; inset-inline: 0; inset-block-end: 4px; height: 1px;
  background: var(--accent); transform: scaleX(0); transform-origin: center; transition: transform 180ms var(--ease);
}
.site-nav a:hover { color: var(--ink); }
.site-nav a:hover::after { transform: scaleX(1); }
.header-tools { display: flex; align-items: center; gap: 12px; flex: none; }

.language-switcher {
  direction: ltr; display: flex; align-items: center; gap: 2px;
  font-family: var(--font-mono); font-size: 11px;
}
.language-switcher__button {
  min-width: 30px; height: 30px; padding-inline: 6px; border: 0; border-radius: var(--r-xs);
  background: transparent; color: var(--ink-3); cursor: pointer; letter-spacing: 0.04em;
  transition: color 140ms var(--ease);
}
.language-switcher__button:hover { color: var(--ink); }
.language-switcher__button[data-active] { color: var(--accent); font-weight: 700; }
.language-switcher__separator { color: var(--line-strong); }

.theme-toggle {
  position: relative; width: 54px; height: 28px; padding: 0;
  border: 0.5px solid var(--line-strong); border-radius: var(--r-pill);
  background: var(--surface-2); cursor: pointer; transition: border-color 160ms var(--ease);
}
.theme-toggle:hover { border-color: var(--ink-3); }
.theme-toggle__thumb {
  position: absolute; inset-block: 3px; inset-inline-start: 3px; width: 20px;
  border-radius: var(--r-pill); background: var(--ink);
  transition: inset-inline-start 220ms var(--ease), background-color 220ms var(--ease);
}
[data-theme="dark"] .theme-toggle__thumb { inset-inline-start: calc(100% - 23px); background: var(--accent); }
.theme-toggle__sun, .theme-toggle__moon { position: absolute; top: 50%; translate: 0 -50%; font-size: 10px; color: var(--ink-3); }
.theme-toggle__sun { inset-inline-start: 8px; }
.theme-toggle__moon { inset-inline-end: 8px; }

/* ========================= hero ========================= */

.hero {
  position: relative; isolation: isolate; overflow: hidden;
  min-height: min(700px, 96svh); display: flex; align-items: center;
  padding-block: 86px 30px;
  background: var(--bg);
}
.hero__bg { position: absolute; inset: 0; z-index: -1; pointer-events: none; }
.hero__bg canvas { opacity: 0.46; transform: translateX(4%); }
[data-theme="dark"] .hero__bg canvas { opacity: 0.38; }
.hero__bg-grid {
  position: absolute; inset: -1px;
  background-image:
    linear-gradient(var(--line) 0.5px, transparent 0.5px),
    linear-gradient(90deg, var(--line) 0.5px, transparent 0.5px);
  background-size: 80px 80px;
  -webkit-mask-image: radial-gradient(ellipse 75% 70% at 72% 36%, #000 0%, transparent 76%);
  mask-image: radial-gradient(ellipse 75% 70% at 72% 36%, #000 0%, transparent 76%);
  opacity: 0.32;
}
.hero__bg canvas { position: absolute; inset: 0; width: 100% !important; height: 100% !important; }
.hero__bg-veil {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, var(--bg) 0%, color-mix(in srgb, var(--bg) 78%, transparent) 48%, color-mix(in srgb, var(--bg) 32%, transparent) 78%);
}
[dir="rtl"] .hero__bg-veil {
  background: linear-gradient(-90deg, var(--bg) 0%, color-mix(in srgb, var(--bg) 35%, transparent) 44%, transparent 72%);
}

.hero__inner {
  display: grid; grid-template-columns: repeat(12, 1fr); gap: var(--col-gap);
  align-items: center; width: 100%;
}
.hero__content { grid-column: 1 / span 7; max-width: 680px; }
.hero__title {
  font-size: 4.55rem; line-height: 0.98; letter-spacing: 0; color: var(--ink);
  margin-block: 6px 24px;
}
.hero__title em { font-weight: 400; }
.hero__lede { display: grid; gap: 22px; max-width: 640px; }
.hero__lead { max-width: 46ch; font-size: 1.08rem; color: var(--ink-2); line-height: 1.62; }
.hero__actions { display: flex; flex-wrap: wrap; align-items: center; gap: 18px 22px; }
.micro-details {
  display: flex; flex-wrap: wrap; gap: 8px 18px; margin: 22px 0 0; padding: 0; list-style: none;
  color: var(--ink-3); font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.02em;
}
.micro-details--center { justify-content: center; }
.micro-details li { display: inline-flex; align-items: center; gap: 8px; }
.micro-details li::before { content: ""; width: 4px; height: 4px; border-radius: 50%; background: var(--accent); }

/* floating analysis card */
.hero__card-wrap { grid-column: 8 / span 5; position: relative; justify-self: end; width: min(100%, 340px); }
.analysis-card {
  position: relative; background: color-mix(in srgb, var(--surface) 92%, transparent);
  border: 0.5px solid var(--line); border-radius: var(--r-md);
  box-shadow: var(--shadow-edit); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  overflow: hidden;
}
.analysis-card__head {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 16px 20px; border-bottom: 0.5px solid var(--line); background: var(--surface-2);
}
.analysis-card__id { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-3); }
.analysis-card__score { font-family: var(--font-display); font-size: 22px; color: var(--ink); }
.analysis-card__score small { color: var(--ink-3); font-size: 12px; }
.analysis-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 14px 20px; }
.analysis-row + .analysis-row { border-top: 0.5px solid var(--line); }
.analysis-row__label { display: inline-flex; align-items: center; gap: 11px; font-size: 13.5px; color: var(--ink-2); }
.analysis-row__dot { width: 8px; height: 8px; border-radius: 50%; flex: none; }
.analysis-row__count { font-family: var(--font-mono); font-size: 14px; font-weight: 500; }
.analysis-row--risk .analysis-row__dot { background: var(--risk); } .analysis-row--risk .analysis-row__count { color: var(--risk); }
.analysis-row--warn .analysis-row__dot { background: var(--warn); } .analysis-row--warn .analysis-row__count { color: var(--warn); }
.analysis-row--fair .analysis-row__dot { background: var(--fair); } .analysis-row--fair .analysis-row__count { color: var(--fair); }
.analysis-card__cite {
  padding: 16px 20px; border-top: 0.5px solid var(--line); background: var(--surface-2);
}
.analysis-card__cite-tag { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent); }
.analysis-card__cite-text { margin-block-start: 8px; font-family: var(--font-display); font-style: italic; font-size: 15px; color: var(--ink); line-height: 1.4; }
.analysis-card__foot { padding: 11px 20px; border-top: 0.5px solid var(--line); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3); }

.hero__proof {
  display: flex; align-items: center; gap: 12px; z-index: 2; margin-block-start: 20px; max-width: 56ch;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; line-height: 1.5; text-transform: uppercase; color: var(--ink-3);
}
.hero__proof span { width: 24px; height: 0.5px; background: var(--ink-3); opacity: 0.5; }

/* ========================= trust strip ========================= */

.trust-strip { border-block: 0.5px solid var(--line); background: var(--surface-2); }
.trust-strip__inner {
  display: grid; grid-template-columns: repeat(4, 1fr);
}
.trust-item { padding: 26px var(--col-gap); border-inline-start: 0.5px solid var(--line); }
.trust-item:first-child { border-inline-start: 0; }
.trust-item strong { display: block; font-family: var(--font-display); font-size: 2rem; color: var(--ink); line-height: 1; }
.trust-item span { display: block; margin-block-start: 10px; font-size: 13px; color: var(--ink-2); }

/* ========================= case study (Hebrew gap) ========================= */

.case { display: grid; grid-template-columns: repeat(12, 1fr); gap: var(--col-gap); }
.case__lead { grid-column: 1 / span 5; }
.case__quote {
  position: relative; margin-block-start: 40px; padding: 32px 36px;
  background: var(--surface); border: 0.5px solid var(--line); border-inline-start: 2px solid var(--accent);
}
.case__quote-tag { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent); }
.case__quote-text { margin-block: 16px 14px; font-family: var(--font-display); font-style: italic; font-size: 1.45rem; line-height: 1.28; color: var(--ink); }
.case__quote-note { font-size: 13.5px; color: var(--ink-2); font-style: italic; }
.case__cards { grid-column: 7 / span 6; display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-content: start; padding-block-start: clamp(0px, 6vw, 80px); }
.case-card { padding: 36px 30px; background: var(--surface); border: 0.5px solid var(--line); transition: box-shadow 400ms var(--ease), transform 400ms var(--ease); }
.case-card:hover { box-shadow: var(--shadow-edit); transform: translateY(-3px); }
.case-card:nth-child(1) { margin-block-start: clamp(0px, 4vw, 56px); }
.case-card__icon { font-size: 26px; line-height: 1; margin-block-end: 28px; }
.case-card__icon--risk { color: var(--risk); }
.case-card__icon--warn { color: var(--accent); }
.case-card__title { font-size: 1.5rem; margin-block-end: 12px; }
.case-card__body { font-size: 14px; color: var(--ink-2); line-height: 1.55; }
.case-card__he { display: inline-block; margin-block-start: 14px; font-family: var(--font-mono); font-size: 12px; color: var(--ink-3); direction: rtl; }

/* ========================= method ========================= */

.method-head { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: flex-end; gap: 24px; margin-block-end: clamp(40px, 6vw, 88px); }
.steps { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 0.5px solid var(--line); }
.step {
  position: relative; overflow: hidden; padding: 48px clamp(24px, 3vw, 44px);
  border-inline-start: 0.5px solid var(--line);
  transition: background-color 300ms var(--ease);
}
.step:first-child { border-inline-start: 0; }
.step:hover { background: var(--surface); }
.step__ghost {
  position: absolute; inset-block-start: -22px; inset-inline-end: -8px;
  font-family: var(--font-display); font-size: 6.5rem; line-height: 1; color: var(--surface-3);
  z-index: 0; transition: color 300ms var(--ease); pointer-events: none;
}
.step:hover .step__ghost { color: var(--accent-tint); }
.step__inner { position: relative; z-index: 1; }
.step__num { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--accent); }
.step__title { margin-block: 24px 12px; font-size: 1.9rem; }
.step__body { font-size: 15px; color: var(--ink-2); line-height: 1.55; }
.step__body strong { color: var(--ink); font-weight: 600; }

/* ========================= widget ========================= */

.widget-section { background: var(--surface-2); border-block: 0.5px solid var(--line); }
.widget {
  margin-block-start: 12px; background: var(--surface);
  border: 0.5px solid var(--line); box-shadow: var(--shadow-edit); overflow: hidden;
}
.widget__bar { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 16px 24px; border-bottom: 0.5px solid var(--line); background: var(--surface-2); }
.widget__bar-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-3); }
.widget__progress { display: flex; gap: 6px; }
.widget__progress span { width: 28px; height: 3px; background: var(--line-strong); transition: background-color 240ms var(--ease); }
.widget__progress span[data-done] { background: var(--accent); }
.widget__progress span[data-current] { background: var(--ink); }
.widget__stage { padding: clamp(28px, 4vw, 52px); }
.widget-q { font-family: var(--font-display); font-size: 1.75rem; line-height: 1.18; color: var(--ink); margin-block-end: 10px; }
.widget-hint { color: var(--ink-3); font-size: 14px; margin-block-end: 30px; }

.chip-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; }
.chip {
  padding: 20px; border: 0.5px solid var(--line-strong); background: var(--surface); color: var(--ink);
  text-align: start; cursor: pointer;
  transition: border-color 200ms var(--ease), background-color 200ms var(--ease), transform 200ms var(--ease), box-shadow 200ms var(--ease);
}
.chip:hover { transform: translateY(-2px); border-color: var(--accent); box-shadow: var(--shadow-sm); }
.chip[aria-pressed="true"] { border-color: var(--accent); background: var(--accent-tint); }
.chip__title { font-weight: 600; font-size: 15.5px; }

.opt-list { display: grid; gap: 10px; max-width: 580px; }
.opt {
  display: flex; align-items: center; gap: 16px; width: 100%; padding: 17px 20px;
  border: 0.5px solid var(--line-strong); background: var(--surface); color: var(--ink);
  text-align: start; font-size: 15.5px; cursor: pointer;
  transition: border-color 180ms var(--ease), background-color 180ms var(--ease), transform 160ms var(--ease);
}
.opt:hover { transform: translateX(3px); border-color: var(--accent); }
[dir="rtl"] .opt:hover { transform: translateX(-3px); }
.opt[aria-pressed="true"] { border-color: var(--accent); background: var(--accent-tint); }
.opt__mark { width: 22px; height: 22px; flex: none; border: 1.5px solid var(--line-strong); border-radius: 50%; display: grid; place-items: center; color: var(--on-accent); font-size: 12px; }
.opt[aria-pressed="true"] .opt__mark { background: var(--accent); border-color: var(--accent); }

.widget-field { max-width: 380px; }
.widget-field label { display: block; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); margin-block-end: 10px; }
.widget-input { display: flex; align-items: center; gap: 10px; border: 0.5px solid var(--line-strong); background: var(--surface); padding-inline: 18px; }
.widget-input:focus-within { border-color: var(--accent); box-shadow: var(--ring); }
.widget-input span { color: var(--ink-3); font-family: var(--font-mono); }
.widget-input input { flex: 1; min-width: 0; border: 0; background: transparent; color: var(--ink); font-family: var(--font-mono); font-size: 20px; padding-block: 16px; }
.widget-input input:focus { outline: 0; }

.widget__nav { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-block-start: 32px; }
.widget-back { border: 0; background: transparent; color: var(--ink-3); font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; cursor: pointer; padding: 6px 2px; }
.widget-back:hover { color: var(--ink); }
.widget-back[hidden] { visibility: hidden; }

.result__verdict { display: flex; gap: 16px; padding: 22px 24px; border: 0.5px solid var(--line); margin-block-end: 24px; }
.result__verdict--risk { background: var(--risk-tint); border-color: color-mix(in srgb, var(--risk) 30%, var(--line)); }
.result__verdict--fair { background: var(--fair-tint); border-color: color-mix(in srgb, var(--fair) 30%, var(--line)); }
.result__verdict-icon { flex: none; width: 28px; height: 28px; display: grid; place-items: center; border-radius: 50%; color: #fff; font-weight: 700; }
.result__verdict--risk .result__verdict-icon { background: var(--risk); }
.result__verdict--fair .result__verdict-icon { background: var(--fair); }
.result__verdict-title { font-family: var(--font-display); font-size: 1.35rem; color: var(--ink); margin-block-end: 6px; }
.result__verdict-body { font-size: 15px; color: var(--ink-2); line-height: 1.55; }
.result__metric { display: grid; grid-template-columns: 1fr 1fr; gap: 0.5px; background: var(--line); border: 0.5px solid var(--line); margin-block-end: 24px; }
.result__metric div { background: var(--surface); padding: 20px; }
.result__metric dt { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-3); margin-block-end: 8px; }
.result__metric dd { margin: 0; font-family: var(--font-display); font-size: 1.7rem; color: var(--ink); }
.result__metric dd.is-bad { color: var(--risk); }
.result__flags { list-style: none; margin: 0 0 24px; padding: 0; display: grid; gap: 12px; }
.result__flags li { display: flex; gap: 12px; font-size: 15px; color: var(--ink-2); line-height: 1.5; }
.result__flags li::before { content: ""; flex: none; width: 6px; height: 6px; margin-block-start: 8px; background: var(--accent); rotate: 45deg; }
.result__source { font-family: var(--font-mono); font-size: 11px; color: var(--ink-3); margin-block-end: 26px; line-height: 1.5; }
.result__source strong { color: var(--ink); }
.result__cta { display: flex; flex-wrap: wrap; align-items: center; gap: 16px; padding-block-start: 26px; border-top: 0.5px solid var(--line); }
.result__restart { border: 0; background: transparent; cursor: pointer; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-3); }
.result__restart:hover { color: var(--ink); }

.gate { border-inline-start: 2px solid var(--risk); background: var(--risk-tint); padding: 26px 28px; }
.gate--neutral { border-inline-start-color: var(--accent); background: var(--accent-tint); }
.gate__title { font-family: var(--font-display); font-size: 1.5rem; color: var(--ink); margin-block-end: 12px; }
.gate__body { font-size: 15.5px; color: var(--ink-2); line-height: 1.6; }
.gate__body strong { color: var(--ink); }

/* ========================= dark feature section ========================= */

.section--dark {
  position: relative; overflow: hidden;
  background: var(--panel); color: var(--panel-ink-2);
}
.section--dark .section__title, .section--dark h3, .section--dark h4 { color: var(--panel-ink); }
.section--dark .kicker { color: var(--accent); }
.feature-head { display: grid; grid-template-columns: repeat(12, 1fr); gap: var(--col-gap); align-items: center; margin-block-end: clamp(48px, 7vw, 110px); }
.feature-head__title { grid-column: 1 / span 6; }
.feature-head__title .section__intro { color: var(--panel-ink-2); }
.feature-head__aside { grid-column: 9 / span 4; }
.feature-grid { display: flex; flex-direction: column; gap: 24px; }
.feature {
  flex: 1; padding: 44px 40px; background: rgba(255,255,255,0.04);
  border: 0.5px solid var(--panel-line); transition: background-color 300ms var(--ease);
}
.feature:hover { background: rgba(255,255,255,0.08); }
.feature__num { font-family: var(--font-mono); font-size: 13px; color: var(--accent); }
.feature__title { margin-block: 28px 14px; font-size: 1.8rem; }
.feature__body { color: var(--panel-ink-2); line-height: 1.6; font-size: 15px; }
.feature-vertical {
  position: absolute; inset-block-start: 0; inset-inline-end: 0; height: 100%; width: 50%;
  opacity: 0.04; pointer-events: none; overflow: hidden; display: flex; align-items: center; justify-content: flex-end;
}
.feature-vertical span {
  writing-mode: vertical-rl; font-family: var(--font-display); font-size: 20rem; font-weight: 700;
  color: var(--panel-ink); line-height: 1; white-space: nowrap; user-select: none;
}
@media (min-width: 1000px) {
  .feature-grid { flex-direction: row; align-items: stretch; }
  .feature:nth-child(2) { margin-block-start: 48px; }
  .feature:nth-child(3) { margin-block-start: 96px; }
}

/* ========================= profiles ========================= */

.profiles-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(min(100%, 260px), 1fr)); gap: 16px; }
.profile-link {
  display: flex; flex-direction: column; gap: 8px; padding: 26px 24px;
  background: var(--surface); border: 0.5px solid var(--line); color: var(--ink);
  transition: border-color 240ms var(--ease), transform 240ms var(--ease), box-shadow 240ms var(--ease);
}
.profile-link:hover { border-color: var(--accent); transform: translateY(-3px); box-shadow: var(--shadow-sm); }
.profile-link__name { display: flex; align-items: baseline; gap: 10px; font-family: var(--font-display); font-size: 1.3rem; }
.profile-link__he { font-size: 14px; color: var(--ink-3); direction: rtl; unicode-bidi: isolate; }
.profile-link__sub { font-size: 13.5px; color: var(--ink-2); line-height: 1.45; }
.profile-link__more { margin-block-start: 8px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent); }
.profile-link__more::after { content: " →"; }
[dir="rtl"] .profile-link__more::after { content: " ←"; }

/* ========================= cities ========================= */

.cities-section { background: var(--surface-2); border-block: 0.5px solid var(--line); }
.cities-cloud { display: flex; flex-wrap: wrap; gap: 10px; }
.city-link {
  display: inline-flex; align-items: center; padding: 10px 18px;
  border: 0.5px solid var(--line-strong); border-radius: var(--r-pill);
  background: var(--surface); color: var(--ink-2); font-size: 14px;
  transition: border-color 160ms var(--ease), color 160ms var(--ease), background-color 160ms var(--ease);
}
.city-link:hover { border-color: var(--accent); color: var(--ink); background: var(--accent-tint); }

/* ========================= law numbers ========================= */

.facts-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr)); gap: clamp(24px, 3vw, 40px); }
.fact { padding-block-start: 28px; border-top: 2px solid var(--accent); }
.fact__figure { font-family: var(--font-display); font-size: 3.1rem; line-height: 1; color: var(--ink); letter-spacing: 0; }
.fact__figure small { font-size: 0.42em; color: var(--ink-2); }
.fact__label { margin-block: 16px 10px; font-family: var(--font-body); font-size: 16px; font-weight: 600; color: var(--ink); }
.fact__body { font-size: 14px; color: var(--ink-2); line-height: 1.5; }
.fact__source { display: inline-block; margin-block-start: 14px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3); }
.fact__source a { color: var(--ink-3); text-decoration: underline; text-underline-offset: 3px; }
.fact__source a:hover { color: var(--accent); }

/* ========================= grounded (honest trust) ========================= */

.grounded-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: var(--col-gap); }
.grounded__lead { grid-column: 1 / span 4; }
.grounded__items { grid-column: 6 / span 7; display: grid; gap: 0; border-top: 0.5px solid var(--line); }
.grounded-item { display: grid; grid-template-columns: auto 1fr; gap: 28px; padding-block: 28px; border-bottom: 0.5px solid var(--line); align-items: baseline; }
.grounded-item__no { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; color: var(--accent); padding-block-start: 4px; }
.grounded-item__title { font-family: var(--font-display); font-size: 1.5rem; color: var(--ink); margin-block-end: 8px; }
.grounded-item__body { font-size: 14.5px; color: var(--ink-2); line-height: 1.55; }
.grounded-item__body .he { direction: rtl; unicode-bidi: isolate; }

/* ========================= multilingual marquee ========================= */

.lang-band { border-block: 0.5px solid var(--line); background: var(--bg); overflow: hidden; }
.lang-band__inner {
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px 8px;
  padding-block: 40px;
  opacity: 0.35; transition: opacity 800ms var(--ease);
}
.lang-band:hover .lang-band__inner { opacity: 1; }
.lang-band__item { font-family: var(--font-display); font-size: 2rem; color: var(--ink); }
.lang-band__item--mono { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-3); align-self: center; }

/* ========================= final CTA ========================= */

.final-cta { text-align: center; position: relative; overflow: hidden; background: var(--surface); border-block: 0.5px solid var(--line); }
.final-cta__inner { position: relative; z-index: 1; max-width: 820px; margin-inline: auto; }
.final-cta__title { font-size: 4rem; line-height: 1; letter-spacing: 0; }
.final-cta__title em { color: var(--accent); font-weight: 400; }
.final-cta__lead { margin-block: 26px 36px; font-size: 1.08rem; color: var(--ink-2); max-width: 46ch; margin-inline: auto; }
.final-cta__actions { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 20px; }

/* ========================= transparency + footer ========================= */

.transparency { background: var(--surface-2); border-top: 0.5px solid var(--line); }
.transparency__inner { display: grid; gap: 16px; padding-block: clamp(36px, 5vw, 56px); }
.transparency p { font-size: 13.5px; color: var(--ink-2); max-width: 90ch; }
.transparency strong { color: var(--ink); }

.site-footer { background: var(--bg); border-top: 0.5px solid var(--line); }
.site-footer__inner { display: grid; grid-template-columns: repeat(12, 1fr); gap: var(--col-gap); padding-block: clamp(44px, 6vw, 72px); }
.site-footer__brand { grid-column: 1 / span 5; }
.site-footer__brand .brand { font-size: 32px; }
.site-footer__tag { margin-block: 18px 0; max-width: 34ch; font-size: 14px; color: var(--ink-2); }
.site-footer__status { margin-block-start: 24px; max-width: 42ch; padding-block-start: 18px; border-top: 0.5px solid var(--line); }
.site-footer__status span { display: block; margin-block-end: 8px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); }
.site-footer__status p { font-size: 13.5px; color: var(--ink-2); line-height: 1.55; }
.site-footer__copy { margin-block-start: 24px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); }
.site-footer__nav { grid-column: 7 / span 6; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 28px; }
.site-footer__nav h2 { font-family: var(--font-mono); font-size: 10px; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); margin-block-end: 18px; }
.site-footer__nav ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 14px; }
.site-footer__nav a { font-size: 14px; color: var(--ink-2); transition: color 140ms var(--ease); }
.site-footer__nav a:hover { color: var(--ink); }

.visually-hidden { position: absolute !important; width: 1px; height: 1px; margin: -1px; padding: 0; border: 0; clip: rect(0 0 0 0); clip-path: inset(50%); overflow: hidden; white-space: nowrap; }

/* ========================= modal ========================= */

.modal { position: fixed; inset: 0; z-index: 100; display: grid; place-items: center; padding: 24px; }
.modal[hidden] { display: none; }
.modal__overlay { position: absolute; inset: 0; background: color-mix(in srgb, #0a0c0e 64%, transparent); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); animation: m-fade 200ms var(--ease); }
.modal__dialog { position: relative; width: min(100%, 440px); padding: clamp(30px, 5vw, 44px); border: 0.5px solid var(--line); background: var(--surface); box-shadow: var(--shadow-edit); text-align: center; animation: m-rise 280ms var(--ease); }
.modal__close { position: absolute; top: 14px; inset-inline-end: 16px; width: 34px; height: 34px; border: 0; border-radius: var(--r-pill); background: transparent; color: var(--ink-3); font-size: 24px; line-height: 1; cursor: pointer; transition: background-color 140ms var(--ease), color 140ms var(--ease); }
.modal__close:hover { background: var(--surface-2); color: var(--ink); }
.modal__badge { display: inline-block; margin-block-end: 20px; padding: 5px 12px; border-radius: var(--r-pill); background: var(--accent-tint); color: var(--accent); font-family: var(--font-mono); font-size: 10px; font-weight: 500; letter-spacing: 0.16em; text-transform: uppercase; }
.modal__mark { width: 56px; height: 56px; margin: 0 auto 20px; display: grid; place-items: center; border-radius: 50%; background: var(--accent-tint); color: var(--accent); }
.modal__title { font-size: clamp(1.5rem, 3vw, 1.8rem); line-height: 1.15; margin-block-end: 14px; }
.modal__body { font-size: 15px; color: var(--ink-2); line-height: 1.55; margin-block-end: 28px; }
.modal__dialog .nr-button { width: 100%; }
@keyframes m-fade { from { opacity: 0; } to { opacity: 1; } }
@keyframes m-rise { from { opacity: 0; transform: translateY(12px) scale(0.98); } to { opacity: 1; transform: none; } }

/* ========================= reveal ========================= */

.reveal { opacity: 0; transform: translateY(30px); transition: opacity 800ms var(--ease), transform 800ms var(--ease); }
.reveal.is-in { opacity: 1; transform: none; }

/* ========================= responsive ========================= */

@media (max-width: 1100px) {
  .site-nav { gap: 18px; }
  .hero__title { font-size: 4rem; }
}
@media (max-width: 920px) {
  .site-header,
  .site-header[data-scrolled] {
    height: auto;
    min-height: 96px;
    padding-block: 12px;
    align-items: flex-start;
  }
  .site-header__inner { align-items: flex-start; flex-wrap: wrap; gap: 10px 16px; }
  .header-left { flex: 1 1 0; flex-wrap: wrap; gap: 8px 18px; }
  .site-nav {
    order: 2; flex: 1 0 100%; gap: 18px; overflow-x: auto; padding-block: 4px 2px;
    scrollbar-width: none;
  }
  .site-nav::-webkit-scrollbar { display: none; }
  .site-nav a { min-height: 28px; white-space: nowrap; font-size: 10px; letter-spacing: 0.08em; }
  .header-tools { padding-block-start: 1px; }
  .hero { min-height: auto; padding-block: 150px 40px; }
  .hero__inner { grid-template-columns: 1fr; gap: 34px; }
  .hero__content, .hero__card-wrap { grid-column: 1 / -1; }
  .hero__content { max-width: 620px; }
  .hero__title { font-size: 3.65rem; line-height: 1; }
  .hero__lead { max-width: 42ch; font-size: 1rem; }
  .hero__card-wrap { max-width: 420px; justify-self: start; }
  .hero__bg canvas { opacity: 0.24; transform: none; }
  .hero__bg-grid { opacity: 0.18; background-size: 64px 64px; }
  .hero__bg-veil { background: linear-gradient(180deg, var(--bg) 0%, color-mix(in srgb, var(--bg) 82%, transparent) 48%, var(--bg) 100%) !important; }
  .hero__proof { margin-block-start: 20px; padding-inline: 0; max-width: none; }
  .case, .grounded-grid, .feature-head, .site-footer__inner { grid-template-columns: 1fr; }
  .case__lead, .case__cards, .grounded__lead, .grounded__items, .feature-head__title, .feature-head__aside,
  .site-footer__brand, .site-footer__nav { grid-column: 1 / -1; }
  .case__cards { padding-block-start: 8px; }
  .case-card:nth-child(1) { margin-block-start: 0; }
  .steps { grid-template-columns: 1fr; }
  .step { border-inline-start: 0; border-top: 0.5px solid var(--line); }
  .step:first-child { border-top: 0; }
  .trust-strip__inner { grid-template-columns: 1fr 1fr; }
  .trust-item:nth-child(-n+2) { border-bottom: 0.5px solid var(--line); }
  .trust-item:nth-child(odd) { border-inline-start: 0; }
  .site-footer__nav { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 560px) {
  .site-header,
  .site-header[data-scrolled] { min-height: 118px; }
  .brand { font-size: 20px; }
  .header-tools { gap: 8px; }
  .language-switcher { font-size: 10px; }
  .language-switcher__button { min-width: 22px; height: 28px; padding-inline: 2px; }
  .language-switcher__separator { opacity: 0.55; }
  .theme-toggle { width: 46px; height: 26px; }
  .theme-toggle__thumb { width: 18px; }
  [data-theme="dark"] .theme-toggle__thumb { inset-inline-start: calc(100% - 21px); }
  .hero { padding-block-start: 150px; }
  .hero__title { font-size: 3.15rem; line-height: 1.02; }
  .hero__actions .nr-button { min-height: 52px; padding-inline: 22px; }
  .hero__actions .nr-button { width: 100%; }
  .hero__card-wrap { display: none; }
  .micro-details { gap: 8px 14px; font-size: 11px; }
  .case__cards, .grounded-item { grid-template-columns: 1fr; }
  .grounded-item { gap: 8px; }
  .result__metric { grid-template-columns: 1fr; }
  .feature-vertical span { font-size: 12rem; }
  .section__title { font-size: 2.25rem; }
  .widget-q { font-size: 1.45rem; }
  .fact__figure { font-size: 2.55rem; }
  .lang-band__item { font-size: 1.55rem; }
  .final-cta__title { font-size: 2.85rem; }
  .final-cta__lead { font-size: 1rem; }
  .site-footer__nav { grid-template-columns: 1fr; gap: 28px; }
}
@media (max-width: 380px) {
  .hero__title { font-size: 2.9rem; }
}

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