/**
 * Product Group Styles - Holy Trinity Pricing Layout
 * Modern pricing cards with centered 3-column layout
 */

/* =========================================================================
   CSS VARIABLES & BASE
   ========================================================================= */
.product-group-page,
.pg-pricing-shortcode {
  --pg-bg-color: #f8f9fa;
  --pg-accent-color: #52c5ff;
  --pg-text-color: #333333;
  --pg-card-bg: #ffffff;
  --pg-border-radius: 12px;
  --pg-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  --pg-shadow-hover: 0 8px 30px rgba(0, 0, 0, 0.12);
  --pg-transition: all 0.3s ease;
  --pg-content-width: 1200px;
}

.product-group-page {
  /* Article is full width */
  width: 100%;
  max-width: none;
}

/* Shortcode wrapper - inherits variables and provides proper container */
.pg-pricing-shortcode {
  padding: 40px 0;
}

/* Override theme's content container restrictions for product group pages */
.rd_product_group .site-content,
.rd_product_group .entry-content,
.rd_product_group #content,
.rd_product_group .container,
.single-rd_product_group .site-content,
.single-rd_product_group .entry-content,
.single-rd_product_group #content,
.single-rd_product_group .container {
  max-width: none;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

/* =========================================================================
   HERO SECTION (Matching single product style)
   ========================================================================= */
.pg-hero {
  background: #ffffff;
  padding: 40px 20px 60px;
}

.pg-hero__container {
  max-width: var(--pg-content-width);
  margin: 0 auto;
}

/* Two-column grid with image */
.pg-hero__grid--with-image {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: center;
}

/* Full-width text only */
.pg-hero__grid--text-only {
  display: block;
}

.pg-hero__content {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.pg-hero__content--centered {
  text-align: center;
  max-width: 900px;
  margin: 0 auto;
}

.pg-hero__headline {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  color: var(--pg-text-color);
  margin: 0;
  line-height: 1.2;
}

.pg-hero__subheadline {
  font-size: clamp(1.1rem, 2vw, 1.3rem);
  color: #555;
  margin: 0;
  line-height: 1.6;
}

.pg-hero__image {
  display: flex;
  justify-content: center;
  align-items: center;
}

.pg-hero__image img {
  max-width: 100%;
  height: auto;
  border-radius: var(--pg-border-radius);
  box-shadow: var(--pg-shadow);
}

/* =========================================================================
   PRICING SECTION - HOLY TRINITY (Full width, no restriction)
   ========================================================================= */
.pg-pricing {
  background-color: var(--pg-bg-color);
  padding: 60px 20px 80px;
}

.pg-pricing__container {
  max-width: 1800px;
  margin: 0 auto;
  padding: 0 20px;
}

.pg-pricing__cards {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}

/* Card with custom accent color */
.pg-pricing__card[style*="--card-accent"] {
  border-color: var(--card-accent);
}

.pg-pricing__card[style*="--card-accent"] .pg-pricing__title {
  color: var(--card-accent);
}

.pg-pricing__card[style*="--card-accent"] .pg-pricing__cta {
  background: var(--card-accent);
}

.pg-pricing__card[style*="--card-accent"] .pg-pricing__badge {
  background: var(--card-accent);
}

.pg-pricing__card[style*="--card-accent"] .pg-pricing__perk-icon {
  color: var(--card-accent);
}

.pg-pricing__card[style*="--card-accent"] .pg-pricing__feature-check {
  color: var(--card-accent);
}

/* Hide cards on mobile when flagged */
.pg-pricing__card--hide-mobile {
  display: flex;
}

@media (max-width: 768px) {
  .pg-pricing__card--hide-mobile {
    display: none;
  }
}

/* Individual Card */
.pg-pricing__card {
  background: var(--pg-card-bg);
  border-radius: var(--pg-border-radius);
  box-shadow: var(--pg-shadow);
  padding: 32px 28px;
  flex: 0 0 auto; /* Don't grow or shrink */
  width: 340px; /* Fixed width */
  max-width: calc(100% - 20px); /* Responsive on very small screens */
  position: relative;
  transition: var(--pg-transition);
  display: flex;
  flex-direction: column;
}

.pg-pricing__card:hover {
  box-shadow: var(--pg-shadow-hover);
  transform: translateY(-4px);
}

/* Featured Card - sticks out with extra padding */
.pg-pricing__card--featured {
  border: 2px solid var(--pg-accent-color);
  padding-top: 48px;
  padding-bottom: 48px;
  margin-top: -16px; /* Offset to make it stick out at top */
  z-index: 1;
}

.pg-pricing__card--featured:hover {
  transform: translateY(-8px);
}

/* Featured Badge */
.pg-pricing__badge {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--pg-accent-color);
  color: #fff;
  font-size: 0.85rem;
  font-weight: 600;
  padding: 6px 20px;
  border-radius: 20px;
  white-space: nowrap;
}

/* Current Card (we're on this product's sales page) */
.pg-pricing__card--current {
  border: 3px solid var(--pg-accent-color);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
}

.pg-pricing__badge--current {
  background: #28a745;
}

/* Inactive Card (Coming Soon) */
.pg-pricing__card--inactive {
  opacity: 0.6;
  filter: grayscale(40%);
}

.pg-pricing__card--inactive:hover {
  transform: none;
  box-shadow: var(--pg-shadow);
}

.pg-pricing__coming-soon-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: rgba(0, 0, 0, 0.85);
  color: #fff;
  padding: 12px 24px;
  border-radius: 8px;
  font-weight: 600;
  z-index: 10;
  white-space: nowrap;
}

