/* ============================================
   WARCRAFT TOOLS - GLOBAL STYLES
   ============================================ */

/* --------------------------------------------
   Accessibility - Skip to Content
   -------------------------------------------- */
.skip-to-content {
    position: absolute;
    left: -9999px;
    top: 0;
    background: var(--color-primary, #27aae2);
    color: #000;
    padding: 12px 20px;
    text-decoration: none;
    font-weight: 600;
    z-index: 9999;
    border-radius: 0 0 6px 0;
}
.skip-to-content:focus {
    left: 0;
}
#main-content {
    outline: none;
}

/* --------------------------------------------
   CSS Variables
   -------------------------------------------- */
:root {
    /* Colors - Primary */
    --color-bg: #050709;
    --color-bg-panel: rgba(8, 12, 20, 0.92);
    --color-bg-dark: rgba(5, 9, 16, 0.9);
    --color-bg-input: rgba(18, 24, 38, 0.9);
    --color-bg-hover: rgba(255, 255, 255, 0.06);
    
    /* Colors - Borders */
    --color-border: rgba(99, 179, 237, 0.2);
    --color-border-light: rgba(255, 255, 255, 0.06);
    --color-border-input: rgba(255, 255, 255, 0.18);
    
    /* Colors - Accent */
    --color-primary: #27aae2;
    --color-primary-hover: #3bb8ed;
    --color-success: #80c342;
    --color-error: #ef4444;
    --color-warning: #f59e0b;
    --color-gold: #ffd700;
    --color-wow-gold: #FFD100;
    
    /* Colors - Text */
    --color-text: #e5e7eb;
    --color-text-light: #e2e8f0;
    --color-text-muted: #94a3b8;
    --color-text-dark: #64748b;
    
    /* Colors - Item Quality */
    --quality-poor: #9d9d9d;
    --quality-common: #ffffff;
    --quality-uncommon: #1eff00;
    --quality-rare: #0070dd;
    --quality-epic: #a335ee;
    --quality-legendary: #ff8000;
    --quality-artifact: #e6cc80;
    --quality-heirloom: #00ccff;
    
    /* Colors - WoW Classes */
    --class-death-knight: #C41E3A;
    --class-demon-hunter: #A330C9;
    --class-druid: #FF7C0A;
    --class-evoker: #33937F;
    --class-hunter: #AAD372;
    --class-mage: #3FC7EB;
    --class-monk: #00FF98;
    --class-paladin: #F48CBA;
    --class-priest: #FFFFFF;
    --class-rogue: #FFF468;
    --class-shaman: #0070DD;
    --class-warlock: #8788EE;
    --class-warrior: #C69B6D;
    
    /* Colors - Gender */
    --color-male: #3ba6ff;
    --color-female: #ff73c5;
    
    /* Colors - Price */
    --price-gold: #ffd700;
    --price-silver: #c0c0c0;
    --price-copper: #b87333;
    
    /* Spacing */
    --spacing-xs: 4px;
    --spacing-sm: 8px;
    --spacing-md: 16px;
    --spacing-lg: 24px;
    --spacing-xl: 32px;
    
    /* Border Radius */
    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 12px;
    --radius-full: 999px;
    
    /* Transitions */
    --transition-fast: 0.15s ease;
    --transition-normal: 0.2s ease;
    --transition-slow: 0.3s ease;
}

/* --------------------------------------------
   Accessibility - Keyboard Focus Indicators
   -------------------------------------------- */
/* Keyboard focus indicators - visible only when using keyboard (not mouse) */
*:focus-visible {
    outline: 2px solid var(--color-primary, #27aae2);
    outline-offset: 2px;
    border-radius: 2px;
}

/* Override for elements that need a custom focus treatment */
.btn:focus-visible,
a.btn:focus-visible {
    outline: 2px solid var(--color-primary, #27aae2);
    outline-offset: 3px;
}

/* Remove the default browser focus outline only when we're providing our own */
*:focus:not(:focus-visible) {
    outline: none;
}

/* --------------------------------------------
   Reset & Base
   -------------------------------------------- */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    background: var(--color-bg);
    color: var(--color-text);
    line-height: 1.5;
    margin: 8px;
    min-height: calc(100vh - 16px);
    display: flex;
    flex-direction: column;
}

body.hub {
    margin: 0;
    min-height: 100vh;
}

a {
    color: var(--color-primary);
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

/* --------------------------------------------
   Layout - Container
   -------------------------------------------- */
.container {
    max-width: 1440px;
    width: 100%;
    margin: 0 auto;
    padding: 20px;
}

.hub .container {
    max-width: 900px;
    padding: 0 24px 60px;
}

/* --------------------------------------------
   Shared Components - Panels
   -------------------------------------------- */
.panel {
    background: var(--color-bg-panel);
    border-radius: var(--radius-lg);
    padding: 20px;
    margin-bottom: 20px;
    border: 1px solid var(--color-border);
}

.panel h2 {
    font-size: 1.25rem;
    font-weight: bold;
    margin: 0;
    word-wrap: break-word;
}

.panel-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 5px;
    padding-bottom: 1rem;
}

.card {
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    padding: 20px;
    margin-bottom: 20px;
}

/* --------------------------------------------
   Shared Components - Buttons
   -------------------------------------------- */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    padding: 9px 18px;
    border-radius: var(--radius-full);
    font-size: 0.95rem;
    font-weight: bold;
    line-height: 1;
    text-decoration: none;
    border: none;
    cursor: pointer;
    background: #15171e;
    color: #fff;
    transition: all var(--transition-fast);
}

.btn img {
    width: 16px;
    height: 16px;
}

.btn:hover,
.btn:focus {
    box-shadow: inset 0 0 0 2px var(--color-primary);
    text-decoration: none;
}

.btn:hover svg,
.btn:focus svg {
    stroke: var(--color-primary);
}

.btn:active {
    transform: translateY(1px);
}

.btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.btn:disabled:hover {
    box-shadow: none;
}

.btn:disabled:hover svg {
    stroke: currentColor;
}

.btn-secondary {
    background: rgba(255,255,255,0.08);
}

.btn-tertiary {
    background: transparent;
    border: 1px solid rgba(255,255,255,0.3);
}

.btn-spinner {
    display: none;
    width: 16px;
    height: 16px;
    border: 2px solid transparent;
    border-top-color: currentColor;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

.btn.loading .btn-text {
    display: none;
}

.btn.loading .btn-spinner {
    display: block;
}

/* --------------------------------------------
   Shared Components - Forms
   -------------------------------------------- */
label {
    display: block;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-muted);
    margin-bottom: 6px;
    font-weight: 500;
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
select,
textarea {
    width: 100%;
    padding: 6px 10px;
    min-height: 36px;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border-input);
    background: var(--color-bg-input);
    color: #fff;
    outline: none;
    font-size: 0.9rem;
    font-family: inherit;
    box-sizing: border-box;
    transition: border-color var(--transition-normal), box-shadow var(--transition-normal);
}

textarea {
    min-height: 150px;
    resize: vertical;
    padding: 10px 12px;
}

input:focus,
select:focus,
textarea:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(39, 170, 226, 0.15);
}

.toggle {
    display: flex;
    gap: 12px;
    margin-top: 8px;
}

.toggle div {
    display: flex;
    align-items: center;
}

.toggle input[type="radio"] {
    margin-right: 4px;
    accent-color: var(--color-primary);
}

.toggle label {
    margin-bottom: 0;
    padding-left: 2px;
    cursor: pointer;
}

/* --------------------------------------------
   Shared Components - Progress Bar
   -------------------------------------------- */
.progress-bar {
    width: 100%;
    height: 6px;
    border-radius: var(--radius-full);
    background: rgba(255,255,255,0.1);
    overflow: hidden;
}

.progress-bar .bar-fill {
    height: 100%;
    width: 0;
    background: linear-gradient(90deg, var(--color-primary), #7c3aed, var(--color-primary));
    transition: width 0.25s ease;
}

.progress-text {
    font-size: 0.85rem;
    margin-top: 6px;
    color: var(--color-text-muted);
}

.progress-container {
    margin-top: 20px;
    padding: 16px;
    border-radius: 10px;
    background: rgba(255,255,255,0.02);
    border: 1px solid var(--color-border-light);
}

/* --------------------------------------------
   Shared Components - Spinner
   -------------------------------------------- */
.spinner {
    width: 16px;
    height: 16px;
    min-width: 16px;
    min-height: 16px;
    border-radius: 50%;
    border: 2px solid rgba(255,255,255,0.2);
    border-top-color: var(--color-primary);
    animation: spin 1s linear infinite;
    display: inline-block;
    vertical-align: middle;
    margin-right: 8px;
    flex-shrink: 0;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* --------------------------------------------
   Shared Components - Badges
   -------------------------------------------- */
.badge {
    display: inline-block;
    padding: 5px 10px;
    border-radius: var(--radius-full);
    font-size: 0.7rem;
    font-weight: 600;
}

.badge.ok, .badge.success {
    background: rgba(34,197,94,0.15);
    color: #86efac;
    border: 1px solid rgba(34,197,94,0.35);
}

.badge.bad, .badge.error {
    background: rgba(239,68,68,0.15);
    color: #fca5a5;
    border: 1px solid rgba(239,68,68,0.35);
}

.badge-beta {
    background: rgba(251,191,36,0.15);
    color: #fcd34d;
    border: 1px solid rgba(251,191,36,0.35);
    text-transform: uppercase;
    padding: 3px 8px;
    margin-left: 10px;
    vertical-align: middle;
    letter-spacing: 0.1em;
}

/* --------------------------------------------
   Shared Components - Tables
   -------------------------------------------- */
table {
    width: 100%;
    border-collapse: collapse;
}

th, td {
    text-align: left;
    padding: 10px 8px;
    font-size: 0.85rem;
    border-bottom: 1px solid var(--color-border-light);
}

th {
    color: var(--color-text-muted);
    font-weight: 500;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* --------------------------------------------
   Shared Components - Quality Colors
   -------------------------------------------- */
.quality-poor { color: var(--quality-poor); }
.quality-common { color: var(--quality-common); }
.quality-uncommon { color: var(--quality-uncommon); }
.quality-rare { color: var(--quality-rare); }
.quality-epic { color: var(--quality-epic); }
.quality-legendary { color: var(--quality-legendary); }
.quality-artifact { color: var(--quality-artifact); }
.quality-heirloom { color: var(--quality-heirloom); }

/* --------------------------------------------
   Shared Components - WoW Class Colors
   -------------------------------------------- */
.death-knight { color: var(--class-death-knight); }
.demon-hunter { color: var(--class-demon-hunter); }
.druid { color: var(--class-druid); }
.evoker { color: var(--class-evoker); }
.hunter { color: var(--class-hunter); }
.mage { color: var(--class-mage); }
.monk { color: var(--class-monk); }
.paladin { color: var(--class-paladin); }
.priest { color: var(--class-priest); }
.rogue { color: var(--class-rogue); }
.shaman { color: var(--class-shaman); }
.warlock { color: var(--class-warlock); }
.warrior { color: var(--class-warrior); }

/* --------------------------------------------
   Shared Components - Price Colors
   -------------------------------------------- */
.price-gold { color: var(--price-gold); }
.price-silver { color: var(--price-silver); }
.price-copper { color: var(--price-copper); }

/* --------------------------------------------
   Shared Components - Tabs
   -------------------------------------------- */
.tabs {
    display: flex;
    gap: 8px;
}

.tabs button {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(255,255,255,0.08);
    border: none;
    color: #fff;
    padding: 9px 18px;
    border-radius: var(--radius-full);
    cursor: pointer;
    font-size: 0.95rem;
    font-weight: bold;
    line-height: 1;
    transition: all var(--transition-fast);
}

.tabs button svg {
    flex-shrink: 0;
}

.tabs button:hover,
.tabs button:focus,
.tabs button.active {
    background-color: var(--color-primary);
    color: #000;
}

.pane { display: none; }
.pane.active { display: block; }

/* --------------------------------------------
   Shared Components - Utility Classes
   -------------------------------------------- */
.text-muted { color: var(--color-text-muted); }
.text-success { color: var(--color-success); }
.text-error { color: var(--color-error); }
.text-center { text-align: center; }
.help { margin-top: 8px; font-size: 0.75rem; color: var(--color-text-muted); }
.small { font-size: 0.75rem; color: var(--color-text-muted); }
.subtitle { color: var(--color-text-muted); font-size: 0.95rem; }
.mobile { display: none; }

/* --------------------------------------------
   Header - Base
   -------------------------------------------- */
.site-header {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 20px;
    position: relative;
}

.site-header h1 {
    font-size: 1.4rem;
    font-weight: 600;
    margin: 0;
}

.site-header .subtitle {
    flex-basis: 100%;
}

.header-left {
    display: flex;
    align-items: center;
    gap: 14px;
    flex: 1;
}

.header-left a {
    margin-top: 5px;
}

.header-right {
    display: flex;
    align-items: center;
    gap: 12px;
}

/* ==========================================================================
   Tool Navigation (interior pages)
   Matches .panel-subtitle chrome so the two panels share a visual language.
   ========================================================================== */
.tool-nav {
    position: relative;
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-md);
    padding: 8px 20px;
    margin-bottom: 20px;
}

.tool-nav-list {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    list-style: none;
    margin: 0;
    padding: 0;
    width: 100%;
}

.tool-nav-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 5px 15px;
    border-radius: 9999px;
    color: var(--color-text);
    text-decoration: none;
    font-size: 0.95rem;
    font-weight: bold;
    white-space: nowrap;
    transition: color 0.15s ease, background 0.15s ease;
}

.tool-nav-link:hover,
.tool-nav-link:focus-visible {
    color: var(--color-text);
    background: rgba(255, 255, 255, 0.04);
}

.tool-nav-link[aria-current="page"] {
    color: var(--color-primary);
    background: rgba(39, 170, 226, 0.12);
}

.tool-nav-link[aria-current="page"]:hover,
.tool-nav-link[aria-current="page"]:focus-visible {
    color: var(--color-primary);
    background: rgba(39, 170, 226, 0.18);
}

.tool-nav-link svg {
    flex-shrink: 0;
}

.tool-nav-toggle {
    display: none;
}

/* Mid-tablet: full labels in 2 rows of 3 centered pills */
@media (min-width: 960px) and (max-width: 1100px) {
    .tool-nav-list {
        flex-wrap: wrap;
        justify-content: center;
        gap: 8px;
    }

    .tool-nav-list li {
        width: calc(33.333% - 6px);
        text-align: center;
    }

    .tool-nav-link {
        justify-content: center;
        width: 100%;
        padding: 5px 14px;
    }
}

/* Tablet: icon-only pills match the grey header icon buttons for uniformity */
@media (min-width: 600px) and (max-width: 959px) {
    .tool-nav {
        padding: 20px;
    }

    .tool-nav-list {
        justify-content: center;
    }

    .tool-nav-label {
        display: none;
    }

    .tool-nav-link {
        padding: 9px 18px;
        background: rgba(255, 255, 255, 0.08);
    }

    .tool-nav-link:hover,
    .tool-nav-link:focus-visible {
        background: rgba(255, 255, 255, 0.14);
    }
}

@media (max-width: 600px) {
    .tool-nav {
        padding: 8px 12px;
    }

    .tool-nav-toggle {
        display: block;
        margin: 8px auto;
        width: 44px;
        height: 44px;
        padding: 10px;
        border: 0;
        background: transparent;
        color: var(--color-text);
        cursor: pointer;
        border-radius: 9999px;
    }

    .tool-nav-toggle:hover,
    .tool-nav-toggle:focus-visible {
        color: var(--color-text);
    }

    .tool-nav-toggle-bar {
        display: block;
        width: 100%;
        height: 2px;
        margin: 4px 0;
        background: currentColor;
        border-radius: 1px;
        transition: transform 0.2s ease, opacity 0.2s ease;
        transform-origin: center;
    }

    .tool-nav-toggle[aria-expanded="true"] .tool-nav-toggle-bar:nth-child(1) {
        transform: translateY(6px) rotate(45deg);
    }

    .tool-nav-toggle[aria-expanded="true"] .tool-nav-toggle-bar:nth-child(2) {
        opacity: 0;
    }

    .tool-nav-toggle[aria-expanded="true"] .tool-nav-toggle-bar:nth-child(3) {
        transform: translateY(-6px) rotate(-45deg);
    }

    .tool-nav-list {
        display: none;
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        padding: 12px 0 4px;
    }

    .tool-nav-list.is-open {
        display: flex;
    }

    .tool-nav-link {
        width: 100%;
        justify-content: center;
        padding: 12px 16px;
        min-height: 44px;
        font-size: 0.95rem;
    }
}

/* Subtitle Panel - appears below header on tool pages */
.panel-subtitle {
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-md);
    padding: 12px 16px;
    margin-bottom: 20px;
}

.panel-subtitle p {
    margin: 0;
    color: var(--color-text-muted);
    font-size: 0.9rem;
}

.user-menu {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
}

.btn-home { display: none; }

.user-menu-buttons {
    display: flex;
    align-items: center;
    gap: 8px;
}

.user-name {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--color-text-muted);
    font-size: 0.9rem;
    text-decoration: none;
    transition: color var(--transition-fast);
    min-width: 0;
    overflow-wrap: break-word;
    word-break: break-word;
}

.user-name:hover {
    color: var(--color-text);
}

.user-name .bnet-icon {
    width: 16px;
    height: 16px;
}

.btn-sm {
    padding: 6px 12px;
    font-size: 0.85rem;
}

.btn-ghost {
    background: transparent;
    color: var(--color-text-muted);
    border: 1px solid var(--color-border);
}

.btn-ghost:hover {
    background: var(--color-bg-hover);
    color: var(--color-text-light);
    border-color: var(--color-border-light);
}

.btn-icon {
    width: 16px;
    height: 16px;
    vertical-align: middle;
    margin-right: 4px;
}

.header-icon {
    width: 42px;
    height: 42px;
    transition: filter var(--transition-slow);
}

.header-icon:hover,
.header-icon:focus {
    filter: drop-shadow(0 0 8px var(--color-primary)) drop-shadow(0 0 15px var(--color-primary));
}

/* --------------------------------------------
   Header - Tool Pages (Option F: Bordered Panel)
   -------------------------------------------- */
.site-header:not(.hub) {
    padding: 16px 20px;
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
}

.header-home-link {
    position: relative;
    top: auto;
    right: auto;
    transform: none;
    margin-left: 8px;
    padding-left: 16px;
    border-left: 1px solid var(--color-border-light);
}

.header-home-link img {
    width: 30px;
    height: 30px;
    margin-top: 5px;
    transition: filter var(--transition-slow);
}

.header-home-link:hover img,
.header-home-link:focus img {
    filter: drop-shadow(0 0 8px var(--color-primary)) drop-shadow(0 0 15px var(--color-primary));
}

/* Hug the icon itself instead of the padded link box (which extends left for the divider) */
.header-home-link:focus-visible {
    outline: none;
}
.header-home-link:focus-visible img {
    outline: 2px solid var(--color-primary, #27aae2);
    outline-offset: 2px;
    border-radius: 4px;
}

/* --------------------------------------------
   Header - Hub/Home Page (Option A: Warcraft Portal)
   -------------------------------------------- */
.hub .site-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 60px 0 10px 0;
    position: relative;
    background: radial-gradient(ellipse at center top, rgba(39, 170, 226, 0.08) 0%, transparent 60%);
    border: none;
    border-radius: 0;
}

