/* main.css — toolmedia (CONSTRUCTION)
   Vibe: rugged precision. Mobile-first. Жёсткие углы, плотная сетка,
   стальной + бетон + строительный жёлтый. Без hover-scale. */

/* ===== Reset / base ===== */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-md);
  line-height: var(--lh-normal);
  color: var(--color-neutral-800);
  background: var(--surface-background);
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--color-primary-600); text-decoration: none; }
a:hover { color: var(--color-primary-700); }

h1, h2, h3, h4 {
  font-family: var(--font-heading);
  color: var(--color-neutral-900);
  line-height: var(--lh-tight);
  margin: 0 0 var(--space-4);
}
h1 { font-weight: var(--fw-black); font-size: var(--fs-xl); }
h2 { font-weight: var(--fw-bold); font-size: var(--fs-lg); }
h3 { font-weight: var(--fw-semibold); font-size: var(--fs-md); }
p { margin: 0 0 var(--space-4); }

/* ===== Layout ===== */
.container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--space-5);
}
.section { padding: var(--space-8) 0; }
.section--tight { padding: var(--space-7) 0; }
.section--subtle { background: var(--surface-subtle); }

.skip-link {
  position: absolute; left: -9999px; top: 0;
  background: var(--color-accent-500); color: var(--color-accent-contrast);
  padding: var(--space-3) var(--space-4); z-index: 100;
}
.skip-link:focus { left: var(--space-3); top: var(--space-3); }

/* ===== Eyebrow (tag-маркер ниши) ===== */
.eyebrow {
  display: inline-block;
  font-family: var(--font-heading);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
  color: var(--color-neutral-500);
  margin-bottom: var(--space-3);
}
/* жёлтая полоса-маркер под eyebrow / слева от заголовков секций */
.accent-bar {
  display: block; width: 48px; height: 4px;
  background: var(--color-accent-500);
  margin-bottom: var(--space-4);
}

/* ===== Buttons / CTA ===== */
.btn {
  display: inline-block;
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-base);
  line-height: 1;
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-6);
  cursor: pointer;
  border: 1px solid transparent;
  transition: background var(--dur-normal) var(--ease-standard),
              color var(--dur-normal) var(--ease-standard),
              border-color var(--dur-normal) var(--ease-standard);
}
.btn-primary {
  background: var(--color-accent-500);
  color: var(--color-accent-contrast);
}
.btn-primary:hover { background: var(--color-accent-600); color: var(--color-accent-contrast); }
.btn-secondary {
  background: transparent;
  color: var(--color-primary-600);
  border-color: var(--color-primary-500);
}
.btn-secondary:hover { background: var(--color-primary-50); color: var(--color-primary-700); }
.btn-lg { padding: 18px var(--space-7); font-size: var(--fs-md); }

/* ===== Header ===== */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: var(--surface-elevated);
  border-bottom: 1px solid var(--color-neutral-200);
}
.header-inner {
  display: flex; align-items: center; gap: var(--space-5);
  min-height: 64px;
}
.logo {
  font-family: var(--font-heading);
  font-weight: var(--fw-black);
  font-size: var(--fs-md);
  color: var(--color-neutral-900);
  letter-spacing: var(--ls-tight);
}
.logo span { color: var(--color-accent-600); }
.main-nav { display: none; gap: var(--space-5); margin-left: auto; }
.main-nav a {
  font-family: var(--font-heading);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--color-neutral-700);
}
.main-nav a:hover, .main-nav a[aria-current="page"] { color: var(--color-primary-600); }
.header-cta { display: none; }
.nav-toggle {
  margin-left: auto;
  background: none; border: 1px solid var(--color-neutral-300);
  border-radius: var(--radius-sm);
  font-size: var(--fs-lg); line-height: 1;
  padding: var(--space-1) var(--space-3); cursor: pointer;
  color: var(--color-neutral-800);
}
.mobile-nav {
  display: none; flex-direction: column; gap: var(--space-2);
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-neutral-200);
  background: var(--surface-elevated);
}
.mobile-nav.open { display: flex; }
.mobile-nav a { font-family: var(--font-heading); font-weight: var(--fw-medium); color: var(--color-neutral-800); padding: var(--space-2) 0; }

