/* =========================================================
   Contacto — épico, premium, responsivo
   Solo estilos de esta página
   ========================================================= */

.ct-hero{
  position: relative;
  min-height: 74vh;
  padding-top: var(--header-h);
  display: flex;
  align-items: center;
  overflow: hidden;
  color: #fff;
  background: #0b1220;
}

.ct-hero-bg{
  position: absolute;
  inset: 0;
  background: url("/v2/assets/img/contacto/c01.png");
  background-size: cover;
  background-position: center;
  transform: scale(1.03);
}

.ct-hero-overlay{
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(1000px 600px at 18% 40%, rgba(30,136,255,.14), transparent 62%),
    linear-gradient(90deg, rgba(3,7,14,.88) 0%, rgba(3,7,14,.66) 55%, rgba(3,7,14,.20) 100%),
    linear-gradient(to bottom, rgba(0,0,0,.12), rgba(0,0,0,.55));
}

.ct-hero-inner{
  position: relative;
  z-index: 2;
  padding: clamp(78px, 11vh, 130px) 0 42px;
  max-width: 980px;
}

.ct-eyebrow{
  margin: 0 0 14px;
  letter-spacing: .22em;
  text-transform: uppercase;
  font-size: 12px;
  opacity: .76;
}

.ct-title{
  margin: 0 0 14px;
  font-weight: 300;
  text-transform: uppercase;
  letter-spacing: .06em;
  line-height: 1.05;
  font-size: clamp(32px, 4.4vw, 62px);
  max-width: 22ch;
  text-shadow: 0 10px 30px rgba(0,0,0,.35);
}

.ct-lead{
  margin: 0 0 18px;
  max-width: 72ch;
  font-size: clamp(15px, 1.2vw, 18px);
  line-height: 1.6;
  color: rgba(255,255,255,.86);
}

.ct-hero-actions{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin: 10px 0 18px;
}

.ct-badges{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 8px;
}

.ct-badge{
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.07);
  backdrop-filter: blur(10px);
  border-radius: 16px;
  padding: 12px 14px;
  min-width: 160px;
}
.ct-badge strong{ display:block; font-size: 14px; letter-spacing: .08em; text-transform: uppercase; }
.ct-badge span{ display:block; font-size: 12px; opacity: .78; margin-top: 3px; }

/* Layout */
.ct-section{ padding-top: 62px; }
.ct-grid{
  display: grid;
  grid-template-columns: 1fr 1.15fr;
  gap: 18px;
  align-items: start;
}

.ct-side h2, .ct-form-head h2{ margin: 0 0 10px; }
.ct-muted{ opacity: .76; margin: 0; }
.ct-note{ margin: 10px 0 0; opacity: .68; font-size: 12px; }

.ct-cards{
  display: grid;
  gap: 12px;
  margin-top: 14px;
}

.ct-card{
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 20px;
  background: #fff;
  box-shadow: 0 12px 32px rgba(0,0,0,.08);
  padding: 16px;
}
.ct-card h3{ margin: 0 0 8px; }

.ct-card-actions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.ct-mini{
  margin-top: 14px;
  border-radius: 20px;
  padding: 16px;
  background: linear-gradient(135deg, #0d1b2c, #0b1220);
  color: #fff;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow);
}
.ct-mini h3{ margin: 0 0 10px; }
.ct-list{
  margin: 0;
  padding-left: 18px;
}
.ct-list li{ margin: 8px 0; opacity: .86; }

/* Form */
.ct-form-wrap{
  border-radius: 24px;
  overflow: hidden;
  background: #ffffff;
  border: 1px solid rgba(0,0,0,.05);
  box-shadow:
    0 30px 80px rgba(0,0,0,.12),
    0 6px 18px rgba(0,0,0,.06);
}
.ct-form-head{
  padding: 18px;
  border-bottom: 1px solid rgba(0,0,0,.08);
  background: linear-gradient(180deg, rgba(30,136,255,.06), transparent);
}

.ct-form{
  padding: 18px;
}

.ct-row{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 12px;
}

.ct-field{
  display: grid;
  gap: 6px;
}

.ct-field span{
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  opacity: .70;
}

.ct-field input,
.ct-field select,
.ct-field textarea{
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.12);
  background: #fff;
  color: #111;
  padding: 12px 12px;
  outline: none;
}

.ct-field textarea{ resize: vertical; }

.ct-field input:focus,
.ct-field select:focus,
.ct-field textarea:focus{
  border-color: rgba(30,136,255,.55);
  box-shadow: 0 0 0 4px rgba(30,136,255,.12);
}

.ct-row--bottom{
  align-items: center;
  grid-template-columns: 1fr auto;
}

.ct-check{
  display: inline-flex;
  gap: 10px;
  align-items: center;
  user-select: none;
  opacity: .86;
}
.ct-check input{ width: 18px; height: 18px; }

.ct-actions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.ct-footnote{
  margin: 12px 0 0;
  opacity: .66;
  font-size: 12px;
  line-height: 1.5;
}

/* Toast */
.ct-toast{
  margin-top: 12px;
  display: none;
  border-radius: 14px;
  padding: 12px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(30,136,255,.08);
}
.ct-toast.is-show{ display: block; }

/* Map */
.ct-map{
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 12px 32px rgba(0,0,0,.08);
  background: #fff;
}
.ct-map iframe{
  width: 100%;
  height: min(420px, 60vh);
  border: 0;
  display: block;
}

/* Responsive */
@media (max-width: 980px){
  .ct-grid{ grid-template-columns: 1fr; }
  .ct-row--bottom{ grid-template-columns: 1fr; }
  .ct-actions{ justify-content: flex-start; }
}

@media (max-width: 768px){
  .ct-hero{ padding-top: var(--header-h-m); }
  .ct-title{ max-width: 26ch; }
  .ct-row{ grid-template-columns: 1fr; }
}
/* ===============================
   CONTACTO – Ajustes premium
   =============================== */

/* Botones ghost mejorados */
.ct-card .btn.ghost{
  background: transparent;
  border: 1px solid rgba(0,0,0,.12);
  color: #111;
  box-shadow: none;
}

.ct-card .btn.ghost:hover{
  background: rgba(0,0,0,.05);
}

/* Eliminar cualquier botón vacío raro */
.ct-card .btn:empty{
  display: none;
}
 .section {
  background: #f6f8fb;
}
.ct-field input,
.ct-field select,
.ct-field textarea{
  border-radius: 16px;
  border: 1px solid rgba(0,0,0,.10);
  background: #ffffff;
  padding: 14px 14px;
  transition: all .2s ease;
}

.ct-field input:focus,
.ct-field select:focus,
.ct-field textarea:focus{
  border-color: rgba(30,136,255,.65);
  box-shadow: 0 0 0 4px rgba(30,136,255,.12);
}
/* ===========================
   FIX botón ghost en contacto
   =========================== */

.ct-form .btn.ghost{
  background: #f2f4f7;            /* gris claro elegante */
  color: #111;                    /* texto visible */
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 999px;
  padding: 14px 24px;
  box-shadow: none;
}

.ct-form .btn.ghost:hover{
  background: #e6e9ee;
}
.contact-form{
background:white;
padding:25px;
border-radius:10px;
box-shadow:0 6px 18px rgba(0,0,0,0.08);
}
/* WhatsApp links */
.wa-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:inherit;
  text-decoration:none;
}

.wa-link:hover{
  color:#25D366;
  text-decoration:none;
}

.wa-icon{
  width:18px;
  height:18px;
  display:inline-block;
  object-fit:contain;
  flex-shrink:0;
}