:root, [data-theme="light"] {
  --text-xs: clamp(0.75rem, 0.72rem + 0.16vw, 0.875rem);
  --text-sm: clamp(0.9rem, 0.86rem + 0.16vw, 1rem);
  --text-base: clamp(1rem, 0.98rem + 0.18vw, 1.125rem);
  --text-lg: clamp(1.14rem, 1.04rem + 0.42vw, 1.4rem);
  --text-xl: clamp(1.6rem, 1.3rem + 1vw, 2.2rem);
  --text-2xl: clamp(2.5rem, 1.8rem + 3.2vw, 5.2rem);
  --space-1: 0.25rem; --space-2: 0.5rem; --space-3: 0.75rem; --space-4: 1rem; --space-5: 1.25rem;
  --space-6: 1.5rem; --space-8: 2rem; --space-10: 2.5rem; --space-12: 3rem; --space-16: 4rem; --space-20: 5rem; --space-24: 6rem;
  --radius-sm: 0.375rem; --radius-md: 0.625rem; --radius-lg: 1rem; --radius-xl: 1.5rem; --radius-2xl: 2rem; --radius-full: 999px;
  --color-bg: #f7f6f2;
  --color-surface: rgba(255, 255, 255, 0.85);
  --color-surface-2: rgba(243, 241, 235, 0.85);
  --color-surface-3: rgba(235, 231, 223, 0.85);
  --color-border: rgba(18, 48, 71, 0.12);
  --color-text: #163042;
  --color-text-muted: #5b6873;
  --color-text-faint: #7c8790;
  --color-primary: #0f7f77;
  --color-primary-hover: #0c6660;
  --color-navy: #123047;
  --color-accent: #f2a313;
  --color-accent-soft: rgba(242, 163, 19, 0.12);
  --color-primary-soft: rgba(15, 127, 119, 0.10);
  --shadow-sm: 0 1px 2px rgba(17, 24, 33, 0.04), 0 8px 20px rgba(17, 24, 33, 0.05);
  --shadow-md: 0 14px 38px rgba(17, 24, 33, 0.08);
  --font-body: 'Inter', Arial, sans-serif;
  --font-display: 'Manrope', 'Inter', Arial, sans-serif;
  --content-default: 1180px;
}
[data-theme="dark"] {
  --color-bg: #121a22;
  --color-surface: rgba(24, 33, 43, 0.85);
  --color-surface-2: rgba(31, 42, 53, 0.85);
  --color-surface-3: rgba(42, 54, 66, 0.85);
  --color-border: rgba(245, 245, 240, 0.10);
  --color-text: #eff2f4;
  --color-text-muted: #bac3ca;
  --color-text-faint: #8b98a2;
  --color-primary: #36a79f;
  --color-primary-hover: #4ab9b0;
  --color-navy: #eff2f4;
  --color-accent: #f2a313;
  --color-accent-soft: rgba(242, 163, 19, 0.12);
  --color-primary-soft: rgba(54, 167, 159, 0.12);
  --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.22);
  --shadow-md: 0 16px 40px rgba(0, 0, 0, 0.34);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.65;
  color: var(--color-text);
  background: transparent;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
