/* recycle.digital // styles.css
   palette: #080C14 #0F1923 #00FF88 #FF3366 #FFD700 #B8C4D0 #5C8A9E #2DD4A8
   fonts: Share Tech Mono / Source Sans 3 / Fira Code
*/

:root {
    --void: #080C14;
    --slate: #0F1923;
    --phosphor: #00FF88;
    --magenta: #FF3366;
    --amber: #FFD700;
    --terminal-gray: #B8C4D0;
    --faded-cyan: #5C8A9E;
    --teal: #2DD4A8;
    --panel-bg: rgba(8, 12, 20, 0.85);
    --panel-border: rgba(0, 255, 136, 0.30);
    --panel-border-hot: rgba(0, 255, 136, 0.85);

    --f-mono: 'Share Tech Mono', 'Fira Code', 'Courier New', monospace;
    --f-body: 'Source Sans 3', 'Inter', system-ui, sans-serif;
    --f-code: 'Fira Code', 'Share Tech Mono', monospace;
}

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

html {
    scroll-behavior: smooth;
    background: var(--void);
}

body {
    font-family: var(--f-body);
    color: var(--terminal-gray);
    background: var(--void);
    background-image:
        radial-gradient(ellipse at 50% 0%, rgba(0, 255, 136, 0.06) 0%, transparent 60%),
        radial-gradient(ellipse at 50% 100%, rgba(255, 51, 102, 0.04) 0%, transparent 70%);
    line-height: 1.75;
    overflow-x: hidden;
    min-height: 100vh;
    position: relative;
}

/* ------- HEX RAIN CANVAS ------- */
#hex-rain {
    position: fixed;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    pointer-events: none;
    opacity: 0.85;
}

/* ------- SCANLINES OVERLAY ------- */
.scanlines {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 60;
    background:
        repeating-linear-gradient(
            to bottom,
            rgba(0, 0, 0, 0) 0px,
            rgba(0, 0, 0, 0) 2px,
            rgba(0, 255, 136, 0.025) 3px,
            rgba(0, 0, 0, 0) 4px
        );
    mix-blend-mode: screen;
}

.scanlines::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at center, transparent 50%, rgba(0, 0, 0, 0.55) 100%);
    pointer-events: none;
}

/* ------- TIMELINE SVG ------- */
.timeline-svg {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    z-index: 2;
    pointer-events: none;
}

/* ------- DEPTH READOUT ------- */
.depth-readout {
    position: fixed;
    top: 24px;
    right: 24px;
    z-index: 50;
    background: rgba(8, 12, 20, 0.80);
    border: 1px solid var(--panel-border);
    padding: 10px 14px;
    font-family: var(--f-code);
    font-size: 11px;
    line-height: 1.6;
    color: var(--phosphor);
    min-width: 220px;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    box-shadow:
        0 0 0 1px rgba(0, 255, 136, 0.10) inset,
        0 0 18px rgba(0, 255, 136, 0.10);
}

.depth-readout::before {
    content: "// ARCHIVE.MONITOR";
    display: block;
    color: var(--faded-cyan);
    font-size: 9px;
    letter-spacing: 0.18em;
    margin-bottom: 6px;
    border-bottom: 1px dashed rgba(92, 138, 158, 0.4);
    padding-bottom: 4px;
}

.readout-row {
    display: flex;
    justify-content: space-between;
    gap: 12px;
}

.readout-row .rk {
    color: var(--faded-cyan);
    letter-spacing: 0.12em;
}

.readout-row .rv {
    color: var(--phosphor);
    text-shadow: 0 0 6px rgba(0, 255, 136, 0.5);
    transition: background-color 120ms ease;
    padding: 0 2px;
}

.readout-row .rv.flash {
    background-color: rgba(0, 255, 136, 0.30);
    color: var(--void);
}

.readout-row .rv.ok {
    color: var(--teal);
}

/* ------- MASTHEAD ------- */
.masthead {
    position: relative;
    z-index: 3;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 80px 40px 40px;
}

.masthead-inner {
    max-width: 720px;
    text-align: center;
    position: relative;
}

