@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700&family=Syne:wght@400;500;600;700;800&family=DM+Sans:wght@400;500;600;700&display=swap');

:root {
  /* Paleta CEGAHO — cegaho.arketstudio.com */
  --primary: #1B4FA8;
  --primary-pale: #EBF1FB;
  --primary-light: #6FA3F0;
  --dark: #0A0F1E;
  --dark-blue: #0A1628;
  --bg: #F8FAFF;
  --bg-2: #EDF2FA;
  --white: #FFFFFF;
  --text: #0D1420;
  --muted: #4A5568;
  --border: rgba(27, 79, 168, 0.12);
  --shadow: 0 20px 60px rgba(10, 15, 30, 0.12);

  /* Alias usados en el formulario */
  --dark-bg: var(--dark);
  --dark-secondary: var(--dark-blue);
  --dark-tertiary: #142038;
  --cream-primary: var(--bg);
  --cream-secondary: var(--white);
  --cream-accent: var(--muted);
  --accent-gold: var(--primary);
  --accent-blue: var(--primary-light);
  --accent-green: #059669;
  --accent-red: #DC2626;
  --on-dark: rgba(255, 255, 255, 0.86);
  --on-dark-muted: rgba(255, 255, 255, 0.62);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { 
  scroll-behavior:smooth; 
  -webkit-text-size-adjust:100%; 
}

/* Soporte para usuarios con preferencia de movimiento reducido */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

body {
  font-family:'DM Sans',sans-serif;
  background-color: var(--bg);
  color: var(--text);
  overflow-x:hidden;
  min-height:100dvh;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* ── LAYOUT (mobile-first) ── */
.desktop-panel { display:none !important; }

html, body {
  height:100%;
  overflow:hidden;
}

.onboarding-container {
  display:flex;
  flex-direction:column;
  height:100dvh;
  height:100svh;
  min-height:0;
  overflow:hidden;
}

/* ── LEFT SIDE ── */
.left-section {
  background: linear-gradient(135deg, var(--dark) 0%, var(--dark-blue) 48%, var(--primary) 100%);
  flex:0 0 auto;
  padding:.75rem 1rem .875rem;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  position:relative;
  height:auto !important;
  min-height:0 !important;
  overflow:visible;
}

.left-section::before {
  content:'';
  position:absolute;
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(111,163,240,.28) 0%,transparent 70%);
  border-radius:50%;
  top:-100px;right:-100px;
  pointer-events:none;
}

.left-section::after {
  content:'';
  position:absolute;
  width:300px;height:300px;
  background:radial-gradient(circle,rgba(27,79,168,.18) 0%,transparent 70%);
  border-radius:50%;
  bottom:-50px;left:-50px;
  pointer-events:none;
}

.left-top,
.left-bottom,
.left-content { position:relative; z-index:1; }

.logo-arket {
  margin-bottom:.75rem;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  animation:fadeInDown .8s ease-out;
}

.logo-cegaho {
  height:58px;
  width:auto;
  max-width:min(220px, 52vw);
  object-fit:contain;
  display:block;
}

.logo-cegaho--mobile {
  height:42px;
  max-width:160px;
}

.logo-arket .gold { color:var(--accent-gold); }

.hero-content { animation:fadeInUp .8s ease-out .2s backwards; }

.hero-title {
  font-family:'Syne',sans-serif;
  font-size:clamp(2rem,5vw,3.5rem);
  font-weight:700;
  line-height:1.1;
  margin-bottom:1.5rem;
  letter-spacing:-1px;
  max-width:90%;
}

.hero-title .highlight {
  background:linear-gradient(135deg,var(--accent-gold) 0%,var(--accent-blue) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.hero-subtitle {
  font-size:1.125rem;
  line-height:1.6;
  color:var(--on-dark-muted);
  max-width:85%;
  margin-bottom:3rem;
  font-weight:300;
}

/* PROGRESS BAR */
.progress-section { margin-bottom:0; width:100%; }

.progress-meta {
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:.4rem;
}

.progress-label {
  display:none;
  font-size:.8rem;
  font-weight:600;
  color:var(--cream-accent);
  text-transform:uppercase;
  letter-spacing:1px;
  font-family:'Montserrat',sans-serif;
}

.progress-counter {
  font-family:'Montserrat',sans-serif;
  font-size:.85rem;
  font-weight:700;
  color:var(--accent-gold);
}

.progress-bar {
  width:100%;
  height:4px;
  background:var(--dark-tertiary);
  border-radius:10px;
  overflow:visible;
  position:relative;
}

.progress-fill {
  height:100%;
  background:linear-gradient(90deg,var(--primary) 0%,var(--primary-light) 100%);
  border-radius:10px;
  transition:width .65s cubic-bezier(.34,1.56,.64,1);
  position:relative;
  will-change:width;
}

.progress-fill::after {
  content:'';
  position:absolute;
  right:-4px;top:-4px;
  width:10px;height:10px;
  background:var(--accent-gold);
  border-radius:50%;
  border:2px solid var(--dark-bg);
  box-shadow:0 0 12px rgba(27,79,168,.6);
  animation:dotPulse 2s ease-in-out infinite;
}

@keyframes dotPulse {
  0%,100% { box-shadow:0 0 8px rgba(27,79,168,.5); }
  50% { box-shadow:0 0 20px rgba(27,79,168,.9); }
}

/* BLOQUE STEPS */
.steps-container {
  display:flex;
  gap:1rem;
  margin-top:1rem;
  flex-wrap:wrap;
}

.step-indicator {
  display:flex;
  align-items:center;
  gap:.5rem;
  font-size:.8rem;
  color:var(--cream-accent);
  transition:all .3s ease;
  font-family:'Montserrat',sans-serif;
  font-weight:500;
}

.step-indicator.active { color:var(--accent-gold); }
.step-indicator.done { color:var(--accent-green); }

.step-dot {
  width:6px;height:6px;
  border-radius:50%;
  background:var(--cream-accent);
  transition:all .3s ease;
  flex-shrink:0;
}

.step-indicator.active .step-dot {
  width:8px;height:8px;
  background:var(--accent-gold);
  box-shadow:0 0 10px rgba(27,79,168,.7);
}

.step-indicator.done .step-dot {
  width:8px;height:8px;
  background:var(--accent-green);
}

/* SAVE STATUS */
.save-status {
  margin-top:.5rem;
  font-family:'Montserrat',sans-serif;
  font-size:.68rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.6px;
  color:var(--accent-gold);
  opacity:0;
  transition:opacity .4s ease;
  height:14px;
}

/* FEATURES */
.features-list {
  position:relative;
  z-index:1;
  display:flex;
  justify-content:space-between;
  gap:1rem;
  font-size:.82rem;
  color:var(--white);
  animation:fadeInUp .8s ease-out .4s backwards;
  padding-bottom:1.5rem;
  border-bottom:1px solid rgba(255,255,255,0.15);
  flex-shrink:0;
}

.footer-credit {
  position:relative;
  z-index:1;
  padding:1.5rem;
  text-align:center;
  font-size:0.78rem;
  color:rgba(255,255,255,0.75);
  font-weight:400;
  letter-spacing:0.02em;
  animation:fadeInUp .8s ease-out .5s backwards;
  flex-shrink:0;
}

.footer-credit strong {
  color:var(--white);
  font-weight:700;
}

.footer-credit--mobile {
  flex-shrink:0;
  padding:1rem 1rem max(1rem, env(safe-area-inset-bottom));
  background:linear-gradient(135deg, var(--dark) 0%, var(--dark-blue) 48%, var(--primary) 100%);
  border-top:1px solid rgba(255,255,255,0.12);
}

.feature-item {
  display:flex;
  align-items:center;
  gap:.5rem;
  opacity:1;
  transition:transform .3s ease;
  color:var(--white);
  font-weight:600;
}

.feature-item:hover { transform:translateY(-2px); }

.feature-icon {
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,0.55);
  border-radius:50%;
  font-size:.875rem;
  background:rgba(255,255,255,0.14);
  transition:all .3s ease;
  flex-shrink:0;
  filter:none;
  backdrop-filter:none;
}

.feature-item:hover .feature-icon {
  border-color:var(--white);
  background:rgba(255,255,255,0.22);
  box-shadow:0 0 16px rgba(255,255,255,0.2);
}

/* ── RIGHT SIDE ── */
.right-section {
  background-color:var(--cream-secondary);
  flex:1 1 auto;
  min-height:0 !important;
  padding:0;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  position:relative;
  overflow:hidden;
}

/* Barra superior móvil (logo + progreso) */
.mobile-header {
  flex-shrink:0;
  background:linear-gradient(135deg, var(--dark) 0%, var(--dark-blue) 48%, var(--primary) 100%);
}

.mobile-shell {
  flex-shrink:0;
  background:transparent;
  padding:.75rem 1rem 0;
}

.mobile-shell-row {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.75rem;
}

.mobile-shell-logo,
.mobile-shell-row .logo-cegaho--mobile {
  flex-shrink:0;
}

.mobile-shell-counter {
  font-family:'Montserrat',sans-serif;
  font-size:.85rem;
  font-weight:700;
  color:#E8B923;
}

.mobile-progress-block {
  padding:0 0 .75rem;
}

.mobile-progress {
  padding-bottom:.55rem;
}

.mobile-progress-block .progress-bar {
  height:3px;
  background:rgba(255,255,255,0.16);
  border-radius:999px;
  overflow:hidden;
}

.mobile-progress-block .progress-fill {
  background:linear-gradient(90deg, #E8B923 0%, var(--primary-light) 100%);
  border-radius:999px;
}

.mobile-progress-block .progress-fill::after { display:none; }

.steps-container--mobile {
  display:flex;
  flex-wrap:nowrap;
  gap:.65rem;
  margin-top:0;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding-bottom:.15rem;
}

.steps-container--mobile::-webkit-scrollbar { display:none; }

.steps-container--mobile .step-indicator {
  flex-shrink:0;
  white-space:nowrap;
  font-size:.72rem;
  color:rgba(255,255,255,0.55);
}

.steps-container--mobile .step-indicator.active {
  color:#E8B923;
}

.steps-container--mobile .step-indicator.done {
  color:#6BCB77;
}

.steps-container--mobile .step-dot {
  background:rgba(255,255,255,0.35);
}

.steps-container--mobile .step-indicator.active .step-dot {
  background:#E8B923;
  box-shadow:0 0 8px rgba(232,185,35,0.55);
}

.steps-container--mobile .step-indicator.done .step-dot {
  background:#6BCB77;
}

.right-section .form-container {
  flex:1 1 auto;
  min-height:0;
  overflow-y:auto;
  overflow-x:hidden;
  padding:1.25rem 1rem 1rem;
  -webkit-overflow-scrolling:touch;
}

.right-section .form-container::-webkit-scrollbar {
  width:8px;
}

.right-section .form-container::-webkit-scrollbar-track {
  background:rgba(168,168,160,.1);
  border-radius:4px;
}

.right-section .form-container::-webkit-scrollbar-thumb {
  background:var(--primary-light);
  border-radius:4px;
}

.right-section .form-container::-webkit-scrollbar-thumb:hover {
  background:var(--primary);
}

.right-section::before {
  content:'';
  position:absolute;
  top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--cream-accent),transparent);
  opacity:.3;
}

.form-container {
  max-width:100%;
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  min-height:100%;
}

#question-area { flex:1 1 auto; }

/* ── PASO DE BIENVENIDA (primer paso del formulario) ── */
.form-container.welcome-step-active {
  justify-content:center;
  align-items:center;
  min-height:100%;
}

.form-container.welcome-step-active #question-area {
  flex:0 0 auto;
  width:100%;
  display:flex;
  justify-content:center;
  align-items:center;
}

