/* ═══════════════════════════════════════════════════════════
   ALYRIUM WIKI · THE DIPLOMATIC REGISTRY
   Shared stylesheet for all category pages
   ═══════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;}
body{
  background:#f7f5f0;color:#1a1612;
  font-family:'IBM Plex Sans',sans-serif;font-size:14px;
  -webkit-font-smoothing:antialiased;
  overflow:hidden;
}

a{color:inherit;text-decoration:none;}

/* ── APP SHELL ───────────────────────────────────────────── */
.dr{display:flex;min-height:100vh;height:100vh;font-family:'IBM Plex Sans',sans-serif;background:#f7f5f0;color:#1a1612;font-size:14px;}
.dr-stripe{width:4px;flex-shrink:0;background:#4a6fa5;}
.dr-wrap{flex:1;display:flex;flex-direction:column;min-width:0;}

/* paper grain overlay */
.dr-wrap::before{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse at 18% 22%, rgba(212,196,160,.16), transparent 45%),
    radial-gradient(ellipse at 82% 78%, rgba(180,160,128,.12), transparent 45%),
    radial-gradient(ellipse at 50% 50%, transparent 40%, rgba(120,108,84,.08) 100%);
}
.dr-wrap::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background:repeating-linear-gradient(
    0deg, transparent 0, transparent 3px,
    rgba(120,108,84,.012) 3px, rgba(120,108,84,.012) 4px
  );
}