.brand-mark {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--f-code);
    font-size: 13px;
    color: var(--phosphor);
    letter-spacing: 0.16em;
    margin-bottom: 12px;
    border: 1px solid var(--panel-border);
    padding: 6px 14px;
    background: rgba(15, 25, 35, 0.5);
}

.brand-glyph {
    color: var(--amber);
    text-shadow: 0 0 6px rgba(255, 215, 0, 0.6);
    animation: pulse 2.4s ease-in-out infinite;
}

@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.45; }
}

.brand-line {
    font-family: var(--f-code);
    font-size: 11px;
    color: var(--faded-cyan);
    letter-spacing: 0.20em;
    margin-bottom: 32px;
}

.masthead-title {
    font-family: var(--f-mono);
    font-size: clamp(40px, 7vw, 92px);
    line-height: 1.05;
    letter-spacing: 0.12em;
    color: var(--phosphor);
    text-transform: uppercase;
    text-shadow:
        0 0 14px rgba(0, 255, 136, 0.55),
        0 0 32px rgba(0, 255, 136, 0.20);
    position: relative;
    margin-bottom: 28px;
}

.masthead-title::before,
.masthead-title::after {
    content: attr(data-text);
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.55;
    mix-blend-mode: screen;
}

.masthead-title::before {
    color: var(--magenta);
    transform: translate(-2px, 0);
    clip-path: polygon(0 0, 100% 0, 100% 30%, 0 30%);
    animation: glitch-a 4.2s steps(1) infinite;
}

.masthead-title::after {
    color: var(--amber);
    transform: translate(2px, 0);
    clip-path: polygon(0 65%, 100% 65%, 100% 100%, 0 100%);
    animation: glitch-b 5.1s steps(1) infinite;
}

@keyframes glitch-a {
    0%, 92%, 100% { transform: translate(0, 0); opacity: 0; }
    93% { transform: translate(-3px, 0); opacity: 0.6; }
    96% { transform: translate(2px, -1px); opacity: 0.5; }
}

@keyframes glitch-b {
    0%, 88%, 100% { transform: translate(0, 0); opacity: 0; }
    89% { transform: translate(2px, 1px); opacity: 0.6; }
    93% { transform: translate(-1px, 0); opacity: 0.4; }
}

.masthead-sub {
    font-size: 17px;
    color: var(--terminal-gray);
    max-width: 580px;
    margin: 0 auto 36px;
    font-weight: 400;
}

.masthead-meta {
    display: flex;
    justify-content: center;
    gap: 24px;
    flex-wrap: wrap;
    font-family: var(--f-code);
    font-size: 11px;
    color: var(--faded-cyan);
    letter-spacing: 0.14em;
    margin-bottom: 64px;
    padding: 10px 0;
    border-top: 1px solid rgba(92, 138, 158, 0.18);
    border-bottom: 1px solid rgba(92, 138, 158, 0.18);
}

.mm {
    position: relative;
}

.mm::before {
    content: "&#x2022;";
    color: var(--phosphor);
    margin-right: 8px;
}

.scroll-hint {
    font-family: var(--f-code);
    font-size: 11px;
    letter-spacing: 0.20em;
    color: var(--phosphor);
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    opacity: 0.85;
}

.scroll-hint .arrow {
    font-size: 18px;
    animation: descend 1.8s ease-in-out infinite;
}

@keyframes descend {
    0%, 100% { transform: translateY(0); opacity: 0.6; }
    50% { transform: translateY(8px); opacity: 1; }
}

/* ------- STRATA / TIMELINE LAYOUT ------- */
#strata {
    position: relative;
    z-index: 4;
    padding: 0 0 120px;
}

.stratum {
    position: relative;
    padding: 60px 4vw;
    display: flex;
    align-items: stretch;
    min-height: 70vh;
}

.stratum.left {
    justify-content: flex-start;
    padding-right: 52%;
}

.stratum.right {
    justify-content: flex-end;
    padding-left: 52%;
}

