:root {
  color-scheme: light;
  --bg: #f5f8ff;
  --bg-accent: #eaf3ff;
  --bg-end: #eef5ff;
  --surface: rgba(255, 255, 255, 0.88);
  --surface-solid: #ffffff;
  --text: #13203d;
  --muted: #4f5d79;
  --primary: #0b3c8a;
  --primary-strong: #2f63b6;
  --secondary-strong: #d03d58;
  --primary-soft: #dbe8ff;
  --secondary: #c41f3d;
  --gold: #f6b60a;
  --line: rgba(19, 32, 61, 0.12);
  --line-strong: rgba(19, 32, 61, 0.24);
  --shadow: 0 14px 35px rgba(16, 34, 73, 0.12);
  --shadow-soft: 0 8px 20px rgba(16, 34, 73, 0.08);
  --success: #0b8a57;
  --danger: #b42318;
  --bg-spot-primary: rgba(11, 60, 138, 0.12);
  --bg-spot-secondary: rgba(196, 31, 61, 0.1);
  --grid-line: rgba(19, 32, 61, 0.03);
  --nav-pill-bg: #f5f9ff;
  --control-bg: #ffffff;
  --stat-panel-start: rgba(11, 60, 138, 0.9);
  --stat-panel-end: rgba(11, 60, 138, 0.72);
  --stat-panel-text: #f3f8ff;
  --stat-panel-muted: rgba(243, 248, 255, 0.92);
  --stat-panel-line: rgba(255, 255, 255, 0.24);
  --category-surface-start: rgba(255, 255, 255, 0.98);
  --category-surface-end: rgba(242, 248, 255, 0.98);
  --newsletter-surface-start: rgba(255, 255, 255, 0.97);
  --newsletter-surface-end: rgba(241, 248, 255, 0.97);
  --input-bg: #ffffff;
  --metric-bg: #f8fbff;
  --share-panel-start: rgba(255, 255, 255, 0.96);
  --share-panel-end: rgba(233, 243, 255, 0.94);
  --share-panel-spot: rgba(208, 61, 88, 0.16);
  --share-panel-border: rgba(11, 60, 138, 0.18);
  --share-panel-inset: rgba(255, 255, 255, 0.66);
  --share-button-start: #0b3c8a;
  --share-button-end: #356bc4;
  --share-button-text: #f5f8ff;
  --jodoh-hero-start: rgba(255, 245, 249, 0.99);
  --jodoh-hero-end: rgba(255, 226, 238, 0.96);
  --jodoh-hero-spot: rgba(232, 73, 137, 0.24);
  --jodoh-panel-start: rgba(255, 251, 253, 0.96);
  --jodoh-panel-end: rgba(255, 239, 245, 0.94);
  --jodoh-panel-border: rgba(211, 88, 131, 0.16);
  --jodoh-panel-inset: rgba(255, 255, 255, 0.66);
  --jodoh-official-start: rgba(255, 250, 252, 0.98);
  --jodoh-official-end: rgba(255, 241, 246, 0.94);
  --jodoh-estimated-start: rgba(255, 242, 247, 0.98);
  --jodoh-estimated-end: rgba(255, 231, 239, 0.94);
  --jodoh-pill-official-bg: rgba(137, 36, 88, 0.09);
  --jodoh-pill-estimated-bg: rgba(234, 89, 143, 0.13);
  --jodoh-pill-private-bg: rgba(255, 223, 233, 0.88);
  --jodoh-accent: #cc4f87;
  --jodoh-accent-strong: #f065a2;
  --jodoh-glow: rgba(240, 101, 162, 0.28);
  --jodoh-ring-track: rgba(211, 88, 131, 0.12);
  --jodoh-ring-fill-start: #d6538e;
  --jodoh-ring-fill-end: #ff8ab8;
  --jodoh-dot-idle: rgba(208, 178, 192, 0.68);
  --jodoh-dot-active: rgba(214, 83, 142, 0.96);
  --jodoh-toggle-bg: rgba(255, 255, 255, 0.72);
  --jodoh-toggle-border: rgba(211, 88, 131, 0.12);
  --jodoh-toggle-selected: rgba(255, 229, 239, 0.92);
  --jodoh-control-surface-start: rgba(255, 255, 255, 0.52);
  --jodoh-control-surface-end: rgba(255, 255, 255, 0.3);
  --jodoh-control-surface-strong-start: rgba(255, 255, 255, 0.74);
  --jodoh-control-surface-strong-end: rgba(255, 255, 255, 0.6);
  --jodoh-control-surface-inset: rgba(255, 255, 255, 0.34);
  --jodoh-result-surface-start: rgba(255, 255, 255, 0.72);
  --jodoh-result-surface-end: rgba(255, 255, 255, 0.52);
  --jodoh-result-surface-inset: rgba(255, 255, 255, 0.46);
  --jodoh-disclosure-surface-start: rgba(255, 252, 254, 0.76);
  --jodoh-disclosure-surface-end: rgba(255, 241, 247, 0.6);
  --jodoh-disclosure-surface-inset: rgba(255, 255, 255, 0.42);
  --jodoh-official-overlay-start: rgba(255, 255, 255, 0.78);
  --jodoh-official-overlay-end: rgba(255, 255, 255, 0.62);
  --jodoh-note-bg: rgba(255, 243, 248, 0.88);
  --jodoh-note-border: rgba(234, 89, 143, 0.16);
  --jodoh-private-text: #7d3a5b;
  --table-head-bg: #edf4ff;
  --error-bg: #fff5f5;
  --focus-ring: rgba(11, 60, 138, 0.32);
  --result-divider: rgba(19, 32, 61, 0.08);
  --form-support-text: #5c6b88;
  --theme-toggle-bg: #ffffff;
  --theme-toggle-color: var(--text);
  --button-primary-strong: #356bc4;
  --section-card-border-opacity: 0.18;
  --section-field-border-opacity: 0.16;
  --section-card-accent-opacity: 0.06;
  --section-card-surface-start: rgba(255, 255, 255, 0.98);
  --section-card-surface-end: rgba(248, 251, 255, 0.96);
  --section-card-inset: rgba(255, 255, 255, 0.7);
  --section-field-surface-start: rgba(255, 255, 255, 0.96);
  --section-field-accent-opacity: 0.03;
  --section-conditional-accent-opacity: 0.06;
  --section-conditional-surface-end: rgba(255, 255, 255, 0.92);
  --metric-tone-epf-employee-rgb: 11, 60, 138;
  --metric-tone-epf-employer-rgb: 196, 31, 61;
  --metric-tone-epf-account-1-rgb: 11, 138, 87;
  --metric-tone-epf-account-2-rgb: 184, 95, 0;
  --metric-tone-epf-account-3-rgb: 0, 109, 169;
  --metric-tone-epf-account-emas-rgb: 142, 105, 0;
  --metric-tone-pcb-monthly-rgb: 11, 60, 138;
  --metric-tone-pcb-annual-rgb: 196, 31, 61;
  --metric-tone-pcb-chargeable-rgb: 11, 138, 87;
  --calc-shell-bg: linear-gradient(165deg, rgba(23, 35, 58, 0.94) 0%, rgba(12, 21, 38, 0.96) 100%);
  --calc-shell-border: rgba(173, 194, 230, 0.28);
  --calc-screen-bg: linear-gradient(180deg, rgba(8, 15, 27, 0.92) 0%, rgba(16, 27, 46, 0.96) 100%);
  --calc-screen-border: rgba(173, 194, 230, 0.22);
  --calc-expression-color: #a9bcdf;
  --calc-result-color: #eff5ff;
  --calc-key-bg: rgba(14, 24, 41, 0.96);
  --calc-key-border: rgba(173, 194, 230, 0.34);
  --calc-key-shadow: 0 8px 18px rgba(0, 0, 0, 0.3);
  --calc-key-text: #e8eefc;
  --calc-key-utility-bg: rgba(255, 123, 150, 0.18);
  --calc-key-utility-text: #ffadc0;
  --calc-key-operator-bg: rgba(143, 180, 255, 0.18);
  --calc-key-operator-text: #c9dcff;
  --calc-key-active-bg: rgba(143, 180, 255, 0.26);
  --calc-accent: #8fb4ff;
  --calc-equals-start: #8fb4ff;
  --calc-equals-end: #6f97e7;
  --calc-nudge-color: #9db0d7;
  --calc-key-size: 3.2rem;
  --calc-key-gap: 0.52rem;
  --calc-shell-width: 19.25rem;
  --calc-key-radius: 999px;
  --radius-lg: 20px;
  --radius-md: 14px;
  --radius-sm: 10px;
}

:root[data-theme='dark'] {
  color-scheme: dark;
  --bg: #090f1c;
  --bg-accent: #0d1527;
  --bg-end: #0b1422;
  --surface: rgba(17, 27, 46, 0.84);
  --surface-solid: #111b2f;
  --text: #e8eefc;
  --muted: #b2c0dc;
  --primary: #8fb4ff;
  --primary-strong: #6f97e7;
  --secondary: #ff7b96;
  --secondary-strong: #e86480;
  --primary-soft: rgba(143, 180, 255, 0.16);
  --line: rgba(173, 194, 230, 0.22);
  --line-strong: rgba(173, 194, 230, 0.34);
  --shadow: 0 14px 35px rgba(0, 0, 0, 0.45);
  --shadow-soft: 0 8px 20px rgba(0, 0, 0, 0.35);
  --success: #52d49d;
  --danger: #ff8c86;
  --bg-spot-primary: rgba(105, 146, 227, 0.28);
  --bg-spot-secondary: rgba(255, 123, 150, 0.18);
  --grid-line: rgba(174, 194, 228, 0.07);
  --nav-pill-bg: rgba(143, 180, 255, 0.12);
  --control-bg: rgba(12, 20, 36, 0.92);
  --stat-panel-start: rgba(85, 123, 198, 0.9);
  --stat-panel-end: rgba(48, 78, 138, 0.92);
  --stat-panel-text: #e9f0ff;
  --stat-panel-muted: rgba(233, 240, 255, 0.94);
  --stat-panel-line: rgba(233, 240, 255, 0.22);
  --category-surface-start: rgba(25, 38, 64, 0.92);
  --category-surface-end: rgba(17, 27, 46, 0.95);
  --newsletter-surface-start: rgba(24, 37, 61, 0.92);
  --newsletter-surface-end: rgba(15, 24, 42, 0.95);
  --input-bg: rgba(12, 20, 36, 0.9);
  --metric-bg: rgba(17, 29, 49, 0.9);
  --share-panel-start: rgba(21, 34, 57, 0.96);
  --share-panel-end: rgba(12, 22, 39, 0.98);
  --share-panel-spot: rgba(255, 123, 150, 0.18);
  --share-panel-border: rgba(143, 180, 255, 0.24);
  --share-panel-inset: rgba(173, 194, 230, 0.12);
  --share-button-start: #8fb4ff;
  --share-button-end: #6f97e7;
  --share-button-text: #09101d;
  --jodoh-hero-start: rgba(63, 24, 46, 0.94);
  --jodoh-hero-end: rgba(27, 11, 27, 0.99);
  --jodoh-hero-spot: rgba(255, 121, 186, 0.22);
  --jodoh-panel-start: rgba(48, 19, 39, 0.96);
  --jodoh-panel-end: rgba(28, 13, 28, 0.98);
  --jodoh-panel-border: rgba(255, 154, 203, 0.22);
  --jodoh-panel-inset: rgba(255, 202, 227, 0.08);
  --jodoh-official-start: rgba(58, 24, 49, 0.94);
  --jodoh-official-end: rgba(36, 16, 35, 0.98);
  --jodoh-estimated-start: rgba(76, 27, 53, 0.94);
  --jodoh-estimated-end: rgba(45, 17, 34, 0.98);
  --jodoh-pill-official-bg: rgba(255, 190, 224, 0.16);
  --jodoh-pill-estimated-bg: rgba(255, 132, 185, 0.2);
  --jodoh-pill-private-bg: rgba(255, 223, 233, 0.12);
  --jodoh-accent: #ff83bb;
  --jodoh-accent-strong: #ffabd4;
  --jodoh-glow: rgba(255, 131, 187, 0.28);
  --jodoh-ring-track: rgba(255, 167, 207, 0.12);
  --jodoh-ring-fill-start: #ff6fac;
  --jodoh-ring-fill-end: #ffb3d8;
  --jodoh-dot-idle: rgba(228, 176, 203, 0.34);
  --jodoh-dot-active: rgba(255, 132, 185, 0.96);
  --jodoh-toggle-bg: rgba(40, 18, 35, 0.92);
  --jodoh-toggle-border: rgba(255, 154, 203, 0.2);
  --jodoh-toggle-selected: rgba(96, 36, 67, 0.96);
  --jodoh-control-surface-start: rgba(112, 72, 96, 0.7);
  --jodoh-control-surface-end: rgba(73, 39, 61, 0.84);
  --jodoh-control-surface-strong-start: rgba(128, 86, 110, 0.78);
  --jodoh-control-surface-strong-end: rgba(88, 52, 72, 0.9);
  --jodoh-control-surface-inset: rgba(255, 214, 233, 0.12);
  --jodoh-result-surface-start: rgba(48, 19, 39, 0.96);
  --jodoh-result-surface-end: rgba(28, 13, 28, 0.98);
  --jodoh-result-surface-inset: rgba(255, 214, 233, 0.12);
  --jodoh-disclosure-surface-start: rgba(48, 19, 39, 0.96);
  --jodoh-disclosure-surface-end: rgba(28, 13, 28, 0.98);
  --jodoh-disclosure-surface-inset: rgba(255, 214, 233, 0.1);
  --jodoh-official-overlay-start: rgba(121, 82, 105, 0.66);
  --jodoh-official-overlay-end: rgba(82, 46, 67, 0.76);
  --jodoh-note-bg: rgba(48, 19, 39, 0.96);
  --jodoh-note-border: rgba(255, 132, 185, 0.18);
  --jodoh-private-text: #ffd7eb;
  --table-head-bg: rgba(26, 41, 70, 0.94);
  --error-bg: rgba(72, 20, 23, 0.55);
  --focus-ring: rgba(143, 180, 255, 0.45);
  --result-divider: rgba(173, 194, 230, 0.16);
  --form-support-text: #c0cee7;
  --theme-toggle-bg: rgba(143, 180, 255, 0.12);
  --theme-toggle-color: #f3f7ff;
  --button-primary-strong: #6f97e7;
  --section-card-border-opacity: 0.28;
  --section-field-border-opacity: 0.24;
  --section-card-accent-opacity: 0.11;
  --section-card-surface-start: rgba(20, 33, 56, 0.97);
  --section-card-surface-end: rgba(14, 24, 43, 0.99);
  --section-card-inset: rgba(173, 194, 230, 0.1);
  --section-field-surface-start: rgba(18, 30, 51, 0.98);
  --section-field-accent-opacity: 0.12;
  --section-conditional-accent-opacity: 0.12;
  --section-conditional-surface-end: rgba(18, 30, 51, 0.98);
  --metric-tone-epf-employee-rgb: 143, 180, 255;
  --metric-tone-epf-employer-rgb: 255, 123, 150;
  --metric-tone-epf-account-1-rgb: 82, 212, 157;
  --metric-tone-epf-account-2-rgb: 255, 177, 72;
  --metric-tone-epf-account-3-rgb: 112, 198, 255;
  --metric-tone-epf-account-emas-rgb: 255, 208, 108;
  --metric-tone-pcb-monthly-rgb: 143, 180, 255;
  --metric-tone-pcb-annual-rgb: 255, 123, 150;
  --metric-tone-pcb-chargeable-rgb: 82, 212, 157;
  --calc-shell-bg: linear-gradient(165deg, #ffffff 0%, #f1f7ff 100%);
  --calc-shell-border: rgba(19, 32, 61, 0.2);
  --calc-screen-bg: linear-gradient(180deg, #e9f2ff 0%, #f8fbff 100%);
  --calc-screen-border: rgba(19, 32, 61, 0.16);
  --calc-expression-color: #445376;
  --calc-result-color: #0f356f;
  --calc-key-bg: #ffffff;
  --calc-key-border: rgba(19, 32, 61, 0.22);
  --calc-key-shadow: 0 6px 14px rgba(19, 32, 61, 0.08);
  --calc-key-text: #13203d;
  --calc-key-utility-bg: #e9f1ff;
  --calc-key-utility-text: #cb3a56;
  --calc-key-operator-bg: #edf4ff;
  --calc-key-operator-text: #0b3c8a;
  --calc-key-active-bg: #dce9ff;
  --calc-accent: #0b3c8a;
  --calc-equals-start: #0b3c8a;
  --calc-equals-end: #356bc4;
  --calc-nudge-color: #4f5d79;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
}

body {
  font-family: 'Manrope', 'Segoe UI', sans-serif;
  color: var(--text);
  min-height: 100vh;
  background:
    radial-gradient(1200px 600px at 0% 0%, var(--bg-spot-primary), transparent 45%),
    radial-gradient(800px 400px at 100% 0%, var(--bg-spot-secondary), transparent 45%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg-accent) 48%, var(--bg-end) 100%);
}

body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image: linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size: 32px 32px;
  opacity: 0.45;
  z-index: -2;
}

