:root {
  --bg: #030303;
  --ink: #080806;
  --panel: #0d0b0a;
  --paper: #d8c7a3;
  --paper-dim: #8d7a55;
  --gold: #a8863d;
  --red: #8b0000;
  --red-bright: #b31320;
  --violet: #120912;
  --text: #f4eee2;
  --muted: #b7aa91;
  --line: rgba(216, 199, 163, 0.18);
  --line-red: rgba(139, 0, 0, 0.48);
  --max: 1200px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; background: var(--bg); }
body {
  margin: 0;
  color: var(--text);
  background:
    radial-gradient(circle at 50% -10%, rgba(168, 134, 61, 0.16), transparent 34rem),
    radial-gradient(circle at 82% 14%, rgba(139, 0, 0, 0.28), transparent 32rem),
    radial-gradient(circle at 14% 74%, rgba(33, 10, 33, 0.54), transparent 30rem),
    linear-gradient(180deg, #020202 0%, #070505 42%, #020202 100%);
  font-family: "Times New Roman", Georgia, ui-serif, serif;
  line-height: 1.55;
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(216, 199, 163, 0.03), transparent 24%, rgba(139, 0, 0, 0.04)),
    repeating-linear-gradient(0deg, rgba(255,255,255,.025) 0 1px, transparent 1px 7px);
  mix-blend-mode: screen;
  opacity: .35;
  z-index: 2;
}

a { color: inherit; text-decoration: none; }

.grain {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  opacity: .28;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,.18) 0 1px, transparent 1px),
    radial-gradient(circle at 70% 60%, rgba(168,134,61,.16) 0 1px, transparent 1px);
  background-size: 13px 17px, 19px 23px;
  animation: grainShift 9s steps(2,end) infinite;
}

.embers {
  position: fixed;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}

.embers i {
  position: absolute;
  bottom: -20px;
  width: 3px;
  height: 3px;
  background: rgba(168, 134, 61, .75);
  box-shadow: 0 0 18px rgba(139, 0, 0, .85);
  animation: ember 16s linear infinite;
}
.embers i:nth-child(1){left:8%;animation-delay:0s}.embers i:nth-child(2){left:23%;animation-delay:4s}.embers i:nth-child(3){left:41%;animation-delay:2s}.embers i:nth-child(4){left:62%;animation-delay:7s}.embers i:nth-child(5){left:78%;animation-delay:1s}.embers i:nth-child(6){left:91%;animation-delay:5s}

.site-topbar,
.teaser-triptych,
.archive-section,
.final-call,
.site-footer {
  width: min(100% - 32px, var(--max));
  margin-inline: auto;
}

.site-topbar {
  position: fixed;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 20;
  min-height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(3,3,3,.88), rgba(3,3,3,.42));
  backdrop-filter: blur(18px);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 950;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.brand-logo {
  width: 48px;
  height: 48px;
  display: block;
  flex: 0 0 auto;
  object-fit: contain;
  filter:
    drop-shadow(0 0 18px rgba(139,0,0,.55))
    drop-shadow(0 0 2px rgba(244,230,199,.32));
}

.site-topbar nav {
  display: flex;
  gap: clamp(14px, 2vw, 24px);
  color: var(--muted);
  font-family: Arial, Helvetica, sans-serif;
  font-size: .74rem;
  font-weight: 850;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.site-topbar a:hover {
  color: #fff;
  text-shadow: 0 0 22px rgba(168,134,61,.5);
}

.hero {
  position: relative;
  min-height: min(780px, 88svh);
  display: flex;
  align-items: center;
  padding: 104px max(18px, calc((100vw - var(--max)) / 2)) 54px;
  overflow: hidden;
  border-bottom: 1px solid var(--line-red);
}

.hero-bg {
  position: absolute;
  inset: 0;
  border: 0;
  min-height: 100%;
  clip-path: none;
}

.hero-bg::before {
  opacity: .75;
  background:
    linear-gradient(115deg, rgba(0,0,0,.9), rgba(0,0,0,.28) 48%, rgba(0,0,0,.86)),
    radial-gradient(circle at 56% 35%, rgba(216,199,163,.18), transparent 16rem),
    repeating-linear-gradient(108deg, rgba(255,255,255,.12) 0 1px, transparent 1px 12px),
    linear-gradient(145deg, #181512, #020202 58%, #18060a);
}

.hero-veil {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.24), rgba(0,0,0,.1) 42%, #030303 100%),
    radial-gradient(circle at 16% 86%, rgba(139,0,0,.35), transparent 26rem);
  z-index: 1;
}

.hero-copy {
  position: relative;
  z-index: 3;
  max-width: 860px;
  animation: slowReveal 1.4s ease both;
}

.seal,
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--paper);
  font-family: Arial, Helvetica, sans-serif;
  font-size: .72rem;
  font-weight: 950;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.seal {
  padding: 9px 12px;
  border: 1px solid rgba(168,134,61,.42);
  background: rgba(0,0,0,.35);
}

