
/* ════════════════════════════
   HOME
════════════════════════════ */
.h-hero{
  position:relative;min-height:400px;overflow:hidden;
  display:flex;align-items:flex-end;
  background:linear-gradient(135deg,#ede4c8 0%,#e8ddb8 50%,#e2d8ae 100%);
  border-bottom:1px solid var(--border2);
}
.h-hero-bg{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:flex-end;
  padding-right:2rem;overflow:hidden;white-space:nowrap;
  font-family:'Cinzel',serif;font-size:16vw;font-weight:700;
  color:rgba(120,85,40,.05);user-select:none;pointer-events:none;
}
.h-hero-fl{
  position:absolute;top:1.5rem;right:2.5rem;
  font-family:'IM Fell English',serif;font-size:6rem;
  color:rgba(120,85,40,.07);user-select:none;pointer-events:none;line-height:1;
}
.h-hero-c{position:relative;padding:3.5rem 4rem;z-index:2;max-width:680px}
.hero-ey{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:'Cinzel',serif;font-size:.56rem;font-weight:600;
  letter-spacing:.42em;text-transform:uppercase;color:var(--gold2);margin-bottom:1.1rem;
}
.hero-ey::before{content:'❧';font-family:'IM Fell English',serif;font-size:.95rem;color:var(--gold)}
.hero-t{font-family:'Cinzel',serif;font-size:clamp(2rem,5vw,3.8rem);font-weight:700;letter-spacing:.06em;line-height:1.05;color:var(--ink);margin-bottom:.8rem}
.hero-t em{font-family:'IM Fell English',serif;font-style:italic;color:var(--gold)}
.hero-rule{display:flex;align-items:center;gap:1rem;margin:1.1rem 0;opacity:.28}
.hero-rule::before,.hero-rule::after{content:'';flex:1;height:1px;background:var(--gold2)}
.hero-rule span{font-family:'IM Fell English',serif;font-size:1rem;color:var(--gold2)}
.hero-d{font-family:'IM Fell English',serif;font-style:italic;font-size:1.05rem;color:var(--ink2);line-height:1.9;max-width:480px;margin-bottom:2rem}
.hero-btns{display:flex;gap:.9rem;flex-wrap:wrap}
.hb{font-family:'Cinzel',serif;font-size:.58rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;padding:.62rem 1.8rem;border:1px solid;cursor:pointer;background:transparent;transition:all .28s;text-decoration:none;display:inline-block}
.hb-p{border-color:var(--gold2);color:var(--gold);background:rgba(140,96,32,.09)}
.hb-p:hover{background:rgba(140,96,32,.18);color:var(--gold2)}
.hb-s{border-color:var(--border2);color:var(--ink3)}
.hb-s:hover{border-color:var(--ink3);color:var(--ink2)}
.hb-a{border-color:var(--border2);color:var(--ink3)}
.hb-a:hover{border-color:var(--ink3);color:var(--ink2)}

/* stats */
.h-stats{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--border2);background:var(--bg2)}
.h-stat{padding:1.3rem 1.5rem;border-right:1px solid var(--border);text-align:center}
.h-stat:last-child{border-right:none}
.sv{font-family:'IM Fell English',serif;font-size:2.1rem;color:var(--gold2);display:block;line-height:1}
.sl{font-family:'Cinzel',serif;font-size:.5rem;letter-spacing:.28em;color:var(--ink4);text-transform:uppercase;margin-top:.3rem;display:block;font-weight:600}

/* panels */
.h-panels{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--border)}
.h-panel{background:var(--bg2);padding:1.8rem 1.5rem;cursor:pointer;transition:background .22s;position:relative;border-right:1px solid var(--border)}
.h-panel:last-child{border-right:none}
.h-panel:hover{background:var(--bg3)}
.h-panel::after{content:'→';position:absolute;bottom:1.1rem;right:1.1rem;font-family:'Cinzel',serif;font-size:.75rem;color:var(--ink5);transition:all .22s}
.h-panel:hover::after{color:var(--gold2);transform:translateX(3px)}
.hp-ic{font-size:1.3rem;margin-bottom:.65rem;opacity:.45;color:var(--gold)}
.hp-ti{font-family:'Cinzel',serif;font-size:.68rem;font-weight:600;letter-spacing:.14em;color:var(--ink2);margin-bottom:.35rem;text-transform:uppercase}
.hp-de{font-family:'Crimson Text',serif;font-size:.88rem;font-style:italic;color:var(--ink3);line-height:1.8}
.hp-ct{margin-top:.55rem;font-family:'Cinzel',serif;font-size:.52rem;font-weight:600;letter-spacing:.2em;color:var(--gold2);text-transform:uppercase}

/* recent */
.h-recent{padding:2.5rem 4rem}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:1.4rem}
.sec-head-t{font-family:'Cinzel',serif;font-size:.9rem;font-weight:700;letter-spacing:.1em;color:var(--ink)}
.sec-head-s{font-family:'IM Fell English',serif;font-style:italic;font-size:.88rem;color:var(--ink4);margin-left:.8rem}
.see-all{font-family:'Cinzel',serif;font-size:.52rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold2);cursor:pointer;text-decoration:none;transition:all .2s;background:none;border:none}
.see-all:hover{color:var(--gold)}
.feat-row{display:flex;gap:1rem;flex-wrap:wrap}
.feat-card{width:88px;cursor:pointer;text-align:center;transition:transform .2s}
.feat-card:hover{transform:translateY(-4px)}
.feat-card:hover .fc-fr{border-color:var(--gold2)}
.fc-fr{width:76px;height:76px;border-radius:50%;margin:0 auto .45rem;background:var(--bg3);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:1.7rem;transition:border-color .2s;overflow:hidden}
.fc-fr .char-av-img{width:100%;height:100%;object-fit:cover;object-position:top;border-radius:50%}
.fc-n{font-family:'Crimson Text',serif;font-size:.82rem;color:var(--ink2)}
.fc-r{font-size:.72rem;color:var(--ink4);font-style:italic}

/* rule helpers */
.rule{width:100%;height:1px;background:linear-gradient(to right,transparent,var(--border3),transparent);margin:.5rem 0}
.rule-double{position:relative;height:6px;margin:.6rem 0}
.rule-double::before,.rule-double::after{content:'';position:absolute;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--border3),transparent)}
.rule-double::before{top:0}.rule-double::after{bottom:0}

