/*
 * dreamdex-extras.css — Overlay sobre el bundle compilado.
 *
 * Aplica encima del CSS minificado del bundle. Usa los CSS variables ya
 * declarados (--color-bg, --color-primary, etc.) para que los cambios respeten
 * la paleta del producto.
 *
 * Convenciones:
 *  - Selectores se elevan a [data-dreamdex-extras] o ::root via :root
 *  - Las clases nuevas tienen prefijo .dx-  para no chocar con utilities
 *    auto-generadas del bundle.
 */

/* ─── Tipografía editorial ────────────────────────────────────
 * Fraunces para summaries y narrativas (tono de poema).
 * Plus Jakarta Sans queda para chrome/UI; Manrope para tabular numerals.
 * Lo cargamos en index.html via <link>.
 */
:root {
  --font-editorial: 'Fraunces', 'Plus Jakarta Sans', serif;
  --font-display:   'Plus Jakarta Sans', system-ui, sans-serif;
  --font-numeric:   'Manrope', system-ui, sans-serif;

  /* Sistema de gradientes por par-emoción. Lo aplica dreamdex-extras.js
   * según analysis.dominantEmotion + emotions[1]. Aquí solo declaramos los
   * tintes base de la paleta editorial. */
  --dx-aurora:    #6f8cff;
  --dx-bruise:    #a14572;
  --dx-mercury:   #cdd5db;
  --dx-ember:     #f08a3c;
  --dx-vellum:    #e9dec1;
  --dx-obsidian:  #0a0a14;
  --dx-iris:      #b591e3;
  --dx-tide:      #2c8a96;
  --dx-bone:      #d8d2bd;
  --dx-ink:       #1d1c2e;
  --dx-saffron:   #f2ca50;
  --dx-moss:      #6b8a4e;
}

/* Numeral tabular en streak counts y stats. El bundle puede usar cualquier
 * elemento; targeteamos cualquier número grande visible. */
.dx-num,
[data-dx-num] {
  font-family: var(--font-numeric);
  font-feature-settings: 'tnum' 1, 'lnum' 1;
  letter-spacing: -0.01em;
}

/* Summary y narrativas de reportes — tono editorial.
 * Marcado por dreamdex-extras.js cuando detecta el bloque de summary. */
.dx-editorial,
.dx-editorial p {
  font-family: var(--font-editorial);
  font-weight: 400;
  font-size: 1.18rem;
  line-height: 1.55;
  letter-spacing: -0.005em;
  color: var(--color-on-surface);
}
.dx-editorial p:first-of-type::first-line,
.dx-editorial > :first-child {
  font-style: italic;
}

/* Archetype names en italic small-caps con underline gold hairline. */
.dx-archetype-name {
  font-family: var(--font-editorial);
  font-style: italic;
  font-variant-caps: small-caps;
  letter-spacing: 0.04em;
  border-bottom: 1px solid var(--color-primary);
  padding-bottom: 1px;
}

/* ─── Lucid dream foil ─────────────────────────────────────────
 * Aplicado por extras.js cuando analysis.lucid === true.
 * Borde holográfico animado. */
@keyframes dx-foil-shift {
  0%   { background-position:   0% 50%; }
  100% { background-position: 200% 50%; }
}
.dx-lucid-foil {
  position: relative;
  isolation: isolate;
}
.dx-lucid-foil::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  background: conic-gradient(
    from 0deg,
    #b591e3, #6f8cff, #00e4f2, #f2ca50, #ddb7ff, #b591e3
  );
  background-size: 200% 200%;
  filter: blur(8px) saturate(140%);
  opacity: 0.55;
  z-index: -1;
  animation: dx-foil-shift 8s linear infinite;
}
.dx-lucid-mark {
  position: absolute;
  top: 8px;
  right: 12px;
  font-family: var(--font-editorial);
  font-style: italic;
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  color: var(--color-primary);
  opacity: 0.85;
  pointer-events: none;
}

/* ─── Wax-seal tags ────────────────────────────────────────────
 * Reemplaza los #chips de tags por sellos circulares de cera.
 * extras.js le pone .dx-tag a los <a/span> que empiezan con '#'. */
.dx-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--color-primary-fixed), var(--color-primary-container));
  color: var(--color-on-primary);
  font-family: var(--font-editorial);
  font-weight: 700;
  font-size: 1rem;
  text-transform: uppercase;
  box-shadow:
    inset -2px -3px 4px rgba(0, 0, 0, 0.35),
    inset 2px 2px 3px rgba(255, 255, 255, 0.18),
    0 1px 3px rgba(0, 0, 0, 0.5);
  margin-right: 6px;
  margin-bottom: 6px;
  cursor: pointer;
  transition: transform 0.18s ease;
}
.dx-tag:hover { transform: translateY(-1px) scale(1.05); }

