/* ================================================================
   COLUMBIA PUBLICATION — pages/service.css
   Service pages + pillar pages. Loaded on all service/pillar pages.
   ================================================================ */

/* ── Page hero ────────────────────────────────────────────────── */
.page-hero {
  background: linear-gradient(135deg, var(--navy-deep) 0%, var(--navy) 100%);
  padding-block: var(--sp-20) var(--sp-16);
  position: relative;
  overflow: hidden;
}

.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 70% at 100% 30%, rgba(198,168,90,.07), transparent);
  pointer-events: none;
}

.page-hero__bar {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--gold-dark), var(--gold), var(--gold-dark), transparent);
}

.page-hero .container { position: relative; z-index: 2; }

.page-hero h1 { color: var(--white); margin-bottom: var(--sp-4); }
.page-hero h1 em { color: var(--gold-light); }
.page-hero .hero-answer { max-width: 720px; }

.hero-answer {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--r-md);
  padding: var(--sp-5) var(--sp-6);
  font-size: 1rem;
  color: rgba(253,251,247,.85);
  line-height: 1.8;
  margin-top: var(--sp-5);
}

.hero-answer strong { color: var(--white); }

.page-hero__meta {
  display: flex;
  align-items: center;
  gap: var(--sp-5);
  margin-top: var(--sp-6);
  flex-wrap: wrap;
}

.page-hero__meta span {
  font-size: 0.8125rem;
  color: rgba(253,251,247,.5);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

/* ── TOC (table of contents) ──────────────────────────────────── */
.toc {
  background: var(--parchment);
  border: 1px solid var(--border-light);
  border-radius: var(--r-lg);
  padding: var(--sp-6) var(--sp-8);
  margin-block: var(--sp-8);
}

.toc__title {
  font-size: 0.8125rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  margin-bottom: var(--sp-4);
}

.toc__list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  counter-reset: toc;
}

.toc__list a {
  font-size: 0.9375rem;
  color: var(--navy);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-2) 0;
  transition: color var(--ease);
  counter-increment: toc;
}

.toc__list a::before {
  content: counter(toc);
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--gold-dark);
  width: 20px;
  flex-shrink: 0;
}

.toc__list a:hover { color: var(--gold-dark); }

/* ── Content body ─────────────────────────────────────────────── */
.content-body h2 {
  margin-top: var(--sp-12);
  margin-bottom: var(--sp-5);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--border-light);
  scroll-margin-top: 90px;
}

.content-body h2:first-child { margin-top: 0; }
.content-body h3 { margin-top: var(--sp-8); margin-bottom: var(--sp-3); }

.content-body p { margin-bottom: var(--sp-5); }
.content-body p:last-child { margin-bottom: 0; }

.content-body a {
  color: var(--navy);
  font-weight: 500;
  text-decoration: underline;
  text-decoration-color: rgba(30,58,95,.3);
  text-underline-offset: 3px;
  transition: text-decoration-color var(--ease);
}

.content-body a:hover { text-decoration-color: var(--navy); }

/* ── Callout box ──────────────────────────────────────────────── */
.callout {
  background: var(--gold-pale);
  border-left: 4px solid var(--gold);
  border-radius: 0 var(--r-md) var(--r-md) 0;
  padding: var(--sp-5) var(--sp-6);
  margin-block: var(--sp-8);
  font-size: 0.9375rem;
  color: var(--ink-light);
  line-height: 1.75;
}

.callout strong { color: var(--navy-deep); }

.callout--navy {
  background: var(--navy-pale);
  border-left-color: var(--navy);
}

/* ── Numbered steps ───────────────────────────────────────────── */
.steps { display: flex; flex-direction: column; gap: var(--sp-6); }

.step {
  display: flex;
  gap: var(--sp-6);
  align-items: flex-start;
  background: var(--white);
  border: 1px solid var(--border-light);
  border-radius: var(--r-lg);
  padding: var(--sp-8);
}

.step__number {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--navy);
  color: var(--white);
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.step__body h3 { font-size: 1.0625rem; margin-bottom: var(--sp-3); }
.step__body p  { font-size: 0.9375rem; color: var(--muted); }

.step__tip {
  background: var(--navy-pale);
  border-radius: var(--r);
  padding: var(--sp-4) var(--sp-5);
  font-size: 0.875rem;
  color: var(--ink-light);
  margin-top: var(--sp-4);
  line-height: 1.7;
}

.step__tip strong { color: var(--navy); }

/* ── Spec table ───────────────────────────────────────────────── */
.spec-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
}

.spec-card {
  background: var(--white);
  border: 1px solid var(--border-light);
  border-radius: var(--r-lg);
  padding: var(--sp-6);
}

.spec-card h3 { font-size: 0.9375rem; margin-bottom: var(--sp-5); }

