/* ============================================================
   CHROME RONIN — ARCHIVE SYSTEM v2.0
   DESIGN SYSTEM / PHASE 1
   "PROPERTY OF THE ARCHIVE — 黒"
   ============================================================ */

/* ------------------------------------------------------------
   00 / TOKENS
   ------------------------------------------------------------ */
:root {
  /* surfaces */
  --void:      #0A0A0A;
  --vault:     #111111;
  --concrete:  #181818;
  --slate:     #1F1F1F;
  --steel:     #2A2A2E;
  --paper:     #E9E7E0;   /* gallery paper — artwork panels */

  /* ink */
  --bone:      #E8E6E1;
  --ash:       #9A988F;
  --graphite:  #55534C;
  --ink:       #101014;

  /* accent — blood red + forged chrome, matching the mask */
  --crimson:      #B01522;
  --crimson-deep: #5E0C14;
  --crimson-hot:  #E11D2A;
  --seal:         #8E1B26;
  --chrome-a:     #D8DBE0;
  --chrome-b:     #6E747E;
  --chrome-dark:  #3A3D44;
  --steel-lit:    #AEB4BE;

  /* lines */
  --hairline: rgba(232,230,225,.08);
  --hairline-strong: rgba(232,230,225,.16);

  /* type */
  --f-display: 'Anton', 'Arial Narrow', sans-serif;
  --f-body:    'Space Grotesk', 'Helvetica Neue', sans-serif;
  --f-mono:    'IBM Plex Mono', 'Courier New', monospace;
  --f-jp:      'Noto Serif JP', serif;

  /* fluid type scale */
  --t-hero:  clamp(4.2rem, 14vw, 15rem);
  --t-h1:    clamp(3rem, 8.5vw, 8.5rem);
  --t-h2:    clamp(2rem, 5vw, 4.6rem);
  --t-h3:    clamp(1.3rem, 2.4vw, 2rem);
  --t-body:  clamp(.95rem, 1.05vw, 1.05rem);
  --t-meta:  .68rem;
  --t-micro: .58rem;

  /* space scale */
  --s-1: .5rem; --s-2: 1rem; --s-3: 2rem; --s-4: 3.5rem;
  --s-5: 6rem;  --s-6: 9rem; --s-7: 14rem;

  /* motion */
  --e-out:  cubic-bezier(.16,1,.3,1);
  --e-in:   cubic-bezier(.7,0,.84,0);
  --e-slow: cubic-bezier(.22,1,.36,1);
  --d-fast: .35s; --d-med: .8s; --d-slow: 1.4s;

  --gutter: clamp(1.25rem, 4vw, 4rem);
  --max-w: 1680px;
}

/* ------------------------------------------------------------
   01 / RESET + BASE
   ------------------------------------------------------------ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  background: var(--void);
  color: var(--bone);
  font-family: var(--f-body);
  font-size: var(--t-body);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  min-height: 100vh;
  cursor: none;
}
@media (hover: none), (pointer: coarse) { body { cursor: auto; } }

::selection { background: var(--crimson); color: var(--bone); }

img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: none; }
@media (hover: none) { button { cursor: pointer; } }
ul { list-style: none; }

h1,h2,h3,h4 { font-weight: 400; line-height: .92; }

/* accessibility */
.sr-only {
  position: absolute; width: 1px; height: 1px;
  clip-path: inset(50%); overflow: hidden; white-space: nowrap;
}
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible {
  outline: 1px solid var(--crimson-hot);
  outline-offset: 3px;
}
.skip-link {
  position: fixed; top: -100%; left: var(--gutter); z-index: 6001;
  background: var(--crimson); color: var(--bone);
  padding: .6rem 1.2rem; font-family: var(--f-mono); font-size: var(--t-meta);
  text-transform: uppercase; letter-spacing: .15em;
  transition: top .3s var(--e-out);
}
.skip-link:focus { top: 0; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
  html { scroll-behavior: auto; }
}

/* ------------------------------------------------------------
   02 / TYPOGRAPHY UTILITIES
   ------------------------------------------------------------ */
