.site-header {
    background-color: #0d0d0d;
    border-bottom: 2px solid #333;
    margin-bottom: 30px;
}

.main-nav {
    max-width: 1200px;
    margin: 0 auto;
    padding: 10px 20px;
    display: flex;
    gap: 20px;
    justify-content: center;
}

.main-nav a {
    color: #ccc;
    text-decoration: none;
    font-weight: bold;
    padding: 6px 10px;
}

.main-nav a:hover {
    color: #fff;
    background-color: #222;
    border-radius: 4px;
}

.tower-nav {
    max-width: 1200px;
    margin: 10px auto 30px;
    padding: 8px 20px;
    display: flex;
    gap: 12px;
    justify-content: center;
    border-bottom: 1px solid #333;
}

.tower-nav a {
    color: #aaa;
    text-decoration: none;
    font-size: 0.9em;
    padding: 4px 8px;
}

.tower-nav a:hover {
    color: #fff;
    background-color: #222;
    border-radius: 3px;
}


.running-nav {
    max-width: 1200px;
    margin: 10px auto 30px;
    padding: 8px 20px;
    display: flex;
    gap: 12px;
    justify-content: center;
    border-bottom: 1px solid #333;
}

.running-nav a {
    color: #aaa;
    text-decoration: none;
    font-size: 0.9em;
    padding: 4px 8px;
}

.running-nav a:hover {
    color: #fff;
    background-color: #222;
    border-radius: 3px;
}

.main-nav a {
    color: #ddd;
}

.main-nav a:hover {
    color: #fff;
}

.gm-warning {
    color: #ff7777;
    text-align: center;
    font-weight: bold;

    background-color: rgba(255, 100, 100, 0.08);
    padding: 6px 10px;

    margin: 15px 0;
}


/* =========================
   GLOBAL LINK STYLING
   ========================= */

a {
    color: #B5A642;           /* gold tone */
    text-decoration: none;
}

a:visited {
    color: #b8925a;
}

a:hover,
a:focus {
    color: #e0c27d;
    text-decoration: underline;
}

a:active {
    color: #ffffff;
}

/* =========================
   HOMEPAGE ONLY STYLES
   ========================= */

.homepage-content {
    max-width: 900px;
    margin: 2rem auto;
    padding: 0 1rem;
}

/* Panel styling */
.homepage-content section {
    background: #111;
    border: 1px solid #333;
    padding: 1.5rem 2rem;
    margin-bottom: 2rem;
    box-shadow: 0 0 12px rgba(0, 0, 0, 0.6);
}

