/* ============================================================
   SCENE COMPOSITION
   Each scene is full-viewport. Reveals are slow and deliberate.
   Holds matter. Empty time is the point.
   ============================================================ */

/* ----- Base scene ----- */

.scene {
  min-height: 100vh;
  position: relative;
  display: grid;
  align-items: center;
  padding: var(--space-16) var(--space-8);
  overflow: hidden;
}

@media (max-width: 768px) {
  .scene {
    padding: var(--space-12) var(--space-4);
    min-height: 100vh;
  }
}

/* ----- Scene 1: First contact ----- */

.scene-first {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.scene-first-inner {
  max-width: 60rem;
  margin: 0 auto;
}

.first-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--bark-quiet);
  margin-bottom: var(--space-10);
  opacity: 0;
  transform: translateY(-8px);
  animation: revealMeta 2000ms var(--ease-reveal) 600ms forwards;
}

@keyframes revealMeta {
  to { opacity: 1; transform: translateY(0); }
}

.first-rule {
  width: 0;
  height: 1px;
  background: var(--bark-quiet);
  margin: 0 auto var(--space-8);
  opacity: 0.4;
  animation: drawRule 2400ms var(--ease-mechanical) 1200ms forwards;
}

@keyframes drawRule {
  to { width: 64px; }
}

/* Headline carved letter-by-letter */
.first-headline {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 6vw, 4.25rem);
  line-height: 1.05;
  letter-spacing: -0.045em;
  font-variation-settings: 'opsz' 144;
  font-weight: 320;
  color: var(--deep-bark);
  margin: 0 0 var(--space-8) 0;
}

.first-headline em {
  font-style: italic;
  color: var(--gold);
  font-weight: 320;
  font-variation-settings: 'opsz' 144;
}

/* Word-by-word reveal with hold */
.first-headline .word {
  display: inline-block;
  opacity: 0;
  transform: translateY(0.4em);
  animation: carveWord 500ms var(--ease-carve) forwards;
}

@keyframes carveWord {
  to { opacity: 1; transform: translateY(0); }
}

.first-dek {
  font-family: var(--font-display);
  font-size: clamp(1.125rem, 1.6vw, 1.5rem);
  font-style: italic;
  font-variation-settings: 'opsz' 96;
  font-weight: 350;
  line-height: 1.5;
  color: var(--bark);
  margin: 0 auto;
  max-width: 38ch;
  opacity: 0;
  /* 300ms (was 1500ms): the dek is an LCP candidate — a 1.5s opacity-0 hold
     was pure render-delay. The headline stagger still lands first. */
  animation: fadeInSlow 600ms var(--ease-deliberate) 300ms forwards;
}

.first-dek em {
  color: var(--gold);
  font-style: italic;
  font-weight: 400;
}

/* Dek link — matches .piece-body a treatment from notes.css */
.first-dek a {
  color: var(--gold);
  text-decoration: none;
  border-bottom: 1px solid var(--gold-glow);
  transition: border-color 200ms var(--ease-deliberate),
              color 200ms var(--ease-deliberate);
}

.first-dek a:hover {
  color: var(--gold-soft);
  border-bottom-color: var(--gold-soft);
}

.first-dek a:visited {
  color: var(--gold);
}

@keyframes fadeInSlow {
  to { opacity: 1; }
}

@keyframes cuePulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.5; }
}

/* Scroll cue — fades in after dek, then breathes gently to signal "next action" */
.first-cue {
  position: absolute;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-mono);
  font-size: var(--text-xxs);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--bark-quiet);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  opacity: 0;
  animation: fadeInSlow 600ms var(--ease-deliberate) 1300ms forwards,
             cuePulse 2500ms var(--ease-deliberate) 1900ms infinite;
}

.first-cue::after {
  content: '';
  width: 1px;
  height: 56px;
  background: linear-gradient(180deg, var(--bark-quiet), transparent);
  animation: cueDrop 3000ms var(--ease-mechanical) 8000ms infinite;
  transform-origin: top;
}

@keyframes cueDrop {
  0%, 100% { transform: scaleY(1); opacity: 0.7; }
  50% { transform: scaleY(1.15); opacity: 0.3; }
}

/* ----- Light source — atmospheric warm glow that drifts across scenes ----- */

