/* ================================================================
   mosoon.xyz — a retro travel-bureau poster for a rainy city
   Strict two-ink duotone over warm screen-print paper.
   Storm Slate #2B3A42 + Awning Teal #5F8C8C on Paper #EDE6D6.
   No gradients. The constraint is the design.
   ================================================================ */

/* :root — paper-and-two-inks system */
:root {
    --paper:         #EDE6D6;   /* warm oat-paper off-white */
    --ink-slate:     #2B3A42;   /* Storm Slate — primary dark */
    --ink-teal:      #5F8C8C;   /* Awning Teal — secondary */
    --tint-halftone: #8BA3A3;   /* Ink Two ~55% — halftone overlay only */
    --shadow-deep:   #1A242A;   /* Ink One pushed darker — baseline rules */

    --font-display:  'Archivo', sans-serif;
    --font-expanded: 'Archivo', sans-serif; /* width-axis variant; expanded set via stretch */
    --font-body:     'Inter', sans-serif;

    --tracking-display: -0.04em;
    --tracking-expanded: 0.02em;
    --tracking-micro: 0.08em;

    --grid-gutter: 24px;
    --baseline-rule-color: var(--shadow-deep);

    --rule-thin: 1px;
    --rule-hair: 0.5px;

    --ripple-duration: 4s;
}

/* ================================================================
   Reset & base
   ================================================================ */
*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    font-size: 16px;
}