/* Intro */
.homepage-content .intro-panel {
    border: 2px solid #555;
    background: linear-gradient(180deg, #151515, #0d0d0d);
}

/* Headings */
.homepage-content h1 {
    font-size: 2.2rem;
    margin-bottom: 1rem;
    border-bottom: 2px solid #444;
    padding-bottom: 0.5rem;
}

.homepage-content h2 {
    margin-top: 0;
    font-size: 1.4rem;
    color: #cfcfcf;
    border-left: 4px solid #666;
    padding-left: 0.75rem;
}

/* Paragraph rhythm */
.homepage-content p {
    line-height: 1.6;
    margin-bottom: 1rem;
}

/* My section*/
.homepage-content .about-author {
    background: #0c0c0c;
    border-color: #444;
}

/* =========================
   GENERIC INDEX TEXT PAGES
   ========================= */

.index-page {
    max-width: 850px;
    margin: 2.5rem auto;
    padding: 0 1.25rem;
}

/* Main title */
.index-page h1 {
    font-size: 2.2rem;
    margin-bottom: 1.5rem;
    padding-bottom: 0.5rem;
    border-bottom: 2px solid #444;
}

/* Section headings */
.index-page h2 {
    margin-top: 2.5rem;
    margin-bottom: 0.75rem;
    font-size: 1.4rem;
    color: #d0d0d0;
    border-left: 4px solid #555;
    padding-left: 0.75rem;
}

/* Paragraphs */
.index-page p {
    line-height: 1.65;
    margin-bottom: 1rem;
    color: #e0e0e0;
}

/* Lists */
.index-page ul {
    margin: 0.5rem 0 1.5rem 1.5rem;
}

.index-page li {
    margin-bottom: 0.5rem;
    line-height: 1.5;
}

/* "strong" emphasis (shared across text pages) */
.index-page strong,
.floor-page strong {
    color: #dfc27f;
    font-weight: 600;
}



.index-page em {
    color: #ccc;
}

.index-page details {
    margin: 1.5rem 0;
    padding: 1rem 1.25rem;
    background: #0f0f0f;
    border-left: 4px solid #666;
}

.index-page summary {
    cursor: pointer;
    font-weight: bold;
    color: #e0c27d;
}

/* =========================
   MAGIC / ITEM ENTRY PANELS
   ========================= */

.item-entry {
    background: #111;
    border: 1px solid #333;

    padding: 1.2rem 1.5rem;
    margin: 1.5rem 0;

    box-shadow: 0 0 10px rgba(0,0,0,0.6);
}

/* Title inside item */
.item-entry h3 {
    margin-top: 0;

    border-left: 4px solid #666;
    padding-left: 8px;

    color: #ddd;
}

/* Optional: subtle divider line */
.item-entry::after {
    content: "";
    display: block;

    margin-top: 1rem;
    border-bottom: 1px solid #222;
}

.item-entry {
    overflow: auto;
}

/* =========================
   NPC PAGE STRUCTURE
   ========================= */

.index-page .npc-entry {
    margin: 3rem 0;
    padding-bottom: 2rem;
    border-bottom: 1px solid #333;
}

body {
    font-family: Arial, sans-serif;
    background-color: #111;
    color: #eee;
    margin: 0;
    padding: 20px;
}

h1 {
    text-align: center;
}

h3 {
    border-left: 3px solid #444;
    padding-left: 0.6rem;
}



h4 {
    margin-top: 2rem;
    margin-bottom: 0.5rem;
    font-size: 1.05rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #bbb;
}

.index-page .page-toc {
    margin: 2rem 0;
    padding: 1rem 1.25rem;
    background: #0f0f0f;
    border-left: 4px solid #666;
}

.index-page .page-toc summary {
    cursor: pointer;
    font-weight: bold;
    font-size: 1.05rem;
}

.index-page .page-toc ul {
    margin-top: 1rem;
    columns: 2;
}

.index-page .back-to-top {
    margin-top: 1.5rem;
    font-size: 0.85rem;
    opacity: 0.7;
}

html {
    scroll-behavior: smooth;
}
.map-container {
    position: relative;
    max-width: 2000px;
    margin: 0 auto;
}

.map-container img {
    width: 100%;
    height: auto;
    display: block;
    border: 2px solid #444;
}

/* shows on hover/focus so users know it's interactive */
.map-hotspot:hover,
.map-hotspot:focus-visible{
  outline: 2px solid #dfc27f;
  background: rgba(223, 194, 127, 0.12);
}

a[target="_blank"]::after {
    content: "↗";
    font-size: 0.8em;
    opacity: 0.6;
}

/* =========================
   INDEX SECTION NAV
   ========================= */

.index-page .section-nav {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.75rem;

    margin: 2rem 0 3rem;
    padding: 0.75rem 1rem;

    background: #0f0f0f;
    border-top: 1px solid #333;
    border-bottom: 1px solid #333;
}

.index-page .section-nav a {
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.85rem;
    letter-spacing: 0.05em;
}

.index-page .section-nav .divider {
    opacity: 0.4;
}


/* =========================
   Homepage hero image
   ========================= */

.homepage-content .intro-panel img {
    display: block;
    max-width: 100%;
    height: auto;
}

/* =========================
   ENCOUNTER TABLES
   ========================= */

.index-page table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 1rem;
    font-size: 0.95rem;
}

.index-page th,
.index-page td {
    padding: 0.5rem 0.75rem;
    border-bottom: 1px solid #333;
    vertical-align: top;
}

.index-page th {
    text-align: left;
    font-weight: bold;
    color: #e0c27d;
    border-bottom: 2px solid #555;
}

