@font-face {
  font-family: "Cinzel";
  font-style: normal;
  font-weight: 400 900;
  font-display: swap;
  src: url("./assets/fonts/cinzel-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: "Cinzel Decorative";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("./assets/fonts/cinzel-decorative-700-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root {
  --ink: #050409;
  --midnight: #0b0712;
  --violet-black: #130b1d;
  --deep-plum: #21102c;
  --ivory: #eee8dc;
  --soft-ivory: rgba(238, 232, 220, 0.74);
  --gold: #b6986a;
  --dim-gold: rgba(182, 152, 106, 0.62);
  --wax: #8f3f4d;
  --wax-dark: #5d2634;
  --rose: #b98092;
  --edge: clamp(1.45rem, 3.45vw, 4.55rem);
  --display: "Cinzel", Didot, "Bodoni 72", "Bodoni MT", Georgia, serif;
  --serif: "Cinzel", Didot, "Bodoni 72", "Bodoni MT", Georgia, serif;
  --ornate: "Cinzel Decorative", "Cinzel", Georgia, serif;
  --sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html, body { min-height: 100%; }
body { margin: 0; background: var(--ink); color: var(--ivory); font-family: var(--sans); }
a { color: inherit; text-decoration: none; }

.page-shell { min-height: 100svh; overflow: hidden; background: var(--ink); }
.hero { position: relative; isolation: isolate; min-height: 100svh; overflow: hidden; background: var(--ink); }

.hero__image {
  position: absolute;
  inset: 0;
  z-index: -4;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 50%;
  filter: saturate(0.95) contrast(1.08) brightness(0.86);
}

.hero__shade {
  position: absolute;
  inset: 0;
  z-index: -3;
  pointer-events: none;
  background:
    radial-gradient(circle at 33% 25%, rgba(204, 183, 229, 0.08), transparent 20rem),
    radial-gradient(circle at 82% 64%, rgba(214, 155, 85, 0.12), transparent 24rem),
    linear-gradient(90deg, rgba(5, 4, 9, 0.82) 0%, rgba(5, 4, 9, 0.42) 38%, rgba(5, 4, 9, 0.12) 74%, rgba(5, 4, 9, 0.26) 100%),
    linear-gradient(180deg, rgba(5, 4, 9, 0.28), transparent 45%, rgba(5, 4, 9, 0.52));
}

.hero__stars {
  position: absolute;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  opacity: 0.18;
  mix-blend-mode: screen;
  background-image:
    radial-gradient(circle at 18% 22%, rgba(238,232,220,0.8) 0 1px, transparent 1.5px),
    radial-gradient(circle at 28% 62%, rgba(182,152,106,0.8) 0 1px, transparent 1.5px),
    radial-gradient(circle at 46% 34%, rgba(238,232,220,0.55) 0 1px, transparent 1.5px),
    radial-gradient(circle at 74% 18%, rgba(238,232,220,0.55) 0 1px, transparent 1.5px);
}

.hero__wordmark,
.hero__nav,
.hero__rail,
.hero__title-block p,
.hero__seal {
  font-family: var(--display);
  font-size: clamp(0.62rem, 0.72vw, 0.76rem);
  font-weight: 500;
  letter-spacing: 0.28em;
  line-height: 1.65;
  text-transform: uppercase;
  text-shadow: 0 1px 22px rgba(0, 0, 0, 0.42);
}

.hero__wordmark {
  position: absolute;
  top: clamp(1.55rem, 3.15vw, 3rem);
  left: var(--edge);
  color: rgba(238, 232, 220, 0.66);
}

.hero__nav {
  position: absolute;
  top: clamp(1.55rem, 3.15vw, 3rem);
  right: var(--edge);
  display: flex;
  align-items: center;
  gap: clamp(0.9rem, 1.8vw, 1.6rem);
  color: rgba(238, 232, 220, 0.58);
}
.hero__nav a { transition: color 180ms ease; }
.hero__nav a:hover, .hero__nav a:focus-visible { color: var(--ivory); outline: none; }

.hero__rail {
  position: absolute;
  top: 50%;
  margin: 0;
  color: rgba(238, 232, 220, 0.38);
  writing-mode: vertical-rl;
  text-orientation: mixed;
  white-space: nowrap;
}
.hero__rail span { color: var(--dim-gold); padding-inline: 0.85rem; }
.hero__rail--left { left: clamp(1.05rem, 2vw, 1.8rem); transform: translateY(-50%) rotate(180deg); }
.hero__rail--right { right: clamp(1.05rem, 2vw, 1.8rem); transform: translateY(-50%); }

.hero__title-block {
  position: absolute;
  left: var(--edge);
  top: 50%;
  transform: translateY(-50%);
  max-width: min(48rem, 54vw);
}

.hero__title-block h1 {
  display: grid;
  margin: 0;
  color: rgba(238, 232, 220, 0.92);
  font-family: var(--display);
  font-weight: 400;
  letter-spacing: -0.035em;
  line-height: 0.84;
  text-shadow: 0 10px 48px rgba(0, 0, 0, 0.56);
}
.hero__title-block h1 span { font-size: clamp(5rem, 10.8vw, 12.5rem); }
.hero__title-block h1 em {
  margin: 0.04em 0 0.03em 0.22em;
  color: rgba(182, 152, 106, 0.9);
  font-size: clamp(2rem, 3.4vw, 4.15rem);
  font-style: italic;
  letter-spacing: 0.02em;
  line-height: 0.85;
}
.hero__title-block p {
  margin: clamp(0.85rem, 1.45vw, 1.25rem) 0 0 0.2rem;
  color: rgba(211, 188, 147, 0.9);
  font-size: clamp(0.88rem, 1.12vw, 1.18rem);
  letter-spacing: 0.11em;
  text-transform: none;
}

.hero__seal {
  position: absolute;
  right: clamp(2.4rem, 6vw, 6.2rem);
  bottom: clamp(2.7rem, 8vw, 6.6rem);
  display: grid;
  place-items: center;
  gap: 0.2rem;
  width: clamp(6.8rem, 9.4vw, 9.4rem);
  aspect-ratio: 1;
  border: 1px solid rgba(238, 232, 220, 0.3);
  border-radius: 50%;
  background:
    radial-gradient(circle at 36% 28%, rgba(255,255,255,0.08), transparent 32%),
    linear-gradient(145deg, rgba(143, 63, 77, 0.94), rgba(93, 38, 52, 0.94));
  color: rgba(238, 232, 220, 0.88);
  text-align: center;
  letter-spacing: 0.16em;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.35), 0 0 0 0.6rem rgba(143, 63, 77, 0.09);
  transition: transform 180ms ease, box-shadow 180ms ease, filter 180ms ease;
}
.hero__seal i { color: rgba(182, 152, 106, 0.9); font-style: normal; font-size: 1rem; }
.hero__seal span { display: block; }
.hero__seal:hover, .hero__seal:focus-visible { transform: translateY(-2px) scale(1.02); filter: brightness(1.05); outline: none; }

@media (max-width: 920px) {
  .hero__image { object-position: 60% 50%; }
  .hero__title-block { max-width: 64vw; }
  .hero__title-block h1 span { font-size: clamp(4.2rem, 12.8vw, 8.1rem); }
  .hero__rail--right { display: none; }
}

@media (max-width: 680px) {
  :root { --edge: 1.15rem; }
  .hero__image { object-position: 56% 50%; filter: saturate(0.98) contrast(1.08) brightness(1.04); }
  .hero__shade { background: radial-gradient(circle at 70% 22%, rgba(238, 232, 220, 0.12), transparent 12rem), linear-gradient(90deg, rgba(5,4,9,0.84), rgba(5,4,9,0.28) 56%, rgba(5,4,9,0.03)), linear-gradient(180deg, rgba(5,4,9,0.22), transparent 46%, rgba(5,4,9,0.52)); }
  .hero__rail { display: none; }
  .hero__wordmark { max-width: 12rem; line-height: 1.4; }
  .hero__title-block { left: var(--edge); right: var(--edge); top: 45%; max-width: none; }
  .hero__title-block h1 { line-height: 0.88; }
  .hero__title-block h1 span { font-size: clamp(3.05rem, 15.5vw, 5.25rem); }
  .hero__title-block h1 em { font-size: clamp(1.35rem, 6vw, 2rem); }
  .hero__title-block p { max-width: 18rem; margin-top: 1rem; color: rgba(238, 232, 220, 0.84); }
  .hero__seal { right: 1.25rem; bottom: calc(2.45rem + env(safe-area-inset-bottom)); width: clamp(6.15rem, 29vw, 7.35rem); }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; transition-duration: 0.001ms !important; animation-duration: 0.001ms !important; }
}

/* Step 7 full-page system */
.page-shell {
  position: relative;
}
.page-shell::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -10;
  background:
    radial-gradient(circle at 15% 20%, rgba(143, 63, 77, 0.12), transparent 32rem),
    radial-gradient(circle at 88% 35%, rgba(182, 152, 106, 0.09), transparent 30rem),
    linear-gradient(180deg, #050409 0%, #0b0712 42%, #130b1d 100%);
}

.oracle-section {
  position: relative;
  padding: clamp(4.8rem, 10vw, 9rem) var(--edge);
  border-top: 1px solid rgba(182, 152, 106, 0.13);
  overflow: hidden;
}

.oracle-section::after {
  content: "✦";
  position: absolute;
  right: var(--edge);
  top: clamp(1.6rem, 3vw, 2.4rem);
  color: rgba(182, 152, 106, 0.22);
  font-size: 0.9rem;
}

.section-kicker {
  margin-bottom: clamp(1.1rem, 2vw, 1.8rem);
  color: rgba(182, 152, 106, 0.72);
  font-family: var(--display);
  font-size: clamp(0.65rem, 0.76vw, 0.78rem);
  font-weight: 600;
  letter-spacing: 0.32em;
  line-height: 1.5;
  text-transform: uppercase;
}

.oracle-section h2 {
  margin: 0;
  max-width: 12ch;
  color: rgba(238, 232, 220, 0.92);
  font-family: var(--serif);
  font-size: clamp(3.15rem, 7vw, 8rem);
  font-weight: 400;
  letter-spacing: -0.055em;
  line-height: 0.9;
}

.oracle-section h3 {
  margin: 0;
  color: rgba(238, 232, 220, 0.9);
  font-family: var(--serif);
  font-size: clamp(1.7rem, 2.6vw, 2.8rem);
  font-weight: 400;
  letter-spacing: -0.035em;
  line-height: 1;
}

.oracle-section p,
.oracle-section li,
.oracle-section summary,
.oracle-section small {
  color: rgba(238, 232, 220, 0.7);
  font-size: clamp(0.98rem, 1.2vw, 1.16rem);
  line-height: 1.8;
}

.intro__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(18rem, 0.62fr);
  gap: clamp(2rem, 8vw, 8rem);
  align-items: end;
}
.intro__grid p {
  max-width: 42rem;
  margin: 0 0 0.5rem;
  color: rgba(238, 232, 220, 0.76);
}

