/* =========================================================
   hanun.ai — Editorial Flow Stylesheet
   Palette: #FFF0F3 (Blush White), #FFB7C5 (Rose Cream),
            #E85D75 (Primary Magenta), #8B1A2B (Deep Crimson),
            #2A0A14 (Midnight Plum), #FFE8ED (Petal Tint)
   Type: Josefin Sans (display), Libre Baskerville (body)
   ========================================================= */

:root {
    --c-blush: #FFF0F3;
    --c-petal: #FFE8ED;
    --c-rose: #FFB7C5;
    --c-magenta: #E85D75;
    --c-crimson: #8B1A2B;
    --c-plum: #2A0A14;

    --f-display: 'Josefin Sans', 'Futura', 'Helvetica Neue', sans-serif;
    --f-body: 'Libre Baskerville', 'Lora', Georgia, serif;

    --ease-soft: cubic-bezier(0.4, 0, 0.2, 1);
    --ease-spring: cubic-bezier(0.22, 1, 0.36, 1);
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html, body {
    width: 100%;
    overflow-x: hidden;
    background: var(--c-blush);
    color: var(--c-plum);
    font-family: var(--f-body);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body {
    overflow-y: auto;
}

a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
em, i { font-style: italic; }

/* =========================================================
   EDITORIAL FLOW — snap scroll container
   ========================================================= */
.editorial-flow {
    width: 100%;
    height: 100vh;
    overflow-y: scroll;
    overflow-x: hidden;
    scroll-snap-type: y mandatory;
    scroll-behavior: smooth;
}

.spread {
    position: relative;
    width: 100%;
    min-height: 100vh;
    height: 100vh;
    overflow: hidden;
    scroll-snap-align: start;
    scroll-snap-stop: always;
}

/* =========================================================
   SHARED TYPOGRAPHY
   ========================================================= */
.section-label {
    font-family: var(--f-display);
    font-weight: 400;
    font-size: clamp(0.75rem, 1.2vw, 0.9rem);
    letter-spacing: 0.15em;
    line-height: 1.4;
    text-transform: uppercase;
}

/* =========================================================
   DUOTONE WRAPPER + PHOTO STAND-INS
   ========================================================= */
.duotone-wrap {
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 100%;
}
.duotone-wrap::after {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--c-magenta);
    mix-blend-mode: multiply;
    opacity: 0.18;
    pointer-events: none;
    transition: opacity 600ms var(--ease-soft);
}
.duotone-wrap:hover::after {
    opacity: 0.28;
}

.duotone-image {
    position: absolute;
    inset: 0;
    background-color: var(--c-rose);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    filter: grayscale(100%) sepia(30%) hue-rotate(320deg) saturate(200%) contrast(1.1);
    mix-blend-mode: multiply;
    transition: filter 600ms var(--ease-soft), transform 12s var(--ease-soft);
}

/* CSS-painted "photographs" — radial blooms */
.duotone-image--peony {
    background:
        radial-gradient(circle at 30% 25%, var(--c-magenta) 0%, transparent 22%),
        radial-gradient(circle at 70% 30%, var(--c-rose) 0%, transparent 25%),
        radial-gradient(circle at 25% 70%, var(--c-magenta) 0%, transparent 28%),
        radial-gradient(circle at 75% 75%, var(--c-crimson) 0%, transparent 30%),
        radial-gradient(circle at 50% 50%, var(--c-rose) 0%, transparent 40%),
        radial-gradient(ellipse at 15% 50%, var(--c-magenta) 0%, transparent 24%),
        radial-gradient(ellipse at 85% 50%, var(--c-magenta) 0%, transparent 24%),
        linear-gradient(135deg, var(--c-rose) 0%, var(--c-magenta) 50%, var(--c-crimson) 100%);
}
.duotone-image--ranunculus {
    background:
        radial-gradient(circle at 50% 30%, var(--c-magenta) 0%, transparent 18%),
        radial-gradient(circle at 30% 60%, var(--c-rose) 0%, transparent 22%),
        radial-gradient(circle at 70% 65%, var(--c-magenta) 0%, transparent 22%),
        radial-gradient(circle at 50% 80%, var(--c-crimson) 0%, transparent 24%),
        radial-gradient(circle at 20% 30%, var(--c-rose) 0%, transparent 16%),
        radial-gradient(circle at 80% 25%, var(--c-magenta) 0%, transparent 16%),
        linear-gradient(160deg, var(--c-rose), var(--c-crimson));
}
.duotone-image--stem {
    background:
        linear-gradient(0deg, var(--c-crimson) 0%, var(--c-magenta) 35%, var(--c-rose) 70%, var(--c-magenta) 100%),
        radial-gradient(circle at 50% 20%, var(--c-rose) 0%, transparent 30%);
}
.duotone-image--bed {
    background:
        radial-gradient(circle at 10% 50%, var(--c-magenta) 0%, transparent 18%),
        radial-gradient(circle at 30% 50%, var(--c-rose) 0%, transparent 18%),
        radial-gradient(circle at 50% 50%, var(--c-magenta) 0%, transparent 18%),
        radial-gradient(circle at 70% 50%, var(--c-rose) 0%, transparent 18%),
        radial-gradient(circle at 90% 50%, var(--c-magenta) 0%, transparent 18%),
        linear-gradient(180deg, var(--c-rose), var(--c-crimson));
}
.duotone-image--macro {
    background:
        radial-gradient(circle at 50% 50%, var(--c-rose) 0%, var(--c-magenta) 35%, var(--c-crimson) 75%, var(--c-plum) 100%);
}
.duotone-image--dahlia {
    background:
        repeating-radial-gradient(circle at 50% 50%, var(--c-rose) 0px, var(--c-magenta) 18px, var(--c-rose) 36px),
        radial-gradient(circle at 50% 50%, transparent 0%, var(--c-crimson) 100%);
}
.duotone-image--vines {
    background:
        linear-gradient(20deg, transparent 40%, var(--c-magenta) 50%, transparent 60%),
        linear-gradient(-20deg, transparent 40%, var(--c-rose) 50%, transparent 60%),
        linear-gradient(180deg, var(--c-rose), var(--c-crimson));
}
.duotone-image--seed {
    background:
        radial-gradient(ellipse 30% 50% at 50% 50%, var(--c-magenta) 0%, transparent 50%),
        radial-gradient(ellipse 50% 30% at 50% 50%, var(--c-rose) 0%, transparent 50%),
        linear-gradient(135deg, var(--c-rose), var(--c-crimson));
}
.duotone-image--bouquet {
    background:
        radial-gradient(circle at 25% 25%, var(--c-magenta) 0%, transparent 20%),
        radial-gradient(circle at 75% 25%, var(--c-rose) 0%, transparent 22%),
        radial-gradient(circle at 25% 75%, var(--c-rose) 0%, transparent 22%),
        radial-gradient(circle at 75% 75%, var(--c-magenta) 0%, transparent 20%),
        radial-gradient(circle at 50% 50%, var(--c-crimson) 0%, transparent 35%),
        linear-gradient(45deg, var(--c-rose), var(--c-magenta));
}
.duotone-image--rose {
    background:
        repeating-radial-gradient(circle at 60% 40%, var(--c-rose) 0px, var(--c-magenta) 12px, var(--c-rose) 24px);
}
.duotone-image--column {
    background:
        linear-gradient(0deg, var(--c-crimson), var(--c-magenta), var(--c-rose), var(--c-magenta));
}
.duotone-image--leaves {
    background:
        radial-gradient(ellipse 50% 20% at 50% 30%, var(--c-magenta) 0%, transparent 60%),
        radial-gradient(ellipse 50% 20% at 50% 60%, var(--c-rose) 0%, transparent 60%),
        radial-gradient(ellipse 50% 20% at 50% 90%, var(--c-magenta) 0%, transparent 60%),
        linear-gradient(180deg, var(--c-crimson), var(--c-rose));
}

.duotone-wrap--full,
.duotone-wrap--strip,
.duotone-wrap--1x3,
.duotone-wrap--5x2,
.duotone-wrap--1x1,
.duotone-wrap--3x4 {
    width: 100%;
    height: 100%;
}

/* =========================================================
   SKELETON LOADING SHIMMER (universal)
   ========================================================= */
@keyframes shimmer {
    0%   { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}

.skeleton {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 5;
    background: linear-gradient(110deg,
        rgba(255, 240, 243, 0.0) 25%,
        rgba(232, 93, 117, 0.18) 37%,
        rgba(255, 183, 197, 0.22) 50%,
        rgba(232, 93, 117, 0.18) 63%,
        rgba(255, 240, 243, 0.0) 75%);
    background-size: 200% 100%;
    background-color: var(--c-petal);
    animation: shimmer 1.6s linear infinite;
    border-radius: 40% 60% 50% 50%;
    opacity: 1;
    transition: opacity 400ms var(--ease-soft);
}

.spread .skeleton-text {
    position: absolute;
    height: 1.2em;
    border-radius: 8px;
    background: linear-gradient(110deg,
        rgba(255, 183, 197, 0.4) 25%,
        rgba(232, 93, 117, 0.3) 50%,
        rgba(255, 183, 197, 0.4) 75%);
    background-size: 200% 100%;
    animation: shimmer 1.6s linear infinite;
    z-index: 5;
    transition: opacity 400ms var(--ease-soft);
}

.spread__content,
.statement-grid,
.feature-cascade,
.feature-header,
.quote-frame,
.grid-burst,
.colophon {
    transition: opacity 600ms var(--ease-soft) 200ms,
                transform 800ms var(--ease-spring) 200ms;
}

.spread:not(.spread--revealed) .spread__content,
.spread:not(.spread--revealed) .statement-grid,
.spread:not(.spread--revealed) .feature-cascade,
.spread:not(.spread--revealed) .feature-header,
.spread:not(.spread--revealed) .quote-frame,
.spread:not(.spread--revealed) .grid-burst,
.spread:not(.spread--revealed) .colophon {
    opacity: 0;
    transform: translateY(28px);
}

.spread--revealed .spread__content,
.spread--revealed .statement-grid,
.spread--revealed .feature-cascade,
.spread--revealed .feature-header,
.spread--revealed .quote-frame,
.spread--revealed .grid-burst,
.spread--revealed .colophon {
    opacity: 1;
    transform: translateY(0);
}

.spread--revealed .skeleton,
.spread--revealed .skeleton-text {
    opacity: 0;
}

/* =========================================================
   DOT NAVIGATION
   ========================================================= */
.dot-nav {
    position: fixed;
    top: 50%;
    right: 1.6rem;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
    z-index: 100;
    opacity: 0;
    transition: opacity 600ms var(--ease-soft);
}
.dot-nav.is-visible {
    opacity: 1;
}
.dot-nav__item {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--c-rose);
    transition: color 300ms var(--ease-soft), transform 300ms var(--ease-spring);
    position: relative;
}
.dot-nav__item.is-active {
    color: var(--c-magenta);
    transform: scale(1.25);
}
.dot-nav__item:hover {
    color: var(--c-crimson);
}
.dot-nav__icon {
    width: 22px;
    height: 22px;
}
.dot-nav__label {
    position: absolute;
    right: 36px;
    top: 50%;
    transform: translateY(-50%) translateX(8px);
    font-family: var(--f-display);
    font-weight: 300;
    font-size: 0.65rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--c-crimson);
    opacity: 0;
    pointer-events: none;
    white-space: nowrap;
    transition: opacity 250ms var(--ease-soft), transform 250ms var(--ease-soft);
}
.dot-nav__item:hover .dot-nav__label,
.dot-nav__item.is-active .dot-nav__label {
    opacity: 1;
    transform: translateY(-50%) translateX(0);
}

