/* =================================================================
   AETHERBLOOM â€” DEDICATED PRICING PAGE STYLES
   File: /wp-content/themes/aetherbloom/css/pricing-page.min.css
   Brand: Dark Green #1C3D2B | Orange #d84e28 | Cream #FDF8F4 | Light Green #E8F0EA
================================================================= */

/* ---------- SCROLL REVEAL ANIMATION BASE ---------- */
.scroll-reveal {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.7s cubic-bezier(0.4, 0, 0.2, 1),
              transform 0.7s cubic-bezier(0.4, 0, 0.2, 1);
}
.scroll-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.scroll-reveal:nth-child(2) { transition-delay: 0.1s; }
.scroll-reveal:nth-child(3) { transition-delay: 0.2s; }
.scroll-reveal:nth-child(4) { transition-delay: 0.3s; }

/* ---------- LAYOUT OVERRIDES â€” defeat theme scroll-snap & overflow ---------- */

/* Override body-level constraints set by the global theme */
.page-our-pricing body,
body.page-our-pricing {
  height: auto !important;
  overflow: auto !important;
  overflow-x: hidden !important;
}

/* Kill the fixed petal animations on this page (they don't suit a static pricing layout) */
.page-our-pricing .fixed-petals-container,
.page-our-pricing .mobile-webp-background {
  display: none !important;
}

/* Override the orange gradient background the theme applies via body::before / body::after */
.page-our-pricing body::before,
.page-our-pricing body::after {
  display: none !important;
}

/* Override scroll-snap on the main scroll container */
.page-our-pricing .site-main,
.page-our-pricing #main {
  height: auto !important;
  overflow-y: visible !important;
  scroll-snap-type: none !important;
}

/* The theme's .content-wrapper is height:100vh â€” neutralise it */
.page-our-pricing .content-wrapper,
.page-our-pricing .pricing-content-wrapper {
  height: auto !important;
  overflow-y: visible !important;
  scroll-snap-type: none !important;
  scroll-snap-align: none !important;
  background: #FDF8F4 !important;
}

.pricing-page-layout {
  position: relative;
  z-index: 2;
  background: #FDF8F4;
  overflow: hidden;
}
.pricing-page {
  min-height: 100vh;
  overflow-y: visible !important;
  scroll-snap-type: none !important;
  height: auto !important;
  background:
    linear-gradient(180deg, rgba(253, 248, 244, 0.78) 0%, rgba(247, 241, 235, 0.88) 48%, rgba(253, 248, 244, 0.96) 100%);
  position: relative;
  z-index: 2;
}
.pricing-content-wrapper {
  background: transparent;
  position: relative;
  z-index: 3;
  scroll-snap-align: none !important;
  height: auto !important;
  overflow-y: visible !important;
  padding: 0;
}
.pricing-atmosphere {
  position: fixed;
  inset: 0;
  z-index: 1;
  overflow: hidden;
  pointer-events: none;
  opacity: 1;
  background:
    radial-gradient(circle at 16% 18%, rgba(216, 78, 40, 0.28) 0, rgba(216, 78, 40, 0) 34%),
    radial-gradient(circle at 82% 14%, rgba(28, 61, 43, 0.2) 0, rgba(28, 61, 43, 0) 30%),
    radial-gradient(circle at 80% 62%, rgba(216, 78, 40, 0.18) 0, rgba(216, 78, 40, 0) 30%),
    radial-gradient(circle at 22% 78%, rgba(28, 61, 43, 0.16) 0, rgba(28, 61, 43, 0) 28%);
}
.pricing-glow,
.pricing-petal-orb {
  position: absolute;
  border-radius: 999px;
  filter: blur(18px);
  opacity: 0.95;
  will-change: transform;
}
.pricing-glow {
  background: radial-gradient(circle at center, rgba(255,255,255,0.82) 0%, rgba(255,255,255,0) 72%);
}
.pricing-glow-one {
  width: 42rem;
  height: 42rem;
  top: -2rem;
  left: -10rem;
  animation: pricingFloatSlow 20s ease-in-out infinite;
}
.pricing-glow-two {
  width: 34rem;
  height: 34rem;
  top: 28rem;
  right: -6rem;
  animation: pricingFloatReverse 24s ease-in-out infinite;
}
.pricing-glow-three {
  width: 28rem;
  height: 28rem;
  bottom: 2rem;
  left: 18%;
  animation: pricingFloatSlow 18s ease-in-out infinite;
}
.pricing-petal-orb {
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.35),
    0 24px 60px rgba(28, 61, 43, 0.08);
}
.pricing-petal-orb-one {
  width: 18rem;
  height: 18rem;
  top: 8rem;
  right: 5%;
  background: linear-gradient(135deg, rgba(216, 78, 40, 0.28), rgba(255,255,255,0.04));
  transform: rotate(-14deg);
  animation: pricingPetalDrift 22s ease-in-out infinite;
}
.pricing-petal-orb-two {
  width: 14rem;
  height: 14rem;
  top: 28rem;
  left: 6%;
  background: linear-gradient(145deg, rgba(28, 61, 43, 0.2), rgba(255,255,255,0.04));
  transform: rotate(18deg);
  animation: pricingPetalDriftAlt 19s ease-in-out infinite;
}
.pricing-petal-orb-three {
  width: 16rem;
  height: 16rem;
  bottom: 18rem;
  right: 14%;
  background: linear-gradient(145deg, rgba(216, 78, 40, 0.24), rgba(253, 248, 244, 0.05));
  transform: rotate(10deg);
  animation: pricingPetalDrift 24s ease-in-out infinite;
}
.pricing-petal-orb-four {
  width: 12rem;
  height: 12rem;
  bottom: 6rem;
  left: 12%;
  background: linear-gradient(145deg, rgba(28, 61, 43, 0.18), rgba(255,255,255,0.03));
  transform: rotate(-12deg);
  animation: pricingPetalDriftAlt 21s ease-in-out infinite;
}
@keyframes pricingFloatSlow {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  50% { transform: translate3d(1.5rem, -1.25rem, 0) scale(1.04); }
}
@keyframes pricingFloatReverse {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  50% { transform: translate3d(-1.75rem, 1rem, 0) scale(1.05); }
}
@keyframes pricingPetalDrift {
  0%, 100% { transform: translate3d(0, 0, 0) rotate(-10deg); }
  50% { transform: translate3d(1.25rem, -1rem, 0) rotate(-2deg); }
}
@keyframes pricingPetalDriftAlt {
  0%, 100% { transform: translate3d(0, 0, 0) rotate(14deg); }
  50% { transform: translate3d(-1rem, 1.2rem, 0) rotate(22deg); }
}
.pricing-page .container {
  max-width: 1380px;
  margin: 0 auto;
  padding: 0 2rem;
}