.t-display {
  font-family: var(--f-display);
  text-transform: uppercase;
  letter-spacing: .01em;
  line-height: .88;
}
.t-meta {
  font-family: var(--f-mono);
  font-size: var(--t-meta);
  text-transform: uppercase;
  letter-spacing: .22em;
  color: var(--ash);
}
.t-micro {
  font-family: var(--f-mono);
  font-size: var(--t-micro);
  text-transform: uppercase;
  letter-spacing: .3em;
  color: var(--graphite);
}
.t-jp { font-family: var(--f-jp); font-weight: 600; }
.t-crimson { color: var(--crimson-hot); }
.t-outline {
  color: transparent;
  -webkit-text-stroke: 1px var(--graphite);
}
.t-chrome {
  background: linear-gradient(160deg, var(--chrome-a) 10%, var(--chrome-b) 45%, #4a4e55 60%, var(--chrome-a) 90%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* vertical kanji rail */
.kanji-rail {
  writing-mode: vertical-rl;
  font-family: var(--f-jp);
  font-size: clamp(1rem, 1.4vw, 1.4rem);
  letter-spacing: .9em;
  color: var(--graphite);
  user-select: none;
}

/* ------------------------------------------------------------
   03 / LAYOUT
   ------------------------------------------------------------ */
.wrap { width: min(100% - 2*var(--gutter), var(--max-w)); margin-inline: auto; }
.section { padding-block: var(--s-6); position: relative; }
.grid-12 { display: grid; grid-template-columns: repeat(12, 1fr); gap: var(--s-2); }

.rule { height: 1px; background: var(--hairline); border: 0; }
.rule--strong { background: var(--hairline-strong); }

.sec-head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--s-2); margin-bottom: var(--s-4); flex-wrap: wrap; }
.sec-head .idx { font-family: var(--f-mono); font-size: var(--t-meta); color: var(--crimson-hot); letter-spacing: .22em; }

/* ------------------------------------------------------------
   04 / GLOBAL OVERLAYS (grain / scan / cursor / veil)
   ------------------------------------------------------------ */
.grain {
  position: fixed; inset: 0; z-index: 2000; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 240 240' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  background-size: 240px 240px;
  opacity: .05;
  animation: grainShift 1.4s steps(4) infinite;
}
@keyframes grainShift {
  0%,100% { background-position: 0 0; }
  25% { background-position: -60px 40px; }
  50% { background-position: 40px -70px; }
  75% { background-position: -30px -30px; }
}
.scanlines {
  position: fixed; inset: 0; z-index: 1999; pointer-events: none;
  background: repeating-linear-gradient(0deg, transparent 0 3px, rgba(0,0,0,.09) 3px 4px);
  opacity: .35;
}

/* custom cursor */
.cursor {
  position: fixed; top: 0; left: 0; z-index: 4000; pointer-events: none;
  width: 10px; height: 10px; margin: -5px 0 0 -5px;
  background: var(--bone);
  border-radius: 50%;
  mix-blend-mode: difference;
  transition: transform .18s var(--e-out), background .18s;
}
.cursor-ring {
  position: fixed; top: 0; left: 0; z-index: 3999; pointer-events: none;
  width: 38px; height: 38px; margin: -19px 0 0 -19px;
  border: 1px solid rgba(232,230,225,.35);
  border-radius: 50%;
  mix-blend-mode: difference;
}
.cursor.is-hot { transform: scale(3.2); background: var(--crimson-hot); mix-blend-mode: normal; }
.cursor-label {
  position: fixed; top: 0; left: 0; z-index: 4001; pointer-events: none;
  font-family: var(--f-mono); font-size: var(--t-micro);
  letter-spacing: .25em; text-transform: uppercase; color: var(--bone);
  transform: translate(16px, 16px);
  opacity: 0; transition: opacity .2s;
}
.cursor-label.on { opacity: 1; }
@media (hover: none), (pointer: coarse) { .cursor, .cursor-ring, .cursor-label { display: none; } }