.eyebrow::before {
  content: "";
  width: 8px;
  height: 8px;
  background: var(--red-bright);
  box-shadow: 0 0 24px rgba(139,0,0,.9);
}

.pretitle {
  margin: 22px 0 0;
  color: #d7c8a6;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 800;
}

.hero h1 {
  position: relative;
  display: inline-block;
  width: fit-content;
  max-width: min(760px, 92vw);
  margin: 12px 0 22px;
  padding: .02em .08em .08em 0;
  font-size: clamp(4rem, 10.8vw, 9.4rem);
  line-height: .88;
  letter-spacing: .028em;
  color: #f8f1e4;
  transform: scaleX(.86);
  transform-origin: left center;
  text-shadow:
    0 0 20px rgba(139,0,0,.42),
    0 12px 54px rgba(0,0,0,.95),
    0 2px 0 rgba(168,134,61,.18);
}

.hero h1::before {
  content: "";
  position: absolute;
  z-index: -1;
  inset: .1em -.18em .04em -.18em;
  background:
    radial-gradient(ellipse at center, rgba(139,0,0,.36), transparent 68%),
    linear-gradient(90deg, transparent, rgba(87,0,19,.24), transparent);
  filter: blur(18px);
  opacity: .95;
}

.hero h1::after {
  content: "";
  position: absolute;
  left: .04em;
  right: .08em;
  bottom: -.04em;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(168,134,61,.62), rgba(139,0,0,.34), transparent);
  box-shadow: 0 0 18px rgba(139,0,0,.35);
}

@supports (-webkit-background-clip: text) {
  .hero h1 {
    background:
      linear-gradient(180deg, #fffaf0 0%, #d7c5a1 43%, #f4eee2 68%, #74633f 100%),
      repeating-linear-gradient(115deg, rgba(255,255,255,.16) 0 1px, transparent 1px 6px);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
  }
}

.memory-line {
  margin: 0;
  color: #fff;
  font-size: clamp(1.7rem, 4vw, 4.1rem);
  line-height: 1.02;
  letter-spacing: -.045em;
  text-shadow: 0 0 18px rgba(216,199,163,.18);
}

.soon-badge {
  display: inline-flex;
  margin-top: 20px;
  color: var(--red-bright);
  font-family: Arial, Helvetica, sans-serif;
  font-size: .82rem;
  letter-spacing: .28em;
  text-shadow: 0 0 20px rgba(139,0,0,.85);
}

.hero-actions,
.community-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}

.social-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 13px 18px;
  border: 1px solid var(--line);
  border-radius: 2px;
  background: rgba(8, 6, 5, .68);
  color: #fff;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 950;
  letter-spacing: .05em;
  text-transform: uppercase;
  transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease, background .35s ease;
}

.social-button.discord { border-color: rgba(139,0,0,.72); background: linear-gradient(135deg, rgba(139,0,0,.36), rgba(8,6,5,.7)); }
.social-button.instagram { border-color: rgba(168,134,61,.48); }
.social-button.tiktok { border-color: rgba(255,255,255,.18); }
.social-button.youtube { border-color: rgba(179,19,32,.62); background: linear-gradient(135deg, rgba(179,19,32,.22), rgba(8,6,5,.72)); }
.social-button.large { min-height: 58px; padding-inline: 22px; }
.social-button:hover {
  transform: translateY(-3px);
  border-color: rgba(216,199,163,.72);
  box-shadow: 0 20px 55px rgba(0,0,0,.5), 0 0 22px rgba(139,0,0,.35);
}

.forbidden-image {
  position: relative;
  min-height: 280px;
  overflow: hidden;
  border: 1px solid var(--line);
  background: #080808;
  clip-path: polygon(0 8px, 98% 0, 100% calc(100% - 12px), 2% 100%);
}