/* footer */
.site-footer{border-top:1px solid var(--border2);padding:2rem 4rem;display:flex;align-items:center;justify-content:space-between;background:var(--bg2)}
.ft-logo{font-family:'Cinzel',serif;font-size:.82rem;font-weight:700;letter-spacing:.12em;color:var(--ink3)}
.ft-logo em{color:var(--gold2);font-style:normal}
.ft-r{font-family:'Crimson Text',serif;font-size:.84rem;font-style:italic;color:var(--ink4);text-align:right;line-height:1.9}
/* ════════════════════════════
   CHARACTERS
════════════════════════════ */
.ch-wrap{display:flex;min-height:calc(100vh - 52px)}
.ch-fil{width:188px;flex-shrink:0;border-right:1px solid var(--border2);background:var(--bg2);padding:.5rem 0}
.cf-gr{border-bottom:1px solid var(--border);padding:.3rem 0 .7rem}
.cf-title{font-family:'Cinzel',serif;font-size:.48rem;font-weight:600;letter-spacing:.32em;text-transform:uppercase;color:var(--ink5);padding:.35rem 1rem}
.cf-btn{display:block;width:100%;text-align:left;padding:.3rem 1rem;font-family:'Crimson Text',serif;font-size:.9rem;color:var(--ink3);background:transparent;border:none;cursor:pointer;transition:all .2s;border-left:2px solid transparent}
.cf-btn:hover{color:var(--ink);background:rgba(120,85,40,.06)}
.cf-btn.active{color:var(--gold);background:rgba(140,96,32,.09);border-left-color:var(--gold2)}
.ch-area{flex:1;padding:1.8rem 2rem;background:var(--bg)}
.cg-tb{display:flex;align-items:center;gap:1rem;margin-bottom:1.3rem;flex-wrap:wrap}
.cg-search{flex:1;min-width:180px;background:transparent;border:none;border-bottom:1px solid var(--border3);padding:.45rem .2rem;font-family:'IM Fell English',serif;font-style:italic;font-size:1rem;color:var(--ink);outline:none;transition:border-color .2s}
.cg-search:focus{border-bottom-color:var(--gold2)}
.cg-search::placeholder{color:var(--ink5)}
.cg-cnt{font-family:'Cinzel',serif;font-size:.58rem;color:var(--ink4);letter-spacing:.12em}
.cg-sort{display:flex;align-items:center;gap:.5rem;margin-left:auto}
.cg-sort-label{font-family:'Cinzel',serif;font-size:.58rem;color:var(--ink4);letter-spacing:.1em}
.cg-sort-sel{background:transparent;border:1px solid var(--border2);color:var(--ink3);font-family:'Cinzel',serif;font-size:.58rem;letter-spacing:.06em;padding:.28rem .5rem;cursor:pointer;outline:none;transition:border-color .2s}
.cg-sort-sel:hover,.cg-sort-sel:focus{border-color:var(--gold2);color:var(--gold2)}
.rar-legend{display:flex;gap:.7rem;align-items:center;margin-bottom:1rem;flex-wrap:wrap}
.rl-item{display:flex;align-items:center;gap:.28rem;font-family:'Cinzel',serif;font-size:.5rem;color:var(--ink4);letter-spacing:.08em}
.rl-dot{width:8px;height:8px;flex-shrink:0;display:inline-block}