.hub .header-left {
    flex-direction: column;
    gap: 0;
}

.hub .header-right {
    position: absolute;
    top: 20px;
    right: 0;
}

.hub .header-icon {
    width: 80px;
    height: 80px;
}

.hub .site-header h1 {
    font-size: 2.75rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    background: linear-gradient(180deg, #fff 0%, #94a3b8 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.hub-subtitle {
    font-size: 1.15rem;
    color: var(--color-text-muted);
    max-width: 400px;
    text-align: center;
    margin: -20px auto 40px;
}

/* --------------------------------------------
   Footer
   -------------------------------------------- */
.site-footer {
    margin-top: 40px;
}

.footer-accent {
    display: none; /* Temporarily hidden */
    height: 3px;
    background: linear-gradient(90deg, var(--color-primary), #7c3aed, var(--color-primary));
}

.footer-content {
    padding: 32px;
}

.footer-tools {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 32px 48px;
    margin-bottom: 24px;
    text-align: center;
}

.footer-tool-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    color: var(--color-text-muted);
    text-decoration: none;
    font-size: 0.8rem;
    transition: color 0.2s;
}

.footer-tool-link:hover {
    color: var(--color-primary);
}

.footer-tool-link svg {
    width: 28px;
    height: 28px;
    opacity: 0.7;
}

.footer-tool-link:hover svg {
    opacity: 1;
}

.footer-divider {
    width: 735px;
    max-width: calc(100% - 32px);
    height: 1px;
    background: var(--color-border);
    margin: 0 auto 20px;
}

.hub .footer-divider {
    width: 460px;
}

.footer-copy {
    text-align: center;
    color: var(--color-text-muted);
    font-size: 0.75rem;
    margin-bottom: 20px;
}

.footer-logo {
    display: none; /* Temporarily hidden */
    justify-content: center;
}

.footer-divider:last-of-type {
    display: none; /* Temporarily hidden */
}

.footer-logo img {
    width: 48px;
    height: 48px;
    filter: drop-shadow(0 0 10px rgba(39, 170, 226, 0.3));
    transition: filter 0.2s;
}

.footer-logo:hover img {
    filter: drop-shadow(0 0 15px rgba(39, 170, 226, 0.5));
}

#btn-logout {
    display: none; /* Temporarily hidden */
}

/* Resolution Warning - shown on very small screens */
.resolution-warning {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: var(--color-bg);
    padding: 24px;
    align-items: center;
    justify-content: center;
}

.resolution-warning-card {
    background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
    border: 1px solid rgba(239, 68, 68, 0.3);
    border-radius: 16px;
    padding: 32px 28px;
    text-align: center;
    max-width: 320px;
}

.resolution-warning-icon {
    width: 48px;
    height: 48px;
    margin: 0 auto 16px;
    color: var(--color-error);
    opacity: 0.85;
}

.resolution-warning-card h2 {
    font-size: 1.25rem;
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--color-text);
}

.resolution-warning-card p {
    color: var(--color-text-muted);
    font-size: 0.9rem;
    line-height: 1.5;
    margin: 0;
}

@media (max-width: 299px) {
    .resolution-warning {
        display: flex;
    }
    
    .container {
        display: none;
    }
}

/* Admin view-as feature */
.view-as-banner {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: #fbbf24;
    color: #1f2937;
    padding: 12px 20px;
    text-align: center;
    font-weight: 600;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    flex-wrap: wrap;
}

.view-as-banner__icon {
    margin-right: 4px;
}

.view-as-banner__exit {
    color: #1f2937;
    text-decoration: underline;
    font-weight: 700;
}

.view-as-banner__exit:hover,
.view-as-banner__exit:focus {
    color: #000;
}

#nav-account-overview {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.viewing-as {
    font-size: 0.875rem;
    font-weight: 400;
    color: var(--color-text-muted);
}

.view-as-select {
    padding: 6px 12px;
    font-size: 0.875rem;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    color: var(--color-text);
    cursor: pointer;
    max-width: 150px;
}

.view-as-select:hover,
.view-as-select:focus {
    border-color: var(--color-primary);
}


/* ============================================
   HUB / HOME PAGE
   ============================================ */

#warcraft-tools .footer-tools,
#maintenance .footer-tools {
    display: none;
}

.tools-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 24px;
}

.tool-card {
    background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 16px;
    padding: 28px;
    text-decoration: none;
    color: var(--color-text);
    transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
    display: block;
    text-align: left;
}

.tool-card:hover,
.tool-card:focus {
    transform: translateY(-4px);
    border-color: rgba(59, 184, 237, 0.4);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4), 0 0 20px rgba(59, 184, 237, 0.1);
    text-decoration: none;
}

.tool-icon {
    width: 48px;
    height: 48px;
    margin-bottom: 16px;
    opacity: 0.85;
}

/* Icon Options - for testing multiple icon designs */
.tool-card h2 {
    font-size: 1.35rem;
    font-weight: 600;
    margin-bottom: 8px;
}

.tool-card p {
    color: var(--color-text-muted);
    font-size: 0.95rem;
    line-height: 1.5;
    margin-bottom: 16px;
}

.tool-link {
    color: var(--color-primary);
    font-size: 0.9rem;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.tool-card:hover .tool-link {
    color: var(--color-primary-hover);
}

.tool-link svg {
    width: 16px;
    height: 16px;
    transition: transform 0.2s ease;
}

.tool-card:hover .tool-link svg {
    transform: translateX(4px);
}

/* Error page card layout */
.error .header-home-link {
    display: none;
}

.error-grid {
    max-width: 400px;
    margin: 0 auto;
}

.error-card {
    text-align: center;
}

.error-card .tool-icon {
    margin: 0 auto 16px;
}

@media (max-width: 450px) {
    .error-grid {
        max-width: 100%;
    }
    
    .error-card {
        padding: 24px 20px;
    }
    
    .error-card h2 {
        font-size: 1.2rem;
    }
    
    .error-card p {
        font-size: 0.9rem;
    }
}

#maintenance .tool-card {
    cursor: default;
}

#maintenance .tool-card:hover {
    transform: none;
}

/* --- Wide tool card variant --- */
.tool-card.wide {
    grid-column: span 2;
}

.tool-card.wide .tool-card-inner {
    display: flex;
    flex-direction: row;
    gap: var(--spacing-lg);
    align-items: center;
}

.tool-card.wide .tool-card-content {
    flex: 1;
}

.tool-card.wide .tool-card-badge {
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 20px 30px;
    background: rgba(251,191,36,0.15);
    border-radius: 12px;
    border: 1px solid rgba(251,191,36,0.35);
}

.tool-card.wide .badge-coming-soon {
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #fcd34d;
    margin-bottom: 4px;
}

.tool-card.wide .badge-year {
    font-size: 1.4rem;
    font-weight: 600;
    color: var(--color-text);
}


/* ============================================
   DASHBOARD
   ============================================ */

/* --- Dashboard: Panel variants --- */
.panel-login { text-align: center; }
.panel-login p { margin: 2px 0 15px 0; font-size: 0.9rem; color: var(--color-text-muted); }
.panel-status .panel-header { flex-wrap: wrap; }

.status-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 0.85rem;
    margin-left: auto;
}

.panel-header-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-left: auto;
}

.panel-header-actions .btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.panel-header-actions .btn svg {
    flex-shrink: 0;
}

.status-item {
    opacity: 0.8;
    font-size: 0.85rem;
    text-align: left;
    width: 100%;
}

.refresh-progress { margin-top: 12px; }

.status-error {
    margin-top: 12px;
    padding: 10px 14px;
    background: rgba(180, 40, 40, 0.15);
    border: 1px solid rgba(180, 40, 40, 0.4);
    border-radius: 4px;
    color: #e88;
    font-size: 0.85rem;
}
.status-error strong {
    display: block;
    margin-bottom: 6px;
    color: #f99;
}
.status-error ul {
    margin: 0;
    padding-left: 20px;
}
.status-error li {
    margin: 2px 0;
}

/* --- Dashboard: Stats loading --- */
.panel-stats-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 150px;
}

.stats-loading-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-sm);
}

.stats-loader-spinner {
    width: 32px;
    height: 32px;
    animation: spin 1s linear infinite;
}

.stats-loader-text {
    font-size: 0.875rem;
    color: var(--color-text-muted);
}

/* --- Dashboard: Stats panel --- */
.panel-stats .stats-row {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin-top: 12px;
    text-align: center;
}

.stat-label {
    color: #ddd;
    display: block;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    opacity: 0.7;
    margin-bottom: 4px;
}

.stat-value { font-size: 1.2rem; font-weight: 600; }
.stat-wide { width: 100%; }
.stats-row.stats-row-classes { display: block; margin-top: 30px; }

.stat-favorite-content {
    display: flex;
    align-items: center;
    gap: 8px;
    justify-content: center;
}

.stat-favorite-content .class-icon { width: 20px; height: 20px; margin-top: 3px; }
.stat-favorite-content .faction-icon { width: 20px; height: 20px; }
.stat-favorite-content .stat-icon { width: 20px; height: 20px; }

.stat.achievements .achievements-icon {
    width: 20px; height: 20px;
    filter: brightness(0) saturate(100%) invert(73%) sepia(97%) saturate(567%) hue-rotate(358deg) brightness(101%) contrast(96%);
}

.stat-favorite-content .alliance-icon {
    filter: invert(23%) sepia(86%) saturate(2094%) hue-rotate(190deg) brightness(95%) contrast(101%);
}

.stat-favorite-content .horde-icon { filter: brightness(1.2) saturate(1.3); }
.stat.horde .stat-favorite-content { gap: 5px; }

.stat-favorite-content .characters-icon {
    filter: brightness(0) saturate(100%) invert(66%) sepia(52%) saturate(405%) hue-rotate(57deg) brightness(95%) contrast(91%);
}

.stat-favorite-content .mounts-icon {
    filter: brightness(0) saturate(100%) invert(67%) sepia(25%) saturate(549%) hue-rotate(346deg) brightness(93%) contrast(86%);
}

.stat-favorite-content .toys-icon {
    filter: brightness(0) saturate(100%) invert(76%) sepia(44%) saturate(420%) hue-rotate(166deg) brightness(98%) contrast(92%);
}

.stat-favorite-content .pets-icon {
    filter: brightness(0) saturate(100%) invert(76%) sepia(69%) saturate(462%) hue-rotate(88deg) brightness(102%) contrast(94%);
}

/* --- Dashboard: Class chips --- */
.stat-classes {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin-top: 8px;
}

.class-chip {
    background: rgba(255,255,255,0.05);
    border-radius: var(--radius-md);
    border: 1px solid rgba(255,255,255,0.15);
    cursor: pointer;
    padding: 0.75rem 1rem;
    font-size: 0.8rem;
    font-weight: bold;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    justify-content: center;
    flex-wrap: wrap;
    transition: background var(--transition-fast);
}

.class-chip:hover { background: rgba(255,255,255,0.08); }
.class-chip.active { justify-content: left; gap: 20px; align-content: flex-start; }

.class-details {
    flex: 100%;
    gap: 5px;
    align-items: center;
    display: flex;
    justify-content: center;
}

.class-chip.active .class-details { justify-content: center; }
.class-details img { margin-top: 2px; }
.class-name { font-size: 0.85rem; }
.class-count { color: #ddd; font-size: 0.85rem; }
.class-chip .class-icon, .combo-class-chip .class-icon { width: 18px; height: 18px; flex-shrink: 0; }

/* --- Dashboard: Spec overview --- */
.spec-overview { display: flex; flex-direction: column; align-items: center; }
.spec-details { align-items: center; gap: 5px; justify-content: center; display: flex; }
.class-chip.active .spec-overview { flex: 0 0 calc(50% - 10px); width: calc(50% - 10px); }
.spec-icon { width: 16px; height: 16px; }
.spec-name { display: none; }
.active .spec-name { display: block; }
.spec-count { color: #ddd; }
.spec-character { display: block; font-size: 0.8rem; color: #aaa; margin-top: 5px; }
.spec-characters { display: none; flex-direction: column; align-items: center; }
.class-chip.active .spec-characters { display: flex; }

/* --- Dashboard: Filters --- */
.panel-filters .filters-row {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.filter-column { display: flex; flex-direction: column; min-height: 60px; }
.filter-column-main .filter-group { margin-bottom: 8px; }
.filter-column-main .filter-group:last-of-type { margin-bottom: 0; }
.filter-column-single .filter-group { flex: 1 1 auto; display: flex; flex-direction: column; }
.filter-group { font-size: 0.85rem; }

.filter-group label {
    color: #ddd;
    display: block;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    opacity: 0.75;
    margin-bottom: 4px !important;
}

.filter-group input, .filter-group select {
    background: var(--color-bg-input);
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border-input);
    color: #fff;
    padding: 6px 10px;
    min-height: 36px;
    font-size: 0.9rem;
    width: 100%;
}

.filter-group select[multiple] { min-height: 100px; padding: 6px 8px; }
.filter-column-single .filter-group select[multiple] { flex: 1 1 auto; }
.filter-spec-option { font-size: 0.9rem; }

#pet-filter-family option {
    text-transform: capitalize;
}

/* --- Dashboard: Level range slider --- */
.filter-group.filter-level-range { display: flex; flex-direction: column; gap: 0.25rem; }
#level-range-slider { margin: 0.75rem 0 0.25rem; }
#level-range-slider.ui-slider { position: relative; height: 0.5rem; border-radius: var(--radius-full); background: rgba(255, 255, 255, 0.12); border: none; }
#level-range-slider .ui-slider-range { background: var(--color-primary); border-radius: var(--radius-full); }
#level-range-slider .ui-slider-handle { top: 50%; transform: translate(-50%, -50%); width: 1rem; height: 1rem; border-radius: 50%; border: 2px solid var(--color-primary); background: #0f1722; cursor: pointer; box-shadow: none; }
#level-range-slider .ui-slider-handle:focus-visible { outline: 2px solid #ffffff; outline-offset: 2px; }
.level-range-labels span { color: #ffffff; opacity: 0.8; }

/* --- Dashboard: Accounts grid --- */
.accounts-grid { display: grid; gap: 10px; grid-template-columns: repeat(4, minmax(0, 1fr)); }

.account-column {
    background: var(--color-bg-dark);
    border-radius: 10px;
    padding: 10px;
    border: 1px solid var(--color-border-light);
    min-height: 60px;
}

.account-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.5rem 0.75rem;
    border-radius: var(--radius-md);
    background: rgba(255,255,255,0.03);
    gap: 8px;
}

.account-header h3 { font-size: 0.95rem; outline: none; }
.account-header h3:focus { box-shadow: 0 0 0 1px var(--color-primary); }

/* Account label with edit icon */
.account-label-group {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}

.account-label-group h3 { margin: 0; }

.account-edit-icon {
    width: 14px;
    height: 14px;
    opacity: 0.5;
    transition: opacity var(--transition-normal), filter var(--transition-normal);
    filter: brightness(0) invert(1); /* white */
}

.account-label-group:hover .account-edit-icon {
    opacity: 1;
    filter: brightness(0) saturate(100%) invert(62%) sepia(93%) saturate(456%) hue-rotate(161deg) brightness(95%) contrast(87%); /* --color-primary #27aae2 */
}

/* Account edit mode */
.account-edit-form {
    display: none;
    align-items: center;
    gap: 8px;
    flex: 1;
}

.account-header.editing .account-label-group,
.account-header.editing .account-faction-summary { display: none; }
.account-header.editing .account-edit-form { display: flex; }

.account-edit-input {
    flex: 1;
    min-width: 0;
    padding: 6px 10px;
    font-size: 0.9rem;
    font-family: inherit;
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    color: var(--color-text-light);
    outline: none;
}

.account-edit-input:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px rgba(39, 170, 226, 0.2);
}

.account-save-icon {
    width: 18px;
    height: 18px;
    cursor: pointer;
    transition: filter var(--transition-normal);
    filter: brightness(0) saturate(100%) invert(68%) sepia(52%) saturate(405%) hue-rotate(51deg) brightness(95%) contrast(89%); /* --color-success #80c342 */
}

.account-save-icon:hover {
    filter: brightness(0) saturate(100%) invert(62%) sepia(93%) saturate(456%) hue-rotate(161deg) brightness(95%) contrast(87%); /* --color-primary #27aae2 */
}

.account-hide-icon,
.account-show-icon {
    width: 18px;
    height: 18px;
    cursor: pointer;
    transition: filter var(--transition-normal);
    filter: brightness(0) invert(1); /* white */
}

.account-hide-icon:hover,
.account-show-icon:hover {
    filter: brightness(0) saturate(100%) invert(62%) sepia(93%) saturate(456%) hue-rotate(161deg) brightness(95%) contrast(87%); /* --color-primary #27aae2 */
}

/* Reorder Accounts Modal */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.8);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--transition-normal), visibility var(--transition-normal);
}

.modal-overlay.active {
    opacity: 1;
    visibility: visible;
}

.modal-content {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    max-width: 450px;
    width: 90%;
    max-height: 80vh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--color-border);
}

.modal-header h3 {
    margin: 0;
    font-size: 1.1rem;
}

.modal-close {
    background: none;
    border: none;
    color: var(--color-text-muted);
    font-size: 1.5rem;
    cursor: pointer;
    line-height: 1;
    padding: 0;
}

.modal-close:hover { color: var(--color-text-light); }

.modal-body {
    flex: 1;
    overflow-y: auto;
    margin-bottom: 1rem;
}

.reorder-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.reorder-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    cursor: grab;
    transition: background var(--transition-normal), border-color var(--transition-normal);
}

.reorder-item:hover {
    background: rgba(255, 255, 255, 0.06);
    border-color: var(--color-border-light);
}

.reorder-item.dragging {
    opacity: 0.5;
    background: rgba(39, 170, 226, 0.1);
    border-color: var(--color-primary);
}

.reorder-item.drag-over {
    border-color: var(--color-primary);
    background: rgba(39, 170, 226, 0.05);
}

.reorder-handle {
    color: var(--color-text-muted);
    font-size: 1.2rem;
    cursor: grab;
}

.reorder-label {
    flex: 1;
    font-size: 0.9rem;
    text-transform: uppercase;
}

.reorder-position {
    color: var(--color-text-muted);
    font-size: 0.8rem;
    min-width: 20px;
    text-align: right;
}

.modal-footer {
    display: flex;
    gap: 12px;
    justify-content: flex-end;
    padding-top: 1rem;
    border-top: 1px solid var(--color-border);
}

.modal-footer .btn { min-width: 100px; }

.account-faction-summary, .server-faction-summary {
    display: flex;
    align-items: center;
    font-size: 0.8rem;
    opacity: 0.9;
    margin: 0;
    padding: 0;
}

.panel-reserved .server-faction-summary { display: none; }
.panel-reserved .server-header .server-label { flex: 100%; }
#btn-batch-check-reserved { display: none; }