.welcome-step {
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  width:100%;
  max-width:620px;
  margin:0 auto;
  padding:2rem 1.25rem;
}

.welcome-step-btn {
  width:100%;
  max-width:340px;
  margin-top:0.25rem;
}

.form-container.welcome-step-active .form-actions {
  display:none !important;
}

/* ── MÓVIL: info concreta (solo antes de empezar, nunca en desktop) ── */
.mobile-intro {
  display:none;
  flex-shrink:0;
  padding:0 1rem 1rem;
  background:transparent;
  border-bottom:none;
}

.mobile-intro-hero {
  padding-top:.15rem;
}

.mobile-intro-features {
  display:flex;
  flex-wrap:wrap;
  gap:0.5rem 0.85rem;
  font-family:'Montserrat',sans-serif;
  font-size:0.78rem;
  font-weight:600;
  color:var(--primary);
  margin-top:.15rem;
  padding-top:.75rem;
  border-top:1px solid rgba(255,255,255,0.1);
}

.mobile-intro-title {
  font-family:'Syne',sans-serif;
  font-size:1.6rem;
  font-weight:700;
  line-height:1.2;
  color:var(--text);
  margin-bottom:0.45rem;
}

.mobile-intro-title span {
  color:var(--primary);
}

.mobile-intro-text {
  font-family:'DM Sans',sans-serif;
  font-size:1.1rem;
  line-height:1.5;
  color:var(--muted);
  margin-bottom:0.75rem;
}

