/* ─────────────────────────────────────────────────────────────
   AlibA.I. detail page — layers on styles.css tokens
   ───────────────────────────────────────────────────────────── */

/* Hero */
.ab-hero {
  position: relative; isolation: isolate; overflow: hidden;
  padding: var(--s-20) var(--s-8) var(--s-16);
  text-align: center;
  border-bottom: 1px solid var(--rule);
}
.ab-hero-glow {
  position: absolute; inset: 0; z-index: -1; pointer-events: none;
  background:
    radial-gradient(60% 70% at 50% 0%, rgba(89,20,31,0.18), transparent 70%),
    radial-gradient(50% 60% at 50% 10%, rgba(242,196,90,0.07), transparent 70%);
}
.ab-hero-inner { max-width: 760px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; gap: var(--s-4); }
.ab-eyebrow {
  font-family: var(--font-display); font-size: 11px; font-weight: 700;
  letter-spacing: 0.26em; text-transform: uppercase; color: var(--accent);
}
.ab-title {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(52px, 9vw, 96px); line-height: 1; margin: 0;
  letter-spacing: 0.01em; color: var(--fg);
  display: inline-flex; align-items: center;
  text-shadow: 0 8px 30px rgba(0,0,0,0.5);
}
/* the magnifying-lens dot in AlibA.I. */
.ab-eye {
  display: inline-block; width: 0.34em; height: 0.34em; margin: 0 0.02em;
  border: 0.07em solid var(--accent); border-radius: 50%;
  position: relative; transform: translateY(0.06em);
  box-shadow: 0 0 18px rgba(242,196,90,0.45);
}
.ab-eye::after {
  content: ''; position: absolute; right: -0.12em; bottom: -0.08em;
  width: 0.16em; height: 0.06em; background: var(--accent);
  transform: rotate(45deg); border-radius: 0.06em;
}
.ab-kicker {
  font-family: var(--font-italic); font-style: italic;
  font-size: clamp(18px, 2.4vw, 24px); color: var(--accent-glow); margin: 0;
}
.ab-lede {
  font-family: var(--font-body); font-size: clamp(16px, 2vw, 19px);
  line-height: 1.65; color: var(--fg-muted); max-width: 620px; margin: var(--s-2) 0 0;
}
.ab-hero-cta { display: flex; gap: var(--s-3); flex-wrap: wrap; justify-content: center; margin-top: var(--s-5); }

/* Section scaffold */
.ab-section { max-width: var(--max-w); margin: 0 auto; padding: var(--s-20) var(--s-8); }
.ab-section--alt {
  max-width: none;
  background: radial-gradient(80% 60% at 50% 0%, rgba(89,20,31,0.08), transparent 70%), var(--panel);
  border-block: 1px solid var(--rule);
}
.ab-section--alt > * { max-width: var(--max-w); margin-inline: auto; }
.ab-head { text-align: center; max-width: 720px; margin: 0 auto var(--s-12); display: flex; flex-direction: column; gap: var(--s-3); align-items: center; }
.ab-head-eyebrow {
  font-family: var(--font-display); font-size: 11px; font-weight: 700;
  letter-spacing: 0.24em; text-transform: uppercase; color: var(--accent);
}
.ab-head-title {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(28px, 4vw, 42px); line-height: 1.12; margin: 0; color: var(--fg);
}
.ab-head-sub {
  font-family: var(--font-body); font-size: 17px; line-height: 1.65;
  color: var(--fg-muted); margin: var(--s-2) 0 0;
}

/* How it plays — three steps */
.ab-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-6); }
@media (max-width: 800px) { .ab-steps { grid-template-columns: 1fr; } }
.ab-step {
  padding: var(--s-8) var(--s-6);
  background: linear-gradient(180deg, var(--panel-light), var(--panel));
  border: 1px solid var(--rule); border-radius: var(--radius-lg);
}
.ab-step-num {
  font-family: var(--font-display); font-weight: 900; font-size: 14px;
  letter-spacing: 0.18em; color: var(--accent); margin-bottom: var(--s-3);
}
.ab-step h3 { font-family: var(--font-display); font-weight: 700; font-size: 22px; margin: 0 0 var(--s-3); color: var(--fg); }
.ab-step p { font-family: var(--font-body); font-size: 16px; line-height: 1.6; color: var(--fg-muted); margin: 0; }

