/* ============================================================================
   pseo.css — Programmatic SEO landing page styles
   Used on all /elevator-[service]-[city]/ pages.
   Imports site-wide brand variables + style.css; only adds page-specific layout.
   ============================================================================ */

/* ----- Page container ----- */
.container-narrow {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 24px;
}

.pseo-section {
  padding: 64px 0;
  border-bottom: 1px solid var(--line, #d8e0ee);
}
.pseo-section:last-of-type { border-bottom: 0; }
.pseo-section h2 {
  font-family: var(--display, 'Fraunces', Georgia, serif);
  font-size: clamp(26px, 3vw, 34px);
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--ink, #0f1d33);
  margin: 0 0 18px;
  line-height: 1.2;
}
.pseo-section h3 {
  font-family: var(--display, 'Fraunces', Georgia, serif);
  font-size: 20px;
  font-weight: 500;
  color: var(--ink, #0f1d33);
  margin: 24px 0 8px;
}
.pseo-section p {
  font-size: 15.5px;
  line-height: 1.65;
  color: var(--ink-mid, #3a4a63);
  margin: 0 0 16px;
}
.pseo-section a {
  color: var(--brand-blue, #163979);
  text-decoration: underline;
  text-decoration-color: rgba(22, 57, 121, 0.3);
  text-underline-offset: 3px;
}
.pseo-section a:hover {
  text-decoration-color: var(--brand-blue, #163979);
}
.pseo-section-lede {
  color: var(--ink-mute, #5d6d85);
  font-size: 14.5px;
  margin-bottom: 28px;
}

/* ----- Hero ----- */
.pseo-hero {
  padding: 80px 0 56px;
  background: linear-gradient(180deg, #050c1e 0%, #0a1933 100%);
  color: #fff;
  border-bottom: 3px solid #c47912;
}
.pseo-hero .pseo-eyebrow {
  font-family: var(--mono, 'JetBrains Mono', monospace);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #f0b35d;
  margin-bottom: 18px;
}
.pseo-hero .pseo-eyebrow a {
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
}
.pseo-hero .pseo-eyebrow a:hover { color: #fff; }
.pseo-hero h1 {
  font-family: var(--display, 'Fraunces', Georgia, serif);
  font-size: clamp(34px, 5vw, 52px);
  font-weight: 500;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: #fff;
  margin: 0 0 18px;
}
.pseo-lede {
  font-size: clamp(16px, 1.6vw, 19px);
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.82);
  margin: 0 0 26px;
  max-width: 720px;
}
.pseo-hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 28px;
  margin: 0 0 30px;
  font-size: 13.5px;
  color: rgba(255, 255, 255, 0.7);
}
.pseo-hero-meta strong {
  display: block;
  font-family: var(--mono, monospace);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #f0b35d;
  margin-bottom: 3px;
}
.pseo-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}

/* Override site-wide btn for pseo-hero context */
.pseo-hero .btn-primary {
  background: #fff !important;
  color: #163979 !important;
  border-color: #fff !important;
}
.pseo-hero .btn-primary:hover {
  background: #f0b35d !important;
  color: #163979 !important;
  border-color: #f0b35d !important;
}
.pseo-hero .btn-ghost {
  background: transparent !important;
  color: #fff !important;
  border-color: rgba(255, 255, 255, 0.4) !important;
}
.pseo-hero .btn-ghost:hover {
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: #fff !important;
}

/* ----- Stats panel ----- */
.pseo-stats {
  background: #f7f9fc;
}
.pseo-stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
  margin: 0 0 24px;
}
.pseo-stat-card {
  padding: 24px 22px;
  background: #fff;
  border: 1px solid var(--line, #d8e0ee);
  border-radius: 10px;
  border-left: 3px solid var(--brand-blue, #163979);
}
.pseo-stat-num {
  font-family: var(--display, 'Fraunces', Georgia, serif);
  font-size: 38px;
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--brand-blue, #163979);
  line-height: 1;
  margin-bottom: 6px;
}
.pseo-stat-label {
  font-size: 13.5px;
  color: var(--ink-mid, #3a4a63);
  line-height: 1.45;
}
.pseo-stats-note {
  font-size: 14.5px;
  color: var(--ink-mid, #3a4a63);
  line-height: 1.6;
  margin-top: 18px;
  padding: 18px 22px;
  background: #fff;
  border-radius: 8px;
  border: 1px solid var(--line, #d8e0ee);
}

/* ----- Pricing ----- */
.pseo-pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
  margin: 24px 0 16px;
}
.pseo-pricing-card {
  padding: 28px 26px;
  background: #fff;
  border: 1px solid var(--line, #d8e0ee);
  border-radius: 10px;
  position: relative;
}
.pseo-pricing-card-feature {
  background: linear-gradient(180deg, #163979 0%, #0f2a5e 100%);
  color: #fff;
  border-color: #163979;
}
.pseo-pricing-tier {
  font-family: var(--mono, monospace);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brand-blue, #163979);
  margin-bottom: 8px;
}
.pseo-pricing-card-feature .pseo-pricing-tier { color: #f0b35d; }
.pseo-pricing-amount {
  font-family: var(--display, 'Fraunces', Georgia, serif);
  font-size: 32px;
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--ink, #0f1d33);
  margin-bottom: 14px;
}
.pseo-pricing-card-feature .pseo-pricing-amount { color: #fff; }
.pseo-pricing-amount span {
  font-size: 14px;
  font-weight: 400;
  color: var(--ink-mute, #5d6d85);
  font-family: var(--ui, 'Inter', sans-serif);
}
.pseo-pricing-card-feature .pseo-pricing-amount span { color: rgba(255, 255, 255, 0.7); }
.pseo-pricing-card ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.pseo-pricing-card li {
  padding: 6px 0 6px 22px;
  position: relative;
  font-size: 14.5px;
  line-height: 1.5;
  color: var(--ink-mid, #3a4a63);
}
.pseo-pricing-card-feature li { color: rgba(255, 255, 255, 0.85); }
.pseo-pricing-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 14px;
  width: 12px;
  height: 2px;
  background: var(--brand-blue, #163979);
  border-radius: 2px;
}
.pseo-pricing-card-feature li::before { background: #f0b35d; }
.pseo-pricing-note {
  text-align: center;
  font-size: 13px;
  color: var(--ink-mute, #5d6d85);
  margin-top: 14px;
}

/* ----- Why Arise list ----- */
.pseo-why-list {
  list-style: none;
  padding: 0;
  margin: 24px 0 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 14px;
}
.pseo-why-list li {
  padding: 16px 18px 16px 22px;
  background: #f7f9fc;
  border-radius: 8px;
  border-left: 3px solid var(--brand-blue, #163979);
  font-size: 14.5px;
  line-height: 1.5;
  color: var(--ink-mid, #3a4a63);
}
.pseo-why-list li strong {
  display: block;
  color: var(--ink, #0f1d33);
  margin-bottom: 4px;
  font-size: 15px;
}

/* ----- FAQs ----- */
.pseo-faq-list { display: grid; gap: 8px; margin-top: 16px; }
.pseo-faq {
  background: #f7f9fc;
  border-radius: 8px;
  border: 1px solid var(--line, #d8e0ee);
  padding: 0;
  transition: background 0.18s;
}
.pseo-faq[open] { background: #fff; border-color: var(--brand-blue-soft, #6b8fc9); }
.pseo-faq summary {
  cursor: pointer;
  list-style: none;
  padding: 18px 22px;
  font-weight: 500;
  font-size: 15.5px;
  color: var(--ink, #0f1d33);
  position: relative;
  padding-right: 50px;
}
.pseo-faq summary::-webkit-details-marker { display: none; }
.pseo-faq summary::after {
  content: "+";
  position: absolute;
  right: 22px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 22px;
  font-weight: 400;
  color: var(--brand-blue, #163979);
  transition: transform 0.2s;
}
.pseo-faq[open] summary::after { content: "−"; }
.pseo-faq p {
  padding: 0 22px 20px;
  margin: 0;
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--ink-mid, #3a4a63);
}

/* ----- Related cities ----- */
.pseo-related-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
  margin-top: 12px;
}
.pseo-related-list a {
  padding: 16px 18px;
  background: #fff;
  border: 1px solid var(--line, #d8e0ee);
  border-radius: 8px;
  font-size: 14.5px;
  font-weight: 500;
  color: var(--brand-blue, #163979);
  text-decoration: none;
  transition: all 0.18s;
}
.pseo-related-list a:hover {
  background: #f7f9fc;
  border-color: var(--brand-blue, #163979);
  transform: translateY(-1px);
}

/* ----- Closing CTA ----- */
.pseo-cta-end {
  background: linear-gradient(135deg, #163979 0%, #0f2a5e 100%);
  color: #fff;
  text-align: center;
}
.pseo-cta-end h2 {
  color: #fff;
  font-size: clamp(28px, 3.5vw, 38px);
}
.pseo-cta-end p {
  color: rgba(255, 255, 255, 0.85);
  max-width: 600px;
  margin: 0 auto 24px;
  font-size: 16px;
}
.pseo-cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
}
.pseo-cta-end .btn-primary {
  background: #fff !important;
  color: #163979 !important;
  border-color: #fff !important;
}
.pseo-cta-end .btn-primary:hover {
  background: #f0b35d !important;
  color: #163979 !important;
  border-color: #f0b35d !important;
}
.pseo-cta-end .btn-ghost {
  background: transparent !important;
  color: #fff !important;
  border-color: rgba(255, 255, 255, 0.4) !important;
}
.pseo-cta-end .btn-ghost:hover {
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: #fff !important;
}

/* ----- Mobile tweaks ----- */
@media (max-width: 700px) {
  .pseo-section { padding: 48px 0; }
  .pseo-hero { padding: 64px 0 44px; }
  .pseo-hero-meta { flex-direction: column; gap: 14px; }
  .pseo-hero-actions, .pseo-cta-actions { flex-direction: column; align-items: stretch; }
  .pseo-hero-actions .btn, .pseo-cta-actions .btn { justify-content: center; }
}
