/* =========================================================
   $GLOB — the goblin that burns itself
   vibe: terminal / CRT / hacker-green on black
   ========================================================= */

:root {
    --bg:           #02060a;
    --bg-2:         #050d10;
    --panel:        rgba(6, 18, 14, 0.78);
    --panel-line:   rgba(0, 255, 102, 0.32);

    --green:        #00ff66;
    --green-dim:    #0bcc55;
    --green-soft:   rgba(0, 255, 102, 0.18);
    --green-glow:   rgba(0, 255, 102, 0.55);
    --green-faint:  rgba(0, 255, 102, 0.08);

    --acid:         #b3ff00;        /* hover / hot */
    --ember:        #ff5c00;        /* danger / burn */
    --ember-soft:   rgba(255, 92, 0, 0.18);

    --ink:          #c8ffd9;        /* primary text */
    --ink-dim:      #6cbf86;
    --ink-faint:    #2f6e47;

    --mono:         'JetBrains Mono', 'Share Tech Mono', 'Consolas', monospace;
    --pixel:        'VT323', 'Share Tech Mono', monospace;
}

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

html, body { height: 100%; }

/* hide scrollbars site-wide (scroll behavior stays intact) */
html, body, * {
    scrollbar-width: none;        /* firefox */
    -ms-overflow-style: none;     /* ie / edge legacy */
}
*::-webkit-scrollbar {             /* chrome, safari, edge */
    width: 0;
    height: 0;
    display: none;
}

body {
    background: var(--bg);
    background-image:
        radial-gradient(ellipse at 50% -10%, rgba(0, 255, 102, 0.14), transparent 60%),
        radial-gradient(ellipse at 50% 110%, rgba(0, 255, 102, 0.10), transparent 55%);
    color: var(--ink);
    font-family: var(--mono);
    font-size: 15.5px;
    line-height: 1.55;
    overflow-x: hidden;
    position: relative;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    cursor: default;
}

::selection { background: var(--green); color: var(--bg); }

a { color: inherit; text-decoration: none; }

img { display: block; max-width: 100%; height: auto; }

/* =========================================================
   CRT OVERLAYS
   ========================================================= */
.crt {
    position: fixed;
    inset: 0;
    z-index: 50;
    pointer-events: none;
}

.scanlines {
    position: absolute; inset: 0;
    background: repeating-linear-gradient(
        to bottom,
        rgba(0, 0, 0, 0) 0,
        rgba(0, 0, 0, 0) 2px,
        rgba(0, 0, 0, 0.22) 3px,
        rgba(0, 0, 0, 0.22) 4px
    );
    mix-blend-mode: multiply;
    opacity: .7;
}

.vignette {
    position: absolute; inset: 0;
    background: radial-gradient(ellipse at center, transparent 55%, rgba(0, 0, 0, 0.65) 100%);
}

.flicker {
    position: absolute; inset: 0;
    background: rgba(0, 255, 102, 0.02);
    animation: flicker 6s steps(2) infinite;
}
@keyframes flicker {
    0%, 19%, 21%, 23%, 25%, 54%, 56%, 100% { opacity: 0.35; }
    20%, 24%, 55% { opacity: 0; }
}

.noise {
    position: absolute; inset: 0;
    background-image:
        radial-gradient(rgba(0, 255, 102, 0.04) 1px, transparent 1px);
    background-size: 3px 3px;
    opacity: .35;
}

/* matrix canvas */
.matrix {
    position: fixed;
    inset: 0;
    z-index: 0;
    width: 100%; height: 100%;
    opacity: .18;
    pointer-events: none;
}

/* =========================================================
   TICKER
   ========================================================= */
.ticker {
    position: relative;
    z-index: 5;
    background: var(--green);
    color: var(--bg);
    border-block: 1px solid var(--green);
    overflow: hidden;
    font-family: var(--mono);
    font-weight: 700;
    font-size: .85rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    text-shadow: none;
}
.ticker-bottom { background: var(--bg); color: var(--green); border-color: var(--green); }

.ticker-track {
    display: flex;
    width: max-content;
    animation: tickerScroll 44s linear infinite;
}
.ticker-track.reverse { animation-direction: reverse; animation-duration: 52s; }

.ticker-content {
    display: inline-block;
    padding: .55rem 0;
    white-space: nowrap;
}