/* page transition veil */
.veil {
  position: fixed; inset: 0; z-index: 5000; pointer-events: none;
  display: grid; place-items: center;
  background: var(--void);
  clip-path: inset(0 0 100% 0);
  transition: clip-path .65s var(--e-in);
}
.veil.on { clip-path: inset(0 0 0 0); pointer-events: all; }
.veil .veil-tag { font-family: var(--f-mono); font-size: var(--t-meta); letter-spacing: .3em; color: var(--crimson-hot); opacity: 0; transition: opacity .3s .3s; }
.veil.on .veil-tag { opacity: 1; }

/* ------------------------------------------------------------
   05 / PRELOADER
   ------------------------------------------------------------ */
.loader {
  position: fixed; inset: 0; z-index: 6000;
  background: var(--void);
  display: grid; place-items: center;
  transition: clip-path .9s var(--e-in) .2s;
}
.loader.done { clip-path: inset(0 0 100% 0); pointer-events: none; }
.loader-core { text-align: center; }
.loader-kanji {
  font-family: var(--f-jp); font-size: clamp(4rem, 10vw, 8rem);
  color: var(--crimson);
  animation: loaderPulse 1.6s var(--e-slow) infinite;
}
@keyframes loaderPulse { 0%,100% { opacity: .25; } 50% { opacity: 1; } }
.loader-line { font-family: var(--f-mono); font-size: var(--t-meta); letter-spacing: .35em; text-transform: uppercase; color: var(--ash); margin-top: var(--s-2); min-height: 1.2em; }
.loader-bar { width: min(280px, 60vw); height: 1px; background: var(--hairline-strong); margin: var(--s-2) auto 0; overflow: hidden; }
.loader-bar i { display: block; height: 100%; width: 0%; background: var(--crimson-hot); transition: width .3s linear; }

/* ------------------------------------------------------------
   06 / NAVIGATION
   ------------------------------------------------------------ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1500;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.1rem var(--gutter);
  mix-blend-mode: difference;
  transition: transform .5s var(--e-out);
}
.nav.hidden { transform: translateY(-110%); }
.nav-brand { display: flex; align-items: center; gap: .8rem; }
.nav-brand svg { width: 30px; height: 34px; }
.nav-brand .b-name { font-family: var(--f-display); font-size: 1.05rem; letter-spacing: .12em; text-transform: uppercase; }
.nav-brand .b-sub { font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: .3em; color: var(--ash); display: block; }
.nav-links { display: flex; gap: 2.4rem; align-items: center; }
.nav-links a {
  font-family: var(--f-mono); font-size: var(--t-meta);
  letter-spacing: .22em; text-transform: uppercase;
  position: relative; padding: .3rem 0;
}
.nav-links a::after {
  content: ''; position: absolute; left: 0; bottom: 0;
  width: 100%; height: 1px; background: var(--bone);
  transform: scaleX(0); transform-origin: right;
  transition: transform .4s var(--e-out);
}
.nav-links a:hover::after, .nav-links a[aria-current]::after { transform: scaleX(1); transform-origin: left; }
.nav-cart { display: flex; align-items: center; gap: .5rem; }
.nav-cart .count {
  font-family: var(--f-mono); font-size: var(--t-micro);
  border: 1px solid currentColor; padding: .15rem .45rem;
}
.nav-burger { display: none; flex-direction: column; gap: 6px; padding: .5rem; }
.nav-burger span { width: 26px; height: 1px; background: var(--bone); transition: transform .3s var(--e-out), opacity .3s; }

/* mobile menu */
.menu {
  position: fixed; inset: 0; z-index: 1400;
  background: var(--void);
  display: grid; align-content: center; gap: .5rem;
  padding: var(--gutter);
  clip-path: inset(0 0 100% 0);
  pointer-events: none;
  transition: clip-path .6s var(--e-in);
}
.menu.on { clip-path: inset(0); pointer-events: auto; }
.menu a {
  font-family: var(--f-display); text-transform: uppercase;
  font-size: clamp(2.4rem, 10vw, 4.5rem); line-height: 1.05;
  color: var(--bone); opacity: .85;
}
.menu a em { font-family: var(--f-mono); font-style: normal; font-size: var(--t-meta); color: var(--crimson-hot); letter-spacing: .25em; vertical-align: super; margin-right: 1rem; }
.menu .menu-meta { margin-top: var(--s-3); }
@media (max-width: 860px) {
  .nav-links { display: none; }
  .nav-burger { display: flex; }
}