body {
    background: var(--paper);
    color: var(--ink-slate);
    font-family: var(--font-body);
    font-weight: 400;
    line-height: 1.65;
    overflow-x: hidden;
    /* Always show the warm paper as base */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Paper grain — extremely faint procedural noise */
.paper-grain {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 1;
    opacity: 0.04;
    background-image:
        radial-gradient(rgba(43, 58, 66, 0.5) 0.5px, transparent 0.5px),
        radial-gradient(rgba(43, 58, 66, 0.4) 0.5px, transparent 0.5px);
    background-size: 3px 3px, 5px 5px;
    background-position: 0 0, 1px 1px;
    mix-blend-mode: multiply;
}

/* ================================================================
   Dot navigation — six dots, fixed, left edge
   ================================================================ */
.dot-nav {
    position: fixed;
    left: 28px;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    gap: 26px;
    z-index: 100;
}

.dot-nav__dot {
    position: relative;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    border: 1.4px solid var(--ink-slate);
    background: transparent;
    text-decoration: none;
    transition: background-color 0.5s ease, border-color 0.5s ease;
    cursor: pointer;
}

.dot-nav__dot:hover {
    background: var(--ink-teal);
    border-color: var(--ink-teal);
}

.dot-nav__dot.is-active {
    background: var(--ink-teal);
    border-color: var(--ink-teal);
}

.dot-nav__tooltip {
    position: absolute;
    left: 22px;
    top: 50%;
    transform: translateY(-50%);
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 0.7rem;
    letter-spacing: var(--tracking-micro);
    text-transform: uppercase;
    color: var(--ink-slate);
    background: var(--paper);
    padding: 4px 8px;
    border: 1px solid var(--ink-slate);
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.25s ease;
}

.dot-nav__dot:hover .dot-nav__tooltip {
    opacity: 1;
}

/* On dark/inverted panels, invert dot-nav too */
.dot-nav.is-on-dark .dot-nav__dot {
    border-color: var(--paper);
}
.dot-nav.is-on-dark .dot-nav__dot:hover,
.dot-nav.is-on-dark .dot-nav__dot.is-active {
    background: var(--ink-teal);
    border-color: var(--ink-teal);
}
.dot-nav.is-on-dark .dot-nav__tooltip {
    color: var(--paper);
    background: var(--ink-slate);
    border-color: var(--paper);
}

/* ================================================================
   Poster — main scroll container
   ================================================================ */
.poster {
    position: relative;
    width: 100%;
    z-index: 2;
}

/* ================================================================
   Panels — 100vh full-viewport, broken 12-col grid
   ================================================================ */
.panel {
    position: relative;
    width: 100%;
    min-height: 100vh;
    padding: 6vh 7vw 6vh 7vw;
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-template-rows: auto 1fr auto;
    column-gap: var(--grid-gutter);
    row-gap: 24px;
    overflow: hidden;
}

/* Inverted panel — paper and slate swap */
.panel--inverted {
    background: var(--ink-slate);
    color: var(--paper);
    --baseline-rule-color: var(--paper);
}

/* ================================================================
   Typography — headers, wordmark, labels
   ================================================================ */
.section-header {
    grid-column: 1 / span 12;
    display: flex;
    align-items: baseline;
    gap: 14px;
    font-family: var(--font-expanded);
    font-weight: 600;
    font-stretch: 125%;
    text-transform: uppercase;
    letter-spacing: var(--tracking-expanded);
    font-size: 0.78rem;
}

.section-header__num {
    color: var(--ink-teal);
    font-weight: 700;
}

.section-header__label {
    color: inherit;
}

.section-header--inverted .section-header__num {
    color: var(--ink-teal);
}

/* Micro labels — Archivo 0.75rem, +0.08em tracking, uppercase */
.micro-label {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 0.72rem;
    letter-spacing: var(--tracking-micro);
    text-transform: uppercase;
    color: inherit;
    display: inline-block;
    line-height: 1.4;
}

/* Wordmark — clamp(4.5rem, 16vw, 13rem), 800, lh 0.85, lowercase */
.wordmark {
    font-family: var(--font-display);
    font-weight: 800;
    font-size: clamp(4.5rem, 16vw, 13rem);
    letter-spacing: var(--tracking-display);
    line-height: 0.85;
    text-transform: lowercase;
    color: var(--ink-slate);
    margin: 0;
}

/* Body p — Inter 1.0625rem, lh 1.65 */
p {
    font-family: var(--font-body);
    font-size: 1.0625rem;
    line-height: 1.65;
    color: inherit;
}

/* Panel index numerals — Roman + small label */
.panel-index {
    grid-column: 1 / span 2;
    grid-row: 3;
    align-self: end;
    display: flex;
    align-items: baseline;
    gap: 12px;
    z-index: 5;
}

.panel-index__roman {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 1.4rem;
    letter-spacing: 0;
    color: var(--ink-teal);
}

.panel-index__label {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 0.72rem;
    letter-spacing: var(--tracking-micro);
    text-transform: uppercase;
    color: inherit;
}

.panel-index--right {
    grid-column: 11 / span 2;
    justify-self: end;
    text-align: right;
}

.panel-index--inverted .panel-index__label {
    color: var(--paper);
}

/* ================================================================
   Baseline rules — thin horizontal hairlines at panel base
   ================================================================ */
.baseline-rule {
    grid-column: 1 / span 12;
    grid-row: 3;
    align-self: end;
    height: 1px;
    background: var(--shadow-deep);
    margin-top: 36px;
    z-index: 1;
}

.baseline-rule--awning {
    grid-column: 1 / span 7;
}

.baseline-rule--broken {
    grid-column: 1 / span 12;
    background: transparent;
    background-image: linear-gradient(
        to right,
        var(--shadow-deep) 0,
        var(--shadow-deep) 38%,
        transparent 38%,
        transparent 46%,
        var(--shadow-deep) 46%,
        var(--shadow-deep) 100%
    );
}

.baseline-rule--inverted {
    background: var(--paper);
}

.baseline-rule--final {
    grid-column: 4 / span 6;
    background: var(--shadow-deep);
}

/* ================================================================
   Ripple — the signature animation
   Concentric circle outlines expanding from a point.
   Slow, soft, hypnotic. ~4s per ring.
   ================================================================ */
.ripple {
    position: absolute;
    pointer-events: none;
    z-index: 3;
}

.ripple__svg {
    width: 100%;
    height: 100%;
    overflow: visible;
}

@keyframes ripple-expand {
    0% {
        r: 0;
        stroke-opacity: 0.6;
    }
    50% {
        stroke-opacity: 0.4;
    }
    100% {
        r: var(--ripple-r-end, 180);
        stroke-opacity: 0;
    }
}

/* Fallback for browsers that do not animate r — animate via stroke-width and transform-scale alternative */
@keyframes ripple-fallback {
    0% {
        transform: scale(0.0);
        opacity: 0.6;
    }
    50% {
        opacity: 0.4;
    }
    100% {
        transform: scale(1);
        opacity: 0;
    }
}

.ripple__ring {
    animation: ripple-expand var(--ripple-duration) ease-out infinite;
    transform-box: fill-box;
    transform-origin: center;
}

.ripple__ring--1 { animation-delay: 0s;   }
.ripple__ring--2 { animation-delay: 0.8s; }
.ripple__ring--3 { animation-delay: 1.6s; }
.ripple__ring--4 { animation-delay: 2.4s; }
.ripple__ring--5 { animation-delay: 3.2s; }
.ripple__ring--6 { animation-delay: 4.0s; }

/* Specific ripple max radii per source (set via inline custom property fallback) */
.ripple--awning      { --ripple-r-end: 180; }
.ripple--forecast    { --ripple-r-end: 120; }
.ripple--underpass   { --ripple-r-end: 240; }
.ripple--underpass-2 { --ripple-r-end: 160; }
.ripple--crossing    { --ripple-r-end: 110; }
.ripple--soon        { --ripple-r-end: 180; }
.ripple--pane        { --ripple-r-end: 80;  }

/* ================================================================
   Moon disc — slow drift in panels where it appears
   ================================================================ */
.moon {
    position: absolute;
    pointer-events: none;
    z-index: 2;
}

.moon__svg {
    width: 100%;
    height: 100%;
    display: block;
}

.moon__halftone {
    /* Halftone fills the right edge / "terminator" via clip */
    clip-path: inset(0 0 0 60%);
    opacity: 0.85;
}

@keyframes moon-drift {
    0%   { transform: translate(0, 0); }
    100% { transform: translate(28px, 14px); }
}

/* ================================================================
   PANEL I — THE AWNING
   ================================================================ */
.panel--awning {
    background: var(--paper);
    grid-template-rows: auto auto 1fr auto;
}

.awning__meta {
    grid-column: 1 / span 4;
    grid-row: 1;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.awning__meta-bureau {
    color: var(--ink-teal);
}

.awning__stamp {
    grid-column: 11 / span 2;
    grid-row: 1;
    justify-self: end;
    transform: rotate(4deg);
    border: 1px solid var(--ink-teal);
    padding: 6px 10px;
    color: var(--ink-teal);
}

/* Wordmark sits low-left, baseline ~70vh */
.wordmark--awning {
    grid-column: 1 / span 7;
    grid-row: 3;
    align-self: end;
    margin-bottom: 22vh; /* push baseline up to ~70vh region */
}

/* Subtitle slip — block on the right */
.awning__sub {
    grid-column: 10 / span 3;
    grid-row: 3;
    align-self: end;
    margin-bottom: 22vh;
    font-family: var(--font-body);
    font-size: 1.0625rem;
    line-height: 1.45;
    display: flex;
    flex-direction: column;
}

.awning__sub-line {
    display: block;
}

.awning__sub-line:first-child {
    color: var(--ink-slate);
}

.awning__sub-line:last-child {
    color: var(--ink-teal);
    font-style: italic;
    font-size: 0.92rem;
}

/* Moon, upper-right gutter, half-bleed off edge */
.moon--awning {
    width: 38vmin;
    height: 38vmin;
    top: -8vmin;
    right: -6vmin;
    animation: moon-drift 32s ease-in-out infinite alternate;
}

/* Ripple, lower third */
.ripple--awning {
    width: 360px;
    height: 360px;
    left: 30%;
    top: 60%;
}

/* ================================================================
   PANEL II — THE FORECAST
   ================================================================ */
.panel--forecast {
    background: var(--paper);
    grid-template-rows: auto 1fr auto;
    padding-bottom: 0; /* skyline reaches the floor */
}

.forecast__blocks {
    grid-column: 1 / span 12;
    grid-row: 2;
    display: grid;
    grid-template-columns: 4fr 5fr 3fr;
    column-gap: var(--grid-gutter);
    align-items: start;
    margin-top: 24px;
    margin-bottom: 38vh; /* leave bottom 40% for skyline */
}

.forecast__block {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.forecast__block--a { padding-top: 0;    }
.forecast__block--b { padding-top: 24px; }
.forecast__block--c { padding-top: 48px; }

.forecast__block .micro-label {
    color: var(--ink-teal);
    margin-bottom: 4px;
}

.forecast__block p {
    max-width: 30ch;
    font-size: 1.0rem;
    line-height: 1.6;
}

/* Skyline silhouette band — full bleed lower 40% */
.skyline {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 40%;
    z-index: 1;
}

.skyline__svg {
    width: 100%;
    height: 100%;
    display: block;
}

/* Ripple above skyline */
.ripple--forecast {
    width: 220px;
    height: 220px;
    right: 14%;
    top: 36%;
}

/* ================================================================
   PANEL III — THE UNDERPASS (inverted)
   ================================================================ */
.panel--underpass {
    background: var(--ink-slate);
    color: var(--paper);
    grid-template-rows: auto 1fr auto;
}

.panel--underpass .section-header {
    color: var(--paper);
}

/* Big ripple, left two-thirds */
.ripple--underpass {
    width: min(70vmin, 560px);
    height: min(70vmin, 560px);
    left: 8%;
    top: 50%;
    transform: translateY(-50%);
}

/* Secondary ripple, upper-left */
.ripple--underpass-2 {
    width: 280px;
    height: 280px;
    left: 22%;
    top: 14%;
}

/* Narrow newsprint column, right */
.underpass__column {
    grid-column: 9 / span 4;
    grid-row: 2;
    display: flex;
    flex-direction: column;
    gap: 14px;
    max-width: 34ch;
    align-self: center;
    color: var(--paper);
    z-index: 4;
}

.underpass__heading {
    font-family: var(--font-expanded);
    font-stretch: 125%;
    font-weight: 600;
    font-size: 1.05rem;
    letter-spacing: var(--tracking-expanded);
    text-transform: uppercase;
    color: var(--paper);
    margin-bottom: 8px;
    line-height: 1.25;
}

.underpass__column p {
    font-size: 1.0rem;
    line-height: 1.7;
    color: var(--paper);
}

.underpass__byline {
    color: var(--ink-teal);
    margin-top: 8px;
}

/* ================================================================
   PANEL IV — THE CROSSING
   ================================================================ */
.panel--crossing {
    background: var(--paper);
    grid-template-rows: auto 1fr 1fr auto;
    overflow: hidden;
}

/* The slanted ink wedge: -8° (negative slope, upper-left to lower-right) */
.crossing__wedge {
    position: absolute;
    left: -10%;
    right: -10%;
    top: 50%;
    height: 60%;
    background: var(--ink-slate);
    transform: rotate(-8deg) translateY(20%);
    transform-origin: center left;
    z-index: 1;
}

/* The teal hairline tracing the slope */
.crossing__accent {
    position: absolute;
    left: -10%;
    right: -10%;
    top: 50%;
    height: 2px;
    background: var(--ink-teal);
    transform: rotate(-8deg) translateY(0%);
    transform-origin: center left;
    z-index: 4;
}

.crossing__upper {
    grid-column: 2 / span 6;
    grid-row: 2;
    align-self: start;
    z-index: 3;
    display: flex;
    flex-direction: column;
    gap: 14px;
    max-width: 44ch;
}

.crossing__heading {
    font-family: var(--font-expanded);
    font-weight: 600;
    font-stretch: 125%;
    font-size: 1.4rem;
    letter-spacing: var(--tracking-expanded);
    text-transform: uppercase;
    color: var(--ink-slate);
    line-height: 1.2;
}

.crossing__upper p {
    color: var(--ink-slate);
    max-width: 38ch;
}

.crossing__lower {
    grid-column: 7 / span 5;
    grid-row: 3;
    align-self: end;
    z-index: 3;
    margin-bottom: 6vh;
    transform: rotate(-8deg);
}

.crossing__lower-text {
    color: var(--paper);
    font-size: 1rem;
    max-width: 30ch;
}

/* Transit signs — flat awning teal rounded rectangles */
.transit-sign {
    position: absolute;
    background: var(--ink-teal);
    border-radius: 6px;
    padding: 8px 14px;
    z-index: 5;
}

.transit-sign__label {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 0.78rem;
    letter-spacing: var(--tracking-micro);
    text-transform: uppercase;
    color: var(--paper);
    line-height: 1;
    white-space: nowrap;
}

.transit-sign--1 { top: 18%;  left: 64%; }
.transit-sign--2 { top: 28%;  left: 78%; transform: rotate(-2deg); }
.transit-sign--3 { top: 76%;  left: 18%; }
.transit-sign--4 { top: 84%;  left: 56%; transform: rotate(-8deg); }

/* Crossing ripple along the slope */
.ripple--crossing {
    width: 220px;
    height: 220px;
    right: 10%;
    top: 56%;
    transform: rotate(-8deg);
}

/* ================================================================
   PANEL V — THE WINDOW
   Mondrian-adjacent broken grid; no two cells share an edge length
   ================================================================ */
.panel--window {
    background: var(--paper);
    grid-template-rows: auto 1fr auto;
}

.window-grid {
    grid-column: 1 / span 12;
    grid-row: 2;
    display: grid;
    grid-template-columns: 2fr 3fr 2fr 4fr 1.5fr;
    grid-template-rows: 1.3fr 0.8fr 1.6fr 1.1fr;
    gap: 0;
    margin-top: 24px;
    min-height: 70vh;
    border: 1px solid var(--ink-slate);
}

.pane {
    position: relative;
    padding: 18px 16px;
    border-right: 1px solid var(--ink-slate);
    border-bottom: 1px solid var(--ink-slate);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    gap: 8px;
    overflow: hidden;
}

/* Mondrian-adjacent placement: each pane spans different sizes */
.pane--a { grid-column: 1 / span 2; grid-row: 1 / span 2; }
.pane--b { grid-column: 3 / span 1; grid-row: 1 / span 1; }
.pane--c { grid-column: 4 / span 2; grid-row: 1 / span 3; }
.pane--d { grid-column: 3 / span 1; grid-row: 2 / span 2; }
.pane--e { grid-column: 1 / span 1; grid-row: 3 / span 1; }
.pane--f { grid-column: 2 / span 1; grid-row: 3 / span 2; }
.pane--g { grid-column: 1 / span 1; grid-row: 4 / span 1; }
.pane--h { grid-column: 3 / span 3; grid-row: 4 / span 1; }

.pane__line {
    font-family: var(--font-expanded);
    font-stretch: 125%;
    font-weight: 600;
    font-size: 1.0rem;
    letter-spacing: var(--tracking-expanded);
    text-transform: uppercase;
    color: var(--ink-slate);
    line-height: 1.2;
}

.pane .micro-label {
    color: var(--ink-teal);
}

.pane--empty {
    background: transparent;
}

/* Moon inside pane--c with slow drift */
.moon--window {
    position: absolute;
    width: 60%;
    height: auto;
    aspect-ratio: 1;
    top: 18%;
    left: 18%;
    animation: moon-drift 28s ease-in-out infinite alternate;
}

/* Tiny ripple inside an empty pane */
.ripple--pane {
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
}

/* ================================================================
   PANEL VI — SOON
   Near-empty, signature line
   ================================================================ */
.panel--soon {
    background: var(--paper);
    grid-template-rows: 1fr auto auto;
    align-items: center;
}

.soon-word {
    grid-column: 4 / span 6;
    grid-row: 2;
    text-align: center;
    font-family: var(--font-display);
    font-weight: 800;
    font-size: clamp(4rem, 14vw, 12rem);
    letter-spacing: var(--tracking-display);
    line-height: 0.9;
    color: var(--ink-slate);
    text-transform: lowercase;
    margin-top: 20vh;
    margin-bottom: 6vh;
}

.ripple--soon {
    width: 380px;
    height: 380px;
    left: 16%;
    top: 56%;
}

.soon__imprint {
    grid-column: 1 / span 12;
    grid-row: 3;
    align-self: end;
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    color: var(--ink-teal);
    margin-bottom: 24px;
    margin-top: 32px;
}

.panel-index--soon {
    grid-column: 11 / span 2;
    grid-row: 3;
    justify-self: end;
    align-self: end;
    margin-bottom: 24px;
}

/* ================================================================
   Panel-entrance stagger — fade up on intersection
   ================================================================ */
.fade-up {
    opacity: 0;
    transform: translateY(24px);
    transition:
        opacity 0.9s ease-out,
        transform 0.9s ease-out;
}

.fade-up.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* Stagger via custom property set in JS */
.fade-up.is-visible {
    transition-delay: var(--fade-delay, 0ms);
}

/* ================================================================
   Reduced motion — honor the user
   ================================================================ */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.001ms !important;
    }

    /* Show only one static ring per ripple source */
    .ripple__ring {
        animation: none;
        r: 60;
        stroke-opacity: 0.35;
    }

    .ripple__ring--2,
    .ripple__ring--3,
    .ripple__ring--4,
    .ripple__ring--5,
    .ripple__ring--6 {
        display: none;
    }

    .moon--awning,
    .moon--window {
        animation: none;
    }

    .fade-up {
        opacity: 1;
        transform: none;
    }
}

/* ================================================================
   Responsive — narrow viewports
   ================================================================ */
@media (max-width: 880px) {
    .panel {
        padding: 5vh 5vw 5vh 9vw;
        column-gap: 12px;
    }

    .dot-nav {
        left: 14px;
        gap: 18px;
    }

    .awning__meta {
        grid-column: 1 / span 8;
    }

    .awning__stamp {
        grid-column: 9 / span 4;
    }

    .wordmark--awning {
        grid-column: 1 / span 12;
        margin-bottom: 18vh;
    }

    .awning__sub {
        grid-column: 1 / span 12;
        margin-bottom: 4vh;
    }

    .moon--awning {
        width: 56vmin;
        height: 56vmin;
        top: -10vmin;
        right: -12vmin;
    }

    .forecast__blocks {
        grid-template-columns: 1fr;
        row-gap: 18px;
        margin-bottom: 44vh;
    }

    .forecast__block--a,
    .forecast__block--b,
    .forecast__block--c {
        padding-top: 0;
    }

    .underpass__column {
        grid-column: 1 / span 12;
        max-width: 100%;
    }

    .ripple--underpass {
        opacity: 0.45;
        left: -10%;
    }

    .crossing__upper {
        grid-column: 1 / span 12;
    }

    .crossing__lower {
        grid-column: 1 / span 12;
        margin-bottom: 12vh;
    }

    .transit-sign--1 { top: 14%; left: 50%; }
    .transit-sign--2 { top: 22%; left: 12%; }
    .transit-sign--3 { top: 70%; left: 50%; }
    .transit-sign--4 { top: 80%; left: 14%; }

    .window-grid {
        grid-template-columns: 1fr 1fr 1fr;
        grid-template-rows: repeat(6, 1fr);
        min-height: 80vh;
    }

    .pane--a { grid-column: 1 / span 2; grid-row: 1 / span 2; }
    .pane--b { grid-column: 3 / span 1; grid-row: 1 / span 1; }
    .pane--c { grid-column: 1 / span 3; grid-row: 3 / span 2; }
    .pane--d { grid-column: 3 / span 1; grid-row: 2 / span 1; }
    .pane--e { grid-column: 1 / span 1; grid-row: 5 / span 1; }
    .pane--f { grid-column: 2 / span 1; grid-row: 5 / span 1; }
    .pane--g { grid-column: 3 / span 1; grid-row: 5 / span 1; }
    .pane--h { grid-column: 1 / span 3; grid-row: 6 / span 1; }

    .soon-word {
        grid-column: 1 / span 12;
    }
}

/* ================================================================
   Tablet sweet spot
   ================================================================ */
@media (max-width: 1280px) and (min-width: 881px) {
    .ripple--underpass {
        left: 4%;
    }
}