/* connector lines from spine to panel */
.connector {
    position: absolute;
    top: 90px;
    width: 4vw;
    height: 1px;
    background: linear-gradient(
        to right,
        rgba(0, 255, 136, 0.0) 0%,
        rgba(0, 255, 136, 0.55) 100%
    );
    pointer-events: none;
}

.stratum.left .connector {
    right: 50%;
    background: linear-gradient(
        to left,
        rgba(0, 255, 136, 0.0) 0%,
        rgba(0, 255, 136, 0.55) 100%
    );
}

.stratum.right .connector {
    left: 50%;
    background: linear-gradient(
        to right,
        rgba(0, 255, 136, 0.0) 0%,
        rgba(0, 255, 136, 0.55) 100%
    );
}

.connector::after {
    content: "";
    position: absolute;
    top: 50%;
    width: 7px;
    height: 7px;
    border: 1px solid var(--phosphor);
    background: var(--void);
    transform: translateY(-50%) rotate(45deg);
}

.stratum.left .connector::after {
    right: -3.5px;
}

.stratum.right .connector::after {
    left: -3.5px;
}

/* ------- PANEL ------- */
.panel {
    position: relative;
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    padding: 28px 32px 0;
    width: 100%;
    max-width: 560px;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 800ms ease-out, transform 800ms ease-out, border-color 600ms ease;
}

.panel.wide {
    max-width: 620px;
}

.panel.in-view {
    opacity: 1;
    transform: translateY(0);
    border-color: var(--panel-border-hot);
    box-shadow:
        0 0 0 1px rgba(0, 255, 136, 0.06) inset,
        0 0 28px rgba(0, 255, 136, 0.10);
}

.panel.active {
    border-color: var(--phosphor);
    animation: panel-pulse 3s ease-in-out infinite;
}

@keyframes panel-pulse {
    0%, 100% { box-shadow: 0 0 0 1px rgba(0, 255, 136, 0.10) inset, 0 0 24px rgba(0, 255, 136, 0.10); }
    50% { box-shadow: 0 0 0 1px rgba(0, 255, 136, 0.20) inset, 0 0 36px rgba(0, 255, 136, 0.22); }
}

/* corner brackets */
.bracket {
    position: absolute;
    width: 22px;
    height: 22px;
    pointer-events: none;
    transition: transform 600ms ease-out, opacity 600ms ease;
    opacity: 0;
}

.bracket::before,
.bracket::after {
    content: "";
    position: absolute;
    background: var(--phosphor);
    box-shadow: 0 0 6px rgba(0, 255, 136, 0.55);
}

.bracket::before {
    width: 22px;
    height: 1.5px;
}

.bracket::after {
    width: 1.5px;
    height: 22px;
}

.bracket-tl { top: -1px; left: -1px; transform: translate(-10px, -10px); }
.bracket-tl::before { top: 0; left: 0; }
.bracket-tl::after { top: 0; left: 0; }

.bracket-tr { top: -1px; right: -1px; transform: translate(10px, -10px); }
.bracket-tr::before { top: 0; right: 0; }
.bracket-tr::after { top: 0; right: 0; }

.bracket-bl { bottom: -1px; left: -1px; transform: translate(-10px, 10px); }
.bracket-bl::before { bottom: 0; left: 0; }
.bracket-bl::after { bottom: 0; left: 0; }

.bracket-br { bottom: -1px; right: -1px; transform: translate(10px, 10px); }
.bracket-br::before { bottom: 0; right: 0; }
.bracket-br::after { bottom: 0; right: 0; }

.panel.in-view .bracket {
    opacity: 1;
    transform: translate(0, 0);
}

.panel.active .bracket {
    animation: bracket-pulse 3s ease-in-out infinite;
}

@keyframes bracket-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.6; }
}

/* panel head */
.panel-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    font-family: var(--f-code);
    font-size: 12px;
    color: var(--faded-cyan);
    letter-spacing: 0.06em;
    padding-bottom: 14px;
    border-bottom: 1px dashed rgba(92, 138, 158, 0.25);
    margin: 0 -32px 22px;
    padding-left: 32px;
    padding-right: 32px;
}