/* status ticker */
.ticker {
  position: relative; overflow: hidden;
  border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline);
  padding: .55rem 0;
  background: var(--vault);
}
.ticker-track { display: flex; gap: 3rem; width: max-content; animation: tick 40s linear infinite; }
.ticker span { font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: .3em; text-transform: uppercase; color: var(--ash); white-space: nowrap; }
.ticker span b { color: var(--crimson-hot); font-weight: 400; }
@keyframes tick { to { transform: translateX(-50%); } }

/* ------------------------------------------------------------
   07 / BUTTONS + LINKS
   ------------------------------------------------------------ */
.btn {
  position: relative; display: inline-flex; align-items: center; gap: .9rem;
  padding: 1.05rem 2.2rem;
  font-family: var(--f-mono); font-size: var(--t-meta);
  letter-spacing: .25em; text-transform: uppercase;
  border: 1px solid var(--hairline-strong);
  background: transparent;
  overflow: hidden;
  transition: color .35s var(--e-out), border-color .35s;
  isolation: isolate;
  will-change: transform;
}
.btn::before {
  content: ''; position: absolute; inset: 0;
  background: var(--crimson);
  transform: scaleY(0); transform-origin: bottom;
  transition: transform .4s var(--e-out);
  z-index: -1;
}
.btn:hover { color: var(--bone); border-color: var(--crimson); }
.btn:hover::before { transform: scaleY(1); }
.btn--solid { background: var(--crimson); border-color: var(--crimson); }
.btn--solid::before { background: var(--bone); }
.btn--solid:hover { color: var(--void); }

.link-line { position: relative; font-family: var(--f-mono); font-size: var(--t-meta); letter-spacing: .22em; text-transform: uppercase; }
.link-line::after {
  content: ''; position: absolute; left: 0; bottom: -3px; width: 100%; height: 1px;
  background: var(--crimson-hot);
  transform: scaleX(0); transform-origin: right; transition: transform .4s var(--e-out);
}
.link-line:hover::after { transform: scaleX(1); transform-origin: left; }

/* ------------------------------------------------------------
   08 / FORMS
   ------------------------------------------------------------ */
.field { position: relative; display: grid; gap: .5rem; }
.field label { font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: .3em; text-transform: uppercase; color: var(--ash); }
.field input, .field textarea {
  background: transparent; border: 0; border-bottom: 1px solid var(--hairline-strong);
  color: var(--bone); font-family: var(--f-body); font-size: 1.05rem;
  padding: .7rem 0;
  transition: border-color .3s;
  border-radius: 0;
}
.field input:focus, .field textarea:focus { outline: none; border-color: var(--crimson-hot); }
.field input::placeholder, .field textarea::placeholder { color: var(--graphite); }

/* ------------------------------------------------------------
   09 / ARTIFACT CARD (museum exhibit)
   ------------------------------------------------------------ */