/* Card Content */
.pg-pricing__card-content {
  display: flex;
  flex-direction: column;
  /* Don't force flex: 1 - let content determine height */
}

.pg-pricing__title {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--pg-text-color);
  margin: 0 0 16px;
  text-align: left;
}

/* Featured card title uses accent color */
.pg-pricing__card--featured .pg-pricing__title {
  color: var(--pg-accent-color);
}

/* Price Block */
.pg-pricing__price-block {
  margin-bottom: 24px;
}

.pg-pricing__price-line {
  display: flex;
  align-items: baseline;
  gap: 4px;
  flex-wrap: wrap;
}

.pg-pricing__price {
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--pg-text-color);
  line-height: 1;
}

.pg-pricing__price-suffix {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--pg-text-color);
}

.pg-pricing__original-price {
  font-size: 1.3rem;
  color: #999;
  text-decoration: line-through;
  margin-right: 8px;
}

.pg-pricing__price--promo {
  color: #ff4757;
}

.pg-pricing__billing-cycle {
  display: block;
  font-size: 0.85rem;
  color: #888;
  margin-top: 6px;
}

.pg-pricing__price-note {
  display: block;
  font-size: 0.85rem;
  color: #666;
  margin-top: 4px;
  font-style: italic;
}

/* CTA Button */
.pg-pricing__cta {
  display: block;
  width: 100%;
  padding: 14px 24px;
  background: var(--pg-accent-color);
  color: #fff;
  font-size: 1rem;
  font-weight: 600;
  text-align: center;
  text-decoration: none;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  transition: var(--pg-transition);
  margin-bottom: 16px;
}

.pg-pricing__cta:hover {
  filter: brightness(1.1);
  transform: translateY(-2px);
}

.pg-pricing__cta--disabled {
  background: #ccc;
  cursor: not-allowed;
  pointer-events: none;
}

/* Secondary Link */
.pg-pricing__secondary-link {
  text-align: center;
  font-size: 0.9rem;
  color: #666;
  margin-bottom: 20px;
}

.pg-pricing__secondary-link a {
  color: var(--pg-accent-color);
  text-decoration: underline;
}