/* ===== Hero ===== */
.hero { padding: var(--space-8) 0; background: var(--surface-background); }
.hero-inner { display: grid; grid-template-columns: 1fr; gap: var(--space-7); align-items: center; }
.hero-text { max-width: 640px; }
.hero h1 {
  font-size: var(--fs-2xl);
  animation: fade-in var(--dur-slow) var(--ease-enter) both;
}
.hero-sub { font-size: var(--fs-md); color: var(--color-neutral-700); max-width: 520px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-top: var(--space-5); }
.hero-visual {
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  background: var(--color-secondary-700);
  overflow: hidden;
  animation: slide-up var(--dur-slow) var(--ease-enter) 100ms both;
}
.hero-visual .placeholder {
  aspect-ratio: 4 / 3;
  display: flex; align-items: center; justify-content: center;
  color: var(--color-neutral-300);
  font-family: var(--font-heading); font-size: var(--fs-sm);
  letter-spacing: var(--ls-wide); text-transform: uppercase;
  background:
    repeating-linear-gradient(45deg, var(--color-secondary-700) 0 18px, var(--color-secondary-900) 18px 36px);
}

@keyframes fade-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes slide-up { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }
@media (prefers-reduced-motion: reduce) {
  .hero h1, .hero-visual { animation: none; }
  html { scroll-behavior: auto; }
}

/* ===== Section heads ===== */
.section-head { margin-bottom: var(--space-6); }
.section-head h2 { font-size: var(--fs-xl); }

/* ===== Pain → solution table ===== */
.pain-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-3); }
.pain-row {
  display: grid; grid-template-columns: 1fr; gap: var(--space-2);
  background: var(--surface-elevated);
  border: 1px solid var(--color-neutral-200);
  border-left: 4px solid var(--color-accent-500);
  border-radius: var(--radius-md);
  padding: var(--space-5);
}
.pain-row .pain {
  font-family: var(--font-heading); font-weight: var(--fw-semibold);
  color: var(--color-neutral-900);
}
.pain-row .solution { color: var(--color-neutral-700); }

/* ===== Feature block (студия без студии) ===== */
.feature-block { background: var(--color-primary-800); color: var(--color-neutral-100); border-radius: var(--radius-md); padding: var(--space-7) var(--space-6); }
.feature-block h2 { color: var(--color-neutral-50); }
.feature-block p { color: var(--color-neutral-200); }
.feature-list { list-style: none; padding: 0; margin: var(--space-5) 0 0; display: grid; gap: var(--space-3); }
.feature-list li { position: relative; padding-left: var(--space-5); color: var(--color-neutral-100); }
.feature-list li::before { content: ""; position: absolute; left: 0; top: 8px; width: 12px; height: 4px; background: var(--color-accent-500); }

/* ===== Service-card grid ===== */
.card-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-5); }
.service-card {
  position: relative;
  background: var(--surface-elevated);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  padding: var(--space-6);
  transition: box-shadow var(--dur-normal) var(--ease-standard);
  overflow: hidden;
}
.service-card::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--color-accent-500);
  transform: scaleX(0); transform-origin: left;
  transition: transform var(--dur-normal) var(--ease-standard);
}
.service-card:hover { box-shadow: var(--shadow-md); }
.service-card:hover::before { transform: scaleX(1); }
.service-card .icon {
  width: 32px; height: 32px; margin-bottom: var(--space-4);
  color: var(--color-primary-500);
}
.service-card h3 { font-size: var(--fs-lg); margin-bottom: var(--space-3); }
.service-card p { color: var(--color-neutral-600); font-size: var(--fs-base); }
.service-card .more {
  font-family: var(--font-heading); font-weight: var(--fw-semibold);
  font-size: var(--fs-sm); color: var(--color-primary-600);
}
.under-cards { margin-top: var(--space-5); color: var(--color-neutral-600); }

