/* ============================================================
   Songs of the Firstborn — Shared Stylesheet
   ============================================================ */

:root{
  --bg:#0a0d0e; --bg2:#101415; --panel:#161b1c; --panel2:#1e2426;
  --text:#eee7dc; --muted:#bdb5aa; --dim:#8f867b;
  --blue:#55c7ff; --blue2:#1e9bff; --ice:#d8f3ff;
  --gold:#c9a96e; --warm:#d7c7b3;
  --line:rgba(85,199,255,.25); --stoneLine:rgba(238,231,220,.12);
}

/* ── VelDrath Script Font ── */
@font-face{
  font-family:'VelDrath';
  src:url('fonts/VelDrath.ttf') format('truetype');
  font-weight:normal;
  font-style:normal;
}
.veldrath{font-family:'VelDrath',serif}

/* ── Reset & Base ── */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:Georgia,"Times New Roman",serif;line-height:1.55}
a{color:inherit;text-decoration:none}

/* ── Navigation ── */
.nav{position:sticky;top:0;z-index:50;background:rgba(10,13,14,.88);backdrop-filter:blur(14px);border-bottom:1px solid var(--stoneLine)}
.navin{max-width:1220px;margin:auto;display:flex;align-items:center;justify-content:space-between;padding:14px 20px;gap:18px}
.brand{color:var(--blue);letter-spacing:.08em;font-size:18px;white-space:nowrap}
.links{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end}
.links a{color:var(--muted);font-size:14px;padding:8px 10px;border-radius:999px;transition:.2s}
.links a:hover,.links a.active{background:rgba(85,199,255,.13);color:var(--ice);box-shadow:0 0 18px rgba(30,155,255,.14)}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;border:1px solid var(--stoneLine);border-radius:10px;background:transparent}
.hamburger span{display:block;width:22px;height:2px;background:var(--muted);border-radius:2px;transition:.3s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none;flex-direction:column;gap:4px;padding:12px 16px 16px;border-top:1px solid var(--stoneLine);background:rgba(10,13,14,.98)}
.mobile-menu.open{display:flex}
.mobile-menu a{color:var(--muted);font-size:15px;padding:11px 14px;border-radius:12px;border:1px solid transparent;transition:.2s}
.mobile-menu a:hover,.mobile-menu a.active{background:rgba(85,199,255,.10);color:var(--ice);border-color:rgba(85,199,255,.18)}

/* ── Hero ── */
.hero{position:relative;min-height:80vh;display:flex;align-items:center;overflow:hidden;padding:72px 20px;border-bottom:1px solid var(--stoneLine);background:radial-gradient(circle at 70% 35%,rgba(85,199,255,.16),transparent 33%),linear-gradient(to bottom,#101617,var(--bg))}
.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent,rgba(255,255,255,.055),transparent);opacity:.38}
.wrap{max-width:1220px;margin:auto;position:relative;z-index:1}
.heroGrid{display:grid;grid-template-columns:1.04fr .96fr;gap:48px;align-items:center}