.panel-head .path {
    color: var(--phosphor);
    text-shadow: 0 0 4px rgba(0, 255, 136, 0.4);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.panel-head .seq {
    color: var(--amber);
    flex-shrink: 0;
}

/* panel body */
.panel-body {
    padding-bottom: 22px;
}

.stratum-num {
    font-family: var(--f-code);
    font-size: 11px;
    letter-spacing: 0.20em;
    color: var(--magenta);
    margin-bottom: 10px;
}

.panel-title {
    font-family: var(--f-mono);
    font-size: clamp(26px, 3.4vw, 40px);
    line-height: 1.10;
    letter-spacing: 0.12em;
    color: var(--phosphor);
    text-transform: uppercase;
    margin-bottom: 18px;
    text-shadow: 0 0 10px rgba(0, 255, 136, 0.35);
}

.panel-body p {
    font-size: 16px;
    color: var(--terminal-gray);
    margin-bottom: 14px;
}

.panel-body p.dim {
    color: var(--faded-cyan);
    font-size: 14px;
}

/* panel foot */
.panel-foot {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    font-family: var(--f-code);
    font-size: 11px;
    color: var(--faded-cyan);
    letter-spacing: 0.08em;
    border-top: 1px dashed rgba(92, 138, 158, 0.25);
    margin: 0 -32px;
    padding: 12px 32px;
    background: rgba(15, 25, 35, 0.55);
}

.panel-foot .meta::before {
    content: "&middot; ";
    color: var(--phosphor);
    margin-right: 4px;
}

.panel-foot .meta.integ {
    color: var(--teal);
}

.panel-foot .meta.integ.warn {
    color: var(--amber);
}

/* ------- PANEL-INTERNAL ELEMENTS ------- */
.hex-list {
    list-style: none;
    font-family: var(--f-code);
    font-size: 12px;
    background: rgba(0, 0, 0, 0.45);
    border: 1px solid rgba(0, 255, 136, 0.15);
    padding: 12px 14px;
    margin-top: 14px;
}

.hex-list li {
    display: grid;
    grid-template-columns: 80px 1fr 100px;
    gap: 14px;
    padding: 2px 0;
}

.hex-list .addr { color: var(--faded-cyan); }
.hex-list .bytes { color: var(--phosphor); letter-spacing: 0.06em; }
.hex-list .ascii { color: var(--amber); }

.filebar {
    margin-top: 14px;
    padding: 12px 14px;
    background: rgba(0, 0, 0, 0.4);
    border-left: 2px solid var(--phosphor);
    font-family: var(--f-code);
    font-size: 12px;
}

.fb-row {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    padding: 2px 0;
}

.fb-k {
    color: var(--faded-cyan);
    letter-spacing: 0.08em;
}

.fb-v {
    color: var(--terminal-gray);
}

.code-relic {
    font-family: var(--f-code);
    font-size: 12px;
    line-height: 1.6;
    background: rgba(0, 0, 0, 0.55);
    border: 1px solid rgba(0, 255, 136, 0.20);
    padding: 14px 16px;
    margin-top: 14px;
    overflow-x: auto;
    color: var(--terminal-gray);
}

.code-relic .c-com { color: var(--faded-cyan); font-style: italic; }
.code-relic .c-key { color: var(--phosphor); }
.code-relic .c-str { color: var(--amber); }

.format-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 8px;
    margin-top: 14px;
}

.fmt {
    background: rgba(0, 0, 0, 0.45);
    border: 1px solid rgba(0, 255, 136, 0.15);
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-family: var(--f-code);
    transition: border-color 200ms ease, background 200ms ease;
}

.fmt:hover {
    border-color: var(--phosphor);
    background: rgba(0, 255, 136, 0.06);
}

.fmt-ext {
    color: var(--amber);
    font-size: 18px;
    letter-spacing: 0.06em;
}

.fmt-name {
    color: var(--terminal-gray);
    font-size: 12px;
}

.fmt-state {
    color: var(--magenta);
    font-size: 10px;
    letter-spacing: 0.14em;
    margin-top: 4px;
}