/* ── TOP NAV ─────────────────────────────────────────────── */
.dr-nav{
  background:#edeae2;border-bottom:1px solid #d4cfc4;
  padding:0 14px;display:flex;align-items:center;height:42px;flex-shrink:0;gap:4px;
  position:relative;z-index:5;
}
.dr-nav-logo{
  font-family:'Cinzel',serif;font-weight:600;font-size:11px;
  letter-spacing:.14em;text-transform:uppercase;color:#1a1612;
  margin-right:8px;white-space:nowrap;flex-shrink:0;
}
.dr-nav-sub{
  font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.14em;
  color:#8a8070;text-transform:uppercase;margin-right:14px;
}
.dr-nav-divider{width:1px;height:18px;background:#d4cfc4;margin:0 6px;}
.dr-nav-items{display:flex;margin-left:auto;gap:0;}
.dr-nav-item{
  font-size:11px;color:#6a6050;padding:0 12px;height:42px;
  display:flex;align-items:center;border-bottom:2px solid transparent;
  cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap;
  letter-spacing:.04em;font-family:'IBM Plex Sans',sans-serif;
}
.dr-nav-item:hover{color:#1a1612;}
.dr-nav-item.on{color:#1a1612;border-bottom-color:#4a6fa5;}

/* ── BODY ROW ────────────────────────────────────────────── */
.dr-row{display:flex;flex:1;overflow:hidden;position:relative;z-index:1;}

/* ── SIDEBAR ─────────────────────────────────────────────── */
.dr-sidebar{
  width:240px;flex-shrink:0;border-right:1px solid #e0dbd2;
  padding:18px 0;background:#edeae2;overflow-y:auto;
  scrollbar-width:thin;scrollbar-color:#c8c0b0 #edeae2;
}
.dr-sidebar::-webkit-scrollbar{width:6px;}
.dr-sidebar::-webkit-scrollbar-track{background:#edeae2;}
.dr-sidebar::-webkit-scrollbar-thumb{background:#c8c0b0;}

.dr-sb-hd{
  font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.2em;
  text-transform:uppercase;color:#8a8070;font-weight:700;
  padding:0 16px;margin-bottom:8px;margin-top:18px;
}
.dr-sb-hd:first-child{margin-top:0;}

.dr-sb-search{
  margin:0 14px 12px;padding:6px 10px;background:#f7f5f0;
  border:1px solid #d4cfc4;font-family:'IBM Plex Sans',sans-serif;
  font-size:11px;color:#1a1612;width:calc(100% - 28px);
}
.dr-sb-search:focus{outline:none;border-color:#4a6fa5;}

.dr-sb-link{
  display:flex;align-items:center;gap:8px;padding:5px 16px;
  font-size:12px;color:#5a5040;cursor:pointer;
  transition:color .15s,background .15s;line-height:1.35;
  font-family:'IBM Plex Sans',sans-serif;
  border-left:2px solid transparent;
}
.dr-sb-link:hover{color:#1a1612;background:rgba(0,0,0,.03);}
.dr-sb-link.on{color:#1a1612;font-weight:500;background:rgba(0,0,0,.05);border-left-color:#4a6fa5;}
.dr-sb-link.hidden{display:none;}

.dr-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:#d0ccc4;}

/* ── MAIN CONTENT ────────────────────────────────────────── */
.dr-main{
  flex:1;padding:24px 36px;overflow-y:auto;min-width:0;
  scrollbar-width:thin;scrollbar-color:#c8c0b0 transparent;
}
.dr-main::-webkit-scrollbar{width:8px;}
.dr-main::-webkit-scrollbar-thumb{background:#c8c0b0;}

.dr-entry{display:none;max-width:920px;}
.dr-entry.on{display:block;}

/* ── BANNER ──────────────────────────────────────────────── */
.dr-banner{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  padding:8px 14px;background:#e8e4dc;border-left:3px solid #4a6fa5;
  margin-bottom:18px;
}
.dr-b-region{
  font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.18em;
  font-weight:700;color:#4a6fa5;text-transform:uppercase;
}
.dr-b-era{
  font-family:'Space Mono',monospace;font-size:10px;color:#6a6050;
  letter-spacing:.06em;
}
.dr-pill{
  font-family:'Space Mono',monospace;font-size:9px;padding:3px 9px;
  border-radius:10px;letter-spacing:.12em;font-weight:700;margin-left:auto;
  text-transform:uppercase;
}
.dr-pill.active   {background:#d3edd9;color:#1a5a28;}
.dr-pill.defunct  {background:#e0dbd2;color:#6a6050;}
.dr-pill.disputed {background:#fef3cc;color:#7a5000;}
.dr-pill.war      {background:#fde8e8;color:#8b1a1a;}
.dr-pill.colony   {background:#e4ddf0;color:#5c3d7a;}

/* ── TITLES ──────────────────────────────────────────────── */
.dr-title{
  font-family:'Playfair Display',serif;font-size:38px;font-weight:700;
  color:#1a1612;line-height:1.05;margin-bottom:6px;letter-spacing:.005em;
}
.dr-sub{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-size:16px;
  color:#6a6050;margin-bottom:18px;line-height:1.4;
}

/* ── INFOBOX (floated right) ─────────────────────────────── */
.dr-infobox{
  float:right;margin:0 0 16px 22px;width:260px;
  border:1px solid #d4cfc4;border-top:3px solid #4a6fa5;
  background:#f7f5f0;font-size:12px;
}
.dr-ib-title{
  background:#e8e4dc;padding:7px 10px;font-weight:600;font-size:11px;
  text-align:center;letter-spacing:.06em;border-bottom:1px solid #d4cfc4;
  font-family:'Cinzel',serif;text-transform:uppercase;color:#1a1612;
}
.dr-ib-row{display:flex;border-bottom:1px solid #ede9e2;}
.dr-ib-row:last-child{border-bottom:none;}
.dr-ib-k{
  padding:5px 9px;width:42%;background:#f0ece4;color:#6a6050;
  font-size:11px;border-right:1px solid #e8e4dc;line-height:1.4;
  font-family:'Space Mono',monospace;letter-spacing:.04em;
}
.dr-ib-v{
  padding:5px 9px;width:58%;color:#1a1612;font-size:12px;line-height:1.45;
}
.dr-ib-flag{
  height:80px;background:#e8e4dc;border-bottom:1px solid #d4cfc4;
  display:flex;align-items:center;justify-content:center;
  font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.18em;
  color:#a89880;text-transform:uppercase;
  background-image:repeating-linear-gradient(45deg, transparent 0, transparent 8px, rgba(168,152,128,.08) 8px, rgba(168,152,128,.08) 16px);
}

/* ── TEXT BODY ───────────────────────────────────────────── */
.dr-text{
  font-size:14px;line-height:1.72;color:#2a2018;text-wrap:pretty;
  margin-bottom:12px;font-family:'IBM Plex Sans',sans-serif;
}
.dr-text em{font-style:italic;color:#3a2a18;}
.dr-text strong{font-weight:600;color:#1a1612;}

.dr-sec{
  font-family:'Cinzel',serif;font-size:13px;font-weight:600;
  text-transform:uppercase;letter-spacing:.12em;color:#1a1612;
  margin:24px 0 10px;padding-bottom:5px;border-bottom:1px solid #d4cfc4;clear:both;
}

.dr-quote{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:16px;line-height:1.55;color:#3a2a18;
  padding:14px 22px;margin:14px 0;
  border-left:3px solid #4a6fa5;background:#f0ece4;
}
.dr-quote-attr{
  display:block;margin-top:8px;font-family:'Space Mono',monospace;
  font-style:normal;font-size:10px;color:#8a8070;
  letter-spacing:.1em;text-transform:uppercase;
}

.dr-list{margin:10px 0 14px 22px;font-size:14px;line-height:1.7;color:#2a2018;}
.dr-list li{margin-bottom:5px;}

.dr-clearfix::after{content:'';display:table;clear:both;}

/* ── ACCESS LOG ──────────────────────────────────────────── */
.dr-access-log{
  clear:both;margin-top:28px;padding:10px 14px;
  background:#f0ece4;border:1px solid #d4cfc4;border-left:3px solid #4a6fa5;
  font-family:'Space Mono',monospace;font-size:10px;color:#6a6050;
  letter-spacing:.04em;
}
.dr-log-title{
  font-weight:700;letter-spacing:.2em;margin-bottom:7px;
  font-size:10px;color:#4a6fa5;text-transform:uppercase;
}
.dr-log-entry{
  display:flex;justify-content:space-between;padding:3px 0;
  border-bottom:1px solid #e8e4dc;font-size:10px;
}
.dr-log-entry:last-child{border-bottom:none;}
.dr-log-tier{color:#9a9080;}

/* ── EMPTY STATE / LANDING ───────────────────────────────── */
.dr-empty{
  text-align:center;padding:80px 20px;color:#8a8070;
  font-family:'Cormorant Garamond',serif;font-style:italic;font-size:18px;
}

/* ── LANDING PAGE GRID ───────────────────────────────────── */
.dr-landing{padding:40px 60px;max-width:1100px;margin:0 auto;}
.dr-landing-eyebrow{
  font-family:'Cinzel',serif;font-weight:500;font-size:11px;
  letter-spacing:.42em;text-transform:uppercase;color:#6a6050;
  margin-bottom:14px;padding-left:.42em;text-align:center;
}
.dr-landing-title{
  font-family:'Playfair Display',serif;font-weight:800;
  font-size:clamp(48px, 8vw, 96px);line-height:.95;text-align:center;
  color:#1a1612;letter-spacing:.025em;margin-bottom:16px;
}
.dr-landing-rule{
  width:160px;height:1px;background:#1a1612;
  margin:0 auto 16px;position:relative;
}
.dr-landing-rule::before,.dr-landing-rule::after{
  content:'';position:absolute;top:-3px;width:7px;height:7px;
  background:#4a6fa5;border-radius:50%;
}
.dr-landing-rule::before{left:-11px;}
.dr-landing-rule::after{right:-11px;}
.dr-landing-sub{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;
  font-size:18px;color:#3a2a18;text-align:center;margin-bottom:6px;
}
.dr-landing-tagline{
  font-family:'Space Mono',monospace;font-size:10px;color:#8a8070;
  letter-spacing:.28em;text-transform:uppercase;text-align:center;
  margin-bottom:48px;
}

.dr-cats{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:14px;margin-bottom:40px;
}
.dr-cat{
  display:block;padding:18px 22px;background:rgba(255,255,255,.5);
  border:1px solid #d4cfc4;border-left:3px solid #4a6fa5;
  cursor:pointer;transition:all .2s ease;
  text-decoration:none;color:#1a1612;
}
.dr-cat:hover{
  background:#edeae2;
  transform:translateY(-2px);
  box-shadow:0 4px 14px rgba(60,40,20,.08);
}
.dr-cat-code{
  font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.2em;
  color:#8a8070;font-weight:700;margin-bottom:6px;text-transform:uppercase;
}
.dr-cat-name{
  font-family:'Playfair Display',serif;font-weight:700;font-size:22px;
  line-height:1.1;margin-bottom:5px;
}
.dr-cat-hint{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-size:13px;
  color:#6a6050;line-height:1.35;
}
.dr-cat-count{
  font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.14em;
  color:#a89880;margin-top:8px;text-transform:uppercase;
}

/* ── REGION COLOR VARIANTS ───────────────────────────────── */
/* Apply via inline style="--region:#hex" on .dr or specific elements */
.dr[data-region="tardam"]    .dr-stripe,
.dr[data-region="tardam"]    .dr-banner{border-left-color:#4a6fa5;}
.dr[data-region="paradisum"] .dr-stripe{background:#5c8a5c;}
.dr[data-region="paradisum"] .dr-banner{border-left-color:#5c8a5c;}
.dr[data-region="novaterra"] .dr-stripe{background:#7252ff;}
.dr[data-region="novaterra"] .dr-banner{border-left-color:#7252ff;}
.dr[data-region="iblus"]     .dr-stripe{background:#b87333;}
.dr[data-region="iblus"]     .dr-banner{border-left-color:#b87333;}
.dr[data-region="jusai"]     .dr-stripe{background:#8b1a1a;}
.dr[data-region="jusai"]     .dr-banner{border-left-color:#8b1a1a;}
.dr[data-region="sinie"]     .dr-stripe{background:#c4961a;}
.dr[data-region="sinie"]     .dr-banner{border-left-color:#c4961a;}

/* ── FOOTER ──────────────────────────────────────────────── */
.dr-footer{
  flex-shrink:0;height:32px;background:#edeae2;border-top:1px solid #d4cfc4;
  display:flex;align-items:center;justify-content:space-between;padding:0 20px;
  font-family:'Space Mono',monospace;font-size:9px;color:#8a8070;
  letter-spacing:.1em;position:relative;z-index:5;text-transform:uppercase;
}
.dr-footer-redact{color:#c8c0b0;letter-spacing:0;font-size:10px;}

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media (max-width: 900px){
  .dr-sidebar{width:180px;}
  .dr-main{padding:18px 24px;}
  .dr-infobox{width:200px;}
  .dr-title{font-size:30px;}
}
