/* ===================================== */
/*   The Encyclopedia of Fear — Valkrum  */
/*   monsterbook.css                     */
/* ===================================== */

/* ---------- Root Palette ---------- */
:root{
  --bg:#efe0bf;
  --bg2:#dcc79a;

  --panel:#f6e9cc;
  --panel-dark:#e9d6af;

  --text:#352416;
  --muted:#6f5038;

  --blood:#8a2017;
  --blood-bright:#b22b1f;
  --brown:#7a5432;

  --line:rgba(95,62,37,.25);
  --line-strong:rgba(95,62,37,.38);
  --shadow:0 12px 30px rgba(74,45,25,.22);
}

/* ---------- Reset ---------- */
*{
  box-sizing:border-box;
}

body{
  margin:0;
  font-family:Georgia, serif;
  background:
    radial-gradient(900px 600px at 18% 8%, rgba(178,43,31,.12), transparent 58%),
    radial-gradient(700px 500px at 85% 20%, rgba(122,84,50,.14), transparent 65%),
    linear-gradient(180deg,var(--bg),var(--bg2));
  color:var(--text);
  min-height:100vh;
}

a{
  color:var(--blood-bright);
  text-decoration:none;
}

a:hover{
  color:#8f2118;
}

/* ---------- Header ---------- */
header{
  position:sticky;
  top:0;
  z-index:20;
  background:
    linear-gradient(180deg, rgba(12,10,9,.98), rgba(4,3,3,.96)),
    radial-gradient(460px 160px at 12% 0%, rgba(178,43,31,.16), transparent 72%);
  border-bottom:1px solid rgba(255,235,220,.22);
  box-shadow:0 14px 32px rgba(0,0,0,.5);
  padding:16px 20px 12px;
}

header h1{
  margin:0;
  font-size:24px;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:600;
  line-height:1.05;
  text-shadow:0 0 14px rgba(177,31,31,.2);
  color:#efe7de;
}

.brand-link,
.brand-link:hover{
  color:inherit;
  text-decoration:none;
}

.brand small{
  display:block;
  font-size:10px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:#cdb9a3;
  margin-top:6px;
  opacity:.85;
}

.head-inner{
  max-width:1200px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:20px;
}

.brand{
  text-align:center;
}

.controls{
  display:grid;
  grid-template-columns:minmax(0, 2fr) minmax(0, 1fr) minmax(0, 1fr) auto;
  align-items:center;
  gap:10px;
  justify-content:center;
  padding:8px;
  border:1px solid rgba(95,62,37,.2);
  border-radius:14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.45), rgba(167,133,89,.18));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.65),
    0 8px 20px rgba(100,70,45,.14);
}

.search-wrap{
  min-width:0;
}

.input,
.select,
.btn{
  height:42px;
  border:1px solid rgba(95,62,37,.28);
  background:
    linear-gradient(180deg, rgba(255,255,255,.5), rgba(142,108,64,.18));
  color:var(--text);
  border-radius:11px;
  padding:0 13px;
  font-size:13px;
  letter-spacing:.02em;
  transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease, background .2s ease;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.58);
}

.input,
.select{
  width:100%;
}

.select{
  min-width:0;
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  font-family:Georgia, serif;
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
  border-color:rgba(178,43,31,.38);
  background-color:rgba(246,231,199,.95);
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(53,36,22,.78) 50%),
    linear-gradient(135deg, rgba(53,36,22,.78) 50%, transparent 50%),
    radial-gradient(80px 40px at calc(100% - 24px) 50%, rgba(178,43,31,.18), transparent 62%),
    linear-gradient(180deg, rgba(178,43,31,.06), rgba(122,84,50,.12));
  background-position:
    calc(100% - 18px) calc(50% - 1px),
    calc(100% - 12px) calc(50% - 1px),
    0 0,
    0 0;
  background-size:6px 6px, 6px 6px, 100% 100%, 100% 100%;
  background-repeat:no-repeat;
  padding-right:40px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.5),
    inset -1px 0 0 rgba(95,62,37,.08),
    0 0 0 1px rgba(95,62,37,.16);
}