a {
  color: inherit;
}

main,
.site-footer,
.site-header {
  width: min(1140px, calc(100vw - 2rem));
  margin-inline: auto;
}

body[data-page='calculator'] main,
body[data-page='calculator'] .site-footer,
body[data-page='calculator'] .site-header {
  width: min(1360px, calc(100vw - 2.5rem));
}

.site-header {
  margin-top: 1rem;
  margin-bottom: 1.5rem;
  padding: 1rem 1.1rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--surface);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: var(--shadow-soft);
  display: grid;
  grid-template-columns: 1fr auto auto auto;
  gap: 1rem;
  align-items: center;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin: 0;
  text-decoration: none;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  letter-spacing: 0.01em;
  font-size: clamp(1.3rem, 2vw, 1.65rem);
}

.brand-logo {
  display: inline-grid;
  place-items: center;
  width: 1.45rem;
  height: 1.45rem;
  font-size: 1.2rem;
  line-height: 1;
}

.brand-text {
  line-height: 1;
}

.brand-tagline {
  margin: 0.2rem 0 0;
  color: var(--muted);
  font-size: 0.88rem;
}

.main-nav {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.main-nav a {
  text-decoration: none;
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--text);
  background: var(--nav-pill-bg);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 0.45rem 0.75rem;
  transition: all 150ms ease;
}

.main-nav a:hover,
.main-nav a:focus-visible {
  border-color: rgba(11, 60, 138, 0.36);
  color: var(--primary);
  transform: translateY(-1px);
}

.lang-switch {
  display: inline-flex;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  overflow: hidden;
  background: var(--control-bg);
}

.lang-switch button {
  border: 0;
  width: 2.8rem;
  height: 2.2rem;
  background: transparent;
  color: var(--text);
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
  cursor: pointer;
}

.lang-switch button.active {
  color: #fff;
  background: linear-gradient(135deg, var(--primary), var(--primary-strong));
}

.theme-toggle {
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  width: 2.6rem;
  height: 2.2rem;
  background: var(--theme-toggle-bg);
  color: var(--theme-toggle-color);
  font-size: 1rem;
  line-height: 1;
  font-weight: 650;
  cursor: pointer;
  transition: transform 150ms ease, background 150ms ease;
}

.theme-toggle.active {
  color: #fff;
  background: linear-gradient(135deg, var(--primary), var(--primary-strong));
}

.theme-toggle:hover,
.theme-toggle:focus-visible {
  transform: translateY(-1px);
}

h1,
h2,
h3,
.kicker,
.metric-value,
.calculator-badge,
.category-name {
  font-family: 'Space Grotesk', sans-serif;
  letter-spacing: -0.01em;
}

h1 {
  margin: 0.55rem 0;
  font-size: clamp(2rem, 5vw, 3.6rem);
  line-height: 1.06;
  font-weight: 700;
}

h2 {
  margin: 0;
  font-size: clamp(1.35rem, 2.6vw, 2rem);
  font-weight: 650;
}

h3 {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 650;
}

.home-intro-shell {
  display: grid;
  gap: 1rem;
  margin-bottom: 1.7rem;
}

.home-search-strip-section {
  margin-top: 0;
  inline-size: 100%;
}

.home-intro-shell .hero-grid {
  margin-bottom: 0;
}

.home-calculator {
  border: 1px solid var(--calc-shell-border);
  border-radius: var(--radius-lg);
  background: var(--calc-shell-bg);
  box-shadow: var(--shadow-soft);
  padding: clamp(0.9rem, 2.2vw, 1.15rem);
  inline-size: min(100%, var(--calc-shell-width));
  justify-self: center;
  display: grid;
  gap: 0.7rem;
}

.home-calculator-screen {
  padding: clamp(0.82rem, 2.1vw, 1rem);
  border: 1px solid var(--calc-screen-border);
  border-radius: calc(var(--radius-md) + 1px);
  background: var(--calc-screen-bg);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.16);
}

.home-calc-expression,
.home-calc-result {
  margin: 0;
  font-family: 'Space Grotesk', sans-serif;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
  word-break: break-word;
  text-align: right;
}

.home-calc-expression {
  color: var(--calc-expression-color);
  min-height: 1.5rem;
  font-size: clamp(1rem, 2.7vw, 1.3rem);
}

.home-calc-result {
  margin-top: 0.34rem;
  color: var(--calc-result-color);
  min-height: 1.95rem;
  font-size: clamp(1.2rem, 3.4vw, 1.6rem);
  font-weight: 700;
}

.home-calc-result.is-error {
  color: var(--danger);
  font-size: 1rem;
}

.home-calculator-keypad {
  display: grid;
  inline-size: 100%;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--calc-key-gap);
  grid-auto-rows: var(--calc-key-size);
}

.calc-key {
  min-height: var(--calc-key-size);
  block-size: var(--calc-key-size);
  border: 1px solid var(--calc-key-border);
  border-radius: var(--calc-key-radius);
  background: var(--calc-key-bg);
  color: var(--calc-key-text);
  font: inherit;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  font-size: 1rem;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  box-shadow: var(--calc-key-shadow);
  touch-action: manipulation;
  transition: transform 120ms ease, border-color 120ms ease, background-color 120ms ease, box-shadow 120ms ease;
}

.calc-key:hover,
.calc-key:focus-visible {
  transform: translateY(-1px);
  border-color: var(--calc-accent);
}

.calc-key:active {
  transform: translateY(1px);
  background: var(--calc-key-active-bg);
  box-shadow: none;
}

.calc-key-utility {
  color: var(--calc-key-utility-text);
  background: var(--calc-key-utility-bg);
}

.calc-key-operator {
  color: var(--calc-key-operator-text);
  background: var(--calc-key-operator-bg);
}

.calc-key-zero {
  grid-column: span 2;
  border-radius: var(--calc-key-radius);
}

.calc-key-equals {
  color: #fff;
  border-color: transparent;
  background: linear-gradient(135deg, var(--calc-equals-start), var(--calc-equals-end));
}

.calc-key-equals:active {
  filter: brightness(0.96);
}

.home-calc-nudge {
  margin-top: 0.15rem;
  display: grid;
  place-items: center;
  text-decoration: none;
  color: var(--calc-nudge-color);
  font-size: 1.35rem;
  line-height: 1;
  transition: transform 140ms ease, color 140ms ease;
}

.home-calc-nudge:hover,
.home-calc-nudge:focus-visible {
  transform: translateY(2px);
  color: var(--calc-accent);
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.45fr 1fr;
  gap: 1rem;
  margin-bottom: 1.75rem;
}

.hero-grid > div,
.hero-stat-block {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--surface);
  box-shadow: var(--shadow-soft);
}

.hero-grid > div {
  padding: clamp(1rem, 2.6vw, 1.8rem);
}

.hero-stat-block {
  padding: 1.1rem;
  background: linear-gradient(145deg, var(--stat-panel-start), var(--stat-panel-end));
  color: var(--stat-panel-text);
}

.hero-stat-block h2 {
  color: #fff;
}

.hero-stat-block p {
  margin: 0.75rem 0 0;
  color: var(--stat-panel-muted);
}

.hero-stat-block .snapshot {
  margin-top: 1rem;
  padding-top: 0.8rem;
  border-top: 1px solid var(--stat-panel-line);
  color: #fff;
  font-weight: 600;
}

.search-strip-section {
  margin-top: -0.4rem;
}

body[data-page='calculator'] .calculator-inline-search-section,
body[data-page='unit-conversion'] .calculator-inline-search-section {
  margin-top: 0;
  margin-bottom: 0.72rem;
}

body[data-page='calculator'] .search-strip,
body[data-page='unit-conversion'] .search-strip {
  padding: 0.58rem 0.64rem;
}

body[data-page='calculator'] .search-strip-input,
body[data-page='unit-conversion'] .search-strip-input {
  padding: 0.66rem 0.72rem;
}

body[data-page='calculator'] .search-strip-placeholder,
body[data-page='unit-conversion'] .search-strip-placeholder {
  left: 0.72rem;
  right: 0.72rem;
}

body[data-page='calculator'] .search-strip-status,
body[data-page='unit-conversion'] .search-strip-status {
  margin-top: 0.34rem;
}

.search-strip {
  position: relative;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--surface);
  box-shadow: var(--shadow-soft);
  padding: 0.7rem 0.78rem;
}

.search-strip-input-wrap {
  position: relative;
}

.search-sort-field {
  display: grid;
  gap: 0.36rem;
  min-width: min(100%, 13rem);
}

.search-sort-label {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--muted);
}

.search-sort-select {
  min-height: 2.8rem;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-sm);
  background: var(--input-bg);
  color: var(--text);
  padding: 0.72rem 2.2rem 0.72rem 0.78rem;
  font: inherit;
}

.search-strip-input {
  width: 100%;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-sm);
  background: var(--input-bg);
  color: var(--text);
  padding: 0.72rem 0.78rem;
  font: inherit;
  font-size: 0.96rem;
}

.search-strip-input-rotating.has-trending-hints::placeholder {
  color: transparent;
}

.search-strip-placeholder {
  position: absolute;
  top: 50%;
  left: 0.78rem;
  right: 0.78rem;
  transform: translateY(-50%);
  color: var(--muted);
  opacity: 0.7;
  pointer-events: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: opacity 240ms ease;
}

.search-strip-placeholder.is-fading,
.search-strip-input-rotating:focus + .search-strip-placeholder,
.search-strip-input-rotating:not(:placeholder-shown) + .search-strip-placeholder {
  opacity: 0;
}

.search-strip-placeholder:empty {
  opacity: 0;
}

.search-strip-status {
  margin: 0.42rem 0 0;
  min-height: 1.05rem;
  color: var(--muted);
  font-size: 0.86rem;
}

.search-quick-results {
  position: absolute;
  top: calc(100% + 0.32rem);
  left: 0;
  right: 0;
  z-index: 25;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-md);
  background: var(--surface-solid);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.search-quick-results[hidden] {
  display: none;
}

.search-empty {
  margin: 0;
  padding: 0.72rem 0.8rem;
  color: var(--muted);
  font-size: 0.9rem;
}

.search-result-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.search-result-list li + li {
  border-top: 1px solid var(--line);
}

.search-result-list a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.7rem;
  padding: 0.62rem 0.8rem;
  text-decoration: none;
  color: var(--text);
  background: transparent;
  transition: background 140ms ease;
}

.search-result-list a:hover,
.search-result-list a:focus-visible {
  background: var(--primary-soft);
}

.search-result-title {
  font-weight: 650;
  font-size: 0.92rem;
}

.search-result-meta {
  color: var(--muted);
  font-size: 0.78rem;
  text-align: right;
  white-space: nowrap;
}

.search-view-all {
  display: block;
  border-top: 1px solid var(--line);
  padding: 0.62rem 0.8rem;
  color: var(--primary);
  font-size: 0.88rem;
  font-weight: 600;
  text-decoration: none;
}

.search-view-all:hover,
.search-view-all:focus-visible {
  text-decoration: underline;
}

.kicker {
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.86rem;
  color: var(--secondary);
}

.kicker::before {
  content: '';
  width: 0.52rem;
  height: 0.52rem;
  border-radius: 50%;
  background: var(--secondary);
}

.hero-copy {
  margin: 0.5rem 0 0;
  max-width: 60ch;
  color: var(--muted);
  font-size: clamp(1rem, 1.7vw, 1.14rem);
}

.hero-actions {
  margin-top: 1.1rem;
  display: flex;
  gap: 0.7rem;
  flex-wrap: wrap;
}

.button {
  text-decoration: none;
  border-radius: 12px;
  padding: 0.72rem 1rem;
  font-weight: 700;
  font-size: 0.88rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform 150ms ease, box-shadow 150ms ease;
}

.button-primary {
  color: #fff;
  background: linear-gradient(135deg, var(--primary), var(--button-primary-strong));
  box-shadow: 0 10px 22px rgba(11, 60, 138, 0.26);
}

.button-ghost {
  color: var(--primary);
  background: var(--primary-soft);
  border: 1px solid rgba(11, 60, 138, 0.2);
}

.button:hover,
.button:focus-visible {
  transform: translateY(-1px);
}

.section {
  margin-bottom: 1.7rem;
}

.section-head {
  margin-bottom: 0.9rem;
}

.hub-grid-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 0.9rem;
  flex-wrap: wrap;
}

.hub-grid-sort {
  display: grid;
  gap: 0.36rem;
  min-width: min(100%, 16rem);
}

.related-calculators-section {
  margin-top: 1.2rem;
}

.related-calculators-grid {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.section-head p {
  margin: 0.45rem 0 0;
  color: var(--muted);
}

.category-grid,
.calculator-grid {
  display: grid;
  gap: 0.85rem;
}

.category-grid {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.category-card,
.calculator-card {
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--surface-solid);
  box-shadow: var(--shadow-soft);
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.category-card {
  padding: 1rem;
  background: linear-gradient(180deg, var(--category-surface-start), var(--category-surface-end));
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.category-card:hover,
.calculator-card:hover {
  transform: translateY(-2px);
  border-color: rgba(11, 60, 138, 0.2);
  box-shadow: var(--shadow);
}

.category-name {
  margin: 0;
  font-size: 1rem;
}

.emoji-mark {
  display: inline-block;
  margin-right: 0.42rem;
  font-size: 1em;
  transform: translateY(1px);
}

.category-count {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
}

.category-links {
  display: grid;
  gap: 0.4rem;
}

.category-links a {
  text-decoration: none;
  font-weight: 600;
  color: var(--primary);
}

.category-links-extra[hidden] {
  display: none;
}

.category-card-actions {
  margin-top: auto;
  display: flex;
  align-items: center;
  gap: 0.55rem;
  flex-wrap: wrap;
}

.featured-actions {
  margin-top: 0.85rem;
  display: flex;
  align-items: center;
  gap: 0.55rem;
  flex-wrap: wrap;
}

.category-toggle,
.featured-toggle {
  border: 1px solid rgba(11, 60, 138, 0.28);
  border-radius: 999px;
  background: rgba(11, 60, 138, 0.08);
  color: var(--secondary);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1;
  padding: 0.45rem 0.72rem;
  cursor: pointer;
  transition: background-color 150ms ease, border-color 150ms ease, transform 150ms ease;
}

.category-toggle:hover,
.category-toggle:focus-visible,
.featured-toggle:hover,
.featured-toggle:focus-visible {
  background: rgba(11, 60, 138, 0.16);
  border-color: rgba(11, 60, 138, 0.4);
}

.category-view-all,
.featured-view-all {
  margin-left: auto;
  text-decoration: none;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--primary);
}

.category-view-all:hover,
.category-view-all:focus-visible,
.featured-view-all:hover,
.featured-view-all:focus-visible {
  text-decoration: underline;
}

.category-links a:hover,
.category-links a:focus-visible {
  text-decoration: underline;
}

.calculator-grid {
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

.featured-overflow-group[hidden] {
  display: none;
}

.featured-overflow-group:not([hidden]) {
  display: contents;
}

.hub-calculator-grid {
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
}

body[data-page='calculators-hub'] .hub-calculator-grid {
  align-items: stretch;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 17rem), 1fr));
}

body[data-page='calculators-hub'] .hub-calculator-card {
  min-height: 15rem;
  gap: 0.8rem;
}

body[data-page='calculators-hub'] .hub-calculator-card .calculator-badge {
  min-height: 1.2rem;
}

