﻿/* ==========================================================================
   Pricing Page Styles
   ========================================================================== */

/* Keep pricing background blobs fixed across wide screens */
body.pricing-page::before {
  background-position:
    101% 132%,
    109% 293%,
    100% 210%,
    -45% 185%,
    -80% 42%,
    -80% 42%;
}

@media (min-width: 1800px) {
  body.pricing-page::before {
    background-position:
      101% 132%,
      109% 293%,
      100% 210%,
      -45% 185%,
      -80% 42%,
      -80% 42%;
  }
}

.pricing-main {
  padding: var(--spacing-2xl) 0 var(--spacing-xl);
}

.pricing-header {
  text-align: center;
  max-width: 800px;
  margin: 0 auto var(--spacing-xl);
}

.pricing-header h1 {
  font-size: 40px;
  margin-bottom: var(--spacing-sm);
  color: var(--text-dark);
}

.pricing-header p {
  font-size: 18px;
  color: var(--text-gray);
}

.billing-toggle-card {
  max-width: 760px;
  margin: 0 auto 28px;
  padding: 18px 20px;
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 12px 32px rgba(15, 23, 42, 0.08);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.billing-toggle-eyebrow {
  margin: 0 0 4px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-gray);
}

.billing-toggle-caption {
  margin: 0;
  font-size: 14px;
  line-height: 1.5;
  color: var(--text-dark);
}

.billing-toggle-control {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px;
  background: #f4f6fb;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  flex-wrap: wrap;
  justify-content: center;
}

.billing-toggle-option {
  min-width: 110px;
  padding: 10px 18px;
  border: none;
  border-radius: 999px;
  background: transparent;
  color: var(--text-gray);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.billing-toggle-option.is-active {
  background: #ffffff;
  color: var(--text-dark);
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.12);
}

.billing-toggle-option:focus-visible {
  outline: 2px solid var(--primary-orange);
  outline-offset: 2px;
}

.billing-save-badge {
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255, 79, 0, 0.12);
  color: var(--primary-orange);
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.billing-note {
  text-align: center;
  margin-top: var(--spacing-xs);
  font-size: 12px;
  line-height: 1.5;
  color: var(--text-gray);
}

/* Pricing Grid */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 1100px;
  margin: 0 auto;
}

.partner-cta {
  margin: 28px auto 0;
}

.partner-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  background: var(--bg-white);
  border-radius: 16px;
  padding: 20px 22px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12);
}

.partner-card h3 {
  font-size: 20px;
  margin: 6px 0 8px 0;
  color: var(--text-dark);
}

.partner-copy {
  font-size: 14px;
  color: var(--text-gray);
  margin: 0 0 10px 0;
  line-height: 1.5;
}

.partner-points {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;
}

.partner-points li {
  font-size: 13px;
  color: var(--text-dark);
  padding-left: 14px;
  position: relative;
}

.partner-points li::before {
  content: "•";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--primary-orange);
}

/* Pricing Card Enhancements */
.card-pricing {
  display: flex;
  flex-direction: column;
  position: relative;
  transition: transform var(--transition-normal), box-shadow var(--transition-normal);
  padding: 24px;
}

.card-pricing:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 55px rgba(0, 0, 0, 0.16);
}

.card-pricing.featured {
  border-width: 2px;
  box-shadow: 0 18px 55px rgba(0, 0, 0, 0.22);
}

.card-pricing.featured::before {
  content: attr(data-badge);
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--primary-orange);
  color: white;
  padding: 6px 18px;
  border-radius: 16px;
  font-size: 12px;
  font-weight: var(--weight-semibold);
  letter-spacing: 0.4px;
}

