/* ============================================================
   RINSA EXPERIENCES — LANDING DE MISIONES
   landing.css · v1.0 · Mayo 2026
   Sistema de diseño: mismo lenguaje visual de exp/css/styles.css
   ============================================================ */

/* ── VARIABLES (mismas que exp/css/styles.css) ─────────────── */
:root {
  --azul:          #1A3A6B;
  --azul-mid:      #1E4580;
  --azul-dark:     #102850;
  --azul-light:    #EDF2FA;
  --rojo:          #B01C2E;
  --rojo-hover:    #8C1521;
  --rojo-claro:    #FDF0F1;
  --verde:         #2D6A4F;
  --verde-hover:   #1F5239;
  --verde-claro:   #EAF4EE;
  --verde-glass:   rgba(45,106,79,.15);
  --crema:         #FAF8F5;
  --negro:         #0D0D0D;
  --gris-osc:      #333333;
  --gris-med:      #666666;
  --gris-claro:    #CCCCCC;
  --gris-fondo:    #F0EFED;
  --blanco:        #FFFFFF;
  --ambar:         #A0620A;
  --ambar-claro:   #FEF3E2;

  --font-head: 'Plus Jakarta Sans', system-ui, sans-serif;
  --font-body: 'Inter', system-ui, sans-serif;

  --radius:    8px;
  --radius-lg: 14px;
  --radius-xl: 20px;
  --shadow-sm: 0 2px 8px rgba(0,0,0,.06);
  --shadow:    0 4px 20px rgba(0,0,0,.10);
  --shadow-lg: 0 12px 48px rgba(0,0,0,.15);
  --tr:        .25s cubic-bezier(.4,0,.2,1);
  --tr-slow:   .4s cubic-bezier(.4,0,.2,1);
}

/* ── RESET ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;scroll-padding-top:76px}
body{font-family:var(--font-body);color:var(--gris-osc);background:var(--crema);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,select,textarea{font-family:inherit}
.container{max-width:1200px;margin:0 auto;padding:0 28px}

/* ── SCROLL REVEAL ─────────────────────────────────────────── */
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
[data-reveal].visible{opacity:1;transform:none}

/* ── LOADER ─────────────────────────────────────────────────── */
.page-loader{position:fixed;inset:0;z-index:9999;background:linear-gradient(135deg,var(--azul-dark) 0%,var(--azul) 60%,var(--verde-hover) 100%);display:flex;align-items:center;justify-content:center;transition:opacity .5s ease}
.page-loader.fade-out{opacity:0;pointer-events:none}
.loader-inner{text-align:center}
.loader-logo{font-family:var(--font-head);font-weight:800;font-size:1.6rem;color:var(--blanco);letter-spacing:.04em;margin-bottom:24px}
.loader-logo span{color:rgba(255,255,255,.55);font-weight:500}
.loader-spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.2);border-top-color:var(--verde);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── NOT FOUND ──────────────────────────────────────────────── */
.not-found{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--azul-dark),var(--azul));text-align:center;padding:40px 24px}
.not-found-inner{max-width:480px}
.not-found-logo{font-family:var(--font-head);font-weight:800;font-size:1.2rem;color:var(--blanco);margin-bottom:32px;letter-spacing:.04em}
.not-found-logo span{color:rgba(255,255,255,.5);font-weight:500}
.not-found h1{font-family:var(--font-head);font-size:1.6rem;color:var(--blanco);margin-bottom:12px}
.not-found p{color:rgba(255,255,255,.65);margin-bottom:28px;line-height:1.7}

/* ── BOTONES ────────────────────────────────────────────────── */
.btn-primary{display:inline-flex;align-items:center;gap:9px;background:var(--rojo);color:var(--blanco);font-family:var(--font-head);font-weight:700;font-size:.95rem;padding:14px 30px;border-radius:var(--radius);transition:var(--tr);box-shadow:0 4px 18px rgba(176,28,46,.35);border:none;cursor:pointer}
.btn-primary:hover{background:var(--rojo-hover);transform:translateY(-2px);box-shadow:0 8px 32px rgba(176,28,46,.45)}
.btn-primary svg{flex-shrink:0;transition:transform var(--tr)}
.btn-primary:hover svg{transform:translateX(3px)}

