.websites-section {
  color: var(--websites-text);
  display: flex;
  flex-direction: column;
  gap: var(--gap-12);
  flex: 1;
  padding-block: 0; /* es un override */
}

.websites-title {
  line-height: 1.3;
  letter-spacing: 0.5px;
  color: var(--websites-text);
  text-align: center;
  margin-top: var(--mg-8);
  margin-bottom: 0;
}

.websites-subtitle {
  color: var(--websites-text);
  text-align: center;
  margin-top: var(--mg-8);
  margin-bottom: var(--mg-12);
  font-size: var(--font-24);
  font-weight: 400;
}

.websites-container {
  width: 100%;
  max-width: 1100px;
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: left;
}

.websites-container h2 {
  color: var(--websites-text);
}

.websites-container ul {
  margin-left: var(--mg-24);
  color: var(--websites-text);
}

.websites-container ol {
  margin-left: var(--mg-24);
  color: var(--websites-text);
}

.bullet-section {
  background: transparent;
  padding-block: 0;
}

.bullet-section h2 {
  margin-top: 0;
  margin-bottom: 0;
}

.bullet-rows {
  display: grid;
  gap: var(--gap-12);
}

/* (Opcional) compactar un poco la altura de cada fila interna */
.bullet-rows .web-row {
  padding-block: var(--pad-24);
}

.bullet-title {
  color: var(--websites-text);
  font-size: var(--font-20);
  margin-bottom: var(--mg-24);
}

.bullet-web-list {
  margin-left: var(--mg-24);
  color: var(--websites-text);
  font-size: var(--font-20);
}
.bullet-web-list a {
  color: var(--websites-a);
  font-weight: 600;
}

/* --- Layout alternado texto/media --- */
.web-row {
  display: grid;
  background-color: var(--websites-row);
  background-image: none; /* es un override */
  grid-template-columns: 1fr;
  align-items: center;
  gap: var(--gap-12);
  padding-block: var(--pad-24);
  padding-inline: var(--pad-24);
  border-radius: var(--radius-12);
}

.web-col-text {
  width: 100%;
  padding-inline: var(--pad-16);
  font-size: var(--font-24);
}

.web-col-text h2 {
  margin-top: 0;
}

.web-col-text-small {
  width: 100%;
  padding-inline: var(--pad-16);
  font-size: var(--font-16);
}

.web-col-text-small h2 {
  margin-top: 0;
}

.web-col-media {
  width: 100%;
  padding-inline: var(--pad-8);
}

.web-media-placeholder {
  width: 100%;
  aspect-ratio: 1.5;
  border-radius: var(--radius-12);
  border: 1px dashed var(--overlay-3);
  background:
    radial-gradient(100% 100% at 0% 0%, rgba(255,255,255,.45), rgba(255,255,255,.1)),
    var(--snow-white, linear-gradient(135deg,#0ea5e9 0%, #22d3ee 100%));
  display: grid;
  place-items: center;
  color: var(--bg, #0b1220);
  font-weight: 600;
  letter-spacing: .2px;
  box-shadow: 0 6px 20px rgba(0,0,0,.08);
}

/* Imagen dentro del slot de media */
.web-media-img {
  width: 64%;
  height: auto;
  display: block;
  object-fit: contain;
}

.web-media-img-big {
  width: 80%;
  height: auto;
  display: block;
  object-fit: contain;
}

/* Cuando ya uses imagen real, quita el fondo y el borde del placeholder */
.web-col-media.has-image .web-media-placeholder {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0; /* opcional */
}

/* Opcional: marco sutil por accesibilidad en fondos claros/oscuros */
.web-col-media.has-image .web-media-frame {
  border-radius: var(--radius-12);
  outline: 1px solid rgba(0,0,0,.06);
}

/* --- Listas y notas --- */
.web-list { margin-left: var(--mg-24); }
.web-steps { margin-left: var(--mg-24); counter-reset: step; }
.web-steps li { margin-bottom: var(--mg-6); }

.web-note {
  margin-top: var(--mg-12);
  margin-bottom: var(--mg-24);
  font-size: var(--font-14);
  color: var(--websites-text);
}

.web-note a {
  color: var(--websites-a);
  font-weight: 600;
}

.plan-note {
  color: var(--websites-text);
  font-size: var(--font-18);
  font-weight: 600;
}

.web-plans-notes {
  margin-top: var(--mg-12);
  margin-bottom: var(--mg-24);
  margin-left: var(--mg-24);
  font-size: var(--font-14);
  color: var(--websites-text);
  align-self: flex-start;
}

.web-plans-notes p {
  color: var(--websites-text);
}

/* --- Pricing (3 cards) --- */
.web-pricing {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--gap-12);
  margin-top: var(--mg-16);
}

.web-card {
  background: var(--box-bg);
  backdrop-filter: blur(6px);
  border: 1.5px solid rgba(0,0,0,.06);
  border-radius: 18px;
  padding-top: var(--pad-40);
  padding-inline: var(--pad-24);
  padding-bottom: var(--pad-24);
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
  display: flex;
  flex-direction: column;
  gap: var(--gap-12);
  transform: translateY(0);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.web-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 28px rgba(0,0,0,.09);
  border: 1.5px solid #22d3ee;
}

.web-card.is-featured {
  position: relative;
  background: var(--box-bg);
}

.web-badge {
  position: absolute;
  top: 12px; right: 12px;
  font-size: .75rem;
  font-weight: 700;
  padding: .2rem .5rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #22d3ee 0%, #0ea5e9 100%);
  color: white;
}

.web-card-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: .75rem;
}

.web-card h3 {
  margin: 0;
  font-size: var(--font-20);
  letter-spacing: .2px;
  color: var(--websites-text);
  font-weight: 600;
}

.web-price {
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--websites-text);
}