.pricing-tier {
  text-align: center;
  font-size: 18px;
  font-weight: var(--weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin-bottom: var(--spacing-xs);
}

.tier-free .pricing-tier {
  color: var(--accent-blue);
}

.tier-growth .pricing-tier {
  color: var(--accent-teal);
}

.tier-pro .pricing-tier {
  color: var(--primary-orange);
}

.pricing-price {
  align-self: center;
  display: flex;
  align-items: baseline;
  gap: 6px;
  margin-bottom: var(--spacing-sm);
}

.price-amount {
  font-size: 42px;
  font-weight: var(--weight-bold);
  font-family: var(--font-secondary);
  color: var(--text-dark);
  line-height: 1;
}

.price-currency {
  font-size: 16px;
  margin-right: 2px;
}

.price-period {
  font-size: 13px;
  color: var(--text-gray);
}

.price-billing-copy {
  margin: -6px 0 6px;
  text-align: center;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-gray);
  min-height: 18px;
}

.price-saving {
  margin: 0 0 12px;
  text-align: center;
  font-size: 12px;
  font-weight: 700;
  color: var(--primary-orange);
  min-height: 18px;
}

.price-saving.is-hidden {
  visibility: hidden;
}

.price-billing-copy--placeholder,
.price-saving--placeholder {
  visibility: hidden;
}

.pricing-description {
  font-size: 14px;
  color: var(--text-gray);
  margin-bottom: var(--spacing-sm);
}

.price-meta {
  font-size: 13px;
  color: var(--text-gray);
  margin-bottom: var(--spacing-md);
}

.pricing-features {
  list-style: none;
  margin-bottom: var(--spacing-md);
}

.pricing-features li {
  padding: 8px 0;
  font-size: 13px;
  color: var(--text-dark);
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.pricing-features li::before {
  content: "•";
  color: var(--primary-orange);
  font-weight: var(--weight-bold);
  font-size: 18px;
  line-height: 1;
}

.pricing-features li.disabled {
  color: var(--text-gray);
  opacity: 0.6;
}

.pricing-features li.disabled::before {
  color: var(--text-gray);
}

.pricing-cta {
  width: 100%;
  margin-top: auto;
}

/* FAQ Section */
.pricing-faq {
  max-width: 800px;
  margin: var(--spacing-xl) auto 0;
  padding: var(--spacing-2xl) var(--spacing-md);
}

.pricing-faq h2 {
  text-align: center;
  font-size: var(--text-3xl);
  margin-bottom: var(--spacing-xl);
  color: var(--text-dark);
}

.faq-item {
  margin-bottom: var(--spacing-md);
  padding: 18px 20px;
  background: white;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
}

.faq-question {
  width: 100%;
  text-align: left;
  background: transparent;
  border: none;
  font-size: 15px;
  font-weight: var(--weight-semibold);
  color: var(--text-dark);
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
}

.faq-question::after {
  content: '+';
  font-size: 18px;
  color: var(--text-gray);
  transition: transform var(--transition-normal);
}

.faq-question[aria-expanded="true"]::after {
  content: '–';
  transform: rotate(90deg);
}

.faq-answer {
  font-size: 14px;
  color: var(--text-gray);
  line-height: 1.6;
  margin-top: 10px;
}

/* Responsive */
@media (max-width: 1024px) {
  .billing-toggle-card {
    flex-direction: column;
    text-align: center;
  }

  .pricing-grid {
    grid-template-columns: 1fr;
    max-width: 520px;
    gap: 16px;
  }

  .partner-card {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 768px) {
  .billing-toggle-control {
    width: 100%;
  }

  .billing-toggle-option {
    min-width: 0;
    flex: 1 1 140px;
  }

  .pricing-header h1 {
    font-size: var(--text-3xl);
  }
  
  .price-amount {
    font-size: 40px;
  }
  
  body.pricing-page {
    padding: 0;
    margin: 0;
  }

  body.pricing-page .app-header {
    top: 0;
    margin-top: 0;
  }
}


/* =========================================
   PRICING — Botones con formato “Home Hero”
   (sin afectar otros sitios)
   ========================================= */

.pricing-main .btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;

  height: 52px;
  padding: 0 40px;
  border-radius: var(--radius-md);

  font-family: var(--font-primary);
  font-size: var(--text-xs);
  font-weight: var(--weight-normal);
  line-height: 1;

  text-decoration: none;
  border: none;
}

/* variantes */
.pricing-main .btn-primary,
.pricing-main .btn-action{
  background-color: var(--primary-orange);
  color: var(--text-black);
}

.pricing-main .btn-primary:hover,
.pricing-main .btn-action:hover{
  background-color: var(--primary-orange-alt);
  transform: translateY(-2px);
}

.pricing-main .btn-outline{
  background-color: transparent;
  color: var(--text-black);
  border: 1px solid var(--text-gray);
}

.pricing-main .btn-outline:hover{
  border-color: var(--primary-orange);
  color: var(--primary-orange);
}

/* el CTA dentro de pricing cards debe seguir full width */
.pricing-main .pricing-cta{
  width: 100%;
  padding: 0;              /* lo maneja el .btn */
}

.pricing-main .pricing-cta.btn{
  width: 100%;
}

/* móvil */
@media (max-width: 768px){
  .pricing-main .btn{
    height: 48px;
    padding: 0 30px;
    font-size: 16px;
  }
}

/* PRICING — Botones (scope solo al contenido de pricing) */
.pricing-main .btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 52px;
  padding: 0 40px;
  border-radius: var(--radius-md);
  font-family: var(--font-primary);
  font-size: var(--text-xs);
  font-weight: var(--weight-normal);
  line-height: 1;
  text-decoration: none;
  border: none;
}

