/* ==========================================================
   chloengine.com — Sun-Drenched Coral Atelier
   Watercolor substrate, asymmetric tide grid, variable-fluid type
   ========================================================== */

@property --w { syntax: '<number>'; inherits: false; initial-value: 360; }
@property --o { syntax: '<number>'; inherits: false; initial-value: 96; }
@property --s { syntax: '<number>'; inherits: false; initial-value: 60; }

:root {
    /* Palette — Warm Reef-Sunset */
    --cream-paper: #FBF3E4;
    --coral-bloom: #F4794E;
    --mango-saffron: #F4C04A;
    --anemone-pink: #E96A8E;
    --reef-indigo: #2A3A6E;
    --sea-foam: #D2D9C2;

    /* Typography */
    --font-display: 'Fraunces', 'Lora', Georgia, serif;
    --font-body: 'Newsreader', 'Lora', Georgia, serif;
    --font-hand: 'Caveat', 'Patrick Hand', cursive;
    --font-mono: 'DM Mono', 'IBM Plex Mono', monospace;

    /* Tide Grid */
    --tide: 38.2vh;

    /* Drift offsets per section */
    --drift: 0vw;
}

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

html {
    scroll-behavior: smooth;
}

body {
    font-family: var(--font-body);
    font-size: 18px;
    line-height: 1.7;
    color: var(--reef-indigo);
    background: var(--cream-paper);
    background-image:
        radial-gradient(circle at 14% 10%, rgba(244, 121, 78, 0.07) 0%, transparent 32%),
        radial-gradient(circle at 86% 22%, rgba(244, 192, 74, 0.08) 0%, transparent 30%),
        radial-gradient(circle at 50% 60%, rgba(233, 106, 142, 0.06) 0%, transparent 36%),
        radial-gradient(circle at 22% 88%, rgba(210, 217, 194, 0.18) 0%, transparent 38%);
    overflow-x: hidden;
    font-optical-sizing: auto;
    cursor: crosshair;
}

/* Granulated pigment specks layer */
body::before {
    content: '';
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 1;
    background-image:
        radial-gradient(circle at 12% 22%, var(--reef-indigo) 0.4px, transparent 1px),
        radial-gradient(circle at 38% 67%, var(--coral-bloom) 0.5px, transparent 1px),
        radial-gradient(circle at 71% 19%, var(--mango-saffron) 0.5px, transparent 1px),
        radial-gradient(circle at 88% 78%, var(--anemone-pink) 0.4px, transparent 1px),
        radial-gradient(circle at 53% 41%, var(--reef-indigo) 0.3px, transparent 1px),
        radial-gradient(circle at 24% 88%, var(--coral-bloom) 0.4px, transparent 1px),
        radial-gradient(circle at 92% 32%, var(--reef-indigo) 0.3px, transparent 1px);
    background-size: 240px 240px;
    opacity: 0.42;
    mix-blend-mode: multiply;
}

/* ==========================================================
   Typography
   ========================================================== */

h1, h2, h3 {
    font-family: var(--font-display);
    color: var(--reef-indigo);
    font-variation-settings: 'wght' var(--w), 'opsz' var(--o), 'SOFT' var(--s), 'WONK' 1;
    transition: --w 600ms ease, --o 600ms ease, --s 600ms ease;
    letter-spacing: -0.02em;
    line-height: 0.98;
}

em {
    font-style: italic;
    color: var(--anemone-pink);
}

p {
    color: var(--reef-indigo);
}

a {
    color: var(--reef-indigo);
    text-decoration: none;
    position: relative;
    transition: color 280ms ease;
}

a:hover {
    color: var(--coral-bloom);
}

/* Hand-painted underlines on inline links */
.section a:not(.rail-mark):not(.rail-version):not(.surface-mark):not(.hand-action)::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: -3px;
    height: 4px;
    background: var(--anemone-pink);
    filter: url(#watercolor-edge);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 320ms ease;
}

.section a:not(.rail-mark):not(.rail-version):not(.surface-mark):not(.hand-action):hover::after {
    transform: scaleX(1);
}

/* ==========================================================
   Stagger reveal
   ========================================================== */