.light-source {
  position: absolute;
  width: 80vw;
  height: 80vh;
  pointer-events: none;
  z-index: 0;
  background: radial-gradient(
    ellipse 50% 50% at center,
    rgba(217, 181, 105, 0.14) 0%,
    rgba(184, 146, 61, 0.06) 30%,
    transparent 70%
  );
  filter: blur(40px);
}

.light-source.top-right {
  top: -20vh;
  right: -20vw;
  opacity: 0;
  animation: lightIn 4000ms var(--ease-deliberate) 1000ms forwards;
}

.light-source.center {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.8);
  opacity: 0;
  animation: lightCenterIn 4800ms var(--ease-deliberate) 800ms forwards;
}

@keyframes lightIn {
  to { opacity: 1; }
}

@keyframes lightCenterIn {
  to { opacity: 1; transform: translate(-50%, -50%) scale(1); }
}

/* ----- Scene 2: Observation begins ----- */

.scene-observation {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.observation-inner {
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
}

.observation-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xxs);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--bark-quiet);
  text-align: center;
  margin-bottom: var(--space-8);
}

.observation-title {
  font-family: var(--font-display);
  font-size: clamp(1.875rem, 3.5vw, 2.75rem);
  line-height: 1.1;
  letter-spacing: -0.025em;
  font-variation-settings: 'opsz' 144;
  font-weight: 350;
  color: var(--deep-bark);
  text-align: center;
  margin: 0 auto var(--space-12) auto;
  max-width: 30ch;
  font-style: italic;
}

.observation-title em {
  color: var(--gold);
  font-style: italic;
}

/* The cycle stage — same vis as Candidate 6 but more deliberate timing */
.cycle-stage {
  position: relative;
  width: 100%;
  aspect-ratio: 1200 / 480;
  max-height: 50vh;
}

.cycle-svg {
  width: 100%;
  height: 100%;
  overflow: visible;
}

.cycle-grid-line {
  stroke: var(--bark-quiet);
  stroke-width: 0.5;
  opacity: 0.12;
}

.cycle-axis-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  fill: var(--bark-quiet);
}

.cycle-y-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  fill: var(--bark-quiet);
}

/* Phase bands appear sequentially, holding longer */
.cycle-phase-band {
  opacity: 0;
}

.scene-observation.in .cycle-phase-band.menstrual {
  animation: bandIn 1800ms var(--ease-deliberate) 800ms forwards;
}
.scene-observation.in .cycle-phase-band.follicular {
  animation: bandIn 1800ms var(--ease-deliberate) 1400ms forwards;
}
.scene-observation.in .cycle-phase-band.ovulatory {
  animation: bandIn 1800ms var(--ease-deliberate) 2000ms forwards;
}
.scene-observation.in .cycle-phase-band.luteal {
  animation: bandIn 1800ms var(--ease-deliberate) 2600ms forwards;
}

@keyframes bandIn {
  to { opacity: 1; }
}

.cycle-phase-band.menstrual { fill: rgba(196, 93, 67, 0.07); }
.cycle-phase-band.follicular { fill: rgba(107, 123, 94, 0.07); }
.cycle-phase-band.ovulatory { fill: rgba(184, 146, 61, 0.10); }
.cycle-phase-band.luteal { fill: rgba(196, 93, 67, 0.10); }

.cycle-phase-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  fill: var(--bark-soft);
  opacity: 0;
}

.scene-observation.in .cycle-phase-label.menstrual { animation: fadeInSlow 1400ms var(--ease-deliberate) 1600ms forwards; }
.scene-observation.in .cycle-phase-label.follicular { animation: fadeInSlow 1400ms var(--ease-deliberate) 2200ms forwards; }
.scene-observation.in .cycle-phase-label.ovulatory { animation: fadeInSlow 1400ms var(--ease-deliberate) 2800ms forwards; }
.scene-observation.in .cycle-phase-label.luteal { animation: fadeInSlow 1400ms var(--ease-deliberate) 3400ms forwards; }

/* Signal traces — drawn very slowly, like an oscilloscope */
.signal-trace {
  fill: none;
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 1600;
  stroke-dashoffset: 1600;
}

.scene-observation.in .signal-trace.barrier {
  stroke: var(--sage);
  animation: drawTrace 5000ms var(--ease-mechanical) 4200ms forwards;
}