.select:hover{
  border-color:rgba(177,31,31,.55);
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(53,36,22,.88) 50%),
    linear-gradient(135deg, rgba(53,36,22,.88) 50%, transparent 50%),
    radial-gradient(90px 45px at calc(100% - 24px) 50%, rgba(178,43,31,.26), transparent 62%),
    linear-gradient(180deg, rgba(178,43,31,.1), rgba(122,84,50,.14));
}

.input::placeholder{
  color:rgba(111,80,56,.7);
}

.input:focus,
.select:focus{
  outline:none;
  border-color:rgba(178,43,31,.72);
  box-shadow:
    0 0 0 3px rgba(178,43,31,.14),
    0 0 16px rgba(178,43,31,.16);
  background:linear-gradient(180deg, rgba(255,255,255,.62), rgba(167,133,89,.22));
}

.select option{
  background:#f6e9cc;
  color:var(--text);
  font-family:Georgia, serif;
  font-size:13px;
  text-transform:none;
}

.btn{
  background:
    linear-gradient(180deg, rgba(178,43,31,.28), rgba(145,38,28,.5));
  border-color:rgba(145,38,28,.5);
  font-weight:600;
  cursor:pointer;
  min-width:88px;
}

.btn:hover{
  border-color:rgba(177,31,31,.85);
  box-shadow:
    0 8px 18px rgba(94,60,34,.24),
    0 0 16px rgba(178,43,31,.22);
  transform:translateY(-1px);
}

.btn:active{
  transform:translateY(0);
  box-shadow:inset 0 2px 8px rgba(94,60,34,.28);
}

.subhead{
  max-width:1200px;
  margin:12px auto 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding-top:10px;
  border-top:1px solid rgba(255,235,220,.14);
}

.subhead-centered{
  justify-content:center;
}

.subhead-centered .subtitle{
  text-align:center;
}

.subtitle{
  margin:0;
  color:#cdb9a3;
  font-size:13px;
  line-height:1.4;
}

.area-title{
  font-size:24px;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:600;
  line-height:1.05;
  color:#efe7de;
  text-shadow:0 0 14px rgba(177,31,31,.2);
}

.stats{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

.pill{
  border:1px solid var(--line);
  background:rgba(255,255,255,.35);
  border-radius:999px;
  font-size:12px;
  padding:5px 10px;
  color:var(--muted);
}

.pill b{
  color:var(--text);
}

/* ---------- Layout ---------- */
main{
  max-width:1200px;
  margin:auto;
  padding:30px 20px 60px;
}

/* ---------- Grid ---------- */
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:20px;
}

.controls-top{
  margin-bottom:30px;
  display:flex;
  justify-content:center;
}

/* ---------- Cards ---------- */
.card{
  background:linear-gradient(180deg,var(--panel),var(--panel-dark));
  border:1px solid var(--line);
  padding:20px;
  border-radius:12px;
  transition:.25s ease;
  cursor:pointer;
  display:block;
  color:inherit;
}

.card:hover{
  border-color:var(--blood);
  transform:translateY(-5px);
  box-shadow:0 10px 25px rgba(100,70,45,.2);
}

.card h3{
  margin:8px 0 10px 0;
  font-size:18px;
}

.card p{
  font-size:14px;
  color:var(--muted);
  line-height:1.5;
}

.card-region{
  margin-top:10px;
  font-size:12px;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:rgba(111,80,56,.9);
}

.id{
  font-family:monospace;
  font-size:12px;
  opacity:.72;
  letter-spacing:.15em;
}

/* ---------- Monster Page ---------- */
.monster-container{
  max-width:900px;
  margin:auto;
  padding:40px 20px;
}