.stagger-line {
    opacity: 0;
    transform: translateX(-4px) translateY(8px);
    transition:
        opacity 880ms cubic-bezier(0.22, 0.61, 0.36, 1),
        transform 880ms cubic-bezier(0.22, 0.61, 0.36, 1);
    transition-delay: calc(var(--idx, 0) * 80ms);
}

[data-section].is-visible .stagger-line {
    opacity: 1;
    transform: translateX(0) translateY(0);
}

[data-section].is-visible .stagger-line:nth-child(odd) {
    transform: translateX(2px) translateY(0);
}

/* ==========================================================
   Section base
   ========================================================== */

.section {
    position: relative;
    min-height: 80vh;
    padding: clamp(4rem, 12vh, 10rem) clamp(1.4rem, 6vw, 5rem);
    display: grid;
    grid-template-columns: [edge-l] minmax(2rem, 6vw) [col-1] repeat(12, 1fr) [col-13] minmax(2rem, 6vw) [edge-r];
    column-gap: clamp(0.6rem, 1.4vw, 1.4rem);
    align-content: start;
    z-index: 2;
}

.section:nth-of-type(odd) {
    --drift: -2vw;
}

.section:nth-of-type(even) {
    --drift: 2vw;
}

.section-head {
    grid-column: col-1 / col-13;
    margin-bottom: clamp(2rem, 6vh, 5rem);
    padding-top: var(--tide);
}

.kicker {
    font-family: var(--font-mono);
    font-size: 0.78rem;
    font-weight: 300;
    text-transform: lowercase;
    letter-spacing: 0.32em;
    color: var(--coral-bloom);
    margin-bottom: 1rem;
    font-feature-settings: "tnum", "ss01";
}

.section-title {
    font-size: clamp(2.4rem, 5.4vw, 5.4rem);
    --w: 380;
    --o: 96;
    --s: 60;
    max-width: 18ch;
    color: var(--reef-indigo);
}

.section-title em {
    font-style: italic;
    color: var(--anemone-pink);
    font-variation-settings: 'wght' 320, 'opsz' 96, 'SOFT' 90, 'WONK' 1;
}

/* ==========================================================
   Top navigation rail
   ========================================================== */

.rail {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.4rem clamp(1.4rem, 4vw, 3rem);
    background: linear-gradient(to bottom, rgba(251, 243, 228, 0.92), rgba(251, 243, 228, 0));
    backdrop-filter: blur(2px);
    pointer-events: auto;
    transition: transform 480ms ease, opacity 480ms ease;
}

.rail.is-hidden {
    transform: translateY(-100%);
    opacity: 0;
    pointer-events: none;
}

.rail-mark {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    font-family: var(--font-display);
    font-size: 1rem;
    font-variation-settings: 'wght' 420, 'opsz' 24, 'SOFT' 80, 'WONK' 1;
    color: var(--reef-indigo);
    text-transform: lowercase;
    letter-spacing: 0.04em;
}

