/* ============================================================
   AURIS — v2 additions: cover hero, position note,
   portal section, analysis embedded in flow
   ============================================================ */

/* ---------- COVER HERO (title layered over full-bleed image) ---------- */
.hero-cover {
  min-height: 100svh;
  padding: 0;
  display: block;
  overflow: hidden;
}
/* ---------- HERO "listening spark" (CSS only) ---------- */
.hero-cover .hero-spark {
  position: absolute;
  left: 50%;
  top: 53%;
  transform: translate(-50%, -50%);
  width: min(72vh, 780px);
  height: min(72vh, 780px);
  z-index: 1;
  pointer-events: none;
  display: grid;
  place-items: center;
}
.hero-cover .hero-spark .orb {
  width: clamp(38px, 5.4vh, 64px);
  height: clamp(38px, 5.4vh, 64px);
  border-radius: 50%;
  background: radial-gradient(circle at 50% 42%, #fff, var(--accent-glow) 32%, var(--accent) 72%);
  box-shadow:
    0 0 calc(50px * var(--glow-strength)) color-mix(in oklab, var(--accent-glow) 90%, transparent),
    0 0 calc(150px * var(--glow-strength)) color-mix(in oklab, var(--accent) 70%, transparent),
    0 0 calc(280px * var(--glow-strength)) color-mix(in oklab, var(--accent) 40%, transparent);
  animation: orbPulse 3.6s ease-in-out infinite;
}
.hero-cover .hero-spark .ring {
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  border: 1px solid color-mix(in oklab, var(--accent-glow) calc(70% * var(--glow-strength)), transparent);
  opacity: 0;
  transform: scale(0.1);
  animation: ripple 6s cubic-bezier(.2,.5,.3,1) infinite;
}
.hero-cover .hero-spark .ring:nth-child(2) { animation-delay: 1.5s; }
.hero-cover .hero-spark .ring:nth-child(3) { animation-delay: 3s; }
.hero-cover .hero-spark .ring:nth-child(4) { animation-delay: 4.5s; }
@keyframes ripple {
  0%   { transform: scale(0.08); opacity: 0; }
  10%  { opacity: calc(0.55 * var(--glow-strength)); }
  100% { transform: scale(1); opacity: 0; }
}
@keyframes orbPulse {
  0%, 100% { transform: scale(0.9); }
  50%      { transform: scale(1.1); }
}
@media (prefers-reduced-motion: reduce) {
  .hero-cover .hero-spark .ring,
  .hero-cover .hero-spark .orb { animation: none; }
  .hero-cover .hero-spark .ring:nth-child(2) { transform: scale(0.55); opacity: 0.25; }
  .hero-cover .hero-spark .ring:nth-child(4) { transform: scale(1); opacity: 0.12; }
}
.hero-cover .hero-title {
  position: relative;
  z-index: 3;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: clamp(96px, 13vh, 150px) var(--gutter) clamp(40px, 7vh, 84px);
}
.hero-cover h1 {
  display: contents;
  font-weight: 400;
}
.hero-cover .line {
  display: block;
  font-size: clamp(42px, 9.2vw, 142px);
  line-height: 0.9;
  letter-spacing: -0.045em;
  font-weight: 700;
  text-wrap: balance;
  text-shadow: 0 2px 60px color-mix(in oklab, var(--wine-deep) 70%, transparent);
}
.hero-cover .line.top { align-self: flex-start; max-width: 14ch; }
.hero-cover .line.bottom { align-self: flex-end; text-align: right; max-width: 18ch; }
.hero-cover .line .serif { font-size: 1.04em; }
@media (max-width: 720px) {
  .hero-cover .line.bottom { text-align: left; align-self: flex-start; }
}

/* ---------- POSITION NOTE (Essence intelligence) ---------- */
.position-aside {
  margin: clamp(40px, 6vw, 76px) auto 0;
  max-width: 70ch;
  padding-top: clamp(26px, 3.5vw, 40px);
  border-top: 1px solid color-mix(in oklab, var(--wine-mid) 26%, transparent);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: clamp(22px, 3.5vw, 56px);
  text-align: left;
}
.position-aside-label {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  white-space: nowrap;
  padding-top: 6px;
  position: relative;
}
.position-aside p {
  margin: 0;
  font-size: clamp(17px, 1.5vw, 25px);
  line-height: 1.4;
  letter-spacing: -0.015em;
  color: color-mix(in oklab, var(--wine-deep) 74%, var(--cream));
  text-wrap: pretty;
}
.position-aside p strong { color: var(--wine-mid); font-weight: 700; }
@media (max-width: 620px) {
  .position-aside { grid-template-columns: 1fr; gap: 14px; }
  .position-aside-label { padding-top: 0; }
}

/* ---------- ANALYSIS embedded inside flow step 07 ---------- */
.step-analysis { margin-top: 32px; }
.step-analysis .a-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
  display: block;
  margin-bottom: 16px;
}
.step .steps7 { margin-bottom: 0; }
.step .s7 { min-height: 150px; }

/* ---------- PORTAL section ---------- */
.portal-grid {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: clamp(30px, 5vw, 70px);
  align-items: center;
}
.portal-copy h2 { font-size: var(--fs-h2); }
.portal-copy h2 em { font-family: var(--font-serif); font-style: italic; color: var(--accent-glow); }
.portal-copy .lead { margin-top: 22px; max-width: 42ch; }
.portal-feats { margin-top: 28px; display: flex; flex-direction: column; gap: 14px; list-style: none; }
.portal-feats li { display: flex; gap: 12px; align-items: baseline; color: var(--ink); font-size: clamp(15px,1.05vw,17px); }
.portal-feats li::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--accent-glow); box-shadow: 0 0 10px var(--accent-glow); flex-shrink: 0; transform: translateY(-2px); }
@media (max-width: 860px){ .portal-grid { grid-template-columns: 1fr; } }

/* ---------- models shared note ---------- */
.models-note {
  margin: clamp(28px, 4vw, 44px) auto 0;
  max-width: 52ch;
  text-align: center;
  font-size: clamp(15px, 1.1vw, 18px);
  line-height: 1.45;
  letter-spacing: -0.01em;
  color: color-mix(in oklab, var(--wine-deep) 66%, var(--cream));
}
.models-note strong { color: var(--wine-mid); font-weight: 700; }

/* highlight the Workshop bullet inside model cards */
.model li strong { color: var(--accent-glow); font-weight: 700; }

/* manifesto: second sentence on its own line */
.manifesto .big .m2 { display: block; margin-top: 0.34em; }

/* ============================================================
   RESPONSIVE PASS
   ============================================================ */
@media (max-width: 900px) {
  .hero-cover .line { font-size: clamp(38px, 10vw, 110px); }
}
@media (max-width: 720px) {
  .hero-cover .hero-title {
    padding-top: clamp(84px, 15vh, 116px);
    padding-bottom: clamp(30px, 6vh, 56px);
  }
  .hero-cover .line { font-size: clamp(34px, 11vw, 92px); line-height: 0.94; }
  .hero-cover .line.top,
  .hero-cover .line.bottom { max-width: 100%; }
}
@media (max-width: 560px) {
  .section-pad { padding-block: clamp(60px, 11vh, 104px); }
  .hero-cover .line { font-size: clamp(32px, 11.5vw, 80px); }
  .position-aside { margin-top: 32px; padding-top: 24px; }
  .step-analysis { margin-top: 24px; }
}
@media (max-width: 400px) {
  .hero-cover .line { font-size: clamp(29px, 12vw, 72px); }
}