/* ===== Audience (для кого) ===== */
.audience-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-4); }
.audience-item {
  background: var(--surface-elevated); border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-md); padding: var(--space-5);
}
.audience-item h3 { font-size: var(--fs-md); }
.audience-item p { color: var(--color-neutral-600); font-size: var(--fs-base); margin: 0; }

/* ===== Steps (как работаем) ===== */
.steps { display: grid; grid-template-columns: 1fr; gap: var(--space-4); counter-reset: step; }
.step {
  background: var(--surface-elevated); border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-md); padding: var(--space-5);
}
.step .num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; margin-bottom: var(--space-3);
  background: var(--color-secondary-800); color: var(--color-accent-500);
  font-family: var(--font-heading); font-weight: var(--fw-bold);
  border-radius: var(--radius-sm);
}
.step h3 { font-size: var(--fs-md); }
.step p { color: var(--color-neutral-600); font-size: var(--fs-base); margin: 0; }
.steps-note { margin-top: var(--space-5); color: var(--color-neutral-600); font-style: italic; }

/* ===== Pricing table ===== */
.pricing { overflow: hidden; border-radius: var(--radius-md); border: 1px solid var(--color-neutral-200); }
.pricing table { width: 100%; border-collapse: collapse; font-size: var(--fs-base); }
.pricing thead th {
  background: var(--color-secondary-700); color: var(--color-neutral-50);
  font-family: var(--font-heading); font-weight: var(--fw-semibold);
  text-align: left; padding: var(--space-4) var(--space-5);
  letter-spacing: var(--ls-wide); font-size: var(--fs-sm);
}
.pricing tbody td { padding: var(--space-4) var(--space-5); border-top: 1px solid var(--color-neutral-200); }
.pricing tbody tr:nth-child(odd) { background: var(--color-neutral-50); }
.pricing tbody tr:nth-child(even) { background: var(--surface-elevated); }
.pricing .svc { font-family: var(--font-heading); font-weight: var(--fw-medium); color: var(--color-neutral-900); }
.pricing .pending { color: var(--color-neutral-500); font-family: var(--font-mono); font-size: var(--fs-sm); }
.pricing-note { margin-top: var(--space-4); color: var(--color-neutral-600); font-size: var(--fs-base); }

/* ===== FAQ ===== */
.faq { display: grid; gap: var(--space-3); }
.faq details {
  background: var(--surface-elevated); border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-md); padding: var(--space-4) var(--space-5);
}
.faq summary {
  cursor: pointer; font-family: var(--font-heading); font-weight: var(--fw-semibold);
  color: var(--color-neutral-900); list-style: none;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::before { content: "+ "; color: var(--color-accent-600); }
.faq details[open] summary::before { content: "− "; }
.faq details p { margin: var(--space-3) 0 0; color: var(--color-neutral-700); }

/* ===== Cases (заглушки) ===== */
.case-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-4); }
.case-stub {
  background: var(--surface-subtle); border: 1px dashed var(--color-neutral-300);
  border-radius: var(--radius-md); padding: var(--space-5);
  color: var(--color-neutral-500); font-family: var(--font-mono); font-size: var(--fs-sm);
}

/* ===== CTA block (финальный, графит) ===== */
.cta-block {
  background: var(--color-secondary-800); color: var(--color-neutral-50);
  border-top: 4px solid var(--color-accent-500);
  padding: var(--space-8) 0; text-align: center;
}
.cta-block h2 { color: var(--color-neutral-50); font-size: var(--fs-xl); }
.cta-block p { color: var(--color-neutral-200); max-width: 560px; margin: 0 auto var(--space-5); }