/* Perks */
.pg-pricing__perks {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #eee;
}

.pg-pricing__perk {
  display: flex;
  align-items: flex-start; /* Align icon and text at top */
  gap: 10px;
  font-size: 0.95rem;
  color: #555;
  text-align: left;
}

.pg-pricing__perk-icon {
  font-size: 1rem;
  color: var(--pg-accent-color);
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  min-height: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 2px; /* Slight offset to align with first line of text */
}

.pg-pricing__perk-text {
  flex: 1;
  text-align: left;
}

/* Icon variants */
.pg-pricing__perk-icon--check::before {
  content: "✓";
  font-weight: 700;
}

.pg-pricing__perk-icon--plus::before {
  content: "+";
  font-weight: 700;
  font-size: 1.2rem;
}

.pg-pricing__perk-icon--arrow::before {
  content: "→";
}

.pg-pricing__perk-icon--dot::before {
  content: "•";
  font-size: 1.4rem;
}

.pg-pricing__perk-icon--star::before {
  content: "★";
  font-size: 0.9rem;
}

/* Highlighted/new perk styling */
.pg-pricing__perk--highlighted {
  background: linear-gradient(
    90deg,
    rgba(82, 197, 255, 0.15) 0%,
    transparent 100%
  );
  padding: 8px 12px;
  margin: -4px -12px;
  border-radius: 6px;
  font-weight: 500;
}

