/* === THEMES === */
/* BLUE DARK THEME */
.theme-blue {
  background: #0a2236 !important;
  color: #cce6ff !important;
}
.theme-blue .main-title, .theme-blue .selected-services-box h5, .theme-blue .footer-text {
  color: #339af0 !important;
}
.theme-blue .service-card, .theme-blue .card.shadow-sm {
  background: #112a45 !important;
  border-color: #339af0 !important;
}
.theme-blue .service-card-icon, .theme-blue .footer-icon, .theme-blue .bi {
  color: #339af0 !important;
  fill: #339af0 !important;
}
/* GREEN DARK THEME */
.theme-green {
  background: #10291a !important;
  color: #d0ffd0 !important;
}
.theme-green .main-title, .theme-green .selected-services-box h5, .theme-green .footer-text {
  color: #27ae60 !important;
}
.theme-green .service-card, .theme-green .card.shadow-sm {
  background: #183d2a !important;
  border-color: #27ae60 !important;
}
.theme-green .service-card-icon, .theme-green .footer-icon, .theme-green .bi {
  color: #27ae60 !important;
  fill: #27ae60 !important;
}
/* RED DARK THEME */
.theme-red {
  background: #2a1010 !important;
  color: #ffd0d0 !important;
}
.theme-red .main-title, .theme-red .selected-services-box h5, .theme-red .footer-text {
  color: #e05a5a !important;
}
.theme-red .service-card, .theme-red .card.shadow-sm {
  background: #3d1818 !important;
  border-color: #e05a5a !important;
}
.theme-red .service-card-icon, .theme-red .footer-icon, .theme-red .bi {
  color: #e05a5a !important;
  fill: #e05a5a !important;
}
@media (max-width: 600px) {
  .service-card {
    width: 100% !important;
    height: 100px !important;
    margin-bottom: 12px;
  }
  .service-cards {
    flex-direction: column !important;
    align-items: center !important;
    gap: 0.5rem !important;
  }
  .service-video {
    height: 120px !important;
  }
  .main-title {
    font-size: 1.5rem !important;
  }
  .main-desc {
    font-size: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .babco-logo-svg {
    width: 100% !important;
    height: auto !important;
    padding: 2px 4px !important;
  }
  .selected-services-box {
    padding: 10px !important;
    max-width: 100% !important;
  }
  .babco-footer .container {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
  }
}
/* Forzar texto blanco en modo oscuro para la lista de servicios seleccionados */
.dark-mode .selected-services-box .list-group-item,
.dark-mode .selected-services-box .list-group-item * {
  color: #fff !important;
}
.dark-mode .selected-services-box h5,
.dark-mode .selected-services-box b,
.dark-mode .selected-services-box strong,
.dark-mode .selected-services-box .count,
.dark-mode .selected-services-box .service-amount {
  color: #27ae60 !important;
}
/* Fondo oscuro y texto verde para la tabla/lista de servicios seleccionados en modo oscuro */
.dark-mode .selected-services-box {
  background: #181f18 !important;
  color: #27ae60 !important;
  border-color: #27ae60 !important;
}
.dark-mode .selected-services-box .list-group-item {
  background: #111 !important;
  color: #27ae60 !important;
  border-color: #27ae60 !important;
}
.dark-mode .selected-services-box h5,
.dark-mode .selected-services-box b,
.dark-mode .selected-services-box strong {
  color: #27ae60 !important;
}
.dark-mode .selected-services-box .count,
.dark-mode .selected-services-box .service-amount {
  color: #27ae60 !important;
}
/* Fondo oscuro para los botones de servicio en modo oscuro */
.dark-mode .service-btn {
  background: #111 !important;
  border-color: #27ae60 !important;
  color: #aaffaa !important;
}
.dark-mode .service-btn:hover {
  background: #222 !important;
  color: #27ae60 !important;
}
/* Íconos de servicios en modo oscuro */
.dark-mode .service-btn i,
.dark-mode .service-card i,
.dark-mode .bi {
  color: #27ae60 !important;
  fill: #27ae60 !important;
}
/* === MODO OSCURO === */
body.dark-mode {
  background: #111 !important;
  color: #d0ffd0 !important;
}
.dark-mode .card,
.dark-mode .modal-content,
.dark-mode .selected-services-box {
  background-color: #181f18 !important;
  color: #d0ffd0 !important;
  border-color: #1a3d1a !important;
}
.dark-mode .btn,
.dark-mode .btn-primary,
.dark-mode .btn-danger,
.dark-mode .btn-dark {
  background-color: #1a3d1a !important;
  border-color: #27ae60 !important;
  color: #aaffaa !important;
}
.dark-mode .btn:hover {
  background-color: #27ae60 !important;
  color: #111 !important;
}
.dark-mode .service-card,
.dark-mode .card.shadow-sm {
  background-color: #181f18 !important;
  border-color: #27ae60 !important;
}
.dark-mode .modal-header, .dark-mode .modal-footer {
  background-color: #1a3d1a !important;
  color: #aaffaa !important;
}
.dark-mode .modal {
  background: rgba(0,0,0,0.7);
}
.dark-mode .form-control {
  background-color: #222 !important;
  color: #aaffaa !important;
  border-color: #27ae60 !important;
}
.dark-mode .count {
  color: #27ae60 !important;
}
/* Textos específicos en verde para dark mode */
.dark-mode .stats h5,
.dark-mode .text-center.mb-4,
.dark-mode .text-center.mb-3,
.dark-mode .user-pro-card > div > div:first-child {
  color: #27ae60 !important;
}
.dark-mode .service-name-label {
  color: #27ae60 !important;
}
/* Fin modo oscuro */
body {
  background: #fff;
  font-family: 'Segoe UI', Arial, sans-serif;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
    }
    .babco-logo {
      height: 80px;
    }
    .babco-logo-svg {
      height: 90px;
      width: 220px;
      display: flex;
      align-items: center;
      background: #fff;
      border-radius: 18px;
      box-shadow: 0 4px 16px rgba(83,191,199,0.10);
      padding: 4px 12px;
      transition: box-shadow 0.3s, transform 0.3s;
    }
    .babco-logo-svg:hover {
      box-shadow: 0 8px 32px rgba(83,191,199,0.18);
      transform: scale(1.04) rotate(-2deg);
    }
    .main-title {
      font-weight: bold;
      font-size: 2.5rem;
      margin-top: 1.5rem;
      color: rgba(100, 250, 250, 1);
      text-align: center;
      text-shadow: 0 4px 12px rgba(0, 0, 0, 0.7),
                   0 2px 4px rgba(0, 0, 0, 0.9),
                   0 0 20px rgba(0, 0, 0, 0.5);
      filter: drop-shadow(0 0 8px rgba(0, 0, 0, 0.6));
    }
    .main-desc {
      color: rgba(120, 250, 250, 1);
      text-align: center;
      margin-bottom: 2rem;
      text-shadow: 0 2px 8px rgba(0, 0, 0, 0.8),
                   0 1px 3px rgba(0, 0, 0, 0.95);
      font-weight: 500;
    }
    .service-video {
      border-radius: 18px;
      box-shadow: 0 4px 24px rgba(0,0,0,0.08);
      overflow: hidden;
      width: 100%;
      height: 320px;
      object-fit: cover;
      margin-bottom: 1.5rem;
    }
    .service-cards {
      display: flex;
      flex-wrap: wrap;
      gap: 1.25rem; /* un poco más de espacio entre las cards */
      justify-content: center; /* center the cards */
      align-items: center;
      max-width: 920px;
      margin: 0 auto;
    }
    .service-card {
      width: 90px;
      height: 90px;
      /* more transparent card background */
      background: linear-gradient(135deg, rgba(83,191,199,0.65) 0%, rgba(224,90,90,0.60) 100%);
      border-radius: 14px;
      box-shadow: 0 4px 12px rgba(0,0,0,0.25);
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      transition: transform 0.40s cubic-bezier(.23,1.02,.32,1), box-shadow 0.20s;
      cursor: pointer;
      perspective: 600px;
      position: relative;
      margin-bottom: 8px;
      backdrop-filter: blur(6px);
      border: 1px solid rgba(255,255,255,0.25);
    }
    .service-card:hover {
      transform: rotateY(180deg) scale(1.05);
      box-shadow: 0 6px 24px rgba(83,191,199,0.45);
    }
    .service-card-icon {
      font-size: 1.7rem;
      color: rgba(255,255,255,0.95);
      margin-bottom: 0.2rem;
      text-shadow: 0 2px 4px rgba(0,0,0,0.3);
    }
    .service-card-title {
      color: rgba(255,255,255,0.95);
      font-weight: 700;
      font-size: 0.85rem;
      text-align: center;
      line-height: 1.1;
      text-shadow: 0 1px 3px rgba(0,0,0,0.4);
    }
    .register-btn {
      background: #e05a5a;
      color: #fff;
      border: none;
      margin-right: 10px;
    }
    .register-btn:hover {
      background: #c13c3c;
      color: #fff;
    }
    .login-btn {
      background: #53bfc7;
      color: #fff;
      border: none;
    }
    .login-btn:hover {
      background: #3ea3ab;
      color: #fff;
    }
    /* Layout: make main container grow so footer sits at page bottom without large empty gaps */
    .container.main-wrapper { flex: 1 0 auto; padding-top: 140px; }
    /* no page background image (cleared per user request) */
    /* Header styling to match login.html: gradient with slight transparency */
    .site-header {
      position: fixed;
      top: 0; left: 0; width: 100%;
      z-index: 6;
      background: linear-gradient(90deg, rgba(83,191,199,0.92) 60%, rgba(224,90,90,0.92) 100%);
      color: #fff;
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 1rem 1.25rem;
      min-height: 110px;
      box-shadow: 0 2px 12px rgba(83,191,199,0.28);
      border-radius: 0 0 18px 18px;
      backdrop-filter: blur(6px);
    }
    /* When header sits inside container, ensure logo and buttons align like original */
    .site-header .babco-logo-svg { background: #fff; box-shadow: 0 2px 12px #eee; padding:8px 18px 8px 8px; border-radius:18px; }
    .babco-footer {
      /* match header gradient + slightly translucent */
      background: linear-gradient(90deg, rgba(83,191,199,0.95) 60%, rgba(224,90,90,0.95) 100%);
      color: #fff;
      border-top: none;
      margin-top: 0;
      min-height: 84px;
      padding: 18px 0;
      font-size: 1.05rem;
      box-shadow: 0 -2px 18px rgba(0,0,0,0.08);
      -webkit-backdrop-filter: blur(8px) saturate(1.04);
      backdrop-filter: blur(8px) saturate(1.04);
      border-radius: 18px 18px 0 0;
      display: flex;
      align-items: center;
      justify-content: center;
    }
    .footer-text {
      color: #53bfc7;
      font-weight: 500;
    }
    .footer-social .footer-icon {
      color: #53bfc7;
      font-size: 1.7rem;
      transition: color 0.2s;
      text-decoration: none;
      vertical-align: middle;
    }
    .footer-social .footer-icon:hover {
      color: #e05a5a;
    }
    @media (max-width: 900px) {
      .service-cards {
        gap: 1rem;
      }
      .service-card {
        width: 120px;
        height: 120px;
      }
      .service-video {
        height: 200px;
      }
    }

    /* Panel que contiene Our Services (empujar contenido hacia la derecha) */
    .services-panel {
      padding-left: 40px; /* desplaza el título y las cards hacia la derecha */
    }
    @media (max-width: 992px) {
      .services-panel { padding-left: 0; }
    }


     body {
      background-color: #fff;
    }
    .dashboard-header {
      display: flex;
      justify-content: flex-end;
      padding: 20px 30px 0 0;
    }
    .stats {
      text-align: center;
      margin-bottom: 30px;
    }
    .stats h5 {
      margin: 0;
      font-weight: bold;
    }
    .stats .count {
      font-size: 1.8rem;
      color: #0097a7;
    }
    .service-btn {
      width: 150px;
      height: 150px;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      font-size: 1rem;
      font-weight: 500;
      margin: 10px;
      border-radius: 16px;
      background: #fff;
      border: 1px solid #e0e0e0;
      box-shadow: 0 2px 8px rgba(0,0,0,0.05);
      color: #333;
      transition: transform 0.1s, background 0.2s;
    }
    .service-btn:hover {
      transform: scale(1.05);
      background: #f8f9fa;
    }
    .service-btn i {
      font-size: 2.5rem;
      color: #0097a7;
      margin-bottom: 10px;
    }
    /* Caja de lista seleccionada */
    .selected-services-box {
      margin: 40px auto;
      padding: 20px;
      border: 1px solid #e0e0e0;
      border-radius: 12px;
      background: #f9f9f9;
      box-shadow: 0 2px 8px rgba(0,0,0,0.05);
      max-width: 900px;
    }
    .selected-services-box h5 {
      margin-bottom: 20px;
      font-weight: bold;
      color: #0097a7;
    }




    .canceled-service {
  background-color: #f5f5f5 !important;
  color: #999 !important;
  text-decoration: line-through;
}



.our_service{

  color: #e05a5a !important;
      font-weight: bold;
      font-size: 2.5rem;
      margin-top: 1.5rem;
      text-align: center;
}