@keyframes tickerScroll {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}

/* =========================================================
   TOP NAV
   ========================================================= */
.topbar {
    position: relative;
    z-index: 4;
    max-width: 1180px;
    margin: 1.4rem auto 0;
    padding: 0 1.4rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}

.brand {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    font-family: var(--mono);
    font-weight: 700;
    font-size: 1.05rem;
    letter-spacing: 3px;
    color: var(--green);
    text-shadow: 0 0 8px var(--green-glow);
}
.brand-bracket { color: var(--green-dim); opacity: .6; }
.brand-mark {
    width: 34px; height: 34px;
    border-radius: 4px;
    object-fit: cover;
    object-position: center;
    border: 1px solid var(--green);
    background: var(--bg-2);
    filter: drop-shadow(0 0 6px var(--green-glow));
}
.brand-text { letter-spacing: 4px; }

.topnav {
    display: inline-flex;
    align-items: center;
    gap: .2rem;
    flex-wrap: wrap;
}
.topnav a {
    padding: .5rem .8rem;
    font-family: var(--mono);
    font-weight: 700;
    font-size: .85rem;
    letter-spacing: 2px;
    text-transform: lowercase;
    color: var(--ink-dim);
    border: 1px solid transparent;
    transition: color .15s ease, border-color .15s ease, background .15s ease, text-shadow .15s ease;
}
.topnav a:hover {
    color: var(--green);
    border-color: var(--green);
    background: var(--green-faint);
    text-shadow: 0 0 8px var(--green-glow);
}

/* "you are here" — applied via aria-current="page" on the link to the
   current page in each HTML file. single source of truth for active state
   so it stays consistent across home / burn / nfts. */
.topnav a[aria-current="page"] {
    color: var(--green);
    border-color: var(--green);
    background: var(--green-faint);
    text-shadow: 0 0 6px var(--green-glow);
    cursor: default;
    position: relative;
}
.topnav a[aria-current="page"]::after {
    content: "_";
    margin-left: 2px;
    color: var(--green);
    animation: navActiveBlink 1.1s steps(1) infinite;
}
@keyframes navActiveBlink {
    0%, 49%  { opacity: 1; }
    50%, 100% { opacity: 0; }
}

/* legacy class kept for any third-party callout we ever add — same look */
.topnav-cta {
    color: var(--green) !important;
    border-color: var(--green) !important;
    background: var(--green-faint);
    text-shadow: 0 0 6px var(--green-glow);
}
.topnav-cta:hover {
    background: var(--green) !important;
    color: var(--bg) !important;
    text-shadow: none !important;
}

@media (max-width: 600px) {
    .topbar { flex-direction: column; align-items: flex-start; }
    .topnav { width: 100%; justify-content: flex-start; }
    .topnav a { padding: .4rem .55rem; font-size: .78rem; letter-spacing: 1.4px; }
}

/* =========================================================
   PAGE LAYOUT
   ========================================================= */
.page {
    position: relative;
    z-index: 2;
    max-width: 1180px;
    margin: 0 auto;
    padding: 0 1.4rem;
}

/* =========================================================
   HERO
   ========================================================= */
.hero {
    padding: 2.4rem 0 3.2rem;
    display: grid;
    place-items: center;
}

.hero-inner {
    width: 100%;
    max-width: 880px;
    display: grid;
    gap: 1.2rem;
    text-align: center;
    justify-items: center;
}

/* logo + ascii frame */
.logo-wrap {
    width: min(100%, 360px);
    margin-bottom: .2rem;
}

.logo-frame {
    position: relative;
    padding: 1.1rem;
    background:
        linear-gradient(180deg, rgba(0, 255, 102, 0.05), transparent 60%),
        var(--bg-2);
    border: 1px solid var(--green);
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, .9),
        0 0 24px rgba(0, 255, 102, 0.20),
        inset 0 0 30px rgba(0, 255, 102, 0.06);
}

.frame-corner {
    position: absolute;
    color: var(--green);
    font-family: var(--mono);
    font-size: 1.1rem;
    line-height: 1;
    text-shadow: 0 0 8px var(--green-glow);
}
.frame-corner.tl { top: -2px; left:  2px; }
.frame-corner.tr { top: -2px; right: 4px; }
.frame-corner.bl { bottom: -2px; left:  2px; }
.frame-corner.br { bottom: -2px; right: 4px; }

