/* ============================================================
   1 e 2 Tessalonicenses — Estudo Bíblico
   Sistema visual: cinematográfico e reverente
   Meia-noite · ouro do templo · pergaminho
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --ink:        #0a0c12;
  --ink-2:      #0d111b;
  --ink-3:      #11151f;
  --panel:      rgba(20,24,34,0.55);

  --gold:       #d8a657;
  --gold-soft:  #e7c489;
  --gold-deep:  #a87a3c;
  --gold-faint: rgba(216,166,87,0.16);
  --gold-line:  rgba(216,166,87,0.22);

  --parch:      #ece5d6;
  --parch-dim:  rgba(236,229,214,0.66);
  --parch-faint:rgba(236,229,214,0.40);

  --serif-display: "Cormorant Garamond", Georgia, serif;
  --serif-read:    "Spectral", Georgia, serif;
  --sans:          "Hanken Grotesk", system-ui, sans-serif;

  --maxw: 760px;
  --maxw-wide: 1080px;

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset / base ---------- */
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  background:var(--ink);
  color:var(--parch);
  font-family:var(--serif-read);
  font-size:19px;
  line-height:1.72;
  font-weight:380;
  letter-spacing:.005em;
  overflow-x:hidden;
  position:relative;
  min-height:100vh;
}

/* Ambient background: vignette + radial gold glow */
body::before{
  content:"";
  position:fixed; inset:0; z-index:-2;
  background:
    radial-gradient(1100px 700px at 50% -10%, rgba(216,166,87,0.10), transparent 60%),
    radial-gradient(900px 900px at 85% 110%, rgba(216,166,87,0.05), transparent 60%),
    var(--ink);
}
body::after{
  content:"";
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:radial-gradient(120% 120% at 50% 40%, transparent 55%, rgba(0,0,0,0.55) 100%);
}

::selection{ background:rgba(216,166,87,0.28); color:#fff; }

a{ color:inherit; text-decoration:none; }
img,svg{ display:block; max-width:100%; }
em,i{ color:var(--gold-soft); font-style:italic; }

/* ---------- Reading progress bar ---------- */
.progress{
  position:fixed; top:0; left:0; height:2px; width:0%;
  background:linear-gradient(90deg, var(--gold-deep), var(--gold-soft));
  z-index:120;
  box-shadow:0 0 12px rgba(216,166,87,0.6);
  transition:width .08s linear;
}

/* ---------- Header ---------- */
.site-head{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px clamp(20px,5vw,52px);
  background:linear-gradient(180deg, rgba(10,12,18,0.92), rgba(10,12,18,0.0));
  backdrop-filter:blur(6px);
  transition:background .3s var(--ease), padding .3s var(--ease);
}
.site-head.scrolled{
  background:rgba(10,12,18,0.86);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--gold-faint);
  padding-top:14px; padding-bottom:14px;
}
.brand{
  display:flex; align-items:center; gap:12px;
  font-family:var(--sans); font-weight:600;
  letter-spacing:.02em; font-size:14px; color:var(--parch);
}
.brand .seal{ width:26px; height:26px; flex:0 0 auto; opacity:.95; }
.brand b{ color:var(--gold-soft); font-weight:600; }
.brand small{
  display:block; font-weight:400; font-size:11px;
  letter-spacing:.18em; text-transform:uppercase; color:var(--parch-faint);
}

.nav{ display:flex; align-items:center; gap:30px; }
.nav a{
  font-family:var(--sans); font-size:13px; font-weight:500;
  letter-spacing:.04em; color:var(--parch-dim);
  position:relative; padding:4px 0; transition:color .25s;
}
.nav a:hover, .nav a[aria-current="page"]{ color:var(--gold-soft); }
.nav a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:1px; width:0;
  background:var(--gold); transition:width .3s var(--ease);
}
.nav a:hover::after, .nav a[aria-current="page"]::after{ width:100%; }