/* Split: text + quote */
.ab-split { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--s-12); align-items: center; }
@media (max-width: 860px) { .ab-split { grid-template-columns: 1fr; gap: var(--s-8); } }
.ab-split-text .ab-head-title { text-align: left; }
.ab-split-text > .ab-head-eyebrow { display: block; text-align: left; margin-bottom: var(--s-3); }
.ab-split-text p { font-family: var(--font-body); font-size: 17px; line-height: 1.7; color: var(--fg-muted); margin: var(--s-4) 0 0; }
.ab-split-text strong { color: var(--fg); }
.ab-ticks { list-style: none; margin: var(--s-6) 0 0; padding: 0; display: flex; flex-direction: column; gap: var(--s-3); }
.ab-ticks li { position: relative; padding-left: var(--s-7); font-family: var(--font-body); font-size: 16px; color: var(--fg-muted); }
.ab-ticks li::before {
  content: ''; position: absolute; left: 0; top: 8px;
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--accent); box-shadow: 0 0 8px rgba(242,196,90,0.5);
}
.ab-quote-card {
  position: relative;
  background: radial-gradient(120% 90% at 50% 0%, rgba(46,74,99,0.5), rgba(13,10,16,0.7));
  border: 1px solid var(--rule); border-radius: var(--radius-lg);
  padding: var(--s-10) var(--s-8) var(--s-8);
  box-shadow: 0 24px 60px rgba(0,0,0,0.5);
}
.ab-quote-mark {
  font-family: var(--font-display); font-size: 90px; line-height: 0.5; color: var(--accent);
  opacity: 0.4; height: 40px;
}
.ab-quote { font-family: var(--font-italic); font-style: italic; font-size: 22px; line-height: 1.5; color: var(--fg); margin: 0 0 var(--s-5); }
.ab-quote-by { font-family: var(--font-display); font-size: 11px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent); }

/* Storylines / worlds */
.ab-worlds { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-6); }
@media (max-width: 860px) { .ab-worlds { grid-template-columns: 1fr; } }
.ab-world {
  padding: var(--s-8) var(--s-6);
  background: linear-gradient(180deg, var(--panel-light), var(--panel));
  border: 1px solid var(--rule); border-radius: var(--radius-lg);
}
.ab-world--live { border-color: rgba(198,159,88,0.45); box-shadow: 0 0 0 1px rgba(198,159,88,0.12), 0 18px 44px rgba(0,0,0,0.4); }
.ab-world-tag {
  font-family: var(--font-display); font-size: 10px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-faint); margin-bottom: var(--s-3);
}
.ab-world--live .ab-world-tag { color: var(--accent); }
.ab-world-name { font-family: var(--font-display); font-weight: 700; font-size: 23px; margin: 0 0 var(--s-3); color: var(--fg); }
.ab-world p { font-family: var(--font-body); font-size: 15.5px; line-height: 1.65; color: var(--fg-muted); margin: 0; }

/* Character cast */
.ab-cast { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-6); }
@media (max-width: 880px) { .ab-cast { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .ab-cast { grid-template-columns: 1fr; } }
.ab-card {
  margin: 0; overflow: hidden;
  background: linear-gradient(180deg, var(--panel-light), var(--panel));
  border: 1px solid var(--rule); border-radius: var(--radius-lg);
  transition: border-color 0.2s, transform 0.2s;
}
.ab-card:hover { border-color: rgba(198,159,88,0.4); transform: translateY(-3px); }
.ab-card-portrait {
  position: relative; aspect-ratio: 1 / 1; overflow: hidden;
  background:
    radial-gradient(80% 70% at 50% 25%, rgba(46,74,99,0.55), transparent 70%),
    linear-gradient(180deg, #1b2530, #11141a);
  display: flex; align-items: flex-end; justify-content: center;
}
.ab-card-portrait img { width: 92%; height: 104%; object-fit: contain; object-position: bottom; filter: drop-shadow(0 10px 24px rgba(0,0,0,0.5)); }
.ab-card--narrator .ab-card-portrait img { width: 100%; height: 100%; object-fit: cover; object-position: center; filter: none; }
.ab-card figcaption { padding: var(--s-6); }
.ab-card-role {
  font-family: var(--font-display); font-size: 10px; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent); margin-bottom: var(--s-2);
}
.ab-card-name { font-family: var(--font-display); font-weight: 700; font-size: 22px; margin: 0 0 var(--s-3); color: var(--fg); }
.ab-card figcaption p { font-family: var(--font-body); font-size: 15px; line-height: 1.6; color: var(--fg-muted); margin: 0; }

/* Closing CTA */
.ab-cta {
  text-align: center;
  background: radial-gradient(70% 90% at 50% 0%, rgba(89,20,31,0.16), transparent 70%);
  border-top: 1px solid var(--rule);
  padding: var(--s-20) var(--s-8);
}
.ab-cta-inner { max-width: 600px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; gap: var(--s-4); }
.ab-cta-title { font-family: var(--font-display); font-weight: 700; font-size: clamp(26px, 4vw, 38px); margin: 0; color: var(--fg); }
.ab-cta-sub { font-family: var(--font-body); font-size: 17px; line-height: 1.6; color: var(--fg-muted); margin: 0 0 var(--s-3); }

/* nav back link (reused from legal) */
.legal-back {
  font-family: var(--font-display); font-size: 11px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-muted);
  display: inline-flex; align-items: center; gap: var(--s-2); transition: color 0.15s;
}
.legal-back:hover { color: var(--accent); }
