.elementor-3447 .elementor-element.elementor-element-755e1eb{--display:flex;}/* Start custom CSS for html, class: .elementor-element-a117d9f */*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background: #060a12;
  color: #e8eef6;
  font-family: 'DM Sans', system-ui, sans-serif;
  font-weight: 300;
  line-height: 1.65;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
 
.page-bg { position: relative; overflow: hidden; }
.page-bg::before {
  content: '';
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(90,154,255,0.032) 1px, transparent 1px),
    linear-gradient(90deg, rgba(90,154,255,0.032) 1px, transparent 1px);
  background-size: 80px 80px;
}
.page-bg::after {
  content: '';
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background-image: url('https://kannuh.com/wp-content/uploads/2026/03/cropped-kannuhsemifc.png');
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 600px auto;
  opacity: 0.03;
  filter: grayscale(1) brightness(3);
}
 
:root {
  --blue:      #1a4db5;
  --blue-mid:  #2d6ae0;
  --blue-hi:   #5a9aff;
  --blue-pale: #9dc4ff;
  --platinum:  #cdd8ea;
  --muted:     rgba(160,190,224,0.48);
  --glass:     rgba(255,255,255,0.032);
  --gbdr:      rgba(90,154,255,0.14);
  --gsheen:    rgba(160,200,255,0.22);
  --serif:     'Cormorant Garamond', Georgia, serif;
  --sans:      'DM Sans', system-ui, sans-serif;
  --ease:      cubic-bezier(.22,1,.36,1);
  --max:       1100px;
}
 
.wrap { max-width: var(--max); margin: 0 auto; padding: 0 44px; position:relative; z-index:1; }
section { position:relative; z-index:1; }
 
.label {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 11px; font-weight: 400; letter-spacing: 3px; text-transform: uppercase;
  color: var(--blue-pale); margin-bottom: 18px;
}
.label::before { content: ''; width: 20px; height: 1px; background: var(--blue-hi); display: inline-block; }
 
h2.section-title {
  font-family: var(--serif);
  font-size: clamp(32px, 5vw, 58px);
  font-weight: 400; line-height: 1.05; letter-spacing: -0.5px;
}
h2.section-title strong { font-weight: 600; }
 
.divider {
  height: 1px; margin: 0 44px;
  background: linear-gradient(90deg, transparent, rgba(90,154,255,0.15), transparent);
}
 
.reveal { opacity:0; transform:translateY(36px); transition: opacity .85s var(--ease), transform .85s var(--ease); }
.reveal.visible { opacity:1; transform:none; }
.d1{transition-delay:.1s} .d2{transition-delay:.2s} .d3{transition-delay:.3s} .d4{transition-delay:.4s}
 
@keyframes fadeup { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:none} }
@keyframes heroOrb {
  from { opacity:.7; transform:translateX(-50%) scale(1); }
  to   { opacity:1;  transform:translateX(-50%) scale(1.1); }
}
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes checkpop {
  0%   { transform: scale(0) rotate(-20deg); opacity:0; }
  70%  { transform: scale(1.2) rotate(5deg); opacity:1; }
  100% { transform: scale(1) rotate(0deg); opacity:1; }
}
 