/* ─── Splash override ──────────────────────────────────────────
 * extras.js renderiza el splash custom dentro de #root antes que React monte.
 * Aquí solo definimos los estilos. */
@keyframes dx-ink-bloom {
  0%   { transform: scale(0.6); opacity: 0; }
  60%  { transform: scale(1.08); opacity: 1; }
  100% { transform: scale(1.0);  opacity: 1; }
}
@keyframes dx-float {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}
.dx-splash {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 14px;
  background:
    radial-gradient(ellipse at 50% 50%, #1a1235 0%, #0d0d1a 70%),
    var(--dx-obsidian);
  pointer-events: none;
  transition: opacity 0.45s ease;
}
.dx-splash--hide { opacity: 0; }
.dx-splash__moon {
  font-size: 64px;
  animation: dx-ink-bloom 0.9s cubic-bezier(0.2, 0.8, 0.3, 1) forwards,
             dx-float 2.8s ease-in-out 1s infinite;
  filter: drop-shadow(0 0 18px rgba(242, 202, 80, 0.35));
}
.dx-splash__title {
  font-family: var(--font-editorial);
  font-style: italic;
  font-weight: 600;
  font-size: 28px;
  color: var(--color-primary);
  letter-spacing: -0.01em;
  opacity: 0;
  animation: dx-fade-up 0.6s ease 0.4s forwards;
}
.dx-splash__sub {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 500;
  color: rgba(208, 197, 175, 0.7);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0;
  animation: dx-fade-up 0.6s ease 0.55s forwards;
}
@keyframes dx-fade-up {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ─── Modal overlay genérico (paywall, share preview, wrapped) ─ */
.dx-modal {
  position: fixed;
  inset: 0;
  z-index: 9998;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  background: rgba(10, 10, 20, 0.72);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  animation: dx-fade-in 0.25s ease;
  padding: env(safe-area-inset-top, 24px) 0 env(safe-area-inset-bottom, 24px);
}
@keyframes dx-fade-in { from { opacity: 0; } to { opacity: 1; } }
.dx-modal__sheet {
  background: var(--color-surface);
  border-top-left-radius: 28px;
  border-top-right-radius: 28px;
  width: 100%;
  max-width: 520px;
  max-height: 90vh;
  overflow-y: auto;
  padding: 28px 24px 32px;
  box-shadow: 0 -10px 40px rgba(0, 0, 0, 0.5);
  animation: dx-slide-up 0.32s cubic-bezier(0.2, 0.8, 0.3, 1);
}
@keyframes dx-slide-up { from { transform: translateY(20%); } to { transform: translateY(0); } }
.dx-modal__close {
  position: absolute;
  top: 12px;
  right: 16px;
  background: transparent;
  border: 0;
  color: var(--color-on-surface-variant);
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  padding: 8px;
}
.dx-modal__handle {
  width: 36px;
  height: 4px;
  border-radius: 2px;
  background: var(--color-outline-variant);
  margin: 0 auto 18px;
}

/* ─── Paywall con recap ────────────────────────────────────────
 * Aparece cuando fetch /api/dreams/* devuelve 403 free_limit con recap. */
.dx-paywall__title {
  font-family: var(--font-editorial);
  font-style: italic;
  font-size: 1.6rem;
  color: var(--color-primary);
  margin-bottom: 12px;
}
.dx-paywall__lead {
  font-family: var(--font-editorial);
  font-size: 1.05rem;
  line-height: 1.5;
  color: var(--color-on-surface);
  margin-bottom: 20px;
}
.dx-paywall__recap {
  background: var(--color-surface-low);
  border-radius: 16px;
  padding: 16px 18px;
  margin-bottom: 22px;
}
.dx-paywall__recap-label {
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-on-surface-variant);
  margin-bottom: 4px;
}
.dx-paywall__recap-line {
  font-family: var(--font-editorial);
  font-size: 1rem;
  color: var(--color-on-surface);
  margin-bottom: 6px;
}
.dx-paywall__recap-line strong { color: var(--color-primary); font-weight: 600; }
.dx-cta {
  display: block;
  width: 100%;
  padding: 16px;
  border-radius: 14px;
  background: var(--color-primary);
  color: var(--color-on-primary);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1rem;
  border: 0;
  cursor: pointer;
  transition: transform 0.12s ease;
}
.dx-cta:active { transform: scale(0.98); }
.dx-cta--ghost {
  background: transparent;
  color: var(--color-on-surface-variant);
  margin-top: 10px;
}

/* ─── Streak share card prompt ─────────────────────────────────*/
.dx-streak-toast {
  position: fixed;
  bottom: calc(env(safe-area-inset-bottom, 16px) + 16px);
  left: 16px;
  right: 16px;
  z-index: 9997;
  background: linear-gradient(135deg, var(--color-primary), #ff9444);
  color: var(--color-on-primary);
  border-radius: 16px;
  padding: 14px 18px;
  font-family: var(--font-display);
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 12px;
  box-shadow: 0 8px 28px rgba(242, 202, 80, 0.32);
  animation: dx-slide-up 0.35s cubic-bezier(0.2, 0.8, 0.3, 1);
  cursor: pointer;
}
.dx-streak-toast__num {
  font-family: var(--font-numeric);
  font-feature-settings: 'tnum' 1;
  font-size: 1.6rem;
  font-weight: 800;
}

/* ─── Share preview (Dream Card / Wrapped / Calendar) ───────── */
.dx-share-card {
  width: 100%;
  max-width: 360px;
  aspect-ratio: 9 / 16;
  margin: 0 auto 20px;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.6);
}
.dx-share-card__canvas {
  width: 100%;
  height: 100%;
  display: block;
}

/* Floating action button para "Compartir este sueño" — extras.js lo
 * inyecta en la vista de detalle de sueño. */
.dx-fab-share {
  position: fixed;
  bottom: calc(env(safe-area-inset-bottom, 16px) + 80px);
  right: 16px;
  z-index: 50;
  width: 52px;
  height: 52px;
  border-radius: 26px;
  background: var(--color-primary);
  color: var(--color-on-primary);
  border: 0;
  font-size: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(242, 202, 80, 0.4);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.dx-fab-share:active {
  transform: scale(0.92);
  box-shadow: 0 2px 8px rgba(242, 202, 80, 0.5);
}

/* ─── Wrapped story (premium yearly) ─────────────────────────── */
.dx-wrapped {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  background: var(--dx-obsidian);
  padding: env(safe-area-inset-top, 20px) 20px env(safe-area-inset-bottom, 20px);
}
.dx-wrapped__progress {
  display: flex;
  gap: 4px;
  margin-bottom: 22px;
}
.dx-wrapped__pip {
  flex: 1;
  height: 3px;
  background: rgba(255, 255, 255, 0.18);
  border-radius: 2px;
  overflow: hidden;
}
.dx-wrapped__pip--filled { background: var(--color-primary); }
.dx-wrapped__pip--active::after {
  content: '';
  display: block;
  height: 100%;
  background: var(--color-primary);
  animation: dx-fill 5s linear forwards;
}
@keyframes dx-fill { from { width: 0; } to { width: 100%; } }
.dx-wrapped__slide {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  gap: 14px;
}
.dx-wrapped__hero {
  font-family: var(--font-editorial);
  font-style: italic;
  font-size: 2.2rem;
  line-height: 1.15;
  color: var(--color-primary);
}
.dx-wrapped__big {
  font-family: var(--font-numeric);
  font-feature-settings: 'tnum' 1;
  font-size: 5.5rem;
  font-weight: 200;
  color: var(--color-primary);
  line-height: 1;
}
.dx-wrapped__nav {
  display: flex;
  justify-content: space-between;
  margin-top: 18px;
}
.dx-wrapped__nav button {
  background: transparent;
  border: 0;
  color: var(--color-on-surface-variant);
  font-family: var(--font-display);
  font-size: 0.9rem;
  cursor: pointer;
  padding: 8px 12px;
}

/* ─── Calendar emotional heatmap shareable enhancement ─────── */
.dx-cal-share-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 999px;
  background: var(--color-surface-low);
  color: var(--color-on-surface);
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 600;
  border: 1px solid var(--color-outline-variant);
  cursor: pointer;
  margin-top: 12px;
}

/* ─── Pill de cupo restante ──────────────────────────────────── */
.dx-quota-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(242, 202, 80, 0.15);
  color: var(--color-primary);
  font-family: var(--font-display);
  font-size: 0.78rem;
  font-weight: 600;
}

/* ─── Push permission prompt soft ────────────────────────────── */
.dx-push-prompt {
  margin: 16px;
  padding: 14px 16px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--color-secondary-container), var(--color-surface-high));
  color: var(--color-on-surface);
  font-family: var(--font-display);
  font-size: 0.92rem;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.dx-push-prompt__buttons {
  display: flex;
  gap: 8px;
}
.dx-push-prompt__buttons button {
  flex: 1;
  padding: 10px;
  border-radius: 10px;
  border: 0;
  font-family: var(--font-display);
  font-weight: 600;
  cursor: pointer;
}
.dx-push-prompt__primary {
  background: var(--color-primary);
  color: var(--color-on-primary);
}
.dx-push-prompt__ghost {
  background: transparent;
  color: var(--color-on-surface-variant);
}