/* Hidden Accounts Panel */
.panel-hidden .server-faction-summary { display: none; }
.panel-hidden .server-header .server-label { flex: 100%; }

.hidden-tile {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 4px 8px;
    background: rgba(255, 255, 255, 0.02);
    border-radius: var(--radius-sm);
}

.hidden-name { flex: 1; }
.hidden-level {
    font-size: 0.79rem;
    color: var(--color-text-muted);
}

.hidden-tile .character-name {
    font-size: 0.79rem;
}

.account-faction-breakdown, .server-faction-breakdown {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    white-space: nowrap;
}

.account-faction-summary .faction-icon, .server-faction-summary .faction-icon {
    height: 16px;
    width: auto;
}

.account-total-label, .server-total-label, .account-total-count, .server-total-count {
    color: var(--color-success);
    font-weight: 600;
}

/* --- Dashboard: Server groups --- */
.server-group { display: flex; flex-direction: column; gap: 10px; }

.server-header {
    padding: 0.5rem 0.75rem;
    border-radius: 6px;
    background: rgba(255,255,255,0.03);
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 10px 0 0 0;
}

.server-header .server-label { font-size: 0.75rem; text-transform: uppercase; margin: 0; }

/* --- Dashboard: Character list --- */
.character-list { display: flex; flex-direction: column; gap: 8px; }

.character-tile {
    background: rgba(255,255,255,0.03);
    border-radius: var(--radius-md);
    padding: 0.5rem 0.75rem;
    cursor: pointer;
    transition: background var(--transition-fast);
    overflow: hidden;
}

.character-tile:hover { background: var(--color-bg-hover); }
.character-tile.inactive { cursor: not-allowed; opacity: 0.5; }
.character-tile.inactive .char-loader { display: flex; }
.character-tile.inactive .char-faction { display: none; }

.character-header { display: flex; justify-content: space-between; align-items: center; gap: 6px; margin-bottom: 4px; }
.character-name { font-size: 0.95rem; margin: 0; }
.character-meta { font-size: 0.75rem; opacity: 0.8; display: flex; gap: 6px; }
.character-summary { font-size: 0.75rem; opacity: 0.9; display: flex; flex-direction: column; gap: 4px; }
.character-summary-top, .character-summary-profs, .character-summary-gold { display: flex; flex-wrap: wrap; gap: 6px; }

.character-class, .character-race, .character-profs, .character-gold, .character-gender {
    padding: 2px 6px;
    border-radius: var(--radius-full);
    background: rgba(255,255,255,0.04);
}

.character-gender.gender-male { color: var(--color-male); border: 1px solid rgba(59,166,255,0.4); }
.character-gender.gender-female { color: var(--color-female); border: 1px solid rgba(255,115,197,0.4); }

/* --- Dashboard: Character tile (WoW-style) --- */
.char-tile {
    display: flex;
    align-items: stretch;
    padding: 0.75rem 1rem;
    background: #111820;
    border-radius: 10px;
    border: 1px solid rgba(255,255,255,0.15);
    gap: 1%;
    flex-wrap: wrap;
}

.char-main { flex: 84%; }
.char-faction img.faction-icon, .char-loader img { max-height: 40px; max-width: 100%; width: auto; }
.reserved-tile .character-name { font-size: 0.79rem; }
.char-faction, .char-loader { flex: 14%; display: flex; justify-content: center; align-items: center; }
.char-loader { display: none; }

.character-details {
    flex: 100%;
    border-top: 1px solid rgba(255, 255, 255, 0.15);
    margin-top: 15px;
    padding-top: 15px;
    font-size: 0.85rem;
}

/* --- Dashboard: Faction icons --- */
.faction-icon.alliance { filter: invert(23%) sepia(86%) saturate(2094%) hue-rotate(190deg) brightness(95%) contrast(101%); }
.faction-icon.horde { filter: invert(23%) sepia(90%) saturate(3100%) hue-rotate(350deg) brightness(94%) contrast(106%); margin-top: 1px; }