.mobile-intro-features span {
  display:inline-flex;
  align-items:center;
  gap:0.3rem;
}

@media (max-width: 1024px) {
  .right-section::before {
    display:none;
  }

  .mobile-header {
    background:linear-gradient(135deg, var(--dark) 0%, var(--dark-blue) 48%, var(--primary) 100%);
  }

  .right-section.form-active .mobile-header {
    border-bottom:1px solid rgba(255,255,255,0.08);
  }

  .right-section:not(.form-active) .mobile-intro {
    display:block;
  }

  .right-section.form-active .mobile-intro-hero,
  .right-section.form-active .mobile-intro-features {
    display:none !important;
  }

  .right-section.form-active .mobile-intro {
    display:block;
    padding:0 1rem .65rem;
  }

  .right-section.form-active .mobile-shell {
    padding-bottom:0;
  }

  .right-section.form-active .mobile-progress-block {
    padding-bottom:0;
  }

  .right-section.form-active .mobile-progress {
    padding-bottom:.45rem;
  }

  .mobile-intro {
    padding:0 1rem 1.05rem;
  }

  .mobile-intro-hero {
    margin-bottom:.55rem;
  }

  .mobile-intro-title {
    font-size:clamp(1.35rem, 5.2vw, 1.65rem);
    color:var(--white);
    line-height:1.15;
    margin-bottom:0.4rem;
  }

  .mobile-intro-title span {
    color:var(--white);
    background:linear-gradient(90deg, #E8B923 0%, var(--primary-light) 100%);
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
  }

  .mobile-intro-text {
    font-size:clamp(0.92rem, 3.6vw, 1.05rem);
    color:rgba(255,255,255,0.72);
    margin-bottom:0;
    line-height:1.45;
  }

  .mobile-intro-features {
    gap:0.55rem 0.85rem;
    font-size:clamp(0.76rem, 3vw, 0.82rem);
    color:rgba(255,255,255,0.9);
    font-weight:600;
    margin-top:.15rem;
    padding-top:.75rem;
    border-top:1px solid rgba(255,255,255,0.1);
  }

  .mobile-intro-features span {
    display:inline-flex;
    align-items:center;
    gap:0.3rem;
  }

  .right-section {
    overflow:hidden;
  }

  .right-section .form-container {
    flex:1 1 auto;
    min-height:0;
    overflow-y:auto;
  }

  .form-container.welcome-step-active {
    flex:1 1 auto;
    min-height:0;
    display:flex;
    flex-direction:column;
    justify-content:center;
    padding:1rem 1rem 1.25rem;
  }

  .welcome-step {
    padding:1rem 0.5rem;
  }

  .welcome-step-btn {
    max-width:100%;
  }

  .welcome-title {
    font-size:clamp(1.45rem, 6vw, 1.9rem);
  }

  .welcome-text {
    font-size:clamp(0.95rem, 3.8vw, 1.05rem);
    margin-bottom:1.75rem;
  }
}

.welcome-title {
  font-family:'Syne',sans-serif;
  font-size:clamp(1.75rem, 4vw, 2.65rem);
  font-weight:700;
  color:var(--text);
  line-height:1.2;
  margin-bottom:1.15rem;
  letter-spacing:-0.02em;
  max-width:540px;
}

.welcome-text {
  font-family:'DM Sans',sans-serif;
  font-size:clamp(1.05rem, 2vw, 1.2rem);
  color:var(--muted);
  line-height:1.65;
  margin-bottom:2rem;
  max-width:480px;
}

#form-actions { display:flex; }

.welcome-carousel-dots {
  position:absolute;
  bottom:1.1rem;
  left:0;
  right:0;
  z-index:2;
  display:flex;
  justify-content:center;
  gap:0.45rem;
}

.welcome-carousel-dot {
  width:8px;
  height:8px;
  border-radius:50%;
  border:none;
  padding:0;
  background:rgba(255,255,255,0.35);
  cursor:pointer;
  transition:background .25s ease, transform .25s ease;
}

.welcome-carousel-dot.active {
  background:var(--white);
  transform:scale(1.12);
}

.welcome-carousel-dot:focus-visible {
  outline:2px solid var(--white);
  outline-offset:2px;
}

/* QUESTION HEADER */
.question-header-area {
  margin-bottom:1rem;
  animation:slideDown .4s ease-out;
}

.block-eyebrow {
  display:flex;
  align-items:center;
  gap:.75rem;
  margin-bottom:.5rem;
}

.left-section .hero-title {
  color: var(--white);
}

.left-section .hero-title .highlight {
  background:linear-gradient(90deg, #E8B923 0%, var(--primary-light) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  color:transparent;
}

.left-section .hero-subtitle,
.left-section .progress-label,
.left-section .progress-counter,
.left-section .save-status,
.left-section .step-indicator {
  color: var(--white);
}

.left-section .step-indicator.active,
.left-section .step-indicator.done {
  color: var(--white);
  font-weight: 700;
}

.left-section .step-dot {
  background: rgba(255, 255, 255, 0.45);
}

.left-section .step-indicator.active .step-dot {
  background: var(--white);
  box-shadow: 0 0 10px rgba(255, 255, 255, 0.45);
}

.left-section .step-indicator.done .step-dot {
  background: rgba(255, 255, 255, 0.75);
}

.mobile-shell-counter {
  color: var(--white);
}

.block-badge {
  font-family:'Montserrat',sans-serif;
  font-size:.65rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1px;
  color:var(--white);
  background:var(--dark);
  border:none;
  padding:4px 12px;
  border-radius:100px;
}

.block-name {
  font-family:'Montserrat',sans-serif;
  font-size:.72rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.8px;
  color:var(--accent-gold);
}

.question-number {
  font-family:'Montserrat',sans-serif;
  font-size:.75rem;
  font-weight:600;
  color:var(--cream-accent);
  text-transform:uppercase;
  letter-spacing:.5px;
  margin-bottom:.75rem;
}

.question-text-label {
  font-family:'Syne',sans-serif;
  font-size:clamp(1.4rem,3.8vw,1.9rem);
  font-weight:700;
  color:var(--text);
  line-height:1.25;
  letter-spacing:-.3px;
  margin-bottom:.25rem;
}

.question-required {
  color:var(--accent-gold);
  margin-left:3px;
}

.question-description {
  font-family:'DM Sans',sans-serif;
  font-size:.95rem;
  color:var(--cream-accent);
  margin-top:.5rem;
  line-height:1.5;
}

/* ── FORM ELEMENTS ── */
.field-area {
  margin-top:1.25rem;
}

.form-input, .form-select {
  width:100%;
  padding:1rem 1.15rem;
  border:1.5px solid var(--border);
  border-radius:4px;
  font-size:1.05rem;
  color:var(--text);
  background:var(--cream-primary);
  transition:all .25s ease-out;
  font-family:'DM Sans',sans-serif;
  letter-spacing:.3px;
  outline:none;
}

.form-input::placeholder { 
  color:var(--cream-accent); 
  opacity:.7;
  transition:opacity .2s ease-out;
}

.form-input:hover::placeholder {
  opacity:1;
}

@media(hover:hover) {
  .form-input:hover, .form-select:hover {
    border-color:rgba(27,79,168,.5);
    background:#fff;
  }
}

.form-input:focus, .form-select:focus {
  border-color:var(--accent-gold);
  background:#fff;
  box-shadow:0 0 0 3px rgba(27,79,168,.15), 0 4px 20px rgba(27,79,168,.12);
  transform:translateY(-1px);
}

/* Focus visible para accesibilidad */
.form-input:focus-visible, .form-select:focus-visible {
  outline:3px solid var(--accent-blue);
  outline-offset:2px;
}

.form-select {
  appearance:none;
  cursor:pointer;
  padding-right:2.5rem;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%234A5568' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right .8rem center;
  background-size:1.2em;
  background-color:var(--cream-primary);
}

.form-select option { background:var(--cream-primary); color:var(--text); }

.q2-detail-wrap {
  margin-top:1rem;
  animation:fadeInUp .28s ease-out;
}

.q2-detail-wrap[hidden] {
  display:none !important;
}

.q2-detail-wrap .field-sub-label {
  display:block;
  font-family:'Montserrat',sans-serif;
  font-size:.78rem;
  font-weight:600;
  color:var(--muted);
  margin-bottom:.4rem;
  text-transform:none;
  letter-spacing:normal;
}

.location-mx-stack {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.field-sub-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--cream-accent);
  margin-bottom: 0.35rem;
}

.field-hint {
  font-size: 0.85rem;
  color: var(--cream-accent);
  margin-top: 0.25rem;
}

.field-hint-error {
  color: var(--accent-red);
}

.form-textarea {
  width:100%;
  padding:.875rem 1rem;
  border:1.5px solid var(--border);
  border-radius:4px;
  font-size:1rem;
  color:var(--text);
  background:var(--cream-primary);
  transition:all .3s cubic-bezier(.34,1.56,.64,1);
  font-family:'DM Sans',sans-serif;
  resize:none;
  min-height:120px;
  outline:none;
}

.form-textarea::placeholder { color:var(--cream-accent); }

.form-textarea:focus {
  border-color:var(--accent-gold);
  background:#fff;
  box-shadow:0 0 0 3px rgba(27,79,168,.15);
  transform:translateY(-2px);
}

.textarea-counter {
  text-align:right;
  font-family:'Montserrat',sans-serif;
  font-size:.68rem;
  font-weight:500;
  color:var(--cream-accent);
  margin-top:.4rem;
}

.textarea-counter .cur { color:var(--accent-gold); font-weight:700; }

/* ── RADIO CARDS ── */
.cards-group {
  display:grid;
  grid-template-columns:1fr;
  gap:.85rem;
}

.cards-group.single-col { grid-template-columns:1fr; }

.card-option { position:relative; }

.card-option input[type="radio"],
.card-option input[type="checkbox"] {
  position:absolute;
  opacity:0;width:0;height:0;
}

.card-label {
  display:flex;
  align-items:center;
  gap:.875rem;
  padding:1.15rem 1.3rem;
  border:2px solid var(--border);
  border-radius:6px;
  cursor:pointer;
  transition:all .28s cubic-bezier(.34,1.56,.64,1);
  background:var(--cream-primary);
  color:var(--dark-secondary);
  font-weight:500;
  font-size:1rem;
  position:relative;
  overflow:hidden;
  min-height:58px;
  user-select:none;
  -webkit-tap-highlight-color:transparent;
}

/* Focus visible para accesibilidad keyboard */
.card-option input:focus-visible + .card-label {
  outline:3px solid var(--accent-blue);
  outline-offset:3px;
  box-shadow:0 0 0 3px rgba(59,130,246,.15), 0 6px 20px rgba(0,0,0,.08);
  border-color:var(--accent-blue);
}

.card-indicator {
  flex-shrink:0;
  width:20px;height:20px;
  border-radius:50%;
  border:2px solid var(--border);
  background:transparent;
  transition:all .28s cubic-bezier(.34,1.56,.64,1);
}

.card-label .card-text {
  flex:1;
  line-height:1.3;
  position:relative;
  z-index:1;
}

.card-label .card-desc {
  font-size:.72rem;
  color:var(--cream-accent);
  margin-top:2px;
  display:block;
}

.card-label::after {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(27,79,168,.08) 0%,transparent 60%);
  opacity:0;
  transition:opacity .28s ease;
  pointer-events:none;
}

