:root {
  --primary: #1a5fb4;
  --primary-dark: #1c518f;
  --primary-light: #e8f2ff;
  --secondary: #26a269;
  --secondary-light: #e9f8f1;
  --accent: #c64600;
  --light: #f8fafc;
  --dark: #1e1e1e;
  --dark-blue: #2c3e50;
  --gray: #64748b;
  --light-gray: #e2e8f0;
  --border-radius: 12px;
  --shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  --shadow-hover: 0 10px 25px -5px rgba(0, 0, 0, 0.15);
  --transition: all 0.3s ease;
}

body {
  background: var(--light);
  color: var(--dark);
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  font-size: 1.25rem;
  line-height: 1.6;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: 700;
  color: var(--dark-blue);
  letter-spacing: -0.025em;
}
.display-6 { font-weight: 800; letter-spacing: -0.03em; }

.navbar {
  padding: 1rem 0;
  background: rgba(255, 255, 255, 0.98);
  backdrop-filter: blur(10px);
  box-shadow: 0 1px 3px rgba(0,0,0,0.05);
  border-bottom: 1px solid rgba(0,0,0,0.05);
}
.navbar-brand { font-weight: 800; font-size: 1.25rem; color: var(--primary); display:flex; align-items:center; gap:.5rem; }
.navbar-brand i { font-size: 1.5rem; }