.monster-hero{
  margin:0 auto 24px;
  width:100%;
  max-width:560px;
  border-radius:14px;
  overflow:hidden;
  border:1px solid var(--line);
  background:linear-gradient(180deg,var(--panel),var(--panel-dark));
  box-shadow:0 14px 30px rgba(94,60,34,.2);
}

.monster-image{
  display:block;
  width:100%;
  height:auto;
  object-fit:cover;
}

.monster-container h1{
  margin-top:0;
  font-size:28px;
}

.monster-lore{
  margin-top:20px;
  font-size:16px;
  line-height:1.7;
  color:var(--muted);
}

.dossier-wrap{
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.28), rgba(167,133,89,.12)),
    linear-gradient(180deg,var(--panel),var(--panel-dark));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.55),
    0 12px 28px rgba(94,60,34,.16);
}

.dossier-table{
  width:100%;
  border-collapse:collapse;
}

.dossier-table tr{
  border-bottom:1px solid rgba(95,62,37,.16);
}

.dossier-table tr:last-child{
  border-bottom:none;
}

.dossier-table th,
.dossier-table td{
  padding:14px 16px;
  vertical-align:top;
}

.dossier-table th{
  width:160px;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(111,80,56,.95);
  border-right:1px solid rgba(95,62,37,.16);
  background:rgba(167,133,89,.14);
}

.dossier-table td{
  color:var(--text);
  line-height:1.5;
}

.tag-list{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.tag-chip{
  display:inline-flex;
  align-items:center;
  border:1px solid rgba(145,38,28,.38);
  border-radius:999px;
  padding:4px 10px;
  font-size:12px;
  color:var(--text);
  background:linear-gradient(180deg, rgba(178,43,31,.2), rgba(145,38,28,.24));
}

.tag-empty{
  color:var(--muted);
  font-style:italic;
}

/* ---------- Back Link ---------- */
.back-link{
  display:inline-block;
  margin-bottom:20px;
  font-size:14px;
  color:var(--blood-bright);
}

.back-link:hover{
  text-decoration:underline;
}

/* ---------- Footer ---------- */
footer{
  border-top:1px solid var(--line);
  padding:20px;
  text-align:center;
  font-size:12px;
  color:var(--muted);
  margin-top:40px;
}

@media (max-width:900px){
  .head-inner{
    align-items:center;
  }

  .controls{
    grid-template-columns:1fr;
    width:100%;
  }

  .search-wrap{
    min-width:0;
    width:100%;
    flex:1 1 100%;
  }

  .select{
    min-width:0;
  }

  .subhead{
    flex-direction:column;
    align-items:center;
  }

  .subtitle{
    text-align:center;
  }

  .dossier-table th,
  .dossier-table td{
    display:block;
    width:100%;
    border-right:none;
  }

  .dossier-table th{
    padding-bottom:6px;
    border-bottom:1px solid rgba(95,62,37,.16);
  }

  .dossier-table td{
    padding-top:10px;
  }
}

/* ---------- Manual Home ---------- */
.manual-home .head-inner{
  align-items:center;
}

.manual-home .brand{
  text-align:center;
}

.manual-home .brand h1{
  font-size:40px;
}

.intro-panel{
  border:1px solid var(--line);
  border-radius:14px;
  padding:20px;
  margin-bottom:26px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.42), rgba(167,133,89,.2)),
    linear-gradient(180deg,var(--panel),var(--panel-dark));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.68),
    0 10px 24px rgba(94,60,34,.14);
}

.intro-panel h2{
  margin:0 0 10px;
  font-size:24px;
  letter-spacing:.04em;
  text-transform:uppercase;
}

.intro-panel p{
  margin:0;
  color:var(--muted);
  line-height:1.65;
  max-width:72ch;
}

.section-title{
  margin:0 0 14px;
  font-size:18px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--text);
}

.manual-home section + section{
  margin-top:26px;
}

.wiki-card{
  min-height:186px;
}

@media (max-width:900px){
  .manual-home .head-inner{
    align-items:center;
  }

  .manual-home .brand{
    text-align:center;
  }
}
