    /* Estilos compactos */
    .progress-wrapper {
      margin-bottom: 1rem;
    }
    
    .caption {
      margin-left: 4px;
      flex-grow: 1;
    }
    
    .progress {
      height: 15px;
      margin-top: 4px;
    }
    
    /* Colores de barras */
    .progress-bar.bg-html { background-color: #e44d26; }
    .progress-bar.bg-js { background-color: #f0db4f; }
    .progress-bar.bg-php { background-color: #787cb5; }
    .progress-bar.bg-python { background-color: #3776ab; }
    .progress-bar.bg-sql { background-color: #00758f; }
    .progress-bar.bg-uiux { background-color: #ff4081; }
    .progress-bar.bg-web { background-color: #2965f1; }
    .progress-bar.bg-apps { background-color: #34a853; }
    .progress-bar.bg-figma { background-color: #a259ff; }
    .progress-bar.bg-ps { background-color: #31a8ff; }
    
    /* Iconos */
    .ti, .fab, .fas {
      font-size: 1.1em;
      min-width: 20px;
      text-align: center;
    }

    /* Estilos para los iconos de tecnología */
    .tech-icons {
      margin-top: 5px;
    }
    .tech-icons .ti,
    .tech-icons .fab {
      font-size: 1.2em;
      color: #fff;
      background: rgba(255,255,255,0.2);
      padding: 5px;
      border-radius: 50%;
      margin-right: 3px;
    }
    .tech-icons .ti:hover,
    .tech-icons .fab:hover {
      background: var(--theme-color);
      transform: scale(1.1);
      transition: all 0.3s ease;
    }
    .tech-icons .ti-plus {
      font-size: 0.9em;
      vertical-align: top;
    }
    
    /* Mejora para el caption */
    .img-caption {
      padding: 15px;
      background: rgba(0,0,0,0.7);
    }
    .img-caption h5 {
      margin-bottom: 5px;
    }
    .img-caption p {
      font-size: 0.9em;
      margin-bottom: 10px;
    }
    .img-caption .btn {
      position: static;
      margin-left: 10px;
    }
 
    /* Estilos para los cards del blog */
    .card {
      transition: transform 0.3s ease, box-shadow 0.3s ease;
      display: flex;
      flex-direction: column;
      height: 100%;
    }
    
    .caption {
      display: flex;
      flex-direction: column;
      flex-grow: 1;
      padding: 20px;
    }
    
    .post-title {
      display: block;
      margin: 10px 0;
      font-size: 1.1rem;
      color: #333;
      font-weight: 500;
    }
    
    .post-title:hover {
      color: var(--theme-color);
      text-decoration: none;
    }
    
    /* Botón leer más a la derecha */
    .text-right {
      margin-top: auto;
      padding-top: 15px;
    }
    
    /* Estilos para los modales */
    .modal-content {
      border-radius: 10px;
      border: none;
    }
    
    .modal-header {
      border-bottom: 1px solid #eee;
    }
    
    .modal-title {
      font-weight: 500;
      color: var(--theme-color);
    }
    
    .modal-body img {
      border-radius: 5px;
      margin-bottom: 20px;
      width: 100%;
      height: auto;
    }
    
    .principle-item {
      padding-left: 15px;
      border-left: 3px solid var(--theme-color);
    }
    
    /* Estilo para el botón de WhatsApp */
    .btn-theme .fa-whatsapp {
      font-size: 1.2em;
      vertical-align: middle;
    }
 
    /* Estilos para el formulario */
    .page-contact {
      background-color: #f9f9f9;
      padding: 2rem 0;
    }

    .container {
      max-width: 1200px;
      padding: 0 1rem;
    }

    .form-control-sm {
      padding: 0.5rem 0.75rem;
      font-size: 0.875rem;
    }

    .features-box {
      background-color: #f8f9fa;
    }

    .btn-outline-theme {
      border-width: 1px;
    }
    
    .vg-contact-form .form-control {
      border-radius: 5px;
      padding: 12px 15px;
      border: 1px solid #ddd;
      transition: all 0.3s;
    }
    
    .vg-contact-form .form-control:focus {
      border-color: var(--theme-color);
      box-shadow: 0 0 0 0.2rem rgba(233, 30, 99, 0.25);
    }
    
    select[multiple] {
      height: auto;
      min-height: 120px;
    }
    
    /* Estilos para el modal */
    #confirmacionModal .modal-content {
      border-radius: 10px;
    }
    
    #confirmacionModal .btn-success {
      background-color: #25D366;
      border-color: #25D366;
    }
    
    /* Responsive */
    @media (max-width: 768px) {
      .vg-contact-form .btn-lg {
        width: 100%;
      }
    }

    @media (min-width: 992px) {
      .px-lg-4 {
        padding-left: 1.5rem !important;
        padding-right: 1.5rem !important;
      }
    }  
    
    .footer-links a:hover,
    .footer-services li:hover {
      color: var(--theme-color) !important;
      transform: translateX(5px);
    }
    
    
    .newsletter-form .form-control::placeholder {
      color: rgba(255,255,255,0.6);
    }
    
    .newsletter-form .btn {
      border-radius: 0;
    }
    
    @media (max-width: 767px) {
      
      .footer-links,
      .footer-services {
        min-height: unset;
        border: none;
      }

      .contact-info {
        margin-bottom: 30px;
      }
      
      .social-icons {
        justify-content: center;
        margin-bottom: 20px;
      }
    }
  

    body, html {
        margin: 0;
        padding: 0;
        width: 100%;
        overflow-x: hidden;
        min-height: 100vh;
        height: auto;
    }

    body {
        position: relative;
    }
  
    .clearfix {
        clear: both;
    }
 
    /* Estilos generales para las cards */
    .card-service {
      transition: all 0.4s cubic-bezier(0.23, 1, 0.32, 1);
      border: none;
      border-radius: 12px;
      overflow: hidden;
      box-shadow: 0 4px 8px rgba(0,0,0,0.1);
      height: 100%;
    }
    
    .card-service:hover {
      transform: translateY(-8px);
      box-shadow: 0 12px 24px rgba(0,0,0,0.15);
    }
    
    /* Contenedor del icono */
    .card-service .icon {
      width: 70px;
      height: 70px;
      margin: 25px auto 15px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      transition: all 0.3s ease;
    }
    
    .card-service:hover .icon {
      transform: scale(1.1);
    }
    
    /* Colores personalizados para cada icono */
    /* Diseño Web */
    .card-service:nth-child(1) .icon {
      background-color: rgba(233, 30, 99, 0.1);
    }
    .card-service:nth-child(1) i {
      color: #e91e63;
    }
    
    /* UI/UX */
    .card-service:nth-child(2) .icon {
      background-color: rgba(156, 39, 176, 0.1);
    }
    .card-service:nth-child(2) i {
      color: #9c27b0;
    }
    
    /* Desarrollo Web */
    .card-service:nth-child(3) .icon {
      background-color: rgba(33, 150, 243, 0.1);
    }
    .card-service:nth-child(3) i {
      color: #2196f3;
    }
    
    /* Apps móviles */
    .card-service:nth-child(4) .icon {
      background-color: rgba(76, 175, 80, 0.1);
    }
    .card-service:nth-child(4) i {
      color: #4caf50;
    }
    
    /* SEO */
    .card-service:nth-child(5) .icon {
      background-color: rgba(255, 152, 0, 0.1);
    }
    .card-service:nth-child(5) i {
      color: #ff9800;
    }
    
    /* E-commerce */
    .card-service:nth-child(6) .icon {
      background-color: rgba(244, 67, 54, 0.1);
    }
    .card-service:nth-child(6) i {
      color: #f44336;
    }
    
    /* Mantenimiento Web */
    .card-service:nth-child(7) .icon {
      background-color: rgba(0, 150, 136, 0.1);
    }
    .card-service:nth-child(7) i {
      color: #009688;
    }
    
    /* Analítica */
    .card-service:nth-child(8) .icon {
      background-color: rgba(63, 81, 181, 0.1);
    }
    .card-service:nth-child(8) i {
      color: #3f51b5;
    }
    
    /* Automatización */
    .card-service:nth-child(9) .icon {
      background-color: rgba(0, 188, 212, 0.1);
    }
    .card-service:nth-child(9) i {
      color: #00bcd4;
    }
    
    /* Texto de la card */
    .card-service .caption {
      padding: 0 20px 25px;
      text-align: center;
    }
    
    .card-service h4 {
      margin-bottom: 12px;
      font-weight: 600;
    }
    
    .card-service p {
      color: #666;
      font-size: 0.9rem;
      margin-bottom: 0;
    }
    
    /* Efecto hover en el texto */
    .card-service:hover h4 {
      color: var(--theme-color);
    }
    
    .card-service:hover p {
      color: #444;
    }
 
        .border-separator {
        border: 1px solid rgba(255, 255, 255, 0.1);
        box-sizing: border-box;
        padding: 30px 0;
    }

    /* Desktop (≥768px): elimina bordes internos para evitar dobles líneas */
    @media (min-width: 768px) {
        /* Quita borde derecho solo a la última columna de cada fila de 4 */
        .row .col-md-3:nth-child(4),
        .row .col-md-3:nth-child(8) {
        border-right: 1px solid rgba(255, 255, 255, 0.1);
        }

        /* Quita borde inferior a los ítems de la última fila (ítems 5–8) */
        .row .col-md-3:nth-child(n+5) {
        border-bottom: 1px solid rgba(255, 255, 255, 0.1);
        }
    }

    /* Mobile (<768px): quita borde inferior solo a los dos últimos ítems */
    @media (max-width: 767.98px) {
        .row .col-6:nth-last-child(-n+2) {
        border-bottom: 1px solid rgba(255, 255, 255, 0.1);
        }

        /* Quita borde derecho a cada segundo ítem por fila */
        .row .col-6:nth-child(2n) {
        border-right: 1px solid rgba(255, 255, 255, 0.1);
        }
    }
 
    .counter-box {
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    .counter-icon {
        font-size: 3.5rem; /* icono más grande */
        color: #ff4d00;    /* o tu color de marca */
        margin-bottom: 10px;
    }

    .number {
        font-size: 3rem;
        font-weight: bold;
        margin: 0;
        line-height: 1;
    }

    .number .unit {
        font-size: 1.5rem;
        margin-left: 4px;
    }
  
    .whatsapp-float {
        position: fixed;
        bottom: 10px;
        left: 10px;
        z-index: 9999;
        width: 60px;
        height: 60px;
        border-radius: 50%;
        background-color: #25D366;
        display: flex;
        align-items: center;
        justify-content: center;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
        transition: transform 0.3s ease;
    }
    .whatsapp-float:hover {
        transform: scale(1.1);
    }
    .whatsapp-float img {
        width: 32px;
        height: 32px;
    }

    .fab-whatsapp {
      z-index: 9999;
      bottom: 20px;
    }
 
    /* Foto circular base */
    .footer-photo {
      width: 60px;
      height: 60px;
      object-fit: cover;
      border-radius: 50%;
      border: 2px solid #fff;
    }

    /* Estilos responsivos para móviles */
    @media (max-width: 768px) {
      

      .footer-photo {
        display: block;
        margin-left: auto;
        margin-right: auto;
      }


      /* Centramos el bloque de nombre y foto en horizontal sin apilar */
      .footer-brand-wrapper {
        display: flex;
        justify-content: center !important;
        align-items: center !important;
        text-align: center !important;
        margin: 0 auto; /* 🔥 Esto centra el bloque entero */
      }
    }

    /* ✅ PEGA aquí — footer mejorado */
    /* ── Base ── */
    .vg-footer {
        background: linear-gradient(135deg, #0f0f0f 0%, #1c1c1c 100%);
        position: relative;
        overflow: hidden;
        margin-top: 0;
        margin-bottom: 0 !important;
        width: 100%;
        }
    /* ... todo el bloque nuevo ... */
    /* Línea de acento superior */
        .vg-footer::before {
        content: "";
        position: absolute;
        top: 0; left: 0;
        width: 100%; height: 3px;
        background: linear-gradient(90deg, transparent, var(--theme-color), transparent);
        }

        /* Patrón decorativo de fondo */
        .vg-footer::after {
        content: "";
        position: absolute;
        bottom: -60px; right: -60px;
        width: 250px; height: 250px;
        border-radius: 50%;
        background: rgba(255,255,255,0.02);
        pointer-events: none;
        }

        /* ── Foto ── */
        .footer-photo-wrap {
        position: relative;
        }

        .footer-photo {
        width: 58px;
        height: 58px;
        object-fit: cover;
        border-radius: 50%;
        border: 2px solid var(--theme-color);
        box-shadow: 0 0 0 4px rgba(233,30,99,0.15);
        }

        /* ── Nombre y subtítulo ── */
        .footer-name {
        font-size: 1.2rem;
        font-weight: 700;
        letter-spacing: 0.5px;
        }

        .footer-subtitle {
        color: rgba(255,255,255,0.45);
        font-size: 0.78rem;
        letter-spacing: 0.3px;
        }

        .footer-desc {
        color: rgba(255,255,255,0.55);
        font-size: 0.88rem;
        line-height: 1.7;
        margin-bottom: 0;
        }

        /* ── Redes sociales ── */
        .social-icons a {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 36px; height: 36px;
        border-radius: 50%;
        background: rgba(255,255,255,0.07);
        border: 1px solid rgba(255,255,255,0.1);
        color: rgba(255,255,255,0.7);
        margin-right: 8px;
        font-size: 0.85rem;
        transition: all 0.3s ease;
        text-decoration: none;
        }

        .social-icons a:hover {
        background: var(--theme-color);
        border-color: var(--theme-color);
        color: #fff;
        transform: translateY(-3px);
        box-shadow: 0 6px 15px rgba(233,30,99,0.35);
        }

        /* ── Badge disponible ── */
        .availability-badge {
        display: inline-flex;
        align-items: center;
        background: rgba(255,255,255,0.05);
        border: 1px solid rgba(255,255,255,0.1);
        border-radius: 20px;
        padding: 5px 12px;
        font-size: 0.78rem;
        color: rgba(255,255,255,0.65);
        }

        .dot-online {
        width: 8px; height: 8px;
        border-radius: 50%;
        background: #4caf50;
        margin-right: 7px;
        box-shadow: 0 0 6px #4caf50;
        animation: pulse-dot 1.5s infinite;
        }

        @keyframes pulse-dot {
        0%, 100% { opacity: 1; }
        50%       { opacity: 0.4; }
        }

        /* ── Separador vertical ── */
        .footer-vline {
        width: 1px;
        height: 100%;
        background: linear-gradient(to bottom, transparent, rgba(255,255,255,0.1), transparent);
        }

        /* ── Headings de columnas ── */
        .footer-heading {
        font-size: 0.7rem;
        text-transform: uppercase;
        letter-spacing: 2px;
        color: var(--theme-color);
        font-weight: 700;
        padding-bottom: 8px;
        border-bottom: 1px solid rgba(255,255,255,0.07);
        }

        /* ── Links ── */
        .footer-links a,
        .footer-services li {
        color: rgba(255,255,255,0.55);
        font-size: 0.88rem;
        padding: 4px 0;
        display: block;
        text-decoration: none;
        transition: all 0.25s ease;
        }

        .footer-links a:hover,
        .footer-services li:hover {
        color: var(--theme-color) !important;
        transform: translateX(5px);
        }

        .footer-services li i {
        font-size: 0.65rem;
        vertical-align: middle;
        }

        /* ── Contacto ── */
        .contact-info li {
        display: flex;
        align-items: flex-start;
        color: rgba(255,255,255,0.55);
        font-size: 0.88rem;
        margin-bottom: 12px;
        }

        .contact-info li i {
        margin-top: 3px;
        min-width: 18px;
        }

        .contact-info a {
        color: rgba(255,255,255,0.55);
        text-decoration: none;
        transition: color 0.2s;
        }

        .contact-info a:hover {
        color: var(--theme-color);
        }

        /* ── Barra inferior ── */
        .footer-bottom {
        background: rgba(0,0,0,0.35);
        border-top: 1px solid rgba(255,255,255,0.06);
        }

        .footer-copy {
        color: rgba(255,255,255,0.4);
        }

        /* ── Badges de tecnología ── */
        .footer-tech-badge {
        display: inline-block;
        background: rgba(255,255,255,0.05);
        border: 1px solid rgba(255,255,255,0.1);
        border-radius: 4px;
        padding: 2px 8px;
        font-size: 0.7rem;
        color: rgba(255,255,255,0.4);
        margin-left: 6px;
        letter-spacing: 0.5px;
        }

        /* ── HR ── */
        .vg-footer hr {
        border-top: 1px solid rgba(255,255,255,0.08);
        background-color: transparent;
        }

        /* ── Responsive ── */
        @media (max-width: 768px) {
        .vg-footer .row > div,
        .vg-footer h2, .vg-footer h5, .vg-footer h6,
        .vg-footer p, .vg-footer a, .vg-footer span,
        .vg-footer ul {
            text-align: center !important;
        }

        .footer-brand-wrapper {
            justify-content: center !important;
        }

        .social-icons {
            justify-content: center;
        }

        .availability-badge {
            margin: 0 auto;
        }

        .contact-info li {
            justify-content: center;
        }

        .footer-tech-badge {
            margin: 3px 3px 0;
        }

        .footer-bottom .d-flex {
            text-align: center !important;
        }
        }

        /* Elimina espacio fantasma debajo del footer */
        #footer {
        display: block;
        line-height: 0;
        margin: 0;
        padding: 0;
        }

        #footer footer {
        line-height: normal; /* restaura dentro del footer */
        display: block;
        margin: 0;
        padding-bottom: 0;
        }

        .vg-footer {
        margin: 0 !important;
        padding-bottom: 0;
        }

        .footer-bottom {
        margin: 0;
        padding-bottom: 0; /* ← esta suele ser la causa principal */
        }

        /* Asegura que body no tenga fondo blanco sobrante */
        body, html {
        background-color: #ffffff;
        }

        /* Evita que columnas vacías muestren borde */
        .vg-footer .col-6,
        .vg-footer .col-md-4,
        .vg-footer .col-12 {
        border: none !important;
        outline: none !important;
        }

