:root{
  --violet:#6A0572;
  --red:#F74436;
  --gold:#F08E03;
  --dark:#1E1E2F;
  --white:#ffffff;
  --glass:rgba(255,255,255,.10);
  --glass2:rgba(255,255,255,.14);
  --border:rgba(255,255,255,.18);
  --shadow:0 18px 50px rgba(0,0,0,.25);
  --radius:22px;
  --transition: all .25s ease;
}

.comunidad-hero{
  min-height: calc(100vh - 80px);
  padding: 120px 16px 70px;
  position: relative;
  background: linear-gradient(135deg, rgba(30,30,47,1), rgba(106,5,114,.95));
  overflow: hidden;
}

.comunidad-hero-bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 20% 15%, rgba(240,142,3,.20) 0%, transparent 45%),
    radial-gradient(circle at 85% 70%, rgba(247,68,54,.18) 0%, transparent 45%),
    radial-gradient(circle at 55% 35%, rgba(255,255,255,.08) 0%, transparent 55%);
  pointer-events:none;
  opacity: 1;
}

.comunidad-wrap{
  position: relative;
  z-index: 2;
  max-width: 980px;
  margin: 0 auto;
}

.comunidad-card{
  background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.06));
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  border-radius: var(--radius);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  padding: 42px 36px;
  animation: fadeUp .6s ease both;
}

@keyframes fadeUp{
  from{ opacity:0; transform: translateY(14px); }
  to{ opacity:1; transform: translateY(0); }
}

.comunidad-title{
  font-size: clamp(2.1rem, 4.6vw, 3.2rem);
  line-height: 1.08;
  margin: 0 0 14px;
  font-weight: 900;
  letter-spacing: -0.02em;
  background: linear-gradient(135deg, #fff, var(--gold), #fff);
  background-size: 200% 200%;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  animation: glowMove 5s ease-in-out infinite;
}

@keyframes glowMove{
  0%,100%{ background-position: 0% 50%; }
  50%{ background-position: 100% 50%; }
}

.comunidad-lead{
  color: rgba(255,255,255,.92);
  font-size: 1.15rem;
  line-height: 1.6;
  margin: 0 0 10px;
}

.comunidad-sub{
  color: rgba(255,255,255,.82);
  margin: 0 0 24px;
  line-height: 1.7;
}

.comunidad-form{
  margin-top: 10px;
}

.form-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 14px;
  margin-bottom: 14px;
}

.field label{
  display:block;
  color: rgba(255,255,255,.86);
  font-size: .92rem;
  margin-bottom: 6px;
  font-weight: 600;
}

.req{ color: var(--gold); }

.field input{
  width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.18);
  color: var(--white);
  outline: none;
  transition: var(--transition);
}

.field input::placeholder{
  color: rgba(255,255,255,.55);
}

.field input:focus{
  border-color: rgba(240,142,3,.55);
  box-shadow: 0 0 0 4px rgba(240,142,3,.12);
  background: rgba(0,0,0,.22);
}

.consent{
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,.14);
}

.check{
  display:flex;
  gap: 10px;
  align-items: flex-start;
  color: rgba(255,255,255,.86);
  font-size: .95rem;
  line-height: 1.45;
}

.check input{
  margin-top: 4px;
  width: 18px;
  height: 18px;
  accent-color: var(--gold);
}

.check a{
  color: var(--gold);
  text-decoration: none;
  font-weight: 700;
}

.check a:hover{ text-decoration: underline; }

.hint{
  margin: 10px 0 6px;
  color: rgba(255,255,255,.85);
  font-size: .92rem;
}

.legal{
  margin: 0;
  color: rgba(255,255,255,.74);
  font-size: .92rem;
  line-height: 1.6;
}

.btn-submit{
  margin-top: 16px;
  width: 100%;
  padding: 14px 18px;
  border: none;
  border-radius: 16px;
  font-weight: 900;
  letter-spacing: .6px;
  color: #fff;
  cursor: pointer;
  background: linear-gradient(135deg, var(--violet), var(--red));
  box-shadow: 0 14px 40px rgba(0,0,0,.25);
  transition: var(--transition);
  text-transform: uppercase;
}

.btn-submit:hover{
  transform: translateY(-2px);
  background: linear-gradient(135deg, var(--red), var(--gold));
}

.btn-submit:active{
  transform: translateY(0);
}

