:root {
  --h-bg: #080b10;
  --h-panel: #10161e;
  --h-panel-soft: #151d27;
  --h-line: rgba(255,255,255,.12);
  --h-text: #f4f0e7;
  --h-muted: #aeb7c3;
  --h-gold: #e3ba63;
  --h-red: #bd4b44;
  --h-display: "Bebas Neue", Impact, sans-serif;
}

.heresies-body {
  margin: 0;
  background:
    radial-gradient(circle at 15% 5%, rgba(189,75,68,.14), transparent 28rem),
    radial-gradient(circle at 90% 20%, rgba(227,186,99,.08), transparent 30rem),
    var(--h-bg);
  color: var(--h-text);
  font-family: "Inter", sans-serif;
}

.heresies-body :is(
  h1,
  h2,
  h3,
  h4,
  .brand,
  .heresies-eyebrow,
  .heresies-button,
  .card-origin,
  .card-link,
  .heresies-nav nav a,
  .checkup-kicker,
  .question-panel legend,
  .answer-letter,
  .warning-card span
) {
  font-family: var(--h-display);
  font-weight: 400;
  letter-spacing: .045em;
}

.heresies-body .container { width: min(1120px, calc(100% - 2.5rem)); margin: 0 auto; }
.heresies-header { position: sticky; top: 0; z-index: 50; border-bottom: 1px solid var(--h-line); background: rgba(8,11,16,.86); backdrop-filter: blur(18px); }
.heresies-nav { min-height: 72px; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.heresies-nav .brand {
  align-self: stretch;
  display: flex;
  align-items: center;
  color: var(--h-text);
  font-size: 4.15rem;
  font-weight: 400;
  letter-spacing: .035em;
  line-height: .72;
  position: relative;
  top: 6px;
  transform: scaleY(1.48);
  transform-origin: center;
}
.heresies-nav nav { display: flex; gap: 1.25rem; }
.heresies-nav nav a { color: var(--h-muted); font-size: .88rem; font-weight: 700; }
.heresies-nav nav a:hover { color: var(--h-gold); }
.heresies-nav nav .donate-nav-button {
  padding: .55rem .8rem;
  border-radius: .35rem;
  background: #b51f31;
  color: #fff;
  font-size: 1.05rem;
}
.heresies-nav nav .donate-nav-button:hover { background: #941827; color: #fff; }

.heresies-hero { padding: clamp(5rem, 10vw, 9rem) 0 clamp(4rem, 8vw, 7rem); border-bottom: 1px solid var(--h-line); }
.heresies-eyebrow { margin: 0 0 .85rem; color: var(--h-gold); font-size: .75rem; font-weight: 800; letter-spacing: .2em; }
.heresies-hero h1, .detail-hero h1 { max-width: 900px; margin: 0; font-family: var(--h-display); font-size: clamp(4rem, 11vw, 8.5rem); line-height: .84; letter-spacing: .01em; }
.heresies-hero h1 span { color: var(--h-gold); }
.heresies-lead { max-width: 760px; margin: 1.75rem 0 0; color: var(--h-muted); font-size: clamp(1.05rem, 2vw, 1.3rem); }
.hero-links { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: 2rem; }
.heresies-button { display: inline-flex; align-items: center; justify-content: center; min-height: 50px; padding: .78rem 1.2rem; border: 1px solid var(--h-line); border-radius: .35rem; color: var(--h-text); font-weight: 800; font-size: 1.125rem; line-height: 1; }
.heresies-button:hover { border-color: var(--h-gold); color: var(--h-gold); }
.heresies-button.primary { background: var(--h-gold); border-color: var(--h-gold); color: #17130c; }

.heresies-intro, .watch-list, .chart-section { padding: clamp(3.5rem, 7vw, 6rem) 0; }
.prose-panel { border: 1px solid var(--h-line); border-radius: .75rem; padding: clamp(1.5rem, 4vw, 3.2rem); background: linear-gradient(145deg, rgba(255,255,255,.055), rgba(255,255,255,.018)); }
.prose-panel h2, .section-heading h2 { margin: 0 0 1rem; font-family: var(--h-display); font-size: clamp(2.3rem, 5vw, 4rem); line-height: 1; }
.prose-panel > p { max-width: 880px; color: var(--h-muted); }
.prose-panel aside, .chart-note { margin-top: 1.5rem; padding: 1rem 1.2rem; border-left: 3px solid var(--h-gold); background: rgba(227,186,99,.07); color: #d5d8dc; }

.heresies-directory { padding: 2rem 0 clamp(4rem, 8vw, 8rem); }
.section-heading { display: flex; align-items: end; justify-content: space-between; gap: 2rem; margin-bottom: .5rem; }
.heresies-search { width: min(420px, 100%); color: var(--h-muted); font-size: .75rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }
.heresies-search input { width: 100%; margin-top: .45rem; padding: .9rem 1rem; border: 1px solid var(--h-line); border-radius: .4rem; background: var(--h-panel); color: var(--h-text); outline: none; }
.heresies-search input:focus { border-color: var(--h-gold); }
.search-status { margin: 0 0 1rem; color: var(--h-muted); font-size: .8rem; }
.heresies-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1rem; }
.heresy-card { position: relative; display: flex; flex-direction: column; min-height: 370px; padding: 1.5rem; overflow: hidden; border: 1px solid var(--h-line); border-radius: .6rem; background: var(--h-panel); }
.heresy-card[hidden] { display: none; }
.heresy-card:hover { transform: translateY(-3px); border-color: rgba(227,186,99,.45); }
.card-number { position: absolute; right: .8rem; top: -.35rem; color: rgba(255,255,255,.045); font-family: var(--h-display); font-size: 6.5rem; font-weight: 400; line-height: 1; }
.card-origin { position: relative; margin: 0 0 1rem; color: var(--h-gold); font-size: .72rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }
.heresy-card h3 { position: relative; margin: 0 0 .8rem; font-family: var(--h-display); font-size: 1.8rem; line-height: 1.05; }
.heresy-card h3 a:hover { color: var(--h-gold); }
.heresy-card > p:not(.card-origin) { position: relative; color: var(--h-muted); font-size: .92rem; }
.card-meta { display: grid; gap: .25rem; margin-top: auto; padding-top: 1.1rem; border-top: 1px solid var(--h-line); color: #d2d7de; font-size: .75rem; }
.card-link { margin-top: 1rem; color: var(--h-gold); font-size: .8rem; font-weight: 800; }
.watch-list { border-top: 1px solid var(--h-line); }
.watch-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: .7rem 2rem; }
.watch-grid p { margin: 0; padding: .8rem 0; border-bottom: 1px solid var(--h-line); color: var(--h-muted); }
.watch-grid strong { color: var(--h-text); }

.detail-main { padding: 3rem 0 6rem; }
.breadcrumbs { display: flex; gap: .6rem; margin-bottom: 3rem; color: var(--h-muted); font-size: .8rem; }
.breadcrumbs a { color: var(--h-gold); }
.detail-hero { padding-bottom: 3rem; border-bottom: 1px solid var(--h-line); }
.detail-hero h1 { font-size: clamp(3.5rem, 9vw, 7rem); }
.detail-hero > p:last-child { max-width: 850px; margin: 1.5rem 0 0; color: var(--h-muted); font-size: 1.25rem; }
.detail-layout { display: grid; grid-template-columns: 300px minmax(0,1fr); gap: clamp(2rem, 6vw, 6rem); padding: 3rem 0; }
.fact-panel { align-self: start; position: sticky; top: 100px; padding: 1.3rem; border: 1px solid var(--h-line); border-radius: .5rem; background: var(--h-panel); }
.fact-panel h2 { margin: 0 0 1rem; font-size: 1rem; }
.fact-panel dl { margin: 0; }
.fact-panel dl div { padding: .8rem 0; border-top: 1px solid var(--h-line); }
.fact-panel dt { color: var(--h-gold); font-size: .67rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }
.fact-panel dd { margin: .3rem 0 0; color: var(--h-muted); font-size: .86rem; }
.fact-panel > a { display: block; margin-top: 1rem; color: var(--h-gold); font-size: .77rem; font-weight: 800; }
.detail-content { display: grid; gap: 2.5rem; }
.detail-content section { position: relative; padding: 0 0 2.5rem 4.2rem; border-bottom: 1px solid var(--h-line); }
.section-mark { position: absolute; left: 0; top: 0; color: var(--h-red); font-weight: 800; }
.detail-content h2 { margin: 0 0 .8rem; font-family: var(--h-display); font-size: 2.4rem; }
.detail-content p { margin: 0; color: var(--h-muted); font-size: 1.05rem; }
.clarification { padding: 1.3rem; border: 1px solid rgba(227,186,99,.35); border-radius: .5rem; background: rgba(227,186,99,.07); }
.clarification strong { color: var(--h-gold); }
.clarification p { margin-top: .45rem; }
.topic-pagination { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; padding-top: 2rem; border-top: 1px solid var(--h-line); }
.topic-pagination a { padding: 1rem; border: 1px solid var(--h-line); border-radius: .45rem; }
.topic-pagination a:hover { border-color: var(--h-gold); }
.topic-pagination span { display: block; color: var(--h-muted); font-size: .7rem; text-transform: uppercase; }
.topic-pagination strong { display: block; margin-top: .3rem; color: var(--h-text); font-size: .85rem; }
.topic-pagination .next { text-align: right; }

.chart-hero h1 { max-width: 1000px; }
.chart-hero .heresies-button { font-size: .95rem; }
.chart-note { margin: 0 0 1.5rem; font-size: 1.05rem; line-height: 1.55; }
.origins-table-wrap { overflow-x: auto; border: 1px solid var(--h-line); border-radius: .55rem; }
.origins-table { width: 100%; min-width: 1000px; border-collapse: collapse; background: var(--h-panel); }
.origins-table th, .origins-table td { padding: 1rem 1.05rem; border-bottom: 1px solid var(--h-line); text-align: left; vertical-align: top; font-size: clamp(.98rem, 1.25vw, 1.05rem); line-height: 1.45; }
.origins-table th { position: sticky; top: 0; z-index: 2; background: #171e27; color: var(--h-gold); text-transform: uppercase; letter-spacing: .07em; }
.origins-table td { color: var(--h-muted); }
.origins-table td:nth-child(2) a { color: var(--h-text); font-weight: 800; }
.origins-table td:nth-child(2) a:hover { color: var(--h-gold); }
.origins-table tbody tr[data-origin-row] { cursor: pointer; transition: background .18s ease, box-shadow .18s ease; }
.origins-table tbody tr[data-origin-row] td { transition: background .18s ease, color .18s ease; }
.origins-table tbody tr[data-origin-row]:hover,
.origins-table tbody tr[data-origin-row]:focus {
  box-shadow: inset 4px 0 0 var(--h-gold);
  outline: none;
}
.origins-table tbody tr[data-origin-row]:hover td,
.origins-table tbody tr[data-origin-row]:focus td {
  background: rgba(227, 186, 99, .12);
  color: #f0dfba;
}
.origins-table tbody tr[data-origin-row]:hover td:nth-child(2) a,
.origins-table tbody tr[data-origin-row]:focus td:nth-child(2) a {
  color: var(--h-gold);
}
.region-groups { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1rem; margin-top: 2rem; }
.region-card { padding: 1.4rem; border: 1px solid var(--h-line); border-radius: .5rem; background: var(--h-panel-soft); }
.region-card h2 { margin: .35rem 0 .75rem; font-family: var(--h-display); font-size: 1.75rem; line-height: 1.08; }
.region-card p { margin: 0; color: var(--h-muted); font-size: 1rem; line-height: 1.55; }
.region-card a:hover { color: var(--h-gold); }
.region-count { color: var(--h-gold) !important; font-weight: 800; text-transform: uppercase; letter-spacing: .07em; }
.heresies-footer { border-top: 1px solid var(--h-line); padding: 1.5rem 0; color: var(--h-muted); font-size: .75rem; }
.heresies-footer .container { display: flex; justify-content: space-between; gap: 1rem; }
.heresies-footer p { margin: 0; }
.heresies-footer a { color: var(--h-gold); }

.checkup-main { min-height: 80vh; }
.checkup-hero { padding: clamp(4rem, 9vw, 7rem) 0 3rem; border-bottom: 1px solid var(--h-line); }
.checkup-hero .container,
.checkup-section > .container {
  width: min(900px, calc(100% - 2.5rem));
}
.checkup-hero h1 { margin: 0; font-family: var(--h-display); font-size: clamp(4rem, 10vw, 8rem); line-height: .86; letter-spacing: .01em; }
.checkup-hero h1 span { color: var(--h-gold); }
.checkup-hero > .container > p:last-child { max-width: 780px; margin: 1.5rem 0 0; color: var(--h-muted); font-size: 1.15rem; }
.checkup-section { padding: clamp(2rem, 6vw, 5rem) 0 7rem; }
.checkup-disclaimer {
  width: 100%; margin: 0 0 1.5rem; padding: 1.1rem 1.25rem;
  border-left: 3px solid var(--h-gold); background: rgba(227,186,99,.07); color: var(--h-muted);
}
.checkup-disclaimer strong { color: var(--h-text); }
.checkup-disclaimer p { margin: .3rem 0 0; font-size: .88rem; }
.checkup-shell {
  width: 100%; min-height: 520px; margin: 0; padding: clamp(1.3rem, 4vw, 3rem);
  border: 1px solid var(--h-line); border-radius: .75rem; background: var(--h-panel); box-shadow: 0 35px 100px rgba(0,0,0,.3);
}
.checkup-shell [hidden] { display: none !important; }
.checkup-start { display: grid; justify-items: start; align-content: center; min-height: 440px; }
.checkup-identity { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; width: min(100%, 720px); margin: 1rem 0; }
.checkup-identity label { display: grid; gap: .45rem; color: var(--h-text); font-size: .78rem; font-weight: 800; }
.checkup-identity input { width: 100%; border: 1px solid var(--h-line); border-radius: .35rem; background: var(--h-panel-soft); color: var(--h-text); padding: .85rem 1rem; font: inherit; }
.checkup-email-choice { display: flex; align-items: center; gap: .55rem; color: var(--h-text); font-size: .85rem; }
.checkup-storage-warning, .checkup-email-status { color: var(--h-gold) !important; font-size: .8rem; }
.checkup-kicker { margin: 0 0 .8rem; color: var(--h-gold); font-size: .78rem; font-weight: 800; text-transform: uppercase; letter-spacing: .1em; }
.checkup-start h2, .checkup-results h2 { margin: 0; font-family: var(--h-display); font-size: clamp(2.4rem, 6vw, 4.2rem); line-height: 1; }
.checkup-start > p:not(.checkup-kicker) { max-width: 650px; color: var(--h-muted); }
.score-key { display: grid; grid-template-columns: repeat(4, auto); gap: .6rem; margin: 1.1rem 0 1.8rem; }
.score-key span { padding: .55rem .7rem; border: 1px solid var(--h-line); border-radius: .3rem; color: var(--h-muted); font-size: .72rem; }
.score-key b { color: var(--h-gold); margin-right: .25rem; }
.checkup-progress { margin-bottom: 2.4rem; }
.checkup-progress > div:first-child { display: flex; justify-content: space-between; gap: 1rem; color: var(--h-muted); font-size: .75rem; text-transform: uppercase; letter-spacing: .08em; }
.checkup-progress strong { color: var(--h-text); }
.progress-track { height: 4px; margin-top: .7rem; overflow: hidden; border-radius: 99px; background: rgba(255,255,255,.08); }
.progress-track span { display: block; height: 100%; background: linear-gradient(90deg, var(--h-red), var(--h-gold)); transition: width .25s ease; }
.question-panel { min-width: 0; margin: 0; padding: 0; border: 0; }
.question-panel legend { width: 100%; margin-bottom: 1.5rem; font-family: var(--h-display); font-size: clamp(2rem, 5vw, 3.2rem); font-weight: 400; line-height: 1.05; }
.answer-list { display: grid; gap: .7rem; }
.answer-option {
  display: grid; grid-template-columns: 2.1rem 1fr; align-items: center; gap: .8rem;
  padding: .9rem 1rem; border: 1px solid var(--h-line); border-radius: .45rem;
  color: var(--h-muted); cursor: pointer; transition: border-color .15s ease, background .15s ease;
}
.answer-option:hover { border-color: rgba(227,186,99,.5); background: rgba(227,186,99,.035); }
.answer-option:has(input:checked) { border-color: var(--h-gold); background: rgba(227,186,99,.09); color: var(--h-text); }
.answer-option input { position: absolute; opacity: 0; pointer-events: none; }
.answer-letter { width: 2rem; height: 2rem; display: grid; place-items: center; border: 1px solid var(--h-line); border-radius: 50%; color: var(--h-gold); font-size: .75rem; font-weight: 800; }
.answer-option:has(input:checked) .answer-letter { background: var(--h-gold); color: #17130c; }
.answer-error { margin: 1rem 0 0; color: #ff8a82; font-size: .82rem; }
.checkup-actions, .result-actions { display: flex; justify-content: space-between; gap: .8rem; margin-top: 2rem; }
.checkup-actions button:disabled { opacity: .35; cursor: not-allowed; }
.result-heading { display: grid; grid-template-columns: 130px 1fr; gap: 1.5rem; align-items: center; padding-bottom: 2rem; border-bottom: 1px solid var(--h-line); }
.result-score { width: 125px; height: 125px; display: grid; place-content: center; text-align: center; border: 1px solid rgba(227,186,99,.5); border-radius: 50%; background: rgba(227,186,99,.07); }
.result-score strong { color: var(--h-gold); font-family: var(--h-display); font-size: 3.3rem; line-height: .8; }
.result-score span { margin-top: .45rem; color: var(--h-muted); font-size: .65rem; text-transform: uppercase; }
.result-heading p { margin: .8rem 0 0; color: var(--h-muted); }
.result-notice { margin: 1.5rem 0; padding: 1rem; border-left: 3px solid var(--h-gold); background: rgba(255,255,255,.035); color: var(--h-muted); font-size: .82rem; }
.warning-results h3 { margin: 2rem 0 1rem; font-family: var(--h-display); font-size: 2rem; }
.warning-results > div { display: grid; gap: .7rem; }
.warning-card { display: flex; justify-content: space-between; align-items: center; gap: 1rem; padding: 1rem; border: 1px solid var(--h-line); border-radius: .4rem; background: var(--h-panel-soft); }
.warning-card span { color: var(--h-gold); font-size: .67rem; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; }
.warning-card h4 { margin: .2rem 0; color: var(--h-text); }
.warning-card p { margin: 0; color: var(--h-muted); font-size: .8rem; }
.warning-card > a { flex-shrink: 0; color: var(--h-gold); font-size: .75rem; font-weight: 800; }

@media (max-width: 900px) {
  .heresies-grid, .region-groups { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .detail-layout { grid-template-columns: 1fr; }
  .fact-panel { position: static; }
}

@media (max-width: 650px) {
  .heresies-nav { align-items: flex-start; padding: 1rem 0; }
  .heresies-nav .brand { align-self: flex-start; font-size: 3.55rem; top: 4px; transform: scaleY(1.35); }
  .heresies-nav nav { justify-content: flex-end; flex-wrap: wrap; gap: .55rem 1rem; }
  .heresies-nav nav a { font-size: .95rem; }
  .section-heading { align-items: stretch; flex-direction: column; }
  .heresies-grid, .region-groups, .watch-grid { grid-template-columns: 1fr; }
  .heresy-card { min-height: 330px; }
  .detail-content section { padding-left: 2.8rem; }
  .topic-pagination { grid-template-columns: 1fr; }
  .topic-pagination .next { text-align: left; }
  .heresies-footer .container { flex-direction: column; }
  .score-key { grid-template-columns: repeat(2, 1fr); }
  .checkup-identity { grid-template-columns: 1fr; }
  .result-heading { grid-template-columns: 1fr; }
  .warning-card { align-items: flex-start; flex-direction: column; }
  .checkup-actions, .result-actions { flex-wrap: wrap; }
}