.artifact {
  position: relative; display: block;
  background: var(--vault);
  border: 1px solid var(--hairline);
  overflow: hidden;
  transition: border-color .4s var(--e-out), transform .6s var(--e-slow);
}
.artifact:hover { border-color: var(--hairline-strong); }
.artifact-stage {
  position: relative; aspect-ratio: 4/4.6;
  display: grid; place-items: center;
  background:
    radial-gradient(ellipse 65% 50% at 50% 38%, rgba(200,204,210,.07), transparent 70%),
    linear-gradient(var(--vault), var(--concrete));
  overflow: hidden;
}
.artifact-stage::before {
  content: ''; position: absolute; left: 12%; right: 12%; bottom: 16%;
  height: 1px; background: var(--hairline-strong);
}
.artifact-stage svg.mark { width: 52%; height: auto; filter: drop-shadow(0 30px 40px rgba(0,0,0,.7)); transition: transform .8s var(--e-slow); }
.artifact:hover .artifact-stage svg.mark { transform: translateY(-4%) scale(1.04) rotate(-1deg); }
.artifact-stage .xh { position: absolute; width: 14px; height: 14px; opacity: .4; }
.xh { position: absolute; width: 14px; height: 14px; }
.xh::before, .xh::after { content: ''; position: absolute; background: var(--ash); }
.xh::before { left: 50%; top: 0; width: 1px; height: 100%; }
.xh::after { top: 50%; left: 0; height: 1px; width: 100%; }
.xh.tl { top: 10px; left: 10px; } .xh.tr { top: 10px; right: 10px; }
.xh.bl { bottom: 10px; left: 10px; } .xh.br { bottom: 10px; right: 10px; }
.artifact-scrim {
  position: absolute; inset: 0;
  display: flex; align-items: flex-end; justify-content: space-between;
  padding: 1rem 1.2rem;
  background: linear-gradient(transparent 55%, rgba(10,10,10,.85));
  opacity: 0; transition: opacity .45s var(--e-out);
}
.artifact:hover .artifact-scrim { opacity: 1; }
.artifact-scrim .t-meta { color: var(--bone); }
.artifact-info { display: flex; justify-content: space-between; align-items: baseline; gap: 1rem; padding: 1.1rem 1.2rem; border-top: 1px solid var(--hairline); }
.artifact-info h3 { font-family: var(--f-display); font-size: 1.15rem; letter-spacing: .06em; text-transform: uppercase; }
.artifact-info .price { font-family: var(--f-mono); font-size: var(--t-meta); color: var(--ash); }
.artifact-tags { display: flex; gap: .6rem; padding: 0 1.2rem 1.1rem; flex-wrap: wrap; }
.artifact-tags span { font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: .2em; color: var(--graphite); border: 1px solid var(--hairline); padding: .25rem .55rem; text-transform: uppercase; }
.artifact .serial {
  position: absolute; top: 12px; right: -34px;
  transform: rotate(90deg); transform-origin: top left;
  font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: .35em; color: var(--graphite);
}

/* classified stamp */
.stamp {
  display: inline-block;
  font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: .3em;
  color: var(--crimson-hot); border: 1px solid var(--crimson-deep);
  padding: .35rem .7rem; text-transform: uppercase;
  transform: rotate(-3deg);
}

/* red hanko seal */
.hanko {
  display: inline-grid; place-items: center;
  width: 3.2rem; height: 3.2rem;
  border: 2px solid var(--seal);
  color: var(--seal);
  font-family: var(--f-jp); font-size: 1.4rem; font-weight: 700;
  transform: rotate(4deg);
}

/* barcode (pure CSS) */
.barcode {
  height: 34px; width: 120px;
  background: repeating-linear-gradient(90deg,
    var(--ash) 0 2px, transparent 2px 5px,
    var(--ash) 5px 6px, transparent 6px 11px,
    var(--ash) 11px 15px, transparent 15px 18px,
    var(--ash) 18px 19px, transparent 19px 23px);
  opacity: .5;
}

/* ------------------------------------------------------------
   10 / REVEAL SYSTEM
   ------------------------------------------------------------ */
.rv { opacity: 0; transform: translateY(36px); transition: opacity var(--d-med) var(--e-out), transform var(--d-med) var(--e-out); }
.rv.in { opacity: 1; transform: none; }
.rv-mask { overflow: hidden; display: block; }
.rv-mask > * { display: inline-block; transform: translateY(110%); transition: transform 1s var(--e-out); }
.rv-mask.in > * { transform: none; }
[data-stagger] > * { transition-delay: calc(var(--i, 0) * 90ms); }

/* no-js / reduced-motion safety: everything visible */
.no-js .rv, .no-js .rv-mask > * { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .rv { opacity: 1; transform: none; }
  .rv-mask > * { transform: none; }
}