/* =========================================================
   SPREAD 1 — THE COVER
   ========================================================= */
.spread--cover {
    background: var(--c-plum);
    color: var(--c-blush);
}
.spread--cover .duotone-wrap--full {
    position: absolute;
    inset: 0;
}
.spread--cover .duotone-image {
    transform: scale(1.05);
}
.spread--revealed.spread--cover .duotone-image {
    transform: scale(1.0);
}

.cover-content {
    position: relative;
    z-index: 2;
    width: 100%;
    height: 100vh;
    padding: clamp(1.5rem, 3vw, 3rem);
    display: grid;
    grid-template-rows: auto 1fr auto;
    align-items: stretch;
}

.cover-title {
    grid-row: 2;
    align-self: center;
    justify-self: start;
    font-family: var(--f-display);
    font-weight: 700;
    font-size: clamp(6rem, 18vw, 18rem);
    letter-spacing: -0.04em;
    line-height: 0.85;
    text-transform: uppercase;
    color: var(--c-blush);
    mix-blend-mode: difference;
    display: flex;
}
.cover-title .char {
    display: inline-block;
    transform: translateY(0);
    opacity: 1;
}
.spread:not(.spread--revealed).spread--cover .cover-title .char {
    transform: translateY(120%);
    opacity: 0;
}
.spread--revealed.spread--cover .cover-title .char {
    transform: translateY(0);
    opacity: 1;
    transition: transform 800ms var(--ease-spring), opacity 600ms var(--ease-soft);
}
.spread--revealed.spread--cover .cover-title .char:nth-child(1) { transition-delay: 200ms; }
.spread--revealed.spread--cover .cover-title .char:nth-child(2) { transition-delay: 250ms; }
.spread--revealed.spread--cover .cover-title .char:nth-child(3) { transition-delay: 300ms; }
.spread--revealed.spread--cover .cover-title .char:nth-child(4) { transition-delay: 350ms; }
.spread--revealed.spread--cover .cover-title .char:nth-child(5) { transition-delay: 400ms; }