.hero { padding: 4rem 0 5rem; background: linear-gradient(135deg,#f8fafc 0%, #e0f2fe 100%); position: relative; overflow: hidden; }
.hero::before { content:''; position:absolute; top:-100px; right:-100px; width:300px; height:300px; background: rgba(26,95,180,.05); border-radius:50%; z-index:0; }
.hero::after { content:''; position:absolute; bottom:-80px; left:-80px; width:200px; height:200px; background: rgba(38,162,105,.05); border-radius:50%; z-index:0; }
.hero-content { position:relative; z-index:2; }

.card { border:none; border-radius:var(--border-radius); box-shadow:var(--shadow); transition:var(--transition); overflow:hidden; }

.card-header { background:white; border-bottom:1px solid var(--light-gray); font-weight:600; padding:1.25rem 1.5rem; }
.card-body { padding:1.5rem; }

.service-card { height:100%; transition:var(--transition); border-left:4px solid var(--primary); }


.btn { border-radius:var(--border-radius); font-weight:600; padding:.75rem 1.5rem; transition:var(--transition); }
.btn-primary { background:var(--primary); border-color:var(--primary); }
.btn-primary:hover { background:var(--primary-dark); border-color:var(--primary-dark); transform: translateY(-2px); }
.btn-success { background:var(--secondary); border-color:var(--secondary); }
.btn-success:hover { background:#208e5a; border-color:#208e5a; }
.btn-lg { padding:1rem 2rem; font-size:1.1rem; }

.form-control,.form-select { border-radius:var(--border-radius); padding:.75rem 1rem; border:1px solid var(--light-gray); font-size:1rem; }
.form-control:focus,.form-select:focus { border-color:var(--primary); box-shadow:0 0 0 .25rem rgba(26,95,180,.15); }

.badge { font-weight:500; padding:.5rem .75rem; border-radius:50px; }
.badge-primary { background: rgba(26,95,180,.1); color: var(--primary); }
.badge-success { background: rgba(38,162,105,.1); color: var(--secondary); }

.section-title { position:relative; padding-bottom:1rem; margin-bottom:2.5rem; text-align:center; }
.section-title::after { content:''; position:absolute; bottom:0; left:50%; transform:translateX(-50%); width:80px; height:4px; background:var(--primary); border-radius:2px; }

.step-card { text-align:center; padding:2.5rem 1.5rem; border-top:4px solid var(--primary-light); }
.step-icon { width:80px; height:80px; border-radius:50%; background:var(--primary-light); display:flex; align-items:center; justify-content:center; margin:0 auto 1.5rem; font-size:2rem; color:var(--primary); transition:var(--transition); }


.testimonial-card { position:relative; padding:2.5rem; border-left:4px solid var(--secondary); }
.testimonial-card::before { content:'"'; position:absolute; top:1.5rem; left:1.5rem; font-size:3.5rem; color:rgba(38,162,105,.1); font-family:Georgia,serif; line-height:1; }

.faq .accordion-button { font-weight:600; padding:1.25rem 1.5rem; border-radius:var(--border-radius)!important; background:var(--light); }
.faq .accordion-button:not(.collapsed){ background:var(--primary); color:white; box-shadow:none; }
.faq .accordion-body { padding:1.5rem; background:var(--light); }

.sticky-cta { box-shadow:0 -5px 15px rgba(0,0,0,.05); background:rgba(255,255,255,.98); backdrop-filter: blur(10px); border-top:1px solid rgba(0,0,0,.05); }

.wapp-fab { box-shadow:0 6px 15px rgba(38,162,105,.3); transition:var(--transition); background:var(--secondary); color:white; width:60px; height:60px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.5rem; position:fixed; bottom:2rem; right:2rem; z-index:1000; }


.pricing-card { border:1px solid var(--light-gray); border-radius:var(--border-radius); overflow:hidden; transition:var(--transition); }

.pricing-header { background:var(--primary); color:white; padding:1.5rem; text-align:center; }
.pricing-body { padding:1.5rem; }
.pricing-features { list-style:none; padding:0; margin:0 0 1.5rem 0; }
.pricing-features li { padding:.5rem 0; display:flex; align-items:center; }
.pricing-features li i { color:var(--secondary); margin-right:.5rem; }
.pricing-price { text-align:center; margin:1.5rem 0; }
.pricing-price .amount { font-size:2.5rem; font-weight:700; color:var(--dark-blue); }
.pricing-price .period { color:var(--gray); }

.coverage-badge { display:inline-flex; align-items:center; gap:.5rem; padding:.5rem 1rem; background:var(--primary-light); color:var(--primary); border-radius:50px; font-weight:500; font-size:.9rem; }

.feature-list { list-style:none; padding:0; }
.feature-list li { padding:.75rem 0; display:flex; align-items:flex-start; gap:.75rem; }
.feature-list li i { color:var(--secondary); font-size:1.25rem; margin-top:.25rem; }

.medical-icon { display:inline-flex; align-items:center; justify-content:center; width:50px; height:50px; background:var(--primary-light); color:var(--primary); border-radius:12px; font-size:1.5rem; margin-bottom:1rem; }

footer { background:var(--dark-blue); color:white; padding:3rem 0 2rem; }
footer h5 { color:white; font-weight:600; margin-bottom:1.5rem; }
footer a { color:rgba(255,255,255,.7); text-decoration:none; transition:var(--transition); }
footer a:hover { color:white; }
.footer-links { list-style:none; padding:0; }
.footer-links li { margin-bottom:.75rem; }
.social-links { display:flex; gap:1rem; margin-top:1.5rem; }
.social-links a:hover { background:var(--primary); transform: translateY(-3px); }

/* Sugerencias (si las usás) */
#barrioSuggestions { z-index:1050; max-height:220px; overflow-y:auto; display:none; position:absolute; width:100%; border-radius:var(--border-radius); box-shadow:var(--shadow); background:white; border:1px solid var(--light-gray); }
#barrioSuggestions li { padding:.75rem 1rem; cursor:pointer; transition:var(--transition); }
#barrioSuggestions li:hover { background:var(--primary-light); }
#barrioSuggestions li.active { background-color:var(--primary); color:white; }

/* Estilos para elementos de formulario con fondo azul suave */
.form-control, .form-select, textarea {
    background-color: rgba(232, 242, 255, 0.6); /* var(--primary-light) con transparencia */
    border: 1px solid var(--light-gray);
    transition: var(--transition);
}

.form-control:focus, .form-select:focus, textarea:focus {
    background-color: rgba(232, 242, 255, 0.9);
    border-color: var(--primary);
    box-shadow: 0 0 0 .25rem rgba(26, 95, 180, .15);
    transform: none; /* Evita que se muevan al enfocarse */
}

/* Estilos para checkboxes y radios personalizados */
.form-check-input {
    background-color: rgba(232, 242, 255, 0.6);
    border: 1px solid var(--light-gray);
}

.form-check-input:checked {
    background-color: var(--primary);
    border-color: var(--primary);
}

/* Estilos para las sugerencias de barrio */
#barrioSuggestions {
    background-color: rgba(232, 242, 255, 0.95);
}

#barrioSuggestions li:hover {
    background-color: rgba(26, 95, 180, 0.15);
}

#barrioSuggestions li.active {
    background-color: var(--primary);
    color: white;
}

/* Eliminar transformaciones en elementos de formulario al hacer hover/focus */
.form-control:hover, .form-select:hover, textarea:hover {
    transform: none;
}

