/* ===========================================================
   RY PARTS — Industrial Supply / Shared stylesheet
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Archivo+Black&family=Big+Shoulders+Display:wght@400;600;700;800;900&family=JetBrains+Mono:wght@400;500;700&family=Space+Grotesk:wght@300;400;500;600;700&family=Bebas+Neue&family=Anton&family=Oswald:wght@400;500;700&family=Inter:wght@400;500;600;700&family=Instrument+Serif:ital@0;1&family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,300;1,9..144,400&display=swap');

:root {
  /* Brand */
  --hazard:    #FF5A1F;   /* primary action / accent */
  --hazard-2:  #E64A0F;
  --caution:   #F5C518;   /* secondary accent */
  --blueprint: #1A3A5A;   /* deep utility blue */
  --safety:    #16A34A;   /* in-stock green */
  --danger:    #C81E1E;   /* out of stock */

  /* Neutrals — warm industrial */
  --paper:     #F2EEE3;
  --paper-2:   #E8E2D2;
  --paper-3:   #D9D2BE;
  --concrete:  #BDB7AA;
  --steel:     #6B6B6B;
  --coal:      #0D0D0D;
  --coal-2:    #1A1A1A;
  --coal-3:    #262626;

  /* Theme tokens (light by default) */
  --bg:        var(--paper);
  --bg-2:      var(--paper-2);
  --bg-3:      var(--paper-3);
  --ink:       var(--coal);
  --ink-soft:  #3A3A3A;
  --ink-mute:  #6B6B6B;
  --line:      var(--coal);
  --card:      #FFFFFF;
  --card-ink:  var(--coal);

  /* Type */
  --font-display: "Archivo Black", "Anton", Impact, sans-serif;
  --font-display-alt: "Big Shoulders Display", "Archivo Black", Impact, sans-serif;
  --font-serif: "Instrument Serif", "Fraunces", Georgia, serif;
  --font-body: "Space Grotesk", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, monospace;

  /* Density (tweakable) */
  --pad: 24px;
  --pad-sm: 16px;
  --pad-lg: 48px;
  --gap: 20px;
  --radius: 0px;
  --line-w: 2px;
}

[data-theme="dark"] {
  --bg:       #0A0A0A;
  --bg-2:     #131313;
  --bg-3:     #1C1C1C;
  --ink:      #F2EEE3;
  --ink-soft: #D9D2BE;
  --ink-mute: #8A8A8A;
  --line:     #F2EEE3;
  --card:     #131313;
  --card-ink: #F2EEE3;
}

[data-density="compact"] { --pad: 16px; --pad-sm: 10px; --pad-lg: 32px; --gap: 12px; }
[data-density="spacious"] { --pad: 32px; --pad-sm: 22px; --pad-lg: 72px; --gap: 28px; }

/* Font swaps via tweaks */
[data-display="big-shoulders"] { --font-display: "Big Shoulders Display", Impact, sans-serif; }
[data-display="bebas"]         { --font-display: "Bebas Neue", Impact, sans-serif; }
[data-display="anton"]         { --font-display: "Anton", Impact, sans-serif; }
[data-display="oswald"]        { --font-display: "Oswald", Impact, sans-serif; }
[data-body="inter"]            { --font-body: "Inter", system-ui, sans-serif; }
[data-body="jetbrains"]        { --font-body: "JetBrains Mono", monospace; }