.ritual {
  background:
    radial-gradient(circle at 75% 20%, rgba(182, 152, 106, 0.08), transparent 26rem),
    rgba(7, 5, 12, 0.62);
}
.ritual__cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 1.6rem);
  margin-top: clamp(2.4rem, 5vw, 4.5rem);
}
.ritual__cards article,
.spread-list article,
.faq details {
  border: 1px solid rgba(182, 152, 106, 0.19);
  background:
    linear-gradient(145deg, rgba(238, 232, 220, 0.045), rgba(238, 232, 220, 0.015)),
    rgba(9, 6, 15, 0.64);
  box-shadow: 0 22px 80px rgba(0, 0, 0, 0.24);
}
.ritual__cards article {
  min-height: 20rem;
  padding: clamp(1.25rem, 2.4vw, 2rem);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.ritual__cards span {
  color: rgba(182, 152, 106, 0.48);
  font-family: var(--serif);
  font-size: clamp(2.5rem, 5vw, 5.2rem);
  line-height: 0.8;
}
.ritual__cards p { margin: 1.35rem 0 0; }

.spreads__header {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 3rem;
}
.spreads__header p {
  max-width: 35rem;
  margin: 0 0 0.5rem;
}
.spread-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  margin-top: clamp(2.5rem, 5vw, 4.5rem);
  border: 1px solid rgba(182, 152, 106, 0.18);
  background: rgba(182, 152, 106, 0.18);
}
.spread-list article {
  min-height: 24rem;
  padding: clamp(1.15rem, 2.2vw, 1.8rem);
  border: 0;
  background: rgba(9, 6, 15, 0.86);
}
.spread-list i {
  display: grid;
  place-items: center;
  width: 4rem;
  aspect-ratio: 1;
  margin-bottom: clamp(3rem, 7vw, 7rem);
  border: 1px solid rgba(182, 152, 106, 0.35);
  border-radius: 50%;
  color: rgba(182, 152, 106, 0.82);
  font-style: normal;
}
.spread-list p { margin-top: 1rem; }