.logo {
    width: 100%;
    height: auto;
    image-rendering: pixelated;
    filter:
        drop-shadow(0 0 8px var(--green-glow))
        drop-shadow(0 0 18px rgba(0, 255, 102, 0.25));
    animation: idleHover 5s ease-in-out infinite;
    user-select: none;
    -webkit-user-drag: none;
    cursor: crosshair;
}
/* video variant — sequential autoplay loop, see script.js #heroVideo */
.logo-video {
    display: block;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    background: #02060a;
    image-rendering: auto;
}

@keyframes idleHover {
    0%, 100% { transform: translateY(0); }
    50%      { transform: translateY(-6px); }
}

.logo-label {
    position: absolute;
    bottom: -14px; left: 50%;
    transform: translateX(-50%);
    background: var(--bg);
    color: var(--green);
    font-family: var(--mono);
    font-size: .72rem;
    letter-spacing: 2px;
    padding: 0 .55rem;
    text-shadow: 0 0 6px var(--green-glow);
    white-space: nowrap;
}

/* eyebrow */
.eyebrow {
    font-family: var(--mono);
    color: var(--green);
    font-size: .9rem;
    letter-spacing: 3px;
    text-transform: uppercase;
    text-shadow: 0 0 6px var(--green-glow);
}

/* title */
.title {
    font-family: var(--mono);
    font-weight: 700;
    color: var(--green);
    font-size: clamp(3.4rem, 12vw, 7.2rem);
    line-height: .95;
    letter-spacing: 4px;
    text-shadow:
        0 0 12px var(--green-glow),
        0 0 28px rgba(0, 255, 102, 0.4);
    margin: .2rem 0;
    user-select: none;
}

.title-line {
    position: relative;
    display: inline-block;
}
/* glitch double */
.title-line::before,
.title-line::after {
    content: attr(data-text);
    position: absolute;
    top: 0; left: 0;
    width: 100%;
    overflow: hidden;
    opacity: .85;
}
.title-line::before {
    color: #00ffff;
    transform: translate(-2px, 0);
    mix-blend-mode: screen;
    clip-path: polygon(0 0, 100% 0, 100% 45%, 0 45%);
    animation: glitchA 3.6s steps(1) infinite;
}
.title-line::after {
    color: var(--ember);
    transform: translate(2px, 0);
    mix-blend-mode: screen;
    clip-path: polygon(0 55%, 100% 55%, 100% 100%, 0 100%);
    animation: glitchB 4.2s steps(1) infinite;
}
@keyframes glitchA {
    0%, 92%, 100% { transform: translate(-2px, 0); }
    93% { transform: translate(-6px, 1px); }
    95% { transform: translate(2px, -2px); }
    97% { transform: translate(-4px, 2px); }
}
@keyframes glitchB {
    0%, 90%, 100% { transform: translate(2px, 0); }
    91% { transform: translate(6px, -1px); }
    94% { transform: translate(-2px, 2px); }
    96% { transform: translate(4px, -2px); }
}

.subtitle {
    font-family: var(--mono);
    font-weight: 400;
    font-size: clamp(1rem, 2.6vw, 1.4rem);
    color: var(--ink);
    letter-spacing: 2px;
    text-transform: lowercase;
    border-top: 1px dashed var(--green-soft);
    border-bottom: 1px dashed var(--green-soft);
    padding: .35rem 1rem;
}

.lede {
    max-width: 640px;
    color: var(--ink);
    font-size: 1rem;
    line-height: 1.7;
    margin-top: .2rem;
    text-align: left;
    padding: .9rem 1rem;
    border: 1px solid var(--green-soft);
    background: rgba(0, 255, 102, 0.02);
}
.lede em {
    color: var(--green);
    font-style: normal;
    text-shadow: 0 0 6px var(--green-glow);
}

/* CA card */
.ca-card {
    width: 100%;
    max-width: 720px;
    background: var(--panel);
    border: 1px solid var(--green);
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, .9),
        0 0 18px rgba(0, 255, 102, 0.22);
    padding: .25rem;
    margin-top: .8rem;
    transition: box-shadow .2s ease;
}
.ca-card:hover {
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, .9),
        0 0 28px rgba(0, 255, 102, 0.45);
}