/* Palette swaps */
[data-palette="blueprint"] { --hazard: #1B5FA6; --hazard-2: #0F4A85; --caution: #F5C518; }
[data-palette="caution"]   { --hazard: #F5C518; --hazard-2: #D4A810; --caution: #FF5A1F; }
[data-palette="safety"]    { --hazard: #16A34A; --hazard-2: #0F7A38; --caution: #F5C518; }
[data-palette="mono"]      { --hazard: #0D0D0D; --hazard-2: #262626; --caution: #F5C518; }

/* ===========================================================
   Reset / base
   =========================================================== */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--ink);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
input, select, textarea { font: inherit; color: inherit; }
hr { border: none; border-top: var(--line-w) solid var(--line); margin: 0; }

/* Selection */
::selection { background: var(--hazard); color: white; }

/* ===========================================================
   Type
   =========================================================== */
.display { font-family: var(--font-display); text-transform: uppercase; line-height: 0.9; letter-spacing: -0.01em; }
.mono { font-family: var(--font-mono); }
.eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-mute);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.eyebrow::before {
  content: "";
  width: 14px; height: 2px;
  background: var(--hazard);
}
.eyebrow.bare::before { display: none; }

.tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 8px;
  border: 1.5px solid var(--ink);
  background: transparent;
  display: inline-block;
  line-height: 1;
}
.tag.solid { background: var(--ink); color: var(--bg); }
.tag.hazard { background: var(--hazard); color: white; border-color: var(--hazard); }
.tag.caution { background: var(--caution); color: var(--coal); border-color: var(--caution); }
.tag.safety { background: var(--safety); color: white; border-color: var(--safety); }
.tag.danger { background: var(--danger); color: white; border-color: var(--danger); }

/* ===========================================================
   Layout primitives
   =========================================================== */
.container { width: 100%; max-width: 1440px; margin: 0 auto; padding: 0 32px; }
.container-wide { width: 100%; max-width: 1600px; margin: 0 auto; padding: 0 32px; }

.section { padding: var(--pad-lg) 0; }

.stack-sm { display: flex; flex-direction: column; gap: 8px; }
.stack-md { display: flex; flex-direction: column; gap: 16px; }
.stack-lg { display: flex; flex-direction: column; gap: 32px; }

.row { display: flex; align-items: center; gap: var(--gap); }
.row.wrap { flex-wrap: wrap; }
.row.tight { gap: 8px; }

.divider-h { border-top: var(--line-w) solid var(--line); }
.divider-v { border-left: var(--line-w) solid var(--line); }

/* ===========================================================
   Hazard stripes + blueprint patterns
   =========================================================== */
.hazard-bar {
  height: 14px;
  background-image: repeating-linear-gradient(
    -45deg,
    var(--coal) 0 14px,
    var(--caution) 14px 28px
  );
}
.hazard-bar.thin { height: 8px; background-image: repeating-linear-gradient(-45deg, var(--coal) 0 8px, var(--caution) 8px 16px); }
.hazard-bar.hazard {
  background-image: repeating-linear-gradient(-45deg, var(--hazard) 0 14px, var(--coal) 14px 28px);
}

.blueprint-bg {
  background-color: var(--bg);
  background-image:
    linear-gradient(to right, color-mix(in srgb, var(--ink) 8%, transparent) 1px, transparent 1px),
    linear-gradient(to bottom, color-mix(in srgb, var(--ink) 8%, transparent) 1px, transparent 1px);
  background-size: 32px 32px;
}
.blueprint-bg.bold {
  background-image:
    linear-gradient(to right, color-mix(in srgb, var(--ink) 14%, transparent) 1px, transparent 1px),
    linear-gradient(to bottom, color-mix(in srgb, var(--ink) 14%, transparent) 1px, transparent 1px),
    linear-gradient(to right, color-mix(in srgb, var(--ink) 22%, transparent) 1px, transparent 1px),
    linear-gradient(to bottom, color-mix(in srgb, var(--ink) 22%, transparent) 1px, transparent 1px);
  background-size: 32px 32px, 32px 32px, 160px 160px, 160px 160px;
}

.grain {
  position: relative;
  isolation: isolate;
}
.grain::after {
  content: "";
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 1;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.5 0'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.45'/></svg>");
  mix-blend-mode: multiply;
  opacity: 0.18;
}
[data-theme="dark"] .grain::after { mix-blend-mode: screen; opacity: 0.10; }

/* ===========================================================
   Buttons
   =========================================================== */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 22px;
  background: var(--ink);
  color: var(--bg);
  border: var(--line-w) solid var(--ink);
  font-family: var(--font-display);
  font-size: 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: transform .12s ease, background .12s ease;
  cursor: pointer;
  border-radius: var(--radius);
  white-space: nowrap;
}
.btn:hover { background: var(--hazard); border-color: var(--hazard); color: white; transform: translate(-1px, -1px); box-shadow: 3px 3px 0 var(--ink); }
.btn:active { transform: translate(0, 0); box-shadow: none; }