/* Hamburger */
.burger{
  display:none; flex-direction:column; gap:5px; cursor:pointer;
  background:none; border:0; padding:8px; z-index:110;
}
.burger span{
  width:26px; height:2px; background:var(--gold-soft);
  transition:transform .3s var(--ease), opacity .3s var(--ease);
}
.burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* Mobile menu drawer */
.mobile-menu{
  position:fixed; inset:0; z-index:105;
  background:rgba(8,10,15,0.97);
  backdrop-filter:blur(10px);
  display:flex; flex-direction:column; justify-content:center;
  padding:0 36px; gap:6px;
  opacity:0; pointer-events:none; transform:translateY(-8px);
  transition:opacity .35s var(--ease), transform .35s var(--ease);
}
.mobile-menu.open{ opacity:1; pointer-events:auto; transform:none; }
.mobile-menu .mm-label{
  font-family:var(--sans); font-size:11px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--parch-faint); margin-bottom:18px;
}
.mobile-menu a{
  font-family:var(--serif-display); font-size:30px; font-weight:500;
  color:var(--parch); padding:9px 0; border-bottom:1px solid var(--gold-faint);
  display:flex; align-items:baseline; gap:16px;
}
.mobile-menu a .n{
  font-family:var(--sans); font-size:13px; color:var(--gold);
  font-weight:600; width:24px; flex:0 0 auto;
}
.mobile-menu a[aria-current="page"]{ color:var(--gold-soft); }

/* ---------- Layout shell ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 clamp(22px,6vw,40px); }
.wrap-wide{ max-width:var(--maxw-wide); margin:0 auto; padding:0 clamp(22px,6vw,40px); }

main{ padding-bottom:40px; }
section{ position:relative; }

/* ---------- HERO (home) ---------- */
.hero{
  min-height:100vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center;
  padding:120px 24px 80px; position:relative; overflow:hidden;
}
/* Concentric rings behind hero */
.hero-rings{
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:min(140vh,1300px); height:min(140vh,1300px);
  pointer-events:none; z-index:0; opacity:.5;
}
.hero-rings circle{ fill:none; stroke:var(--gold); stroke-width:.5; }

.hero-inner{ position:relative; z-index:2; max-width:880px; }
.kicker{
  font-family:var(--sans); font-size:12px; font-weight:600;
  letter-spacing:.4em; text-transform:uppercase; color:var(--gold);
  margin-bottom:26px; opacity:.9;
}
.hero h1{
  font-family:var(--serif-display); font-weight:600;
  font-size:clamp(28px,6.8vw,100px); line-height:.98;
  letter-spacing:-.035em;
  background:linear-gradient(178deg, #fbe7c6 0%, var(--gold) 46%, var(--gold-deep) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  padding:0 .04em .1em;
  filter:drop-shadow(0 6px 30px rgba(216,166,87,0.18));
}
.hero h1 .big1{ display:block; font-size:1.18em; }
.hero .subtitle{
  font-family:var(--serif-display); font-style:italic; font-weight:500;
  font-size:clamp(22px,3.4vw,34px); color:var(--parch);
  margin-top:10px; letter-spacing:.01em;
}
.hero .lede{
  font-family:var(--serif-read); font-size:clamp(17px,2vw,20px);
  color:var(--parch-dim); max-width:560px; margin:26px auto 0;
}
.hero-verse{
  margin-top:40px; font-family:var(--serif-display); font-style:italic;
  font-size:clamp(20px,3vw,28px); color:var(--gold-soft); line-height:1.4;
}
.hero-verse cite{
  display:block; font-style:normal; font-family:var(--sans);
  font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--parch-faint); margin-top:14px;
}
.hero-meta{
  margin-top:30px; display:flex; gap:30px; justify-content:center; flex-wrap:wrap;
  font-family:var(--sans); font-size:12px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--parch-faint);
}
.hero-meta span b{ color:var(--gold-soft); font-weight:600; }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--sans); font-size:14px; font-weight:600;
  letter-spacing:.06em; padding:15px 30px;
  border:1px solid var(--gold); color:var(--gold-soft);
  border-radius:2px; background:rgba(216,166,87,0.04);
  transition:all .3s var(--ease); cursor:pointer;
}
.btn:hover{ background:var(--gold); color:var(--ink); box-shadow:0 8px 30px rgba(216,166,87,0.25); }
.btn .arr{ transition:transform .3s var(--ease); }
.btn:hover .arr{ transform:translateX(5px); }
.btn-row{ margin-top:44px; display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }

.scroll-cue{
  position:absolute; bottom:30px; left:50%; transform:translateX(-50%);
  font-family:var(--sans); font-size:11px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--parch-faint); z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:8px;
}
.scroll-cue .bar{ width:1px; height:34px; background:linear-gradient(var(--gold),transparent); animation:cue 2s var(--ease) infinite; }
@keyframes cue{ 0%{opacity:.2;transform:scaleY(.3);transform-origin:top} 50%{opacity:1;transform:scaleY(1)} 100%{opacity:.2;transform:scaleY(.3);transform-origin:bottom} }

/* ---------- Home index ---------- */
.index-sec{ padding:96px 0 110px; }
.sec-head{ text-align:center; margin-bottom:60px; }
.sec-head .eyebrow{
  font-family:var(--sans); font-size:12px; letter-spacing:.34em;
  text-transform:uppercase; color:var(--gold); margin-bottom:16px;
}
.sec-head h2{
  font-family:var(--serif-display); font-weight:500;
  font-size:clamp(34px,5vw,54px); line-height:1.05; color:var(--parch);
}
.sec-head p{ color:var(--parch-dim); max-width:520px; margin:18px auto 0; font-size:18px; }

.chapter-list{ list-style:none; max-width:820px; margin:0 auto; }
.chapter-list li{ border-top:1px solid var(--gold-faint); }
.chapter-list li:last-child{ border-bottom:1px solid var(--gold-faint); }
.chap-link{
  display:grid; grid-template-columns:72px 1fr auto; align-items:center;
  gap:20px; padding:26px 14px; transition:background .3s var(--ease), padding .3s var(--ease);
}
.chap-link:hover{ background:rgba(216,166,87,0.05); padding-left:24px; }
.chap-link .num{
  font-family:var(--serif-display); font-size:42px; font-weight:500;
  color:var(--gold); line-height:1; opacity:.8;
}
.chap-link:hover .num{ opacity:1; }
.chap-link .body h3{
  font-family:var(--serif-display); font-weight:500; font-size:26px;
  color:var(--parch); line-height:1.15;
}
.chap-link .body p{
  font-family:var(--sans); font-size:13.5px; color:var(--parch-dim);
  margin-top:5px; letter-spacing:.01em;
}
.chap-link .go{
  font-family:var(--sans); font-size:22px; color:var(--gold);
  opacity:.4; transition:opacity .3s, transform .3s var(--ease);
}
.chap-link:hover .go{ opacity:1; transform:translateX(4px); }

/* ---------- Chapter hero ---------- */
.chap-hero{
  min-height:74vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center;
  padding:160px 24px 70px; position:relative; overflow:hidden;
}
.chap-hero .glyph{ width:84px; height:84px; margin:0 auto 30px; opacity:.9; }
.chap-num{
  font-family:var(--sans); font-size:13px; font-weight:600;
  letter-spacing:.4em; text-transform:uppercase; color:var(--gold);
  margin-bottom:20px;
}
.chap-hero h1{
  font-family:var(--serif-display); font-weight:600;
  font-size:clamp(40px,7.5vw,86px); line-height:1.0; letter-spacing:-.005em;
  background:linear-gradient(178deg,#fbe7c6,var(--gold) 55%,var(--gold-deep));
  -webkit-background-clip:text; background-clip:text; color:transparent;
  max-width:14ch; padding-bottom:.06em;
}
.chap-hero .deck{
  font-family:var(--serif-display); font-style:italic; font-size:clamp(19px,2.6vw,26px);
  color:var(--parch-dim); margin-top:18px; max-width:30ch;
}
.chap-hero .refs{
  margin-top:24px; font-family:var(--sans); font-size:12px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--parch-faint);
}

/* ---------- Prose content ---------- */
.prose{ padding:20px 0 60px; }
.prose > * + *{ margin-top:1.5em; }
.prose p{ color:var(--parch-dim); text-wrap:pretty; }
.prose p strong, .prose strong{ color:var(--parch); font-weight:600; }
.prose .lead{ font-size:clamp(20px,2.6vw,24px); color:var(--parch); line-height:1.6; }