/* --- Dashboard: Character details --- */
.guild span:first-of-type, .spec-label, .ilvl span:first-of-type, .profession span:first-of-type, .mythic span:first-of-type, .login span:first-of-type { color: #ddd; opacity: 0.7; }
.spec { display: flex; gap: 5px; align-items: center; width: 100%; order: 0; }
.guild { width: 100%; order: 2; }
.guild span { color: #ddd; }
.guild a { display: inline-block; color: var(--color-wow-gold); text-decoration: none; }
.guild a:hover, .guild a:focus { text-decoration: underline; }
.spec-label { color: #ddd; }
.ilvl { color: #ddd; width: 100%; order: 1; }
.ilvl span { color: #ddd; }
.profession { color: #ddd; width: 100%; order: 3; }
.mythic { color: #ddd; width: 100%; order: 4; }
.mythic span { color: #ddd; }
.login { color: #ddd; width: 100%; order: 5; border-bottom: 1px solid rgba(255, 255, 255, 0.15); padding-bottom: 15px; }
.login span { color: #ddd; }

.char-name { display: inline-block; font-size: 1.05rem; font-weight: 600; color: var(--color-wow-gold); text-decoration: none; }
.char-name:hover { text-decoration: underline; }
.char-level-class { margin-top: 0.15rem; font-size: 0.9rem; }
.char-level-label { color: #ddd; margin-right: 0; }
.char-level-value { color: #ddd; margin-right: 0; }
.char-class-name { font-weight: 600; }
.char-line { margin-top: 0.15rem; font-size: 0.85rem; }
.char-race-gender { display: flex; align-items: center; }
.char-race-gender .gender-icon { margin-right: 0.35rem; width: 12px; height: 12px; }
.char-race-gender .gender-icon.female { width: 15px; height: 15px; }
.char-race { color: #ddd; }
.char-guild-link { color: #ddd; text-decoration: none; }
.char-guild-link:hover { text-decoration: underline; }

.char-title { display: none; font-size: 0.75rem; color: var(--color-wow-gold); }
.character-tile.expanded .char-title { display: block; }
.char-title.no-title { color: #888; }

.character-media { border-radius: var(--radius-md); margin-top: 15px; }
.character-media figure { margin: 0; width: 100%; }
.character-media img { display: block; border-radius: var(--radius-md); width: 100%; }
.media-avatar, .media-main { display: none; }

.reserved-tile { cursor: default; }
.reserved-tile .character-header { justify-content: flex-start; }

/* --- Dashboard: Collection grids (Mounts, Pets, Toys) --- */
.mounts-filters-row, .pets-filters-row, .toys-filters-row {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-bottom: 15px;
    padding-bottom: 15px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.mounts-grid, .pets-grid, .toys-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.mount-card, .pet-card, .toy-card {
    background: var(--color-bg-dark);
    border-radius: 10px;
    padding: 12px;
    border: 1px solid var(--color-border-light);
    display: flex;
    gap: 12px;
}

.mount-card.is-favorite, .pet-card.is-favorite, .toy-card.is-favorite { border-color: rgba(255, 215, 0, 0.3); }
.mount-card.unowned, .pet-card.unowned, .toy-card.unowned { opacity: 0.5; }
.mount-card.unowned:hover, .mount-card.unowned:focus,
.pet-card.unowned:hover, .pet-card.unowned:focus,
.toy-card.unowned:hover, .toy-card.unowned:focus { opacity: 1; }
.mount-card.unknown-source, .pet-card.unknown-source, .toy-card.unknown-source { display: none; }

.mount-card > a, .pet-card > a, .toy-card > a {
    width: 40px;
    height: 40px;
    flex-shrink: 0;
    display: block;
    background: #1a1f2e url('/img/ui/icon-missing.svg') center center no-repeat;
    background-size: 20px 20px;
    border-radius: 6px;
}

.mount-icon, .pet-icon, .toy-icon { width: 40px; height: 40px; border-radius: 6px; display: block; background: var(--color-bg); }
.mount-icon[src=""], .pet-icon[src=""], .toy-icon[src=""],
.mount-icon:not([src]), .pet-icon:not([src]), .toy-icon:not([src]) { visibility: hidden; }
/* Hide alt text on broken images */
.mount-icon, .pet-icon, .toy-icon { color: transparent; text-indent: -9999px; overflow: hidden; }

.mount-content, .pet-content, .toy-content {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.mount-header, .pet-header, .toy-header { display: flex; align-items: flex-start; gap: 6px; }

.mount-name, .pet-name, .toy-name {
    font-weight: 600;
    font-size: 0.95rem;
    color: #fff;
    text-decoration: none;
}

.mount-name:hover, .pet-name:hover, .toy-name:hover { text-decoration: underline; }
.mount-favorite, .pet-favorite, .toy-favorite { color: gold; margin-left: auto; }

.mount-faction-icon { width: 16px; height: 16px; margin-top: 5px; }
.mount-faction-icon.alliance { filter: brightness(0) saturate(100%) invert(50%) sepia(98%) saturate(398%) hue-rotate(176deg) brightness(93%) contrast(89%); }
.mount-faction-icon.horde { filter: brightness(0) saturate(100%) invert(23%) sepia(96%) saturate(2641%) hue-rotate(347deg) brightness(87%) contrast(92%); }

.mount-description, .pet-description { font-size: 0.8rem; color: rgba(255,255,255,0.6); line-height: 1.3; padding-bottom: 10px; }
.mount-source, .toy-source { font-size: 0.8rem; color: rgba(255,255,255,0.6); margin-top: auto; }
.pet-source { font-size: 0.75rem; color: rgba(255,255,255,0.5); margin-top: auto; }

.mounts-grid .loading-message, .pets-grid .loading-message, .toys-grid .loading-message {
    grid-column: 1 / -1;
    text-align: center;
    padding: 20px;
    color: rgba(255,255,255,0.5);
}

.toy-content { gap: 5px; }
.header-count { font-size: 0.7em; font-weight: 400; opacity: 0.7; }

/* --- Dashboard: Pets specific --- */
.pet-family-icon { width: 20px; height: 20px; flex-shrink: 0; }
.pet-family-icon[title="Dragonkin"] { margin-top: 1px; }
.pet-family-icon[title="Mechanical"] { margin-top: 2px; }
.pet-family-icon[title="Humanoid"] { margin-top: 1px; }
.pet-family-icon[title="Undead"] { margin-top: 2px; }
.pet-family-icon[title="Flying"] { margin-top: 1px; }
.pet-family-icon[title="Magic"] { margin-top: 1px; }
.pet-family-icon[title="Aquatic"] { margin-top: 1px; }
.pet-family-icon[title="Critter"] { margin-top: 1px; }

.pet-details { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 2px; }
.pet-tag { font-size: 0.7rem; padding: 2px 6px; border-radius: 4px; }
.pet-tag.positive { background: rgba(25, 244, 105, 0.15); color: #19f469; }
.pet-tag.negative { background: rgba(244, 67, 54, 0.15); color: #f44336; }

/* --- Dashboard: Race/Class combos --- */
.panel-combos .combos-textarea {
    display: none;
    width: 100%;
    min-height: 220px;
    margin-top: 10px;
    margin-bottom: 15px;
    padding: 8px;
    border-radius: 6px;
    border: 1px solid rgba(255,255,255,0.2);
    background: rgba(0, 0, 0, 0.35);
    color: #fff;
    font-size: 0.8rem;
    font-family: Menlo, Monaco, Consolas, monospace;
    resize: vertical;
}

.panel-combos .combos-columns { display: flex; flex-direction: column; gap: 20px; }
.combos-column h3 { font-size: 1.15rem; margin-bottom: 15px; }
.combo-race-group { margin-bottom: 15px; }
.combo-race-group:first-of-type { margin-top: 15px; }

.combo-race-title {
    font-size: 0.9rem;
    font-weight: bold;
    margin-bottom: 10px;
    opacity: 0.9;
    display: flex;
    align-items: center;
    gap: 6px;
}

.combo-race-name { width: 100%; }

.combo-class-list {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    font-size: 0.78rem;
}

/* Combo class list needs 2 columns earlier due to complex content */
@media (max-width: 1000px) {
    .combo-class-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.combo-class-chip {
    background: rgba(255,255,255,0.05);
    border-radius: var(--radius-md);
    padding: 0.75rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    justify-content: flex-start;
}

.combo-class { display: flex; font-weight: bold; gap: 5px; justify-content: center; }
.combo-class-name { display: inline-block; }
.combo-gender-flags { display: inline-flex; gap: 4px; font-size: 0.8rem; margin-left: auto; }

.combo-gender-flag {
    padding: 8px;
    border-width: 3px;
    border-radius: var(--radius-full);
    border-color: rgba(128, 195, 66, 0.25);
    border-style: solid;
    line-height: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.combo-gender-flag.male { border-color: rgba(59,166,255,0.5); }
.combo-gender-flag.female { border-color: rgba(255,115,197,0.5); }
.combo-gender-flag.owned { background: #2c491b; border-color: #2c491b; }
.combo-gender-flag.missing { background: #000; opacity: 0.3; border-style: dashed; }

/* Gender icon images */
.gender-icon {
    width: 16px;
    height: 16px;
    display: block;
}
.gender-icon.male {
    filter: invert(54%) sepia(69%) saturate(632%) hue-rotate(176deg) brightness(101%) contrast(101%);
}
.gender-icon.female {
    filter: invert(63%) sepia(40%) saturate(1556%) hue-rotate(296deg) brightness(103%) contrast(101%);
    width: 20px;
    height: 20px;
}
.combo-gender-flag.has-tooltip { position: relative; }
.combo-gender-flag.has-tooltip:hover { z-index: 100; }

.combo-faction-genders {
    background: var(--color-bg-panel);
    border-radius: var(--radius-md);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 5%;
    font-size: 1.25rem;
    width: 90%;
}

.combo-faction-row { display: flex; align-items: center; gap: 10px; justify-content: space-evenly; width: 100%; }
.combo-faction-row .faction-icon { height: 37px; width: auto; min-width: 40.33px; }
.combo-faction-label { font-weight: 500; opacity: 0.8; }
.combo-class-chip.all-genders-all-factions-owned { border: 1px solid var(--color-success); }
.combo-class-chip.both-owned { background: rgba(128, 195, 66, 0.25); border: 1px solid var(--color-success); }
.combo-faction-icon { width: 16px; height: 16px; flex-shrink: 0; }
.combo-faction-icon.alliance { filter: invert(23%) sepia(86%) saturate(2094%) hue-rotate(190deg) brightness(95%) contrast(101%); }

.combo-faction-header { display: flex; align-items: center; gap: 8px; margin: 1rem 0 0.5rem; font-size: 0.95rem; font-weight: 600; }
.combo-faction-header-label { display: inline-block; }
.combo-faction-header .combo-faction-icon { width: 18px; height: 18px; }

/* --- Dashboard: Combos Duplicates --- */
.combos-duplicates {
    display: none;
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid var(--color-border);
}

.combos-duplicates h3 {
    font-size: 1rem;
    margin-bottom: 12px;
    opacity: 0.9;
}

.duplicates-list {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    font-size: 0.78rem;
}

.duplicate-card {
    background: rgba(255,255,255,0.05);
    border-radius: var(--radius-md);
    padding: 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.duplicate-header {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: start;
    gap: 6px;
    font-weight: 500;
}

.duplicate-header-center {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 11px;
}

.duplicate-header-class {
    display: flex;
    align-items: center;
    gap: 6px;
}

.duplicate-faction-icon {
    width: 28px;
    height: 28px;
    flex-shrink: 0;
}

.duplicate-faction-icon.alliance {
    filter: invert(23%) sepia(86%) saturate(2094%) hue-rotate(190deg) brightness(95%) contrast(101%);
}

.duplicate-race {
    font-weight: bold;
    padding-bottom: 3px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.8);
}

.duplicate-class-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    border-radius: var(--radius-sm);
}

.duplicate-class {
    font-weight: bold;
}

.duplicate-gender {
    line-height: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.duplicate-gender .gender-icon {
    width: 20px;
    height: 20px;
}
.duplicate-gender .gender-icon.female {
    width: 24px;
    height: 24px;
}

.duplicate-servers {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.duplicate-server-line {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    justify-content: center;
}

.duplicate-server-name {
    font-weight: 500;
    opacity: 0.8;
}

.duplicate-char-names {
    color: #fff;
}

/* Duplicates grid: 2 columns at 1000px (matches combo-class-list) */
@media (max-width: 1000px) {
    .duplicates-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* --- Dashboard: Tooltips --- */
.clipboard-toast, .hover-tooltip {
    position: absolute;
    z-index: 9999;
    background: #1f3d1f;
    border: 1px solid var(--color-success);
    color: #e6ffe6;
    padding: 4px 10px;
    border-radius: 4px;
    font-size: 0.8rem;
    pointer-events: none;
    box-shadow: 0 2px 6px rgba(0,0,0,0.4);
    white-space: nowrap;
    display: none;
    transition: opacity 0.2s ease;
}

/* --- Dashboard: Section navigation --- */
.panel-section-nav .panel-body { padding-top: 12px; padding-bottom: 12px; }

.section-nav-links {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    align-items: center;
    text-align: center;
}

.section-nav-links a {
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
    display: inline-block;
    padding: 5px;
    border-radius: var(--radius-full);
    font-size: 0.95rem;
    text-decoration: none;
    cursor: pointer;
}

.section-nav-links a:hover, .section-nav-links a:focus-visible {
    background-color: var(--color-primary);
    color: #000;
}

.panel-section-nav {
    display: none;
    background: rgba(8, 12, 20, 1.0);
    position: sticky;
    top: 0;
    z-index: 9999;
    padding: 0 20px;
}

/* --- Dashboard: Collapsible panels --- */
.panel-collapsible .panel-collapsible-content { display: none; }
.panel-collapsible .panel-header { padding-bottom: 0; }
.panel-collapsible.is-expanded .panel-header { padding-bottom: 1rem; }
.panel-collapsible.is-expanded .panel-collapsible-content { display: block; }
.panel-collapsible .btn-collapse { display: none; }
.panel-collapsible.is-expanded .btn-collapse { display: inline-flex; }
.panel-collapsible.is-expanded .btn-expand { display: none; }


/* ============================================
   PRICE GOBLIN
   ============================================ */

/* --- Price Check: Search --- */
.search-container { display: flex; gap: 12px; }
.search-input-wrapper { flex: 1; position: relative; }

.search-input {
    width: 100%;
    padding: 14px 18px;
    font-size: 1rem;
    font-family: inherit;
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    color: var(--color-text-light);
    outline: none;
    transition: border-color var(--transition-normal), box-shadow var(--transition-normal);
}

.search-input:focus { border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(39, 170, 226, 0.15); }
.search-input::placeholder { color: var(--color-text-muted); }

/* --- Price Check: Autocomplete --- */
.search-suggestions {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: #111827;
    border: 1px solid var(--color-border);
    border-top: none;
    border-radius: 0 0 var(--radius-md) var(--radius-md);
    max-height: 300px;
    overflow-y: auto;
    z-index: 100;
    display: none;
}

.search-suggestions.active { display: block; }

.suggestion-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    cursor: pointer;
    transition: background var(--transition-fast);
}

.suggestion-item:hover, .suggestion-item.selected { background: rgba(39, 170, 226, 0.15); }
.suggestion-icon { width: 28px; height: 28px; border-radius: 4px; background: rgba(0, 0, 0, 0.3); }
.suggestion-name { flex: 1; font-size: 0.95rem; }
.suggestion-type { font-size: 0.8rem; color: var(--color-text-muted); }
.suggestion-item.no-results { cursor: default; color: var(--color-text-muted); font-style: italic; }
.suggestion-item.no-results:hover { background: transparent; }

/* --- Price Check: Search status --- */
.search-status {
    display: none;
    margin-top: 16px;
    padding: 12px 16px;
    font-size: 0.9rem;
    color: var(--color-text-muted);
    background: rgba(0, 0, 0, 0.2);
    border-radius: var(--radius-md);
    border: 1px solid rgba(99, 179, 237, 0.15);
}

.search-status.active { display: block; }
.search-status.error { display: block; color: #fca5a5; background: rgba(239, 68, 68, 0.1); border-color: rgba(239, 68, 68, 0.3); }

/* --- Price Check: Results panel --- */
.panel-results { padding: 0; overflow: hidden; }

.results-header {
    padding: 20px;
    border-bottom: 1px solid var(--color-border);
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    align-items: center;
}

.item-info { display: flex; align-items: center; gap: 16px; flex: 1; min-width: 200px; }

.item-icon {
    width: 56px;
    height: 56px;
    border-radius: var(--radius-md);
    background: rgba(0, 0, 0, 0.3);
    border: 2px solid var(--color-border);
}

.item-details h2 { font-size: 1.35rem; font-weight: 600; margin-bottom: 4px; }
.item-meta { font-size: 0.85rem; color: var(--color-text-muted); }

.results-summary { display: flex; gap: 32px; }
.summary-stat { text-align: center; }
.summary-stat .stat-label { display: block; font-size: 0.75rem; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 4px; }
.summary-stat .stat-value { font-size: 1.1rem; font-weight: 600; }
.stat-value.price { color: var(--price-gold); }

/* --- Price Check: Results table --- */
.results-table-wrapper { overflow-x: auto; }
.results-table { width: 100%; border-collapse: collapse; }
.results-table th, .results-table td { padding: 14px 20px; text-align: left; vertical-align: top; }
.results-table th { background: rgba(0, 0, 0, 0.2); font-size: 0.8rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--color-text-muted); }
.results-table tbody tr { border-top: 1px solid rgba(255, 255, 255, 0.05); }
.results-table tbody tr:first-child { background: rgba(128, 195, 66, 0.1); }
.results-table .realm-name { font-weight: 500; }
.results-table .price-cell { font-family: 'JetBrains Mono', 'Fira Code', monospace; white-space: nowrap; }
.results-table .quantity-cell { color: var(--color-text-muted); }
.results-table .diff-cell { font-size: 0.9rem; }
.diff-lowest { color: var(--color-success); font-weight: 600; }
.diff-low { color: var(--color-success); }
.diff-medium { color: var(--color-warning); }
.diff-high { color: var(--color-error); }
.realm-separator { color: rgb(148, 163, 184); margin: 0 4px; }

.commodity-note {
    padding: 16px 24px;
    font-size: 0.9rem;
    color: var(--color-text-muted);
    background: rgba(0, 0, 0, 0.2);
    border-top: 1px solid var(--color-border);
}

.panel-info { padding: 16px 20px; }
.data-status { font-size: 0.85rem; color: var(--color-text-muted); display: flex; flex-wrap: wrap; align-items: center; gap: 8px; }
.status-separator { opacity: 0.5; }
#last-updated { color: var(--color-text-light); }

.item-wowhead-link { text-decoration: none; }
.item-wowhead-link:hover, .item-wowhead-link:focus { text-decoration: underline; }

/* --- Price Check: Browse panel --- */
.panel-browse { padding: 0; overflow: hidden; }
.browse-container { display: flex; min-height: 500px; }

.browse-sidebar {
    width: 30%;
    min-width: 220px;
    max-width: 320px;
    border-right: 1px solid var(--color-border);
    display: flex;
    flex-direction: column;
    max-height: 600px;
}

.browse-sidebar-title {
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-text-muted);
    padding: 12px 16px;
    margin: 0;
    border-bottom: 1px solid rgba(99, 179, 237, 0.1);
}

.category-tree { padding: 8px 0; overflow-y: auto; flex: 1; }
.category-item { cursor: pointer; user-select: none; }

.category-label {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    font-size: 0.9rem;
    color: var(--color-text-light);
    transition: background var(--transition-fast), color var(--transition-fast);
}

.category-label:hover { background: rgba(39, 170, 226, 0.1); color: var(--color-primary); }
.category-item.active > .category-label { background: rgba(39, 170, 226, 0.15); color: var(--color-primary); font-weight: 500; }
.category-arrow { font-size: 0.7rem; transition: transform var(--transition-normal); color: var(--color-text-dark); width: 12px; }
.category-item.expanded > .category-label .category-arrow { transform: rotate(90deg); }
.category-children { display: none; padding-left: 12px; }
.category-item.expanded > .category-children { display: block; }
.category-count { font-size: 0.75rem; color: var(--color-text-dark); margin-left: auto; }

/* --- Price Check: Browse content --- */
.browse-content { flex: 1; display: flex; flex-direction: column; overflow: hidden; }

.browse-table-header {
    display: flex;
    padding: 0 16px;
    background: rgba(0, 0, 0, 0.2);
    border-bottom: 1px solid var(--color-border);
}

.browse-col {
    padding: 12px 0;
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-text-muted);
    display: flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    transition: color var(--transition-fast);
}

.browse-col:hover { color: var(--color-text-light); }
.browse-col-name { flex: 1; min-width: 0; }
.browse-col-price { width: 120px; flex-shrink: 0; }
.browse-col-realm { width: 120px; flex-shrink: 0; }
.browse-col-available { width: 100px; flex-shrink: 0; }

.sort-arrow { font-size: 0.7rem; opacity: 0; transition: opacity var(--transition-fast); }
.browse-col.sorted .sort-arrow { opacity: 1; }
.sort-arrow::after { content: '▲'; }
.browse-col.sorted.desc .sort-arrow::after { content: '▼'; }

.browse-items { flex: 1; overflow-y: auto; max-height: 559px; }
.browse-empty { display: flex; align-items: center; justify-content: center; gap: 12px; height: 100%; min-height: 300px; color: var(--color-text-dark); font-size: 1rem; }
.browse-empty-arrow { font-size: 1.5rem; }

.browse-row {
    display: flex;
    align-items: center;
    padding: 10px 16px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    transition: background var(--transition-fast);
    cursor: pointer;
}

.browse-row:hover { background: rgba(39, 170, 226, 0.05); }
.browse-row-name { flex: 1; min-width: 0; display: flex; align-items: center; gap: 10px; }
.browse-item-icon { width: 28px; height: 28px; border-radius: 4px; background: rgba(0, 0, 0, 0.3); flex-shrink: 0; }
.browse-item-name { font-size: 0.9rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.browse-row-price { width: 120px; font-family: 'JetBrains Mono', 'Fira Code', monospace; font-size: 0.85rem; flex-shrink: 0; }
.browse-row-realm { width: 120px; font-size: 0.85rem; color: var(--color-success); flex-shrink: 0; }
.browse-row-available { width: 100px; font-size: 0.85rem; color: var(--color-success); flex-shrink: 0; }
.browse-not-listed { color: var(--color-text-dark); font-style: italic; }

.browse-row-loader {
    display: none;
    width: 14px;
    height: 14px;
    border: 2px solid rgba(39, 170, 226, 0.2);
    border-top-color: var(--color-primary);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    margin-left: 8px;
    flex-shrink: 0;
}

.browse-row.loading .browse-row-loader { display: inline-block; }
.browse-loading { display: flex; align-items: center; justify-content: center; height: 100%; min-height: 300px; color: var(--color-text-muted); }

/* Browse table mobile card layout */
@media (max-width: 959px) {
    .browse-table-header {
        display: none;
    }
    
    .browse-empty-arrow {
        display: none;
    }
    
    .browse-row {
        flex-wrap: wrap;
        gap: 8px;
        padding: 12px 16px;
    }
    
    .browse-row-name {
        flex: 0 0 100%;
        min-width: 0;
    }
    
    .browse-item-name {
        white-space: normal;
        word-break: break-word;
    }
    
    .browse-row-price,
    .browse-row-realm,
    .browse-row-available {
        width: auto;
        flex: 1;
        font-size: 0.8rem;
    }
    
    .browse-row-available {
        max-width: 90px;
    }
    
    .browse-row-price::before {
        content: 'Price: ';
        color: var(--color-text-muted);
        font-family: inherit;
    }
    
    .browse-row-realm::before {
        content: 'Realm: ';
        color: var(--color-text-muted);
    }
    
    .browse-row-available::before {
        content: 'Qty: ';
        color: var(--color-text-muted);
    }
}

@media (max-width: 600px) {
    .browse-row {
        flex-direction: column;
        text-align: center;
    }
    
    .browse-row-name,
    .browse-row-price,
    .browse-row-realm,
    .browse-row-available {
        width: 100%;
        max-width: none;
    }
    
    .browse-row-name {
        justify-content: center;
    }
}

/* --- Price Check Results: Mobile --- */
@media (max-width: 959px) {
    .results-header {
        flex-direction: column;
        gap: 16px;
        padding: 16px;
    }
    
    .item-info {
        min-width: 0;
        flex-direction: column;
        text-align: center;
        gap: 12px;
    }
    
    .item-details h2 {
        font-size: 1.15rem;
    }
    
    .results-summary {
        width: 100%;
        justify-content: space-around;
        gap: 16px;
    }
    
    .results-table thead {
        display: none;
    }
    
    .results-table tbody tr {
        display: flex;
        flex-wrap: wrap;
        padding: 12px;
        gap: 8px;
    }
    
    .results-table td {
        padding: 0;
        border: none;
    }
    
    .results-table td:nth-child(1) {
        flex: 0 0 100%;
        font-weight: 600;
    }
    
    .results-table td:nth-child(2),
    .results-table td:nth-child(3),
    .results-table td:nth-child(4) {
        flex: 0 0 100%;
        font-size: 0.85rem;
    }
    
    .results-table td:nth-child(2)::before {
        content: 'Price: ';
        color: var(--color-text-muted);
        font-family: inherit;
    }
    
    .results-table td:nth-child(3)::before {
        content: 'Qty: ';
        color: var(--color-text-muted);
    }
    
    .results-table td:nth-child(4)::before {
        content: 'Diff: ';
        color: var(--color-text-muted);
    }
}


/* ============================================
   ACCOUNT PAGE
   ============================================ */

.account-profile {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 24px;
}

.account-bnet-icon {
    width: 42px;
    height: 42px;
}

#account .account-info {
    width: 100%;
}

.account-battletag {
    font-size: 1.5rem;
    font-weight: 600;
    margin: 0 0 4px 0;
}

.account-session {
    color: var(--color-text-muted);
    font-size: 0.9rem;
    margin: 0;
}

.account-row {
    display: flex;
    gap: 32px;
    padding-top: 24px;
    padding-bottom: 24px;
    border-top: 1px solid var(--color-border);
}

.account-section {
    flex: 0 0 calc(50% - 16px);
}

.account-section h3 {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 1rem;
    font-weight: 600;
    margin: 0 0 12px 0;
    color: var(--color-text);
}

.account-section h3 .h3-icon {
    width: 14px;
    height: 14px;
    filter: brightness(0) invert(1);
}

.account-section .btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.account-section .btn .btn-icon {
    width: 18px;
    height: 18px;
}

.account-help {
    color: var(--color-text-muted);
    font-size: 0.9rem;
    margin: 0 0 12px 0;
}

.account-muted {
    color: var(--color-text-muted);
    font-size: 0.9rem;
    font-style: italic;
    margin: 0;
}

.account-arthas {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
    margin-bottom: 12px;
    border-radius: 4px;
}

.btn-danger {
    background: var(--color-error);
    color: #fff;
    border: none;
}

.btn-danger:hover {
    background: #dc2626;
}

.confirm-inline {
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 16px;
    margin-top: 12px;
}

.confirm-inline p {
    margin: 0;
    font-weight: 500;
}

#delete-data-confirm {
    margin-bottom: 12px;
}

.confirm-buttons {
    display: flex;
    gap: 12px;
}

.success-msg {
    color: var(--color-success);
    margin: 0;
}

/* Account Page Responsive */
@media (max-width: 959px) {
    .account-profile {
        flex-direction: column;
        text-align: center;
    }
}


/* ============================================
   NAME CHECKER
   ============================================ */

.name-search .grid { display: grid; gap: 16px; grid-template-columns: 1fr; }
.name-search .result { margin-top: 20px; padding: 16px; border-radius: 10px; background: rgba(255,255,255,0.02); border: 1px solid var(--color-border-light); display: none; margin-top: 8px; font-size: 0.85rem; color: var(--color-text-muted); }
.name-search .actions { display: flex; gap: 10px; margin-top: 16px; }
.name-search .btn { width: 100%; }
.name-search .btn-wrapper { display: flex; align-items: flex-end; }
.name-search .progress-container.hidden { display: none; }
.name-search details { margin-top: 12px; }
.name-search details summary { cursor: pointer; }
.name-search details pre#diag { margin-top: 8px; white-space: pre-wrap; word-break: break-all; }
.name-search .names-wrapper { margin-top: 16px; }
.name-search #checkBtn { margin-top: 24px; }

/* Name Search Responsive */
@media (max-width: 959px) {
    .name-search .result {
        text-align: center;
    }
}

@media (max-width: 640px) {
    .name-search .actions {
        flex-direction: column;
    }
    
    .name-search .result {
        padding: 12px;
    }
    
    .name-search textarea {
        min-height: 120px;
    }
}

@media (max-width: 400px) {
    .name-search .panel {
        padding: 16px;
    }
    
    .name-search .btn {
        padding: 12px 16px;
    }
}


/* ============================================
   MEDIA QUERIES
   ============================================ */

/* --- Hub/Home Responsive --- */
@media (max-width: 700px) {
    .footer-tools {
        gap: 24px 32px;
    }
}

@media (max-width: 600px) {
    .hub .container {
        padding: 0 16px 40px 16px;
    }
    
    .footer-tools {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }
    
    /* Center the 5th item (Azeroth Living) if odd number */
    .footer-tool-link:last-child:nth-child(odd) {
        grid-column: 1 / -1;
    }
}

@media (max-width: 400px) {
    .footer-tools {
        grid-template-columns: 1fr;
    }
}

/* --- Shared Responsive --- */
@media (max-width: 959px) {
    /* Tool page headers */
    .site-header:not(.hub) {
        flex-wrap: wrap;
        padding: 12px 16px;
    }
    
    .site-header:not(.hub) h1 {
        font-size: 1.75rem;
        text-align: center;
    }
    
    .site-header:not(.hub) .header-right {
        order: 3;
        width: 100%;
        justify-content: center;
        margin-top: 12px;
        padding-top: 12px;
        padding-bottom: 15px;
        border-top: 1px solid var(--color-border-light);
    }
    
    .user-menu-buttons {
        gap: 15px;
    }

    .site-footer {
        margin-top: 0;
    }

    .search-input-wrapper input {
        text-align: center;
    }

    .site-header:not(.hub) .header-right {
        padding-bottom: 15px;
    }

    .site-header:not(.hub) .header-home-link {
        order: 4;
        width: 100%;
        display: none;
        justify-content: center;
        margin-left: 0;
        margin-top: 12px;
        padding-top: 12px;
        padding-left: 0;
        border-left: none;
        border-top: 1px solid var(--color-border-light);
    }
    
    .hub .header-home-link {
        display: none !important;
    }
    
    .header-left {
        flex-direction: column;
        gap: 0;
    }
    
    .header-icon, .hub .header-icon {
        width: 60px;
        height: 60px;
    }
    
    .header-home-link img {
        width: 24px;
        height: 24px;
    }

     .hub .container {
        padding: 0 12px 24px 12px;
        max-width: 100%;
    }

    .tools-grid {
        display: flex;
        flex-direction: column;
        gap: 16px;
    }

    .tool-card {
        padding: 20px;
        border-radius: 12px;
        text-align: center;
    }
    
    /* Badge breaks to new line */
    .badge {
        display: block;
        margin-top: 4px;
    }

    .tool-card h2 {
        width: fit-content;
        margin: 0 auto 8px auto;
    }

    .tool-card.wide {
        grid-column: span 1;
    }

    .tool-card.wide .tool-card-inner {
        flex-direction: column;
        text-align: center;
    }

    .tool-card.wide .tool-card-content {
        width: 100%;
    }

    .tool-card.wide .tool-icon {
        margin: 0 auto 16px;
    }

    .tool-card.wide .tool-card-badge {
        width: 100%;
        padding: 16px;
    }
    
    /* User menu - battletag on top, icons below */
    .user-menu {
        display: flex;
        flex-wrap: wrap;
        gap: 15px;
        justify-content: center;
    }

    .user-name {
        width: 100%;
        justify-content: center;
        text-align: center;
    }

    .btn-home { display: inline-flex; }
    .header-home-link { display: none; }

    .tabs { flex-direction: column; }
    .tabs button { width: 100%; justify-content: center; }
}

@media (max-width: 400px) {
    /* Very small screens */
    .btn-sm {
        padding: 5px 10px;
        font-size: 0.8rem;
    }
}

/* --- Dashboard Responsive --- */
@media (max-width: 1150px) {
    .panel-filters .filters-row, .mounts-filters-row, .pets-filters-row, .toys-filters-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    
    .accounts-grid, .mounts-grid, .pets-grid, .toys-grid,
    .stat-classes, .combo-class-list, .duplicates-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .panel-stats .stats-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    
    .section-nav-links {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Dashboard panel headers: stack title and buttons between 960-1100px */
@media (max-width: 1100px) and (min-width: 960px) {
    /* Stack title and buttons for non-collapsible panels */
    .panel-header-accounts,
    .panel-header-reserved {
        flex-wrap: wrap;
    }

    .panel-header-accounts h2,
    .panel-header-reserved h2 {
        width: 100%;
        margin-bottom: 10px;
    }

    .panel-header-accounts .panel-header-actions,
    .panel-header-reserved .panel-header-actions {
        margin-left: 0;
        width: 100%;
    }

    .panel-header-accounts .panel-header-actions .btn,
    .panel-header-reserved .panel-header-actions .btn {
        flex: 1;
    }

    /* Collapsible panels with multiple buttons: stack when expanded */
    .panel-combos.is-expanded .panel-header,
    .panel-mounts.is-expanded .panel-header,
    .panel-pets.is-expanded .panel-header,
    .panel-toys.is-expanded .panel-header {
        flex-wrap: wrap;
    }

    .panel-combos.is-expanded .panel-header h2,
    .panel-mounts.is-expanded .panel-header h2,
    .panel-pets.is-expanded .panel-header h2,
    .panel-toys.is-expanded .panel-header h2 {
        width: 100%;
        margin-bottom: 10px;
    }

    .panel-combos.is-expanded .panel-header-actions,
    .panel-mounts.is-expanded .panel-header-actions,
    .panel-pets.is-expanded .panel-header-actions,
    .panel-toys.is-expanded .panel-header-actions {
        margin-left: 0;
        width: 100%;
    }

    .panel-combos.is-expanded .panel-header-actions .btn,
    .panel-mounts.is-expanded .panel-header-actions .btn,
    .panel-pets.is-expanded .panel-header-actions .btn,
    .panel-toys.is-expanded .panel-header-actions .btn {
        flex: 1;
    }
}

@media (max-width: 959px) {
    .panel-filters .filters-row, .mounts-filters-row, .pets-filters-row, .toys-filters-row,
    .accounts-grid, .mounts-grid, .pets-grid, .toys-grid,
    .stat-classes, .combo-class-list, .duplicates-list, .panel-stats .stats-row, .section-nav-links {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .account-row {
        flex-direction: column;
        gap: 24px;
    }

    .account-section {
        flex: 0 0 100%;
    }

    .account-section + .account-section {
        padding-top: 24px;
        border-top: 1px solid var(--color-border-light);
    }

    #btn-refresh-data,
    #btn-reset-filters,
    .panel-header .btn:disabled {
        width: 100%;
    }

    .mount-card,
    .pet-card,
    .toy-card {
        flex-direction: column;
        text-align: center;
        align-items: center;
    }

    .mount-favorite,
    .pet-favorite,
    .toy-favorite {
        margin-left: 0;
    }

    .pet-details {
        justify-content: center;
    }
}

@media (max-width: 959px) {
    body {
        margin: 0;
    }
}

@media (max-width: 640px) {
    .panel-combos .combos-columns { grid-template-columns: 1fr; }
    .panel-filters .filters-row, .mounts-filters-row, .pets-filters-row, .toys-filters-row,
    .accounts-grid, .mounts-grid, .pets-grid, .toys-grid,
    .stat-classes, .combo-class-list, .duplicates-list, .panel-stats .stats-row, .section-nav-links {
        grid-template-columns: 1fr;
    }
    .combo-race-title { text-align: center; }
    .toy-content { gap: 4px; }
    .mount-description, .pet-description { padding-bottom: 0; }
    .spec-details { flex-direction: column; }
}

@media (max-width: 350px) {
    .combo-faction-row, .account-header, .server-header { flex-direction: column; gap: 8px; }
    .account-header h3 { margin: 0; }
    .account-section .btn { gap: 5px; }
    .user-menu-buttons { gap: 5px; }
}

@media (max-width: 299px) {
    .character-dashboard .panel { padding: 5%; }
    .character-dashboard .site-header h1 { font-size: 1.5rem; text-align: center; }
    .stats-row { text-align: center; }
    .stat-favorite-content { flex-direction: column; gap: 2px; }
    .class-chip { flex-direction: column; gap: 3px; flex-wrap: nowrap; align-items: center; }
    .char-tile { align-items: center; text-align: center; gap: 15px; }
    .char-main, .char-faction, .char-loader { flex: 100%; max-width: 100%; }
    .character-name { text-align: center; }
    .class-name, .spec-name { display: none; }
    .guild, .spec, .ilvl, .profession { justify-content: center; width: 100%; }
    .btn, .progress-bar, .character-race, .character-profs, .character-gold, .character-gender,
    .combo-gender-flag, #level-range-slider.ui-slider, #level-range-slider .ui-slider-range,
    .section-nav-links a { border-radius: var(--radius-md); }
}

/* --- Price Check Responsive --- */
@media (max-width: 959px) {
    .search-container { flex-direction: column; }
    .price-check .search-container .btn { width: 100%; }
    .results-header { 
        flex-direction: column; 
        align-items: center; 
        text-align: center;
        justify-content: center;
    }
    .item-info { 
        flex-direction: column; 
        align-items: center; 
        text-align: center;
        justify-content: center;
    }
    .results-summary { 
        width: 100%; 
        justify-content: center; 
        text-align: center;
    }
    .summary-stat { text-align: center; }
    .results-table th, .results-table td { padding: 12px 14px; text-align: center; }
    .browse-container { flex-direction: column; }
    .browse-sidebar { 
        width: 100%; 
        max-width: none; 
        max-height: none; 
        border-right: none; 
        border-bottom: 1px solid var(--color-border); 
    }
    .browse-items { max-height: none; }
    .browse-empty { padding: 5%; text-align: center; }
    .data-status { justify-content: center; }
    #results-stats {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }
    #results-stats select {
        width: 100%;
        text-align: center;
    }
}

@media (max-width: 600px) {
    .price-check .site-header { flex-wrap: wrap; }
    .header-icon { width: 40px; height: 40px; }
    .price-check .site-header h1 { font-size: 1.5rem; }
    .results-summary { flex-direction: column; gap: 12px; }
    .browse-row-name { flex-direction: column; }
}

/* --- Name Search Responsive --- */
@media (min-width: 959px) {
    .name-search .grid { grid-template-columns: 140px 180px 1fr 200px 120px; align-items: start; }
    .name-search .grid-batch { grid-template-columns: 140px 180px 1fr; }
    .name-search .toggle div { padding-top: 8px; }
}

@media (max-width: 958px) {
    .name-search #checkBtn { margin-top: 0; }
    
    /* Name search table responsive - stack rows */
    .name-search thead {
        display: none;
    }
    
    .name-search table {
        width: 100%;
        display: block;
    }
    
    .name-search tbody {
        display: block;
    }
    
    .name-search tr {
        display: flex;
        flex-direction: column;
        padding: 12px 0;
        border-bottom: 1px solid var(--color-border);
    }
    
    .name-search td {
        display: block;
        width: 100% !important;
        min-width: 100% !important;
        padding: 4px 0;
        text-align: center;
    }
    
    .name-search td:first-child {
        width: 100% !important;
        min-width: 100% !important;
    }
    
    #batchTable table {
        width: 100%;
        display: block;
    }
    
    #batchTable thead {
        display: none;
    }
    
    #batchTable tbody {
        display: block;
    }
    
    #batchTable tr {
        display: flex;
        flex-direction: column;
        padding: 12px 0;
        border-bottom: 1px solid var(--color-border);
    }
    
    #batchTable td {
        display: block;
        width: 100% !important;
        padding: 4px 0;
        text-align: center;
    }
}

@media (max-width: 640px) {
    .name-search .actions { flex-direction: column; }
}

@media (max-width: 450px) {
    .name-search .tabs { flex-direction: column; }
    .name-search .tabs button { width: 100%; }
}


/* ============================================
   ADMIN PANEL
   ============================================ */

.admin .admin-main-panel {
    /* No max-width - uses panel defaults */
}

.admin .admin-content {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.admin .admin-row {
    display: flex;
    gap: 1.5rem;
}

.admin .admin-panel {
    flex: 1;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 1.25rem;
}

.admin .admin-panel-full {
    flex: none;
    width: 100%;
}

.admin .admin-panel h2 {
    font-size: 1.1rem;
    font-weight: 600;
    margin: 0 0 1.25rem 0;
    color: var(--color-text);
}

.admin .admin-panel h3 {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin: 1.25rem 0 0.75rem 0;
}

.admin .admin-panel h3:first-of-type {
    margin-top: 0;
}

/* Settings Panel */
.admin .settings-section {
    margin-bottom: 1.25rem;
}

.admin .settings-section:last-child {
    margin-bottom: 0;
}

.admin .settings-section > label {
    display: block;
    font-size: 0.9rem;
    font-weight: 500;
    margin-bottom: 0.5rem;
    color: var(--color-text);
}

.admin .settings-row {
    display: flex;
    gap: 0.5rem;
}

.admin .settings-row .input {
    flex: 1;
}

.admin .settings-help {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    margin: 0.5rem 0 0 0;
}

.admin .settings-message {
    font-size: 0.85rem;
    margin: 0.5rem 0 0 0;
    padding: 0;
    border-radius: 4px;
}

.admin .settings-message.success {
    color: var(--color-success);
    background: rgba(46, 204, 113, 0.1);
}

.admin .settings-message.error {
    color: var(--color-error);
    background: rgba(231, 76, 60, 0.1);
}

.admin .settings-message.warning {
    color: var(--color-warning);
    background: rgba(251, 191, 36, 0.1);
}

.admin .radio-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.admin .radio-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.9rem;
    cursor: pointer;
    text-transform: capitalize;
}

.admin .radio-label input[type="radio"] {
    accent-color: var(--color-primary);
}

/* Whitelist */
.admin .whitelist-entries {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
    max-height: 150px;
    overflow-y: auto;
}

.admin .whitelist-entry {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem 0;
    background: var(--color-bg);
    border-radius: 6px;
    text-transform: capitalize;
    font-size: 0.9rem;
}

.admin .whitelist-entry .btn-icon-only {
    background: none;
    border: none;
    color: var(--color-text-muted);
    font-size: 1.2rem;
    cursor: pointer;
    padding: 0 0.25rem;
    line-height: 1;
}

.admin .whitelist-entry .btn-icon-only:hover {
    color: var(--color-error);
}

.admin .whitelist-add {
    display: flex;
    gap: 0.5rem;
}

.admin .whitelist-add .autocomplete-wrapper {
    flex: 1;
    position: relative;
}

.admin .autocomplete-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--color-bg-panel);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    margin-top: 4px;
    max-height: 200px;
    overflow-y: auto;
    display: none;
    z-index: 100;
}

.admin .autocomplete-dropdown.active {
    display: block;
}

.admin .autocomplete-item {
    padding: 0.5rem 0.75rem;
    cursor: pointer;
    font-size: 0.9rem;
}

.admin .autocomplete-item:hover {
    background: var(--color-bg);
}

/* Users Panel */
.admin .users-controls {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.admin .users-controls label {
    font-size: 0.9rem;
    color: var(--color-text-muted);
}

.admin .users-controls .input {
    width: auto;
}

.admin .users-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    max-height: 300px;
    overflow-y: auto;
}

.admin .user-item {
    padding: 0.75rem 0;
    background: var(--color-bg);
    border-radius: 8px;
}

.admin .user-info {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.25rem;
}

.admin .user-bnet-icon {
    width: 16px;
    height: 16px;
    opacity: 0.7;
}

.admin .user-battletag {
    font-weight: 500;
}

.admin .user-meta {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    margin-bottom: 0.5rem;
}

.admin .user-actions {
    display: flex;
    gap: 0.5rem;
}

.admin .user-confirm {
    margin-top: 0.75rem;
    padding: 0.75rem;
    background: rgba(231, 76, 60, 0.1);
    border-radius: 6px;
}

.admin .user-confirm p {
    margin: 0 0 0.5rem 0;
    font-size: 0.9rem;
}

.admin .user-confirm .confirm-buttons {
    display: flex;
    gap: 0.5rem;
}

.admin .users-count {
    font-size: 0.85rem;
    color: var(--color-text-muted);
    margin: 0.75rem 0 0 0;
}

/* Stats Panel */
.admin .stats-section {
    margin-bottom: 1rem;
}

.admin .stats-section:last-child {
    margin-bottom: 0;
}

.admin .stat-row {
    display: flex;
    justify-content: space-between;
    padding: 0.35rem 0;
    font-size: 0.9rem;
}

.admin .stat-label {
    color: var(--color-text-muted);
}

.admin .stat-value {
    font-weight: 500;
}

/* Log Viewer Panel */
.admin .logs-controls {
    margin-bottom: 1rem;
}

.admin .logs-controls .input {
    width: 100%;
}

.admin .log-content {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 1rem;
    height: 363px;
    overflow-y: auto;
    font-family: monospace;
    font-size: 0.8rem;
}

.admin .log-content pre {
    margin: 0;
    white-space: pre-wrap;
    word-break: break-all;
}

.admin .log-placeholder {
    color: var(--color-text-muted);
    margin: 0;
}

.admin .log-error {
    color: var(--color-error);
    margin: 0;
}

.admin .log-info {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    margin: 0.5rem 0 0 0;
}

/* Name Cloud Panel */
.admin .name-stats {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.admin .name-stat {
    background: var(--color-bg);
    border-radius: 8px;
    padding: 1rem;
    text-align: center;
}

.admin .name-stat-label {
    display: block;
    font-size: 0.75rem;
    color: var(--color-text-muted);
    margin-bottom: 0.35rem;
}

.admin .name-stat-value {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-size: 1rem;
    font-weight: 600;
}

.admin .name-stat-value .class-icon {
    width: 18px;
    height: 18px;
}

.admin .name-stat .gender-male,
.admin .name-stat .gender-female {
    display: inline-flex;
    align-items: center;
    gap: 3px;
}

.admin .name-stat .gender-male { color: var(--color-male); }
.admin .name-stat .gender-female { color: var(--color-female); margin-left: 8px; }

.admin .name-stat .gender-icon {
    width: 14px;
    height: 14px;
}

.admin .name-stat .gender-icon.female {
    width: 16px;
    height: 16px;
}

.admin .names-textarea {
    width: 100%;
    height: 150px;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 1rem;
    font-size: 0.9rem;
    color: var(--color-text);
    resize: vertical;
    font-family: inherit;
}

.admin .names-actions {
    display: flex;
    justify-content: flex-end;
    margin-top: 1rem;
}

/* Mount Colors Panel */
.admin .mount-colors-stats {
    font-size: 0.9rem;
    font-weight: normal;
    color: var(--color-text-muted);
}

.admin .mount-colors-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.admin .mount-stat-card {
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 1rem;
    text-align: center;
}

.admin .mount-stat-card .mount-stat-value {
    display: block;
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--color-text);
    line-height: 1.2;
}

.admin .mount-stat-card .mount-stat-label {
    display: block;
    font-size: 0.8rem;
    color: var(--color-text-muted);
    margin-top: 0.25rem;
}

.admin .mount-stat-card.highlight-new.has-items {
    border-color: var(--color-primary);
    background: rgba(var(--color-primary-rgb), 0.1);
}

.admin .mount-stat-card.highlight-new.has-items .mount-stat-value {
    color: var(--color-primary);
}

.admin .mount-stat-card.highlight-flagged.has-items {
    border-color: var(--color-warning);
    background: rgba(251, 191, 36, 0.1);
}

.admin .mount-stat-card.highlight-flagged.has-items .mount-stat-value {
    color: var(--color-warning);
}

.admin .mount-colors-cost {
    display: flex;
    gap: 1.5rem;
    align-items: center;
    margin-bottom: 1.25rem;
    font-size: 0.9rem;
    color: var(--color-text);
}

.admin .mount-colors-cost .cost-note {
    color: var(--color-text-muted);
    font-size: 0.8rem;
}

.admin .mount-colors-actions {
    display: flex;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.admin .mc-confirm {
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 1rem;
}

.admin .mc-confirm p {
    margin: 0 0 0.5rem 0;
}

.admin .mc-confirm-subtitle {
    color: var(--color-text-muted);
    font-size: 0.9rem;
}

.admin .mc-confirm .confirm-buttons {
    display: flex;
    gap: 0.5rem;
    margin-top: 1rem;
}

.admin .mount-colors-batches {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--color-border);
}

.admin .mount-colors-batches h3 {
    margin: 0 0 1rem 0;
}

.admin .batches-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.admin .batches-empty {
    color: var(--color-text-muted);
    font-size: 0.9rem;
    font-style: italic;
}

.admin .batch-item {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.5rem 0.75rem;
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid var(--color-border);
    border-radius: 6px;
    font-size: 0.85rem;
}

.admin .batch-item .batch-date {
    color: var(--color-text-muted);
    min-width: 90px;
}

.admin .batch-item .batch-type {
    color: var(--color-text);
    font-weight: 500;
    min-width: 100px;
}

.admin .batch-item .batch-count {
    color: var(--color-text-muted);
}

.admin .batch-item .batch-cost {
    color: var(--color-text-muted);
    margin-left: auto;
}

.admin .batch-item .batch-errors {
    color: var(--color-error);
}

.admin .batch-errors-expandable {
    cursor: pointer;
    text-decoration: underline;
    text-decoration-style: dotted;
}

.admin .batch-errors-expandable:hover {
    text-decoration-style: solid;
}

.admin .batch-item-wrapper {
    display: flex;
    flex-direction: column;
}

.admin .batch-error-details {
    margin-top: 0.5rem;
    margin-left: 1rem;
    padding: 0.5rem 0.75rem;
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.3);
    border-radius: 6px;
    font-size: 0.8rem;
}

.admin .batch-error-detail {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 0.25rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.admin .batch-error-detail:last-child {
    border-bottom: none;
}

.admin .batch-error-detail a {
    color: var(--color-text);
    text-decoration: none;
    font-weight: 500;
}

.admin .batch-error-detail a:hover {
    color: var(--color-primary);
}

.admin .batch-error-msg {
    color: var(--color-text-muted);
    font-size: 0.75rem;
    text-align: right;
}

.admin .batch-error-truncated {
    margin-top: 0.5rem;
    padding-top: 0.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    color: var(--color-text-muted);
    font-style: italic;
    text-align: center;
}

/* Mount Colors Progress */
.admin .mc-progress {
    padding: 1rem;
}

.admin .mc-progress-bar {
    height: 20px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 10px;
    overflow: hidden;
    margin-bottom: 0.75rem;
}

.admin .mc-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--color-primary), var(--color-primary-light, #60a5fa));
    border-radius: 10px;
    transition: width 0.3s ease;
}

.admin .mc-progress-text {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.9rem;
}

.admin .mc-progress-message {
    color: var(--color-text);
}

.admin .mc-progress-count {
    color: var(--color-text-muted);
    font-variant-numeric: tabular-nums;
}

@media (max-width: 959px) {
    .admin .mount-colors-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .admin .mount-colors-cost {
        flex-wrap: wrap;
    }

    .admin .mount-colors-actions {
        flex-wrap: wrap;
    }
}

@media (max-width: 640px) {
    .admin .mount-colors-grid {
        grid-template-columns: 1fr;
    }

    .admin .batch-item {
        flex-wrap: wrap;
    }

    .admin .batch-item .batch-cost {
        margin-left: 0;
    }
}

/* Mount Browser */
.admin .mount-browser-section {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--color-border);
}

.admin .mount-browser-section h3 {
    margin: 0 0 1rem 0;
}

.admin .mount-browser-controls {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
}

.admin .mount-browser-search {
    flex: 1;
    max-width: 300px;
}

.admin .mount-browser-search .input {
    width: 100%;
}

.admin .mount-browser-info {
    color: var(--color-text-muted);
    font-size: 0.9rem;
}

.admin .mount-flagged-section {
    margin-bottom: 1.5rem;
    padding: 1rem;
    background: rgba(251, 191, 36, 0.05);
    border: 1px solid var(--color-warning);
    border-radius: 8px;
}

.admin .mount-flagged-section h4 {
    margin: 0 0 1rem 0;
    color: var(--color-warning);
}

.admin .mount-browser-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
}

.admin .mount-browser-empty {
    grid-column: 1 / -1;
    text-align: center;
    color: var(--color-text-muted);
    padding: 2rem;
}

.admin .mount-browser-item {
    position: relative;
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    overflow: hidden;
    transition: border-color 0.2s;
}

.admin .mount-browser-item:hover {
    border-color: var(--color-primary);
}

.admin .mount-browser-item.flagged {
    border-color: var(--color-warning);
}

.admin .mount-browser-item.not-analyzed {
    opacity: 0.7;
}

.admin .mount-image-link {
    display: block;
    aspect-ratio: 1;
    background: #1a1a1a;
    overflow: hidden;
}

.admin .mount-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.2s;
}

.admin .mount-browser-item:hover .mount-image {
    transform: scale(1.05);
}

.admin .mount-info {
    padding: 0.75rem;
}

.admin .mount-name {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    font-weight: 600;
    color: var(--color-text);
    text-decoration: none;
    font-size: 0.9rem;
    line-height: 1.3;
}

.admin .mount-name:hover {
    color: var(--color-primary);
}

.admin .mount-name .icon-external {
    width: 12px;
    height: 12px;
    opacity: 0.5;
}

.admin .mount-source {
    display: block;
    font-size: 0.75rem;
    color: var(--color-text-muted);
    margin-top: 0.25rem;
}

.admin .mount-colors {
    margin-top: 0.5rem;
    padding-top: 0.5rem;
    border-top: 1px solid var(--color-border);
}

.admin .mount-color-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.25rem;
}

.admin .mount-color-row:last-child {
    margin-bottom: 0;
}

.admin .mount-color-row.mount-primary,
.admin .mount-color-row.mount-secondary {
    padding-bottom: 0.35rem;
    margin-bottom: 0.35rem;
    border-bottom: 1px solid var(--color-border);
}

.admin .mount-color-swatch {
    width: 16px;
    height: 16px;
    border-radius: 4px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    flex-shrink: 0;
}

.admin .mount-color-label {
    font-size: 0.75rem;
    color: var(--color-text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.admin .mount-no-colors {
    font-size: 0.75rem;
    color: var(--color-text-muted);
    font-style: italic;
}

.admin .mount-actions {
    display: flex;
    gap: 0.5rem;
    margin-top: 0.5rem;
    padding-top: 0.5rem;
    border-top: 1px solid var(--color-border);
}

.admin .mount-hint-input {
    flex: 1;
    font-size: 0.75rem;
    padding: 0.25rem 0.5rem;
    min-width: 0;
}

.admin .mount-actions .btn-sm {
    padding: 0.25rem 0.5rem;
}

.admin .mount-browser-item .btn-flag {
    position: absolute;
    top: 0.5rem;
    right: 0.5rem;
    opacity: 0;
    background: rgba(0, 0, 0, 0.7);
    border: 1px solid var(--color-border);
    color: var(--color-text-muted);
    padding: 0.25rem;
    border-radius: 4px;
    cursor: pointer;
    transition: opacity 0.2s, color 0.2s, border-color 0.2s;
}

.admin .mount-browser-item:hover .btn-flag {
    opacity: 1;
}

.admin .mount-browser-item .btn-flag:hover {
    color: var(--color-warning);
    border-color: var(--color-warning);
}

/* Mount Browser Pagination */
.admin .mount-browser-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.25rem;
    margin-top: 1.5rem;
    padding-top: 1rem;
    border-top: 1px solid var(--color-border);
}

.admin .mount-browser-pagination .btn-sm {
    min-width: 32px;
    padding: 0.25rem 0.5rem;
}

.admin .mount-page-ellipsis {
    color: var(--color-text-muted);
    padding: 0 0.5rem;
}

@media (max-width: 959px) {
    .admin .mount-browser-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .admin .mount-browser-controls {
        flex-wrap: wrap;
    }

    .admin .mount-browser-search {
        max-width: none;
        width: 100%;
    }
}

@media (max-width: 640px) {
    .admin .mount-browser-grid {
        grid-template-columns: 1fr;
    }

    .admin .mount-browser-item .btn-flag {
        opacity: 1;
    }

    .admin .mount-browser-pagination {
        flex-wrap: wrap;
    }
}

/* Character Renders Panel */
.admin .renders-stats {
    font-size: 0.9rem;
    font-weight: normal;
    color: var(--color-text-muted);
}

.admin .renders-import {
    margin-bottom: 1.5rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid var(--color-border);
}

.admin .renders-import label {
    display: block;
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.admin .renders-import-row {
    display: flex;
    gap: 0.5rem;
}

.admin .renders-import-row .input {
    flex: 1;
}

.admin .import-confirm {
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid var(--color-border);
    border-radius: 8px;
    padding: 1rem;
}

.admin .import-confirm p {
    margin: 0 0 0.5rem 0;
}

.admin .import-confirm p:last-of-type {
    margin-bottom: 1rem;
}

.admin .import-confirm .confirm-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.admin .import-confirm .confirm-buttons .btn {
    flex-shrink: 0;
}

.admin .renders-section {
    margin-bottom: 1.5rem;
}

.admin .renders-section:last-child {
    margin-bottom: 0;
}

.admin .renders-section h3.alliance {
    color: var(--color-alliance);
}

.admin .renders-section h3.horde {
    color: var(--color-horde);
}

.admin .renders-section h3 {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1rem;
    font-size: 0.95rem;
}

.admin .renders-section h3 .faction-icon {
    width: 20px;
    height: 20px;
}

.admin .renders-section h3.alliance .faction-icon {
    filter: invert(23%) sepia(86%) saturate(2094%) hue-rotate(190deg) brightness(95%) contrast(101%);
}

.admin .renders-section h3.horde .faction-icon {
    filter: invert(23%) sepia(90%) saturate(3100%) hue-rotate(350deg) brightness(94%) contrast(106%);
}

.admin .renders-section h4.alliance,
.admin .renders-section h4.horde {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.85rem;
    text-transform: uppercase;
    opacity: 0.9;
}

.admin .renders-section h4 .faction-icon {
    width: 16px;
    height: 16px;
}

.admin .renders-section h4.alliance .faction-icon {
    filter: invert(23%) sepia(86%) saturate(2094%) hue-rotate(190deg) brightness(95%) contrast(101%);
}

.admin .renders-section h4.horde .faction-icon {
    filter: invert(23%) sepia(90%) saturate(3100%) hue-rotate(350deg) brightness(94%) contrast(106%);
}

.admin .renders-section h4.alliance {
    color: var(--color-alliance);
}

.admin .renders-section h4.horde {
    color: var(--color-horde);
}

.admin .renders-section h4 {
    margin: 1rem 0 0.75rem 0;
    font-size: 0.9rem;
}

.admin .renders-section h4:first-of-type {
    margin-top: 0;
}

.admin .flagged-section {
    padding-bottom: 1.5rem;
    margin-bottom: 1.5rem;
    border-bottom: 1px solid var(--color-border);
}

.admin .renders-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}

@media (max-width: 959px) {
    .admin .renders-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .admin .renders-grid {
        grid-template-columns: 1fr;
    }
}

.admin .render-item {
    position: relative;
    background: rgba(255, 255, 255, 0.02);
    border: 2px solid var(--color-border);
    border-radius: 8px;
    overflow: hidden;
    transition: border-color var(--transition-fast);
}

.admin .render-item:hover {
    border-color: var(--color-border-light);
}

.admin .render-item.missing {
    border-color: var(--color-error);
}

.admin .render-item.flagged {
    border-color: var(--color-warning);
    background: rgba(251, 191, 36, 0.05);
}

.admin .render-image-link {
    display: block;
    aspect-ratio: 1;
    background: rgba(0, 0, 0, 0.2);
}

.admin .render-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
}

.admin .render-info {
    padding: 6px 8px;
    font-size: 0.85rem;
    line-height: 1.3;
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.admin .render-race {
    display: flex;
    align-items: center;
    gap: 4px;
    font-weight: 600;
    color: var(--color-text);
}

.admin .render-race .gender-icon {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
}

.admin .render-race .gender-icon.female {
    width: 16px;
    height: 16px;
}

.admin .render-class-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.admin .render-class {
    display: flex;
    align-items: center;
    gap: 4px;
}

.admin .render-class .class-icon {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
}

.admin .render-gender-icon {
    display: flex;
    align-items: center;
}

.admin .render-gender-icon .gender-icon {
    width: 14px;
    height: 14px;
}

.admin .render-gender-icon .gender-icon.female {
    width: 16px;
    height: 16px;
}

.admin .render-character {
    display: block;
    margin-top: 6px;
    padding-top: 6px;
    border-top: 1px solid var(--color-border);
    font-size: 0.85rem;
    color: var(--color-link);
    text-decoration: none;
}

.admin .render-character:hover {
    text-decoration: underline;
}

.admin .render-source {
    display: block;
    font-size: 0.65rem;
    color: var(--color-text-muted);
}

.admin .render-character .icon-external {
    width: 10px;
    height: 10px;
    margin-left: 4px;
    vertical-align: middle;
    opacity: 0.5;
}

.admin .render-character:hover .icon-external {
    opacity: 0.9;
}

.admin .renders-section h5 {
    margin: 0.75rem 0 0.5rem 0;
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--color-text-muted);
}

.admin .renders-section h5:first-of-type {
    margin-top: 0;
}

.admin .btn-flag,
.admin .btn-unflag {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 24px;
    height: 24px;
    padding: 0;
    border: none;
    border-radius: 4px;
    background: rgba(0, 0, 0, 0.6);
    color: var(--color-text-muted);
    cursor: pointer;
    opacity: 0;
    transition: opacity var(--transition-fast), background var(--transition-fast), color var(--transition-fast);
    display: flex;
    align-items: center;
    justify-content: center;
}

.admin .render-item:hover .btn-flag,
.admin .render-item:hover .btn-unflag {
    opacity: 1;
}

.admin .btn-flag:hover {
    background: var(--color-warning);
    color: #000;
}

.admin .btn-unflag:hover {
    background: var(--color-success);
    color: #fff;
}

.admin .render-item.flagged .btn-flag {
    opacity: 1;
    background: var(--color-warning);
    color: #000;
}

/* Admin Responsive */
@media (max-width: 959px) {
    .admin .admin-row {
        flex-direction: column;
    }
    
    .admin .name-stats {
        grid-template-columns: repeat(1, 1fr);
        gap: 0.75rem;
    }
    
    .admin .users-list {
        max-height: 250px;
    }
    
    .admin .log-content {
        height: auto;
        min-height: 250px;
    }
    .admin .admin-panel {
        padding: 1rem;
    }
    
    .admin .name-stat {
        padding: 0.75rem;
    }
    
    .admin .user-actions {
        flex-direction: column;
    }
    
    .admin .user-actions .btn {
        width: 100%;
    }

    .admin .names-actions {
        justify-content: center;
    }
}

/* ============================================
   MOUNT PALETTE STYLES
   ============================================ */

/* Two-Column Layout */
.mount-palette .palette-layout {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: var(--spacing-lg);
    align-items: start;
}

.mount-palette .palette-left {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.mount-palette .palette-right {
    /* No sticky - too tall */
}

/* ========================================
   DETAIL PANEL
   ======================================== */

.mount-palette .panel-mount-detail {
    position: relative;
}

.mount-palette .detail-close {
    display: none;
    position: absolute;
    top: var(--spacing-md);
    right: var(--spacing-md);
    background: none;
    border: none;
    color: var(--color-text-muted);
    cursor: pointer;
    padding: var(--spacing-xs);
    border-radius: var(--radius-sm);
    transition: all 0.15s;
    z-index: 1;
}

.mount-palette .detail-close:hover {
    color: var(--color-text);
    background: rgba(255, 255, 255, 0.1);
}

/* Two column: image left, info right */
.mount-palette .detail-body {
    display: flex;
    flex-direction: row;
    gap: var(--spacing-lg);
    align-items: start;
}

.mount-palette .detail-render {
    width: calc(50% - var(--spacing-lg) / 2);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
}

.mount-palette .detail-render-image {
    background: #181818;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    aspect-ratio: 1;
    width: 100%;
}

.mount-palette .detail-render-image a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    border-radius: var(--radius-md);
    border: 2px solid transparent;
    transition: all 0.15s;
}

.mount-palette .detail-render-image a:hover,
.mount-palette .detail-render-image a:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px rgba(39, 170, 226, 0.3);
}

.mount-palette .detail-render img {
    max-width: 90%;
    max-height: 90%;
    object-fit: contain;
}

.mount-palette .detail-view-3d {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    margin-top: var(--spacing-md);
    font-size: 0.75rem;
    color: var(--color-text-muted);
    text-decoration: none;
    transition: color 0.15s;
}

.mount-palette .detail-view-3d:hover,
.mount-palette .detail-view-3d:focus {
    color: var(--color-primary);
    text-decoration: underline;
}

.mount-palette .detail-view-3d img {
    width: 14px;
    height: 14px;
    filter: brightness(0) saturate(100%) invert(60%) sepia(5%) saturate(200%) hue-rotate(180deg);
    transition: filter 0.15s;
}

.mount-palette .detail-view-3d:hover img,
.mount-palette .detail-view-3d:focus img {
    filter: brightness(0) saturate(100%) invert(62%) sepia(93%) saturate(1352%) hue-rotate(166deg) brightness(96%) contrast(87%);
}

.mount-palette .detail-info {
    width: calc(50% - var(--spacing-lg) / 2);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.mount-palette .detail-mount-name {
    font-size: 1.25rem;
    font-weight: 700;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 6px;
}

.mount-palette .detail-mount-name a {
    color: var(--color-text);
    text-decoration: none;
    transition: color 0.15s;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.mount-palette .detail-mount-name a:hover,
.mount-palette .detail-mount-name a:focus {
    color: var(--color-primary);
    text-decoration: underline;
}

.mount-palette .detail-mount-name .icon-external {
    width: 14px;
    height: 14px;
    filter: brightness(0) saturate(100%) invert(100%);
    opacity: 0.7;
    transition: filter 0.15s, opacity 0.15s;
    flex-shrink: 0;
}

.mount-palette .detail-mount-name a:hover .icon-external,
.mount-palette .detail-mount-name a:focus .icon-external {
    filter: brightness(0) saturate(100%) invert(62%) sepia(93%) saturate(1352%) hue-rotate(166deg) brightness(96%) contrast(87%);
    opacity: 1;
}

.mount-palette .detail-mount-source {
    font-size: 0.85rem;
    color: var(--color-text-muted);
    margin: 0;
}

.mount-palette .detail-mount-collected {
    font-size: 0.85rem;
    color: var(--color-text-muted);
    margin: 0;
}

.mount-palette .detail-mount-collected .collected-owned {
    color: var(--color-success);
    font-weight: 500;
}

.mount-palette .detail-mount-collected .collected-unowned {
    color: var(--color-text-muted);
}

.mount-palette .detail-mount-faction {
    display: inline-block;
    padding: 3px 8px;
    border-radius: 4px;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    width: fit-content;
}

.mount-palette .detail-mount-faction.alliance {
    background: rgba(0, 112, 221, 0.2);
    color: #4a9eff;
}

.mount-palette .detail-mount-faction.horde {
    background: rgba(196, 30, 58, 0.2);
    color: #ff6b6b;
}

.mount-palette .detail-mount-faction.neutral {
    background: rgba(255, 255, 255, 0.1);
    color: var(--color-text-muted);
}

/* Colors Grid - 3 column layout */
.mount-palette .detail-colors {
    margin-top: var(--spacing-sm);
    width: 100%;
}

.mount-palette .detail-colors-grid {
    display: flex;
    flex-direction: column;
}

/* Color row containers */
.mount-palette .detail-color-row {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: var(--spacing-sm);
}

.mount-palette .detail-color-slot {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.mount-palette .detail-color-label {
    font-size: 0.65rem;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.mount-palette .detail-swatch {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 6px 10px;
    background: rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-sm);
    cursor: pointer;
    border: 2px solid transparent;
    transition: all 0.15s;
}

.mount-palette .detail-swatch:hover,
.mount-palette .detail-swatch:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px rgba(39, 170, 226, 0.3);
}

.mount-palette .detail-swatch-color {
    width: 35px;
    height: 35px;
    border-radius: var(--radius-sm);
    border: 1px solid rgba(255, 255, 255, 0.2);
    flex-shrink: 0;
}

.mount-palette .detail-swatch-name {
    font-size: 0.75rem;
    color: var(--color-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.mount-palette .detail-swatch-percent {
    font-size: 0.65rem;
    color: var(--color-text-muted);
    margin-left: auto;
    flex-shrink: 0;
}

/* Variants - horizontal row, 33% width each */
.mount-palette .detail-variants {
    margin-top: var(--spacing-sm);
}

.mount-palette .detail-variants h4 {
    font-size: 0.65rem;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0 0 var(--spacing-xs) 0;
}

.mount-palette .variant-list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
}

.mount-palette .variant-thumb {
    width: calc(33.333% - 6px);
    aspect-ratio: 1;
    border-radius: var(--radius-sm);
    overflow: hidden;
    cursor: pointer;
    border: 2px solid transparent;
    background: linear-gradient(135deg, rgba(20, 30, 48, 0.8) 0%, rgba(10, 15, 24, 0.9) 100%);
    transition: all 0.15s;
}

.mount-palette .variant-thumb:hover {
    border-color: var(--color-primary);
}

.mount-palette .variant-thumb.active {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px rgba(39, 170, 226, 0.3);
}

.mount-palette .variant-thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

/* ========================================
   EMPTY STATE
   ======================================== */

.mount-palette .panel-empty {
    padding: var(--spacing-xl) var(--spacing-lg);
    text-align: center;
}

.mount-palette .empty-content {
    max-width: 300px;
    margin: 0 auto;
}

.mount-palette .empty-icon {
    width: 60px;
    height: 60px;
    color: var(--color-text-dark);
    margin-bottom: var(--spacing-md);
}

.mount-palette .empty-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--color-text);
    margin: 0 0 var(--spacing-xs) 0;
}

.mount-palette .empty-text {
    font-size: 0.85rem;
    color: var(--color-text-muted);
    margin: 0;
}

/* ========================================
   SEARCH PANEL
   ======================================== */

.mount-palette .panel-search {
    padding: var(--spacing-md);
}

.mount-palette .panel-search .search-container {
    display: flex;
    gap: 12px;
}

.mount-palette .panel-search .search-input-wrapper {
    flex: 1;
    position: relative;
}

.mount-palette .panel-search .search-input {
    width: 100%;
    padding: 14px 18px;
    font-size: 1rem;
    font-family: inherit;
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    color: var(--color-text-light);
    outline: none;
    transition: border-color var(--transition-normal), box-shadow var(--transition-normal);
}

.mount-palette .panel-search .search-input:focus {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(39, 170, 226, 0.15);
}

.mount-palette .panel-search .search-input::placeholder {
    color: var(--color-text-muted);
}

/* ========================================
   ACTIVE FILTERS PANEL
   ======================================== */

.mount-palette .panel-filters {
    padding: var(--spacing-sm) var(--spacing-md);
}

.mount-palette .filters-row {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
    width: 100%;
}

.mount-palette .filters-label {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    font-weight: 500;
    line-height: 1.5;
    padding-top: 4px;
}

.mount-palette .filter-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
    flex: 1;
    min-width: 0;
}

.mount-palette .btn-reset {
    margin-left: auto;
    margin-top: 2px;
    flex-shrink: 0;
    align-self: flex-start;
}

.mount-palette .filter-tag {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 8px;
    background: rgba(255, 255, 255, 0.08);
    border-radius: 16px;
    font-size: 0.75rem;
    line-height: 1.25rem;
    color: var(--color-text);
}

.mount-palette .filter-tag-role {
    font-size: 0.6rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    line-height: 1;
    padding-top: 2px;
    color: var(--color-text-muted);
}

.mount-palette .filter-tag-color {
    width: 12px;
    height: 12px;
    min-width: 12px;
    min-height: 12px;
    flex-shrink: 0;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.3);
}

.mount-palette .filter-tag-remove {
    background: none;
    border: none;
    color: var(--color-text-muted);
    cursor: pointer;
    padding: 0;
    line-height: 1;
    font-size: 1rem;
    transition: color 0.15s;
    margin-left: 2px;
}

.mount-palette .filter-tag-remove:hover {
    color: var(--color-error);
}

.mount-palette .btn-reset {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: transparent;
    border: 1px solid var(--color-border);
    color: var(--color-text-muted);
    padding: 4px 10px;
    border-radius: 16px;
    font-size: 0.75rem;
    cursor: pointer;
    transition: all 0.15s;
    margin-left: auto;
}

.mount-palette .btn-reset:hover {
    border-color: var(--color-text-muted);
    color: var(--color-text);
}

/* ========================================
   RESULTS STATS PANEL
   ======================================== */

.mount-palette .panel-stats {
    padding: var(--spacing-sm) var(--spacing-md);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-md);
}

.mount-palette .stats-info {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.mount-palette .stat-count {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--color-success);
}

.mount-palette .stat-label {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    margin-bottom: 0;
}

.mount-palette .stats-sort {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.mount-palette .stats-filter {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    margin-left: auto;
}

.mount-palette .stats-filter label {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    margin-bottom: 0;
    white-space: nowrap;
}

.mount-palette .stats-sort label {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    margin-bottom: 0;
    white-space: nowrap;
}

.mount-palette .sort-select {
    background: var(--color-bg-input);
    border: 1px solid var(--color-border-input);
    border-radius: var(--radius-sm);
    color: var(--color-text);
    padding: 4px 10px;
    font-size: 0.8rem;
    cursor: pointer;
}

.mount-palette .sort-select:focus {
    border-color: var(--color-primary);
}

/* ========================================
   COLORS LOADING STATE
   ======================================== */

.mount-palette .panel-colors-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 200px;
    padding: var(--spacing-lg);
}

.mount-palette .colors-loading-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-md);
}

.mount-palette .colors-loader-spinner {
    width: 40px;
    height: 40px;
    animation: spin 1s linear infinite;
}

.mount-palette .colors-loader-text {
    font-size: 0.875rem;
    color: var(--color-text-muted);
}

@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

/* ========================================
   MOUNT GRID
   ======================================== */

.mount-palette .panel-mounts {
    padding: var(--spacing-md);
}

.mount-palette .mount-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-sm);
}

.mount-palette .mount-grid-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: var(--spacing-xl);
    color: var(--color-text-muted);
}

.mount-palette .mount-card {
    display: flex;
    flex-direction: column;
    background: var(--color-bg-panel);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
    cursor: pointer;
    transition: all 0.2s ease;
}

.mount-palette .mount-card.unowned {
    background: rgba(40, 45, 55, 0.4);
    border: 1px dashed rgba(255, 255, 255, 0.25);
}

.mount-palette .mount-card.unowned .mount-card-name {
    color: var(--color-text-muted);
}

.mount-palette .mount-card:hover {
    border-color: var(--color-primary);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3);
}

.mount-palette .mount-card.unowned:hover {
    border-style: solid;
}

.mount-palette .mount-card-image {
    aspect-ratio: 1;
    background: #181818;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.mount-palette .mount-card-image img {
    max-width: 85%;
    max-height: 85%;
    object-fit: contain;
}

.mount-palette .mount-card-info {
    width: 100%;
}

.mount-palette .mount-card-name {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--color-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.mount-palette .mount-card-colors {
    display: flex;
    gap: 4px;
    margin-top: 6px;
}

.mount-palette .mount-card-color {
    width: calc(20% - 3.2px);
    aspect-ratio: 1;
    border-radius: 3px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    position: relative;
}

.mount-palette .mount-card-color.matched {
    border: 2px solid #fff;
    box-shadow: 0 0 0 1px var(--color-primary);
}

.mount-palette .mount-card-color[title]:hover::after {
    content: attr(title);
    position: absolute;
    top: -30px;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0, 0, 0, 0.9);
    color: #fff;
    padding: 3px 6px;
    border-radius: 4px;
    font-size: 10px;
    white-space: nowrap;
    pointer-events: none;
    z-index: 100;
}

/* ========================================
   COLOR PICKER PANEL
   ======================================== */

.mount-palette .panel-colors {
    padding: 0;
    overflow: hidden;
}

.mount-palette .colors-toggle {
    display: none;
    width: 100%;
    padding: var(--spacing-md);
    background: transparent;
    border: none;
    color: var(--color-text);
    font-size: 0.9rem;
    font-weight: 600;
    cursor: pointer;
    justify-content: space-between;
    align-items: center;
}

.mount-palette .colors-toggle-text {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.mount-palette .colors-toggle-arrow {
    transition: transform 0.2s;
}

.mount-palette .colors-toggle.open .colors-toggle-arrow {
    transform: rotate(180deg);
}

.mount-palette .colors-body {
    padding: var(--spacing-md);
}

/* Color Sections */
.mount-palette .color-section {
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-lg);
    border-bottom: 1px solid var(--color-border);
}

.mount-palette .color-section:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}

.mount-palette .color-section-header {
    margin-bottom: var(--spacing-sm);
}

.mount-palette .color-section-label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.mount-palette .color-section-body {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    container-type: inline-size;
}

/* Category swatches row */
.mount-palette .color-category-swatches {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.mount-palette .color-category-swatches.other {
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--color-border);
}

/* Category swatch - large colored button */
.mount-palette .color-category-swatch {
    width: calc(100cqw / 7 - 5.2px);
    aspect-ratio: 1;
    border-radius: 6px;
    cursor: pointer;
    border: 2px solid rgba(255, 255, 255, 0.15);
    transition: all 0.15s ease;
    position: relative;
}

.mount-palette .color-category-swatch:hover {
    transform: scale(1.15);
    z-index: 1;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
    border-color: rgba(255, 255, 255, 0.4);
}

.mount-palette .color-category-swatch.selected {
    border-color: #fff;
    box-shadow: 0 0 0 2px var(--color-primary), 0 4px 12px rgba(0, 0, 0, 0.4);
}

/* Selected category header row */
.mount-palette .color-selected-category {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) 0;
}