.pricing-main .btn-primary,
.pricing-main .btn-action{
  background-color: var(--primary-orange);
  color: var(--text-black);
}

.pricing-main .btn-outline{
  background-color: transparent;
  color: var(--text-black);
  border: 1px solid var(--text-gray);
}

@media (max-width: 768px){
  .pricing-main .btn{
    height: 48px;
    padding: 0 30px;
    font-size: 16px;
  }
}

/* =========================
   PRICING — Partner card polish
   ========================= */

.partner-card{
  border-radius: var(--radius-md);
  padding: 26px 28px;
}

.partner-card .eyebrow{
  font-size: 12px;
  font-weight: var(--weight-semibold);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-gray);
  margin: 0 0 10px 0;
}

.partner-card h3{
  font-size: 22px;
  line-height: 1.2;
  margin: 0 0 10px 0;
}

.partner-copy{
  font-size: 15px;
  line-height: 1.6;
  margin: 0 0 14px 0;
  max-width: 64ch;
}

/* pills */
.partner-tags{
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}



.partner-tags li{
  display: inline-flex;
  align-items: center;
  gap: 10px;

  padding: 8px 14px;
  border-radius: 999px;

  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.10);
  box-shadow: 0 10px 24px rgba(0,0,0,0.06);

  font-size: 13px;
  font-weight: var(--weight-medium);
  color: var(--text-dark);
}

.partner-tags li{
  display: inline-flex;
  align-items: center;     
  gap: 10px;
}


.partner-tags li::before{
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--primary-orange);
  flex: 0 0 7px;

  position: relative;
  top: 0;                  /* por si algo lo empuja */
  transform: translateY(0);
}

/* =========================================================
   PRICING — Trustworthy / “not sketchy” typography polish
   Scope: ONLY pricing page
   Paste at the END of css/pages/pricing.css
   ========================================================= */

body.pricing-page{
  color: var(--text-dark-gray);
}

/* ---------- Header block ---------- */
body.pricing-page .pricing-header h1{
  /* stronger, confident headline */
  font-size: clamp(36px, 3vw, 44px);
  line-height: 1.1;
  font-weight: var(--weight-bold);
  letter-spacing: 0;
  color: var(--text-dark-gray);
  margin-bottom: 14px;
}