@media(hover:hover) {
  .card-label:hover {
    border-color:var(--accent-gold);
    transform:translateY(-2px);
    box-shadow:0 6px 20px rgba(0,0,0,.08);
  }
  .card-label:hover .card-indicator {
    border-color:rgba(27,79,168,.7);
  }
}

.card-label:active { transform:scale(.97); }

.card-option input:checked + .card-label {
  border-color:var(--accent-gold);
  background:#fff;
  color:var(--text);
  box-shadow:0 8px 28px rgba(27,79,168,.18);
  transform:translateY(-3px);
  font-weight:600;
}

.card-option input:checked + .card-label::after { opacity:1; }

.card-option input:checked + .card-label .card-indicator {
  background:var(--accent-gold);
  border-color:var(--accent-gold);
  box-shadow:0 0 0 3px rgba(27,79,168,.18);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 6l3 3 5-5' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:center;
  background-size:9px;
}

/* CHECKBOX indicator es cuadrado */
.card-option.is-checkbox .card-indicator {
  border-radius:4px;
}

/* ── BUTTONS ── */
.form-actions {
  display:flex;
  flex-direction:column;
  gap:.625rem;
  flex-shrink:0;
  position:sticky;
  bottom:0;
  z-index:20;
  margin-top:auto;
  padding:1rem 0 max(1rem, env(safe-area-inset-bottom));
  background:var(--cream-secondary);
  box-shadow:0 -12px 24px rgba(0,0,0,.06);
}