.spec-row {
  display: flex;
  justify-content: space-between;
  gap: var(--sp-4);
  font-size: 0.8125rem;
  padding: var(--sp-2) 0;
  border-bottom: 1px solid var(--border-light);
}

.spec-row:last-child { border-bottom: none; }
.spec-row span:first-child { color: var(--muted); }
.spec-row span:last-child  { color: var(--ink); font-weight: 500; text-align: right; }

/* ── Comparison table ─────────────────────────────────────────── */
.compare-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9375rem;
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--border-light);
}

.compare-table th {
  background: var(--navy);
  color: var(--white);
  padding: var(--sp-5) var(--sp-6);
  font-family: var(--font-body);
  font-weight: 600;
  text-align: left;
}

.compare-table th.col-highlight { background: var(--navy-mid); }

.compare-table td {
  padding: var(--sp-4) var(--sp-6);
  color: var(--ink-light);
  border-bottom: 1px solid var(--border-light);
  vertical-align: middle;
}

.compare-table td.col-highlight {
  background: var(--navy-pale);
  font-weight: 500;
  color: var(--navy);
}

.compare-table tbody tr:last-child td { border-bottom: none; }
.compare-table tbody tr:hover td      { background: var(--parchment); }
.compare-table tbody tr:hover td.col-highlight { background: var(--navy-pale); }

.compare-table .check { color: var(--success); font-weight: 700; }
.compare-table .cross { color: var(--error); }

/* ── Two-column layout with sidebar ──────────────────────────── */
.page-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--sp-12);
  align-items: start;
}

.page-sidebar {
  position: sticky;
  top: 90px;
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}

.sidebar-card {
  background: var(--white);
  border: 1px solid var(--border-light);
  border-radius: var(--r-lg);
  padding: var(--sp-6);
}

.sidebar-card--cta {
  background: var(--navy);
}

.sidebar-card--cta h4 {
  color: var(--white);
  font-size: 1rem;
  margin-bottom: var(--sp-3);
}

.sidebar-card--cta p {
  color: rgba(253,251,247,.65);
  font-size: 0.875rem;
  line-height: 1.65;
  margin-bottom: var(--sp-5);
}

.sidebar-card h4 {
  font-size: 0.8125rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  margin-bottom: var(--sp-4);
}

.sidebar-links {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.sidebar-links a {
  font-size: 0.875rem;
  color: var(--navy);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  transition: color var(--ease);
}

.sidebar-links a::before { content: '\2192'; flex-shrink: 0; font-size: 0.75rem; }
.sidebar-links a:hover { color: var(--gold-dark); text-decoration: underline; }

/* ── Related grid ─────────────────────────────────────────────── */
.related-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-10);
}

.related-section h3 {
  font-size: 0.9375rem;
  margin-bottom: var(--sp-5);
}

.related-links {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.related-link {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-4) var(--sp-5);
  background: var(--white);
  border: 1px solid var(--border-light);
  border-radius: var(--r-md);
  text-decoration: none;
  transition: box-shadow var(--ease), border-color var(--ease);
}

.related-link:hover { box-shadow: var(--shadow-xs); border-color: var(--border); }

.related-link__icon { font-size: 1.25rem; flex-shrink: 0; }

.related-link strong {
  display: block;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--navy);
}

.related-link span {
  font-size: 0.75rem;
  color: var(--muted);
}

/* ── Fit grid (pros/cons) ─────────────────────────────────────── */
.fit-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-6); }

.fit-card { border-radius: var(--r-lg); padding: var(--sp-8); }
.fit-card--yes { background: rgba(26,122,74,.05); border: 1px solid rgba(26,122,74,.15); }
.fit-card--no  { background: var(--parchment); border: 1px solid var(--border-light); }

.fit-card h3 { font-size: 1rem; margin-bottom: var(--sp-5); }

.fit-card ul { display: flex; flex-direction: column; gap: var(--sp-4); }

.fit-card li {
  font-size: 0.875rem;
  color: var(--ink-light);
  padding-left: var(--sp-6);
  position: relative;
  line-height: 1.6;
}

.fit-card--yes li::before { content: '\2713'; position: absolute; left: 0; color: var(--success); font-weight: 700; }
.fit-card--no  li::before { content: '\2714'; position: absolute; left: 0; color: var(--muted); }

/* ── Responsive ───────────────────────────────────────────────── */
@media (max-width: 1100px) {
  .page-layout { grid-template-columns: 1fr 280px; gap: var(--sp-8); }
  .spec-grid   { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 900px) {
  .page-layout { grid-template-columns: 1fr; }
  .page-sidebar { position: static; }
  .fit-grid     { grid-template-columns: 1fr; }
  .related-grid { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .spec-grid { grid-template-columns: 1fr; }
  .step { flex-direction: column; gap: var(--sp-4); }
}