body.pricing-page .pricing-header p{
  /* calmer supporting text */
  font-size: clamp(16px, 1.1vw, 18px);
  line-height: 1.65;
  color: var(--text-charcoal);
  max-width: 760px;
  margin: 0 auto;
}

/* ---------- Pricing cards: overall text rhythm ---------- */
body.pricing-page .card-pricing{
  border-radius: 18px;
}

body.pricing-page .pricing-tier{
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.14em;          /* more “serious SaaS” */
  text-transform: uppercase;
  margin-bottom: 10px;
}

body.pricing-page .pricing-description{
  font-size: 15px;                 /* +1px for trust/readability */
  line-height: 1.6;
  color: var(--text-charcoal);
}

body.pricing-page .price-meta{
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-gray);
}

/* Price block: align currency nicely, reduce “shout” */
body.pricing-page .pricing-price{
  gap: 8px;
  margin-bottom: 14px;
}

body.pricing-page .price-currency{
  font-size: 16px;
  color: var(--text-gray);
  margin-right: 0;
  transform: translateY(4px); /* optical alignment with large number */
}

body.pricing-page .price-amount{
  font-size: 44px;                 /* slightly more consistent */
  font-weight: 700;
  letter-spacing: -0.02em;         /* looks more premium */
  color: var(--text-dark-gray);
}

body.pricing-page .price-period{
  font-size: 13px;
  color: var(--text-gray);
  transform: translateY(4px);
}

/* “Highlights” label */
body.pricing-page .card-pricing .highlights-title,
body.pricing-page .card-pricing > .highlights-title{
  font-size: 16px;
  font-weight: 600;
  color: var(--text-dark-gray);
}

body.pricing-page .card-pricing ul.pricing-features{
  margin-top: 10px;
}

/* Feature list: bigger, clearer, more trustworthy */
body.pricing-page .pricing-features li{
  font-size: 14px;                 /* was 13px */
  line-height: 1.6;
  color: var(--text-dark-gray);
  padding: 9px 0;
  gap: 10px;
}

body.pricing-page .pricing-features li::before{
  font-size: 16px;                 /* less “toy-ish” */
  line-height: 1;
  transform: translateY(2px);
  color: var(--primary-orange);
}

/* Disabled features: still readable but clearly disabled */
body.pricing-page .pricing-features li.disabled{
  opacity: 0.55;
}

/* Featured badge: more “product” less “gimmick” */
body.pricing-page .card-pricing.featured::before{
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  border-radius: 999px;
  padding: 7px 16px;
}

/* ---------- Partner CTA (the highlighted card) ---------- */
body.pricing-page .partner-card{
  border-radius: 18px;
  padding: 22px 24px;
  box-shadow: 0 14px 40px rgba(0,0,0,0.12);
}

body.pricing-page .partner-card .eyebrow{
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-gray);
  margin-bottom: 8px;
}

body.pricing-page .partner-card h3{
  font-size: 22px;
  line-height: 1.2;
  font-weight: 700;
  margin: 0 0 10px;
  color: var(--text-dark-gray);
}

body.pricing-page .partner-copy{
  font-size: 15px;
  line-height: 1.65;
  color: var(--text-charcoal);
  margin-bottom: 14px;
}

/* --- Pills: make them look like “real UI”, and fix orange dot alignment --- */
body.pricing-page .partner-points{
  gap: 10px;
}

body.pricing-page .partner-points li{
  /* turn bullets into pills */
  padding: 8px 12px 8px 12px;
  border: 1px solid rgba(15, 23, 42, 0.10);
  border-radius: 999px;
  background: #fff;
  font-size: 13px;
  color: var(--text-dark-gray);

  /* IMPORTANT: align dot + text cleanly */
  display: inline-flex;
  align-items: center;
  gap: 8px;
  position: relative;
  padding-left: 12px; /* no extra left padding needed for absolute dot */
}