.cover-meta {
    grid-row: 1;
    display: flex;
    align-items: center;
    gap: 1rem;
    color: var(--c-blush);
    font-family: var(--f-display);
    font-weight: 400;
    font-size: clamp(0.7rem, 1vw, 0.85rem);
    letter-spacing: 0.18em;
    text-transform: uppercase;
}
.cover-meta__rule {
    flex: 0 0 60px;
    height: 1px;
    background: var(--c-magenta);
}
.cover-meta__title {
    color: var(--c-rose);
}

.cover-subtitle {
    grid-row: 3;
    align-self: end;
    justify-self: start;
    max-width: 520px;
    font-family: var(--f-body);
    font-style: italic;
    font-size: clamp(0.95rem, 1.3vw, 1.15rem);
    line-height: 1.5;
    color: var(--c-rose);
    border-left: 1px solid var(--c-magenta);
    padding-left: 1rem;
}

.cover-corner {
    position: absolute;
    width: clamp(60px, 8vw, 110px);
    height: clamp(60px, 8vw, 110px);
    color: var(--c-magenta);
    z-index: 3;
}
.cover-corner--tl {
    top: clamp(1.5rem, 3vw, 3rem);
    right: clamp(1.5rem, 3vw, 3rem);
}
.cover-corner--br {
    bottom: clamp(5rem, 8vw, 8rem);
    right: clamp(1.5rem, 3vw, 3rem);
}
.cover-corner .ornament { width: 100%; height: 100%; }