.btn.hazard { background: var(--hazard); border-color: var(--hazard); color: white; }
.btn.hazard:hover { background: var(--coal); border-color: var(--coal); color: var(--bg); box-shadow: 3px 3px 0 var(--hazard); }

.btn.ghost { background: transparent; color: var(--ink); }
.btn.ghost:hover { background: var(--ink); color: var(--bg); }

.btn.sm { padding: 8px 14px; font-size: 12px; }
.btn.lg { padding: 18px 28px; font-size: 16px; }

.btn .arrow { font-family: var(--font-mono); font-weight: 700; font-size: 16px; }

/* ===========================================================
   Cards & borders
   =========================================================== */
.card {
  background: var(--card);
  color: var(--card-ink);
  border: var(--line-w) solid var(--line);
  position: relative;
  border-radius: var(--radius);
}
.card.flat { background: transparent; }

.bordered { border: var(--line-w) solid var(--line); }
.bordered-t { border-top: var(--line-w) solid var(--line); }
.bordered-b { border-bottom: var(--line-w) solid var(--line); }
.bordered-l { border-left: var(--line-w) solid var(--line); }
.bordered-r { border-right: var(--line-w) solid var(--line); }

/* Corner ticks (industrial registration marks) */
.ticked {
  position: relative;
}
.ticked::before,
.ticked::after,
.ticked > .tk1,
.ticked > .tk2 {
  content: "";
  position: absolute;
  width: 12px; height: 12px;
  border: 2px solid var(--ink);
  pointer-events: none;
}
.ticked::before { top: -2px; left: -2px; border-right: none; border-bottom: none; }
.ticked::after { bottom: -2px; right: -2px; border-left: none; border-top: none; }
.ticked > .tk1 { top: -2px; right: -2px; border-left: none; border-bottom: none; }
.ticked > .tk2 { bottom: -2px; left: -2px; border-right: none; border-top: none; }

/* Stamp */
.stamp {
  display: inline-block;
  border: 2px solid currentColor;
  padding: 6px 10px;
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  transform: rotate(-3deg);
  color: var(--hazard);
}

/* ===========================================================
   Form controls
   =========================================================== */
.input, .select, .textarea {
  display: block;
  width: 100%;
  padding: 12px 14px;
  background: var(--bg);
  border: var(--line-w) solid var(--line);
  font-family: var(--font-body);
  font-size: 14px;
  border-radius: var(--radius);
  outline: none;
}
.input:focus, .select:focus, .textarea:focus { background: var(--card); box-shadow: 3px 3px 0 var(--hazard); }
.label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 6px; display: block; }

/* ===========================================================
   Top nav
   =========================================================== */
.topbar {
  background: var(--coal);
  color: #E8E2D2;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
}
.topbar a:hover { color: var(--caution); }
.topbar .row > * { padding: 8px 0; }
.topbar .container { display: flex; justify-content: space-between; align-items: center; gap: 24px; }