.app-experience {
  background:
    radial-gradient(circle at 20% 50%, rgba(185, 128, 146, 0.09), transparent 24rem),
    linear-gradient(180deg, rgba(5, 4, 9, 0.2), rgba(33, 16, 44, 0.34));
}
.app-experience__panel {
  display: grid;
  grid-template-columns: minmax(17rem, 0.52fr) minmax(0, 0.72fr);
  gap: clamp(2rem, 7vw, 7rem);
  align-items: center;
  max-width: 82rem;
  margin-inline: auto;
}
.app-experience__panel h2 { max-width: 9ch; }
.app-experience__panel p { max-width: 42rem; }
.app-experience__panel ul {
  display: grid;
  gap: 0.75rem;
  margin: 2rem 0 0;
  padding: 0;
  list-style: none;
}
.app-experience__panel li::before {
  content: "✦";
  margin-right: 0.7rem;
  color: rgba(182, 152, 106, 0.76);
}
.phone-oracle {
  position: relative;
  width: min(22rem, 100%);
  aspect-ratio: 0.72;
  justify-self: center;
  border: 1px solid rgba(182, 152, 106, 0.26);
  border-radius: 2.4rem;
  background:
    radial-gradient(circle at 50% 18%, rgba(238, 232, 220, 0.16), transparent 5rem),
    radial-gradient(circle at 50% 58%, rgba(143, 63, 77, 0.22), transparent 8rem),
    linear-gradient(180deg, rgba(19, 11, 29, 0.92), rgba(5, 4, 9, 0.94));
  box-shadow: inset 0 0 0 0.7rem rgba(238, 232, 220, 0.035), 0 44px 90px rgba(0, 0, 0, 0.38);
  overflow: hidden;
}
.phone-oracle__moon {
  position: absolute;
  left: 50%;
  top: 12%;
  width: 5rem;
  aspect-ratio: 1;
  transform: translateX(-50%);
  border-radius: 50%;
  background: rgba(238, 232, 220, 0.82);
  box-shadow: 0 0 54px rgba(238, 232, 220, 0.32);
}
.phone-oracle__card {
  position: absolute;
  left: 50%;
  top: 39%;
  width: 7rem;
  height: 11rem;
  border: 1px solid rgba(182, 152, 106, 0.38);
  border-radius: 0.9rem;
  background: linear-gradient(145deg, rgba(238, 232, 220, 0.14), rgba(182, 152, 106, 0.08));
}
.phone-oracle__card--one { transform: translateX(-72%) rotate(-9deg); }
.phone-oracle__card--two { transform: translateX(-18%) rotate(10deg); }
.phone-oracle span {
  position: relative;
  top: 75%;
  display: block;
  margin: 0.48rem auto;
  width: 70%;
  color: rgba(238, 232, 220, 0.42);
  font-size: 0.72rem;
  letter-spacing: 0.24em;
  text-align: center;
  text-transform: uppercase;
}