.form-actions .btn { width:100%; text-align:center; }

.btn {
  padding:1.15rem 2rem;
  font-size:1rem;
  font-weight:700;
  border:none;
  border-radius:4px;
  cursor:pointer;
  transition:all .28s cubic-bezier(.34,1.56,.64,1);
  font-family:'Montserrat',sans-serif;
  text-transform:uppercase;
  letter-spacing:.6px;
  position:relative;
  overflow:hidden;
  user-select:none;
  -webkit-tap-highlight-color:transparent;
}

.btn > span { position:relative; z-index:1; }

.btn::before {
  content:'';
  position:absolute;
  top:0;left:-100%;
  width:100%;height:100%;
  background:rgba(255,255,255,.15);
  transition:left .4s ease;
  z-index:0;
}

.btn:hover::before { left:100%; }
.btn:active { transform:scale(.97); }

.btn-primary {
  background:var(--primary);
  color:#fff;
  flex:1;
  position:relative;
  overflow:hidden;
}

.btn-primary::before {
  content:'';
  position:absolute;
  inset:0;
  background:rgba(255,255,255,0.12);
  opacity:0;
  transition:opacity .2s ease-out;
  left:0;
  width:100%;
}

.btn-primary:hover::before {
  opacity:1;
}

.btn-primary:hover {
  background:var(--primary);
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(27,79,168,.3);
}

