/* ============================================================
   CANDELA — Estilos de páginas internas
   (Encuesta "La Experiencia" + Booking)
   Depende de candela.css (design tokens)
   ============================================================ */

/* Cabecera corta de página interna */
.page-hero {
  position: relative; padding: 9rem var(--pad-x) 4rem;
  text-align: center;
  background:
    linear-gradient(var(--noche-70), var(--noche-90)),
    radial-gradient(circle at 50% 0%, rgba(201,165,106,0.14), transparent 60%),
    var(--noche-vega);
}
.page-hero .label { display:block; margin-bottom: 1rem; }
.page-hero h1 { font-size: clamp(2.4rem, 7vw, 4.4rem); color: var(--capa-natural); letter-spacing: 0.04em; }
.page-hero h1 em { font-style: italic; color: var(--candela-viva); }
.page-hero p { margin: 1.4rem auto 0; }

/* ============================================================
   ENCUESTA — flujo una pregunta a la vez
   ============================================================ */
.quiz { max-width: 760px; margin-inline: auto; padding: 3rem var(--pad-x) 6rem; }

.quiz__progress {
  height: 2px; width: 100%; background: var(--oro-tenue);
  border-radius: 2px; overflow: hidden; margin-bottom: 2.4rem;
}
.quiz__bar { height: 100%; width: 0%; background: var(--candela-viva); transition: width .5s ease; }

.quiz__step { display: none; animation: fadeStep .5s ease; }
.quiz__step.active { display: block; }
@keyframes fadeStep { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }

.quiz__count { font-size: 0.72rem; letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--colorado); margin-bottom: 1rem; }
.quiz__q { font-family: var(--display); font-size: clamp(1.7rem, 4.5vw, 2.6rem); color: var(--capa-natural); line-height: 1.15; margin-bottom: .6rem; }
.quiz__hint { color: rgba(245,235,213,0.6); font-size: .95rem; margin-bottom: 2rem; }

/* Opciones */
.quiz__opts { display: grid; gap: .9rem; }
.opt {
  display: flex; align-items: center; gap: 1rem; width: 100%;
  text-align: left; cursor: pointer;
  padding: 1.1rem 1.3rem; border: 1px solid var(--oro-linea); border-radius: 3px;
  background: linear-gradient(160deg, rgba(201,165,106,0.04), transparent);
  color: var(--capa-natural); font-family: var(--cuerpo); font-size: 1rem;
  transition: border-color .25s ease, background .25s ease, transform .2s ease;
}
.opt:hover { border-color: var(--candela-viva); transform: translateX(4px); }
.opt.selected { border-color: var(--candela-viva); background: var(--oro-tenue); }
.opt__mark {
  flex: 0 0 auto; width: 22px; height: 22px; border-radius: 50%;
  border: 1px solid var(--oro-linea); display: grid; place-items: center; transition: all .25s ease;
}
.opt.selected .opt__mark { border-color: var(--candela-viva); background: var(--candela-viva); }
.opt.selected .opt__mark::after { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--noche-vega); }
.opt__body strong { display: block; font-weight: 500; }
.opt__body small { display: block; color: rgba(245,235,213,0.55); font-size: .85rem; margin-top: .15rem; }

/* Navegación del quiz */
.quiz__nav { display: flex; justify-content: space-between; align-items: center; margin-top: 2.4rem; }
.quiz__back { background: none; border: 0; color: rgba(245,235,213,0.6); cursor: pointer; font-family: var(--cuerpo); font-size: .85rem; letter-spacing: .1em; text-transform: uppercase; }
.quiz__back:hover { color: var(--candela-viva); }
.quiz__back[disabled] { opacity: 0; pointer-events: none; }

/* ============================================================
   RESULTADO
   ============================================================ */