.btn-ghost{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.85);font-weight:600;font-size:.92rem;padding:14px 26px;border-radius:var(--radius);border:1.5px solid rgba(255,255,255,.3);transition:var(--tr);backdrop-filter:blur(8px)}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.55)}

.btn-verde{display:inline-flex;align-items:center;gap:8px;background:var(--verde);color:var(--blanco);font-family:var(--font-head);font-weight:700;font-size:.95rem;padding:14px 30px;border-radius:var(--radius);transition:var(--tr);border:none;cursor:pointer;box-shadow:0 4px 16px rgba(45,106,79,.35)}
.btn-verde:hover{background:var(--verde-hover);transform:translateY(-2px)}

.btn-wa{display:inline-flex;align-items:center;gap:9px;background:#25D366;color:var(--blanco);font-family:var(--font-head);font-weight:700;font-size:.95rem;padding:14px 30px;border-radius:var(--radius);transition:var(--tr);box-shadow:0 4px 16px rgba(37,211,102,.35)}
.btn-wa:hover{background:#1DA851;transform:translateY(-2px)}

.btn-lg{font-size:1.05rem!important;padding:17px 38px!important}
.btn-block{width:100%;justify-content:center}

/* ── TAG ────────────────────────────────────────────────────── */
.tag{display:inline-flex;align-items:center;gap:7px;font-size:.72rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;background:var(--verde-claro);color:var(--verde);padding:5px 14px;border-radius:20px;border:1px solid rgba(45,106,79,.2)}
.tag-light{background:rgba(255,255,255,.12);color:rgba(255,255,255,.9);border-color:rgba(255,255,255,.2)}
.tag-azul{background:var(--azul-light);color:var(--azul);border-color:rgba(26,58,107,.15)}
.tag-ambar{background:var(--ambar-claro);color:var(--ambar);border-color:rgba(160,98,10,.2)}

/* ── BADGE STATUS ───────────────────────────────────────────── */
.status-badge{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:700;padding:5px 13px;border-radius:20px;letter-spacing:.06em;text-transform:uppercase}
.status-badge.convocatoria{background:rgba(45,106,79,.9);color:#fff}
.status-badge.programada{background:rgba(26,58,107,.9);color:#fff}
.status-badge.completo{background:rgba(176,28,46,.9);color:#fff}
.status-dot{width:6px;height:6px;border-radius:50%;background:currentColor;animation:blink 1.4s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* ── SECTION BASE ───────────────────────────────────────────── */
.section-header{text-align:center;max-width:700px;margin:0 auto 56px}
.section-header .tag{margin-bottom:12px}
.section-header h2{font-family:var(--font-head);font-size:clamp(1.75rem,3vw,2.4rem);font-weight:800;color:var(--azul);margin-bottom:14px;line-height:1.2}
.section-header p{color:var(--gris-med);font-size:1rem;line-height:1.75}
.section-header.light h2{color:var(--blanco)}
.section-header.light p{color:rgba(255,255,255,.7)}

/* ════════════════════════════════════════════════════════════
   NAVBAR
════════════════════════════════════════════════════════════ */
.navbar{position:sticky;top:0;z-index:100;background:rgba(250,248,245,.9);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid rgba(45,106,79,.1);transition:var(--tr)}
.navbar.scrolled{background:rgba(250,248,245,.97);box-shadow:0 4px 24px rgba(0,0,0,.08)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:70px;gap:16px}
.nav-logo{display:flex;align-items:center;gap:8px;font-family:var(--font-head);font-weight:800;font-size:.95rem;color:var(--azul);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}
.nav-logo svg{color:var(--verde);flex-shrink:0}
.nav-logo-badge{background:var(--verde);color:var(--blanco);font-size:.6rem;padding:3px 9px;border-radius:20px;font-weight:700;letter-spacing:.05em}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a{color:var(--gris-osc);font-size:.84rem;font-weight:500;padding:7px 12px;border-radius:var(--radius);transition:var(--tr);white-space:nowrap}
.nav-links a:hover{color:var(--verde);background:var(--verde-claro)}
.nav-cta{display:inline-flex;align-items:center;gap:7px;background:#25D366;color:var(--blanco)!important;font-weight:700!important;font-size:.84rem;padding:9px 16px;border-radius:var(--radius);transition:var(--tr);white-space:nowrap;flex-shrink:0}
.nav-cta:hover{background:#1DA851;transform:translateY(-1px)}
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px}
.hamburger span{display:block;width:22px;height:2px;background:var(--azul);border-radius:2px;transition:var(--tr)}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

@media(max-width:820px){
  .nav-links{display:none;position:fixed;top:70px;left:0;right:0;background:rgba(250,248,245,.98);backdrop-filter:blur(18px);padding:16px 20px 20px;flex-direction:column;align-items:stretch;border-bottom:2px solid var(--verde-claro);box-shadow:0 8px 24px rgba(0,0,0,.1);z-index:99}
  .nav-links.open{display:flex}
  .nav-links a{padding:12px 16px;border-radius:var(--radius);font-size:.95rem}
  .hamburger{display:flex}
}

/* ════════════════════════════════════════════════════════════
   HERO
════════════════════════════════════════════════════════════ */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden;background:var(--azul-dark)}
.hero-bg{position:absolute;inset:0}
.hero-img{width:100%;height:100%;object-fit:cover;object-position:center;opacity:.35}
.hero-overlay{position:absolute;inset:0;background:
  linear-gradient(to right,rgba(16,40,80,.92) 0%,rgba(16,40,80,.7) 50%,rgba(16,40,80,.45) 100%),
  linear-gradient(to top,rgba(16,40,80,.8) 0%,transparent 50%)}
.hero-content{position:relative;z-index:1;width:100%;padding:90px 0 72px}
.hero-inner{max-width:760px}
.hero-badge-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:20px}
.hero-title{font-family:var(--font-head);font-size:clamp(2.2rem,5vw,4rem);font-weight:800;line-height:1.1;color:var(--blanco);margin-bottom:10px}
.hero-title .hl{background:linear-gradient(135deg,#5FD99A 0%,#2D6A4F 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-subtitle{font-family:var(--font-head);font-size:clamp(1.05rem,2vw,1.35rem);font-weight:500;color:rgba(255,255,255,.7);margin-bottom:28px;line-height:1.45}
.hero-meta{display:flex;flex-wrap:wrap;gap:18px;margin-bottom:36px}
.hero-meta-item{display:flex;align-items:center;gap:7px;font-size:.88rem;color:rgba(255,255,255,.75)}
.hero-meta-item svg{color:var(--verde);flex-shrink:0}
.hero-stats-bar{display:flex;gap:0;background:rgba(255,255,255,.08);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-xl);padding:18px 0;max-width:580px;margin-bottom:36px}
.hero-stat{flex:1;text-align:center;border-right:1px solid rgba(255,255,255,.1)}
.hero-stat:last-child{border-right:none}
.hero-stat strong{display:block;font-family:var(--font-head);font-weight:800;font-size:clamp(1.3rem,2.5vw,1.9rem);color:var(--blanco);line-height:1}
.hero-stat span{font-size:.7rem;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.08em;margin-top:4px;display:block}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.hero-scroll-hint{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:5px;opacity:.4}
.hero-scroll-hint span{font-size:.65rem;color:var(--blanco);letter-spacing:.12em;text-transform:uppercase}
.hero-scroll-line{width:1px;height:28px;background:linear-gradient(to bottom,rgba(255,255,255,.6),transparent);animation:scrollPulse 2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{opacity:.4;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.15)}}

@media(max-width:640px){
  .hero{min-height:100svh}
  .hero-stats-bar{flex-wrap:wrap;max-width:100%}
  .hero-stat{flex:0 0 50%;border-right:none;border-bottom:1px solid rgba(255,255,255,.1);padding:10px 0}
  .hero-stat:nth-child(odd){border-right:1px solid rgba(255,255,255,.1)}
  .hero-stat:last-child{border-bottom:none}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .hero-actions .btn-primary,.hero-actions .btn-ghost{width:100%;justify-content:center}
}

/* ════════════════════════════════════════════════════════════
   SECCIÓN: ¿QUÉ ES ESTA MISIÓN?
════════════════════════════════════════════════════════════ */
.section-mision{padding:88px 0;background:var(--blanco)}
.mision-layout{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.mision-desc .tag{margin-bottom:16px}
.mision-desc h2{font-family:var(--font-head);font-size:clamp(1.6rem,2.8vw,2.1rem);font-weight:800;color:var(--azul);margin-bottom:18px;line-height:1.2}
.mision-desc p{color:var(--gris-med);font-size:1rem;line-height:1.8;margin-bottom:20px}
.publico-title{font-family:var(--font-head);font-weight:700;font-size:.82rem;color:var(--azul);text-transform:uppercase;letter-spacing:.07em;margin-bottom:10px}
.publico-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}
.publico-list li{display:flex;align-items:center;gap:10px;font-size:.88rem;color:var(--gris-osc)}
.publico-list li svg{color:var(--verde);flex-shrink:0}
.mision-detalles{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px}
.detalle-chip{display:inline-flex;align-items:center;gap:7px;background:var(--gris-fondo);font-size:.8rem;color:var(--gris-osc);padding:7px 14px;border-radius:var(--radius);border:1px solid rgba(0,0,0,.06)}
.detalle-chip svg{color:var(--verde);flex-shrink:0}

/* Highlights */
.highlights-grid{display:flex;flex-direction:column;gap:18px}
.highlight-card{background:var(--crema);border-radius:var(--radius-lg);padding:24px;border-left:4px solid var(--verde);display:flex;gap:16px;align-items:flex-start;transition:var(--tr)}
.highlight-card:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(45,106,79,.1)}
.hl-icon{width:48px;height:48px;border-radius:12px;background:var(--verde-claro);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hl-icon svg{color:var(--verde)}
.hl-text h4{font-family:var(--font-head);font-weight:700;font-size:.95rem;color:var(--azul);margin-bottom:6px}
.hl-text p{font-size:.84rem;color:var(--gris-med);line-height:1.6}

/* Callout familia */
.nota-familia{background:linear-gradient(135deg,var(--azul-light),rgba(237,242,250,.5));border:1px solid rgba(26,58,107,.15);border-radius:var(--radius-lg);padding:18px 20px;margin-top:20px;display:flex;gap:12px;align-items:flex-start}
.nota-familia svg{color:var(--azul);flex-shrink:0;margin-top:2px}
.nota-familia p{font-size:.87rem;color:var(--azul);line-height:1.6}
.nota-familia strong{font-weight:700}

@media(max-width:900px){.mision-layout{grid-template-columns:1fr;gap:40px}}

/* ════════════════════════════════════════════════════════════
   SECCIÓN: PROGRAMA
════════════════════════════════════════════════════════════ */
.section-programa{padding:88px 0;background:var(--gris-fondo)}
.programa-timeline{max-width:860px;margin:0 auto;position:relative;padding-left:32px}
.programa-timeline::before{content:'';position:absolute;left:11px;top:12px;bottom:12px;width:2px;background:linear-gradient(to bottom,var(--verde),rgba(45,106,79,.15))}
.programa-item{position:relative;margin-bottom:32px}
.programa-item:last-child{margin-bottom:0}
.programa-dot{position:absolute;left:-32px;top:16px;width:22px;height:22px;border-radius:50%;background:var(--blanco);border:2px solid var(--verde);display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:1}
.programa-dot.destacado{background:var(--verde);border-color:var(--verde)}
.programa-dot svg{color:var(--verde);width:10px;height:10px}
.programa-dot.destacado svg{color:var(--blanco)}
.programa-card{background:var(--blanco);border-radius:var(--radius-lg);padding:22px 24px;box-shadow:var(--shadow-sm);transition:var(--tr);border:1px solid transparent}
.programa-card.is-destacado{border-color:rgba(45,106,79,.2);background:linear-gradient(135deg,rgba(234,244,238,.6),var(--blanco))}
.programa-card:hover{box-shadow:var(--shadow);transform:translateX(4px)}
.prog-header{display:flex;align-items:center;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.prog-dia{font-size:.7rem;font-weight:700;color:var(--verde);background:var(--verde-claro);padding:3px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.06em}
.prog-fecha{font-size:.8rem;color:var(--gris-med)}
.prog-destacado-badge{font-size:.67rem;font-weight:700;color:var(--verde);background:var(--verde-claro);padding:2px 9px;border-radius:20px;border:1px solid rgba(45,106,79,.2);letter-spacing:.04em}
.programa-card h4{font-family:var(--font-head);font-weight:700;font-size:1rem;color:var(--azul);margin-bottom:8px}
.programa-card p{font-size:.875rem;color:var(--gris-med);line-height:1.7}

/* ════════════════════════════════════════════════════════════
   SECCIÓN: INCLUYE / NO INCLUYE
════════════════════════════════════════════════════════════ */
.section-incluye{padding:88px 0;background:var(--blanco)}
.incluye-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;max-width:960px;margin:0 auto}
.incluye-col{background:var(--crema);border-radius:var(--radius-xl);padding:28px 28px 24px;border:1px solid rgba(0,0,0,.06)}
.incluye-col-title{font-family:var(--font-head);font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.07em;margin-bottom:18px;display:flex;align-items:center;gap:8px}
.incluye-col-title.si{color:var(--verde)}
.incluye-col-title.no{color:var(--rojo)}
.incluye-list{display:flex;flex-direction:column;gap:11px}
.incluye-item{display:flex;align-items:flex-start;gap:10px;font-size:.875rem;color:var(--gris-osc);line-height:1.55}
.incluye-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.incluye-icon.si{background:#E8F5EE;color:var(--verde)}
.incluye-icon.no{background:var(--rojo-claro);color:var(--rojo)}
.extra-detalles{max-width:960px;margin:28px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.extra-chip{background:var(--gris-fondo);border-radius:var(--radius-lg);padding:16px 18px;display:flex;gap:10px;align-items:flex-start;border:1px solid rgba(0,0,0,.05)}
.extra-chip svg{color:var(--verde);flex-shrink:0;margin-top:2px}
.extra-chip-label{font-size:.72rem;font-weight:700;color:var(--azul);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}
.extra-chip-value{font-size:.83rem;color:var(--gris-osc);line-height:1.5}

@media(max-width:720px){
  .incluye-grid{grid-template-columns:1fr}
  .extra-detalles{grid-template-columns:1fr;gap:12px}
}

/* ════════════════════════════════════════════════════════════
   SECCIÓN: INVERSIÓN / PRECIO
════════════════════════════════════════════════════════════ */
.section-precio{padding:88px 0;background:linear-gradient(135deg,var(--azul-dark) 0%,var(--azul) 60%,var(--verde-hover) 100%);position:relative;overflow:hidden}
.section-precio::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 80% at 20% 50%,rgba(45,106,79,.2) 0%,transparent 60%);pointer-events:none}
.section-precio .section-header{position:relative;z-index:1}
.precio-grid{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1;max-width:860px;margin:0 auto}
.precio-card{background:rgba(255,255,255,.07);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-xl);padding:32px 36px;flex:1;min-width:280px;max-width:380px;text-align:center;transition:var(--tr)}
.precio-card.club{background:rgba(255,255,255,.12);border-color:rgba(95,217,154,.35);position:relative;overflow:hidden}
.precio-card.club::before{content:'EXCLUSIVO';position:absolute;top:16px;right:-28px;background:linear-gradient(135deg,#5FD99A,var(--verde));color:var(--blanco);font-size:.62rem;font-weight:700;padding:4px 36px;transform:rotate(35deg);letter-spacing:.1em}
.precio-card-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.55);margin-bottom:14px}
.precio-card.club .precio-card-label{color:#5FD99A}
.precio-tachado{font-size:1.1rem;color:rgba(255,255,255,.35);text-decoration:line-through;margin-bottom:4px;font-weight:500}
.precio-amount{font-family:var(--font-head);font-weight:800;font-size:clamp(2.4rem,5vw,3.2rem);color:var(--blanco);line-height:1}
.precio-amount sup{font-size:1.2rem;font-weight:700;vertical-align:top;margin-top:.5rem;margin-right:2px}
.precio-pp{font-size:.78rem;color:rgba(255,255,255,.5);margin-top:6px}
.precio-card.club .precio-amount{color:#5FD99A}
.precio-nota{font-size:.78rem;color:rgba(255,255,255,.45);margin-top:18px;line-height:1.5}
.precio-fecha-limite{margin-top:20px;background:rgba(255,255,255,.06);border-radius:var(--radius);padding:10px 16px;font-size:.82rem;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:8px;justify-content:center;flex-wrap:wrap;text-align:center}
.precio-fecha-limite svg{color:#FBBF24;flex-shrink:0}
.precio-cta{margin-top:32px;text-align:center;position:relative;z-index:1}
.precio-cta p{color:rgba(255,255,255,.55);font-size:.85rem;margin-bottom:16px}
.precio-cta .precio-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ════════════════════════════════════════════════════════════
   SECCIÓN: REGISTRO / FORMULARIO
════════════════════════════════════════════════════════════ */
.section-registro{padding:88px 0;background:var(--gris-fondo)}
.registro-wrap{max-width:640px;margin:0 auto}
.registro-card{background:var(--blanco);border-radius:var(--radius-xl);padding:40px;box-shadow:var(--shadow-lg);border:1px solid rgba(0,0,0,.04)}
.form-title{font-family:var(--font-head);font-weight:700;font-size:1.3rem;color:var(--azul);margin-bottom:6px}
.form-subtitle{font-size:.88rem;color:var(--gris-med);margin-bottom:28px;line-height:1.6}

.form-field{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.form-field label{font-size:.82rem;font-weight:600;color:var(--azul)}
.form-field input,
.form-field select{width:100%;padding:12px 16px;border:1.5px solid rgba(0,0,0,.12);border-radius:var(--radius);font-size:.92rem;color:var(--gris-osc);background:var(--crema);transition:var(--tr);outline:none}
.form-field input:focus,
.form-field select:focus{border-color:var(--verde);background:var(--blanco);box-shadow:0 0 0 3px rgba(45,106,79,.1)}
.form-field input.error,
.form-field select.error{border-color:var(--rojo)}
.form-field input::placeholder{color:var(--gris-claro)}

/* Select custom arrow */
.form-field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23666666' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}

/* Phone wrap */
.phone-wrap{display:flex;border:1.5px solid rgba(0,0,0,.12);border-radius:var(--radius);overflow:hidden;background:var(--crema);transition:var(--tr)}
.phone-wrap:focus-within{border-color:var(--verde);background:var(--blanco);box-shadow:0 0 0 3px rgba(45,106,79,.1)}
.phone-prefix{display:flex;align-items:center;padding:0 14px;font-size:.88rem;font-weight:700;color:var(--azul);background:var(--azul-light);border-right:1.5px solid rgba(0,0,0,.08);white-space:nowrap;min-width:62px;justify-content:center;flex-shrink:0;user-select:none}
.phone-wrap input{border:none!important;border-radius:0!important;background:transparent!important;box-shadow:none!important;padding-left:14px!important;flex:1;min-width:0}
.phone-wrap input:focus{box-shadow:none!important;border:none!important}

/* 2 columnas */
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:520px){.form-row-2{grid-template-columns:1fr}}

/* Field error msg */
.field-error{font-size:.75rem;color:var(--rojo);margin-top:-10px;margin-bottom:4px;display:none}
.field-error.show{display:block}

/* Submit area */
.form-submit{margin-top:8px}
.form-submit .btn-primary{font-size:1rem;padding:15px 32px}
.btn-loading{opacity:.7;pointer-events:none}

/* Success */
.form-success{text-align:center;padding:32px 16px}
.form-success-icon{width:72px;height:72px;background:var(--verde-claro);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.form-success-icon svg{color:var(--verde)}
.form-success h3{font-family:var(--font-head);font-weight:700;font-size:1.3rem;color:var(--azul);margin-bottom:10px}
.form-success p{font-size:.9rem;color:var(--gris-med);line-height:1.7;margin-bottom:24px}

/* Error general */
.form-error-msg{background:var(--rojo-claro);border:1px solid rgba(176,28,46,.2);border-radius:var(--radius);padding:12px 16px;font-size:.85rem;color:var(--rojo);margin-top:14px;display:none}
.form-error-msg.show{display:block}

/* ════════════════════════════════════════════════════════════
   SECCIÓN: FAQ
════════════════════════════════════════════════════════════ */
.section-faq{padding:88px 0;background:var(--blanco)}
.faq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.faq-item{background:var(--crema);border-radius:var(--radius-lg);border:1px solid rgba(45,106,79,.1);overflow:hidden;transition:var(--tr)}
.faq-item.open{border-color:var(--verde);background:var(--blanco);box-shadow:0 4px 16px rgba(45,106,79,.08)}
.faq-question{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;cursor:pointer;font-family:var(--font-head);font-weight:600;font-size:.95rem;color:var(--azul)}
.faq-chevron{flex-shrink:0;transition:transform var(--tr);color:var(--verde)}
.faq-item.open .faq-chevron{transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .25s ease}
.faq-item.open .faq-answer{max-height:400px}
.faq-answer-inner{padding:0 22px 18px;font-size:.88rem;color:var(--gris-med);line-height:1.75}

/* ════════════════════════════════════════════════════════════
   SECCIÓN: CTA FINAL
════════════════════════════════════════════════════════════ */
.section-cta{padding:88px 0;background:var(--gris-fondo);text-align:center}
.cta-inner{max-width:640px;margin:0 auto}
.cta-inner h2{font-family:var(--font-head);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;color:var(--azul);margin-bottom:14px}
.cta-inner p{color:var(--gris-med);font-size:1rem;line-height:1.75;margin-bottom:32px}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.cta-contact-info{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;margin-top:24px}
.cta-contact-link{display:flex;align-items:center;gap:7px;font-size:.85rem;color:var(--gris-med);transition:var(--tr)}
.cta-contact-link:hover{color:var(--verde)}
.cta-contact-link svg{color:var(--verde);flex-shrink:0}

/* ════════════════════════════════════════════════════════════
   FOOTER MINI
════════════════════════════════════════════════════════════ */
.footer-mini{background:var(--azul-dark);color:rgba(255,255,255,.6);padding:32px 0}
.footer-mini-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.footer-logo{font-family:var(--font-head);font-weight:800;font-size:.95rem;color:var(--blanco);letter-spacing:.04em}
.footer-logo span{color:rgba(255,255,255,.4);font-weight:500}
.footer-links{display:flex;gap:20px;flex-wrap:wrap}
.footer-links a{font-size:.8rem;color:rgba(255,255,255,.5);transition:var(--tr)}
.footer-links a:hover{color:var(--blanco)}
.footer-copy{font-size:.78rem;color:rgba(255,255,255,.35)}
.footer-social{display:flex;gap:14px}
.footer-social a{color:rgba(255,255,255,.4);transition:var(--tr)}
.footer-social a:hover{color:var(--blanco)}

@media(max-width:640px){
  .footer-mini-inner{flex-direction:column;align-items:center;text-align:center}
  .footer-links{justify-content:center}
}