/* ===== List pages (services/catalog/blog) ===== */
.page-head { padding: var(--space-7) 0 var(--space-6); }
.page-head .lead { color: var(--color-neutral-700); font-size: var(--fs-md); max-width: 640px; }
.list-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-5); }
.list-card {
  position: relative; display: block;
  background: var(--surface-elevated); border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-md); box-shadow: var(--shadow-sm);
  padding: var(--space-6); color: inherit; overflow: hidden;
  transition: box-shadow var(--dur-normal) var(--ease-standard);
}
.list-card::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--color-accent-500); transform: scaleX(0); transform-origin: left;
  transition: transform var(--dur-normal) var(--ease-standard);
}
.list-card:hover { box-shadow: var(--shadow-md); }
.list-card:hover::before { transform: scaleX(1); }
.list-card h3 { color: var(--color-neutral-900); margin-bottom: var(--space-2); }
.list-card p { color: var(--color-neutral-600); font-size: var(--fs-base); margin: 0; }

/* ===== Article / single ===== */
.article { max-width: 720px; margin: 0 auto; padding: var(--space-7) 0; }
.article h1 { font-size: var(--fs-2xl); }
.article .content { font-size: var(--fs-md); line-height: var(--lh-relaxed); color: var(--color-neutral-800); }
.article .content h2 { font-size: var(--fs-lg); margin-top: var(--space-6); }
.article .content h3 { font-size: var(--fs-md); margin-top: var(--space-5); }
.article .content ul, .article .content ol { padding-left: var(--space-5); }
.article .content li { margin-bottom: var(--space-2); }
.article .content blockquote, .article .content .callout {
  background: var(--surface-subtle); border-left: 4px solid var(--color-accent-500);
  border-radius: var(--radius-sm); padding: var(--space-4) var(--space-5);
  margin: var(--space-5) 0; color: var(--color-neutral-700);
}
.article .content table { width: 100%; border-collapse: collapse; margin: var(--space-5) 0; font-size: var(--fs-base); }
.article .content th { background: var(--color-secondary-700); color: var(--color-neutral-50); text-align: left; padding: var(--space-3) var(--space-4); font-family: var(--font-heading); }
.article .content td { padding: var(--space-3) var(--space-4); border-top: 1px solid var(--color-neutral-200); }
.article .content tr:nth-child(even) td { background: var(--color-neutral-50); }
.article-cta { margin-top: var(--space-6); }

/* ===== Contact form ===== */
.contact-form { display: grid; gap: var(--space-4); max-width: 560px; }
.contact-form label { font-family: var(--font-heading); font-weight: var(--fw-medium); font-size: var(--fs-sm); color: var(--color-neutral-700); display: grid; gap: var(--space-2); }
.contact-form input, .contact-form select, .contact-form textarea {
  font-family: var(--font-body); font-size: var(--fs-base);
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-neutral-300); border-radius: var(--radius-md);
  background: var(--surface-elevated); color: var(--color-neutral-900);
}
.contact-form textarea { min-height: 120px; resize: vertical; }
.form-note { color: var(--color-neutral-600); font-size: var(--fs-base); }

/* ===== Footer ===== */
.site-footer {
  background: var(--color-secondary-900); color: var(--color-neutral-300);
  border-top: 2px solid var(--color-accent-500);
  padding: var(--space-8) 0 var(--space-6);
}
.footer-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-6); }
.footer-col h4 {
  font-family: var(--font-heading); font-size: var(--fs-sm);
  letter-spacing: var(--ls-wide); text-transform: uppercase;
  color: var(--color-neutral-100); margin-bottom: var(--space-4);
}
.footer-col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--space-2); }
.footer-col a { color: var(--color-neutral-100); font-size: var(--fs-base); }
.footer-col a:hover { color: var(--color-accent-500); }
.footer-col p { margin: 0 0 var(--space-2); font-size: var(--fs-base); }
.footer-bar {
  margin-top: var(--space-6); padding-top: var(--space-5);
  border-top: 1px solid var(--color-secondary-700);
  font-size: var(--fs-sm); color: var(--color-neutral-400);
  display: flex; flex-wrap: wrap; gap: var(--space-3); justify-content: space-between;
}

/* ===== Breadcrumbs ===== */
.breadcrumbs { font-size: var(--fs-sm); color: var(--color-neutral-500); padding-top: var(--space-5); }
.breadcrumbs a { color: var(--color-neutral-600); }