/* Responsive */
@media (max-width: 768px){
  .comunidad-card{ padding: 32px 18px; }
  .form-grid{ grid-template-columns: 1fr; }
  .comunidad-hero{ padding-top: 110px; }
}
.alert-success {
  margin-bottom: 20px;
  padding: 14px 18px;
  border-radius: 14px;
  background: linear-gradient(135deg, #6A0572, #F74436);
  color: white;
  font-weight: 600;
  box-shadow: 0 10px 25px rgba(0,0,0,0.15);
}

.alert-error {
  margin-bottom: 20px;
  padding: 14px 18px;
  border-radius: 14px;
  background: rgba(255, 0, 0, 0.08);
  border: 1px solid rgba(255, 0, 0, 0.25);
  color: #b30000;
}

.alert-error ul {
  padding-left: 18px;
  margin: 0;
}
/* ===== Layout Grid ===== */
.comunidad-grid{
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 40px;
  align-items: center;
}

/* ===== Visual ===== */
.comunidad-visual{
  position: relative;
  min-height: 520px;
  display: flex;
  justify-content: center;
  align-items: center;
}

/* Glow effects */
.glow{
  position: absolute;
  width: 380px;
  height: 380px;
  border-radius: 50%;
  filter: blur(60px);
  opacity: .3;
}
.glow-1{ background: #F74436; right: -80px; top: 40px; }
.glow-2{ background: #6A0572; left: -60px; bottom: 20px; }

/* ===== Phone Mockup ===== */
.phone{
  width: 280px;
  height: 560px;
  border-radius: 34px;
  background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.05));
  border: 1px solid rgba(255,255,255,.15);
  box-shadow: 0 25px 70px rgba(0,0,0,.35);
  position: relative;
  overflow: hidden;
}

.phone-notch{
  position:absolute;
  top: 14px;
  left: 50%;
  transform: translateX(-50%);
  width: 120px;
  height: 26px;
  border-radius: 18px;
  background: rgba(0,0,0,.4);
}

.phone-screen{
  position:absolute;
  inset: 54px 16px 18px 16px;
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(30,30,47,.6), rgba(106,5,114,.4));
  padding: 16px;
}

.phone-badge{
  display:inline-block;
  font-weight: 700;
  font-size: .95rem;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.12);
  color: #fff;
}

.phone-line{
  height: 10px;
  border-radius: 999px;
  margin-top: 14px;
  background: rgba(255,255,255,.15);
}
.phone-line.w80{ width: 80%; }
.phone-line.w70{ width: 70%; }
.phone-line.w60{ width: 60%; }
.phone-line.w50{ width: 50%; }

.phone-mini-card{
  margin-top: 22px;
  padding: 14px;
  border-radius: 16px;
  background: rgba(0,0,0,.25);
  display:flex;
  gap: 10px;
}
.phone-mini-card .dot{
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #F74436;
}

.phone-cta{
  position:absolute;
  left: 16px;
  right: 16px;
  bottom: 16px;
  text-align: center;
  font-weight: 800;
  padding: 12px;
  border-radius: 16px;
  background: linear-gradient(135deg, #6A0572, #F74436);
  color: #fff;
}

@media (max-width: 992px){
  .comunidad-grid{
    grid-template-columns: 1fr;
    gap: 18px;
    align-items: start;
  }

  /* ✅ Mostrar el visual en móvil */
  .comunidad-visual{
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: auto;
    order: -1; /* lo sube arriba del formulario */
    padding: 8px 0 2px;
  }

  /* ✅ Celular más pequeño */
  .phone{
    width: 220px;
    height: 440px;
    border-radius: 28px;
  }

  .phone-screen{
    inset: 48px 12px 14px 12px;
    border-radius: 18px;
    padding: 12px;
  }

  .glow{
    width: 260px;
    height: 260px;
    filter: blur(50px);
    opacity: .28;
  }
}
/* =========================
   SELECT2 - FIX ESTILO ESCOLI
   (Pegar AL FINAL)
========================= */

.select2-container { width: 100% !important; }

/* Caja */
.select2-container--default .select2-selection--single{
  height: 46px !important;
  border-radius: 14px !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  background: rgba(0,0,0,.18) !important;
  display: flex !important;
  align-items: center !important;
}

/* Texto seleccionado */
.select2-container--default .select2-selection--single .select2-selection__rendered{
  color: rgba(255,255,255,.92) !important;
  line-height: 46px !important;
  padding-left: 14px !important;
  padding-right: 40px !important;
}

/* Flecha */
.select2-container--default .select2-selection--single .select2-selection__arrow{
  height: 46px !important;
  right: 10px !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow b{
  border-color: rgba(255,255,255,.75) transparent transparent transparent !important;
}

/* Focus dorado */
.select2-container--default.select2-container--focus .select2-selection--single{
  border-color: rgba(240,142,3,.55) !important;
  box-shadow: 0 0 0 4px rgba(240,142,3,.12) !important;
  background: rgba(0,0,0,.22) !important;
}

/* Dropdown (lo que te sale blanco) */
.select2-dropdown{
  background: rgba(30,30,47,.98) !important;
  border: 1px solid rgba(255,255,255,.15) !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  box-shadow: 0 18px 50px rgba(0,0,0,.35) !important;
}

/* Lista */
.select2-results { background: transparent !important; }

.select2-container--default .select2-results__option{
  color: rgba(255,255,255,.92) !important;
  padding: 10px 12px !important;
}

/* Hover */
.select2-container--default .select2-results__option--highlighted.select2-results__option--selectable{
  background: rgba(240,142,3,.18) !important;
  color: #fff !important;
}

/* Seleccionado */
.select2-container--default .select2-results__option--selected{
  background: rgba(106,5,114,.35) !important;
  color: #fff !important;
}

/* Buscador arriba */
.select2-container--default .select2-search--dropdown{
  padding: 10px !important;
  background: rgba(30,30,47,.98) !important;
}
.select2-container--default .select2-search--dropdown .select2-search__field{
  border-radius: 14px !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  background: rgba(0,0,0,.25) !important;
  color: #fff !important;
  padding: 10px 12px !important;
  outline: none !important;
}
.select2-container--default .select2-search--dropdown .select2-search__field::placeholder{
  color: rgba(255,255,255,.55) !important;
}