/* character grid */
.ch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:2px;background:var(--border)}
.c-card{background:var(--bg2);cursor:pointer;position:relative;overflow:hidden;transition:all .25s;aspect-ratio:.76;display:flex;flex-direction:column}
.c-card:hover{background:var(--bg3);z-index:2}
.c-card:hover .c-ov{opacity:1}
.c-rar{position:absolute;top:0;left:0;right:0;height:3px}
.r1{background:var(--r1)}.r2{background:var(--r2)}.r3{background:var(--r3)}.r4{background:var(--r4)}.r5{background:var(--r5)}
.c-art{flex:1;display:flex;align-items:center;justify-content:center;font-size:3.2rem;background:linear-gradient(135deg,var(--bg3),var(--bg4));position:relative;overflow:hidden}
.c-art img{width:100%;height:100%;object-fit:cover;object-position:top;filter:sepia(.12) contrast(1.05)}
.c-bot{padding:.52rem .62rem;background:var(--panel);border-top:1px solid var(--border)}
.c-n{font-family:'Cinzel',serif;font-size:.7rem;font-weight:600;letter-spacing:.06em;color:var(--ink2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.c-ro{font-family:'Crimson Text',serif;font-size:.76rem;font-style:italic;color:var(--ink4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.c-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(40,25,5,.9) 0%,rgba(40,25,5,.25) 55%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:.72rem;opacity:0;transition:opacity .3s}
.c-ov-n{font-family:'Cinzel',serif;font-size:.7rem;font-weight:600;color:var(--bg2)}
.c-ov-d{font-family:'Crimson Text',serif;font-size:.75rem;font-style:italic;color:var(--bg4);margin-bottom:.28rem}
.c-ov-b{font-family:'Cinzel',serif;font-size:.48rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;border:1px solid var(--bg4);color:var(--bg3);padding:.18rem .52rem;display:inline-block;width:fit-content}

/* gender badges */
.badge-row{display:flex;align-items:center;gap:.45rem;margin-bottom:.55rem;flex-wrap:wrap}
.gbadge{font-family:'Cinzel',serif;font-size:.52rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;padding:.1rem .52rem;border:1px solid}
.g-futa{border-color:rgba(140,60,180,.4);color:#8a40b8}
.g-male{border-color:rgba(40,100,200,.38);color:#3868c0}
.g-female{border-color:rgba(180,60,100,.38);color:#b04070}
.g-other{border-color:rgba(100,60,180,.38);color:#7848b8}

/* ════════════════════════════
   CHARACTER DETAIL
════════════════════════════ */
.cd-wrap{padding:2.5rem 3rem;max-width:980px}
.cd-back{display:inline-flex;align-items:center;gap:.4rem;font-family:'Cinzel',serif;font-size:.52rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--ink4);cursor:pointer;margin-bottom:1.5rem;transition:color .2s;border:none;background:none}
.cd-back::before{content:'← '}
.cd-back:hover{color:var(--gold2)}
.cd-nr{display:flex;align-items:center;gap:1rem;margin-bottom:.2rem;flex-wrap:wrap}
.cd-like-btn{background:none;border:1px solid var(--border2);border-radius:20px;padding:.2rem .65rem;cursor:pointer;font-family:'Crimson Text',serif;font-size:.9rem;color:var(--ink4);display:flex;align-items:center;gap:.3rem;transition:border-color .2s,color .2s,opacity .2s;align-self:center;opacity:.5}
.cd-like-btn:hover{border-color:var(--gold2);color:var(--gold2);opacity:1}
.cd-like-btn.liked{border-color:#c0556a;color:#c0556a;opacity:1}
.cd-like-icon{font-size:.85rem;line-height:1}
.cd-like-count{font-size:.8rem}
.char-like-badge{position:absolute;top:.4rem;right:.4rem;background:rgba(30,15,5,.65);color:#e8a0a8;font-family:'Crimson Text',serif;font-size:.72rem;padding:.1rem .4rem;border-radius:10px;pointer-events:none}
.cd-nm{font-family:'Cinzel',serif;font-size:2.4rem;font-weight:700;letter-spacing:.05em;color:var(--ink);line-height:1}
.cd-fullname{font-family:'Crimson Text',serif;font-size:1rem;font-style:italic;color:var(--ink3);letter-spacing:.02em;margin-top:.15rem;width:100%}
.cd-stars{color:var(--gold2);font-size:.9rem;letter-spacing:.06em}
.cd-role{font-family:'Cinzel',serif;font-size:.6rem;font-weight:600;letter-spacing:.2em;color:var(--gold2);text-transform:uppercase;margin-bottom:1rem}
.cd-rule{display:flex;align-items:center;gap:1rem;margin-bottom:1.1rem;opacity:.25}
.cd-rule::before,.cd-rule::after{content:'';flex:1;height:1px;background:var(--gold2)}
.cd-rule span{font-family:'IM Fell English',serif;font-size:1.1rem;color:var(--gold2)}
.cd-tabs{display:flex;border-bottom:1px solid var(--border2);margin-bottom:1.4rem}
.cd-tab{font-family:'Cinzel',serif;font-size:.56rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink4);padding:.5rem 1.1rem;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;background:none;border-top:none;border-left:none;border-right:none}
.cd-tab:hover{color:var(--ink2);background:rgba(120,85,40,.05)}
.cd-tab.active{color:var(--gold2);border-bottom-color:var(--gold2)}
.cd-tc{display:none}.cd-tc.active{display:block}
.cd-sg{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-bottom:1.3rem}
.cd-s{background:var(--bg2);padding:.62rem .88rem;display:flex;flex-direction:column;gap:.15rem}
.cd-sl{font-family:'Cinzel',serif;font-size:.48rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ink4);font-weight:600}
.cd-sv{font-family:'Crimson Text',serif;font-size:.95rem;color:var(--ink2)}
.cd-bio{font-family:'IM Fell English',serif;font-size:1rem;font-style:italic;color:var(--ink2);line-height:2;border-left:3px solid var(--gold2);padding:.9rem 1rem .9rem 1.2rem;background:rgba(140,96,32,.05);margin-bottom:1.3rem}
.cd-lore{margin-bottom:1.4rem}
.cd-lore-title{font-family:'Cinzel',serif;font-size:.52rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold2);margin-bottom:.65rem;padding-bottom:.3rem;border-bottom:1px solid var(--border)}
.cd-lore-body{font-family:'Crimson Text',serif;font-size:.97rem;color:var(--ink2);line-height:1.95}
.cd-lore-body p{margin:0 0 .7em}
.cd-lore-body a{color:var(--gold2);text-decoration:underline;cursor:pointer}
.cd-lore-body a:hover{color:var(--ink1)}
.lore-stat-table{border-collapse:collapse;margin-bottom:1rem;font-family:'Crimson Text',serif;font-size:.95rem;color:var(--ink2)}
.lore-stat-table td{padding:.25rem .8rem .25rem 0;vertical-align:top}
.lore-stat-table td:first-child{font-family:'Cinzel',serif;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold2);white-space:nowrap;padding-right:1.2rem}
.cd-lore-spoiler-row{font-family:'IM Fell English',serif;font-size:.95rem;font-style:italic;color:#a03030;cursor:pointer;user-select:none;margin-bottom:.6rem;display:flex;align-items:center;justify-content:space-between;background:rgba(140,96,32,.05);border-left:3px solid #a03030;padding:.75rem 1rem .75rem 1.2rem}
.cd-lore-spoiler-row:hover{background:rgba(140,96,32,.09)}
.cd-sp-arr{font-family:'IM Fell English',serif;font-size:.95rem;font-style:italic;color:#a03030;white-space:nowrap;flex-shrink:0}
/* grimoire */
.cd-grimoire{margin-bottom:1.6rem}
.gr-spell{border:1px solid var(--border2);background:var(--bg2);margin-bottom:.8rem}
.gr-spell-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;cursor:pointer;user-select:none}
.gr-spell-header:hover{background:rgba(140,96,32,.05)}
.gr-spell-body{padding:0 1rem .9rem}
.gr-toggle{font-family:'IM Fell English',serif;font-size:.88rem;font-style:italic;color:var(--gold2);white-space:nowrap;flex-shrink:0;margin-left:1rem}
.gr-spell-name{font-family:'Cinzel',serif;font-size:.78rem;font-weight:700;letter-spacing:.06em;color:var(--ink)}
.gr-pron{font-family:'Crimson Text',serif;font-size:.82rem;font-weight:400;font-style:italic;letter-spacing:0;color:var(--ink3)}
.gr-spell-desc{font-family:'Crimson Text',serif;font-size:.92rem;color:var(--ink2);line-height:1.8;margin-bottom:.6rem}
.gr-spell-stats{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.7rem}
.gr-stat{font-family:'Crimson Text',serif;font-size:.82rem;color:var(--ink2);background:var(--bg3);border:1px solid var(--border);padding:.15rem .55rem;display:flex;gap:.4rem;align-items:baseline}
.gr-stat-l{font-family:'Cinzel',serif;font-size:.44rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold2);font-weight:600}
.gr-note{font-family:'Crimson Text',serif;font-size:.9rem;font-style:italic;color:var(--ink3);line-height:1.8;border-left:2px solid var(--border2);padding-left:.75rem}
.cd-tags{display:flex;gap:.38rem;flex-wrap:wrap;margin-bottom:1.2rem}
.cd-tag{font-family:'Cinzel',serif;font-size:.48rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--border2);color:var(--ink3);padding:.1rem .55rem}
.lb{margin-bottom:1.2rem}
.lb-t{font-family:'Cinzel',serif;font-size:.55rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold2);margin-bottom:.5rem;padding-bottom:.32rem;border-bottom:1px solid var(--border)}
.lb p{font-family:'Crimson Text',serif;font-size:.95rem;color:var(--ink2);line-height:2;font-style:italic}
.rel-list{display:flex;flex-direction:column;gap:2px;background:var(--border)}
.rel-it{display:flex;align-items:center;gap:.88rem;background:var(--bg2);padding:.62rem .88rem;cursor:pointer;transition:background .2s}
.rel-it:hover{background:var(--bg3)}
.rel-av{width:34px;height:34px;border-radius:50%;background:var(--bg3);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:.88rem;flex-shrink:0;overflow:hidden}
.rel-av .char-av-img{width:100%;height:100%;object-fit:cover;object-position:top;border-radius:50%}
.rel-n{font-family:'Cinzel',serif;font-size:.68rem;font-weight:600;color:var(--ink2);letter-spacing:.06em}
.rel-t{font-family:'Crimson Text',serif;font-size:.78rem;color:var(--ink4);font-style:italic}
.rel-ar{margin-left:auto;color:var(--ink4);font-family:'Cinzel',serif;font-size:.68rem}
.rel-spoiler-toggle{display:flex;align-items:center;justify-content:space-between;padding:.62rem .88rem;background:rgba(140,32,32,.07);border-left:3px solid #a03030;font-family:'IM Fell English',serif;font-size:.92rem;font-style:italic;color:#a03030;cursor:pointer;user-select:none}
.rel-spoiler-toggle:hover{background:rgba(140,32,32,.12)}
.rel-sp-arr{font-style:italic;white-space:nowrap;flex-shrink:0}
.rel-spoiler-body{flex-direction:column;gap:2px}

/* GALLERY TAB */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:3px;background:var(--border)}
.gallery-item{background:var(--bg3);aspect-ratio:1;position:relative;overflow:hidden;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;filter:sepia(.08);transition:transform .3s,filter .3s,opacity .3s;opacity:0}
.gallery-item img.loaded{opacity:1}
.gallery-item-loader{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:var(--bg3);transition:opacity .3s;pointer-events:none}
.gallery-item-loader::after{content:'✦';font-size:1.4rem;color:var(--ink4);animation:gl-pulse 1.4s ease-in-out infinite}
.gallery-item.loaded .gallery-item-loader{opacity:0}
@keyframes gl-pulse{0%,100%{opacity:.2;transform:scale(.9)}50%{opacity:.7;transform:scale(1.05)}}
.gallery-item:hover img{transform:scale(1.04);filter:sepia(0)}
.gallery-item-info{position:absolute;bottom:0;left:0;right:0;padding:.5rem .6rem;background:linear-gradient(to top,rgba(40,25,5,.88),transparent);opacity:0;transition:opacity .3s}
.gallery-item:hover .gallery-item-info{opacity:1}
.gallery-item-title{font-family:'Cinzel',serif;font-size:.58rem;font-weight:600;color:var(--bg2);letter-spacing:.06em}
.gallery-item-chars{font-family:'Crimson Text',serif;font-size:.72rem;font-style:italic;color:var(--bg4)}
.gallery-empty{font-family:'IM Fell English',serif;font-style:italic;color:var(--ink4);font-size:.95rem;padding:2rem;text-align:center;background:var(--bg2);grid-column:1/-1}
/* lightbox */
#lightbox{display:none;position:fixed;inset:0;background:rgba(20,12,4,.92);z-index:9000;align-items:center;justify-content:center;padding:2rem;gap:1.5rem;cursor:pointer}
#lightbox.open{display:flex}
#lightbox img{max-width:80vw;max-height:88vh;object-fit:contain;box-shadow:0 8px 48px rgba(0,0,0,.6);border:1px solid var(--border2);cursor:default}
#lightbox-close{position:absolute;top:1.5rem;right:2rem;font-family:'Cinzel',serif;font-size:1.2rem;color:var(--bg3);cursor:pointer;border:none;background:none;opacity:.7;transition:opacity .2s}
#lightbox-close:hover{opacity:1}
.lb-nav{background:none;border:none;color:var(--bg3);font-size:2rem;cursor:pointer;padding:.5rem 1rem;opacity:.6;transition:opacity .2s;flex-shrink:0;user-select:none}
.lb-nav:hover{opacity:1}

/* ════════════════════════════
   QUIZ
════════════════════════════ */
.qz-wrap{display:flex;align-items:center;justify-content:center;min-height:70vh;padding:2rem 1rem;flex-direction:column}
.qz-card{background:var(--bg2);border:1px solid var(--border2);max-width:640px;width:100%;padding:2.5rem 2rem;display:flex;flex-direction:column;gap:1.5rem}
.qz-landing{display:flex;flex-direction:column;align-items:center;gap:1.8rem;max-width:700px;width:100%;padding:2rem 1rem}
.qz-pick-title{font-family:'Cinzel',serif;font-size:1.3rem;color:var(--ink1);letter-spacing:.06em;text-align:center}
.qz-pick-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;width:100%}
.qz-pick-card{background:var(--bg2);border:1px solid var(--border2);padding:2rem 1.5rem;display:flex;flex-direction:column;align-items:center;gap:.7rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}
.qz-pick-card:hover{border-color:var(--gold2);background:var(--bg3)}
.qz-pick-em{font-size:2.2rem;line-height:1}
.qz-pick-name{font-family:'Cinzel',serif;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink1)}
.qz-pick-sub{font-family:'Crimson Text',serif;font-style:italic;font-size:.95rem;color:var(--ink3);line-height:1.5}
.qz-land-title{font-family:'Cinzel',serif;font-size:1.6rem;color:var(--ink1);letter-spacing:.06em}
.qz-land-sub{font-family:'Crimson Text',serif;font-style:italic;font-size:1.05rem;color:var(--ink2)}
.qz-start{font-family:'Cinzel',serif;font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;background:var(--gold1);color:var(--bg1);border:none;padding:.7rem 2.2rem;cursor:pointer;transition:background .2s}
.qz-start:hover{background:var(--gold2)}
.qz-meta{display:flex;flex-direction:column;gap:.4rem}
.qz-prog-label{font-family:'Cinzel',serif;font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold2)}
.qz-bar{height:3px;background:var(--border2);border-radius:2px;overflow:hidden}
.qz-bar-fill{height:100%;background:var(--gold1);transition:width .4s ease}
.qz-q{font-family:'Cinzel',serif;font-size:1rem;color:var(--ink1);letter-spacing:.04em;line-height:1.5}
.qz-answers{display:flex;flex-direction:column;gap:.6rem}
.qz-ans{background:var(--bg1);border:1px solid var(--border2);padding:.85rem 1.1rem;text-align:left;font-family:'Crimson Text',serif;font-size:1rem;color:var(--ink2);cursor:pointer;transition:border-color .15s,background .15s,color .15s;line-height:1.4}
.qz-ans:hover{border-color:var(--gold2);background:var(--bg3);color:var(--ink1)}
/* result */
.qz-result-card{align-items:center;text-align:center;gap:1rem}
.qz-result-label{font-family:'Cinzel',serif;font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold2)}
.qz-result-av{width:96px;height:96px;border-radius:50%;overflow:hidden;border:2px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:2.5rem;flex-shrink:0}
.qz-result-av .qz-av-img,.qz-result-av img{width:100%;height:100%;object-fit:cover}
.qz-result-name{font-family:'Cinzel',serif;font-size:1.5rem;color:var(--ink1);letter-spacing:.08em}
.qz-result-role{font-family:'Cinzel',serif;font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold2)}
.qz-result-desc{font-family:'Crimson Text',serif;font-style:italic;font-size:1.05rem;color:var(--ink2);line-height:1.65;max-width:460px}
.qz-result-btns{display:flex;gap:.8rem;flex-wrap:wrap;justify-content:center;margin-top:.5rem}
.qz-retry{background:none;border:1px solid var(--border2);font-family:'Cinzel',serif;font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:var(--ink2);padding:.55rem 1.4rem;cursor:pointer;transition:border-color .15s,color .15s}
.qz-retry:hover{border-color:var(--gold2);color:var(--ink1)}
.qz-goto{font-family:'Cinzel',serif;font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;background:var(--gold1);color:var(--bg1);border:none;padding:.55rem 1.4rem;cursor:pointer;transition:background .2s}
.qz-goto:hover{background:var(--gold2)}

