/* ── INDEX PAGE STYLES ── */
.hero-h1   { font-family: var(--serif); font-size: var(--text-hero); font-weight: 400; line-height: 1.1; color: var(--text-dark); letter-spacing: 0.02em; margin-bottom: 28px; }
.hero-lead { font-size: var(--text-body); color: var(--text-mid); line-height: 1.75; max-width: 420px; margin-bottom: 40px; }
.hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; }

.signals-grid   { display: grid; grid-template-columns: repeat(3, 1fr); }
.signal-item    { padding: 0 32px; border-left: 0.5px solid rgba(255,255,255,0.12); }
.signal-item:first-child { padding-left: 0; border-left: none; }
.signal-val     { font-family: var(--serif); font-size: 28px; font-weight: 400; color: var(--cream); margin-bottom: 5px; }
.signal-label   { font-family: var(--sans); font-size: var(--text-label); letter-spacing: 0.12em; text-transform: uppercase; color: var(--green-pale); }

.sol-intro-h2 { font-family: var(--serif); font-size: var(--text-h2); font-weight: 400; color: var(--text-dark); line-height: 1.25; margin-bottom: 36px; }
.sol-grid  { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--cream-dark); }
.sol-card  { background: var(--white); padding: 32px 28px; display: flex; flex-direction: column; gap: 12px; transition: background 0.15s; }
.sol-card:hover { background: var(--cream); }
.sol-num   { font-family: var(--serif); font-size: var(--text-small-title); font-weight: 400; color: var(--text-mid); }
.sol-card h3 { font-family: var(--serif); font-size: var(--text-h3); font-weight: 500; color: var(--text-dark); line-height: 1.3; }
.sol-card p  { font-size: var(--text-body-sm); color: var(--text-mid); line-height: 1.65; flex: 1; }
.sol-link  { font-family: var(--sans); font-size: var(--text-label); letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-light); display: flex; align-items: center; gap: 7px; }

.phil-grid  { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }
.phil-h2    { font-family: var(--serif); font-size: var(--text-h2); font-weight: 400; color: var(--cream); line-height: 1.25; margin-bottom: 18px; }
.phil-p     { font-size: var(--text-body-sm); color: var(--green-pale); line-height: 1.75; margin-bottom: 24px; }
.process-step  { display: grid; grid-template-columns: 32px 1fr; gap: 16px; padding: 18px 0; border-top: 0.5px solid rgba(255,255,255,0.1); }
.process-num   { font-family: var(--serif); font-size: var(--text-small-title); font-weight: 400; color: var(--cream); padding-top: 1px; }
.process-title { font-family: var(--serif); font-size: var(--text-small-title); font-weight: 500; color: var(--cream); margin-bottom: 5px; }
.process-text  { font-size: var(--text-body-sm); color: var(--cream); line-height: 1.65; }

.insights-h2 { font-family: var(--serif); font-size: var(--text-h2); font-weight: 400; color: var(--text-dark); line-height: 1.25; margin-bottom: 32px; }
.ins-grid  { display: grid; grid-template-columns: 110px 1fr auto; gap: 28px; align-items: start; padding-top: 28px; border-top: 0.5px solid var(--cream-dark); }
.ins-date  { font-family: var(--sans); font-size: var(--text-label); letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-light); padding-top: 3px; }
.ins-title { font-family: var(--serif); font-size: var(--text-item); font-weight: 500; color: var(--text-dark); margin-bottom: 10px; }
.ins-body  { font-size: var(--text-body-sm); color: var(--text-mid); line-height: 1.7; }
.ins-link  { font-family: var(--sans); font-size: var(--text-label); letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-light); display: flex; align-items: center; gap: 7px; white-space: nowrap; padding-top: 3px; }

.cta-center { text-align: center; }
.cta-h2 { font-family: var(--serif); font-size: var(--text-h2); font-weight: 400; color: var(--cream); line-height: 1.2; margin-bottom: 14px; }
.cta-p  { font-size: var(--text-body-sm); color: var(--green-pale); line-height: 1.7; margin-bottom: 32px; }

@media (max-width: 960px) {
  .signals-grid { grid-template-columns: 1fr; gap: 20px; }
  .signal-item  { padding: 16px 0 0; border-left: none; border-top: 0.5px solid rgba(255,255,255,0.12); }
  .signal-item:first-child { padding-top: 0; border-top: none; }
  .sol-grid  { grid-template-columns: 1fr; }
  .phil-grid { grid-template-columns: 1fr; gap: 40px; }
  .ins-grid  { grid-template-columns: 1fr; gap: 12px; }
  .ins-link  { display: none; }
}