/* Replace the previous absolute bullet with a clean centered dot */
body.pricing-page .partner-points li::before{
  position: static;              /* <— fixes the “misplaced orange dots” */
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--primary-orange);
  flex: 0 0 6px;
  transform: none;
}

/* Optional: hover feels more polished (still subtle / trustworthy) */
body.pricing-page .partner-points li:hover{
  border-color: rgba(15, 23, 42, 0.18);
  box-shadow: 0 6px 18px rgba(0,0,0,0.06);
}

/* Button in partner card: a bit more “CTA but calm” */
body.pricing-page .partner-card .btn{
  height: 48px;
  padding: 0 28px;
  font-weight: 600;
}

/* ---------- Responsive polish ---------- */
@media (max-width: 768px){
  body.pricing-page .pricing-header h1{
    font-size: clamp(32px, 7vw, 38px);
  }

  body.pricing-page .partner-card{
    padding: 18px 18px;
  }
}
/* PRICING — Highlights: keep each bullet on one line (desktop) */
@media (min-width: 1024px){
  .pricing-page .pricing-features li{
    white-space: nowrap;
  }
}

/* Pricing comparison table: mobile viewport-safe layout */
@media (max-width: 768px){
  body.pricing-page .pricing-main .container{
    max-width: 100%;
    overflow-x: hidden;
  }

  body.pricing-page .pricing-comparison{
    width: 100%;
    max-width: 100%;
    margin-top: 32px;
    padding: 22px 10px 18px;
    overflow: hidden;
    border-radius: 14px;
  }

  body.pricing-page .comparison-header{
    margin-bottom: 16px;
    padding: 0 6px;
  }

  body.pricing-page .comparison-header h2{
    font-size: clamp(24px, 7vw, 30px);
    line-height: 1.15;
  }

  body.pricing-page .comparison-header p{
    font-size: 14px;
    line-height: 1.5;
  }

  body.pricing-page .comparison-table-wrapper{
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    padding-bottom: 8px;
  }

  body.pricing-page .comparison-table{
    width: 100% !important;
    min-width: 0 !important;
    table-layout: fixed;
  }

  body.pricing-page .comparison-table th,
  body.pricing-page .comparison-table td{
    padding: 9px 5px;
    font-size: 12px;
    line-height: 1.35;
    overflow-wrap: anywhere;
    word-break: normal;
    hyphens: auto;
  }

  body.pricing-page .comparison-table .feature-col,
  body.pricing-page .comparison-table td:first-child{
    width: 40% !important;
  }

  body.pricing-page .comparison-table th:not(.feature-col),
  body.pricing-page .comparison-table td:not(:first-child){
    width: 20% !important;
  }

  body.pricing-page .plan-title{
    font-size: 12px;
    line-height: 1.2;
    margin-bottom: 4px;
  }

  body.pricing-page .plan-price{
    font-size: 15px;
    line-height: 1.1;
  }

  body.pricing-page .plan-period{
    display: block;
    font-size: 10px;
    line-height: 1.2;
    margin-top: 2px;
  }

  body.pricing-page .feature-label,
  body.pricing-page .feature-quantity{
    font-size: 12px;
    line-height: 1.35;
  }

  body.pricing-page .feature-icon{
    width: 22px;
    height: 22px;
    font-size: 11px;
  }

  body.pricing-page .section-toggle{
    padding: 11px 12px;
    font-size: 14px;
    border-radius: 8px;
  }
}

@media (max-width: 390px){
  body.pricing-page .pricing-comparison{
    padding-left: 6px;
    padding-right: 6px;
  }

  body.pricing-page .comparison-table th,
  body.pricing-page .comparison-table td{
    padding-left: 3px;
    padding-right: 3px;
    font-size: 11px;
  }

  body.pricing-page .feature-label,
  body.pricing-page .feature-quantity{
    font-size: 11px;
  }
}