/* ════════════════════════════
   LORE + SERIES (merged wiki)
════════════════════════════ */
/* ── Series Landing ── */
#lore-ca{min-height:calc(100vh - 52px)}
.sl-landing{padding:3rem 4rem;max-width:1000px;margin:0 auto}
.sl-heading{font-family:'Cinzel',serif;font-size:1.7rem;font-weight:700;letter-spacing:.06em;color:var(--ink);margin-bottom:2rem;padding-bottom:.8rem;border-bottom:1px solid var(--border)}
.sl-grid{display:flex;flex-direction:column;gap:1px;background:var(--border)}
.sl-card{background:var(--bg2);padding:1.4rem 1.8rem;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:1.4rem}
.sl-card:hover{background:var(--bg3)}
.sl-card-icon{font-size:1.6rem;opacity:.8;flex-shrink:0;width:2.5rem;text-align:center}
.sl-card-text{display:flex;flex-direction:column;gap:.2rem}
.sl-card-name{font-family:'Cinzel',serif;font-size:.82rem;font-weight:700;letter-spacing:.1em;color:var(--gold2)}
.sl-card-desc{font-family:'Crimson Text',serif;font-size:.9rem;color:var(--ink3);line-height:1.6}
.sa-subtabs{display:none;padding:0 3rem;background:var(--bg3);border-bottom:1px solid var(--border2);gap:0;overflow-x:auto;scrollbar-width:none}
.sa-subtabs::-webkit-scrollbar{display:none}
.sa-subtab{font-family:'Cinzel',serif;font-size:.48rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink4);padding:.42rem .9rem;cursor:pointer;border:none;border-bottom:2px solid transparent;background:none;white-space:nowrap;transition:all .2s;margin-bottom:-1px}
.sa-subtab:hover{color:var(--ink2)}
.sa-subtab.active{color:var(--gold2);border-bottom-color:var(--gold2)}
/* ── Series Article Page ── */
.sa-wrap{display:flex;flex-direction:column;min-height:calc(100vh - 52px)}
.sa-header{display:flex;align-items:center;gap:1.2rem;padding:1rem 3rem .8rem;border-bottom:1px solid var(--border2);background:var(--bg2)}
.sa-back{font-family:'Cinzel',serif;font-size:.5rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--ink4);cursor:pointer;border:none;background:none;transition:color .2s}
.sa-back:hover{color:var(--gold2)}
.sa-name{font-family:'Cinzel',serif;font-size:.75rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink2)}
.sa-tabs{display:flex;border-bottom:1px solid var(--border2);padding:0 3rem;background:var(--bg2);overflow-x:auto;flex-shrink:0;scrollbar-width:none}
.sa-tabs::-webkit-scrollbar{display:none}
.sa-tab{font-family:'Cinzel',serif;font-size:.54rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink4);padding:.55rem 1rem;cursor:pointer;border:none;border-bottom:2px solid transparent;background:none;white-space:nowrap;transition:all .2s;margin-bottom:-1px}
.sa-tab:hover{color:var(--ink2);background:rgba(120,85,40,.05)}
.sa-tab.active{color:var(--gold2);border-bottom-color:var(--gold2)}
.sa-content{padding:2.5rem 4rem;max-width:860px;flex:1}
.lore-credit{font-family:'Crimson Text',serif;font-size:.85rem;color:var(--ink2);opacity:.55;margin-top:1.4rem;border-top:1px solid var(--border);padding-top:.7rem}
/* lore article */
.la{display:none}.la.active{display:block}
.la-label{font-family:'Cinzel',serif;font-size:.5rem;font-weight:600;letter-spacing:.4em;text-transform:uppercase;color:var(--gold2);margin-bottom:.45rem;opacity:.75}
.la-t{font-family:'Cinzel',serif;font-size:1.9rem;font-weight:700;letter-spacing:.05em;color:var(--ink);margin-bottom:.4rem;line-height:1.1}
.la-rule{display:flex;align-items:center;gap:1rem;margin:.8rem 0 1.4rem;opacity:.25}
.la-rule::before,.la-rule::after{content:'';flex:1;height:1px;background:var(--gold2)}
.la-rule span{font-family:'IM Fell English',serif;font-size:1.1rem;color:var(--gold2)}
.la-b{font-family:'Crimson Text',serif;font-size:1rem;color:var(--ink2);line-height:2.1}
.la-b p{margin-bottom:1rem}
.la-b h3{font-family:'Cinzel',serif;font-size:.62rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold2);margin:1.6rem 0 .5rem;border-left:3px solid var(--gold2);padding-left:.65rem}
.la-b blockquote{border:1px solid var(--border2);border-left:3px solid var(--gold2);background:rgba(140,96,32,.05);padding:1rem 1.2rem;margin:1.2rem 0;font-style:italic;color:var(--ink3)}
.la-b blockquote cite{display:block;margin-top:.4rem;font-size:.72rem;color:var(--ink4);font-style:normal;font-family:'Cinzel',serif;letter-spacing:.08em}
/* ── Wikipedia-style elements ── */
.wiki-fig{float:right;clear:right;margin:0 0 1rem 1.5rem;max-width:220px;border:1px solid var(--border2);background:var(--bg2);padding:.4rem;font-size:.78rem;text-align:center}
.wiki-fig.left{float:left;clear:left;margin:0 1.5rem 1rem 0}
.wiki-fig img{width:100%;display:block}
.wiki-fig figcaption{margin-top:.35rem;color:var(--ink4);font-style:italic;font-family:'Crimson Text',serif;font-size:.82rem;line-height:1.4}
.wiki-toc{float:right;clear:right;margin:0 0 1.2rem 1.5rem;background:var(--bg2);border:1px solid var(--border2);padding:.75rem 1rem;min-width:150px;max-width:220px;font-size:.84rem}
.wiki-toc-title{font-family:'Cinzel',serif;font-weight:700;font-size:.52rem;letter-spacing:.15em;text-transform:uppercase;color:var(--ink2);margin-bottom:.45rem}
.wiki-toc ol{padding-left:1.1rem;margin:0;list-style:decimal}
.wiki-toc li{margin-bottom:.18rem;color:var(--gold2);cursor:pointer;font-family:'Crimson Text',serif;font-size:.88rem}
.wiki-toc li:hover{text-decoration:underline}
.wiki-footer-section{margin-top:1.8rem;border-top:1px solid var(--border);padding-top:.9rem;clear:both}
.wiki-footer-title{font-family:'Cinzel',serif;font-size:.52rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold2);margin-bottom:.55rem}
.wiki-footer-list{list-style:disc;padding-left:1.4rem;font-family:'Crimson Text',serif;font-size:.92rem;color:var(--ink2);line-height:1.9;margin:0}
.wiki-footer-list li{margin-bottom:.1rem}
.wiki-footer-list a{color:var(--gold2);text-decoration:underline;cursor:pointer}
.wiki-footer-list a:hover{color:var(--ink1)}
.wiki-fn{font-size:.65rem;vertical-align:super;color:var(--gold2);cursor:pointer;font-family:'Cinzel',serif}
.wiki-fn:hover{text-decoration:underline}
/* ── Wikipedia character infobox ── */
.wiki-infobox{float:right;clear:right;margin:0 0 1.2rem 1.8rem;width:210px;border:1px solid var(--border2);background:var(--bg2);font-size:.82rem;flex-shrink:0}
.wiki-infobox-title{background:var(--gold2);color:#fff6e8;text-align:center;padding:.38rem .6rem;font-family:'Cinzel',serif;font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700}
.wiki-infobox table{width:100%;border-collapse:collapse}
.wiki-infobox td{padding:.32rem .6rem;border-top:1px solid var(--border);vertical-align:top;font-family:'Crimson Text',serif;font-size:.88rem;color:var(--ink2)}
.wiki-infobox td:first-child{font-family:'Cinzel',serif;font-size:.48rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink4);font-weight:600;width:42%}
.wiki-infobox td a{color:var(--gold2);text-decoration:underline;cursor:pointer}
.wi-spoiler-toggle{color:#8b1a1a;font-style:italic;font-size:.8rem;cursor:pointer;user-select:none;display:flex;align-items:center;justify-content:space-between;background:rgba(139,26,26,.08);border:1px solid rgba(139,26,26,.2);padding:.2rem .45rem;margin-top:.25rem}
.wi-arr{font-style:italic;font-size:.8rem;line-height:1;white-space:nowrap;flex-shrink:0}
.wi-spoiler-toggle:hover{background:rgba(139,26,26,.14)}
.wi-spoiler-body{margin-top:.4rem}
.wiki-infobox td a:hover{color:var(--ink1)}
.wi-relatives{border-top:1px solid var(--border2)}
.wi-relatives-title{font-family:'Cinzel',serif;font-size:.48rem;letter-spacing:.18em;text-transform:uppercase;color:#fff6e8;font-weight:600;background:var(--gold2);opacity:.85;padding:.28rem .6rem}
.wi-relatives-body{padding:.45rem .6rem;font-family:'Crimson Text',serif;font-size:.86rem;color:var(--ink2);line-height:1.8}
.wi-relatives-body a{color:var(--gold2);text-decoration:underline;cursor:pointer}
.wi-relatives-body a:hover{color:var(--ink1)}
.wi-av{text-align:center;padding:.5rem;background:var(--bg3);position:relative;cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Ctext y='26' font-size='26'%3E🤚%3C/text%3E%3C/svg%3E") 12 4,pointer;user-select:none}
.wi-av img{width:100%;aspect-ratio:1;object-fit:cover;object-position:top;display:block}
.wi-av .wi-av-em{font-size:3rem;line-height:1;padding:.5rem 0}
.wi-pat-anim img,.wi-pat-anim .wi-av-em{animation:pat-bounce .35s ease}
@keyframes pat-bounce{0%{transform:translateY(0)}30%{transform:translateY(-6px)}60%{transform:translateY(2px)}100%{transform:translateY(0)}}
.wi-pat-react{position:absolute;top:-2.6rem;left:50%;transform:translateX(-50%);font-family:'Crimson Text',serif;font-size:1rem;color:var(--ink1);background:var(--bg2);border:1px solid var(--border2);border-radius:12px;padding:.25rem .7rem;pointer-events:none;opacity:0;white-space:nowrap;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.wi-pat-react::after{content:'';position:absolute;bottom:-7px;left:50%;transform:translateX(-50%);border:4px solid transparent;border-top-color:var(--border2)}
.wi-pat-react::before{content:'';position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);border:4px solid transparent;border-top-color:var(--bg2);z-index:1}
.wi-pat-react.wi-pat-show{animation:pat-float 1.8s ease forwards}
@keyframes pat-float{0%{opacity:1;transform:translateX(-50%) translateY(0)}70%{opacity:1;transform:translateX(-50%) translateY(-6px)}100%{opacity:0;transform:translateX(-50%) translateY(-10px)}}
@media(max-width:640px){.wiki-fig,.wiki-toc{float:none;margin:0 0 1rem;max-width:100%;width:100%}.wiki-infobox{float:none;margin:0 auto 1.2rem;width:100%;max-width:100%;box-sizing:border-box}}
/* series lore extras */
.la-char-list{display:flex;flex-direction:column;gap:2px;background:var(--border);margin:1rem 0}
.la-char-row{display:flex;align-items:flex-start;gap:.9rem;background:var(--bg2);padding:.9rem 1rem;cursor:pointer;transition:background .2s}
.la-char-row:hover{background:var(--bg3)}
.la-char-em{font-size:1.5rem;flex-shrink:0;width:2rem;height:2rem;text-align:center;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center}
.la-char-em .char-av-img{width:100%;height:100%;object-fit:cover;object-position:top;border-radius:50%}
.la-char-name{font-family:'Cinzel',serif;font-size:.75rem;font-weight:600;color:var(--gold2);letter-spacing:.06em}
.la-char-role{font-family:'Cinzel',serif;font-size:.52rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink4);margin-bottom:.22rem}
.la-char-desc{font-family:'Crimson Text',serif;font-size:.88rem;color:var(--ink3);line-height:1.8;font-style:italic}

/* ════════════════════════════
   GAMES
════════════════════════════ */
/* ── GAMES LIST (Steam banners) ── */
.gm-page{padding:2.5rem 3rem}
.gm-section-header{margin-bottom:2rem}
.gm-section-title{font-family:'Cinzel',serif;font-size:1.25rem;font-weight:700;letter-spacing:.1em;color:var(--ink);margin-bottom:.3rem}
.gm-section-sub{font-family:'Crimson Text',serif;font-size:.95rem;font-style:italic;color:var(--ink3)}
.gm-banners{display:flex;flex-direction:column;gap:3px;background:var(--border)}

.gm-banner{
  display:grid;grid-template-columns:300px 1fr;
  background:var(--bg2);cursor:pointer;
  transition:background .22s;position:relative;overflow:hidden;
  border-bottom:1px solid var(--border);min-height:170px;
}
.gm-banner:hover{background:var(--bg3)}
.gm-banner::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold2);transform:scaleY(0);transition:transform .3s;transform-origin:bottom}
.gm-banner:hover::before{transform:scaleY(1)}