.ca-row {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: .4rem;
    padding: .35rem;
}

.ca-chain {
    background: var(--green);
    color: var(--bg);
    font-family: var(--mono);
    font-weight: 700;
    font-size: .78rem;
    letter-spacing: 2px;
    padding: .55rem .75rem;
    white-space: nowrap;
}

.ca-address {
    font-family: var(--mono);
    font-size: .92rem;
    color: var(--green);
    text-shadow: 0 0 6px var(--green-glow);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    cursor: copy;
    text-align: left;
    padding: 0 .4rem;
}

.ca-copy {
    background: var(--bg);
    color: var(--green);
    border: 1px solid var(--green);
    padding: .55rem 1rem;
    font-family: var(--mono);
    font-weight: 700;
    font-size: .82rem;
    letter-spacing: 2px;
    cursor: pointer;
    transition: background .15s ease, color .15s ease, text-shadow .15s ease;
    text-transform: uppercase;
}
.ca-copy .copy-done { display: none; }
.ca-copy.copied { background: var(--green); color: var(--bg); }
.ca-copy.copied .copy-default { display: none; }
.ca-copy.copied .copy-done    { display: inline; }
.ca-copy:hover { background: var(--green-faint); text-shadow: 0 0 6px var(--green-glow); }
.ca-copy:active { transform: scale(.97); }

@media (max-width: 620px) {
    .ca-row { grid-template-columns: 1fr; }
    .ca-address { padding: .25rem .4rem; font-size: .8rem; text-align: center; }
    .ca-chain, .ca-copy { justify-self: stretch; text-align: center; }
}

/* CTA */
.cta {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .6rem;
    margin-top: .4rem;
}

.btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .85rem 1.2rem;
    font-family: var(--mono);
    font-weight: 700;
    font-size: .88rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    border: 1px solid var(--green);
    cursor: pointer;
    transition: background .15s ease, color .15s ease, transform .12s ease, text-shadow .15s ease, box-shadow .2s ease;
    color: var(--green);
    background: var(--bg);
}

.btn-primary {
    background: var(--green);
    color: var(--bg);
    box-shadow: 0 0 16px rgba(0, 255, 102, 0.4);
}
.btn-primary:hover {
    background: var(--acid);
    border-color: var(--acid);
    color: var(--bg);
    box-shadow: 0 0 24px rgba(179, 255, 0, 0.55);
}

.btn-ghost { background: transparent; }
.btn-ghost:hover {
    background: var(--green-faint);
    text-shadow: 0 0 8px var(--green-glow);
    box-shadow: 0 0 14px rgba(0, 255, 102, 0.25);
}

.btn:active { transform: translateY(1px); }
.btn-ico { font-size: 1rem; line-height: 1; }

/* =========================================================
   SECTION HEAD (shared)
   ========================================================= */
.section-head {
    text-align: center;
    margin-bottom: 1.6rem;
}
.kicker {
    font-family: var(--mono);
    color: var(--ink-dim);
    font-size: .9rem;
    letter-spacing: 2px;
    margin-bottom: .35rem;
}
.section-title {
    font-family: var(--mono);
    font-weight: 700;
    font-size: clamp(1.6rem, 4.5vw, 2.6rem);
    color: var(--green);
    letter-spacing: 4px;
    text-transform: lowercase;
    text-shadow: 0 0 10px var(--green-glow);
}
.section-head .sub {
    max-width: 640px;
    margin: .7rem auto 0;
    color: var(--ink);
    font-size: .98rem;
    line-height: 1.6;
}

/* =========================================================
   BURN SECTION
   ========================================================= */
.burn {
    padding: 3rem 0;
    display: grid;
    gap: 2.2rem;
}

/* === main meter card === */
.meter-card {
    background: var(--panel);
    border: 1px solid var(--green);
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, .9),
        0 0 30px rgba(0, 255, 102, 0.18);
    padding: 1.4rem 1.4rem 1.6rem;
    position: relative;
    overflow: hidden;
}
.meter-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(0, 255, 102, 0.05), transparent 30%);
    pointer-events: none;
}