.mount-palette .color-selected-category .color-category-swatch {
    flex-shrink: 0;
}

.mount-palette .color-selected-category .color-category-swatch:hover {
    transform: none;
}

.mount-palette .color-category-name {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--color-text);
    display: flex;
    align-items: center;
}

.mount-palette .color-category-count {
    font-size: 0.8rem;
    color: var(--color-text-muted);
    display: flex;
    align-items: center;
    transform: translateY(1px);
}

/* Sub-swatches (specific colors within a category) */
.mount-palette .color-sub-swatches {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    padding-top: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.mount-palette .color-sub-label,
.mount-palette .color-other-label {
    width: 100%;
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 2px;
}

.mount-palette .color-sub-swatch {
    width: calc(100cqw / 7 - 5.2px);
    aspect-ratio: 1;
    border-radius: 4px;
    cursor: pointer;
    border: 2px solid rgba(255, 255, 255, 0.1);
    transition: all 0.15s ease;
}

.mount-palette .color-sub-swatch:hover {
    transform: scale(1.2);
    z-index: 1;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
    border-color: rgba(255, 255, 255, 0.3);
}

.mount-palette .color-sub-swatch.selected {
    border-color: #fff;
    box-shadow: 0 0 0 2px var(--color-primary), 0 4px 12px rgba(0, 0, 0, 0.4);
    transform: scale(1.1);
}

/* Keyboard focus indicators for swatches */
.mount-palette .color-category-swatch:focus-visible,
.mount-palette .color-sub-swatch:focus-visible,
.mount-palette .detail-swatch:focus-visible {
    outline: 2px solid #ffffff;
    outline-offset: 3px;
    z-index: 2;
}

/* ============================================
   NAME GENERATOR STYLES
   ============================================ */

/* Mode Selection Cards - extends .tool-card */
.name-generator .mode-cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
    margin-bottom: var(--spacing-lg);
}