/* ── Typography ── */
.eyebrow{letter-spacing:.32em;text-transform:uppercase;color:rgba(165,225,255,.82);font-size:12px;margin-bottom:15px}
h1{font-size:clamp(50px,9vw,104px);line-height:.9;letter-spacing:-.06em;font-weight:500;margin:0}
h1 span,h2 span{color:var(--blue)}
h2{font-size:clamp(34px,6vw,58px);line-height:1.02;letter-spacing:-.045em;font-weight:500;margin:0 0 18px}
h3{font-size:25px;font-weight:500;margin:0;color:var(--ice)}
h4{font-size:19px;font-weight:500;margin:0 0 8px;color:var(--ice)}
p{font-size:18px;color:var(--muted)}
.lead{font-size:21px;color:#dcd4c9;max-width:820px}
.quote{font-style:italic;color:#d8d0c4;font-size:24px;margin-top:25px}

/* ── Buttons ── */
.btns{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px}
.btn{display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(85,199,255,.42);border-radius:999px;padding:13px 20px;color:var(--blue);background:rgba(85,199,255,.04);transition:background .22s ease,color .22s ease,border-color .22s ease,box-shadow .22s ease,transform .22s ease}
.btn:hover{background:linear-gradient(135deg,#8fe1ff,#1e9bff);color:#041018;border-color:#75d7ff;box-shadow:0 0 28px rgba(30,155,255,.28);transform:translateY(-1px)}

/* ── Layout ── */
section{padding:76px 20px}
.dark{background:var(--bg2)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}

/* ── Cards ── */
.card{background:rgba(255,255,255,.035);border:1px solid var(--stoneLine);border-radius:26px;padding:24px;box-shadow:0 20px 70px rgba(0,0,0,.20)}
.card.blue{border-color:var(--line);background:linear-gradient(135deg,rgba(85,199,255,.08),rgba(255,255,255,.025))}

/* ── Misc UI ── */
.meta{color:rgba(165,225,255,.78);font-size:14px;margin-top:5px}
.small{font-size:16px}
.booknum{font-size:12px;letter-spacing:.25em;color:var(--blue);text-transform:uppercase;margin-bottom:10px}
.note{font-size:14px;color:var(--dim);margin-top:8px}

/* ── Hero Image ── */
.heroImage{min-height:520px;border:1px solid rgba(165,225,255,.18);border-radius:34px;background:radial-gradient(circle at 50% 42%,rgba(120,140,150,.10),transparent 42%),linear-gradient(145deg,#101416,#050607);position:relative;overflow:hidden;box-shadow:0 28px 90px rgba(0,0,0,.42)}
.heroImage img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;filter:contrast(1.04)}
.heroImage:after{content:"The Forgotten Word";position:absolute;bottom:28px;left:0;right:0;text-align:center;letter-spacing:.22em;text-transform:uppercase;color:rgba(210,235,255,.62);font-size:12px;text-shadow:0 0 18px rgba(36,145,255,.42)}

/* ── Book Grid ── */
.bookGrid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.bookCard{min-height:260px;display:flex;flex-direction:column;justify-content:space-between}
.bookCard p{font-size:16px}

/* ── Characters ── */
.character{padding:0;overflow:hidden;transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease}
.character:hover{transform:translateY(-3px);border-color:rgba(85,199,255,.36);box-shadow:0 0 30px rgba(30,155,255,.12),0 20px 70px rgba(0,0,0,.24)}
.character a{display:block}
.portrait{display:block;width:100%;aspect-ratio:3/4;object-fit:cover;background:#161b1c;border-bottom:1px solid var(--stoneLine)}
.charbody{padding:18px}
.charbody h3{font-size:22px}
.charbody p{font-size:15.5px}

/* ── Profile Cards ── */
.profileList{display:grid;gap:30px}
.profileCard{display:grid;grid-template-columns:420px 1fr;gap:0;background:rgba(255,255,255,.035);border:1px solid var(--stoneLine);border-radius:32px;overflow:hidden;box-shadow:0 20px 70px rgba(0,0,0,.22);scroll-margin-top:90px}
.profileArt{background:#0c0f10;border-right:1px solid var(--stoneLine);display:flex;align-items:center;justify-content:center;padding:16px}
.profileArt img{width:100%;height:auto;max-height:760px;object-fit:contain;border-radius:20px;box-shadow:0 18px 60px rgba(0,0,0,.32)}
.profileText{padding:34px}
.profileText h2{margin-bottom:8px}
.profileMeta{color:rgba(165,225,255,.78);font-size:15px;margin-bottom:18px}
.profileKicker{letter-spacing:.25em;text-transform:uppercase;color:rgba(165,225,255,.7);font-size:11px;margin-top:24px;margin-bottom:6px}

/* ── Maps & Artifacts ── */
.mapimg,.artifactImg{width:100%;border-radius:28px;border:1px solid var(--line);box-shadow:0 30px 90px rgba(0,0,0,.35);background:#111}
.artifactImg{max-height:760px;object-fit:contain;background:#07090a}

/* ── Timeline ── */
.timeline{display:grid;gap:16px}
.step{display:grid;grid-template-columns:150px 1fr;gap:18px;align-items:start}
.badge{border:1px solid var(--line);color:var(--blue);border-radius:18px;padding:10px;text-align:center;background:rgba(85,199,255,.07)}

/* ── Two Column Text ── */
.twoColText{columns:2;column-gap:36px}
.twoColText p{break-inside:avoid}

/* ── Archive ── */
.archiveBox{text-align:center;max-width:680px;margin:auto;border:1px solid var(--line);border-radius:34px;background:linear-gradient(135deg,rgba(85,199,255,.07),rgba(255,255,255,.025));padding:36px 32px;box-shadow:0 20px 70px rgba(0,0,0,.22)}
.inputRow{display:flex;gap:12px;max-width:560px;margin:26px auto 0}
.fakeInput{flex:1;border:1px solid var(--stoneLine);border-radius:999px;padding:13px 18px;color:var(--dim);background:#0d0f0f;text-align:left}

/* ── Footer ── */
.footer{border-top:1px solid var(--stoneLine);padding:34px 20px;color:var(--dim)}
.footer .wrap{display:flex;justify-content:space-between;gap:20px;font-size:14px}

/* ── Companion / Lore ── */
.companionGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}
.companionCard{display:flex;flex-direction:column;justify-content:space-between;min-height:260px}
.companionCard .btns{margin-top:22px}
.companionDetail{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:28px;align-items:start}
.lorePanel{background:rgba(255,255,255,.035);border:1px solid var(--stoneLine);border-radius:28px;padding:28px;box-shadow:0 20px 70px rgba(0,0,0,.22)}
.loreList{display:grid;gap:14px}
.loreItem{border:1px solid var(--stoneLine);border-radius:20px;padding:16px 18px;background:rgba(255,255,255,.028)}
.loreItem h3{margin-bottom:7px}
.loreHeroGrid{display:grid;grid-template-columns:1.15fr .85fr;gap:28px;align-items:start}
.loreIntroCard{background:rgba(255,255,255,.035);border:1px solid var(--stoneLine);border-radius:28px;padding:28px;box-shadow:0 20px 70px rgba(0,0,0,.22)}
.loreSection{border-top:1px solid var(--stoneLine);padding-top:32px;margin-top:34px}
.loreSection:first-child{border-top:0;margin-top:0;padding-top:0}
.loreSection h2{margin-bottom:14px}
.loreAnchorNav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:28px 0 34px}
.loreAnchorNav a{display:block;border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:16px 14px;background:rgba(255,255,255,.035);color:rgba(165,225,255,.96);text-decoration:none;font-size:16px;line-height:1.2;font-weight:400;font-style:normal;letter-spacing:0;text-transform:none}
.loreAnchorNav a:hover{border-color:rgba(85,199,255,.50);background:rgba(85,199,255,.065);color:#fff}
.loreFactGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:18px}
.loreFact{border:1px solid var(--stoneLine);border-radius:18px;padding:16px;background:rgba(255,255,255,.028)}
.loreFact strong{display:block;color:var(--gold);margin-bottom:6px}
.lorePull{font-size:22px;line-height:1.45;font-style:italic;color:rgba(165,225,255,.84);border-left:3px solid rgba(85,199,255,.72);padding:18px 22px;background:rgba(85,199,255,.055);border-radius:0 20px 20px 0;margin:24px 0}
.noteBox{border-left:3px solid rgba(85,199,255,.72);padding:16px 20px;background:rgba(85,199,255,.06);border-radius:0 18px 18px 0;color:var(--muted)}

/* ── Terms / Glossary ── */
.termGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.term{border:1px solid var(--stoneLine);border-radius:18px;padding:16px;background:rgba(255,255,255,.028)}
.term h3{margin-bottom:8px;color:var(--gold)}
.timeNode{display:grid;grid-template-columns:150px 1fr;gap:18px;border:1px solid var(--stoneLine);border-radius:20px;padding:18px;background:rgba(255,255,255,.028)}
.timeNode strong{color:var(--gold)}
.fullLore{max-width:980px}
.fullLore h2{margin-top:38px;margin-bottom:16px}
.fullLore h3{margin-top:28px;margin-bottom:12px;color:var(--gold)}
.fullLore p{margin-bottom:16px}
.fullLore .chapterTitle{border-top:1px solid var(--stoneLine);padding-top:28px;margin-top:34px}
.fullLore .miniTOC{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:24px 0 36px}
.fullLore .miniTOC a{border:1px solid var(--stoneLine);border-radius:16px;padding:12px 14px;background:rgba(255,255,255,.03);color:rgba(165,225,255,.84);text-decoration:none}
.fullLore .miniTOC a:hover{border-color:rgba(85,199,255,.45)}
.fullLore .quoteBlock{font-size:22px;color:rgba(165,225,255,.82);font-style:italic;line-height:1.45;margin:24px 0;padding:20px 24px;border-left:3px solid rgba(85,199,255,.72);background:rgba(85,199,255,.055);border-radius:0 20px 20px 0}
.fullLore .termBlock{border:1px solid var(--stoneLine);border-radius:18px;padding:18px 20px;background:rgba(255,255,255,.028);margin-bottom:16px}
.fullLore .termBlock h3{margin-top:0}

/* ── Glossary ── */
.glossLore{max-width:1080px}
.glossIntro{border:1px solid var(--stoneLine);border-radius:28px;padding:26px 28px;background:rgba(255,255,255,.035);box-shadow:0 20px 70px rgba(0,0,0,.22);margin-bottom:34px}
.glossNav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:0 0 38px}
.glossNav a{display:block;border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:16px 14px;background:rgba(255,255,255,.035);color:rgba(165,225,255,.96);text-decoration:none;font-size:16px;line-height:1.2;font-weight:400;font-style:normal;letter-spacing:0;text-transform:none}
.glossNav a:hover{border-color:rgba(85,199,255,.50);background:rgba(85,199,255,.065);color:#fff}
.glossSection{border-top:1px solid var(--stoneLine);padding-top:36px;margin-top:40px}
.glossSection:first-child{border-top:0;margin-top:0;padding-top:0}
.glossSection>h2{margin-bottom:10px}
.glossSection>p{color:var(--muted);margin-bottom:24px}
.glossGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.glossEntry{border:1px solid var(--stoneLine);border-radius:20px;padding:18px 20px;background:rgba(255,255,255,.028)}
.glossEntry h2{font-size:24px;margin-bottom:10px;color:var(--gold)}
.glossEntry p{color:var(--text);line-height:1.6;margin:0}

/* ── Script Reference ── */
.scriptLore{max-width:1080px}
.scriptIntro{border:1px solid var(--stoneLine);border-radius:28px;padding:26px 28px;background:rgba(255,255,255,.035);box-shadow:0 20px 70px rgba(0,0,0,.22);margin-bottom:34px}
.scriptNav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:0 0 38px}
.scriptNav a{display:block;border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:16px 14px;background:rgba(255,255,255,.035);color:rgba(165,225,255,.96);text-decoration:none;font-size:16px;line-height:1.2;font-weight:400;font-style:normal;letter-spacing:0;text-transform:none}
.scriptNav a:hover{border-color:rgba(85,199,255,.50);background:rgba(85,199,255,.065);color:#fff}
.scriptGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.scriptCard{border:1px solid var(--stoneLine);border-radius:20px;padding:18px 20px;background:rgba(255,255,255,.028)}
.scriptCard h3{font-size:21px;margin-bottom:8px;color:var(--gold)}
.scriptCard p{margin:0;color:var(--text);line-height:1.55}
.scriptSample{font-family:'VelDrath',serif;font-size:34px;letter-spacing:.12em;color:rgba(165,225,255,.85);line-height:1.3;border:1px solid rgba(85,199,255,.20);border-radius:22px;padding:18px;background:rgba(85,199,255,.05);margin:20px 0}
.scriptSection{border-top:1px solid var(--stoneLine);padding-top:36px;margin-top:40px}
.scriptSection:first-child{border-top:0;margin-top:0;padding-top:0}
.scriptSection>h2{margin-bottom:12px}
.scriptSection>p{color:var(--muted);margin-bottom:22px}
.scriptSection>h2:not(:first-child){margin-top:52px}
.scriptSection .scriptGrid{margin-top:22px;margin-bottom:54px}
.scriptSection .scriptGrid+h2{margin-top:56px;padding-top:20px;border-top:1px solid var(--stoneLine)}
.scriptSection .ruleList{margin-top:22px}
.scriptSection .phraseDetail{margin-top:20px}
.scriptSection .fontUseList{margin-top:20px}
.scriptSection .characterReference{margin-top:22px;margin-bottom:42px}
.scriptSection .characterReference+h2{margin-top:56px;padding-top:20px;border-top:1px solid var(--stoneLine)}
.ruleList{display:grid;gap:16px}
.ruleItem{border:1px solid var(--stoneLine);border-radius:20px;padding:18px 20px;background:rgba(255,255,255,.028)}
.ruleItem h3{color:var(--gold);margin-bottom:8px}
.refDetail{border:1px solid var(--stoneLine);border-radius:20px;padding:18px 20px;background:rgba(255,255,255,.028);margin:16px 0}
.refDetail h3{color:var(--gold);margin-bottom:8px}
.refDetail .meta{color:rgba(165,225,255,.9);font-size:14px;margin-bottom:10px}
.refDetail p{color:var(--text);line-height:1.62;margin:0 0 10px}
.refDetail p:last-child{margin-bottom:0}

/* ── Map Table ── */
.mapTable{width:100%;border-collapse:separate;border-spacing:0 10px;margin-top:20px}
.mapTable th{text-align:left;color:rgba(165,225,255,.90);font-weight:600;padding:0 12px 4px}
.mapTable td{background:rgba(255,255,255,.028);border-top:1px solid var(--stoneLine);border-bottom:1px solid var(--stoneLine);padding:13px 12px;vertical-align:top}
.mapTable td:first-child{border-left:1px solid var(--stoneLine);border-radius:16px 0 0 16px;color:var(--gold)}
.mapTable td:last-child{border-right:1px solid var(--stoneLine);border-radius:0 16px 16px 0}

/* ── Parchment / Paper Doc ── */
.paperDoc{
  --text:#3f2f22;--muted:#4c3a2b;--ice:#3f2f22;--blue:#3f2f22;--blue2:#3f2f22;--dim:#5f4a37;
  border:1px solid rgba(124,92,54,.46);border-radius:32px;padding:34px;
  background-color:#ead9b0;background-image:url('../assets/parchment-paper-bg-v2.jpg');
  background-size:100% auto;background-repeat:repeat-y;background-position:top center;
  box-shadow:0 20px 70px rgba(0,0,0,.22);color:#3f2f22;
}
.paperDoc *{color:#3f2f22}
.paperDoc h1,.paperDoc h2,.paperDoc h3,.paperDoc h4{color:#3f2f22}
.paperDoc h2,.paperDoc .paperTitle,.paperDoc .byline,.paperDoc p{font-family:"Lucida Calligraphy","Monotype Corsiva","Palatino Linotype","Book Antiqua",Palatino,Georgia,"Times New Roman",serif}
.paperDoc h2{font-size:clamp(28px,4vw,40px);border-top:1px solid rgba(109,81,49,.26);padding-top:28px;margin-top:34px;margin-bottom:16px}
.paperDoc h2.paperTitle{border-top:0;padding-top:0;margin-top:0}
.paperDoc p{font-size:18px;line-height:1.62;margin:0 0 17px}
.paperDoc .paperTitle{font-size:clamp(30px,4vw,46px);line-height:1.05;letter-spacing:-.035em;color:#2e2117;margin:0 0 18px;text-align:center;max-width:820px;margin-left:auto;margin-right:auto}
.paperDoc .byline{color:#5f4a37;font-size:18px;margin:3px 0;text-align:center}
.paperDoc .shortEmphasis{font-style:italic;color:#38281e;font-size:20px}
.paperDoc .paperSeal{border:0;border-radius:0;padding:0 0 22px;margin:0 0 26px;background:transparent;box-shadow:none;text-align:center;color:#2e2117}
.paperDoc .paperSeal .sealTitle{letter-spacing:.24em;text-transform:uppercase;color:#2e2117;font-size:24px;margin-bottom:8px}
.paperDoc .paperSeal .sealMeta{color:#5f4a37;font-size:16px;letter-spacing:.08em}
.paperDoc .signature{color:#33251b;margin-top:3px;margin-bottom:3px}
.paperDoc .signature.signStart{margin-top:24px}
.paperDoc .archiveNote{border-left:3px solid rgba(109,81,49,.52);padding:16px 20px;background:rgba(109,81,49,.08);border-radius:0 18px 18px 0;margin-top:22px}
.paperDoc .archiveNote p{margin-bottom:0}

/* ── Responsive ── */
@media(max-width:1000px){
  .heroGrid,.grid2{grid-template-columns:1fr}
  .bookGrid{grid-template-columns:1fr 1fr}
  .grid4{grid-template-columns:1fr 1fr}
  .profileCard{grid-template-columns:1fr}
  .profileArt{border-right:0;border-bottom:1px solid var(--stoneLine)}
}
@media(max-width:900px){
  .companionGrid,.companionDetail,.termGrid{grid-template-columns:1fr}
  .timeNode{grid-template-columns:1fr}
  .loreHeroGrid,.loreFactGrid{grid-template-columns:1fr}
  .scriptGrid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:800px){
  .fullLore .miniTOC{grid-template-columns:1fr}
}
@media(max-width:760px){
  .glossNav,.glossGrid{grid-template-columns:1fr}
  .loreAnchorNav{grid-template-columns:1fr}
  .scriptNav,.scriptGrid{grid-template-columns:1fr}
  .mapTable{font-size:14px}
}
@media(max-width:650px){
  .links{display:none}
  .hamburger{display:flex}
  .hero{min-height:auto;padding:54px 18px}
  .heroImage{min-height:430px}
  .grid3,.grid4,.bookGrid{grid-template-columns:1fr}
  .footer .wrap{display:block;text-align:center}
  .inputRow{flex-direction:column}
  .fakeInput{text-align:center}
  .twoColText{columns:1}
  .step{grid-template-columns:1fr}
  section{padding:58px 18px}
  .profileText{padding:24px}
  .paperDoc{padding:24px;background-size:100% auto}
  .paperDoc .paperSeal{padding:0 0 18px}
  .paperDoc p{font-size:17px}
}