/* ------------------------------------------------------------
   11 / GLITCH SYSTEM (analog, restrained)
   ------------------------------------------------------------ */
.glitch { position: relative; display: inline-block; }
.glitch::before, .glitch::after {
  content: attr(data-text);
  position: absolute; inset: 0;
  clip-path: inset(50% 0 50% 0);
  opacity: 0;
}
.glitch.play::before {
  animation: gl1 .5s steps(2) 1;
  color: var(--crimson-hot); opacity: .8;
}
.glitch.play::after {
  animation: gl2 .5s steps(3) 1;
  color: var(--chrome-b); opacity: .8;
}
@keyframes gl1 {
  0% { clip-path: inset(10% 0 80% 0); transform: translate(-4px,0); }
  33% { clip-path: inset(60% 0 20% 0); transform: translate(4px,0); }
  66% { clip-path: inset(30% 0 55% 0); transform: translate(-2px,0); }
  100% { clip-path: inset(50% 0 50% 0); transform: none; }
}
@keyframes gl2 {
  0% { clip-path: inset(70% 0 10% 0); transform: translate(3px,0); }
  50% { clip-path: inset(15% 0 70% 0); transform: translate(-3px,0); }
  100% { clip-path: inset(50% 0 50% 0); transform: none; }
}
.flicker { animation: flick 7s linear infinite; }
@keyframes flick {
  0%, 97%, 100% { opacity: 1; }
  97.5% { opacity: .4; } 98% { opacity: 1; } 98.5% { opacity: .6; } 99% { opacity: 1; }
}

/* ------------------------------------------------------------
   12 / FOOTER
   ------------------------------------------------------------ */
.footer { background: var(--vault); border-top: 1px solid var(--hairline); padding: var(--s-5) 0 var(--s-3); position: relative; overflow: hidden; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--s-3); }
.footer h4 { font-family: var(--f-mono); font-size: var(--t-micro); letter-spacing: .3em; text-transform: uppercase; color: var(--graphite); margin-bottom: 1.2rem; }
.footer li { margin-bottom: .55rem; }
.footer li a { font-size: .9rem; color: var(--ash); transition: color .3s; }
.footer li a:hover { color: var(--bone); }
.footer-ghost {
  font-family: var(--f-display); text-transform: uppercase;
  font-size: clamp(4rem, 13vw, 13rem); line-height: 1;
  color: transparent; -webkit-text-stroke: 1px rgba(232,230,225,.07);
  white-space: nowrap; user-select: none;
  margin-top: var(--s-4);
}
.footer-base { display: flex; justify-content: space-between; align-items: center; gap: 1rem; flex-wrap: wrap; margin-top: var(--s-3); padding-top: var(--s-2); border-top: 1px solid var(--hairline); }
@media (max-width: 860px) { .footer-grid { grid-template-columns: 1fr 1fr; } }

/* ------------------------------------------------------------
   13 / MARQUEE DIVIDER
   ------------------------------------------------------------ */
.mq { overflow: hidden; padding: var(--s-2) 0; border-block: 1px solid var(--hairline); }
.mq-track { display: flex; gap: 4rem; width: max-content; animation: tick 30s linear infinite; }
.mq-track span {
  font-family: var(--f-display); text-transform: uppercase;
  font-size: clamp(1.6rem, 3.4vw, 3rem);
  color: transparent; -webkit-text-stroke: 1px var(--graphite);
  white-space: nowrap;
}
.mq-track span.fill { color: var(--crimson); -webkit-text-stroke: 0; }

/* ------------------------------------------------------------
   14 / TOAST
   ------------------------------------------------------------ */
.toast {
  position: fixed; bottom: 1.5rem; left: 50%; transform: translate(-50%, 200%);
  z-index: 4500;
  background: var(--slate); border: 1px solid var(--hairline-strong);
  border-left: 3px solid var(--crimson);
  padding: .9rem 1.6rem;
  font-family: var(--f-mono); font-size: var(--t-meta); letter-spacing: .18em; text-transform: uppercase;
  transition: transform .5s var(--e-out);
}
.toast.on { transform: translate(-50%, 0); }