/* Filter Sections */
.name-generator .filter-section {
    margin-bottom: var(--spacing-lg);
}

.name-generator .filter-label {
    display: block;
    font-weight: 600;
    color: var(--text-secondary);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: var(--spacing-sm);
}

/* Pill Groups */
.name-generator .pill-group {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
}

.name-generator .pill {
    background: rgba(255,255,255,0.08);
    border: none;
    color: #fff;
    padding: 9px 18px;
    border-radius: var(--radius-full);
    font-size: 0.95rem;
    font-weight: bold;
    line-height: 1;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.name-generator .pill:hover,
.name-generator .pill:focus {
    background-color: var(--color-primary);
    color: #000;
}

.name-generator .pill.active {
    background-color: var(--color-primary);
    color: #000;
}

/* Pane Actions */
.name-generator .pane-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-top: var(--spacing-lg);
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--border-color);
}

.name-generator .generate-hint {
    color: var(--color-text-muted);
    font-size: 0.9rem;
    font-style: italic;
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding-right: var(--spacing-xl);
}

.name-generator .generate-hint .hint-arrow {
    width: 18px;
    height: 18px;
    stroke: var(--color-text-muted);
    animation: hintArrowBounce 1.5s ease-in-out infinite;
}

@keyframes hintArrowBounce {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-4px); }
}

