/* ===================================================
   OGame Clone ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â Premium Sci-Fi UI
   =================================================== */
@font-face {
font-family: 'Exo 2';
    font-style: normal;
    font-weight: 300 700;
    font-display: swap;
    src: url('./assets/fonts/exo2-latin-variable.woff2') format('woff2');
}

/* ---------- CSS Custom Properties ---------- */
:root {
    --fluent-duration-fast: 160ms;
    --fluent-ease-standard: cubic-bezier(0.4, 0, 0.2, 1);
    --ui-radius-sm: 10px;
    --ui-radius-md: 10px;
    --ui-radius-lg: 10px;
}

/* ---------- Reset & Base ---------- */
*,
*::before,
*::after {
box-sizing: border-box;
}

/* ---------- UI consistency pass ---------- */
.card,
.resources article,
.panel,
.queue-item,
.report-item,
.message-item,
.alliance-chat-message,
.wiki-card,
button,
.button,
.btn,
.link-btn,
.sidebar-link,
.cookie-banner-btn {
border-radius: 10px;
}

html {
scroll-behavior: smooth;
}

body {
margin: 0;
    font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    min-height: 100vh;
    line-height: 1.55;
    overflow-x: hidden;
}

/* ---------- Links ---------- */
a {
transition: color 0.2s;
}

.section-title-icon,
.sidebar-planet-icon,
.inline-action-icon,
.hamburger-icon,
.nav-icon {
display: inline-block;
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    vertical-align: middle;
}

.section-title-icon {
width: 22px;
    height: 22px;
}

.sidebar-planet-icon,
.hamburger-icon {
width: 16px;
    height: 16px;
}

/* ---------- Layout containers ---------- */
.container {
padding-bottom: 40px;
}

/* ---------- Resource cards ---------- */
.resources {
display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
    margin-bottom: 18px;
}

.resources article,
.card {
border-radius: 10px;
    padding: 16px;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    transition: transform 0.25s, border-color 0.3s, box-shadow 0.3s;
}

@media (max-width: 480px) {
.card {
padding: 12px;
    }
}

.about-legal {
text-align: justify;
    margin-top: 40px;
}

.about-legal .about-legal-disclosure {
margin-top: 1.35rem;
    padding-top: 1.35rem;
    text-align: justify;
}

.about-legal .about-legal-disclosure p {
text-align: justify;
    font-size: 0.88rem;
    line-height: 1.55;
}

.about-disclosure {
text-align: center;
    margin-top: 24px;
}

.page-block+.page-block {
margin-top: 24px;
}

.database-admin-grid {
display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
    align-items: stretch;
}

.database-admin-grid > .page-block,
.database-admin-grid > .page-block + .page-block {
margin-top: 0;
}

.database-admin-grid > .page-block {
display: flex;
    flex-direction: column;
}

.database-admin-grid .database-admin-form {
flex: 1;
}

.database-admin-grid > .page-block > p.muted {
min-height: 3.2em;
}

.database-admin-grid .database-admin-form button[type="submit"] {
margin-top: auto;
}

.friends-requests-grid {
display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
    margin: 32px 0;
    align-items: start;
}

.friends-requests-grid>.page-block,
.friends-requests-grid>.page-block+.page-block {
margin-top: 0;
}

.friend-request-item {
padding: 11px 13px 11px 18px;
}

.message-item-head.friend-request-head {
align-items: center;
    gap: 10px;
    margin-bottom: 0;
    padding: 2px 4px;
}

.friend-request-head > div:first-child {
flex: 1;
    min-width: 0;
}

.friend-request-identity {
flex: 1;
    min-width: 0;
}

.friend-request-meta {
margin-top: 1px;
    font-size: 0.8rem;
}

.friend-request-actions {
flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-end;
    align-self: center;
    padding-left: 4px;
}

.friend-request-actions form {
display: flex;
}

.friend-request-actions button,
.friend-request-actions .link-btn {
min-width: 96px;
    min-height: 36px;
    padding: 7px 10px;
    font-size: 0.8rem;
}

.message-item.friend-list-item {
padding: 11px 13px;
}

.message-item-head.friend-list-head {
align-items: center;
    gap: 10px;
    margin-bottom: 0;
    padding: 2px 4px;
}

.friend-list-head .galaxy-actions {
align-self: center;
}

.friend-list-head .message-item-profile,
.friend-request-head .message-item-profile {
align-items: center;
}

.alliance-members-list .message-item-profile {
align-items: center;
}

.admin-users-settings-grid {
display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
    align-items: stretch;
}

.admin-users-settings-grid > .page-block,
.admin-users-settings-grid > .page-block + .page-block {
margin-top: 0;
}

.card.card-no-hover:hover {
box-shadow: none;
}

.resources h2,
.card h2,
.card h3 {
margin: 0 0 8px 0;
    font-size: 1.05rem;
    font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    letter-spacing: 0.03em;
}

.card h2 {
display: flex;
    align-items: center;
    gap: 8px;
}

.card h2 .section-title-icon {
display: block;
    margin-right: 0;
}