.eyebrow-h{
  font-family:var(--sans); font-size:12px; letter-spacing:.3em;
  text-transform:uppercase; color:var(--gold); margin:64px 0 4px;
}
.prose h2{
  font-family:var(--serif-display); font-weight:500; font-size:clamp(28px,4.4vw,42px);
  color:var(--parch); line-height:1.1; margin-top:8px;
}
.prose h3{
  font-family:var(--serif-display); font-weight:600; font-size:clamp(22px,3vw,28px);
  color:var(--gold-soft); margin-top:48px;
}
.prose h2 + p, .prose h3 + p{ margin-top:1em; }

.rule{ height:1px; background:var(--gold-faint); margin:18px 0; border:0; }
.divider-ornament{
  display:flex; align-items:center; justify-content:center; gap:18px;
  margin:64px 0; color:var(--gold); opacity:.7;
}
.divider-ornament::before, .divider-ornament::after{
  content:""; height:1px; width:90px; background:linear-gradient(90deg,transparent,var(--gold-line),transparent);
}
.divider-ornament svg{ width:22px; height:22px; }

/* ---------- Verse card ---------- */
.verse-card{
  position:relative; border:1px solid var(--gold-line); border-radius:3px;
  background:linear-gradient(180deg, rgba(216,166,87,0.05), rgba(216,166,87,0.01));
  padding:48px 44px 38px; margin:42px 0; overflow:hidden;
  transition:border-color .4s var(--ease), transform .4s var(--ease), box-shadow .4s var(--ease);
}
.verse-card:hover{
  border-color:rgba(216,166,87,0.45);
  box-shadow:0 18px 50px rgba(0,0,0,0.4), inset 0 0 50px rgba(216,166,87,0.03);
}
.verse-card .mark{
  position:absolute; top:-18px; left:22px;
  font-family:var(--serif-display); font-size:130px; line-height:1;
  color:var(--gold); opacity:.16; user-select:none; pointer-events:none;
}
.verse-card p{
  font-family:var(--serif-read); font-size:clamp(19px,2.4vw,23px);
  line-height:1.62; color:var(--parch); font-style:italic; position:relative;
}
.verse-card cite{
  display:block; font-style:normal; margin-top:20px;
  font-family:var(--sans); font-size:12px; font-weight:600;
  letter-spacing:.14em; text-transform:uppercase; color:var(--gold-soft);
}
.verse-card cite span{ color:var(--parch-faint); font-weight:400; text-transform:none; letter-spacing:.02em; }

/* ---------- Pull quote ---------- */
.pull{
  text-align:center; margin:80px auto; max-width:18ch;
  font-family:var(--serif-display); font-style:italic; font-weight:500;
  font-size:clamp(30px,6vw,56px); line-height:1.12; color:var(--gold-soft);
  filter:drop-shadow(0 4px 24px rgba(216,166,87,0.12));
}
.pull.wide{ max-width:24ch; }
.pull cite{
  display:block; font-style:normal; font-family:var(--sans);
  font-size:12px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--parch-faint); margin-top:22px; font-weight:500;
}

/* ---------- Parallel / hinge table ---------- */
.parallel{ margin:48px 0; }
.parallel-head{
  display:grid; grid-template-columns:1fr 1fr; gap:0;
  font-family:var(--sans); font-size:13px; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; text-align:center;
}
.parallel-head div{ padding:14px; color:var(--gold-soft); }
.parallel-head div:first-child{ border-right:1px solid var(--gold-line); }
.parallel-row{
  display:grid; grid-template-columns:1fr 1fr; position:relative;
  border-top:1px solid var(--gold-faint);
}
.parallel-row > div{
  padding:18px 24px; font-family:var(--serif-read); font-size:16.5px;
  color:var(--parch-dim); line-height:1.5;
}
.parallel-row > div:first-child{ text-align:right; border-right:1px solid var(--gold-line); }
.parallel-row > div:last-child{ text-align:left; }
.parallel-row .a{ color:var(--parch); }
/* central hinge */
.parallel::after{ content:none; }
.hinge{
  position:relative; display:flex; align-items:center; justify-content:center;
  margin:0 auto;
}
.parallel-wrap{ position:relative; border:1px solid var(--gold-faint); border-radius:3px; overflow:hidden; background:rgba(216,166,87,0.02); }
.parallel-wrap::before{
  content:""; position:absolute; top:0; bottom:0; left:50%; width:1px;
  background:linear-gradient(180deg, transparent, var(--gold-line) 12%, var(--gold-line) 88%, transparent);
  transform:translateX(-.5px); z-index:1;
}
.hinge-dot{
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:34px; height:34px; border-radius:50%; z-index:2;
  background:var(--ink-2); border:1px solid var(--gold); color:var(--gold);
  display:flex; align-items:center; justify-content:center; font-size:14px;
  font-family:var(--sans);
}

