/* ============================================================
   My HOA Spot — Component Styles (style2.css)
   Page-specific layouts and components
   ============================================================ */

/* ── HOME: THREE-COMPANY STACK ── */
.stack-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 48px;
}
.stack-card {
  border-radius: var(--radius-lg);
  padding: 32px 28px;
  border: 1px solid var(--border);
}
.stack-card-icon { font-size: 28px; margin-bottom: 10px; }
.stack-card-tag {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  margin-bottom: 8px;
  opacity: 0.65;
}
.stack-card h3 { font-size: 20px; margin-bottom: 10px; }
.stack-card p { font-size: 14px; line-height: 1.65; }
.stack-blue { background: #eef4fd; border-color: #c5d9f5; }
.stack-blue .stack-card-tag, .stack-blue h3 { color: #2a5fa8; }
.stack-green { background: #edfaf4; border-color: #b8edda; }
.stack-green .stack-card-tag, .stack-green h3 { color: #1a7a52; }
.stack-orange { background: #fff5e6; border-color: #ffd9a0; }
.stack-orange .stack-card-tag, .stack-orange h3 { color: #a06000; }

/* ── HOME: SERVICES OVERVIEW ── */
.services-overview-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}
.services-overview-right {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.service-tile {
  border-radius: var(--radius-md);
  padding: 22px;
  border: 1px solid var(--border);
}
.tile-icon { font-size: 22px; margin-bottom: 10px; }
.service-tile h4 { font-size: 15px; margin-bottom: 6px; }
.service-tile p { font-size: 13px; line-height: 1.6; }
.tile-blue { background: #eef4fd; border-color: #c5d9f5; }
.tile-blue h4 { color: #2a5fa8; }
.tile-orange { background: #fff5e6; border-color: #ffd9a0; }
.tile-orange h4 { color: #a06000; }
.tile-green { background: #edfaf4; border-color: #b8edda; }
.tile-green h4 { color: #1a7a52; }
.tile-navy { background: #eef1f5; border-color: #c8d4de; }
.tile-navy h4 { color: var(--navy); }

/* ── HOME: HOW IT WORKS ── */
.steps-flow {
  display: flex;
  align-items: flex-start;
  margin-top: 48px;
}
.step-item { flex: 1; text-align: center; padding: 0 20px; }
.step-number {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--blue);
  color: #fff;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700;
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 14px;
}
.step-title { font-size: 16px; font-weight: 600; color: var(--text); margin-bottom: 8px; }
.step-desc { font-size: 13px; color: var(--text2); line-height: 1.6; }
.step-arrow { font-size: 22px; color: var(--blue); padding-top: 10px; flex-shrink: 0; }

/* ── HOME: PRICING TEASER ── */
.pricing-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 48px;
}
.pricing-card {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 32px 28px;
  background: var(--white);
  position: relative;
}
.pricing-card.featured {
  border-color: var(--blue);
  box-shadow: 0 0 0 2px rgba(70,127,207,0.15);
}
.pricing-popular {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--blue);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 4px 14px;
  border-radius: 12px;
  white-space: nowrap;
  letter-spacing: 0.3px;
}
.pricing-tier { font-size: 13px; font-weight: 700; color: var(--text2); margin-bottom: 10px; text-transform: uppercase; letter-spacing: 0.5px; }
.pricing-amount { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 36px; font-weight: 700; color: var(--text); margin-bottom: 12px; }
.pricing-amount span { font-size: 14px; font-weight: 500; color: var(--text2); }
.pricing-desc { font-size: 14px; color: var(--text2); line-height: 1.6; margin-bottom: 24px; }
.pricing-footnote { text-align: center; margin-top: 24px; font-size: 14px; }

/* ── HOME: WHY US ── */
.why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin-top: 48px;
}
.why-icon { font-size: 24px; margin-bottom: 12px; }
.why-item h4 { font-size: 16px; margin-bottom: 8px; }
.why-item p { font-size: 14px; color: var(--text2); line-height: 1.6; }

/* ── SERVICES: INTRO ── */
.intro-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 64px;
  align-items: start;
}
.intro-text h2 { font-size: 26px; margin-bottom: 16px; }
.intro-text p { font-size: 15px; line-height: 1.7; margin-bottom: 12px; }
.intro-stats { display: flex; flex-direction: column; gap: 16px; }
.intro-stat-box {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 20px 28px;
  text-align: center;
  min-width: 160px;
  background: var(--white);
}
.intro-stat-value {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 32px;
  font-weight: 700;
  color: var(--blue);
  display: block;
}
.intro-stat-label { font-size: 12px; color: var(--text2); margin-top: 4px; display: block; }

/* ── SERVICES: SERVICE SECTIONS ── */
.service-section-grid {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 48px;
  align-items: start;
}
.service-section-main h2 { font-size: 26px; margin-bottom: 12px; }
.service-section-main > p { margin-bottom: 20px; font-size: 15px; }
.service-tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 20px;
  margin-bottom: 14px;
  letter-spacing: 0.3px;
}
.tag-blue { background: rgba(70,127,207,0.1); color: #2d60aa; }
.tag-orange { background: rgba(255,162,43,0.12); color: #b07000; }
.tag-green { background: rgba(52,195,143,0.1); color: #1e8a62; }
.tag-navy { background: rgba(14,34,48,0.08); color: var(--navy); }
.sidebar-card {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px;
  background: var(--white);
}
.sidebar-card h4 { font-size: 14px; margin-bottom: 14px; }
.sidebar-checklist { list-style: none; padding: 0; margin: 0; }
.sidebar-checklist li {
  font-size: 13px;
  color: var(--text2);
  padding: 7px 0;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 8px;
}
.sidebar-checklist li:last-child { border-bottom: none; }
.sidebar-checklist li::before { content: '\2713'; color: var(--green); font-weight: 700; font-size: 12px; }

/* ── SERVICES: WORK ORDER FLOW ── */
.work-order-flow { display: flex; flex-direction: column; }
.flow-step { display: flex; align-items: flex-start; gap: 14px; padding: 12px 0; }
.flow-dot { width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0; margin-top: 4px; }
.flow-blue { background: var(--blue); }
.flow-orange { background: var(--orange); }
.flow-green { background: var(--green); }
.flow-navy { background: var(--navy); }
.flow-line { width: 2px; height: 20px; background: var(--border); margin-left: 5px; }
.flow-step strong { font-size: 14px; display: block; margin-bottom: 2px; color: var(--text); }
.flow-step p { font-size: 12px; margin: 0; }

/* ── SERVICES: COMPLIANCE ── */
.compliance-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: 32px;
}
.compliance-card {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 22px;
  background: var(--white);
}
.compliance-icon { font-size: 24px; margin-bottom: 10px; }
.compliance-card h4 { font-size: 15px; margin-bottom: 8px; }
.compliance-card p { font-size: 13px; line-height: 1.6; }

/* ── SERVICES: GOVERNANCE ── */
.governance-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}
.governance-left h2 { font-size: 26px; margin-bottom: 12px; }
.governance-left > p { margin-bottom: 20px; font-size: 15px; }
.portal-card {
  border: 2px solid var(--blue);
  border-radius: var(--radius-lg);
  padding: 32px;
  background: var(--white);
}
.portal-badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  color: var(--blue);
  background: rgba(70,127,207,0.08);
  padding: 4px 12px;
  border-radius: 12px;
  margin-bottom: 12px;
}
.portal-card h3 { font-size: 22px; margin-bottom: 8px; }
.portal-card > p { font-size: 14px; margin-bottom: 20px; }
.portal-features { list-style: none; padding: 0; margin: 0 0 24px; }
.portal-features li {
  font-size: 14px;
  color: var(--text2);
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}
.portal-features li:last-child { border-bottom: none; }

/* ── SERVICES: ARC + RESERVE ── */
.arc-reserve-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
}
.arc-reserve-col h2 { font-size: 26px; margin-bottom: 12px; }
.arc-reserve-col > p { margin-bottom: 20px; font-size: 15px; }

/* ── CTA BAND ── */
.cta-band {
  background: var(--navy2);
  padding: 80px 0;
  text-align: center;
}
.cta-band h2 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 32px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 12px;
  letter-spacing: -0.3px;
}
.cta-band p {
  font-size: 16px;
  color: rgba(255,255,255,0.55);
  margin-bottom: 28px;
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.6;
}