.gm-banner-img{
  width:300px;background:var(--bg4);
  display:flex;flex-direction:column;
  flex-shrink:0;
}
.gm-bi-main{width:100%;height:auto;object-fit:contain;filter:sepia(.1);display:block}
.gm-bi-thumbs{display:flex;gap:2px;padding:3px;background:var(--bg3);flex-wrap:wrap}
.gm-bi-thumb{width:58px;flex-shrink:0;cursor:pointer;border:2px solid transparent;opacity:.65;transition:opacity .2s,border-color .2s}
.gm-bi-thumb.active,.gm-bi-thumb:hover{opacity:1;border-color:var(--gold2)}
.gm-bi-thumb img{width:100%;height:auto;display:block}
.gm-banner-img-ph{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  width:100%;height:100%;min-height:170px;
  background:linear-gradient(135deg,var(--bg3),var(--bg4));
  gap:.5rem;
}
.gm-banner-img-ph .ph-em{font-size:2.8rem;opacity:.35}
.gm-banner-img-ph .ph-lbl{font-family:'Cinzel',serif;font-size:.52rem;font-weight:600;letter-spacing:.2em;color:var(--ink4);text-transform:uppercase;opacity:.6}

.gm-banner-info{padding:1.5rem 2rem;display:flex;flex-direction:column;justify-content:space-between}
.gm-banner-top{}
.gm-banner-badges{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.6rem;align-items:center}
.gm-banner-title{font-family:'Cinzel',serif;font-size:1.3rem;font-weight:700;letter-spacing:.06em;color:var(--ink);margin-bottom:.25rem;line-height:1.1}
.gm-banner-genre{font-family:'Cinzel',serif;font-size:.52rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold2);opacity:.7;margin-bottom:.7rem}
.gm-banner-desc{font-family:'Crimson Text',serif;font-size:.92rem;font-style:italic;color:var(--ink3);line-height:1.85;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.gm-banner-footer{display:flex;align-items:center;justify-content:space-between;margin-top:.9rem;flex-wrap:wrap;gap:.5rem}
.gm-banner-tags{display:flex;gap:.35rem;flex-wrap:wrap}
.gm-banner-arrow{font-family:'Cinzel',serif;font-size:.65rem;color:var(--ink4);transition:all .25s;white-space:nowrap}
.gm-banner:hover .gm-banner-arrow{color:var(--gold2);transform:translateX(4px)}


/* ── GAME DETAIL PAGE ── */
.gd-wrap{padding:2rem 3rem;max-width:1000px}
.gd-back{display:inline-flex;align-items:center;gap:.4rem;font-family:'Cinzel',serif;font-size:.52rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--ink4);cursor:pointer;margin-bottom:1.5rem;transition:color .2s;border:none;background:none}
.gd-back::before{content:'← '}
.gd-back:hover{color:var(--gold2)}