.btn-primary:active {
  transform:translateY(0) scale(0.98);
  transition-duration:.1s;
}

.btn-primary:focus-visible {
  outline:3px solid var(--accent-gold);
  outline-offset:3px;
  box-shadow:0 0 0 3px rgba(27,79,168,.2);
}

.btn-secondary {
  background:var(--cream-primary);
  color:var(--text);
  border:1.5px solid var(--border);
}

.btn-secondary:hover {
  border-color:var(--primary);
  background:#fff;
  transform:translateY(-1px);
}

.btn-secondary:active {
  transform:translateY(0) scale(0.98);
  transition-duration:.1s;
}

.btn-secondary:focus-visible {
  outline:3px solid var(--accent-blue);
  outline-offset:3px;
  box-shadow:0 0 0 3px rgba(111,163,240,.2);
}

/* ── RESULTS SCREEN ── */
.results-screen {
  animation:slideDown .5s ease-out;
}

.results-icon {
  font-size:3rem;
  margin-bottom:1rem;
  display:block;
  animation:bounceIn .6s cubic-bezier(.34,1.56,.64,1) .2s backwards;
}

.results-title {
  font-family:'Syne',sans-serif;
  font-size:clamp(1.8rem,5vw,2.5rem);
  font-weight:800;
  color:var(--text);
  letter-spacing:-1px;
  margin-bottom:.5rem;
}

.results-subtitle {
  font-size:1rem;
  color:var(--cream-accent);
  margin-bottom:2.5rem;
}

.score-ring-wrap {
  display:flex;
  justify-content:center;
  margin-bottom:2.5rem;
}

.score-ring {
  position:relative;
  width:180px;height:180px;
}

.score-ring svg {
  transform:rotate(-90deg);
}

.score-ring-text {
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
}