.cover-issue {
    position: absolute;
    bottom: clamp(1rem, 2vw, 2rem);
    right: clamp(1.5rem, 3vw, 3rem);
    font-family: var(--f-display);
    font-weight: 300;
    font-size: 0.75rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--c-rose);
    text-align: right;
    z-index: 3;
}
.cover-issue__no {
    display: block;
    font-size: 1rem;
    color: var(--c-magenta);
    font-weight: 600;
}
.cover-issue__price { display: block; }

.scroll-cue {
    position: absolute;
    left: 50%;
    bottom: 1.4rem;
    transform: translateX(-50%);
    color: var(--c-rose);
    font-family: var(--f-display);
    font-size: 0.7rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.4rem;
    opacity: 0.85;
    z-index: 3;
}
.scroll-cue__arrow {
    width: 18px;
    height: 50px;
    animation: cueBob 2.4s ease-in-out infinite;
}
@keyframes cueBob {
    0%, 100% { transform: translateY(0); opacity: 0.7; }
    50%      { transform: translateY(8px); opacity: 1; }
}

/* =========================================================
   SPREAD 2 — THE OPENING STATEMENT
   ========================================================= */
.spread--statement {
    background: var(--c-blush);
    color: var(--c-plum);
}

.statement-grid {
    display: grid;
    grid-template-columns: 65% 35%;
    height: 100vh;
}

