.lani-oracle {
  --lani-oracle-blue: #1e7dde;
  --lani-oracle-cyan: #00c4c4;
  --lani-oracle-ink: #1d1b20;
  --lani-oracle-muted: #5f6f7a;
  --lani-oracle-gold: #c99a3a;
  --lani-oracle-line: #c8ecf5;
  color: var(--lani-oracle-ink);
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  margin: 28px auto;
  max-width: 430px;
  width: 100%;
}

.lani-oracle * {
  box-sizing: border-box;
}

.lani-oracle__panel {
  background:
    radial-gradient(circle at 86% 0%, rgba(0, 196, 196, 0.16), transparent 36%),
    linear-gradient(135deg, #f8fdff 0%, #ecfbff 48%, #e9fffb 100%);
  border: 1px solid var(--lani-oracle-line);
  border-radius: 8px;
  box-shadow: 0 12px 30px rgba(16, 42, 58, 0.08);
  overflow: hidden;
  padding: 24px 18px 22px;
  position: relative;
  text-align: center;
}

.lani-oracle__halo {
  background:
    conic-gradient(from 220deg, rgba(30, 125, 222, 0.88), rgba(0, 196, 196, 0.88), rgba(255, 214, 112, 0.92), rgba(30, 125, 222, 0.88));
  border-radius: 999px;
  display: grid;
  height: 68px;
  margin: 0 auto 14px;
  place-items: center;
  width: 68px;
}

.lani-oracle__halo span {
  background:
    radial-gradient(circle at 48% 36%, #fff 0 20%, rgba(255,255,255,0.72) 21% 44%, transparent 45%),
    linear-gradient(135deg, #eaf8ff, #fff5cf);
  border-radius: 999px;
  height: 46px;
  width: 46px;
}

.lani-oracle__eyebrow {
  color: #0077a7;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0;
  margin: 0 0 8px;
}

.lani-oracle__title {
  font-size: clamp(24px, 5.8vw, 30px);
  line-height: 1.42;
  margin: 0;
}

.lani-oracle__lead,
.lani-oracle__note,
.lani-oracle__error {
  font-size: 15px;
  line-height: 1.9;
}

.lani-oracle__lead {
  margin: 14px auto 0;
  max-width: 440px;
}

.lani-oracle__note {
  background: rgba(255, 255, 255, 0.86);
  border: 1px solid var(--lani-oracle-line);
  border-radius: 8px;
  color: #32465a;
  display: grid;
  gap: 4px;
  margin: 18px auto 0;
  max-width: 460px;
  padding: 13px 14px;
  text-align: left;
}

.lani-oracle__button {
  appearance: none;
  background: linear-gradient(90deg, var(--lani-oracle-blue), var(--lani-oracle-cyan));
  border: 0;
  border-radius: 8px;
  box-shadow: 0 10px 22px rgba(0, 160, 190, 0.22);
  color: #fff;
  cursor: pointer;
  font-size: 16px;
  font-weight: 900;
  margin-top: 18px;
  min-height: 52px;
  padding: 14px 22px;
  width: min(100%, 360px);
}

.lani-oracle__button:disabled {
  cursor: wait;
  opacity: 0.66;
}

.lani-oracle[data-locked="1"] .lani-oracle__button {
  background: #fff;
  border: 1px solid var(--lani-oracle-line);
  box-shadow: none;
  color: #0c5a78;
}

.lani-oracle__locked-note {
  color: var(--lani-oracle-muted);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.7;
  margin: 10px 0 0;
}

.lani-oracle__error {
  color: #b73232;
  font-weight: 700;
}

.lani-oracle__modal {
  inset: 0;
  opacity: 0;
  position: fixed;
  transition: opacity 0.18s ease;
  visibility: hidden;
  z-index: 99999;
}

.lani-oracle__modal.is-visible {
  opacity: 1;
  visibility: visible;
}

.lani-oracle__backdrop {
  background: rgba(13, 18, 28, 0.78);
  inset: 0;
  position: absolute;
}

.lani-oracle__dialog {
  background:
    radial-gradient(circle at 80% 0%, rgba(217, 255, 246, 0.78), transparent 28%),
    linear-gradient(180deg, #fff 0%, #faffff 100%);
  border: 1px solid rgba(198, 238, 244, 0.96);
  border-radius: 18px;
  box-shadow: 0 22px 70px rgba(5, 13, 24, 0.32);
  left: 50%;
  max-height: min(86vh, 760px);
  max-width: 430px;
  overflow: auto;
  padding: 18px;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -48%) scale(0.98);
  transition: transform 0.18s ease;
  width: calc(100vw - 32px);
}

.lani-oracle__modal.is-visible .lani-oracle__dialog {
  transform: translate(-50%, -50%) scale(1);
}

.lani-oracle__close {
  align-items: center;
  background: #f0fbff;
  border: 1px solid #cceef5;
  border-radius: 999px;
  color: #0c5a78;
  cursor: pointer;
  display: flex;
  font-size: 20px;
  font-weight: 900;
  height: 40px;
  justify-content: center;
  left: 14px;
  position: sticky;
  top: 0;
  width: 40px;
  z-index: 2;
}

.lani-oracle__loading {
  padding: 16px 6px 26px;
  text-align: center;
}

.lani-oracle__spinner {
  animation: lani-oracle-pulse 1.8s ease-in-out infinite;
  background: conic-gradient(from 180deg, var(--lani-oracle-blue), var(--lani-oracle-cyan), #ffdc81, var(--lani-oracle-blue));
  border-radius: 999px;
  display: grid;
  height: 92px;
  margin: 0 auto 18px;
  place-items: center;
  width: 92px;
}

.lani-oracle__spinner span {
  background: #fff;
  border-radius: 999px;
  height: 58px;
  width: 58px;
}

.lani-oracle__loading-kicker,
.lani-oracle__result-kicker,
.lani-oracle__angel {
  color: #0077a7;
  display: block;
  font-size: 12px;
  font-weight: 900;
  margin: 0 0 8px;
  text-align: center;
}

.lani-oracle__loading h2,
.lani-oracle__result-title {
  align-items: center;
  background: linear-gradient(90deg, var(--lani-oracle-blue), var(--lani-oracle-cyan)) !important;
  border: 0 !important;
  border-radius: 8px;
  box-shadow: 0 12px 26px rgba(0, 160, 190, 0.18) !important;
  color: #fff;
  display: flex;
  flex-wrap: wrap;
  font-size: 22px;
  gap: 8px;
  justify-content: center;
  line-height: 1.45;
  margin: 0 0 18px;
  padding: 13px 14px !important;
  text-align: center;
}

.lani-oracle__reading.is-no .lani-oracle__result-title {
  background: linear-gradient(90deg, #53a6d8, #8cded5) !important;
}

.lani-oracle__loading h2 {
  background: none !important;
  box-shadow: none !important;
  color: var(--lani-oracle-ink);
  display: block;
  font-size: 24px;
  margin: 0 0 14px;
  padding: 0 !important;
}

.lani-oracle__result-title span,
.lani-oracle__result-title small {
  color: inherit;
  font: inherit;
  letter-spacing: 0;
}

.lani-oracle__result-title small::before {
  content: "/";
  margin-right: 8px;
  opacity: 0.82;
}

.lani-oracle__loading h2::before,
.lani-oracle__loading h2::after,
.lani-oracle__result-title::before,
.lani-oracle__result-title::after,
.lani-oracle__card-text h3::before,
.lani-oracle__card-text h3::after,
.lani-oracle__section h3::after {
  content: none !important;
  display: none !important;
}

.lani-oracle__loading p {
  line-height: 1.9;
  margin: 0 auto;
  max-width: 330px;
}

.lani-oracle__card-stack {
  display: grid;
  gap: 16px;
  margin: 8px 0 20px;
  text-align: center;
}

.lani-oracle__card-figure {
  display: grid;
  gap: 8px;
  justify-items: center;
  margin: 0;
}

.lani-oracle__card {
  aspect-ratio: 2 / 3;
  border-radius: 13px;
  box-shadow: 0 12px 28px rgba(17, 38, 58, 0.18);
  overflow: hidden;
  position: relative;
  width: min(56vw, 178px);
}

.lani-oracle__card img {
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.lani-oracle__card-number {
  background: rgba(16, 42, 58, 0.72);
  border-radius: 999px;
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  left: 8px;
  min-width: 24px;
  padding: 3px 7px;
  position: absolute;
  top: 8px;
}

.lani-oracle__card-text {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(244, 253, 255, 0.74));
  border: 1px solid #d6f0f5;
  border-radius: 8px;
  padding: 14px 14px 15px;
  text-align: center;
}

.lani-oracle__card-text h3 {
  background: none !important;
  border: 0 !important;
  box-shadow: none !important;
  font-size: 23px;
  line-height: 1.45;
  margin: 0 0 6px;
  padding: 0 !important;
}

.lani-oracle__card-label {
  color: #0077a7;
  display: block;
  font-size: 12px;
  font-weight: 900;
  margin: 0 0 6px;
}

.lani-oracle__role {
  color: var(--lani-oracle-muted);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.7;
  margin: 0;
}

.lani-oracle__answer {
  background: linear-gradient(135deg, rgba(30, 125, 222, 0.11), rgba(0, 196, 196, 0.12));
  border: 1px solid #c8edf4;
  border-radius: 8px;
  line-height: 1.9;
  margin: 0 0 14px;
  padding: 14px;
}

.lani-oracle__answer strong {
  color: #084b72;
  display: block;
  font-size: 16px;
  margin-bottom: 8px;
}

.lani-oracle__answer p,
.lani-oracle__section p,
.lani-oracle__notice {
  line-height: 1.9;
  margin: 0;
}

.lani-oracle__section {
  border-top: 1px solid #d6f0f5;
  padding: 16px 0 0;
  margin-top: 16px;
}

.lani-oracle__section h3 {
  border: 0;
  color: #14324a;
  font-size: 17px;
  line-height: 1.5;
  margin: 0 0 8px;
  padding: 0 0 0 12px;
  position: relative;
}

.lani-oracle__section h3::before {
  background: linear-gradient(180deg, var(--lani-oracle-blue), var(--lani-oracle-cyan));
  border-radius: 999px;
  content: "";
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 4px;
}

.lani-oracle__notice {
  color: var(--lani-oracle-muted);
  font-size: 12px;
  margin-top: 16px;
}

.lani-oracle__reading.is-no .lani-oracle__answer {
  background: linear-gradient(135deg, rgba(255, 248, 230, 0.94), rgba(235, 255, 252, 0.88));
  border-color: #efd99e;
}

.lani-oracle-is-open {
  overflow: hidden;
}

@keyframes lani-oracle-pulse {
  0%, 100% {
    filter: brightness(1);
    transform: scale(1);
  }
  50% {
    filter: brightness(1.08);
    transform: scale(1.05);
  }
}

@media (max-width: 420px) {
  .lani-oracle__dialog {
    border-radius: 16px 16px 0 0;
    bottom: 0;
    left: 0;
    max-height: 88vh;
    max-width: none;
    top: auto;
    transform: translateY(18px);
    width: 100%;
  }

  .lani-oracle__modal.is-visible .lani-oracle__dialog {
    transform: translateY(0);
  }

  .lani-oracle__card {
    width: min(52vw, 166px);
  }
}