.web-card-list {
  margin-left: var(--mg-20);
}

.web-btn {
  margin-top: auto;
  display: inline-block;
  text-align: center;
  padding: .65rem 1rem;
  border-radius: 12px;
  font-weight: 700;
  letter-spacing: .2px;
  background: linear-gradient(135deg, #0ea5e9 0%, #22d3ee 100%);
  color: white;
  box-shadow: 0 6px 16px rgba(14,165,233,.25);
  transition: transform .15s ease, box-shadow .15s ease, opacity .2s ease;
}
.web-btn:hover { transform: translateY(-1px); box-shadow: 0 10px 18px rgba(14,165,233,.28); }
.web-btn:active { transform: translateY(0); box-shadow: 0 6px 16px rgba(14,165,233,.24); }

.web-block {
  display: grid;
  background-color: var(--websites-row);
  background-image: none; /* es un override */
  align-items: center;
  gap: var(--gap-12);
  padding-block: var(--pad-24);
  padding-inline: var(--pad-24);
  border-radius: var(--radius-12);
  width: 100%;
}

.web-block h2 {
  margin-top: 0;
  margin-bottom: 0;
}

.faq-list { 
  align-self: flex-start;
  margin-left: var(--mg-12);
}

.faq-question {
  font-weight: 600;
}

.faq-answer {
  margin-left: var(--mg-24);
  color: var(--websites-text);
}

.websites-cierre {
  margin-top: var(--mg-20);
  margin-bottom: var(--mg-20);
}
.websites-cierre p {
  color: var(--websites-text);
}
.websites-cierre a {
  color: var(--websites-a);
  font-weight: 600;
}

/* Opcional: entrada suave de los bloques si ya usas data-animate-card */
[data-animate-card] {
  opacity: 0;
  transform: translateY(10px);
  animation: fadeUp .45s ease forwards;
}

/* CARDS GALERIA */

.websites-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(232px, 1fr));
  gap: var(--gap-40);
  max-width: 1024px;
  margin-inline: auto;
  align-items: stretch;
  margin-bottom: var(--mg-32);
}

.websites-card {
  background: var(--websites-row);
  color: var(--websites-text);
  border-radius: var(--radius-12);
  padding-bottom: var(--pad-24);
  box-shadow: 0 0 14px var(--overlay-5);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  height: 100%;
  justify-content: flex-start;
  gap: 0;
}

.websites-card-content {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  flex-grow: 1;
  gap: var(--gap-12);
  color: var(--websites-text);
}

.websites-card-image {
  width: 100%;
  height: auto;
  overflow: hidden;
  margin-bottom: 0;
  border-radius: var(--radius-12) var(--radius-12) 0 0;
}

.websites-card-content img {
  width: 100%;
  height: auto;
  object-fit: cover;
  object-position: center;
}

.websites-card-text {
  display: flex;
  flex-direction: column;
  gap: var(--gap-8);
  position: relative;
  color: var(--websites-text);
}
.websites-card-text h3 {
  font-size: var(--font-16);
  font-weight: 500;
  color: var(--websites-text);
  margin-top: 0;
  margin-inline: var(--mg-16);
  margin-bottom: 0;
  text-align: left;
}

.websites-card-text p {
  font-size: var(--font-14);              
  color: var(--websites-text);                /* o el color que estés usando para textos */
  line-height: 1.5;
  text-align: left;
  margin-inline: var(--mg-16);                   
}

.web-taglist {
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  margin:.5rem 0 0;
  align-items: center;
  justify-content: center;
}

/* badges */
.websites-container ul.web-taglist {
  margin-left: 0;           /* override del global */
  padding-left: 0;          /* quita el padding por defecto del UL */
  list-style: none;         /* sin viñetas */
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: .5rem;        /* separador superior */
  color: var(--websites-tag-text);
  margin-inline: var(--mg-16);   
}

/* cada tag */
.websites-container ul.web-taglist > li.web-tag {
  font-size: .8rem;
  padding: .2rem .5rem;
  border-radius: 999px;
  background: var(--websites-tag);
}

.web-tag{
  font-size:.8rem;
  padding:.2rem .5rem;
  border-radius:999px;
  background:var(--websites-tag)
}

@keyframes fadeUp {
  to { opacity: 1; transform: translateY(0); }
}

@media (min-width: 768px) {
  .web-pricing {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 420px) {
  .web-row {
    grid-template-columns: 1.15fr 0.85fr;
  }
  .bullet-rows .web-row {
    padding-block: var(--pad-24);
  }
}

@media (max-width: 430px) {
  
  .websites-container {
    padding-inline: var(--pad-12);
  }
  .bullet-rows {
    padding-inline: 0; /* Overide basico */
  }
  .bullet-section h2 {
    text-align: center;
  }
  .bullet-section {
    background: transparent;
    gap: var(--gap-8);
  }
  .bullet-rows .web-row {
    padding-block: var(--pad-12);
    padding-inline: var(--pad-12);
  }
  .web-col-text {
    padding-inline: var(--pad-12);
  }
  .web-plans-notes {
    margin-left: 0;
  }
  .websites-container h2 {
    margin-bottom: var(--mg-8);
  }
}