.statement-text {
    padding: clamp(3rem, 6vh, 5rem) clamp(2rem, 6vw, 6rem) clamp(3rem, 6vh, 5rem) clamp(4rem, 20vw, 14rem);
    display: flex;
    flex-direction: column;
    justify-content: center;
    overflow: hidden;
}

.statement-text .section-label {
    color: var(--c-magenta);
    margin-bottom: 1.5rem;
}
.statement-title {
    font-family: var(--f-display);
    font-weight: 600;
    font-size: clamp(2rem, 5vw, 4rem);
    letter-spacing: 0.01em;
    line-height: 1.05;
    color: var(--c-crimson);
    margin-bottom: 1.8rem;
    max-width: 18ch;
}
.statement-body p {
    font-family: var(--f-body);
    font-weight: 400;
    font-size: clamp(0.95rem, 1.25vw, 1.15rem);
    line-height: 1.7;
    letter-spacing: 0.005em;
    color: var(--c-plum);
    margin-bottom: 1rem;
    max-width: 50ch;
}
.statement-body .lede {
    font-size: clamp(1.1rem, 1.5vw, 1.3rem);
    color: var(--c-crimson);
    margin-bottom: 1.4rem;
}
.statement-body em {
    color: var(--c-magenta);
    font-style: italic;
}

.seedpod-list {
    margin-top: 1.4rem;
    border-top: 1px solid var(--c-rose);
    padding-top: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.seedpod-list li {
    position: relative;
    padding-left: 1.7rem;
    font-family: var(--f-display);
    font-weight: 400;
    font-size: 0.85rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--c-crimson);
}
.seedpod-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.35em;
    width: 14px;
    height: 8px;
    border: 1px solid var(--c-magenta);
    border-radius: 50% 50% 0 0 / 100% 100% 0 0;
    transform: rotate(-15deg);
    background:
        radial-gradient(circle at 50% 50%, var(--c-magenta) 0 1.2px, transparent 1.2px) 50% 60% / 100% 100%;
}

.statement-image {
    position: relative;
    overflow: hidden;
    background: var(--c-petal);
}
.duotone-wrap--strip {
    height: 100%;
}
.statement-image__caption {
    position: absolute;
    left: 1rem;
    bottom: 1rem;
    background: rgba(42, 10, 20, 0.7);
    color: var(--c-blush);
    padding: 0.5rem 0.7rem;
    font-family: var(--f-display);
    font-weight: 300;
    font-size: 0.7rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    z-index: 3;
    max-width: 80%;
}
.statement-image__caption em { color: var(--c-rose); font-style: italic; }

/* =========================================================
   SPREAD 3 — THE FEATURE WELL (cascading columns)
   ========================================================= */
.spread--feature {
    background: var(--c-petal);
    color: var(--c-plum);
    overflow: hidden;
}