.result { display: none; text-align: center; max-width: 720px; margin-inline: auto; padding: 3rem var(--pad-x) 6rem; animation: fadeStep .6s ease; }
.result.active { display: block; }
.result__label { display:block; margin-bottom: 1rem; }
.result__name { font-family: var(--display); font-size: clamp(2.6rem, 8vw, 5rem); color: var(--candela-viva); line-height: 1.05; }
.result__terr { font-size: 0.78rem; letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--colorado); margin-top: 1rem; }
.result__meter { display: flex; gap: 6px; justify-content: center; margin: 1.6rem auto; max-width: 280px; }
.result__meter i { height: 4px; flex: 1; background: var(--oro-tenue); border-radius: 2px; }
.result__meter i.on { background: var(--candela-viva); }
.result__desc { color: rgba(245,235,213,0.82); font-size: 1.08rem; margin: 1.4rem auto 0; max-width: 56ch; }
.result__cta { margin-top: 2.6rem; display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.result__restart { background:none; border:0; color: rgba(245,235,213,0.55); cursor:pointer; text-transform:uppercase; letter-spacing:.1em; font-size:.78rem; margin-top:2rem; font-family:var(--cuerpo); }
.result__restart:hover { color: var(--candela-viva); }

/* Aviso-recomendación (desajuste de nivel) */
.result__warn {
  margin: 1.8rem auto 0; max-width: 60ch; text-align: left;
  padding: 1.1rem 1.3rem; border-radius: 3px;
  border: 1px solid rgba(122,79,34,0.55);
  background: linear-gradient(160deg, rgba(122,79,34,0.16), rgba(122,79,34,0.04));
  color: rgba(245,235,213,0.86); font-size: .92rem; line-height: 1.55;
}
.result__warn strong { color: var(--candela-viva); }
.result__warn em { font-style: normal; color: var(--candela-viva); }
.warn-redo {
  display: inline-block; margin-top: 1rem; background: none; border: 1px solid var(--oro-linea);
  color: var(--candela-viva); font-family: var(--cuerpo); font-weight: 500; font-size: .74rem;
  letter-spacing: .12em; text-transform: uppercase; padding: .55rem 1.1rem; border-radius: 2px;
  cursor: pointer; transition: background .25s ease, border-color .25s ease;
}
.warn-redo:hover { background: var(--oro-tenue); border-color: var(--candela-viva); }

/* Detalles enriquecidos */
.result__details {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem;
  margin: 2.4rem auto 0; max-width: 720px; text-align: left;
}
.rcard {
  border: 1px solid var(--oro-linea); border-radius: 3px; padding: 1.2rem 1.1rem;
  background: linear-gradient(160deg, rgba(201,165,106,0.05), transparent);
}
.rcard__label {
  display: block; font-size: 0.66rem; letter-spacing: var(--tracking-label);
  text-transform: uppercase; color: var(--colorado); margin-bottom: .55rem;
}
.rcard__text { font-size: 0.95rem; color: rgba(245,235,213,0.85); line-height: 1.45; }
.result__note { margin: 1.6rem auto 0; max-width: 52ch; font-size: .82rem; color: rgba(245,235,213,0.5); font-style: italic; }
.result__explore { margin-top: 1.4rem; }
.result__explore a { font-size: .85rem; letter-spacing: .04em; color: var(--candela-viva); border-bottom: 1px solid var(--oro-linea); padding-bottom: 2px; transition: border-color .25s ease; }
.result__explore a:hover { border-color: var(--candela-viva); }

/* ============================================================
   DICCIONARIO DEL HABANO
   ============================================================ */
.dic-cats { display: flex; flex-wrap: wrap; gap: .5rem; justify-content: center; max-width: var(--maxw); margin: 0 auto 1.6rem; padding: 0 var(--pad-x); }
.dic-cat { background: none; border: 1px solid var(--oro-linea); border-radius: 2px; color: rgba(245,235,213,0.6); font-family: var(--cuerpo); font-weight: 500; font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; padding: .45rem .9rem; cursor: pointer; transition: color .25s ease, border-color .25s ease, background .25s ease; }
.dic-cat:hover { color: var(--candela-viva); border-color: var(--candela-viva); }
.dic-cat.active { background: var(--candela-viva); color: var(--noche-vega); border-color: var(--candela-viva); }

.dic-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1rem; max-width: var(--maxw); margin: 0 auto; padding: 0 var(--pad-x) 3rem; }
.term { border: 1px solid var(--oro-linea); border-radius: 3px; padding: 1.3rem 1.4rem; background: linear-gradient(160deg, rgba(201,165,106,0.04), transparent); transition: border-color .25s ease, transform .25s ease; }
.term:hover { border-color: var(--candela-viva); transform: translateY(-2px); }
.term__head { display: flex; justify-content: space-between; align-items: baseline; gap: .6rem; margin-bottom: .5rem; }
.term__name { font-family: var(--display); font-size: 1.35rem; color: var(--candela-viva); line-height: 1.1; }
.term__cat { font-size: .6rem; letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--colorado); flex: 0 0 auto; padding-top: .2rem; }
.term__def { font-size: .92rem; color: rgba(245,235,213,0.8); line-height: 1.55; }