.meter-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: .6rem;
    border-bottom: 1px dashed var(--green-soft);
    padding-bottom: .7rem;
    margin-bottom: 1rem;
}
.meter-label {
    color: var(--green);
    font-weight: 700;
    font-size: 1rem;
    letter-spacing: 3px;
    text-shadow: 0 0 6px var(--green-glow);
}
.meter-status {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    color: var(--ember);
    font-weight: 700;
    font-size: .85rem;
    letter-spacing: 2px;
}
.meter-status .dot {
    width: 10px; height: 10px;
    background: var(--ember);
    border-radius: 50%;
    box-shadow: 0 0 10px var(--ember);
    animation: pulse 1.2s ease-in-out infinite;
}
/* upgraded indicator when on-chain supply lookup succeeded (set by script.js) */
.meter-status.is-live {
    color: var(--green);
    text-shadow: 0 0 6px var(--green-glow);
}
.meter-status.is-live .dot {
    background: var(--green);
    box-shadow: 0 0 12px var(--green-glow);
}
@keyframes pulse {
    0%, 100% { opacity: 1;   transform: scale(1); }
    50%      { opacity: .35; transform: scale(.75); }
}

.meter-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1.2rem;
}
@media (max-width: 720px) { .meter-stats { grid-template-columns: 1fr; } }

.stat {
    background: rgba(0, 255, 102, 0.04);
    border: 1px dashed var(--green-soft);
    padding: .65rem .8rem;
    display: grid;
    gap: .15rem;
}
.stat-key {
    color: var(--ink-dim);
    font-size: .72rem;
    letter-spacing: 2px;
    text-transform: uppercase;
}
.stat-val {
    color: var(--green);
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-shadow: 0 0 6px var(--green-glow);
}

/* === the big progressive bar === */
.meter-track {
    position: relative;
    width: 100%;
    height: 42px;
    background:
        repeating-linear-gradient(
            90deg,
            rgba(0, 255, 102, 0.04) 0,
            rgba(0, 255, 102, 0.04) 8px,
            transparent 8px,
            transparent 9px
        ),
        var(--bg-2);
    border: 1px solid var(--green);
    overflow: hidden;
}
.meter-fill {
    position: absolute;
    inset: 0 auto 0 0;
    width: 0%;
    background:
        linear-gradient(90deg, var(--green) 0%, var(--acid) 60%, var(--ember) 100%);
    box-shadow:
        0 0 14px var(--green-glow),
        inset 0 0 12px rgba(255, 255, 255, 0.25);
    transition: width 1.4s cubic-bezier(.22, .9, .25, 1);
}
.meter-fill::after {
    content: "";
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        90deg,
        rgba(0, 0, 0, 0.18) 0,
        rgba(0, 0, 0, 0.18) 6px,
        transparent 6px,
        transparent 12px
    );
    animation: stripes 1.4s linear infinite;
}
@keyframes stripes {
    from { background-position: 0 0; }
    to   { background-position: -24px 0; }
}
.meter-grid {
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        repeating-linear-gradient(
            90deg,
            transparent 0,
            transparent calc(10% - 1px),
            rgba(0, 255, 102, 0.25) calc(10% - 1px),
            rgba(0, 255, 102, 0.25) 10%
        );
}

.meter-scale {
    display: flex;
    justify-content: space-between;
    margin-top: .35rem;
    color: var(--ink-faint);
    font-size: .72rem;
    letter-spacing: 1px;
}

.meter-percent {
    margin-top: 1.4rem;
    text-align: center;
    color: var(--green);
}
.big-percent {
    font-family: var(--pixel);
    font-size: clamp(3.2rem, 10vw, 5.4rem);
    line-height: 1;
    color: var(--green);
    text-shadow:
        0 0 16px var(--green-glow),
        0 0 32px rgba(0, 255, 102, 0.4);
    letter-spacing: 2px;
}
.big-percent-sign {
    font-family: var(--pixel);
    font-size: clamp(2rem, 6vw, 3rem);
    color: var(--ember);
    text-shadow: 0 0 14px var(--ember);
    margin-left: .15rem;
}
.big-percent-sub {
    display: block;
    margin-top: .2rem;
    color: var(--ink-dim);
    font-size: .85rem;
    letter-spacing: 2px;
    text-transform: uppercase;
}