.feature-header {
    position: absolute;
    top: clamp(2rem, 4vh, 3rem);
    left: clamp(2rem, 4vw, 4rem);
    right: clamp(2rem, 4vw, 4rem);
    z-index: 3;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 2rem;
    pointer-events: none;
}
.feature-header .section-label { color: var(--c-magenta); }
.feature-title {
    font-family: var(--f-display);
    font-weight: 600;
    font-size: clamp(1.4rem, 2.4vw, 2rem);
    letter-spacing: 0.01em;
    line-height: 1.1;
    color: var(--c-crimson);
    text-align: right;
    max-width: 50%;
}

.feature-cascade {
    position: absolute;
    inset: 0;
    padding: clamp(7rem, 12vh, 9rem) clamp(2rem, 4vw, 4rem) clamp(2rem, 3vh, 3rem);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: clamp(1rem, 2vw, 2rem);
    height: 100vh;
    overflow: hidden;
}

.feature-block {
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
    align-self: start;
}
.feature-block:nth-child(1)  { grid-column: 1; margin-top: 0; }
.feature-block:nth-child(2)  { grid-column: 2; margin-top: 14vh; }
.feature-block:nth-child(3)  { grid-column: 3; margin-top: 4vh; }
.feature-block:nth-child(4)  { grid-column: 1; margin-top: 1.2rem; }
.feature-block:nth-child(5)  { grid-column: 2; margin-top: 1.2rem; }
.feature-block:nth-child(6)  { grid-column: 3; margin-top: 1.2rem; }

.feature-block .duotone-wrap {
    width: 100%;
}
.feature-block--tall .duotone-wrap { aspect-ratio: 1 / 2.2; }
.feature-block--pano .duotone-wrap { aspect-ratio: 2.4 / 1; }
.feature-block--square .duotone-wrap { aspect-ratio: 1 / 1; }
.feature-block--portrait .duotone-wrap { aspect-ratio: 3 / 4; }

.feature-block__caption {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    padding-top: 0.4rem;
    border-top: 1px solid var(--c-rose);
}
.feature-block__no {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 0.7rem;
    letter-spacing: 0.2em;
    color: var(--c-magenta);
}
.feature-block__title {
    font-family: var(--f-display);
    font-weight: 600;
    font-size: clamp(0.95rem, 1.3vw, 1.15rem);
    letter-spacing: 0.02em;
    line-height: 1.15;
    color: var(--c-crimson);
}
.feature-block__caption p {
    font-family: var(--f-body);
    font-size: clamp(0.78rem, 0.95vw, 0.9rem);
    line-height: 1.55;
    color: var(--c-plum);
}
.feature-block__caption em { color: var(--c-magenta); font-style: italic; }

/* =========================================================
   SPREAD 4 — THE PULL QUOTE
   ========================================================= */
.spread--quote {
    background: var(--c-crimson);
    color: var(--c-blush);
    display: flex;
    align-items: center;
    justify-content: center;
}

.quote-frame {
    position: relative;
    width: min(92vw, 1200px);
    padding: clamp(3rem, 8vh, 6rem) clamp(2rem, 8vw, 6rem);
    text-align: center;
}
.quote-corner {
    position: absolute;
    width: clamp(80px, 10vw, 140px);
    height: clamp(80px, 10vw, 140px);
    color: var(--c-blush);
    opacity: 0.85;
}
.quote-corner--tl { top: 0; left: 0; }
.quote-corner--br { bottom: 0; right: 0; transform: rotate(180deg); }