.forbidden-image::before {
  content: attr(data-label);
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  color: rgba(244,238,226,.36);
  font-family: Arial, Helvetica, sans-serif;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-align: center;
  text-transform: uppercase;
  background:
    linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.72)),
    radial-gradient(circle at 52% 20%, rgba(255,255,255,.18), transparent 10rem),
    repeating-linear-gradient(90deg, rgba(255,255,255,.055) 0 1px, transparent 1px 10px),
    var(--image),
    linear-gradient(135deg, #1a1713 0%, #050505 68%, #000 100%);
  background-size: cover, cover, auto, cover, cover;
  background-position: center, center, center, center, center;
  filter: contrast(1.04) saturate(.92);
  transition: transform .6s ease, filter .6s ease;
}

.forbidden-image::after {
  content: attr(data-caption);
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  z-index: 2;
  color: rgba(244,238,226,.86);
  font-size: .82rem;
  font-style: italic;
  text-shadow: 0 2px 12px #000;
}

.forbidden-image:hover::before {
  transform: scale(1.035);
  filter: contrast(1.1) saturate(.96);
}

.image-mark {
  position: absolute;
  right: 13px;
  bottom: 10px;
  z-index: 3;
  color: rgba(255,255,255,.22);
  font-family: Arial, Helvetica, sans-serif;
  font-size: .7rem;
  font-weight: 950;
  letter-spacing: .18em;
}

.teaser-triptych {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: -36px;
  position: relative;
  z-index: 5;
}

.teaser-triptych figure {
  margin: 0;
  min-height: 360px;
  box-shadow: 0 24px 70px rgba(0,0,0,.55);
}

.teaser-triptych figcaption {
  position: absolute;
  left: 16px;
  top: 14px;
  z-index: 3;
  color: var(--paper);
  font-family: Arial, Helvetica, sans-serif;
  font-size: .7rem;
  font-weight: 950;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.archive-section {
  padding: 86px 0;
  border-top: 1px solid var(--line);
}

.section-head {
  display: grid;
  grid-template-columns: minmax(0,.85fr) minmax(300px,.75fr);
  gap: 28px;
  align-items: end;
  margin-bottom: 28px;
}

.section-head h2,
.helicon-section h2,
.final-call h2 {
  margin: 12px 0 0;
  font-size: clamp(2.55rem, 7vw, 6.4rem);
  line-height: .9;
  letter-spacing: -.065em;
}

.section-head p,
.helicon-section p,
.final-call p {
  margin: 0;
  color: var(--muted);
  font-size: clamp(1rem, 1.8vw, 1.18rem);
}

.torn {
  padding-bottom: 22px;
  border-bottom: 1px solid var(--line);
  clip-path: polygon(0 0, 100% 0, 98% 100%, 63% 93%, 42% 100%, 0 94%);
}

.forbidden-grid,
.episode-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.fragment-card,
.episode-grid article,
.character-grid article,
.relic-grid article {
  border: 1px solid var(--line);
  background:
    linear-gradient(145deg, rgba(216,199,163,.055), transparent 32%),
    linear-gradient(180deg, rgba(15,12,10,.94), rgba(5,5,5,.96));
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.45);
}

.fragment-card {
  padding: 12px;
  transition: transform .35s ease, border-color .35s ease;
}

.fragment-card:hover {
  transform: translateY(-5px);
  border-color: var(--line-red);
}

.fragment-card .forbidden-image {
  min-height: 360px;
}

.fragment-card span,
.episode-grid small,
.character-grid small,
.relic-grid span {
  display: block;
  margin-top: 16px;
  color: var(--gold);
  font-family: Arial, Helvetica, sans-serif;
  font-size: .7rem;
  font-weight: 950;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.fragment-card h3,
.episode-grid h3,
.character-grid h3 {
  margin: 8px 0 8px;
  font-size: 1.45rem;
  line-height: 1.05;
}

.character-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}

.character-grid article {
  padding: 10px;
  min-height: 390px;
  transition: transform .35s ease, border-color .35s ease;
}

.character-grid article:hover {
  transform: translateY(-4px);
  border-color: rgba(168,134,61,.42);
}

.portrait {
  min-height: 240px;
}

.character-grid p {
  margin: 0;
  color: var(--muted);
  font-size: .94rem;
}

.character-grid a {
  display: block;
  color: inherit;
  text-decoration: none;
}

.character-open {
  border-color: rgba(168,134,61,.34);
}

.character-sealed {
  opacity: .72;
}

.character-sealed .portrait::before {
  filter: grayscale(.9) brightness(.32) contrast(1.2);
}