.ascii-flame {
    margin-top: 1.2rem;
    color: var(--ember);
    font-family: var(--mono);
    font-size: .68rem;
    line-height: 1.1;
    text-align: center;
    text-shadow: 0 0 6px var(--ember);
    overflow: auto;
    opacity: .85;
}

/* =========================================================
   CHECKLIST
   ========================================================= */
.checklist {
    background: var(--panel);
    border: 1px solid var(--green);
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, .9),
        0 0 24px rgba(0, 255, 102, 0.15);
    padding: 1.3rem 1.4rem;
}

.checklist-title {
    font-family: var(--mono);
    color: var(--green);
    font-size: 1rem;
    letter-spacing: 3px;
    margin-bottom: 1rem;
    border-bottom: 1px dashed var(--green-soft);
    padding-bottom: .6rem;
    text-shadow: 0 0 6px var(--green-glow);
}

.checklist-list { list-style: none; display: grid; gap: 1rem; }

.check-item {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1rem;
    padding: .9rem 1rem;
    border: 1px dashed var(--green-soft);
    background: rgba(0, 255, 102, 0.025);
    transition: border-color .2s ease, background .2s ease, box-shadow .2s ease;
}
.check-item:hover {
    border-color: var(--green);
    background: rgba(0, 255, 102, 0.05);
    box-shadow: 0 0 18px rgba(0, 255, 102, 0.12);
}

/* checkbox state */
.check-mark {
    font-family: var(--mono);
    font-size: 1.15rem;
    font-weight: 700;
    line-height: 1;
    padding-top: .1rem;
    color: var(--ink-dim);
}
.check-mark .mark-empty,
.check-mark .mark-done,
.check-mark .mark-run { display: none; }
.check-item[data-status="pending"] .mark-empty { display: inline; color: var(--ink-dim); }
.check-item[data-status="done"]    .mark-done  { display: inline; color: var(--green); text-shadow: 0 0 6px var(--green-glow); }
.check-item[data-status="running"] .mark-run   { display: inline; color: var(--ember); text-shadow: 0 0 6px var(--ember); animation: blink 1s steps(2) infinite; }

.check-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: .3rem;
}
.check-name {
    color: var(--green);
    font-weight: 700;
    font-size: 1rem;
    letter-spacing: 2px;
    text-shadow: 0 0 6px var(--green-glow);
}
.check-pct {
    font-family: var(--pixel);
    font-size: 1.6rem;
    color: var(--ember);
    text-shadow: 0 0 10px var(--ember);
    line-height: 1;
}
.check-item[data-status="done"] .check-pct { color: var(--green); text-shadow: 0 0 10px var(--green-glow); }

.check-desc {
    color: var(--ink);
    font-size: .9rem;
    line-height: 1.55;
    margin-bottom: .6rem;
}

.check-bar {
    position: relative;
    width: 100%;
    height: 10px;
    background:
        repeating-linear-gradient(
            90deg,
            rgba(0, 255, 102, 0.04) 0,
            rgba(0, 255, 102, 0.04) 8px,
            transparent 8px,
            transparent 9px
        ),
        var(--bg-2);
    border: 1px solid var(--green-soft);
    overflow: hidden;
}
.check-bar-fill {
    position: absolute;
    inset: 0 auto 0 0;
    width: var(--target, 0%);
    background: linear-gradient(90deg, var(--green), var(--acid));
    box-shadow: 0 0 10px var(--green-glow);
    transition: width 1.4s cubic-bezier(.22, .9, .25, 1);
}
.check-bar-fill--run {
    background: linear-gradient(90deg, var(--ember), #ff8a3a);
    box-shadow: 0 0 10px var(--ember);
}
.check-bar-fill--run::after {
    content: "";
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        90deg,
        rgba(0,0,0,0.2) 0, rgba(0,0,0,0.2) 4px,
        transparent 4px, transparent 8px
    );
    animation: stripes 1s linear infinite;
}

.check-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: .8rem;
    flex-wrap: wrap;
    margin-top: .55rem;
    font-size: .82rem;
    color: var(--ink-dim);
    letter-spacing: 1px;
}
.check-meta b { color: var(--green); font-weight: 700; }
.check-item[data-status="running"] .check-meta b { color: var(--ember); }
.check-item[data-status="pending"] .check-meta b { color: var(--ink-dim); }