.ethics {
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(18rem, 0.65fr);
  gap: clamp(2rem, 7vw, 7rem);
  align-items: end;
}
.ethics blockquote {
  margin: 0;
  padding: clamp(1.5rem, 4vw, 3rem);
  border-left: 1px solid rgba(182, 152, 106, 0.44);
}
.ethics blockquote p {
  margin: 0;
  color: rgba(238, 232, 220, 0.88);
  font-family: var(--serif);
  font-size: clamp(2.2rem, 4.4vw, 5.2rem);
  letter-spacing: -0.05em;
  line-height: 0.98;
}
.ethics__copy h2 { font-size: clamp(2.7rem, 5vw, 5.5rem); }
.ethics__copy p { margin-bottom: 0; }

.faq__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-top: clamp(2rem, 4vw, 3.5rem);
}
.faq details {
  padding: clamp(1.1rem, 2vw, 1.55rem);
}
.faq summary {
  cursor: pointer;
  color: rgba(238, 232, 220, 0.88);
  font-family: var(--serif);
  font-size: clamp(1.35rem, 2.1vw, 2.2rem);
  line-height: 1.1;
}
.faq details p { margin: 1rem 0 0; }

.final-cta {
  min-height: 82svh;
  display: grid;
  place-items: center;
  text-align: center;
  background:
    radial-gradient(circle at 50% 40%, rgba(143, 63, 77, 0.16), transparent 22rem),
    linear-gradient(180deg, rgba(5,4,9,0.18), rgba(5,4,9,0.74));
}
.final-cta > * { max-width: 50rem; }
.final-cta h2 { max-width: 10ch; }
.final-cta p:not(.section-kicker) { margin: 1.4rem auto 0; max-width: 35rem; }
.final-cta small { display: block; margin-top: 1.1rem; color: rgba(238, 232, 220, 0.42); }
.final-cta__seal {
  display: grid;
  place-items: center;
  width: clamp(4.5rem, 8vw, 7.5rem);
  aspect-ratio: 1;
  margin-bottom: 2rem;
  border: 1px solid rgba(182, 152, 106, 0.42);
  border-radius: 50%;
  color: rgba(182, 152, 106, 0.88);
  background: rgba(143, 63, 77, 0.16);
  box-shadow: 0 0 80px rgba(143, 63, 77, 0.22);
}
.download-link {
  display: inline-grid;
  place-items: center;
  min-width: 12rem;
  margin-top: 2.2rem;
  padding: 1rem 1.35rem;
  border: 1px solid rgba(238, 232, 220, 0.28);
  border-radius: 999rem;
  background: linear-gradient(135deg, rgba(143, 63, 77, 0.86), rgba(93, 38, 52, 0.88));
  color: rgba(238, 232, 220, 0.92);
  font-family: var(--display);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  box-shadow: 0 18px 52px rgba(0, 0, 0, 0.28);
}

@media (max-width: 980px) {
  .intro__grid,
  .app-experience__panel,
  .ethics {
    grid-template-columns: 1fr;
  }
  .ritual__cards,
  .spread-list,
  .faq__grid {
    grid-template-columns: 1fr 1fr;
  }
  .spreads__header {
    display: block;
  }
  .spreads__header p { margin-top: 1.5rem; }
  .spread-list article { min-height: 18rem; }
}

@media (max-width: 680px) {
  .oracle-section { padding-block: 4.2rem; }
  .oracle-section h2 { font-size: clamp(2.75rem, 14vw, 4.8rem); }
  .ritual__cards,
  .spread-list,
  .faq__grid {
    grid-template-columns: 1fr;
  }
  .ritual__cards article,
  .spread-list article { min-height: auto; }
  .spread-list i { margin-bottom: 2.2rem; }
  .phone-oracle { max-width: 17rem; }
  .ethics blockquote { padding-inline: 1.2rem 0; }
  .ethics blockquote p { font-size: clamp(2rem, 12vw, 3.6rem); }
}