.helicon-section {
  display: grid;
  grid-template-columns: minmax(0,.85fr) minmax(320px,1fr);
  gap: 30px;
}

.relic-panel {
  min-height: 520px;
  padding: 34px;
  border: 1px solid var(--line-red);
  background:
    radial-gradient(circle at 80% 0, rgba(168,134,61,.22), transparent 20rem),
    linear-gradient(180deg, #0e0b09, #040404);
}

.relic-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.relic-grid article {
  min-height: 92px;
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 18px;
}

.relic-grid span {
  margin: 0;
  min-width: 42px;
  color: rgba(244,238,226,.42);
  font-size: 1.65rem;
}

.relic-grid strong {
  font-size: 1.25rem;
}

.release-section {
  position: relative;
}

.release-section::before {
  content: "";
  position: absolute;
  left: -4vw;
  right: -4vw;
  top: 34px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(139,0,0,.58), rgba(168,134,61,.24), transparent);
  opacity: .8;
}

.release-note {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  margin: 22px 0 30px;
  padding: 11px 14px;
  border: 1px solid rgba(168,134,61,.28);
  background:
    linear-gradient(90deg, rgba(139,0,0,.16), transparent),
    rgba(5,5,5,.72);
  color: var(--muted);
  font-family: Arial, Helvetica, sans-serif;
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.release-note strong {
  color: var(--gold);
}

.episode-grid {
  grid-template-columns: repeat(5, 1fr);
}

.episode-grid article {
  position: relative;
  min-height: 396px;
  padding: 10px;
  overflow: hidden;
  transition: transform .35s ease, border-color .35s ease, box-shadow .35s ease;
}

.episode-grid article::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(139,0,0,.16), transparent 36%),
    repeating-linear-gradient(0deg, transparent 0 21px, rgba(244,238,226,.025) 22px 23px);
  opacity: .55;
  pointer-events: none;
}

.episode-grid article:hover {
  transform: translateY(-4px);
  border-color: rgba(168,134,61,.46);
  box-shadow: 0 22px 60px rgba(0,0,0,.48), inset 0 0 0 1px rgba(139,0,0,.18);
}

.episode-grid article.is-first {
  border-color: rgba(139,0,0,.48);
}

.episode-grid article.is-first::after {
  content: "ARQUIVO 01";
  position: absolute;
  top: 18px;
  left: -30px;
  z-index: 3;
  padding: 5px 34px;
  background: rgba(139,0,0,.86);
  color: #fff;
  font-family: Arial, Helvetica, sans-serif;
  font-size: .58rem;
  font-weight: 950;
  letter-spacing: .12em;
  transform: rotate(-38deg);
}

.episode-cover {
  min-height: 230px;
  margin-bottom: 2px;
}

.episode-grid h3 {
  position: relative;
  z-index: 2;
  min-height: 2.25em;
  font-size: 1.08rem;
}

.episode-grid p {
  position: relative;
  z-index: 2;
  margin: 0;
  color: rgba(244,238,226,.52);
  font-family: Arial, Helvetica, sans-serif;
  font-size: .78rem;
  line-height: 1.45;
}

.launch-countdown {
  width: fit-content;
  margin: 22px 0 0;
  padding: 13px 16px;
  border: 1px solid rgba(168,134,61,.28);
  background:
    linear-gradient(90deg, rgba(139,0,0,.16), transparent),
    rgba(0,0,0,.48);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.025);
  color: rgba(244,238,226,.62);
  font-family: Arial, Helvetica, sans-serif;
  text-transform: uppercase;
  letter-spacing: .13em;
}

.launch-countdown span {
  display: block;
  font-size: .62rem;
  font-weight: 900;
}

.launch-countdown strong {
  display: block;
  margin-top: 5px;
  color: var(--text);
  font-size: clamp(1rem, 2vw, 1.45rem);
  letter-spacing: .06em;
}

.episode-grid--schedule {
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.episode-grid--schedule .episode-card {
  position: relative;
  min-height: 220px;
  display: grid;
  align-content: space-between;
  padding: 24px;
  overflow: hidden;
  border: 1px solid rgba(216,199,163,.16);
  background:
    linear-gradient(110deg, rgba(23,19,14,.94), rgba(7,5,4,.94)),
    repeating-linear-gradient(0deg, transparent 0 18px, rgba(244,238,226,.03) 19px 20px);
  box-shadow: 0 20px 64px rgba(0,0,0,.34);
  transform: skewX(-1.6deg);
  transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease;
}

.episode-grid--schedule .episode-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 12% 14%, rgba(139,0,0,.22), transparent 12rem),
    linear-gradient(90deg, rgba(168,134,61,.08), transparent 40%);
  opacity: .66;
  pointer-events: none;
}