/* ══ HERO ══ */
.s1 {
  padding: 120px 44px 90px;
  text-align: center;
  position: relative; overflow: hidden;
}
.s1-orb1 {
  position: absolute; border-radius: 50%; pointer-events: none;
  width: 800px; height: 500px;
  background: radial-gradient(ellipse, rgba(26,77,181,0.5) 0%, transparent 65%);
  top: -100px; left: 50%; transform: translateX(-50%);
  filter: blur(80px);
  animation: heroOrb 10s ease-in-out infinite alternate;
}
.s1-orb2 {
  position: absolute; border-radius: 50%; pointer-events: none;
  width: 500px; height: 300px;
  background: radial-gradient(ellipse, rgba(80,40,160,0.3) 0%, transparent 65%);
  top: 0; right: -100px;
  filter: blur(80px);
  animation: heroOrb 14s ease-in-out infinite alternate-reverse;
}
.s1-eyebrow {
  display: inline-block;
  font-size: 11px; font-weight: 400; letter-spacing: 4px; text-transform: uppercase;
  color: var(--muted); margin-bottom: 28px;
  animation: fadeup .9s var(--ease) both;
}
.s1 h1 {
  font-family: var(--serif);
  font-size: clamp(48px, 8vw, 100px);
  font-weight: 300; line-height: 0.95; letter-spacing: -2px;
  margin-bottom: 10px;
  animation: fadeup .9s var(--ease) .07s both;
}
.s1 h1 .line2 { font-style: italic; font-weight: 300; color: rgba(255,255,255,0.55); }
.s1-tagline {
  font-family: var(--serif);
  font-size: clamp(16px, 2vw, 22px);
  font-weight: 300; font-style: italic;
  color: var(--muted);
  margin: 20px auto 0; max-width: 520px;
  animation: fadeup .9s var(--ease) .14s both;
}
 
/* ══ SECCIÓN CONTACTO + FAQ ══ */
.s2 { padding: 80px 44px 100px; }
.s2-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: start; }
 
/* ── FORMULARIO ── */
.form-card {
  background: var(--glass);
  border: 1px solid var(--gbdr);
  border-radius: 20px;
  padding: 44px 40px;
  backdrop-filter: blur(14px);
  position: relative; overflow: hidden;
}
.form-card::before {
  content: '';
  position: absolute; top:0; left:0; right:0; height:1px;
  background: linear-gradient(90deg,transparent,var(--gsheen),transparent);
}
.form-card h2 {
  font-family: var(--serif);
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 400; line-height: 1.1;
  margin-bottom: 8px;
}
.form-card h2 strong { font-weight: 600; }
.form-subtitle {
  font-size: 14px; color: var(--muted); margin-bottom: 32px; line-height: 1.6;
}
 
.field { display: flex; flex-direction: column; gap: 8px; margin-bottom: 18px; }
.field label { font-size: 12px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--blue-pale); font-weight: 400; }
.field input,
.field textarea,
.field select {
  background: #ffffff;
  border: 1px solid rgba(90,154,255,0.18);
  border-radius: 10px;
  color: #0d1525 !important;          /* ← agregá el !important */
  font-family: var(--sans); font-size: 15px; font-weight: 400;  /* ← weight 400 en lugar de 300 */
  padding: 13px 16px;
  outline: none;
  transition: border-color .2s, background .2s, box-shadow .2s;
  width: 100%;
  resize: none;
  -webkit-text-fill-color: #0d1525;   /* ← esto es clave en Safari/Chrome */
}
.field input::placeholder,
.field textarea::placeholder {
  color: rgba(13,21,37,0.4);                 /* placeholder gris oscuro suave */
  opacity: 1;
}
.field input:focus,
.field textarea:focus,
.field select:focus {
  border-color: rgba(26,77,181,0.5);
  background: #ffffff;
  box-shadow: 0 0 0 3px rgba(90,154,255,0.12);
}

.field select option {
  background: #ffffff;
  color: #0d1525;
}
.field textarea { min-height: 120px; }
 
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
 
.btn-submit {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  width: 100%; margin-top: 8px;
  background: #fff; color: #060a12;
  font-family: var(--sans); font-size: 14px; font-weight: 500; letter-spacing: 0.5px;
  padding: 15px 28px; border-radius: 100px;
  border: none; cursor: pointer;
  box-shadow: 0 0 40px rgba(255,255,255,0.1);
  transition: all .35s var(--ease);
  position: relative; overflow: hidden;
}
.btn-submit:hover { background: var(--blue-pale); box-shadow: 0 0 60px rgba(157,196,255,0.3); transform: translateY(-2px); }
.btn-submit:active { transform: translateY(0); }
.btn-submit .arr {
  width: 26px; height: 26px; border-radius: 50%;
  background: #060a12; display: flex; align-items: center; justify-content: center;
  font-size: 13px; transition: transform .3s;
}
.btn-submit:hover .arr { transform: translateX(3px); }
 
