    /* =================================== */
    /* VARIABLES Y BASE                    */
    /* =================================== */
    :root{
      --primary-color:#5D3A7B;
      --secondary-color:#3e2752;
      --accent-color:#D81B60;
      --bg-light:#F4F0F8;
      --text-dark:#333;
      --text-light:#666;
      --white:#ffffff;
      --border-color:#ddd;
    }
    html{ scroll-behavior:smooth; }
    body{ font-family:'Open Sans',sans-serif; margin:0; color:var(--text-dark); background:var(--white); line-height:1.7; }
    .container{ max-width:1100px; margin:0 auto; padding:0 20px; }
    section{ padding:80px 0; }
    h1,h2,h3,h4{ font-family:'Montserrat',sans-serif; font-weight:700; color:var(--primary-color); }
    h2{ text-align:center; font-size:2.5rem; margin-bottom:1rem; }
    .section-subtitle{ text-align:center; color:var(--text-light); margin-bottom:50px; max-width:600px; margin-left:auto; margin-right:auto; }

    /* =================================== */
    /* BOTONES                             */
    /* =================================== */
    .btn{
      display:inline-block; background:var(--accent-color); color:#fff; padding:12px 28px; border-radius:50px;
      text-decoration:none; font-weight:bold; transition:background-color .3s ease, transform .3s ease; border:none; cursor:pointer;
    }
    .btn:hover{ background:#b7154f; transform:translateY(-2px); }
    .btn.btn--ghost{ background:transparent; border:2px solid var(--primary-color); color:var(--primary-color); }
    .btn.btn--ghost:hover{ background:var(--primary-color); color:#fff; }
    .btn-block{ width:auto; display:inline-block; }

    /* =================================== */
    /* HEADER / NAVEGACIÓN                 */
    /* =================================== */
    header{ background:#fff; padding:15px 0; position:sticky; top:0; z-index:1000; box-shadow:0 2px 10px rgba(0,0,0,.05); }
    nav{ display:flex; justify-content:space-between; align-items:center; }
    .logo img{ height:50px; }
    .nav-links{ list-style:none; display:flex; gap:30px; margin:0; }
    .nav-links a{ text-decoration:none; color:var(--primary-color); font-weight:600; }
    .menu-toggle{ display:none; font-size:1.8rem; cursor:pointer; background:none; border:none; }
    /* CTA navegación */
    .nav-cta-desktop{ margin-left:20px; }
    .nav-cta-desktop .btn{ padding:8px 35px; font-size:.95rem; }
    .nav-cta-mobile{ display:none; } /* mostrado sólo en móvil */

    /* =================================== */
    /* HERO                                */
    /* =================================== */
    #inicio{
      background-image:linear-gradient(rgba(0,0,0,.4),rgba(0,0,0,.4)),url('../imagenes/slide-principal2-1.png');
      background-size:cover; background-position:center; color:#fff; height:90vh; display:flex; align-items:center; text-align:center; padding:0 20px;
    }
    .hero-content{ max-width:800px; margin:auto; animation:fadeIn 1s; }
    #inicio h1{ font-size:3.5rem; color:#fff; margin:0 0 1rem 0; }
    #inicio p{ font-size:1.2rem; margin-bottom:2rem; }
    .hero-buttons{ margin-bottom:2.0rem; }
    .hero-buttons .btn{ margin:0 10px; }
    .btn-secondary{ background:transparent; border:2px solid #fff; }
    .btn-secondary:hover{ background:#fff; color:var(--primary-color); }
    .city-badges{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; max-width:700px; margin:20px auto 0; }
    .badge{ background:rgba(255,255,255,.2); color:#fff; padding:6px 10px; border-radius:20px; font-size:.85rem; font-weight:600; border:1px solid rgba(255,255,255,.3); backdrop-filter:blur(5px); -webkit-backdrop-filter:blur(5px); text-align:center; white-space:nowrap; }
    @keyframes fadeIn{ from{opacity:0} to{opacity:1} }

    /* =================================== */
    /* CONFIANZA                           */
    /* =================================== */
    #confianza{ background:var(--bg-light); }
    .trust-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; text-align:center; }
    .trust-item svg{ width:50px; height:50px; color:var(--accent-color); margin-bottom:1rem; }
    .trust-item h3{ margin-top:0; font-size:1.2rem; }

    /* =================================== */
    /* SOBRE MÍ                            */
    /* =================================== */
    .about-split{ display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:start; }
    .about-col{ display:flex; flex-direction:column; gap:20px; }
    .about-col img.about-img-cover{ width:100%; border-radius:12px; box-shadow:0 12px 36px rgba(0,0,0,.12); }
    #about-title{ margin-top:0; padding-top:0; line-height:1.1; margin-bottom:.3rem; }
    .about-pro__subtitle{ margin:.0 0 .8rem 0; color:var(--text-light); font-weight:600; }
    .about-pro__meta{ display:flex; flex-wrap:wrap; gap:10px; padding:0; margin:0 0 14px 0; list-style:none; }
    .pill{ display:inline-block; font-size:.9rem; background:var(--bg-light); color:var(--primary-color); border:1px solid #e9e4ef; padding:6px 12px; border-radius:999px; font-weight:600; }
    .about-pro__lead{ font-size:1.05rem; color:#444; margin:10px 0 22px 0; }
    .about-pro__kpis{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
    .kpi{ background:var(--bg-light); border:1px solid #eee; border-radius:12px; padding:14px 10px; text-align:center; }
    .kpi__value{ display:block; font-family:'Montserrat', sans-serif; font-weight:700; font-size:1.35rem; color:var(--primary-color); line-height:1; margin-bottom:4px; }
    .kpi__label{ font-size:.82rem; color:var(--text-light); }
    .accordion{ margin-top:8px; }
    .acc-item{ border:1px solid #eee; border-radius:12px; margin:10px 0; background:#fff; overflow:hidden; }
    .acc-head{ list-style:none; cursor:pointer; padding:14px 16px; font-weight:700; color:var(--primary-color); position:relative; }
    .acc-head::-webkit-details-marker{ display:none; }
    .acc-head::after{ content:"+"; position:absolute; right:16px; top:50%; transform:translateY(-50%); font-weight:700; color:var(--accent-color); }
    .acc-item[open] .acc-head::after{ content:"–"; }
    .acc-body{ padding:0 16px 14px 16px; color:var(--text-dark); }
    .checklist{ padding-left:0; list-style:none; margin:0; }
    .checklist li{ position:relative; padding-left:26px; margin:8px 0; }
    .checklist li::before{ content:"✔"; position:absolute; left:0; top:0; color:var(--accent-color); font-weight:700; }
    .about-pro__cta{ display:flex; gap:12px; margin:16px 0 6px 0; }
    .about-quote{ margin:10px 0 0 0; padding:12px 16px; border-left:4px solid var(--accent-color); background:#fdf7fa; color:#5a2950; border-radius:8px; }

    /* =================================== */
    /* SERVICIOS                           */
    /* =================================== */
    #servicios{ background:var(--bg-light); }
    .services-container{ background:#fff; border-radius:10px; box-shadow:0 10px 40px rgba(0,0,0,.08); overflow:hidden; }
    .service-tabs{ display:flex; background:var(--bg-light); }
    .tab-button{ flex:1; padding:20px; border:none; background:transparent; cursor:pointer; font-family:'Montserrat',sans-serif; font-size:1rem; font-weight:600; color:var(--text-light); transition:background-color .3s, color .3s; border-bottom:3px solid transparent; }
    .tab-button.active{ color:var(--primary-color); border-bottom-color:var(--accent-color); }
    .tab-content{ display:none; padding:40px; animation:fadeIn .5s; }
    .tab-content.active{ display:block; }
    .svc-list{ display:flex; flex-direction:column; gap:20px; }
    .svc-item{ background:#fff; border:1px solid #eee; border-radius:12px; padding:20px; box-shadow:0 6px 20px rgba(0,0,0,.05); transition: transform .2s ease, box-shadow .2s ease; }
    .svc-item:hover{ transform: translateY(-2px); box-shadow:0 10px 25px rgba(0,0,0,.08); }
    .svc-item h4{ margin:0 0 6px 0; color:var(--primary-color); font-size:1.1rem; }
    .svc-item p{ margin:0 0 12px 0; color:var(--text-light); }
    .svc-bottom{ display:flex; align-items:center; justify-content:space-between; margin-top:auto; }
    .price{ font-weight:700; font-size:1.2rem; color:var(--primary-color); }

    /* =================================== */
    /* OPINIONES                           */
    /* =================================== */
    .testimonials{ display:grid; grid-template-columns: repeat(3,1fr); gap:20px; margin-top:30px; }
    .testimonial-card{ background:var(--bg-light); padding:24px; border-radius:12px; border-left:5px solid var(--accent-color); box-shadow:0 8px 20px rgba(0,0,0,.05); display:flex; flex-direction:column; justify-content:space-between; }
    .testimonial-text{ font-size:1rem; font-style:italic; margin:0 0 14px 0; color:var(--text-dark); }
    .author{ font-weight:700; color:var(--primary-color); margin:0; text-align:right; font-size:.95rem; }

    /* =================================== */
    /* MAPA / UBICACIÓN                    */
    /* =================================== */
    #ubicacion.map-section{ background:var(--bg-light); padding:70px 0; }
    .map-card{ background:#fff; border-radius:16px; box-shadow:0 12px 36px rgba(0,0,0,.08); padding:32px; max-width:1100px; margin:0 auto; text-align:center; }
    .map-card__head h2{ margin:0 0 .5rem 0; }
    .map-card__head .section-subtitle{ margin-bottom:1.6rem; }
    .map-card__map{ border-radius:14px; overflow:hidden; border:1px solid #eee; height:500px; }
    .map-card__map iframe{ width:100%; height:100%; border:0; }

    /* =================================== */
    /* FAQ                                 */
    /* =================================== */
    /*#faq{ background:var(--secondary-color); }*/
    /* Preguntas Frecuentes - items */
    #faq .acc-item {
      background: var(--bg-light);   /* antes era #fff */
      border: 1px solid #ddd;
      border-radius: 12px;
      margin: 10px 0;
      overflow: hidden;
    }

    /* =================================== */
    /* CONTACTO OPTIMIZADO                 */
    /* =================================== */
    #contacto{ background:var(--bg-light); }
    .contact-form-container{ background:var(--white); border-radius:16px; padding:32px; box-shadow:0 10px 40px rgba(0,0,0,.08); max-width:1100px; margin:0 auto; }
    .contact-form .form-row{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
    .contact-form .form-group{ display:flex; flex-direction:column; gap:6px; margin-bottom:16px; }
    .contact-form label{ font-weight:600; color:var(--primary-color); font-size:.95rem; }
    .contact-form input,.contact-form select,.contact-form textarea{
      width:100%; padding:12px 14px; border:1px solid var(--border-color); border-radius:10px; font-family:'Open Sans',sans-serif; font-size:1rem; background:#fff; box-sizing:border-box; transition:border-color .2s ease, box-shadow .2s ease;
    }
    .contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{ outline:none; border-color:var(--primary-color); box-shadow:0 0 0 3px rgba(93,58,123,.15); }
    .contact-form textarea{ resize:vertical; min-height:120px; }
    .form-fieldset{ margin:10px 0 20px 0; border:1px solid #eee; padding:16px; border-radius:12px; }
    .form-fieldset>legend{ padding:0 8px; color:var(--primary-color); font-weight:700; font-size:1rem; }
    .contact-methods{ display:flex; flex-wrap:wrap; gap:16px 24px; align-items:center; }
    .chk{ display:inline-flex; align-items:center; gap:8px; }

    /* Urgencia (radio alineado a la izquierda) */
    .urgency-options{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
    .rad{ display:grid; grid-template-columns:auto 1fr; align-items:center; column-gap:8px; background:#faf7ff; border:1px solid #eee; border-radius:10px; padding:12px; cursor:pointer; transition:border-color .2s ease, box-shadow .2s ease; }
    .rad:hover{ border-color:var(--accent-color); }
    .rad input{ margin:0; justify-self:start; }
    .rad span{ margin:0; white-space:nowrap; }
    .rad:focus-within{ outline:none; border-color:var(--primary-color); box-shadow:0 0 0 3px rgba(93,58,123,.15); }

    .manana-rangos{ margin-top:16px; animation:fadeIn .4s; }
    .manana-rangos label{ display:block; margin-bottom:8px; }

    .form-consent-inline{ margin:16px 0; }
    .consent-label{ display:block; position:relative; padding-left:28px; font-size:.9rem; line-height:1.5; color:var(--text-light); cursor:pointer; }
    .consent-label input[type="checkbox"]{ position:absolute; left:0; top:3px; width:18px; height:18px; }

    /* =================================== */
    /* FOOTER                              */
    /* =================================== */
    footer{ background:var(--secondary-color); color:#fff; text-align:center; padding:40px 0; }

    /* =================================== */
    /* RESPONSIVE                          */
    /* =================================== */
    @media (max-width:768px){
      h1,#inicio h1{ font-size:2.5rem; line-height:1.08; margin-bottom:.6rem; }
      h2{ font-size:2rem; }
      section{ padding:60px 0; }

      /* Menú móvil */
      .nav-links{ display:none; flex-direction:column; position:absolute; top:80px; left:0; background:#fff; width:100%; box-shadow:0 5px 10px rgba(0,0,0,.1); padding:10px 0; text-align:center; }
      .nav-links.active{ display:flex; }
      .nav-links a{ padding:15px; }
      .menu-toggle{ display:block; }
      .nav-cta-desktop{ display:none; }
      .nav-cta-mobile{ display:flex; justify-content:center; margin:10px 0; }
      .nav-cta-mobile .btn{ width:auto; padding:10px 20px; font-size:.95rem; }

      /* Hero */
      .hero-content p{ font-size:1rem; margin-bottom:.8rem; }
      .city-badges{ grid-template-columns:repeat(2,1fr); }
      .hero-buttons{ display:flex; flex-direction:column; align-items:center; gap:14px; margin-top:.2rem; margin-bottom:1.4rem; }
      .hero-buttons .btn{ width:72vw; max-width:260px; margin:0 auto; }

      /* Grids */
      .trust-grid{ grid-template-columns:1fr; }
      .about-split{ grid-template-columns:1fr; }
      .about-pro__kpis{ grid-template-columns:repeat(3,1fr); }
      .svc-list{ gap:16px; }
      .svc-item{ padding:16px; text-align:center; }
      .svc-bottom{ flex-direction:column; align-items:center; gap:10px; }
      .testimonials{ grid-template-columns:1fr; }

      /* Formulario */
      .contact-form .form-row{ grid-template-columns:1fr; gap:0; }
      .urgency-options{ grid-template-columns:1fr; }
      .rad span{ white-space:normal; }
      
      /* Input oculto detector de spam */
      .hp-field {
      display: none !important;
      visibility: hidden;
      height: 0;
      overflow: hidden;
        }

      /* Mapa */
      .map-card{ padding:24px; }
      .map-card__map{ height:350px; }
    }
    
    /* =============================== */
/* ANTI-SPAM HONEYPOT (oculto)     */
/* =============================== */
.hp-field {
  display: none !important;
  visibility: hidden !important;
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
}


/* Evita que los inputs cambien de tamaño por el contenido */
.contact-form input, 
.contact-form select, 
.contact-form textarea { min-width: 0; }

/* Alinea verticalmente los campos en las filas dobles */
.contact-form .form-row { align-items: flex-start; }

/* Los “cards” de radio no se rompen raro por saltos de línea */
.contact-form .rad span { white-space: nowrap; }




/* ============================= */ 
/* TOAST (éxito / error centrado) */
/* ============================= */
.toast {
  position: fixed;
  top: 50%; 
  left: 50%;
  transform: translate(-50%, -50%) scale(0.9); /* centrado */
  background: #fff;
  border-left: 6px solid #00c896; /* éxito */
  padding: 16px 22px;
  border-radius: 14px;
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  font-family: 'Open Sans', sans-serif;
  color: #333;
  font-size: 1rem;
  font-weight: 600;
  z-index: 9999;
  opacity: 0;
  transition: opacity .35s ease, transform .35s ease;
  text-align: center;
  min-width: 280px;
}
.toast.show {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1); /* animación suave */
}
.toast.error {
  border-left-color: #e53935;
}
.toast .toast-close {
  position: absolute;
  top: 8px;
  right: 12px;
  border: none;
  background: transparent;
  font-size: 18px;
  cursor: pointer;
}





/* ============================= */ 
/* FAB Social (Instagram + WhatsApp) */
/* ============================= */

/* --- ESTILOS BASE (PARA ESCRITORIO) --- */
    .floating-buttons-container {
        position: fixed;
        top: 50%;
        right: 0;
        /* Por defecto, centrado verticalmente para PC */
        transform: translateY(-50%); 
        display: flex;
        flex-direction: column;
        gap: 7px;
        z-index: 1000;
        transition: transform 0.4s ease-in-out; 
    }

    /* (Estos estilos son iguales para PC y móvil) */
    .float-button {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 40px;
        height: 45px;
        box-shadow: -2px 4px 8px rgba(0, 0, 0, 0.2);
        text-decoration: none;
    }
    
    .float-button.instagram {
        background: radial-gradient(circle at 30% 107%, #fdf497 0%, #fdf497 5%, #fd5949 45%,#d6249f 60%,#285AEB 90%);
        border-radius: 18px 0 0 18px;
    }

    .float-button.whatsapp {
        background-color: #25D366;
        border-radius: 18px 0 0 18px;
    }

    .float-button img {
        width: 30px;
        height: 30px;
        margin-right: -3px;
    }

    /* --- ESTILOS ESPECÍFICOS PARA MÓVIL --- */
    /* Se aplica solo si el ancho de la pantalla es de 768px o menos */
    @media (max-width: 768px) {
        .floating-buttons-container {
            /* 1. Cambiamos la posición vertical en móvil */
            transform: translateY(-180%);
            /* 2. Añadimos la transición para el efecto de transparencia */
            transition: opacity 0.4s ease-in-out, visibility 0.4s ease-in-out;
        }

        /* 3. Clase que los oculta con transparencia (solo en móvil) */
        .floating-buttons-container.hidden {
            opacity: 0;
            visibility: hidden;
            pointer-events: none;
        }
    }
    
    
    
    /* --- ESTILOS SERVICIOS NEW --- */
   /* Grilla de servicios: 3 columnas escritorio, 2 tablet, 1 móvil */
/* ===== Grilla de tarjetas (3 columnas) ===== */
.svc-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 26px;
  margin: 24px 0;
  padding: 0;
  list-style: none;
}

/* ===== Tarjeta ===== */
.svc-card{
  background:#fff;
  border-radius:16px;
  border:1px solid #eee;
  box-shadow: 0 10px 30px rgba(0,0,0,.06);
  padding: 28px 26px;
  text-align: center;
  display:flex;
  flex-direction:column;
  align-items:center;
  transition: transform .2s ease, box-shadow .2s ease;
}
.svc-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 18px 40px rgba(0,0,0,.10);
}

/* Icono grande en color primario suave */
.svc-icon{
  width:72px; height:72px;
  border-radius: 20px;
  background: rgba(93,58,123,.08); /* usa --primary-color muy suave */
  display:grid; place-items:center;
  color: var(--primary-color);
  margin-bottom: 14px;
}

/* Título y texto */
.svc-title{
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  font-size:1.4rem;
  color: var(--primary-color);
  margin: 8px 0 8px 0;
}
.svc-desc{
  color: var(--text-light);
  margin:0 0 16px 0;
}

/* Pie: precio + botón */
.svc-foot{
  margin-top:auto;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
}
.svc-foot .price{
  font-weight:700;
  color: var(--primary-color);
  font-size:1.05rem;
}

/* ===== Responsive ===== */
@media (max-width: 1024px){
  .svc-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px){
  .svc-grid{ grid-template-columns: 1fr; gap:16px; }
  .svc-card{ padding:22px 18px; }
}

/* ===== Servicios: listas limpias + separación del botón ===== */
.svc-card{
  display: flex;
  flex-direction: column;
}

.svc-list{
  list-style: disc;              /* viñeta clásica */
  list-style-position: outside;  /* como en tu captura */
  padding-left: 1.2rem;          /* sangría cómoda */
  margin: 8px 0 14px;            /* espacio arriba/abajo, separa del botón */
}

.svc-list li{
  margin: 4px 0;                 /* aire entre líneas */
}

.svc-card .btn{
  margin-top: 8px;               /* evita que “toque” las viñetas */
  align-self: flex-start;        /* mantiene el botón alineado a la izquierda */
}

/* ============================= */
/* Servicios: responsive fix     */
/* ============================= */

/* centrar y limitar ancho del grid en desktop */
#servicios .services-grid{
  max-width: 1100px;
  margin: 0 auto;
}

/* Tablet: 2 columnas */
@media (max-width: 1024px){
  #servicios .services-grid{
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 16px !important;
  }
}

/* Móvil: 1 columna y tipografías más compactas */
@media (max-width: 640px){
  #servicios .services-grid{
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  /* tarjeta más respirada pero compacta */
  #servicios .svc-card{
    padding: 16px !important;
    border-radius: 12px !important;
  }

  /* títulos más pequeños y con mejor interlineado */
  #servicios .svc-card h3{
    font-size: 1.05rem !important;
    line-height: 1.25 !important;
    margin: 0 0 .25rem 0 !important;
    text-align: center !important;
  }

  /* subtítulo más cerca del título */
  #servicios .svc-card > p{
    margin: .2rem 0 .5rem 0 !important;
    text-align: center !important;
  }

  /* badge de precio un poco más chico */
  #servicios .svc-card div[style*="border-radius:999px"] span{
    font-size: .9rem !important;
    padding: 5px 10px !important;
  }

  /* líneas de contenido (las que hiciste con • + <br>) más juntas */
  #servicios .svc-card div[style*="line-height"]{
    line-height: 1.3 !important;
    font-size: .95rem !important;
    margin-bottom: 12px !important;
  }

  /* botón ancho cómodo y centrado */
  #servicios .svc-card .btn{
    display: inline-block !important;
    width: 100%;
    max-width: 260px;
    text-align: center;
  }
}

 /* ============================= */
/* Servicios en móvil mejorados  */
/* ============================= */
@media (max-width: 640px){
  #servicios .svc-card{
    padding: 18px !important;
    border-radius: 12px !important;
    min-height: 380px !important; /* más alto para dar aire */
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
  }

  /* botón centrado y con ancho fijo */
  #servicios .svc-card .btn{
    display: block !important;
    margin: 12px auto 0 auto !important;
    width: 90% !important;
    max-width: 280px !important;
    text-align: center !important;
  }
}
@media (max-width: 640px){
  #servicios .svc-card{
    padding: 18px !important;
    border-radius: 12px !important;
    min-height: 320px !important; /* antes 380px → más compacto */
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important; /* no los bajes tanto */
  }

  /* botón centrado y con buen espacio arriba */
  #servicios .svc-card .btn{
    display: block !important;
    margin: 16px auto 8px auto !important; /* menos separación */
    width: 85% !important;
    max-width: 260px !important;
    text-align: center !important;
  }

  /* espacio más compacto en las viñetas */
  #servicios .svc-card div{
    line-height: 1.3 !important;
    margin-bottom: 10px !important;
  }
}
@media (max-width: 640px){
  #servicios .svc-card{
    padding: 14px 16px 18px 16px !important; /* menos espacio arriba y abajo */
    border-radius: 12px !important;
    min-height: auto !important; /* quitamos la altura fija, que ajusten solas */
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
  }

  #servicios .svc-card h3{
    margin-top: 6px !important;   /* baja el espacio sobre el título */
    margin-bottom: 4px !important;
    font-size: 1.1rem !important; /* título un poco más compacto */
  }

  #servicios .svc-card p{
    margin: 0 0 6px 0 !important; /* subtítulo más pegado al título */
  }

  #servicios .svc-card .btn{
    display: block !important;
    margin: 12px auto 0 auto !important; /* solo 12px sobre el botón */
    width: 85% !important;
    max-width: 240px !important;
    text-align: center !important;
  }

  /* viñetas más compactas */
  #servicios .svc-card div{
    line-height: 1.3 !important;
    margin-bottom: 8px !important;
  }
}

/* ===== Arreglo: centrar botón Agendar en móvil ===== */
@media (max-width: 640px){
  #servicios .svc-card .btn{
    align-self: center !important;      /* anula el flex-start anterior */
    margin-left: auto !important;
    margin-right: auto !important;
    display: block !important;          /* por si algún inline-block se cuela */
    width: 85% !important;              /* el ancho que ya venías usando */
    max-width: 260px !important;
    text-align: center !important;
  }
}
/* Opcional: centrar SIEMPRE el botón en las tarjetas */
#servicios .svc-card .btn{
  align-self: center;
}


/* FIX DEFINITIVO: centrar botón Agendar en móvil */
@media (max-width: 640px){
  #servicios .svc-card a.btn,
  #servicios .svc-card > .btn{
    /* centrado absoluto en el eje X, ignora align-self/justify */
    position: relative !important;
    left: 50% !important;
    transform: translateX(-50%) !important;

    /* que no “salte” de tamaño */
    display: inline-block !important;
    width: 85% !important;
    max-width: 260px !important;
    text-align: center !important;

    /* márgenes compactos y simétricos */
    margin: 12px auto 8px auto !important;
  }
}