.scene-observation.in .signal-trace.reactivity {
  stroke: var(--coral);
  animation: drawTrace 5000ms var(--ease-mechanical) 5400ms forwards;
}

.scene-observation.in .signal-trace.hydration {
  stroke: var(--gold);
  opacity: 0.75;
  animation: drawTrace 5000ms var(--ease-mechanical) 6200ms forwards;
}

@keyframes drawTrace {
  to { stroke-dashoffset: 0; }
}

.signal-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  opacity: 0;
  font-weight: 500;
}

.scene-observation.in .signal-label.barrier { fill: var(--sage); animation: fadeInSlow 1400ms var(--ease-deliberate) 8400ms forwards; }
.scene-observation.in .signal-label.reactivity { fill: var(--coral); animation: fadeInSlow 1400ms var(--ease-deliberate) 9000ms forwards; }
.scene-observation.in .signal-label.hydration { fill: var(--gold); animation: fadeInSlow 1400ms var(--ease-deliberate) 9600ms forwards; }

/* Day cursor — appears very late, after all traces drawn */
.cycle-cursor {
  stroke: var(--deep-bark);
  stroke-width: 1.5;
  stroke-dasharray: 3 5;
  opacity: 0;
}

.scene-observation.in .cycle-cursor {
  animation: cursorAppear 1600ms var(--ease-deliberate) 10500ms forwards;
}

@keyframes cursorAppear {
  to { opacity: 0.55; }
}

.cycle-cursor-dot {
  fill: var(--deep-bark);
  opacity: 0;
}

.scene-observation.in .cycle-cursor-dot {
  animation: cursorAppear 1600ms var(--ease-deliberate) 11000ms forwards;
}

/* Mela's reading card — appears last, anchors the scene */
.mela-card {
  position: absolute;
  bottom: var(--space-2);
  right: var(--space-3);
  background: var(--parchment-light);
  border: 1px solid rgba(58, 51, 41, 0.08);
  border-radius: 14px;
  padding: var(--space-3) var(--space-4);
  max-width: 380px;
  box-shadow: 0 24px 64px rgba(74, 53, 38, 0.16), 0 4px 16px rgba(74, 53, 38, 0.06);
  opacity: 0;
  transform: translateY(20px) scale(0.96);
  z-index: 5;
}

.scene-observation.in .mela-card {
  animation: cardCarve 2000ms var(--ease-carve) 11800ms forwards;
}

@keyframes cardCarve {
  to { opacity: 1; transform: translateY(0) scale(1); }
}

.mela-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--gold) 0%, var(--gold-soft) 60%, transparent 100%);
  border-radius: 14px 14px 0 0;
}

.mela-card-label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--bark-quiet);
  margin: 0 0 var(--space-1) 0;
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.mela-card-label::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--sage);
  box-shadow: 0 0 0 0 rgba(107, 123, 94, 0.5);
  animation: cardPulse 2800ms var(--ease-deliberate) infinite;
}

@keyframes cardPulse {
  0% { box-shadow: 0 0 0 0 rgba(107, 123, 94, 0.5); }
  60% { box-shadow: 0 0 0 10px rgba(107, 123, 94, 0); }
  100% { box-shadow: 0 0 0 0 rgba(107, 123, 94, 0); }
}

.mela-card-text {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-style: italic;
  line-height: 1.35;
  color: var(--deep-bark);
  font-variation-settings: 'opsz' 36;
  font-weight: 400;
  margin: 0 0 var(--space-1) 0;
}

.mela-card-text em {
  color: var(--gold);
}

.mela-card-detail {
  font-size: var(--text-sm);
  color: var(--bark);
  line-height: 1.5;
  margin: 0;
}

@media (max-width: 900px) {
  .mela-card {
    position: relative;
    bottom: auto;
    right: auto;
    margin: var(--space-4) auto 0;
    max-width: 100%;
  }
}

/* ----- Scene 3: The argument ----- */

.scene-argument {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.argument-inner {
  max-width: 720px;
  margin: 0 auto;
}

.argument-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xxs);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--bark-quiet);
  margin-bottom: var(--space-6);
  opacity: 0;
  transition: opacity 1800ms var(--ease-reveal);
}

.scene-argument.in .argument-meta { opacity: 1; }

