:root{
  --blue:#2f6df0; --purple:#8a5cf6; --orange:#ef7d2e; --green:#1fa463; --yellow-dk:#b8860b; --red:#e23b3b;
  --locnum:#024564; --cardnum:#73351c;
  --ink:#10213a; --mut:#5b6b86; --line:#d8e0ee; --card:#ffffff; --accent:#1f3a73;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;min-height:100vh;font-family:Inter,Anuphan,sans-serif;color:#eaf0ff;
  background:#0b1020;line-height:1.6;overflow-x:hidden}
a{color:var(--blue);text-decoration:none}

/* language toggle */
.lang-switch{position:fixed;top:14px;right:14px;z-index:80;display:flex;gap:2px;
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);border-radius:999px;padding:3px;backdrop-filter:blur(6px)}
.lang-switch button{font-family:Khand;font-weight:700;font-size:.92rem;letter-spacing:.06em;
  color:#cdd9f5;background:transparent;border:0;cursor:pointer;padding:.2rem .7rem;border-radius:999px;line-height:1}
.lang-switch button.active{background:#fff;color:var(--accent)}
.lang-switch button:not(.active):hover{background:rgba(255,255,255,.18)}

/* planet background */
.bg{position:fixed;inset:0;z-index:-2;background:url(ui/vantage-bg.webp) center/cover no-repeat;background-attachment:fixed}
.bg-veil{position:fixed;inset:0;z-index:-1;background:
  linear-gradient(180deg,rgba(8,12,26,.78) 0%,rgba(8,12,26,.42) 22%,rgba(8,12,26,.32) 50%,rgba(8,12,26,.62) 100%);}

/* ---------- HOME ---------- */
.home{min-height:100vh;display:flex;flex-direction:column;align-items:center;
  padding:clamp(1.5rem,6vh,5rem) 1rem 4rem;gap:1.2rem}
.logo-wrap{text-align:center;margin-bottom:.3rem;position:relative}
.logo-wrap::before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:120%;height:200%;background:radial-gradient(closest-side,rgba(6,10,22,.75),transparent 75%);z-index:-1}
.logo{font-family:Khand;font-weight:700;font-size:clamp(3.2rem,11vw,7rem);letter-spacing:.06em;margin:0;
  color:#fff;line-height:.9;
  text-shadow:0 2px 4px rgba(0,0,0,.95),0 4px 24px rgba(0,0,0,.8),0 0 48px rgba(40,80,160,.5)}
.logo-sub{font-family:Khand;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:#cdd9f5;
  margin:.3rem 0 0;font-size:clamp(.8rem,2vw,1rem);text-shadow:0 1px 8px rgba(0,0,0,.7)}
.logo-sub span{color:#8fb4ff}

.searchwrap{position:relative;width:min(560px,94vw)}
#search{width:100%;padding:.7rem 1.1rem;border-radius:12px;border:1px solid rgba(255,255,255,.25);
  background:rgba(10,18,38,.7);backdrop-filter:blur(8px);color:#fff;font-size:1rem}
#search::placeholder{color:#9fb0d4}
#search:focus{outline:none;border-color:#6f9bff;background:rgba(10,18,38,.92)}
.search-results{position:absolute;top:112%;left:0;right:0;z-index:20;background:#fff;color:var(--ink);
  border-radius:12px;max-height:60vh;overflow:auto;box-shadow:0 16px 50px rgba(0,0,0,.5)}
.search-results a{display:block;padding:.55rem .9rem;border-bottom:1px solid var(--line);color:var(--ink)}
.search-results a:hover{background:#eef3fc}
.search-results .grp{font-size:.7rem;color:var(--mut);text-transform:uppercase;letter-spacing:.08em}

.keybar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:center;
  background:rgba(10,18,38,.7);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);
  border-radius:14px;padding:.55rem .8rem}
.keybar-label{font-family:Khand;font-weight:600;font-size:1.05rem;color:#cdd9f5;display:flex;align-items:center;gap:.4rem}
#entryNum{font-family:Khand;font-size:1.5rem;font-weight:700;width:88px;text-align:center;letter-spacing:.1em;
  background:#0a1226;border:1px solid rgba(255,255,255,.25);border-radius:10px;color:#fff;padding:.1rem}
#entryNum:focus{outline:none;border-color:#6f9bff}
.go{font-family:Khand;font-size:1.1rem;font-weight:700;padding:.25rem 1.1rem;border-radius:10px;border:0;cursor:pointer;
  background:linear-gradient(135deg,var(--blue),var(--purple));color:#fff}
.chip{font-family:Khand;font-weight:600;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);
  color:#dce6ff;border-radius:999px;padding:.15rem .7rem;cursor:pointer}
.chip:hover{background:rgba(255,255,255,.22)}
.search-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;
  cursor:pointer;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#dce6ff}
.search-btn:hover{background:rgba(255,255,255,.22)}
.search-btn svg{width:20px;height:20px}

/* search popup */
.search-pop{position:fixed;inset:0;z-index:70;display:flex;align-items:flex-start;justify-content:center;padding:12vh 1rem 1rem}
.search-pop[hidden]{display:none}
.search-pop-scrim{position:absolute;inset:0;background:rgba(6,10,22,.55);backdrop-filter:blur(4px)}
.search-pop-box{position:relative;z-index:1;width:min(600px,96vw);animation:pop .18s ease}
.search-pop-box #search{width:100%;padding:.8rem 1.1rem;border-radius:12px 12px 0 0;border:1px solid var(--line);
  background:#fff;color:var(--ink);font-size:1.05rem;border-bottom:0}
.search-pop-box #search:focus{outline:none}
.search-pop .search-results{position:static;display:block;border-radius:0 0 12px 12px;max-height:60vh;border:1px solid var(--line);border-top:0}
.search-pop .search-results:empty{border:0}

/* pill nav cluster */
.navcluster{width:min(820px,96vw);display:flex;flex-direction:column;gap:.5rem;margin-top:.4rem}
.nav-group{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center;align-items:center}
.nav-group .gl{flex-basis:100%;display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
  font-family:Khand;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#aebde0;font-size:.82rem;
  margin:.5rem 0 .1rem;text-shadow:0 1px 6px rgba(0,0,0,.6);background:none;border:0;cursor:pointer;
  transition:color .12s}
.nav-group .gl:hover{color:#fff}
.gl-count{font-weight:500;opacity:.65;font-size:.78em}
.gl .chev{display:inline-block;transition:transform .2s;font-size:.8em}
.nav-group.collapsed .gl .chev{transform:rotate(-90deg)}
.nav-pills{flex-basis:100%;display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center}
.nav-group.collapsed .nav-pills{display:none}
.pill{font-family:Khand;font-weight:600;font-size:1.02rem;padding:.28rem .85rem;border-radius:999px;cursor:pointer;
  background:rgba(255,255,255,.92);color:#15294d;border:1px solid rgba(255,255,255,.5);
  box-shadow:0 2px 10px rgba(0,0,0,.25);transition:transform .12s,background .12s}
.pill:hover{transform:translateY(-1px);background:#fff}
.pill.spoiler{background:rgba(28,40,70,.78);color:#dfe7fb;border-color:rgba(255,255,255,.25)}
.pill.spoiler:hover{background:rgba(40,54,92,.92)}

/* ---------- MODAL CARD ---------- */
.modal{position:fixed;inset:0;z-index:60;display:flex;align-items:flex-start;justify-content:center;padding:4vh 1rem}
.modal[hidden]{display:none}
.modal-scrim{position:absolute;inset:0;background:rgba(6,10,22,.55);backdrop-filter:blur(4px)}
.card{position:relative;z-index:1;background:var(--card);color:var(--ink);width:min(760px,96vw);max-height:92vh;
  overflow:auto;border-radius:18px;box-shadow:0 24px 80px rgba(0,0,0,.6);padding:1.6rem clamp(1.1rem,3vw,2.2rem) 2rem;
  animation:pop .2s ease}
@keyframes pop{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
.close{position:sticky;float:right;top:0;margin:-.6rem -.4rem 0 0;background:#eef2fa;border:1px solid var(--line);
  width:36px;height:36px;border-radius:50%;font-size:1.5rem;line-height:1;color:#3a4a68;cursor:pointer}
.close:hover{background:#e0e7f5}
.card-body{clear:both}

/* card content typography (light) */
.card-title{font-family:Khand;font-weight:700;font-size:2rem;color:var(--accent);margin:.1rem 0 .2rem}
.card-tag{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:#fff;background:var(--purple);border-radius:6px;padding:.05rem .5rem;margin-bottom:.7rem}
.card-body p{margin:.6rem 0}
.card-body ul,.card-body ol{padding-left:1.3rem}.card-body li{margin:.3rem 0}
.card-body img{max-width:240px;height:auto;border-radius:8px;border:1px solid var(--line);vertical-align:middle}
.card-body .grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(118px,1fr));gap:.7rem;margin:.8rem 0;
  list-style:none;padding:0}
.card-body .grid li{margin:0;list-style:none}
.card-body .grid a{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:.4rem;
  text-align:center;height:100%;background:#f3f6fc;border:1px solid var(--line);border-radius:12px;
  padding:.7rem .5rem;color:var(--ink);font-weight:600;font-size:.92rem}
.card-body .grid img{max-width:100%;max-height:78px;width:auto;height:auto;object-fit:contain;border:0}
.card-body svg{width:76px;height:76px;fill:#1a2c4e;vertical-align:middle}
.card-body .grid svg{width:40px;height:40px}
.card-body .grid p{margin:0}
/* any other stray ul/list reset inside cards */
.card-body ul.see-also{list-style:none;padding:0;display:flex;gap:.5rem;flex-wrap:wrap;margin:.2rem 0 1rem}
.card-body ul.see-also a{background:#eef3fc;border:1px solid var(--line);border-radius:999px;padding:.1rem .7rem;font-size:.9rem}
.card-body p svg{width:1.15em;height:1.15em;vertical-align:-.18em}
.card-body details{background:#f3f6fc;border:1px solid var(--line);border-radius:10px;padding:.5rem .8rem;margin:.5rem 0}
.card-body summary{cursor:pointer;font-weight:600}
/* rulepop radio toggles (Expanded/Brief etc) -> pill switch */
.card-body fieldset.rp-controls{border:0;margin:.5rem 0 1rem;padding:0}
.card-body .rp-controls ul{list-style:none;display:inline-flex;gap:.25rem;padding:.25rem;background:#eaf0fb;
  border:1px solid var(--line);border-radius:999px;margin:0}
.card-body .rp-controls li{margin:0}
.card-body .rp-controls label{display:block;cursor:pointer;position:relative}
.card-body .rp-controls input{position:absolute;opacity:0;width:0;height:0}
.card-body .rp-controls span{display:block;font-family:Khand;font-weight:600;font-size:1rem;padding:.18rem 1rem;border-radius:999px;color:#33415c;transition:.15s}
.card-body .rp-controls input:checked+span{background:var(--blue);color:#fff}

/* storybook in modal */
.story-head{display:flex;align-items:baseline;gap:.6rem;margin-bottom:.5rem}
.story-head .num{font-family:Khand;font-size:2.3rem;font-weight:700;color:var(--accent);line-height:1}
.tabs{display:flex;gap:.4rem;flex-wrap:wrap;margin:.3rem 0 1rem}
.tab{font-family:Khand;font-weight:600;font-size:.95rem;padding:.22rem .8rem;border-radius:999px;cursor:pointer;
  border:1px solid var(--line);background:#f3f6fc;color:#33415c;text-transform:capitalize;
  display:inline-flex;align-items:center;gap:.35rem}
.tab .ic{width:1.15em;height:1.15em}
.tab.active{color:#fff;border-color:transparent}
.tab.active .ic{fill:#fff}
.tab[data-cat=move] .ic{fill:var(--blue)} .tab[data-cat=look] .ic{fill:var(--purple)}
.tab[data-cat=engage] .ic{fill:var(--orange)} .tab[data-cat=help] .ic{fill:var(--green)}
.tab[data-cat=take] .ic{fill:var(--yellow-dk)} .tab[data-cat=overpower] .ic{fill:var(--red)}
.tab[data-cat=depart] .ic{fill:#5b6b86} .tab[data-cat=special] .ic{fill:#b8860b}
.tab[data-cat=move].active{background:var(--blue)} .tab[data-cat=look].active{background:var(--purple)}
.tab[data-cat=engage].active{background:var(--orange)} .tab[data-cat=help].active{background:var(--green)}
.tab[data-cat=take].active{background:var(--yellow-dk)} .tab[data-cat=overpower].active{background:var(--red)}
.tab[data-cat=depart].active{background:#5b6b86} .tab[data-cat=special].active{background:#b8860b}
.entry{background:#f7f9fd;border:1px solid var(--line);border-radius:12px;padding:.9rem 1rem;margin-bottom:.7rem}
.entry-meta{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.45rem}
.cost-badge,.dir-badge{font-family:Khand;font-weight:700;border:1px solid var(--line);border-radius:8px;padding:.02rem .55rem}
.cost-badge{background:#e9eefb;color:var(--accent)} .dir-badge{background:#fff;color:var(--mut)}
.entry .action{font-weight:600;font-size:1.05rem;margin-bottom:.35rem}
.entry .result{color:#23344f}
/* spoiler guard */
.reveal{position:relative;min-height:54px}
.reveal-content{filter:blur(8px);opacity:.55;user-select:none;pointer-events:none;transition:filter .25s,opacity .25s}
.reveal.shown .reveal-content{filter:none;opacity:1;user-select:auto;pointer-events:auto}
.reveal-btn{position:absolute;inset:0;margin:auto;width:max-content;height:max-content;
  display:inline-flex;align-items:center;gap:.4rem;font-family:Khand;font-weight:600;font-size:1rem;
  padding:.4rem 1.1rem;border-radius:999px;cursor:pointer;color:var(--accent);
  background:rgba(255,255,255,.9);border:1.5px solid var(--blue);box-shadow:0 2px 12px rgba(0,0,0,.2)}
.reveal-btn:hover{background:#fff;transform:scale(1.03)}
.reveal-btn .ic{fill:var(--blue)}
.reveal.shown .reveal-btn{display:none}

/* shared markup (light bg) */
.move{color:var(--blue);font-weight:700}.look{color:var(--purple);font-weight:700}
.engage{color:var(--orange);font-weight:700}.help{color:var(--green);font-weight:700}
.take{color:var(--yellow-dk);font-weight:700}.overpower{color:var(--red);font-weight:700}
.loc-num{font-family:Khand;color:var(--locnum);font-weight:700}.card-num{font-family:Khand;color:var(--cardnum);font-weight:700}
.skill{font-style:italic}
svg.ic,.ic{width:1.1em;height:1.1em;vertical-align:-.15em;fill:currentColor}

.foot{position:relative;text-align:center;color:#9fb0d4;font-size:.8rem;padding:1.4rem 1rem 2rem;text-shadow:0 1px 6px rgba(0,0,0,.6)}

@media(max-width:560px){
  .card{padding:1.3rem 1rem 1.6rem}
  .card-body img{max-width:160px}
}