.gd-hero{display:grid;grid-template-columns:360px 1fr;gap:2rem;margin-bottom:2rem;align-items:start}
.gd-cover{
  width:360px;background:linear-gradient(135deg,var(--bg3),var(--bg4));
  border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:0;flex-shrink:0;
}
.gd-main-img{width:100%;height:auto;object-fit:contain;filter:sepia(.1);display:block}
.gd-thumbs{display:flex;gap:2px;padding:3px;background:var(--bg3);width:100%;box-sizing:border-box;flex-wrap:wrap}
.gd-thumb{width:58px;flex-shrink:0;cursor:pointer;border:2px solid transparent;opacity:.65;transition:opacity .2s,border-color .2s}
.gd-thumb.active,.gd-thumb:hover{opacity:1;border-color:var(--gold2)}
.gd-thumb img{width:100%;height:auto;display:block}
.gd-cover .ph-em{font-size:3rem;opacity:.3}
.gd-cover .ph-lbl{font-family:'Cinzel',serif;font-size:.52rem;letter-spacing:.2em;color:var(--ink4);text-transform:uppercase;opacity:.5}

.gd-info{}
.gd-badges{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.7rem}
.gd-title{font-family:'Cinzel',serif;font-size:2rem;font-weight:700;letter-spacing:.06em;color:var(--ink);line-height:1.05;margin-bottom:.25rem}
.gd-genre{font-family:'Cinzel',serif;font-size:.58rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold2);opacity:.75;margin-bottom:1rem}
.gd-desc{font-family:'Crimson Text',serif;font-size:1rem;font-style:italic;color:var(--ink2);line-height:2;margin-bottom:1.2rem}
.gd-tags{display:flex;gap:.38rem;flex-wrap:wrap;margin-bottom:1.2rem}
.gd-tag{font-family:'Cinzel',serif;font-size:.48rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--border2);color:var(--ink3);padding:.1rem .55rem}
.gd-chars{display:flex;gap:.4rem;align-items:center;margin-bottom:1.2rem}
.gd-chi{width:26px;height:26px;border-radius:50%;background:var(--bg3);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:.75rem;overflow:hidden}
.gd-chi .char-av-img{width:100%;height:100%;object-fit:cover;object-position:top;border-radius:50%}
.gd-chl{font-family:'Crimson Text',serif;font-size:.82rem;color:var(--ink4);margin-left:.3rem;font-style:italic}