.score-number {
  font-family:'Syne',sans-serif;
  font-size:3rem;
  font-weight:800;
  background:linear-gradient(135deg,var(--accent-gold) 0%,var(--accent-blue) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;
}

.score-label {
  font-family:'Montserrat',sans-serif;
  font-size:.7rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1px;
  color:var(--cream-accent);
  margin-top:.2rem;
}

.score-level-badge {
  display:inline-block;
  font-family:'Montserrat',sans-serif;
  font-size:.72rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.8px;
  padding:4px 12px;
  border-radius:100px;
  margin-bottom:2rem;
}

.recommendation-box {
  background:var(--cream-primary);
  border:1.5px solid var(--border);
  border-left:4px solid var(--accent-gold);
  border-radius:6px;
  padding:1.25rem 1.25rem;
  margin-bottom:2rem;
  font-size:.95rem;
  color:var(--dark-secondary);
  line-height:1.6;
}

.results-actions {
  display:flex;
  flex-direction:column;
  gap:.75rem;
}

.save-status-msg {
  text-align:center;
  margin:1.25rem 0 0;
  padding:0.85rem 1rem;
  border-radius:8px;
  font-size:0.9rem;
  line-height:1.4;
}
.save-status-msg.saving { background:#f3f4f6; color:#555; }
.save-status-msg.ok { background:#ecfdf5; color:#047857; border:1px solid #a7f3d0; }
.save-status-msg.error { background:#fef2f2; color:#b91c1c; border:1px solid #fecaca; }

.btn-restart {
  padding:.875rem 1.75rem;
  font-size:.85rem;
  font-weight:700;
  border:1.5px solid var(--border);
  border-radius:4px;
  cursor:pointer;
  font-family:'Montserrat',sans-serif;
  text-transform:uppercase;
  letter-spacing:.6px;
  background:var(--cream-primary);
  color:var(--dark-secondary);
  transition:all .28s ease;
}

.btn-restart:hover { border-color:var(--dark-secondary); background:#fff; }

.completion-box {
  background:var(--cream-bg);
  border:1px solid rgba(168,168,160,.25);
  border-radius:8px;
  padding:1.5rem;
  margin:0 0 2rem;
  text-align:left;
  line-height:1.65;
  color:#4A4A48;
}

.completion-box strong { color:var(--text); }

.completion-note {
  font-size:.9rem;
  color:var(--cream-accent);
  margin-top:1rem;
  padding-top:1rem;
  border-top:1px solid rgba(168,168,160,.2);
}

@media print {
  .desktop-panel, .mobile-header, .form-actions, .toast,
  .btn-restart, .save-status-msg { display:none !important; }
  html, body { height:auto !important; overflow:visible !important; }
  .onboarding-container { display:block !important; height:auto !important; overflow:visible !important; }
  .right-section, .form-container { overflow:visible !important; height:auto !important; padding:0 !important; }
  .results-screen { break-inside:avoid; }
}
.toast {
  position:fixed;
  bottom:24px;right:24px;z-index:9999;
  background:var(--dark-secondary);
  border:1px solid rgba(27,79,168,.4);
  border-radius:10px;
  padding:12px 18px;
  display:flex;align-items:center;gap:10px;
  box-shadow:0 16px 48px rgba(0,0,0,.5);
  font-size:.82rem;color:var(--cream-primary);
  max-width:300px;
  transform:translateY(100px);opacity:0;
  transition:all .4s cubic-bezier(.34,1.56,.64,1);
  pointer-events:none;
}

.toast.show { transform:translateY(0);opacity:1; }
.toast-icon { font-size:1rem; }

/* ANIMATIONS */
@keyframes fadeInDown {
  from { opacity:0; transform:translateY(-30px); }
  to { opacity:1; transform:translateY(0); }
}
@keyframes fadeInUp {
  from { opacity:0; transform:translateY(30px); }
  to { opacity:1; transform:translateY(0); }
}
@keyframes slideDown {
  from { opacity:0; transform:translateY(20px); }
  to { opacity:1; transform:translateY(0); }
}
@keyframes bounceIn {
  from { opacity:0; transform:scale(.4); }
  to { opacity:1; transform:scale(1); }
}

/* STAGGER cards */
.card-option:nth-child(1) { animation:fadeInUp .35s ease-out .04s backwards; }
.card-option:nth-child(2) { animation:fadeInUp .35s ease-out .08s backwards; }
.card-option:nth-child(3) { animation:fadeInUp .35s ease-out .12s backwards; }
.card-option:nth-child(4) { animation:fadeInUp .35s ease-out .16s backwards; }
.card-option:nth-child(5) { animation:fadeInUp .35s ease-out .20s backwards; }
.card-option:nth-child(6) { animation:fadeInUp .35s ease-out .24s backwards; }
.card-option:nth-child(7) { animation:fadeInUp .35s ease-out .28s backwards; }
.card-option:nth-child(8) { animation:fadeInUp .35s ease-out .32s backwards; }

/* Ajustes móvil pequeño */
@media(max-width:640px) {
  .question-text-label { font-size:1.55rem; }
  .question-description { font-size:1rem; }

  .form-input, .form-select, .form-textarea {
    padding:1.15rem 1.2rem;
    font-size:1.1rem;
  }

  .card-label {
    padding:1.15rem 1.2rem;
    font-size:1.05rem;
    min-height:58px;
  }

  .toast { bottom:12px; right:12px; left:12px; max-width:none; }
}

/* Desktop */
@media(min-width:1025px) {
  html, body {
    height:auto;
    overflow:auto;
  }

  .desktop-panel {
    display:flex !important;
  }

  .mobile-header { display:none !important; }

  .onboarding-container {
    display:grid;
    grid-template-columns:2fr 3fr;
    align-items:stretch;
    height:auto;
    min-height:100dvh;
    overflow:visible;
  }

  .mobile-intro {
    display:none !important;
  }

  /* Desktop — panel izquierdo siempre a altura completa de la fila */
  .left-section {
    flex:unset;
    padding:clamp(1.75rem, 3vh, 2.75rem) clamp(1.5rem, 2.2vw, 2.5rem) clamp(1.25rem, 2.2vh, 1.75rem);
    min-height:100dvh;
    height:100%;
    align-self:stretch;
    position:relative;
    top:auto;
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    gap:0;
    overflow:hidden;
  }

  .left-section .left-top {
    flex:1 1 auto;
    display:flex;
    flex-direction:column;
    gap:clamp(0.65rem, 1.2vh, 0.95rem);
    min-height:0;
  }

  .left-section .left-bottom {
    flex:0 0 auto;
    margin-top:auto;
    display:flex;
    flex-direction:column;
    gap:clamp(0.85rem, 1.6vh, 1.25rem);
  }

  .left-section .hero-content {
    flex:0 0 auto;
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    padding-top:clamp(0.35rem, 1.2vh, 0.85rem);
    min-height:0;
  }

  .desktop-panel .footer-credit {
    display:block;
  }

  .footer-credit--mobile {
    display:none;
  }

  .left-section .logo-arket {
    margin-bottom:0;
    flex-shrink:0;
  }

  .left-section .logo-cegaho {
    height:clamp(42px, 5.5vh, 52px);
    max-width:min(200px, 90%);
  }

  .left-section .hero-title {
    font-size:clamp(2.65rem, 6.2vh + 0.5rem, 3.85rem);
    margin-bottom:clamp(0.85rem, 1.4vh, 1.1rem);
    line-height:1.08;
    max-width:100%;
    letter-spacing:-0.03em;
  }

  .left-section .hero-subtitle {
    font-size:clamp(1.15rem, 2.1vh + 0.4rem, 1.38rem);
    margin-bottom:clamp(0.85rem, 1.5vh, 1.15rem);
    line-height:1.55;
    max-width:92%;
    color:rgba(255,255,255,0.72);
  }

  .left-section .progress-section {
    flex:0 0 auto;
    margin-bottom:0;
    margin-top:0;
    width:100%;
  }

  .left-section .progress-meta {
    margin-bottom:0.5rem;
  }

  .left-section .progress-label {
    display:block;
    color:rgba(255,255,255,0.6);
    font-size:clamp(0.92rem, 1.35vh + 0.22rem, 1.08rem);
    letter-spacing:0.08em;
  }

  .left-section .progress-counter {
    font-size:clamp(1.05rem, 1.5vh + 0.25rem, 1.22rem);
    color:#E8B923;
  }

  .left-section .progress-bar {
    height:5px;
    background:rgba(255,255,255,0.12);
  }

  .left-section .progress-fill {
    background:linear-gradient(90deg, #E8B923 0%, var(--primary-light) 100%);
  }

  .left-section .progress-fill::after {
    background:#E8B923;
    border-color:var(--dark);
  }

  .left-section .steps-container {
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    gap:0.65rem 1.1rem;
    margin-top:0.95rem;
  }

  .left-section .step-indicator {
    flex:0 0 auto;
    font-size:clamp(0.95rem, 1.4vh + 0.25rem, 1.08rem);
    gap:0.42rem;
    line-height:1.2;
    white-space:nowrap;
    color:rgba(255,255,255,0.55);
  }

  .left-section .step-indicator.active,
  .left-section .step-indicator.done {
    color:#E8B923;
    font-weight:600;
  }

  .left-section .step-dot {
    width:7px;
    height:7px;
    background:rgba(255,255,255,0.4);
  }

  .left-section .step-indicator.active .step-dot {
    width:8px;
    height:8px;
    background:#E8B923;
    box-shadow:0 0 8px rgba(232,185,35,0.5);
  }

  .left-section .step-indicator.done .step-dot {
    width:7px;
    height:7px;
    background:var(--accent-green);
  }

  .left-section .save-status {
    height:10px;
    margin-top:0.35rem;
  }

  .left-section .features-list {
    padding-bottom:clamp(0.65rem, 1.2vh, 0.85rem);
    border-bottom:1px solid rgba(255,255,255,0.12);
    font-size:clamp(0.72rem, 1vh + 0.15rem, 0.82rem);
    gap:0.5rem;
    color:rgba(255,255,255,0.75);
  }

  .left-section .feature-icon {
    width:clamp(28px, 3.2vh, 32px);
    height:clamp(28px, 3.2vh, 32px);
    font-size:0.8rem;
    border-color:rgba(255,255,255,0.35);
    background:rgba(255,255,255,0.08);
  }

  .left-section .footer-credit {
    padding:0;
    font-size:clamp(0.68rem, 0.95vh + 0.12rem, 0.76rem);
    line-height:1.35;
    color:rgba(255,255,255,0.55);
  }

  .progress-label { display:block; }

  .right-section {
    flex:unset;
    height:100dvh;
    max-height:100dvh;
    min-height:0 !important;
    padding:0;
    overflow:hidden;
    display:flex;
    flex-direction:column;
  }

  .right-section .form-container {
    flex:1 1 auto;
    min-height:0;
    max-height:100dvh;
    overflow-y:auto;
    overflow-x:hidden;
    padding:clamp(2rem, 4vh, 3rem) clamp(2.5rem, 4vw, 4.5rem) clamp(1.5rem, 3vh, 2.5rem);
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
  }

  .question-text-label {
    font-size:clamp(1.75rem, 2.5vw, 2.15rem);
  }

  .question-number {
    color:var(--muted);
    font-size:0.72rem;
    letter-spacing:0.06em;
  }

  .block-name {
    color:#C9920A;
  }

  .form-container.welcome-step-active {
    justify-content:center;
    align-items:center;
    min-height:100%;
    padding:clamp(1.5rem, 4vh, 2.5rem) clamp(2.5rem, 4vw, 4.5rem);
  }

  .welcome-step {
    padding:1.5rem 1rem;
  }

  .welcome-step-btn {
    max-width:100%;
  }

  .welcome-title {
    font-size:clamp(2.1rem, 2.8vw, 2.85rem);
    margin-bottom:1.25rem;
    color:var(--text);
  }

  .welcome-text {
    font-size:1.15rem;
    color:var(--muted);
  }

  .question-header-area { margin-bottom:1.5rem; }

  .form-actions {
    flex-direction:row;
    position:static;
    margin-top:2rem;
    padding:0 0 0.5rem;
    box-shadow:none;
    background:transparent;
  }

  .form-actions .btn { width:auto; }
  .form-actions .btn-primary { flex:1; }

  .cards-group { grid-template-columns:1fr 1fr; }
}

@media (min-width: 1025px) and (max-height: 760px) {
  .left-section {
    padding:1.1rem 1.25rem 0.85rem;
    gap:0.75rem;
  }

  .left-section .logo-cegaho {
    height:34px;
  }

  .left-section .hero-title {
    font-size:2rem;
  }

  .left-section .hero-subtitle {
    font-size:1rem;
  }

  .left-section .hero-content {
    padding-top:0.35rem;
  }

  .left-section .step-indicator {
    font-size:0.82rem;
  }

  .left-section .steps-container {
    gap:0.45rem 0.85rem;
    margin-top:0.7rem;
  }

  .left-section .progress-label {
    font-size:0.82rem;
  }

  .left-section .progress-counter {
    font-size:0.95rem;
  }

  .left-section .features-list {
    font-size:0.65rem;
  }

  .left-section .footer-credit {
    font-size:0.6rem;
  }
}

@media(prefers-reduced-motion:reduce) {
  *,*::before,*::after { animation-duration:.01ms !important; transition-duration:.1ms !important; }
}