.pull-quote {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: clamp(2.4rem, 9vw, 7.5rem);
    letter-spacing: -0.025em;
    line-height: 0.95;
    color: var(--c-blush);
    text-transform: none;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.pull-quote .quote-line {
    display: block;
    overflow: hidden;
    transform: translateY(0);
}
.pull-quote .quote-line:nth-child(odd) { color: var(--c-rose); }
.pull-quote .quote-line:nth-child(2) { padding-left: 6vw; }
.pull-quote .quote-line:nth-child(3) { padding-right: 4vw; }
.pull-quote .quote-line:nth-child(4) { padding-left: 8vw; }

.spread:not(.spread--revealed).spread--quote .quote-line {
    transform: translateY(110%);
    opacity: 0;
}
.spread--revealed.spread--quote .quote-line {
    transform: translateY(0);
    opacity: 1;
    transition: transform 700ms var(--ease-spring), opacity 600ms var(--ease-soft);
}
.spread--revealed.spread--quote .quote-line:nth-child(1) { transition-delay: 250ms; }
.spread--revealed.spread--quote .quote-line:nth-child(2) { transition-delay: 350ms; }
.spread--revealed.spread--quote .quote-line:nth-child(3) { transition-delay: 450ms; }
.spread--revealed.spread--quote .quote-line:nth-child(4) { transition-delay: 550ms; }
.spread--revealed.spread--quote .quote-line:nth-child(5) { transition-delay: 650ms; }

.quote-attribution {
    margin-top: 2rem;
    color: var(--c-rose);
}
.quote-attribution .section-label { color: var(--c-rose); }

/* =========================================================
   SPREAD 5 — THE GRID BURST
   ========================================================= */
.spread--grid {
    background: var(--c-blush);
}
.grid-burst {
    width: 100%;
    height: 100vh;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(3, 1fr);
    gap: 0;
    background: var(--c-rose);
}
.grid-cell {
    position: relative;
    border: 1px solid var(--c-rose);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}
.grid-cell--span-2x2 { grid-column: span 2; grid-row: span 2; }
.grid-cell--span-2x1 { grid-column: span 2; grid-row: span 1; }
.grid-cell--span-1x2 { grid-column: span 1; grid-row: span 2; }

.grid-cell--photo { background: var(--c-petal); }
.grid-cell--photo .duotone-wrap { width: 100%; height: 100%; }

.grid-cell--solid {
    background: var(--c-crimson);
    color: var(--c-blush);
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-end;
    padding: clamp(1rem, 2vw, 1.6rem);
    gap: 0.6rem;
}
.grid-cell--solid:nth-of-type(5n) {
    background: var(--c-magenta);
    color: var(--c-plum);
}
.grid-cell__head {
    font-family: var(--f-display);
    font-weight: 600;
    font-size: clamp(1.2rem, 2vw, 1.7rem);
    letter-spacing: 0.02em;
    line-height: 1.05;
}
.grid-cell__body {
    font-family: var(--f-body);
    font-size: clamp(0.78rem, 0.9vw, 0.92rem);
    line-height: 1.55;
    max-width: 36ch;
}
.grid-cell__body em {
    color: var(--c-rose);
    font-style: italic;
}
.grid-cell--solid:nth-of-type(5n) .grid-cell__body em {
    color: var(--c-crimson);
}

.grid-cell--svg {
    background: var(--c-blush);
    color: var(--c-magenta);
    flex-direction: column;
    gap: 0.6rem;
    padding: 1rem;
}
.grid-cell--svg .ornament {
    width: clamp(60px, 7vw, 100px);
    height: clamp(60px, 7vw, 100px);
}
.grid-cell__caption {
    font-family: var(--f-display);
    font-weight: 300;
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--c-crimson);
}

/* fern fiddlehead draw-on */
.ornament--fern .fern-path {
    stroke-dasharray: 360;
    stroke-dashoffset: 360;
    transition: stroke-dashoffset 1.6s ease-in-out;
}
.spread--revealed.spread--grid .ornament--fern .fern-path {
    stroke-dashoffset: 0;
}

/* =========================================================
   SPREAD 6 — THE COLOPHON
   ========================================================= */