.pg-pricing__perk-badge {
  background: #e3f4ff;
  color: #0077b6;
  font-size: 0.65rem;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Coming soon perk styling */
.pg-pricing__perk--coming-soon {
  opacity: 0.6;
}

.pg-pricing__perk-coming-soon {
  background: #f5f5f5;
  color: #888;
  font-size: 0.65rem;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 4px;
  font-style: italic;
}

/* Promotion badge on card */
.pg-pricing__promo-badge {
  position: absolute;
  top: -12px;
  right: 16px;
  background: linear-gradient(135deg, #ff6b6b 0%, #ff4757 100%);
  color: #fff;
  font-size: 0.75rem;
  font-weight: 700;
  padding: 5px 12px;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(255, 71, 87, 0.4);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  z-index: 2;
}

/* Original price strikethrough */
.pg-pricing__original-price {
  font-size: 1.2rem;
  color: #999;
  text-decoration: line-through;
  margin-right: 8px;
}

/* Promo price styling */
.pg-pricing__price--promo {
  color: #ff4757;
}

/* Key Features */
.pg-pricing__features {
  /* Don't use flex: 1 - let it size naturally */
}

.pg-pricing__features-label {
  font-size: 0.85rem;
  font-weight: 600;
  color: #888;
  margin-bottom: 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.pg-pricing__features-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.pg-pricing__feature {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.95rem;
  color: var(--pg-text-color);
  line-height: 1.4;
}

/* Highlighted/new feature styling */
.pg-pricing__feature--new {
  background: linear-gradient(
    90deg,
    rgba(46, 125, 50, 0.08) 0%,
    transparent 100%
  );
  padding: 6px 10px;
  margin: -3px -10px;
  border-radius: 6px;
}

.pg-pricing__feature-check {
  width: 18px;
  height: 18px;
  color: var(--pg-accent-color);
  flex-shrink: 0;
  margin-top: 2px;
}

.pg-pricing__feature-new {
  background: #e8f5e9;
  color: #2e7d32;
  font-size: 0.7rem;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 4px;
  margin-left: 6px;
}

/* More Details Text */
.pg-pricing__more-details {
  text-align: center;
  color: #666;
  font-size: 1rem;
  margin-top: 40px;
}

/* Conditions Compact (under pricing cards) */
.pg-pricing__conditions-compact {
  text-align: center;
  color: #888;
  font-size: 0.85rem;
  line-height: 1.6;
  margin-top: 20px;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}

/* =========================================================================
   GENERIC SECTION STYLES
   ========================================================================= */
.pg-section {
  padding: 80px 20px;
}

.pg-section:nth-child(even) {
  background-color: #f8f9fa;
}

.pg-section__container {
  max-width: var(--pg-content-width);
  margin: 0 auto;
  padding: 0 20px;
}

.pg-section__title {
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 700;
  color: var(--pg-text-color);
  text-align: center;
  margin: 0 0 20px;
}

.pg-section__description {
  font-size: 1.1rem;
  color: #555;
  text-align: center;
  max-width: 700px;
  margin: 0 auto 40px;
  line-height: 1.7;
}

/* =========================================================================
   WHAT'S INSIDE SECTION (uses Svelte carousel from whats-inside-section.css)
   ========================================================================= */
.pg-whats-inside {
  background-color: #fff;
}

/* Allow space for card shadows */
.pg-whats-inside .pg-section__container {
  overflow: visible;
}

.pg-whats-inside .rd-carousel {
  overflow: visible;
  padding: 10px 0 20px; /* Space for shadows */
}

/* Ensure What's Inside cards have drop shadow */
.pg-whats-inside .rd-whats-inside-card {
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

.pg-whats-inside .rd-whats-inside-card:hover {
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
}

/* =========================================================================
   AT A GLANCE SECTION
   ========================================================================= */
.pg-at-glance__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 24px;
}

.pg-at-glance__item {
  display: flex;
  align-items: center;
  gap: 16px;
  background: var(--pg-card-bg);
  padding: 20px;
  border-radius: var(--pg-border-radius);
  box-shadow: var(--pg-shadow);
}

.pg-at-glance__icon {
  font-size: 2rem;
}

.pg-at-glance__text {
  display: flex;
  flex-direction: column;
}

.pg-at-glance__label {
  font-size: 0.9rem;
  color: #666;
}

.pg-at-glance__value {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--pg-text-color);
}

/* =========================================================================
   FEATURES SECTION
   ========================================================================= */
.pg-features__layout {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.pg-features__layout--with-image {
  flex-direction: row;
  align-items: center;
}

.pg-features__content {
  flex: 1;
}

.pg-features__layout--with-image .pg-section__title,
.pg-features__layout--with-image .pg-section__description {
  text-align: left;
  margin-left: 0;
}

.pg-features__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.pg-features__item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 1.05rem;
  color: var(--pg-text-color);
}

.pg-features__item-icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.pg-features__image {
  flex: 1;
  max-width: 450px;
}

.pg-features__image img {
  width: 100%;
  border-radius: var(--pg-border-radius);
  box-shadow: var(--pg-shadow);
}

/* =========================================================================
   PROBLEM & SOLUTION SECTION
   ========================================================================= */
.pg-problem-solution__layout {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.pg-problem-solution__pairs {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.pg-problem-solution__pair {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 20px;
  align-items: center;
  background: var(--pg-card-bg);
  padding: 24px;
  border-radius: var(--pg-border-radius);
  box-shadow: var(--pg-shadow);
}

.pg-problem-solution__problem,
.pg-problem-solution__solution {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.pg-problem-solution__icon {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  font-weight: bold;
  flex-shrink: 0;
}

.pg-problem-solution__icon--problem {
  background: #ffebee;
  color: #c62828;
}

.pg-problem-solution__icon--solution {
  background: #e8f5e9;
  color: #2e7d32;
}

.pg-problem-solution__problem p,
.pg-problem-solution__solution p {
  margin: 0;
  font-size: 1rem;
  line-height: 1.5;
}

.pg-problem-solution__arrow {
  color: #999;
  font-size: 1.5rem;
}

.pg-problem-solution__image img {
  width: 100%;
  max-width: 500px;
  border-radius: var(--pg-border-radius);
  margin: 0 auto;
  display: block;
}

.pg-problem-solution__story {
  font-size: 1.05rem;
  color: #555;
  line-height: 1.8;
  max-width: 800px;
  margin: 0 auto;
}

/* =========================================================================
   WHO IT'S FOR SECTION
   ========================================================================= */
.pg-who-its-for__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 30px;
  margin-top: 40px;
}

.pg-who-its-for__card {
  background: var(--pg-card-bg);
  border-radius: var(--pg-border-radius);
  box-shadow: var(--pg-shadow);
  overflow: hidden;
  text-align: center;
  transition: var(--pg-transition);
}

.pg-who-its-for__card:hover {
  transform: translateY(-4px);
  box-shadow: var(--pg-shadow-hover);
}

.pg-who-its-for__card-image {
  height: 180px;
  overflow: hidden;
}

.pg-who-its-for__card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pg-who-its-for__card-title {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--pg-text-color);
  margin: 20px 20px 10px;
}

.pg-who-its-for__card-desc {
  font-size: 0.95rem;
  color: #666;
  margin: 0 20px 20px;
  line-height: 1.5;
}

/* =========================================================================
   FORMAT SECTION
   ========================================================================= */
.pg-format__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 20px;
}

.pg-format__item {
  background: var(--pg-card-bg);
  padding: 24px;
  border-radius: var(--pg-border-radius);
  box-shadow: var(--pg-shadow);
  text-align: center;
}

.pg-format__icon {
  font-size: 2.5rem;
  display: block;
  margin-bottom: 12px;
}

.pg-format__label {
  font-size: 0.9rem;
  color: #666;
  display: block;
}

.pg-format__value {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--pg-text-color);
  display: block;
  margin-top: 4px;
}

/* =========================================================================
   AUTHORS SECTION
   ========================================================================= */
.pg-authors__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 30px;
}