/* Step 7 readability polish */
.hero__title-block p {
  color: rgba(238, 232, 220, 0.9);
}
.oracle-section p,
.oracle-section li,
.oracle-section summary,
.oracle-section small {
  color: rgba(238, 232, 220, 0.78);
}
.faq details {
  padding: clamp(1.35rem, 2.4vw, 1.9rem);
}
.faq details p {
  color: rgba(238, 232, 220, 0.75);
}
.download-link {
  border-color: rgba(238, 232, 220, 0.42);
  background:
    radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.1), transparent 32%),
    linear-gradient(135deg, rgba(166, 73, 88, 0.96), rgba(101, 41, 58, 0.96));
  box-shadow: 0 20px 58px rgba(0, 0, 0, 0.34), 0 0 44px rgba(143, 63, 77, 0.26);
}
.final-cta small {
  color: rgba(238, 232, 220, 0.56);
}
@media (max-width: 680px) {
  .faq details { padding-block: 1.55rem; }
  .download-link { width: min(100%, 19rem); min-height: 3.35rem; }
}

/* Cassandra mobile art-directed background layer */
.hero__cassandra-mobile {
  display: none;
}

@media (max-width: 680px) {
  .hero__cassandra-mobile {
    display: block;
    position: absolute;
    z-index: -2;
    top: clamp(3.2rem, 8vh, 5rem);
    right: clamp(-14.5rem, -34vw, -8.4rem);
    height: min(77svh, 41rem);
    width: auto;
    pointer-events: none;
    opacity: 0.84;
    filter: saturate(0.94) contrast(1.03) brightness(0.96);
  }
}

/* Privacy page */
.privacy-page {
  min-height: 100svh;
  background:
    radial-gradient(circle at 82% 8%, rgba(182, 152, 106, 0.12), transparent 24rem),
    radial-gradient(circle at 14% 18%, rgba(143, 63, 77, 0.13), transparent 28rem),
    linear-gradient(180deg, #050409 0%, #0b0712 48%, #130b1d 100%);
}

.privacy-hero {
  position: relative;
  padding: clamp(6rem, 12vw, 10rem) var(--edge) clamp(3rem, 7vw, 6rem);
  border-bottom: 1px solid rgba(182, 152, 106, 0.18);
}

.privacy-hero::after {
  content: "";
  position: absolute;
  right: var(--edge);
  bottom: -3rem;
  width: clamp(8rem, 18vw, 18rem);
  aspect-ratio: 1;
  border: 1px solid rgba(182, 152, 106, 0.16);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(238, 232, 220, 0.08), transparent 62%);
  pointer-events: none;
}