.argument-title {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw, 4rem);
  line-height: 1.0;
  letter-spacing: -0.035em;
  font-variation-settings: 'opsz' 144;
  font-weight: 320;
  color: var(--deep-bark);
  margin: 0 0 var(--space-10) 0;
  max-width: 18ch;
}

.argument-title em {
  font-style: italic;
  color: var(--gold);
}

.argument-title .word {
  display: inline-block;
  opacity: 0;
  transform: translateY(0.4em);
  transition: opacity 1400ms var(--ease-carve),
              transform 1400ms var(--ease-carve);
}

.scene-argument.in .argument-title .word {
  opacity: 1;
  transform: translateY(0);
}

.argument-body p {
  font-size: var(--text-lg);
  line-height: 1.7;
  color: var(--deep-bark);
  margin: 0 0 var(--space-5) 0;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 1600ms var(--ease-reveal),
              transform 1600ms var(--ease-reveal);
}

.scene-argument.in .argument-body p {
  opacity: 1;
  transform: translateY(0);
}

.scene-argument.in .argument-body p:nth-of-type(1) { transition-delay: 2000ms; }
.scene-argument.in .argument-body p:nth-of-type(2) { transition-delay: 2800ms; }
.scene-argument.in .argument-body p:nth-of-type(3) { transition-delay: 3600ms; }

/* Pull line - large editorial */
.argument-pull {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-style: italic;
  font-variation-settings: 'opsz' 144;
  font-weight: 350;
  line-height: 1.25;
  color: var(--deep-bark);
  letter-spacing: -0.02em;
  padding: var(--space-5) 0 var(--space-5) var(--space-5);
  border-left: 2px solid var(--gold);
  margin: var(--space-6) 0;
  max-width: 28ch;
  opacity: 0;
  transform: translateX(20px);
  transition: opacity 1800ms var(--ease-reveal),
              transform 1800ms var(--ease-reveal);
}

.scene-argument.in .argument-pull {
  opacity: 1;
  transform: translateX(0);
  transition-delay: 3200ms;
}

.argument-pull em {
  color: var(--gold);
}

/* ----- Scene 4: Methodology ----- */

.scene-methodology {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.methodology-inner {
  max-width: 720px;
  margin: 0 auto;
  width: 100%;
}

.methodology-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xxs);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--bark-quiet);
  margin-bottom: var(--space-6);
  opacity: 0;
  transition: opacity 1600ms var(--ease-reveal);
}

.methodology-stat {
  font-family: var(--font-display);
  font-size: clamp(4rem, 12vw, 9rem);
  line-height: 0.9;
  letter-spacing: -0.05em;
  font-variation-settings: 'opsz' 144;
  font-weight: 280;
  color: var(--deep-bark);
  margin: 0 0 var(--space-2) 0;
}

.methodology-stat .unit {
  font-size: 0.28em;
  color: var(--bark-quiet);
  font-style: italic;
  margin-left: 0.2em;
  vertical-align: super;
}

.methodology-stat-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bark-quiet);
  margin-bottom: var(--space-10);
  opacity: 0;
  transition: opacity 1400ms var(--ease-reveal);
}

.methodology-stat .digit {
  display: inline-block;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 1200ms var(--ease-carve),
              transform 1200ms var(--ease-carve);
}

.scene-methodology.in .methodology-meta { opacity: 1; }
.scene-methodology.in .methodology-stat .digit { opacity: 1; transform: translateY(0); }
.scene-methodology.in .methodology-stat .digit:nth-child(1) { transition-delay: 600ms; }
.scene-methodology.in .methodology-stat .digit:nth-child(2) { transition-delay: 900ms; }
.scene-methodology.in .methodology-stat-label { opacity: 1; transition-delay: 1500ms; }

.methodology-body {
  max-width: 50ch;
}

.methodology-body p {
  font-size: var(--text-lg);
  line-height: 1.65;
  color: var(--deep-bark);
  margin: 0 0 var(--space-4) 0;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 1600ms var(--ease-reveal),
              transform 1600ms var(--ease-reveal);
}

.scene-methodology.in .methodology-body p {
  opacity: 1;
  transform: translateY(0);
}

.scene-methodology.in .methodology-body p:nth-of-type(1) { transition-delay: 2200ms; }
.scene-methodology.in .methodology-body p:nth-of-type(2) { transition-delay: 2900ms; }

.methodology-cta {
  margin-top: var(--space-6);
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 1400ms var(--ease-reveal),
              transform 1400ms var(--ease-reveal);
}