.jpeg-grid {
    display: grid;
    grid-template-columns: repeat(16, 1fr);
    gap: 1px;
    width: 100%;
    aspect-ratio: 1 / 1;
    margin: 14px 0;
    background: var(--void);
    border: 1px solid rgba(0, 255, 136, 0.20);
    padding: 2px;
}

.jpeg-tile {
    background: var(--slate);
    transition: background-color 220ms ease, opacity 220ms ease;
    opacity: 0.25;
}

.jpeg-tile.recovered {
    opacity: 1;
}

.recovery-progress {
    margin-top: 10px;
    font-family: var(--f-code);
    font-size: 12px;
}

.rp-row {
    display: flex;
    justify-content: space-between;
    padding: 2px 0;
}

.rp-k { color: var(--faded-cyan); letter-spacing: 0.08em; }
.rp-v { color: var(--phosphor); }

.rp-bar {
    margin-top: 8px;
    height: 6px;
    background: rgba(0, 0, 0, 0.5);
    border: 1px solid rgba(0, 255, 136, 0.20);
    overflow: hidden;
}

.rp-fill {
    display: block;
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, var(--teal), var(--phosphor));
    box-shadow: 0 0 12px rgba(0, 255, 136, 0.55);
    transition: width 200ms linear;
}

.frag-list {
    list-style: none;
    margin-top: 14px;
    counter-reset: frag;
}

.frag-list li {
    display: grid;
    grid-template-columns: 90px 1fr 100px;
    gap: 12px;
    align-items: start;
    padding: 10px 0;
    border-bottom: 1px dashed rgba(92, 138, 158, 0.18);
    font-family: var(--f-code);
    font-size: 12px;
}

.frag-list li:last-child {
    border-bottom: none;
}

.frag-id {
    color: var(--amber);
    letter-spacing: 0.10em;
}

.frag-text {
    color: var(--terminal-gray);
    font-style: italic;
}

.frag-tag {
    color: var(--magenta);
    font-size: 10px;
    letter-spacing: 0.16em;
    text-align: right;
}

.proto-list {
    list-style: none;
    margin-top: 14px;
    counter-reset: proto;
}

.proto-list li {
    display: grid;
    grid-template-columns: 50px 110px 1fr;
    gap: 14px;
    padding: 12px 0;
    align-items: start;
    border-bottom: 1px dashed rgba(92, 138, 158, 0.18);
}

.proto-list li:last-child {
    border-bottom: none;
}

.pn {
    font-family: var(--f-code);
    font-size: 22px;
    color: var(--amber);
    letter-spacing: 0.06em;
    text-shadow: 0 0 8px rgba(255, 215, 0, 0.4);
}

.pt {
    font-family: var(--f-mono);
    color: var(--phosphor);
    letter-spacing: 0.14em;
    font-size: 14px;
    padding-top: 4px;
}

.pd {
    color: var(--terminal-gray);
    font-size: 14px;
    line-height: 1.6;
}

.signoff {
    margin-top: 14px;
    padding: 14px 16px;
    background: rgba(0, 0, 0, 0.55);
    border: 1px solid rgba(0, 255, 136, 0.20);
    font-family: var(--f-code);
    font-size: 12px;
}

.so-row {
    display: flex;
    justify-content: space-between;
    padding: 3px 0;
}

.so-k { color: var(--faded-cyan); letter-spacing: 0.08em; }
.so-v { color: var(--phosphor); }
.so-v.blink { color: var(--amber); animation: blink 1s steps(2) infinite; }

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

/* ------- CORRUPTION BANDS ------- */
.corruption-band {
    position: relative;
    width: 100%;
    height: 28px;
    overflow: hidden;
    z-index: 5;
    margin: 4px 0;
    isolation: isolate;
}