.auth-honeypot {
position: absolute;
    left: -10000px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.resources p {
margin: 0;
    font-size: 1.55rem;
    font-weight: 700;
}

.resources small {
font-size: 0.85rem;
}

.resources article.resource-highlight h2,
.resources article.resource-highlight p,
.resources article.resource-highlight small {
font-weight: 700;
}

.auth-intro-more {
margin: 14px 0 0;
}

.auth-intro-more a {
display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 700;
    text-decoration: none;
}

.auth-intro-more a::after {
content: '>';
    font-size: 0.95rem;
}

.auth-intro-more--overlay {
position: absolute;
    right: 18px;
    bottom: 18px;
    z-index: 2;
    margin: 0;
}

.auth-intro-more--overlay a {
padding: 10px 14px;
    border-radius: 10px;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

.auth-hero-visual {
position: relative;
    flex: 0 0 auto;
}

.auth-intro-note {
margin: 16px 0 0;
    font-size: 0.92rem;
}

.auth-layout-container--about {
padding-bottom: 48px;
}

/* ---------- Public landing (home) ---------- */
.landing-page {
min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.landing-page .auth-layout-container--about {
flex: 1 0 auto;
    justify-content: flex-start;
    min-height: 0;
    padding-top: 28px;
}

.wiki-public-page {
min-height: 100vh;
    display: flex;
    flex-direction: column;
    /* Chrome: clip évite parfois un conteneur de défilement coûteux vs overflow-x: hidden seul */
    overflow-x: hidden;
    overflow-x: clip;
}

.wiki-public-page .wiki-layout {
flex: 1 0 auto;
    min-height: 0;
}

.site-landing-query-flash {
width: auto;
    max-width: none;
    margin: 0 40px 12px;
    box-sizing: border-box;
}

.site-landing-query-flash .flash {
margin: 0;
}

.site-landing-header {
display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 16px 24px;
    width: auto;
    max-width: none;
    margin: 20px 40px 8px;
    padding: 14px 22px;
    box-sizing: border-box;
    position: relative;
    z-index: 20;
    border-radius: 10px;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    transition: transform 0.25s, border-color 0.3s, box-shadow 0.3s;
}

.site-landing-brand {
display: inline-flex;
    align-items: center;
    gap: 14px;
    text-decoration: none;
}

.site-landing-logo {
width: 68px;
    height: auto;
    max-height: 76px;
    object-fit: contain;
    flex-shrink: 0;
}

.site-landing-name {
font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    font-size: 1.05rem;
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    transition: color 0.2s ease;
}

.site-landing-tools {
display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 10px 14px;
}

.site-landing-status {
display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 42px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid rgba(214, 84, 84, 0.24);
    background: rgba(214, 84, 84, 0.08);
    color: #8f2f2f;
    font-size: 0.92rem;
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
}

.site-landing-nav {
display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 10px 14px;
}

.site-landing-locale-switcher {
display: inline-flex;
    align-items: center;
    gap: 8px;
}

.site-landing-locale-option {
display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    padding: 0;
    border-radius: 999px;
    border: 1px solid rgba(130, 173, 225, 0.24);
    background: transparent;
    cursor: pointer;
    transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.site-landing-locale-option:hover,
.site-landing-locale-option:focus-visible {
transform: translateY(-1px);
    border-color: rgba(130, 173, 225, 0.42);
    outline: none;
}

.site-landing-locale-option img {
width: 22px;
    height: 22px;
    display: block;
    filter: none;
    opacity: 1;
}

.site-landing-locale-option.active {
box-shadow: none;
}

/* Même aspect que .sidebar-link (menu gauche du jeu) */
.site-landing-nav button.sidebar-link {
font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    margin: 0;
    text-align: left;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
}

/* Même rendu que les autres entrées : pas de style .sidebar-link.active du jeu */
.site-landing-nav .sidebar-link.active {
font-weight: 400;
    box-shadow: none;
}

.site-landing-nav a.sidebar-link.active {
pointer-events: none;
    cursor: default;
}

.site-landing-auth-popover {
position: fixed;
    z-index: 2100;
    width: min(calc(100vw - 24px), 360px);
    box-sizing: border-box;
    max-height: min(85vh, 640px);
    overflow-y: auto;
    padding: 18px 18px 16px;
    margin: 0;
    text-align: left;
}

.site-landing-auth-popover[hidden] {
display: none !important;
}

.site-landing-auth-popover-title {
margin: 0 28px 12px 0;
    font-size: 1.2rem;
    font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    font-weight: 700;
}

.site-landing-auth-popover .auth-footer {
margin-top: 14px;
    margin-bottom: 0;
    font-size: 0.88rem;
}

.site-landing-auth-popover-close {
position: absolute;
    top: 6px;
    right: 8px;
    width: 36px;
    height: 36px;
    padding: 0;
    border: none;
    border-radius: 8px;
    font-size: 1.5rem;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s ease, color 0.2s ease;
}

.site-landing-auth-inline-link {
background: none;
    border: none;
    padding: 0;
    margin: 0;
    font: inherit;
    font-size: inherit;
    text-decoration: underline;
    cursor: pointer;
}

.site-landing-footer {
width: 100%;
    max-width: none;
    margin-top: auto;
    margin-left: 0;
    margin-right: 0;
    padding: 32px 40px 40px;
    box-sizing: border-box;
    text-align: center;
}

.site-landing-footer-line {
margin: 0;
    font-size: 0.88rem;
}

.site-landing-footer-contact {
margin: 12px 0 0;
    font-size: 0.88rem;
}

.site-landing-footer-contact .contact-admin-link {
font-weight: 600;
    text-decoration: none;
}

.site-landing-footer-contact .contact-admin-link:hover {
text-decoration: underline;
}

@media (max-width: 900px) {
.landing-page .site-landing-header,
    .wiki-public-page .site-landing-header {
margin-left: 12px;
        margin-right: 12px;
    }

    .site-landing-footer {
padding-left: 12px;
        padding-right: 12px;
    }

    .wiki-public-page .wiki-layout {
padding: 12px;
    }

    .site-landing-query-flash {
margin-left: 12px;
        margin-right: 12px;
    }
}

@media (max-width: 600px) {
.landing-page .site-landing-header,
    .wiki-public-page .site-landing-header {
margin: 16px 16px 8px;
    }

    .site-landing-header {
padding: 12px 14px;
        flex-direction: column;
        align-items: stretch;
    }

    .site-landing-brand {
justify-content: center;
    }

    .site-landing-tools {
flex-direction: column;
        align-items: stretch;
        gap: 8px;
    }

    .site-landing-nav {
flex-direction: column;
        align-items: stretch;
        justify-content: center;
        gap: 8px;
    }

    .site-landing-nav .sidebar-link {
justify-content: center;
    }

    .site-landing-locale-switcher {
justify-content: center;
    }

    .landing-page .auth-layout-container--about {
padding: 20px 16px 32px;
    }

    .wiki-public-page .wiki-layout {
padding: 20px 16px 32px;
    }

    .site-landing-query-flash {
margin-left: 16px;
        margin-right: 16px;
    }

    .site-landing-footer {
padding: 24px 16px 32px;
    }
}

.auth-layout-container--login {
padding: 0 32px 14px;
    justify-content: center;
}

@media (max-width: 600px) {
.auth-layout-container--login {
padding: 0 12px 14px;
    }
}

.auth-layout-container--login .auth-header {
margin-bottom: 14px;
}

.auth-layout-container--login .auth-brand-logo {
max-width: 180px;
}

.auth-layout-container--login .auth-columns {
gap: 32px;
    max-width: 1000px;
}

.auth-layout-container--login .auth-left-panel,
.auth-layout-container--login .auth-right-panel.card {
width: min(48vw, 440px);
}

.auth-layout-container--login .hero-container {
min-height: 0;
}

.auth-layout-container--login .auth-hero-art {
height: clamp(180px, 36vh, 320px);
}

.auth-layout-container--login .auth-intro {
padding: 16px 20px;
    font-size: 0.88rem;
    line-height: 1.4;
}

.auth-layout-container--login .auth-intro-more {
margin-top: 10px;
}

.auth-layout-container--login .auth-intro-more--overlay {
margin-top: 0;
}

.auth-layout-container--login .auth-right-panel.card {
padding: 20px 24px;
}

.auth-layout-container--login .auth-right-panel h1 {
margin-bottom: 18px;
    font-size: 1.5rem;
}

.auth-layout-container--login .auth-feedback {
margin-bottom: 12px;
}

.auth-layout-container--login .auth-intro-note {
margin-top: 12px;
    max-width: 920px;
    text-align: center;
}

.auth-layout-container--login .about-disclosure {
width: 100%;
    max-width: 1000px;
}

.about-hero {
display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
    gap: 0;
    align-items: stretch;
    margin-bottom: 24px;
    text-align: justify;
    padding: 0;
    overflow: hidden;
}

.about-hero-copy {
padding: 28px 30px;
}

.about-hero h1 {
margin: 0 0 22px;
    font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    font-size: clamp(1.7rem, 3vw, 2.6rem);
    line-height: 1.08;
}

.about-hero p {
margin: 0;
    max-width: none;
    width: 100%;
}

.about-hero-actions {
display: flex;
    gap: 12px;
    margin-top: 20px;
    flex-wrap: wrap;
}

.about-hero-visual {
display: flex;
    align-items: center;
    justify-content: center;
    height: auto;
    padding: 24px;
}

.about-hero-visual img {
width: 100%;
    height: auto;
    max-height: 100%;
    display: block;
    object-fit: contain;
    border-radius: 10px;
    padding: 8px;
}

.about-grid {
display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
    margin-bottom: 24px;
}

.about-feature-card {
display: grid;
    grid-template-columns: 180px minmax(0, 1fr);
    gap: 0;
    align-items: stretch;
    padding: 0;
    overflow: hidden;
}

.about-feature-image {
width: 100%;
    aspect-ratio: 1 / 1;
    height: auto;
    min-height: 0;
    object-fit: contain;
    padding: 0;
    border-radius: 10px;
    border: 0;
    display: block;
}

.about-feature-card>div {
padding: 20px 22px;
}

.about-feature-card h2 {
margin-bottom: 10px;
}

.about-flow h2 {
margin-bottom: 20px;
    text-align: center;
}

.about-feature-card p {
margin: 0;
    text-align: justify;
}

.about-flow-grid {
display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.about-flow-grid article {
display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 24px 18px;
    border-radius: 10px;
}

.about-step-index {
display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    margin-bottom: 12px;
    border-radius: 10px;
    font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    font-size: 0.9rem;
}

.about-flow-grid h3 {
margin: 0 0 8px;
}

.about-flow-grid p {
margin: 0;
    text-align: justify;
}

.about-disclosure p {
margin: 0;
    font-size: 0.95rem;
    text-align: center;
}

@media (max-width: 960px) {
.about-hero,
    .about-grid,
    .about-flow-grid {
grid-template-columns: 1fr;
        justify-items: center;
    }

    .about-hero h2,
    .about-flow h2,
    .about-legal h3 {
text-align: center;
        width: 100%;
    }

    .about-hero,
    .about-hero-copy,
    .about-feature-card {
display: flex;
        flex-direction: column;
        align-items: center;
        text-align: justify;
    }

    .about-flow-grid article {
display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

    .about-flow-grid h3 {
text-align: center;
        width: 100%;
        margin-top: 10px;
    }

    .about-hero-copy {
width: 100%;
        padding: 20px 18px 22px;
    }

    .about-hero-visual {
order: -1;
        width: 100%;
        max-width: 500px;
        padding: 18px;
    }

    .about-hero-visual img {
height: auto;
    }

    .about-feature-card {
padding: 0;
        overflow: hidden;
    }

    .about-feature-card>div {
width: 100%;
        padding: 18px 18px 20px;
    }

    .about-feature-image {
width: 100%;
        aspect-ratio: 1 / 1;
        min-height: 0;
    }
}

@media (max-width: 640px) {
.about-feature-card {
text-align: justify;
    }

    .about-feature-card h2 {
text-align: center;
        width: 100%;
    }

    .about-feature-image {
width: 100%;
        aspect-ratio: 1 / 1;
        height: auto;
        min-height: 0;
    }
}

.resources article.resource-highlight {
transform: translateY(-2px);
}

.fleet-ships-table .fleet-ship-name,
.fleet-ships-table .fleet-ship-value {
font-weight: 600;
}

.gameplay-data-table {
table-layout: fixed;
}

.gameplay-data-table th,
.gameplay-data-table td {
padding: 12px 14px;
}

.gameplay-data-table td:last-child,
.gameplay-data-table th:last-child {
width: 180px;
}

.fleet-ships-table .fleet-ship-value {
text-align: center;
    font-variant-numeric: tabular-nums;
}

.fleet-ships-table th:last-child {
text-align: center;
}

.fleet-summary-table {
margin-top: 32px;
}

.fleet-ships-table .fleet-ship-row--total td,
.fleet-ships-table .fleet-ship-row--capacity td {
font-weight: 700;
}

.fleet-ships-table .fleet-ship-row--total td {
padding-top: 14px;
}

.fleet-summary-table .fleet-ship-name {
letter-spacing: 0.02em;
}

.fleet-summary-table .fleet-ship-value {
font-size: 1rem;
}

.technologies-table .technology-name {
font-weight: 600;
}

.technologies-table .technology-level {
text-align: center;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
}

.technologies-table th:last-child {
text-align: center;
}

/* ---------- Tables ---------- */
.table {
width: 100%;
    border-collapse: collapse;
}

.table-responsive {
width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin-bottom: 1rem;
}

.table th,
.table td {
text-align: left;
    padding: 10px 8px;
    transition: background 0.15s;
}

.table th {
font-size: 0.88rem;
    font-weight: 600;
    font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

/* Galaxy alternating rows */
.fleet-summary-cell {
min-width: 220px;
    white-space: normal;
    font-size: 0.92rem;
    line-height: 1.45;
}

.dashboard-card-grid {
display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 16px;
}

.dashboard-info-card {
display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 16px;
    border-radius: 10px;
}

.dashboard-info-card__header {
display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
}

.dashboard-info-card__eyebrow {
margin: 0 0 4px;
    font-size: 0.74rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.dashboard-info-card__title {
margin: 0;
    font-size: 1rem;
}

.dashboard-info-card__badges {
display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
}

.dashboard-info-card__meta {
display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin: 0;
}

.dashboard-info-card__meta dt {
margin: 0 0 4px;
    font-size: 0.76rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.dashboard-info-card__meta dd {
margin: 0;
    line-height: 1.4;
}

.dashboard-info-card__summary {
margin: 0;
    line-height: 1.5;
}

.dashboard-info-card__actions {
display: flex;
    align-items: center;
    justify-content: flex-end;
}

@media (max-width: 640px) {
.dashboard-card-grid {
grid-template-columns: 1fr;
    }

    .dashboard-info-card__header,
    .dashboard-info-card__actions {
flex-direction: column;
        align-items: stretch;
    }

    .dashboard-info-card__badges {
justify-content: flex-start;
    }

    .dashboard-info-card__meta {
grid-template-columns: 1fr;
    }
}

.galaxy-player-meta {
display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 6px;
    font-size: 0.82rem;
}

.ranking-summary {
margin: 0;
}

.ranking-rank-cell {
text-align: center;
    vertical-align: middle;
}

.ranking-rank-icon {
width: 24px;
    height: 24px;
    display: inline-block;
    vertical-align: middle;
}

.ranking-table-wrap {
width: 100%;
}

.ranking-card-list {
display: none;
}

.ranking-card {
display: grid;
    gap: 12px;
    padding: 14px;
    border-radius: 10px;
}

.ranking-card+.ranking-card {
margin-top: 12px;
}

.ranking-card__header {
display: flex;
    align-items: flex-start;
    gap: 12px;
    justify-content: space-between;
}

.ranking-card__rank {
flex: 0 0 auto;
    min-width: 28px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    text-align: center;
}

.ranking-rank-number {
display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 28px;
    min-height: 28px;
    border-radius: 10px;
    font-size: 0.82rem;
    font-weight: 700;
}

.ranking-card__identity {
flex: 1 1 auto;
    min-width: 0;
}

.ranking-card__identity h3 {
margin: 0;
    font-size: 0.98rem;
}

.ranking-card__identity p {
margin: 4px 0 0;
    font-size: 0.84rem;
}

.ranking-card__meta {
display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 14px;
    margin: 0;
}

.ranking-card__meta div {
min-width: 0;
    display: flex;
    align-items: baseline;
    gap: 6px;
    flex-wrap: wrap;
}

.ranking-card__meta dt {
margin: 0;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.ranking-card__meta dd {
margin: 0;
    font-weight: 600;
    word-break: break-word;
}

.admin-users-table {
width: 100%;
}

.admin-user-card-list {
display: none;
}

.admin-user-card {
display: grid;
    gap: 12px;
    padding: 14px;
    border-radius: 10px;
}

.admin-user-card + .admin-user-card {
margin-top: 12px;
}

.admin-user-card__header {
display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.admin-user-card__identity {
min-width: 0;
}

.admin-user-card__identity h3 {
margin: 0;
    font-size: 0.98rem;
}

.admin-user-card__identity p {
margin: 4px 0 0;
    font-size: 0.84rem;
}

.admin-user-card__meta {
display: grid;
    gap: 10px;
    margin: 0;
}

.admin-user-card__meta div {
min-width: 0;
}

.admin-user-card__meta dt {
margin: 0 0 4px;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.admin-user-card__meta dd {
margin: 0;
    font-weight: 600;
    word-break: break-word;
}

.admin-user-card__actions form,
.admin-user-card__actions button,
.admin-user-card__actions .link-btn {
width: 100%;
}

.status-badge {
display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px 10px;
    border-radius: 10px;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    white-space: nowrap;
}

/* ---------- Buttons ---------- */
button,
.link-btn {
border-radius: 10px;
    padding: 10px 16px;
    cursor: pointer;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-family: 'Exo 2', sans-serif;
    font-weight: 600;
    font-size: 0.92rem;
    letter-spacing: 0.02em;
    transition: all 0.25s;
    min-height: 44px;
    min-width: 44px;
}

button:focus-visible,
.link-btn:focus-visible,
input:focus-visible,
select:focus-visible {
outline-offset: 2px;
}

button:disabled {
cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

/* ---------- Inputs & Selects ---------- */
select {
border-radius: 10px;
    padding: 10px;
    font-family: 'Exo 2', sans-serif;
    transition: border-color 0.2s, box-shadow 0.2s;
    min-height: 44px;
}

input {
border-radius: 10px;
    padding: 10px;
    font-family: 'Exo 2', sans-serif;
    transition: border-color 0.2s, box-shadow 0.2s;
    min-height: 44px;
}

textarea {
border-radius: 10px;
    padding: 10px;
    font-family: 'Exo 2', sans-serif;
    transition: border-color 0.2s, box-shadow 0.2s;
    min-height: 44px;
    resize: vertical;
}

/* ---------- Auth pages ---------- */
.auth-layout-container {
min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 40px;
    position: relative;
}

.auth-header {
display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 28px;
    z-index: 10;
    position: relative;
}

.auth-brand-logo {
display: block;
    height: 132px;
    width: auto;
    margin: 0 auto 12px;
}

.auth-brand-title-box {
border-radius: 10px;
    padding: 12px 45px;
    text-align: center;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    position: relative;
}

.auth-brand-title-box::before,
.auth-brand-title-box::after {
content: '';
    position: absolute;
    bottom: 0;
    width: 2px;
    height: 12px;
}

.auth-brand-title-box::before {
left: -1px;
}

.auth-brand-title-box::after {
right: -1px;
}

.auth-brand-name {
margin: 0;
    font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    font-size: 1.15rem;
    font-weight: 700;
    letter-spacing: 0.25em;
    text-transform: uppercase;
}

.auth-columns {
display: flex;
    justify-content: center;
    align-items: stretch;
    gap: 40px;
    max-width: 1000px;
    width: 100%;
}

/* Left Panel */
.auth-left-panel {
display: flex;
    flex-direction: column;
    align-items: center;
    width: 380px;
    position: relative;
}

.hero-container {
display: flex;
    flex-direction: column;
    height: 100%;
    border-radius: 10px;
    overflow: hidden;
    position: relative;
}

.auth-hero-art {
display: block;
    width: 100%;
    height: 100%;
    min-height: 0;
    object-fit: cover;
    flex: 1 1 auto;
}

.auth-intro {
margin: 0;
    padding: 24px 28px;
    text-align: center;
    line-height: 1.5;
    font-size: 0.9rem;
}

/* Right Panel Form Card */
.auth-right-panel.card {
width: 380px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
    padding: 24px 28px;
    border-radius: 10px;
    position: relative;
    margin: 0;
    animation: authCardReveal 0.5s ease-out;
}

/* Register page: wider card since no left panel */
.auth-layout-container:not(.auth-layout-container--login) .auth-right-panel.card {
width: min(90vw, 480px);
    padding: 32px 36px;
}

.auth-register-form input[type="text"],
.auth-register-form input[type="email"] {
width: 100%;
}

.auth-right-panel h1 {
font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    text-align: center;
    letter-spacing: 0.05em;
    margin: 0 0 24px 0;
    font-size: 1.7rem;
}

/* Responsive adjustments */
@media (max-width: 900px) {
.auth-header {
flex-direction: row;
        align-items: center;
        justify-content: center;
        gap: 12px;
    }

    .auth-brand-logo {
height: 64px;
        margin: 0;
    }

    .auth-columns {
flex-direction: column;
        gap: 30px;
        align-items: center;
        width: 100%;
    }

    .auth-layout-container {
padding: 12px;
        justify-content: flex-start;
        margin-top: 20px;
    }

    .auth-layout-container--login .auth-right-panel.card,
    .auth-layout-container--login .auth-left-panel {
width: 100%;
        max-width: none;
    }

    .auth-layout-container--login .auth-intro {
padding: 12px 14px;
    }

    .auth-layout-container--login .auth-right-panel.card {
order: 1;
    }

    .auth-layout-container--login .auth-left-panel {
order: 2;
    }

    .auth-brand-title-box {
padding: 8px 16px;
    }
}

/* ---------- Forms ---------- */
.form {
display: grid;
    gap: 14px;
}

.inline-form {
display: flex;
    flex-wrap: wrap;
    gap: 14px;
    align-items: end;
}

.inline-form input,
.inline-form select {
width: 100%;
}

h2 .section-title-icon,
p .inline-action-icon,
a .inline-action-icon,
button .inline-action-icon,
.link-btn .inline-action-icon {
margin-right: 8px;
}

.rename-form {
display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: end;
    margin: 10px 0 14px;
}

.dashboard-facts p+.rename-form {
margin-top: -12px;
}

.dashboard-facts p {
margin-bottom: 0;
}

.rename-form label {
flex: 1 1 280px;
}

.rename-form input[type="text"] {
width: 100%;
}

.display-preferences-inline {
display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 12px;
    align-items: end;
}

.display-preferences-inline .rename-form {
margin: 0;
}

.account-security-group {
margin: 12px 0 20px;
}

.account-security-group--photo {
display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(140px, 0.65fr);
    gap: 20px;
    align-items: center;
}

.account-security-form {
margin: 0;
    gap: 12px;
}

.account-security-form label {
min-width: 0;
}

.account-security-form input[type="email"],
.account-security-form input[type="password"],
.account-security-form input[type="file"] {
width: 100%;
}

.account-security-form button {
flex: 0 0 220px;
    min-width: 220px;
    white-space: nowrap;
}

.account-security-form--photo label {
flex: 1 1 min(520px, 100%);
}

.account-security-form--photo button {
min-height: 46px;
    padding: 11px 18px;
    letter-spacing: 0.03em;
}

.account-security-help {
flex: 1 1 100%;
    margin-top: 2px;
}

.account-security-current-photo {
display: grid;
    justify-items: center;
    align-content: center;
    gap: 10px;
    padding: 10px 14px 12px;
    border: 0;
    border-radius: 0;
}

.account-security-current-photo img {
width: 78px;
    height: 78px;
    border-radius: 50%;
    object-fit: cover;
}

.account-security-current-photo .section-subtitle {
margin: 0;
    text-align: center;
}

.account-security-form + .account-security-form {
margin-top: 14px;
}

@media (max-width: 980px) {
.account-security-group--photo {
grid-template-columns: 1fr;
        align-items: start;
        gap: 14px;
    }

    .account-security-current-photo {
justify-items: start;
        text-align: left;
    }

    .account-security-current-photo .section-subtitle {
text-align: left;
    }
}

@media (max-width: 740px) {
.account-security-form {
gap: 10px;
    }

    .account-security-form button {
width: 100%;
        min-width: 0;
        flex-basis: 100%;
    }
}

label {
display: grid;
    gap: 4px;
    font-size: 0.92rem;
}

label.checkbox-label {
display: flex;
    align-items: center;
    gap: 12px;
    cursor: pointer;
    width: auto;
    font-size: 1rem;
}

label.checkbox-label input[type="checkbox"] {
width: 20px;
    height: 20px;
    margin: 0;
    cursor: pointer;
    transition: transform 0.15s ease;
}

label.checkbox-label input[type="checkbox"]:active {
transform: scale(0.9);
}

.field-help {
font-size: 0.8rem;
    line-height: 1.4;
}

.input-with-action {
position: relative;
    display: block;
}

.input-with-action input {
width: 100%;
}

.input-with-action--inline {
display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    align-items: center;
}

.password-toggle {
width: 98px;
    min-width: 98px;
    padding: 6px 10px;
    border-radius: 10px;
    font-size: 0.78rem;
    box-shadow: none;
    align-self: stretch;
}

.password-toggle:hover {
box-shadow: none;
}

/* ---------- Feedback ---------- */
.error {
border-radius: 10px;
    padding: 10px 12px;
    margin: 0 0 12px;
    animation: slideDown 0.35s ease-out;
}

.flash {
display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    border-radius: 10px;
    padding: 10px 12px;
    margin: 0 0 12px;
    animation: slideDown 0.35s ease-out;
    transition: opacity 0.25s ease, transform 0.25s ease, max-height 0.25s ease, margin 0.25s ease, padding 0.25s ease;
    opacity: 1;
    max-height: 200px;
    overflow: hidden;
}

.flash[hidden] {
    display: none;
}

.flash--static {
justify-content: flex-start;
}

.auth-login-form,
.auth-register-form {
gap: 18px;
}

.auth-login-form button[type="submit"],
.auth-register-form button[type="submit"] {
width: 100%;
    margin-top: 4px;
    padding: 12px 16px;
    font-size: 1rem;
}

.auth-register-form .input-with-action--inline {
display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    align-items: center;
}

.auth-footer {
text-align: center;
    margin-top: 24px;
    font-size: 0.9rem;
}

.flash-close {
min-width: 32px;
    min-height: 32px;
    padding: 0;
    border-radius: 10px;
    font-size: 1.1rem;
    line-height: 1;
    flex: 0 0 auto;
}

.flash-close:hover {
box-shadow: none;
}

.flash.is-dismissing {
opacity: 0;
    transform: translateY(-8px);
    max-height: 0;
    margin: 0;
    padding-top: 0;
    padding-bottom: 0;
}

@keyframes slideDown {
from {
opacity: 0;
        transform: translateY(-10px);
    }

    to {
opacity: 1;
        transform: translateY(0);
    }
}

@keyframes authCardReveal {
from {
opacity: 0;
        transform: translateY(18px);
    }

    to {
opacity: 1;
        transform: translateY(0);
    }
}

.section-subtitle {
margin: 6px 0 0;
    font-size: 0.92rem;
    max-width: 100ch;
}

/* ---------- Install Wizard ---------- */
.install-wizard {
max-width: 1280px;
    margin: 0 auto;
    padding: 32px 24px 48px;
}

.install-wizard .auth-header {
margin-bottom: 24px;
}

.install-header-main {
display: flex;
    flex-direction: column;
    align-items: center;
}

.install-locale-switcher {
margin-top: 16px;
}

.install-wizard .card {
max-width: 980px;
    margin: 0 auto;
    padding: 28px 32px 32px;
}

.install-wizard .card>h2 {
text-align: left;
    font-size: 1.6rem;
    margin: 0 0 8px;
    font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    letter-spacing: 0.04em;
}

.install-wizard .card>h2 .section-title-icon {
width: 28px;
    height: 28px;
}

/* ---- Stepper ---- */
.install-stepper {
display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 0;
    list-style: none;
    padding: 0;
    margin: 0 0 28px;
    counter-reset: step-counter;
}

.install-stepper li {
display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    position: relative;
    flex: 1 1 0;
    max-width: 180px;
}

.install-stepper li::before {
counter-increment: step-counter;
    content: counter(step-counter);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 10px;
    font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    font-size: 0.85rem;
    font-weight: 700;
    transition: all 0.3s ease;
    position: relative;
    z-index: 2;
}

.install-stepper li::after {
content: '';
    position: absolute;
    top: 19px;
    left: calc(50% + 22px);
    width: calc(100% - 44px);
    height: 2px;
    z-index: 1;
}

.install-stepper li:last-child::after {
display: none;
}

.install-stepper-label {
font-size: 0.78rem;
    text-align: center;
    line-height: 1.3;
    transition: color 0.3s ease;
}

/* Completed step */
/* Active step */
.install-stepper li[aria-current="step"]::before {
animation: stepPulse 2s ease-in-out infinite;
}

.install-stepper li[aria-current="step"] .install-stepper-label {
font-weight: 600;
}

/* ---- Form layout ---- */
.install-form {
display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
    width: 100%;
}

.install-form .inline-form {
display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
    width: 100%;
}

.install-form label {
flex: 1 1 0;
    min-width: 0;
}

.install-form input,
.install-form select {
width: 100%;
}

/* ---- Section titles ---- */
.install-section-title {
display: flex;
    align-items: center;
    gap: 10px;
    margin: 24px 0 10px;
    padding-bottom: 10px;
    font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    font-size: 0.95rem;
    letter-spacing: 0.04em;
}

.install-section-title:first-of-type {
margin-top: 0;
}

.install-section-title .section-title-icon {
width: 20px;
    height: 20px;
    flex-shrink: 0;
}

/* ---- Navigation buttons ---- */
.install-nav {
display: flex;
    justify-content: flex-end;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-top: 12px;
    padding-top: 6px;
}

.install-nav--primary {
margin-top: 4px;
    margin-bottom: 6px;
}

.install-nav button {
background: linear-gradient(135deg, #f59e0b, #f97316);
    border: 1px solid rgba(249, 115, 22, 0.55);
    color: #fff7ed;
    min-width: 148px;
    box-shadow: 0 12px 28px rgba(217, 119, 6, 0.24);
}

.install-nav button:hover {
background: linear-gradient(135deg, #fbbf24, #fb923c);
    border-color: rgba(251, 146, 60, 0.7);
    transform: translateY(-1px);
}

.install-nav button[type="submit"]:last-child {
margin-left: 0;
}

.install-nav .install-back-btn {
background: rgba(37, 99, 235, 0.08);
    border: 1px solid rgba(37, 99, 235, 0.24);
    color: #1d4ed8;
    box-shadow: none;
}

.install-nav .install-back-btn:hover {
box-shadow: none;
}

/* ---- Responsive ---- */
@media (max-width: 640px) {
.install-wizard {
padding: 20px 12px 36px;
    }

    .install-wizard .auth-header {
flex-direction: column;
    }

    .install-locale-switcher {
margin-top: 12px;
    }

    .install-wizard .card {
padding: 20px 16px 24px;
    }

    .install-stepper-label {
display: none;
    }

    .install-stepper li::after {
left: calc(50% + 20px);
        width: calc(100% - 40px);
    }

    .install-form .inline-form {
grid-template-columns: 1fr;
    }
}

/* ---------- Admin universe ---------- */
.admin-universe-panel {
display: grid;
    gap: 14px;
}

.admin-universe-intro {
margin: -6px 0 4px;
    font-size: 0.9rem;
}

.admin-universe-sticky-tools {
position: sticky;
    top: 10px;
    z-index: 12;
    display: grid;
    gap: 8px;
    padding: 10px;
    border-radius: 10px;
    backdrop-filter: blur(3px);
}

.admin-universe-dirty-indicator {
margin: 0;
    font-size: 0.82rem;
}

.admin-universe-form {
gap: 18px;
}

.admin-universe-section {
margin: 0;
    padding: 14px;
    border-radius: 10px;
}

.admin-universe-section legend {
padding: 0 8px;
    font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    font-size: 0.8rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.admin-universe-grid {
display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
}

.admin-universe-field {
gap: 5px;
}

.admin-universe-field .field-help {
min-height: 1.1rem;
}

.admin-universe-actions {
display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
    padding-top: 6px;
}

.admin-universe-actions button[type="submit"] {
min-width: 220px;
}

.smtp-admin-grid {
grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
}

.smtp-admin-checkbox {
align-self: end;
    min-height: 42px;
    margin: 0;
}

.smtp-admin-actions {
justify-content: flex-start;
}

.smtp-admin-actions button[type="submit"] {
min-width: 190px;
}

.admin-universe-reset-btn:hover {
box-shadow: none;
}

@media (max-width: 760px) {
.admin-users-settings-grid {
grid-template-columns: 1fr;
    }

    .admin-universe-sticky-tools {
position: static;
    }

    .admin-universe-grid {
grid-template-columns: 1fr;
    }

    .admin-universe-actions {
justify-content: stretch;
    }

    .admin-universe-actions .admin-universe-reset-btn {
width: 100%;
    }

    .admin-universe-actions button[type="submit"] {
width: 100%;
        min-width: 0;
    }

    .smtp-admin-checkbox {
min-height: 0;
    }
}

.section-header {
display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}

/* Merged into .section-subtitle above */
/* ---------- Reports ---------- */
.reports-filter-form {
display: grid;
    gap: 10px;
    margin-bottom: 18px;
}

.reports-filter-buttons {
display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.reports-filter-icon {
width: 16px;
    height: 16px;
    display: inline-block;
    flex: 0 0 auto;
}

.reports {
display: grid;
    gap: 10px;
}

.reports-delete-all-form {
margin-bottom: 18px;
    align-self: flex-start;
}

.report-item {
border-left-width: 4px;
    border-radius: 10px;
    padding: 12px;
    transition: border-color 0.2s, background 0.2s;
}

.report-item h3 {
margin: 0 0 4px;
    font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    font-size: 0.95rem;
}

.report-title {
display: inline-flex;
    align-items: center;
    gap: 8px;
}

.report-head {
display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.report-item p {
margin: 8px 0 0;
}

.report-message {
white-space: pre-line;
}

.report-badge {
display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    border-radius: 10px;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.report-badge--icon-only {
padding: 5px;
    gap: 0;
    flex: 0 0 auto;
}

.report-badge-icon {
width: 14px;
    height: 14px;
    opacity: 0.9;
}

.pagination {
display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 16px;
    flex-wrap: wrap;
}

.pagination-status {
font-size: 0.92rem;
}

.message-compose-grid {
display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 14px;
}

.message-compose-grid input,
.message-compose-dialog textarea {
width: 100%;
}

.messages-toolbar {
display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 14px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.messages-toolbar-actions {
display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.messages-shell {
display: grid;
    grid-template-columns: minmax(300px, 420px) minmax(0, 1fr);
    gap: 20px;
    align-items: start;
}

.message-list-panel,
.message-detail-panel {
border-radius: 10px;
}

.message-list-panel {
overflow: hidden;
}

.message-detail-panel {
padding: 14px;
    min-height: 420px;
}

.messages-unread-count {
display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    padding: 0 6px;
    margin-left: 8px;
    border-radius: 10px;
    font-size: 0.8rem;
}

.message-list {
display: grid;
    gap: 10px;
    padding: 10px 10px 10px 0;
    max-height: 560px;
    overflow-y: auto;
}

.message-item {
padding: 0;
    border-radius: 10px;
}

.message-item-select {
display: grid;
    gap: 8px;
    width: 100%;
    text-align: left;
    border: 0;
    border-radius: 10px;
    padding: 10px 12px 10px 10px;
    min-height: 0;
}

.message-item-select:hover {
box-shadow: none;
}

.message-compose-modal {
position: fixed;
    inset: 0;
    z-index: 1200;
    display: grid;
    place-items: center;
    padding: 24px;
}

.message-compose-modal[hidden] {
display: none;
}

.message-compose-backdrop {
position: absolute;
    inset: 0;
    backdrop-filter: blur(4px);
}

.message-compose-dialog {
position: relative;
    width: min(760px, calc(100vw - 32px));
    max-height: calc(100vh - 48px);
    overflow: auto;
    z-index: 1;
}

.message-compose-head {
display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
}

.message-compose-head h2 {
margin-bottom: 0;
}

.message-compose-close {
min-width: 40px;
    min-height: 40px;
    padding: 0;
    border-radius: 10px;
    font-size: 1.4rem;
    line-height: 1;
}

body.compose-modal-open {
overflow: hidden;
}

body.missile-modal-open {
overflow: hidden;
}

body.image-zoom-open {
overflow: hidden;
}

.message-item-head {
display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
    margin-bottom: 10px;
}

.alliance-pending-application-head {
align-items: center;
}

.alliance-pending-application-head form {
align-self: center;
    display: flex;
    align-items: center;
}

.alliance-pending-application-head .link-btn {
align-self: center;
}

.alliance-application-item-head {
align-items: center;
}

.alliance-application-actions {
align-items: center;
    align-self: center;
}

.alliance-application-actions form {
display: flex;
    align-items: center;
}

.alliance-application-item-head>.alliance-application-actions {
align-self: center !important;
}

.message-item h3 {
margin: 0 0 3px;
    font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    font-size: 0.98rem;
}

.message-item-profile {
display: flex;
    align-items: flex-start;
    gap: 10px;
    min-width: 0;
}

.message-avatar {
width: 34px;
    height: 34px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    flex: 0 0 auto;
}

.message-avatar img {
display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: inherit;
}

.friend-list-avatar {
width: 42px;
    height: 42px;
    border-radius: 999px;
    overflow: hidden;
    padding: 0;
}

.friend-list-avatar img {
display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.message-preview {
margin: 0;
    font-size: 0.88rem;
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
}

.message-detail-head {
display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
    margin-bottom: 10px;
}

.message-state-badge {
margin: 0 0 10px;
}

.alliance-role {
display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 3px 9px;
    border-radius: 10px;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.message-meta {
margin: 0;
    font-size: 0.88rem;
}

.message-body {
line-height: 1.55;
    white-space: normal;
    overflow-wrap: anywhere;
    margin-top: 8px;
    padding-top: 10px;
}

.messages-empty-state {
margin: 0;
    padding: 16px;
    border-radius: 10px;
}

.alliance-chat-list {
margin-top: 14px;
    max-height: 420px;
    overflow-y: auto;
    padding: 10px 4px;
    display: grid;
    gap: 10px;
}

.alliance-chat-shell {
display: grid;
    gap: 14px;
}

.alliance-chat-empty {
margin: 0;
    padding: 18px;
    border-radius: 10px;
}

.alliance-chat-message {
display: grid;
    gap: 4px;
    justify-items: start;
    border: 0;
    box-shadow: none;
    padding: 0;
}

.alliance-chat-message-own {
justify-items: end;
}

.alliance-chat-meta {
width: min(100%, 78ch);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 0 8px;
}

.alliance-chat-meta-main {
display: block;
}

.alliance-chat-author {
display: block;
    margin-bottom: 2px;
    font-size: 0.92rem;
}

.alliance-chat-time {
font-size: 0.78rem;
    width: fit-content;
    max-width: min(100%, 78ch);
    padding: 0 8px;
}

.alliance-chat-bubble {
width: fit-content;
    max-width: min(100%, 78ch);
    padding: 14px 16px;
    border-radius: 14px 14px 14px 6px;
    white-space: normal;
    overflow-wrap: anywhere;
}

.alliance-chat-message-own .alliance-chat-bubble {
border-radius: 14px 14px 6px 14px;
}

.alliance-chat-message-own .alliance-chat-meta-main {
text-align: right;
    margin-left: auto;
}

.alliance-chat-message-own .alliance-chat-time {
margin-left: auto;
    text-align: right;
}

.alliance-chat-delete {
border: 0;
    font-size: 0.8rem;
    padding: 4px 0;
    cursor: pointer;
}

.alliance-chat-delete:hover {
text-decoration: underline;
}

.alliance-chat-composer {
display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    align-items: end;
    padding-top: 10px;
}

.alliance-chat-composer label {
display: block;
    width: 100%;
    min-width: 0;
}

.alliance-chat-composer textarea {
display: block;
    width: 100%;
    min-height: 78px;
    resize: vertical;
    box-sizing: border-box;
}

.alliance-chat-composer button {
justify-self: end;
}

.sr-only {
position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

@media (max-width: 980px) {
.messages-shell {
grid-template-columns: 1fr;
    }

    .message-detail-panel {
min-height: 0;
    }
}

.fleet-mission-ships {
display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px 24px;
}

.fleet-mission-ships label {
display: grid;
    grid-template-columns: minmax(0, 1fr) 140px;
    gap: 12px;
    align-items: center;
}

.fleet-mission-ships input[type="number"] {
width: 100%;
}

.mission-section-title {
margin: 20px 0 6px;
}

.mission-steps {
display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    list-style: none;
    margin: 0 0 14px;
    padding: 0;
}

.mission-steps li {
border-radius: 10px;
    padding: 8px 10px;
    text-align: center;
    font-size: 0.82rem;
    font-weight: 700;
}

.mission-inline-actions {
display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin: 8px 0 12px;
}

.mission-step-actions {
display: flex;
    gap: 8px;
    justify-content: flex-end;
    margin-top: 14px;
}

.mission-form button:disabled {
opacity: 0.45;
    cursor: not-allowed;
}

.mission-live-summary {
margin-top: 14px;
    border-radius: 10px;
    padding: 10px 12px;
}

.mission-live-summary p {
margin: 0 0 6px;
}

.mission-live-summary p:last-child {
margin-bottom: 0;
}

/* ---------- Mission cargo grid ---------- */
.mission-cargo-grid {
display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.mission-cargo-grid label {
display: grid;
    gap: 6px;
}

.mission-cargo-grid input {
width: 100%;
}

/* ---------- Mission parameters grid ---------- */
.mission-params-grid {
display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 14px;
}

.mission-params-grid label {
display: grid;
    gap: 6px;
}

.mission-params-grid input,
.mission-params-grid select {
width: 100%;
}

.mission-acs-options .inline-form {
align-items: flex-end;
}

.mission-acs-options .checkbox-label {
margin-bottom: 0;
    min-height: 44px;
    /* Matches input height for perfect flex-end alignment */
}

.mission-help-group {
margin-top: 12px;
}

.mission-help-group p {
margin: 0;
}

.requirements-list {
margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: nowrap;
    white-space: nowrap;
    overflow-x: auto;
}

.requirements-list li {
margin: 0;
}

.requirements-list li+li::before {
content: "|";
    margin-right: 8px;
}

.construction-meta--requirements {
display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.galaxy-actions {
display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.missile-modal {
position: fixed;
    inset: 0;
    z-index: 1200;
    display: grid;
    place-items: center;
    padding: 20px;
}

.missile-modal[hidden] {
display: none;
}

.missile-modal-backdrop {
position: absolute;
    inset: 0;
    backdrop-filter: blur(2px);
}

.missile-modal-dialog {
position: relative;
    width: min(560px, calc(100vw - 28px));
    max-height: calc(100vh - 40px);
    overflow: auto;
    z-index: 1;
}

.missile-modal-head {
display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.missile-modal-close {
border: 0;
    font-size: 1.8rem;
    line-height: 1;
    min-height: 0;
    min-width: 0;
    padding: 0 2px;
}

.missile-modal-close:hover {
box-shadow: none;
}

.missile-modal-target {
margin: 10px 0 14px;
    font-size: 0.92rem;
}

.missile-modal-status {
margin: 0 0 14px;
    font-size: 0.85rem;
}

.missile-modal-form {
display: grid;
    gap: 10px;
}

.missile-modal-form label {
display: grid;
    gap: 6px;
}

.missile-modal-form input,
.missile-modal-form select {
width: 100%;
}

.zoomable-image {
cursor: zoom-in;
}

.image-zoom-modal {
position: fixed;
    inset: 0;
    z-index: 1300;
    display: grid;
    place-items: center;
    padding: 20px;
}

.image-zoom-modal[hidden] {
display: none;
}

.image-zoom-backdrop {
position: absolute;
    inset: 0;
    backdrop-filter: blur(3px);
}

.image-zoom-dialog {
position: relative;
    z-index: 1;
    margin: 0;
    width: min(980px, calc(100vw - 28px));
    max-height: calc(100vh - 40px);
    display: grid;
    gap: 10px;
    justify-items: center;
}

.image-zoom-dialog img {
width: auto;
    max-width: 100%;
    max-height: calc(100vh - 160px);
    border-radius: 10px;
}

.image-zoom-close {
position: absolute;
    top: 8px;
    right: 10px;
    border: 0;
    font-size: 1.9rem;
    line-height: 1;
    min-height: 0;
    min-width: 0;
    padding: 0 2px;
}

.image-zoom-close:hover {
box-shadow: none;
}

.image-zoom-caption {
margin: 0;
    text-align: center;
    font-size: 0.9rem;
}

.protection-hint {
margin: 10px 0 0;
    padding: 10px 12px;
    border-radius: 10px;
    font-size: 0.88rem;
}

.mission-step-warning-message {
margin-bottom: 12px;
}

.galaxy-actions form,
.message-item-head form {
margin: 0;
}

.queue-item-actions {
display: flex;
    align-items: center;
}

.queue-item-actions form {
margin: 0;
}

/* ---------- App Shell ---------- */
.app-shell {
display: grid;
    grid-template-columns: 230px 1fr;
    min-height: 100vh;
    position: relative;
}

/* ---------- Sidebar ---------- */
.sidebar {
padding: 14px 14px 18px;
    position: sticky;
    top: 0;
    z-index: 1000;
    height: 100vh;
    overflow: auto;
    display: flex;
    flex-direction: column;
}

/* Custom scrollbar (global) */
*::-webkit-scrollbar {
width: 6px;
    height: 6px;
}

*::-webkit-scrollbar-thumb {
border-radius: 10px;
}

/* Firefox scrollbar */
* {
scrollbar-width: thin;
}

.sidebar h1 {
margin: 0 0 8px;
    font-size: 1.05rem;
    font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    letter-spacing: 0.08em;
    -webkit-background-clip: text;
    background-clip: text;
}

.sidebar-brand {
display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    text-align: center;
}

.sidebar-brand--no-icon {
gap: 0;
}

.sidebar-brand-link {
display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 999px;
}

.sidebar-brand-icon {
width: 100%;
    height: 100%;
    display: block;
    border-radius: inherit;
    object-fit: cover;
}

.sidebar-brand-name {
display: block;
    text-decoration: none;
}

.sidebar-brand-name:hover {
text-decoration: underline;
}

.sidebar-planet {
display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin: 0 0 18px;
    font-size: 0.84rem;
    text-align: center;
}

.sidebar-planet-name-button {
border: 0;
    border-radius: 0;
    box-shadow: none;
    font: inherit;
    padding: 0;
    min-height: 0;
    min-width: 0;
    display: inline;
    cursor: pointer;
    text-align: inherit;
}

.sidebar-planet-name-button:hover,
.sidebar-planet-name-button:focus-visible {
box-shadow: none;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.sidebar-planet-rename-modal {
position: fixed;
    inset: 0;
    z-index: 2200;
    display: grid;
    place-items: center;
    padding: 16px;
}

.sidebar-planet-rename-modal[hidden] {
display: none;
}

.sidebar-planet-rename-backdrop {
position: absolute;
    inset: 0;
    border: 0;
    padding: 0;
    min-width: 0;
    min-height: 0;
    box-shadow: none;
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
}

.sidebar-planet-rename-backdrop:hover,
.sidebar-planet-rename-backdrop:active {
box-shadow: none;
}

.sidebar-planet-rename-dialog {
position: relative;
    z-index: 1;
    width: min(420px, calc(100% - 24px));
    padding: 16px;
}

.sidebar-planet-rename-dialog h3 {
margin: 0 0 10px;
}

.sidebar-planet-rename-close {
position: absolute;
    top: 10px;
    right: 10px;
    width: 30px;
    height: 30px;
    padding: 0;
    min-height: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    border: 0;
    border-radius: 10px;
    cursor: pointer;
}

body.sidebar-planet-rename-open {
overflow: hidden;
}

.sidebar-planet-rename-form {
display: grid;
    gap: 8px;
}

.sidebar-planet-rename-form input[type="text"] {
width: 100%;
}

.sidebar-planet-rename-form button {
width: 100%;
}

.sidebar-nav {
display: grid;
    gap: 6px;
    flex: 1 1 auto;
    align-content: start;
}

.sidebar-section-title {
margin: 16px 10px 8px;
    font-size: 0.7rem;
    font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    font-weight: 600;
    letter-spacing: 0.09em;
    text-transform: uppercase;
}

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

.sidebar-link {
display: flex;
    align-items: center;
    gap: 10px;
    padding: 11px 14px;
    border-radius: 10px;
    text-decoration: none;
    transition: all 0.18s ease;
    font-size: 0.88rem;
    font-weight: 400;
    min-height: 44px;
}

.sidebar-link.active {
font-weight: 600;
}

.sidebar-link .nav-icon {
width: 24px;
    height: 24px;
    flex-shrink: 0;
}

.sidebar-messages-unread {
position: static;
    margin-left: auto;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    font-size: 0.7rem;
    font-weight: 700;
}

.messages-unread-count[hidden],
.sidebar-messages-unread[hidden] {
display: none !important;
}

.sidebar-messages-unread.is-pulsing {
animation: sidebarUnreadPulse 600ms ease-out;
}

@keyframes sidebarUnreadPulse {
0% {
transform: scale(1);
    }

    45% {
transform: scale(1.08);
    }

    100% {
transform: scale(1);
    }
}

.sidebar-footer {
margin-top: 16px;
    padding-top: 14px;
}

.sidebar-logout {
display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    text-align: center;
}

/* ---------- Main content ---------- */
.app-main {
padding: 16px 24px 24px;
    min-width: 0;
    font-size: 0.92rem;
}

@media (min-width: 601px) {
.app-main {
padding-left: 14px;
        padding-right: 14px;
    }
}

/* ---------- Header resource bar ---------- */
/* ---------- Construction cards ---------- */
.construction-list {
display: grid;
    gap: 16px;
}

.construction-card {
display: grid;
    grid-template-columns: 160px 1fr 240px;
    gap: 16px;
    border-radius: 10px;
    padding: 14px;
    align-items: center;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

.construction-image img {
width: 100%;
    height: 100%;
    aspect-ratio: 1 / 1;
    object-fit: contain;
    border-radius: 10px;
    display: block;
    transition: border-color 0.3s;
}

.construction-mobile-title {
display: none;
}

.construction-mobile-link {
text-decoration: none;
}

.construction-mobile-link:hover,
.construction-mobile-link:focus-visible {
text-decoration: underline;
}

.construction-main h3 {
margin: 0 0 6px;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    font-size: 0.98rem;
    letter-spacing: 0.02em;
}

.construction-main p {
margin: 0 0 6px;
}

.build-state-pill {
display: inline-block;
    padding: 3px 9px;
    border-radius: 10px;
    font-size: 0.75rem;
    font-weight: 700;
}

.construction-main p:not(.construction-meta) {
text-align: justify;
}

.construction-meta {
font-size: 0.9rem;
}

/* Cost coloring */
.construction-action {
display: grid;
    gap: 8px;
    justify-items: end;
    align-content: center;
}

.construction-action form {
width: auto;
}

.construction-action .inline-form {
width: auto;
}

.construction-action input[type="number"] {
width: 100%;
}

.construction-build-form {
display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 10px;
    width: auto;
}

.construction-stepper {
display: inline-grid;
    grid-template-columns: 28px minmax(44px, 60px) 28px;
    align-items: stretch;
    justify-self: start;
    width: fit-content;
    max-width: 100%;
    border-radius: 0;
    overflow: hidden;
}

.construction-stepper--mission {
grid-template-columns: 28px minmax(44px, 60px) 28px;
}

.construction-stepper input[type="number"] {
width: 100%;
    box-sizing: border-box;
    min-width: 0;
    min-height: 32px;
    padding: 4px 4px;
    border: 0;
    border-radius: 0;
    text-align: center;
    -moz-appearance: textfield;
    appearance: textfield;
}

.construction-stepper input[type="number"]::-webkit-outer-spin-button,
.construction-stepper input[type="number"]::-webkit-inner-spin-button {
-webkit-appearance: none;
    margin: 0;
}

.construction-stepper-button {
min-height: 32px;
    min-width: 28px;
    padding: 0;
    border: 0;
    border-radius: 0;
    font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
    font-size: 0.85rem;
    font-weight: 700;
    line-height: 1;
    box-shadow: none;
}

.construction-stepper-button:hover:not(:disabled),
.construction-stepper-button:focus-visible:not(:disabled) {
box-shadow: none;
}

.construction-stepper-button:disabled {
opacity: 0.45;
    cursor: not-allowed;
}

.construction-build-quantity {
width: 100% !important;
    min-width: 0;
    min-height: 32px;
    text-align: center !important;
    border: 0;
    border-radius: 0;
    -moz-appearance: textfield;
    appearance: textfield;
}

.construction-build-quantity::-webkit-outer-spin-button,
.construction-build-quantity::-webkit-inner-spin-button {
-webkit-appearance: none;
    margin: 0;
}

.construction-build-submit {
min-height: 40px;
    padding: 8px 12px;
    font-size: 0.82rem;
}

.construction-build-max {
width: 100%;
    text-align: right;
    margin-top: -2px;
}

.queue-list {
display: grid;
    gap: 10px;
    margin: 0 0 18px;
}

.queue-item {
display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    padding: 12px 14px;
    border-radius: 10px;
}

.queue-item-main {
flex: 1 1 0;
    min-width: 0;
}

.queue-item-title {
margin: 0 0 4px;
    font-weight: 600;
}

.queue-item-meta {
margin: 0;
    font-size: 0.88rem;
}

.queue-item-meta-action {
display: inline-flex;
    align-items: center;
    margin-left: 12px;
}

.queue-item-meta-action form {
margin: 0;
}

.queue-item-timer {
flex: 0 0 auto;
    text-align: right;
    white-space: nowrap;
    font-size: 0.88rem;
}

/* ---------- Progress bar for active construction ---------- */
.construction-progress {
width: 100%;
    height: 12px;
    border-radius: 10px;
    overflow: hidden;
    margin-top: 10px;
}

.queue-item>.construction-progress {
flex: 1 0 100%;
    margin-top: 0;
}

.construction-progress-bar {
height: 100%;
    border-radius: 10px;
    transition: width 1s linear;
    animation: progressPulse 2s ease-in-out infinite;
}

@keyframes progressPulse {
0%,
    100% {
opacity: 1;
    }

    50% {
opacity: 0.7;
    }
}

/* ---------- Resource settings ---------- */
.resource-settings-sections {
display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 14px;
}

.resource-settings-group {
margin: 0;
    padding: 12px;
    border-radius: 12px;
}

.resource-settings-group legend {
padding: 0 6px;
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.resource-settings-grid {
display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 12px;
}

.resource-settings-grid label {
padding: 10px;
    border-radius: 10px;
}

.resource-settings-grid input {
width: 100%;
}

.resource-settings-table {
display: grid;
    grid-template-columns: minmax(0, 1fr) 130px;
    border-radius: 10px;
    overflow: hidden;
}

.resource-settings-table__head {
padding: 9px 10px;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.resource-settings-table__head:nth-child(2n) {
text-align: center;
}

.resource-settings-table__cell {
padding: 10px;
}

.resource-settings-table__name {
display: flex;
    align-items: center;
}

.resource-settings-table__value {
display: flex;
    align-items: center;
    justify-content: flex-end;
}

.resource-settings-table__value input {
width: 100px;
    text-align: right;
}

.resource-settings-table__cell:nth-last-child(-n + 2) {
border-bottom: 0;
}

@media (max-width: 700px) {
.resource-settings-table {
grid-template-columns: minmax(0, 1fr) 110px;
    }

    .resource-settings-table__value input {
width: 86px;
    }

    .resource-settings-table .construction-stepper-button {
font-size: 0.72rem;
    }
}

/* ---------- Queue badges ---------- */
.queue-badge {
display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    border-radius: 10px;
    font-size: 0.85rem;
    font-weight: 500;
}

/* ---------- Countdown styling ---------- */
[data-countdown-end] {
font-weight: 600;
    font-variant-numeric: tabular-nums;
}

.countdown-urgent {
animation: urgentPulse 1s ease-in-out infinite;
}

@keyframes urgentPulse {
0%,
    100% {
opacity: 1;
    }

    50% {
opacity: 0.6;
    }
}

/* ---------- Galaxy navigation quick buttons ---------- */
.galaxy-toolbar {
display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: 12px;
}

.galaxy-toolbar-main {
display: flex;
    align-items: end;
    gap: 10px;
    flex-wrap: wrap;
}

.galaxy-toolbar-nav {
display: flex;
    align-items: end;
    gap: 8px;
    padding: 0;
    border-radius: 0;
    border: 0;
    box-shadow: none;
}

.galaxy-toolbar-fields {
display: flex;
    gap: 10px;
    align-items: end;
    flex-wrap: wrap;
}

.galaxy-toolbar-field {
min-width: 92px;
    font-size: 0.8rem;
    font-weight: 600;
}

.galaxy-toolbar-input {
min-height: 38px;
    text-align: center;
    font-variant-numeric: tabular-nums;
}

.galaxy-toolbar-field input {
width: 100%;
}

.galaxy-toolbar-submit {
min-height: 32px;
    padding-inline: 14px;
}

.galaxy-toolbar-summary {
display: flex;
    gap: 10px;
    align-items: center;
    justify-content: center;
    padding: 8px 10px;
    border-radius: 10px;
    font-size: 0.84rem;
    white-space: nowrap;
}

.galaxy-position-cell {
font-weight: 700;
    text-align: center;
}

.galaxy-planet-cell {
display: grid;
    gap: 4px;
}

.galaxy-planet-line {
display: flex;
    gap: 8px;
    align-items: center;
    flex-wrap: wrap;
}

.galaxy-planet-meta {
font-size: 0.8rem;
}

.galaxy-inline-pill {
display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 0.78rem;
}

.galaxy-debris-cell {
display: grid;
    gap: 4px;
}

.galaxy-card-list {
display: none;
}

.galaxy-card {
display: grid;
    gap: 12px;
    padding: 14px;
    border-radius: 10px;
}

.galaxy-card+.galaxy-card {
margin-top: 12px;
}

.galaxy-card__header {
display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
}

.galaxy-card__eyebrow {
margin: 0 0 4px;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.galaxy-card__title,
.galaxy-card__name {
margin: 0;
    font-weight: 700;
}

.galaxy-card__meta {
margin: 0;
    font-size: 0.84rem;
}

.galaxy-card__section {
display: grid;
    gap: 6px;
}

.galaxy-card__actions {
display: grid;
    gap: 10px;
}

.overview-empire-list,
.overview-report-list {
display: grid;
    gap: 12px;
}

.overview-empire-item,
.overview-report-item {
display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: center;
    padding: 12px 14px;
    border-radius: 10px;
}

.overview-empire-main,
.overview-report-item {
min-width: 0;
}

.overview-empire-title,
.overview-report-title {
margin: 0;
    font-weight: 700;
}

.overview-empire-meta,
.overview-report-head {
margin: 4px 0 0;
    font-size: 0.84rem;
}

.empire-card-list {
display: none;
}

.empire-card {
align-items: flex-start;
}

.empire-card-meta {
display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
}

.empire-card-action {
flex: 0 0 auto;
}

.overview-report-head {
display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
}

.dashboard-section--overview .dashboard-facts {
display: grid;
    gap: 12px;
}

.dashboard-live-sections {
margin-top: 24px;
    margin-bottom: 24px;
}

.admin-universe-form {
gap: 14px;
}

/* ---------- Hamburger toggle (mobile) ---------- */
.hamburger {
display: none;
    background: none;
    border: none;
    cursor: pointer;
    line-height: 0;
    padding: 8px;
    position: fixed;
    top: 12px;
    left: 12px;
    z-index: 1001;
    min-height: 44px;
    min-width: 44px;
    border-radius: 10px;
    transition: background 0.2s;
}

.hamburger-icon {
display: block;
    flex: 0 0 auto;
    width: 20px;
    height: 20px;
}

.hamburger.is-open {
opacity: 0;
    pointer-events: none;
}

/* ---------- Mobile overlay ---------- */
.sidebar-overlay {
display: none;
}

/* ===================================================
   Responsive
   =================================================== */
@media (max-width: 980px) {
.hamburger {
display: flex;
        align-items: center;
        justify-content: center;
        width: 52px;
        height: 48px;
        padding: 0;
        border: 0;
        box-shadow: none;
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
        top: 10px;
        left: 0;
        border-radius: 10px;
        min-height: 0;
        min-width: 0;
    }

    .app-shell {
grid-template-columns: 1fr;
    }

    .sidebar {
position: fixed;
        top: 0;
        left: 0;
        width: 280px;
        height: 100vh;
        height: 100dvh;
        max-height: 100dvh;
        z-index: 1000;
        transform: translateX(-102%);
        transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        overflow: hidden;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
    }

    .sidebar.open {
transform: translateX(0);
    }

    .sidebar-nav {
min-height: 0;
        overflow-y: auto;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 12px;
    }

    .sidebar-footer {
position: sticky;
        bottom: 0;
        margin-top: 12px;
        padding-bottom: calc(14px + env(safe-area-inset-bottom, 0px));
    }

    .sidebar-overlay {
display: none;
        position: fixed;
        inset: 0;
        z-index: 999;
        backdrop-filter: blur(2px);
    }

    .sidebar-overlay.visible {
display: block;
    }

    .app-main {
padding: 84px 16px 24px;
    }

    .hamburger {
top: 13px;
        left: 12px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: var(--header-item-height);
        height: var(--header-item-height);
        min-width: var(--header-item-height);
        min-height: var(--header-item-height);
        padding: 0;
    }

    .section-header {
flex-direction: column;
        align-items: stretch;
    }

    .construction-card {
grid-template-columns: 1fr;
        justify-items: center;
        text-align: center;
    }

    .construction-image img {
max-width: 180px;
        /* Bit larger for centering */
    }

    .construction-main h3 {
text-align: center;
        width: 100%;
    }

    .construction-action {
justify-items: center;
        width: 100%;
    }

    .construction-build-form {
justify-content: center;
    }

    .friends-requests-grid {
grid-template-columns: 1fr;
    }

    .database-admin-grid {
grid-template-columns: 1fr;
    }

    .galaxy-toolbar {
display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 8px;
    }

    .table th,
    .table td {
padding: 8px 6px;
        font-size: 0.88rem;
    }

    .galaxy-actions {
gap: 6px;
    }

    .galaxy-actions .link-btn {
padding: 6px 10px;
        min-height: 40px;
        font-size: 0.82rem;
    }

    .friend-request-head {
align-items: stretch;
        flex-direction: column;
        gap: 8px;
    }

    .friend-request-actions {
width: 100%;
        justify-content: flex-start;
        flex-wrap: wrap;
    }

    .friend-request-actions form {
flex: 1 1 auto;
        min-width: 120px;
    }

    .friend-request-actions button,
    .friend-request-actions .link-btn {
width: 100%;
        min-width: 0;
    }

    .galaxy-toolbar-main {
min-width: 0;
        flex-wrap: nowrap;
    }

    .galaxy-toolbar-nav {
min-width: 0;
        flex-wrap: nowrap;
        gap: 6px;
        padding: 6px;
    }

    .galaxy-toolbar-fields {
width: auto;
        min-width: 0;
        flex-wrap: nowrap;
        gap: 6px;
    }

    .galaxy-toolbar-field {
min-width: 0;
    }

    .galaxy-toolbar-field input {
min-width: 0;
    }

    .galaxy-toolbar-summary {
margin-left: auto;
        font-size: 0.78rem;
        padding: 6px 8px;
    }

    .galaxy-toolbar-submit {
min-width: 58px;
        padding: 8px 10px;
    }
}

@media (max-width: 600px) {
.galaxy-toolbar {
flex-direction: column;
        align-items: stretch;
        gap: 6px;
    }

    .galaxy-toolbar-main {
width: 100%;
        justify-content: space-between;
    }

    .galaxy-toolbar-nav {
flex: 1 1 auto;
    }

    .galaxy-toolbar-summary {
justify-content: center;
        margin-top: 0;
    }

    .galaxy-toolbar-field {
min-width: 72px;
    }

    .galaxy-toolbar-field label,
    .galaxy-toolbar-field {
font-size: 0.82rem;
    }
}

@media (max-width: 600px) {
.resources {
grid-template-columns: 1fr 1fr;
    }

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

    .inline-form>* {
width: 100%;
    }

    .fleet-mission-ships {
grid-template-columns: 1fr;
    }

    .fleet-mission-ships label {
grid-template-columns: 1fr;
    }

    .mission-steps {
grid-template-columns: 1fr;
    }

    .construction-build-form {
flex-wrap: wrap;
        justify-content: flex-start;
    }

    .construction-build-submit {
width: auto;
    }

    .construction-list {
grid-template-columns: 1fr;
        gap: 12px;
    }

    .construction-card {
gap: 0;
        padding: 0;
        overflow: hidden;
        position: relative;
        aspect-ratio: 1 / 1;
    }

    .construction-main {
display: none;
    }

    .construction-image {
width: 100%;
        height: 100%;
        position: relative;
    }

    .construction-image img {
width: 100%;
        height: 100%;
        aspect-ratio: 1 / 1;
        max-width: none;
        object-fit: cover;
        border: 0;
        border-radius: 10px;
    }

    .construction-mobile-title {
display: block;
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        padding: 10px 10px 16px;
        font-family: 'Exo 2', Tahoma, Verdana, sans-serif;
        font-size: 0.8rem;
        font-weight: 700;
        letter-spacing: 0.02em;
    }

    .construction-mobile-level {
display: inline-block;
        margin-left: 6px;
        font-size: 0.72rem;
        font-weight: 600;
    }

    .construction-mobile-cost {
display: block;
        margin-top: 5px;
        font-size: 0.68rem;
        font-weight: 600;
        line-height: 1.3;
    }

.construction-mobile-duration {
display: block;
        margin-top: 3px;
        font-size: 0.66rem;
        font-weight: 600;
    }

    .construction-mobile-requirements {
display: block;
        margin-top: 6px;
        font-size: 0.64rem;
        font-weight: 600;
        line-height: 1.35;
    }

    .construction-mobile-requirements-label {
display: inline;
    }

    .construction-mobile-requirements-items {
display: inline;
    }

    .construction-mobile-requirements-items > span + span::before {
content: " | ";
        color: inherit;
    }

    .construction-action {
position: absolute;
        left: 0;
        right: 0;
        bottom: 0;
        width: 100%;
        justify-items: stretch;
        padding: 16px 12px 12px;
    }

    .construction-action small,
    .construction-action br {
display: none;
    }

    .construction-action form {
width: 100%;
    }

    .construction-action .construction-build-form {
display: flex !important;
        flex-direction: row;
        flex-wrap: nowrap !important;
        align-items: stretch;
        justify-content: flex-start;
        gap: 8px;
        width: 100%;
    }

    .construction-action .construction-stepper {
grid-template-columns: 28px 1fr 28px;
        width: 116px;
    }

    .construction-action .construction-stepper input[type="number"] {
min-height: 30px;
        padding: 0 2px;
        text-align: center !important;
    }

    .construction-action .construction-build-quantity {
width: 100% !important;
        min-width: 0;
        min-height: 30px;
        padding: 0 2px;
        text-align: center !important;
    }

    .construction-action .construction-stepper-button {
width: 28px !important;
        min-width: 28px;
        min-height: 30px;
        font-size: 0.8rem;
    }

    .construction-action .construction-build-submit {
min-height: 34px;
        padding: 7px 10px;
        font-size: 0.74rem;
    }

    .construction-action button:not(.construction-stepper-button) {
width: 100%;
        min-height: 36px;
        padding: 8px 10px;
        font-size: 0.8rem;
    }

    .construction-action .construction-build-submit {
flex: 1 1 auto;
        width: 100%;
        min-width: 0;
    }

    .reports-filter-buttons {
display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
        width: 100%;
    }

    .reports-filter-btn {
width: 100%;
        justify-content: center;
    }

    .empire-table-wrap {
display: none;
    }

    .empire-card-list {
display: grid;
    }

    .empire-card {
flex-direction: column;
        align-items: stretch;
    }

    .empire-card-meta {
display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px 12px;
    }

    .empire-card-action {
width: 100%;
    }

    .empire-card-action form,
    .empire-card-action .link-btn,
    .empire-card-action button {
width: 100%;
    }

    .galaxy-table {
display: none;
    }

    .galaxy-card-list {
display: grid;
    }

    .galaxy-actions {
display: grid;
    }

    .galaxy-actions .link-btn,
    .galaxy-actions button,
    .galaxy-card__actions .link-btn,
    .galaxy-card__actions button {
width: 100%;
        justify-content: center;
    }

    .ranking-table--desktop {
display: none;
    }

    .ranking-card-list {
display: block;
    }

    .ranking-card__header {
flex-wrap: wrap;
    }

    .ranking-card__meta {
grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .admin-users-table {
display: none;
    }

    .admin-user-card-list {
display: block;
    }

    .admin-user-card__header {
flex-wrap: wrap;
    }
}

/* ---------- Empire overview table ---------- */
.empire-active-badge {
display: inline-block;
    padding: 4px 10px;
    border-radius: 10px;
    font-size: 0.82rem;
    font-weight: 600;
    letter-spacing: 0.03em;
}

/* ---------- Cookie Banner ---------- */
.cookie-banner {
position: fixed;
    bottom: 24px;
    left: 24px;
    right: 24px;
    border-radius: 10px;
    padding: 16px 24px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 24px;
    z-index: 10000;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    animation: slideUp 0.5s ease-out;
}

.cookie-banner p {
margin: 0;
    font-size: 0.95rem;
    line-height: 1.4;
}

.cookie-banner-btn {
padding: 10px 16px;
    border-radius: 10px;
    cursor: pointer;
    font-family: 'Exo 2', sans-serif;
    font-weight: 600;
    font-size: 0.92rem;
    white-space: nowrap;
    transition: all 0.25s;
    min-height: 44px;
}

.cookie-banner-btn:active {
transform: scale(0.95);
}

@keyframes slideUp {
from {
transform: translateY(100%) scale(0.9);
        opacity: 0;
    }

    to {
transform: translateY(0) scale(1);
        opacity: 1;
    }
}

@media (max-width: 768px) {
.cookie-banner {
flex-direction: column;
        text-align: center;
        bottom: 12px;
        left: 12px;
        right: 12px;
        padding: 20px;
    }
}

.w-100 {
width: 100% !important;
}

/* ---------- Status badges (admin) ---------- */
.status-approved {
font-weight: 600;
}

.status-pending {
font-weight: 600;
}

/* ---------- Pagination ---------- */
.btn {
border-radius: 10px;
    padding: 10px 16px;
    cursor: pointer;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-family: 'Exo 2', sans-serif;
    font-weight: 600;
    font-size: 0.92rem;
    letter-spacing: 0.02em;
    transition: all 0.25s;
    min-height: 44px;
    min-width: 44px;
}

.pagination-info {
font-size: 0.92rem;
}

/* ---------- Spacing utilities ---------- */
.mb-md {
margin-bottom: 24px;
}

.mt-md {
margin-top: 1.5rem;
}

/* ---------- Scroll to top ---------- */
.scroll-to-top {
position: fixed;
    bottom: 24px;
    width: 44px;
    height: 44px;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    cursor: pointer;
    z-index: 1000;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    opacity: 0;
    visibility: hidden;
    transform: translateY(15px);
    transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

.scroll-to-top {
right: 24px;
}

.scroll-to-top:hover {
transform: translateY(-2px);
}

.scroll-to-top.visible {
opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.scroll-to-top-icon {
width: 24px;
    height: 24px;
    stroke-width: 2.5;
    fill: none;
    transition: transform 0.2s;
}

.scroll-to-top:hover .scroll-to-top-icon {
transform: translateY(-2px);
}

/* Same horizontal inset as .auth-layout-container (landing / about) */
.wiki-layout {
width: 100%;
    max-width: none;
    margin: 0 auto;
    padding: 28px 40px 48px;
    box-sizing: border-box;
}

.wiki-site-brand {
display: inline-flex;
    align-items: center;
    gap: 14px;
    text-decoration: none;
    margin-bottom: 14px;
}

.wiki-site-logo {
width: 72px;
    height: 72px;
    object-fit: contain;
}

.wiki-site-title {
font-size: 2rem;
    font-weight: 800;
    letter-spacing: 0.04em;
}

.wiki-breadcrumb {
display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0 0 12px;
    font-size: 0.92rem;
}

.wiki-breadcrumb a {
text-decoration: none;
}

.wiki-breadcrumb a:hover {
text-decoration: underline;
}

.wiki-breadcrumb > *:not(:last-child)::after {
content: "/";
    margin-left: 8px;
}

.wiki-hero,
.wiki-detail-hero {
position: relative;
    margin-bottom: 32px;
}

.wiki-eyebrow {
position: absolute;
    top: 18px;
    right: 22px;
    margin: 0;
    font-size: 0.8rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    text-align: right;
}

@media (max-width: 640px) {
.wiki-hero {
display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
    }

    .wiki-eyebrow {
position: static;
        order: -1;
        align-self: flex-start;
        text-align: left;
        max-width: 100%;
        line-height: 1.35;
        overflow-wrap: anywhere;
    }

    .wiki-breadcrumb {
flex-direction: column;
        flex-wrap: nowrap;
        align-items: stretch;
        gap: 0;
        margin: 0;
        max-width: 100%;
        font-size: 0.86rem;
        line-height: 1.4;
    }

    .wiki-breadcrumb > * {
overflow-wrap: anywhere;
    }

    .wiki-breadcrumb > *:not(:last-child)::after {
display: none;
        content: '';
    }

    .wiki-breadcrumb > * + * {
margin-top: 8px;
        padding-top: 8px;
        padding-left: 12px;
    }
}

.wiki-hero h1,
.wiki-detail-copy h1 {
margin-bottom: 12px;
}

.wiki-http-error-kicker {
margin: 0 0 10px;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.wiki-detail-copy .wiki-http-error-next-title {
margin: 22px 0 10px;
    font-size: clamp(1.05rem, 2vw, 1.28rem);
    font-weight: 700;
    line-height: 1.25;
}

.wiki-grid,
.wiki-detail-grid {
display: grid;
    gap: 20px;
    margin-top: 24px;
}

.wiki-grid {
grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.wiki-detail-grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
}

.wiki-card {
overflow: hidden;
}

.wiki-card-link {
display: block;
    text-decoration: none;
}

.wiki-card-link:hover .wiki-card,
.wiki-card-link:focus-visible .wiki-card {
transform: translateY(-3px);
}

.wiki-card--overlay {
position: relative;
}

.wiki-card-image,
.wiki-detail-image {
    display: block;
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
}

.wiki-card-image {
object-fit: contain;
    padding: 24px;
}

.wiki-card-image--cover {
aspect-ratio: 1 / 1;
    object-fit: cover;
    padding: 0;
    background: none;
}

/* Grille wiki : zone image plus compacte (accueil wiki + cartes catégorie) */
.wiki-grid .wiki-card:not(.wiki-card--overlay) .wiki-card-image {
width: 100%;
    height: auto;
    max-height: 128px;
    aspect-ratio: unset;
    padding: 8px 12px;
    object-fit: contain;
    box-sizing: border-box;
}

.wiki-grid .wiki-card--overlay .wiki-card-image.wiki-card-image--cover {
width: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    padding: 0;
    background: none;
}

.wiki-card-body {
padding: 18px;
}

.wiki-card-overlay {
position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 18px;
}

.wiki-card-overlay h2 {
margin: 0;
    text-align: center;
}

.wiki-card-body h2,
.wiki-panel h2 {
margin-bottom: 10px;
}

.wiki-card-count {
margin: 0 0 8px;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.wiki-inline-link {
text-decoration: none;
    font-weight: 700;
}

.wiki-inline-link:hover {
text-decoration: underline;
}

.wiki-detail-hero {
display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(280px, 420px);
    gap: 24px;
    align-items: center;
    padding: 24px;
}

.wiki-detail-image {
border-radius: 10px;
}

.wiki-panel {
padding: 22px;
}

.wiki-intro-panel {
margin-bottom: 24px;
}

.wiki-grid--overview {
align-items: stretch;
}

.wiki-grid--overview .wiki-panel {
height: 100%;
}

.wiki-grid--overview .wiki-panel p:last-child {
margin-bottom: 0;
}

.wiki-overview-block + .wiki-overview-block {
margin-top: 28px;
padding-top: 28px;
border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.wiki-overview-block p:last-child {
margin-bottom: 0;
}

.wiki-section-title {
display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}

.wiki-section-title h1 {
margin: 0;
}

.wiki-section-icon {
width: 22px;
    height: 22px;
    object-fit: contain;
    flex: 0 0 auto;
}

.wiki-panel--wide {
grid-column: 1 / -1;
    display: flex;
    flex-direction: column;
    align-items: stretch;
}

.wiki-data-list {
display: grid;
    gap: 12px;
    margin: 0;
}

.wiki-data-list div {
display: flex;
    justify-content: space-between;
    gap: 16px;
    padding-bottom: 10px;
}

.wiki-data-list dd {
margin: 0;
    font-weight: 700;
}

.wiki-requirements {
margin: 0;
    padding-left: 18px;
}

.wiki-requirements--chips {
display: flex;
    flex-wrap: wrap;
    gap: 10px 16px;
    padding-left: 0;
    list-style: none;
}

.wiki-requirements--chips li {
padding: 8px 12px;
    border-radius: 10px;
}

.wiki-empty {
margin: 0;
}

.wiki-evolution-wrap {
margin-top: 8px;
}

.wiki-evolution-table {
display: table;
    min-width: 100%;
    width: 100%;
    border-collapse: separate;
    table-layout: auto;
}

.wiki-evolution-table thead {
display: table-header-group;
}

.wiki-evolution-table tbody {
display: table-row-group;
}

.wiki-evolution-table tr {
display: table-row;
}

.wiki-evolution-table th,
.wiki-evolution-table td {
white-space: nowrap;
    font-variant-numeric: tabular-nums;
    text-align: center;
    vertical-align: middle;
}

.wiki-evolution-group-row th {
text-align: center;
    font-size: 0.82rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.wiki-evolution-group {
font-weight: 800;
}

.wiki-evolution-table tbody td:first-child,
.wiki-evolution-table thead th:first-child {
position: sticky;
    left: 0;
    z-index: 1;
    font-weight: 800;
}

.wiki-evolution-table thead th:first-child {
z-index: 2;
    letter-spacing: 0.04em;
}

.wiki-evolution-table tr.wiki-evolution-row--hidden {
display: none;
}

.wiki-evolution-table tr.wiki-evolution-row--hidden.wiki-evolution-row--visible {
display: table-row;
}

.wiki-evolution-toggle {
margin-top: 16px;
    align-self: center;
}

@media (max-width: 900px) {
.wiki-detail-hero,
    .wiki-detail-grid {
grid-template-columns: 1fr;
    }

    .wiki-detail-visual {
        order: -1;
    }
}

@media (max-width: 600px) {
.wiki-grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 14px;
    }

    .wiki-evolution-wrap {
overflow: visible;
    }

    .wiki-evolution-table {
display: block;
    }

    .wiki-evolution-table thead {
display: none;
    }

    .wiki-evolution-table tbody {
display: grid;
        gap: 14px;
    }

    .wiki-evolution-table tr {
display: block;
        padding: 14px;
        border-radius: 10px;
    }

    .wiki-evolution-table tr.wiki-evolution-row--hidden {
display: none;
    }

    .wiki-evolution-table tr.wiki-evolution-row--hidden.wiki-evolution-row--visible {
display: block;
    }

    .wiki-evolution-table td {
display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 12px;
        width: 100%;
        padding: 8px 0;
        white-space: normal;
        text-align: right;
    }

    .wiki-evolution-table td::before {
content: attr(data-label);
        flex: 1 1 auto;
        font-weight: 700;
        text-align: left;
    }

    .wiki-evolution-table tbody td:first-child,
    .wiki-evolution-table thead th:first-child {
position: static;
        left: auto;
        z-index: auto;
        background: none;
        box-shadow: none;
    }

    .wiki-evolution-table tbody td:first-child {
display: block;
        padding: 0 0 10px;
        margin-bottom: 2px;
        font-size: 1rem;
        font-weight: 800;
        text-align: left;
    }

    .wiki-evolution-table tbody td:first-child::before {
display: block;
        margin-bottom: 4px;
        font-size: 0.72rem;
        letter-spacing: 0.08em;
        text-transform: uppercase;
    }

    .wiki-evolution-table tbody td:last-child {
border-bottom: 0;
        padding-bottom: 0;
    }

    .wiki-grid .wiki-card--overlay {
position: relative;
    }

    .wiki-grid .wiki-card--overlay .wiki-card-image.wiki-card-image--cover {
width: 100%;
        height: auto;
        aspect-ratio: 1 / 1;
        object-fit: cover;
        padding: 0;
        background: none;
    }

    .wiki-grid .wiki-card:not(.wiki-card--overlay) .wiki-card-image {
max-height: min(104px, 42vw);
        padding: 6px 10px;
    }

    .wiki-card-body {
position: static;
        padding: 14px;
        background: none;
    }

    .wiki-card--overlay .wiki-card-body {
position: absolute;
        right: 0;
        bottom: 0;
        left: 0;
        padding: 14px;
    }

    .wiki-card--overlay .wiki-card-body h2 {
margin-bottom: 6px;
    }

    .wiki-card--overlay .wiki-card-body p:last-child {
margin-bottom: 0;
    }
}

/* ---------- Intentional round / pill shapes ---------- */
.status-badge,
.report-badge,
.queue-badge,
.build-state-pill,
.galaxy-inline-pill,
.alliance-role,
.empire-active-badge,
.messages-unread-count,
.sidebar-messages-unread {
border-radius: 999px;
}

.message-avatar,
.about-step-index,
.install-stepper li::before,
.scroll-to-top {
border-radius: 50%;
}

:is(.button,
.btn,
.link-btn,
.sidebar-link,
input,
select,
textarea):focus-visible {
outline-offset: 2px;
    box-shadow: none;
}

:is(.button,
.btn,
.link-btn,
.cookie-banner-btn,
.sidebar-link,
.messages-folder-tab,
.reports-filter-btn,
.construction-stepper-button,
select,
textarea):disabled {
cursor: not-allowed;
    opacity: 1;
    box-shadow: none;
}

/* ---------- Header height normalization (desktop/mobile) ---------- */
body {
--header-row-height: 52px;
    --header-item-height: 40px;
}

@media (max-width: 980px) {
body {
--header-row-height: 48px;
        --header-item-height: 36px;
    }
}

/* ---------- Dedicated content header (no legacy inheritance) ---------- */
.content-header {
width: 100%;
    margin: 0 0 24px;
}

.content-header__bar {
width: 100%;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    border-radius: 4px;
    box-sizing: border-box;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.content-header__title,
.content-header__mobile-title {
display: inline-flex;
    align-items: center;
    gap: 8px;
    margin: 0;
    white-space: nowrap;
    font-size: 16px;
    font-weight: 700;
}

.content-header__title-icon {
width: 18px;
    height: 18px;
    flex: 0 0 auto;
}

.content-header__resources {
margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-width: 0;
}

.content-header__resource-item {
display: inline-flex;
    align-items: center;
    gap: 4px;
    min-height: 40px;
    padding: 0 10px;
    border-radius: 4px;
    white-space: nowrap;
}

.content-header__resource-icon {
width: 18px;
    height: 18px;
    object-fit: contain;
}

.content-header__resource-item strong {
font-weight: 700;
}

.content-header__admin-link {
min-height: 36px;
    padding: 0 10px;
    border-radius: 4px;
}

.content-header__mobile-title {
display: none;
}

@media (max-width: 980px) {
.content-header__bar {
position: fixed;
        top: 0;
        left: 0;
        right: 0;
        z-index: 998;
        border-radius: 0;
        min-height: 48px;
        padding: 10px 14px 10px 60px;
    }

    .content-header__title {
display: none;
    }

    .content-header__mobile-title {
display: inline-flex;
        font-size: 14px;
        flex: 0 0 auto;
    }

    .content-header__resources {
flex: 1 1 auto;
        overflow-x: auto;
        scrollbar-width: none;
        font-size: 13px;
    }

    .content-header__resources::-webkit-scrollbar {
display: none;
    }

    .content-header__resource-item {
min-height: 36px;
        padding: 0 6px;
        font-size: 13px;
    }

    .hamburger {
top: 10px;
    }

    .hamburger-icon {
width: 18px;
        height: 18px;
        object-fit: contain;
    }

    .content-header__resource-item strong {
display: none;
    }

    .content-header__resource-item .content-header__resource-abbr {
display: inline;
        font-weight: 700;
        font-size: 11px;
        text-transform: uppercase;
    }
}

/* ---------- Accessibility: reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
*,
    *::before,
    *::after {
animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

/* Dark theme overrides */
/* Keep icon SVGs readable on dark backgrounds */
/* ---------- Dark Theme Fluent UI pass ---------- */
body .site-landing-nav .sidebar-link.active {
font-weight: 400;
    box-shadow: none;
}

body :is(button, .button, .btn, .link-btn, .sidebar-link, input, select, textarea):focus-visible {
outline-offset: 2px;
    box-shadow: none;
}

body :is(button, .button, .btn, .link-btn, .cookie-banner-btn, .sidebar-link, .messages-folder-tab, .reports-filter-btn, .construction-stepper-button, input, select, textarea):disabled {
cursor: not-allowed;
    opacity: 1;
    box-shadow: none;
}