.scene-methodology.in .methodology-cta {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 3500ms;
}

/* One button grammar (Oura craft spec): solid pill, Inter w600 sentence-case,
   colour-only 150ms transition, no movement — stillness is the crispness. */
.btn-cinematic {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 48px;
  padding: 0 26px;
  font-family: var(--font-body);
  font-size: 15.5px;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: none;
  text-decoration: none;
  background: var(--deep-bark);
  color: var(--parchment-light);
  border: 0;
  border-radius: var(--r-pill, 999px);
  cursor: pointer;
  transition: background-color 150ms var(--ease-micro), color 150ms var(--ease-micro);
}

.btn-cinematic:hover {
  background: var(--ink-body);
  color: var(--parchment-light);
}

.btn-cinematic:active {
  transform: scale(0.985);
  transition-duration: 75ms;
}

.btn-cinematic::after {
  content: '→';
  display: inline-block;
  font-weight: 500;
}

/* ----- Scene 5: Signup ----- */

.scene-signup {
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: left;
}

.signup-inner {
  max-width: 880px;
  margin: 0 auto;
  width: 100%;
}

.signup-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xxs);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--bark-quiet);
  margin-bottom: var(--space-6);
  opacity: 0;
  transition: opacity 1600ms var(--ease-reveal);
}

.signup-title {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw, 4rem);
  line-height: 1.0;
  letter-spacing: -0.035em;
  font-variation-settings: 'opsz' 144;
  font-weight: 320;
  color: var(--deep-bark);
  margin: 0 0 var(--space-6) 0;
  max-width: 20ch;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 1600ms var(--ease-carve),
              transform 1600ms var(--ease-carve);
}

.signup-title em {
  font-style: italic;
  color: var(--gold);
}

.signup-body p {
  font-size: var(--text-lg);
  line-height: 1.65;
  color: var(--deep-bark);
  margin: 0 0 var(--space-3) 0;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 1400ms var(--ease-reveal),
              transform 1400ms var(--ease-reveal);
}

.signup-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
  margin-top: var(--space-8);
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 1400ms var(--ease-reveal),
              transform 1400ms var(--ease-reveal);
}

@media (max-width: 720px) {
  .signup-grid { grid-template-columns: 1fr; }
}

.signup-aside {
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: var(--parchment-deep);
  border: 1px solid rgba(58, 51, 41, 0.06);
  border-left: 2px solid var(--gold);
  padding: var(--space-5) var(--space-5);
  text-decoration: none;
  color: var(--deep-bark);
  transition: border-left-width 400ms var(--ease-deliberate),
              background 400ms var(--ease-deliberate);
}

.signup-aside:hover {
  border-left-width: 6px;
  background: var(--parchment-light);
}

.signup-aside-label {
  font-family: var(--font-mono);
  font-size: var(--text-xxs);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: var(--space-3);
}

.signup-aside-title {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2vw, 1.6rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
  font-weight: 320;
  margin: 0 0 var(--space-2) 0;
  color: var(--deep-bark);
}

.signup-aside-body {
  font-size: var(--text-base);
  line-height: 1.55;
  color: var(--bark-quiet);
  margin: 0 0 var(--space-4) 0;
}

.signup-aside-arrow {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
}

.signup-aside-arrow em {
  font-style: normal;
  display: inline-block;
  margin-left: 4px;
  transition: transform 400ms var(--ease-deliberate);
}

.signup-aside:hover .signup-aside-arrow em {
  transform: translateX(4px);
}

.scene-signup.in .signup-meta { opacity: 1; }
.scene-signup.in .signup-title { opacity: 1; transform: translateY(0); transition-delay: 600ms; }
.scene-signup.in .signup-body p { opacity: 1; transform: translateY(0); }
.scene-signup.in .signup-body p:nth-of-type(1) { transition-delay: 1400ms; }
.scene-signup.in .signup-body p:nth-of-type(2) { transition-delay: 2000ms; }
.scene-signup.in .signup-grid { opacity: 1; transform: translateY(0); transition-delay: 2600ms; }

.signup-form {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-bottom: var(--space-2);
}

