/* ============================================================
   GG33 - Numerology Calculator page. Builds on home.css tokens
   and lifepath.css base (lp-body, lp-bg, lp-top, lp-main, lp-section...).
   Elite ember/dark calculator console + instant result cards.
   ============================================================ */

/* Hero */
.calc-hero { text-align: center; padding: 2.4rem 0 0.6rem; }
.calc-hero .lp-kicker { margin-bottom: 0.5rem; }
.calc-hero h1 { font-family: var(--display); font-size: clamp(2.2rem, 9vw, 3.2rem); font-weight: 700; letter-spacing: -0.03em; line-height: 1.04; margin: 0; }
.calc-hero h1 .hl { color: var(--orange-2); display: block; }
.calc-hero .calc-sub { font-size: 1.05rem; line-height: 1.55; color: var(--soft); margin: 0.9rem auto 0; max-width: 38ch; }

/* The console */
.calc-wrap {
  margin: 1.8rem auto 0; max-width: 30rem;
  padding: 1.4rem 1.3rem 1.5rem; border-radius: 22px;
  border: 1px solid rgba(255, 107, 20, 0.32);
  background: linear-gradient(180deg, rgba(255, 107, 20, 0.1), rgba(247, 244, 236, 0.02));
  box-shadow: 0 24px 70px rgba(255, 107, 20, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(14px);
}
.calc-wrap-label { font-size: 0.66rem; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--orange-2); text-align: center; margin: 0 0 1rem; }
.calc-form { display: grid; grid-template-columns: 1.3fr 0.8fr 1fr; gap: 0.6rem; }
@media (max-width: 480px) {
  .calc-form { grid-template-columns: 1.15fr 0.85fr 1fr; gap: 0.45rem; }
  .calc-select { padding: 0 1.6rem 0 0.65rem; background-position: right 0.55rem center; font-size: 0.95rem; }
}
.calc-field { display: flex; flex-direction: column; gap: 0.35rem; }
.calc-field label { font-size: 0.64rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); padding-left: 0.2rem; }
.calc-select {
  appearance: none; -webkit-appearance: none;
  width: 100%; min-height: 3.1rem; padding: 0 2rem 0 0.85rem;
  border-radius: 13px; border: 1px solid var(--line-strong);
  background: rgba(8, 5, 3, 0.6);
  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'%3E%3Cpath d='M6 9l6 6 6-6' stroke='%23ff8a2c' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 0.8rem center;
  color: var(--ink); font-family: var(--sans); font-size: 1rem; font-weight: 600;
  transition: border-color 160ms var(--ease), box-shadow 160ms var(--ease);
}
.calc-select:focus { outline: none; border-color: var(--orange); box-shadow: 0 0 0 3px rgba(255, 107, 20, 0.18); }
.calc-select option { background: #0a0604; color: var(--ink); }
.calc-go {
  margin-top: 1rem; width: 100%; min-height: 3.4rem;
  border: 0; border-radius: 999px; cursor: pointer;
  background: linear-gradient(135deg, #ff8a2c, #df520d);
  color: #160a04; font-family: var(--sans); font-weight: 700; font-size: 1rem;
  box-shadow: 0 16px 40px rgba(255, 107, 20, 0.3);
  transition: transform 160ms var(--ease), box-shadow 160ms var(--ease), opacity 160ms var(--ease);
}
.calc-go:hover { transform: translateY(-2px); box-shadow: 0 20px 50px rgba(255, 107, 20, 0.4); }
.calc-go:active { transform: translateY(0); }
.calc-go:disabled { opacity: 0.5; cursor: not-allowed; transform: none; box-shadow: none; }
.calc-hint { text-align: center; font-size: 0.78rem; color: var(--muted); margin: 0.85rem 0 0; }
.calc-err { text-align: center; font-size: 0.82rem; color: var(--orange-2); margin: 0.7rem 0 0; min-height: 1rem; }

/* Results */
.calc-results { margin: 1.6rem auto 0; max-width: 32rem; display: grid; gap: 0.8rem; }
.calc-results[hidden] { display: none; }
.calc-results.is-in .calc-card { animation: calcCardIn 560ms var(--ease) both; }
.calc-results.is-in .calc-card:nth-child(2) { animation-delay: 110ms; }
.calc-results.is-in .calc-card:nth-child(3) { animation-delay: 240ms; }
@keyframes calcCardIn { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }

.calc-card {
  display: grid; grid-template-columns: 4.6rem 1fr; gap: 1rem; align-items: center;
  padding: 1.05rem 1.15rem; border-radius: 18px;
  border: 1px solid var(--line); background: rgba(247, 244, 236, 0.03);
}
.calc-card .calc-num {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 4.6rem;
  height: 4.6rem;
  border-radius: 50%;
  border: 1px solid rgba(255, 138, 44, 0.3);
  background: radial-gradient(circle at 50% 44%, rgba(255, 107, 20, 0.16), rgba(255, 107, 20, 0.03) 60%, transparent 75%);
  box-shadow: inset 0 0 18px rgba(0, 0, 0, 0.45);
  font-family: var(--display);
  font-weight: 700;
  font-size: 2.1rem;
  line-height: 1;
  color: var(--orange-2);
  text-align: center;
  letter-spacing: -0.03em;
  text-shadow: 0 6px 30px rgba(255, 107, 20, 0.35);
}
.calc-card .calc-num::before { content: ""; position: absolute; inset: 5px; border-radius: 50%; border: 1px solid rgba(255, 138, 44, 0.13); }
.calc-card .calc-medal { width: 4.6rem; height: 4.6rem; border-radius: 50%; overflow: hidden; border: 1px solid rgba(255, 107, 20, 0.3); background: #0a0604; }
.calc-card .calc-medal img { width: 100%; height: 100%; object-fit: cover; display: block; }
.calc-card .calc-k { font-size: 0.64rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); margin: 0 0 0.15rem; }
.calc-card .calc-ttl { font-family: var(--display); font-weight: 700; font-size: 1.15rem; color: var(--ink); margin: 0; line-height: 1.1; }
.calc-card .calc-note { font-size: 0.9rem; color: var(--soft); margin: 0.3rem 0 0; line-height: 1.45; }
.calc-card .calc-readmore { display: inline-block; margin: 0.45rem 0 0; font-size: 0.8rem; font-weight: 600; color: var(--orange-2); text-decoration: none; border-bottom: 1px solid rgba(255, 138, 44, 0.4); }

/* Post-result CTA */
.calc-unlock { margin: 1.3rem auto 0; max-width: 32rem; padding: 1.5rem 1.3rem; border-radius: 20px; border: 1px solid rgba(255, 107, 20, 0.3); background: linear-gradient(180deg, rgba(255, 107, 20, 0.12), rgba(247, 244, 236, 0.015)); text-align: center; }
.calc-unlock[hidden] { display: none; }
.calc-unlock h2 { font-family: var(--display); font-size: clamp(1.3rem, 5vw, 1.7rem); font-weight: 700; margin: 0 0 0.4rem; letter-spacing: -0.02em; }
.calc-unlock p { color: var(--soft); margin: 0 auto 1.1rem; font-size: 0.96rem; line-height: 1.55; max-width: 36ch; }
.calc-unlock-row { display: flex; flex-direction: column; gap: 0.6rem; max-width: 22rem; margin: 0 auto; }
.calc-cta { display: flex; align-items: center; justify-content: center; min-height: 3.2rem; border-radius: 999px; font-family: var(--sans); font-weight: 600; font-size: 0.96rem; text-decoration: none; }
.calc-cta-solid { background: linear-gradient(135deg, #ff8a2c, #df520d); color: #160a04; box-shadow: 0 14px 36px rgba(255, 107, 20, 0.3); }
.calc-cta-ghost { border: 1px solid var(--line-strong); color: var(--ink); background: rgba(247, 244, 236, 0.04); }

/* Worked-examples table */
.calc-table-wrap { overflow-x: auto; margin: 1.2rem 0 0; border-radius: 14px; border: 1px solid var(--line); }
.calc-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; min-width: 28rem; }
.calc-table th, .calc-table td { text-align: left; padding: 0.7rem 0.9rem; border-bottom: 1px solid rgba(247, 244, 236, 0.07); }
.calc-table th { font-size: 0.66rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); font-weight: 600; }
.calc-table td { color: var(--soft); }
.calc-table td:first-child { color: var(--ink); font-weight: 600; }
.calc-table tr:last-child td { border-bottom: 0; }

/* Press / proof strip */
.calc-proof { display: flex; flex-wrap: wrap; justify-content: center; gap: 0.5rem 1.6rem; margin: 1.4rem auto 0; max-width: 32rem; text-align: center; }
.calc-proof span { font-size: 0.8rem; color: var(--muted); }
.calc-proof strong { color: var(--soft); font-weight: 600; }

@media (prefers-reduced-motion: reduce) {
  .calc-results.is-in .calc-card { animation: none; }
  .calc-go:hover { transform: none; }
}

/* keyboard focus - same orange treatment as the homepage */
a:focus-visible, button:focus-visible { outline: 2px solid var(--orange-2, #ff8a2c); outline-offset: 2px; }

/* press feedback on touch */
@media (hover: none) {
  .calc-cta:active, .calc-go:active:not(:disabled) { transform: scale(0.97); transition: transform 80ms ease; }
}

/* ============================================================
   Desktop layer (min-width: 761px) — mobile rendering untouched.
   The console and result cards scale up to a real desktop tool.
   ============================================================ */
@media (min-width: 761px) {
  .calc-hero { padding-top: 4rem; }
  .calc-hero h1 { font-size: clamp(3rem, 4.6vw, 4rem); }
  .calc-hero .calc-sub { font-size: 1.14rem; max-width: 52ch; }

  .calc-wrap { max-width: 38rem; margin-top: 2.4rem; padding: 1.8rem 1.8rem 1.9rem; border-radius: 26px; }
  .calc-form { gap: 0.8rem; }
  .calc-select { min-height: 3.4rem; font-size: 1.05rem; }
  .calc-go { margin-top: 1.2rem; min-height: 3.6rem; font-size: 1.06rem; }

  .calc-results { max-width: 38rem; margin-top: 2rem; gap: 0.9rem; }
  .calc-card { padding: 1.25rem 1.4rem; border-radius: 20px; grid-template-columns: 5.2rem 1fr; }
  .calc-card .calc-num, .calc-card .calc-medal { width: 5.2rem; height: 5.2rem; }
  .calc-card .calc-num { font-size: 2.4rem; }
  .calc-card .calc-ttl { font-size: 1.3rem; }
  .calc-card .calc-note { font-size: 0.97rem; }

  .calc-unlock { max-width: 38rem; padding: 2rem 1.8rem; }
  .calc-unlock-row { flex-direction: row; justify-content: center; max-width: none; gap: 0.8rem; }
  .calc-cta { padding: 0 1.7rem; }

  .calc-proof { max-width: none; gap: 0.5rem 2.2rem; }
  .calc-proof span { font-size: 0.86rem; }

  .calc-table { font-size: 0.98rem; }
  .calc-table th, .calc-table td { padding: 0.85rem 1.1rem; }
}