@media (max-width: 640px) { .result__details { grid-template-columns: 1fr; } }

/* ============================================================
   FORMULARIO (Booking)
   ============================================================ */
.form-wrap { max-width: 720px; margin-inline: auto; padding: 3rem var(--pad-x) 5rem; }
.field { margin-bottom: 1.6rem; }
.field label { display: block; font-size: 0.78rem; letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--candela-viva); margin-bottom: .6rem; }
.field input, .field select, .field textarea {
  width: 100%; padding: .95rem 1.1rem; background: rgba(245,235,213,0.04);
  border: 1px solid var(--oro-linea); border-radius: 3px; color: var(--capa-natural);
  font-family: var(--cuerpo); font-size: 1rem; transition: border-color .25s ease, background .25s ease;
}
.field input::placeholder, .field textarea::placeholder { color: rgba(245,235,213,0.35); }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--candela-viva); background: rgba(245,235,213,0.07); }
.field select option { background: var(--noche-vega); color: var(--capa-natural); }
.field textarea { resize: vertical; min-height: 120px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
@media (max-width: 620px) { .field-row { grid-template-columns: 1fr; } }

.send-options { display: grid; gap: 1rem; margin-top: 2rem; }
.send-btn { display: flex; align-items: center; justify-content: center; gap: .7rem; }
.send-note { text-align: center; color: rgba(245,235,213,0.5); font-size: .85rem; margin-top: 1.4rem; }

/* Tarjeta informativa lateral / bloques */
.info-card { border: 1px solid var(--oro-linea); border-radius: 3px; padding: 1.6rem; background: linear-gradient(160deg, rgba(201,165,106,0.05), transparent); }
.info-card h3 { font-family: var(--display); color: var(--candela-viva); font-size: 1.4rem; margin-bottom: .6rem; }
.info-card p { color: rgba(245,235,213,0.72); font-size: .95rem; }

/* Volver al inicio */
.back-home { display:inline-block; margin-top: 1.4rem; font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color: rgba(245,235,213,0.6); }
.back-home:hover { color: var(--candela-viva); }

/* ============================================================
   MI HISTORIA — relato editorial
   ============================================================ */
.story { max-width: 720px; margin-inline: auto; padding: 2rem var(--pad-x) 5rem; }

.story__quote {
  position: relative; margin: 0 auto 4rem; padding: 2rem 1.5rem; text-align: center;
  font-family: var(--display); font-style: italic; font-size: clamp(1.4rem, 3.5vw, 2rem);
  line-height: 1.35; color: var(--capa-natural);
  border-top: 1px solid var(--oro-linea); border-bottom: 1px solid var(--oro-linea);
}
.story__quote cite {
  display: block; margin-top: 1.2rem; font-style: normal; font-family: var(--cuerpo);
  font-size: 0.74rem; letter-spacing: var(--tracking-label); text-transform: uppercase;
  color: var(--candela-viva);
}

.acto { margin-bottom: 3.5rem; }
.acto__num {
  font-family: var(--display); font-size: 3rem; line-height: 1; color: var(--colorado);
  opacity: 0.9; margin-bottom: 0.4rem;
}
.acto__title {
  font-family: var(--display); font-size: clamp(1.8rem, 4.5vw, 2.6rem);
  color: var(--candela-viva); margin-bottom: 1.2rem;
}
.acto p {
  font-size: 1.08rem; line-height: 1.75; color: rgba(245,235,213,0.85); margin-bottom: 1rem;
}
.acto p em { font-style: italic; color: var(--candela-viva); }

/* Frases destacadas entre actos */
.story__pull {
  margin: 1rem auto 3.5rem; max-width: 18ch; text-align: center;
  font-family: var(--display); font-style: italic; font-weight: 500;
  font-size: clamp(1.6rem, 4.5vw, 2.4rem); line-height: 1.25; color: var(--candela-viva);
}

/* Cierre */
.story__end { text-align: center; padding-top: 1.5rem; border-top: 1px solid var(--oro-linea); }
.story__end p {
  font-family: var(--display); font-style: italic; font-size: clamp(1.3rem, 3.5vw, 1.8rem);
  color: var(--capa-natural); margin-bottom: 2rem;
}
.story__end .back-home { display: block; margin-top: 2rem; }
.story__end .story__sign { font-style: italic; font-size: clamp(1.6rem, 4vw, 2.2rem); color: var(--candela-viva); margin-bottom: .15rem; }
.story__end .story__sign-role { font-family: var(--cuerpo); font-style: normal; font-size: .72rem; letter-spacing: var(--tracking-label); text-transform: uppercase; color: rgba(245,235,213,0.6); margin-bottom: 2rem; }

/* ============================================================
   GRUPO — configurador
   ============================================================ */
.group { max-width: 780px; margin-inline: auto; padding: 3rem var(--pad-x) 6rem; }
.group__head { margin-bottom: 2.2rem; }
.group__head .label { display: block; margin-bottom: 1rem; }
.group__title { font-family: var(--display); font-size: clamp(1.7rem, 4.5vw, 2.6rem); color: var(--capa-natural); line-height: 1.15; margin-bottom: .6rem; }
.group__title em { font-style: italic; color: var(--candela-viva); }
.group .field-row { align-items: end; }
.group__people-label { display: block; margin: 2.2rem 0 1rem; }
.group__count { font-family: var(--cuerpo); font-weight: 300; font-size: .78rem; color: rgba(245,235,213,0.45); letter-spacing: .12em; text-transform: none; margin-left: .4rem; }
.group__max { margin-top: 1.1rem; font-size: .9rem; color: rgba(245,235,213,0.78); line-height: 1.6; border-left: 2px solid var(--adriatico); padding: .7rem 1.1rem; background: rgba(46,75,90,0.14); border-radius: 0 3px 3px 0; }
.group__max a { color: var(--candela-viva); border-bottom: 1px solid var(--oro-linea); }
.group__max a:hover { color: var(--capa-natural); }
.group__error { margin-top: 1.4rem; font-size: .88rem; color: #d8794a; }

.gperson { display: grid; grid-template-columns: auto 1.4fr 1fr 1fr auto; gap: .7rem; align-items: center; margin-bottom: .8rem; }
.gperson__num { width: 26px; height: 26px; display: grid; place-items: center; border-radius: 50%; border: 1px solid var(--oro-linea); color: var(--candela-viva); font-size: .8rem; flex: 0 0 auto; }
.gp-nombre, .gp-nivel, .gp-int { padding: .7rem .8rem; background: rgba(245,235,213,0.04); border: 1px solid var(--oro-linea); border-radius: 3px; color: var(--capa-natural); font-family: var(--cuerpo); font-size: .92rem; width: 100%; }
.gp-nombre::placeholder { color: rgba(245,235,213,0.35); }
.gp-nombre:focus, .gp-nivel:focus, .gp-int:focus { outline: none; border-color: var(--candela-viva); }
.gp-nivel option, .gp-int option { background: var(--noche-vega); color: var(--capa-natural); }
.gp-del { background: none; border: 0; color: rgba(245,235,213,0.45); font-size: 1.4rem; cursor: pointer; line-height: 1; padding: 0 .3rem; }
.gp-del:hover { color: #b4502a; }
#gAdd { margin-top: .4rem; }
.group__nav { display: flex; justify-content: space-between; align-items: center; margin-top: 2.4rem; gap: 1rem; flex-wrap: wrap; }

@media (max-width: 640px) {
  .gperson { grid-template-columns: auto 1fr auto; grid-template-areas: "num nombre del" "num nivel nivel" "num int int"; row-gap: .5rem; }
  .gperson__num { grid-area: num; align-self: start; margin-top: .4rem; }
  .gp-nombre { grid-area: nombre; }
  .gp-nivel { grid-area: nivel; }
  .gp-int { grid-area: int; }
  .gp-del { grid-area: del; }
}

/* ============================================================
   GRUPO — resultado
   ============================================================ */
.result-group { display: none; text-align: center; max-width: 940px; margin-inline: auto; padding: 3rem var(--pad-x) 6rem; animation: fadeStep .6s ease; }
.result-group.active { display: block; }
.rg-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1rem; margin: 2.4rem 0; text-align: left; }
.rg-card { border: 1px solid var(--oro-linea); border-radius: 3px; padding: 1.4rem 1.2rem; background: linear-gradient(160deg, rgba(201,165,106,0.06), transparent); }
.rg-card__top { display: flex; justify-content: space-between; align-items: baseline; gap: .5rem; margin-bottom: .3rem; }
.rg-card__name { font-family: var(--display); font-size: 1.4rem; color: var(--capa-natural); }
.rg-card__terr { font-size: .66rem; letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--candela-viva); text-align: right; flex: 0 0 auto; }
.rg-card__meter { max-width: 130px; margin: .5rem 0 1rem; }
.rg-card__perfil { font-size: .9rem; color: rgba(245,235,213,0.8); line-height: 1.45; margin-bottom: 1rem; }
.rg-card__pair { display: flex; flex-direction: column; gap: .25rem; }
.rg-card__pair span { font-size: .85rem; color: rgba(245,235,213,0.9); }
.rg-card__pair span::before { content: "· "; color: var(--colorado); }
.rg-card__warn { margin-top: 1rem; font-size: .8rem; color: #d89a6a; line-height: 1.45; border-top: 1px solid var(--oro-tenue); padding-top: .7rem; }
.rg-card__dalmata { margin-top: .9rem; padding-top: .75rem; border-top: 1px solid rgba(46,75,90,0.55); font-size: .85rem; color: #9cc0d2; line-height: 1.4; }
.rg-card__dalmata::before { content: "Dálmata · "; color: #7fa8bd; font-family: var(--cuerpo); font-size: .68rem; letter-spacing: .18em; text-transform: uppercase; }

/* ============================================================
   EL PUENTE DÁLMATA — bloque del resultado individual
   Único uso del color Adriático (#2E4B5A) por pieza (regla de marca)
   ============================================================ */
.dalmata {
  margin: 2rem auto 0; max-width: 640px; text-align: left;
  border: 1px solid var(--adriatico); border-left: 3px solid var(--adriatico);
  border-radius: 3px; padding: 1.6rem 1.6rem;
  background: linear-gradient(160deg, rgba(46,75,90,0.20), rgba(46,75,90,0.04));
}
.dalmata__label { display: block; font-family: var(--cuerpo); font-weight: 600; font-size: .66rem; letter-spacing: var(--tracking-label); text-transform: uppercase; color: #7fa8bd; margin-bottom: .6rem; }
.dalmata__name { font-family: var(--display); font-size: 1.5rem; color: var(--capa-natural); margin-bottom: .5rem; line-height: 1.2; }
.dalmata__desc { font-size: .96rem; color: rgba(245,235,213,0.82); line-height: 1.55; margin-bottom: .9rem; }
.dalmata__pan { font-size: .9rem; color: rgba(245,235,213,0.7); }
.dalmata__pan span { font-family: var(--cuerpo); font-size: .64rem; letter-spacing: var(--tracking-label); text-transform: uppercase; color: #7fa8bd; margin-right: .5rem; }
.dalmata__pan em { font-style: italic; color: var(--candela-viva); }