.index-page td:first-child {
    width: 4rem;
    text-align: center;
    font-weight: bold;
    color: #ccc;
}

.index-page tbody tr:hover {
    background-color: rgba(255, 255, 255, 0.03);
}

.index-page table tbody tr:empty {
    display: none;
}

/* =========================
   ENCOUNTER TABLES (reusable)
   ========================= */

.encounter-table table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 1rem;
    font-size: 0.95rem;
}

.encounter-table th,
.encounter-table td {
    padding: 0.5rem 0.75rem;
    border-bottom: 1px solid #333;
    vertical-align: top;
}

.encounter-table th {
    text-align: left;
    font-weight: bold;
    color: #e0c27d;
    border-bottom: 2px solid #555;
}

.encounter-table td:first-child {
    width: 4rem;
    text-align: center;
    font-weight: bold;
    color: #ccc;
}

.encounter-table tbody tr:hover {
    background-color: rgba(255, 255, 255, 0.03);
}

/* Hide phantom rows reliably */
.encounter-table tbody tr:not(:has(td)) {
    display: none;
}



/* NPC specific (optional overrides later) .index-page .npc-entry {} */

/* Faction specific (optional overrides later) .index-page .faction-entry {} */


/* =========================
   LORE ENTRY (GENERIC)
   ========================= */

.index-page .lore-entry {
    margin: 3rem 0;
    padding-bottom: 2rem;
    border-bottom: 1px solid #333;
}


/* =========================
   Floor Styles
   ========================= */

/* Debug mode for room positioning */   
   .debug .room {
    outline: 1px dashed red;
}

.debug .door {
    outline: 1px dashed blue;
}

/* Tooltip style (optional, same style as room tooltips) */
.door[title]:hover::after {
    content: attr(title);
    position: absolute;
    top: -20px;
    left: 0;
    background: #222;
    color: #fff;
    padding: 2px 5px;
    border-radius: 3px;
    font-size: 12px;
    white-space: nowrap;
    z-index: 10;
}

.floor-page ul ul {
    list-style-type: circle;
}

.floor-page section {
    margin: 50px auto;
    max-width: 2000px;
    padding: 20px;
    border-left: 4px solid #888;
    background-color: #1a1a1a;
    border-radius: 5px;
}

/* Clear floated images inside rooms */
.floor-page section::after {
    content: "";
    display: block;
    clear: both;
}



/* =========================
   Shared Room Styles
   ========================= */

   .door {
    position: absolute;
    width: 30px;        /* adjust to match door size */
    height: 10px;       /* adjust to match door orientation */
    background-color: rgba(41, 14, 1, 0.3);  /* temporary visibility */
    outline: 1px solid rgb(114, 41, 7);                 /* temporary for positioning */
    cursor: pointer;
}

.room {
    position: absolute;

    /* invisible but interactive */
    background-color: rgba(255, 0, 0, 0.0);
}

/* Shared room tooltip */
.room[title]:hover::after {
    content: attr(title);
    position: absolute;
    top: -25px;
    left: 0;
    background: #222;
    color: #fff;
    padding: 3px 6px;
    border-radius: 3px;
    white-space: nowrap;
    z-index: 10;
}

.room-image-right {
    float: right;

    width: auto;
    height: auto;

    /* size limits */
    max-width: 400px;
    max-height: min(300px, 40vh);

    margin: 0.25rem 0 15px 15px;
    border: 2px solid #555;
    border-radius: 2px;
    display: block;
}

.room-image-left {
    float: left;

    width: auto;
    height: auto;

    /* size limits */
    max-width: 400px;
    max-height: min(300px, 40vh);

    margin: 0.25rem 0 15px 15px;
    border: 2px solid #555;
    border-radius: 2px;
    display: block;
}

/* =========================
   DEBUG: show map hotspots
   ========================= */

.debug .map-hotspot,
.debug .room,
.debug .door {
    outline: 2px dashed rgba(223, 194, 127, 0.9);
    background: rgba(223, 194, 127, 0.18);
}




/* ===============================
   Index / For images going into the next sections
   =============================== */
.index-page h2 {
    clear: both;
}

   .index-page h3 {
    clear: both;
}