body[data-page='calculators-hub'] .hub-calculator-card h3 {
  margin: 0;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

body[data-page='calculators-hub'] .hub-calculator-card > p:last-of-type {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

body[data-page='calculators-hub'] .hub-calculator-card .card-action {
  margin-top: auto;
}

.hub-calculator-meta {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  border-radius: 999px;
  padding: 0.34rem 0.62rem;
  background: var(--primary-soft);
  color: var(--primary);
  font-size: 0.8rem;
  font-weight: 700;
}

.calculator-grid-empty {
  margin: 0;
  border: 1px dashed var(--line-strong);
  border-radius: var(--radius-md);
  padding: 1rem;
  background: var(--surface);
  color: var(--muted);
}

.calculator-card {
  padding: 1rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.7rem;
  height: 100%;
}

.calculator-badge {
  margin: 0;
  color: var(--secondary);
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

.calculator-card h3 {
  line-height: 1.25;
}

.calculator-card p {
  margin: 0;
  color: var(--muted);
}

#trending-grid {
  display: block;
  min-height: 18rem;
}

.trending-empty {
  margin: 0;
  border: 1px dashed var(--line-strong);
  border-radius: var(--radius-md);
  background: var(--surface);
  color: var(--muted);
  padding: 1rem;
}

.trending-marquee {
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  scrollbar-width: none;
  -ms-overflow-style: none;
  -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 7%, #000 93%, transparent 100%);
  mask-image: linear-gradient(to right, transparent 0%, #000 7%, #000 93%, transparent 100%);
}

.trending-marquee::-webkit-scrollbar {
  display: none;
}


.trending-marquee.trending-speed-fast {
  --trending-duration: 42s;
}

.trending-marquee.trending-speed-medium {
  --trending-duration: 54s;
}

.trending-marquee.trending-speed-slow {
  --trending-duration: 72s;
}

.trending-track {
  display: flex;
  width: max-content;
  animation: trending-scroll var(--trending-duration, 48s) linear infinite;
  will-change: transform;
}

.trending-marquee.is-paused .trending-track {
  animation-play-state: paused;
}

.trending-set {
  display: flex;
  align-items: stretch;
  gap: 0.85rem;
  padding-right: 0.85rem;
  flex-shrink: 0;
}

.trending-card {
  display: flex;
  flex-direction: column;
  flex: 0 0 clamp(250px, 28vw, 320px);
  max-width: clamp(250px, 28vw, 320px);
  min-height: 0;
}

.trending-description {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 3.9em;
}

.trending-count {
  margin-top: auto;
  margin-bottom: 0.45rem;
  font-size: 0.86rem;
  color: var(--secondary);
}

.trending-action {
  margin-top: 0;
}

@keyframes trending-scroll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .trending-marquee {
    -webkit-mask-image: none;
    mask-image: none;
  }

  .trending-track {
    animation: none;
  }
}

.card-action {
  margin-top: auto;
  text-decoration: none;
  color: #fff;
  background: linear-gradient(135deg, var(--secondary), var(--secondary-strong));
  border-radius: var(--radius-sm);
  padding: 0.58rem 0.8rem;
  font-size: 0.82rem;
  font-weight: 700;
  width: fit-content;
}

.card-action:hover,
.card-action:focus-visible {
  filter: brightness(1.02);
}

.newsletter-block {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: linear-gradient(145deg, var(--newsletter-surface-start), var(--newsletter-surface-end));
  box-shadow: var(--shadow-soft);
  padding: 1rem;
  margin-bottom: 2rem;
}

.newsletter-block.compact {
  margin-top: 1.2rem;
}

.newsletter-block h2 {
  margin-bottom: 0.45rem;
}

.newsletter-block p {
  margin: 0 0 0.8rem;
  color: var(--muted);
}

.newsletter-block form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.65rem;
  align-items: center;
}

.newsletter-block input,
.field input,
.field select {
  width: 100%;
  font: inherit;
  color: var(--text);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-sm);
  background: var(--input-bg);
  padding: 0.68rem 0.72rem;
  transition: border-color 140ms ease, box-shadow 140ms ease, background-color 140ms ease;
}

.field select {
  appearance: none;
  -webkit-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, currentColor 50%),
    linear-gradient(135deg, currentColor 50%, transparent 50%);
  background-position:
    calc(100% - 18px) calc(50% + 1px),
    calc(100% - 12px) calc(50% + 1px);
  background-repeat: no-repeat;
  background-size: 6px 6px;
  padding-right: 2.3rem;
}

.field > input:focus-visible,
.field > select:focus-visible,
.newsletter-block input:focus-visible {
  outline: 0;
  border-color: rgba(var(--field-section-accent-rgb, 11, 60, 138), 0.58);
  box-shadow: 0 0 0 3px rgba(var(--field-section-accent-rgb, 11, 60, 138), 0.14);
}

.newsletter-block button {
  border: 0;
  border-radius: var(--radius-sm);
  background: linear-gradient(135deg, var(--primary), var(--button-primary-strong));
  color: #fff;
  padding: 0.72rem 1rem;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
}

.newsletter-block button:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

.form-status {
  grid-column: 1 / -1;
  margin: 0;
  min-height: 1.15rem;
  font-size: 0.9rem;
}

.form-status.ok {
  color: var(--success);
}

.form-status.error {
  color: var(--danger);
}

.site-footer {
  margin-bottom: 1rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--surface);
  padding: 0.9rem 1rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 0.7rem;
  color: var(--muted);
  font-size: 0.9rem;
}

.site-footer p {
  margin: 0;
}

.back-link {
  display: inline-block;
  margin-bottom: 0.65rem;
  text-decoration: none;
  color: var(--primary);
  font-weight: 600;
}

body[data-page='methodology'] .back-link {
  display: inline-flex;
  align-items: center;
  min-height: 2.75rem;
  padding: 0.35rem 0.72rem;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-solid);
}

body[data-page='methodology'] .theme-toggle,
body[data-page='methodology'] .lang-switch button {
  min-width: 2.75rem;
  min-height: 2.75rem;
}

.back-link:hover,
.back-link:focus-visible {
  text-decoration: underline;
}

.calculator-hero {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--surface);
  box-shadow: var(--shadow-soft);
  padding: 0.9rem;
  margin-bottom: 0.82rem;
}

.calculator-hero h1 {
  margin: 0.38rem 0 0.28rem;
  font-size: clamp(1.68rem, 3.4vw, 2.5rem);
  line-height: 1.06;
}

.calculator-hero p {
  margin: 0.36rem 0 0;
  color: var(--muted);
}

.rule-meta {
  margin-top: 0.62rem;
  padding-top: 0.56rem;
  border-top: 1px solid var(--line);
  display: grid;
  gap: 0.22rem;
}

.rule-meta p {
  margin: 0;
  color: var(--muted);
}

.rule-meta strong {
  color: var(--text);
}

.calculator-share-panel {
  margin-top: 0.72rem;
  padding: 0.68rem 0.78rem;
  border: 1px solid var(--share-panel-border);
  border-radius: calc(var(--radius-md) + 2px);
  background:
    radial-gradient(circle at 100% 0%, var(--share-panel-spot), transparent 38%),
    linear-gradient(135deg, var(--share-panel-start) 0%, var(--share-panel-end) 100%);
  box-shadow: inset 0 1px 0 var(--share-panel-inset);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.72rem;
}

.calculator-share-panel[data-share-state='success'] {
  border-color: color-mix(in srgb, var(--success) 44%, var(--share-panel-border));
}

.calculator-share-panel[data-share-state='error'] {
  border-color: color-mix(in srgb, var(--danger) 52%, var(--share-panel-border));
}

.calculator-share-copy {
  min-width: 0;
  display: grid;
  gap: 0.22rem;
}

.calculator-share-label,
.calculator-share-status {
  margin: 0;
}

.calculator-share-label {
  color: var(--text);
  font-family: 'Space Grotesk', sans-serif;
  font-size: 0.91rem;
  font-weight: 700;
  line-height: 1.2;
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  flex-wrap: wrap;
}

.calculator-share-emoji {
  width: 1.45rem;
  height: 1.45rem;
  border-radius: 999px;
  background: rgba(208, 61, 88, 0.12);
  box-shadow: inset 0 0 0 1px rgba(208, 61, 88, 0.14);
  display: inline-grid;
  place-items: center;
  font-size: 0.9rem;
  line-height: 1;
}

.calculator-share-status {
  color: var(--muted);
  font-size: 0.8rem;
  line-height: 1.38;
}

.calculator-share-button {
  flex-shrink: 0;
  min-height: 2.75rem;
  padding: 0.48rem 0.78rem 0.48rem 0.62rem;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--share-button-start), var(--share-button-end));
  color: var(--share-button-text);
  box-shadow: 0 12px 24px rgba(16, 34, 73, 0.18);
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font: inherit;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: transform 120ms ease, box-shadow 120ms ease, filter 120ms ease;
}

.calculator-share-button:hover,
.calculator-share-button:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 14px 28px rgba(16, 34, 73, 0.24);
  filter: saturate(1.06);
}

.calculator-share-button:focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 2px;
}

.calculator-share-button-icon {
  width: 1.55rem;
  height: 1.55rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.18);
  display: inline-grid;
  place-items: center;
  font-size: 0.98rem;
  line-height: 1;
}

body[data-page='calculator'][data-calculator='jodoh'] .calculator-hero {
  position: relative;
  overflow: hidden;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-bottom: 0;
  padding: clamp(1rem, 2.6vw, 2rem) clamp(1rem, 4vw, 2.5rem) clamp(2.4rem, 6vw, 4rem);
  border-radius: 0;
  border-left: 0;
  border-right: 0;
  border-top: 0;
  border-color: var(--jodoh-panel-border);
  background:
    linear-gradient(180deg, rgba(84, 42, 62, 0.12) 0, rgba(84, 42, 62, 0.04) 1.2rem, transparent 2.9rem),
    radial-gradient(circle at 82% 24%, color-mix(in srgb, var(--jodoh-accent) 26%, transparent), transparent 24%),
    radial-gradient(circle at 18% 82%, color-mix(in srgb, var(--jodoh-ring-fill-end) 18%, transparent), transparent 30%),
    linear-gradient(145deg, var(--jodoh-hero-start) 0%, var(--jodoh-hero-end) 100%);
  box-shadow:
    inset 0 1.4rem 1.7rem -1.65rem rgba(78, 35, 56, 0.34),
    inset 0 -1px 0 color-mix(in srgb, var(--jodoh-panel-border) 90%, transparent);
}

body[data-page='calculator'][data-calculator='jodoh'] .calculator-hero::before,
body[data-page='calculator'][data-calculator='jodoh'] .calculator-hero::after {
  content: '';
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
  z-index: 0;
}

body[data-page='calculator'][data-calculator='jodoh'] .calculator-hero::before {
  inset: -5rem auto auto -4rem;
  width: 14rem;
  height: 14rem;
  background: radial-gradient(circle at center, color-mix(in srgb, var(--jodoh-ring-fill-end) 12%, transparent), transparent 70%);
}

body[data-page='calculator'][data-calculator='jodoh'] .calculator-hero::after {
  inset: auto -3.5rem -5rem auto;
  width: 18rem;
  height: 18rem;
  background: radial-gradient(circle at center, color-mix(in srgb, var(--jodoh-accent) 16%, transparent), transparent 72%);
}

.jodoh-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(16rem, 23rem);
  gap: clamp(1rem, 3vw, 2rem);
  position: relative;
  z-index: 1;
  align-items: center;
  width: var(--jodoh-shell-width);
  margin: 0 auto;
}

.jodoh-hero-copy {
  display: grid;
  gap: 0.82rem;
  justify-items: start;
  text-align: left;
  max-width: 33rem;
}

.jodoh-hero-copy h1 {
  margin: 0;
  max-width: 8ch;
  font-size: clamp(3.2rem, 6.2vw, 5.8rem);
  line-height: 0.92;
  letter-spacing: -0.05em;
  text-wrap: balance;
}

.jodoh-hero-copy #calculator-description {
  max-width: 28rem;
  font-size: 1.08rem;
  line-height: 1.56;
  color: color-mix(in srgb, var(--text) 88%, var(--muted));
  text-wrap: pretty;
}

.jodoh-hero-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: flex-start;
}

.jodoh-hero-pill {
  display: inline-flex;
  align-items: center;
  min-height: 1.95rem;
  padding: 0.3rem 0.64rem;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  color: var(--text);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--jodoh-panel-border) 70%, transparent);
}

.jodoh-hero-pill.official {
  background: var(--jodoh-pill-official-bg);
}

.jodoh-hero-pill.estimated {
  background: var(--jodoh-pill-estimated-bg);
}

.jodoh-hero-pill.private {
  background: var(--jodoh-pill-private-bg);
}

.jodoh-hero-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.72rem 1rem;
  margin-top: 0.2rem;
}

.jodoh-hero-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3.25rem;
  padding: 0.84rem 1.42rem;
  border-radius: 999px;
  text-decoration: none;
  border: 1px solid color-mix(in srgb, var(--jodoh-accent) 28%, transparent);
  background: linear-gradient(135deg, var(--jodoh-ring-fill-start), var(--jodoh-ring-fill-end));
  color: #fff7fb;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 0.95rem;
  font-weight: 700;
  box-shadow: 0 16px 34px color-mix(in srgb, var(--jodoh-glow) 130%, transparent);
  transition: transform 180ms ease, box-shadow 180ms ease, filter 180ms ease;
}

.jodoh-hero-cta:hover,
.jodoh-hero-cta:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 18px 36px color-mix(in srgb, var(--jodoh-glow) 145%, transparent);
  filter: saturate(1.06);
}

.jodoh-hero-note {
  margin: 0;
  max-width: 18rem;
  color: var(--jodoh-private-text);
  font-size: 0.9rem;
  line-height: 1.45;
}

.jodoh-hero-visual {
  position: relative;
  height: clamp(18rem, 30vw, 24rem);
  width: 100%;
  display: grid;
  place-items: center;
}

.jodoh-hero-heart {
  position: relative;
  width: clamp(11rem, 19vw, 16rem);
  aspect-ratio: 1;
  transform: rotate(-45deg);
  border-radius: 1.8rem 1.8rem 0.8rem 0.8rem;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--jodoh-ring-fill-end) 75%, white 25%), color-mix(in srgb, var(--jodoh-ring-fill-start) 88%, transparent));
  box-shadow:
    0 26px 60px color-mix(in srgb, var(--jodoh-glow) 150%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.45);
}

.jodoh-hero-heart::before,
.jodoh-hero-heart::after {
  content: '';
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: inherit;
}

.jodoh-hero-heart::before {
  top: -50%;
  left: 0;
}

.jodoh-hero-heart::after {
  left: 50%;
  top: 0;
}

.jodoh-hero-heart-core {
  position: absolute;
  inset: 18%;
  border-radius: 999px;
  background: radial-gradient(circle at 40% 35%, rgba(255, 255, 255, 0.85), rgba(255, 255, 255, 0.08) 62%, transparent 70%);
  transform: rotate(45deg);
}

.jodoh-hero-spark {
  position: absolute;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 0 0 0.34rem color-mix(in srgb, var(--jodoh-glow) 70%, transparent);
}

.jodoh-hero-spark.spark-a {
  width: 0.62rem;
  height: 0.62rem;
  inset: 18% 18% auto auto;
}

.jodoh-hero-spark.spark-b {
  width: 0.42rem;
  height: 0.42rem;
  inset: auto auto 24% 12%;
}

.jodoh-hero-spark.spark-c {
  width: 0.32rem;
  height: 0.32rem;
  inset: 28% auto auto 10%;
}

.jodoh-stage-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.94fr) minmax(0, 1.06fr);
  gap: 1rem;
  width: var(--jodoh-shell-width);
  margin: -2.75rem auto 1rem;
  align-items: start;
  position: relative;
  z-index: 2;
}

.jodoh-panel {
  border: 1px solid var(--jodoh-panel-border);
  border-radius: calc(var(--radius-lg) + 2px);
  background:
    linear-gradient(160deg, var(--jodoh-panel-start) 0%, var(--jodoh-panel-end) 100%);
  box-shadow: inset 0 1px 0 var(--jodoh-panel-inset), 0 18px 44px rgba(78, 29, 39, 0.07);
  padding: 1rem;
  position: relative;
  overflow: hidden;
}

body[data-page='calculator'][data-calculator='jodoh'] {
  --jodoh-shell-width: min(1180px, calc(100vw - 2rem));
  background:
    linear-gradient(180deg, #f7f8fc 0%, #f8f3fb 34%, #f6f4ff 100%);
}

:root[data-theme='dark'] body[data-page='calculator'][data-calculator='jodoh'] {
  background:
    linear-gradient(180deg, #101726 0%, #111321 26%, #10111f 56%, #0d1524 100%);
}

body[data-page='calculator'][data-calculator='jodoh'] main,
body[data-page='calculator'][data-calculator='jodoh'] .site-header,
body[data-page='calculator'][data-calculator='jodoh'] .site-footer {
  width: var(--jodoh-shell-width);
}

body[data-page='calculator'][data-calculator='jodoh'] .site-footer {
  background: var(--surface);
  border-color: var(--line);
}

.jodoh-panel::before {
  content: none;
}

.jodoh-panel-heading {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.3rem;
  margin-bottom: 0.9rem;
}

.jodoh-panel-heading h2,
.jodoh-panel-heading p {
  margin: 0;
}

.jodoh-panel-heading h2 {
  line-height: 1.08;
  text-wrap: balance;
}

.jodoh-panel-kicker {
  display: block;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 0.76rem;
  font-weight: 700;
  line-height: 1.18;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--jodoh-accent);
}

.jodoh-form,
.jodoh-factor-columns,
.jodoh-result-stage,
.jodoh-disclosure-grid {
  position: relative;
  z-index: 1;
}

.jodoh-form {
  display: grid;
  gap: 0.7rem;
}

.jodoh-form-group {
  padding: 0.9rem;
  border: 1px solid color-mix(in srgb, var(--jodoh-panel-border) 92%, transparent);
  border-radius: calc(var(--radius-md) + 4px);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--jodoh-official-overlay-start) 86%, transparent), color-mix(in srgb, var(--jodoh-official-overlay-end) 88%, transparent)),
    linear-gradient(145deg, color-mix(in srgb, var(--jodoh-official-start) 96%, white 4%) 0%, color-mix(in srgb, var(--jodoh-official-end) 96%, white 4%) 100%);
  display: grid;
  gap: 0.78rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.24), 0 12px 24px rgba(78, 29, 39, 0.04);
}

.jodoh-form-group-head {
  display: grid;
  gap: 0.28rem;
}

.jodoh-form-group-head h3,
.jodoh-form-group-head p {
  margin: 0;
}