/* screenshots */
.gd-screenshots{margin-bottom:2rem}
.gd-shots-strip{display:flex;gap:4px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:.4rem}
.gd-shots-strip::-webkit-scrollbar{height:4px}
.gd-shots-strip::-webkit-scrollbar-track{background:var(--bg3)}
.gd-shots-strip::-webkit-scrollbar-thumb{background:var(--border2)}
.gd-shot{
  flex-shrink:0;height:220px;scroll-snap-align:start;
  cursor:pointer;overflow:hidden;position:relative;
}
.gd-shot img{height:100%;width:auto;object-fit:contain;filter:sepia(.08);transition:filter .3s;display:block}
.gd-shot:hover img{filter:sepia(0)}

/* lore section inside game page */
.gd-lore{border-top:1px solid var(--border);padding-top:1.5rem;margin-top:.5rem}
.gd-lore-title{font-family:'Cinzel',serif;font-size:.62rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold2);margin-bottom:.8rem;padding-bottom:.35rem;border-bottom:1px solid var(--border)}
.gd-lore-body{font-family:'Crimson Text',serif;font-size:.95rem;color:var(--ink2);line-height:2}
.gd-lore-body p{margin-bottom:.8rem;font-style:italic}
.gd-lore-body h3{font-family:'Cinzel',serif;font-size:.6rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold2);margin:1.2rem 0 .4rem;border-left:3px solid var(--gold2);padding-left:.6rem;font-style:normal}
.gd-lore-body blockquote{border:1px solid var(--border2);border-left:3px solid var(--gold2);background:rgba(140,96,32,.05);padding:.9rem 1.1rem;margin:1rem 0;font-style:italic;color:var(--ink3)}
.gd-lore-body blockquote cite{display:block;margin-top:.3rem;font-size:.65rem;color:var(--ink4);font-style:normal;font-family:'Cinzel',serif;letter-spacing:.08em}
.gd-fi-chars{display:flex;flex-direction:column;gap:2px;margin:.5rem 0;background:var(--border)}
.gd-fi-char{display:flex;align-items:flex-start;gap:.85rem;background:var(--bg3);padding:.85rem 1rem}
.gd-fi-char-em{font-size:1.45rem;flex-shrink:0;width:2rem;height:2rem;text-align:center;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center}
.gd-fi-char-em .char-av-img{width:100%;height:100%;object-fit:cover;object-position:top;border-radius:50%}
.gd-fi-char-name{font-family:'Cinzel',serif;font-weight:600;font-size:.78rem;color:var(--gold2);letter-spacing:.07em}
.gd-fi-char-role{font-family:'Cinzel',serif;font-size:.52rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink4);margin-bottom:.22rem}
.gd-fi-char-desc{font-family:'Crimson Text',serif;font-size:.88rem;color:var(--ink3);line-height:1.8;font-style:italic}

