/* ============================================
   BLOODBORNE SERVER STATISTICS - GOTHIC THEME
   ============================================ */

@font-face {
    font-family: 'Fleshandblood';
    src: url('/static/fonts/Fleshandblood-MVA5x.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

:root {
    --bg-dark: #0a0a0f;
    --bg-surface: #141420;
    --bg-card: #1a1a2e;
    --border-blood: #2a1a1a;
    --border-subtle: #252535;
    --text-gold: #c8b88a;
    --text-muted: #8a8a7a;
    --text-dim: #5a5a50;
    --accent-red: #8b0000;
    --accent-bright-red: #cc3333;
    --highlight-gold: #d4a847;
    --highlight-bright: #e8c94a;
    --eval-plus: #5a9a4a;
    --eval-minus: #9a4a4a;
    --ghost-blue: #4a6a9a;
    --summon-gold: #b8962a;
    --lamp-warm: #c89a4a;
    --level-purple: #7a4a9a;
    --chalice-pthumeru: #4a6a8a;
    --chalice-hintertomb: #6a4a7a;
    --chalice-loran: #8a7a3a;
    --chalice-isz: #3a7a5a;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    font-size: 16px;
    scroll-behavior: smooth;
}

body {
    font-family: 'EB Garamond', 'Georgia', serif;
    background-color: var(--bg-dark);
    color: var(--text-gold);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    line-height: 1.5;
}

/* ============ HEADER ============ */

.site-header {
    background: linear-gradient(180deg, #12121e 0%, var(--bg-dark) 100%);
    border-bottom: 1px solid var(--border-blood);
    padding: 0 2rem;
    position: sticky;
    top: 0;
    z-index: 100;
}

.header-content {
    max-width: 1400px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 70px;
}

.logo {
    text-decoration: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
}

.logo-text {
    font-family: 'Fleshandblood', 'Cinzel', serif;
    font-weight: normal;
    font-size: 1.8rem;
    color: var(--highlight-gold);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    line-height: 1;
}

.logo-sub {
    font-family: 'Cinzel', serif;
    font-size: 0.65rem;
    color: var(--text-muted);
    letter-spacing: 0.25em;
    text-transform: uppercase;
}

.main-nav {
    display: flex;
    gap: 0.25rem;
}

.nav-link {
    font-family: 'Cinzel', serif;
    font-size: 0.85rem;
    color: var(--text-muted);
    text-decoration: none;
    padding: 0.5rem 1rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    border: 1px solid transparent;
    transition: all 0.2s ease;
}

.nav-link:hover {
    color: var(--text-gold);
    border-color: var(--border-blood);
}

.nav-link.active {
    color: var(--highlight-gold);
    border-color: var(--accent-red);
    background: rgba(139, 0, 0, 0.1);
}

/* ============ MAIN CONTENT ============ */

.main-content {
    flex: 1;
    max-width: 1400px;
    margin: 0 auto;
    padding: 2rem;
    width: 100%;
}

/* ============ HERO STATS ============ */

.hero-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.hero-stats.small {
    grid-template-columns: repeat(3, 1fr);
    margin-bottom: 2rem;
}

.stat-card {
    background: var(--bg-surface);
    border: 1px solid var(--border-blood);
    padding: 1.5rem;
    text-align: center;
    position: relative;
}

.stat-card.hero {
    padding: 2rem 1.5rem;
}

.stat-card.hero::before,
.stat-card.hero::after {
    content: '';
    position: absolute;
    width: 12px;
    height: 12px;
    border-color: var(--accent-red);
}

.stat-card.hero::before {
    top: -1px;
    left: -1px;
    border-top: 2px solid;
    border-left: 2px solid;
}

.stat-card.hero::after {
    bottom: -1px;
    right: -1px;
    border-bottom: 2px solid;
    border-right: 2px solid;
}

.stat-card.hero.inline {
    display: inline-flex;
    flex-direction: column;
    padding: 1rem 2rem;
}

.stat-icon {
    margin-bottom: 0.5rem;
    opacity: 0.7;
}

.stat-icon svg {
    width: 1.8rem;
    height: 3rem;
    fill: currentColor;
    filter: drop-shadow(0 0 2px currentColor);
}

.stat-value {
    font-family: 'Cinzel', serif;
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--highlight-gold);
    line-height: 1;
    margin-bottom: 0.25rem;
    transition: color 0.3s ease;
}

.stat-card.hero .stat-value {
    font-size: 3rem;
}

.stat-card.hero.inline .stat-value {
    font-size: 2.5rem;
}

.stat-value.updated {
    color: var(--highlight-bright);
}

.stat-label {
    font-family: 'Cinzel', serif;
    font-size: 0.75rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.15em;
}

/* ============ PAGE HEADER ============ */

.page-header {
    display: flex;
    align-items: center;
    gap: 2rem;
    margin-bottom: 2rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border-blood);
}

.page-title {
    font-family: 'Cinzel', serif;
    font-size: 1.8rem;
    font-weight: 600;
    color: var(--highlight-gold);
    letter-spacing: 0.1em;
}

/* ============ GRID LAYOUTS ============ */

.dashboard-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
}

.content-grid {
    display: grid;
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}

.content-grid.two-col {
    grid-template-columns: repeat(2, 1fr);
}

.content-grid.single {
    grid-template-columns: 1fr;
}

/* ============ CARDS ============ */

.card {
    background: var(--bg-surface);
    border: 1px solid var(--border-subtle);
    position: relative;
}