.privacy-back {
  display: inline-flex;
  margin-bottom: clamp(2rem, 5vw, 4rem);
  color: rgba(238, 232, 220, 0.62);
  font-family: var(--display);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.privacy-back:hover,
.privacy-back:focus-visible {
  color: var(--ivory);
  outline: none;
}

.privacy-hero h1 {
  margin: 0;
  max-width: 10ch;
  color: rgba(238, 232, 220, 0.94);
  font-family: var(--display);
  font-size: clamp(4rem, 11vw, 11rem);
  font-weight: 400;
  letter-spacing: -0.035em;
  line-height: 0.86;
  text-shadow: 0 16px 60px rgba(0, 0, 0, 0.42);
}

.privacy-hero > p:not(.section-kicker) {
  max-width: 47rem;
  margin: clamp(1.5rem, 3vw, 2.4rem) 0 0;
  color: rgba(238, 232, 220, 0.76);
  font-size: clamp(1.04rem, 1.3vw, 1.22rem);
  line-height: 1.85;
}

.privacy-content {
  display: grid;
  gap: 1px;
  max-width: 76rem;
  margin: 0 auto;
  padding: clamp(3rem, 8vw, 7rem) var(--edge);
}

.privacy-content section,
.privacy-footnote {
  border: 1px solid rgba(182, 152, 106, 0.17);
  background:
    linear-gradient(145deg, rgba(238, 232, 220, 0.042), rgba(238, 232, 220, 0.014)),
    rgba(9, 6, 15, 0.68);
  padding: clamp(1.25rem, 3vw, 2.4rem);
}

.privacy-content h2 {
  margin: 0 0 1.1rem;
  color: rgba(238, 232, 220, 0.92);
  font-family: var(--display);
  font-size: clamp(1.55rem, 2.7vw, 3rem);
  font-weight: 500;
  letter-spacing: -0.015em;
  line-height: 1.05;
}

.privacy-content p,
.privacy-content li {
  color: rgba(238, 232, 220, 0.76);
  font-size: clamp(0.96rem, 1.08vw, 1.08rem);
  line-height: 1.8;
}

.privacy-content ul {
  display: grid;
  gap: 0.55rem;
  margin: 1rem 0 1.4rem;
  padding-left: 1.2rem;
}

.privacy-content a {
  color: rgba(211, 188, 147, 0.94);
  text-decoration: underline;
  text-decoration-color: rgba(182, 152, 106, 0.42);
  text-underline-offset: 0.22em;
}

.privacy-content a:hover,
.privacy-content a:focus-visible {
  color: var(--ivory);
  outline: none;
}

.final-cta small a {
  color: rgba(211, 188, 147, 0.9);
  text-decoration: underline;
  text-decoration-color: rgba(182, 152, 106, 0.35);
  text-underline-offset: 0.22em;
}

@media (max-width: 680px) {
  .hero__nav {
    gap: 0.7rem;
    max-width: 11rem;
    justify-content: flex-end;
    text-align: right;
  }

  .privacy-hero {
    padding-top: 5rem;
  }

  .privacy-hero h1 {
    font-size: clamp(3.3rem, 17vw, 5.6rem);
  }
}

/* Privacy QA polish */
.privacy-nav {
  position: absolute;
  top: clamp(1.55rem, 3.15vw, 3rem);
  right: var(--edge);
  display: flex;
  align-items: center;
  gap: clamp(0.9rem, 1.8vw, 1.6rem);
  color: rgba(238, 232, 220, 0.62);
  font-family: var(--display);
  font-size: clamp(0.62rem, 0.72vw, 0.76rem);
  font-weight: 500;
  letter-spacing: 0.28em;
  line-height: 1.65;
  text-transform: uppercase;
}

.privacy-nav a { transition: color 180ms ease; }
.privacy-nav a:hover,
.privacy-nav a:focus-visible,
.privacy-nav a[aria-current="page"] {
  color: rgba(238, 232, 220, 0.92);
  outline: none;
}

.privacy-content p,
.privacy-content li {
  color: rgba(245, 239, 226, 0.82);
  font-size: clamp(1rem, 1.14vw, 1.13rem);
  line-height: 1.86;
}

.privacy-content section,
.privacy-footnote {
  padding: clamp(1.45rem, 3.4vw, 2.75rem);
}

@media (max-width: 680px) {
  .privacy-nav {
    gap: 0.7rem;
    max-width: 11rem;
    justify-content: flex-end;
    text-align: right;
  }

  .privacy-content p,
  .privacy-content li {
    font-size: 0.98rem;
    line-height: 1.78;
  }

  .privacy-content section,
  .privacy-footnote {
    padding: 1.35rem 1.08rem;
  }
}

/* Client upgrade: bolder Cinzel, reference gold, and moon-lavender accents */
:root {
  --reference-gold: #f5d77e;
  --reference-gold-bright: #fff0ad;
  --reference-gold-deep: #6f3a15;
  --reference-gold-shadow: rgba(72, 26, 19, 0.86);
  --moon-lavender: #c8a8ff;
  --moon-lavender-soft: rgba(222, 205, 255, 0.88);
  --moon-lavender-dim: rgba(200, 168, 255, 0.34);
}

.hero__wordmark,
.hero__nav,
.hero__rail,
.hero__title-block p,
.hero__seal,
.section-kicker,
.download-link,
.privacy-back,
.privacy-nav {
  font-weight: 700;
}

.hero__wordmark,
.hero__nav,
.privacy-back,
.privacy-nav {
  color: var(--moon-lavender-soft);
  text-shadow: 0 1px 20px rgba(77, 49, 116, 0.55), 0 0 22px rgba(200, 168, 255, 0.14);
}

.hero__nav a:hover,
.hero__nav a:focus-visible,
.privacy-nav a:hover,
.privacy-nav a:focus-visible,
.privacy-nav a[aria-current="page"] {
  color: rgba(238, 232, 220, 0.96);
}

.hero__rail {
  color: rgba(222, 205, 255, 0.78);
}
.hero__rail span {
  color: rgba(245, 215, 126, 0.82);
}

.hero__title-block h1,
.oracle-section h2,
.oracle-section h3,
.privacy-hero h1,
.privacy-content h2,
.ethics blockquote p,
.faq summary {
  font-weight: 700;
}

.hero__title-block h1 span,
.oracle-section h2,
.final-cta h2,
.privacy-hero h1 {
  color: var(--reference-gold);
  background: linear-gradient(180deg, var(--reference-gold-bright) 0%, var(--reference-gold) 44%, #d79b45 72%, #7d4217 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow:
    0 2px 0 var(--reference-gold-shadow),
    0 12px 34px rgba(0, 0, 0, 0.62),
    0 0 28px rgba(245, 215, 126, 0.12);
}

.hero__title-block h1 em {
  color: var(--moon-lavender);
  font-family: var(--ornate);
  font-weight: 700;
  text-shadow: 0 2px 18px rgba(0, 0, 0, 0.7), 0 0 26px rgba(200, 168, 255, 0.3);
}

.hero__title-block p,
.section-kicker,
.privacy-content a,
.final-cta small a {
  color: var(--moon-lavender-soft);
}

.ritual__cards span,
.spread-list i,
.final-cta__seal,
.hero__seal i {
  color: var(--reference-gold);
}

.hero__seal,
.download-link {
  border-color: rgba(245, 215, 126, 0.5);
  color: rgba(255, 240, 173, 0.94);
  background:
    radial-gradient(circle at 30% 18%, rgba(255, 240, 173, 0.16), transparent 34%),
    linear-gradient(145deg, rgba(127, 55, 70, 0.96), rgba(67, 25, 43, 0.96));
  box-shadow:
    0 24px 64px rgba(0, 0, 0, 0.4),
    0 0 0 0.6rem rgba(245, 215, 126, 0.06),
    0 0 38px rgba(200, 168, 255, 0.1);
}

.phone-oracle {
  border-color: rgba(200, 168, 255, 0.24);
  box-shadow: inset 0 0 0 0.7rem rgba(200, 168, 255, 0.035), 0 44px 90px rgba(0, 0, 0, 0.38);
}

/* Client upgrade: compact privacy header so content appears first */
.privacy-hero {
  min-height: auto;
  padding: clamp(4.5rem, 7vw, 6.2rem) var(--edge) clamp(1.05rem, 2vw, 1.55rem);
}

.privacy-hero::after,
.privacy-hero > p:not(.section-kicker) {
  display: none;
}

.privacy-hero .section-kicker {
  margin-bottom: 0.45rem;
}

.privacy-hero h1 {
  max-width: none;
  font-size: clamp(2.15rem, 4.3vw, 4.85rem);
  line-height: 0.98;
  letter-spacing: -0.02em;
}

.privacy-content {
  padding-top: clamp(1.25rem, 3vw, 2.2rem);
}

@media (max-width: 680px) {
  .hero__title-block h1 span {
    font-weight: 700;
    letter-spacing: -0.045em;
  }

  .privacy-hero {
    padding-top: 4.45rem;
    padding-bottom: 1rem;
  }

  .privacy-hero h1 {
    font-size: clamp(2.25rem, 11vw, 3.25rem);
  }

  .privacy-content {
    padding-top: 1rem;
  }
}

/* Minor post-QA mobile hardening */
@media (max-width: 480px) {
  .hero__seal {
    right: clamp(1rem, 4.5vw, 1.4rem);
    bottom: calc(clamp(1.65rem, 5vw, 2.25rem) + env(safe-area-inset-bottom));
  }

  .privacy-content p,
  .privacy-content li {
    font-size: 1rem;
    line-height: 1.84;
  }
}

/* Client upgrade: brighter yellow-gold reference and larger centered hero CTA */
:root {
  --reference-gold: #ffd66b;
  --reference-gold-bright: #fff4b8;
  --reference-gold-deep: #d8891d;
  --reference-gold-shadow: rgba(78, 45, 6, 0.68);
}

.hero__title-block h1 span,
.oracle-section h2,
.final-cta h2,
.privacy-hero h1 {
  background: linear-gradient(180deg, #fff7c7 0%, #ffe68a 32%, #ffd05a 58%, #f0a936 82%, #d8891d 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow:
    0 1px 0 rgba(255, 250, 205, 0.38),
    0 3px 0 var(--reference-gold-shadow),
    0 13px 34px rgba(0, 0, 0, 0.62),
    0 0 26px rgba(255, 214, 107, 0.18);
}

.hero__seal {
  right: clamp(4.2rem, 9vw, 8.8rem);
  bottom: clamp(3.4rem, 8.5vw, 7.1rem);
  width: clamp(7.75rem, 11.3vw, 11.1rem);
  font-size: clamp(0.68rem, 0.82vw, 0.86rem);
  border-color: rgba(255, 214, 107, 0.68);
  color: rgba(255, 244, 184, 0.98);
  box-shadow:
    0 28px 74px rgba(0, 0, 0, 0.44),
    0 0 0 0.7rem rgba(255, 214, 107, 0.075),
    0 0 46px rgba(255, 214, 107, 0.14),
    0 0 40px rgba(200, 168, 255, 0.11);
}

.hero__seal i {
  color: var(--reference-gold-bright);
  font-size: 1.08rem;
}

@media (max-width: 680px) {
  .hero__seal {
    right: clamp(1.75rem, 7vw, 2.55rem);
    bottom: calc(clamp(2.5rem, 7vw, 3.2rem) + env(safe-area-inset-bottom));
    width: clamp(7.05rem, 34vw, 8.35rem);
    font-size: clamp(0.64rem, 2.7vw, 0.78rem);
  }
}

/* Final CTA nudge after QA */
.hero__seal {
  right: clamp(4.85rem, 9.8vw, 9.6rem);
}

@media (max-width: 680px) {
  .hero__seal {
    right: clamp(2rem, 8vw, 2.8rem);
  }
}

/* Production hardening: visible keyboard focus, tap targets, and pending app CTA */
.hero__nav a,
.privacy-nav a {
  display: inline-flex;
  align-items: center;
  min-height: 2.75rem;
  padding-inline: 0.22rem;
}

:where(a, button, input, textarea, select):focus-visible {
  outline: 2px solid currentColor !important;
  outline-offset: 4px !important;
}

.final-cta small {
  color: rgba(245, 239, 226, 0.76);
}

/* Client tweak: reference poster inside app oracle panel + slightly larger Start Reading CTAs */
.phone-oracle {
  aspect-ratio: 620 / 944;
  max-width: min(24rem, 100%);
  border-color: rgba(255, 214, 107, 0.34);
  background: #07050d;
  box-shadow:
    inset 0 0 0 0.45rem rgba(255, 214, 107, 0.045),
    0 44px 92px rgba(0, 0, 0, 0.42),
    0 0 42px rgba(200, 168, 255, 0.08);
}

.phone-oracle img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
  filter: saturate(1.02) contrast(1.03) brightness(0.94);
}

.hero__seal {
  width: clamp(8.25rem, 12vw, 11.9rem);
  font-size: clamp(0.72rem, 0.9vw, 0.92rem);
}

.hero__seal i {
  font-size: 1.14rem;
}

.download-link {
  min-width: 13.4rem;
  min-height: 3.65rem;
  padding: 1.08rem 1.55rem;
  font-size: 0.78rem;
}

@media (max-width: 680px) {
  .phone-oracle {
    max-width: min(18.4rem, 100%);
  }

  .hero__seal {
    width: clamp(7.55rem, 36vw, 8.95rem);
    font-size: clamp(0.68rem, 2.9vw, 0.82rem);
  }

  .download-link {
    width: min(100%, 20.2rem);
    min-height: 3.75rem;
  }
}

/* SEO deploy QA: keep mobile hero title/nav/CTA safely inside narrow Telegram/iPhone viewports. */
@media (max-width: 680px) {
  .hero__wordmark,
  .hero__nav {
    font-size: clamp(0.54rem, 2.15vw, 0.62rem);
    letter-spacing: 0.18em;
  }

  .hero__nav {
    gap: 0.48rem;
    max-width: none;
  }

  .hero__nav a,
  .privacy-nav a {
    min-height: 2.45rem;
    padding-inline: 0.08rem;
  }

  .hero__title-block {
    top: 43%;
    width: calc(100% - (var(--edge) * 2));
  }

  .hero__title-block h1 {
    width: min(100%, 22rem);
  }

  .hero__title-block h1 span {
    font-size: clamp(2.65rem, 13vw, 3.45rem);
    letter-spacing: -0.055em;
  }

  .hero__title-block h1 em {
    font-size: clamp(1.24rem, 5vw, 1.75rem);
  }

  .hero__seal {
    right: 1rem;
    width: clamp(6.65rem, 30vw, 7.65rem);
  }
}

/* Client tweak: paired reading examples in The Oracle Opens section */
.intro__side {
  display: grid;
  gap: clamp(1.25rem, 2.4vw, 2rem);
  align-self: end;
  justify-items: center;
}

.intro__art-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(0.8rem, 1.55vw, 1.3rem);
  width: min(36rem, 100%);
  margin-inline: auto;
  align-items: end;
}

.intro__art {
  position: relative;
  width: 100%;
  margin: 0;
  overflow: hidden;
  border: 1px solid rgba(255, 214, 107, 0.34);
  border-radius: 1.8rem;
  background: #07050d;
  box-shadow:
    inset 0 0 0 0.38rem rgba(255, 214, 107, 0.04),
    0 26px 62px rgba(0, 0, 0, 0.34),
    0 0 34px rgba(200, 168, 255, 0.08);
}

.intro__art::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(5, 4, 9, 0.02), rgba(5, 4, 9, 0.18));
}

