/* the cards gallery + cross-deck compare pages. Zero JavaScript: filtering is
   pure CSS (:has() + radio :checked). Loads after home.css and reuses its tokens. */
.cards-main,.arch-main{max-width:1460px;margin:0 auto;padding:clamp(1.4rem,4vw,3rem) var(--margin) 5rem}
.cards-hero,.arch-hero{margin-bottom:clamp(1.4rem,3vw,2.4rem)}
.cards-title,.arch-title{font-family:'Anton',sans-serif;font-weight:400;line-height:1.02;
  text-transform:uppercase;letter-spacing:.01em;font-size:var(--s-3)}
.cards-kicker,.arch-line{color:var(--muted);font-size:var(--s-0);margin-top:.4rem}

/* facets */
.facets{display:flex;flex-direction:column;gap:.7rem;margin:0 0 clamp(1.4rem,3vw,2.2rem)}
.facet-row{display:flex;flex-wrap:wrap;gap:.5rem}
.cf-radio{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}
.chip{display:inline-flex;align-items:center;gap:.45em;cursor:pointer;
  padding:.42rem .85rem;border:1px solid var(--hair);border-radius:999px;
  font-size:var(--s--1);font-weight:600;letter-spacing:.04em;color:var(--muted);
  background:color-mix(in srgb,var(--bg2) 60%,transparent);transition:color .15s,border-color .15s,background .15s}