.card-title {
    font-family: 'Cinzel', serif;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text-gold);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--border-blood);
    background: rgba(42, 26, 26, 0.15);
}

.card-title-count {
    float: right;
    font-size: 0.75rem;
    color: var(--highlight-gold);
    font-weight: 400;
}

.card-body {
    padding: 1rem 1.25rem;
}

.card-body.scrollable {
    max-height: 400px;
    overflow-y: auto;
}

.card-body.scrollable.tall {
    max-height: 600px;
}

.card-body.scrollable::-webkit-scrollbar {
    width: 6px;
}

.card-body.scrollable::-webkit-scrollbar-track {
    background: var(--bg-dark);
}

.card-body.scrollable::-webkit-scrollbar-thumb {
    background: var(--border-blood);
}

/* ============ DATA LISTS ============ */

.data-list {
    list-style: none;
}

.data-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.6rem 0;
    border-bottom: 1px solid rgba(42, 26, 26, 0.3);
}

.data-item:last-child {
    border-bottom: none;
}

.data-item.empty {
    color: var(--text-dim);
    font-style: italic;
    justify-content: center;
    padding: 2rem 0;
}

.item-icon {
    width: 2rem;
    height: 2rem;
    text-align: center;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.item-icon svg {
    width: 1.2rem;
    height: 2rem;
    fill: currentColor;
    filter: drop-shadow(0 0 1px currentColor);
}

.item-icon.death { color: var(--accent-bright-red); }
.item-icon.message { color: var(--text-gold); }
.item-icon.lamp { color: var(--lamp-warm); }

.item-text {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.item-text strong {
    font-weight: 500;
    color: var(--text-gold);
    font-size: 0.95rem;
}

.item-text small {
    color: var(--text-muted);
    font-size: 0.8rem;
}

.item-count {
    font-family: 'Cinzel', serif;
    font-size: 0.85rem;
    color: var(--text-muted);
    flex-shrink: 0;
}

.item-count.death {
    color: var(--accent-bright-red);
}

.item-eval {
    display: flex;
    gap: 0.5rem;
    flex-shrink: 0;
}

.eval-plus {
    color: var(--eval-plus);
    font-weight: 600;
    font-size: 0.9rem;
}

.eval-minus {
    color: var(--eval-minus);
    font-weight: 600;
    font-size: 0.9rem;
}

/* ============ BAR CHARTS ============ */

.bar-chart {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.bar-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.bar-label {
    font-size: 0.85rem;
    color: var(--text-gold);
    width: 160px;
    flex-shrink: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.bar-track {
    flex: 1;
    height: 20px;
    background: rgba(20, 20, 32, 0.8);
    border: 1px solid var(--border-subtle);
    overflow: hidden;
}

.bar-fill {
    height: 100%;
    transition: width 0.5s ease;
    min-width: 2px;
}

.bar-fill.death { background: linear-gradient(90deg, var(--accent-red), var(--accent-bright-red)); }
.bar-fill.enemy { background: linear-gradient(90deg, #6a2020, #aa3333); }
.bar-fill.location { background: linear-gradient(90deg, #2a4a6a, #4a7aaa); }
.bar-fill.message { background: linear-gradient(90deg, #5a4a20, var(--highlight-gold)); }
.bar-fill.weapon { background: linear-gradient(90deg, #4a4a20, #8a8a40); }
.bar-fill.ghost { background: linear-gradient(90deg, #2a3a5a, var(--ghost-blue)); }
.bar-fill.summon { background: linear-gradient(90deg, #5a4a10, var(--summon-gold)); }
.bar-fill.level { background: linear-gradient(90deg, #3a2a5a, var(--level-purple)); }
.bar-fill.armor { background: linear-gradient(90deg, #3a3a4a, #6a6a8a); }
.bar-fill.gesture { background: linear-gradient(90deg, #2a4a3a, #4a8a6a); }

/* Leaderboard table */
.leaderboard-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.85rem;
}
.leaderboard-table thead th {
    text-align: left;
    padding: 0.5rem 0.75rem;
    border-bottom: 1px solid var(--border-blood);
    color: var(--text-gold);
    font-family: 'Cinzel', serif;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}
.leaderboard-table tbody tr {
    border-bottom: 1px solid rgba(100, 60, 40, 0.15);
}
.leaderboard-table tbody tr:hover {
    background: rgba(100, 60, 40, 0.1);
}
.leaderboard-table td {
    padding: 0.4rem 0.75rem;
}
.lb-rank {
    width: 3rem;
    color: var(--text-muted);
    font-size: 0.8rem;
    text-align: center !important;
}
.lb-name {
    white-space: nowrap;
}
.lb-count {
    width: 5rem;
    text-align: right !important;
    font-weight: 600;
    color: var(--text-gold);
}
.lb-bar {
    width: 40%;
}
.lb-bar .bar-track {
    height: 12px;
}

.bar-value {
    font-family: 'Cinzel', serif;
    font-size: 0.8rem;
    color: var(--text-muted);
    width: 40px;
    text-align: right;
    flex-shrink: 0;
}

/* ============ SEARCH FORM ============ */

.search-form {
    margin: 0;
}

.form-row {
    display: flex;
    gap: 0.75rem;
    align-items: center;
}

.search-input {
    flex: 1;
    background: var(--bg-dark);
    border: 1px solid var(--border-subtle);
    color: var(--text-gold);
    font-family: 'EB Garamond', serif;
    font-size: 1rem;
    padding: 0.6rem 1rem;
    outline: none;
    transition: border-color 0.2s;
}

.search-input:focus {
    border-color: var(--accent-red);
}

.search-input::placeholder {
    color: var(--text-dim);
}

.search-select {
    background: var(--bg-dark);
    border: 1px solid var(--border-subtle);
    color: var(--text-gold);
    font-family: 'EB Garamond', serif;
    font-size: 1rem;
    padding: 0.6rem 1rem;
    outline: none;
    cursor: pointer;
}

.search-select:focus {
    border-color: var(--accent-red);
}

.search-btn {
    background: var(--accent-red);
    border: 1px solid #5a1010;
    color: var(--text-gold);
    font-family: 'Cinzel', serif;
    font-size: 0.85rem;
    padding: 0.6rem 1.5rem;
    cursor: pointer;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    transition: background 0.2s;
}

.search-btn:hover {
    background: #a01010;
}

/* ============ DUNGEON GRID ============ */

.dungeon-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 1rem;
}

.dungeon-card {
    background: var(--bg-card);
    border: 1px solid var(--border-subtle);
    padding: 1rem;
    transition: border-color 0.2s;
}

.dungeon-card:hover {
    border-color: var(--text-muted);
}

.dungeon-glyph {
    font-family: 'Cinzel', serif;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--highlight-gold);
    letter-spacing: 0.2em;
    text-align: center;
    margin-bottom: 0.5rem;
    text-transform: lowercase;
}

.dungeon-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.15rem;
}

.dungeon-type {
    font-family: 'Cinzel', serif;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--text-muted);
}

.dungeon-name {
    font-size: 0.85rem;
    color: var(--text-gold);
}

.dungeon-depth {
    font-size: 0.75rem;
    color: var(--text-dim);
}

.dungeon-category {
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 0.1em 0.45em;
    border-radius: 3px;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: var(--text-muted);
}
.dungeon-category.category-farming { color: #7aba5e; border-color: rgba(122, 186, 94, 0.3); }
.dungeon-category.category-equipment { color: #5e9aba; border-color: rgba(94, 154, 186, 0.3); }
.dungeon-category.category-bloodgems { color: #ba5e7a; border-color: rgba(186, 94, 122, 0.3); }
.dungeon-category.category-testing { color: #baa05e; border-color: rgba(186, 160, 94, 0.3); }

.dungeon-desc {
    font-size: 0.7rem;
    color: var(--text-dim);
    line-height: 1.3;
    word-break: break-word;
}

/* Chalice type color borders */
.dungeon-card.chalice-border-pthumeru,
.dungeon-card.chalice-border-central-pthumeru,
.dungeon-card.chalice-border-lower-pthumeru { border-left: 3px solid var(--chalice-pthumeru); }
.dungeon-card.chalice-border-hintertomb,
.dungeon-card.chalice-border-lower-hintertomb { border-left: 3px solid var(--chalice-hintertomb); }
.dungeon-card.chalice-border-ailing-loran,
.dungeon-card.chalice-border-lower-loran,
.dungeon-card.chalice-border-loran { border-left: 3px solid var(--chalice-loran); }
.dungeon-card.chalice-border-isz { border-left: 3px solid var(--chalice-isz); }
.dungeon-card.chalice-border-defiled,
.dungeon-card.chalice-border-cursed-and-defiled { border-left: 3px solid var(--accent-bright-red); }

.chalice-type.chalice-pthumeru { color: var(--chalice-pthumeru); }
.chalice-type.chalice-hintertomb { color: var(--chalice-hintertomb); }
.chalice-type.chalice-loran,
.chalice-type.chalice-ailing-loran,
.chalice-type.chalice-lower-loran { color: var(--chalice-loran); }
.chalice-type.chalice-isz { color: var(--chalice-isz); }

.empty-text {
    color: var(--text-dim);
    font-style: italic;
    text-align: center;
    padding: 2rem 0;
}

/* Clickable dungeon cards */
.dungeon-card-link {
    text-decoration: none;
    color: inherit;
    display: block;
}

.dungeon-card-link .dungeon-card {
    cursor: pointer;
}

.dungeon-creator {
    font-size: 0.7rem;
    color: var(--text-dim);
}

/* ============ CHALICE DETAIL PAGE ============ */

.back-link {
    font-family: 'Cinzel', serif;
    font-size: 0.8rem;
    color: var(--text-muted);
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 0.4rem 0.8rem;
    border: 1px solid var(--border-subtle);
    transition: all 0.2s;
}

.back-link:hover {
    color: var(--text-gold);
    border-color: var(--border-blood);
}

/* Detail fields (label: value pairs) */
.detail-fields {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.detail-field {
    display: flex;
    align-items: baseline;
    gap: 1rem;
    padding: 0.3rem 0;
    border-bottom: 1px solid rgba(42, 26, 26, 0.2);
}

.detail-field:last-child {
    border-bottom: none;
}

.detail-label {
    font-family: 'Cinzel', serif;
    font-size: 0.75rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    width: 140px;
    flex-shrink: 0;
}

.detail-label.dim {
    color: var(--text-dim);
}

.detail-value {
    color: var(--text-gold);
    font-size: 0.95rem;
}

.detail-value.highlight {
    color: var(--highlight-gold);
    font-weight: 600;
}

.detail-value.dim {
    color: var(--text-dim);
    font-size: 0.85rem;
}

.formdata-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.5rem 2rem;
}

/* Rite badges */
.rite-badge {
    display: inline-block;
    font-family: 'Cinzel', serif;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 0.2rem 0.6rem;
    margin-right: 0.3rem;
    border: 1px solid;
}

.rite-badge.rite-fetid {
    color: #8a9a4a;
    border-color: #5a6a2a;
    background: rgba(90, 106, 42, 0.15);
}

.rite-badge.rite-rotted {
    color: #7a5a3a;
    border-color: #5a3a1a;
    background: rgba(90, 58, 26, 0.15);
}

.rite-badge.rite-cursed {
    color: var(--accent-bright-red);
    border-color: var(--accent-red);
    background: rgba(139, 0, 0, 0.15);
}

.rite-badge.rite-sinister {
    color: #8a5a9a;
    border-color: #5a3a6a;
    background: rgba(90, 58, 106, 0.15);
}

.rite-badge.rite-great-curse {
    color: #cc3333;
    border-color: #991111;
    background: rgba(153, 17, 17, 0.2);
}

/* Boss section */
.boss-type-label {
    color: var(--text-gold);
    margin-bottom: 1rem;
    font-size: 0.95rem;
}

.boss-note {
    color: var(--text-dim);
    font-size: 0.85rem;
    font-style: italic;
    margin-bottom: 1rem;
}

.boss-layer-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.boss-layer {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.6rem 0.8rem;
    background: rgba(20, 20, 32, 0.5);
    border-left: 3px solid var(--accent-red);
}

.boss-layer-num {
    font-family: 'Cinzel', serif;
    font-size: 0.75rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    width: 70px;
    flex-shrink: 0;
}

.boss-layer-name {
    color: var(--highlight-gold);
    font-weight: 500;
    font-size: 1.05rem;
}

.boss-pool-header {
    color: var(--text-gold);
    font-size: 0.9rem;
    margin-bottom: 0.75rem;
}

.boss-pool-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.boss-pool-item {
    display: inline-block;
    padding: 0.3rem 0.8rem;
    background: rgba(20, 20, 32, 0.5);
    border: 1px solid var(--border-subtle);
    color: var(--text-gold);
    font-size: 0.9rem;
}

.boss-rite-effects {
    margin-top: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-blood);
}

.boss-rite-header {
    font-family: 'Cinzel', serif;
    font-size: 0.8rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 0.5rem;
}

.boss-rite-entry {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.5rem;
    font-size: 0.9rem;
    color: var(--text-gold);
}

/* Lottery table entries */
.subsection-title {
    font-family: 'Cinzel', serif;
    font-size: 0.8rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin: 1rem 0 0.5rem 0;
    padding-bottom: 0.3rem;
    border-bottom: 1px solid var(--border-blood);
}

.subsection-title:first-child {
    margin-top: 0;
}

.lot-group {
    margin-bottom: 1rem;
}

.lot-header {
    font-size: 0.85rem;
    color: var(--text-muted);
    margin-bottom: 0.4rem;
}

.lot-name {
    color: var(--text-gold);
}

.feature-entry {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.2rem 0;
    font-size: 0.85rem;
}

.feature-bar-track {
    width: 60px;
    height: 10px;
    background: rgba(20, 20, 32, 0.8);
    border: 1px solid var(--border-subtle);
    flex-shrink: 0;
    overflow: hidden;
}

.feature-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--chalice-pthumeru), #6a8aaa);
    min-width: 1px;
}

.feature-pct {
    font-family: 'Cinzel', serif;
    font-size: 0.75rem;
    color: var(--text-dim);
    width: 42px;
    text-align: right;
    flex-shrink: 0;
}

.feature-id {
    font-family: monospace;
    font-size: 0.75rem;
    color: var(--chalice-pthumeru);
    width: 28px;
    flex-shrink: 0;
}

.feature-name {
    color: var(--text-gold);
    font-size: 0.85rem;
}

/* Ritual slot entries */
.ritual-slot-entry {
    padding: 0.6rem 0;
    border-bottom: 1px solid rgba(42, 26, 26, 0.2);
}

.ritual-slot-entry:last-child {
    border-bottom: none;
}

.ritual-slot-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.2rem;
}

.ritual-slot-num {
    font-family: 'Cinzel', serif;
    font-size: 0.7rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.ritual-slot-name {
    color: var(--highlight-gold);
    font-weight: 500;
}

.ritual-slot-desc {
    font-size: 0.85rem;
    color: var(--text-dim);
    font-style: italic;
    margin-left: 0.5rem;
}

.ritual-slot-gem {
    font-size: 0.8rem;
    color: var(--chalice-pthumeru);
    margin-left: 0.5rem;
    margin-top: 0.15rem;
}

/* Feature tag badges bar */
.feature-tags-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1.5rem;
    justify-content: center;
}

.feature-tag {
    display: inline-block;
    font-family: 'Cinzel', serif;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 0.35rem 0.9rem;
    border: 1px solid;
}

.feature-tag.tag-shop {
    color: var(--summon-gold);
    border-color: #5a4a10;
    background: rgba(184, 150, 42, 0.12);
}

.feature-tag.tag-rare-shop {
    color: var(--highlight-gold);
    border-color: #6a5a20;
    background: rgba(212, 168, 71, 0.15);
}

.feature-tag.tag-npc {
    color: #cc6633;
    border-color: #6a3311;
    background: rgba(204, 102, 51, 0.12);
}

.feature-tag.tag-unique {
    color: #9a8aff;
    border-color: #4a3a8a;
    background: rgba(154, 138, 255, 0.1);
}

.feature-tag.tag-poison {
    color: #6aaa3a;
    border-color: #3a5a1a;
    background: rgba(106, 170, 58, 0.1);
}

.feature-tag.tag-curse {
    color: var(--accent-bright-red);
    border-color: var(--accent-red);
    background: rgba(139, 0, 0, 0.12);
}

.feature-tag.tag-sinister {
    color: #8a5a9a;
    border-color: #5a3a6a;
    background: rgba(138, 90, 154, 0.1);
}

.feature-tag.tag-unlock {
    color: var(--ghost-blue);
    border-color: #2a3a5a;
    background: rgba(74, 106, 154, 0.1);
}

/* Ritual cost card */
.ritual-cost-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: baseline;
}

.ritual-cost-echoes {
    display: inline-flex;
    align-items: baseline;
    gap: 0.4rem;
    margin-right: 0.25rem;
}

.cost-echo-value {
    font-family: 'Cinzel', serif;
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--highlight-gold);
    line-height: 1;
}

.cost-echo-label {
    font-family: 'Cinzel', serif;
    font-size: 0.7rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.ritual-cost-sep {
    color: var(--text-dim);
    font-size: 0.8rem;
    margin: 0 0.1rem;
}

.ritual-cost-item {
    display: inline-flex;
    align-items: baseline;
    gap: 0.3rem;
    padding: 0.2rem 0.5rem;
    background: rgba(20, 20, 32, 0.4);
    border: 1px solid var(--border-subtle);
    font-size: 0.85rem;
    white-space: nowrap;
}

.ritual-cost-item.ritual-cost-chalice {
    border-color: var(--border-blood);
}

.cost-item-qty {
    font-family: 'Cinzel', serif;
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--highlight-gold);
}

.cost-item-name {
    color: var(--text-gold);
    font-size: 0.85rem;
}

.cost-item-label {
    font-family: 'Cinzel', serif;
    font-size: 0.6rem;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-left: 0.15rem;
}

/* Enemy roster */
.enemy-roster-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 0.4rem;
}

.enemy-roster-entry {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.4rem 0.6rem;
    background: rgba(20, 20, 32, 0.3);
    border-left: 2px solid var(--border-subtle);
}

.enemy-count {
    font-family: 'Cinzel', serif;
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--highlight-gold);
    min-width: 2rem;
    text-align: right;
}

.enemy-name {
    color: var(--text-gold);
    font-size: 0.9rem;
    flex: 1;
}

/* Lottery winning highlight */
.feature-entry.feature-won {
    background: rgba(212, 168, 71, 0.08);
    border-left: 2px solid var(--highlight-gold);
    padding-left: 0.3rem;
    margin-left: -0.5rem;
}

.feature-bar-fill.won {
    background: linear-gradient(90deg, var(--highlight-gold), #e8c94a);
}

.feature-won-marker {
    color: var(--highlight-gold);
    font-size: 0.85rem;
    font-weight: 700;
    margin-left: 0.3rem;
}

/* Loot lists */
.loot-list {
    list-style: none;
    padding: 0;
    margin: 0 0 0.5rem 0;
}

.loot-list li {
    padding: 0.25rem 0 0.25rem 1rem;
    color: var(--text-gold);
    font-size: 0.9rem;
    position: relative;
}

.loot-list li::before {
    content: "\2022";
    color: var(--text-dim);
    position: absolute;
    left: 0;
}

/* Rite detail entries */
.rite-detail-entry {
    padding: 0.75rem 0;
    border-bottom: 1px solid rgba(42, 26, 26, 0.2);
}

.rite-detail-entry:last-child {
    border-bottom: none;
}

.rite-effect-text {
    color: var(--text-gold);
    font-size: 0.9rem;
    margin-top: 0.4rem;
    margin-left: 0.5rem;
}

/* ============ GENERATOR PAGE ============ */

.generator-description {
    color: var(--text-muted);
    font-size: 0.95rem;
    margin-bottom: 1.5rem;
    max-width: 700px;
}

.generator-form {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.generator-label {
    font-family: 'Cinzel', serif;
    font-size: 0.8rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.generator-select {
    width: 100%;
    max-width: 500px;
}

/* Rite offerings row */
.rite-row {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

.rite-option {
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

.rite-option.locked {
    opacity: 0.7;
    cursor: not-allowed;
}

.rite-cb {
    accent-color: var(--highlight-gold);
    width: 16px;
    height: 16px;
    cursor: pointer;
}

.rite-option.locked .rite-cb {
    cursor: not-allowed;
}

.rite-option .rite-badge {
    cursor: inherit;
    user-select: none;
}

/* Boss selection */
.boss-dropdown-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1rem;
}

.boss-dropdown-row {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.boss-dropdown-row .generator-select {
    max-width: none;
}

.boss-info {
    margin-top: 0.75rem;
}

.boss-match-info {
    font-size: 0.85rem;
    color: var(--text-muted);
    font-style: italic;
}

.boss-match-info.boss-no-match {
    color: var(--accent-bright-red);
}

.feature-categories {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 1.25rem;
}

.feature-category {
    background: rgba(20, 20, 32, 0.4);
    border: 1px solid var(--border-subtle);
    padding: 0.75rem 1rem;
}

.feature-category-title {
    font-family: 'Cinzel', serif;
    font-size: 0.75rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: 0.6rem;
    padding-bottom: 0.4rem;
    border-bottom: 1px solid var(--border-blood);
}

.feature-checkbox-grid {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.feature-checkbox {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.35rem 0.5rem;
    cursor: pointer;
    transition: background 0.15s;
    border-left: 2px solid transparent;
}

.feature-checkbox:hover {
    background: rgba(200, 184, 138, 0.05);
}

.feature-checkbox.disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

.feature-cb {
    accent-color: var(--highlight-gold);
    width: 16px;
    height: 16px;
    cursor: pointer;
    flex-shrink: 0;
}

.feature-cb:checked + .feature-cb-label {
    color: var(--highlight-gold);
}

.feature-checkbox:has(.feature-cb:checked) {
    border-left-color: var(--highlight-gold);
    background: rgba(212, 168, 71, 0.06);
}

.feature-cb-label {
    color: var(--text-gold);
    font-size: 0.9rem;
    flex: 1;
}

.feature-cb-id {
    font-family: monospace;
    font-size: 0.7rem;
    color: var(--text-dim);
    flex-shrink: 0;
}

/* False depth section */
.false-depth-section {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-blood);
}

.false-depth-toggle {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
}

.false-depth-cb {
    accent-color: #cc6633;
    width: 16px;
    height: 16px;
    cursor: pointer;
}

.false-depth-label {
    font-family: 'Cinzel', serif;
    font-size: 0.8rem;
    color: #cc6633;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.anomaly-warning {
    margin-top: 0.5rem;
    padding: 0.5rem 0.75rem;
    font-size: 0.75rem;
    color: #ff4444;
    border: 1px solid rgba(255, 68, 68, 0.3);
    border-radius: 4px;
    background: rgba(255, 68, 68, 0.08);
}

#variant-select-row {
    margin-top: 0.75rem;
}

.generator-btn {
    font-size: 1rem;
    padding: 0.8rem 2.5rem;
    letter-spacing: 0.15em;
}

.generator-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.generator-error {
    color: var(--accent-bright-red);
    margin-top: 1rem;
    font-size: 0.9rem;
}

.glyph-result {
    font-family: 'Cinzel', serif;
    font-size: 3rem;
    font-weight: 700;
    color: var(--highlight-gold);
    letter-spacing: 0.3em;
    text-transform: lowercase;
    margin-bottom: 0.25rem;
    text-shadow: 0 0 20px rgba(212, 168, 71, 0.3);
}

.glyph-result-label {
    font-family: 'Cinzel', serif;
    font-size: 0.75rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.2em;
}

/* Item Pool Section */
.item-pool-desc {
    color: var(--text-muted);
    font-size: 0.85rem;
    margin-bottom: 1rem;
}

.item-pool-grid {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.item-pool-category-title {
    font-family: 'Cinzel', serif;
    font-size: 0.8rem;
    color: var(--highlight-gold);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 0.5rem;
}

.item-pool-items {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.item-pool-badge {
    background: rgba(26, 26, 46, 0.6);
    border: 1px solid var(--border-subtle);
    color: var(--text-muted);
    padding: 0.2rem 0.6rem;
    border-radius: 3px;
    font-size: 0.8rem;
}

.item-pool-badge.special {
    border-color: var(--highlight-gold);
    color: var(--highlight-gold);
}

/* ============ FOOTER ============ */

.site-footer {
    border-top: 1px solid var(--border-blood);
    padding: 1rem 2rem;
    text-align: center;
}

.footer-content {
    max-width: 1400px;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.75rem;
}

.footer-text {
    font-size: 0.8rem;
    color: var(--text-dim);
}

.footer-sep {
    color: var(--border-blood);
}

#ws-status {
    font-size: 0.75rem;
}

#ws-status.connected {
    color: var(--eval-plus);
}

#ws-status.disconnected {
    color: var(--accent-bright-red);
}

/* ============ ANOMALY DETECTION ============ */

.anomaly-text {
    color: #cc6633 !important;
}

.anomaly-stat-link {
    text-decoration: none;
    border: 1px solid rgba(204, 102, 51, 0.3);
    transition: border-color 0.2s ease;
}

.anomaly-stat-link:hover {
    border-color: rgba(204, 102, 51, 0.6);
}

.generator-link {
    text-decoration: none;
    border: 1px solid rgba(180, 160, 120, 0.3);
    transition: border-color 0.2s ease;
}

.generator-link:hover {
    border-color: rgba(180, 160, 120, 0.6);
}

.generator-link .stat-value {
    font-size: 1.6rem;
}

.hero-stats-inline {
    display: flex;
    gap: 1.5rem;
    align-items: center;
}

/* Anomaly badge on listing cards */
.anomaly-badge {
    display: inline-block;
    color: #cc6633;
    font-size: 0.85em;
    margin-left: 0.3em;
    vertical-align: middle;
}

.anomaly-card {
    border-color: rgba(204, 102, 51, 0.4) !important;
    box-shadow: inset 0 0 8px rgba(204, 102, 51, 0.08);
}

/* Anomaly filter button */
.anomaly-filter-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.3em;
    padding: 0.5rem 1rem;
    border: 1px solid var(--border-subtle);
    background: var(--bg-card);
    color: var(--text-muted);
    font-family: 'EB Garamond', 'Georgia', serif;
    font-size: 0.95rem;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.2s ease;
    white-space: nowrap;
}

.anomaly-filter-btn:hover {
    color: #cc6633;
    border-color: rgba(204, 102, 51, 0.4);
}

.anomaly-filter-btn.active {
    color: #cc6633;
    border-color: #cc6633;
    background: rgba(204, 102, 51, 0.1);
}

.anomaly-filter-active {
    color: #cc6633;
    font-size: 0.85em;
}

/* Anomaly section on detail page */
.anomaly-section {
    border-color: rgba(204, 102, 51, 0.5) !important;
    background: linear-gradient(135deg, rgba(204, 102, 51, 0.06) 0%, var(--bg-card) 100%);
}

.anomaly-title {
    color: #cc6633;
}

.anomaly-intro {
    margin-bottom: 0.5rem;
    color: var(--text-gold);
    font-size: 0.95rem;
}

.anomaly-warning-text {
    margin-bottom: 1rem;
    padding: 0.5rem 0.75rem;
    font-size: 0.8rem;
    color: #ff4444;
    border: 1px solid rgba(255, 68, 68, 0.3);
    border-radius: 4px;
    background: rgba(255, 68, 68, 0.08);
}

.anomaly-flags {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.anomaly-flag {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    padding: 0.75rem 1rem;
    border-left: 3px solid #cc6633;
    background: rgba(204, 102, 51, 0.05);
}

.anomaly-flag-label {
    font-weight: bold;
    color: #cc6633;
    font-size: 0.95rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.anomaly-flag-detail {
    color: var(--text-muted);
    font-size: 0.9rem;
}

/* Specific flag color variants */
.anomaly-flag-cross_type {
    border-left-color: #cc3333;
}

.anomaly-flag-cross_type .anomaly-flag-label {
    color: #cc3333;
}

.anomaly-flag-unknown_config {
    border-left-color: #9933cc;
}

.anomaly-flag-unknown_config .anomaly-flag-label {
    color: #9933cc;
}

.anomaly-flag-unknown_tile {
    border-left-color: #9933cc;
}

.anomaly-flag-unknown_tile .anomaly-flag-label {
    color: #9933cc;
}

/* ============ MAP VIEWER ============ */

.map-viewer-card {
    overflow: visible;
}

.map-controls {
    float: right;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 400;
}

.map-layer-label {
    font-size: 0.8rem;
    color: var(--text-gold);
    min-width: 60px;
    text-align: center;
}

.map-layer-btn {
    background: transparent;
    border: 1px solid var(--border-subtle);
    color: var(--text-muted);
    padding: 0.15rem 0.5rem;
    cursor: pointer;
    font-family: 'Cinzel', serif;
    font-size: 0.8rem;
    transition: all 0.2s;
}

.map-layer-btn:hover:not(:disabled) {
    color: var(--highlight-gold);
    border-color: var(--highlight-gold);
}

.map-layer-btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

.map-viewer-body {
    display: flex;
    gap: 1rem;
    padding: 1rem 1.25rem;
}

.map-floor-buttons {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    flex-shrink: 0;
}

.map-floor-btn {
    background: var(--bg-card);
    border: 1px solid var(--border-subtle);
    color: var(--text-dim);
    padding: 0.6rem 0.8rem;
    font-family: 'Cinzel', serif;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    cursor: pointer;
    transition: all 0.2s;
    white-space: nowrap;
}

.map-floor-btn:hover {
    color: var(--text-gold);
    border-color: var(--border-blood);
}

.map-floor-btn.active {
    border-color: var(--highlight-gold);
    color: var(--highlight-gold);
    background: rgba(212, 168, 71, 0.08);
}

.map-svg-container {
    flex: 1;
    background: #0d0d15;
    border: 1px solid var(--border-subtle);
    min-height: 500px;
    position: relative;
    overflow: hidden;
}

.map-svg-container svg {
    width: 100%;
    height: 100%;
    display: block;
}

.map-loading {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: var(--text-dim);
    font-style: italic;
    font-size: 0.9rem;
}

/* ============ MAP LEGEND ============ */

.map-legend {
    margin-top: 0.75rem;
    border-top: 1px solid var(--border-subtle);
    padding-top: 0.5rem;
}

.map-legend details {
    margin: 0;
}

.map-legend-toggle {
    cursor: pointer;
    font-family: 'Cinzel', serif;
    font-size: 0.8rem;
    color: var(--text-muted);
    letter-spacing: 0.05em;
    padding: 0.3rem 0;
    user-select: none;
    list-style: none;
}

.map-legend-toggle::-webkit-details-marker {
    display: none;
}

.map-legend-toggle::before {
    content: '\25B6';
    display: inline-block;
    margin-right: 0.5rem;
    font-size: 0.6rem;
    transition: transform 0.2s ease;
    color: var(--text-dim);
}

details[open] > .map-legend-toggle::before {
    transform: rotate(90deg);
}

.map-legend-toggle:hover {
    color: var(--text-gold);
}

.map-legend-content {
    padding: 0.75rem 0 0.25rem;
}

.map-legend-svg-container {
    width: 100%;
    height: 420px;
    position: relative;
    background: #3a4555;
    border: 1px solid var(--border-subtle);
    border-radius: 6px;
    overflow: hidden;
}

.map-legend-svg-container svg {
    width: 100%;
    height: 100%;
}

/* ============ DIFFICULTY SCALING ============ */

.scaling-table {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-bottom: 0.75rem;
}

.scaling-header {
    display: grid;
    grid-template-columns: 140px repeat(4, 1fr);
    gap: 0;
    padding: 0.4rem 0.6rem;
    border-bottom: 1px solid var(--border-blood);
}

.scaling-header .scaling-col {
    font-family: 'Cinzel', serif;
    font-size: 0.7rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-align: center;
}

.scaling-header .scaling-col-label {
    font-size: 0.7rem;
}

.scaling-row {
    display: grid;
    grid-template-columns: 140px repeat(4, 1fr);
    gap: 0;
    padding: 0.35rem 0.6rem;
    border-bottom: 1px solid rgba(42, 26, 26, 0.15);
}

.scaling-row:last-child {
    border-bottom: none;
}

.scaling-row-highlight {
    background: rgba(212, 168, 71, 0.06);
}

.scaling-col-label {
    font-family: 'Cinzel', serif;
    font-size: 0.75rem;
    color: var(--text-muted);
    letter-spacing: 0.05em;
}

.scaling-col {
    text-align: center;
    color: var(--text-gold);
    font-size: 0.9rem;
}

.scaling-note {
    padding: 0.5rem 0.75rem;
    margin-top: 0.5rem;
    font-size: 0.9rem;
    color: var(--text-gold);
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.scaling-note.discovery-note {
    margin-top: 0.75rem;
    padding: 0.6rem 0.8rem;
    background: rgba(139, 0, 0, 0.08);
    border: 1px solid rgba(139, 0, 0, 0.2);
    display: block;
}

.scaling-formula {
    display: block;
    font-size: 0.8rem;
    color: var(--text-dim);
    font-style: italic;
    margin-top: 0.25rem;
}

/* ============ ABOUT PAGE ============ */

.about-text {
    color: var(--text-gold);
    font-size: 1.05rem;
    line-height: 1.7;
    margin-bottom: 0.75rem;
}

.about-text:last-child {
    margin-bottom: 0;
}

.about-text.about-note {
    color: var(--text-muted);
    font-style: italic;
    font-size: 0.95rem;
    margin-top: 1rem;
    margin-bottom: 0;
}

.about-link {
    color: var(--highlight-gold);
    text-decoration: none;
    border-bottom: 1px solid rgba(212, 168, 71, 0.3);
    transition: border-color 0.2s;
}

.about-link:hover {
    border-bottom-color: var(--highlight-gold);
}

.about-features {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.about-features li {
    padding: 0.5rem 0 0.5rem 1.25rem;
    color: var(--text-gold);
    font-size: 1rem;
    line-height: 1.6;
    position: relative;
    border-bottom: 1px solid rgba(42, 26, 26, 0.2);
}

.about-features li:last-child {
    border-bottom: none;
}

.about-features li::before {
    content: "\2022";
    color: var(--accent-bright-red);
    position: absolute;
    left: 0;
    font-size: 1.2rem;
}

.about-features li strong {
    color: var(--highlight-gold);
    font-family: 'Cinzel', serif;
    font-size: 0.9rem;
    letter-spacing: 0.05em;
}

.about-credits {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
}

.about-credit {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    padding: 0.6rem 0.8rem;
    border-left: 3px solid var(--accent-red);
    background: rgba(20, 20, 32, 0.4);
}

.about-credit strong {
    color: var(--highlight-gold);
    font-family: 'Cinzel', serif;
    font-size: 0.9rem;
    letter-spacing: 0.05em;
}

.about-credit span {
    color: var(--text-muted);
    font-size: 0.95rem;
    line-height: 1.5;
}

.about-hosted {
    padding-top: 1rem;
    border-top: 1px solid var(--border-blood);
    color: var(--text-muted);
    font-size: 0.95rem;
}

.about-hosted strong {
    color: var(--text-gold);
}

/* ============ RESPONSIVE ============ */

@media (max-width: 1024px) {
    .hero-stats {
        grid-template-columns: repeat(2, 1fr);
    }

    .dashboard-grid,
    .content-grid.two-col {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .header-content {
        flex-direction: column;
        height: auto;
        padding: 1rem 0;
        gap: 0.75rem;
    }

    .main-nav {
        flex-wrap: wrap;
        justify-content: center;
    }

    .nav-link {
        font-size: 0.75rem;
        padding: 0.4rem 0.6rem;
    }

    .main-content {
        padding: 1rem;
    }

    .hero-stats {
        grid-template-columns: repeat(2, 1fr);
        gap: 0.75rem;
    }

    .stat-card.hero .stat-value {
        font-size: 2rem;
    }

    .page-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 1rem;
    }

    .bar-label {
        width: 100px;
        font-size: 0.75rem;
    }

    .form-row {
        flex-direction: column;
    }

    .search-input,
    .search-select,
    .search-btn {
        width: 100%;
    }

    .dungeon-grid {
        grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    }

    .formdata-grid {
        grid-template-columns: 1fr;
    }

    .map-viewer-body {
        flex-direction: column;
    }

    .map-floor-buttons {
        flex-direction: row;
        justify-content: center;
    }

    .map-svg-container {
        min-height: 350px;
    }

    .scaling-header,
    .scaling-row {
        grid-template-columns: 100px repeat(4, 1fr);
    }

    .scaling-header .scaling-col {
        font-size: 0.6rem;
    }

    .detail-label {
        width: 110px;
    }

    .feature-categories {
        grid-template-columns: 1fr;
    }

    .glyph-result {
        font-size: 2rem;
    }
}

@media (max-width: 480px) {
    .hero-stats {
        grid-template-columns: 1fr;
    }

    .hero-stats.small {
        grid-template-columns: 1fr;
    }

    .logo-text {
        font-size: 1.2rem;
    }
}