/* ===== Responsive: tablet ===== */
@media (min-width: 768px) {
  h1 { font-size: var(--fs-2xl); }
  .pain-row { grid-template-columns: 1fr 1fr; align-items: start; }
  .card-grid { grid-template-columns: repeat(2, 1fr); }
  .audience-grid { grid-template-columns: repeat(2, 1fr); }
  .steps { grid-template-columns: repeat(2, 1fr); }
  .case-grid { grid-template-columns: repeat(2, 1fr); }
  .list-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ===== Responsive: desktop ===== */
@media (min-width: 1200px) {
  .hero h1 { font-size: var(--fs-3xl); }
  .hero-inner { grid-template-columns: 60% 40%; }
  .card-grid { grid-template-columns: repeat(3, 1fr); }
  .audience-grid { grid-template-columns: repeat(2, 1fr); }
  .steps { grid-template-columns: repeat(4, 1fr); }
  .list-grid { grid-template-columns: repeat(3, 1fr); }
  .footer-grid { grid-template-columns: repeat(4, 1fr); }
  .main-nav { display: flex; }
  .header-cta { display: inline-block; }
  .nav-toggle { display: none; }
}

/* ============================================================
   T-21..T-30 FEATURE COMPONENTS (rugged precision, no hover-scale)
   ============================================================ */

/* ---- Tools hub / feature intro grid ---- */
.tools-hub { display: grid; grid-template-columns: 1fr; gap: var(--space-5); }
@media (min-width: 768px) { .tools-hub { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1200px) { .tools-hub { grid-template-columns: repeat(3, 1fr); } }

/* ---- Calculator / configurator (T-21) ---- */
.calc { display: grid; gap: var(--space-6); }
@media (min-width: 1200px) { .calc { grid-template-columns: 1.2fr 0.8fr; align-items: start; } }
.calc-panel {
  background: var(--surface-elevated); border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-md); padding: var(--space-6); box-shadow: var(--shadow-sm);
}
.calc-options { display: grid; gap: var(--space-3); }
.calc-opt {
  display: flex; align-items: flex-start; gap: var(--space-3);
  padding: var(--space-4); border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-md); cursor: pointer; transition: border-color var(--dur-normal) var(--ease-standard);
}
.calc-opt:hover { border-color: var(--color-primary-400); }
.calc-opt input { margin-top: 4px; accent-color: var(--color-accent-600); }
.calc-opt .opt-title { font-family: var(--font-heading); font-weight: var(--fw-semibold); color: var(--color-neutral-900); }
.calc-opt .opt-desc { color: var(--color-neutral-600); font-size: var(--fs-base); }
.calc-field { margin-top: var(--space-5); }
.calc-field label { display: block; font-family: var(--font-heading); font-weight: var(--fw-medium); font-size: var(--fs-sm); color: var(--color-neutral-700); margin-bottom: var(--space-2); }
.calc-field input[type="range"] { width: 100%; accent-color: var(--color-accent-600); }
.calc-field input[type="number"] {
  width: 120px; font-family: var(--font-body); font-size: var(--fs-base);
  padding: var(--space-2) var(--space-3); border: 1px solid var(--color-neutral-300); border-radius: var(--radius-md);
}
.calc-volume-val { font-family: var(--font-heading); font-weight: var(--fw-bold); color: var(--color-primary-600); }
.calc-summary {
  background: var(--color-primary-800); color: var(--color-neutral-100);
  border-radius: var(--radius-md); padding: var(--space-6); position: sticky; top: 80px;
}
.calc-summary h3 { color: var(--color-neutral-50); }
.calc-summary .accent-bar { background: var(--color-accent-500); }
.calc-summary ul { list-style: none; padding: 0; margin: 0 0 var(--space-4); display: grid; gap: var(--space-2); }
.calc-summary li { position: relative; padding-left: var(--space-5); color: var(--color-neutral-100); }
.calc-summary li::before { content: ""; position: absolute; left: 0; top: 8px; width: 12px; height: 4px; background: var(--color-accent-500); }
.calc-summary .calc-empty { color: var(--color-neutral-300); font-style: italic; }
.calc-meta { display: grid; gap: var(--space-2); margin: var(--space-4) 0; padding-top: var(--space-4); border-top: 1px solid var(--color-primary-600); }
.calc-meta .row { display: flex; justify-content: space-between; gap: var(--space-3); }
.calc-meta .label { color: var(--color-neutral-300); }
.calc-meta .value { font-family: var(--font-heading); font-weight: var(--fw-semibold); color: var(--color-accent-500); text-align: right; }
.calc-price-note { font-size: var(--fs-sm); color: var(--color-neutral-300); margin-top: var(--space-3); }