/* Footer fix: body::before is removed on this page, so give the footer a solid
   background so its white text stays visible (matches the dark theme look) */
.pricing-page-layout .site-footer,
.page-our-pricing .site-footer {
  background: #1C3D2B !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
.pricing-page-layout .footer-bottom,
.page-our-pricing .footer-bottom {
  background: rgba(0, 0, 0, 0.15) !important;
  border-top-color: rgba(255, 255, 255, 0.15) !important;
}
.pricing-page-layout .newsletter,
.page-our-pricing .newsletter {
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: rgba(255, 255, 255, 0.15) !important;
}

/* ================================================================
   SECTION 1 â€” HERO
================================================================ */
/* ================================================================
   CALCULATOR EMBED SECTION
================================================================ */
.pricing-calculator-embed {
  background: transparent;
  padding: 80px 0 0;
}
.calc-embed-header {
  text-align: center;
  max-width: 700px;
  margin: 0 auto 1rem;
  padding: 0 2rem;
}
.calc-embed-title {
  font-family: 'Poppins', sans-serif;
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  font-weight: 700;
  color: #303D2C;
  margin-bottom: 0.75rem;
  letter-spacing: -0.02em;
  line-height: 1.2;
}
.calc-embed-sub {
  font-family: 'Inter', sans-serif;
  font-size: 1.05rem;
  color: #6b7280;
  font-weight: 300;
  line-height: 1.6;
  margin: 0;
}
.pricing-calculator-embed .calculator-section {
  background: transparent !important;
  min-height: auto !important;
  padding: 2rem 0 4rem !important;
}

/* Cards / panels */
.pricing-calculator-embed .uk-section,
.pricing-calculator-embed .aetherbloom-card {
  background: #ffffff !important;
  border: 1.5px solid rgba(28, 61, 43, 0.15) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  box-shadow: 0 8px 32px rgba(28, 61, 43, 0.08) !important;
}

/* Section labels */
.pricing-calculator-embed .section-label,
.pricing-calculator-embed .calculator-section-title {
  color: #ffffff !important;
  text-shadow: 0 2px 20px rgba(0, 0, 0, 0.6) !important;
}
.pricing-calculator-embed .calculator-section-subtitle {
  color: rgba(255, 255, 255, 0.90) !important;
  font-weight: 500 !important;
  text-shadow: 0 1px 10px rgba(0, 0, 0, 0.5) !important;
}

/* Dropdown trigger */
.pricing-calculator-embed .dropdown-trigger {
  background: #f9fafb !important;
  border: 1.5px solid rgba(28, 61, 43, 0.2) !important;
}
.pricing-calculator-embed .dropdown-trigger:hover {
  background: #f0f4f1 !important;
  border-color: #1C3D2B !important;
}
.pricing-calculator-embed .dropdown-label {
  color: #1C3D2B !important;
}
.pricing-calculator-embed .dropdown-arrow {
  color: #1C3D2B !important;
}

/* Dropdown menu */
.pricing-calculator-embed .dropdown-menu {
  background: #ffffff !important;
  border-color: rgba(28, 61, 43, 0.2) !important;
  box-shadow: 0 16px 40px rgba(28, 61, 43, 0.15) !important;
}
.pricing-calculator-embed .dropdown-header {
  background: #f0f4f1 !important;
  border-bottom-color: rgba(28, 61, 43, 0.1) !important;
  color: #d84e28 !important;
}
.pricing-calculator-embed .dropdown-option {
  border-bottom-color: rgba(28, 61, 43, 0.07) !important;
}
.pricing-calculator-embed .dropdown-option:hover {
  background: #f0f4f1 !important;
}
.pricing-calculator-embed .dropdown-option.selected {
  background: #e8f0ea !important;
}

/* Breakdown rows */
.pricing-calculator-embed .breakdown-item {
  border-bottom-color: rgba(28, 61, 43, 0.1) !important;
}
.pricing-calculator-embed .breakdown-label {
  color: #374151 !important;
}
.pricing-calculator-embed .breakdown-value {
  color: #1C3D2B !important;
}
.pricing-calculator-embed .total-cost {
  color: #1C3D2B !important;
  text-shadow: none !important;
}
.pricing-calculator-embed .savings-value-highlight {
  color: #d84e28 !important;
}

/* Total breakdown rows */
.pricing-calculator-embed .total-annual-cost-item {
  border-top-color: rgba(28, 61, 43, 0.15) !important;
}
.pricing-calculator-embed .uk-right.two-column-grid .total-breakdown {
  border-top-color: rgba(28, 61, 43, 0.15) !important;
}


/* ================================================================
   SECTION 1 - HERO + CONTAINED PETAL ANIMATION
================================================================ */
.pricing-hero {
  position: relative;
  background: #1C3D2B;
  width: 100%;
  padding: 160px 0 110px;
  overflow: hidden;       /* keeps petals clipped to hero bounds */
}

/* ---- Petal container ---- */
.ph-petals {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

/* ---- Individual petal base ---- */
.ph-petal {
  position: absolute;
  width: 110vw;
  height: 150vh;
  background: rgba(212, 94, 28, 0.55);
  filter: blur(10px);
  border-radius: 40% 60% 55% 45% / 30% 45% 55% 70%;
  transform-origin: 50% 100%;
  bottom: -30vh;
  left: 50%;
  animation-timing-function: cubic-bezier(0.4, 0.0, 0.6, 1);
  animation-iteration-count: infinite;
  animation-direction: alternate;
}

.ph-petal1 {
  transform: translateX(-50%) rotate(-45deg);
  animation: phSway1 22s infinite;
}
.ph-petal2 {
  transform: translateX(-50%) rotate(45deg);
  animation: phSway2 22s infinite;
  animation-delay: -2s;
}
.ph-petal3 {
  transform: translateX(-50%) rotate(-90deg);
  animation: phSway3 26s infinite;
  animation-delay: -5s;
}
.ph-petal4 {
  transform: translateX(-50%) rotate(90deg);
  animation: phSway4 26s infinite;
  animation-delay: -8s;
}

@keyframes phSway1 {
  0%   { transform: translateX(-50%) rotate(-45deg) rotate(-25deg) scale(0.9); }
  50%  { transform: translateX(-50%) rotate(-45deg) rotate(10deg)  scale(1.08); }
  100% { transform: translateX(-50%) rotate(-45deg) rotate(-25deg) scale(0.9); }
}
@keyframes phSway2 {
  0%   { transform: translateX(-50%) rotate(45deg) rotate(0deg)   scale(1.0); }
  50%  { transform: translateX(-50%) rotate(45deg) rotate(30deg)  scale(0.95); }
  100% { transform: translateX(-50%) rotate(45deg) rotate(0deg)   scale(1.0); }
}
@keyframes phSway3 {
  0%   { transform: translateX(-50%) rotate(-90deg) rotate(-20deg) scale(1.05); }
  50%  { transform: translateX(-50%) rotate(-90deg) rotate(60deg)  scale(0.9); }
  100% { transform: translateX(-50%) rotate(-90deg) rotate(-20deg) scale(1.05); }
}
@keyframes phSway4 {
  0%   { transform: translateX(-50%) rotate(90deg) rotate(0deg)    scale(0.95); }
  50%  { transform: translateX(-50%) rotate(90deg) rotate(-60deg)  scale(1.1); }
  100% { transform: translateX(-50%) rotate(90deg) rotate(0deg)    scale(0.95); }
}

/* ---- Hero content sits above petals ---- */
.pricing-hero-overlay {
  position: relative;
  z-index: 2;
  width: 100%;
}
.pricing-hero-content {
  text-align: center;
  max-width: 800px;
  margin: 0 auto;
  padding: 0 1rem;
}
.pricing-hero-title {
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  font-weight: 700;
  color: #ffffff;
  margin-bottom: 1.2rem;
  letter-spacing: -0.02em;
  line-height: 1.15;
  font-family: 'Poppins', -apple-system, sans-serif;
}
.pricing-hero-sub {
  font-size: clamp(1rem, 2vw, 1.25rem);
  color: rgba(255,255,255,0.88);
  max-width: 580px;
  margin: 0 auto;
  font-weight: 300;
  line-height: 1.7;
  font-family: 'Inter', -apple-system, sans-serif;
}

/* Respect reduced-motion preference */
@media (prefers-reduced-motion: reduce) {
  .ph-petal { animation: none !important; }
}

/* ================================================================
   SECTION 2 — PRICING TIERS + SIDEBAR
================================================================ */
.pricing-tiers-section {
  background: transparent;
  padding: 80px 0 100px;
}
.pricing-tiers-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  align-items: start;
}
.pricing-cards-col {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  align-items: start;
}
.pricing-sidebar-wrap {
  margin-top: 1.6rem;
  padding-top: 1.75rem;
  border-top: 1px solid rgba(28, 61, 43, 0.1);
}
.pricing-sidebar-intro {
  max-width: 720px;
  margin: 0 auto 1.25rem;
  text-align: center;
}
.pricing-sidebar-kicker {
  margin: 0 0 0.35rem;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #d84e28;
  font-family: 'Inter', sans-serif;
}
.pricing-sidebar-title {
  margin: 0;
  font-size: 1.2rem;
  line-height: 1.4;
  font-weight: 600;
  color: #1C3D2B;
  font-family: 'Poppins', sans-serif;
}

/* --- Individual Card Base --- */
.pricing-card {
  background: #ffffff;
  border: 1.5px solid rgba(28, 61, 43, 0.18);
  border-radius: 20px;
  padding: 2rem 1.75rem;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: box-shadow 0.3s ease, transform 0.3s ease;
}
.pricing-card:hover {
  box-shadow: 0 20px 50px rgba(28,61,43,0.12);
  transform: translateY(-4px);
}

/* --- Featured (Growth) Card --- */
.featured-card {
  background: #1C3D2B;
  border-color: #1C3D2B;
  margin-top: -20px;
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
  box-shadow: 0 24px 60px rgba(28, 61, 43, 0.3);
}
.featured-card:hover {
  box-shadow: 0 30px 70px rgba(28, 61, 43, 0.4);
  transform: translateY(-8px);
}

/* --- Top Badges --- */
.card-top-badge {
  display: inline-block;
  padding: 0.35rem 1rem;
  border-radius: 50px;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  align-self: flex-start;
  font-family: 'Inter', sans-serif;
}
.green-badge {
  background: #E8F0EA;
  color: #1C3D2B;
}
.orange-badge {
  background: #d84e28;
  color: #ffffff;
}

/* --- Best Value Label --- */
.best-value-label {
  position: absolute;
  top: 1.2rem;
  right: 1.2rem;
  font-size: 0.72rem;
  font-weight: 700;
  color: #d84e28;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border: 1.5px solid #d84e28;
  border-radius: 6px;
  padding: 0.2rem 0.55rem;
  font-family: 'Inter', sans-serif;
}

/* --- Card Header --- */
.card-header { display: flex; flex-direction: column; gap: 0.4rem; }
.card-tier-name {
  font-size: 1.65rem;
  font-weight: 700;
  color: #1C3D2B;
  margin: 0;
  font-family: 'Poppins', sans-serif;
}
.featured-card .card-tier-name { color: #ffffff; }

.card-price-row { display: flex; align-items: baseline; gap: 0.3rem; }
.card-price {
  font-size: 2.8rem;
  font-weight: 800;
  color: #1C3D2B;
  letter-spacing: -0.03em;
  line-height: 1;
  font-family: 'Poppins', sans-serif;
}
.featured-card .card-price { color: #ffffff; }
.card-period {
  font-size: 1rem;
  color: #6b7280;
  font-weight: 400;
  font-family: 'Inter', sans-serif;
}
.featured-card .card-period { color: rgba(255,255,255,0.75); }

.card-hours {
  font-size: 0.9rem;
  color: #6b7280;
  margin: 0;
  font-family: 'Inter', sans-serif;
}
.featured-card .card-hours { color: rgba(255,255,255,0.7); }

.card-billing-label {
  font-size: 0.75rem;
  color: #1C3D2B;
  margin: 0.1rem 0 0;
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  letter-spacing: 0.01em;
}
.featured-card .card-billing-label { color: rgba(255,255,255,0.92); }

/* --- Divider --- */
.card-divider {
  height: 1px;
  background: rgba(28, 61, 43, 0.12);
  margin: 0.4rem 0;
}
.white-divider { background: rgba(255,255,255,0.2); }

/* --- Features List --- */
.card-features { flex: 1; }
.features-heading {
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: #1C3D2B;
  margin-bottom: 0.75rem;
  font-family: 'Inter', sans-serif;
}
.featured-card .features-heading { color: rgba(255,255,255,0.8); }
.card-features ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}
.card-features li {
  font-size: 0.93rem;
  color: #374151;
  line-height: 1.45;
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  font-family: 'Inter', sans-serif;
}
.featured-card .card-features li { color: rgba(255,255,255,0.9); }

.check {
  flex-shrink: 0;
  font-weight: 700;
  font-size: 0.95rem;
  margin-top: 0.05rem;
}
.green-check { color: #1C3D2B; }
.orange-check { color: #d84e28; }

/* Sub-note beneath a feature bullet (e.g. Growth card multi-channel line) */
.feature-sub-note {
  display: block;
  font-size: 0.78rem;
  font-style: italic;
  color: rgba(255,255,255,0.6);
  font-weight: 300;
  line-height: 1.45;
  margin-top: 0.2rem;
  padding-left: 0.05rem;
  font-family: 'Inter', sans-serif;
}

/* Tier description tagline — sits between heading and bullet list */
.card-tier-desc {
  font-size: 0.88rem;
  color: #6b7280;
  font-style: italic;
  font-weight: 400;
  line-height: 1.55;
  margin: 0 0 0.75rem;
  font-family: 'Inter', sans-serif;
  padding-bottom: 0.65rem;
  border-bottom: 1px solid rgba(28,61,43,0.08);
}
.featured-card .card-tier-desc {
  color: rgba(255,255,255,0.55);
  border-bottom-color: rgba(255,255,255,0.12);
}

/* --- Savings Pill --- */
.savings-pill {
  display: inline-block;
  padding: 0.4rem 1rem;
  border-radius: 50px;
  font-size: 0.82rem;
  font-weight: 600;
  font-family: 'Inter', sans-serif;
  align-self: flex-start;
}
.orange-pill {
  background: #d84e28;
  color: #ffffff;
}

/* --- CTA Button --- */
.pricing-cta-btn {
  display: block;
  width: 100%;
  text-align: center;
  padding: 0.85rem 1rem;
  border-radius: 12px;
  font-size: 0.95rem;
  font-weight: 700;
  text-decoration: none;
  transition: all 0.25s ease;
  font-family: 'Inter', sans-serif;
  letter-spacing: 0.02em;
}
.orange-btn {
  background: #d84e28;
  color: #ffffff;
}
.orange-btn:hover {
  background: #c0411c;
  box-shadow: 0 8px 24px rgba(216, 78, 40, 0.35);
  transform: translateY(-2px);
  color: #ffffff;
}

/* ----------------------------------------------------------------
   SINGLE SHARED CTA — below all three cards
---------------------------------------------------------------- */
.pricing-shared-cta {
  display: flex;
  justify-content: center;
  margin-top: 2.5rem;
  padding: 0 1rem;
}
.pricing-main-cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #C94B2C;
  color: #ffffff;
  font-family: 'Inter', sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-decoration: none;
  padding: 1rem 3.5rem;
  border-radius: 14px;
  min-width: 260px;
  box-shadow: 0 6px 24px rgba(201, 75, 44, 0.32);
  transition: background 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
}
.pricing-main-cta-btn:hover {
  background: #b03d22;
  transform: translateY(-3px);
  box-shadow: 0 12px 36px rgba(201, 75, 44, 0.42);
  color: #ffffff;
}
.pricing-main-cta-btn:active {
  transform: translateY(-1px);
}
@media (max-width: 600px) {
  .pricing-main-cta-btn {
    width: 100%;
    min-width: unset;
    padding: 1rem 2rem;
    font-size: 1rem;
  }
  .pricing-shared-cta {
    margin-top: 2rem;
  }
}

/* ----------------------------------------------------------------
   SIDEBAR
---------------------------------------------------------------- */
.pricing-sidebar {
  display: grid;
  grid-template-columns: repeat(2, minmax(300px, 360px));
  gap: 1.25rem;
  position: static;
  margin-top: 0;
  justify-content: center;
  align-items: stretch;
}
.sidebar-box {
  border-radius: 18px;
  padding: 1.75rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  min-height: 100%;
  transition: box-shadow 0.3s ease, transform 0.3s ease;
}
.adhoc-box {
  background: #ffffff;
  border: 1.5px solid rgba(28,61,43,0.15);
}
.adhoc-box:hover {
  box-shadow: 0 12px 36px rgba(28,61,43,0.1);
  transform: translateY(-3px);
}

.bookcall-box {
  background: #1C3D2B;
}
.bookcall-box:hover {
  box-shadow: 0 16px 44px rgba(28,61,43,0.35);
  transform: translateY(-3px);
}

.sidebar-icon { color: #d84e28; }
.sidebar-heading {
  font-size: 1.15rem;
  font-weight: 700;
  color: #1C3D2B;
  margin: 0;
  font-family: 'Poppins', sans-serif;
}
.white-text { color: #ffffff !important; }
.sidebar-text {
  font-size: 0.9rem;
  color: #4b5563;
  line-height: 1.6;
  margin: 0;
  font-family: 'Inter', sans-serif;
  flex: 1;
}
.sidebar-btn {
  display: block;
  text-align: center;
  padding: 0.75rem 1rem;
  border-radius: 10px;
  font-size: 0.9rem;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.25s ease;
  font-family: 'Inter', sans-serif;
}
.outline-btn {
  border: 2px solid #1C3D2B;
  color: #1C3D2B;
  background: transparent;
}
.outline-btn:hover {
  background: #1C3D2B;
  color: #ffffff;
}
.orange-filled-btn {
  background: #d84e28;
  color: #ffffff;
  border: none;
}
.orange-filled-btn:hover {
  background: #c0411c;
  box-shadow: 0 6px 20px rgba(216,78,40,0.35);
  transform: translateY(-2px);
  color: #ffffff;
}

/* ================================================================
   SECTION 3 â€” UK SAVINGS COMPARISON
================================================================ */
.savings-comparison-section {
  background: linear-gradient(180deg, rgba(28, 61, 43, 0.92) 0%, rgba(28, 61, 43, 0.88) 100%);
  padding: 90px 0;
}
.section-header-centered {
  text-align: center;
  margin-bottom: 3rem;
}
.section-title-white {
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  font-weight: 700;
  color: #ffffff;
  margin-bottom: 0.75rem;
  font-family: 'Poppins', sans-serif;
  letter-spacing: -0.02em;
}
.section-sub-white {
  font-size: 1.05rem;
  color: rgba(255,255,255,0.8);
  font-weight: 300;
  font-family: 'Inter', sans-serif;
}
.savings-highlight-line {
  font-family: 'Inter', sans-serif;
  font-size: 0.88rem;
  color: #ff9340;
  text-align: center;
  margin-top: 0.6rem;
  font-weight: 400;
  letter-spacing: 0.01em;
}
.savings-columns {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-bottom: 2.5rem;
}
.savings-col {
  text-align: center;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 18px;
  padding: 2rem 1.5rem;
  transition: background 0.3s ease, transform 0.3s ease;
}
.savings-col:hover {
  background: rgba(255,255,255,0.09);
  transform: translateY(-4px);
}
.savings-label {
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(255,255,255,0.65);
  font-weight: 600;
  margin-bottom: 0.75rem;
  font-family: 'Inter', sans-serif;
}
.uk-cost-strike {
  font-size: 1.15rem;
  color: rgba(255,255,255,0.5);
  text-decoration: line-through;
  margin-bottom: 0.5rem;
  font-family: 'Inter', sans-serif;
}
.aether-price {
  font-size: 1.7rem;
  font-weight: 800;
  color: #d84e28;
  margin-bottom: 0.75rem;
  font-family: 'Poppins', sans-serif;
  letter-spacing: -0.02em;
}
.you-save-amount {
  font-size: 1.35rem;
  font-weight: 700;
  color: #ffffff;
  font-family: 'Poppins', sans-serif;
}
.save-pct {
  font-size: 1rem;
  opacity: 0.8;
}
.savings-footnote {
  text-align: center;
  font-size: 0.82rem;
  color: rgba(255,255,255,0.5);
  max-width: 700px;
  margin: 0 auto;
  line-height: 1.6;
  font-style: italic;
  font-family: 'Inter', sans-serif;
}

/* ================================================================
   SECTION 4 â€” TIER UPGRADE LOGIC
================================================================ */
.upgrade-logic-section {
  background: transparent;
  padding: 90px 0;
}
.section-title-dark {
  font-size: clamp(1.7rem, 3vw, 2.5rem);
  font-weight: 700;
  color: #1C3D2B;
  margin-bottom: 0.5rem;
  font-family: 'Poppins', sans-serif;
  letter-spacing: -0.02em;
}
.section-sub-dark {
  font-size: 1.05rem;
  color: #4b5563;
  font-weight: 300;
  font-family: 'Inter', sans-serif;
}
.upgrade-cards-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  margin-top: 2.5rem;
}
.upgrade-card {
  border-radius: 20px;
  padding: 2.5rem 2rem;
  position: relative;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.upgrade-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 20px 50px rgba(0,0,0,0.15);
}
.orange-upgrade-card { background: #d84e28; }
.green-upgrade-card { background: #1C3D2B; }

.upgrade-arrow {
  font-size: 2rem;
  color: rgba(255,255,255,0.35);
  position: absolute;
  top: 1.5rem;
  right: 1.75rem;
  line-height: 1;
}
.upgrade-heading {
  font-size: 1.35rem;
  font-weight: 700;
  color: #ffffff;
  margin-bottom: 1rem;
  font-family: 'Poppins', sans-serif;
}
.upgrade-text {
  font-size: 0.97rem;
  color: rgba(255,255,255,0.88);
  line-height: 1.7;
  font-family: 'Inter', sans-serif;
  font-weight: 300;
}

/* ================================================================
   SECTION 5 â€” COMPARISON TABLE
================================================================ */
.comparison-table-section {
  background: transparent;
  padding: 90px 0;
}
.pricing-table-wrap {
  overflow-x: auto;
  border-radius: 18px;
  box-shadow: 0 8px 40px rgba(28,61,43,0.1);
  -webkit-overflow-scrolling: touch;
}
.pricing-comparison-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 600px;
  border-radius: 18px;
  overflow: hidden;
}
.pricing-comparison-table thead tr {
  background: #1C3D2B;
}
.pricing-comparison-table thead th {
  padding: 1.1rem 1.25rem;
  text-align: center;
  font-size: 0.95rem;
  font-weight: 700;
  color: #ffffff;
  font-family: 'Inter', sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.pricing-comparison-table thead th + th {
  border-left: 1px solid rgba(255,255,255,0.18);
}
.pricing-comparison-table thead th.feature-col {
  text-align: left;
}
/* Essentials column header — brand green */
.pricing-comparison-table thead th:nth-child(2) {
  background: #1C3D2B;
  color: #ffffff;
}
.pricing-comparison-table tbody td {
  padding: 1rem 1.25rem;
  text-align: center;
  font-size: 0.93rem;
  color: #374151;
  font-family: 'Inter', sans-serif;
  border-bottom: 1px solid #f0f0f0;
  vertical-align: middle;
}
.pricing-comparison-table tbody td + td {
  border-left: 1px solid rgba(28, 61, 43, 0.08);
}
/* Essentials column body — brand green */
.pricing-comparison-table tbody td:nth-child(2) {
  background: #1C3D2B;
  color: #ffffff;
  border-left: 1px solid rgba(255,255,255,0.14);
  border-right: 1px solid rgba(255,255,255,0.14);
}
.pricing-comparison-table tbody td:first-child {
  text-align: left;
  font-weight: 600;
  color: #1C3D2B;
}
.pricing-comparison-table tbody tr:last-child td { border-bottom: none; }
.alt-row td { background: #E8F0EA; }
/* Essentials alt-row stays green, slightly darker */
.alt-row td:nth-child(2) { background: #163320 !important; }
/* Growth/featured-col alt-row stays orange, slightly darker */
.alt-row td.featured-col { background: #c0411c !important; }

/* Growth/featured-col column — brand orange */
.pricing-comparison-table .featured-col {
  background: #d84e28;
  color: #ffffff !important;
  font-weight: 600;
}
.pricing-comparison-table tbody td.featured-col {
  border-left: 1px solid rgba(255,255,255,0.16);
  border-right: 1px solid rgba(255,255,255,0.16);
}
.pricing-comparison-table .featured-col:first-child { color: #ffffff !important; }

.table-strikethrough {
  text-decoration: line-through;
  color: #9ca3af;
}
/* Essentials col (green bg) — strikethrough text */
.pricing-comparison-table tbody td:nth-child(2) .table-strikethrough {
  color: rgba(255,255,255,0.55);
}
.table-strikethrough-white {
  text-decoration: line-through;
  color: rgba(255,255,255,0.5);
}
/* featured-col (orange bg) — strikethrough text */
.pricing-comparison-table tbody td.featured-col .table-strikethrough {
  color: rgba(255,255,255,0.55);
}
.table-check-green { color: #ffffff; font-weight: 700; font-size: 1rem; }
.table-dash { color: #9ca3af; }
/* Essentials col dashes */
.pricing-comparison-table tbody td:nth-child(2) .table-dash {
  color: rgba(255,255,255,0.65);
}
/* Growth/featured-col dashes */
.pricing-comparison-table tbody td.featured-col .table-dash {
  color: rgba(255,255,255,0.65);
}
.pricing-comparison-table tbody td:nth-child(2) strong {
  color: #ffffff;
}
.pricing-comparison-table tbody td.featured-col strong {
  color: #ffffff;
}
/* Essentials CTA button on green bg — coral override */
.pricing-comparison-table tbody td:nth-child(2) .table-cta-btn {
  background: #C94B2C;
  color: #ffffff;
}
.pricing-comparison-table tbody td:nth-child(2) .table-cta-btn:hover {
  background: #b03d22;
  color: #ffffff;
}
/* Growth/featured-col CTA button on orange bg — coral override */
.pricing-comparison-table tbody td.featured-col .table-cta-btn {
  background: #C94B2C;
  color: #ffffff;
}
.pricing-comparison-table tbody td.featured-col .table-cta-btn:hover {
  background: #b03d22;
  color: #ffffff;
}

.table-cta-btn {
  display: inline-block;
  padding: 0.55rem 1.2rem;
  border-radius: 8px;
  font-size: 0.85rem;
  font-weight: 700;
  text-decoration: none;
  background: #C94B2C;
  color: #ffffff;
  transition: background 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
  font-family: 'Inter', sans-serif;
}
.table-cta-btn:hover {
  background: #b03d22;
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(201,75,44,0.35);
  color: #ffffff;
}
/* Remove old white variant — no longer needed */
.table-cta-white {
  background: #C94B2C;
  color: #ffffff !important;
  border: none;
}
.table-cta-white:hover {
  background: #b03d22;
  color: #ffffff !important;
}

/* ================================================================
   SECTION 6 â€” INDUSTRIES
================================================================ */
.industries-section {
  background: linear-gradient(180deg, rgba(28, 61, 43, 0.92) 0%, rgba(28, 61, 43, 0.88) 100%);
  padding: 90px 0;
}
.industries-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  margin-top: 2rem;
}
.industry-pill {
  display: inline-block;
  padding: 0.75rem 1.6rem;
  border-radius: 50px;
  border: 1.5px solid rgba(255,255,255,0.7);
  color: #ffffff;
  font-size: 0.95rem;
  font-weight: 500;
  font-family: 'Inter', sans-serif;
  cursor: default;
  transition: background 0.25s ease, border-color 0.25s ease, transform 0.25s ease;
}
.industry-pill:hover {
  background: #d84e28;
  border-color: #d84e28;
  color: #ffffff;
  transform: translateY(-3px);
}

/* ================================================================
   SECTION 7 â€” FINAL CTA
================================================================ */
.pricing-final-cta {
  background: #d84e28;
  padding: 100px 0;
}
.final-cta-content {
  text-align: center;
  max-width: 700px;
  margin: 0 auto;
}
.final-cta-title {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  color: #ffffff;
  margin-bottom: 1rem;
  letter-spacing: -0.02em;
  font-family: 'Poppins', sans-serif;
}
.final-cta-sub {
  font-size: 1.1rem;
  color: rgba(255,255,255,0.9);
  margin-bottom: 2.5rem;
  font-weight: 300;
  line-height: 1.7;
  font-family: 'Inter', sans-serif;
}
.final-cta-buttons {
  display: flex;
  justify-content: center;
  gap: 1.25rem;
  flex-wrap: wrap;
}
.final-btn {
  display: inline-block;
  padding: 0.95rem 2.2rem;
  border-radius: 12px;
  font-size: 1rem;
  font-weight: 700;
  text-decoration: none;
  transition: all 0.25s ease;
  font-family: 'Inter', sans-serif;
  letter-spacing: 0.02em;
}
.final-btn-white {
  background: #ffffff;
  color: #1C3D2B;
}
.final-btn-white:hover {
  background: #f5f5f5;
  box-shadow: 0 8px 24px rgba(0,0,0,0.15);
  transform: translateY(-3px);
  color: #1C3D2B;
}
.final-btn-outline {
  background: transparent;
  color: #ffffff;
  border: 2px solid rgba(255,255,255,0.8);
}
.final-btn-outline:hover {
  background: rgba(255,255,255,0.15);
  border-color: #ffffff;
  transform: translateY(-3px);
  color: #ffffff;
}

/* ================================================================
   SECTION: ADDITIONAL SERVICES
================================================================ */
.additional-services-section {
  background: #E8F0EA;
  padding: 90px 0;
}
.additional-services-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2.5rem;
  background: #ffffff;
  border: 1.5px solid rgba(28, 61, 43, 0.15);
  border-radius: 20px;
  padding: 3rem 3.5rem;
  box-shadow: 0 8px 32px rgba(28, 61, 43, 0.07);
}
.additional-services-text { flex: 1; }
.additional-services-title {
  font-family: 'Poppins', sans-serif;
  font-size: clamp(1.6rem, 2.8vw, 2.2rem);
  font-weight: 700;
  color: #1C3D2B;
  margin-bottom: 1rem;
  letter-spacing: -0.02em;
  line-height: 1.2;
}
.additional-services-body {
  font-family: 'Inter', sans-serif;
  font-size: 1rem;
  color: #4b5563;
  line-height: 1.75;
  font-weight: 300;
  margin: 0;
  max-width: 620px;
}
.additional-services-btn {
  display: inline-block;
  flex-shrink: 0;
  padding: 0.9rem 2rem;
  background: #1C3D2B;
  color: #ffffff;
  border-radius: 12px;
  font-family: 'Inter', sans-serif;
  font-size: 0.95rem;
  font-weight: 700;
  text-decoration: none;
  letter-spacing: 0.02em;
  transition: background 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
  white-space: nowrap;
}
.additional-services-btn:hover {
  background: #d84e28;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(216, 78, 40, 0.3);
  color: #ffffff;
}


/* ================================================================
   RESPONSIVE â€” TABLET (â‰¤1024px)
================================================================ */
@media (max-width: 1024px) {
  .pricing-glow-one {
    width: 24rem;
    height: 24rem;
    left: -6rem;
  }
  .pricing-glow-two {
    width: 20rem;
    height: 20rem;
  }
  .pricing-petal-orb-one,
  .pricing-petal-orb-three {
    width: 10rem;
    height: 10rem;
  }
  .pricing-tiers-layout {
    grid-template-columns: 1fr;
  }
  .pricing-cards-col {
    grid-template-columns: repeat(3, 1fr);
  }
  .pricing-sidebar {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
    position: static;
  }
  .savings-columns {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
  }
  .upgrade-cards-row {
    grid-template-columns: 1fr 1fr;
  }
}

/* ================================================================
   RESPONSIVE â€” MOBILE (â‰¤768px)
================================================================ */
@media (max-width: 768px) {
  .pricing-atmosphere {
    background:
      radial-gradient(circle at 20% 14%, rgba(216, 78, 40, 0.12) 0, rgba(216, 78, 40, 0) 34%),
      radial-gradient(circle at 82% 24%, rgba(28, 61, 43, 0.1) 0, rgba(28, 61, 43, 0) 30%);
  }
  .pricing-glow-three,
  .pricing-petal-orb-three,
  .pricing-petal-orb-four {
    display: none;
  }
  .pricing-glow-one {
    width: 18rem;
    height: 18rem;
    top: 7rem;
  }
  .pricing-glow-two {
    width: 16rem;
    height: 16rem;
    top: 28rem;
    right: -5rem;
  }
  .pricing-petal-orb-one,
  .pricing-petal-orb-two {
    width: 7.5rem;
    height: 7.5rem;
    filter: blur(7px);
  }
  .pricing-hero { padding: 110px 0 70px; }
  .pricing-cards-col {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
  .featured-card { margin-top: 0; }
  .pricing-sidebar-wrap {
    margin-top: 1.35rem;
    padding-top: 1.35rem;
  }
  .pricing-sidebar-intro {
    margin-bottom: 1rem;
  }
  .pricing-sidebar {
    grid-template-columns: 1fr;
    justify-content: stretch;
  }
  .savings-columns {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  .upgrade-cards-row {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
  .industries-grid {
    gap: 0.75rem;
  }
  .industry-pill {
    font-size: 0.88rem;
    padding: 0.65rem 1.2rem;
  }
  .final-cta-buttons {
    flex-direction: column;
    align-items: center;
  }
  .final-btn {
    width: 100%;
    max-width: 320px;
    text-align: center;
  }
  .pricing-tiers-section,
  .savings-comparison-section,
  .upgrade-logic-section,
  .comparison-table-section,
  .industries-section,
  .additional-services-section,
  .pricing-final-cta {
    padding: 60px 0;
  }
  .additional-services-inner {
    flex-direction: column;
    align-items: flex-start;
    padding: 2rem;
    gap: 1.75rem;
  }
  .additional-services-btn {
    width: 100%;
    text-align: center;
  }
}

/* ================================================================
   RESPONSIVE â€” SMALL MOBILE (â‰¤480px)
================================================================ */
@media (max-width: 480px) {
  .pricing-page .container { padding: 0 1rem; }
  .pricing-card { padding: 1.5rem 1.25rem; }
  .sidebar-box { padding: 1.5rem 1.25rem; }
  .upgrade-card { padding: 2rem 1.5rem; }
  .card-price { font-size: 2.2rem; }
  .pricing-comparison-table thead th,
  .pricing-comparison-table tbody td { padding: 0.75rem 0.75rem; font-size: 0.82rem; }
}

/* ================================================================
   REDUCED MOTION
================================================================ */
@media (prefers-reduced-motion: reduce) {
  .scroll-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }
  .pricing-card,
  .sidebar-box,
  .upgrade-card,
  .savings-col,
  .industry-pill,
  .final-btn,
  .pricing-cta-btn,
  .sidebar-btn,
  .table-cta-btn { transition: none !important; }
}



/* ================================================================= */
/* FAQ SECTION                                                         */
/* ================================================================= */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@600;700&family=Inter:wght@300;400;500&display=swap');

.pricing-faq {
  background: transparent;
  padding: 96px 0 80px;
  position: relative;
}
.pricing-faq::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,75,44,.25), transparent);
}

/* Header */
.faq-header {
  text-align: center;
  margin-bottom: 56px;
}
.faq-eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: .68rem;
  font-weight: 500;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: #C94B2C;
  display: block;
  margin-bottom: 14px;
}
.faq-title {
  font-family: 'Poppins', sans-serif;
  font-size: clamp(1.75rem, 3.5vw, 2.6rem);
  font-weight: 700;
  color: #303D2C;
  line-height: 1.2;
  letter-spacing: -.5px;
  margin: 0 0 14px;
}
.faq-title em {
  font-style: italic;
  color: #C94B2C;
}
.faq-sub {
  font-family: 'Inter', sans-serif;
  font-size: 1rem;
  font-weight: 400;
  color: #6b7280;
  margin: 0;
  line-height: 1.6;
}

/* FAQ List */
.faq-list {
  max-width: 820px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* Each Item */
.faq-item {
  border-bottom: 1px solid rgba(48,61,44,.1);
  position: relative;
}
.faq-item:first-child {
  border-top: 1px solid rgba(48,61,44,.1);
}
.faq-item::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: #C94B2C;
  transform: scaleY(0);
  transform-origin: top;
  transition: transform .35s cubic-bezier(.4,0,.2,1);
  border-radius: 0 2px 2px 0;
}
.faq-item.is-open::before {
  transform: scaleY(1);
}

/* Question button */
.faq-q {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 22px 20px 22px 24px;
  background: transparent;
  border: none;
  cursor: pointer;
  text-align: left;
  font-family: 'Poppins', sans-serif;
  font-size: clamp(.92rem, 1.4vw, 1.05rem);
  font-weight: 600;
  color: #1a2e1a;
  line-height: 1.4;
  transition: color .2s;
}
.faq-q:hover,
.faq-item.is-open .faq-q {
  color: #C94B2C;
}

/* Plus/minus icon */
.faq-icon {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 1.5px solid rgba(48,61,44,.25);
  flex-shrink: 0;
  position: relative;
  transition: border-color .25s, background .25s, transform .35s cubic-bezier(.4,0,.2,1);
}
.faq-icon::before,
.faq-icon::after {
  content: '';
  position: absolute;
  background: #303D2C;
  border-radius: 2px;
  transition: background .2s, transform .35s cubic-bezier(.4,0,.2,1), opacity .25s;
}
.faq-icon::before {
  width: 10px; height: 1.5px;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
}
.faq-icon::after {
  width: 1.5px; height: 10px;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
}
.faq-item.is-open .faq-icon {
  background: #C94B2C;
  border-color: #C94B2C;
  transform: rotate(45deg);
}
.faq-item.is-open .faq-icon::before,
.faq-item.is-open .faq-icon::after {
  background: #fff;
}

/* Answer panel */
/* Override [hidden] attribute — we control visibility via max-height animation */
.faq-a[hidden] { display: block !important; }
.faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height .45s cubic-bezier(.4,0,.2,1), padding .35s;
  padding: 0 24px 0 24px;
}
.faq-item.is-open .faq-a {
  max-height: 400px;
  padding: 0 24px 24px 24px;
}
.faq-a p {
  font-family: 'Inter', sans-serif;
  font-size: .97rem;
  font-weight: 400;
  color: #4b5563;
  line-height: 1.85;
  margin: 0;
}

/* Remove focus outline on FAQ buttons */
.faq-q:focus,
.faq-q:focus-visible {
  outline: none !important;
  box-shadow: none !important;
}

/* Hide FAQ eyebrow */
.faq-eyebrow {
  display: none !important;
}

@media (max-width: 640px) {
  .pricing-faq { padding: 64px 0 56px; }
  .faq-q { padding: 18px 16px 18px 16px; font-size: .9rem; }
  .faq-a { padding: 0 16px 0 16px; }
  .faq-item.is-open .faq-a { padding: 0 16px 20px 16px; }
  .faq-title { font-size: 1.6rem; }
}
