@import url('https://fonts.googleapis.com/css2?family=Electrolize&display=swap');

@font-face {
    font-family: 'Zero Prime';
    src: local('Zero Prime'), local('ZeroPrime'),
         url('../fonts/zero-prime.woff2') format('woff2'),
         url('../fonts/zero-prime.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

:root {
    --bg: #020405;
    --panel: rgba(6, 10, 12, 0.94);
    --line: rgba(225, 0, 0, 0.72);
    --line-soft: rgba(225, 0, 0, 0.25);
    --cyan: #21eaff;
    --cyan-soft: rgba(33, 234, 255, 0.18);
    --red: #e00000;
    --green: #77ff46;
    --text: #f1f4f6;
    --muted: #8d979e;
    --grid: rgba(33, 234, 255, 0.085);
    --cell-border: rgba(172, 193, 202, 0.18);
    --row-a-col-a: rgba(10, 14, 16, .96);
    --row-a-col-b: rgba(15, 19, 22, .96);
    --row-b-col-a: rgba(18, 22, 25, .96);
    --row-b-col-b: rgba(23, 27, 30, .96);
}

* { box-sizing: border-box; }

body {
    margin: 0;
    min-height: 100vh;
    color: var(--text);
    background:
        radial-gradient(circle at 76% 0%, rgba(152, 0, 0, .22), transparent 34rem),
        radial-gradient(circle at 20% 100%, rgba(33, 234, 255, .055), transparent 30rem),
        var(--bg);
    font-family: "Electrolize", "Segoe UI", "Arial Narrow", Arial, sans-serif;
    overflow-x: hidden;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(var(--grid) 1px, transparent 1px),
        linear-gradient(90deg, var(--grid) 1px, transparent 1px),
        radial-gradient(circle, rgba(255,255,255,.22) 1px, transparent 1px);
    background-size: 92px 92px, 92px 92px, 180px 180px;
    opacity: .85;
    mask-image: linear-gradient(to bottom, rgba(0,0,0,.95), rgba(0,0,0,.35));
}

.app-shell {
    position: relative;
    width: min(1920px, calc(100vw - 42px));
    margin: 0 auto;
    padding: 8px 0 22px;
}

.site-header {
    min-height: 176px;
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-areas:
        "brand status"
        "nav status";
    gap: 14px 28px;
    padding: 22px 34px 16px;
    border-bottom: 3px solid var(--red);
    background:
        linear-gradient(120deg, rgba(14, 20, 24, .94), rgba(3, 5, 7, .70)),
        radial-gradient(circle at 70% 42%, rgba(33, 234, 255, .10), transparent 20rem),
        linear-gradient(90deg, rgba(255,255,255,.055), transparent 42%);
    clip-path: polygon(0 0, 100% 0, 100% 78%, 73% 78%, 70% 100%, 0 100%);
    box-shadow: 0 18px 60px rgba(0,0,0,.42);
}

.brand {
    grid-area: brand;
    display: flex;
    align-items: center;
    gap: 20px;
}

.crest-img {
    width: 116px;
    height: 116px;
    object-fit: contain;
    filter: drop-shadow(0 0 14px rgba(255, 202, 96, .24)) drop-shadow(0 0 12px rgba(224, 0, 0, .35));
}

.brand-title {
    font-family: "Zero Prime", "Electrolize", "Segoe UI", sans-serif;
    font-size: clamp(34px, 3.8vw, 62px);
    line-height: .94;
    font-weight: 950;
    letter-spacing: .105em;
    text-transform: uppercase;
    color: #fafafa;
    text-shadow: 0 2px 0 #777, 0 0 18px rgba(255,255,255,.42);
}

.brand-subtitle {
    font-family: "Zero Prime", "Electrolize", "Segoe UI", sans-serif;
    margin-top: 10px;
    color: #d5d9dc;
    font-size: clamp(13px, 1.35vw, 22px);
    letter-spacing: .16em;
    text-transform: uppercase;
}

.nav-tabs {
    grid-area: nav;
    display: flex;
    align-items: end;
    gap: 16px;
    padding-left: 136px;
    overflow-x: auto;
}

.nav-tabs span,
.nav-tabs a {
    min-width: 130px;
    padding: 15px 16px;
    color: #aeb5bb;
    background: linear-gradient(180deg, rgba(255,255,255,.055), rgba(0,0,0,.20));
    border-bottom: 2px solid rgba(255,255,255,.14);
    clip-path: polygon(9% 0, 100% 0, 91% 100%, 0 100%);
    text-align: center;
    text-transform: uppercase;
    font-size: 13px;
    font-weight: 900;
    letter-spacing: .095em;
}

.nav-tabs span.active,
.nav-tabs a.active {
    color: #fff;
    border-bottom-color: var(--red);
    box-shadow: inset 0 -3px 0 var(--red), 0 0 18px rgba(224,0,0,.40);
}

.status-panels {
    grid-area: status;
    display: grid;
    grid-template-columns: 240px 220px;
    gap: 16px;
    align-content: start;
    padding-top: 12px;
}

.field {
    display: grid;
    gap: 8px;
    padding: 13px 14px;
    background: rgba(2, 5, 7, .72);
    border: 1px solid var(--line-soft);
    clip-path: polygon(0 0, 93% 0, 100% 23%, 100% 100%, 7% 100%, 0 77%);
}

.field span {
    color: var(--muted);
    font-size: 11px;
    font-weight: 950;
    letter-spacing: .12em;
    text-transform: uppercase;
}

input, select, button { font: inherit; }

input, select {
    width: 100%;
    min-height: 40px;
    padding: 8px 10px;
    color: var(--text);
    background: rgba(0,0,0,.62);
    border: 1px solid rgba(255,255,255,.18);
    outline: none;
}

input:focus, select:focus {
    border-color: var(--cyan);
    box-shadow: 0 0 0 2px var(--cyan-soft);
}

button {
    min-height: 38px;
    padding: 9px 14px;
    color: #fff;
    background: rgba(0,0,0,.62);
    border: 1px solid var(--line);
    clip-path: polygon(8px 0, 100% 0, calc(100% - 8px) 100%, 0 100%);
    cursor: pointer;
    font-size: 12px;
    font-weight: 950;
    letter-spacing: .08em;
    text-transform: uppercase;
}

button:hover {
    color: var(--cyan);
    border-color: var(--cyan);
    box-shadow: 0 0 16px var(--cyan-soft);
}

.subbar {
    display: grid;
    grid-template-columns: minmax(260px, 390px) 1fr auto;
    gap: 14px;
    align-items: stretch;
    margin: 16px 0 14px;
}

.mode-field { padding: 10px 14px; }

.hint, .active-role {
    display: flex;
    align-items: center;
    padding: 12px 18px;
    color: var(--muted);
    background: rgba(4,8,10,.72);
    border: 1px solid rgba(255,255,255,.08);
}

.active-role {
    min-width: 150px;
    justify-content: center;
    color: var(--cyan);
    border-color: var(--line-soft);
    font-weight: 950;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.dashboard {
    display: grid;
    grid-template-columns: minmax(1120px, 1fr) minmax(520px, 650px);
    gap: 18px;
    align-items: start;
}

.panel {
    position: relative;
    background:
        linear-gradient(180deg, rgba(255,255,255,.04), transparent 110px),
        var(--panel);
    border: 1px solid var(--line);
    box-shadow: 0 0 0 1px rgba(255,0,0,.07) inset, 0 20px 60px rgba(0,0,0,.38);
    clip-path: polygon(18px 0, 100% 0, 100% calc(100% - 18px), calc(100% - 18px) 100%, 0 100%, 0 18px);
}

.panel-corner {
    position: absolute;
    top: -1px;
    left: 28px;
    right: 76px;
    height: 4px;
    background: linear-gradient(90deg, transparent, var(--red), transparent);
    opacity: .78;
}

.panel-title {
    min-height: 62px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 17px 22px 14px;
    border-bottom: 1px solid rgba(255,255,255,.08);
    background: linear-gradient(90deg, rgba(255,255,255,.05), transparent);
}

.panel-title h1,
.panel-title h2 {
    margin: 0;
    font-size: 23px;
    line-height: 1.1;
    letter-spacing: .065em;
    text-transform: uppercase;
}

.panel-title h2 { font-size: 21px; }

.panel-title span {
    color: var(--muted);
    font-size: 12px;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.table-scroll {
    overflow: auto;
    max-height: calc(100vh - 310px);
    min-height: 620px;
    scrollbar-color: var(--red) rgba(255,255,255,.08);
}

.role-matrix {
    width: 100%;
    min-width: 3180px;
    border-collapse: collapse;
    table-layout: fixed;
    font-size: 12px;
}

.role-matrix th,
.role-matrix td {
    border: 1px solid var(--cell-border);
    vertical-align: top;
}

.role-matrix thead th {
    position: sticky;
    top: 0;
    z-index: 5;
    padding: 10px 8px;
    color: #dfe8ec;
    background: rgba(8, 13, 15, .98);
    font-size: 11px;
    font-weight: 950;
    letter-spacing: .055em;
    text-align: center;
    text-transform: uppercase;
}

.role-matrix thead tr:nth-child(2) th { top: 38px; }

.role-head-cell {
    width: 270px;
    left: 0;
    z-index: 8 !important;
}

.role-cell {
    position: sticky;
    left: 0;
    z-index: 4;
    width: 270px;
    padding: 12px 12px;
    background: rgba(6, 10, 12, .98);
}

.role-matrix tbody tr:nth-child(odd) .task-cell.col-odd { background: var(--row-a-col-a); }
.role-matrix tbody tr:nth-child(odd) .task-cell.col-even { background: var(--row-a-col-b); }
.role-matrix tbody tr:nth-child(even) .task-cell.col-odd { background: var(--row-b-col-a); }
.role-matrix tbody tr:nth-child(even) .task-cell.col-even { background: var(--row-b-col-b); }

.role-matrix tbody tr:nth-child(even) .role-cell { background: rgba(14, 18, 21, .98); }

.role-matrix tbody tr.role-hover .task-cell,
.role-matrix tbody tr.role-selected .task-cell {
    background: rgba(33,234,255,.105) !important;
    box-shadow: inset 0 1px 0 rgba(33,234,255,.18), inset 0 -1px 0 rgba(33,234,255,.18);
}

.role-matrix tbody tr.role-hover .role-cell,
.role-matrix tbody tr.role-selected .role-cell {
    background: rgba(0, 46, 54, .95);
    box-shadow: inset 4px 0 0 var(--cyan);
}

.role-card-mini {
    display: grid;
    grid-template-columns: 36px 1fr;
    align-items: start;
    gap: 10px;
}

.role-icon {
    width: 30px;
    height: 30px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    background: #a2aab0;
    color: #020304;
    font-weight: 950;
    box-shadow: 0 0 14px rgba(255,255,255,.10);
}

tr.role-hover .role-icon,
tr.role-selected .role-icon {
    background: var(--cyan);
    box-shadow: 0 0 20px rgba(33,234,255,.72);
}

.role-name {
    color: #fff;
    font-size: 15px;
    font-weight: 950;
    line-height: 1.1;
}

.role-note,
.role-order {
    margin-top: 4px;
    color: var(--muted);
    font-size: 11px;
    line-height: 1.25;
}

.assignment {
    margin-top: 7px;
    color: var(--green);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.assignment.empty { color: #737b81; }

.task-cell {
    width: 244px;
    padding: 8px 8px;
    color: #d2dde2;
    line-height: 1.28;
    white-space: normal;
    overflow-wrap: break-word;
    word-break: normal;
    hyphens: auto;
}

.mode-highlight {
    background: rgba(33,234,255,.075) !important;
    box-shadow: inset 0 0 0 1px rgba(33,234,255,.20);
}

.empty-dash {
    display: block;
    color: rgba(255,255,255,.14);
    text-align: center;
}

.task-line {
    display: grid;
    grid-template-columns: 20px 1fr;
    gap: 6px;
    align-items: start;
    padding: 3px 0;
}

.task-line + .task-line {
    margin-top: 4px;
    border-top: 1px solid rgba(255,255,255,.07);
    padding-top: 7px;
}

.prio-badge {
    display: inline-grid;
    place-items: center;
    width: 18px;
    height: 18px;
    border: 1px solid rgba(33,234,255,.32);
    color: var(--cyan);
    background: rgba(0,0,0,.32);
    font-size: 11px;
    font-weight: 950;
    line-height: 1;
}

.panel-footer {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    padding: 14px 22px;
    color: #a5adb3;
    font-size: 12px;
    border-top: 1px solid rgba(255,255,255,.08);
    background: rgba(0,0,0,.26);
}

.panel-footer b { color: #fff; }

.ship-panel { min-height: 780px; }

.ship-map-wrap {
    position: relative;
    min-height: 650px;
    margin: 16px;
    border: 1px solid rgba(255,255,255,.08);
    background:
        linear-gradient(rgba(33,234,255,.07) 1px, transparent 1px),
        linear-gradient(90deg, rgba(33,234,255,.07) 1px, transparent 1px),
        rgba(0,0,0,.28);
    background-size: 28px 28px;
    overflow: hidden;
}

.ship-stage {
    position: absolute;
    left: 42%;
    top: 52%;
    transform: translate(-50%, -50%);
    width: min(58%, 390px);
    aspect-ratio: 768 / 1500;
}

.ship-stage img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
    opacity: .96;
    filter: drop-shadow(0 0 28px rgba(33,234,255,.15));
}

.marker-layer {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.marker {
    --marker-color: var(--cyan);
    position: absolute;
    left: var(--x);
    top: var(--y);
    width: 27px;
    height: 27px;
    transform: translate(-50%, -50%);
    display: grid;
    place-items: center;
    color: #001215;
    background: var(--marker-color);
    border: 2px solid rgba(255,255,255,.80);
    border-radius: 50%;
    opacity: .27;
    transition: opacity .16s ease, transform .16s ease, box-shadow .16s ease, filter .16s ease;
    pointer-events: auto;
}

.marker.station { --marker-color: var(--cyan); }
.marker.fire_extinguisher { --marker-color: #ff3730; }
.marker.escape_pod { --marker-color: var(--green); }

.marker.relevant,
.marker.general-active {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.25);
    box-shadow: 0 0 16px var(--marker-color), 0 0 38px var(--marker-color);
    filter: saturate(1.35);
}

.marker.dimmed { opacity: .13; }

.marker-symbol {
    font-size: 13px;
    font-weight: 950;
}

.marker-label {
    display: none;
    position: absolute;
    top: 50%;
    left: 32px;
    transform: translateY(-50%);
    min-width: max-content;
    max-width: 180px;
    padding: 5px 8px;
    color: #eafcff;
    background: rgba(0,0,0,.78);
    border: 1px solid rgba(33,234,255,.32);
    font-size: 11px;
    line-height: 1.25;
}

.marker.tooltip-enabled:hover .marker-label { display: block; }

.legend-card,
.role-info-card {
    position: absolute;
    right: 18px;
    width: 215px;
    padding: 16px;
    background: rgba(3, 7, 9, .82);
    border: 1px solid rgba(255,255,255,.18);
    clip-path: polygon(12px 0, 100% 0, 100% calc(100% - 12px), calc(100% - 12px) 100%, 0 100%, 0 12px);
    box-shadow: 0 0 22px rgba(0,0,0,.34);
}

.legend-card { top: 18px; }
.role-info-card { top: 232px; }

.legend-card h3,
.role-info-card h3 {
    margin: 0 0 12px;
    color: #fff;
    font-size: 13px;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.role-info-card h3 { color: var(--cyan); }

.legend-card div,
.role-info-card div {
    color: #d4d9dc;
    font-size: 13px;
    line-height: 1.45;
}

.legend-card div + div { margin-top: 11px; }

.legend-dot {
    display: inline-block;
    width: 17px;
    height: 17px;
    margin-right: 10px;
    border-radius: 50%;
    vertical-align: -4px;
    box-shadow: 0 0 13px currentColor;
}

.legend-dot.station { color: var(--cyan); background: var(--cyan); }
.legend-dot.fire_extinguisher { color: #ff3730; background: #ff3730; }
.legend-dot.escape_pod { color: var(--green); background: var(--green); }

.assign-card {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: center;
    margin: 0 16px 16px;
    padding: 16px;
    background: rgba(0,0,0,.30);
    border: 1px solid rgba(255,255,255,.10);
}

.assign-label {
    color: var(--muted);
    font-size: 11px;
    font-weight: 950;
    letter-spacing: .10em;
    text-transform: uppercase;
}

.assign-role {
    margin-top: 4px;
    color: var(--cyan);
    font-size: 19px;
    font-weight: 950;
    text-transform: uppercase;
}

.assign-user {
    margin-top: 4px;
    color: var(--muted);
    font-size: 13px;
}

.assign-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 10px;
}

.empty-state {
    margin-top: 16px;
    padding: 40px;
    border: 1px solid var(--line);
    background: var(--panel);
}

@media (max-width: 1600px) {
    .dashboard { grid-template-columns: 1fr; }
    .table-scroll { max-height: none; min-height: 0; }
    .ship-panel { min-height: 780px; }
}

@media (max-width: 980px) {
    .app-shell { width: min(100vw - 18px, 1920px); }

    .site-header {
        grid-template-columns: 1fr;
        grid-template-areas:
            "brand"
            "nav"
            "status";
        clip-path: none;
        padding: 18px;
    }

    .brand { align-items: flex-start; }
    .crest-img { width: 82px; height: 82px; }
    .nav-tabs { padding-left: 0; }
    .status-panels, .subbar { grid-template-columns: 1fr; }

    .legend-card,
    .role-info-card {
        position: static;
        width: auto;
        margin: 12px;
    }

    .ship-map-wrap { min-height: 820px; }

    .ship-stage {
        top: 42%;
        left: 50%;
        width: min(70%, 390px);
    }
}

.coverage-note {
    margin-top: 7px;
    color: #f1c66a;
    font-size: 11px;
    line-height: 1.25;
}

.marker.medbay { --marker-color: #ffffff; }
.marker.airlock { --marker-color: #ffb347; }
.marker.component { --marker-color: #b884ff; }
.marker.fuse { --marker-color: #ffdf4d; }

.marker.covered {
    outline: 2px dashed rgba(255, 198, 106, .9);
    outline-offset: 4px;
}

.legend-dot.medbay { color: #ffffff; background: #ffffff; }
.legend-dot.airlock { color: #ffb347; background: #ffb347; }
.legend-dot.component { color: #b884ff; background: #b884ff; }
.legend-dot.fuse { color: #ffdf4d; background: #ffdf4d; }

.nav-tabs a { text-decoration: none; }

.nav-tabs a { text-decoration: none; }

.link-page-panel {
    margin-top: 18px;
    padding-bottom: 22px;
}

.link-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 18px;
    padding: 22px;
}

.link-card {
    display: grid;
    grid-template-columns: 58px 1fr;
    gap: 16px;
    min-height: 132px;
    padding: 18px;
    color: var(--text);
    text-decoration: none;
    background: linear-gradient(145deg, rgba(255,255,255,.055), rgba(0,0,0,.18));
    border: 1px solid rgba(33,234,255,.18);
    clip-path: polygon(14px 0, 100% 0, 100% calc(100% - 14px), calc(100% - 14px) 100%, 0 100%, 0 14px);
    transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}

.link-card:hover {
    border-color: var(--cyan);
    box-shadow: 0 0 22px rgba(33,234,255,.18);
    transform: translateY(-2px);
}

.link-card-icon {
    width: 54px;
    height: 54px;
    display: grid;
    place-items: center;
    color: #001215;
    background: var(--cyan);
    border-radius: 50%;
    font-size: 24px;
    font-weight: 950;
    box-shadow: 0 0 18px rgba(33,234,255,.45);
}

.link-card h2 {
    margin: 0 0 8px;
    color: #fff;
    font-size: 17px;
    text-transform: uppercase;
    letter-spacing: .065em;
}

.link-card p {
    margin: 0;
    color: var(--muted);
    line-height: 1.45;
}

.link-page-note {
    margin: 0 22px 22px;
    color: var(--muted);
}

.link-section {
    padding: 0 22px 22px;
}

.link-section-title {
    margin: 22px 0 12px;
    color: var(--cyan);
    font-size: 18px;
    letter-spacing: .10em;
    text-transform: uppercase;
}

.link-card-icon img {
    width: 34px;
    height: 34px;
    object-fit: contain;
    filter: drop-shadow(0 0 10px rgba(33, 234, 255, .25));
}

@font-face { font-family: 'ZeroPrimeVCG'; src: url('/assets/fonts/zero-prime.woff2') format('woff2'), url('/assets/fonts/zero-prime.ttf') format('truetype'); font-weight: 400; font-style: normal; font-display: swap; }


.marker.hidden-by-filter { display: none; }
.marker.tooltip-enabled:hover { z-index: 30; }
.ship-view-toolbar { display: grid; grid-template-columns: repeat(2, minmax(180px, 1fr)); gap: 12px; padding: 14px 16px 0; }
.compact-field { padding: 10px 12px; }
.brand-title, .brand-subtitle, .panel-title h1, .panel-title h2, .admin-header h1, .link-section-title { font-family: 'ZeroPrimeVCG', 'Zero Prime', 'Electrolize', system-ui, sans-serif; }


/* VCG cleanup: Markerfilter sitzt in der Legende */
.legend-filter-card {
    padding: 12px 14px;
}

.legend-filter-card summary {
    cursor: pointer;
    color: var(--cyan);
    text-transform: uppercase;
    letter-spacing: .08em;
    font-weight: 950;
    margin-bottom: 8px;
}

.legend-filter-item {
    width: 100%;
    display: grid;
    grid-template-columns: 18px 1fr;
    align-items: center;
    gap: 8px;
    margin: 4px 0;
    padding: 3px 2px;
    border: 0;
    background: transparent;
    color: var(--text);
    font: inherit;
    font-size: 12px;
    text-align: left;
    cursor: pointer;
}

.legend-filter-item:hover {
    color: var(--cyan);
}

.legend-filter-item.legend-filter-muted {
    opacity: .32;
    filter: grayscale(.8);
}

.legend-filter-item.legend-filter-muted span:last-child {
    text-decoration: line-through;
}

.marker.hidden-by-filter {
    display: none !important;
}

.marker.medbay { --marker-color: #ffffff; }
.marker.airlock { --marker-color: #ffb347; }
.marker.component { --marker-color: #b884ff; }
.marker.fuse { --marker-color: #ffdf4d; }
.legend-dot.medbay { background: #ffffff; }
.legend-dot.airlock { background: #ffb347; }
.legend-dot.component { background: #b884ff; }
.legend-dot.fuse { background: #ffdf4d; }


/* legend-admin-deck-2-roster */
.legend-filter-card {
    padding: 12px 14px;
}

.legend-filter-card summary {
    cursor: pointer;
    color: var(--cyan);
    text-transform: uppercase;
    letter-spacing: .08em;
    font-weight: 950;
    margin-bottom: 8px;
}

.legend-filter-item {
    width: 100%;
    display: grid;
    grid-template-columns: 18px 1fr;
    align-items: center;
    gap: 8px;
    margin: 4px 0;
    padding: 3px 2px;
    border: 0;
    background: transparent;
    color: var(--text);
    font: inherit;
    font-size: 12px;
    text-align: left;
    cursor: pointer;
}

.legend-filter-item:hover {
    color: var(--red);
}

.legend-filter-item.legend-filter-muted {
    opacity: .30;
    filter: grayscale(.85);
}

.legend-filter-item.legend-filter-muted span:last-child {
    text-decoration: line-through;
}

.marker.hidden-by-filter {
    display: none !important;
}

.marker.medbay { --marker-color: #ffffff; }
.marker.airlock { --marker-color: #ffb347; }
.marker.component { --marker-color: #b884ff; }
.marker.fuse { --marker-color: #ffdf4d; }
.legend-dot.medbay { background: #ffffff; }
.legend-dot.airlock { background: #ffb347; }
.legend-dot.component { background: #b884ff; }
.legend-dot.fuse { background: #ffdf4d; }

.placeholder-page {
    padding: 28px;
    color: var(--muted);
    line-height: 1.6;
}


/* stable-ui-1-roster */
.nav-tabs a,
.nav-tabs span {
    transition: color .16s ease, background .16s ease, border-color .16s ease, text-shadow .16s ease, transform .16s ease;
}

.nav-tabs a:hover {
    color: var(--cyan);
    border-color: var(--cyan);
    text-shadow: 0 0 14px rgba(33,234,255,.75);
    transform: translateY(-1px);
}

.ship-view-toolbar {
    display: grid;
    grid-template-columns: repeat(2, minmax(160px, 1fr));
    gap: 12px;
    padding: 14px 16px 0;
}

.compact-field {
    padding: 10px 12px;
}

.legend-filter-card {
    padding: 12px 14px;
}

.legend-filter-card summary {
    cursor: pointer;
    color: var(--cyan);
    text-transform: uppercase;
    letter-spacing: .08em;
    font-weight: 950;
    margin-bottom: 8px;
}

.legend-filter-item {
    width: 100%;
    display: grid;
    grid-template-columns: 18px 1fr;
    align-items: center;
    gap: 8px;
    margin: 4px 0;
    padding: 3px 2px;
    border: 0;
    background: transparent;
    color: var(--text);
    font: inherit;
    font-size: 12px;
    text-align: left;
    cursor: pointer;
}

.legend-filter-item:hover {
    color: var(--red);
}

.legend-filter-item.legend-filter-muted {
    opacity: .30;
    filter: grayscale(.85);
}

.legend-filter-item.legend-filter-muted span:last-child {
    text-decoration: line-through;
}

.marker.hidden-by-filter {
    display: none !important;
}

.marker.tooltip-enabled:hover .marker-label {
    display: block;
}

.marker.medbay { --marker-color: #ffffff; }
.marker.airlock { --marker-color: #ffb347; }
.marker.component { --marker-color: #b884ff; }
.marker.fuse { --marker-color: #ffdf4d; }
.legend-dot.medbay { background: #ffffff; }
.legend-dot.airlock { background: #ffb347; }
.legend-dot.component { background: #b884ff; }
.legend-dot.fuse { background: #ffdf4d; }

.link-grid {
    padding: 24px;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: 14px;
}

.link-card {
    display: grid;
    grid-template-columns: 36px 1fr;
    gap: 6px 12px;
    align-items: center;
    padding: 16px;
    border: 1px solid rgba(33,234,255,.22);
    background: rgba(255,255,255,.035);
    color: var(--text);
    text-decoration: none;
}

.link-card:hover {
    border-color: var(--cyan);
    box-shadow: 0 0 18px rgba(33,234,255,.18);
}

.link-icon {
    grid-row: span 2;
    width: 34px;
    height: 34px;
    display: grid;
    place-items: center;
    color: var(--cyan);
    border: 1px solid rgba(33,234,255,.4);
}

.link-card small,
.placeholder-page {
    color: var(--muted);
}

.placeholder-page {
    padding: 28px;
    line-height: 1.6;
}


/* visual-fix-2-roster */
.legend-filter-card {
    z-index: 20;
}

.legend-role-info {
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid rgba(172,193,202,.18);
}

.legend-role-info h3 {
    margin: 0 0 6px;
    color: var(--cyan);
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.legend-role-info div {
    color: var(--text);
    font-size: 12px;
    line-height: 1.45;
}

.role-info-card {
    display: none !important;
}

/* admin-matrix-3-roster */

/* Discord landing page */
.landing-shell {
    min-height: 100vh;
    padding: 24px;
}

.landing-hero {
    max-width: 1600px;
    margin: 0 auto;
    padding: 28px;
}

.landing-brand {
    display: flex;
    align-items: center;
    gap: 18px;
    margin-bottom: 26px;
}

.landing-crest {
    width: 88px;
    height: 88px;
    object-fit: contain;
    filter: drop-shadow(0 0 16px rgba(255, 0, 32, 0.25));
}

.landing-grid {
    display: grid;
    grid-template-columns: minmax(360px, 1fr) minmax(420px, 1.15fr);
    gap: 24px;
    align-items: stretch;
}

.landing-copy {
    display: flex;
    flex-direction: column;
    gap: 18px;
    justify-content: center;
}

.landing-kicker {
    font-family: 'ZeroPrimeVCG', 'Zero Prime', 'Electrolize', system-ui, sans-serif;
    font-size: 0.95rem;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--accent);
}

.landing-copy h1 {
    margin: 0;
    font-family: 'ZeroPrimeVCG', 'Zero Prime', 'Electrolize', system-ui, sans-serif;
    font-size: clamp(2rem, 4vw, 3.75rem);
    line-height: 1.02;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-primary);
}

.landing-copy p {
    margin: 0;
    max-width: 62ch;
    font-size: 1rem;
    line-height: 1.7;
    color: var(--text-secondary);
}

.landing-alert {
    border: 1px solid rgba(255, 72, 72, 0.65);
    background: rgba(78, 6, 6, 0.46);
    color: #ffd7d7;
    padding: 12px 14px;
    box-shadow: inset 0 0 0 1px rgba(255, 0, 0, 0.08), 0 0 16px rgba(255, 0, 0, 0.1);
}

.landing-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    align-items: center;
}

.discord-login-btn,
.landing-secondary-btn,
.public-link-row a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 0 18px;
    border: 1px solid rgba(255, 0, 0, 0.45);
    background: linear-gradient(180deg, rgba(10, 17, 23, 0.96), rgba(6, 10, 15, 0.98));
    color: var(--text-primary);
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-family: 'ZeroPrimeVCG', 'Zero Prime', 'Electrolize', system-ui, sans-serif;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
    cursor: pointer;
}

.discord-login-btn:hover,
.landing-secondary-btn:hover,
.public-link-row a:hover {
    transform: translateY(-1px);
    border-color: rgba(0, 235, 255, 0.65);
    box-shadow: 0 0 18px rgba(0, 235, 255, 0.18);
}

.landing-secondary-btn {
    background: rgba(7, 11, 17, 0.92);
}

.public-link-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.landing-user-card {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    padding: 10px 14px;
    border: 1px solid rgba(0, 235, 255, 0.35);
    background: rgba(0, 20, 28, 0.48);
    max-width: fit-content;
}

.landing-user-card img {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    object-fit: cover;
    border: 1px solid rgba(255, 255, 255, 0.18);
}

.landing-user-card strong,
.landing-user-card span {
    display: block;
}

.landing-user-card span {
    color: var(--text-secondary);
    margin-top: 4px;
}

.landing-visuals {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    min-height: 100%;
}

.landing-visual-card {
    position: relative;
    min-height: 240px;
    overflow: hidden;
    border: 1px solid rgba(255, 0, 0, 0.36);
    background: rgba(0, 0, 0, 0.28);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.02), 0 16px 24px rgba(0,0,0,0.18);
}

.landing-visual-card::after {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(180deg, rgba(0,0,0,0.03), rgba(0,0,0,0.22));
}

.landing-visual-card--wide {
    grid-column: 1 / -1;
    min-height: 320px;
}

.landing-visual-card img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: center center;
}

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

@media (max-width: 760px) {
    .landing-shell {
        padding: 14px;
    }

    .landing-hero {
        padding: 18px;
    }

    .landing-brand {
        align-items: flex-start;
    }

    .landing-crest {
        width: 68px;
        height: 68px;
    }

    .landing-visuals {
        grid-template-columns: 1fr;
    }

    .landing-visual-card--wide {
        grid-column: auto;
    }
}


/* member-header-1 */
.member-card {
    grid-area: status;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
    min-width: 340px;
    max-width: 430px;
    padding: 12px 14px;
    background: linear-gradient(120deg, rgba(4, 9, 12, .86), rgba(10, 15, 18, .72));
    border: 1px solid var(--line-soft);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.025), 0 0 18px rgba(0,0,0,.22);
    clip-path: polygon(0 0, 94% 0, 100% 24%, 100% 100%, 6% 100%, 0 76%);
}

.status-panels {
    grid-template-columns: minmax(240px, 300px) minmax(330px, 430px);
}

.status-panels .member-card {
    grid-area: auto;
    min-width: 0;
    max-width: none;
}

.member-avatar {
    width: 54px;
    height: 54px;
    border-radius: 0;
    object-fit: cover;
    border: 1px solid rgba(33, 234, 255, .4);
    box-shadow: 0 0 16px rgba(33,234,255,.14);
    clip-path: polygon(12% 0, 100% 0, 88% 100%, 0 100%);
}

.member-avatar-fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--cyan);
    font-size: 12px;
    font-weight: 950;
    background: rgba(0,0,0,.52);
}

.member-meta {
    min-width: 0;
    display: grid;
    gap: 2px;
}

.member-meta span,
.member-meta small {
    color: var(--muted);
    font-size: 10px;
    font-weight: 950;
    letter-spacing: .11em;
    text-transform: uppercase;
}

.member-meta strong {
    color: var(--text);
    font-size: 15px;
    font-weight: 950;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.member-meta a,
.landing-user-card a {
    color: var(--cyan);
    font-size: 11px;
    font-weight: 950;
    letter-spacing: .08em;
    text-transform: uppercase;
    text-decoration: none;
}

.member-meta a:hover,
.landing-user-card a:hover {
    color: #fff;
    text-shadow: 0 0 12px var(--cyan);
}

.member-logout-form {
    margin: 0;
}

.member-logout-btn {
    min-width: 84px;
    min-height: 34px;
    padding: 8px 10px;
    color: #fff;
    border-color: rgba(224, 0, 0, .84);
    background: rgba(0, 0, 0, .64);
}

.member-logout-btn:hover {
    color: var(--cyan);
    border-color: var(--cyan);
}

@media (max-width: 980px) {
    .site-header {
        grid-template-columns: 1fr;
        grid-template-areas:
            "brand"
            "nav"
            "status";
        clip-path: none;
    }

    .nav-tabs {
        padding-left: 0;
    }

    .status-panels {
        grid-template-columns: 1fr;
    }

    .member-card {
        max-width: none;
        min-width: 0;
    }
}


/* rsi-handle-profile-1 */
.member-link-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.profile-panel {
    margin-top: 18px;
    padding-bottom: 28px;
}

.profile-grid {
    display: grid;
    grid-template-columns: minmax(280px, 420px) minmax(320px, 1fr);
    gap: 18px;
    padding: 20px;
}

.profile-card {
    border: 1px solid var(--line-soft);
    background: rgba(4, 8, 10, .72);
    padding: 18px;
    clip-path: polygon(0 0, 96% 0, 100% 9%, 100% 100%, 4% 100%, 0 91%);
}

.profile-card h2 {
    margin: 0 0 16px;
    font-family: "Zero Prime", "Electrolize", "Segoe UI", sans-serif;
    color: var(--cyan);
    letter-spacing: .08em;
    text-transform: uppercase;
}

.profile-card dl {
    display: grid;
    grid-template-columns: 150px 1fr;
    gap: 10px 14px;
    margin: 0;
}

.profile-card dt {
    color: var(--muted);
    font-size: 11px;
    font-weight: 950;
    letter-spacing: .11em;
    text-transform: uppercase;
}

.profile-card dd {
    margin: 0;
    color: var(--text);
}

.profile-form {
    display: grid;
    gap: 14px;
}

.profile-hint {
    margin: 0;
    color: var(--muted);
    line-height: 1.55;
}

.profile-status,
.profile-errors {
    margin: 18px 20px 0;
    padding: 12px 14px;
    border: 1px solid rgba(33, 234, 255, .35);
    background: rgba(0, 24, 30, .46);
    color: var(--text);
}

.profile-errors {
    border-color: rgba(224, 0, 0, .55);
    background: rgba(60, 0, 0, .42);
}

.profile-rsi-link {
    display: inline-flex;
    margin-top: 14px;
    color: var(--cyan);
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: .08em;
    text-decoration: none;
}

.profile-rsi-link:hover {
    color: #fff;
    text-shadow: 0 0 14px var(--cyan);
}

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

    .profile-card dl {
        grid-template-columns: 1fr;
    }
}


/* admin-section-roster-1 */
.roster-controlbar {
    grid-template-columns: minmax(230px, 320px) minmax(230px, 320px) minmax(260px, 390px) 1fr auto;
}

.ship-picker-field,
.role-filter-field {
    padding: 10px 14px;
}

.role-filter-hidden {
    display: none !important;
}

.admin-section-layout {
    display: grid;
    grid-template-columns: 250px minmax(0, 1fr);
    gap: 18px;
    align-items: start;
}

.admin-section-content {
    display: grid;
    grid-template-columns: inherit;
    gap: inherit;
    min-width: 0;
}

.admin-section-sidebar {
    position: sticky;
    top: 16px;
    display: grid;
    gap: 10px;
    padding: 14px;
}

.admin-section-sidebar a {
    display: block;
    padding: 14px 12px;
    color: #aeb5bb;
    text-decoration: none;
    text-transform: uppercase;
    font-weight: 950;
    letter-spacing: .08em;
    background: rgba(0,0,0,.42);
    border: 1px solid rgba(255,255,255,.10);
    clip-path: polygon(7% 0, 100% 0, 93% 100%, 0 100%);
}

.admin-section-sidebar a:hover,
.admin-section-sidebar a.active {
    color: #fff;
    border-color: var(--red);
    box-shadow: inset 0 -3px 0 var(--red), 0 0 18px rgba(224,0,0,.32);
}

.admin-section-hidden {
    display: none !important;
}

.admin-placeholder-page {
    margin: 18px;
}

@media (max-width: 1100px) {
    .roster-controlbar,
    .subbar {
        grid-template-columns: 1fr;
    }

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

    .admin-section-sidebar {
        position: relative;
        top: auto;
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    }
}


/* roles-are-columns-1 */
.role-column-hidden {
    display: none !important;
}

.role-column-filtered {
    min-width: 560px;
}

.role-column-filtered .role-head-cell,
.role-column-filtered .role-cell {
    width: 300px;
}

.roster-controlbar {
    grid-template-columns: minmax(240px, 330px) minmax(280px, 430px) 1fr auto;
}

.role-column-field,
.ship-picker-field {
    padding: 10px 14px;
}

.site-header > .member-card {
    grid-area: status;
}

.admin-section-layout {
    display: grid;
    grid-template-columns: 86px minmax(0, 1fr);
    gap: 14px;
    align-items: start;
}

.admin-section-sidebar {
    position: sticky;
    top: 16px;
    z-index: 20;
    width: 72px;
    min-height: 0;
    display: grid;
    gap: 10px;
    padding: 10px;
    overflow: visible;
    transition: width .18s ease, box-shadow .18s ease;
}

.admin-section-sidebar:hover {
    width: 250px;
    box-shadow: 0 0 30px rgba(0,0,0,.42), 0 0 18px rgba(224,0,0,.18);
}

.admin-section-sidebar a {
    display: grid;
    grid-template-columns: 42px 1fr;
    align-items: center;
    gap: 10px;
    min-height: 46px;
    padding: 8px 10px;
    color: #aeb5bb;
    text-decoration: none;
    text-transform: uppercase;
    font-weight: 950;
    letter-spacing: .08em;
    background: rgba(0,0,0,.42);
    border: 1px solid rgba(255,255,255,.10);
    clip-path: polygon(7% 0, 100% 0, 93% 100%, 0 100%);
    white-space: nowrap;
}

.admin-section-code {
    display: grid;
    place-items: center;
    width: 36px;
    height: 30px;
    color: var(--cyan);
    border: 1px solid rgba(33,234,255,.35);
    background: rgba(0,0,0,.52);
    font-size: 12px;
}

.admin-section-label {
    max-width: 0;
    opacity: 0;
    overflow: hidden;
    transition: max-width .18s ease, opacity .18s ease;
}

.admin-section-sidebar:hover .admin-section-label {
    max-width: 180px;
    opacity: 1;
}

.admin-section-sidebar a:hover,
.admin-section-sidebar a.active {
    color: #fff;
    border-color: var(--red);
    box-shadow: inset 0 -3px 0 var(--red), 0 0 18px rgba(224,0,0,.32);
}

.admin-section-hidden {
    display: none !important;
}

.admin-section-content {
    min-width: 0;
}

@media (max-width: 1100px) {
    .roster-controlbar,
    .subbar {
        grid-template-columns: 1fr;
    }

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

    .admin-section-sidebar,
    .admin-section-sidebar:hover {
        position: relative;
        top: auto;
        width: auto;
        grid-template-columns: repeat(auto-fit, minmax(86px, 1fr));
    }

    .admin-section-sidebar .admin-section-label {
        max-width: none;
        opacity: 1;
    }
}


/* admin-members-width-1 */
.admin-section-layout {
    grid-template-columns: 86px minmax(0, 1fr) !important;
    width: 100%;
}

.admin-section-content {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 18px !important;
    width: 100% !important;
    min-width: 0;
}

.admin-section-content > .panel {
    width: 100%;
    min-width: 0;
}

.admin-section-sidebar {
    width: 72px;
}

.admin-section-sidebar:hover {
    width: 265px;
}

.admin-section-sidebar a {
    grid-template-columns: 42px minmax(0, 1fr);
}

.admin-members-table small {
    display: block;
    margin-top: 4px;
    color: var(--muted);
}

.admin-members-table input {
    min-width: 160px;
}

.mono-cell {
    font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace;
    font-size: 11px;
    color: var(--muted);
}

.admin-member-note {
    margin: 16px 18px 0;
    padding: 12px 14px;
    border: 1px solid rgba(33, 234, 255, .28);
    background: rgba(0, 24, 30, .32);
    color: var(--muted);
    line-height: 1.55;
}

@media (max-width: 1100px) {
    .admin-section-layout {
        grid-template-columns: 1fr !important;
    }

    .admin-section-sidebar,
    .admin-section-sidebar:hover {
        width: auto;
    }
}


/* roles-hide-ship-sidebar-1 */
.role-column-hidden,
.role-matrix .role-column-hidden {
    display: none !important;
}

.role-column-filtered {
    min-width: 620px !important;
}

.role-column-filtered .role-head-cell,
.role-column-filtered .role-cell {
    width: 300px;
}

.admin-sidebar-ship-form {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    align-items: center;
    gap: 10px;
    min-height: 54px;
    margin: 0 0 8px;
    padding: 8px 10px;
    border: 1px solid rgba(33, 234, 255, .28);
    background: rgba(0, 18, 24, .44);
    clip-path: polygon(7% 0, 100% 0, 93% 100%, 0 100%);
}

.admin-ship-code {
    color: #fff;
    border-color: rgba(224, 0, 0, .7);
}

.admin-sidebar-ship-label {
    display: grid;
    gap: 5px;
    max-width: 0;
    opacity: 0;
    overflow: hidden;
    transition: max-width .18s ease, opacity .18s ease;
}

.admin-section-sidebar:hover .admin-sidebar-ship-label {
    max-width: 190px;
    opacity: 1;
}

.admin-sidebar-ship-label span {
    color: var(--muted);
    font-size: 10px;
    font-weight: 950;
    letter-spacing: .11em;
    text-transform: uppercase;
}

.admin-sidebar-ship-label select {
    min-height: 34px;
    padding: 6px 8px;
    font-size: 12px;
}

.admin-current-ship-strip {
    display: flex;
    align-items: baseline;
    gap: 12px;
    width: 100%;
    padding: 12px 16px;
    border: 1px solid rgba(33, 234, 255, .22);
    background: linear-gradient(90deg, rgba(0, 26, 34, .52), rgba(4, 8, 10, .62));
    color: var(--text);
    clip-path: polygon(12px 0, 100% 0, 100% calc(100% - 12px), calc(100% - 12px) 100%, 0 100%, 0 12px);
}

.admin-current-ship-strip span {
    color: var(--muted);
    font-size: 11px;
    font-weight: 950;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.admin-current-ship-strip strong {
    color: var(--cyan);
    font-family: "Zero Prime", "Electrolize", "Segoe UI", sans-serif;
    font-size: 18px;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.admin-current-ship-strip small {
    color: var(--muted);
}

@media (max-width: 1100px) {
    .admin-sidebar-ship-label {
        max-width: none;
        opacity: 1;
    }

    .admin-sidebar-ship-form {
        grid-template-columns: 42px minmax(180px, 1fr);
    }

    .admin-current-ship-strip {
        flex-wrap: wrap;
    }
}


/* role-dropdown-marker-visible-1 */
.role-matrix [hidden],
.role-matrix .role-column-hidden {
    display: none !important;
    visibility: collapse !important;
    width: 0 !important;
    min-width: 0 !important;
    max-width: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    overflow: hidden !important;
}

.role-column-filtered {
    min-width: 620px !important;
}

.role-column-filtered .role-head-cell,
.role-column-filtered .role-cell {
    width: 300px;
}

.marker.all-visible {
    opacity: .92;
    filter: saturate(1.15);
    box-shadow: 0 0 10px rgba(33, 234, 255, .18);
}

.marker.all-visible:hover {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.12);
    box-shadow: 0 0 16px var(--marker-color), 0 0 30px rgba(33, 234, 255, .22);
}


/* role-filter-last-active-1 */
.role-matrix [hidden],
.role-matrix .role-column-hidden {
    display: none !important;
    visibility: collapse !important;
    width: 0 !important;
    min-width: 0 !important;
    max-width: 0 !important;
    padding: 0 !important;
    border-width: 0 !important;
    overflow: hidden !important;
}

.role-column-filtered {
    min-width: 620px !important;
}

.role-column-filtered .role-head-cell,
.role-column-filtered .role-cell {
    width: 300px;
}

.marker.all-visible {
    opacity: .92;
    filter: saturate(1.15);
    box-shadow: 0 0 10px rgba(33, 234, 255, .18);
}

.marker.all-visible:hover {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.12);
    box-shadow: 0 0 16px var(--marker-color), 0 0 30px rgba(33, 234, 255, .22);
}


/* role-header-sync-1 */
.role-matrix [hidden],
.role-matrix .role-column-hidden {
    display: none !important;
    visibility: collapse !important;
    width: 0 !important;
    min-width: 0 !important;
    max-width: 0 !important;
    padding: 0 !important;
    border-width: 0 !important;
    overflow: hidden !important;
}

.role-matrix.role-column-filtered {
    table-layout: auto;
    min-width: 620px !important;
}

.role-matrix.role-column-filtered .position-col,
.role-matrix.role-column-filtered .position-head {
    width: 380px;
}

.role-matrix.role-column-filtered .role-group-head,
.role-matrix.role-column-filtered .role-head-cell,
.role-matrix.role-column-filtered .role-cell {
    width: auto;
    text-align: left;
}

.role-matrix.role-column-filtered .role-group-head {
    text-align: center;
}


/* equipment-profiles-1 */
.equipment-profile-admin-grid,
.equipment-profile-page-grid {
    display: grid;
    gap: 18px;
    padding: 18px;
}

.equipment-profile-admin-card,
.equipment-profile-public-card,
.equipment-profile-roster-card {
    border: 1px solid var(--line-soft);
    background: rgba(4, 8, 10, .72);
    padding: 16px;
    clip-path: polygon(0 0, 97% 0, 100% 12%, 100% 100%, 3% 100%, 0 88%);
}

.equipment-profile-admin-card {
    display: grid;
    gap: 12px;
}

.admin-inline-delete-form {
    margin: 0;
    justify-self: start;
}

.equipment-item-wrap {
    margin-top: 8px;
}

.equipment-item-table input {
    min-width: 110px;
}

.equipment-profile-roster-card {
    margin-top: 14px;
}

.equipment-profile-roster-card h3,
.equipment-profile-public-card h2 {
    margin: 0 0 10px;
    color: var(--cyan);
    font-family: "Zero Prime", "Electrolize", "Segoe UI", sans-serif;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.equipment-profile-roster-title {
    color: #fff;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: .06em;
}

.equipment-profile-roster-card p,
.equipment-profile-public-card p {
    margin: 8px 0 10px;
    color: var(--muted);
    line-height: 1.45;
}

.equipment-profile-roster-card ul,
.equipment-profile-public-card ul {
    list-style: none;
    display: grid;
    gap: 8px;
    margin: 0;
    padding: 0;
}

.equipment-profile-roster-card li,
.equipment-profile-public-card li {
    display: grid;
    grid-template-columns: 50px 1fr;
    gap: 8px;
    align-items: baseline;
    padding: 8px 10px;
    border: 1px solid rgba(33, 234, 255, .16);
    background: rgba(0, 18, 24, .28);
}

.equipment-profile-roster-card li span,
.equipment-profile-public-card li small {
    grid-column: 2;
    color: var(--muted);
}

.equipment-profile-roster-empty {
    color: var(--muted);
}

.equipment-profile-public-head {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: baseline;
    border-bottom: 1px solid rgba(255,255,255,.08);
    margin-bottom: 12px;
    padding-bottom: 10px;
}

.equipment-profile-public-head span {
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .08em;
    font-size: 11px;
}

.equipment-profile-page-grid {
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
}


/* equipment-slots-section-stay-1 */
.equipment-slot-table {
    min-width: 1180px;
}

.equipment-slot-table input[type="file"] {
    min-width: 180px;
}

.equipment-slot-label {
    color: var(--cyan);
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: .08em;
    white-space: nowrap;
}

.equipment-slot-preview,
.equipment-slot-thumb,
.equipment-profile-image-preview img {
    width: 54px;
    height: 54px;
    object-fit: cover;
    border: 1px solid rgba(33, 234, 255, .28);
    background: rgba(0,0,0,.5);
}

.equipment-profile-image-preview {
    justify-self: start;
    padding: 8px;
    border: 1px solid rgba(255,255,255,.08);
    background: rgba(0,0,0,.28);
}

.equipment-profile-roster-card li,
.equipment-profile-public-card li {
    grid-template-columns: 58px 50px 1fr;
}

.equipment-profile-roster-card li .equipment-slot-thumb,
.equipment-profile-public-card li .equipment-slot-thumb {
    grid-row: span 2;
}

.equipment-profile-roster-card li span,
.equipment-profile-public-card li small {
    grid-column: 3;
}


/* layout-links-taskmatrix-1 */
.admin-section-label {
    font-size: 9px !important;
    letter-spacing: .045em !important;
}

.admin-section-sidebar:hover .admin-section-label {
    max-width: 205px !important;
}

.equipment-bottom-panel {
    margin-top: 18px;
}

.equipment-profile-roster-card--bottom {
    margin-top: 0;
    padding: 18px 22px 24px;
    border: 0;
    background: transparent;
    clip-path: none !important;
    overflow: visible !important;
}

.equipment-profile-roster-card--bottom .equipment-profile-roster-title {
    margin-bottom: 12px;
    font-size: 20px;
}

.equipment-profile-roster-card--bottom ul {
    grid-template-columns: repeat(auto-fit, minmax(290px, 1fr));
    gap: 12px;
}

.equipment-profile-roster-card--bottom li {
    min-height: 78px;
    overflow: visible;
}

.equipment-profile-roster-card--bottom p {
    max-width: 1100px;
}

.equipment-profile-admin-card,
.equipment-profile-public-card {
    clip-path: none !important;
    overflow: visible !important;
}

.equipment-profile-admin-card button,
.equipment-slot-form button,
.admin-inline-delete-form button {
    clip-path: none !important;
    min-width: 170px;
    padding-left: 22px;
    padding-right: 22px;
    line-height: 1.25;
    overflow: visible;
}

.equipment-slot-form {
    overflow: visible;
    padding-bottom: 12px;
}

.equipment-profile-admin-card {
    padding: 18px 20px 22px !important;
}

.equipment-profile-public-card li {
    overflow: visible;
}

.task-matrix-horizontal-wrap {
    max-width: 100%;
    overflow-x: auto;
}

.task-matrix-horizontal-table {
    min-width: 980px;
    table-layout: fixed;
}

.task-matrix-horizontal-table .task-slot-head,
.task-matrix-horizontal-table .task-slot-label {
    width: 110px;
    min-width: 110px;
    color: var(--cyan);
    text-transform: uppercase;
    letter-spacing: .08em;
}

.task-matrix-horizontal-table .task-group-head {
    text-align: center;
    color: var(--cyan);
    background: rgba(0, 34, 42, .28);
}

.task-matrix-horizontal-table .task-role-head {
    min-width: 210px;
    width: 210px;
    color: var(--text);
    text-align: center;
}

.task-matrix-horizontal-table .task-input-cell {
    min-width: 210px;
    width: 210px;
    vertical-align: top;
}

.task-matrix-horizontal-table textarea {
    min-height: 56px;
    resize: vertical;
    line-height: 1.35;
    font-size: 12px;
}

.position-task-matrix-horizontal[hidden] {
    display: none !important;
}


/* revert-before-missioncards-1 */
.role-matrix.role-column-filtered{
    width:auto!important;
    min-width:514px!important;
    table-layout:fixed!important;
}
.role-matrix.role-column-filtered .position-head,
.role-matrix.role-column-filtered .position-col{
    width:270px!important;
    min-width:270px!important;
    max-width:270px!important;
}
.role-matrix.role-column-filtered .role-group-head,
.role-matrix.role-column-filtered .mode-head,
.role-matrix.role-column-filtered .role-head-cell:not(.position-head),
.role-matrix.role-column-filtered .task-cell:not(.role-column-hidden){
    width:244px!important;
    min-width:244px!important;
    max-width:244px!important;
}
.role-matrix .task-cell{
    position:static!important;
    left:auto!important;
}
.ship-overview-controlbar{
    grid-template-columns:minmax(240px,360px) minmax(240px,360px) 1fr;
}
.ship-overview-map-panel{
    margin-top:18px;
}
.ship-overview-map-wrap{
    position:relative;
    padding:18px;
    min-height:780px;
}
.ship-overview-stage{
    min-height:760px;
    max-height:none;
}
.ship-overview-stage img{
    width:100%;
    max-height:76vh;
    object-fit:contain;
}
.ship-overview-legend{
    position:absolute;
    right:34px;
    top:34px;
    min-width:230px;
    background:rgba(4,8,10,.80);
}
.admin-bulk-save-button,
.admin-group-save-button{
    border:1px solid rgba(224,0,0,.55);
    background:rgba(224,0,0,.12);
    color:#fff;
    font-weight:900;
    letter-spacing:.04em;
    cursor:pointer;
    border-radius:8px;
    padding:8px 12px;
}
.admin-group-save-button{
    margin-left:auto;
    padding:5px 9px;
    font-size:11px;
}
.marker-type-section summary{
    display:flex;
    align-items:center;
    gap:12px;
}
.admin-bulk-save-button:disabled,
.admin-group-save-button:disabled{
    opacity:.55;
    cursor:wait;
}


/* overview-links-style-1 */
.overview-link-section {
    margin-top: 34px;
}

.overview-link-section:first-of-type {
    margin-top: 18px;
}

.overview-link-section .link-section-title {
    margin: 0 0 16px 64px !important;
    padding: 0 0 0 18px;
    color: rgba(241,244,246,.88) !important;
    border-left: 3px solid var(--red);
    font-size: 18px;
    line-height: 1.1;
    letter-spacing: .105em;
    text-transform: uppercase;
    text-shadow: 0 0 12px rgba(255,255,255,.10);
}

.overview-link-section .link-grid {
    padding-left: 64px;
}

@media (max-width: 900px) {
    .overview-link-section .link-section-title {
        margin-left: 22px !important;
    }

    .overview-link-section .link-grid {
        padding-left: 22px;
    }
}


/* equipment-heading-style-1
   Ausrüstungsprofil-Überschriften konsistent: kein Cyan/Blau mehr.
*/
.equipment-profile-public-head h2,
.equipment-profile-card h2,
.equipment-profile-card h3,
.equipment-profile-admin-card h2,
.equipment-profile-admin-card h3,
.equipment-profile-title,
.equipment-page .equipment-profile-public-head h2,
.equipment-page .equipment-profile-card h2,
.equipment-page .equipment-profile-card h3 {
    color: rgba(241, 244, 246, .94) !important;
    text-shadow: 0 0 12px rgba(255,255,255,.10) !important;
}

.equipment-profile-public-head h2::before,
.equipment-profile-card h2::before,
.equipment-profile-card h3::before {
    border-color: var(--red) !important;
}
