/* ============================================================
   Grimdark Archive — Adeptus Mechanicus skin
   (Mechanicus cogitator-terminal re-skin of the live catalog)
   ============================================================ */
:root {
  --void:#0B0907; --iron:#15120d; --iron2:#1f1a13; --panel:#16130d;
  --bone:#D7CCB8; --bone-dim:#9C9079; --ink:#D7CCB8; --muted:#8f8576;
  --brass:#C49A4A; --brass-lo:#7A5C28; --copper:#A65B33; --rust:#8E3B22; --signal:#C13A1E;
  --crt:#5FE0A0; --crt-dim:#2f7a56; --holo:#E8A33D;
  --line:rgba(196,154,74,.18); --line-2:rgba(196,154,74,.10);
  --gold:var(--brass); --gold-dim:var(--brass-lo); --danger:var(--signal);
  --mono:'IBM Plex Mono',ui-monospace,monospace;
  --display:'Teko',sans-serif; --ui:'Oswald',sans-serif; --body:'Spectral',Georgia,serif;
  --hazard:repeating-linear-gradient(45deg,#C49A4A 0 10px,#1a1610 10px 20px);
  --grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
* { box-sizing: border-box; }
.hidden { display: none !important; }
html, body { margin: 0; }
body {
  background: var(--void);
  background-image:
    radial-gradient(circle at 50% -8%, rgba(196,154,74,.06), transparent 55%),
    radial-gradient(circle at 92% 108%, rgba(166,91,51,.08), transparent 45%);
  color: var(--ink);
  font-family: var(--body);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  padding-bottom: 40px;
}
.wrap { max-width: 1180px; margin: 0 auto; padding: 0 20px; }
a { color: var(--brass); }

/* ===== themed cogitator chrome: text selection + scrollbars ===== */
::selection { background: rgba(95,224,160,.26); color: #eafff4; text-shadow: 0 0 6px rgba(95,224,160,.5); }
* { scrollbar-width: thin; scrollbar-color: var(--brass-lo) transparent; }
::-webkit-scrollbar { width: 11px; height: 11px; }
::-webkit-scrollbar-track { background: #0c0a07; }
::-webkit-scrollbar-thumb { background: linear-gradient(180deg,#7a5c28,#473515); border: 3px solid #0c0a07; border-radius: 6px; }
::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg,var(--brass),#6b5024); }
::-webkit-scrollbar-corner { background: #0c0a07; }

/* ===== global CRT atmosphere ===== */
.crt-ov { position: fixed; inset: 0; z-index: 8; pointer-events: none; }
.crt-ov::before { content:""; position:absolute; inset:0; background:repeating-linear-gradient(0deg,rgba(95,224,160,.022) 0 1px,transparent 1px 3px); }
.crt-ov::after { content:""; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 46%,transparent 58%,rgba(0,0,0,.22) 100%); box-shadow:inset 0 0 120px rgba(0,0,0,.38); }
.crt-flick { position: fixed; inset: 0; z-index: 9; pointer-events: none; background: rgba(120,235,180,.016); opacity: 0; animation: crtglobal 7s steps(1) infinite; }
@keyframes crtglobal { 0%,95%,100%{opacity:0} 96%{opacity:.5} 97%{opacity:0} 98%{opacity:.7} 99%{opacity:.2} }

/* ===== boot sequence (first visit) ===== */
.boot { position: fixed; inset: 0; z-index: 200; background: radial-gradient(circle at 50% 45%,#0e0c09,#060504 80%);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 16px;
  font-family: var(--mono); color: var(--crt); transition: opacity .55s ease; }
.boot[hidden] { display: none; }
.boot.done { opacity: 0; pointer-events: none; }
.boot .bcog { width: 84px; height: 84px; filter: drop-shadow(0 0 16px rgba(95,224,160,.45)); animation: bootspin 1.7s cubic-bezier(.2,.8,.2,1) both; }
@keyframes bootspin { 0%{transform:rotate(-260deg) scale(.5);opacity:0} 60%{opacity:.95} 100%{transform:rotate(0) scale(1);opacity:.92} }
.boot .blines { font-size: 11px; line-height: 2; letter-spacing: .06em; text-align: left; min-width: 340px; text-shadow: 0 0 6px rgba(95,224,160,.5); }
.boot .blines b { color: var(--bone); }
.boot .blines span { opacity: 0; animation: bln .25s steps(1) forwards; }
.boot .blines span:nth-of-type(1){animation-delay:.25s}.boot .blines span:nth-of-type(2){animation-delay:.6s}
.boot .blines span:nth-of-type(3){animation-delay:.95s}.boot .blines span:nth-of-type(4){animation-delay:1.25s}
@keyframes bln { to { opacity: 1; } }
.boot .bbar { width: 340px; height: 4px; background: #0d100e; border: 1px solid var(--crt-dim); overflow: hidden; }
.boot .bbar i { display: block; height: 100%; width: 0; background: linear-gradient(90deg,var(--crt-dim),var(--crt)); box-shadow: 0 0 8px rgba(95,224,160,.6); animation: bootbar 1.5s ease-out forwards; }
@keyframes bootbar { to { width: 100%; } }
.boot .commune { font-size: 9px; letter-spacing: .18em; color: var(--crt-dim); animation: blink 1.1s steps(1) infinite; }

/* ===== cogitator status bar + hazard ===== */
.statusbar { font-family: var(--mono); font-size: 11px; letter-spacing: .04em; color: var(--crt);
  background: #0d0f0d; border-bottom: 1px solid rgba(95,224,160,.16); padding: 6px 0; text-shadow: 0 0 6px rgba(95,224,160,.35);
  animation: crtflicker 8s infinite steps(1); position: relative; z-index: 6; }
.statusbar .wrap { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 8px; align-items: center; }
/* own row + single line so the rotating CREED can't oscillate header height (layout shift) */
.statusbar .dim { color: var(--crt-dim); flex: 1 0 100%; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.blink { animation: blink 1.1s steps(1) infinite; }
@keyframes blink { 50% { opacity: 0; } }
@keyframes crtflicker { 0%,17%,19%,100%{opacity:1} 18%{opacity:.6} 43%{opacity:.85} 45%{opacity:1} 77%{opacity:.72} 79%{opacity:1} }
#creed { transition: opacity .4s ease; color: var(--crt); }
.noos { font-family: var(--mono); color: var(--crt-dim); letter-spacing: .14em; }
.vox { display: inline-flex; align-items: center; gap: 5px; cursor: pointer; border: 1px solid var(--crt-dim); padding: 1px 7px; border-radius: 2px;
  background: transparent; font-family: var(--mono); font-size: 11px; color: var(--crt); letter-spacing: .08em; transition: box-shadow .15s, border-color .15s; user-select: none; text-shadow: inherit; }
.vox:hover { box-shadow: 0 0 11px rgba(95,224,160,.3); }
.vox.muted { color: var(--bone-dim); border-color: #3a342a; text-shadow: none; }
.vox-spk { width: 13px; height: 13px; flex: none; }
.vox-spk .wave { transition: opacity .15s; }
.vox.muted .vox-spk .wave { opacity: 0; }
.hazard { height: 6px; background: var(--hazard); background-size: 28.3px 28.3px; opacity: .85; animation: march 1.1s linear infinite; position: relative; z-index: 6; }
@keyframes march { to { background-position: 28.3px 0; } }

/* ===== masthead ===== */
.site-header { position: relative; background: linear-gradient(180deg,#13110c 0%,#0b0907 100%); border-bottom: 1px solid var(--line); padding: 22px 0 18px; overflow: hidden; }
/* faint machine-panel schematic grid, lit near the cog-skull and fading out */
.site-header::before { content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none; opacity: .6;
  background-image:
    repeating-linear-gradient(90deg, rgba(196,154,74,.05) 0 1px, transparent 1px 56px),
    repeating-linear-gradient(0deg,  rgba(196,154,74,.035) 0 1px, transparent 1px 56px);
  -webkit-mask-image: radial-gradient(125% 135% at 16% 0%, #000 10%, transparent 70%);
          mask-image: radial-gradient(125% 135% at 16% 0%, #000 10%, transparent 70%); }
.header-grid { position: relative; z-index: 1; display: flex; justify-content: space-between; align-items: flex-start; gap: 20px; flex-wrap: wrap; }
.header-titles { min-width: 0; flex: 1 1 360px; }
.brand { display: flex; align-items: center; gap: 16px; }
.brand .seal-mark { width: 56px; height: 56px; position: relative; flex: none; filter: drop-shadow(0 2px 4px rgba(0,0,0,.6)); }
.brand .gear, .brand .face { position: absolute; inset: 0; width: 100%; height: 100%; }
.brand:hover .gear { animation: gearspin 2.4s linear infinite; }
@keyframes gearspin { to { transform: rotate(360deg); } }
.site-header h1 { margin: 0; font-family: var(--display); font-weight: 600; font-size: 40px; line-height: .85; letter-spacing: .02em; text-transform: uppercase; color: var(--bone); }
.tag-proto { font-family: var(--mono); font-size: 9px; vertical-align: middle; text-transform: uppercase; letter-spacing: 1.5px;
  color: #14120c; background: var(--brass); padding: 2px 6px; border-radius: 2px; }
.tagline { margin: 7px 0 0; color: var(--bone-dim); font-size: 14.5px; font-style: italic; max-width: 640px; }
.tagline em { color: var(--brass); font-style: italic; }

/* SSO intent buttons */
.sso { text-align: right; }
.sso-label { display: block; font-family: var(--mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--bone-dim); margin-bottom: 7px; }
.sso-label em { color: var(--brass); font-style: normal; }
.sso-row { display: flex; gap: 6px; flex-wrap: wrap; justify-content: flex-end; }
.sso-btn { display: inline-flex; align-items: center; gap: 6px; font-family: var(--ui); text-transform: uppercase; letter-spacing: .06em; font-size: 11px; padding: 6px 10px; border-radius: 2px; border: 1px solid var(--brass-lo); background: #0e0c09; color: var(--bone-dim); cursor: pointer; transition: border-color .15s, color .15s, box-shadow .15s; }
.sso-btn:hover { border-color: var(--crt-dim); color: var(--bone); box-shadow: 0 0 10px rgba(95,224,160,.12); }
.sso-btn.interested { background: var(--brass); color: #14120c; border-color: var(--brass); font-weight: 600; }
.sso-ico { display: inline-flex; width: 15px; height: 15px; align-items: center; justify-content: center; }
.sso-ico svg { width: 15px; height: 15px; }
.sso-ico-g { font-weight: 700; color: #e9c97a; } .sso-ico-a { font-weight: 700; color: #e9c97a; }

/* ===== controls (sticky) ===== */
.controls-sticky { position: sticky; top: 0; z-index: 30; background: rgba(11,9,7,.96); border-bottom: 1px solid var(--line); box-shadow: 0 6px 16px rgba(0,0,0,.35); backdrop-filter: blur(3px); }
.controls { padding: 14px 20px 10px; }
.search-wrap { position: relative; margin-bottom: 10px; }
/* scanning underline that sweeps in when the data-vault is being interrogated */
.search-wrap::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 1px; width: 0; margin: 0 auto;
  background: linear-gradient(90deg,transparent,var(--crt),transparent); box-shadow: 0 0 8px rgba(95,224,160,.5);
  opacity: 0; transition: width .35s ease, opacity .2s ease; pointer-events: none; z-index: 3; }
.search-wrap:focus-within::after { width: 100%; opacity: 1; }
.search-wrap::before { content: ">"; position: absolute; left: 13px; top: 11px; color: var(--crt); font-family: var(--mono); font-weight: 600; z-index: 2; animation: blink 1.1s steps(1) infinite; }
#search { width: 100%; padding: 11px 14px 11px 30px; font-size: 14px; color: var(--bone); background: #0e0c09; border: 1px solid var(--brass-lo); border-radius: 2px; font-family: var(--mono); }
#search::placeholder { color: var(--bone-dim); }
#search:focus { outline: none; border-color: var(--crt-dim); box-shadow: 0 0 0 1px rgba(95,224,160,.22), 0 0 16px rgba(95,224,160,.1); }
.control-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin-top: 6px; }
.spacer { flex: 1 1 auto; }
.toggle { font-family: var(--ui); text-transform: uppercase; letter-spacing: .05em; font-size: 11px; color: var(--bone-dim); cursor: pointer; white-space: nowrap; display: inline-flex; align-items: center; gap: 6px; }
.toggle input { accent-color: var(--crt); }
select { font-family: var(--ui); text-transform: uppercase; letter-spacing: .04em; font-size: 11px; color: var(--bone); border: 1px solid var(--brass-lo); border-radius: 2px;
  appearance: none; -webkit-appearance: none; -moz-appearance: none; cursor: pointer; padding: 7px 26px 7px 9px;
  background-color: #0e0c09; background-repeat: no-repeat; background-position: right 9px center;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' fill='none' stroke='%23C49A4A' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); transition: border-color .15s, box-shadow .15s; }
select:hover { border-color: var(--crt-dim); }
select:focus-visible { outline: 2px solid var(--crt); outline-offset: 2px; }
.filters-toggle { display: none; font-family: var(--ui); text-transform: uppercase; letter-spacing: .05em; font-size: 11px; cursor: pointer; padding: 7px 12px; border-radius: 2px; border: 1px solid var(--brass-lo); background: #0e0c09; color: var(--bone); white-space: nowrap; }
.filters-toggle:hover { border-color: var(--crt-dim); }
.count { color: var(--bone-dim); font-size: 11px; font-family: var(--mono); letter-spacing: .04em; margin: 11px 0 0; }

/* My Collection quick toggle */
.collection-toggle { display: inline-flex; align-items: center; gap: 7px; font-family: var(--ui); text-transform: uppercase; letter-spacing: .05em; font-size: 11px; cursor: pointer; padding: 7px 11px; border-radius: 2px; border: 1px solid var(--brass-lo); background: #0e0c09; color: var(--bone-dim); white-space: nowrap; transition: border-color .15s, color .15s, background .15s, box-shadow .15s; }
.collection-toggle:hover { border-color: var(--crt-dim); color: var(--bone); }
.collection-toggle .seal-dot { width: 11px; height: 11px; border-radius: 50%; background: radial-gradient(circle at 38% 32%, #c23a2d, #6c110c 72%); box-shadow: inset 0 0 0 1px rgba(0,0,0,.45), 0 0 4px rgba(150,30,22,.5); flex: none; }
.collection-toggle .cc { font-family: var(--mono); font-variant-numeric: tabular-nums; background: rgba(196,154,74,.16); color: var(--brass); border-radius: 2px; padding: 0 5px; font-size: 10px; }
.collection-toggle.active { background: var(--brass); color: #14120c; border-color: var(--brass); font-weight: 600; }
.collection-toggle.active .cc { background: rgba(20,18,12,.22); color: #14120c; }
.collection-toggle:focus-visible { outline: 2px solid var(--crt); outline-offset: 2px; }

/* query cogitation state */
.qstatus { font-family: var(--mono); font-size: 11px; letter-spacing: .05em; color: var(--bone-dim); height: 0; margin: 0; opacity: 0; overflow: hidden; display: flex; align-items: center; gap: 7px; transition: opacity .2s ease, height .2s ease, margin .2s ease; }
.qstatus.busy, .qstatus.done { height: 17px; margin-top: 9px; opacity: 1; }
.qstatus .spin { color: var(--crt); display: inline-block; width: 9px; text-align: center; text-shadow: 0 0 6px rgba(95,224,160,.55); }
.qstatus .hx { color: var(--crt-dim); letter-spacing: .1em; }
.qstatus.done { color: var(--crt); text-shadow: 0 0 6px rgba(95,224,160,.3); }
.qstatus.done b { color: var(--bone); font-weight: 600; }

/* applied-filter chips */
.applied { display: flex; flex-wrap: wrap; gap: 6px; }
.applied:empty { display: none; }
.applied-chip { font-family: var(--ui); text-transform: uppercase; letter-spacing: .06em; font-size: 10px; padding: 5px 10px; border: 1px solid var(--brass-lo); background: rgba(196,154,74,.08); color: var(--bone); cursor: pointer;
  border-radius: 2px; transition: border-color .15s, box-shadow .15s; }
.applied-chip:hover { border-color: var(--crt-dim); box-shadow: inset 0 0 10px rgba(95,224,160,.12); }
.applied-clear { font-family: var(--ui); text-transform: uppercase; letter-spacing: .06em; font-size: 10px; padding: 4px 8px; background: none; border: none; color: var(--brass); cursor: pointer; }
.applied-clear:hover { color: var(--crt); }

/* ===== layout: sidebar + results ===== */
.layout { display: grid; grid-template-columns: 232px minmax(0,1fr); gap: 24px; align-items: start; padding-top: 8px; }
#main { min-width: 0; }
.sidebar { position: sticky; top: 132px; align-self: start; max-height: calc(100vh - 150px); overflow: auto;
  background: linear-gradient(180deg,#1c170f 0,var(--iron) 110px); border: 1px solid var(--line); border-top: 2px solid var(--brass-lo); border-radius: 3px; padding: 13px 16px 14px;
  box-shadow: inset 0 1px 0 rgba(196,154,74,.12), 0 8px 22px rgba(0,0,0,.32); }
.sidebar-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px solid var(--brass-lo); font-family: var(--ui); text-transform: uppercase; letter-spacing: .08em; font-size: 12px; color: var(--bone); }
.sidebar-head span::before { content: "\25A3"; color: var(--crt-dim); margin-right: 6px; }
.sidebar-head span { font-weight: 600; }
.facet-group { margin-bottom: 18px; }
.facet-group h3 { font-family: var(--ui); font-size: 11px; text-transform: uppercase; letter-spacing: .12em; color: var(--brass); margin: 0 0 8px; font-weight: 600; }
.facet-group h3::before { content: "\25B8"; color: var(--crt-dim); margin-right: 5px; font-size: 9px; vertical-align: 1px; }
.facet-item { display: flex; align-items: center; gap: 8px; font-family: var(--ui); font-size: 12px; letter-spacing: .02em; color: var(--bone); padding: 3px 6px; margin: 0 -6px; border-radius: 2px; cursor: pointer; transition: background .12s, color .12s; }
.facet-item:hover { background: rgba(196,154,74,.09); color: var(--bone); }
.facet-item:hover .facet-count { color: var(--brass); }
.facet-item input { width: 14px; height: 14px; accent-color: var(--crt); cursor: pointer; margin: 0; flex: 0 0 auto; }
.facet-label { flex: 1 1 auto; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.facet-count { color: var(--bone-dim); font-size: 10px; font-family: var(--mono); font-variant-numeric: tabular-nums; flex: 0 0 auto; }
.facet-search { width: 100%; padding: 6px 8px; font-size: 12px; font-family: var(--mono); color: var(--bone); background: #0e0c09; border: 1px solid var(--brass-lo); border-radius: 2px; margin-bottom: 6px; }
.facet-search:focus { outline: none; border-color: var(--crt-dim); }
.facet-list { max-height: 240px; overflow: auto; }
.facet-empty, .facet-more { font-family: var(--mono); font-size: 11px; margin: 4px 0 0; }

/* ===== grid + cards ===== */
.grid { display: grid; gap: 20px; padding: 18px 0 24px; grid-template-columns: repeat(auto-fill,minmax(150px,1fr)); }
.card { position: relative; cursor: pointer; display: flex; flex-direction: column; gap: 0; background: none; border: none; transition: transform .18s ease; }
.card:hover { transform: translateY(-3px); }
.card:focus-visible { outline: 2px solid var(--crt); outline-offset: 3px; }

.cover-frame { position: relative; aspect-ratio: 2/3; border: 1px solid var(--brass-lo); border-radius: 2px; background: #15110c;
  box-shadow: 0 8px 20px rgba(0,0,0,.5); transition: border-color .2s, box-shadow .2s; }
.cover-frame::after { content: ""; position: absolute; inset: 0; z-index: 2; pointer-events: none; border-radius: 2px;
  box-shadow: inset 0 -46px 38px -30px rgba(0,0,0,.7), inset 0 0 0 1px rgba(196,154,74,.16);
  background: repeating-linear-gradient(0deg,rgba(95,224,160,.04) 0 2px,transparent 2px 4px); }
.card:hover .cover-frame { border-color: var(--brass); box-shadow: 0 10px 26px rgba(0,0,0,.6), 0 0 0 1px rgba(95,224,160,.22), 0 0 22px rgba(95,224,160,.09); }
.card.owned .cover-frame { border-color: var(--brass); }
.cover { width: 100%; aspect-ratio: 2/3; object-fit: cover; display: block; border-radius: 2px; filter: saturate(.94) contrast(1.03); }
.cover-fallback { position: relative; width: 100%; aspect-ratio: 2/3; display: flex; align-items: center; justify-content: center; text-align: center; padding: 12px;
  color: var(--bone-dim); font-family: var(--display); font-size: 19px; line-height: .95; text-transform: uppercase; border-radius: 2px;
  background: linear-gradient(160deg,#241c14,#100b07); }
.cover-frame > .cover-fallback { position: absolute; inset: 0; width: auto; height: auto; aspect-ratio: auto; }
.cover-frame > .cover-fallback::after { content: "// PICT-FEED LOST"; position: absolute; bottom: 12px; left: 0; right: 0; font-family: var(--mono); font-size: 8px; letter-spacing: .1em; color: var(--signal); text-transform: none; }
.detail .cover-fallback { width: 168px; flex-shrink: 0; }
.mini-card .cover-fallback { width: 92px; }

/* PDP / modal datacard header */
.dchead { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; font-family: var(--mono); font-size: 10px; letter-spacing: .07em;
  color: var(--bone-dim); border-bottom: 1px solid var(--line); padding: 0 38px 9px 0; margin: 0 0 10px; }
.dchead .id { color: var(--brass); font-weight: 600; }
.dchead .sp { flex: 1; }
.dchead .ok { color: var(--crt); border: 1px solid var(--crt-dim); padding: 1px 7px; border-radius: 2px; text-shadow: 0 0 6px rgba(95,224,160,.4); white-space: nowrap; }
.dchead .ok-no { color: var(--bone-dim); border-color: var(--brass-lo); text-shadow: none; }

/* corner brackets */
.br { position: absolute; width: 13px; height: 13px; border: 1.5px solid var(--brass); opacity: .9; z-index: 4; transition: border-color .2s, box-shadow .2s; }
.br.tl { top: 5px; left: 5px; border-right: 0; border-bottom: 0; }
.br.brr { bottom: 5px; right: 5px; border-left: 0; border-top: 0; }
/* (no hover glow on the brackets — the lit top-left corner read as a leftover checkbox control) */

/* auspex readout (slides up on hover) */
.auspex { position: absolute; left: 0; right: 0; bottom: 0; z-index: 5; display: flex; justify-content: space-between; gap: 8px;
  font-family: var(--mono); font-size: 8.5px; letter-spacing: .04em; color: var(--crt); padding: 18px 9px 7px;
  background: linear-gradient(0deg,rgba(7,11,9,.95),rgba(7,11,9,.5) 62%,transparent); text-shadow: 0 0 6px rgba(95,224,160,.45);
  transform: translateY(101%); opacity: 0; pointer-events: none; transition: transform .22s ease, opacity .2s ease; border-radius: 0 0 2px 2px; }
.card:hover .auspex { transform: translateY(0); opacity: 1; }
.auspex b { color: var(--bone); font-weight: 500; }

/* owned checkbox */
/* seal toggle = the owned/read control (no checkbox): empty "seal slot" → tap → stamped wax seal */
.seal-toggle { position: absolute; top: -13px; right: -13px; width: 56px; height: 56px; z-index: 7; padding: 0; border: 0;
  background: none; cursor: pointer; overflow: visible; -webkit-tap-highlight-color: transparent; }
.seal-toggle:focus-visible { outline: 2px solid var(--crt); outline-offset: 2px; border-radius: 50%; }
/* empty-seal affordance (the "outline"): dashed slot + faint cog-skull + SEAL, shown when not owned */
.seal-hint { position: absolute; inset: 6px; border-radius: 50%; border: 1.5px dashed var(--brass-lo);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1px;
  color: var(--brass-lo); background: rgba(11,9,7,.45); opacity: 0; transform: rotate(-11deg) scale(.9);
  transition: opacity .18s, transform .18s, border-color .18s, color .18s; }
.hint-skull { width: 44%; height: auto; opacity: .55; }
.hint-tx { font-family: var(--mono); font-size: 7px; letter-spacing: .08em; line-height: 1; }
.card:not(.owned):hover .seal-toggle .seal-hint,
.seal-toggle:focus-visible .seal-hint { opacity: .92; transform: rotate(-11deg) scale(1); border-color: var(--brass); color: var(--brass); }
.seal-toggle.owned .seal-hint { opacity: 0 !important; pointer-events: none; }
@media (hover: none) { .card:not(.owned) .seal-toggle .seal-hint { opacity: .5; } } /* touch: always show the slot */

.card-body { padding: 10px 2px 4px; display: flex; flex-direction: column; gap: 3px; flex: 1; }
.card-title { font-family: var(--display); font-weight: 500; font-size: 18px; line-height: .98; color: var(--bone); text-transform: uppercase; }
.card-title .title-link { color: inherit; text-decoration: none; }
.card-title .title-link:hover { color: var(--brass); }
.card-author { font-family: var(--body); font-style: italic; font-size: 12.5px; color: var(--bone-dim); }
.card-meta { margin-top: auto; display: flex; align-items: center; flex-wrap: wrap; gap: 6px; padding-top: 7px; font-family: var(--mono); }
.badge-rating { font-size: 11px; color: var(--brass); font-weight: 600; }
.badge-rating .rc { color: var(--bone-dim); font-weight: 400; font-size: 10px; }
.badge-rating.low-conf { color: var(--bone-dim); font-weight: 400; }
.badge-year { font-size: 10px; color: var(--bone-dim); }
.setting-pill { font-family: var(--ui); text-transform: uppercase; letter-spacing: .06em; font-size: 9px; color: var(--bone); border: 1px solid var(--brass-lo); border-radius: 2px; padding: 1px 5px; }

/* wax seal owned-badge + stamp interaction (fills the .seal-toggle button) */
.seal.wax { position: absolute; inset: 0; z-index: 2; --rot: -11deg; transform: rotate(var(--rot));
  filter: drop-shadow(0 4px 6px rgba(0,0,0,.72)); pointer-events: none; }
.seal.wax svg { position: relative; z-index: 2; width: 100%; height: 100%; display: block; }
/* purity-seal parchment ribbon (torn, inscribed strip pinned under the wax) */
.seal-paper { position: absolute; z-index: 1; top: 21px; left: 50%; width: 27px; height: 66px; transform: translateX(-50%);
  overflow: hidden;
  background:
    radial-gradient(ellipse at 24% 12%, rgba(126,86,38,.28), transparent 40%),
    radial-gradient(ellipse at 82% 44%, rgba(96,60,24,.32), transparent 46%),
    radial-gradient(ellipse at 40% 92%, rgba(66,40,16,.42), transparent 52%),
    linear-gradient(166deg, #e0cda0 2%, #cbb47e 40%, #b69b67 100%);
  box-shadow: inset 0 0 18px rgba(82,52,20,.6), inset 0 -7px 9px -5px rgba(40,24,9,.7), inset 0 0 5px rgba(36,22,9,.45);
  /* irregular, hand-torn lower edge (ragged, not a clean zigzag) */
  clip-path: polygon(0 0, 100% 0, 100% 83%, 90% 91%, 95% 97%, 80% 93%, 84% 100%, 68% 92%, 62% 99%, 49% 91%, 45% 99%, 33% 93%, 27% 99%, 15% 92%, 9% 98%, 0 89%);
  pointer-events: none; }
.seal-paper::after { content: ""; position: absolute; inset: 0; background-image: var(--grain); background-size: 64px; opacity: .3; mix-blend-mode: multiply; }
/* inked micro-script — illegible at size, reads as a written litany on the parchment */
.sp-ink { position: absolute; left: 2px; right: 2px; top: 38%; bottom: 4px; overflow: hidden;
  font-family: var(--mono); font-weight: 600; font-size: 3.6px; line-height: 1.5; letter-spacing: .2px;
  text-align: center; word-break: break-all; color: rgba(48,31,13,.74); }
.card:hover .seal.wax { transform: rotate(var(--rot)) scale(1.06); }
.seal.wax.stamping { animation: waxstamp .6s cubic-bezier(.18,.85,.3,1) both; transform-origin: 54% 46%; }
@keyframes waxstamp {
  0%{transform:translateY(-48px) rotate(calc(var(--rot) - 4deg)) scale(1.7);opacity:0;filter:drop-shadow(0 20px 11px rgba(0,0,0,.45)) brightness(1.45)}
  46%{opacity:1}
  56%{transform:translateY(3px) rotate(var(--rot)) scale(.83);filter:drop-shadow(0 2px 4px rgba(0,0,0,.75)) brightness(1.1)}
  73%{transform:translateY(0) rotate(var(--rot)) scale(1.08)}
  88%{transform:translateY(0) rotate(var(--rot)) scale(.98)}
  100%{transform:translateY(0) rotate(var(--rot)) scale(1);filter:drop-shadow(0 4px 6px rgba(0,0,0,.72))}
}
.seal.wax.unsealing { animation: waxunseal .24s ease-in forwards; }
@keyframes waxunseal { to { transform: rotate(var(--rot)) scale(.35) translateY(-8px); opacity: 0; } }
.stamp-ring { position: absolute; inset: 4px; border-radius: 50%; pointer-events: none; box-shadow: 0 0 0 0 rgba(196,58,46,0); animation: stampring .5s ease-out .27s both; }
@keyframes stampring { 0%{box-shadow:0 0 0 1px rgba(232,120,96,.7),0 0 16px 5px rgba(255,214,196,.55)} 100%{box-shadow:0 0 0 15px rgba(196,58,46,0),0 0 0 0 rgba(255,214,196,0)} }
/* stamp recoil lives on the cover-frame (not .card) so it can't fight the card's hover
   translateY — that conflict made the tile look like it bumped twice. Single clean press. */
.cover-frame.recoil { animation: recoil .34s cubic-bezier(.22,.72,.3,1); }
@keyframes recoil { 0%{transform:translateY(0)} 45%{transform:translateY(4px) scale(.992)} 100%{transform:translateY(0)} }
.wax-smudge { position: absolute; top: -6px; right: -3px; width: 46px; height: 46px; z-index: 6; pointer-events: none;
  border-radius: 48% 52% 46% 54%/52% 46% 54% 48%; background: radial-gradient(circle at 42% 38%,rgba(150,30,22,.5),rgba(86,15,11,.3) 58%,transparent 74%);
  filter: blur(1.1px); animation: smudgefade 2.6s ease-out forwards; }
@keyframes smudgefade { 0%{opacity:.9} 18%{opacity:.8} 100%{opacity:0} }

/* ===== grouped-by-series view ===== */
.grouped { display: block; padding: 8px 0 60px; }
.series-group { margin-bottom: 28px; }
.series-group-title { font-family: var(--display); text-transform: uppercase; letter-spacing: .03em; font-size: 22px; color: var(--brass); border-bottom: 1px solid var(--line); padding-bottom: 6px; margin: 0 0 14px; }
.series-group-title::before { content: "\25B8"; color: var(--crt-dim); margin-right: 9px; font-size: 16px; vertical-align: 2px; }
.series-group .grid { padding: 0; }

/* ===== detail modal — datacard ===== */
.modal { position: fixed; inset: 0; display: flex; align-items: center; justify-content: center; z-index: 50; }
.modal.hidden { display: none; }
.modal-backdrop { position: absolute; inset: 0; background: rgba(4,3,2,.78); }
.modal-card { position: relative; background: var(--iron); border: 1px solid var(--line); max-width: 660px; width: calc(100% - 32px); max-height: 88vh; overflow: auto; padding: 26px 24px 24px; z-index: 1;
  clip-path: polygon(16px 0,100% 0,100% calc(100% - 16px),calc(100% - 16px) 100%,0 100%,0 16px); }
.modal-topband { position: absolute; left: 0; top: 0; width: 100%; height: 4px; background: var(--hazard); background-size: 28.3px 28.3px; animation: march 1.1s linear infinite; z-index: 2; }
.modal-close { position: absolute; top: 11px; right: 12px; width: 30px; height: 30px; display: flex; align-items: center; justify-content: center;
  background: rgba(9,7,5,.82); border: 1px solid var(--brass-lo); border-radius: 2px; color: var(--bone-dim); font-size: 22px; cursor: pointer; line-height: 1; z-index: 4;
  transition: color .15s, border-color .15s, box-shadow .15s; }
.modal-close:hover { color: var(--signal); border-color: var(--signal); box-shadow: 0 0 10px rgba(193,58,30,.4); }
.detail { display: flex; gap: 22px; align-items: flex-start; }
.detail-cover { width: 168px; aspect-ratio: 2/3; object-fit: cover; flex-shrink: 0; border: 1px solid var(--brass-lo); border-radius: 2px; background: #15110c; align-self: flex-start; box-shadow: 0 8px 20px rgba(0,0,0,.5); }
.detail-main { min-width: 0; flex: 1; }
.detail h2 { margin: 2px 0 4px; font-family: var(--display); font-weight: 600; font-size: 34px; line-height: .86; text-transform: uppercase; color: var(--bone); }
.detail .by { font-family: var(--body); font-style: italic; color: var(--bone-dim); margin: 0 0 12px; font-size: 14.5px; }
.detail .by .more-authors { color: var(--brass); cursor: pointer; }
.detail dl { display: grid; grid-template-columns: auto 1fr; gap: 5px 16px; margin: 0 0 14px; font-family: var(--mono); font-size: 11.5px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 13px 0; }
.detail dt { color: var(--bone-dim); letter-spacing: .04em; text-transform: uppercase; }
.detail dd { margin: 0; color: var(--bone); text-align: right; }
.own-toggle { display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 11px; letter-spacing: .03em; color: var(--crt); cursor: pointer; margin: 0 0 14px; text-shadow: 0 0 6px rgba(95,224,160,.3); }
.own-toggle input { width: 15px; height: 15px; accent-color: var(--signal); cursor: pointer; }
.own-sub { color: var(--bone-dim); text-shadow: none; }
.synopsis { font-size: 14px; line-height: 1.55; color: #c5bba6; margin: 0 0 16px; }
.detail-note { margin-top: 14px; font-size: 12px; color: var(--bone-dim); font-family: var(--mono); }
.actions { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.btn { font-family: var(--ui); text-transform: uppercase; letter-spacing: .06em; font-size: 12px; text-decoration: none; padding: 10px 16px; border-radius: 2px; border: 1px solid var(--brass-lo); color: var(--bone); background: #0e0c09; cursor: pointer; }
.btn:hover { border-color: var(--crt-dim); }
.btn-amazon { font-family: var(--ui); text-transform: uppercase; letter-spacing: .14em; font-weight: 600; font-size: 13px; background: var(--signal); color: #f4e6df; border: none; padding: 13px 24px;
  clip-path: polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px); transition: filter .15s, background .15s; }
.btn-amazon:hover { background: #d94627; filter: drop-shadow(0 0 9px rgba(193,58,30,.5)); }
.affiliate-note { font-family: var(--mono); font-size: 10px; color: var(--bone-dim); margin: 10px 0 0; letter-spacing: .02em; }
.reviews-line { font-family: var(--mono); font-size: 11px; color: var(--bone-dim); margin: 14px 0 0; letter-spacing: .02em; }
.reviews-line a { color: var(--brass); text-decoration: none; }
.reviews-line a:hover { color: var(--crt); }
.review-snip { margin: 12px 0 0; padding: 9px 13px; border-left: 3px solid var(--brass-lo); background: var(--iron2); font-size: 13.5px; color: #c5bba6; }
.review-src { font-family: var(--ui); font-size: 10px; text-transform: uppercase; letter-spacing: .08em; color: var(--brass); margin-right: 6px; }
.review-snip a { color: var(--brass); text-decoration: none; font-family: var(--mono); font-size: 11px; }

/* related carousels */
.related-block { margin-top: 18px; border-top: 1px solid var(--line); padding-top: 14px; }
.related-head-row { display: flex; justify-content: space-between; align-items: baseline; gap: 10px; }
.related-head { font-family: var(--ui); text-transform: uppercase; letter-spacing: .05em; font-size: 12px; color: var(--bone); margin-bottom: 10px; }
.muted { color: var(--bone-dim); font-weight: 400; text-transform: none; letter-spacing: 0; font-family: var(--mono); font-size: 11px; }
.view-all { font-family: var(--ui); text-transform: uppercase; letter-spacing: .05em; font-size: 11px; color: var(--brass); background: none; border: none; cursor: pointer; padding: 0; white-space: nowrap; }
.view-all:hover { color: var(--crt); }
.carousel { display: flex; gap: 12px; overflow-x: auto; padding: 2px 2px 10px; }
.mini-card { flex: 0 0 92px; cursor: pointer; }
.mini-cover { width: 92px; aspect-ratio: 2/3; object-fit: cover; border-radius: 2px; border: 1px solid var(--brass-lo); display: block; background: #15110c; }
.mini-card:hover .mini-cover { border-color: var(--crt-dim); }
.mini-card.current .mini-cover { border-color: var(--brass); box-shadow: 0 0 0 1px var(--brass); }
.mini-title { font-size: 11px; line-height: 1.2; margin-top: 4px; color: var(--bone); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.mini-rating { font-size: 11px; color: var(--brass); font-family: var(--mono); }
.mini-pos { font-size: 10px; color: var(--bone-dim); font-family: var(--mono); }
.empty { color: var(--bone-dim); font-family: var(--mono); }

/* ===== autocomplete ===== */
.autocomplete { position: absolute; left: 0; right: 0; top: 100%; z-index: 45; background: var(--iron); border: 1px solid var(--line); border-radius: 2px; box-shadow: 0 12px 30px rgba(0,0,0,.6); max-height: 380px; overflow: auto; }
.ac-item { display: flex; align-items: center; gap: 10px; padding: 7px 10px; cursor: pointer; border-bottom: 1px solid var(--line-2); font-family: var(--body); }
.ac-item:last-child { border-bottom: none; }
.ac-item.active, .ac-item:hover { background: var(--iron2); }
.ac-cover { width: 30px; height: 45px; object-fit: cover; border-radius: 2px; flex: 0 0 auto; background: #15110c; border: 1px solid var(--brass-lo); }
.ac-item .cover-fallback { position: static; width: 30px; height: 45px; aspect-ratio: auto; padding: 0; font-size: 0; border-radius: 2px; flex: 0 0 auto; }
.ac-item .cover-fallback::after { content: none; }
.ac-text { display: flex; flex-direction: column; min-width: 0; }
.ac-title { font-size: 13.5px; color: var(--bone); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ac-sub { font-family: var(--mono); font-size: 10.5px; color: var(--bone-dim); }
.ac-scope-ico { width: 30px; text-align: center; color: var(--brass); font-size: 15px; flex: 0 0 auto; }

/* ===== lightbox ===== */
.lightbox { position: fixed; inset: 0; z-index: 70; display: flex; align-items: center; justify-content: center; background: rgba(4,3,2,.88); cursor: zoom-out; }
#lightbox-img { max-width: 90vw; max-height: 90vh; object-fit: contain; border-radius: 2px; border: 1px solid var(--brass-lo); box-shadow: 0 12px 40px rgba(0,0,0,.6); }

/* ===== back-to-top + toast ===== */
.to-top { position: fixed; right: 18px; bottom: 18px; z-index: 40; font-family: var(--ui); text-transform: uppercase; letter-spacing: .06em; font-size: 11px; padding: 9px 13px; border-radius: 2px; border: 1px solid var(--brass-lo); background: #0e0c09; color: var(--bone); cursor: pointer; box-shadow: 0 4px 12px rgba(0,0,0,.5); }
.to-top:hover { border-color: var(--crt-dim); }
.to-top.hidden { display: none; }
.toast { position: fixed; left: 50%; bottom: 26px; transform: translateX(-50%); z-index: 60; background: var(--brass); color: #14120c; font-family: var(--ui); text-transform: uppercase; letter-spacing: .06em; font-size: 13px; font-weight: 600; padding: 10px 18px; border-radius: 2px; box-shadow: 0 6px 20px rgba(0,0,0,.5); }
.toast.hidden { display: none; }

/* ===== first-use onboarding coachmark ===== */
.coach { position: absolute; z-index: 100; max-width: 288px; background: var(--iron); border: 1px solid var(--brass); border-radius: 3px; padding: 14px 15px 13px;
  box-shadow: 0 14px 40px rgba(0,0,0,.6), 0 0 0 1px rgba(95,224,160,.16); font-family: var(--body); }
.coach-arrow { position: absolute; top: -8px; left: 16px; width: 13px; height: 13px; background: var(--iron); border-left: 1px solid var(--brass); border-top: 1px solid var(--brass); transform: rotate(45deg); }
.coach-h { font-family: var(--ui); text-transform: uppercase; letter-spacing: .06em; font-size: 12px; color: var(--brass); margin-bottom: 6px; font-weight: 600; }
.coach p { margin: 0 0 12px; font-size: 13px; line-height: 1.5; color: var(--bone); }
.coach p b { color: var(--crt); font-weight: 600; }
.coach .coach-ok { font-size: 11px; padding: 7px 14px; }
.onboard-pulse { animation: onboardpulse 1.4s ease-in-out infinite; border-color: var(--crt) !important; }
@keyframes onboardpulse { 0%,100%{box-shadow:0 0 0 0 rgba(95,224,160,.55)} 50%{box-shadow:0 0 0 6px rgba(95,224,160,0)} }
/* onboarding points at the seal slot — keep it circular + reveal the hint while the coachmark is up */
.seal-toggle.onboard-pulse { border-radius: 50%; }
.seal-toggle.onboard-pulse .seal-hint { opacity: .95; transform: rotate(-11deg) scale(1); border-color: var(--crt); color: var(--crt); }

/* ===== no-results recovery ===== */
/* #grid keeps class="grid" (a CSS grid) even when empty, so the recovery block must
   span all columns — otherwise it's squeezed into one ~150px track (single column). */
.empty-block { padding: 6px 0 50px; grid-column: 1 / -1; }
.empty-block .grid { padding: 10px 0 0; }
.np-card { cursor: pointer; }
.np-card .cover, .np-card .cover-fallback { border: 1px solid var(--brass-lo); border-radius: 2px; }
.np-card:hover .cover { border-color: var(--crt-dim); }
.link-btn { background: none; border: none; padding: 0; color: var(--brass); cursor: pointer; font: inherit; text-decoration: underline; }
.loadmore-wrap { display: flex; justify-content: center; padding: 8px 0 50px; }
#load-more { min-width: 200px; text-align: center; }

/* ===== homepage browse (static, crawlable SEO block above the footer) ===== */
.site-browse { margin: 34px auto 0; padding: 26px 20px 0; border-top: 1px solid var(--line); }
.site-browse > h2 { font-family: var(--ui); text-transform: uppercase; letter-spacing: .14em; font-size: 14px; color: var(--brass); margin: 0 0 16px; }
.browse-cols { display: flex; flex-wrap: wrap; gap: 24px 60px; }
.browse-cols h3 { font-family: var(--mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); margin: 0 0 8px; }
.browse-cols ul { list-style: none; margin: 0 0 14px; padding: 0; }
.browse-cols li { padding: 3px 0; font-family: var(--ui); }
.browse-cols a { color: var(--ink); text-decoration: none; }
.browse-cols a:hover { color: var(--brass); }
.browse-blurb { max-width: 80ch; margin: 20px 0 0; font-family: var(--body); color: var(--muted); font-size: 14px; line-height: 1.65; }

/* ===== footer ===== */
.site-footer { padding: 26px 20px 50px; color: var(--bone-dim); font-size: 12px; font-family: var(--mono); letter-spacing: .02em; border-top: 1px solid var(--line); margin-top: 30px; }
.site-footer p { margin: 0 0 8px; max-width: 900px; line-height: 1.6; }
.footer-disclaimer { color: var(--bone-dim); }
.footer-links { margin-top: 12px; }
.footer-links a, .site-footer a { color: var(--brass); text-decoration: none; }
.footer-links a:hover, .site-footer a:hover { color: var(--crt); }

/* ===== legal / disclaimer page ===== */
.legal { max-width: 760px; margin: 0 auto; padding: 40px 20px 80px; font-family: var(--body); }
.legal .back-link { color: var(--brass); text-decoration: none; font-family: var(--mono); font-size: 12px; }
.legal .back-link:hover { color: var(--crt); }
.legal h1 { font-family: var(--display); font-size: 36px; text-transform: uppercase; color: var(--bone); margin: 16px 0 4px; letter-spacing: .02em; }
.legal .updated { color: var(--bone-dim); font-family: var(--mono); font-size: 12px; margin: 0 0 28px; }
.legal h2 { font-family: var(--ui); text-transform: uppercase; letter-spacing: .05em; font-size: 17px; color: var(--brass); margin: 30px 0 8px; }
.legal p, .legal li { color: var(--bone-dim); font-size: 14px; line-height: 1.65; }
.legal a { color: var(--brass); text-decoration: none; }
.legal a:hover { color: var(--crt); }
.legal ul { padding-left: 20px; margin: 8px 0; }
.legal li { margin: 4px 0; }
.legal .legal-foot { margin-top: 40px; padding-top: 16px; border-top: 1px solid var(--line); color: var(--bone-dim); font-size: 12px; }

/* ===== image loading shimmer ===== */
@keyframes shimmer { 0% { background-position: -200px 0; } 100% { background-position: 200px 0; } }
.cover, .detail-cover, .mini-cover, .ac-cover { background-color: #110d09; background-image: linear-gradient(90deg,#110d09 0px,#16231b 78px,#241d12 84px,#110d09 160px); background-size: 200px 100%; animation: shimmer 1.15s linear infinite; }

/* ===== keyboard focus ===== */
.np-card:focus-visible, .applied-chip:focus-visible, .sso-btn:focus-visible, .mini-card:focus-visible, .view-all:focus-visible { outline: 2px solid var(--crt); outline-offset: 2px; }

/* ===== responsive ===== */
@media (max-width: 860px) {
  .layout { grid-template-columns: 1fr; }
  .filters-toggle { display: inline-block; }
  .sidebar { position: static; max-height: none; display: none; margin-bottom: 18px; }
  .sidebar.open { display: block; }
}
@media (max-width: 560px) {
  .detail { flex-direction: column; }
  .detail-cover { width: 140px; }
  .header-grid { flex-direction: column; }
  .sso, .sso-row { text-align: left; justify-content: flex-start; }
  .site-header h1 { font-size: 32px; }
}

/* ---------- audio dramas: square art letterboxed in the 2:3 frame + format badge ---------- */
.cover.is-audio, .detail-cover.is-audio, .np-card .cover.is-audio,
.mini-cover.is-audio, .ac-cover.is-audio { object-fit: contain; background: #0c0a07; }
.fmt-badge { position: absolute; top: 6px; left: 6px; z-index: 5; font-family: var(--mono);
  font-size: 8.5px; letter-spacing: .14em; padding: 2px 6px; border-radius: 2px;
  background: rgba(10,9,6,.84); color: var(--crt); border: 1px solid var(--crt-dim);
  text-shadow: 0 0 6px rgba(95,224,160,.45); pointer-events: none; }

@media (prefers-reduced-motion: reduce) { * { animation: none !important; } }