/* ---------- Before → after ---------- */
.transform-row{
  display:grid; grid-template-columns:1fr auto 1fr; gap:22px; align-items:stretch;
  margin:24px 0;
}
.transform-card{
  border:1px solid var(--gold-line); border-radius:3px; padding:26px 26px;
  background:rgba(216,166,87,0.025);
}
.transform-card .tag{
  font-family:var(--sans); font-size:11px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--gold); margin-bottom:10px;
}
.transform-card h4{ font-family:var(--serif-display); font-size:23px; font-weight:600; color:var(--parch); }
.transform-card p{ font-family:var(--sans); font-size:13.5px; color:var(--parch-dim); margin-top:8px; }
.transform-arrow{
  display:flex; align-items:center; justify-content:center; color:var(--gold); font-size:26px;
}
.transform-arrow svg{ width:38px; height:38px; }

/* ---------- Stats (O Livro em Números) ---------- */
.stat-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
  gap:1px; background:var(--gold-faint); border:1px solid var(--gold-faint);
  border-radius:3px; overflow:hidden; margin:40px 0;
}
.stat{
  background:var(--ink); padding:38px 26px; text-align:center;
  transition:background .4s var(--ease);
}
.stat:hover{ background:var(--ink-3); }
.stat .big{
  font-family:var(--serif-display); font-weight:600; line-height:.9;
  font-size:clamp(48px,7vw,68px);
  background:linear-gradient(178deg,#fbe7c6,var(--gold) 60%,var(--gold-deep));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.stat .lab{
  font-family:var(--sans); font-size:12.5px; letter-spacing:.08em;
  color:var(--parch-dim); margin-top:12px; line-height:1.4;
}

/* ---------- Act cards (estrutura narrativa) ---------- */
.acts-label{
  font-family:var(--serif-display); font-style:italic; font-size:clamp(26px,4vw,38px);
  color:var(--gold-soft); text-align:center; margin:60px 0 8px;
}
.act{
  display:grid; grid-template-columns:130px 1fr; gap:30px;
  padding:34px 0; border-top:1px solid var(--gold-faint); align-items:start;
}
.act:last-child{ border-bottom:1px solid var(--gold-faint); }
.act .meta .ano{
  font-family:var(--serif-display); font-size:30px; font-weight:600; color:var(--gold);
  line-height:1;
}
.act .meta .caps{
  font-family:var(--sans); font-size:12px; letter-spacing:.06em;
  color:var(--parch-faint); margin-top:8px;
}
.act .text h4{ font-family:var(--serif-display); font-weight:600; font-size:25px; color:var(--parch); }
.act .text p{ font-family:var(--serif-read); font-size:16.5px; color:var(--parch-dim); margin-top:10px; }

/* ---------- Reason / numbered blocks ---------- */
.reason{
  display:grid; grid-template-columns:auto 1fr; gap:24px; align-items:start;
  padding:30px 0; border-top:1px solid var(--gold-faint);
}
.reason .badge{
  font-family:var(--sans); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--gold); border:1px solid var(--gold-line); border-radius:40px;
  padding:7px 15px; white-space:nowrap;
}
.reason h4{ font-family:var(--serif-display); font-weight:600; font-size:24px; color:var(--parch); }
.reason p{ font-family:var(--serif-read); color:var(--parch-dim); margin-top:8px; }

/* Curiosity list */
.curio{ list-style:none; counter-reset:c; margin:32px 0; }
.curio li{
  counter-increment:c; display:grid; grid-template-columns:auto 1fr; gap:22px;
  padding:22px 0; border-top:1px solid var(--gold-faint);
  font-family:var(--serif-read); color:var(--parch-dim); font-size:16.5px; align-items:start;
}
.curio li::before{
  content:counter(c,decimal-leading-zero);
  font-family:var(--serif-display); font-size:26px; font-weight:500;
  color:var(--gold); opacity:.8; line-height:1.2;
}

