/* LLITTL.com — Art Deco × Sci-Fi HUD */

:root {
    --navy-deep: #0B1628;
    --navy-soft: #162A4A;
    --gold: #C9A84C;
    --brass: #E8C95A;
    --steel: #8A9BB0;
    --cream: #F0E6D3;
    --white: #FAFAF7;
    --charcoal: #111A2B;

    --diag: 8deg;
    --diag-skew: -8deg;
    --gutter: 48px;
    --ease: cubic-bezier(0.25, 0.46, 0.45, 0.94);

    --font-display: "Space Grotesk", "Inter", sans-serif;
    --font-body: "DM Sans", "Inter", sans-serif;
    --font-accent: "Josefin Sans", "Inter", sans-serif;
    --font-mono: "IBM Plex Mono", "Space Mono", monospace;
}

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

html, body {
    background: var(--navy-deep);
    color: var(--cream);
    font-family: var(--font-body);
    font-size: 18px;
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}

body {
    background:
        radial-gradient(ellipse at 80% -10%, rgba(201,168,76,0.06), transparent 50%),
        radial-gradient(ellipse at -10% 60%, rgba(22,42,74,0.55), transparent 60%),
        linear-gradient(180deg, var(--navy-deep) 0%, var(--charcoal) 100%);
    background-attachment: fixed;
    min-height: 100vh;
    position: relative;
}

a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }

/* ========== Background hex grid (parallax) ========== */
.hex-grid {
    position: fixed;
    inset: -20vh -10vw;
    z-index: 0;
    pointer-events: none;
    opacity: 0.08;
    background-image:
        repeating-linear-gradient(60deg, var(--navy-soft) 0 1px, transparent 1px 60px),
        repeating-linear-gradient(-60deg, var(--navy-soft) 0 1px, transparent 1px 60px),
        repeating-linear-gradient(0deg, var(--navy-soft) 0 1px, transparent 1px 52px);
    transform: translateY(0);
    will-change: transform;
}

/* ========== Floating particles ========== */
.floating-particles {
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
}
.particle {
    position: absolute;
    left: var(--x);
    top: var(--y);
    width: 8px;
    height: 8px;
    opacity: 0.15;
    animation: drift var(--d, 22s) ease-in-out infinite;
}
.particle--diamond { background: var(--steel); transform: rotate(45deg); }
.particle--circle { background: var(--steel); border-radius: 50%; }
.particle--triangle {
    background: transparent;
    width: 0; height: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-bottom: 10px solid var(--steel);
}
@keyframes drift {
    0%, 100% { transform: translate(0,0) rotate(0); }
    25% { transform: translate(20px,-30px) rotate(45deg); }
    50% { transform: translate(-15px,20px) rotate(90deg); }
    75% { transform: translate(25px,10px) rotate(135deg); }
}
.particle--diamond {
    animation-name: drift-diamond;
}
@keyframes drift-diamond {
    0%, 100% { transform: translate(0,0) rotate(45deg); }
    50% { transform: translate(20px,-25px) rotate(90deg); }
}

/* ========== Scan line ========== */
.scan-line {
    position: fixed;
    left: 0; right: 0;
    top: -10%;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(201,168,76,0.55), transparent);
    box-shadow: 0 0 20px rgba(201,168,76,0.4);
    z-index: 1;
    pointer-events: none;
    animation: scan 12s linear infinite;
}
@keyframes scan {
    0% { transform: translateY(0); }
    100% { transform: translateY(120vh); }
}

/* ========== Top Bar ========== */
.topbar {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 50;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 32px;
    background: linear-gradient(180deg, rgba(11,22,40,0.92) 0%, rgba(11,22,40,0.55) 80%, transparent 100%);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-bottom: 1px solid rgba(201,168,76,0.18);
}
.monogram-mark {
    display: flex;
    align-items: center;
    gap: 12px;
}
.monogram-svg { width: 28px; height: 28px; }
.monogram-svg path { stroke: var(--gold); fill: none; stroke-width: 2; }
.monogram-text {
    font-family: var(--font-accent);
    font-weight: 300;
    letter-spacing: 0.32em;
    color: var(--cream);
    font-size: 15px;
}
.hud-readout {
    display: flex;
    gap: 18px;
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--steel);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    animation: hud-flicker 4s infinite;
}
.hud-readout--top { display: flex; }
.hud-pill {
    border: 1px solid rgba(138,155,176,0.35);
    padding: 4px 10px;
    border-radius: 0;
}
@keyframes hud-flicker {
    0%, 100% { opacity: 1; }
    25% { opacity: 0.7; }
    55% { opacity: 0.85; }
    80% { opacity: 1; }
}
.hamburger {
    width: 38px;
    height: 32px;
    background: transparent;
    border: 1px solid rgba(201,168,76,0.5);
    cursor: pointer;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    padding: 0 8px;
    transition: all 0.3s var(--ease);
}
.hamburger span {
    display: block;
    height: 1.5px;
    background: var(--gold);
    transition: all 0.3s var(--ease);
}
.hamburger:hover {
    border-color: var(--brass);
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(11,22,40,0.4);
}
.hamburger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.is-open span:nth-child(2) { opacity: 0; }
.hamburger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 720px) {
    .hud-readout--top { display: none; }
}