/* ---- Quiz wizard (T-22) ---- */
.quiz { max-width: 720px; margin: 0 auto; }
.quiz-progress { display: flex; gap: var(--space-2); margin-bottom: var(--space-6); }
.quiz-progress .dot { flex: 1; height: 4px; background: var(--color-neutral-200); border-radius: var(--radius-sm); }
.quiz-progress .dot.active { background: var(--color-accent-500); }
.quiz-step { display: none; background: var(--surface-elevated); border: 1px solid var(--color-neutral-200); border-radius: var(--radius-md); padding: var(--space-6); box-shadow: var(--shadow-sm); }
.quiz-step.active { display: block; }
.quiz-step h2 { font-size: var(--fs-lg); }
.quiz-answers { display: grid; gap: var(--space-3); margin-top: var(--space-5); }
.quiz-answer {
  text-align: left; font-family: var(--font-body); font-size: var(--fs-base);
  background: var(--surface-subtle); border: 1px solid var(--color-neutral-200);
  border-left: 4px solid transparent; border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5); cursor: pointer; color: var(--color-neutral-800);
  transition: border-color var(--dur-normal) var(--ease-standard), background var(--dur-normal) var(--ease-standard);
}
.quiz-answer:hover, .quiz-answer.selected { border-left-color: var(--color-accent-500); background: var(--color-neutral-50); }
.quiz-nav { display: flex; justify-content: space-between; gap: var(--space-3); margin-top: var(--space-6); }
.quiz-result { display: none; background: var(--color-primary-800); color: var(--color-neutral-100); border-radius: var(--radius-md); padding: var(--space-7) var(--space-6); }
.quiz-result.active { display: block; }
.quiz-result h2 { color: var(--color-neutral-50); }
.quiz-result p { color: var(--color-neutral-200); }
.quiz-result .rec { font-family: var(--font-heading); font-weight: var(--fw-bold); font-size: var(--fs-lg); color: var(--color-accent-500); margin: var(--space-3) 0; }

/* ---- Comparison table (T-25) ---- */
.cmp { overflow-x: auto; border-radius: var(--radius-md); border: 1px solid var(--color-neutral-200); }
.cmp table { width: 100%; border-collapse: collapse; font-size: var(--fs-base); min-width: 640px; }
.cmp thead th {
  background: var(--color-secondary-700); color: var(--color-neutral-50);
  font-family: var(--font-heading); font-weight: var(--fw-semibold);
  text-align: left; padding: var(--space-4) var(--space-5); font-size: var(--fs-sm); letter-spacing: var(--ls-wide);
}
.cmp thead th.us { background: var(--color-primary-700); position: relative; }
.cmp thead th.us::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 3px; background: var(--color-accent-500); }
.cmp tbody th { text-align: left; font-family: var(--font-heading); font-weight: var(--fw-medium); color: var(--color-neutral-900); padding: var(--space-4) var(--space-5); background: var(--color-neutral-50); }
.cmp tbody td { padding: var(--space-4) var(--space-5); border-top: 1px solid var(--color-neutral-200); color: var(--color-neutral-700); }
.cmp tbody td.us { background: var(--color-primary-50); color: var(--color-neutral-900); font-weight: var(--fw-medium); }
.cmp .yes { color: var(--color-success); font-weight: var(--fw-semibold); }
.cmp .no { color: var(--color-danger); }