html { background: var(--color-bg); }
.site-header, main, .site-footer { position: relative; z-index: 1; }
#network-bg {
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}
@media (prefers-reduced-motion: reduce) { #network-bg { display: none; } }
img, svg { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
p { margin: 0; color: var(--color-text-muted); max-width: 70ch; }
h1, h2, h3 { margin: 0; line-height: 1.08; color: var(--color-text); text-wrap: balance; }
button { font: inherit; }
.container { width: min(calc(100% - 2rem), var(--content-default)); margin-inline: auto; }
.section { padding-block: clamp(var(--space-10), 5vw, var(--space-16)); }
.skip-link { position: absolute; left: 1rem; top: -3rem; background: var(--color-text); color: var(--color-bg); padding: 0.75rem 1rem; border-radius: var(--radius-sm); z-index: 100; }
.skip-link:focus { top: 1rem; }
.eyebrow {
  display: inline-flex; align-items: center; gap: 0.6rem; padding: 0.45rem 0.8rem; border-radius: var(--radius-full);
  background: var(--color-surface-2); border: 1px solid var(--color-border); color: var(--color-text);
  font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
}
.eyebrow::before { content: ""; width: 0.46rem; height: 0.46rem; border-radius: 50%; background: var(--color-accent); }
.section-head { display: grid; gap: var(--space-4); margin-bottom: var(--space-10); }
.section-title { font-family: var(--font-display); font-size: clamp(2rem, 1.5rem + 1.8vw, 3.5rem); max-width: 13ch; letter-spacing: -0.03em; }
.site-header {
  position: sticky; top: 0; z-index: 30; backdrop-filter: blur(14px);
  background: color-mix(in srgb, var(--color-bg) 88%, transparent); border-bottom: 1px solid var(--color-border);
}
.nav { min-height: 4.8rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.logo img { height: 2.3rem; width: auto; }
.nav-burger { display: none; background: none; border: none; cursor: pointer; padding: 0.5rem; flex-direction: column; gap: 5px; }
.nav-burger span { display: block; width: 24px; height: 2px; background: var(--color-text); border-radius: 2px; transition: transform 200ms ease, opacity 200ms ease; }
.nav-burger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-burger.is-open span:nth-child(2) { opacity: 0; }
.nav-burger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.nav-links { display: flex; gap: 1.1rem; align-items: center; flex-wrap: wrap; }
.nav-links a { font-size: var(--text-sm); color: var(--color-text-muted); }
.nav-links a:hover { color: var(--color-text); }
.theme-toggle, .button, .button-secondary { border-radius: var(--radius-full); transition: background 180ms ease, color 180ms ease, border-color 180ms ease, transform 180ms ease; }
.theme-toggle {
  width: 2.8rem; height: 2.8rem; display: grid; place-items: center; border: 1px solid var(--color-border);
  background: var(--color-surface); color: var(--color-text);
}
.button, .button-secondary {
  display: inline-flex; align-items: center; justify-content: center; min-height: 3rem; padding: 0.95rem 1.25rem; font-size: var(--text-sm); font-weight: 700; border: 1px solid transparent;
}
.button { background: var(--color-primary); color: white; box-shadow: var(--shadow-sm); }
.button:hover { background: var(--color-primary-hover); transform: translateY(-1px); }
.button-secondary { background: var(--color-surface); color: var(--color-text); border-color: var(--color-border); }
.button-secondary:hover, .theme-toggle:hover { background: var(--color-surface-2); }
.hero {
  padding-block: clamp(4rem, 9vw, 7rem) clamp(3rem, 6vw, 4.5rem);
  background:
    radial-gradient(circle at 12% 0%, var(--color-primary-soft), transparent 26%),
    radial-gradient(circle at 88% 10%, var(--color-accent-soft), transparent 18%);
}
.hero-grid { display: grid; grid-template-columns: 1.02fr 0.98fr; gap: var(--space-10); align-items: center; }
.hero-copy { display: grid; gap: var(--space-6); }
.hero-title { font-family: var(--font-display); font-size: clamp(3rem, 2rem + 4.6vw, 6rem); max-width: 9ch; letter-spacing: -0.05em; color: var(--color-navy); }
.hero-lead { font-size: var(--text-lg); max-width: 34ch; color: var(--color-text-muted); }
.hero-actions { display: flex; gap: 0.9rem; flex-wrap: wrap; }
.hero-points { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-4); }
.hero-point { padding: var(--space-4); background: color-mix(in srgb, var(--color-surface) 92%, white); border: 1px solid var(--color-border); border-radius: var(--radius-lg); }
.hero-point strong { display: block; margin-bottom: 0.35rem; color: var(--color-text); font-size: var(--text-sm); }
.hero-point span { font-size: var(--text-sm); color: var(--color-text-muted); }
.hero-visual-wrap, .image-card, .panel, .case-card, .process-card, .faq-item, .contact-card {
  background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-xl); box-shadow: var(--shadow-sm);
}
.hero-visual-wrap { padding: var(--space-5); }
.hero-visual-wrap img, .image-card img { width: 100%; border-radius: calc(var(--radius-xl) - var(--space-5)); object-fit: cover; }
.hero-visual-wrap img { aspect-ratio: 16/10; }
.manifesto, .story-layout, .split-note, .image-split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-8); }
.panel { padding: var(--space-8); }
.manifesto-quote { font-family: var(--font-display); font-size: clamp(1.7rem, 1.2rem + 1.4vw, 2.7rem); color: var(--color-navy); max-width: 15ch; letter-spacing: -0.03em; }
.list { display: grid; gap: var(--space-4); }
.list-item { display: grid; grid-template-columns: auto 1fr; gap: 0.9rem; padding-bottom: var(--space-4); border-bottom: 1px solid var(--color-border); }
.list-item:last-child { border-bottom: 0; padding-bottom: 0; }
.list-icon { width: 2rem; height: 2rem; border-radius: 0.7rem; background: var(--color-primary-soft); color: var(--color-primary); display: grid; place-items: center; font-weight: 700; font-size: var(--text-sm); }
.story-layout { align-items: start; }
.story-card { position: sticky; top: 6rem; }
.story-card h3 { font-family: var(--font-display); font-size: clamp(1.6rem, 1.25rem + 1vw, 2.35rem); margin: var(--space-4) 0; color: var(--color-navy); letter-spacing: -0.03em; }
.timeline { display: grid; gap: var(--space-5); }
.timeline-item { position: relative; padding-left: var(--space-6); display: grid; gap: 0.3rem; }
.timeline-item::before { content: ""; position: absolute; left: 0.1rem; top: 0.42rem; width: 0.78rem; height: 0.78rem; border-radius: 50%; background: var(--color-accent); box-shadow: 0 0 0 6px var(--color-accent-soft); }
.timeline-item::after { content: ""; position: absolute; left: 0.47rem; top: 1.45rem; bottom: -1.8rem; width: 1px; background: var(--color-border); }
.timeline-item:last-child::after { display: none; }
.timeline-role { color: var(--color-text); font-weight: 700; }
.timeline-company { color: var(--color-primary); font-size: var(--text-sm); }
.examples-grid, .process-grid, .faq-grid { display: grid; gap: var(--space-5); }
.examples-grid, .process-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.faq-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); align-items: start; }
.case-card, .process-card, .faq-item { padding: var(--space-6); }
.case-card, .process-card { display: grid; gap: var(--space-5); }
.case-kicker { font-size: var(--text-xs); letter-spacing: 0.08em; text-transform: uppercase; font-weight: 700; color: var(--color-text-faint); }
.case-card h3, .split-note h3, .faq-item h3, .process-card h3 { color: var(--color-text); font-size: var(--text-lg); }
.metric-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-3); }
.metric { padding: var(--space-4); background: var(--color-surface-2); border: 1px solid var(--color-border); border-radius: var(--radius-lg); }
.metric strong { display: block; color: var(--color-text); margin-bottom: 0.2rem; }
.metric span { font-size: var(--text-xs); color: var(--color-text-muted); }
.case-stack { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.tag { padding: 0.45rem 0.7rem; border-radius: var(--radius-full); background: var(--color-surface); border: 1px solid var(--color-border); font-size: var(--text-xs); color: var(--color-text); }
.case-head { display: grid; gap: var(--space-2); }
.case-audience { display: block; font-size: var(--text-xs); color: var(--color-accent); font-weight: 600; }

/* Price comparison */
.price-compare-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-5); align-items: stretch; }
.price-compare-grid .case-card { display: flex; flex-direction: column; }
.price-compare-grid .case-stack { margin-top: auto; }
.price-compare { display: grid; grid-template-columns: 1fr auto 1fr; gap: var(--space-3); align-items: stretch; }
.price-compare__col { padding: var(--space-4); border-radius: var(--radius-lg); text-align: center; display: flex; flex-direction: column; justify-content: center; gap: 0.3rem; }
.price-compare__vs { display: flex; align-items: center; }
.price-compare__col--saas { background: color-mix(in srgb, #ef4444 6%, transparent); border: 1px solid color-mix(in srgb, #ef4444 20%, transparent); }
.price-compare__col--oss { background: color-mix(in srgb, var(--color-primary) 8%, transparent); border: 1px solid color-mix(in srgb, var(--color-primary) 30%, transparent); }
.price-compare__label { font-size: var(--text-xs); font-weight: 600; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.05em; }
.price-compare__per { font-size: var(--text-xs); color: var(--color-text-muted); }
.price-compare__total { font-size: var(--text-base); font-weight: 700; color: var(--color-text); }
.price-compare__total small { font-weight: 400; font-size: var(--text-xs); color: var(--color-text-muted); display: block; }
.price-compare__col--saas .price-compare__total { color: #b91c1c; }
.price-compare__col--oss .price-compare__total { color: var(--color-primary); }
.price-compare__monthly { font-size: var(--text-sm); font-weight: 600; color: var(--color-text-muted); }
.price-compare__breakdown { font-size: var(--text-xs); color: var(--color-text-muted); }
.price-compare__vs { font-weight: 700; color: var(--color-text-faint); font-size: var(--text-sm); }
.price-compare__saving { padding: var(--space-3) var(--space-4); background: color-mix(in srgb, var(--color-accent) 10%, transparent); border: 1px solid color-mix(in srgb, var(--color-accent) 25%, transparent); border-radius: var(--radius-lg); text-align: center; }
.price-compare__saving strong { display: block; color: var(--color-text); font-size: var(--text-base); }
.price-compare__saving span { font-size: var(--text-xs); color: var(--color-text-muted); }

/* Price summary */
.price-summary { display: grid; gap: 0; }
.price-summary__row { display: grid; grid-template-columns: 1fr auto; gap: var(--space-2); padding: var(--space-4) 0; border-bottom: 1px solid var(--color-border); }
.price-summary__label { font-weight: 600; color: var(--color-text); grid-column: 1; }
.price-summary__desc { font-size: var(--text-xs); color: var(--color-text-muted); grid-column: 1; }
.price-summary__price { font-weight: 700; color: var(--color-text); grid-column: 2; grid-row: 1 / 3; align-self: center; text-align: right; font-size: var(--text-base); white-space: nowrap; }
.price-summary__total { display: flex; justify-content: space-between; gap: var(--space-4); padding-top: var(--space-5); flex-wrap: wrap; }
.price-summary__total > div { display: grid; gap: 0.2rem; }
.price-summary__total-label { font-size: var(--text-sm); color: var(--color-text-muted); }
.price-summary__total-price { font-size: var(--text-xl); font-weight: 700; }
.price-summary__total-price--saas { color: #b91c1c; }
.price-summary__total-price--oss { color: var(--color-primary); }
.process-number { width: 2.3rem; height: 2.3rem; border-radius: 50%; display: grid; place-items: center; background: var(--color-primary-soft); color: var(--color-primary); font-weight: 700; }
.image-card { padding: var(--space-5); }
.image-card img { aspect-ratio: 4/3; }
.contact-card {
  padding: clamp(1.5rem, 3vw, 3rem); display: grid; gap: var(--space-6);
  background: linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 88%, white), var(--color-surface-2));
  border-radius: var(--radius-2xl); box-shadow: var(--shadow-md);
}
.contact-actions, .contact-meta { display: flex; gap: 0.85rem; flex-wrap: wrap; }
.contact-meta span { padding: 0.45rem 0.75rem; border-radius: var(--radius-full); background: var(--color-surface); border: 1px solid var(--color-border); font-size: var(--text-sm); color: var(--color-text-muted); }
.site-footer { padding: var(--space-10) 0; color: var(--color-text-muted); font-size: var(--text-sm); }
.footer-inner { display: grid; gap: var(--space-5); justify-items: center; text-align: center; padding-top: var(--space-8); border-top: 1px solid var(--color-border); }
.footer-brand { display: flex; align-items: center; gap: var(--space-2); }
.footer-links { display: flex; gap: var(--space-5); flex-wrap: wrap; justify-content: center; }
.footer-links a { color: var(--color-text-muted); transition: color 180ms ease; }
.footer-links a:hover { color: var(--color-text); }
.footer-legal { color: var(--color-text-faint); }
.reveal { opacity: 0; transform: translateY(24px); transition: opacity 700ms ease, transform 700ms ease; }
.reveal.is-visible { opacity: 1; transform: translateY(0); }
@media (max-width: 1080px) {
  .hero-grid, .manifesto, .story-layout, .split-note, .image-split, .examples-grid, .process-grid, .faq-grid, .price-compare-grid { grid-template-columns: 1fr; }
  .story-card { position: static; }
  .hero-points { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .nav { flex-wrap: wrap; padding-block: 1rem; }
  .nav-burger { display: flex; }
  .nav-links { display: none; flex-direction: column; align-items: flex-start; width: 100%; gap: 0.5rem; padding-top: 1rem; }
  .nav-links.is-open { display: flex; }
  .hero-actions, .contact-actions { flex-direction: column; }
  .button, .button-secondary { width: 100%; }
  .metric-grid { grid-template-columns: 1fr; }
  .price-compare { grid-template-columns: 1fr; }
  .price-compare__vs { text-align: center; }
  .panel, .case-card, .process-card, .faq-item, .image-card { padding: 1.25rem; }
  .contact-card, .hero-visual-wrap { padding: 1.25rem; }
  .logo img { height: 2rem; }
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; transition: none; }
  .button:hover { transform: none; }
}

/* ============================================
   ADDITIONAL: FAQ Accordion
   ============================================ */
.faq-item { cursor: pointer; transition: box-shadow 200ms ease; }
.faq-item:hover { box-shadow: var(--shadow-md); }
.faq-item h3 { display: flex; justify-content: space-between; align-items: center; font-size: var(--text-base); font-weight: 600; }
.faq-toggle { font-size: 1.4rem; color: var(--color-text-muted); transition: transform 300ms ease; flex-shrink: 0; margin-left: var(--space-4); }
.faq-item.is-open .faq-toggle { transform: rotate(45deg); }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height 400ms ease, padding 400ms ease; }
.faq-answer p { padding: 0 0 var(--space-4); }
.faq-item.is-open .faq-answer { max-height: 30rem; }

/* ============================================
   ADDITIONAL: Contact Form
   ============================================ */
.contact-form { display: grid; gap: var(--space-4); width: 100%; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
.form-field { display: grid; gap: var(--space-2); }
.form-field label { font-size: var(--text-sm); font-weight: 600; color: var(--color-text); }
.form-field input,
.form-field textarea {
  padding: 0.85rem 1rem; border-radius: var(--radius-md); border: 1px solid var(--color-border);
  background: var(--color-surface); color: var(--color-text); font: inherit; font-size: var(--text-sm);
  transition: border-color 200ms ease, box-shadow 200ms ease;
}
.form-field input:focus,
.form-field textarea:focus { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 3px var(--color-primary-soft); }
.form-field textarea { min-height: 7rem; resize: vertical; }
.form-submit { justify-self: start; }
.form-success { display: none; padding: var(--space-6); text-align: center; }
.form-success.is-visible { display: block; }
@media (max-width: 760px) { .form-row { grid-template-columns: 1fr; } }

/* ============================================
   ADDITIONAL: Blog Grid & Cards
   ============================================ */
.blog-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-5); }
.blog-card { display: grid; gap: var(--space-4); text-decoration: none; color: inherit; transition: transform 200ms ease, box-shadow 200ms ease; }
.blog-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.blog-card__category { font-size: var(--text-xs); letter-spacing: 0.08em; text-transform: uppercase; font-weight: 700; color: var(--color-primary); }
.blog-card__title { font-size: var(--text-lg); color: var(--color-text); font-weight: 700; }
.blog-card__desc { font-size: var(--text-sm); color: var(--color-text-muted); }
.blog-card__footer { display: flex; justify-content: space-between; align-items: center; font-size: var(--text-xs); color: var(--color-text-faint); border-top: 1px solid var(--color-border); padding-top: var(--space-4); }
.blog-card__link { color: var(--color-primary); font-weight: 600; }
@media (max-width: 1080px) { .blog-grid { grid-template-columns: 1fr; } }

