/* ── BOARD READABILITY ────────────────────────────────────── */

:root {
  --board-readability-scale: 1.18;
}

.evidence-card .evidence-title {
  font-size: calc(0.78rem * var(--board-readability-scale));
  margin-bottom: 4px;
}

/* ── CARD TYPE: FOLDER (Mastermind) ───────────────────────── */

.card-folder {
  width: 398px;
  min-height: 302px;
  padding: 26px 24px 20px;
  border-radius: 4px 4px 6px 6px;
  color: #2e2516;
  background:
    /* paper fiber texture */
    repeating-linear-gradient(
      0deg,
      transparent 0px,
      transparent 3px,
      rgba(0, 0, 0, 0.015) 3px,
      rgba(0, 0, 0, 0.015) 4px
    ),
    /* age spots */
    radial-gradient(
        circle at 75% 20%,
        rgba(160, 130, 80, 0.15) 0%,
        transparent 30%
      ),
    radial-gradient(
      circle at 25% 80%,
      rgba(140, 110, 60, 0.12) 0%,
      transparent 25%
    ),
    /* base manila */
    linear-gradient(180deg, #e2d5b8 0%, #d8c8a5 40%, #cbb591 100%);
  box-shadow:
    0 10px 30px rgba(0, 0, 0, 0.4),
    0 2px 8px rgba(0, 0, 0, 0.25),
    inset 0 1px 0 rgba(255, 255, 255, 0.25);
}

.evidence-card[data-id="mastermind"].card-folder {
  width: 468px;
  min-height: 352px;
  padding: 30px 28px 24px;
}

/* folder tab */
.folder-tab {
  position: absolute;
  top: -14px;
  right: 30px;
  background: linear-gradient(180deg, #ddd0b5 0%, #d0c09a 100%);
  padding: 2px 16px 4px;
  font-family: var(--font-case);
  font-size: max(calc(0.65rem * var(--board-readability-scale)), 0.76rem);
  letter-spacing: 0.12em;
  color: #8b1a1a;
  border-radius: 4px 4px 0 0;
  box-shadow: 0 -2px 4px rgba(0, 0, 0, 0.15);
}

.folder-stamp {
  position: absolute;
  top: 12px;
  right: 16px;
  font-family: var(--font-case);
  font-size: max(calc(0.6rem * var(--board-readability-scale)), 0.72rem);
  color: #2e7d32;
  border: 1.5px solid #2e7d32;
  padding: 1px 8px;
  border-radius: 2px;
  letter-spacing: 0.1em;
  transform: rotate(3deg);
  opacity: 0.7;
}

.evidence-card[data-id="mastermind"] .folder-stamp {
  top: 14px;
  right: 22px;
  padding: 2px 10px;
}

.folder-content {
  position: relative;
}

.subject-name {
  font-size: calc(1.6rem * var(--board-readability-scale));
  font-weight: 700;
  color: #1a1408;
  line-height: 1.05;
  margin-bottom: 6px;
}

.evidence-card[data-id="mastermind"] .subject-name {
  font-size: calc(1.92rem * var(--board-readability-scale));
  margin-bottom: 10px;
}

.mugshot-area {
  float: right;
  margin: 0 0 6px 10px;
}

.evidence-card[data-id="mastermind"] .mugshot-area {
  margin: 2px 0 10px 16px;
}

.mugshot-placeholder {
  width: 88px;
  height: 108px;
  border: 2px solid rgba(0, 0, 0, 0.2);
  background:
    repeating-linear-gradient(
      45deg,
      rgba(0, 0, 0, 0.04) 0px,
      rgba(0, 0, 0, 0.04) 5px,
      transparent 5px,
      transparent 10px
    ),
    #d4c9b0;
  display: grid;
  place-items: center;
  border-radius: 2px;
  overflow: hidden;
  position: relative;
}

.evidence-card[data-id="mastermind"] .mugshot-placeholder {
  width: 108px;
  height: 132px;
}

.mugshot-placeholder img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.mugshot-label {
  font-family: var(--font-case);
  font-size: max(calc(0.55rem * var(--board-readability-scale)), 0.68rem);
  text-align: center;
  color: rgba(0, 0, 0, 0.35);
  letter-spacing: 0.08em;
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
}

.mugshot-placeholder img.loaded ~ .mugshot-label {
  display: none;
}

.dossier-lines {
  font-size: calc(0.82rem * var(--board-readability-scale));
  line-height: 1.56;
}

.evidence-card[data-id="mastermind"] .dossier-lines {
  font-size: calc(0.92rem * var(--board-readability-scale));
  line-height: 1.66;
}

.label-stamp {
  font-family: var(--font-case);
  font-size: calc(0.68rem * var(--board-readability-scale));
  letter-spacing: 0.06em;
  color: #5a4a2e;
  margin-right: 4px;
}

/* ── CARD TYPE: POLAROID (Norsify) ───────────────────────── */

.card-polaroid {
  width: 304px;
  min-height: 352px;
  padding: 14px 14px 30px;
  color: #1e1e1e;
  border-radius: 3px;
  background:
    /* slight age/yellowing */
    radial-gradient(
      circle at 60% 80%,
      rgba(230, 220, 190, 0.3) 0%,
      transparent 50%
    ),
    linear-gradient(180deg, #f5f3ee 0%, #eae6dc 100%);
  box-shadow:
    0 12px 35px rgba(0, 0, 0, 0.45),
    0 3px 10px rgba(0, 0, 0, 0.3),
    inset 0 0 0 1px rgba(0, 0, 0, 0.06);
}

.polaroid-frame {
  background: #c8c4bb;
  border-radius: 2px;
  overflow: hidden;
  margin-bottom: 8px;
}

.polaroid-image {
  height: 204px;
  display: grid;
  place-items: center;
  background:
    linear-gradient(135deg, rgba(0, 0, 0, 0.05) 0%, transparent 50%), #bbb8b0;
}

.app-icon-placeholder {
  width: 104px;
  height: 104px;
  border-radius: 22px;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  display: grid;
  place-items: center;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
  position: relative;
  overflow: hidden;
}

.app-icon-placeholder img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 22px;
}

.app-icon-fallback {
  font-family: var(--font-ui);
  font-size: calc(2rem * var(--board-readability-scale));
  font-weight: 700;
  color: white;
  position: absolute;
}

.app-icon-placeholder img.loaded ~ .app-icon-fallback {
  display: none;
}

.polaroid-caption {
  font-size: calc(1.15rem * var(--board-readability-scale));
  line-height: 1.12;
  color: #2a2a2a;
  margin-top: 2px;
}

.polaroid-date {
  font-size: calc(0.85rem * var(--board-readability-scale));
  color: #888;
  margin-top: 2px;
}

/* ── CARD TYPE: MAP (TwinsTie) ───────────────────────────── */

.card-map {
  width: 352px;
  min-height: 272px;
  padding: 24px 22px 18px;
  color: #2e2516;
  border-radius: 2px;
  background:
    /* aged paper */
    radial-gradient(
      circle at 20% 60%,
      rgba(180, 150, 100, 0.2) 0%,
      transparent 40%
    ),
    radial-gradient(
      circle at 80% 30%,
      rgba(200, 170, 120, 0.15) 0%,
      transparent 35%
    ),
    linear-gradient(170deg, #ddd0b5 0%, #d0c09a 50%, #c4b088 100%);
  box-shadow:
    0 10px 30px rgba(0, 0, 0, 0.4),
    0 2px 8px rgba(0, 0, 0, 0.25);
  /* torn edges */
  clip-path: polygon(
    0% 2%,
    5% 0%,
    12% 1.5%,
    20% 0.5%,
    30% 2%,
    40% 0%,
    50% 1%,
    60% 0.5%,
    70% 2%,
    80% 0%,
    88% 1%,
    95% 0.5%,
    100% 1.5%,
    100% 97%,
    96% 100%,
    88% 98.5%,
    80% 100%,
    70% 98%,
    60% 100%,
    50% 99%,
    40% 100%,
    30% 98%,
    20% 100%,
    12% 99%,
    5% 100%,
    0% 98%
  );
}

.map-content {
  position: relative;
  min-height: 118px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 124px;
  gap: 14px;
  align-items: start;
}

.map-copy {
  min-width: 0;
}

.map-logo-wrap {
  position: relative;
  min-height: 92px;
  padding: 12px 14px;
  border-radius: 16px 5px 16px 5px;
  background:
    linear-gradient(180deg, rgba(255, 250, 238, 0.95) 0%, rgba(240, 226, 197, 0.92) 100%);
  border: 1px solid rgba(94, 72, 38, 0.18);
  box-shadow:
    0 10px 18px rgba(65, 45, 18, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.6);
  display: grid;
  place-items: center;
  overflow: hidden;
}

.map-logo-wrap::before {
  content: "";
  position: absolute;
  top: -10px;
  right: 10px;
  width: 46px;
  height: 16px;
  border-radius: 2px;
  background: linear-gradient(180deg, rgba(230, 216, 182, 0.72), rgba(195, 177, 138, 0.62));
  box-shadow: 0 2px 5px rgba(74, 54, 23, 0.12);
  transform: rotate(6deg);
  opacity: 0.92;
}

.map-logo-wrap img {
  position: relative;
  z-index: 1;
  width: 100%;
  max-height: 56px;
  object-fit: contain;
}

.map-logo-fallback {
  font-family: var(--font-case);
  font-size: calc(1.55rem * var(--board-readability-scale));
  letter-spacing: 0.08em;
  color: #735329;
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
}

.map-logo-wrap img.loaded ~ .map-logo-fallback {
  display: none;
}

.map-pins {
  position: absolute;
  inset: 0;
}

.map-pin {
  position: absolute;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--pin-red);
  box-shadow: 0 0 4px rgba(200, 30, 30, 0.5);
}

.map-pin::after {
  content: "";
  position: absolute;
  top: 9px;
  left: 3.5px;
  width: 2px;
  height: 5px;
  background: #666;
  border-radius: 0 0 1px 1px;
}

.map-label {
  font-size: calc(1.4rem * var(--board-readability-scale));
  font-weight: 700;
  color: #1a1408;
  position: relative;
}

.map-sublabel {
  font-family: var(--font-case);
  font-size: max(calc(0.7rem * var(--board-readability-scale)), 0.82rem);
  color: #6b5a3e;
  letter-spacing: 0.06em;
  margin-top: 2px;
}

.torn-note {
  margin-top: 14px;
  background: #f4dc75;
  padding: 9px 12px;
  border-radius: 2px;
  transform: rotate(-1deg);
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.2);
  font-size: calc(0.95rem * var(--board-readability-scale));
  line-height: 1.28;
  color: #333;
}

/* ── CARD TYPE: FIELD NOTES ─────────────────────────────── */

.card-fieldnotes {
  width: 104px;
  padding: 12px 10px 10px;
  border-radius: 3px;
  color: #69573a;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 24%),
    linear-gradient(180deg, #ece3cf 0%, #e1d5bb 50%, #d5c6a7 100%);
  border: 1px solid rgba(90, 74, 46, 0.14);
  box-shadow:
    0 10px 24px rgba(0, 0, 0, 0.28),
    0 2px 8px rgba(0, 0, 0, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

.card-fieldnotes::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    repeating-linear-gradient(
      0deg,
      transparent 0 18px,
      rgba(60, 48, 28, 0.05) 18px 19px
    );
  opacity: 0.65;
  pointer-events: none;
}

.card-fieldnotes .evidence-title {
  display: none;
}

.card-fieldnotes .evidence-body {
  position: relative;
  z-index: 1;
}

.card-fieldnotes .pin {
  top: -7px;
  left: calc(50% - 7px);
  width: 14px;
  height: 14px;
}

.card-fieldnotes .pin-head {
  width: 14px;
  height: 14px;
}

.card-fieldnotes .pin-head::after {
  top: 2px;
  left: 3px;
  width: 3px;
  height: 3px;
}

.card-fieldnotes .pin-shadow {
  top: 4px;
  left: 2px;
  width: 10px;
  height: 10px;
}

.fieldnotes-memo {
  position: relative;
}

/* ── CARD TYPE: BLUEPRINT (SupplyMe) ─────────────────────── */

.card-blueprint {
  width: 366px;
  min-height: 302px;
  padding: 23px 22px 18px;
  color: #d0e8ff;
  border-radius: 3px;
  background:
    /* grid lines */
    linear-gradient(rgba(255, 255, 255, 0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.08) 1px, transparent 1px),
    /* blue gradient */
    linear-gradient(180deg, #3a6fa0 0%, #2a5580 50%, #1e4468 100%);
  background-size:
    20px 20px,
    20px 20px,
    100% 100%;
  box-shadow:
    0 10px 30px rgba(0, 0, 0, 0.45),
    0 2px 8px rgba(0, 0, 0, 0.3),
    inset 0 0 40px rgba(0, 0, 0, 0.15);
}

.blueprint-header {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-case);
  font-size: max(calc(0.6rem * var(--board-readability-scale)), 0.72rem);
  opacity: 0.6;
  letter-spacing: 0.08em;
  margin-bottom: 7px;
}

.blueprint-title {
  font-family: var(--font-case);
  font-size: calc(0.95rem * var(--board-readability-scale));
  letter-spacing: 0.1em;
  margin-bottom: 12px;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}

.blueprint-diagram {
  display: flex;
  align-items: center;
  gap: 1px;
  margin-bottom: 12px;
}

.bp-box {
  border: 1px solid rgba(255, 255, 255, 0.25);
  padding: 5px 11px;
  font-family: var(--font-case);
  font-size: max(calc(0.6rem * var(--board-readability-scale)), 0.7rem);
  letter-spacing: 0.08em;
  border-radius: 2px;
}

.bp-line {
  width: 22px;
  height: 1px;
  background: rgba(255, 255, 255, 0.25);
}

.card-blueprint .logo-wrap {
  margin-top: 10px;
  min-height: 56px;
}

.card-blueprint img {
  max-height: 72px;
  object-fit: contain;
  filter: brightness(1.1);
}

/* ── CARD TYPE: COMIC (ComicBooksGeo) ────────────────────── */

.card-comic {
  width: 318px;
  min-height: 324px;
  padding: 22px 20px 18px;
  color: #1e1d17;
  border-radius: 4px;
  border: 3px solid #222;
  background:
    /* halftone dots */
    radial-gradient(circle 1.5px, rgba(0, 0, 0, 0.04) 0.5px, transparent 1px) 0
      0 / 6px 6px,
    /* cream paper */
    linear-gradient(180deg, #f8f3e8 0%, #efe8d6 50%, #e5dcc8 100%);
  box-shadow:
    0 10px 30px rgba(0, 0, 0, 0.4),
    0 2px 8px rgba(0, 0, 0, 0.25);
}

.comic-panel {
  position: relative;
}

.comic-halftone {
  position: absolute;
  inset: 0;
  background: radial-gradient(
      circle 1px,
      rgba(0, 0, 0, 0.06) 0.3px,
      transparent 1px
    )
    0 0 / 4px 4px;
  pointer-events: none;
}

.speech-bubble {
  background: white;
  border: 2px solid #222;
  border-radius: 18px;
  padding: 10px 14px;
  position: relative;
  margin-bottom: 12px;
  font-family: var(--font-hand);
  font-size: calc(1.05rem * var(--board-readability-scale));
  font-weight: 600;
  line-height: 1.18;
}

/* speech bubble tail */
.speech-bubble::after {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 25px;
  width: 0;
  height: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-top: 10px solid white;
}

.speech-bubble::before {
  content: "";
  position: absolute;
  bottom: -13px;
  left: 24px;
  width: 0;
  height: 0;
  border-left: 9px solid transparent;
  border-right: 9px solid transparent;
  border-top: 12px solid #222;
}

.card-comic .logo-wrap {
  margin-top: 8px;
  min-height: 52px;
}

.card-comic img {
  max-height: 78px;
  object-fit: contain;
}

.comic-caption {
  font-family: var(--font-case);
  font-size: max(calc(0.7rem * var(--board-readability-scale)), 0.82rem);
  margin-top: 8px;
  opacity: 0.6;
  letter-spacing: 0.05em;
}

/* ── CARD TYPE: LEDGER (Competitor Banks) ────────────────── */

.card-ledger {
  width: 338px;
  min-height: 272px;
  padding: 22px 20px 18px;
  color: #1a2a1a;
  border-radius: 3px;
  background:
    /* ledger lines */
    repeating-linear-gradient(
      0deg,
      transparent 0px,
      transparent 23px,
      rgba(0, 100, 0, 0.1) 23px,
      rgba(0, 100, 0, 0.1) 24px
    ),
    /* vertical rule */
    linear-gradient(
        90deg,
        transparent 48px,
        rgba(200, 0, 0, 0.15) 48px,
        rgba(200, 0, 0, 0.15) 49px,
        transparent 49px
      ),
    /* aged paper */
    linear-gradient(180deg, #f0ead8 0%, #e8e0c8 50%, #ddd5be 100%);
  box-shadow:
    0 10px 30px rgba(0, 0, 0, 0.4),
    0 2px 8px rgba(0, 0, 0, 0.25);
}

.ledger-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 2px solid rgba(0, 0, 0, 0.1);
}

.ledger-icon {
  font-size: calc(1.4rem * var(--board-readability-scale));
  font-weight: 700;
  color: #2e7d32;
  font-family: var(--font-case);
}

.ledger-title-text {
  font-family: var(--font-case);
  font-size: calc(0.8rem * var(--board-readability-scale));
  letter-spacing: 0.1em;
  color: #3a3a2a;
}

.ledger-rows {
  margin-bottom: 10px;
}

.ledger-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 3px 0;
  font-size: calc(0.82rem * var(--board-readability-scale));
  line-height: 1.35;
  font-family: var(--font-case);
  border-bottom: 1px dotted rgba(0, 0, 0, 0.1);
}

.ledger-val {
  font-size: max(calc(0.7rem * var(--board-readability-scale)), 0.8rem);
  letter-spacing: 2px;
  color: #555;
}

.ledger-val.highlight {
  color: #2e7d32;
  font-weight: 700;
  font-size: calc(0.85rem * var(--board-readability-scale));
}

.card-ledger .logo-wrap {
  margin-top: 8px;
  min-height: 48px;
}

.card-ledger img {
  max-height: 66px;
  object-fit: contain;
}

/* ── CARD TYPE: NOTE CLUSTER (Suspects) ──────────────────── */

.card-notecluster {
  width: 398px;
  min-height: 278px;
  padding: 22px;
  background: transparent;
  box-shadow: none;
}

.sticky {
  padding: 12px 14px;
  border-radius: 2px;
  margin-bottom: 10px;
  box-shadow:
    0 6px 14px rgba(0, 0, 0, 0.3),
    0 1px 3px rgba(0, 0, 0, 0.2);
  font-size: calc(0.88rem * var(--board-readability-scale));
  line-height: 1.32;
  position: relative;
}

/* curled corner */
.sticky::before {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: 20px;
  height: 20px;
  background: linear-gradient(135deg, transparent 50%, rgba(0, 0, 0, 0.08) 50%);
}

.sticky-yellow {
  background: linear-gradient(180deg, #f8e77a 0%, #f0dc60 100%);
  color: #2a2508;
}

.sticky-blue {
  background: linear-gradient(180deg, #a8d4f0 0%, #8ec4e6 100%);
  color: #0a2a3e;
}

.sticky p {
  line-height: 1.32;
}

.card-notecluster .small {
  font-size: calc(0.82rem * var(--board-readability-scale));
}

.index-card {
  background: linear-gradient(180deg, #f5f0e2 0%, #ede6d4 100%);
  border-left: 4px solid #c4cdd8;
  padding: 12px 14px;
  border-radius: 2px;
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.25);
  font-size: calc(0.82rem * var(--board-readability-scale));
  line-height: 1.38;
  color: #2a2a2a;
}

/* ── CARD TYPE: ENVELOPE (Contact) ───────────────────────── */

.card-envelope {
  width: 322px;
  min-height: 196px;
  padding: 0;
  border-radius: 3px;
  color: #2a2a2a;
  overflow: visible;
  background: linear-gradient(180deg, #e8e0d0 0%, #ddd5c4 100%);
  box-shadow:
    0 10px 30px rgba(0, 0, 0, 0.4),
    0 2px 8px rgba(0, 0, 0, 0.25);
}

.envelope-flap {
  width: 100%;
  height: 58px;
  background: linear-gradient(180deg, #d5ccb8 0%, #ccc3ae 100%);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  position: relative;
  z-index: 1;
}

.envelope-flap::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.05) 0%, transparent 100%);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
}

.envelope-body {
  padding: 10px 18px 18px;
}

.envelope-body p {
  margin-bottom: 8px;
}

.card-envelope .handwritten {
  font-size: calc(0.96rem * var(--board-readability-scale));
  line-height: 1.15;
}

.envelope-details {
  font-family: var(--font-case);
  font-size: max(calc(0.72rem * var(--board-readability-scale)), 0.84rem);
  letter-spacing: 0.03em;
  line-height: 1.56;
  color: #4a4a4a;
}

/* ── SHARED CARD UTILITIES ───────────────────────────────── */

.evidence-list {
  list-style: none;
  padding: 0;
}

.evidence-list li {
  padding: 5px 0 5px 16px;
  position: relative;
  font-size: 0.88rem;
  line-height: 1.5;
}

.evidence-list li::before {
  content: ">";
  position: absolute;
  left: 0;
  color: var(--string);
  font-weight: 700;
  font-family: var(--font-case);
}

.skills-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.skill-tag {
  font-family: var(--font-case);
  font-size: 0.68rem;
  padding: 3px 10px;
  border-radius: 3px;
  letter-spacing: 0.04em;
}

.evidence-link {
  display: inline-block;
  font-family: var(--font-case);
  font-size: 0.82rem;
  letter-spacing: 0.04em;
  padding: 8px 16px;
  border-radius: 4px;
  margin-top: 6px;
  transition:
    background-color 0.2s ease,
    color 0.2s ease,
    border-color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.evidence-link:hover {
  text-decoration: none;
}