.signup-form input[type=email] {
  flex: 1;
  min-width: 240px;
  font-family: var(--font-body);
  font-size: var(--text-base);
  padding: 16px 18px;
  border: 1px solid var(--bark-quiet);
  border-radius: 0;
  background: var(--parchment-light);
  color: var(--deep-bark);
  transition: border-color 600ms var(--ease-deliberate);
}

.signup-form input[type=email]:focus {
  outline: none;
  border-color: var(--deep-bark);
}

.signup-promise {
  font-size: var(--text-sm);
  color: var(--bark-quiet);
  font-style: italic;
  font-family: var(--font-display);
  margin: 0;
}

/* ----- Footer ----- */

.cinematic-footer {
  background: var(--parchment-deep);
  padding: var(--space-12) var(--space-8) var(--space-6);
  border-top: 1px solid rgba(58, 51, 41, 0.06);
}

.footer-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  gap: var(--space-6);
}

.footer-cols {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

@media (min-width: 768px) {
  .footer-cols {
    grid-template-columns: 2fr 1fr 1fr;
  }
}

.footer-disclaimer {
  font-size: var(--text-sm);
  color: var(--bark-soft);
  max-width: 60ch;
  line-height: 1.5;
}

.footer-meta {
  font-size: var(--text-xs);
  color: var(--bark-quiet);
  letter-spacing: 0.04em;
  padding-top: var(--space-4);
  border-top: 1px solid rgba(58, 51, 41, 0.06);
  font-family: var(--font-mono);
}

.footer-col-title {
  font-family: var(--font-mono);
  font-size: var(--text-xxs);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--bark-quiet);
  margin: 0 0 var(--space-2) 0;
}

.footer-cols nav a {
  font-size: var(--text-sm);
  color: var(--deep-bark);
  text-decoration: none;
  display: block;
  padding: 4px 0;
  transition: color 400ms var(--ease-deliberate);
}

.footer-cols nav a:hover { color: var(--gold); }

/* ----- Reduced motion ----- */

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-delay: 0ms !important;
    transition-duration: 0.01ms !important;
  }
  .scene > *, .scene * { opacity: 1 !important; transform: none !important; }
  .signal-trace { stroke-dashoffset: 0 !important; }
}

/* ============================================================
   SCENE 3 (NEW) — CARVED DECLARATION
   Three short carved lines. Then a hold. Then italic gold coda.
   ============================================================ */

.scene-declaration {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.declaration-inner {
  max-width: 720px;
  margin: 0 auto;
  text-align: left;
  width: 100%;
}

.declaration-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xxs);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--bark-quiet);
  margin-bottom: var(--space-10);
  opacity: 0;
  transition: opacity 1600ms var(--ease-reveal);
}

.scene-declaration.in .declaration-meta { opacity: 1; }

.declaration-lines {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  margin-bottom: var(--space-12);
}

.declaration-line {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4.5vw, 3.5rem);
  line-height: 1.05;
  letter-spacing: -0.025em;
  font-variation-settings: 'opsz' 96;
  font-weight: 320;
  color: var(--deep-bark);
  margin: 0;
  opacity: 0;
  transform: translateY(0.4em);
  transition: opacity 800ms var(--ease-carve),
              transform 800ms var(--ease-carve);
}

.scene-declaration.in .declaration-line.line-1 {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 400ms;
}

.scene-declaration.in .declaration-line.line-2 {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 1200ms;
}

.scene-declaration.in .declaration-line.line-3 {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 2000ms;
}

.declaration-coda {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2.2vw, 1.875rem);
  font-style: italic;
  font-variation-settings: 'opsz' 96;
  font-weight: 350;
  letter-spacing: -0.015em;
  line-height: 1.35;
  color: var(--gold);
  margin: 0;
  padding-left: var(--space-5);
  border-left: 2px solid var(--gold);
  opacity: 0;
  transform: translateX(20px);
  transition: opacity 1800ms var(--ease-reveal),
              transform 1800ms var(--ease-reveal);
  max-width: 30ch;
}

.scene-declaration.in .declaration-coda {
  opacity: 1;
  transform: translateX(0);
  transition-delay: 3200ms;
}

/* Folio (dark) declaration — flip the mono label to the on-dark register and keep
   the coda as the section's one gold accent (brightened for the dark ground). */
.section--folio .declaration-meta { color: #9C8A6F; }
.section--folio .declaration-coda { color: var(--gold-soft); border-left-color: var(--gold-soft); }
