/* Calculadora Numerológica — formulario texto + alfabeto, y resultado con el número,
   su desglose, atributos esotéricos, significado y aspectos positivos/negativos. */

.num-page { color: #f3ead2; }
.num-header { text-align: center; margin-bottom: 1.4rem; }
.num-header h1 {
  font-family: 'Cinzel', 'Times New Roman', serif;
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  color: #f0d68a;
  text-shadow: 0 0 16px rgba(240,214,138,0.45);
  margin: 0 0 .6rem;
}
.num-intro {
  max-width: 64ch;
  margin: 0 auto;
  color: rgba(243,234,210,0.85);
  line-height: 1.55;
}

.num-app {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 1.4rem;
}

/* ---------- Form ---------- */
.num-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1.3rem 1.2rem;
  border-radius: 14px;
  border: 1px solid rgba(240,214,138,0.28);
  background:
    radial-gradient(120% 90% at 50% 0%, rgba(255,240,200,0.06), transparent 60%),
    linear-gradient(165deg, #2a2440 0%, #16121f 100%);
}
.num-label { font-weight: 700; color: #f0d68a; }
.num-input {
  width: 100%;
  padding: .8rem 1rem;
  background: rgba(20,16,30,0.6);
  border: 1px solid rgba(240,214,138,0.4);
  border-radius: 10px;
  color: #f3ead2;
  font-size: 1.05rem;
  font-family: inherit;
  box-sizing: border-box;
}
.num-input:focus {
  outline: none;
  border-color: rgba(240,214,138,0.85);
  box-shadow: 0 0 0 3px rgba(240,214,138,0.2);
}
.num-input::placeholder { color: rgba(243,234,210,0.4); }

.num-alphabet {
  border: 1px solid rgba(240,214,138,0.25);
  border-radius: 10px;
  padding: .7rem 1rem;
  display: flex;
  flex-wrap: wrap;
  gap: 1.2rem;
  align-items: center;
}
.num-alphabet legend { padding: 0 .4rem; color: rgba(243,234,210,0.7); font-size: .9rem; }
.num-radio { display: inline-flex; align-items: center; gap: .4rem; cursor: pointer; }
.num-radio input { accent-color: #d6b24a; }
.num-calc { align-self: flex-start; min-width: 160px; }

/* ---------- Result ---------- */
.num-headline {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  flex-wrap: wrap;
  padding: 1.1rem 1.2rem;
  border-radius: 14px;
  background: linear-gradient(165deg, #3a2c12 0%, #1a1408 100%);
  border: 1px solid rgba(240,214,138,0.35);
}
.num-img {
  width: 130px;
  height: auto;
  flex: none;
  filter: drop-shadow(0 6px 16px rgba(0,0,0,0.5));
}
.num-headline-text { flex: 1; min-width: 200px; }
.num-processed { margin: 0 0 .4rem; color: rgba(243,234,210,0.8); }
.num-breakdown {
  margin: 0;
  line-height: 1.7;
  color: rgba(243,234,210,0.92);
  word-break: break-word;
}
.num-final {
  color: #ffe08a;
  font-size: 1.5rem;
  text-shadow: 0 0 12px rgba(255,224,138,0.6);
}
.num-master-note {
  margin: .6rem 0 0;
  font-size: .85rem;
  font-style: italic;
  color: #ffd28a;
}

/* Attributes grid */
.num-attrs {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: .5rem;
}
.num-attr {
  display: flex;
  flex-direction: column;
  gap: .1rem;
  padding: .55rem .8rem;
  border-radius: 9px;
  background: rgba(40,32,18,0.5);
  border-left: 3px solid rgba(240,214,138,0.55);
}
.num-attr-label {
  font-size: .72rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(240,214,138,0.7);
}
.num-attr-value { color: #f3ead2; font-weight: 600; }

/* Meaning */
.num-meaning-block {
  padding: 1.1rem 1.2rem;
  border-radius: 12px;
  background: rgba(26,20,30,0.55);
  border: 1px solid rgba(240,214,138,0.18);
}
.num-meaning-title {
  font-family: 'Cinzel', 'Times New Roman', serif;
  font-size: 1.2rem;
  color: #f0d68a;
  margin: 0 0 .6rem;
}
.num-meaning { margin: 0; line-height: 1.6; color: rgba(243,234,210,0.92); }

/* Positives / negatives */
.num-posneg {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: .9rem;
}
.num-pos, .num-neg {
  padding: .9rem 1.1rem;
  border-radius: 12px;
  background: rgba(26,20,30,0.55);
}
.num-pos { border-left: 4px solid #4caf6a; }
.num-neg { border-left: 4px solid #d65a5a; }
.num-pos-title { color: #8fffa8; margin: 0 0 .5rem; font-size: 1.05rem; }
.num-neg-title { color: #ffb0b0; margin: 0 0 .5rem; font-size: 1.05rem; }
.num-pos-text, .num-neg-text { margin: 0; line-height: 1.55; color: rgba(243,234,210,0.9); }

.num-error { text-align: center; color: #ff9999; margin: 0; }

@media (max-width: 520px) {
  .num-calc { align-self: stretch; }
  .num-img { width: 96px; }
}