.episode-grid--schedule .episode-card:hover {
  transform: translateY(-4px) skewX(-1.6deg);
  border-color: rgba(168,134,61,.42);
  box-shadow: 0 28px 80px rgba(0,0,0,.52), 0 0 36px rgba(139,0,0,.08);
}

.episode-grid--schedule .episode-card small,
.episode-grid--schedule .episode-card h3,
.episode-grid--schedule .episode-card p,
.episode-grid--schedule .episode-card strong {
  position: relative;
  z-index: 2;
}

.episode-grid--schedule .episode-card small {
  color: var(--gold);
  font-family: Arial, Helvetica, sans-serif;
  font-size: .72rem;
  font-weight: 950;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.episode-grid--schedule .episode-card h3 {
  min-height: auto;
  margin: 24px 0 8px;
  color: var(--text);
  font-size: clamp(1.35rem, 2.2vw, 1.9rem);
  line-height: 1.05;
}

.episode-grid--schedule .episode-card strong {
  width: fit-content;
  margin-top: 18px;
  padding: 8px 11px;
  border: 1px solid rgba(139,0,0,.58);
  color: #f7dfb7;
  background: rgba(139,0,0,.18);
  font-family: Arial, Helvetica, sans-serif;
  font-size: .72rem;
  font-weight: 950;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.episode-grid--schedule .episode-card.is-premium {
  border-color: rgba(139,0,0,.3);
}

.premium-section {
  position: relative;
}

.premium-pass {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, .36fr);
  gap: clamp(22px, 5vw, 64px);
  align-items: center;
  padding: clamp(28px, 6vw, 62px);
  border: 1px solid rgba(139,0,0,.42);
  background:
    radial-gradient(circle at 82% 12%, rgba(139,0,0,.24), transparent 20rem),
    linear-gradient(135deg, rgba(16,10,8,.95), rgba(3,3,3,.94));
  box-shadow: 0 40px 120px rgba(0,0,0,.58), inset 0 0 0 1px rgba(255,255,255,.025);
}

.premium-pass h2 {
  margin: 18px 0 12px;
  font-size: clamp(2rem, 4.4vw, 4rem);
  line-height: 1;
}

.premium-pass p {
  max-width: 720px;
  color: rgba(244,238,226,.64);
}

.premium-offer {
  border: 1px solid rgba(168,134,61,.28);
  padding: 24px;
  background:
    repeating-linear-gradient(0deg, transparent 0 18px, rgba(244,238,226,.035) 19px 20px),
    rgba(0,0,0,.34);
}

.premium-offer small {
  color: var(--gold);
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 950;
  letter-spacing: .16em;
}

.premium-offer > strong {
  display: block;
  margin: 8px 0 18px;
  color: var(--text);
  font-size: clamp(2.4rem, 5vw, 4rem);
  line-height: .95;
}

.premium-offer p {
  margin: 14px 0 0;
  color: rgba(244,238,226,.48);
  font-family: Arial, Helvetica, sans-serif;
  font-size: .78rem;
}

.final-call {
  width: min(100% - 32px, var(--max));
  margin: 42px auto;
  padding: clamp(36px, 7vw, 78px);
  text-align: center;
  border: 1px solid var(--line-red);
  background:
    radial-gradient(circle at 50% 0, rgba(139,0,0,.32), transparent 24rem),
    linear-gradient(180deg, #100909, #050505);
  box-shadow: 0 40px 120px rgba(0,0,0,.55);
}

.final-call .eyebrow {
  justify-content: center;
}

.final-call p {
  max-width: 650px;
  margin-inline: auto;
}

.final-call .community-actions {
  justify-content: center;
}

.site-footer {
  padding: 36px 0 52px;
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  gap: 28px;
  color: var(--muted);
}

.site-footer strong {
  display: block;
  color: var(--text);
  letter-spacing: .08em;
  margin-bottom: 8px;
}

.site-footer p {
  margin: 0;
  max-width: 580px;
}

.site-footer nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 14px;
  font-family: Arial, Helvetica, sans-serif;
  font-size: .86rem;
  font-weight: 850;
}

.site-footer a:hover {
  color: #fff;
}

@keyframes ember {
  0% { transform: translate3d(0,0,0); opacity: 0; }
  10% { opacity: .7; }
  100% { transform: translate3d(24px,-110vh,0); opacity: 0; }
}

@keyframes grainShift {
  0%,100% { transform: translate(0,0); }
  50% { transform: translate(-1%,1%); }
}

@keyframes slowReveal {
  from { opacity: 0; transform: translateY(18px); }
  to { opacity: 1; transform: translateY(0); }
}

@media (max-width: 1080px) {
  .forbidden-grid,
  .episode-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .character-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .helicon-section,
  .section-head {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  body {
    overflow-x: hidden;
  }

  .site-topbar {
    width: calc(100% - 24px);
    min-height: auto;
    padding: 12px 0 10px;
    align-items: flex-start;
    flex-direction: column;
  }
  .site-topbar nav {
    width: 100%;
    overflow-x: auto;
    overscroll-behavior-x: contain;
    gap: 18px;
    padding: 4px 0 6px;
    white-space: nowrap;
    scrollbar-width: none;
  }
  .site-topbar nav::-webkit-scrollbar {
    display: none;
  }
  .hero {
    min-height: auto;
    padding: 142px 14px 42px;
  }
  .hero-copy,
  .pretitle,
  .launch-countdown {
    max-width: calc(100vw - 32px);
    overflow-wrap: break-word;
  }
  .hero h1 {
    max-width: 94vw;
    margin-bottom: 18px;
    font-size: clamp(3rem, 16vw, 4.35rem);
    line-height: .92;
    letter-spacing: .018em;
    transform: scaleX(.9);
  }
  .memory-line {
    max-width: min(100%, 9.5em);
    font-size: clamp(1.95rem, 11vw, 2.7rem);
    letter-spacing: 0;
  }
  .release-note {
    width: 100%;
    align-items: flex-start;
    flex-direction: column;
    gap: 5px;
  }
  .episode-grid--schedule {
    grid-template-columns: 1fr;
  }
  .episode-grid--schedule .episode-card {
    min-height: 190px;
    transform: none;
  }
  .episode-grid--schedule .episode-card:hover {
    transform: translateY(-3px);
  }
  .premium-pass {
    grid-template-columns: 1fr;
  }
  .hero-actions,
  .community-actions {
    display: grid;
    grid-template-columns: 1fr;
  }
  .social-button {
    width: 100%;
  }
  .teaser-triptych,
  .archive-section,
  .final-call,
  .site-footer {
    width: calc(100% - 28px);
  }
  .teaser-triptych,
  .forbidden-grid,
  .character-grid,
  .episode-grid {
    grid-template-columns: 1fr;
  }
  .teaser-triptych {
    margin-top: 14px;
  }
  .archive-section {
    padding: 58px 0;
  }
  .section-head h2,
  .helicon-section h2,
  .final-call h2 {
    max-width: calc(100vw - 32px);
    font-size: clamp(1.85rem, 9.5vw, 2.55rem);
    line-height: .98;
    letter-spacing: 0;
    overflow-wrap: break-word;
  }
  .section-head p,
  .helicon-section p,
  .final-call p {
    max-width: calc(100vw - 32px);
  }
  .forbidden-image,
  .fragment-card .forbidden-image {
    min-height: 330px;
  }
  .portrait {
    min-height: 310px;
  }
  .relic-panel {
    min-height: 420px;
    padding: 24px;
  }
  .site-footer {
    display: block;
  }
  .site-footer nav {
    justify-content: flex-start;
    margin-top: 18px;
  }
}

/* Pre-launch readability pass: keep the forbidden archive mood, but make /manga easier to scan. */
.site-topbar {
  min-height: 64px;
}

.brand {
  font-size: .68rem;
  letter-spacing: .14em;
}

.brand-logo {
  width: 40px;
  height: 40px;
}

.site-topbar nav {
  gap: clamp(10px, 1.5vw, 18px);
  font-size: .66rem;
  letter-spacing: .09em;
}

.hero {
  min-height: min(720px, 84svh);
  padding-top: 92px;
}

.hero-copy {
  max-width: 760px;
}

.hero h1 {
  font-size: clamp(3.55rem, 8vw, 7.2rem);
  line-height: .92;
}

.memory-line {
  max-width: 620px;
  font-size: clamp(1.35rem, 2.8vw, 2.8rem);
  line-height: 1.08;
  letter-spacing: 0;
}

.section-head h2,
.helicon-section h2,
.final-call h2 {
  font-size: clamp(2rem, 4.8vw, 4.65rem);
  line-height: 1;
  letter-spacing: -.025em;
}

.archive-section {
  padding-block: 70px;
}

.character-grid {
  grid-template-columns: repeat(4, 1fr);
}

.character-grid article {
  min-height: 350px;
}

.portrait {
  min-height: 205px;
}

.episode-grid--schedule {
  grid-template-columns: repeat(4, 1fr);
}

.episode-grid--schedule .episode-card {
  min-height: 176px;
  padding: 20px;
  transform: none;
}

.episode-grid--schedule .episode-card:hover {
  transform: translateY(-3px);
}

.episode-grid--schedule .episode-card h3 {
  margin-top: 18px;
  font-size: clamp(1.14rem, 1.5vw, 1.42rem);
}

.episode-grid--schedule .episode-card p {
  font-size: .82rem;
}

@media (max-width: 1080px) {
  .character-grid,
  .episode-grid--schedule {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 760px) {
  .site-topbar {
    width: 100%;
    padding: 10px 14px;
    border-bottom-color: rgba(216,199,163,.18);
  }

  .site-topbar nav {
    gap: 14px;
    font-size: .62rem;
  }

  .hero {
    padding-top: 132px;
    padding-bottom: 36px;
  }

  .hero h1 {
    font-size: clamp(2.8rem, 14vw, 3.65rem);
  }

  .memory-line {
    width: min(100%, 19rem);
    max-width: 100%;
    font-size: clamp(1.18rem, 6.2vw, 1.72rem);
    overflow-wrap: normal;
  }

  .section-head h2,
  .helicon-section h2,
  .final-call h2 {
    font-size: clamp(1.85rem, 9vw, 3rem);
  }

  .character-grid,
  .episode-grid--schedule {
    grid-template-columns: 1fr;
  }

  .episode-grid--schedule .episode-card {
    min-height: 156px;
  }
}


/* HESIDIO automatic watermark system */
.forbidden-image,
.watermarked-image {
  user-select: none;
  -webkit-user-select: none;
}

.forbidden-image img,
.watermarked-image img {
  user-select: none;
  -webkit-user-select: none;
  -webkit-user-drag: none;
}

.image-mark {
  display: grid;
  gap: 1px;
  min-width: 82px;
  text-align: right;
  color: rgba(244, 238, 226, 0.25);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 0.66rem;
  font-weight: 900;
  letter-spacing: 0.22em;
  line-height: 1.05;
  text-shadow: 0 2px 9px rgba(0, 0, 0, 0.82);
  pointer-events: none;
}

.image-mark::after {
  content: "@hesidio";
  display: block;
  color: rgba(244, 238, 226, 0.23);
  font-size: 0.52rem;
  letter-spacing: 0.12em;
  text-transform: none;
}

.diagonal-mark,
.pattern-mark {
  position: absolute;
  pointer-events: none;
  user-select: none;
  -webkit-user-select: none;
  font-family: Georgia, "Times New Roman", serif;
  font-weight: 900;
  letter-spacing: 0.22em;
  text-shadow: 0 2px 18px rgba(0, 0, 0, 0.7);
  z-index: 3;
}

.diagonal-mark {
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) rotate(-25deg);
  color: rgba(244, 238, 226, 0.06);
  font-size: clamp(3rem, 10vw, 9rem);
  line-height: 1;
  white-space: nowrap;
  opacity: 0;
}

.pattern-mark {
  inset: -40%;
  display: none;
  align-items: center;
  justify-content: center;
  color: rgba(244, 238, 226, 0.055);
  font-size: 1rem;
  line-height: 7rem;
  transform: rotate(-25deg);
  background-image:
    repeating-linear-gradient(
      0deg,
      transparent 0 52px,
      rgba(244, 238, 226, 0.035) 52px 53px,
      transparent 53px 116px
    );
  overflow: hidden;
}

.pattern-mark::before {
  content: "HESIDIO · @hesidio   HESIDIO · @hesidio   HESIDIO · @hesidio   HESIDIO · @hesidio";
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  white-space: pre-wrap;
  word-spacing: 4rem;
}

.wm-hero .diagonal-mark,
.wm-page .diagonal-mark,
.recovered-grid .diagonal-mark,
.teaser-triptych .diagonal-mark {
  opacity: 1;
}

.wm-page .pattern-mark,
.recovered-grid .pattern-mark {
  display: flex;
}

.wm-subtle .diagonal-mark,
.wm-subtle .pattern-mark {
  display: none;
}

.watermarked-image {
  position: relative;
  overflow: hidden;
  margin: 0;
  border: 1px solid var(--line, rgba(255, 255, 255, 0.13));
  background: #050505;
}

.watermarked-image img {
  display: block;
  width: 100%;
  height: 100%;
}

.watermarked-image--cover img { object-fit: cover; }
.watermarked-image--contain img { object-fit: contain; }

.watermarked-image__corner {
  position: absolute;
  right: 13px;
  bottom: 10px;
  z-index: 4;
  display: grid;
  gap: 1px;
  text-align: right;
  color: rgba(244, 238, 226, 0.25);
  font-family: Georgia, "Times New Roman", serif;
  letter-spacing: 0.22em;
  line-height: 1.05;
  pointer-events: none;
  text-shadow: 0 2px 9px rgba(0, 0, 0, 0.82);
}

.watermarked-image__corner strong {
  font-size: 0.66rem;
}

.watermarked-image__corner small {
  color: rgba(244, 238, 226, 0.23);
  font-size: 0.52rem;
  letter-spacing: 0.12em;
}

.watermarked-image__diagonal {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 3;
  transform: translate(-50%, -50%) rotate(-25deg);
  color: rgba(244, 238, 226, 0.06);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(3rem, 10vw, 9rem);
  font-weight: 900;
  letter-spacing: 0.22em;
  white-space: nowrap;
  pointer-events: none;
}

.watermarked-image__pattern {
  position: absolute;
  inset: -40%;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(244, 238, 226, 0.055);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1rem;
  font-weight: 900;
  letter-spacing: 0.22em;
  line-height: 7rem;
  transform: rotate(-25deg);
  pointer-events: none;
}

@media (max-width: 760px) {
  .diagonal-mark,
  .watermarked-image__diagonal {
    font-size: clamp(2.4rem, 18vw, 5.2rem);
  }
  .image-mark,
  .watermarked-image__corner {
    right: 10px;
    bottom: 9px;
    transform: scale(0.92);
    transform-origin: right bottom;
  }
}


/* Official HESIDIO image presence */
.forbidden-image .diagonal-mark {
  width: min(42%, 220px);
  aspect-ratio: 1;
  color: transparent;
  background: url("/public/manga/logo.png") center / contain no-repeat;
  opacity: .24;
  filter: drop-shadow(0 0 28px rgba(139,0,0,.42));
}

.hero-bg .diagonal-mark {
  width: min(34vw, 390px);
  opacity: .18;
}

.portrait .diagonal-mark,
.episode-cover .diagonal-mark {
  width: min(54%, 170px);
  opacity: .3;
}

.forbidden-image::before {
  text-shadow: 0 2px 12px rgba(0,0,0,.92);
}

/* Restricted archive hardening */
.forbidden-image,
.forbidden-image *,
.watermarked-image,
.watermarked-image * {
  user-select: none;
  -webkit-user-select: none;
}

.forbidden-image::after,
.image-mark,
.diagonal-mark,
.pattern-mark,
.watermarked-image__corner,
.watermarked-image__diagonal,
.watermarked-image__pattern {
  pointer-events: none;
}

.forbidden-image::before {
  background:
    linear-gradient(180deg, rgba(0,0,0,.28), rgba(0,0,0,.84)),
    radial-gradient(circle at 52% 20%, rgba(139,0,0,.22), transparent 12rem),
    repeating-linear-gradient(90deg, rgba(255,255,255,.045) 0 1px, transparent 1px 10px),
    var(--image),
    linear-gradient(135deg, #1a1713 0%, #050505 68%, #000 100%);
  background-size: cover, cover, auto, cover, cover;
  background-position: center;
  filter: contrast(1.14) saturate(.62) brightness(.5);
}

.image-mark,
.watermarked-image__corner {
  color: rgba(242,242,242,.25);
}

.diagonal-mark,
.watermarked-image__diagonal {
  color: rgba(244,238,226,.06);
}

.pattern-mark,
.watermarked-image__pattern {
  color: rgba(244,238,226,.04);
}

.forbidden-image .diagonal-mark,
.hero-bg .diagonal-mark,
.portrait .diagonal-mark,
.episode-cover .diagonal-mark {
  opacity: .06;
  filter: drop-shadow(0 0 22px rgba(0,0,0,.6));
}