.checklist-foot {
    margin-top: 1rem;
    text-align: center;
    color: var(--ink-dim);
    font-size: .85rem;
    letter-spacing: 2px;
}
.checklist-foot #lastBurn {
    color: var(--green);
    font-weight: 700;
    text-shadow: 0 0 6px var(--green-glow);
}

.blink { animation: blink 1s steps(2) infinite; }
@keyframes blink {
    0%, 49%   { opacity: 1; }
    50%, 100% { opacity: 0; }
}

/* =========================================================
   LORE
   ========================================================= */
.lore {
    padding: 3rem 0 4rem;
}

.lore-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 2rem;
}
@media (max-width: 920px) { .lore-grid { grid-template-columns: 1fr; } }

.lore-card {
    background: var(--panel);
    border: 1px solid var(--green);
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, .9),
        0 0 18px rgba(0, 255, 102, 0.12);
    padding: 1.2rem 1.2rem 1.4rem;
    position: relative;
    transition: transform .25s ease, box-shadow .25s ease;
}
.lore-card:hover {
    transform: translateY(-3px);
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, .9),
        0 0 30px rgba(0, 255, 102, 0.32);
}

.lore-head {
    font-family: var(--mono);
    color: var(--ink-dim);
    font-size: .78rem;
    letter-spacing: 2px;
    border-bottom: 1px dashed var(--green-soft);
    padding-bottom: .45rem;
    margin-bottom: .7rem;
}

.lore-card h3 {
    font-family: var(--mono);
    color: var(--green);
    font-size: 1.05rem;
    letter-spacing: 2px;
    text-transform: lowercase;
    margin-bottom: .55rem;
    text-shadow: 0 0 6px var(--green-glow);
}

.lore-card p {
    color: var(--ink);
    font-size: .94rem;
    line-height: 1.65;
}
.lore-card p em {
    color: var(--green);
    font-style: normal;
    text-shadow: 0 0 6px var(--green-glow);
}

.terminal-quote {
    margin: 0 auto;
    max-width: 720px;
    background: var(--bg-2);
    border: 1px solid var(--green);
    padding: 1.1rem 1.3rem;
    color: var(--green);
    font-family: var(--mono);
    font-size: .95rem;
    line-height: 1.8;
    text-shadow: 0 0 6px var(--green-glow);
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, .9),
        0 0 22px rgba(0, 255, 102, 0.22);
    white-space: pre-wrap;
}

/* =========================================================
   FOOTER
   ========================================================= */
.page-foot {
    position: relative;
    z-index: 2;
    max-width: 1180px;
    margin: 0 auto;
    padding: 2.5rem 1.4rem 3rem;
    text-align: center;
    display: grid;
    gap: .35rem;
}
.copyright {
    color: var(--ink-dim);
    font-family: var(--mono);
    font-size: .8rem;
    letter-spacing: 1.5px;
}
.copyright.dim { color: var(--ink-faint); font-size: .72rem; }

/* =========================================================
   TOAST
   ========================================================= */
.toast {
    position: fixed;
    left: 50%;
    bottom: 2rem;
    transform: translate(-50%, 30px);
    background: var(--bg);
    color: var(--green);
    padding: .65rem 1.1rem;
    font-family: var(--mono);
    font-weight: 700;
    letter-spacing: 2px;
    font-size: .85rem;
    border: 1px solid var(--green);
    box-shadow:
        0 0 0 1px rgba(0, 0, 0, .9),
        0 0 16px rgba(0, 255, 102, 0.45);
    text-shadow: 0 0 6px var(--green-glow);
    opacity: 0;
    pointer-events: none;
    transition: opacity .25s ease, transform .25s ease;
    z-index: 9999;
}
.toast.show {
    opacity: 1;
    transform: translate(-50%, 0);
}

/* =========================================================
   REDUCED MOTION
   only kill the noisy decorative stuff. functional motion
   (the marquee on /nfts, animated counters, the burn-meter
   fill, etc) is content — it stays.
   ========================================================= */
@media (prefers-reduced-motion: reduce) {
    .flicker,
    .matrix,
    .bg .blob,
    .bg .spark,
    .title-line::before,
    .title-line::after,
    .glitch,
    .glitch::before,
    .glitch::after,
    .blink {
        animation: none !important;
    }
    *, *::before, *::after { transition-duration: .01ms !important; }
}