/* how-to-play / intro box */
.fb-intro{background:rgba(140,96,32,.07);border:1px solid var(--border2);border-left:3px solid var(--gold2);padding:1rem 1.2rem;margin-bottom:1.2rem}
.fb-intro-title{font-family:'Cinzel',serif;font-size:.58rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold2);margin-bottom:.5rem}
.fb-intro p{font-family:'Crimson Text',serif;font-size:.9rem;font-style:italic;color:var(--ink2);line-height:1.85;margin-bottom:.5rem}
.fb-intro-list{list-style:none;padding:0}
.fb-intro-list li{font-family:'Crimson Text',serif;font-size:.88rem;color:var(--ink2);line-height:1.85;padding-left:1rem;position:relative;font-style:italic}
.fb-intro-list li::before{content:'◆';position:absolute;left:0;color:var(--gold2);font-size:.42rem;top:.45rem}

/* play button */
.g-play-btn{display:inline-flex;align-items:center;gap:.6rem;font-family:'Cinzel',serif;font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;background:var(--gold2);color:#fff8ee;border:none;padding:.75rem 2rem;cursor:pointer;text-decoration:none;transition:all .25s;box-shadow:0 2px 12px rgba(140,96,32,.3)}
.g-play-btn:hover{background:var(--gold);box-shadow:0 4px 20px rgba(140,96,32,.45);transform:translateY(-1px)}
.g-play-btn::before{content:'▶';font-size:.7rem}
.g-dl-note{font-family:'Crimson Text',serif;font-size:.82rem;font-style:italic;color:var(--ink4);margin-top:.5rem}
/* status badges (shared) */
.g-st{display:inline-block;font-family:'Cinzel',serif;font-size:.48rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;padding:.12rem .58rem;border:1px solid}
.s-dev{color:var(--gold2);border-color:rgba(140,96,32,.35)}
.s-plan{color:var(--ink4);border-color:var(--border)}
.s-rel{color:#3a7840;border-color:rgba(58,120,64,.35);background:rgba(58,120,64,.06)}
.g-type-badge{display:inline-flex;align-items:center;gap:.3rem;font-family:'Cinzel',serif;font-size:.5rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;padding:.14rem .6rem;border:1px solid}
.type-game{color:var(--gold2);border-color:rgba(140,96,32,.25)}
.type-comic{color:var(--red);border-color:rgba(139,32,32,.3)}
.g-tag{font-family:'Cinzel',serif;font-size:.48rem;letter-spacing:.1em;color:var(--ink4);border:1px solid var(--border);padding:.09rem .48rem;text-transform:uppercase}