.jodoh-form-group-head h3 {
  font-size: 1.06rem;
  line-height: 1.16;
}

.jodoh-form-group-head p {
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.45;
  text-wrap: pretty;
}

.jodoh-form-group-body {
  display: grid;
  gap: 0.7rem;
}

.jodoh-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.7rem;
}

.jodoh-form-section {
  padding: 0.78rem;
  border: 1px solid var(--jodoh-toggle-border);
  border-radius: calc(var(--radius-md) + 2px);
  background: linear-gradient(180deg, color-mix(in srgb, var(--jodoh-toggle-bg) 94%, white 6%), color-mix(in srgb, var(--jodoh-toggle-bg) 84%, transparent));
  display: grid;
  gap: 0.56rem;
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--jodoh-panel-inset) 80%, transparent);
}

.jodoh-form-section.estimated {
  background: linear-gradient(145deg, color-mix(in srgb, var(--jodoh-estimated-start) 92%, white 8%) 0%, var(--jodoh-estimated-end) 100%);
}

.jodoh-field-head {
  display: grid;
  gap: 0.18rem;
}

.jodoh-field-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.55rem;
}

.jodoh-field-label,
.jodoh-field-hint {
  margin: 0;
}

.jodoh-field-label {
  font-size: 0.92rem;
  font-weight: 800;
  color: var(--text);
}

.jodoh-field-hint {
  color: var(--muted);
  font-size: 0.79rem;
  line-height: 1.4;
}

.jodoh-toggle-grid,
.jodoh-segment-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.45rem;
}

.jodoh-toggle-card,
.jodoh-segment-card {
  position: relative;
  border-radius: calc(var(--radius-md) + 2px);
  overflow: hidden;
  cursor: pointer;
}

.jodoh-toggle-card input,
.jodoh-segment-card input {
  position: absolute;
  inset: 0;
  opacity: 0;
}

.jodoh-toggle-card span,
.jodoh-segment-card span {
  min-height: 3rem;
  padding: 0.68rem 0.78rem;
  border: 1px solid var(--jodoh-toggle-border);
  border-radius: inherit;
  background: linear-gradient(180deg, var(--jodoh-control-surface-start), var(--jodoh-control-surface-end));
  display: grid;
  place-items: center;
  text-align: center;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--text);
  transition: background 120ms ease, border-color 120ms ease, box-shadow 120ms ease;
}

.jodoh-toggle-card input:checked + span,
.jodoh-segment-card input:checked + span {
  background: linear-gradient(180deg, color-mix(in srgb, var(--jodoh-toggle-selected) 86%, white 14%), color-mix(in srgb, var(--jodoh-toggle-selected) 96%, transparent));
  border-color: color-mix(in srgb, var(--jodoh-accent) 55%, transparent);
  box-shadow: 0 10px 24px rgba(78, 29, 39, 0.08);
}

.jodoh-toggle-card input:focus-visible + span,
.jodoh-segment-card input:focus-visible + span,
.jodoh-select:focus-visible,
.jodoh-range:focus-visible,
.jodoh-reveal-button:focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 2px;
}

.jodoh-select {
  width: 100%;
  min-height: 3rem;
  padding: 0.72rem 0.84rem;
  border: 1px solid var(--jodoh-toggle-border);
  border-radius: calc(var(--radius-md) + 2px);
  background: linear-gradient(180deg, var(--jodoh-control-surface-strong-start), var(--jodoh-control-surface-strong-end));
  color: var(--text);
  font: inherit;
}

.jodoh-range-shell {
  display: grid;
  gap: 0.8rem;
}

.jodoh-range-values {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.66rem 0.78rem;
  border-radius: calc(var(--radius-md) + 2px);
  background: linear-gradient(180deg, var(--jodoh-control-surface-strong-start), var(--jodoh-control-surface-strong-end));
  box-shadow: inset 0 1px 0 var(--jodoh-control-surface-inset);
}

.jodoh-range-values strong {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1rem;
}

.jodoh-range-values span {
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.jodoh-range-inputs {
  display: grid;
  gap: 0.55rem;
}

.jodoh-range {
  width: 100%;
  accent-color: var(--jodoh-accent-strong);
  -webkit-appearance: none;
  appearance: none;
  height: 1.65rem;
  background: transparent;
}

.jodoh-range::-webkit-slider-runnable-track {
  height: 0.38rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--jodoh-toggle-border) 70%, rgba(255, 255, 255, 0.45));
}

.jodoh-range::-moz-range-track {
  height: 0.38rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--jodoh-toggle-border) 70%, rgba(255, 255, 255, 0.45));
}

.jodoh-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 1rem;
  height: 1rem;
  margin-top: -0.31rem;
  border-radius: 999px;
  border: 2px solid rgba(255, 255, 255, 0.92);
  background: linear-gradient(135deg, var(--jodoh-ring-fill-start), var(--jodoh-ring-fill-end));
  box-shadow: 0 5px 12px rgba(78, 29, 39, 0.18);
}

.jodoh-range::-moz-range-thumb {
  width: 1rem;
  height: 1rem;
  border-radius: 999px;
  border: 2px solid rgba(255, 255, 255, 0.92);
  background: linear-gradient(135deg, var(--jodoh-ring-fill-start), var(--jodoh-ring-fill-end));
  box-shadow: 0 5px 12px rgba(78, 29, 39, 0.18);
}

.jodoh-dual-range {
  position: relative;
  height: 1.8rem;
  display: grid;
  align-items: center;
}

.jodoh-dual-range-track,
.jodoh-dual-range-fill {
  position: absolute;
  inset: 50% 0 auto;
  height: 0.38rem;
  transform: translateY(-50%);
  border-radius: 999px;
}

.jodoh-dual-range-track {
  background: color-mix(in srgb, var(--jodoh-toggle-border) 70%, rgba(255, 255, 255, 0.45));
}

.jodoh-dual-range-fill {
  background: linear-gradient(135deg, var(--jodoh-ring-fill-start), var(--jodoh-ring-fill-end));
}

.jodoh-dual-range .jodoh-range {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.jodoh-dual-range .jodoh-range::-webkit-slider-runnable-track,
.jodoh-dual-range .jodoh-range::-moz-range-track {
  background: transparent;
}

.jodoh-dual-range .jodoh-range-min {
  z-index: 3;
}

.jodoh-dual-range .jodoh-range-max {
  z-index: 2;
}

.jodoh-dual-range[data-active-thumb='max'] .jodoh-range-min {
  z-index: 2;
}

.jodoh-dual-range[data-active-thumb='max'] .jodoh-range-max {
  z-index: 3;
}

.jodoh-dual-range .jodoh-range::-webkit-slider-thumb {
  pointer-events: auto;
}

.jodoh-dual-range .jodoh-range::-moz-range-thumb {
  pointer-events: auto;
}

.jodoh-range-endpoints {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  color: var(--muted);
  font-size: 0.76rem;
}

.jodoh-estimated-pill,
.jodoh-factor-badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 1.5rem;
  padding: 0.12rem 0.48rem;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--jodoh-panel-border) 85%, transparent);
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: var(--jodoh-pill-official-bg);
  color: color-mix(in srgb, var(--text) 82%, var(--jodoh-accent));
}

.jodoh-estimated-pill,
.jodoh-factor-badge.estimated {
  background: var(--jodoh-pill-estimated-bg);
}

.jodoh-form-actions {
  display: grid;
  gap: 0.48rem;
  margin-top: 0.42rem;
  justify-items: center;
}

.jodoh-reveal-button {
  min-height: 3.2rem;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 0.98rem;
  font-weight: 700;
  background: linear-gradient(135deg, var(--jodoh-ring-fill-start), var(--jodoh-ring-fill-end));
  border: 0;
  color: #fff8f4;
  box-shadow: 0 10px 24px var(--jodoh-glow);
  border-radius: 999px;
  width: fit-content;
  padding: 0.8rem 1.35rem;
}

.jodoh-privacy-note {
  margin: 0;
  color: var(--jodoh-private-text);
  font-size: 0.8rem;
  text-align: center;
}

.jodoh-result-panel {
  display: grid;
  gap: 0.94rem;
  padding: 1rem 1.12rem 1.08rem;
  background:
    radial-gradient(circle at 78% 28%, color-mix(in srgb, var(--jodoh-accent) 10%, transparent), transparent 24%),
    linear-gradient(160deg, var(--jodoh-panel-start) 0%, var(--jodoh-panel-end) 100%);
}

.jodoh-result-stage {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1rem;
  position: relative;
  align-items: start;
  padding: 1rem 0 0.65rem;
}

.jodoh-result-summary {
  display: grid;
  gap: 0.82rem;
  min-width: 0;
}

.jodoh-result-action {
  display: flex;
  justify-content: flex-end;
  align-items: start;
  position: relative;
  z-index: 1;
}

.jodoh-result-button {
  width: auto;
  min-width: 9.75rem;
  min-height: 3rem;
  padding-inline: 1.1rem;
}

.jodoh-result-stage::before {
  content: '';
  position: absolute;
  inset: 3rem -1rem auto auto;
  width: min(21rem, 48%);
  height: 21rem;
  background: radial-gradient(circle at center, color-mix(in srgb, var(--jodoh-glow) 140%, transparent), transparent 70%);
  opacity: 0.5;
  pointer-events: none;
}

.jodoh-visual-stack {
  width: 100%;
  max-width: none;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.74rem;
  justify-items: stretch;
  align-self: stretch;
  position: relative;
  z-index: 1;
}

.jodoh-share-hero {
  padding: 1.08rem 1.12rem 1rem;
  border: 1px solid var(--jodoh-toggle-border);
  border-radius: calc(var(--radius-md) + 2px);
  background: linear-gradient(180deg, var(--jodoh-result-surface-start), var(--jodoh-result-surface-end));
  display: grid;
  gap: 0.44rem;
  position: relative;
  z-index: 1;
  box-shadow: inset 0 1px 0 var(--jodoh-result-surface-inset), 0 10px 26px rgba(78, 29, 39, 0.06);
}

.jodoh-share-hero .jodoh-visual-card,
.jodoh-metric-card .jodoh-visual-card {
  margin-top: 0.14rem;
}

.jodoh-share-hero .jodoh-dot-field {
  width: min(12.5rem, 100%);
}

.jodoh-share-top {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 0.9rem;
}

.jodoh-share-copy {
  display: grid;
  gap: 0.22rem;
  min-width: 0;
}

.jodoh-rarity-label {
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.jodoh-share-hero strong {
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(2.5rem, 4.2vw, 3.55rem);
  line-height: 0.95;
  letter-spacing: -0.05em;
}

.jodoh-share-caption {
  margin: 0;
  max-width: 28rem;
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.45;
}

.jodoh-visual-caption {
  display: grid;
  gap: 0.2rem;
}

.jodoh-visual-card {
  padding: 0.82rem 0.86rem 0.8rem;
  border: 1px solid color-mix(in srgb, var(--jodoh-toggle-border) 96%, transparent);
  border-radius: calc(var(--radius-md) + 1px);
  background: linear-gradient(180deg, color-mix(in srgb, var(--jodoh-result-surface-start) 82%, transparent), color-mix(in srgb, var(--jodoh-result-surface-end) 92%, transparent));
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--jodoh-result-surface-inset) 84%, transparent);
  display: grid;
  gap: 0.62rem;
}

.jodoh-dot-card {
  align-content: start;
}

.jodoh-dot-field {
  width: min(16.5rem, 100%);
  display: grid;
  grid-template-columns: repeat(var(--jodoh-dot-columns, 9), minmax(0, 1fr));
  gap: 0.34rem;
  position: relative;
  margin: 0 auto;
  filter: drop-shadow(0 18px 34px color-mix(in srgb, var(--jodoh-glow) 62%, transparent));
  transition: opacity 220ms ease, transform 360ms cubic-bezier(0.22, 1, 0.36, 1), filter 220ms ease;
}

.jodoh-dot {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 0.28rem;
  background: transparent;
  transition: background 140ms ease, opacity 140ms ease;
}

.jodoh-dot.is-person {
  background: var(--jodoh-dot-idle);
  opacity: 1;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, white 22%, transparent);
}

.jodoh-dot.is-void {
  opacity: 0;
}

.jodoh-dot.is-active {
  background: var(--jodoh-dot-active);
  opacity: 1;
  box-shadow: 0 0 0 1px color-mix(in srgb, white 32%, transparent), 0 10px 18px color-mix(in srgb, var(--jodoh-dot-active) 34%, transparent);
}

.jodoh-population-board-shell {
  width: 100%;
  transition: opacity 220ms ease, transform 360ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 220ms ease;
}

.jodoh-population-board {
  --jodoh-hex-size: clamp(0.46rem, 0.86vw, 0.68rem);
  display: grid;
  grid-template-columns: repeat(var(--jodoh-board-columns, 16), var(--jodoh-hex-size));
  gap: 0.14rem;
  justify-content: center;
}

.jodoh-population-row {
  display: contents;
}

.jodoh-hex {
  width: var(--jodoh-hex-size);
  height: var(--jodoh-hex-size);
  flex: 0 0 auto;
  border-radius: 0.16rem;
  background: color-mix(in srgb, var(--jodoh-dot-idle) 84%, white 6%);
  opacity: 0.9;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, white 14%, transparent);
  transition: background 140ms ease, opacity 140ms ease, box-shadow 140ms ease, transform 140ms ease;
}

.jodoh-hex.is-active {
  background: color-mix(in srgb, var(--jodoh-dot-active) 94%, white 6%);
  opacity: 1;
  box-shadow: 0 0 0 1px color-mix(in srgb, white 26%, transparent), 0 0 18px color-mix(in srgb, var(--jodoh-dot-active) 30%, transparent);
}

.jodoh-metrics {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0.68rem;
}

.jodoh-metric-card {
  padding: 0.92rem 0.98rem;
  border-radius: calc(var(--radius-md) + 2px);
  border: 1px solid var(--jodoh-toggle-border);
  background: linear-gradient(180deg, color-mix(in srgb, var(--jodoh-result-surface-start) 92%, transparent), color-mix(in srgb, var(--jodoh-result-surface-end) 92%, transparent));
  display: grid;
  align-content: start;
  gap: 0.34rem;
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--jodoh-result-surface-inset) 90%, transparent);
}

.jodoh-metric-card-population {
  position: relative;
  overflow: hidden;
  padding: 1.02rem 1.04rem 1rem;
  gap: 0.42rem;
  border-color: color-mix(in srgb, var(--jodoh-dot-active) 24%, var(--jodoh-toggle-border));
  background:
    radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--jodoh-dot-active) 15%, transparent), transparent 36%),
    linear-gradient(180deg, color-mix(in srgb, var(--jodoh-result-surface-start) 96%, transparent), color-mix(in srgb, var(--jodoh-result-surface-end) 94%, transparent));
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, var(--jodoh-result-surface-inset) 92%, transparent),
    0 14px 34px color-mix(in srgb, var(--jodoh-dot-active) 10%, transparent);
}

.jodoh-metric-card-population::before {
  content: '';
  position: absolute;
  inset: auto -1.4rem -1.8rem auto;
  width: 8rem;
  height: 8rem;
  border-radius: 50%;
  background: radial-gradient(circle at center, color-mix(in srgb, var(--jodoh-dot-active) 18%, transparent), transparent 70%);
  pointer-events: none;
}

.jodoh-metric-card span {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}

.jodoh-metric-card-population span {
  color: color-mix(in srgb, var(--text) 72%, var(--jodoh-dot-active));
}

.jodoh-metric-card strong {
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(1.24rem, 1.8vw, 1.48rem);
  line-height: 1.02;
}

.jodoh-metric-card-population strong {
  font-size: clamp(1.98rem, 4vw, 2.7rem);
  line-height: 0.96;
  letter-spacing: -0.05em;
}

.jodoh-metric-lede {
  margin: 0;
  max-width: 18rem;
  font-size: 0.95rem;
  line-height: 1.32;
  color: color-mix(in srgb, var(--text) 80%, var(--muted));
}

.jodoh-metric-card .jodoh-population-board {
  --jodoh-hex-size: clamp(0.34rem, 0.68vw, 0.5rem);
  gap: 0.1rem;
}

.jodoh-metric-card-wide {
  grid-column: 1 / -1;
}

.jodoh-rarity-meter {
  display: flex;
  align-items: center;
  gap: 0.22rem;
  min-height: 1.9rem;
}

.jodoh-rarity-star {
  width: 0.92rem;
  height: 0.92rem;
  opacity: 0.26;
  background: color-mix(in srgb, var(--jodoh-dot-idle) 88%, white 10%);
  clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 92%, 50% 71%, 21% 92%, 32% 57%, 2% 35%, 39% 35%);
  transition: opacity 140ms ease, transform 140ms ease, filter 140ms ease, background 140ms ease, box-shadow 140ms ease;
}

.jodoh-rarity-star.is-active {
  opacity: 1;
  transform: translateY(-1px);
  filter: drop-shadow(0 6px 12px color-mix(in srgb, var(--jodoh-glow) 72%, transparent));
  background: linear-gradient(180deg, var(--jodoh-ring-fill-start), var(--jodoh-ring-fill-end));
  box-shadow: 0 0 0 1px color-mix(in srgb, white 22%, transparent);
}