.corruption-band::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        repeating-linear-gradient(
            90deg,
            transparent 0,
            transparent 2px,
            rgba(255, 51, 102, 0.18) 2px,
            rgba(255, 51, 102, 0.18) 3px,
            transparent 3px,
            transparent 7px
        ),
        repeating-linear-gradient(
            90deg,
            transparent 0,
            transparent 5px,
            rgba(0, 255, 136, 0.15) 5px,
            rgba(0, 255, 136, 0.15) 6px,
            transparent 6px,
            transparent 11px
        ),
        repeating-linear-gradient(
            90deg,
            transparent 0,
            transparent 13px,
            rgba(255, 215, 0, 0.10) 13px,
            rgba(255, 215, 0, 0.10) 14px,
            transparent 14px,
            transparent 23px
        );
    animation: band-shift 12s linear infinite;
}

.corruption-band::after {
    content: "";
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        to bottom,
        transparent 0,
        transparent 1px,
        rgba(0, 0, 0, 0.45) 1px,
        rgba(0, 0, 0, 0.45) 2px
    );
    pointer-events: none;
}

.corruption-band.band-a::before {
    animation-duration: 14s;
    animation-direction: normal;
}

.corruption-band.band-b::before {
    animation-duration: 11s;
    animation-direction: reverse;
    background-position: -25px 0, -10px 0, -5px 0;
}

.corruption-band.band-c::before {
    animation-duration: 16s;
    height: 36px;
    background:
        repeating-linear-gradient(
            90deg,
            transparent 0,
            transparent 1px,
            rgba(255, 51, 102, 0.25) 1px,
            rgba(255, 51, 102, 0.25) 2px,
            transparent 2px,
            transparent 5px
        ),
        repeating-linear-gradient(
            90deg,
            transparent 0,
            transparent 8px,
            rgba(255, 215, 0, 0.18) 8px,
            rgba(255, 215, 0, 0.18) 9px,
            transparent 9px,
            transparent 17px
        );
}

.corruption-band.band-c {
    height: 38px;
}

@keyframes band-shift {
    0% { background-position: 0 0, 0 0, 0 0; }
    100% { background-position: 200px 0, -200px 0, 100px 0; }
}

/* ------- ARCHIVE FOOT ------- */
.archive-foot {
    position: relative;
    z-index: 4;
    text-align: center;
    padding: 60px 40px 40px;
    font-family: var(--f-code);
    font-size: 12px;
    color: var(--faded-cyan);
    letter-spacing: 0.10em;
    border-top: 1px dashed rgba(92, 138, 158, 0.18);
    margin-top: 40px;
}

.af-line {
    margin-bottom: 6px;
    color: var(--phosphor);
}

.af-line.dim {
    color: var(--faded-cyan);
}

/* ------- RESPONSIVE COLLAPSE ------- */
@media (max-width: 900px) {
    .stratum,
    .stratum.left,
    .stratum.right {
        padding: 40px 20px 40px 56px;
        justify-content: flex-start;
    }

    .panel {
        max-width: 100%;
    }

    .timeline-svg line {
        transform: translateX(-50%);
    }

    /* shift spine left on small screens */
    #spine-line {
        x1: 32px;
        x2: 32px;
    }

    .connector {
        top: 70px;
        width: 24px;
        background: linear-gradient(to right, rgba(0, 255, 136, 0.55), rgba(0, 255, 136, 0));
        right: auto !important;
        left: 32px !important;
    }

    .stratum.left .connector,
    .stratum.right .connector {
        background: linear-gradient(to right, rgba(0, 255, 136, 0.55), rgba(0, 255, 136, 0));
        left: 32px;
        right: auto;
    }

    .stratum.left .connector::after,
    .stratum.right .connector::after {
        right: -3.5px;
        left: auto;
    }

    .depth-readout {
        top: 12px;
        right: 12px;
        min-width: 180px;
        font-size: 10px;
    }

    .masthead {
        padding: 60px 20px 30px 56px;
    }

    .hex-list li {
        grid-template-columns: 60px 1fr 70px;
        font-size: 11px;
        gap: 8px;
    }

    .frag-list li {
        grid-template-columns: 80px 1fr;
    }

    .frag-list .frag-tag {
        grid-column: 1 / -1;
        text-align: left;
    }

    .proto-list li {
        grid-template-columns: 40px 90px 1fr;
        gap: 8px;
    }

    .jpeg-grid {
        grid-template-columns: repeat(12, 1fr);
    }
}