/* ============================================
   ADDITIONAL: Blog Filters
   ============================================ */
.blog-filters { display: flex; gap: var(--space-2); flex-wrap: wrap; margin-bottom: var(--space-8); }
.blog-filters__btn {
  padding: 0.5rem 1rem; border-radius: var(--radius-full); border: 1px solid var(--color-border);
  background: var(--color-surface); color: var(--color-text-muted); font-size: var(--text-xs);
  font-weight: 600; cursor: pointer; transition: all 180ms ease;
}
.blog-filters__btn:hover { background: var(--color-surface-2); color: var(--color-text); }
.blog-filters__btn.is-active { background: var(--color-primary); color: white; border-color: var(--color-primary); }

/* ============================================
   ADDITIONAL: Blog Article Typography
   ============================================ */
.article-wrap { max-width: 70ch; margin-inline: auto; }
.article-header { display: grid; gap: var(--space-3); margin-bottom: var(--space-10); }
.article-back { font-size: var(--text-sm); color: var(--color-primary); font-weight: 600; }
.article-back:hover { text-decoration: underline; }
.article-title { font-family: var(--font-display); font-size: clamp(2rem, 1.5rem + 2vw, 3.5rem); letter-spacing: -0.03em; }
.article-meta { display: flex; gap: var(--space-3); font-size: var(--text-sm); color: var(--color-text-muted); flex-wrap: wrap; }
.article-content { max-width: 70ch; }
.article-content h2 { font-family: var(--font-display); font-size: clamp(1.4rem, 1.2rem + 0.8vw, 2rem); margin: var(--space-10) 0 var(--space-4); letter-spacing: -0.02em; }
.article-content h3 { font-size: var(--text-lg); margin: var(--space-8) 0 var(--space-3); }
.article-content p { margin-bottom: var(--space-4); color: var(--color-text-muted); max-width: 70ch; line-height: 1.75; }
.article-content a { color: var(--color-primary); text-decoration: underline; text-underline-offset: 2px; }
.article-content a:hover { color: var(--color-primary-hover); }
.article-content strong { color: var(--color-text); }
.article-content ul, .article-content ol { margin: var(--space-4) 0; padding-left: var(--space-6); color: var(--color-text-muted); }
.article-content li { margin-bottom: var(--space-2); line-height: 1.75; }
.article-content hr { border: none; border-top: 1px solid var(--color-border); margin: var(--space-8) 0; }
.article-content blockquote { border-left: 3px solid var(--color-primary); padding-left: var(--space-4); margin: var(--space-6) 0; font-style: italic; color: var(--color-text-muted); }