.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--bg);
  border-bottom: var(--line-w) solid var(--line);
  backdrop-filter: blur(8px);
}
.nav-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;
  padding: 18px 32px;
  max-width: 1600px;
  margin: 0 auto;
}
.brand { display: flex; align-items: center; gap: 12px; }
.brand-mark {
  width: 44px; height: 44px;
  background: var(--ink);
  color: var(--bg);
  display: grid; place-items: center;
  font-family: var(--font-display);
  font-size: 18px;
  letter-spacing: -0.04em;
  position: relative;
}
.brand-mark::after { content: ""; position: absolute; top: 0; right: 0; width: 0; height: 0; border-style: solid; border-width: 0 10px 10px 0; border-color: transparent var(--hazard) transparent transparent; }
.brand-name { font-family: var(--font-display); font-size: 20px; letter-spacing: -0.01em; line-height: 1; }
.brand-sub { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; color: var(--ink-mute); text-transform: uppercase; }

.menu { display: flex; align-items: center; gap: 28px; justify-content: center; }
.menu a { font-family: var(--font-display); font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; position: relative; padding: 6px 0; }
.menu a:hover { color: var(--hazard); }
.menu a.active::after { content: ""; position: absolute; bottom: -22px; left: 0; right: 0; height: 3px; background: var(--hazard); }

.nav-actions { display: flex; align-items: center; gap: 12px; }
.icon-btn { width: 40px; height: 40px; border: var(--line-w) solid var(--line); display: grid; place-items: center; background: transparent; }
.icon-btn:hover { background: var(--ink); color: var(--bg); }
.icon-btn .badge { position: absolute; top: -6px; right: -6px; background: var(--hazard); color: white; font-family: var(--font-mono); font-size: 10px; padding: 2px 5px; line-height: 1; }
.icon-btn { position: relative; }

/* ===========================================================
   Footer
   =========================================================== */
.footer {
  background: var(--coal);
  color: var(--paper);
}
.footer a { color: var(--paper-3); }
.footer a:hover { color: var(--caution); }
.footer .col-title { font-family: var(--font-display); font-size: 14px; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 18px; color: var(--paper); }
.footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; font-size: 14px; }

/* ===========================================================
   Product card
   =========================================================== */
.pcard {
  background: var(--card);
  color: var(--card-ink);
  border: var(--line-w) solid var(--line);
  display: flex;
  flex-direction: column;
  position: relative;
  transition: transform .15s ease;
}
.pcard:hover { transform: translate(-2px, -2px); box-shadow: 4px 4px 0 var(--ink); }
.pcard .ph {
  aspect-ratio: 1 / 1;
  background: var(--paper-2);
  border-bottom: var(--line-w) solid var(--line);
  position: relative;
  overflow: hidden;
}
.pcard .ph-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, color-mix(in srgb, var(--ink) 10%, transparent) 1px, transparent 1px),
    linear-gradient(to bottom, color-mix(in srgb, var(--ink) 10%, transparent) 1px, transparent 1px);
  background-size: 24px 24px;
}
[data-theme="dark"] .pcard .ph { background: var(--coal-3); }
.pcard .ph-tag { position: absolute; top: 10px; left: 10px; }
.pcard .ph-sku { position: absolute; bottom: 10px; left: 10px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-mute); }
.pcard .body { padding: 14px 16px 16px; display: flex; flex-direction: column; gap: 8px; }
.pcard .brand-row { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-mute); display: flex; justify-content: space-between; }
.pcard h3 { font-family: var(--font-display); font-size: 15px; line-height: 1.15; margin: 0; text-transform: uppercase; letter-spacing: -0.005em; }
.pcard .specs { font-family: var(--font-mono); font-size: 11px; color: var(--ink-soft); display: flex; gap: 10px; flex-wrap: wrap; }
.pcard .price-row { display: flex; align-items: baseline; justify-content: space-between; border-top: 1.5px dashed color-mix(in srgb, var(--ink) 35%, transparent); padding-top: 10px; margin-top: 6px; }
.pcard .price { font-family: var(--font-display); font-size: 18px; }
.pcard .price small { font-family: var(--font-mono); font-size: 10px; color: var(--ink-mute); margin-left: 4px; }
.pcard .add { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; border: 1.5px solid var(--ink); padding: 6px 10px; background: transparent; }
.pcard .add:hover { background: var(--hazard); border-color: var(--hazard); color: white; }
.pcard .stock { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; display: inline-flex; align-items: center; gap: 6px; }
.pcard .stock .dot { width: 8px; height: 8px; border-radius: 50%; }
.pcard .stock.ok .dot { background: var(--safety); box-shadow: 0 0 0 2px color-mix(in srgb, var(--safety) 30%, transparent); }
.pcard .stock.low .dot { background: var(--caution); }
.pcard .stock.out .dot { background: var(--danger); }

