/* =============================================================
   STILLPOINT — shared rulebook stylesheet
   Aged-paper body, slate covers, amber "live time" accents.
   ============================================================= */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700;900&family=EB+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=IM+Fell+English+SC&display=swap');

:root{
  --paper:#efe7d4;
  --paper-2:#e7ddc6;
  --ink:#211d16;
  --ink-soft:#4a4234;
  --slate:#1b232e;
  --slate-2:#27323f;
  --slate-3:#34414f;
  --frost:#dfe7ee;
  --amber:#c8862e;
  --amber-bright:#e0a54a;
  --amber-deep:#9c6418;
  --rule:#c2b596;
  --shadow:rgba(20,16,10,.28);
  --maxw:780px;
}

*{box-sizing:border-box;}

html{scroll-behavior:smooth;}

body{
  margin:0;
  background:
    radial-gradient(circle at 20% -10%, rgba(255,255,255,.35), transparent 40%),
    var(--paper);
  color:var(--ink);
  font-family:'EB Garamond', Georgia, serif;
  font-size:19px;
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
}

/* subtle paper grain */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;opacity:.5;
}

.wrap{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:0 26px 120px;}

/* ---------- COVER ---------- */
.cover{
  position:relative;min-height:100vh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;
  color:var(--frost);overflow:hidden;
  background:var(--slate);
}
.cover img.cover-art{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:brightness(.62) contrast(1.05);z-index:0;
}
.cover .veil{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg, rgba(15,20,27,.55) 0%, rgba(15,20,27,.15) 38%, rgba(15,20,27,.78) 100%);}
.cover .cover-inner{position:relative;z-index:2;padding:40px;max-width:760px;}
.cover .eyebrow{font-family:'IM Fell English SC',serif;letter-spacing:.45em;
  text-transform:uppercase;font-size:.82rem;color:var(--amber-bright);margin-bottom:1.1rem;
  text-shadow:0 2px 12px #000;}
.cover h1{
  font-family:'Cinzel',serif;font-weight:900;font-size:clamp(3.4rem,11vw,7rem);
  letter-spacing:.06em;margin:0;line-height:.95;color:#f3ead6;
  text-shadow:0 3px 26px rgba(0,0,0,.85), 0 0 50px rgba(200,134,46,.25);
}
.cover .tagline{font-family:'Cinzel',serif;font-weight:400;letter-spacing:.32em;
  text-transform:uppercase;font-size:clamp(.8rem,2.4vw,1.05rem);margin-top:1.4rem;color:#cdd6df;
  text-shadow:0 2px 10px #000;}
.cover .booktype{margin-top:2.4rem;font-family:'IM Fell English SC',serif;
  font-size:1.45rem;letter-spacing:.2em;color:var(--amber-bright);
  border-top:1px solid rgba(224,165,74,.5);border-bottom:1px solid rgba(224,165,74,.5);
  padding:.55rem 1.6rem;text-shadow:0 2px 10px #000;}
.cover .scroll-cue{position:absolute;bottom:26px;z-index:2;color:#9fb0bf;font-size:.8rem;
  letter-spacing:.3em;text-transform:uppercase;animation:bob 2.4s ease-in-out infinite;}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(7px)}}

/* ---------- TYPOGRAPHY ---------- */
h2,h3,h4{font-family:'Cinzel',serif;color:var(--slate);line-height:1.15;}
h2{font-size:2rem;font-weight:700;margin:2.6rem 0 .2rem;letter-spacing:.02em;}
h2 .kicker{display:block;font-family:'IM Fell English SC',serif;font-size:.78rem;
  letter-spacing:.4em;color:var(--amber-deep);text-transform:uppercase;margin-bottom:.35rem;}
h2::after{content:"";display:block;height:2px;width:100%;margin-top:.5rem;
  background:linear-gradient(90deg,var(--amber) 0%, var(--rule) 60%, transparent 100%);}
h3{font-size:1.4rem;font-weight:600;margin:2rem 0 .3rem;color:var(--slate-2);}
h4{font-size:1.08rem;font-weight:600;margin:1.4rem 0 .2rem;color:var(--amber-deep);
  font-family:'EB Garamond',serif;letter-spacing:.04em;text-transform:uppercase;font-style:italic;}
p{margin:.7rem 0;}
a{color:var(--amber-deep);}
strong{color:#3a2f1a;}
em{color:#352d1f;}

.lead{font-size:1.18rem;color:var(--ink-soft);font-style:italic;}
.dropcap::first-letter{
  font-family:'Cinzel',serif;font-weight:900;float:left;font-size:4.4rem;line-height:.78;
  padding:.05em .12em 0 0;color:var(--amber-deep);text-shadow:1px 2px 0 rgba(0,0,0,.08);
}
.kw{font-variant:small-caps;letter-spacing:.04em;color:var(--amber-deep);font-weight:600;}
.term{font-style:italic;}

/* ---------- CHAPTER OPENERS ---------- */
.chapter{padding-top:30px;}
.chapter-opener{position:relative;margin:30px 0 30px;border-radius:5px;overflow:hidden;
  box-shadow:0 14px 34px var(--shadow);border:1px solid #b7a987;}
.chapter-opener img{display:block;width:100%;height:340px;object-fit:cover;filter:contrast(1.03);}
.chapter-opener .co-veil{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,26,33,.15),rgba(20,26,33,.82));}
.chapter-opener .co-text{position:absolute;left:0;right:0;bottom:0;padding:22px 26px;color:#f2ead8;}
.chapter-opener .co-num{font-family:'IM Fell English SC',serif;letter-spacing:.4em;
  font-size:.82rem;color:var(--amber-bright);text-transform:uppercase;}
.chapter-opener .co-title{font-family:'Cinzel',serif;font-weight:900;font-size:2.5rem;
  line-height:1;margin:.1rem 0 0;text-shadow:0 2px 16px #000;}

/* ---------- FIGURES ---------- */
figure{margin:1.6rem 0;border:1px solid #b7a987;background:#fbf7ec;padding:8px;
  box-shadow:0 8px 20px var(--shadow);}
figure img{display:block;width:100%;border:1px solid #8d7f60;}
figure.portrait{max-width:340px;}
figure.float-right{float:right;max-width:330px;margin:.4rem 0 1.2rem 1.6rem;}
figure.float-left{float:left;max-width:330px;margin:.4rem 1.6rem 1.2rem 0;}
figcaption{font-family:'IM Fell English SC',serif;font-size:.82rem;letter-spacing:.08em;
  color:var(--ink-soft);text-align:center;padding:.5rem .4rem .2rem;}
.clearfix{clear:both;}

/* ---------- TABLES ---------- */
.table-title{font-family:'IM Fell English SC',serif;letter-spacing:.12em;font-size:.95rem;
  color:var(--amber-deep);margin:1.6rem 0 .1rem;text-transform:uppercase;}
table{width:100%;border-collapse:collapse;margin:.5rem 0 1.6rem;font-size:.96rem;
  background:#fbf8ef;box-shadow:0 6px 16px var(--shadow);border:1px solid #b7a987;}
caption{caption-side:top;font-family:'IM Fell English SC',serif;letter-spacing:.1em;
  color:var(--amber-deep);text-align:left;padding:.3rem 0;font-size:.95rem;text-transform:uppercase;}
th{background:var(--slate-2);color:var(--frost);font-family:'Cinzel',serif;font-weight:600;
  font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;padding:.55rem .7rem;text-align:left;
  border-bottom:2px solid var(--amber-deep);}
td{padding:.5rem .7rem;border-bottom:1px solid #d8cbab;vertical-align:top;}
tbody tr:nth-child(odd){background:#f2ebd8;}
tbody tr:hover{background:#f6eecb;}
td.c,th.c{text-align:center;}
td.dice{font-family:'Cinzel',serif;font-weight:700;color:var(--amber-deep);white-space:nowrap;}

/* ---------- SIDEBARS / ASIDES ---------- */
aside.sidebar{background:linear-gradient(180deg,#f7f0dd,#efe5cb);
  border:1px solid #c2b08a;border-left:5px solid var(--amber);
  padding:1rem 1.2rem;margin:1.6rem 0;box-shadow:0 6px 16px var(--shadow);border-radius:3px;}
aside.sidebar h4{margin-top:0;color:var(--amber-deep);}
aside.lore{background:linear-gradient(180deg,#222c38,#1a232d);color:#dfe7ee;
  border:1px solid #3c4a5a;border-left:5px solid var(--amber);
  padding:1.1rem 1.3rem;margin:1.6rem 0;box-shadow:0 8px 22px var(--shadow);border-radius:3px;}
aside.lore h4{color:var(--amber-bright);}
aside.lore .term,aside.lore strong{color:#f0e6cf;}

/* in-world flavor quote */
.flavor{font-style:italic;color:var(--ink-soft);border-left:3px solid var(--rule);
  padding:.2rem 0 .2rem 1.1rem;margin:1.4rem 0;font-size:1.06rem;}
.flavor .by{display:block;font-style:normal;font-variant:small-caps;letter-spacing:.08em;
  font-size:.85rem;color:var(--amber-deep);margin-top:.3rem;}

/* ---------- STAT BLOCKS ---------- */
.statblock{background:#fbf8ef;border:1px solid #9c8c66;border-top:5px solid var(--slate-2);
  padding:1rem 1.2rem;margin:1.4rem 0;box-shadow:0 8px 20px var(--shadow);border-radius:3px;
  font-size:.94rem;}
.statblock .sb-name{font-family:'Cinzel',serif;font-weight:700;font-size:1.25rem;color:var(--slate);
  margin:0;}
.statblock .sb-type{font-style:italic;color:var(--ink-soft);margin:.05rem 0 .5rem;font-size:.92rem;}
.statblock hr{border:0;border-top:1px solid var(--amber-deep);margin:.5rem 0;}
.statblock .sb-line{margin:.2rem 0;}
.statblock .sb-line b{color:var(--slate-2);font-variant:small-caps;letter-spacing:.03em;}
.sb-stats{display:flex;flex-wrap:wrap;gap:.4rem .9rem;margin:.5rem 0;}
.sb-stats span{font-family:'Cinzel',serif;font-size:.8rem;background:var(--slate-2);color:var(--frost);
  padding:.2rem .55rem;border-radius:3px;letter-spacing:.04em;}

/* class feature card */
.feature{border:1px dashed #b09a6c;background:#f7f1e0;padding:.7rem 1rem;margin:.8rem 0;border-radius:3px;}
.feature .ft-name{font-family:'Cinzel',serif;font-weight:600;color:var(--amber-deep);}

/* ---------- GRIDS ---------- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;margin:1.4rem 0;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:1.4rem 0;}
@media(max-width:680px){.grid-2,.grid-3{grid-template-columns:1fr;}}

/* pull stat list */
.statline{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0;}
.statline .chip{font-family:'Cinzel',serif;font-size:.8rem;letter-spacing:.04em;
  background:var(--slate-2);color:var(--frost);padding:.3rem .7rem;border-radius:20px;}
.statline .chip b{color:var(--amber-bright);}

/* ---------- ORNAMENTS ---------- */
.ornament{display:flex;align-items:center;justify-content:center;gap:1rem;margin:2.4rem 0;}
.ornament::before,.ornament::after{content:"";height:1px;flex:1;max-width:160px;
  background:linear-gradient(90deg,transparent,var(--rule),transparent);}
.ornament img{height:44px;opacity:.85;}
.ornament .glyph{color:var(--amber-deep);font-size:1.2rem;letter-spacing:.5em;}

/* ---------- TOC ---------- */
.toc{background:#f7f0dd;border:1px solid #c2b08a;padding:1.4rem 1.6rem;margin:2rem 0;
  box-shadow:0 8px 20px var(--shadow);border-radius:4px;}
.toc h2{margin-top:0;}
.toc ol{columns:2;column-gap:2.4rem;margin:0;padding-left:1.2rem;}
.toc li{margin:.3rem 0;break-inside:avoid;}
.toc a{text-decoration:none;color:var(--slate-2);}
.toc a:hover{color:var(--amber-deep);}
@media(max-width:680px){.toc ol{columns:1;}}

/* badge for example boxes */
.example{background:#eef3f5;border:1px solid #b9c6cf;border-left:5px solid var(--slate-3);
  padding:.9rem 1.1rem;margin:1.3rem 0;border-radius:3px;font-size:.95rem;}
.example .ex-tag{font-family:'IM Fell English SC',serif;letter-spacing:.18em;
  color:var(--slate-3);text-transform:uppercase;font-size:.8rem;display:block;margin-bottom:.3rem;}

.note-amber{color:var(--amber-deep);font-weight:600;}

hr.rule{border:0;border-top:1px solid var(--rule);margin:2rem 0;}

/* footer */
.book-foot{text-align:center;margin-top:4rem;padding-top:1.5rem;border-top:1px solid var(--rule);
  font-family:'IM Fell English SC',serif;letter-spacing:.2em;color:var(--ink-soft);font-size:.85rem;}

/* ---------- PRINT ---------- */
@media print{
  body{font-size:11pt;background:#fff;}
  body::before{display:none;}
  .cover{min-height:auto;page-break-after:always;}
  .scroll-cue{display:none;}
  .chapter{page-break-before:always;}
  figure,table,.statblock,aside,.example{page-break-inside:avoid;}
  h2,h3,h4{page-break-after:avoid;}
  .chapter-opener{box-shadow:none;}
  a{color:var(--ink);}
}