/* Estado de carga */
.btn-submit.loading { pointer-events: none; opacity: .7; }
.btn-submit.loading .btn-text { opacity: 0; }
.btn-submit .spinner {
  display: none; width: 18px; height: 18px;
  border: 2px solid rgba(6,10,18,0.3);
  border-top-color: #060a12;
  border-radius: 50%;
  position: absolute;
  animation: spin .6s linear infinite;
}
.btn-submit.loading .spinner { display: block; }
 
/* Estado de éxito */
.form-success {
  display: none;
  text-align: center; padding: 48px 20px;
}
.form-success.show { display: block; }
.form-success-icon {
  width: 64px; height: 64px; border-radius: 50%;
  background: rgba(0,180,90,0.12);
  border: 1px solid rgba(0,180,90,0.3);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 20px;
  animation: checkpop .5s var(--ease) both;
}
.form-success-icon svg { width: 28px; height: 28px; }
.form-success h3 {
  font-family: var(--serif); font-size: 28px; font-weight: 400;
  margin-bottom: 10px; color: var(--platinum);
}
.form-success p { font-size: 14px; color: var(--muted); line-height: 1.7; }
 
/* ── FAQ ── */
.faq-col { display: flex; flex-direction: column; gap: 0; }
.faq-col h2 {
  font-family: var(--serif);
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 400; margin-bottom: 8px;
}
.faq-col h2 strong { font-weight: 600; }
.faq-subtitle { font-size: 14px; color: var(--muted); margin-bottom: 32px; line-height: 1.6; }
 
.faq-item {
  border-bottom: 1px solid rgba(90,154,255,0.1);
  overflow: hidden;
}
.faq-item:first-of-type { border-top: 1px solid rgba(90,154,255,0.1); }
 
.faq-q {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 20px 0;
  cursor: pointer;
  font-size: 15px; font-weight: 400; color: var(--platinum);
  transition: color .2s;
  background: none; border: none; width: 100%; text-align: left;
  font-family: var(--sans);
}
.faq-q:hover { color: #fff; }
.faq-icon {
  width: 28px; height: 28px; flex-shrink: 0;
  border-radius: 50%;
  border: 1px solid rgba(90,154,255,0.25);
  background: rgba(26,77,181,0.12);
  display: flex; align-items: center; justify-content: center;
  transition: all .3s var(--ease);
}
.faq-icon svg { width: 12px; height: 12px; stroke: var(--blue-hi); transition: transform .3s var(--ease); }
.faq-item.open .faq-icon {
  background: transparent;
  border-color: rgba(90,154,255,0.25);
}

.faq-q:hover .faq-icon {
  background: transparent;
}
.faq-a {
  max-height: 0; overflow: hidden;
  transition: max-height .4s var(--ease), padding .3s var(--ease);
}
.faq-a-inner {
  padding: 0 0 20px;
  font-size: 14px; color: var(--muted); line-height: 1.8;
}
.faq-item.open .faq-a { max-height: 200px; }
 
/* ══ RESPONSIVE ══ */
@media(max-width:900px){
  .s2-grid { grid-template-columns: 1fr; gap: 40px; }
  .field-row { grid-template-columns: 1fr; }
  .wrap,.s1,.s2 { padding-left:20px; padding-right:20px; }
  .form-card { padding: 32px 24px; }
}
/* ── Neutralizar hover de WordPress/Elementor sobre botones FAQ ── */
.faq-q,
.faq-q:hover,
.faq-q:focus,
.faq-q:active,
.faq-q:focus-visible {
  background: none !important;
  background-color: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  outline: none !important;
  color: var(--platinum);
}

.faq-q:hover {
  color: #fff !important;
}/* End custom CSS */