.jodoh-metric-note {
  margin: 0;
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.35;
}

.jodoh-metric-card-population .jodoh-metric-note {
  max-width: 18rem;
  color: color-mix(in srgb, var(--text) 72%, var(--muted));
  font-size: 0.9rem;
  line-height: 1.38;
}

.jodoh-factor-columns,
.jodoh-disclosure-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.7rem;
}

body[data-page='calculator'][data-calculator='jodoh'] .jodoh-disclosure-grid .result-section {
  margin-top: 0;
  padding: 1rem 1.05rem 1.02rem;
  border-top: 0;
  border: 1px solid color-mix(in srgb, var(--jodoh-panel-border) 92%, transparent);
  border-radius: calc(var(--radius-md) + 2px);
  background: linear-gradient(180deg, var(--jodoh-disclosure-surface-start), var(--jodoh-disclosure-surface-end));
  box-shadow: inset 0 1px 0 var(--jodoh-disclosure-surface-inset), 0 10px 22px rgba(78, 29, 39, 0.05);
}

body[data-page='calculator'][data-calculator='jodoh'] .jodoh-disclosure-grid .result-section summary {
  display: block;
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.2;
}

body[data-page='calculator'][data-calculator='jodoh'] .jodoh-disclosure-grid .result-section[open] summary {
  margin-bottom: 0.82rem;
}

body[data-page='calculator'][data-calculator='jodoh'] .jodoh-disclosure-grid .result-list {
  margin-top: 0;
  gap: 0.55rem;
}

body[data-page='calculator'][data-calculator='jodoh'] .jodoh-disclosure-grid .result-list li {
  padding-bottom: 0.55rem;
  line-height: 1.5;
}

body[data-page='calculator'][data-calculator='jodoh'] .jodoh-disclosure-grid .result-list li:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

body[data-page='calculator'][data-calculator='jodoh'] .jodoh-disclosure-grid .result-list.sources a {
  color: color-mix(in srgb, var(--text) 74%, var(--jodoh-accent-strong));
}

.jodoh-factor-card {
  position: relative;
  overflow: hidden;
  border-radius: calc(var(--radius-md) + 2px);
  border: 1px solid color-mix(in srgb, var(--jodoh-panel-border) 95%, transparent);
  padding: 1.02rem;
  display: grid;
  gap: 0.82rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22), 0 12px 24px rgba(78, 29, 39, 0.05);
}

.jodoh-factor-card.official {
  background:
    linear-gradient(180deg, var(--jodoh-official-overlay-start), var(--jodoh-official-overlay-end)),
    linear-gradient(145deg, var(--jodoh-official-start) 0%, var(--jodoh-official-end) 100%);
}

.jodoh-factor-card.pool {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--jodoh-official-overlay-start) 88%, transparent), color-mix(in srgb, var(--jodoh-official-overlay-end) 90%, transparent)),
    linear-gradient(145deg, color-mix(in srgb, var(--jodoh-official-start) 98%, white 2%) 0%, color-mix(in srgb, var(--jodoh-official-end) 98%, white 2%) 100%);
}

.jodoh-factor-card.estimated {
  background: linear-gradient(145deg, var(--jodoh-estimated-start) 0%, var(--jodoh-estimated-end) 100%);
}

.jodoh-factor-card.pool::before,
.jodoh-factor-card.official::before,
.jodoh-factor-card.estimated::before {
  content: '';
  position: absolute;
  inset: 0 auto 0 0;
  width: 0.22rem;
  border-radius: 999px;
}

.jodoh-factor-card.pool::before {
  background: linear-gradient(180deg, color-mix(in srgb, var(--jodoh-accent) 72%, white), color-mix(in srgb, var(--jodoh-accent-strong) 78%, white));
}

.jodoh-factor-card.official::before {
  background: linear-gradient(180deg, color-mix(in srgb, var(--text) 58%, var(--jodoh-accent)), color-mix(in srgb, var(--jodoh-accent) 42%, white));
}

.jodoh-factor-card.estimated::before {
  background: linear-gradient(180deg, var(--jodoh-ring-fill-start), var(--jodoh-ring-fill-end));
}

.jodoh-factor-heading {
  display: grid;
  gap: 0.34rem;
}

.jodoh-factor-heading h3 {
  margin: 0;
  font-size: 1.1rem;
  line-height: 1.14;
}

.jodoh-factor-intro {
  margin: 0;
  max-width: 26rem;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.45;
  text-wrap: pretty;
}

.jodoh-factor-list {
  margin: 0;
  padding-left: 0;
  list-style: none;
  display: grid;
  gap: 0.45rem;
}

.jodoh-factor-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.75rem;
  align-items: end;
  padding: 0.18rem 0 0.58rem;
  border-bottom: 1px solid color-mix(in srgb, var(--jodoh-panel-border) 52%, transparent);
}

.jodoh-factor-label {
  display: block;
  margin-bottom: 0.24rem;
  color: color-mix(in srgb, var(--text) 78%, var(--muted));
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.jodoh-factor-note {
  margin: 0;
  color: var(--muted);
  font-size: 0.8rem;
  line-height: 1.46;
  text-wrap: pretty;
}

.jodoh-factor-item strong {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  min-height: 2.05rem;
  padding-left: 0.85rem;
  color: var(--text);
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(1.2rem, 1.9vw, 1.55rem);
  line-height: 1;
  letter-spacing: -0.035em;
  text-align: right;
}

.jodoh-factor-empty {
  margin: 0;
  padding: 0.4rem 0 0.1rem;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.5;
  text-wrap: pretty;
}

.jodoh-note-strip {
  padding: 0.82rem 0.9rem;
  border-radius: calc(var(--radius-md) + 2px);
  border: 1px solid var(--jodoh-note-border);
  background: var(--jodoh-note-bg);
}

.jodoh-note-strip p {
  margin: 0;
  color: var(--text);
  font-size: 0.94rem;
  line-height: 1.55;
  text-wrap: pretty;
}

body[data-page='calculator'][data-calculator='jodoh'] .calculator-hero .back-link,
body[data-page='calculator'][data-calculator='jodoh'] .rule-meta {
  position: relative;
  z-index: 1;
}

body[data-page='calculator'][data-calculator='jodoh'] .calculator-hero .back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  width: fit-content;
  min-height: 2.5rem;
  align-self: start;
  margin: 0 0 1.2rem;
  padding: 0.36rem 0.82rem;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--jodoh-panel-border) 95%, transparent);
  background: rgba(255, 255, 255, 0.38);
  color: color-mix(in srgb, var(--text) 82%, var(--jodoh-accent));
  font-size: 0.9rem;
  font-weight: 700;
  text-decoration: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.42);
  backdrop-filter: blur(10px);
  transition: border-color 160ms ease, background 160ms ease, transform 160ms ease;
}

body[data-page='calculator'][data-calculator='jodoh'] .calculator-hero .back-link::before {
  content: '←';
  font-size: 0.95rem;
  line-height: 1;
}

body[data-page='calculator'][data-calculator='jodoh'] .calculator-hero .back-link:hover,
body[data-page='calculator'][data-calculator='jodoh'] .calculator-hero .back-link:focus-visible {
  text-decoration: none;
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.5);
  border-color: color-mix(in srgb, var(--jodoh-accent) 28%, transparent);
}

body[data-page='calculator'][data-calculator='jodoh'] .rule-meta {
  width: min(32rem, calc(100% - 1.5rem));
  margin-left: auto;
  margin-right: auto;
  padding-top: 0.7rem;
  border-top: 0;
  justify-items: center;
  text-align: center;
  gap: 0.28rem;
}

body[data-page='calculator'][data-calculator='jodoh'] .rule-meta::before {
  content: '';
  width: 100%;
  border-top: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
}

body[data-page='calculator'][data-calculator='jodoh'] .calculator-share-panel {
  width: var(--jodoh-shell-width);
  margin-left: auto;
  margin-right: auto;
}

body[data-page='calculator'][data-calculator='jodoh'] .related-calculators-section,
body[data-page='calculator'][data-calculator='jodoh'] .newsletter-block.compact,
body[data-page='calculator'][data-calculator='jodoh'] .site-footer {
  position: relative;
  z-index: 2;
  width: var(--jodoh-shell-width);
  margin-left: auto;
  margin-right: auto;
}

body[data-page='calculator'][data-calculator='jodoh'] .newsletter-block.compact {
  border-color: var(--line);
  background: linear-gradient(145deg, var(--newsletter-surface-start), var(--newsletter-surface-end));
}

@media (max-width: 1180px) {
  .jodoh-result-stage {
    grid-template-columns: minmax(0, 1fr);
    gap: 0.85rem;
    padding-top: 0.6rem;
  }

  .jodoh-result-summary {
    gap: 0.72rem;
  }

  .jodoh-visual-stack {
    max-width: none;
    margin-left: 0;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.72rem;
  }

  .jodoh-visual-card,
  .jodoh-population-board-shell {
    min-height: 100%;
  }

  .jodoh-dot-field {
    width: min(13.5rem, 100%);
  }
}

@media (max-width: 980px) {
  body[data-page='calculator'][data-calculator='jodoh'] .calculator-hero {
    width: 100vw;
    max-width: none;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding-bottom: 2.5rem;
  }

  .jodoh-stage-layout {
    grid-template-columns: 1fr;
    width: 100%;
    margin-top: -1.7rem;
  }

  .jodoh-panel {
    padding: 0.92rem;
  }

  .jodoh-hero-grid {
    grid-template-columns: minmax(0, 1fr);
    justify-items: center;
  }

  .jodoh-hero-copy {
    justify-items: center;
    text-align: center;
  }

  .jodoh-hero-pills,
  .jodoh-hero-actions {
    justify-content: center;
  }

  .jodoh-hero-visual {
    height: 10.5rem;
    margin-top: 0.9rem;
    place-items: end center;
  }

  .jodoh-hero-heart {
    width: clamp(8rem, 21vw, 9.4rem);
    border-radius: 1.45rem 1.45rem 0.7rem 0.7rem;
  }

  .jodoh-hero-spark.spark-a {
    inset: 20% 21% auto auto;
  }

  .jodoh-hero-spark.spark-b {
    inset: auto auto 16% 18%;
  }

  .jodoh-hero-spark.spark-c {
    inset: 30% auto auto 18%;
  }

  .jodoh-result-panel {
    padding: 0.92rem 1rem 1rem;
  }

  body[data-page='calculator'][data-calculator='jodoh'] .related-calculators-section,
  body[data-page='calculator'][data-calculator='jodoh'] .newsletter-block.compact,
  body[data-page='calculator'][data-calculator='jodoh'] .site-footer {
    width: 100%;
  }

  .jodoh-result-stage {
    grid-template-columns: minmax(0, 1fr);
    gap: 0.85rem;
    padding-top: 0.6rem;
  }

  .jodoh-result-summary {
    gap: 0.72rem;
  }

  .jodoh-visual-stack {
    max-width: none;
    margin-left: 0;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.72rem;
  }

  .jodoh-visual-card,
  .jodoh-population-board-shell {
    min-height: 100%;
  }

  .jodoh-dot-field {
    width: min(13.5rem, 100%);
  }
}

@media (max-width: 700px) {
  body[data-page='calculator'][data-calculator='jodoh'] .calculator-hero {
    padding: 0.76rem 0.9rem 2rem;
  }

  body[data-page='calculator'][data-calculator='jodoh'] .calculator-hero .back-link {
    align-self: center;
    margin-bottom: 0.9rem;
    min-height: 2.35rem;
    padding: 0.3rem 0.72rem;
    font-size: 0.84rem;
  }

  .jodoh-hero-grid {
    gap: 0.66rem;
  }

  .jodoh-hero-copy {
    gap: 0.44rem;
  }

  .jodoh-hero-copy h1 {
    max-width: 10ch;
    font-size: clamp(2.1rem, 11vw, 2.9rem);
    line-height: 1.01;
    letter-spacing: -0.025em;
  }

  .jodoh-hero-copy #calculator-description {
    font-size: 0.92rem;
    line-height: 1.5;
  }

  .jodoh-hero-pills {
    gap: 0.34rem;
  }

  .jodoh-hero-pill {
    min-height: 1.7rem;
    padding: 0.22rem 0.5rem;
    font-size: 0.68rem;
  }

  .jodoh-hero-actions {
    width: 100%;
    gap: 0.66rem;
  }

  .jodoh-hero-cta {
    width: 100%;
  }

  .jodoh-hero-note {
    max-width: 22rem;
    font-size: 0.84rem;
    text-align: center;
  }

  .jodoh-hero-visual {
    height: 7.8rem;
    margin-top: 0.72rem;
    place-items: end center;
  }

  .jodoh-hero-heart {
    width: 6.2rem;
    border-radius: 1.25rem 1.25rem 0.6rem 0.6rem;
  }

  .jodoh-hero-spark.spark-a {
    inset: 18% 16% auto auto;
  }

  .jodoh-hero-spark.spark-b {
    inset: auto auto 18% 14%;
  }

  .jodoh-hero-spark.spark-c {
    inset: 26% auto auto 14%;
  }

  .jodoh-stage-layout {
    gap: 0.72rem;
    width: 100%;
    margin-top: -1.1rem;
  }

  .jodoh-panel {
    padding: 1.02rem 0.98rem 0.94rem;
    border-radius: calc(var(--radius-md) + 4px);
  }

  .jodoh-input-panel {
    padding-top: 1.34rem;
    overflow: visible;
  }

  .jodoh-result-panel {
    gap: 0.72rem;
    padding: 0.72rem 0.82rem 0.86rem;
  }

  .jodoh-panel-heading {
    gap: 0.3rem;
    margin-bottom: 0.72rem;
    padding-inline: 0.04rem;
    overflow: visible;
  }

  .jodoh-panel-kicker {
    font-size: 0.8rem;
    line-height: 1.22;
    padding-top: 0.12rem;
  }

  .jodoh-panel-heading h2 {
    font-size: clamp(1.44rem, 6.6vw, 1.78rem);
    line-height: 1.06;
  }

  .jodoh-panel-heading p {
    font-size: 0.86rem;
    line-height: 1.42;
  }

  .jodoh-form {
    gap: 0.76rem;
  }

  .jodoh-form-group {
    padding: 0.84rem;
    gap: 0.68rem;
  }

  .jodoh-form-group-head h3 {
    font-size: 1rem;
  }

  .jodoh-form-group-head p {
    font-size: 0.8rem;
  }

  .jodoh-form-section {
    padding: 0.82rem;
    gap: 0.62rem;
  }

  .jodoh-field-head {
    gap: 0.3rem;
  }

  .jodoh-field-row {
    flex-wrap: wrap;
    align-items: flex-start;
  }

  .jodoh-field-label {
    font-size: 0.92rem;
    line-height: 1.25;
  }

  .jodoh-field-hint {
    font-size: 0.8rem;
    line-height: 1.5;
  }

  .jodoh-toggle-grid,
  .jodoh-segment-grid {
    gap: 0.56rem;
  }

  .jodoh-toggle-card span,
  .jodoh-segment-card span {
    min-height: 3.15rem;
    padding: 0.74rem 0.82rem;
  }

  .jodoh-select {
    min-height: 2.95rem;
    font-size: 0.95rem;
  }

  .jodoh-range-shell {
    gap: 0.62rem;
  }

  .jodoh-range-values strong {
    font-size: 0.96rem;
  }

  .jodoh-range-values span,
  .jodoh-range-endpoints {
    font-size: 0.72rem;
  }

  .jodoh-reveal-button {
    width: 100%;
    min-height: 3.05rem;
    justify-content: center;
  }

  .jodoh-result-stage {
    gap: 0.5rem;
    padding-top: 0.08rem;
  }

  .jodoh-share-top {
    flex-direction: row;
    align-items: flex-end;
    gap: 0.52rem;
  }

  .jodoh-result-summary {
    gap: 0.52rem;
  }

  .jodoh-result-action {
    width: auto;
  }

  .jodoh-result-button {
    width: auto;
    min-width: 6.2rem;
    min-height: 2.5rem;
    padding-inline: 0.92rem;
  }

  .jodoh-share-hero {
    padding: 0.72rem 0.76rem;
    gap: 0.34rem;
  }

  .jodoh-share-hero strong {
    font-size: clamp(1.92rem, 10vw, 2.45rem);
    line-height: 1;
  }

  .jodoh-share-caption {
    font-size: 0.74rem;
    line-height: 1.34;
  }

  .jodoh-dot-field {
    width: min(8.8rem, 100%);
    gap: 0.18rem;
    margin: 0 auto;
    filter: drop-shadow(0 14px 22px color-mix(in srgb, var(--jodoh-glow) 54%, transparent));
  }

  .jodoh-visual-card,
  .jodoh-population-board-shell {
    width: 100%;
    padding: 0.52rem 0.42rem 0.48rem;
  }

  .jodoh-visual-caption {
    gap: 0.12rem;
  }

  .jodoh-visual-caption .jodoh-share-caption {
    display: none;
  }

  .jodoh-population-board {
    --jodoh-hex-size: clamp(0.29rem, 1.15vw, 0.42rem);
    gap: 0.08rem;
  }

  .jodoh-population-row {
    gap: 0.08rem;
  }

  .jodoh-metrics {
    grid-template-columns: 1fr;
    gap: 0.44rem;
  }

  .jodoh-metric-card {
    padding: 0.62rem 0.66rem;
    gap: 0.22rem;
  }

  .jodoh-metric-card-population {
    padding: 0.82rem 0.76rem 0.8rem;
    gap: 0.32rem;
  }

  .jodoh-metric-card span {
    font-size: 0.68rem;
    letter-spacing: 0.05em;
  }

  .jodoh-metric-card strong {
    font-size: 1.22rem;
    line-height: 1;
  }

  .jodoh-metric-card-population strong {
    font-size: 1.78rem;
  }

  .jodoh-metric-lede {
    font-size: 0.84rem;
    line-height: 1.28;
  }

  .jodoh-rarity-meter {
    min-height: 1.4rem;
  }

  .jodoh-rarity-star {
    width: 0.8rem;
    height: 0.8rem;
  }

  .jodoh-metric-note {
    font-size: 0.72rem;
    line-height: 1.28;
  }

  .jodoh-metric-card-population .jodoh-metric-note {
    font-size: 0.8rem;
  }

  .jodoh-factor-card {
    padding: 0.76rem;
  }

  .jodoh-factor-item {
    grid-template-columns: 1fr;
    gap: 0.26rem;
  }

  .jodoh-factor-item strong {
    font-size: 1rem;
    line-height: 1.3;
  }

  .jodoh-note-strip {
    padding: 0.7rem 0.76rem;
  }

  .jodoh-note-strip p {
    font-size: 0.88rem;
    line-height: 1.48;
  }

  body[data-page='calculator'][data-calculator='jodoh'] .result-section {
    padding-left: 0.72rem;
    padding-right: 0.72rem;
  }
}

