
:root {
  --bg: #f7f4ee;
  --paper: #fffdf8;
  --ink: #171411;
  --muted: #685f55;
  --rule: #d8cdbf;
  --accent: #563c21;
  --body-size: 1.95rem;
  --line-height: 1.72;
  --container: 100%;
  --side-pad: 1rem;
  --h1: 3rem;
  --h2: 2.45rem;
  --h3: 2.1rem;
  --toc: 2rem;
}
@media (min-width:576px){:root{--body-size:1.8rem;--container:94%;--side-pad:1.25rem;--h1:3.05rem;--h2:2.5rem;--h3:2.1rem;--toc:1.9rem;}}
@media (min-width:768px){:root{--body-size:1.55rem;--container:88%;--side-pad:1.5rem;--h1:3rem;--h2:2.35rem;--h3:1.95rem;--toc:1.65rem;}}
@media (min-width:992px){:root{--body-size:1.32rem;--container:860px;--side-pad:2rem;--h1:2.75rem;--h2:2.1rem;--h3:1.65rem;--toc:1.38rem;}}
@media (min-width:1200px){:root{--body-size:1.25rem;--container:940px;--h1:2.8rem;--h2:2.15rem;--h3:1.65rem;--toc:1.3rem;}}
@media (min-width:1400px){:root{--body-size:1.28rem;--container:1040px;--h1:2.95rem;--h2:2.25rem;--h3:1.72rem;--toc:1.35rem;}}
*{box-sizing:border-box;}
html{font-size:16px;scroll-behavior:smooth;}
body{margin:0;background:var(--bg);color:var(--ink);font-family:Georgia,'Times New Roman',serif;font-size:var(--body-size);line-height:var(--line-height);}
a{color:#563c21;text-decoration-thickness:.08em;text-underline-offset:.16em;}
a:focus{outline:4px solid #99734a;outline-offset:4px;border-radius:.25rem;}
.site-header,.site-footer{background:#21180f;color:#fff;padding:1rem var(--side-pad);}
.site-header a,.site-footer a{color:#fff;}
.brand{font-family:Georgia,'Times New Roman',serif;font-weight:700;font-size:clamp(1.35rem,5vw,2rem);line-height:1.2;}
.container{width:min(var(--container), calc(100% - (var(--side-pad) * 2)));margin-inline:auto;}
main.container{background:var(--paper);padding:1.25rem var(--side-pad) 3rem;border-left:1px solid var(--rule);border-right:1px solid var(--rule);min-height:70vh;}
h1,h2,h3{line-height:1.18;margin:1.5em 0 .65em;color:#23190f;font-weight:700;overflow-wrap:anywhere;}
h1{font-size:var(--h1);margin-top:.55em;}
h2{font-size:var(--h2);border-top:2px solid var(--rule);padding-top:.8em;}
h3{font-size:var(--h3);}
p{margin:0 0 1.15em;overflow-wrap:anywhere;}
.article{margin-top:1.45em;}
.question{font-weight:700;margin-top:1.4em;}
.answer{margin-left:.3em;}
.proof{background:#fbf6ea;border-left:.35rem solid #bfa274;padding:.8rem .9rem;margin:1rem 0;font-size:.95em;}
.proof-label{font-weight:700;color:#3b2917;}
.footnote-ref{font-weight:700;display:inline-flex;min-width:1.6em;min-height:1.6em;align-items:center;justify-content:center;margin-inline:.08em;border-radius:.35em;}
.proof-back{display:inline-flex;min-width:2rem;min-height:2rem;align-items:center;justify-content:center;margin-left:.35rem;font-weight:700;text-decoration:none;background:#efe2cf;border-radius:999px;}
.nav-row{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center;justify-content:center;margin:1rem 0 1.5rem;}
.nav-row a,.top-link{display:inline-flex;align-items:center;justify-content:center;min-height:3rem;padding:.55rem .9rem;border:1px solid #7e674e;border-radius:.75rem;background:#fff9ef;color:#2a1b0e;text-decoration:none;font-size:.86em;}
.source-note{font-size:.8em;color:var(--muted);border-top:1px solid var(--rule);padding-top:.85rem;margin-top:1rem;}
.toc-grid{display:grid;gap:1rem;margin:1.5rem 0 2rem;}
.toc-card{display:block;background:#fffaf1;border:1px solid var(--rule);border-radius:1rem;padding:1rem 1.1rem;text-decoration:none;color:#1f160d;font-size:var(--toc);line-height:1.35;}
.toc-card small{display:block;color:var(--muted);font-size:.72em;margin-top:.3rem;}
.cover{max-width:min(420px,100%);height:auto;display:block;margin:1rem auto 2rem;border-radius:.35rem;box-shadow:0 12px 35px rgba(0,0,0,.25);}
.skip{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden;}.skip:focus{left:1rem;top:1rem;width:auto;height:auto;background:#fff;padding:.8rem;z-index:10;}
@media (max-width:575.98px){main.container{border:0;padding-top:1rem}.nav-row a{width:100%;font-size:1em}.proof{padding:1rem .8rem}.footnote-ref{min-width:2.2em;min-height:2.2em}.toc-card{padding:1.2rem 1rem;}}

/* Clean table-of-contents line layout */
.toc-grid{grid-template-columns:1fr !important;}
.toc-card{margin-bottom:.25rem;}
.source-toc-list{margin:1.5rem 0 2rem;}
.source-toc-list ol{padding-left:1.5em;margin:.5rem 0 1rem;}
.source-toc-list li{font-size:var(--toc);line-height:1.45;margin:.55rem 0;}
.source-toc-list a{color:#1f160d;text-decoration:none;border-bottom:1px solid rgba(81,55,32,.25);}
.source-toc-list a:focus,.source-toc-list a:hover{border-bottom-color:currentColor;}
.source-toc-list .confession-sublist{margin-top:.65rem;}
@media (max-width:575.98px){.source-toc-list ol{padding-left:1.15em}.source-toc-list li{margin:.7rem 0;}}


/* Final clean TOC readability fix */
.clean-toc-list > ol { list-style-position: outside; padding-left: 1.35em; }
.clean-toc-list li { display: list-item; padding: .35rem 0 .35rem .15rem; }
.clean-toc-list li::marker { font-weight: 700; color: var(--accent); }
.clean-toc-list .confession-sublist { padding-left: 1.15em; margin-top: .7rem; border-left: .18rem solid var(--rule); }
.clean-toc-list a { display: inline; line-height: 1.45; }
@media (max-width:575.98px){
  .clean-toc-list > ol { padding-left: 1.05em; }
  .clean-toc-list .confession-sublist { padding-left: .85em; }
}

.site-subtitle{font-size:clamp(1.65rem,4.8vw,2.35rem);font-weight:700;line-height:1.35;margin:0 0 2rem;color:#374151;}
/* Catechism proof-anchor stability */
[id^="fn-"], .proof-label[id] { scroll-margin-top: 1.5rem; }
.proof-label[id] { display: inline-block; }