/* ===========================================================
   Category tile
   =========================================================== */
.cat-tile {
  position: relative;
  border: var(--line-w) solid var(--line);
  background: var(--card);
  padding: 24px;
  min-height: 220px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  overflow: hidden;
  transition: transform .15s;
}
.cat-tile:hover { transform: translate(-2px, -2px); box-shadow: 6px 6px 0 var(--ink); background: var(--coal); color: var(--bg); }
.cat-tile:hover .cat-num { color: var(--hazard); }
.cat-tile .cat-num { font-family: var(--font-display); font-size: 56px; line-height: 1; color: var(--ink-mute); transition: color .15s; }
.cat-tile h3 { font-family: var(--font-display); font-size: 24px; margin: 0; text-transform: uppercase; line-height: 1; letter-spacing: -0.01em; }
.cat-tile p { font-size: 13px; margin: 6px 0 0; color: var(--ink-mute); }
.cat-tile .arrow { font-family: var(--font-mono); font-size: 20px; align-self: flex-end; }
.cat-tile .cat-icon { position: absolute; right: -8px; bottom: -8px; opacity: 0.08; pointer-events: none; }
.cat-tile:hover .cat-icon { opacity: 0.18; color: var(--hazard); }

/* ===========================================================
   Utility
   =========================================================== */
.text-mute { color: var(--ink-mute); }
.text-hazard { color: var(--hazard); }
.text-caution { color: var(--caution); }
.text-center { text-align: center; }
.bg-coal { background: var(--coal); color: var(--paper); }
.bg-paper-2 { background: var(--bg-2); }
.bg-hazard { background: var(--hazard); color: white; }
.bg-caution { background: var(--caution); color: var(--coal); }