/* ---- Video demo (T-26) ---- */
.video-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-5); }
@media (min-width: 768px) { .video-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1200px) { .video-grid { grid-template-columns: repeat(3, 1fr); } }
.video-card { background: var(--surface-elevated); border: 1px solid var(--color-neutral-200); border-radius: var(--radius-md); overflow: hidden; box-shadow: var(--shadow-sm); }
.video-thumb {
  aspect-ratio: 16 / 9; display: flex; align-items: center; justify-content: center;
  background: repeating-linear-gradient(45deg, var(--color-secondary-700) 0 18px, var(--color-secondary-900) 18px 36px);
  color: var(--color-neutral-300); position: relative;
}
.video-thumb .play { width: 56px; height: 56px; border-radius: var(--radius-full); background: var(--color-accent-500); display: flex; align-items: center; justify-content: center; }
.video-thumb .play svg { color: var(--color-accent-contrast); }
.video-thumb .badge { position: absolute; bottom: var(--space-3); left: var(--space-3); background: var(--surface-overlay); color: var(--color-neutral-100); font-size: var(--fs-xs); padding: 2px var(--space-2); border-radius: var(--radius-sm); letter-spacing: var(--ls-wide); }
.video-card .body { padding: var(--space-5); }
.video-card h3 { font-size: var(--fs-md); margin-bottom: var(--space-2); }
.video-card p { color: var(--color-neutral-600); font-size: var(--fs-base); margin: 0; }

/* ---- Glossary (T-27) ---- */
.glossary-nav { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-bottom: var(--space-6); }
.glossary-nav a { display: inline-flex; min-width: 32px; justify-content: center; padding: var(--space-2) var(--space-3); background: var(--surface-elevated); border: 1px solid var(--color-neutral-200); border-radius: var(--radius-sm); font-family: var(--font-heading); font-weight: var(--fw-semibold); color: var(--color-primary-600); }
.glossary-nav a:hover { border-color: var(--color-accent-500); }
.glossary-group { margin-bottom: var(--space-6); }
.glossary-group h2 { font-size: var(--fs-xl); color: var(--color-accent-600); border-bottom: 2px solid var(--color-neutral-200); padding-bottom: var(--space-2); }
.glossary-term { background: var(--surface-elevated); border: 1px solid var(--color-neutral-200); border-left: 4px solid var(--color-accent-500); border-radius: var(--radius-md); padding: var(--space-5); margin-bottom: var(--space-4); }
.glossary-term dt { font-family: var(--font-heading); font-weight: var(--fw-bold); color: var(--color-neutral-900); font-size: var(--fs-md); margin-bottom: var(--space-2); }
.glossary-term dd { margin: 0; color: var(--color-neutral-700); }

/* ---- Reviews wall (T-28) ---- */
.reviews-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-5); }
@media (min-width: 768px) { .reviews-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1200px) { .reviews-grid { grid-template-columns: repeat(3, 1fr); } }
.review-card { background: var(--surface-elevated); border: 1px solid var(--color-neutral-200); border-radius: var(--radius-md); padding: var(--space-5); box-shadow: var(--shadow-sm); display: flex; flex-direction: column; gap: var(--space-4); }
.review-card .quote { color: var(--color-neutral-700); font-style: italic; }
.review-card .who { display: flex; align-items: center; gap: var(--space-3); margin-top: auto; }
.review-card .avatar { width: 44px; height: 44px; border-radius: var(--radius-full); background: var(--color-secondary-300); display: flex; align-items: center; justify-content: center; color: var(--color-secondary-900); font-family: var(--font-heading); font-weight: var(--fw-bold); flex-shrink: 0; }
.review-card .name { font-family: var(--font-heading); font-weight: var(--fw-semibold); color: var(--color-neutral-900); }
.review-card .company { font-size: var(--fs-sm); color: var(--color-neutral-500); }
.reviews-note { margin-top: var(--space-5); color: var(--color-neutral-600); font-style: italic; }