.pg-authors__card {
  background: var(--pg-card-bg);
  border-radius: var(--pg-border-radius);
  box-shadow: var(--pg-shadow);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.pg-authors__card-image {
  height: 250px;
  overflow: hidden;
}

.pg-authors__card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pg-authors__card-content {
  padding: 24px;
}

.pg-authors__card-name {
  font-size: 1.3rem;
  font-weight: 600;
  color: var(--pg-text-color);
  margin: 0 0 4px;
}

.pg-authors__card-role {
  font-size: 0.95rem;
  color: var(--pg-accent-color);
  margin: 0 0 12px;
  font-weight: 500;
}

.pg-authors__card-bio {
  font-size: 0.95rem;
  color: #666;
  margin: 0;
  line-height: 1.6;
}

/* =========================================================================
   TESTIMONIALS SECTION
   ========================================================================= */
.pg-testimonials__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 30px;
}

.pg-testimonials__card {
  background: var(--pg-card-bg);
  border-radius: var(--pg-border-radius);
  box-shadow: var(--pg-shadow);
  padding: 30px;
}

.pg-testimonials__rating {
  margin-bottom: 16px;
}

.pg-testimonials__star {
  color: #ddd;
  font-size: 1.2rem;
}

.pg-testimonials__star--filled {
  color: #ffc107;
}

.pg-testimonials__quote {
  font-size: 1.05rem;
  color: var(--pg-text-color);
  line-height: 1.7;
  margin: 0 0 24px;
  font-style: italic;
}

.pg-testimonials__author {
  display: flex;
  align-items: center;
  gap: 14px;
}

.pg-testimonials__author-image {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  object-fit: cover;
}

.pg-testimonials__author-info {
  display: flex;
  flex-direction: column;
}

.pg-testimonials__author-name {
  font-weight: 600;
  color: var(--pg-text-color);
}

.pg-testimonials__author-title {
  font-size: 0.9rem;
  color: #666;
}

/* =========================================================================
   FINAL CTA SECTION
   ========================================================================= */