@media (max-width: 430px) {
  .jodoh-result-panel {
    gap: 0.6rem;
    padding: 0.68rem 0.76rem 0.82rem;
  }

  .jodoh-panel-heading {
    margin-bottom: 0.56rem;
  }

  .jodoh-panel-heading p {
    font-size: 0.82rem;
    line-height: 1.34;
  }

  .jodoh-result-stage {
    gap: 0.42rem;
    padding-top: 0;
  }

  .jodoh-result-summary,
  .jodoh-metrics {
    gap: 0.38rem;
  }

  .jodoh-share-hero {
    padding: 0.68rem 0.72rem;
    gap: 0.28rem;
  }

  .jodoh-share-hero strong {
    font-size: clamp(1.84rem, 9vw, 2.2rem);
  }

  .jodoh-share-caption {
    font-size: 0.72rem;
    line-height: 1.28;
  }

  .jodoh-result-button {
    min-width: 5.9rem;
    min-height: 2.35rem;
    padding-inline: 0.84rem;
  }

  .jodoh-share-hero .jodoh-visual-card {
    display: grid;
    width: calc(100% + 0.18rem);
    margin-top: 0.08rem;
    margin-left: -0.09rem;
    padding: 0.34rem 0.18rem 0.24rem;
    gap: 0.18rem;
  }

  .jodoh-share-hero .jodoh-visual-caption {
    display: none;
  }

  .jodoh-share-hero .jodoh-dot-field {
    width: min(5.6rem, 100%);
    gap: 0.12rem;
    filter: drop-shadow(0 10px 16px color-mix(in srgb, var(--jodoh-glow) 42%, transparent));
  }

  .jodoh-metric-card {
    padding: 0.56rem 0.62rem;
  }

  .jodoh-metric-card-population {
    padding: 0.74rem 0.7rem;
    gap: 0.28rem;
  }

  .jodoh-metric-card-population .jodoh-visual-card {
    display: grid;
    width: calc(100% + 0.18rem);
    margin-top: 0.14rem;
    margin-left: -0.09rem;
    padding: 0.38rem 0.14rem 0.22rem;
    background: linear-gradient(180deg, color-mix(in srgb, var(--jodoh-result-surface-start) 78%, transparent), color-mix(in srgb, var(--jodoh-result-surface-end) 86%, transparent));
  }

  .jodoh-metric-card-population .jodoh-visual-caption {
    display: none;
  }

  .jodoh-metric-card-population .jodoh-population-board {
    grid-template-columns: repeat(20, minmax(0, 1fr));
    gap: 0.09rem;
    justify-content: stretch;
  }

  .jodoh-metric-card-population .jodoh-hex {
    width: 100%;
    height: auto;
    aspect-ratio: 1;
    border-radius: 0.11rem;
  }

  .jodoh-metric-card strong {
    font-size: 1.12rem;
  }

  .jodoh-metric-card-population strong {
    font-size: 1.62rem;
  }

  .jodoh-metric-lede {
    font-size: 0.8rem;
    line-height: 1.24;
  }

  .jodoh-metric-note,
  .jodoh-metric-card-population .jodoh-metric-note {
    font-size: 0.74rem;
    line-height: 1.26;
  }
}

body[data-page='calculator'][data-calculator='jodoh'] .newsletter-block {
  border-color: var(--line);
  background: linear-gradient(145deg, var(--newsletter-surface-start), var(--newsletter-surface-end));
}

body[data-page='calculator'][data-calculator='jodoh'] .calculator-share-panel {
  border-color: var(--jodoh-panel-border);
  background:
    radial-gradient(circle at 100% 0%, var(--jodoh-hero-spot), transparent 34%),
    linear-gradient(135deg, var(--jodoh-panel-start) 0%, var(--jodoh-panel-end) 100%);
  box-shadow: inset 0 1px 0 var(--jodoh-panel-inset), 0 10px 26px rgba(78, 29, 39, 0.05);
}

body[data-page='calculator'][data-calculator='jodoh'] .calculator-share-emoji {
  background: var(--jodoh-pill-estimated-bg);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--jodoh-accent) 22%, transparent);
}

body[data-page='calculator'][data-calculator='jodoh'] .calculator-share-button {
  background: linear-gradient(135deg, var(--jodoh-ring-fill-start), var(--jodoh-ring-fill-end));
  box-shadow: 0 14px 30px color-mix(in srgb, var(--jodoh-glow) 130%, transparent);
}

body[data-page='calculator'][data-calculator='jodoh'] .result-section {
  border: 1px solid var(--jodoh-toggle-border);
  border-radius: calc(var(--radius-md) + 2px);
  background: rgba(255, 255, 255, 0.36);
  padding-left: 0.82rem;
  padding-right: 0.82rem;
}

body.calc-loading[data-page='calculator'][data-calculator='jodoh'] .jodoh-input-panel,
body.calc-loading[data-page='calculator'][data-calculator='jodoh'] .jodoh-result-panel {
  opacity: 0.001;
}

body[data-page='calculator'][data-calculator='jodoh'] .jodoh-share-hero,
body[data-page='calculator'][data-calculator='jodoh'] .jodoh-dot-field,
body[data-page='calculator'][data-calculator='jodoh'] .jodoh-population-board-shell,
body[data-page='calculator'][data-calculator='jodoh'] .jodoh-reveal-button,
body[data-page='calculator'][data-calculator='jodoh'] .jodoh-toggle-card span,
body[data-page='calculator'][data-calculator='jodoh'] .jodoh-segment-card span {
  transition: opacity 160ms ease, background 120ms ease, border-color 120ms ease, box-shadow 120ms ease, transform 260ms cubic-bezier(0.22, 1, 0.36, 1);
}

body[data-page='calculator'][data-calculator='jodoh'] .jodoh-result-panel[data-result-phase='calculating'] .jodoh-share-hero,
body[data-page='calculator'][data-calculator='jodoh'] .jodoh-result-panel[data-result-phase='calculating'] .jodoh-dot-field,
body[data-page='calculator'][data-calculator='jodoh'] .jodoh-result-panel[data-result-phase='calculating'] .jodoh-population-board-shell {
  opacity: 0.82;
  transform: scale(0.985);
}

body[data-page='calculator'][data-calculator='jodoh'] .jodoh-result-panel[data-result-phase='idle'] .jodoh-dot-field,
body[data-page='calculator'][data-calculator='jodoh'] .jodoh-result-panel[data-result-phase='idle'] .jodoh-population-board-shell {
  opacity: 0.62;
  transform: translateY(8px) scale(0.965);
}

body[data-page='calculator'][data-calculator='jodoh'] .jodoh-result-panel[data-result-phase='revealed'] .jodoh-dot-field,
body[data-page='calculator'][data-calculator='jodoh'] .jodoh-result-panel[data-result-phase='revealed'] .jodoh-population-board-shell,
body[data-page='calculator'][data-calculator='jodoh'] .jodoh-result-panel[data-result-phase='revealed'] .jodoh-share-hero {
  transform: translateY(0) scale(1);
}

@media (prefers-reduced-motion: reduce) {
  .jodoh-share-hero,
  .jodoh-dot-field,
  .jodoh-population-board-shell,
  .jodoh-dot,
  .jodoh-hex,
  .jodoh-toggle-card span,
  .jodoh-segment-card span,
  .calculator-share-button,
  .jodoh-reveal-button {
    transition: none;
  }
}

body[data-page='unit-conversion'] .converter-hero {
  margin-bottom: 0.78rem;
}

body[data-page='unit-conversion'] .converter-hero h1 {
  font-size: clamp(1.62rem, 3.4vw, 2.18rem);
}

.converter-shell {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--surface);
  box-shadow: var(--shadow-soft);
  padding: 0.84rem;
  margin-bottom: 1rem;
}

.converter-row {
  display: grid;
  grid-template-columns: minmax(170px, 1.15fr) minmax(150px, 0.95fr) 2.85rem minmax(150px, 0.95fr) auto minmax(220px, 1.15fr);
  grid-template-areas: 'value from swap to equals output';
  gap: 0.7rem 0.5rem;
  align-items: end;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: linear-gradient(145deg, var(--surface-solid), var(--metric-bg));
  padding: 0.7rem;
}

.converter-row > * {
  min-width: 0;
}

.converter-field {
  display: grid;
  gap: 0.34rem;
  min-width: 0;
}

.converter-field-value {
  grid-area: value;
}

.converter-field-from {
  grid-area: from;
}

.converter-field-to {
  grid-area: to;
}

.converter-field-output {
  grid-area: output;
}

.converter-field-label {
  margin: 0;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.converter-input,
.converter-select,
.converter-swap {
  min-height: 2.85rem;
  min-width: 0;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  background: var(--input-bg);
  color: var(--text);
  font: inherit;
  font-size: 0.95rem;
  line-height: 1;
}

.converter-input {
  padding: 0.58rem 0.84rem;
  font-variant-numeric: tabular-nums;
}

.converter-select {
  padding: 0.58rem 2rem 0.58rem 0.82rem;
  cursor: pointer;
}

.converter-select:disabled {
  cursor: default;
  opacity: 1;
  color: var(--text);
  background:
    linear-gradient(145deg, var(--surface-solid), var(--metric-bg));
}

body[data-converter-mode='locked'] .converter-row[data-converter-layout='locked'] {
  grid-template-columns: minmax(170px, 1.15fr) minmax(150px, 0.95fr) minmax(150px, 0.95fr) auto minmax(220px, 1.15fr);
  grid-template-areas: 'value from to equals output';
}

body[data-converter-mode='locked'] .converter-presets,
body[data-converter-mode='locked'] .converter-swap {
  display: none;
}

.converter-swap {
  grid-area: swap;
  padding: 0;
  cursor: pointer;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1rem;
  font-weight: 700;
  color: var(--primary);
  align-self: end;
}

.converter-swap:hover,
.converter-swap:focus-visible {
  border-color: var(--primary);
  transform: translateY(-1px);
}

.converter-equals {
  grid-area: equals;
  color: var(--muted);
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  font-size: 1.15rem;
  align-self: end;
  padding-bottom: 0.85rem;
}

.converter-output-wrap {
  margin: 0;
  min-height: 2.85rem;
  min-width: 0;
  padding: 0.58rem 0.94rem;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  background: var(--surface-solid);
  display: inline-flex;
  align-items: baseline;
  justify-content: flex-end;
  gap: 0.32rem;
  white-space: nowrap;
}

.converter-output-value {
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(1.18rem, 2vw, 1.5rem);
  line-height: 1;
  color: var(--primary);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

.converter-output-unit {
  color: var(--muted);
  font-weight: 700;
  font-size: 0.9rem;
}

.converter-meta {
  margin: 0.65rem 0 0;
  color: var(--muted);
  font-size: 0.87rem;
}

.converter-shortcut-footer {
  margin: 0.28rem 0 0;
}

.converter-full-link {
  color: var(--primary);
  font-size: 0.87rem;
  font-weight: 700;
  text-decoration: none;
}

.converter-full-link:hover,
.converter-full-link:focus-visible {
  text-decoration: underline;
}

.converter-fixed-unit {
  min-height: 2.85rem;
  padding: 0.58rem 0.82rem;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-sm);
  background: linear-gradient(145deg, var(--surface-solid), var(--metric-bg));
  color: var(--text);
  display: flex;
  align-items: center;
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.2;
}

.converter-fixed-unit[hidden] {
  display: none !important;
}

.converter-presets {
  margin-top: 0.62rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.converter-preset {
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  background: var(--surface-solid);
  color: var(--primary);
  font: inherit;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 0.8rem;
  font-weight: 700;
  padding: 0.34rem 0.62rem;
  cursor: pointer;
  transition: transform 120ms ease, border-color 120ms ease;
}

.converter-preset:hover,
.converter-preset:focus-visible {
  transform: translateY(-1px);
  border-color: var(--primary);
}

.converter-preset.is-active {
  border-color: color-mix(in srgb, var(--primary) 60%, var(--line-strong));
  background: color-mix(in srgb, var(--primary) 10%, var(--surface-solid));
}

.converter-error {
  margin: 0.42rem 0 0;
  min-height: 1.05rem;
  color: var(--danger);
  font-size: 0.86rem;
  font-weight: 600;
}

.calculator-layout {
  display: grid;
  grid-template-columns: minmax(360px, 0.92fr) minmax(440px, 1.08fr);
  gap: 0.94rem;
  align-items: start;
}

.calculator-panel,
.calculator-result,
.methodology-hero,
.methodology-table-wrap,
.methodology-notes {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--surface);
  box-shadow: var(--shadow-soft);
  padding: 0.9rem;
}

.calculator-panel h2,
.calculator-result h2 {
  margin-bottom: 0.66rem;
}

.error-banner {
  margin: 0 0 0.58rem;
  color: var(--danger);
  font-size: 0.94rem;
  font-weight: 600;
}

.field {
  margin-bottom: 0.68rem;
}

.field-section-card {
  margin: 0 0 0.68rem;
  min-width: 0;
  padding: 0.68rem;
  border: 1px solid rgba(var(--field-section-accent-rgb, 11, 60, 138), var(--section-card-border-opacity));
  border-radius: calc(var(--radius-md) + 2px);
  background:
    linear-gradient(180deg, rgba(var(--field-section-accent-rgb, 11, 60, 138), var(--section-card-accent-opacity)) 0%, rgba(var(--field-section-accent-rgb, 11, 60, 138), 0) 36%),
    linear-gradient(180deg, var(--section-card-surface-start), var(--section-card-surface-end));
  box-shadow: inset 0 1px 0 var(--section-card-inset);
}

.field-section-heading {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  width: 100%;
  margin: 0 0 0.42rem;
  padding: 0;
  border: 0;
  color: var(--primary);
  font-family: 'Space Grotesk', sans-serif;
  font-size: 0.96rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.field-section-heading-icon {
  display: inline-grid;
  place-items: center;
  width: 1.8rem;
  height: 1.8rem;
  border-radius: 999px;
  background: rgba(var(--field-section-accent-rgb, 11, 60, 138), 0.12);
  box-shadow: inset 0 0 0 1px rgba(var(--field-section-accent-rgb, 11, 60, 138), 0.14);
  font-size: 0.98rem;
}

.field-section-heading-title {
  color: rgb(var(--field-section-accent-rgb, 11, 60, 138));
}

.field-section-description {
  margin: 0 0 0.58rem;
  color: var(--form-support-text);
  font-size: 0.84rem;
  line-height: 1.45;
}

.field-section-grid {
  display: grid;
  grid-template-columns: repeat(var(--field-section-columns, 1), minmax(0, 1fr));
  gap: 0.62rem;
}

.field label {
  display: block;
  margin-bottom: 0.3rem;
  font-weight: 600;
  font-size: 0.91rem;
}

.field-input-shell {
  display: flex;
  align-items: stretch;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-sm);
  background: var(--input-bg);
  overflow: hidden;
}

.field-prefix {
  display: inline-flex;
  align-items: center;
  padding: 0 0.72rem;
  border-right: 1px solid rgba(var(--field-section-accent-rgb, 11, 60, 138), 0.18);
  background: rgba(var(--field-section-accent-rgb, 11, 60, 138), 0.08);
  color: rgb(var(--field-section-accent-rgb, 11, 60, 138));
  font-family: 'Space Grotesk', sans-serif;
  font-size: 0.84rem;
  font-weight: 700;
}

.field-input-shell input {
  border: 0;
  border-radius: 0;
  background: transparent;
}

.field-input-shell:focus-within {
  border-color: rgba(var(--field-section-accent-rgb, 11, 60, 138), 0.58);
  box-shadow: 0 0 0 3px rgba(var(--field-section-accent-rgb, 11, 60, 138), 0.14);
}

.field-toggle {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.44rem;
}

.field-toggle-option {
  position: relative;
  display: block;
}

.field-toggle-option input {
  position: absolute;
  inset: 0;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.field-toggle-option span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 2.7rem;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-sm);
  background: var(--input-bg);
  color: var(--muted);
  font-family: 'Space Grotesk', sans-serif;
  font-size: 0.9rem;
  font-weight: 700;
  text-align: center;
  transition: border-color 120ms ease, background-color 120ms ease, color 120ms ease, transform 120ms ease;
}