/* Scene blocks */
.scene{ margin:56px 0; }
.scene .scene-tag{
  font-family:var(--sans); font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--gold); margin-bottom:8px;
}
.scene h3{ margin-top:0; color:var(--parch); }
.scene .ref{ font-family:var(--sans); font-size:12px; letter-spacing:.08em; color:var(--parch-faint); margin-top:4px; }
.scene p{ font-family:var(--serif-read); color:var(--parch-dim); margin-top:16px; }

/* ---------- Footer nav (prev/next) ---------- */
.foot-nav{
  display:grid; grid-template-columns:1fr 1fr; gap:18px;
  max-width:var(--maxw-wide); margin:40px auto 0; padding:48px clamp(22px,6vw,40px) 0;
  border-top:1px solid var(--gold-faint);
}
.foot-link{
  border:1px solid var(--gold-faint); border-radius:3px; padding:24px 26px;
  transition:all .35s var(--ease); background:rgba(216,166,87,0.02);
}
.foot-link:hover{ border-color:var(--gold-line); background:rgba(216,166,87,0.06); }
.foot-link .dir{
  font-family:var(--sans); font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--gold); margin-bottom:10px;
}
.foot-link .ti{ font-family:var(--serif-display); font-size:23px; font-weight:500; color:var(--parch); line-height:1.1; }
.foot-link.next{ text-align:right; }
.foot-link.disabled{ opacity:.28; pointer-events:none; }

.site-foot{
  text-align:center; padding:70px 24px 60px; max-width:var(--maxw); margin:0 auto;
}
.site-foot .closing{
  font-family:var(--serif-display); font-style:italic; font-size:clamp(24px,4vw,34px);
  color:var(--gold-soft); line-height:1.3; margin-bottom:30px;
}
.site-foot .sources{
  font-family:var(--sans); font-size:12px; letter-spacing:.04em; color:var(--parch-faint);
  line-height:2;
}
.site-foot .sources b{ color:var(--parch-dim); display:block; letter-spacing:.18em; text-transform:uppercase; margin-bottom:10px; font-size:11px; }
.site-foot .copyr{ margin-top:34px; font-family:var(--sans); font-size:11px; letter-spacing:.14em; color:var(--parch-faint); text-transform:uppercase; }

/* ---------- Scroll reveal ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; }
.reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto; }
}

/* ---------- Responsive ---------- */
@media (max-width:880px){
  .nav{ display:none; }
  .burger{ display:flex; }
}
@media (max-width:680px){
  body{ font-size:17.5px; }
  .chap-link{ grid-template-columns:54px 1fr; gap:14px; padding:22px 6px; }
  .chap-link .go{ display:none; }
  .chap-link .num{ font-size:32px; }
  .act{ grid-template-columns:1fr; gap:10px; }
  .act .meta{ display:flex; align-items:baseline; gap:14px; }
  .act .meta .caps{ margin-top:0; }
  .reason{ grid-template-columns:1fr; gap:12px; }
  .transform-row{ grid-template-columns:1fr; }
  .transform-arrow{ transform:rotate(90deg); padding:4px 0; }
  .foot-nav{ grid-template-columns:1fr; }
  .verse-card{ padding:42px 26px 30px; }
  .parallel-row > div{ padding:14px 14px; font-size:14.5px; }
  .parallel-head{ font-size:11px; }
}


/* ===== RESTYLE Meia-noite & Ouro (telão) — override ===== */
:root{
  --midnight:#060709; --midnight-2:#0d1019; --midnight-3:#12151f;
  --gold:#f0bd45; --gold-soft:#ffe09a; --gold-deep:#bb8230;
  --parchment:#f1ebde; --parchment-dim:#dcd5c6;
  --line:rgba(240,189,69,0.30); --line-soft:rgba(236,229,214,0.10);
  --accent:#f0bd45;
  --ink:#060709; --ink-2:#0d1019; --ink-3:#12151f;
  --parch:#f1ebde; --parch-dim:#dcd5c6;
}
body{ font-size:22px; line-height:1.8; }
strong, b{ color:#ffe09a; font-weight:600; }
em{ color:#ffe09a; }
.verse-ref, .bl-ref, .pull-quote-cite, .hero-verse cite, .a-ref, .ref{ color:#ff2a1f; text-shadow:none; }
.eyebrow{ font-size:14px; }