/* ========== Overlay Menu ========== */
.overlay-menu {
    position: fixed;
    inset: 0;
    z-index: 100;
    background: radial-gradient(ellipse at center, rgba(22,42,74,0.98), rgba(11,22,40,0.99));
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.5s var(--ease);
}
.overlay-menu.is-open {
    opacity: 1;
    pointer-events: auto;
}
.overlay-reticle {
    position: absolute;
    width: 520px;
    height: 520px;
    max-width: 80vmin;
    max-height: 80vmin;
}
.reticle-ring {
    position: absolute;
    inset: 0;
    border: 1px solid rgba(201,168,76,0.4);
    border-radius: 50%;
    animation: spin-slow 120s linear infinite;
}
.reticle-ring--outer { inset: 0; border-color: rgba(201,168,76,0.4); }
.reticle-ring--inner { inset: 18%; border-color: rgba(201,168,76,0.25); animation-direction: reverse; animation-duration: 90s; }
.reticle-cross {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(transparent calc(50% - 0.5px), rgba(201,168,76,0.25) calc(50% - 0.5px), rgba(201,168,76,0.25) calc(50% + 0.5px), transparent calc(50% + 0.5px)),
        linear-gradient(90deg, transparent calc(50% - 0.5px), rgba(201,168,76,0.25) calc(50% - 0.5px), rgba(201,168,76,0.25) calc(50% + 0.5px), transparent calc(50% + 0.5px));
}
@keyframes spin-slow {
    from { transform: rotate(0); }
    to { transform: rotate(360deg); }
}
.compass-menu {
    position: relative;
    list-style: none;
    width: 520px; height: 520px;
    max-width: 80vmin; max-height: 80vmin;
}
.compass-item {
    position: absolute;
    transform: translate(-50%, -50%);
}
.compass-item a {
    font-family: var(--font-display);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: 14px;
    color: var(--cream);
    border: 1px solid rgba(201,168,76,0.35);
    padding: 10px 18px;
    background: rgba(11,22,40,0.7);
    transition: all 0.3s var(--ease);
    display: inline-flex;
    align-items: center;
    gap: 10px;
}
.compass-item a::before {
    content: attr(data-label);
    font-family: var(--font-mono);
    color: var(--gold);
    font-size: 11px;
    letter-spacing: 0.2em;
}
.compass-item a:hover {
    border-color: var(--brass);
    color: var(--brass);
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(11,22,40,0.6);
}
.compass-n { left: 50%; top: 6%; }
.compass-ne { left: 87%; top: 18%; }
.compass-e  { left: 96%; top: 50%; }
.compass-se { left: 87%; top: 82%; }
.compass-s  { left: 50%; top: 94%; }
.compass-sw { left: 13%; top: 82%; }
.compass-w  { left: 4%; top: 50%; }
.compass-nw { left: 13%; top: 18%; }

.overlay-close {
    position: absolute;
    bottom: 32px;
    right: 32px;
    background: transparent;
    color: var(--gold);
    border: 1px solid rgba(201,168,76,0.4);
    font-family: var(--font-mono);
    letter-spacing: 0.2em;
    font-size: 12px;
    padding: 10px 16px;
    cursor: pointer;
    transition: all 0.3s var(--ease);
}
.overlay-close:hover {
    background: rgba(201,168,76,0.1);
    color: var(--brass);
}

/* ========== Panels ========== */
main {
    position: relative;
    z-index: 2;
}
.panel {
    position: relative;
    min-height: 100vh;
    padding: 120px 6vw;
    display: flex;
    align-items: center;
    isolation: isolate;
}
.panel__inner {
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: var(--gutter);
    align-items: center;
    position: relative;
}
.panel__inner--centered {
    grid-template-columns: 1fr;
    text-align: center;
    justify-items: center;
}