.rail-mark svg {
    filter: url(#watercolor-edge);
}

.rail-mark-word em {
    color: var(--anemone-pink);
}

.rail-nav {
    display: flex;
    gap: clamp(1.2rem, 3vw, 2.6rem);
    font-family: var(--font-mono);
    font-size: 0.74rem;
    font-weight: 300;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-feature-settings: "tnum", "ss01";
}

.rail-nav a {
    color: var(--reef-indigo);
    transition: color 280ms ease;
}

.rail-nav a:hover {
    color: var(--coral-bloom);
}

.rail-version {
    font-family: var(--font-mono);
    font-size: 0.7rem;
    font-weight: 300;
    color: var(--coral-bloom);
    letter-spacing: 0.14em;
    font-feature-settings: "tnum", "ss01";
}

@media (max-width: 760px) {
    .rail-nav { gap: 1rem; font-size: 0.66rem; letter-spacing: 0.14em; }
    .rail-version { display: none; }
}

/* Surface mark (return to top) */
.surface-mark {
    position: fixed;
    bottom: 1.6rem;
    right: 1.6rem;
    z-index: 99;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.4rem;
    font-family: var(--font-hand);
    font-size: 1.1rem;
    color: var(--coral-bloom);
    opacity: 0;
    pointer-events: none;
    transition: opacity 480ms ease, transform 480ms ease;
    transform: translateY(20px);
}

.surface-mark.is-visible {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.surface-mark-arrow {
    display: block;
    width: 2px;
    height: 32px;
    background: var(--coral-bloom);
    position: relative;
    filter: url(#watercolor-edge);
}

.surface-mark-arrow::before {
    content: '';
    position: absolute;
    top: 0;
    left: -5px;
    width: 12px;
    height: 12px;
    border-top: 2px solid var(--coral-bloom);
    border-left: 2px solid var(--coral-bloom);
    transform: rotate(45deg);
}

/* ==========================================================
   Pigment cursor canvas
   ========================================================== */

#pigmentCursor {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 50;
    mix-blend-mode: multiply;
    opacity: 0.42;
}

@media (hover: none) {
    #pigmentCursor { display: none; }
}

/* ==========================================================
   Section: Lagoon Hero
   ========================================================== */

.section-hero {
    min-height: 100vh;
    padding-top: 8rem;
    transform: translateX(var(--drift));
    overflow: hidden;
}

.hero-tide {
    position: absolute;
    top: 38.2%;
    left: 0;
    width: 70%;
    height: 80px;
    pointer-events: none;
}

#heroTidePath {
    stroke-dasharray: 2400;
    stroke-dashoffset: 2400;
    animation: paintStroke 1.6s 0.4s cubic-bezier(0.22, 0.61, 0.36, 1) forwards;
}

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

.hero-wash {
    position: absolute;
    border-radius: 50%;
    filter: url(#watercolor-strong);
    mix-blend-mode: multiply;
    pointer-events: none;
    opacity: 0;
    animation: bloomIn 2.4s 0.2s ease-out forwards;
}

.hero-wash-1 {
    top: -8vh;
    left: -12vw;
    width: 56vw;
    height: 56vw;
    background: radial-gradient(circle, var(--coral-bloom) 0%, transparent 60%);
    opacity: 0.35;
}

.hero-wash-2 {
    top: 30vh;
    right: -10vw;
    width: 44vw;
    height: 44vw;
    background: radial-gradient(circle, var(--mango-saffron) 0%, transparent 60%);
    animation-delay: 0.6s;
}

.hero-wash-3 {
    bottom: -14vh;
    left: 28vw;
    width: 42vw;
    height: 42vw;
    background: radial-gradient(circle, var(--anemone-pink) 0%, transparent 65%);
    animation-delay: 1.0s;
}

@keyframes bloomIn {
    0% { opacity: 0; transform: scale(0.86); }
    100% { opacity: 0.32; transform: scale(1); }
}

.hero-content {
    position: relative;
    z-index: 5;
    grid-column: col-2 / col-10;
    align-self: end;
    padding-top: 22vh;
}

.hero-title {
    font-family: var(--font-display);
    font-size: clamp(3.6rem, 7.2vw, 8rem);
    --w: 320;
    --o: 144;
    --s: 100;
    line-height: 0.95;
    letter-spacing: -0.025em;
    color: var(--reef-indigo);
    margin-bottom: 1.4rem;
    display: block;
}

.hero-mark, .hero-rest {
    display: inline-block;
}

.hero-mark em {
    font-style: italic;
    color: var(--coral-bloom);
    font-variation-settings: 'wght' 320, 'opsz' 144, 'SOFT' 100, 'WONK' 1;
}

.hero-rest {
    color: var(--reef-indigo);
}

.hero-sub {
    font-family: var(--font-display);
    font-size: clamp(1.4rem, 2.4vw, 2.2rem);
    color: var(--anemone-pink);
    font-variation-settings: 'wght' 360, 'opsz' 36, 'SOFT' 90, 'WONK' 1;
    margin-bottom: 2.4rem;
    letter-spacing: -0.01em;
}

.hero-line {
    font-family: var(--font-body);
    font-size: clamp(1.05rem, 1.4vw, 1.3rem);
    line-height: 1.65;
    color: var(--reef-indigo);
    margin-bottom: 0.8rem;
    max-width: 56ch;
}

.hand-action {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    margin-top: 3rem;
    font-family: var(--font-hand);
    font-size: clamp(1.6rem, 2.4vw, 2.4rem);
    color: var(--coral-bloom);
    transition: transform 360ms ease, color 280ms ease;
}

.hand-action:hover {
    color: var(--anemone-pink);
    transform: translateX(4px);
}

.hand-action-arrow {
    width: 80px;
    height: 30px;
}

.hand-action::after { display: none; }

/* Fish in hero */
.fish {
    position: absolute;
    pointer-events: none;
    z-index: 4;
    filter: url(#watercolor-edge);
}

.fish-tang-host {
    width: clamp(80px, 9vw, 140px);
    height: auto;
    top: 18%;
    left: 0;
    will-change: transform;
}

.fish-butterfly-host {
    width: clamp(64px, 7vw, 110px);
    height: auto;
    top: 60%;
    right: 12%;
    will-change: transform;
}

.fish-dragonet-host {
    width: clamp(100px, 12vw, 180px);
    height: auto;
    top: 24%;
    right: 14%;
    will-change: transform;
    z-index: 3;
}

.granulate-layer {
    position: absolute;
    inset: 0;
    pointer-events: none;
    background-image:
        radial-gradient(circle at 11% 32%, var(--coral-bloom) 0.4px, transparent 1px),
        radial-gradient(circle at 71% 51%, var(--mango-saffron) 0.4px, transparent 1px),
        radial-gradient(circle at 88% 13%, var(--reef-indigo) 0.3px, transparent 1px);
    background-size: 180px 180px;
    opacity: 0.34;
    mix-blend-mode: multiply;
}

/* ==========================================================
   Section: The Tackle Box
   ========================================================== */

.section-tackle {
    transform: translateX(var(--drift));
}

.tackle-grid {
    grid-column: col-1 / col-13;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: clamp(2rem, 4vw, 4rem);
    align-items: start;
    padding-top: 2rem;
}

.pillar {
    display: flex;
    flex-direction: column;
    gap: 1.6rem;
    position: relative;
}

.pillar-1 { transform: translateY(0); }
.pillar-2 { transform: translateY(4rem); }
.pillar-3 { transform: translateY(2rem); }

.koi-roundel {
    position: relative;
    width: clamp(180px, 24vw, 280px);
    aspect-ratio: 1;
}

.koi-svg {
    width: 100%;
    height: 100%;
    transition: transform 600ms cubic-bezier(0.22, 0.61, 0.36, 1);
    will-change: transform;
}

.pillar:hover .koi-svg {
    transform: rotate(8deg);
}

.pillar-num {
    position: absolute;
    top: 8%;
    left: 8%;
    font-family: var(--font-display);
    font-size: clamp(2rem, 3.4vw, 3.4rem);
    font-style: italic;
    font-variation-settings: 'wght' 320, 'opsz' 96, 'SOFT' 100, 'WONK' 1;
    color: var(--cream-paper);
    line-height: 1;
}

.pillar-h {
    font-family: var(--font-display);
    font-size: clamp(1.4rem, 2.2vw, 2.2rem);
    --w: 380;
    --o: 48;
    --s: 50;
    margin-bottom: 0.4rem;
    color: var(--reef-indigo);
}

.pillar-copy p {
    font-family: var(--font-body);
    font-size: 1.05rem;
    line-height: 1.65;
    color: var(--reef-indigo);
    max-width: 36ch;
}

@media (max-width: 880px) {
    .tackle-grid {
        grid-template-columns: 1fr;
        gap: 3rem;
    }
    .pillar-1, .pillar-2, .pillar-3 { transform: translateY(0); }
}

/* ==========================================================
   Section: Ribbon of Performance
   ========================================================== */

.section-ribbon {
    transform: translateX(var(--drift));
    overflow: hidden;
    min-height: 100vh;
}

.ribbon-rail {
    grid-column: col-1 / col-13;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 2rem 0 4rem;
    scroll-behavior: smooth;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.ribbon-rail::-webkit-scrollbar {
    display: none;
}

.ribbon-track {
    display: flex;
    gap: clamp(1.4rem, 3vw, 3rem);
    width: max-content;
    padding-right: 4rem;
}

.ribbon-card {
    flex-shrink: 0;
    width: clamp(220px, 26vw, 320px);
    padding: 2rem 1.8rem;
    background: linear-gradient(135deg, var(--mango-saffron) 0%, var(--coral-bloom) 100%);
    color: var(--cream-paper);
    border-radius: 4px;
    position: relative;
    filter: url(#watercolor-edge);
    transform: rotate(-0.8deg);
}

.ribbon-card:nth-child(even) {
    transform: rotate(0.6deg);
    background: linear-gradient(135deg, var(--coral-bloom) 0%, var(--anemone-pink) 100%);
}

.ribbon-card:nth-child(3n) {
    background: linear-gradient(135deg, var(--reef-indigo) 0%, var(--anemone-pink) 100%);
}

.ribbon-num {
    font-family: var(--font-display);
    font-size: clamp(3rem, 5vw, 5rem);
    font-variation-settings: 'wght' 320, 'opsz' 144, 'SOFT' 60, 'WONK' 1;
    line-height: 1;
    margin-bottom: 1rem;
    font-feature-settings: "tnum";
}

.ribbon-num-unit {
    font-family: var(--font-mono);
    font-size: 0.4em;
    font-weight: 300;
    margin-left: 0.2em;
    letter-spacing: 0.05em;
}

.ribbon-label {
    font-family: var(--font-mono);
    font-size: 0.74rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--cream-paper);
    margin-bottom: 0.8rem;
    opacity: 0.92;
}

.ribbon-note {
    font-family: var(--font-body);
    font-size: 0.95rem;
    line-height: 1.5;
    color: var(--cream-paper);
    opacity: 0.86;
    font-style: italic;
}

.ribbon-progress {
    grid-column: col-2 / col-12;
    height: 4px;
    background: rgba(42, 58, 110, 0.12);
    border-radius: 2px;
    overflow: hidden;
    filter: url(#watercolor-edge);
}

.ribbon-progress-fill {
    height: 100%;
    background: linear-gradient(to right, var(--coral-bloom), var(--mango-saffron));
    width: 0%;
    transition: width 200ms ease-out;
}

/* ==========================================================
   Section: Showcase Pool
   ========================================================== */

.section-showcase {
    transform: translateX(var(--drift));
}

.masonry {
    grid-column: col-1 / col-13;
    column-count: 3;
    column-gap: clamp(1.4rem, 3vw, 3rem);
}

.tile {
    break-inside: avoid;
    margin-bottom: clamp(1.4rem, 3vw, 3rem);
    transform: rotate(var(--tile-rot, 0deg));
    filter: url(#watercolor-edge);
    transition: transform 600ms cubic-bezier(0.22, 0.61, 0.36, 1);
    cursor: crosshair;
}

.tile:hover {
    transform: rotate(0deg) translateY(-4px);
}

.tile-art {
    display: block;
    width: 100%;
    height: auto;
}

.tile figcaption {
    padding: 1rem 0.4rem 0;
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}

.tile-title {
    font-family: var(--font-display);
    font-size: 1.1rem;
    font-variation-settings: 'wght' 380, 'opsz' 24, 'SOFT' 80, 'WONK' 1;
    font-style: italic;
    color: var(--reef-indigo);
}

.tile-meta {
    font-family: var(--font-mono);
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--coral-bloom);
}

.tile-1 { break-after: column; }

@media (max-width: 980px) {
    .masonry { column-count: 2; }
}

@media (max-width: 620px) {
    .masonry { column-count: 1; }
}

/* ==========================================================
   Section: Atelier Quickstart
   ========================================================== */

.section-atelier {
    transform: translateX(var(--drift));
    background: linear-gradient(180deg, rgba(244, 192, 74, 0.04) 0%, rgba(210, 217, 194, 0.18) 100%);
}

.recipe-card {
    grid-column: col-3 / col-11;
    background: var(--cream-paper);
    padding: clamp(2.4rem, 6vw, 5rem);
    transform: rotate(0.7deg);
    filter: url(#watercolor-edge);
    position: relative;
    border: 1px solid rgba(42, 58, 110, 0.08);
}

.recipe-card::before {
    content: '';
    position: absolute;
    inset: -8px;
    background: linear-gradient(135deg, var(--coral-bloom), var(--mango-saffron));
    z-index: -1;
    filter: url(#watercolor-strong);
    opacity: 0.18;
}

.paperweight {
    position: absolute;
    top: -2rem;
    right: -2rem;
    width: clamp(60px, 8vw, 110px);
    height: auto;
    transform: rotate(-12deg);
    filter: url(#watercolor-edge);
}

.recipe-body {
    transform: rotate(-0.7deg);
}

.recipe-line {
    font-family: var(--font-body);
    font-size: 1.1rem;
    line-height: 1.6;
    color: var(--reef-indigo);
    margin: 1.4rem 0 0.6rem;
    display: flex;
    align-items: baseline;
    gap: 0.6rem;
}

.recipe-line:first-child { margin-top: 0; }

.recipe-step {
    font-family: var(--font-display);
    font-size: 1.3rem;
    font-style: italic;
    font-variation-settings: 'wght' 320, 'opsz' 36, 'SOFT' 100, 'WONK' 1;
    color: var(--coral-bloom);
    flex-shrink: 0;
}

.recipe-code {
    background: rgba(210, 217, 194, 0.18);
    padding: 1rem 1.2rem;
    margin: 0.4rem 0 0.8rem 1.4rem;
    border-left: 3px solid var(--mango-saffron);
    font-family: var(--font-mono);
    font-size: 0.92rem;
    line-height: 1.6;
    color: var(--reef-indigo);
    overflow-x: auto;
    font-feature-settings: "tnum", "ss01";
}

.recipe-code code {
    font-family: inherit;
    color: inherit;
}

.recipe-prose {
    font-family: var(--font-body);
    font-size: 1.05rem;
    line-height: 1.7;
    color: var(--reef-indigo);
    margin: 0.6rem 0 1.4rem 1.4rem;
    max-width: 56ch;
    font-style: italic;
}

.recipe-sign {
    font-family: var(--font-hand);
    font-size: 1.6rem;
    color: var(--anemone-pink);
    margin-top: 2rem;
    text-align: right;
}

.recipe-sign em {
    color: var(--coral-bloom);
    font-style: italic;
}

/* ==========================================================
   Section: Tide Footer
   ========================================================== */

.section-footer {
    min-height: 60vh;
    padding-top: 16vh;
    padding-bottom: 4rem;
    position: relative;
    overflow: hidden;
    background: linear-gradient(180deg, transparent 0%, rgba(42, 58, 110, 0.08) 100%);
}

.footer-tide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 50%;
    z-index: 1;
    pointer-events: none;
}

.section-footer .fish-dragonet-host {
    top: 18%;
    right: 10%;
    width: clamp(80px, 12vw, 160px);
    z-index: 3;
}

.footer-content {
    grid-column: col-2 / col-12;
    z-index: 4;
    position: relative;
    text-align: left;
    align-self: end;
    padding-top: 16vh;
}

.footer-mark {
    font-family: var(--font-display);
    font-size: clamp(2.4rem, 5vw, 5rem);
    font-variation-settings: 'wght' 320, 'opsz' 144, 'SOFT' 80, 'WONK' 1;
    color: var(--cream-paper);
    line-height: 1;
    margin-bottom: 1rem;
    text-shadow: 0 2px 0 rgba(42, 58, 110, 0.08);
    letter-spacing: -0.025em;
}

.footer-mark em {
    color: var(--mango-saffron);
    font-style: italic;
}

.footer-line {
    font-family: var(--font-display);
    font-size: clamp(1.2rem, 2vw, 2rem);
    font-style: italic;
    color: var(--anemone-pink);
    font-variation-settings: 'wght' 360, 'opsz' 36, 'SOFT' 90, 'WONK' 1;
    margin-bottom: 0.6rem;
}

.footer-tag {
    font-family: var(--font-body);
    font-size: 1rem;
    color: var(--cream-paper);
    opacity: 0.78;
    font-style: italic;
    margin-bottom: 2rem;
}

.footer-meta {
    font-family: var(--font-mono);
    font-size: 0.74rem;
    color: var(--cream-paper);
    opacity: 0.6;
    text-transform: lowercase;
    letter-spacing: 0.14em;
    font-feature-settings: "tnum", "ss01";
}

/* ==========================================================
   Responsive tuning
   ========================================================== */

@media (max-width: 760px) {
    .hero-content {
        grid-column: col-1 / col-13;
        padding-top: 12vh;
    }
    .section-head { grid-column: col-1 / col-13; }
    .recipe-card { grid-column: col-1 / col-13; }
    .ribbon-card { width: 78vw; }
}

@media (prefers-reduced-motion: reduce) {
    .stagger-line {
        opacity: 1;
        transform: none;
        transition: none;
    }
    #heroTidePath {
        stroke-dashoffset: 0;
        animation: none;
    }
    .hero-wash {
        animation: none;
        opacity: 0.32;
    }
    .fish { animation: none !important; }
}