/* ---- ROI / what visualization saves (T-29) ---- */
.roi { display: grid; gap: var(--space-6); }
@media (min-width: 1200px) { .roi { grid-template-columns: 0.8fr 1.2fr; align-items: start; } }
.roi-input { background: var(--surface-elevated); border: 1px solid var(--color-neutral-200); border-radius: var(--radius-md); padding: var(--space-6); box-shadow: var(--shadow-sm); }
.roi-input label { display: block; font-family: var(--font-heading); font-weight: var(--fw-medium); font-size: var(--fs-sm); color: var(--color-neutral-700); margin-bottom: var(--space-2); }
.roi-input input[type="number"] { width: 140px; font-family: var(--font-body); font-size: var(--fs-md); padding: var(--space-2) var(--space-3); border: 1px solid var(--color-neutral-300); border-radius: var(--radius-md); }
.roi-results { display: grid; grid-template-columns: 1fr; gap: var(--space-4); }
@media (min-width: 768px) { .roi-results { grid-template-columns: repeat(2, 1fr); } }
.roi-card { background: var(--surface-subtle); border: 1px solid var(--color-neutral-200); border-top: 3px solid var(--color-accent-500); border-radius: var(--radius-md); padding: var(--space-5); }
.roi-card .metric { font-family: var(--font-heading); font-weight: var(--fw-black); font-size: var(--fs-xl); color: var(--color-primary-600); }
.roi-card .metric.pending { font-size: var(--fs-md); color: var(--color-neutral-500); font-family: var(--font-mono); }
.roi-card h3 { font-size: var(--fs-md); margin: var(--space-2) 0; }
.roi-card p { color: var(--color-neutral-600); font-size: var(--fs-base); margin: 0; }

/* ---- Timeline / process (T-30) ---- */
.timeline { position: relative; display: grid; gap: var(--space-5); margin-top: var(--space-6); }
.timeline::before { content: ""; position: absolute; left: 17px; top: 8px; bottom: 8px; width: 2px; background: var(--color-neutral-200); }
.tl-step { position: relative; padding-left: var(--space-8); }
.tl-step .marker { position: absolute; left: 0; top: 0; width: 36px; height: 36px; border-radius: var(--radius-sm); background: var(--color-secondary-800); color: var(--color-accent-500); display: flex; align-items: center; justify-content: center; font-family: var(--font-heading); font-weight: var(--fw-bold); z-index: 1; }
.tl-step h3 { font-size: var(--fs-md); margin-bottom: var(--space-2); }
.tl-step .when { font-family: var(--font-heading); font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--color-accent-600); letter-spacing: var(--ls-wide); }
.tl-step p { color: var(--color-neutral-700); font-size: var(--fs-base); margin: var(--space-2) 0 0; }

/* ---- Checklist / lead magnet (T-24) ---- */
.checklist { display: grid; gap: var(--space-4); margin-top: var(--space-6); }
.check-block { background: var(--surface-elevated); border: 1px solid var(--color-neutral-200); border-radius: var(--radius-md); padding: var(--space-5); }
.check-block h3 { font-size: var(--fs-md); display: flex; align-items: center; gap: var(--space-3); }
.check-block h3 .n { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; background: var(--color-accent-500); color: var(--color-accent-contrast); border-radius: var(--radius-sm); font-size: var(--fs-sm); flex-shrink: 0; }
.check-items { list-style: none; padding: 0; margin: var(--space-3) 0 0; display: grid; gap: var(--space-2); }
.check-items li { position: relative; padding-left: var(--space-6); color: var(--color-neutral-700); }
.check-items li::before { content: "✓"; position: absolute; left: 0; top: 0; color: var(--color-success); font-weight: var(--fw-bold); }
.magnet-cta { background: var(--color-primary-800); color: var(--color-neutral-100); border-radius: var(--radius-md); padding: var(--space-6); margin-top: var(--space-6); text-align: center; }
.magnet-cta h2 { color: var(--color-neutral-50); }
.magnet-cta p { color: var(--color-neutral-200); }
.magnet-cta .accent-bar { margin: 0 auto var(--space-4); }