.field-toggle-option input:checked + span {
  border-color: rgba(var(--toggle-tone-rgb, 11, 60, 138), 0.45);
  background: rgba(var(--toggle-tone-rgb, 11, 60, 138), 0.12);
  color: rgb(var(--toggle-tone-rgb, 11, 60, 138));
  transform: translateY(-1px);
}

.field-toggle-option input:focus-visible + span {
  outline: 3px solid var(--focus-ring);
  outline-offset: 1px;
}

body[data-page='calculator'][data-calculator-form-style='section-cards'] #calculator-form {
  display: grid;
  gap: 0.62rem;
}

body[data-page='calculator'][data-calculator-form-style='section-cards'] .field {
  margin-bottom: 0;
  padding: 0.58rem 0.6rem 0.62rem;
  border: 1px solid rgba(var(--field-section-accent-rgb, 11, 60, 138), var(--section-field-border-opacity));
  border-radius: var(--radius-sm);
  background: linear-gradient(180deg, var(--section-field-surface-start), rgba(var(--field-section-accent-rgb, 11, 60, 138), var(--section-field-accent-opacity)));
  box-shadow: inset 0 1px 0 var(--section-card-inset);
}

body[data-page='calculator'][data-calculator-form-style='section-cards'] .field[data-field-section] {
  border-top: 3px solid rgba(var(--field-section-accent-rgb, 11, 60, 138), 0.38);
}

body[data-page='calculator'][data-calculator-form-style='section-cards'] .field-section-heading {
  margin-bottom: 0.28rem;
}

body[data-page='calculator'][data-calculator-form-style='section-cards'] .field[data-conditional-field='true'] {
  border-style: dashed;
  background: linear-gradient(180deg, rgba(var(--field-section-accent-rgb, 11, 60, 138), var(--section-conditional-accent-opacity)), var(--section-conditional-surface-end));
}

.field-hint {
  margin: 0.28rem 0 0;
  color: var(--form-support-text);
  font-size: 0.84rem;
  line-height: 1.45;
}

.field-hint-link {
  color: var(--link);
  font-weight: 600;
  text-underline-offset: 0.14em;
}

.field-hint-link:hover,
.field-hint-link:focus-visible {
  color: var(--link-hover);
}

.field-error {
  margin: 0.28rem 0 0;
  color: var(--danger);
  font-size: 0.86rem;
  min-height: 1rem;
}

.field.has-error > input,
.field.has-error select,
.field.has-error .field-input-shell {
  border-color: rgba(180, 35, 24, 0.62);
  box-shadow: 0 0 0 3px rgba(180, 35, 24, 0.12);
}

.field.has-error .field-toggle-option span {
  border-color: rgba(180, 35, 24, 0.62);
}

.calculator-result {
  position: sticky;
  top: 0.88rem;
  max-height: min(760px, calc(100vh - 1.76rem));
  overflow: auto;
}

body.calc-loading[data-page='calculator'][data-calculator='housing-loan'] #calculator-form {
  min-height: 24rem;
}

body.calc-loading[data-page='calculator'][data-calculator='housing-loan'] #result-highlights {
  min-height: 7.6rem;
}

body.calc-loading[data-page='calculator'][data-calculator='housing-loan'] #result-projection-chart {
  min-height: 18rem;
}

body.calc-loading[data-page='calculator'][data-calculator='housing-loan'] #result-breakdown {
  min-height: 14rem;
}

body.calc-loading[data-page='calculator'][data-calculator='housing-loan'] #result-assumptions,
body.calc-loading[data-page='calculator'][data-calculator='housing-loan'] #result-sources {
  min-height: 4.6rem;
}

.metric-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(145px, 1fr));
  gap: 0.52rem;
  margin-bottom: 0.72rem;
  align-items: stretch;
}

.result-context-note {
  margin: -0.1rem 0 0.72rem;
  padding: 0.5rem 0.58rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--primary-soft);
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.4;
}

.metric {
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--metric-bg);
  padding: 0.58rem;
  display: grid;
  grid-template-rows: auto auto;
  gap: 0.32rem;
  align-content: start;
}

.metric[class*='metric-tone-'] {
  --metric-tone-active-rgb: var(--metric-tone-rgb-light, var(--metric-tone-rgb));
  border-color: rgba(var(--metric-tone-active-rgb), 0.32);
  background: linear-gradient(170deg, rgba(var(--metric-tone-active-rgb), 0.14), var(--metric-bg));
}

:root[data-theme='dark'] .metric[class*='metric-tone-'] {
  --metric-tone-active-rgb: var(--metric-tone-rgb-dark, var(--metric-tone-rgb-light, var(--metric-tone-rgb)));
}

.metric-label {
  margin: 0;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.3;
}

.metric[class*='metric-tone-'] .metric-label {
  color: rgba(var(--metric-tone-active-rgb), 0.88);
}

.metric-value {
  margin: 0;
  font-size: clamp(1.05rem, 1.2vw, 1.42rem);
  line-height: 1.08;
  color: var(--primary);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
  white-space: nowrap;
}

.metric[class*='metric-tone-'] .metric-value {
  color: rgb(var(--metric-tone-active-rgb));
}

.metric-tone-epf-employee {
  --metric-tone-rgb: var(--metric-tone-epf-employee-rgb);
}

.metric-tone-epf-employer {
  --metric-tone-rgb: var(--metric-tone-epf-employer-rgb);
}

.metric-tone-epf-account-1 {
  --metric-tone-rgb: var(--metric-tone-epf-account-1-rgb);
}

.metric-tone-epf-account-2 {
  --metric-tone-rgb: var(--metric-tone-epf-account-2-rgb);
}

.metric-tone-epf-account-3 {
  --metric-tone-rgb: var(--metric-tone-epf-account-3-rgb);
}

.metric-tone-epf-account-emas {
  --metric-tone-rgb: var(--metric-tone-epf-account-emas-rgb);
}

.metric-tone-pcb-monthly {
  --metric-tone-rgb: var(--metric-tone-pcb-monthly-rgb);
}

.metric-tone-pcb-annual {
  --metric-tone-rgb: var(--metric-tone-pcb-annual-rgb);
}

.metric-tone-pcb-chargeable {
  --metric-tone-rgb: var(--metric-tone-pcb-chargeable-rgb);
}

.range-scale-wrap {
  display: grid;
  gap: 0.72rem;
}

.range-scale-wrap h3 {
  margin: 0;
}

.range-scale-readout {
  --metric-tone-active-rgb: var(--metric-tone-rgb-light, var(--metric-tone-rgb, 15, 23, 42));
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.8rem;
  flex-wrap: wrap;
}

:root[data-theme='dark'] .range-scale-readout {
  --metric-tone-active-rgb: var(--metric-tone-rgb-dark, var(--metric-tone-rgb-light, var(--metric-tone-rgb, 191, 219, 254)));
}

.range-scale-current-value {
  font-size: clamp(1.4rem, 2vw, 1.9rem);
  line-height: 1;
  letter-spacing: -0.02em;
  color: rgb(var(--metric-tone-active-rgb));
}

.range-scale-current-label {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--muted);
}

.range-scale-figure {
  display: grid;
  gap: 0.5rem;
}

.range-scale-track {
  position: relative;
  height: 1rem;
  border-radius: 999px;
  overflow: visible;
  background: var(--metric-bg);
  border: 1px solid var(--line);
}

.range-scale-segment {
  --metric-tone-active-rgb: var(--metric-tone-rgb-light, var(--metric-tone-rgb, 15, 23, 42));
  position: absolute;
  top: 0;
  bottom: 0;
  background: rgba(var(--metric-tone-active-rgb), 0.74);
}

:root[data-theme='dark'] .range-scale-segment {
  --metric-tone-active-rgb: var(--metric-tone-rgb-dark, var(--metric-tone-rgb-light, var(--metric-tone-rgb, 191, 219, 254)));
}

.range-scale-segment:first-child {
  border-top-left-radius: 999px;
  border-bottom-left-radius: 999px;
}

.range-scale-segment:last-child {
  border-top-right-radius: 999px;
  border-bottom-right-radius: 999px;
}

.range-scale-segment-label {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.range-scale-marker {
  --metric-tone-active-rgb: var(--metric-tone-rgb-light, var(--metric-tone-rgb, 15, 23, 42));
  position: absolute;
  top: -1.58rem;
  transform: translateX(-50%);
  display: grid;
  justify-items: center;
  gap: 0.14rem;
  z-index: 2;
}

:root[data-theme='dark'] .range-scale-marker {
  --metric-tone-active-rgb: var(--metric-tone-rgb-dark, var(--metric-tone-rgb-light, var(--metric-tone-rgb, 191, 219, 254)));
}

.range-scale-marker-pill {
  min-width: 2.9rem;
  padding: 0.26rem 0.5rem;
  border-radius: 999px;
  background: rgb(var(--metric-tone-active-rgb));
  color: #fff;
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1;
  text-align: center;
  box-shadow: var(--shadow-soft);
}

:root[data-theme='dark'] .range-scale-marker-pill {
  color: rgb(15, 23, 42);
}

.range-scale-marker-line {
  width: 2px;
  height: 1.7rem;
  border-radius: 999px;
  background: rgb(var(--metric-tone-active-rgb));
}

.range-scale-marker-arrow {
  width: 0;
  height: 0;
  margin-top: -0.06rem;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-bottom: 8px solid rgb(var(--metric-tone-active-rgb));
  filter: drop-shadow(0 1px 0 rgba(255, 255, 255, 0.35));
}

:root[data-theme='dark'] .range-scale-marker-arrow {
  filter: drop-shadow(0 1px 0 rgba(15, 23, 42, 0.35));
}

.range-scale-ticks {
  position: relative;
  height: 1.6rem;
  margin-top: 0.52rem;
}

.range-scale-tick {
  position: absolute;
  top: 0.6rem;
  transform: translateX(-50%);
  font-size: 0.74rem;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}

.range-scale-tick::before {
  content: '';
  position: absolute;
  top: -0.52rem;
  left: 50%;
  width: 1px;
  height: 0.5rem;
  transform: translateX(-50%);
  background: color-mix(in srgb, var(--line) 88%, transparent);
}

.range-scale-legend {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.85rem;
}

.range-scale-legend li {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: var(--muted);
  font-size: 0.82rem;
}

.range-scale-legend-swatch {
  --metric-tone-active-rgb: var(--metric-tone-rgb-light, var(--metric-tone-rgb, 15, 23, 42));
  width: 0.82rem;
  height: 0.82rem;
  border-radius: 999px;
  border: 1px solid rgba(var(--metric-tone-active-rgb), 0.28);
  background: rgba(var(--metric-tone-active-rgb), 0.72);
}

:root[data-theme='dark'] .range-scale-legend-swatch {
  --metric-tone-active-rgb: var(--metric-tone-rgb-dark, var(--metric-tone-rgb-light, var(--metric-tone-rgb, 191, 219, 254)));
}

.result-section {
  margin-top: 0.6rem;
  padding-top: 0.6rem;
  border-top: 1px solid var(--line);
}

.result-section summary {
  cursor: pointer;
  font-weight: 700;
  color: var(--text);
}

.result-list {
  margin: 0.5rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.42rem;
}

.result-list li {
  display: flex;
  justify-content: space-between;
  gap: 0.7rem;
  border-bottom: 1px solid var(--result-divider);
  padding-bottom: 0.35rem;
}

.result-list.warnings li,
.result-list.sources li,
.result-list#result-assumptions li {
  display: block;
  border-bottom: 0;
  padding-bottom: 0;
}

.result-list.sources a {
  color: var(--primary);
  word-break: break-word;
  overflow-wrap: anywhere;
  line-height: 1.35;
}

.mobile-sticky-summary {
  position: fixed;
  left: 0.8rem;
  right: 0.8rem;
  bottom: 0.7rem;
  z-index: 45;
  border: 1px solid var(--line-strong);
  border-radius: calc(var(--radius-md) - 1px);
  background: var(--surface-solid);
  box-shadow: var(--shadow);
  padding: 0.58rem 0.62rem 0.66rem;
  display: none;
  gap: 0.52rem;
}

.mobile-sticky-summary-title {
  margin: 0;
  color: var(--muted);
  font-size: 0.79rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.mobile-sticky-summary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.5rem;
}

.mobile-sticky-summary-item {
  margin: 0;
  padding: 0.44rem 0.5rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--metric-bg);
}

.mobile-sticky-summary-item p {
  margin: 0;
  color: var(--muted);
  font-size: 0.74rem;
  line-height: 1.28;
}

.mobile-sticky-summary-item strong {
  display: block;
  margin-top: 0.2rem;
  color: var(--primary);
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.1;
}

.mobile-sticky-summary-item[class*='metric-tone-'] {
  --metric-tone-active-rgb: var(--metric-tone-rgb-light, var(--metric-tone-rgb));
  border-color: rgba(var(--metric-tone-active-rgb), 0.34);
  background: linear-gradient(170deg, rgba(var(--metric-tone-active-rgb), 0.15), var(--metric-bg));
}

:root[data-theme='dark'] .mobile-sticky-summary-item[class*='metric-tone-'] {
  --metric-tone-active-rgb: var(--metric-tone-rgb-dark, var(--metric-tone-rgb-light, var(--metric-tone-rgb)));
}

.mobile-sticky-summary-item[class*='metric-tone-'] p {
  color: rgba(var(--metric-tone-active-rgb), 0.9);
}

.mobile-sticky-summary-item[class*='metric-tone-'] strong {
  color: rgb(var(--metric-tone-active-rgb));
}

.mobile-sticky-summary-button {
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  background: linear-gradient(135deg, var(--primary), var(--primary-strong));
  color: #fff;
  font: inherit;
  font-weight: 700;
  font-size: 0.85rem;
  min-height: 2.8rem;
  padding: 0.62rem 0.68rem;
  cursor: pointer;
}

.mobile-sticky-summary-button:hover,
.mobile-sticky-summary-button:focus-visible {
  filter: brightness(1.04);
}

.mobile-sticky-summary-chart[hidden] {
  display: none;
}

.compact-range-scale {
  display: grid;
  gap: 0.28rem;
}

.compact-range-scale-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.45rem;
  flex-wrap: wrap;
}

.compact-range-scale-title {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.compact-range-scale-status {
  font-size: 0.74rem;
  font-weight: 700;
  color: var(--primary);
}

.compact-range-scale-track {
  position: relative;
  height: 0.6rem;
  border-radius: 999px;
  overflow: visible;
  background: var(--metric-bg);
  border: 1px solid var(--line);
}

.compact-range-scale-segment {
  --metric-tone-active-rgb: var(--metric-tone-rgb-light, var(--metric-tone-rgb, 15, 23, 42));
  position: absolute;
  top: 0;
  bottom: 0;
  background: rgba(var(--metric-tone-active-rgb), 0.72);
}

:root[data-theme='dark'] .compact-range-scale-segment {
  --metric-tone-active-rgb: var(--metric-tone-rgb-dark, var(--metric-tone-rgb-light, var(--metric-tone-rgb, 191, 219, 254)));
}

.compact-range-scale-marker {
  --metric-tone-active-rgb: var(--metric-tone-rgb-light, var(--metric-tone-rgb, 15, 23, 42));
  position: absolute;
  top: -0.06rem;
  transform: translateX(-50%);
  display: grid;
  justify-content: center;
  justify-items: center;
}

:root[data-theme='dark'] .compact-range-scale-marker {
  --metric-tone-active-rgb: var(--metric-tone-rgb-dark, var(--metric-tone-rgb-light, var(--metric-tone-rgb, 191, 219, 254)));
}

.compact-range-scale-marker-line {
  width: 2px;
  height: 0.78rem;
  background: rgb(var(--metric-tone-active-rgb));
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.55);
}

:root[data-theme='dark'] .compact-range-scale-marker-line {
  box-shadow: 0 0 0 1px rgba(15, 23, 42, 0.5);
}

.compact-range-scale-marker-arrow {
  width: 0;
  height: 0;
  margin-top: -0.02rem;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-bottom: 7px solid rgb(var(--metric-tone-active-rgb));
  filter: drop-shadow(0 1px 0 rgba(255, 255, 255, 0.35));
}