/* Diagonal panels: skewed background, content unskewed */
.panel--diag {
    margin-top: -120px;
}
.panel--diag::before {
    content: "";
    position: absolute;
    inset: -60px -10vw;
    background: linear-gradient(135deg, var(--navy-deep) 0%, var(--navy-soft) 100%);
    transform: skewY(var(--diag-skew));
    transform-origin: top left;
    z-index: -1;
    border-top: 1px solid rgba(201,168,76,0.35);
    border-bottom: 1px solid rgba(201,168,76,0.18);
    box-shadow: 0 -20px 60px rgba(11,22,40,0.5);
}
.panel--diag.panel--right::before {
    background: linear-gradient(225deg, var(--navy-soft) 0%, var(--charcoal) 100%);
    transform: skewY(calc(-1 * var(--diag-skew)));
}
.panel--diag.panel--center::before {
    background: linear-gradient(180deg, var(--charcoal) 0%, var(--navy-deep) 100%);
    transform: skewY(0);
}

/* Sunburst at section seam */
.panel--diag::after {
    content: "";
    position: absolute;
    top: -20px;
    left: 50%;
    width: 220px;
    height: 110px;
    margin-left: -110px;
    background-image:
        repeating-conic-gradient(from 180deg at 50% 100%,
            rgba(201,168,76,0.5) 0deg 0.5deg,
            transparent 0.5deg 15deg);
    opacity: 0.55;
    pointer-events: none;
    mask: linear-gradient(180deg, #000, transparent);
    -webkit-mask: linear-gradient(180deg, #000, transparent);
}

/* Hero */
.panel--hero {
    min-height: 100vh;
    padding-top: 100px;
    background:
        radial-gradient(ellipse at 50% 30%, rgba(201,168,76,0.08), transparent 60%),
        linear-gradient(180deg, var(--navy-deep), var(--charcoal));
}
.panel--hero::before, .panel--hero::after { display: none; }

.hero-stage {
    position: relative;
    width: 380px;
    height: 380px;
    max-width: 80vmin;
    max-height: 80vmin;
    margin: 0 auto;
}
.hero-reticle, .hero-monogram, .hero-rays {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.hero-reticle .reticle-ring {
    position: absolute;
    inset: 4%;
    border-radius: 50%;
    border: 1px solid rgba(201,168,76,0.45);
    animation: spin-slow 120s linear infinite;
}
.hero-reticle .reticle-ring--outer { inset: 0; }
.hero-reticle .reticle-ring--inner { inset: 16%; border-color: rgba(201,168,76,0.28); animation-duration: 90s; animation-direction: reverse; }
.hero-reticle .reticle-cross {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(transparent calc(50% - 0.5px), rgba(201,168,76,0.2) calc(50% - 0.5px), rgba(201,168,76,0.2) calc(50% + 0.5px), transparent calc(50% + 0.5px)),
        linear-gradient(90deg, transparent calc(50% - 0.5px), rgba(201,168,76,0.2) calc(50% - 0.5px), rgba(201,168,76,0.2) calc(50% + 0.5px), transparent calc(50% + 0.5px));
}
.reticle-tick {
    position: absolute;
    width: 2px; height: 14px;
    background: var(--gold);
}
.reticle-tick--n { top: -2px; left: 50%; transform: translateX(-50%); }
.reticle-tick--s { bottom: -2px; left: 50%; transform: translateX(-50%); }
.reticle-tick--e { right: -2px; top: 50%; width: 14px; height: 2px; transform: translateY(-50%); }
.reticle-tick--w { left: -2px; top: 50%; width: 14px; height: 2px; transform: translateY(-50%); }

.monogram-large {
    width: 60%;
    height: 60%;
    filter: drop-shadow(0 0 18px rgba(201,168,76,0.35));
}
.monogram-pulse {
    position: absolute;
    width: 30%; height: 30%;
    border-radius: 50%;
    border: 1px solid var(--gold);
    animation: pulse 3s ease-out infinite;
}
@keyframes pulse {
    0%   { transform: scale(0.8); opacity: 0.5; box-shadow: 0 0 0 0 rgba(201,168,76,0.4); }
    70%  { transform: scale(1.6); opacity: 0; box-shadow: 0 0 0 40px rgba(201,168,76,0); }
    100% { transform: scale(1.6); opacity: 0; }
}

.hero-tagline {
    font-family: var(--font-display);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.22em;
    color: var(--cream);
    font-size: clamp(20px, 3.2vw, 38px);
    margin-top: 56px;
}
.hero-sub {
    font-family: var(--font-accent);
    font-weight: 300;
    letter-spacing: 0.32em;
    color: var(--gold);
    text-transform: uppercase;
    font-size: 12px;
    margin-top: 14px;
}

.hud-readout--bl, .hud-readout--br {
    position: absolute;
    bottom: 40px;
    flex-direction: column;
    gap: 6px;
    align-items: flex-start;
    font-size: 10.5px;
}
.hud-readout--bl { left: 32px; }
.hud-readout--br { right: 32px; align-items: flex-end; }

/* Panel content */
.panel__numbering {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    gap: 18px;
    font-family: var(--font-mono);
    font-size: 12px;
    color: var(--gold);
    letter-spacing: 0.22em;
    text-transform: uppercase;
    margin-bottom: 18px;
}
.panel__numbering em {
    font-style: normal;
    color: var(--steel);
    font-family: var(--font-accent);
    letter-spacing: 0.4em;
}
.panel__numbering--right { justify-content: flex-end; }
.panel__numbering--center { justify-content: center; }

.panel__title {
    font-family: var(--font-display);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    line-height: 1.05;
    color: var(--white);
    font-size: clamp(34px, 5.5vw, 64px);
    margin-bottom: 28px;
}
.panel__title--center { text-align: center; }
.panel__lede {
    font-size: 20px;
    color: var(--cream);
    margin-bottom: 18px;
    max-width: 56ch;
}
.panel__copy {
    color: var(--steel);
    font-size: 17px;
    line-height: 1.7;
    max-width: 56ch;
    margin-bottom: 28px;
}
.panel__body--right { order: 2; }
.panel__art--left { order: 1; }
.panel__body { padding: 0 8px; }

/* Right-heavy variant: shift body to right side */
.panel--right .panel__inner {
    grid-template-columns: 1fr 1.05fr;
}

.panel__art {
    position: relative;
    padding: 24px;
    border: 1px solid rgba(201,168,76,0.28);
    background:
        linear-gradient(135deg, rgba(22,42,74,0.6), rgba(11,22,40,0.4)),
        repeating-linear-gradient(60deg, rgba(138,155,176,0.05) 0 1px, transparent 1px 22px);
    clip-path: polygon(0 12px, 12px 0, calc(100% - 12px) 0, 100% 12px, 100% calc(100% - 12px), calc(100% - 12px) 100%, 12px 100%, 0 calc(100% - 12px));
    transition: all 0.4s var(--ease);
}
.panel__art:hover {
    transform: translateY(-6px);
    box-shadow: 0 8px 32px rgba(11,22,40,0.55);
    border-color: var(--brass);
}
.art-svg {
    width: 100%;
    height: auto;
    aspect-ratio: 1;
}
.art-caption {
    display: block;
    margin-top: 14px;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.2em;
    color: var(--steel);
}

/* Soft link */
.link-soft {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--font-display);
    text-transform: uppercase;
    font-size: 13px;
    letter-spacing: 0.22em;
    color: var(--cream);
    padding: 10px 0;
    position: relative;
    transition: all 0.3s var(--ease);
}
.link-soft::after {
    content: "";
    position: absolute;
    left: 0; bottom: 0;
    height: 1px; width: 0;
    background: var(--brass);
    transition: width 0.3s var(--ease);
}
.link-soft:hover {
    color: var(--brass);
    transform: translateY(-6px);
}
.link-soft:hover::after { width: 100%; }
.link-soft span { color: var(--gold); }

/* Keystone pull-quote */
.keystone {
    margin: 28px 0;
    padding: 28px 36px;
    background: rgba(17,26,43,0.65);
    border: 1px solid rgba(201,168,76,0.35);
    clip-path: polygon(8% 0, 92% 0, 100% 100%, 0 100%);
    position: relative;
    max-width: 56ch;
}
.keystone p {
    font-family: var(--font-display);
    font-weight: 500;
    color: var(--cream);
    font-size: 19px;
    line-height: 1.45;
    letter-spacing: 0.01em;
}
.keystone-sig {
    display: block;
    margin-top: 12px;
    font-family: var(--font-accent);
    font-weight: 300;
    letter-spacing: 0.32em;
    color: var(--gold);
    font-size: 11px;
    text-transform: uppercase;
}

/* Telemetry grid */
.telemetry-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    margin: 24px 0 32px;
    max-width: 600px;
}
.telemetry-cell {
    border: 1px solid rgba(138,155,176,0.25);
    padding: 14px 16px;
    background: rgba(11,22,40,0.55);
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-family: var(--font-mono);
    transition: all 0.3s var(--ease);
}
.telemetry-cell:hover {
    transform: translateY(-6px);
    border-color: var(--gold);
    box-shadow: 0 8px 22px rgba(11,22,40,0.5);
}
.telemetry-key {
    font-size: 10px;
    letter-spacing: 0.3em;
    color: var(--gold);
    text-transform: uppercase;
}
.telemetry-val {
    font-size: 14px;
    color: var(--cream);
    letter-spacing: 0.06em;
}
.telemetry-val--blink { animation: hud-flicker 4s infinite; color: var(--brass); }

@media (max-width: 720px) {
    .telemetry-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Reveal animations */
.reveal {
    opacity: 0;
    transform: translateY(40px);
    clip-path: polygon(0 0, 100% 0, 100% 0, 0 0);
    transition: opacity 0.9s var(--ease), transform 0.9s var(--ease), clip-path 1.2s var(--ease);
}
.reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}
.reveal > * {
    transition-delay: calc(var(--i, 0) * 120ms);
}

/* ========== Form ========== */
.correspondence {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 22px;
    margin-top: 36px;
    width: 100%;
    max-width: 720px;
    text-align: left;
}
.field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.field--wide { grid-column: 1 / -1; }
.field__key {
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.28em;
    color: var(--gold);
    text-transform: uppercase;
}
.field input, .field textarea {
    background: rgba(11,22,40,0.7);
    border: 1px solid rgba(201,168,76,0.3);
    border-bottom: 1px solid var(--gold);
    color: var(--cream);
    padding: 12px 14px;
    font-family: var(--font-body);
    font-size: 16px;
    outline: none;
    resize: vertical;
    transition: all 0.3s var(--ease);
}
.field input:focus, .field textarea:focus {
    border-color: var(--brass);
    background: rgba(22,42,74,0.7);
    box-shadow: 0 8px 24px rgba(11,22,40,0.5);
}
.send-btn {
    grid-column: 1 / -1;
    position: relative;
    background: transparent;
    border: 1px solid var(--gold);
    color: var(--brass);
    font-family: var(--font-display);
    text-transform: uppercase;
    letter-spacing: 0.32em;
    font-size: 13px;
    padding: 16px 28px;
    cursor: pointer;
    overflow: hidden;
    transition: all 0.3s var(--ease);
    justify-self: flex-start;
}
.send-btn__bar {
    position: absolute;
    left: 0; bottom: 0;
    height: 2px; width: 0;
    background: var(--brass);
    transition: width 0.3s var(--ease);
}
.send-btn:hover {
    transform: translateY(-6px);
    box-shadow: 0 8px 32px rgba(11,22,40,0.5);
    color: var(--white);
    border-color: var(--brass);
}
.send-btn:hover .send-btn__bar { width: 100%; }
.send-status {
    grid-column: 1 / -1;
    font-family: var(--font-mono);
    font-size: 12px;
    letter-spacing: 0.2em;
    color: var(--steel);
    min-height: 18px;
}

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

/* ========== Footer ========== */
.site-footer {
    position: relative;
    z-index: 2;
    background: var(--charcoal);
    border-top: 1px solid rgba(201,168,76,0.3);
    padding: 56px 6vw 24px;
    margin-top: -60px;
}
.footer-row {
    max-width: 1280px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    flex-wrap: wrap;
}
.footer-monogram {
    display: flex;
    align-items: center;
    gap: 12px;
    font-family: var(--font-accent);
    font-weight: 300;
    letter-spacing: 0.32em;
    color: var(--cream);
    font-size: 14px;
}
.footer-monogram svg { width: 36px; height: 36px; }
.footer-copy {
    font-family: var(--font-body);
    color: var(--steel);
    font-size: 13px;
    letter-spacing: 0.06em;
}
.footer-hud {
    display: flex;
    gap: 18px;
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--steel);
    letter-spacing: 0.2em;
    text-transform: uppercase;
    animation: hud-flicker 4s infinite;
}
.footer-strip {
    margin-top: 28px;
    height: 6px;
    background-image: repeating-linear-gradient(90deg,
        var(--gold) 0 12px,
        transparent 12px 18px,
        var(--gold) 18px 24px,
        transparent 24px 36px);
    opacity: 0.55;
}

/* ========== Reduced motion ========== */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
    .reveal { opacity: 1; transform: none; clip-path: none; }
}

/* ========== Smaller screens ========== */
@media (max-width: 920px) {
    .panel__inner, .panel--right .panel__inner { grid-template-columns: 1fr; }
    .panel__art--left { order: 2; }
    .panel__body--right { order: 1; }
    .panel { padding: 100px 6vw; }
    .hero-tagline { font-size: 26px; }
    .hud-readout--bl, .hud-readout--br { display: none; }
    .topbar { padding: 0 18px; }
}