.pg-final-cta {
  background: linear-gradient(135deg, var(--pg-accent-color) 0%, #00a3a6 100%);
  text-align: center;
  color: #fff;
}

.pg-final-cta__headline {
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 700;
  margin: 0 0 16px;
}

.pg-final-cta__subheadline {
  font-size: 1.15rem;
  opacity: 0.9;
  margin: 0 0 30px;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.pg-final-cta__button {
  display: inline-block;
  background: #fff;
  color: var(--pg-accent-color);
  font-size: 1.1rem;
  font-weight: 600;
  padding: 16px 40px;
  border-radius: 8px;
  text-decoration: none;
  transition: var(--pg-transition);
}

.pg-final-cta__button:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.2);
}

/* =========================================================================
   ICON CLASSES (matching product CPT)
   ========================================================================= */
.icon-check-blue::before {
  content: "✓";
  color: #52c5ff;
}
.icon-check-green::before {
  content: "✓";
  color: #4caf50;
}
.icon-heart-red::before {
  content: "♥";
  color: #e53935;
}
.icon-plus-purple::before {
  content: "+";
  color: #9c27b0;
}
.icon-alert-orange::before {
  content: "!";
  color: #ff9800;
}
.icon-person::before {
  content: "👤";
}
.icon-people::before {
  content: "👥";
}
.icon-search::before {
  content: "🔍";
}

/* =========================================================================
   RESPONSIVE STYLES
   ========================================================================= */
@media (max-width: 1024px) {
  .pg-hero__grid--with-image {
    grid-template-columns: 1fr;
    gap: 30px;
  }

  .pg-hero__image {
    order: -1; /* Image on top on mobile */
  }

  /* Center cards when they wrap on tablet */
  .pg-pricing__card--featured {
    margin-top: 0;
    order: -1; /* Featured first on tablet/mobile */
  }

  .pg-pricing__card--featured:hover {
    transform: translateY(-4px);
  }

  .pg-features__layout--with-image {
    flex-direction: column;
  }

  .pg-features__image {
    max-width: 100%;
  }

  .pg-problem-solution__pair {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .pg-problem-solution__arrow {
    transform: rotate(90deg);
    justify-self: center;
  }
}

@media (max-width: 768px) {
  .pg-hero {
    padding: 30px 20px 40px;
  }

  .pg-section {
    padding: 60px 20px;
  }

  .pg-pricing {
    padding: 40px 20px 60px;
  }

  .pg-pricing__card {
    padding: 24px 20px;
    width: 100%;
    max-width: 400px;
  }

  .pg-pricing__card--featured {
    padding-top: 36px;
    padding-bottom: 36px;
  }

  .pg-at-glance__grid,
  .pg-format__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .pg-who-its-for__grid,
  .pg-authors__grid,
  .pg-testimonials__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .pg-at-glance__grid,
  .pg-format__grid {
    grid-template-columns: 1fr;
  }

  .pg-pricing__price {
    font-size: 2rem;
  }
}

/* =========================================================================
   CONDITIONS LONG (Fine Print at bottom of page)
   ========================================================================= */
.pg-conditions-long {
  background-color: #f5f5f5;
  padding: 40px 20px;
  border-top: 1px solid #e0e0e0;
}

.pg-conditions-long__container {
  max-width: 900px;
  margin: 0 auto;
  font-size: 0.75rem;
  color: #666;
  line-height: 1.7;
}

.pg-conditions-long__container p {
  margin: 0 0 12px;
}

.pg-conditions-long__container p:last-child {
  margin-bottom: 0;
}

.pg-conditions-long__container a {
  color: #555;
  text-decoration: underline;
}

.pg-conditions-long__container a:hover {
  color: var(--pg-accent-color);
}

.pg-conditions-long__container ul,
.pg-conditions-long__container ol {
  margin: 0 0 12px;
  padding-left: 20px;
}

.pg-conditions-long__container li {
  margin-bottom: 4px;
}