/* More Options */
.name-generator .more-options {
    margin-top: var(--spacing-lg);
}

.name-generator .more-options summary {
    cursor: pointer;
    color: var(--text-muted);
    font-size: 0.9rem;
    padding: var(--spacing-sm) 0;
    user-select: none;
}

.name-generator .more-options summary:hover {
    color: var(--text-primary);
}

.name-generator .more-options-content {
    padding: var(--spacing-md) 0;
}

.name-generator .more-options-content label {
    display: block;
    font-weight: 500;
    color: var(--text-secondary);
    font-size: 0.9rem;
    margin-bottom: var(--spacing-xs);
}

.name-generator .more-options-content input {
    width: 100%;
    max-width: 300px;
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    background: var(--bg-input);
    color: var(--text-primary);
    font-size: 0.95rem;
}

.name-generator .more-options-content input:focus {
    border-color: var(--color-primary);
}

.name-generator .more-options-content .help {
    font-size: 0.8rem;
    color: var(--text-muted);
    margin-top: var(--spacing-xs);
}

/* Names list */
.name-generator .names-list {
    display: flex;
    flex-direction: column;
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.name-generator .names-list .name-row:first-child {
    border-top-left-radius: var(--radius-lg);
    border-top-right-radius: var(--radius-lg);
}

.name-generator .names-list .name-row:last-child {
    border-bottom-left-radius: var(--radius-lg);
    border-bottom-right-radius: var(--radius-lg);
}

.name-generator .names-empty {
    text-align: center;
    padding: var(--spacing-xl);
    color: var(--text-muted);
    font-style: italic;
}

.name-generator .pagination {
    text-align: center;
    padding: var(--spacing-lg);
    border-top: 1px solid var(--border-color);
}

.name-generator .page-controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    font-weight: bold;
}

.name-generator .page-numbers {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.name-generator .page-btn {
    padding: var(--spacing-xs) var(--spacing-sm);
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
    color: var(--text-primary);
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-size: 0.9em;
    font-weight: bold;
    min-width: 32px;
    transition: all 0.15s ease;
}

.name-generator .page-btn:hover:not(:disabled) {
    background: var(--bg-tertiary);
    border-color: var(--text-muted);
}

.name-generator .page-btn.active {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: #000;
}

.name-generator .page-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.name-generator .page-ellipsis {
    color: var(--text-muted);
    padding: 0 var(--spacing-xs);
}

.name-generator #favorites-count {
    font-size: 0.85em;
    color: var(--text-muted);
    font-weight: normal;
}

/* Name row */
.name-generator .name-row {
    display: flex;
    align-items: center;
    padding: var(--spacing-md);
    border-top: 1px solid var(--border-color);
    gap: 7px;
    transition: background-color 0.2s, opacity 0.2s;
}

.name-generator .name-row:nth-child(odd) {
    background-color: rgba(255, 255, 255, 0.02);
}

.name-generator .name-row:nth-child(even) {
    background-color: rgba(255, 255, 255, 0.05);
}

.name-generator .name-row:first-child {
    border-top: none;
}

.name-generator .name-row:hover {
    background-color: rgba(255, 255, 255, 0.12);
}

/* Rating states */
.name-generator .name-row.liked {
    background-color: rgba(34, 197, 94, 0.08);
}

.name-generator .name-row.disliked {
    background-color: rgba(239, 68, 68, 0.05);
    opacity: 0.7;
}

.name-generator .name-row.favorited .name-text {
    color: var(--color-gold);
}

/* Name text */
.name-generator .name-text {
    font-size: 1.1rem;
    font-weight: 600;
    color: #fff;
    min-width: 140px;
}

/* Name metadata */
.name-generator .name-meta {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    color: var(--color-text-light);
    font-size: 0.9rem;
    flex: 1;
}

.name-generator .name-meta-item {
    display: flex;
    align-items: center;
    gap: 4px;
}

.name-generator .name-meta-separator {
    display: none;
}

.name-generator .name-meta-label {
    color: var(--text-muted);
    font-size: 0.85rem;
    margin-right: 4px;
    opacity: 0.8;
}

.name-generator .name-seed {
    color: var(--color-text-muted);
    font-size: 0.85rem;
    margin-top: 1px;
}

.name-generator .name-seed-link {
    color: var(--color-text-muted);
    font-size: 0.85rem;
    text-decoration: underline;
    cursor: pointer;
    margin-top: 2px;
}

.name-generator .name-seed-link:hover {
    color: var(--color-link);
}

.name-generator .name-seed-unknown {
    color: var(--color-text-muted);
    font-size: 0.85rem;
    opacity: 0.6;
    margin-top: 2px;
}

/* Confidence badge */
.name-generator .confidence-badge {
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.name-generator .confidence-strong {
    background-color: rgba(34, 197, 94, 0.15);
    color: #22c55e;
}

.name-generator .confidence-good {
    background-color: rgba(59, 130, 246, 0.15);
    color: #3b82f6;
}

.name-generator .confidence-fair {
    background-color: rgba(251, 191, 36, 0.15);
    color: #f59e0b;
}

.name-generator .confidence-weak {
    background-color: rgba(156, 163, 175, 0.15);
    color: #9ca3af;
}

/* Name actions */
.name-generator .name-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.name-generator .name-action {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border: none;
    background: transparent;
    border-radius: 6px;
    cursor: pointer;
    color: var(--text-muted);
    transition: all 0.15s;
}

.name-generator .name-action:hover,
.name-generator .name-action:focus {
    background-color: var(--bg-hover);
    color: var(--color-primary);
}

.name-generator .name-action:hover svg,
.name-generator .name-action:focus svg {
    stroke: var(--color-primary);
}

.name-generator .name-action svg {
    width: 18px;
    height: 18px;
}

/* Action states */
.name-generator .name-action.action-like.active {
    color: #22c55e;
    background-color: rgba(34, 197, 94, 0.15);
}

.name-generator .name-action.action-dislike.active {
    color: #ef4444;
    background-color: rgba(239, 68, 68, 0.15);
}

.name-generator .name-action.action-favorite.active {
    color: var(--color-gold);
    background-color: rgba(251, 191, 36, 0.15);
}

.name-generator .name-action.action-favorite.active:hover,
.name-generator .name-action.action-favorite.active:focus {
    background-color: rgba(120, 90, 20, 0.4);
}

.name-generator .name-action.action-favorite.active:hover svg,
.name-generator .name-action.action-favorite.active:focus svg {
    stroke: #050709;
}

.name-generator .name-action.action-favorite.active svg {
    fill: var(--color-gold);
}

/* Copy success animation */
.name-generator .name-action.copied {
    color: #22c55e !important;
}

/* Rating feedback animation */
.name-generator .name-action.rated {
    color: #22c55e !important;
    pointer-events: none;
}

/* Loading state */
.name-generator .names-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-xl);
    gap: var(--spacing-sm);
    color: var(--text-muted);
}

.name-generator .names-loading::before {
    content: '';
    width: 20px;
    height: 20px;
    border: 2px solid var(--border-color);
    border-top-color: var(--color-primary);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

/* --------------------------------------------
   Character Creator UI (Tailored Mode)
   -------------------------------------------- */

/* Character creator colors */
:root {
    --color-creator-yellow: #fcd34d;
    --color-creator-grey: #6b7280;
    --color-alliance-blue: #3b82f6;
    --color-horde-red: #dc2626;
}

.name-generator .character-creator {
    position: relative;
    padding: var(--spacing-lg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.name-generator .creator-main {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-lg);
    align-items: start;
    position: relative;
    z-index: 1;
}

/* Unified Icon Button (race, class, gender) */
.name-generator .icon-btn {
    width: 75px;
    height: 75px;
    padding: 0;
    background: transparent;
    border: 3px solid transparent;
    border-radius: 50%;
    cursor: pointer;
    transition: all 0.15s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.name-generator .icon-btn img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

/* Default borders by type */
.name-generator .class-btn,
.name-generator .body-type-btn {
    border-color: var(--color-creator-grey);
}

.name-generator .race-panel.alliance .race-btn {
    border-color: var(--color-alliance-blue);
}

.name-generator .race-panel.horde .race-btn {
    border-color: var(--color-horde-red);
}

/* Hover goes to yellow (higher specificity for race buttons) */
.name-generator .icon-btn:hover,
.name-generator .race-panel.alliance .race-btn:hover,
.name-generator .race-panel.horde .race-btn:hover {
    border-color: var(--color-creator-yellow);
}

/* Active state - bright yellow with glow (higher specificity for race buttons) */
.name-generator .icon-btn.active,
.name-generator .race-panel.alliance .race-btn.active,
.name-generator .race-panel.horde .race-btn.active {
    border-color: var(--color-creator-yellow);
    box-shadow: 0 0 12px rgba(252, 211, 77, 0.4);
}

/* Disabled state */
.name-generator .icon-btn.disabled {
    opacity: 0.25;
    cursor: not-allowed;
}

.name-generator .icon-btn.disabled:hover,
.name-generator .race-panel .race-btn.disabled:hover {
    border-color: var(--color-creator-grey);
}

/* Body type icons */
.name-generator .body-type-btn img {
    padding: 6px;
    object-fit: contain;
}

/* Race Panels (Alliance/Horde) */
.name-generator .race-panel {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    width: 185px;
}

/* Faction Title */
.name-generator .faction-title {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    font-size: 1rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin: 0 0 var(--spacing-md) 0;
    color: var(--color-creator-yellow);
}

.name-generator .faction-logo {
    width: 75px;
    height: 75px;
    flex-shrink: 0;
}

/* Color faction logos using CSS filters */
.name-generator .race-panel.alliance .faction-logo {
    filter: brightness(0) saturate(100%) invert(44%) sepia(93%) saturate(1352%) hue-rotate(196deg) brightness(103%) contrast(92%);
}

.name-generator .race-panel.horde .faction-logo {
    filter: brightness(0) saturate(100%) invert(19%) sepia(86%) saturate(5765%) hue-rotate(355deg) brightness(93%) contrast(94%);
}

/* Flip shared-appearance Horde races (Dracthyr, Pandaren, Earthen, Haranir) to face left */
.name-generator .race-panel.horde .race-btn[data-race-id="70"] img,
.name-generator .race-panel.horde .race-btn[data-race-id="26"] img,
.name-generator .race-panel.horde .race-btn[data-race-id="84"] img,
.name-generator .race-panel.horde .race-btn[data-race-id="91"] img {
    transform: scaleX(-1);
}

.name-generator .race-panel.horde {
    align-items: flex-end;
}

.name-generator .race-panel.horde .faction-title {
    justify-content: flex-end;
}

/* Race Columns (Core + Allied side by side) */
.name-generator .race-columns {
    display: flex;
    gap: var(--spacing-md);
    align-items: center;
}

.name-generator .race-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

/* Render Area (Center column - just body type toggle now) */
.name-generator .render-area {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: var(--spacing-md);
}

/* Body Type Toggle */
.name-generator .body-type-toggle {
    display: flex;
    gap: var(--spacing-md);
}

/* Render container - full panel background layer */
.name-generator .render-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background-size: cover;
    background-position: center;
    z-index: 0;
    pointer-events: none;
}

/* Render placeholder - shows when no selection, has the bordered box */
.name-generator .render-placeholder {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 60%;
    height: 60%;
    color: var(--color-creator-yellow);
    padding: var(--spacing-lg);
    pointer-events: auto;
}

.name-generator #intro {
    font-size: 1.5rem;
    font-weight: 600;
    text-align: center;
    background: rgba(0, 0, 0, 0.7);
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius-md);
}