.intro__art img {
  display: block;
  width: 100%;
  height: auto;
  filter: saturate(1.02) contrast(1.03) brightness(0.95);
}

.intro__side p {
  max-width: 36rem;
  margin-inline: auto;
  text-align: center;
}

@media (max-width: 980px) {
  .intro__art-row {
    width: min(33rem, 100%);
  }
}

@media (max-width: 680px) {
  .intro__side {
    gap: 1.15rem;
  }

  .intro__art-row {
    gap: 0.7rem;
  }

  .intro__art {
    border-radius: 1.25rem;
  }
}

/* Final live visual QA guardrail: also tame the hero at tablet/narrow layout widths.
   Some screenshot/webview paths render a wider layout viewport into a small physical canvas. */
@media (max-width: 980px) {
  .hero__wordmark,
  .hero__nav {
    font-size: clamp(0.54rem, 1.45vw, 0.66rem);
    letter-spacing: 0.18em;
  }

  .hero__nav {
    right: 1rem;
    gap: 0.52rem;
  }

  .hero__seal {
    right: 1rem;
    width: clamp(6.65rem, 12vw, 7.7rem);
  }

  .hero__title-block h1 span {
    font-size: clamp(2.65rem, 7vw, 4.85rem);
  }
}

/* Live app launch: use the official Google Play badge in the existing CTA slot. */
.download-link--store {
  width: min(14.8rem, 100%);
  min-width: 0;
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: 0 18px 54px rgba(0, 0, 0, 0.26);
  transition: transform 180ms ease, filter 180ms ease;
}

.download-link--store:hover {
  transform: translateY(-1px);
  filter: brightness(1.08);
}

.download-link--store img {
  display: block;
  width: 100%;
  height: auto;
}