.grid { display: grid; gap: var(--gap); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
.grid-6 { grid-template-columns: repeat(6, 1fr); }
.grid-12 { grid-template-columns: repeat(12, 1fr); }

@media (max-width: 1024px) {
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-6 { grid-template-columns: repeat(3, 1fr); }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .menu { display: none; }
  .nav-inner { grid-template-columns: 1fr auto; gap: 12px; }
}
@media (max-width: 640px) {
  .grid-2, .grid-3, .grid-4, .grid-6 { grid-template-columns: 1fr; }
  .container, .container-wide { padding: 0 18px; }
  .nav-inner { padding: 14px 18px; }
}

/* ===========================================================
   Scroll marquee
   =========================================================== */
.marquee {
  background: var(--coal);
  color: var(--paper);
  overflow: hidden;
  border-top: var(--line-w) solid var(--line);
  border-bottom: var(--line-w) solid var(--line);
}
.marquee-track {
  display: flex;
  gap: 48px;
  padding: 14px 0;
  white-space: nowrap;
  animation: marquee 38s linear infinite;
  font-family: var(--font-display);
  font-size: 18px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.marquee-track span { display: inline-flex; align-items: center; gap: 48px; }
.marquee-track span::after { content: "✦"; color: var(--hazard); margin-left: 48px; }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ===========================================================
   Animations
   =========================================================== */
@keyframes fadeUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
.fade-up { animation: fadeUp .5s ease both; }
.fade-up.d1 { animation-delay: .05s; }
.fade-up.d2 { animation-delay: .10s; }
.fade-up.d3 { animation-delay: .15s; }
.fade-up.d4 { animation-delay: .20s; }

/* ===========================================================
   Editorial type — engineering monograph register
   =========================================================== */
.serif { font-family: var(--font-serif); }
.serif-italic { font-family: var(--font-serif); font-style: italic; font-weight: 400; }

.kicker {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.kicker .dot { display: inline-block; width: 5px; height: 5px; background: var(--hazard); margin: 0 8px 2px; vertical-align: middle; }

.dek {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(18px, 1.4vw, 22px);
  line-height: 1.35;
  color: var(--ink-soft);
  max-width: 52ch;
  font-weight: 400;
}

.folio {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

.rule-fine { border-top: 1px solid var(--ink); height: 0; }
.rule-hair { border-top: 1px dashed color-mix(in srgb, var(--ink) 35%, transparent); }

/* Drop-cap for first paragraph */
.has-dropcap::first-letter {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 5.4em;
  line-height: 0.85;
  float: left;
  padding: 4px 12px 0 0;
  color: var(--hazard);
  font-weight: 400;
}

/* Plate header (editorial section headers) */
.plate-head { display: grid; grid-template-columns: auto 1fr auto; align-items: end; gap: 32px; padding-bottom: 18px; border-bottom: 1.5px solid var(--ink); margin-bottom: 36px; }
.plate-head .plate-no { font-family: var(--font-serif); font-style: italic; font-size: clamp(40px, 5vw, 72px); line-height: 0.85; color: var(--hazard); font-weight: 400; }
.plate-head .plate-title { font-family: var(--font-display); font-size: clamp(28px, 3.4vw, 48px); line-height: 0.95; letter-spacing: -0.015em; text-transform: uppercase; margin: 0; }
.plate-head .plate-meta { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; color: var(--ink-mute); text-transform: uppercase; text-align: right; line-height: 1.6; }
@media (max-width: 768px) {
  .plate-head { grid-template-columns: 1fr; gap: 8px; }
  .plate-head .plate-meta { text-align: left; }
}

/* ===========================================================
   Tweaks panel (custom)
   =========================================================== */
.tweaks-fab {
  position: fixed;
  right: 20px; bottom: 20px;
  z-index: 200;
  width: 52px; height: 52px;
  background: var(--ink);
  color: var(--bg);
  border: 2px solid var(--ink);
  display: grid; place-items: center;
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 18px;
}
.tweaks-fab:hover { background: var(--hazard); border-color: var(--hazard); color: white; }
.tweaks-panel {
  position: fixed;
  right: 20px; bottom: 84px;
  z-index: 200;
  width: 320px;
  max-height: 80vh;
  overflow: auto;
  background: var(--card);
  color: var(--card-ink);
  border: 2px solid var(--ink);
  box-shadow: 6px 6px 0 var(--ink);
  padding: 18px;
  display: none;
}
.tweaks-panel.open { display: block; }
.tweaks-panel h4 { font-family: var(--font-display); font-size: 14px; margin: 0 0 12px; text-transform: uppercase; }
.tweaks-panel .section-title { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-mute); margin: 16px 0 8px; }
.tweaks-panel .swatches { display: flex; gap: 6px; }
.tweaks-panel .swatch { width: 32px; height: 32px; border: 2px solid var(--ink); cursor: pointer; }
.tweaks-panel .swatch.active { outline: 2px solid var(--ink); outline-offset: 3px; }
.tweaks-panel .opts { display: flex; flex-wrap: wrap; gap: 4px; }
.tweaks-panel .opt { font-family: var(--font-mono); font-size: 11px; padding: 6px 10px; border: 1.5px solid var(--ink); background: transparent; text-transform: uppercase; letter-spacing: 0.06em; cursor: pointer; }
.tweaks-panel .opt.active { background: var(--ink); color: var(--bg); }