.name-generator .render-placeholder svg {
    width: 56px;
    height: 56px;
    stroke-width: 3.5;
    filter:
        drop-shadow(1px 0 0 black)
        drop-shadow(-1px 0 0 black)
        drop-shadow(0 1px 0 black)
        drop-shadow(0 -1px 0 black)
        drop-shadow(2px 2px 3px rgba(0, 0, 0, 0.5));
}

.name-generator .render-placeholder .arrow-top,
.name-generator .render-placeholder .arrow-bottom {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.name-generator .render-placeholder .arrow-top svg {
    animation: bounceDown 2s ease-in-out infinite;
}

.name-generator .render-placeholder .arrow-bottom svg {
    animation: bounceUp 2s ease-in-out infinite;
}

.name-generator .render-placeholder .arrow-middle {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    width: 100%;
}

.name-generator .render-placeholder .arrow-left,
.name-generator .render-placeholder .arrow-right {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.name-generator .render-placeholder .arrow-left svg {
    animation: bounceRight 2s ease-in-out infinite;
}

.name-generator .render-placeholder .arrow-right svg {
    animation: bounceLeft 2s ease-in-out infinite;
}

@keyframes bounceDown {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(8px); }
}

@keyframes bounceUp {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
}

@keyframes bounceLeft {
    0%, 100% { transform: translateX(0); }
    50% { transform: translateX(-8px); }
}

@keyframes bounceRight {
    0%, 100% { transform: translateX(0); }
    50% { transform: translateX(8px); }
}

/* Character render - centered in the full container */
.name-generator .character-render {
    max-height: 99%;
    object-fit: contain;
    pointer-events: auto;
}

/* Class Bar */
.name-generator .class-bar {
    display: flex;
    justify-content: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
    flex-wrap: wrap;
    position: relative;
    z-index: 1;
}

/* Name Input Section */
.name-generator .name-input-section {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.name-generator .name-input-label {
    font-size: 0.9rem;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.name-generator .name-input {
    width: 100%;
    max-width: 400px;
    padding: var(--spacing-md) var(--spacing-lg);
    font-size: 1.25rem;
    text-align: center;
    background: rgba(0, 0, 0, 0.4);
    border: 2px solid rgba(255, 255, 255, 0.2);
    border-radius: var(--radius-md);
    color: var(--color-text);
    transition: border-color 0.15s ease;
}

.name-generator .name-input:focus {
    border-color: var(--color-creator-yellow);
}

.name-generator .name-input::placeholder {
    color: var(--color-text-muted);
    font-size: 1rem;
}

/* Creator Actions */
.name-generator .creator-actions {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-md);
}

.name-generator .creator-actions .btn:disabled {
    opacity: 1;
    cursor: not-allowed;
}

/* Seed Controls */
.name-generator .seed-controls {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.name-generator .seed-inputs {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.name-generator .generator-buttons {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 2px;
}

.name-generator .seed-controls label {
    color: var(--color-text-muted);
    font-size: 0.9rem;
    white-space: nowrap;
    margin-top: 4px;
}

.name-generator .seed-input {
    width: 100px;
    padding: 6px 10px;
    font-size: 0.9rem;
    font-family: var(--font-mono);
    text-align: center;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg-dark);
    color: var(--color-text);
}

.name-generator .seed-input::placeholder {
    color: var(--color-text-muted);
    font-style: italic;
}

.name-generator .seed-input:focus {
    border-color: var(--color-accent);
}

.name-generator .seed-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    padding: 0;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-bg-dark);
    color: var(--color-text);
    cursor: pointer;
    transition: all 0.15s ease;
}

.name-generator .seed-btn:hover:not(:disabled) {
    background: var(--color-bg-darker);
    border-color: var(--color-accent);
    color: var(--color-accent);
}

.name-generator .seed-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

/* Featured Profile Panel */
.name-generator .panel-featured {
    display: none;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-xs);
}

.name-generator .panel-featured.alliance,
.name-generator .panel-featured.horde {
    display: flex;
}

.name-generator .featured-selection {
    display: inline-flex;
    gap: var(--spacing-sm);
    font-size: 1.25rem;
    font-weight: 600;
}

/* Faction and class icons */
.name-generator .featured-faction-icon,
.name-generator .featured-class-icon {
    display: none; /* temporarily hidden */
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    align-self: center;
}

.name-generator .panel-featured.alliance .featured-faction-icon {
    filter: brightness(0) saturate(100%) invert(44%) sepia(93%) saturate(1352%) hue-rotate(196deg) brightness(103%) contrast(92%);
}

.name-generator .panel-featured.horde .featured-faction-icon {
    filter: brightness(0) saturate(100%) invert(19%) sepia(86%) saturate(5765%) hue-rotate(355deg) brightness(93%) contrast(94%);
}

.name-generator .featured-label,
.name-generator .badge-name,
.name-generator .badge-source {
    line-height: 1;
}

.name-generator .featured-label {
    color: var(--color-text-muted);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.name-generator .character-badge {
    display: flex;
    flex-direction: row;
    align-items: baseline;
    gap: var(--spacing-lg);
    color: var(--color-text);
    text-decoration: none;
    border-top: 1px solid var(--color-border);
    margin-top: var(--spacing-sm);
    padding-top: var(--spacing-md);
}

.name-generator .character-badge .badge-name {
    font-weight: 700;
}

.name-generator .character-badge:hover .badge-name {
    text-decoration: underline;
}

.name-generator .badge-group,
.name-generator .badge-source {
    display: flex;
    align-items: baseline;
    gap: var(--spacing-sm);
}

.name-generator .source-label {
    color: var(--color-text-muted);
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.name-generator .source-value {
    color: var(--color-text);
    font-weight: 700;
}

.name-generator .panel-featured.wt-user .source-value {
    color: var(--color-creator-yellow);
}

/* Names Generated Indicator - Achievement style pill */
.name-generator .names-indicator {
    position: fixed;
    bottom: 32px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 9999;
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md) var(--spacing-xl);
    background: #166534;
    color: #fff;
    border: 1px solid #22c55e;
    font-size: 1.25rem;
    font-weight: 600;
    border-radius: var(--radius-full);
    cursor: pointer;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
    animation: indicatorSlideIn 0.4s ease-out;
    transition: transform 0.15s ease, background 0.15s ease, border-color 0.15s ease;
}

.name-generator .names-indicator:hover {
    transform: translateX(-50%) scale(1.05);
    background: #14532d;
    color: #fff;
    border-color: #fff;
}

.name-generator .names-indicator .indicator-arrow {
    width: 24px;
    height: 24px;
    animation: indicatorBounce 1.5s ease-in-out infinite;
}

@keyframes indicatorSlideIn {
    from {
        opacity: 0;
        transform: translateX(-50%) translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateX(-50%) translateY(0);
    }
}

@keyframes indicatorSlideOut {
    from {
        opacity: 1;
        transform: translateX(-50%) translateY(0);
    }
    to {
        opacity: 0;
        transform: translateX(-50%) translateY(20px);
    }
}

.name-generator .names-indicator.hiding {
    animation: indicatorSlideOut 0.4s ease-out forwards;
}

@keyframes indicatorBounce {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(4px); }
}

/* ========================================
   RESPONSIVE BREAKPOINTS
   ======================================== */

@media (max-width: 1250px) {
    .mount-palette .palette-layout {
        grid-template-columns: 1fr 380px;
    }
}

@media (max-width: 1100px) {
    .mount-palette .palette-layout {
        grid-template-columns: 1fr 250px;
    }

    .mount-palette .detail-info {
        width: calc(65% - var(--spacing-lg) / 2);
    }

    .mount-palette .detail-render {
        width: calc(35% - var(--spacing-lg) / 2);
    }
}

/* --------------------------------------------
   FAQ Panel
   -------------------------------------------- */

.panel-faq h2 {
    margin-bottom: 0;
}

.panel-faq .faq-item {
    padding: var(--spacing-md) 0;
    border-bottom: 1px solid var(--color-border);
}

.panel-faq .faq-item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.panel-faq .faq-item:first-child {
    margin-top: var(--spacing-md);
}

.panel-faq .faq-item h3 {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: var(--spacing-sm);
    color: var(--color-text);
}

.panel-faq .faq-item p {
    font-size: 0.9rem;
    line-height: 1.6;
    color: var(--color-text-muted);
    margin: 0;
}

.name-generator .tabs {
    align-items: center;
}

.name-generator #generate-random-btn {
    margin-left: auto;
}

/* 1300px: Smaller icons for medium screens */
@media (max-width: 1300px) {
    .name-generator .icon-btn {
        width: 55px;
        height: 55px;
    }

    .name-generator .faction-logo {
        width: 55px;
        height: 55px;
    }
}

/* 1100px: Even smaller icons */
@media (max-width: 1100px) {
    .name-generator .icon-btn {
        width: 48px;
        height: 48px;
    }

    .name-generator .faction-logo {
        width: 48px;
        height: 48px;
    }
}

/* 959px: Mobile begins - single column layout */
@media (max-width: 959px) {
    .panel-subtitle { text-align: center; }

    .name-generator .render-container {
        position: relative;
        border-radius: var(--radius-lg);
        height: 550px;
        margin-top: var(--spacing-xl);
    }

    .name-generator .character-render {
        width: 175%;
        height: 120%;
    }

    .name-generator .render-placeholder {
        width: 100%;
        height: 100%;
    }

    .name-generator .render-placeholder .arrow-middle,
    .name-generator .render-placeholder .arrow-top {
        display: none;
    }

    .name-generator .render-placeholder .arrow-bottom {
        display: flex;
        transform: rotate(180deg);
    }

    .name-generator #intro {
        margin-top: auto;
        margin-bottom: auto;
    }

    .mobile {
        display: block;
    }

    .name-generator .names-indicator {
        font-size: 0.95rem;
        gap: var(--spacing-sm);
        padding: 5%;
        width: 80%;
        justify-content: center;
    }

    .name-generator .icon-btn {
        width: 85px;
        height: 85px;
    }

    .name-generator #generate-random-btn {
        margin-left: 0;
    }

    .name-generator .mode-cards {
        grid-template-columns: 1fr;
    }

    .name-generator .name-row {
        flex-direction: column;
        gap: var(--spacing-xs);
    }

    .name-generator .name-text {
        min-width: auto;
        padding-bottom: 3px;
        border-bottom: 1px solid rgba(255, 255, 255, 0.8);
    }

    .name-generator .name-meta {
        flex-wrap: wrap;
        justify-content: center;
    }

    .name-generator .name-meta-label {
        width: 100%;
        text-align: center;
        margin-right: 0;
        margin-bottom: 0;
        margin-top: 3px;
    }

    .name-generator .name-actions {
        margin-top: 10px;
    }

    .name-generator .creator-actions {
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }

    .name-generator .creator-actions .btn {
        width: 100%;
        font-size: 0.95rem;
        padding: 9px 18px;
    }

    .name-generator .generator-buttons {
        flex-direction: column;
        justify-content: center;
        width: 100%;
        margin-top: var(--spacing-sm);
        padding-top: var(--spacing-md);
        border-top: 1px solid var(--color-border);
    }

    .name-generator .generator-buttons .btn {
        width: 100%;
    }

    .name-generator .seed-controls {
        justify-content: center;
    }

    .name-generator .generate-hint {
        justify-content: center;
        width: 100%;
        padding-right: 0;
    }

    .name-generator .panel-featured {
        margin-left: 0;
        width: 100%;
    }

    .name-generator .panel-featured.alliance,
    .name-generator .panel-featured.horde {
        justify-content: center;
    }

    .name-generator .character-badge {
        flex-direction: column;
        align-items: center;
        gap: var(--spacing-lg);
        text-align: center;
    }

    .name-generator .badge-group,
    .name-generator .badge-source {
        flex-direction: column;
        align-items: center;
    }

    .name-generator .creator-main {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: var(--spacing-md);
    }

    .name-generator .creator-main > * {
        width: 100%;
    }

    .name-generator .render-area {
        order: -1;
    }

    .name-generator .race-list {
        display: contents;
    }

    .name-generator .race-panel {
        margin: var(--spacing-md);
        border-top: 1px solid var(--color-border);
    }

    .name-generator .faction-title {
        flex-direction: column;
        justify-content: center;
        padding-top: var(--spacing-lg);
    }

    .name-generator .race-panel.horde {
        align-items: center;
    }

    .name-generator .race-panel.horde .faction-title {
        flex-direction: column-reverse;
        justify-content: center;
    }

    .name-generator .class-bar {
        margin: 0;
        padding: 30px 0;
        border-top: 1px solid var(--color-border);
        border-bottom: 1px solid var(--color-border);
    }

    .name-generator .race-columns {
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: center;
    }

    .mount-palette .palette-layout {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    
    .mount-palette .palette-right {
        order: -1;
    }
    
    .mount-palette .panel-colors {
        margin-bottom: 0;
    }
    
    .mount-palette .colors-toggle {
        display: flex;
    }

    .mount-palette .colors-toggle-arrow {
        transform: rotate(180deg);
    }

    .mount-palette .colors-toggle.closed .colors-toggle-arrow {
        transform: rotate(0);
    }

    .mount-palette .colors-body {
        display: block;
        padding: var(--spacing-sm) var(--spacing-md) var(--spacing-md);
    }

    .mount-palette .colors-body.closed {
        display: none;
    }

    .mount-palette .detail-color-row {
        flex-direction: column;
        gap: var(--spacing-sm);
    }
    
    .mount-palette .detail-color-slot {
        width: 100%;
    }
    
    .mount-palette .detail-swatch {
        width: 100%;
    }
    
    .mount-palette .stats-filter {
        margin-left: 0;
    }
    
    .mount-palette .filters-row {
        flex-direction: column;
        align-items: center;
    }
    
    .mount-palette .filters-label {
        text-align: center;
    }
    
    .mount-palette .filter-tags {
        justify-content: center;
    }
    
    .mount-palette .btn-reset {
        margin-left: 0;
        margin: 0 auto;
    }
    
    .help {
        text-align: center;
    }
    
    .grid .help {
        text-align: left;
    }
    
    .name-search th,
    .name-search td {
        border-bottom: 0;
    }
    
    .mount-palette .panel-stats {
        gap: var(--spacing-md);
    }
    
    .mount-palette .detail-body {
        flex-direction: column;
    }
    
    .mount-palette .detail-render,
    .mount-palette .detail-info {
        width: 100%;
    }
    
    .mount-palette .detail-info {
        text-align: center;
        align-items: center;
        order: 1;
    }
    
    .mount-palette .detail-render {
        order: 2;
    }
    
    .mount-palette .stats-filter,
    .mount-palette .stats-sort {
        width: 100%;
    }
    
    .mount-palette .filter-tag {
        flex-direction: column;
        text-align: center;
    }
    
    .mount-palette .detail-mount-name a {
        flex-direction: column;
    }
    
    .mount-favorite,
    .pet-favorite,
    .toy-favorite {
        width: 100%;
    }
    
    .mount-header,
    .pet-header,
    .toy-header {
        flex-direction: column;
        align-items: center;
    }
    
    .panel h2 {
        text-align: center;
        width: 100%;
    }
    
    #refresh-progress {
        text-align: center;
    }
    
    .header-count {
        display: block;
    }
    
    .suggestion-item {
        flex-direction: column;
        border-top: 1px solid var(--color-border-light);
    }
    
    .mount-palette .detail-mount-name {
        justify-content: center;
    }
    
    .view-as-select {
        max-width: none;
    }
    
    .panel-header-actions .btn {
        width: 100%;
    }
    
    #nav-account-overview,
    .character-dashboard .panel-header {
        text-align: center;
        align-content: center;
        justify-content: center;
    }

    .status-item {
        text-align: center;
    }
    
    .hub .site-header {
        padding: 30px 0 12px 0 !important;
    }
    
    .hub .header-right {
        position: relative;
        top: auto;
        right: auto;
    }
    
    .site-header:not(.hub) .header-right {
        padding-top: 20px;
    }
    
    .panel-header,
    .status-meta {
        flex-direction: column;
        align-items: flex-start;
    }
    
    .panel-header {
        gap: 15px;
    }
    
    .status-meta {
        order: 3;
        margin-left: 0;
        width: 100%;
        flex-wrap: wrap;
    }
    
    .panel-header-actions {
        margin-left: 0;
        width: 100%;
        flex-wrap: wrap;
        gap: 8px;
    }
}

/* 600px: 2 mounts per row, stack detail panel */
@media (max-width: 600px) {
    .mount-palette .mount-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .mount-palette .detail-colors-grid {
        justify-content: center;
    }
    
    .mount-palette .detail-color-row {
        justify-content: center;
    }
    
    .mount-palette .variant-list {
        justify-content: center;
    }

    .mount-palette .panel-stats {
        flex-direction: column;
        gap: var(--spacing-sm);
        align-items: center;
        text-align: center;
    }
}

@media (max-width: 500px) {
    .name-generator .render-container {
        height: 300px;
    }
}

@media (max-width: 400px) {
    .name-generator .seed-controls {
        flex-direction: column;
        align-items: center;
    }

    .name-generator .seed-controls label {
        margin-top: 0;
        margin-bottom: var(--spacing-xs);
    }
}