/* Estilos para elementos deshabilitados */
.form-control:disabled, .form-select:disabled {
    background-color: rgba(232, 242, 255, 0.3);
}

/* Aviso debajo del campo de dirección */
.address-notice{
  display: none;
  margin-top: .5rem;
  padding: .625rem .75rem;
  border: 1px solid #ffd58a;         /* llamativo */
  background: #fff3cd;               /* amarillo suave */
  color: #7a4c00;                    /* texto contrastante */
  border-radius: .5rem;
  font-size: .95rem;
  line-height: 1.4;
}

/* Mostrar cuando el input de dirección está en foco */
#address:focus ~ .address-notice{
  display: block;
  animation: fadeIn 160ms ease-in;
}

/* Mostrar también si quedó inválido (nuestro guard agrega .is-invalid) */
#address.is-invalid ~ .address-notice{
  display: block;
}

/* Suavidad */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(-2px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Mejoras para el autocompletado de Google Maps - Todos los dispositivos */

/* Estilos base para todos los dispositivos */
.pac-container {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
    border-radius: 0 0 12px 12px !important;
    margin-top: -1px !important;
    z-index: 1051 !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
    border: 1px solid var(--primary) !important;
    border-top: none !important;
    overflow: hidden;
}

.pac-item {
    border-bottom: 1px solid #f0f0f0 !important;
    line-height: 1.4 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    cursor: pointer !important;
    transition: background-color 0.2s ease !important;
}

.pac-item:hover {
    background-color: var(--primary-light) !important;
}

/* Dirección principal (ej: "Av Cazon 23") */
.pac-item-query {
    font-weight: 600 !important;
    color: var(--dark) !important;
    margin-bottom: 4px !important;
    line-height: 1.3 !important;
}

/* Detalles/ubicación (ej: "Tigre, Buenos Aires") */
.pac-item span:not(.pac-item-query) {
    color: var(--gray) !important;
    line-height: 1.3 !important;
    opacity: 0.9;
}

/* Icono de marcador */
.pac-icon {
    margin-top: 3px !important;
}

/* Elemento seleccionado */
.pac-item-selected {
    background-color: var(--primary-light) !important;
}

/* Estilos específicos para móviles */
@media (max-width: 768px) {
    #address {
        font-size: 16px; /* Previene zoom en iOS */
    }
    
    .pac-container {
        font-size: 16px !important;
        max-height: 70vh !important; /* Limitar altura máxima */
        overflow-y: auto !important; /* Permitir scroll si hay muchas sugerencias */
    }
    
    .pac-item {
        padding: 16px 14px !important;
        min-height: 70px !important; /* Altura mínima para cada elemento */
    }
    
    .pac-item-query {
        font-size: 18px !important;
    }
    
    .pac-item span:not(.pac-item-query) {
        font-size: 16px !important;
    }
    
    .pac-icon {
        margin-right: 12px !important;
    }
}

/* Estilos específicos para PC/escritorio */
@media (min-width: 769px) {
    .pac-container {
        font-size: 15px !important;
        max-width: 600px !important; /* Ancho máximo para no estirarse demasiado */
    }
    
    .pac-item {
        padding: 14px 12px !important;
        min-height: 60px !important;
    }
    
    .pac-item-query {
        font-size: 17px !important;
    }
    
    .pac-item span:not(.pac-item-query) {
        font-size: 15px !important;
    }
    
    .pac-icon {
        margin-right: 10px !important;
    }
}

/* Mejoras para tablets */
@media (min-width: 769px) and (max-width: 1024px) {
    .pac-item {
        padding: 15px 13px !important;
    }
    
    .pac-item-query {
        font-size: 17px !important;
    }
    
    .pac-item span:not(.pac-item-query) {
        font-size: 15px !important;
    }
}

/* Mejorar contraste para modo oscuro */
@media (prefers-color-scheme: dark) {
    .pac-container {
        background-color: #2c3e50 !important;
        border-color: var(--primary) !important;
    }
    
    .pac-item {
        border-bottom-color: #3a506b !important;
    }
    
    .pac-item-query {
        color: white !important;
    }
    
    .pac-item span:not(.pac-item-query) {
        color: #c0c9d6 !important;
    }
    
    .pac-item:hover {
        background-color: #3a506b !important;
    }
    
    .pac-item-selected {
        background-color: #3a506b !important;
    }
}

/* Ocultos */
#originInfo { display:none !important; }
#kmLabel    { display:none !important; }