/* ============================================
   ADDITIONAL: Tools Hub Cards
   ============================================ */
.tools-hub-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-5); }
.tools-hub-card { text-decoration: none; color: inherit; display: grid; gap: var(--space-4); transition: transform 200ms ease, box-shadow 200ms ease; }
.tools-hub-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.tools-hub-card .case-kicker { color: var(--color-primary); }
@media (max-width: 1080px) { .tools-hub-grid { grid-template-columns: 1fr; } }

/* ============================================
   ADDITIONAL: Tools Subpage Styles
   ============================================ */
.tools-filter-bar { display: flex; gap: var(--space-4); flex-wrap: wrap; margin-bottom: var(--space-8); align-items: center; }
.tools-filter-bar select,
.tools-filter-bar input {
  padding: 0.7rem 1rem; border-radius: var(--radius-md); border: 1px solid var(--color-border);
  background: var(--color-surface); color: var(--color-text); font: inherit; font-size: var(--text-sm);
  min-width: 12rem;
}
.tools-filter-bar select:focus,
.tools-filter-bar input:focus { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 3px var(--color-primary-soft); }
.tools-table { width: 100%; border-collapse: collapse; }
.tools-table th { text-align: left; padding: var(--space-3) var(--space-4); border-bottom: 2px solid var(--color-border); font-size: var(--text-sm); font-weight: 700; color: var(--color-text); cursor: pointer; }
.tools-table td { padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--color-border); font-size: var(--text-sm); color: var(--color-text-muted); }
.tools-table tr:hover td { background: var(--color-surface-2); }
.tool-card { padding: var(--space-5); display: grid; gap: var(--space-3); }
.tool-card h3 { font-size: var(--text-base); }
.tool-card .tag { font-size: var(--text-xs); }
.tools-feed-item { padding: var(--space-5); display: grid; gap: var(--space-3); }
.tools-feed-item h3 { font-size: var(--text-base); }
.tools-feed-item a { color: var(--color-primary); }

/* ============================================
   ADDITIONAL: CTA Section (bottom of pages)
   ============================================ */
.cta-bottom { text-align: center; }
.cta-bottom .contact-card { max-width: 48rem; margin-inline: auto; }

/* ============================================
   ADDITIONAL: Logo (text-based from current site)
   ============================================ */
.logo-text { font-family: var(--font-display); font-size: 1.5rem; font-weight: 800; color: var(--color-text); letter-spacing: -0.03em; }
.logo-text .logo-i { color: var(--color-primary); }