.spread--colophon {
    background: var(--c-blush);
    color: var(--c-plum);
    display: flex;
    align-items: center;
    justify-content: center;
}
.colophon {
    width: min(92vw, 520px);
    text-align: center;
    padding: 2rem 0;
}
.colophon__ornament {
    color: var(--c-magenta);
    margin-bottom: 1.2rem;
    display: flex;
    justify-content: center;
}
.colophon__ornament .ornament {
    width: clamp(140px, 18vw, 200px);
    height: clamp(60px, 8vw, 80px);
}
.colophon__title {
    font-family: var(--f-display);
    font-weight: 600;
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--c-crimson);
    margin-bottom: 1.4rem;
}
.colophon__body p {
    font-family: var(--f-body);
    font-size: clamp(0.85rem, 1vw, 0.98rem);
    line-height: 1.7;
    color: var(--c-plum);
    margin-bottom: 1rem;
}
.colophon__body em {
    color: var(--c-magenta);
    font-style: italic;
}
.colophon__credits {
    margin: 1.5rem auto 1.5rem;
    border-top: 1px solid var(--c-rose);
    border-bottom: 1px solid var(--c-rose);
    padding: 1rem 0;
    text-align: left;
}
.colophon__row {
    display: grid;
    grid-template-columns: 30% 70%;
    column-gap: 1rem;
    padding: 0.3rem 0;
    border-bottom: 1px dotted var(--c-rose);
}
.colophon__row:last-child { border-bottom: none; }
.colophon__row dt {
    font-family: var(--f-display);
    font-weight: 600;
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--c-magenta);
    align-self: center;
}
.colophon__row dd {
    font-family: var(--f-body);
    font-size: 0.85rem;
    color: var(--c-crimson);
    margin: 0;
}
.colophon__signoff {
    font-family: var(--f-display);
    font-weight: 400;
    font-size: 0.85rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--c-magenta);
    margin-top: 0.6rem;
}

/* =========================================================
   ORNAMENT BASE
   ========================================================= */
.ornament {
    display: block;
    width: 100%;
    height: 100%;
    color: var(--c-magenta);
}
.ornament--peony,
.ornament--fern,
.ornament--root {
    color: inherit;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 900px) {
    .statement-grid {
        grid-template-columns: 1fr;
        grid-template-rows: 1fr 30vh;
    }
    .statement-text {
        padding: 5vh clamp(1.4rem, 5vw, 2rem) 2vh clamp(1.4rem, 5vw, 2rem);
    }
    .feature-cascade {
        grid-template-columns: repeat(2, 1fr);
    }
    .feature-block:nth-child(1)  { grid-column: 1; margin-top: 0; }
    .feature-block:nth-child(2)  { grid-column: 2; margin-top: 6vh; }
    .feature-block:nth-child(3)  { grid-column: 1; margin-top: 1rem; }
    .feature-block:nth-child(4)  { grid-column: 2; margin-top: 1rem; }
    .feature-block:nth-child(5)  { grid-column: 1; margin-top: 1rem; }
    .feature-block:nth-child(6)  { grid-column: 2; margin-top: 1rem; }
    .grid-burst {
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: repeat(6, 1fr);
    }
    .grid-cell--span-2x2 { grid-column: span 2; grid-row: span 2; }
    .grid-cell--span-2x1 { grid-column: span 2; grid-row: span 1; }
    .grid-cell--span-1x2 { grid-column: span 1; grid-row: span 2; }
    .feature-header {
        flex-direction: column;
        gap: 0.4rem;
    }
    .feature-title { text-align: left; max-width: 100%; }
    .dot-nav { right: 0.6rem; }
    .dot-nav__label { display: none; }
}

@media (max-width: 600px) {
    .cover-title { font-size: clamp(3.4rem, 22vw, 7rem); }
    .statement-text {
        padding: 4vh 1.2rem 1vh 1.2rem;
    }
    .feature-cascade {
        grid-template-columns: 1fr;
        overflow-y: auto;
    }
    .feature-block { margin-top: 1rem !important; grid-column: 1 !important; }
    .grid-burst {
        grid-template-columns: 1fr;
        grid-template-rows: repeat(11, 1fr);
    }
    .grid-cell--span-2x2,
    .grid-cell--span-2x1,
    .grid-cell--span-1x2 { grid-column: span 1; grid-row: span 1; }
}