.chip:hover{color:var(--ink)}
.chip-n{font-size:.82em;opacity:.7}
.cf-radio:checked+.chip{color:var(--ink);border-color:color-mix(in srgb,var(--accent,#fff) 70%,transparent);
  background:color-mix(in srgb,var(--accent,#fff) 16%,transparent)}
.cf-radio:focus-visible+.chip{outline:3px solid var(--focus);outline-offset:3px}

/* the gallery grid */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  gap:clamp(.8rem,1.6vw,1.4rem)}
.cards-empty{color:var(--muted);font-size:var(--s-1)}
.tile{position:relative;display:flex;flex-direction:column}
.tile-link{display:flex;flex-direction:column;gap:.4rem}
.tile-link img{aspect-ratio:940/1401;object-fit:cover;border-radius:8px;
  border:1px solid color-mix(in srgb,var(--accent,#888) 38%,transparent);
  box-shadow:0 3px 16px rgba(0,0,0,.42)}
.tile-name{font-weight:600;font-size:var(--s--1);color:var(--ink);line-height:1.2}
.tile-deck{font-family:var(--wm,'Anton',sans-serif);font-size:var(--s--2);letter-spacing:.08em;
  text-transform:uppercase;color:color-mix(in srgb,var(--accent,#fff) 85%,var(--ink))}
.tile-six{align-self:flex-start;margin-top:.25rem;font-size:var(--s--2);letter-spacing:.05em;
  text-transform:uppercase;color:var(--muted)}
.tile-six:hover{color:var(--accent,#fff)}

/* type facet rules (deck rules are injected per-render as an inline <style>) */
.cards-main:has(#f-type-major:checked) .tile:not(.c-type-major){display:none}
.cards-main:has(#f-type-cups:checked) .tile:not(.c-type-cups){display:none}
.cards-main:has(#f-type-pentacles:checked) .tile:not(.c-type-pentacles){display:none}
.cards-main:has(#f-type-swords:checked) .tile:not(.c-type-swords){display:none}
.cards-main:has(#f-type-wands:checked) .tile:not(.c-type-wands){display:none}

/* compare page: the standing meaning + the six-deck grid */
.arch-back{margin-bottom:1rem;font-size:var(--s--1);color:var(--muted)}
.arch-back a:hover{color:var(--ink)}
.arch-meaning{display:grid;gap:clamp(1rem,2.4vw,1.8rem);grid-template-columns:minmax(0,1fr);
  margin:0 0 clamp(1.6rem,3.5vw,2.6rem)}
@media(min-width:680px){.arch-meaning{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}}
.arch-m{border:1px solid var(--hair);border-radius:12px;padding:clamp(1rem,2.5vw,1.4rem);
  background:color-mix(in srgb,var(--bg2) 45%,transparent)}
.arch-m-tag{display:block;font-size:var(--s--2);letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.arch-m-kw{display:block;font-weight:600;color:var(--ink);margin:.3rem 0 .5rem}
.arch-m p{color:var(--muted)}
.arch-grid{display:grid;gap:clamp(.7rem,1.6vw,1.3rem);
  grid-template-columns:repeat(2,minmax(0,1fr))}
@media(min-width:620px){.arch-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(min-width:980px){.arch-grid{grid-template-columns:repeat(6,minmax(0,1fr))}}
.cell{display:flex;flex-direction:column;gap:.4rem}
.cell-img{position:relative;aspect-ratio:940/1401;border-radius:8px;overflow:hidden;
  border:1px solid color-mix(in srgb,var(--accent,#888) 40%,transparent)}
.cell-img img{width:100%;height:100%;object-fit:cover}
.cell-img img.reversed{transform:rotate(180deg)}
.cell-deck{font-family:var(--wm,'Anton',sans-serif);font-size:var(--s--2);letter-spacing:.08em;
  text-transform:uppercase;color:color-mix(in srgb,var(--accent,#fff) 85%,var(--ink))}
.cell-date{display:block;font-size:var(--s--2);color:var(--muted)}

/* coming-soon placeholder: dimmed card-back, deck-voiced label, thin full border */
.cell--soon .cell-img{border-color:color-mix(in srgb,var(--accent,#888) 26%,transparent);
  background:color-mix(in srgb,var(--bg2) 70%,var(--bg))}
.soon-back{opacity:.3;filter:grayscale(.5)}
.soon-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:.4rem;text-align:center;padding:.8rem}
.soon-eyebrow{font-size:var(--s--2);letter-spacing:.18em;text-transform:uppercase;
  color:color-mix(in srgb,var(--accent,#fff) 70%,var(--muted))}
.soon-name{font-family:var(--wm,'Anton',sans-serif);font-size:var(--s-0);line-height:1.1;
  color:color-mix(in srgb,var(--accent,#fff) 60%,var(--ink))}

/* 'browse by' nav at the foot of the gallery: crawlable links to every facet page */
.cards-browse{margin-top:clamp(2rem,5vw,3.5rem);padding-top:clamp(1.4rem,3vw,2.2rem);
  border-top:1px solid var(--hair);display:flex;flex-direction:column;gap:.9rem}
.cb-group{display:flex;flex-wrap:wrap;gap:.5rem .9rem;align-items:baseline}
.cb-label{font-size:var(--s--2);letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
  min-width:5rem;flex:0 0 auto}
.cards-browse a{font-size:var(--s--1);color:var(--ink);
  border-bottom:1px solid color-mix(in srgb,var(--ink) 25%,transparent);padding-bottom:1px}
.cards-browse a:hover,.cards-browse a:focus-visible{color:var(--cic-hi);border-color:var(--cic-mid)}

/* complete A-Z card directory: links every archetype compare page (no orphans) */
.cards-index{margin-top:clamp(2rem,5vw,3.2rem);padding-top:clamp(1.4rem,3vw,2.2rem);border-top:1px solid var(--hair)}
.cards-index-h{font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase;letter-spacing:.02em;
  font-size:var(--s-1);margin-bottom:1.1rem}
.ci-group{display:flex;flex-wrap:wrap;gap:.4rem .8rem;align-items:baseline;margin-bottom:.7rem}
.ci-label{font-size:var(--s--2);letter-spacing:.16em;text-transform:uppercase;color:var(--muted);
  min-width:7rem;flex:0 0 auto}
.ci-links{display:flex;flex-wrap:wrap;gap:.35rem .8rem}
.cards-index a{font-size:var(--s--1);color:var(--ink);
  border-bottom:1px solid color-mix(in srgb,var(--ink) 20%,transparent)}
.cards-index a:hover,.cards-index a:focus-visible{color:var(--cic-hi);border-color:var(--cic-mid)}

/* prev/next archetype navigation on the compare pages */
.arch-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:clamp(2rem,5vw,3.2rem);
  padding-top:clamp(1.4rem,3vw,2.2rem);border-top:1px solid var(--hair)}
.arch-nav a{display:flex;flex-direction:column;gap:.2rem;max-width:48%;color:var(--ink)}
.arch-next{text-align:right;margin-left:auto}
.arch-nav-dir{font-size:var(--s--2);letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.arch-nav-name{font-family:'Anton',sans-serif;font-weight:400;font-size:var(--s-0);line-height:1.1}
.arch-nav a:hover .arch-nav-name,.arch-nav a:focus-visible .arch-nav-name{color:var(--cic-hi)}