:root[data-theme='dark'] .compact-range-scale-marker-arrow {
  filter: drop-shadow(0 1px 0 rgba(15, 23, 42, 0.35));
}

.compact-range-scale-axis {
  display: flex;
  justify-content: space-between;
  gap: 0.45rem;
  color: var(--muted);
  font-size: 0.7rem;
  font-variant-numeric: tabular-nums;
}

.mobile-sticky-summary[hidden] {
  display: none;
}

.projection-chart-wrap {
  display: grid;
  gap: 0.55rem;
}

.projection-chart-wrap h3 {
  margin: 0;
}

.projection-chart-description {
  margin: 0;
  color: var(--muted);
  font-size: 0.83rem;
  line-height: 1.45;
}

.projection-chart-scroll {
  position: relative;
  overflow-x: auto;
}

.projection-chart {
  display: block;
  min-width: 540px;
  width: 100%;
  height: auto;
}

.projection-grid line {
  stroke: var(--line);
  stroke-width: 1;
}

.projection-axis-labels text {
  fill: var(--muted);
  font-size: 11px;
  font-family: 'Manrope', 'Segoe UI', sans-serif;
}

.projection-series-line {
  fill: none;
  stroke-width: 3;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.projection-series-area {
  stroke: none;
}

.projection-series-area.projection-series-0 {
  fill: var(--primary);
  opacity: 0.12;
}

.projection-series-area.projection-series-1 {
  fill: var(--secondary);
  opacity: 0.1;
}

.projection-series-area.projection-series-2 {
  fill: var(--primary-strong);
  opacity: 0.1;
}

.projection-point-marker {
  fill: var(--surface-solid);
  stroke-width: 1.6;
  vector-effect: non-scaling-stroke;
  transition: fill 120ms ease, stroke-width 120ms ease;
  cursor: pointer;
}

.projection-point-marker:hover,
.projection-point-marker:focus-visible {
  fill: var(--primary-soft);
  stroke-width: 2.2;
  outline: none;
}

.projection-series-0 {
  stroke: var(--primary);
}

.projection-series-1 {
  stroke: var(--secondary);
}

.projection-series-2 {
  stroke: var(--primary-strong);
}

.projection-point-marker.projection-series-0 {
  stroke: var(--primary);
}

.projection-point-marker.projection-series-1 {
  stroke: var(--secondary);
}

.projection-point-marker.projection-series-2 {
  stroke: var(--primary-strong);
}

.projection-tooltip {
  position: absolute;
  left: 0;
  top: 0;
  transform: translate(-50%, -100%);
  background: var(--surface-solid);
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  color: var(--text);
  padding: 0.3rem 0.45rem;
  font-size: 0.76rem;
  line-height: 1.2;
  white-space: nowrap;
  box-shadow: var(--shadow-soft);
  pointer-events: none;
  z-index: 3;
}

.projection-tooltip::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -5px;
  width: 9px;
  height: 9px;
  background: var(--surface-solid);
  border-right: 1px solid var(--line-strong);
  border-bottom: 1px solid var(--line-strong);
  transform: translateX(-50%) rotate(45deg);
}

.projection-chart-axis-meta {
  margin: 0;
  display: flex;
  justify-content: space-between;
  gap: 0.6rem;
  color: var(--muted);
  font-size: 0.8rem;
}

.projection-chart-axis-meta span:last-child {
  text-align: right;
}

.projection-chart-legend {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem 0.9rem;
}

.projection-chart-legend li {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: var(--muted);
  font-size: 0.82rem;
}

.projection-legend-swatch {
  width: 0.85rem;
  height: 0.85rem;
  border-radius: 999px;
  border: 1px solid var(--line-strong);
}

.projection-legend-swatch.projection-series-0 {
  background: var(--primary);
}

.projection-legend-swatch.projection-series-1 {
  background: var(--secondary);
}

.projection-legend-swatch.projection-series-2 {
  background: var(--primary-strong);
}

.methodology-hero {
  margin-bottom: 1rem;
}

.methodology-hero h1 {
  margin-top: 0;
  font-size: clamp(1.7rem, 4.4vw, 2.8rem);
}

.methodology-hero p,
.methodology-notes p {
  margin-bottom: 0;
  color: var(--muted);
}

.methodology-controls {
  margin-bottom: 1rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 0.9rem;
  background: var(--surface);
  box-shadow: var(--shadow-soft);
  display: grid;
  gap: 0.55rem;
}

.methodology-controls label {
  font-weight: 600;
}

.methodology-controls input {
  width: 100%;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-sm);
  background: var(--input-bg);
  color: var(--text);
  padding: 0.55rem 0.7rem;
  font: inherit;
}

#methodology-search-status {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
}

.methodology-table-wrap,
.methodology-notes {
  margin-bottom: 1rem;
}

.table-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.methodology-table-wrap table {
  min-width: 980px;
}

table {
  border-collapse: collapse;
  width: 100%;
  min-width: 760px;
}

th,
td {
  border: 1px solid var(--line);
  padding: 0.55rem;
  text-align: left;
  vertical-align: top;
  font-size: 0.9rem;
}

th {
  background: var(--table-head-bg);
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 600;
}

.methodology-calculator-link {
  color: var(--primary);
  font-weight: 700;
  text-decoration: none;
}

.methodology-calculator-link:hover,
.methodology-calculator-link:focus-visible {
  text-decoration: underline;
}

.methodology-calculator-id {
  margin: 0.2rem 0 0;
  color: var(--muted);
  font-size: 0.78rem;
}

.methodology-source-list {
  margin: 0;
  padding-left: 1rem;
  display: grid;
  gap: 0.22rem;
}

.methodology-source-list a {
  color: var(--primary);
  text-decoration: none;
}

.methodology-source-list a:hover,
.methodology-source-list a:focus-visible {
  text-decoration: underline;
}

.methodology-empty {
  color: var(--muted);
}

.methodology-cell-error {
  margin: 0;
  color: var(--danger);
  font-weight: 600;
}

.methodology-cell-error code {
  color: var(--danger);
  font-weight: 500;
  font-size: 0.8rem;
}

.error-state {
  border: 1px solid rgba(180, 35, 24, 0.35);
  border-radius: var(--radius-sm);
  background: var(--error-bg);
  color: var(--danger);
  padding: 0.8rem;
  font-weight: 600;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
summary:focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 1px;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

@media (max-width: 1024px) {
  .site-header {
    grid-template-columns: 1fr;
    gap: 0.8rem;
  }

  .lang-switch {
    justify-self: start;
    width: fit-content;
  }

  .theme-toggle {
    justify-self: start;
  }

  .brand {
    min-height: 2.75rem;
    align-items: center;
  }

  .main-nav {
    gap: 0.4rem;
  }

  .main-nav a {
    min-height: 2.75rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem 0.88rem;
  }

  .lang-switch button,
  .theme-toggle {
    width: 2.75rem;
    height: 2.75rem;
  }

  .hero-grid,
  .calculator-layout {
    grid-template-columns: 1fr;
  }

  .calculator-result {
    position: static;
    max-height: none;
    overflow: visible;
  }

  .converter-row {
    grid-template-columns: minmax(120px, 1fr) minmax(130px, 0.9fr) 2.85rem minmax(130px, 0.9fr);
    grid-template-areas:
      'value from swap to'
      'output output output output';
    border-radius: var(--radius-md);
  }

  .converter-equals {
    display: none;
  }

  .converter-output-wrap {
    justify-content: flex-start;
    border-radius: var(--radius-sm);
  }

  body[data-converter-mode='locked'] .converter-row[data-converter-layout='locked'] {
    grid-template-columns: minmax(120px, 1fr) minmax(130px, 0.9fr) minmax(130px, 0.9fr);
    grid-template-areas:
      'value from to'
      'output output output';
  }
}

@media (min-width: 1025px) {
  body[data-page='calculator'] .metric-grid {
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  }

  .home-intro-shell {
    grid-template-columns: minmax(320px, 0.92fr) minmax(0, 1.08fr);
    align-items: stretch;
  }

  .home-search-strip-section {
    grid-column: 1 / -1;
  }

  .home-calculator {
    grid-column: 1;
    align-self: start;
  }

  .home-calculator-keypad {
    align-content: start;
  }

  .home-calc-nudge {
    margin-top: 0;
    padding-top: 0.15rem;
  }

  .home-intro-shell .hero-grid {
    grid-column: 2;
    grid-template-columns: 1fr;
  }

  .metric {
    grid-template-rows: minmax(2.4rem, auto) auto;
  }
}

@media (min-width: 1440px) {
  body[data-page='calculator'] .calculator-layout {
    grid-template-columns: minmax(420px, 0.9fr) minmax(560px, 1.1fr);
    gap: 1.25rem;
  }
}

@media (min-width: 701px) and (max-width: 1024px) {
  body[data-page='calculator'][data-calculator='jodoh'] .site-header {
    grid-template-columns: minmax(0, 1fr) auto auto auto;
    gap: 0.75rem;
    padding: 0.8rem 1rem;
    align-items: center;
  }

  body[data-page='calculator'][data-calculator='jodoh'] .brand-block {
    min-width: 0;
  }

  body[data-page='calculator'][data-calculator='jodoh'] .brand-tagline {
    display: none;
  }

  body[data-page='calculator'][data-calculator='jodoh'] .main-nav {
    min-width: 0;
    flex-wrap: nowrap;
    justify-content: flex-end;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
  }

  body[data-page='calculator'][data-calculator='jodoh'] .main-nav::-webkit-scrollbar {
    display: none;
  }

  body[data-page='calculator'][data-calculator='jodoh'] .main-nav a {
    min-height: 2.4rem;
    padding: 0.42rem 0.72rem;
    white-space: nowrap;
  }

  body[data-page='calculator'][data-calculator='jodoh'] .lang-switch {
    justify-self: end;
  }

  body[data-page='calculator'][data-calculator='jodoh'] .lang-switch button,
  body[data-page='calculator'][data-calculator='jodoh'] .theme-toggle {
    width: 2.4rem;
    height: 2.4rem;
  }
}

@media (max-width: 700px) {
  main,
  .site-footer,
  .site-header {
    width: min(1140px, calc(100vw - 1rem));
  }

  .site-header {
    margin-top: 0.5rem;
    margin-bottom: 0.7rem;
    padding: 0.52rem 0.58rem;
    gap: 0.35rem;
    border-radius: 14px;
    grid-template-columns: 1fr auto auto;
    grid-template-areas:
      'brand theme lang'
      'nav nav nav';
    align-items: center;
  }

  .brand-block {
    grid-area: brand;
  }

  .brand {
    font-size: clamp(1.08rem, 5.8vw, 1.4rem);
    gap: 0.34rem;
  }

  .brand-tagline {
    display: none;
  }

  .converter-shell {
    padding: 0.7rem;
  }

  .converter-row {
    grid-template-columns: 1fr auto;
    grid-template-areas:
      'value value'
      'from from'
      'swap swap'
      'to to'
      'output output';
    gap: 0.45rem;
    border-radius: var(--radius-md);
  }

  .converter-swap {
    width: 100%;
    border-radius: var(--radius-sm);
  }

  .converter-input,
  .converter-select,
  .converter-fixed-unit,
  .converter-output-wrap {
    width: 100%;
    border-radius: var(--radius-sm);
  }

  body[data-converter-mode='locked'] .converter-row[data-converter-layout='locked'] {
    grid-template-columns: 1fr;
    grid-template-areas:
      'value value'
      'from from'
      'to to'
      'output output';
  }

  .category-view-all {
    margin-left: 0;
  }

  .main-nav {
    grid-area: nav;
    display: flex;
    flex-wrap: wrap;
    gap: 0.28rem;
    justify-self: start;
  }

  .main-nav a {
    text-align: center;
    min-height: 2.6rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.34rem 0.62rem;
    font-size: 0.78rem;
    white-space: nowrap;
  }

  .theme-toggle {
    grid-area: theme;
    width: 2.55rem;
    height: 2.55rem;
    font-size: 0.9rem;
    justify-self: start;
  }

  .lang-switch {
    grid-area: lang;
    justify-self: end;
  }

  .lang-switch button {
    width: 2.25rem;
    height: 2.55rem;
    font-size: 0.84rem;
  }

  body[data-page='calculator'][data-calculator-mobile-summary='enabled']:not([data-mobile-summary-suppressed='true']) {
    padding-bottom: 13rem;
  }

  body[data-page='calculator'][data-calculator-mobile-summary='enabled'] .mobile-sticky-summary:not([hidden]) {
    display: grid;
  }

  body[data-page='calculator'][data-calculator-mobile-summary='enabled'][data-mobile-summary-suppressed='true'] .mobile-sticky-summary:not([hidden]) {
    display: none;
  }

  body[data-page='calculator'][data-calculator-mobile-summary='enabled'] .mobile-sticky-summary {
    left: 0.55rem;
    right: 0.55rem;
    bottom: 0.55rem;
    padding: 0.5rem 0.52rem 0.56rem;
  }

  .calculator-hero {
    padding: 0.82rem;
    margin-bottom: 0.72rem;
  }

  .calculator-hero h1 {
    font-size: clamp(1.52rem, 7vw, 2rem);
  }

  .converter-shell,
  .calculator-panel,
  .calculator-result {
    padding: 0.8rem;
  }

  body[data-page='calculator'][data-calculator-form-style='section-cards'] .calculator-panel,
  body[data-page='calculator'][data-calculator-form-style='section-cards'] .calculator-result {
    padding: 0.82rem;
  }

  body[data-page='calculator'][data-calculator-form-style='section-cards'] .field {
    padding: 0.5rem 0.54rem 0.58rem;
  }

  body[data-page='calculator'][data-calculator-form-style='section-cards'] .field-toggle {
    gap: 0.34rem;
  }

  .field-section-card {
    padding: 0.68rem;
  }

  .field-section-grid {
    grid-template-columns: 1fr;
  }

  body[data-page='calculator'][data-calculator-form-style='section-cards'] .mobile-sticky-summary-item strong {
    font-size: 0.97rem;
  }

  body[data-page='calculator'][data-calculator-form-style='section-cards'] .mobile-sticky-summary-button {
    min-height: 2.95rem;
    font-size: 0.92rem;
  }

  .hero-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .calculator-share-panel {
    align-items: stretch;
    flex-direction: column;
    padding: 0.66rem 0.68rem;
    gap: 0.58rem;
  }

  .calculator-share-button {
    width: 100%;
    justify-content: center;
  }

  .jodoh-hero-grid,
  .jodoh-stage-layout,
  .jodoh-result-stage,
  .jodoh-factor-columns,
  .jodoh-disclosure-grid,
  .jodoh-form-grid {
    grid-template-columns: 1fr;
  }

  .jodoh-metrics,
  .jodoh-segment-grid,
  .jodoh-toggle-grid {
    grid-template-columns: 1fr;
  }

  body[data-page='calculator'][data-calculator='jodoh'] .jodoh-input-panel {
    padding: 1.34rem 0.98rem 0.94rem;
  }

  body[data-page='calculator'][data-calculator='jodoh'] .jodoh-result-panel {
    padding: 0.78rem 0.92rem 0.92rem;
  }

  .button {
    width: 100%;
  }

  .newsletter-block form {
    grid-template-columns: 1fr;
  }

  .hub-calculator-grid {
    grid-template-columns: 1fr;
  }

  .hub-grid-sort,
  .search-sort-field {
    min-width: 0;
  }

  body[data-page='calculators-hub'] .hub-calculator-card h3,
  body[data-page='calculators-hub'] .hub-calculator-card > p:last-of-type {
    display: block;
    overflow: visible;
    -webkit-box-orient: initial;
    -webkit-line-clamp: unset;
  }

  body[data-page='calculators-hub'] .hub-calculator-card {
    min-height: 100%;
  }

  body[data-page='methodology'] .methodology-table-wrap {
    padding: 0.78rem;
  }

  body[data-page='methodology'] .table-scroll {
    overflow: visible;
  }

  body[data-page='methodology'] .methodology-table-wrap table {
    min-width: 0;
    width: 100%;
  }

  body[data-page='methodology'] .methodology-table-wrap thead {
    display: none;
  }

  body[data-page='methodology'] .methodology-table-wrap tbody {
    display: grid;
    gap: 0.72rem;
  }

  body[data-page='methodology'] .methodology-table-wrap tr {
    display: block;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--surface-solid);
    padding: 0.62rem 0.72rem;
  }

  body[data-page='methodology'] .methodology-table-wrap tr.methodology-message-row {
    padding: 0;
  }

  body[data-page='methodology'] .methodology-table-wrap td {
    display: block;
    border: 0;
    padding: 0.34rem 0;
  }

  body[data-page='methodology'] .methodology-table-wrap td + td {
    border-top: 1px dashed var(--line);
  }

  body[data-page='methodology'] .methodology-table-wrap td::before {
    content: attr(data-col-label);
    display: block;
    margin-bottom: 0.2rem;
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--muted);
    letter-spacing: 0.03em;
    text-transform: uppercase;
  }

  body[data-page='methodology'] .methodology-table-wrap tr.methodology-message-row td::before {
    content: none;
  }

  body[data-page='methodology'] .methodology-calculator-link {
    font-size: 1rem;
  }
}
