﻿@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Orbitron:wght@500;600;700;800&display=swap');

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


:root {
    
    --epic-bg: #121212;
    --epic-surface: #2a2a2a;
    --epic-elevated: #313131;
    --epic-hover: #3a3a3a;
    --epic-sidebar: #202020;
    --epic-border: #404040;
    --epic-primary: #0078f2;
    --epic-primary-hover: #0c8dff;
    --epic-text: #ffffff;
    --epic-text-secondary: #b3b3b3;
    --epic-text-dim: #7a7a7a;
    --epic-success: #2ecc71;
    --epic-warning: #f39c12;
    --epic-danger: #e74c3c;
    --epic-card-bg: #1e1e1e;
    
    
    --app-bg: #121212;
    --content-bg: #2a2a2a;
    --tab-bg: #313131;
    --tab-text: #ffffff;
    --primary-color: #0078f2;
    --primary-hover: #0c8dff;
    --border-color: #404040;
    --text-color: #ffffff;
}


@keyframes fadeIn {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes slideIn {
    from { transform: translateX(-20px); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}

@keyframes scaleIn {
    from { transform: scale(0.95); opacity: 0; }
    to { transform: scale(1); opacity: 1; }
}

@keyframes shimmer {
    0% { background-position: -1000px 0; }
    100% { background-position: 1000px 0; }
}

@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

html, body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    background: var(--epic-bg);
    color: var(--epic-text);
    margin: 0;
    padding: 0;
    min-height: 100%;
    overflow-x: hidden;
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

html.enigma-global-zoom-fallback body {
    min-height: 125vh;
}

#app {
    min-height: 100vh;
    min-height: -webkit-fill-available;
    display: flex;
    flex-direction: column;
}


.app-header {
    background:
        linear-gradient(180deg, rgba(9, 13, 23, 0.96), rgba(9, 13, 23, 0.88)),
        var(--epic-sidebar);
    padding: 18px 28px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid rgba(124, 166, 255, 0.12);
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    z-index: 1000;
    -webkit-backdrop-filter: blur(16px);
    backdrop-filter: blur(16px);
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.18);
}

.app-header h1,
.app-header h2,
.app-header h3 {
    margin: 0;
    font-weight: 700;
}

.app-header h1 {
    font-size: 1.5rem;
    color: var(--epic-text);
    letter-spacing: -0.5px;
}

.app-header h2 {
    font-size: 1.1rem;
    color: var(--epic-text-secondary);
    font-weight: 500;
}

.app-header h3 {
    font-size: 0.9rem;
    color: var(--epic-text-dim);
    font-weight: 400;
}


.nav-tabs, .nav {
    display: flex;
    gap: 8px;
    list-style: none;
    padding: 0;
    margin: 0;
}

.nav-link {
    padding: 10px 20px;
    color: var(--epic-text-secondary);
    text-decoration: none;
    font-size: 0.95rem;
    font-weight: 500;
    transition: all 0.2s ease;
    border-radius: 4px;
}

.nav-link:hover {
    color: var(--epic-text);
    background: var(--epic-hover);
}

.nav-link.active {
    color: var(--epic-text);
    background: var(--epic-elevated);
}


.app-content {
    flex: 1;
    padding: 24px;
    background: var(--epic-bg);
    animation: fadeIn 0.3s ease-out;
}

.content {
    max-width: 1400px;
    margin: 0 auto;
}


.app-footer {
    background: var(--epic-sidebar);
    padding: 20px 24px;
    text-align: center;
    font-size: 0.85rem;
    color: var(--epic-text-dim);
    border-top: 1px solid var(--epic-border);
}


.btn, .btn-primary {
    font-family: 'Inter', sans-serif;
    border: 1px solid transparent;
    color: var(--epic-text);
    padding: 12px 20px;
    min-height: 46px;
    font-size: 0.95rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    cursor: pointer;
    border-radius: 14px;
    transition: transform 0.18s ease, background 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, color 0.18s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    text-decoration: none;
}

.btn:hover, .btn-primary:hover {
    background: var(--epic-hover);
    transform: translateY(-1px);
    box-shadow: 0 12px 26px rgba(0, 0, 0, 0.22);
}

.btn:active, .btn-primary:active {
    transform: translateY(0);
}

.subtext-mt-4{
    margin-top: 1rem;
    text-align: center;
    color: var(--epic-text);
}

.btn-primary {
    background: linear-gradient(135deg, var(--epic-primary), var(--epic-primary-hover));
    color: white;
    box-shadow: 0 14px 32px rgba(0, 120, 242, 0.18);
}

.btn-primary:hover {
    background: var(--epic-primary-hover);
}

.btn-danger {
    background: var(--epic-danger);
    color: white;
    box-shadow: 0 14px 30px rgba(231, 76, 60, 0.18);
}

.btn-danger:hover {
    background: #d62c1a;
}

.btn-success {
    background: var(--epic-success);
    color: white;
    box-shadow: 0 14px 30px rgba(46, 204, 113, 0.18);
}

.btn-success:hover {
    background: #27ae60;
}


.form-control, .form-control-plaintext {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.015)),
        var(--epic-surface);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: var(--epic-text);
    font-family: 'Inter', sans-serif;
    font-size: 0.95rem;
    padding: 12px 16px;
    border-radius: 14px;
    transition: all 0.2s ease;
    width: 100%;
    color-scheme: dark;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.03),
        0 8px 18px rgba(0, 0, 0, 0.08);
}

.form-control:focus, .form-control-plaintext:focus {
    outline: none;
    border-color: var(--epic-primary);
    box-shadow: 0 0 0 3px rgba(0, 120, 242, 0.2);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.02)),
        var(--epic-elevated);
    color: var(--epic-text);
    -webkit-text-fill-color: var(--epic-text);
    caret-color: var(--epic-text);
}

.form-control::placeholder {
    color: rgba(160, 178, 203, 0.56);
    -webkit-text-fill-color: rgba(160, 178, 203, 0.56);
    opacity: 1;
}

.form-control::-webkit-input-placeholder {
    color: rgba(160, 178, 203, 0.56);
    -webkit-text-fill-color: rgba(160, 178, 203, 0.56);
    opacity: 1;
}

.form-control:-ms-input-placeholder,
.form-control::-ms-input-placeholder {
    color: rgba(160, 178, 203, 0.56);
}

input.form-control,
textarea.form-control,
select.form-control,
select.form-select {
    color: var(--epic-text);
    -webkit-text-fill-color: var(--epic-text);
    caret-color: var(--epic-text);
}

input.form-control:-webkit-autofill,
input.form-control:-webkit-autofill:hover,
input.form-control:-webkit-autofill:focus,
textarea.form-control:-webkit-autofill,
textarea.form-control:-webkit-autofill:hover,
textarea.form-control:-webkit-autofill:focus {
    -webkit-text-fill-color: var(--epic-text);
    caret-color: var(--epic-text);
    -webkit-box-shadow: 0 0 0 1000px rgba(31, 31, 31, 0.98) inset;
    box-shadow: 0 0 0 1000px rgba(31, 31, 31, 0.98) inset;
    transition: background-color 9999s ease-in-out 0s;
}

select.form-control,
select.form-select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    cursor: pointer;
    padding-right: 16px;
    color-scheme: dark;
    border-color: rgba(118, 156, 232, 0.18);
    background-image: linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0));
    background-repeat: no-repeat;
    background-position: center;
    background-size: 100% 100%;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.035),
        0 10px 24px rgba(0, 0, 0, 0.12);
}

select.form-control:hover,
select.form-select:hover {
    border-color: rgba(126, 184, 255, 0.28);
    background-color: rgba(255, 255, 255, 0.045);
}

select.form-control:focus,
select.form-select:focus {
    border-color: rgba(116, 176, 255, 0.72);
    background-image: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.02));
}

input[type="number"].form-control,
input[type="number"].form-select {
    appearance: textfield;
    -webkit-appearance: textfield;
    -moz-appearance: textfield;
    color-scheme: dark;
    padding-right: 16px;
    border-color: rgba(118, 156, 232, 0.18);
}

input[type="number"].form-control::-webkit-inner-spin-button,
input[type="number"].form-control::-webkit-outer-spin-button,
input[type="number"].form-select::-webkit-inner-spin-button,
input[type="number"].form-select::-webkit-outer-spin-button {
    -webkit-appearance: none;
    appearance: none;
    margin: 0;
    opacity: 0;
    width: 0;
    display: none;
}

input[type="number"].form-control:hover::-webkit-inner-spin-button,
input[type="number"].form-control:hover::-webkit-outer-spin-button,
input[type="number"].form-select:hover::-webkit-inner-spin-button,
input[type="number"].form-select:hover::-webkit-outer-spin-button {
    opacity: 0;
}

.enigma-dropdown.form-control,
.enigma-stepper.form-control {
    padding: 0;
    overflow: visible;
}

.enigma-dropdown {
    position: relative;
}

.enigma-dropdown-trigger {
    width: 100%;
    min-height: 50px;
    border: 0;
    border-radius: 14px;
    padding: 12px 46px 12px 16px;
    background: transparent;
    color: var(--epic-text);
    font-family: 'Inter', sans-serif;
    font-size: 0.95rem;
    font-weight: 600;
    text-align: left;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    cursor: pointer;
}

.enigma-dropdown-trigger:focus-visible {
    outline: none;
}

.enigma-dropdown-trigger-label {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.enigma-dropdown-trigger-icon {
    position: absolute;
    right: 16px;
    top: 50%;
    width: 10px;
    height: 10px;
    border-right: 2px solid rgba(235, 241, 255, 0.9);
    border-bottom: 2px solid rgba(235, 241, 255, 0.9);
    transform: translateY(-65%) rotate(45deg);
    pointer-events: none;
    transition: transform 0.18s ease, border-color 0.18s ease;
}

.enigma-dropdown-trigger.open .enigma-dropdown-trigger-icon {
    transform: translateY(-35%) rotate(225deg);
}

.enigma-dropdown:hover {
    border-color: rgba(126, 184, 255, 0.28);
    background-color: rgba(255, 255, 255, 0.045);
}

.enigma-dropdown:focus-within {
    border-color: rgba(116, 176, 255, 0.72);
    box-shadow: 0 0 0 3px rgba(0, 120, 242, 0.2);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.02)),
        var(--epic-elevated);
}

.enigma-dropdown-menu {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 8px);
    padding: 8px;
    border-radius: 18px;
    border: 1px solid rgba(122, 170, 255, 0.26);
    background:
        linear-gradient(180deg, rgba(15, 22, 35, 0.98), rgba(10, 15, 24, 0.98)),
        var(--epic-card-bg);
    box-shadow:
        0 24px 48px rgba(0, 0, 0, 0.34),
        inset 0 1px 0 rgba(255, 255, 255, 0.04);
    z-index: 1200;
    max-height: 280px;
    overflow-y: auto;
    -webkit-backdrop-filter: blur(18px);
    backdrop-filter: blur(18px);
}

.enigma-dropdown-option {
    width: 100%;
    border: 0;
    border-radius: 12px;
    background: transparent;
    color: var(--epic-text);
    font-family: 'Inter', sans-serif;
    font-size: 0.95rem;
    font-weight: 600;
    text-align: left;
    padding: 11px 14px;
    cursor: pointer;
    transition: background 0.16s ease, color 0.16s ease, transform 0.16s ease;
}

.enigma-dropdown-option:hover,
.enigma-dropdown-option:focus-visible {
    outline: none;
    background: rgba(78, 132, 224, 0.18);
    color: #f7fbff;
}

.enigma-dropdown-option.selected {
    background: linear-gradient(135deg, rgba(53, 118, 214, 0.9), rgba(77, 140, 237, 0.78));
    color: #ffffff;
}

.enigma-stepper {
    position: relative;
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr) 44px;
    align-items: center;
    gap: 8px;
    padding: 6px;
    isolation: isolate;
}

.enigma-stepper-button {
    position: relative;
    z-index: 3;
    width: 44px;
    min-width: 44px;
    height: 40px;
    border: 1px solid rgba(133, 176, 255, 0.18);
    border-radius: 11px;
    background:
        linear-gradient(180deg, rgba(29, 40, 62, 0.92), rgba(14, 20, 32, 0.92));
    color: var(--epic-text);
    font-size: 1.05rem;
    font-weight: 800;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    pointer-events: auto;
    -webkit-tap-highlight-color: transparent;
    transition: transform 0.16s ease, border-color 0.16s ease, background 0.16s ease, opacity 0.16s ease;
}

.enigma-stepper-button:hover:not(:disabled) {
    transform: translateY(-1px);
    border-color: rgba(143, 192, 255, 0.42);
    background:
        linear-gradient(180deg, rgba(41, 58, 90, 0.98), rgba(17, 25, 40, 0.98));
}

.enigma-stepper-button:disabled,
.enigma-stepper-button.is-disabled {
    opacity: 0.42;
    cursor: default;
}

.enigma-stepper-input {
    min-width: 0;
    width: 100%;
    border: 0;
    background: transparent;
    color: var(--epic-text);
    font-family: 'Inter', sans-serif;
    font-size: 1rem;
    font-weight: 700;
    text-align: center;
    outline: none;
    box-shadow: none;
}

.enigma-stepper-input::placeholder {
    color: rgba(160, 178, 203, 0.56);
    -webkit-text-fill-color: rgba(160, 178, 203, 0.56);
}

.form-label, label {
    display: block;
    margin-bottom: 8px;
    color: var(--epic-text-secondary);
    font-size: 0.9rem;
    font-weight: 500;
}

.form-group, .input-group {
    margin-bottom: 20px;
}

.password-field-wrap {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: stretch;
    gap: 10px;
}

.password-field-wrap .form-control {
    min-width: 0;
}

.password-toggle-button {
    min-width: 88px;
    padding: 0 16px;
    border-radius: 14px;
    border: 1px solid rgba(143, 183, 255, 0.22);
    background: linear-gradient(180deg, rgba(23, 33, 54, 0.98), rgba(15, 21, 34, 0.98));
    color: var(--epic-text);
    font-weight: 700;
    letter-spacing: 0.01em;
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
}

.password-toggle-button:hover {
    transform: translateY(-1px);
    border-color: rgba(143, 183, 255, 0.4);
    background: linear-gradient(180deg, rgba(31, 45, 71, 0.98), rgba(17, 24, 38, 0.98));
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
}

.password-issue-list {
    display: grid;
    gap: 7px;
    margin-top: 10px;
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid rgba(255, 169, 169, 0.24);
    background: rgba(231, 76, 60, 0.08);
}

.password-issue-item {
    display: flex;
    align-items: center;
    gap: 10px;
    color: rgba(255, 210, 210, 0.96);
    font-size: 0.86rem;
    line-height: 1.3;
}

.password-issue-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    border-radius: 999px;
    font-size: 0.7rem;
    font-weight: 700;
    border: 1px solid rgba(255, 165, 165, 0.36);
    background: rgba(193, 65, 65, 0.22);
    color: rgba(255, 219, 219, 0.96);
}


.form-check-input,
.darker-border-checkbox.form-check-input {
    width: 20px;
    height: 20px;
    border: 2px solid var(--epic-border);
    background: var(--epic-surface);
    cursor: pointer;
}

.form-check-input:checked {
    background-color: var(--epic-primary);
    border-color: var(--epic-primary);
}

.form-check-input:focus {
    box-shadow: 0 0 0 3px rgba(0, 120, 242, 0.2);
}

.form-check-label {
    margin-left: 8px;
    color: var(--epic-text);
    cursor: pointer;
}


.card, .panel {
    background: var(--epic-card-bg);
    border-radius: 8px;
    padding: 24px;
    margin: 20px 0;
    border: 1px solid var(--epic-border);
    transition: all 0.3s ease;
}

.card:hover, .panel:hover {
    border-color: var(--epic-primary);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5);
}

.card-title, .card h2 {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--epic-text);
    margin-bottom: 16px;
}

.card-body {
    padding: 0;
    
}


.game-card {
    background: var(--epic-card-bg);
    border-radius: 8px;
    overflow: hidden;
    transition: all 0.3s ease;
    cursor: pointer;
    border: 1px solid transparent;
}

.game-card:hover {
    transform: translateY(-4px);
    border-color: var(--epic-primary);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.6);
}

.game-card-image {
    width: 100%;
    aspect-ratio: 16/9;
    object-fit: cover;
    background: var(--epic-surface);
}

.menu-image-card,
.menu-text-card {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    padding: 0;
    text-align: left;
}

.home-tab-grid {
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    align-items: stretch;
}

.menu-card-media {
    display: flex;
    align-items: center;
    justify-content: center;
    aspect-ratio: 16 / 9;
    padding: 0;
    overflow: hidden;
    background:
        radial-gradient(circle at top left, rgba(67, 132, 255, 0.16), transparent 38%),
        linear-gradient(180deg, rgba(15, 21, 34, 0.98), rgba(11, 15, 24, 0.98));
}

.menu-card-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 0;
}

.menu-card-placeholder {
    background:
        radial-gradient(circle at top left, rgba(67, 132, 255, 0.22), transparent 38%),
        linear-gradient(135deg, rgba(19, 34, 63, 0.98), rgba(10, 14, 24, 0.98));
}

.menu-card-glyph {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 132px;
    min-height: 132px;
    padding: 20px;
    border-radius: 26px;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(143, 183, 255, 0.18);
    color: var(--epic-text);
    font-size: 1.25rem;
    font-weight: 800;
    letter-spacing: 0.02em;
}

.game-card-content {
    padding: 16px;
}

.game-card-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--epic-text);
    margin-bottom: 8px;
}

.game-card-meta {
    font-size: 0.85rem;
    color: var(--epic-text-secondary);
}


.grid {
    display: grid;
    gap: 20px;
}

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

.grid-3 {
    grid-template-columns: repeat(3, 1fr);
}

.grid-4 {
    grid-template-columns: repeat(4, 1fr);
}

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


.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
    margin: 24px 0;
}

.stat-box {
    background: var(--epic-surface);
    border: 1px solid var(--epic-border);
    border-radius: 8px;
    padding: 24px;
    text-align: center;
    transition: all 0.3s ease;
}

.stat-box:hover {
    border-color: var(--epic-primary);
    transform: translateY(-2px);
}

.stat-value {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--epic-primary);
    margin-bottom: 8px;
}

.stat-label {
    font-size: 0.9rem;
    color: var(--epic-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 500;
}


table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    background: var(--epic-card-bg);
    border-radius: 8px;
    overflow: hidden;
}

thead {
    background: var(--epic-surface);
}

th {
    padding: 16px;
    text-align: left;
    color: var(--epic-text-secondary);
    font-size: 0.85rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-bottom: 1px solid var(--epic-border);
}

td {
    padding: 16px;
    color: var(--epic-text);
    font-size: 0.95rem;
    border-bottom: 1px solid var(--epic-border);
}

tbody tr {
    transition: background 0.2s ease;
}

tbody tr:hover {
    background: var(--epic-hover);
}

tbody tr:last-child td {
    border-bottom: none;
}


.badge {
    display: inline-block;
    padding: 4px 12px;
    font-size: 0.8rem;
    font-weight: 600;
    border-radius: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.badge-primary {
    background: rgba(0, 120, 242, 0.2);
    color: var(--epic-primary);
}

.badge-success {
    background: rgba(46, 204, 113, 0.2);
    color: var(--epic-success);
}

.badge-warning {
    background: rgba(243, 156, 18, 0.2);
    color: var(--epic-warning);
}

.badge-danger {
    background: rgba(231, 76, 60, 0.2);
    color: var(--epic-danger);
}


.difficulty-badge {
    display: inline-block;
    padding: 6px 14px;
    font-size: 0.8rem;
    font-weight: 600;
    border-radius: 4px;
    text-transform: uppercase;
}

.difficulty-e {
    background: rgba(46, 204, 113, 0.2);
    color: var(--epic-success);
    border: 1px solid var(--epic-success);
}

.difficulty-m {
    background: rgba(243, 156, 18, 0.2);
    color: var(--epic-warning);
    border: 1px solid var(--epic-warning);
}

.difficulty-h {
    background: rgba(231, 76, 60, 0.2);
    color: var(--epic-danger);
    border: 1px solid var(--epic-danger);
}


.rank-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    font-weight: 700;
    font-size: 0.95rem;
}

.rank-1 {
    background: linear-gradient(135deg, #FFD700, #FFA500);
    color: #000;
}

.rank-2 {
    background: linear-gradient(135deg, #C0C0C0, #808080);
    color: #000;
}

.rank-3 {
    background: linear-gradient(135deg, #CD7F32, #8B4513);
    color: #fff;
}


.alert {
    padding: 16px 20px;
    margin: 16px 0;
    border-radius: 4px;
    border-left: 4px solid;
    animation: slideIn 0.3s ease-out;
}

.alert-success {
    background: rgba(46, 204, 113, 0.1);
    border-color: var(--epic-success);
    color: var(--epic-success);
}

.alert-warning {
    background: rgba(243, 156, 18, 0.1);
    border-color: var(--epic-warning);
    color: var(--epic-warning);
}

.alert-danger {
    background: rgba(231, 76, 60, 0.1);
    border-color: var(--epic-danger);
    color: var(--epic-danger);
}

.alert-info {
    background: rgba(0, 120, 242, 0.1);
    border-color: var(--epic-primary);
    color: var(--epic-primary);
}

.global-notification-stack {
    position: fixed;
    top: 82px;
    right: 20px;
    z-index: 3600;
    width: min(360px, calc(100vw - 24px));
    display: grid;
    gap: 10px;
    pointer-events: none;
}

.global-notification {
    min-height: 42px;
    padding: 10px 12px;
    border-radius: 14px;
    border: 1px solid rgba(147, 197, 255, 0.32);
    background:
        linear-gradient(180deg, rgba(20, 35, 61, 0.94), rgba(12, 20, 35, 0.95));
    color: #e6f3ff;
    font-size: 0.84rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.24);
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: start;
    gap: 10px;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    animation: slideIn 0.22s ease-out;
}

.global-notification-dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    margin-top: 5px;
    background: #7cc7ff;
    box-shadow: 0 0 0 3px rgba(124, 199, 255, 0.2);
}

.global-notification.info {
    border-color: rgba(117, 173, 255, 0.4);
}

.global-notification.info .global-notification-dot {
    background: #7cc7ff;
}

.global-notification.success {
    border-color: rgba(98, 225, 170, 0.42);
}

.global-notification.success .global-notification-dot {
    background: #7ef1ba;
    box-shadow: 0 0 0 3px rgba(126, 241, 186, 0.2);
}

.global-notification.warning {
    border-color: rgba(249, 201, 122, 0.45);
}

.global-notification.warning .global-notification-dot {
    background: #ffd38a;
    box-shadow: 0 0 0 3px rgba(255, 211, 138, 0.2);
}

.global-notification.error {
    border-color: rgba(255, 148, 148, 0.45);
}

.global-notification.error .global-notification-dot {
    background: #ff9a9a;
    box-shadow: 0 0 0 3px rgba(255, 154, 154, 0.2);
}

.valid.modified:not([type=checkbox]) {
    border-color: rgba(116, 176, 255, 0.72);
    box-shadow: 0 0 0 3px rgba(0, 120, 242, 0.2);
}

.invalid {
    border-color: var(--epic-danger);
    box-shadow: 0 0 0 3px rgba(231, 76, 60, 0.2);
}

.validation-message {
    color: var(--epic-danger);
    font-size: 0.85rem;
    margin-top: 6px;
}


.blazor-error-boundary {
    background: var(--epic-danger);
    padding: 20px;
    color: white;
    border-radius: 4px;
    font-weight: 500;
    margin: 20px 0;
}

.blazor-error-boundary::after {
    content: "An error has occurred.";
}


a, .btn-link {
    color: var(--epic-primary);
    text-decoration: none;
    transition: color 0.2s ease;
}

a:hover, .btn-link:hover {
    color: var(--epic-primary-hover);
}


.hero {
    background: var(--epic-surface);
    border-radius: 8px;
    padding: 60px 40px;
    margin-bottom: 32px;
    text-align: center;
    background: linear-gradient(135deg, var(--epic-surface), var(--epic-card-bg));
}

.hero h1 {
    font-size: 3rem;
    font-weight: 800;
    margin-bottom: 16px;
    background: linear-gradient(135deg, var(--epic-primary), #00c3ff);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.form-control option,
.form-select option {
    background: #111722;
    color: #eef5ff;
    font-family: 'Inter', sans-serif;
    font-size: 0.95rem;
    padding: 12px 14px;
    font-weight: 500;
}

.form-control option:checked,
.form-select option:checked {
    background: #2f63c8;
    color: #ffffff;
}

.form-control option:hover,
.form-select option:hover {
    background: #1f355d;
    color: #ffffff;
}

.form-control option:disabled,
.form-select option:disabled {
    color: rgba(239, 245, 255, 0.46);
    width: 100%;
}

.podium-card strong {
    font-size: 1.5rem;
    color: var(--epic-text);
}

.podium-rank {
    font-size: 0.9rem;
    color: var(--epic-text);
}

.hero p {
    font-size: 1.1rem;
    color: var(--epic-text);
    max-width: 600px;
    margin: 0 auto;
}

.enigma-room-hud {
    font-size: 0.85rem;
    color: var(--epic-text-secondary);
}

.enigma-puzzle-status{
    font-size: 0.85rem;
    color: var(--epic-text-secondary);
}
.spinner, .loader {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 3px solid var(--epic-border);
    border-top-color: var(--epic-primary);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}


h1, h2, h3, h4, h5, h6 {
    color: var(--epic-text);
    font-weight: 700;
    margin-bottom: 16px;
}

p {
    color: var(--epic-text);
    font-size: 1rem;
    line-height: 1.6;
    margin-bottom: 16px;
}

h1 { font-size: 2.5rem; }
h2 { font-size: 2rem; }
h3 { font-size: 1.5rem; }
h4 { font-size: 1.25rem; }
h5 { font-size: 1.1rem; }
h6 { font-size: 1rem; }

h1:focus {
    outline: none;
}


::-webkit-scrollbar {
    width: 12px;
}

::-webkit-scrollbar-track {
    background: var(--epic-bg);
}

::-webkit-scrollbar-thumb {
    background: var(--epic-surface);
    border-radius: 6px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--epic-hover);
}


.btn:focus,
.btn:active:focus,
.btn-link.nav-link:focus,
.form-control:focus,
.form-check-input:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(0, 120, 242, 0.2);
}

@media (max-width: 1200px) {
    .grid-4 { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
    .app-header { padding: 12px 16px; }
    .app-header h1 { font-size: 1.25rem; }
    .app-content { padding: 16px; }
    .hero { padding: 40px 24px; }
    .hero h1 { font-size: 2rem; }
    .grid-2,
    .grid-3,
    .grid-4 { grid-template-columns: 1fr; }
    .stats-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
    .stats-grid { grid-template-columns: 1fr; }
    .btn { padding: 10px 20px; font-size: 0.9rem; }
}


.friend-list {
    background: var(--epic-card-bg);
    border-radius: 8px;
    padding: 16px;
    max-height: 600px;
    overflow-y: auto;
}

.friend-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    border-radius: 4px;
    transition: background 0.2s ease;
}

.friend-item:hover {
    background: var(--epic-hover);
}

.friend-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--epic-surface);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    position: relative;
}

.friend-status {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    border: 2px solid var(--epic-card-bg);
}

.friend-status.online { background: var(--epic-success); }
.friend-status.away { background: var(--epic-warning); }
.friend-status.offline { background: var(--epic-text-dim); }


.shop-item {
    background: var(--epic-card-bg);
    border: 1px solid var(--epic-border);
    border-radius: 8px;
    padding: 20px;
    transition: all 0.3s ease;
}

.shop-item:hover {
    border-color: var(--epic-primary);
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.6);
}

.shop-item-price {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--epic-primary);
    margin: 12px 0;
}

.currency {
    color: var(--epic-warning);
    font-weight: 600;
}

.btn-secondary {
    background: var(--epic-elevated);
    color: var(--epic-text);
}

.btn-secondary:hover {
    background: var(--epic-hover);
}

.enigma-end-page {
    width: 100%;
}

.enigma-game-page {
    width: 100vw;
    min-height: 100vh;
    max-width: none;
    margin-inline: calc(50% - 50vw);
    padding: 4px;
    display: grid;
    place-items: center;
    background: #03070d;
    overflow: hidden;
}

.enigma-game-shell {
    width: 100%;
    min-height: calc(100vh - 8px);
    display: grid;
    place-items: center;
}

.enigma-kicker {
    display: inline-block;
    margin-bottom: 8px;
    color: var(--epic-primary);
    font-size: 0.8rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 700;
}

.enigma-room-meta-grid,
.enigma-stat-grid,
.enigma-end-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(120px, 1fr));
    gap: 14px;
}

.enigma-room-meta-grid div,
.enigma-stat-grid div,
.enigma-end-grid div {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--epic-border);
    border-radius: 10px;
    padding: 14px;
}

.enigma-room-meta-grid span,
.enigma-stat-grid span,
.enigma-end-grid span {
    display: block;
    margin-bottom: 6px;
    color: var(--epic-text-dim);
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.enigma-room-meta-grid strong,
.enigma-stat-grid strong,
.enigma-end-grid strong {
    color: var(--epic-text);
    font-size: 1rem;
}

.enigma-game-subline {
    max-width: 52ch;
    margin: 0;
    color: var(--epic-text-secondary);
    line-height: 1.45;
}

.enigma-room-stage-wrap {
    width: min(calc(100vw - 8px), calc((100vh - 8px) * 16 / 9));
    max-width: 100vw;
    overflow: hidden;
    padding: 0;
    margin: 0;
    border: none;
    border-radius: 0;
    background: none;
    box-shadow: none;
}

.enigma-room-stage {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    min-height: 0;
    border-radius: 0;
    overflow: hidden;
    outline: none;
    background: #09111a;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.05);
}

.enigma-room-stage-base,
.enigma-room-stage-art,
.enigma-room-stage-tint {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.enigma-room-stage-base {
    background:
        radial-gradient(circle at 50% 78%, rgba(64, 96, 118, 0.05), rgba(0, 0, 0, 0) 26%),
        linear-gradient(145deg, var(--room-stage-tint-start, #293140) 0%, var(--room-stage-tint-end, #151b26) 100%);
}

.enigma-room-stage-art {
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    opacity: 0.66;
    filter: saturate(0.56) brightness(0.2) contrast(1.14);
    transform: scale(1.01);
}

.enigma-room-stage-tint {
    background:
        linear-gradient(180deg, rgba(1, 3, 6, 0.58) 0%, rgba(1, 2, 4, 0.86) 100%),
        radial-gradient(circle at 50% 84%, rgba(80, 116, 140, 0.028), rgba(0, 0, 0, 0) 18%),
        radial-gradient(circle at 12% 18%, rgba(112, 150, 172, 0.014), rgba(0, 0, 0, 0) 15%);
}

.enigma-room-stage::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.03), transparent 18%, transparent 82%, rgba(0, 0, 0, 0.18));
    pointer-events: none;
}

.enigma-radar-darkness,
.enigma-radar-wave-stack {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.enigma-radar-darkness {
    z-index: 7;
    opacity: 0.999;
    background:
        radial-gradient(
            circle at var(--radar-x, 50%) var(--radar-y, 50%),
            rgba(122, 184, 214, calc((0.006 + (var(--radar-pulse-strength, 0) * 0.014)) * (0.68 + (var(--radar-wall-proximity, 1) * 0.2)))) 0%,
            rgba(56, 92, 112, calc((0.01 + (var(--radar-pulse-strength, 0) * 0.015)) * (0.72 + (var(--radar-wall-proximity, 1) * 0.16)))) calc(var(--radar-core-radius, 14%) * 0.46),
            rgba(10, 16, 22, 0.32) calc(var(--radar-core-radius, 14%) * 0.72),
            rgba(2, 5, 8, 0.92) calc(var(--radar-detail-radius, 32%) * 0.82),
            rgba(1, 2, 5, 0.982) calc(var(--radar-outer-radius, 56%) * 0.98),
            rgba(0, 0, 0, 0.992) 100%),
        radial-gradient(
            circle at var(--radar-x, 50%) var(--radar-y, 50%),
            rgba(210, 232, 255, 0) calc(var(--radar-detail-radius, 32%) * 0.93),
            rgba(208, 228, 255, calc(0.008 + (var(--radar-pulse-strength, 0) * 0.02))) calc(var(--radar-detail-radius, 32%) * 0.955),
            rgba(208, 228, 255, calc(0.024 + (var(--radar-pulse-strength, 0) * 0.032))) calc(var(--radar-detail-radius, 32%) * 0.972),
            rgba(208, 228, 255, 0) calc(var(--radar-detail-radius, 32%) * 0.992),
            rgba(208, 228, 255, calc(0.006 + (var(--radar-pulse-strength, 0) * 0.014))) calc(var(--radar-outer-radius, 56%) * 0.986),
            rgba(208, 228, 255, 0) calc(var(--radar-outer-radius, 56%) * 1.008));
    transition: background 90ms linear, opacity 180ms ease;
}

.enigma-radar-darkness::before {
    content: "";
    position: absolute;
    inset: 0;
    opacity: calc(0.014 + (var(--radar-interference, 0) * 0.06));
    background:
        repeating-linear-gradient(
            180deg,
            rgba(126, 186, 255, 0.04) 0px,
            rgba(126, 186, 255, 0.04) 1px,
            rgba(0, 0, 0, 0) 2px,
            rgba(0, 0, 0, 0) 4px);
    mix-blend-mode: screen;
}

.enigma-radar-darkness.interference {
    animation: enigmaRadarInterference 1.9s steps(2, end) infinite;
}

.enigma-radar-wave-stack {
    z-index: 7;
    overflow: hidden;
    background: none;
}

.enigma-radar-wave-stack::before {
    content: "";
    position: absolute;
    left: var(--radar-x, 50%);
    top: var(--radar-y, 50%);
    width: calc(var(--radar-core-radius, 14%) * 2.1);
    aspect-ratio: 1 / 1;
    border-radius: 999px;
    background:
        radial-gradient(circle,
            rgba(208, 228, 255, calc(0.2 + (var(--radar-pulse-strength, 0) * 0.06))) 0%,
            rgba(148, 182, 212, calc(0.1 + (var(--radar-pulse-strength, 0) * 0.04))) 36%,
            rgba(82, 122, 150, 0.08) 58%,
            rgba(0, 0, 0, 0) 76%);
    transform: translate(-50%, -50%);
    opacity: 0.82;
    mix-blend-mode: screen;
    filter: blur(1px);
}

.enigma-radar-ring {
    position: absolute;
    left: var(--radar-x, 50%);
    top: var(--radar-y, 50%);
    width: calc(var(--radar-core-radius, 14%) * 1.88);
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    transform: translate(-50%, -50%) translateZ(0) scale(0.78);
    opacity: 0;
    mix-blend-mode: screen;
    will-change: transform, opacity;
    backface-visibility: hidden;
    animation-name: enigmaRadarRingExpand;
    animation-duration: var(--radar-cycle, 5.6s);
    animation-timing-function: linear;
    animation-iteration-count: infinite;
    animation-fill-mode: both;
}

.enigma-radar-ring.primary {
    border: 2px solid rgba(212, 228, 255, 0.8);
    box-shadow:
        0 0 14px rgba(204, 228, 255, 0.2),
        inset 0 0 10px rgba(204, 228, 255, 0.08);
}

.enigma-radar-ring.ripple {
    border: 1px solid rgba(204, 224, 255, 0.3);
    box-shadow: 0 0 8px rgba(204, 224, 255, 0.08);
}

.enigma-radar-ring.primary.ring-a {
    animation-delay: calc(var(--radar-cycle-offset, 0s));
}

.enigma-radar-ring.primary.ring-b {
    animation-delay: calc(var(--radar-cycle-offset, 0s) + var(--radar-primary-spacing, 2.8s));
}

.enigma-radar-ring.ripple.ripple-a {
    animation-delay: calc(var(--radar-cycle-offset, 0s) + var(--radar-secondary-spacing, 0.933s));
}

.enigma-radar-ring.ripple.ripple-b {
    animation-delay: calc(var(--radar-cycle-offset, 0s) + (var(--radar-secondary-spacing, 0.933s) * 2));
}

.enigma-radar-ring.ripple.ripple-c {
    animation-delay: calc(var(--radar-cycle-offset, 0s) + var(--radar-primary-spacing, 2.8s) + var(--radar-secondary-spacing, 0.933s));
}

.enigma-radar-ring.ripple.ripple-d {
    animation-delay: calc(var(--radar-cycle-offset, 0s) + var(--radar-primary-spacing, 2.8s) + (var(--radar-secondary-spacing, 0.933s) * 2));
}

.enigma-radar-wave-stack.interference::before {
    background:
        radial-gradient(circle,
            rgba(244, 183, 194, calc(0.22 + (var(--radar-pulse-strength, 0) * 0.06))) 0%,
            rgba(184, 104, 126, calc(0.1 + (var(--radar-pulse-strength, 0) * 0.04))) 40%,
            rgba(0, 0, 0, 0) 76%);
}

.enigma-radar-wave-stack.interference .enigma-radar-ring.primary {
    border-color: rgba(244, 183, 194, 0.84);
    box-shadow:
        0 0 16px rgba(241, 113, 130, 0.24),
        inset 0 0 10px rgba(241, 113, 130, 0.08);
}

.enigma-radar-wave-stack.interference .enigma-radar-ring.ripple {
    border-color: rgba(244, 183, 194, 0.36);
    box-shadow: 0 0 10px rgba(241, 113, 130, 0.12);
}

@keyframes enigmaRadarRingExpand {
    0% {
        transform: translate(-50%, -50%) translateZ(0) scale(0.78);
        opacity: 0;
    }
    4% {
        opacity: calc(0.58 + (var(--radar-pulse-strength, 0) * 0.12));
    }
    28% {
        opacity: calc(0.2 + (var(--radar-pulse-strength, 0) * 0.06));
    }
    100% {
        transform: translate(-50%, -50%) translateZ(0) scale(var(--radar-pulse-scale, 3.1));
        opacity: 0;
    }
}

@keyframes enigmaRadarInterference {
    0%,
    100% {
        filter: saturate(1) contrast(1);
        opacity: 0.96;
    }
    40% {
        filter: saturate(1.18) contrast(1.08);
        opacity: 0.99;
    }
    62% {
        filter: saturate(0.94) contrast(0.96);
        opacity: 0.92;
    }
}

.enigma-wall,
.enigma-wall.door-glow {
    position: absolute;
    z-index: 6;
}

.enigma-wall {
    background: linear-gradient(180deg, rgba(6, 12, 20, 1), rgba(18, 30, 46, 1));
    box-shadow:
        inset 0 0 0 1px rgba(196, 220, 255, 0.08),
        0 0 0 1px rgba(22, 37, 58, 0.58);
}

.enigma-wall.door-glow {
    background: rgba(87, 195, 255, 0.16);
    box-shadow: 0 0 18px rgba(87, 195, 255, 0.22);
}

.enigma-room-stage .enigma-wall,
.enigma-room-stage .enigma-plate,
.enigma-room-stage .enigma-zone,
.enigma-room-stage .enigma-reward-pickup,
.enigma-room-stage .enigma-black-hole,
.enigma-room-stage .enigma-phase-node,
.enigma-room-stage .enigma-harmonic-node,
.enigma-room-stage .enigma-path-cell,
.enigma-room-stage .enigma-weight-pad,
.enigma-room-stage .enigma-weight-block,
.enigma-room-stage .enigma-word-tile,
.enigma-room-stage .enigma-descriptor-tile,
.enigma-room-stage .enigma-coop-stage-target,
.enigma-room-stage .enigma-knot-line,
.enigma-room-stage .enigma-world-interactable {
    --radar-signal-safe: clamp(0.06, var(--radar-signal, 1), 1);
    opacity: calc(0.05 + (var(--radar-signal-safe) * 0.95));
    filter: brightness(calc(0.3 + (var(--radar-signal-safe) * 0.8))) saturate(calc(0.14 + (var(--radar-signal-safe) * 0.9)));
    transition: opacity 120ms linear, filter 140ms linear, box-shadow 140ms linear, border-color 140ms linear;
}

.enigma-room-stage .radar-silhouette {
    text-shadow: none;
}

.enigma-room-stage .radar-core {
    filter: brightness(1.08) saturate(1.06);
}

.enigma-room-stage .enigma-wall {
    opacity: calc(0.9 + (var(--radar-signal-safe) * 0.1));
    filter: brightness(calc(0.46 + (var(--radar-signal-safe) * 0.86))) saturate(calc(0.3 + (var(--radar-signal-safe) * 0.78)));
}

.enigma-room-stage .enigma-wall.door-glow {
    opacity: calc(0.5 + (var(--radar-signal-safe) * 0.42));
    filter: brightness(calc(0.48 + (var(--radar-signal-safe) * 0.82))) saturate(calc(0.36 + (var(--radar-signal-safe) * 0.84)));
}

.enigma-plate,
.enigma-zone,
.enigma-reward-pickup,
.enigma-black-hole,
.enigma-player {
    position: absolute;
}

.enigma-plate,
.enigma-zone {
    z-index: 1;
    border-radius: 18px;
    display: grid;
    place-items: center;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.9);
}

.enigma-plate {
    background: radial-gradient(circle, rgba(67, 163, 114, 0.8), rgba(22, 58, 42, 0.9));
    box-shadow: 0 0 20px rgba(76, 196, 134, 0.25);
    animation: enigmaPlateHum 2.4s ease-in-out infinite;
}

.enigma-zone {
    background: rgba(255, 197, 79, 0.16);
    border: 2px solid rgba(255, 197, 79, 0.4);
    transition: background 0.22s ease, border-color 0.22s ease, transform 0.22s ease, box-shadow 0.22s ease;
}

.enigma-zone.current {
    background: rgba(0, 120, 242, 0.2);
    border-color: rgba(0, 120, 242, 0.45);
    animation: enigmaCurrentZonePulse 1.35s ease-in-out infinite;
}

.enigma-zone.complete {
    background: rgba(46, 204, 113, 0.22);
    border-color: rgba(46, 204, 113, 0.45);
    box-shadow: 0 0 18px rgba(74, 201, 125, 0.16);
}

.enigma-world-interactable {
    --node-accent-rgb: 148, 206, 255;
    position: absolute;
    z-index: 2;
    display: grid;
    place-items: center;
    border-radius: 16px;
    border: 1px solid rgba(var(--node-accent-rgb), 0.52);
    background:
        radial-gradient(circle at 26% 20%, rgba(var(--node-accent-rgb), 0.3), rgba(16, 28, 44, 0.62) 58%),
        linear-gradient(165deg, rgba(12, 21, 34, 0.84), rgba(7, 12, 21, 0.82));
    color: rgba(236, 244, 255, 0.95);
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    box-shadow:
        inset 0 0 0 1px rgba(210, 231, 255, 0.08),
        0 12px 30px rgba(0, 0, 0, 0.42);
    overflow: hidden;
    isolation: isolate;
    transition: transform 0.14s ease, border-color 0.14s ease, box-shadow 0.14s ease, background 0.14s ease, filter 0.14s ease;
}

.enigma-world-interactable::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(160deg, rgba(var(--node-accent-rgb), 0.26), transparent 58%);
    opacity: 0.3;
    pointer-events: none;
}

.enigma-world-interactable::after {
    content: "";
    position: absolute;
    inset: 2px;
    border-radius: calc(16px - 2px);
    border: 1px solid rgba(var(--node-accent-rgb), 0.24);
    opacity: 0.9;
    pointer-events: none;
}

.enigma-world-interactable.color-coded:not(.cargo-link) {
    border-color: rgba(var(--node-accent-rgb), 0.74);
    background:
        radial-gradient(circle at 24% 18%, rgba(var(--node-accent-rgb), 0.42), rgba(16, 28, 44, 0.66) 58%),
        linear-gradient(165deg, rgba(12, 21, 34, 0.86), rgba(7, 12, 21, 0.84));
    box-shadow:
        inset 0 0 0 1px rgba(var(--node-accent-rgb), 0.2),
        0 12px 30px rgba(0, 0, 0, 0.42),
        0 0 18px rgba(var(--node-accent-rgb), 0.2);
}

.enigma-world-interactable.color-coded:not(.cargo-link)::before {
    opacity: 0.44;
}

.enigma-world-interactable.color-coded:not(.cargo-link)::after {
    border-color: rgba(var(--node-accent-rgb), 0.34);
}

.enigma-world-interactable span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 24px;
    min-height: 24px;
    padding: 0 7px;
    border-radius: 999px;
    background: rgba(2, 10, 20, 0.56);
    border: 1px solid rgba(var(--node-accent-rgb), 0.42);
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.44);
    line-height: 1;
    z-index: 1;
}

.enigma-world-interactable:hover,
.enigma-world-interactable:focus-visible {
    transform: translateY(-1px) scale(1.02);
    border-color: rgba(158, 216, 255, 0.82);
    box-shadow:
        inset 0 0 0 1px rgba(193, 230, 255, 0.2),
        0 16px 34px rgba(0, 0, 0, 0.45),
        0 0 26px rgba(108, 186, 255, 0.3);
    outline: none;
}

.enigma-world-interactable.nearest {
    border-color: rgba(var(--node-accent-rgb), 0.94);
    box-shadow:
        inset 0 0 0 1px rgba(var(--node-accent-rgb), 0.26),
        0 0 0 1px rgba(var(--node-accent-rgb), 0.72),
        0 0 36px rgba(var(--node-accent-rgb), 0.4);
    animation: enigmaInteractablePulse 1.2s ease-in-out infinite;
}

.enigma-world-interactable.color-coded.nearest:not(.cargo-link) {
    border-color: rgba(var(--node-accent-rgb), 0.98);
    box-shadow:
        inset 0 0 0 1px rgba(var(--node-accent-rgb), 0.34),
        0 0 0 1px rgba(var(--node-accent-rgb), 0.78),
        0 0 42px rgba(var(--node-accent-rgb), 0.44);
}

.enigma-world-interactable.disabled {
    opacity: 0.45;
    cursor: not-allowed;
    filter: saturate(0.45);
    pointer-events: none;
}

.enigma-world-interactable.state-active {
    box-shadow: 0 0 0 1px rgba(123, 194, 255, 0.42), 0 10px 24px rgba(0, 0, 0, 0.35);
}

.enigma-world-interactable.state-failed {
    border-color: rgba(255, 126, 126, 0.7);
    box-shadow: 0 0 0 1px rgba(255, 126, 126, 0.5), 0 10px 24px rgba(0, 0, 0, 0.35);
}

.enigma-world-interactable.state-resetting,
.enigma-world-interactable.state-cooldown {
    filter: saturate(0.35) brightness(0.8);
}

.enigma-world-interactable.decorative {
    pointer-events: none;
}

.enigma-world-interactable.cargo-link {
    z-index: 1;
    border-radius: 999px;
    border: none;
    box-shadow: none;
    background: rgba(var(--node-accent-rgb), 0.09);
    opacity: 0.18;
    mix-blend-mode: screen;
}

.enigma-world-interactable.cargo-link::before,
.enigma-world-interactable.cargo-link::after {
    display: none;
}

.enigma-world-interactable.cargo-link.idle {
    background: rgba(var(--node-accent-rgb), 0.04);
    opacity: 0.08;
}

.enigma-world-interactable.cargo-link.active {
    background: rgba(var(--node-accent-rgb), 0.2);
    box-shadow: 0 0 4px rgba(var(--node-accent-rgb), 0.18);
    opacity: 0.32;
}

.enigma-world-interactable.cargo-link.locked {
    background: rgba(130, 236, 191, 0.14);
    box-shadow: 0 0 3px rgba(112, 235, 184, 0.12);
    opacity: 0.28;
}

.enigma-world-interactable.cargo-link.layer-bridge.idle {
    background: rgba(196, 166, 255, 0.03);
}

.enigma-world-interactable.cargo-link.layer-bridge.active {
    background: rgba(196, 166, 255, 0.16);
    box-shadow: 0 0 4px rgba(182, 147, 255, 0.16);
}

.enigma-world-interactable.cargo-link.layer-bridge.locked {
    background: rgba(174, 244, 228, 0.12);
    box-shadow: 0 0 3px rgba(139, 233, 207, 0.12);
}

.enigma-room-stage .enigma-world-interactable.cargo-link {
    --radar-signal: 1 !important;
    filter: none !important;
}

@keyframes enigmaInteractablePulse {
    0% {
        box-shadow:
            inset 0 0 0 1px rgba(199, 238, 255, 0.24),
            0 0 0 1px rgba(188, 234, 255, 0.65),
            0 0 28px rgba(98, 186, 255, 0.3);
    }
    50% {
        box-shadow:
            inset 0 0 0 1px rgba(211, 244, 255, 0.3),
            0 0 0 1px rgba(203, 242, 255, 0.84),
            0 0 42px rgba(116, 200, 255, 0.5);
    }
    100% {
        box-shadow:
            inset 0 0 0 1px rgba(199, 238, 255, 0.24),
            0 0 0 1px rgba(188, 234, 255, 0.65),
            0 0 28px rgba(98, 186, 255, 0.3);
    }
}

.enigma-world-interactable.signal-relay {
    border-radius: 18px;
    background: rgba(20, 40, 62, 0.62);
}

.enigma-world-interactable.signal-relay.required {
    border-color: rgba(113, 195, 255, 0.6);
}

.enigma-world-interactable.signal-relay.active {
    background: radial-gradient(circle, rgba(74, 176, 255, 0.45), rgba(22, 58, 97, 0.74));
}

.enigma-world-interactable.signal-relay.overload {
    box-shadow: 0 0 0 1px rgba(255, 134, 147, 0.46), 0 14px 26px rgba(0, 0, 0, 0.36);
}

.enigma-world-interactable.signal-relay.linked::before {
    content: "";
    width: 18px;
    height: 3px;
    border-radius: 999px;
    background: rgba(180, 220, 255, 0.4);
}

.enigma-world-interactable.echo-pad {
    border-radius: 22px;
    background: rgba(23, 35, 52, 0.6);
}

.enigma-world-interactable.echo-pad.reveal {
    background: radial-gradient(circle, rgba(104, 236, 192, 0.5), rgba(14, 72, 57, 0.8));
    border-color: rgba(139, 255, 221, 0.8);
}

.enigma-world-interactable.echo-pad.locked {
    background: rgba(67, 136, 204, 0.42);
}

.enigma-world-interactable.echo-pad.echo-core {
    border-radius: 999px;
    background: radial-gradient(circle, rgba(120, 198, 255, 0.54), rgba(16, 52, 80, 0.78));
    border-color: rgba(172, 230, 255, 0.82);
}

.enigma-world-interactable.duallayer-toggle {
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(94, 117, 255, 0.54), rgba(155, 79, 255, 0.48));
}

.enigma-world-interactable.duallayer-node.alpha {
    background: rgba(58, 116, 196, 0.56);
}

.enigma-world-interactable.duallayer-node.beta {
    background: rgba(110, 72, 195, 0.56);
}

.enigma-world-interactable.duallayer-node.target {
    box-shadow: 0 0 0 1px rgba(171, 230, 255, 0.72), 0 0 20px rgba(110, 191, 255, 0.3);
}

.enigma-world-interactable.behavior-terminal {
    border-radius: 999px;
    min-height: 52px;
    background: rgba(18, 25, 37, 0.7);
}

.enigma-world-interactable.behavior-terminal.left::after,
.enigma-world-interactable.behavior-terminal.center::after,
.enigma-world-interactable.behavior-terminal.right::after {
    content: "";
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: rgba(213, 229, 255, 0.85);
}

.enigma-world-interactable.recursive-anchor {
    border-radius: 18px;
    background: rgba(53, 70, 94, 0.6);
}

.enigma-world-interactable.recursive-anchor.locked {
    background: rgba(68, 143, 110, 0.48);
}

.enigma-world-interactable.recursive-anchor.target {
    border-color: rgba(255, 215, 137, 0.82);
    box-shadow: 0 0 0 1px rgba(255, 219, 161, 0.5), 0 0 18px rgba(255, 198, 111, 0.2);
}

.enigma-world-interactable.living-grid-cell {
    border-radius: 10px;
    background:
        linear-gradient(165deg, rgba(11, 18, 30, 0.9), rgba(6, 11, 20, 0.86)),
        repeating-linear-gradient(90deg, rgba(137, 177, 230, 0.08) 0 2px, transparent 2px 9px);
    border-color: rgba(155, 198, 255, 0.28);
}

.enigma-world-interactable.living-grid-cell.target {
    box-shadow:
        inset 0 0 0 1px rgba(146, 202, 255, 0.26),
        0 8px 22px rgba(0, 0, 0, 0.34);
    background-image:
        linear-gradient(165deg, rgba(11, 18, 30, 0.9), rgba(6, 11, 20, 0.86)),
        repeating-linear-gradient(90deg, rgba(137, 177, 230, 0.1) 0 2px, transparent 2px 9px),
        repeating-linear-gradient(0deg, rgba(137, 177, 230, 0.07) 0 2px, transparent 2px 9px);
}

.enigma-world-interactable.living-grid-cell.needed {
    border-color: rgba(255, 212, 138, 0.72);
    box-shadow:
        inset 0 0 0 1px rgba(255, 232, 179, 0.32),
        0 0 26px rgba(255, 195, 96, 0.26),
        0 10px 24px rgba(0, 0, 0, 0.4);
    animation: enigmaGridNeededPulse 1.05s ease-in-out infinite;
}

.enigma-world-interactable.living-grid-cell.active {
    background:
        radial-gradient(circle at 50% 46%, rgba(108, 210, 255, 0.54), rgba(22, 72, 120, 0.72)),
        linear-gradient(165deg, rgba(16, 33, 52, 0.86), rgba(8, 16, 28, 0.84));
}

.enigma-world-interactable.living-grid-cell.excess {
    border-color: rgba(255, 138, 138, 0.66);
    box-shadow:
        inset 0 0 0 1px rgba(255, 187, 187, 0.2),
        0 0 20px rgba(255, 109, 109, 0.2),
        0 10px 24px rgba(0, 0, 0, 0.4);
    background-image:
        linear-gradient(165deg, rgba(30, 13, 13, 0.88), rgba(16, 8, 9, 0.84)),
        repeating-linear-gradient(45deg, rgba(255, 138, 138, 0.16) 0 4px, rgba(0, 0, 0, 0) 4px 10px);
}

.enigma-world-interactable.living-grid-cell.matched {
    border-color: rgba(121, 235, 188, 0.78);
    box-shadow:
        inset 0 0 0 1px rgba(189, 255, 228, 0.24),
        0 0 22px rgba(119, 238, 188, 0.26),
        0 10px 24px rgba(0, 0, 0, 0.36);
    background-image:
        radial-gradient(circle at 50% 50%, rgba(125, 244, 201, 0.24), rgba(35, 77, 61, 0.2)),
        linear-gradient(165deg, rgba(10, 26, 21, 0.88), rgba(7, 17, 14, 0.84));
}

.enigma-room-stage .enigma-world-interactable.living-grid-cell.target {
    --radar-signal: 0.78 !important;
    opacity: 0.92 !important;
    filter: brightness(1.02) saturate(1.08) !important;
}

.enigma-room-stage .enigma-world-interactable.living-grid-cell.needed {
    --radar-signal: 0.94 !important;
    opacity: 0.98 !important;
    filter: brightness(1.14) saturate(1.2) !important;
}

.enigma-room-stage .enigma-world-interactable.living-grid-cell.excess {
    --radar-signal: 0.84 !important;
    opacity: 0.96 !important;
    filter: brightness(1.08) saturate(1.14) !important;
}

@keyframes enigmaGridNeededPulse {
    0% {
        box-shadow:
            inset 0 0 0 1px rgba(255, 232, 179, 0.26),
            0 0 18px rgba(255, 195, 96, 0.2),
            0 10px 24px rgba(0, 0, 0, 0.38);
    }
    50% {
        box-shadow:
            inset 0 0 0 1px rgba(255, 238, 194, 0.36),
            0 0 32px rgba(255, 208, 126, 0.34),
            0 12px 28px rgba(0, 0, 0, 0.42);
    }
    100% {
        box-shadow:
            inset 0 0 0 1px rgba(255, 232, 179, 0.26),
            0 0 18px rgba(255, 195, 96, 0.2),
            0 10px 24px rgba(0, 0, 0, 0.38);
    }
}

.enigma-world-interactable.symbol-node {
    border-radius: 999px;
    font-size: 0.92rem;
}

.enigma-world-interactable.symbol-node.sigma {
    background: rgba(70, 125, 212, 0.62);
}

.enigma-world-interactable.symbol-node.delta {
    background: rgba(112, 91, 212, 0.62);
}

.enigma-world-interactable.symbol-node.lambda {
    background: rgba(67, 172, 191, 0.62);
}

.enigma-world-interactable.symbol-node.omega {
    background: rgba(176, 100, 194, 0.62);
}

.enigma-world-interactable.time-gate {
    border-radius: 14px;
    background: rgba(30, 44, 63, 0.68);
}

.enigma-world-interactable.time-gate.open {
    background: rgba(101, 190, 255, 0.5);
}

.enigma-world-interactable.time-gate.locked {
    border-color: rgba(131, 243, 194, 0.72);
}

.enigma-world-interactable.false-terminal {
    border-radius: 16px;
    background: rgba(35, 39, 53, 0.72);
}

.enigma-world-interactable.false-terminal.primed {
    box-shadow: 0 0 0 1px rgba(255, 212, 152, 0.6), 0 0 22px rgba(255, 198, 116, 0.24);
}

.enigma-world-interactable.false-terminal.decoy {
    border-color: rgba(172, 136, 255, 0.64);
}

.enigma-world-interactable.heat-control,
.enigma-world-interactable.pressure-control {
    border-radius: 999px;
    font-size: 0.88rem;
}

.enigma-world-interactable.heat-control {
    background: rgba(189, 99, 74, 0.62);
}

.enigma-world-interactable.pressure-control {
    background: rgba(84, 124, 196, 0.62);
}

.enigma-world-interactable.hidden-rule-tile {
    border-radius: 10px;
    background: rgba(17, 25, 38, 0.76);
    font-size: 0.68rem;
}

.enigma-world-interactable.hidden-rule-tile.confirmed {
    border-color: rgba(122, 224, 181, 0.72);
}

.enigma-world-interactable.cargo-item {
    border-radius: 18px;
    background:
        radial-gradient(circle at 30% 24%, rgba(170, 212, 255, 0.2), rgba(16, 26, 41, 0.86) 60%),
        linear-gradient(170deg, rgba(10, 18, 30, 0.94), rgba(7, 12, 20, 0.9));
}

.enigma-world-interactable.cargo-item::after {
    border-radius: 14px;
}

.enigma-world-interactable.cargo-item.carried {
    border-color: rgba(255, 218, 144, 0.7);
    box-shadow:
        inset 0 0 0 1px rgba(255, 227, 184, 0.24),
        0 0 0 1px rgba(255, 211, 133, 0.5),
        0 0 26px rgba(255, 189, 90, 0.34);
}

.enigma-world-interactable.cargo-item.delivered {
    border-color: rgba(126, 233, 187, 0.76);
    background:
        radial-gradient(circle at 30% 24%, rgba(154, 255, 214, 0.24), rgba(12, 30, 24, 0.88) 62%),
        linear-gradient(170deg, rgba(8, 24, 20, 0.94), rgba(7, 13, 12, 0.9));
}

.enigma-world-interactable.cargo-item.reveal {
    border-color: rgba(150, 236, 255, 0.84);
    animation: enigmaCargoRevealPulse 0.88s ease-in-out infinite;
}

@keyframes enigmaCargoRevealPulse {
    0% {
        box-shadow: 0 0 0 1px rgba(160, 238, 255, 0.38), 0 0 18px rgba(106, 206, 255, 0.26);
    }
    50% {
        box-shadow: 0 0 0 1px rgba(180, 244, 255, 0.66), 0 0 32px rgba(126, 220, 255, 0.42);
    }
    100% {
        box-shadow: 0 0 0 1px rgba(160, 238, 255, 0.38), 0 0 18px rgba(106, 206, 255, 0.26);
    }
}

.enigma-world-interactable.cargo-socket {
    border-radius: 14px;
    border-style: dashed;
    border-width: 2px;
    background:
        radial-gradient(circle at center, rgba(96, 140, 211, 0.14), rgba(14, 21, 32, 0.86) 66%),
        linear-gradient(180deg, rgba(10, 16, 27, 0.9), rgba(6, 11, 18, 0.92));
}

.enigma-world-interactable.cargo-socket.target {
    border-color: rgba(172, 230, 255, 0.9);
    box-shadow:
        inset 0 0 0 1px rgba(211, 241, 255, 0.22),
        0 0 0 1px rgba(170, 231, 255, 0.56),
        0 0 30px rgba(109, 201, 255, 0.3);
}

.enigma-world-interactable.cargo-socket.locked {
    border-style: solid;
    border-color: rgba(118, 232, 184, 0.78);
    background:
        radial-gradient(circle at center, rgba(104, 235, 186, 0.2), rgba(11, 32, 24, 0.9) 66%),
        linear-gradient(180deg, rgba(9, 24, 21, 0.9), rgba(5, 14, 12, 0.92));
}

.enigma-world-interactable.cargo-socket.decoy {
    border-color: rgba(196, 149, 255, 0.72);
    background:
        radial-gradient(circle at center, rgba(162, 115, 255, 0.18), rgba(24, 14, 34, 0.9) 66%),
        linear-gradient(180deg, rgba(18, 12, 29, 0.9), rgba(10, 8, 17, 0.92));
}

.enigma-world-interactable.cargo-socket.open {
    animation: enigmaSocketOpenPulse 0.96s ease-in-out infinite;
}

@keyframes enigmaSocketOpenPulse {
    0% {
        box-shadow: 0 0 0 1px rgba(171, 232, 255, 0.44), 0 0 18px rgba(88, 185, 255, 0.2);
    }
    50% {
        box-shadow: 0 0 0 1px rgba(195, 241, 255, 0.72), 0 0 34px rgba(124, 208, 255, 0.38);
    }
    100% {
        box-shadow: 0 0 0 1px rgba(171, 232, 255, 0.44), 0 0 18px rgba(88, 185, 255, 0.2);
    }
}

.enigma-world-interactable.cargo-replay {
    border-radius: 999px;
    background: linear-gradient(140deg, rgba(90, 125, 245, 0.62), rgba(64, 92, 196, 0.48));
}

.enigma-world-interactable.cargo-layer-toggle {
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(92, 119, 255, 0.56), rgba(170, 90, 255, 0.46));
}

.enigma-world-interactable.layer-alpha {
    background:
        radial-gradient(circle at 30% 24%, rgba(120, 186, 255, 0.24), rgba(16, 38, 66, 0.86) 60%),
        linear-gradient(170deg, rgba(12, 24, 42, 0.94), rgba(8, 14, 24, 0.9));
}

.enigma-world-interactable.layer-beta {
    background:
        radial-gradient(circle at 30% 24%, rgba(186, 128, 255, 0.22), rgba(36, 16, 62, 0.86) 60%),
        linear-gradient(170deg, rgba(20, 12, 36, 0.94), rgba(10, 8, 21, 0.9));
}

.enigma-world-interactable.canister-item {
    border-radius: 20px;
    font-size: 0.78rem;
}

.enigma-world-interactable.canister-item.heatplus,
.enigma-world-interactable.canister-item.heatminus {
    background:
        radial-gradient(circle at 30% 24%, rgba(255, 174, 138, 0.24), rgba(70, 24, 14, 0.9) 60%),
        linear-gradient(170deg, rgba(52, 20, 14, 0.94), rgba(20, 9, 7, 0.9));
}

.enigma-world-interactable.canister-item.pressureplus,
.enigma-world-interactable.canister-item.pressureminus {
    background:
        radial-gradient(circle at 30% 24%, rgba(156, 192, 255, 0.26), rgba(18, 36, 72, 0.9) 60%),
        linear-gradient(170deg, rgba(14, 28, 52, 0.94), rgba(8, 14, 24, 0.9));
}

.enigma-world-interactable.manifold-port {
    border-radius: 18px;
    border-width: 2px;
    border-style: solid;
    font-size: 0.84rem;
}

.enigma-world-interactable.manifold-port.heat {
    border-color: rgba(255, 170, 138, 0.56);
    background:
        radial-gradient(circle at center, rgba(255, 150, 111, 0.2), rgba(35, 14, 11, 0.9) 66%),
        linear-gradient(180deg, rgba(22, 10, 9, 0.9), rgba(9, 6, 7, 0.92));
}

.enigma-world-interactable.manifold-port.pressure {
    border-color: rgba(144, 194, 255, 0.56);
    background:
        radial-gradient(circle at center, rgba(125, 176, 255, 0.2), rgba(11, 22, 42, 0.9) 66%),
        linear-gradient(180deg, rgba(9, 15, 28, 0.9), rgba(7, 10, 16, 0.92));
}

.enigma-world-interactable.manifold-port.stable {
    border-color: rgba(126, 233, 187, 0.82);
    box-shadow:
        inset 0 0 0 1px rgba(196, 255, 228, 0.18),
        0 0 0 1px rgba(126, 233, 187, 0.54),
        0 0 30px rgba(100, 229, 179, 0.3);
}

.enigma-world-interactable.theme-signal {
    --cargo-theme: rgba(106, 194, 255, 0.5);
}

.enigma-world-interactable.theme-echo {
    --cargo-theme: rgba(123, 240, 206, 0.5);
}

.enigma-world-interactable.theme-behavior {
    --cargo-theme: rgba(255, 201, 125, 0.5);
}

.enigma-world-interactable.theme-recursive {
    --cargo-theme: rgba(196, 165, 255, 0.52);
}

.enigma-world-interactable.theme-grid {
    --cargo-theme: rgba(160, 215, 255, 0.48);
}

.enigma-world-interactable.theme-symbol {
    --cargo-theme: rgba(228, 174, 255, 0.48);
}

.enigma-world-interactable.theme-time {
    --cargo-theme: rgba(146, 228, 255, 0.52);
}

.enigma-world-interactable.theme-false {
    --cargo-theme: rgba(210, 166, 255, 0.5);
}

.enigma-world-interactable.theme-hidden {
    --cargo-theme: rgba(180, 214, 255, 0.5);
}

.enigma-world-interactable.color-slot-0 { --node-accent-rgb: 74, 176, 255; }
.enigma-world-interactable.color-slot-1 { --node-accent-rgb: 69, 232, 198; }
.enigma-world-interactable.color-slot-2 { --node-accent-rgb: 255, 188, 74; }
.enigma-world-interactable.color-slot-3 { --node-accent-rgb: 255, 113, 175; }
.enigma-world-interactable.color-slot-4 { --node-accent-rgb: 159, 116, 255; }
.enigma-world-interactable.color-slot-5 { --node-accent-rgb: 89, 214, 255; }
.enigma-world-interactable.color-slot-6 { --node-accent-rgb: 133, 241, 110; }
.enigma-world-interactable.color-slot-7 { --node-accent-rgb: 255, 139, 88; }

.enigma-world-interactable.family-p { --node-accent-rgb: 238, 97, 185; }
.enigma-world-interactable.family-q { --node-accent-rgb: 88, 234, 255; }
.enigma-world-interactable.family-r { --node-accent-rgb: 255, 193, 96; }
.enigma-world-interactable.family-s { --node-accent-rgb: 166, 126, 255; }
.enigma-world-interactable.family-t { --node-accent-rgb: 121, 224, 255; }
.enigma-world-interactable.family-u { --node-accent-rgb: 138, 241, 168; }
.enigma-world-interactable.family-v { --node-accent-rgb: 224, 173, 255; }
.enigma-world-interactable.family-w { --node-accent-rgb: 114, 214, 255; }
.enigma-world-interactable.family-x { --node-accent-rgb: 255, 168, 207; }
.enigma-world-interactable.family-y { --node-accent-rgb: 255, 150, 108; }
.enigma-world-interactable.family-z { --node-accent-rgb: 255, 211, 116; }

.enigma-world-interactable.color-coded.icon-route::before {
    background:
        repeating-linear-gradient(90deg, rgba(var(--node-accent-rgb), 0.22) 0 2px, rgba(0, 0, 0, 0) 2px 7px),
        linear-gradient(160deg, rgba(var(--node-accent-rgb), 0.28), transparent 58%);
}

.enigma-world-interactable.color-coded.icon-echo::before {
    background:
        radial-gradient(circle at 50% 50%, rgba(var(--node-accent-rgb), 0.26) 0 16%, rgba(0, 0, 0, 0) 16% 100%),
        linear-gradient(160deg, rgba(var(--node-accent-rgb), 0.24), transparent 58%);
}

.enigma-world-interactable.color-coded.icon-grid::before {
    background:
        repeating-linear-gradient(90deg, rgba(var(--node-accent-rgb), 0.18) 0 1px, rgba(0, 0, 0, 0) 1px 9px),
        repeating-linear-gradient(0deg, rgba(var(--node-accent-rgb), 0.16) 0 1px, rgba(0, 0, 0, 0) 1px 9px),
        linear-gradient(160deg, rgba(var(--node-accent-rgb), 0.2), transparent 58%);
}

.enigma-world-interactable.color-coded.icon-time::before {
    background:
        radial-gradient(circle at 50% 50%, rgba(0, 0, 0, 0) 42%, rgba(var(--node-accent-rgb), 0.3) 44% 48%, rgba(0, 0, 0, 0) 50% 100%),
        linear-gradient(160deg, rgba(var(--node-accent-rgb), 0.22), transparent 58%);
}

.enigma-world-interactable.color-coded.icon-cipher::before {
    background:
        linear-gradient(40deg, rgba(var(--node-accent-rgb), 0.2), rgba(0, 0, 0, 0) 45%),
        linear-gradient(-40deg, rgba(var(--node-accent-rgb), 0.18), rgba(0, 0, 0, 0) 45%),
        linear-gradient(160deg, rgba(var(--node-accent-rgb), 0.2), transparent 58%);
}

.enigma-world-interactable.color-coded.icon-shift::before {
    background:
        linear-gradient(135deg, rgba(var(--node-accent-rgb), 0.26) 0 34%, rgba(0, 0, 0, 0) 36% 100%),
        linear-gradient(315deg, rgba(var(--node-accent-rgb), 0.22) 0 28%, rgba(0, 0, 0, 0) 30% 100%),
        linear-gradient(160deg, rgba(var(--node-accent-rgb), 0.2), transparent 58%);
}

.enigma-world-interactable.color-coded.icon-commit::before {
    background:
        radial-gradient(circle at 50% 50%, rgba(var(--node-accent-rgb), 0.36) 0 18%, rgba(0, 0, 0, 0) 20% 100%),
        linear-gradient(0deg, rgba(var(--node-accent-rgb), 0.18), rgba(0, 0, 0, 0) 68%),
        linear-gradient(160deg, rgba(var(--node-accent-rgb), 0.22), transparent 58%);
}

.enigma-world-interactable.color-coded.icon-loop::before {
    background:
        radial-gradient(circle at 50% 50%, rgba(0, 0, 0, 0) 33%, rgba(var(--node-accent-rgb), 0.24) 35% 45%, rgba(0, 0, 0, 0) 47% 100%),
        conic-gradient(from 210deg, rgba(var(--node-accent-rgb), 0) 0 45%, rgba(var(--node-accent-rgb), 0.3) 53% 70%, rgba(var(--node-accent-rgb), 0) 78% 100%),
        linear-gradient(160deg, rgba(var(--node-accent-rgb), 0.2), transparent 58%);
}

.enigma-world-interactable.color-coded.icon-heat::before {
    background:
        radial-gradient(circle at 50% 76%, rgba(var(--node-accent-rgb), 0.34), rgba(0, 0, 0, 0) 60%),
        linear-gradient(180deg, rgba(var(--node-accent-rgb), 0.32), rgba(0, 0, 0, 0) 72%),
        linear-gradient(160deg, rgba(var(--node-accent-rgb), 0.2), transparent 58%);
}

.enigma-world-interactable.color-coded.icon-pressure::before {
    background:
        radial-gradient(circle at 50% 50%, rgba(var(--node-accent-rgb), 0.22) 0 18%, rgba(0, 0, 0, 0) 19% 100%),
        repeating-radial-gradient(circle at 50% 50%, rgba(var(--node-accent-rgb), 0.12) 0 4px, rgba(0, 0, 0, 0) 5px 12px),
        linear-gradient(160deg, rgba(var(--node-accent-rgb), 0.2), transparent 58%);
}

.enigma-world-interactable.color-coded.icon-node::before {
    background:
        radial-gradient(circle at 50% 50%, rgba(var(--node-accent-rgb), 0.28) 0 22%, rgba(0, 0, 0, 0) 24% 100%),
        linear-gradient(160deg, rgba(var(--node-accent-rgb), 0.2), transparent 58%);
}

.enigma-room-stage .enigma-world-interactable.signal-relay.active,
.enigma-room-stage .enigma-world-interactable.echo-pad.reveal,
.enigma-room-stage .enigma-world-interactable.echo-pad.locked,
.enigma-room-stage .enigma-world-interactable.duallayer-node.target,
.enigma-room-stage .enigma-world-interactable.duallayer-node.solved,
.enigma-room-stage .enigma-world-interactable.behavior-terminal.solved,
.enigma-room-stage .enigma-world-interactable.recursive-anchor.locked,
.enigma-room-stage .enigma-world-interactable.recursive-anchor.target,
.enigma-room-stage .enigma-world-interactable.living-grid-cell.matched,
.enigma-room-stage .enigma-world-interactable.time-gate.open,
.enigma-room-stage .enigma-world-interactable.time-gate.locked,
.enigma-room-stage .enigma-world-interactable.false-terminal.primed,
.enigma-room-stage .enigma-world-interactable.hidden-rule-tile.confirmed,
.enigma-room-stage .enigma-world-interactable.cargo-item.delivered,
.enigma-room-stage .enigma-world-interactable.cargo-socket.locked,
.enigma-room-stage .enigma-world-interactable.cargo-socket.target,
.enigma-room-stage .enigma-world-interactable.manifold-port.stable {
    --radar-signal: 1 !important;
    opacity: 1 !important;
    filter: brightness(1.2) saturate(1.38) !important;
    border-color: rgba(166, 232, 255, 0.86);
    box-shadow:
        inset 0 0 0 1px rgba(225, 244, 255, 0.24),
        0 0 0 1px rgba(166, 232, 255, 0.62),
        0 0 36px rgba(90, 196, 255, 0.4),
        0 14px 32px rgba(0, 0, 0, 0.44);
    animation: enigmaGoodInteractableGlow 1.5s ease-in-out infinite;
}

@keyframes enigmaGoodInteractableGlow {
    0% {
        box-shadow:
            inset 0 0 0 1px rgba(225, 244, 255, 0.22),
            0 0 0 1px rgba(166, 232, 255, 0.54),
            0 0 28px rgba(90, 196, 255, 0.32),
            0 14px 30px rgba(0, 0, 0, 0.44);
    }
    50% {
        box-shadow:
            inset 0 0 0 1px rgba(233, 248, 255, 0.28),
            0 0 0 1px rgba(186, 239, 255, 0.74),
            0 0 44px rgba(126, 209, 255, 0.5),
            0 16px 34px rgba(0, 0, 0, 0.46);
    }
    100% {
        box-shadow:
            inset 0 0 0 1px rgba(225, 244, 255, 0.22),
            0 0 0 1px rgba(166, 232, 255, 0.54),
            0 0 28px rgba(90, 196, 255, 0.32),
            0 14px 30px rgba(0, 0, 0, 0.44);
    }
}

.enigma-reward-pickup {
    z-index: 4;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, #ffe08b, #ffbb33 48%, #a45e09 100%);
    box-shadow: 0 0 24px rgba(255, 189, 51, 0.5);
    animation: pulse 1.2s ease-in-out infinite;
}

.enigma-black-hole {
    z-index: 4;
    border-radius: 50%;
    background: radial-gradient(circle at 50% 45%, #1f2c4f 0%, #05070d 45%, #000 72%, #2e6cff 100%);
    box-shadow: 0 0 40px rgba(46, 108, 255, 0.45);
    animation: enigmaSwirl 2.8s linear infinite;
}

@keyframes enigmaSwirl {
    from { transform: rotate(0deg) scale(1); }
    50% { transform: rotate(180deg) scale(1.05); }
    to { transform: rotate(360deg) scale(1); }
}

.enigma-player {
    z-index: 3;
    pointer-events: none;
    border-radius: 12px;
    background: linear-gradient(180deg, #ffffff, #d4e0f0);
    border: 1px solid rgba(255, 255, 255, 0.62);
    box-shadow: 0 5px 14px rgba(0, 0, 0, 0.2);
    backface-visibility: hidden;
    transform: translateZ(0);
    will-change: left, top;
    transition: box-shadow 0.12s ease;
}

.enigma-player::after {
    content: "";
    position: absolute;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: #0b1220;
}

.enigma-player.facing-up::after {
    top: 8px;
    left: calc(50% - 6px);
}

.enigma-player.facing-right::after {
    right: 8px;
    top: calc(50% - 6px);
}

.enigma-player.facing-down::after {
    bottom: 8px;
    left: calc(50% - 6px);
}

.enigma-player.facing-left::after {
    left: 8px;
    top: calc(50% - 6px);
}

.enigma-player.is-moving {
    box-shadow: 0 7px 16px rgba(0, 0, 0, 0.24);
}

.enigma-room-hud,
.enigma-room-banner {
    position: absolute;
    z-index: 11;
    padding: 8px 12px;
    border-radius: 999px;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    background: rgba(7, 11, 18, 0.8);
    border: 1px solid rgba(122, 181, 255, 0.18);
    color: var(--epic-text);
    font-size: 0.8rem;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.55);
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.24);
}

.enigma-room-hud-right {
    top: 14px;
    right: 14px;
}

.enigma-room-hud-left {
    top: 14px;
    left: 14px;
}

.enigma-room-banner {
    left: 50%;
    top: 64px;
    bottom: auto;
    transform: translateX(-50%);
    min-width: min(70%, 460px);
    min-height: 42px;
    padding-inline: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    background: rgba(6, 10, 16, 0.92);
    border-color: rgba(122, 181, 255, 0.24);
    font-weight: 700;
    line-height: 1.25;
    box-shadow: 0 16px 36px rgba(0, 0, 0, 0.34);
}

.enigma-room-footer {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px;
    color: var(--epic-text-secondary);
    font-size: 0.9rem;
}

.enigma-sidebar {
    display: grid;
    grid-template-columns: minmax(320px, 380px) minmax(0, 1fr);
    grid-template-areas: "summary puzzle";
    gap: 20px;
    align-content: start;
}

.enigma-sidebar-summary {
    grid-area: summary;
    display: flex;
    flex-direction: column;
    gap: 14px;
    position: sticky;
    top: 24px;
}

.enigma-sidebar-card {
    padding: 18px;
    border-radius: 18px;
    margin: 0;
}

.enigma-coop-card {
    grid-column: 1 / -1;
}

.enigma-sidebar-card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
}

.enigma-status-goal {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(77, 131, 255, 0.14);
    border: 1px solid rgba(122, 181, 255, 0.18);
    color: #ddecff;
    font-size: 0.78rem;
    font-weight: 700;
    white-space: nowrap;
}

.enigma-status-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.enigma-status-metric {
    min-height: 94px;
    padding: 14px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.enigma-status-metric-wide {
    grid-column: 1 / -1;
    min-height: auto;
}

.enigma-status-metric span {
    display: block;
    margin-bottom: 6px;
    color: var(--epic-text-dim);
    font-size: 0.74rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.enigma-status-metric strong {
    display: block;
    color: var(--epic-text);
    font-size: 1.15rem;
    line-height: 1.25;
    word-break: break-word;
}

.enigma-status-loadout {
    display: grid;
    gap: 10px;
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.enigma-status-section-label {
    color: var(--epic-text-dim);
    font-size: 0.72rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.enigma-status-empty {
    padding: 12px 14px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px dashed rgba(255, 255, 255, 0.08);
    color: var(--epic-text-secondary);
    line-height: 1.45;
}

.enigma-status-loadout-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.enigma-status-loadout-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 38px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(79, 140, 255, 0.12);
    border: 1px solid rgba(79, 140, 255, 0.18);
    color: var(--epic-text);
}

.enigma-status-loadout-pill strong {
    font-size: 0.88rem;
    font-weight: 700;
    line-height: 1;
}

.enigma-status-loadout-pill span {
    color: #dcecff;
    font-size: 0.78rem;
    font-weight: 800;
}

.enigma-puzzle-card h2 {
    margin-bottom: 8px;
}

.enigma-puzzle-card {
    grid-area: puzzle;
    display: grid;
    gap: 14px;
    position: relative;
    top: auto;
    background:
        radial-gradient(circle at top left, rgba(60, 118, 255, 0.12), transparent 34%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.025), rgba(255, 255, 255, 0.01)),
        #171b24;
    border: 1px solid rgba(122, 181, 255, 0.14);
    box-shadow: 0 24px 56px rgba(0, 0, 0, 0.22);
    margin: 0;
    min-width: 0;
}

.enigma-puzzle-head {
    display: grid;
    gap: 8px;
    padding-bottom: 14px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.enigma-puzzle-head h2 {
    margin: 0;
    font-size: clamp(1.7rem, 1.35rem + 0.9vw, 2.2rem);
    letter-spacing: -0.04em;
}

.enigma-puzzle-head-clean {
    gap: 6px;
    padding-bottom: 12px;
}

.enigma-puzzle-head .enigma-puzzle-copy {
    margin: 0;
    line-height: 1.65;
}

.enigma-puzzle-surface {
    display: grid;
    gap: 16px;
    padding-top: 6px;
}

.enigma-world-puzzle-surface {
    display: grid;
    gap: 14px;
}

.enigma-world-puzzle-guide {
    grid-template-columns: 1fr;
    gap: 10px;
}

.enigma-world-puzzle-state-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.enigma-world-puzzle-state-label {
    color: var(--epic-text-dim);
    font-size: 0.72rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.enigma-world-puzzle-state {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    font-size: 0.74rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.05);
    color: var(--epic-text);
}

.enigma-world-puzzle-guide .enigma-puzzle-guide-row p {
    display: flex;
    align-items: center;
}

.enigma-world-puzzle-state.state-active {
    border-color: rgba(123, 194, 255, 0.5);
    background: rgba(83, 148, 242, 0.2);
}

.enigma-world-puzzle-state.state-solved {
    border-color: rgba(122, 224, 181, 0.58);
    background: rgba(61, 153, 109, 0.24);
}

.enigma-world-puzzle-state.state-failed {
    border-color: rgba(255, 143, 143, 0.56);
    background: rgba(150, 66, 66, 0.28);
}

.enigma-world-puzzle-state.state-resetting,
.enigma-world-puzzle-state.state-cooldown {
    border-color: rgba(197, 214, 255, 0.34);
    background: rgba(101, 122, 170, 0.2);
}

.enigma-world-puzzle-state.state-hint {
    border-color: rgba(255, 220, 150, 0.54);
    background: rgba(166, 124, 58, 0.24);
}

.enigma-world-puzzle-state.state-idle {
    border-color: rgba(184, 207, 245, 0.34);
    background: rgba(95, 111, 153, 0.2);
}

.enigma-world-puzzle-progress-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 10px;
    color: var(--epic-text-secondary);
    font-size: 0.82rem;
}

.enigma-world-puzzle-progress-head strong {
    color: var(--epic-text);
    font-size: 0.88rem;
}

.enigma-world-puzzle-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.enigma-world-puzzle-cell {
    display: grid;
    gap: 4px;
    padding: 10px 12px;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.035);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.enigma-world-puzzle-cell span {
    color: var(--epic-text-dim);
    font-size: 0.68rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.enigma-world-puzzle-cell strong {
    color: var(--epic-text);
    font-size: 0.95rem;
    letter-spacing: 0.01em;
}

.enigma-world-puzzle-helper {
    margin: 0;
    font-size: 0.82rem;
}

.enigma-loadout-list {
    display: grid;
    gap: 12px;
}

.enigma-loadout-item {
    display: grid;
    gap: 10px;
    padding: 14px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.enigma-loadout-item-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.enigma-loadout-item-top strong {
    color: var(--epic-text);
    font-size: 0.98rem;
    line-height: 1.35;
}

.enigma-loadout-quantity {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    min-height: 32px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(79, 140, 255, 0.18);
    border: 1px solid rgba(79, 140, 255, 0.28);
    color: #dcecff;
    font-size: 0.84rem;
    font-weight: 800;
}

.enigma-loadout-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.enigma-loadout-tag,
.enigma-loadout-empty {
    color: var(--epic-text-secondary);
}

.enigma-loadout-tag {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: capitalize;
}

.enigma-loadout-empty {
    padding: 14px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px dashed rgba(255, 255, 255, 0.08);
    line-height: 1.5;
}

.enigma-loadout-card {
    display: grid;
    gap: 12px;
}

.enigma-puzzle-copy,
.enigma-helper {
    color: var(--epic-text-secondary);
}

.enigma-puzzle-guide {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    margin: 0;
    padding: 0;
    border: 0;
    background: transparent;
}

.enigma-puzzle-guide-row {
    display: grid;
    gap: 6px;
    padding: 14px 16px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.03);
}

.enigma-puzzle-guide-row span {
    color: var(--epic-text-dim);
    font-size: 0.72rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.enigma-puzzle-guide-row p {
    margin: 0;
    color: var(--epic-text);
    line-height: 1.5;
}

.enigma-puzzle-status {
    padding: 12px 14px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.035);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: var(--epic-text);
    line-height: 1.5;
}

.enigma-puzzle-guide-row p {
    margin: 0;
    color: var(--epic-text);
    line-height: 1.55;
}

.enigma-puzzle-status {
    margin: 0;
    padding: 12px 14px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.enigma-world-puzzle-status {
    display: grid;
    gap: 6px;
}

.enigma-world-puzzle-status strong {
    color: #e8f3ff;
    font-size: 0.92rem;
    font-weight: 800;
}

.enigma-world-puzzle-status span {
    color: var(--epic-text-secondary);
    font-size: 0.84rem;
}

.enigma-progress-shell,
.enigma-timing-track {
    position: relative;
    width: 100%;
    height: 18px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    overflow: hidden;
    margin-bottom: 16px;
}

.enigma-progress-bar {
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #57c3ff, #74f2b3);
    transition: width 0.14s linear;
    will-change: width;
}

.enigma-coop-stage-target {
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 28px;
    background: rgba(16, 26, 48, 0.58);
    border: 2px solid rgba(125, 166, 255, 0.4);
    color: #f7fbff;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
}

.enigma-coop-stage-target.target {
    border-color: rgba(84, 163, 255, 0.88);
    box-shadow: 0 0 0 1px rgba(84, 163, 255, 0.22), 0 0 28px rgba(84, 163, 255, 0.26);
}

.enigma-coop-stage-target.active {
    background: rgba(50, 120, 255, 0.24);
}

.enigma-coop-stage-target.complete {
    background: rgba(42, 150, 104, 0.28);
    border-color: rgba(82, 219, 163, 0.68);
}

.co-op-tile-active {
    border-color: rgba(104, 160, 255, 0.72);
}

.co-op-tile-locked {
    opacity: 0.84;
    border-color: rgba(255, 102, 102, 0.62);
    background:
        radial-gradient(circle at top, rgba(255, 116, 116, 0.16), transparent 60%),
        rgba(34, 12, 18, 0.9);
    box-shadow: inset 0 0 0 1px rgba(255, 102, 102, 0.08);
}

.coop-rotation-shell {
    display: grid;
    gap: 1rem;
}

.coop-rotation-board {
    display: grid;
    gap: 12px;
    padding: 14px;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(6, 16, 32, 0.94), rgba(10, 20, 38, 0.82));
    border: 1px solid rgba(104, 160, 255, 0.18);
}

.enigma-rotation-tile {
    position: relative;
    min-height: 108px;
    padding: 12px;
    align-content: center;
    text-align: center;
    background:
        radial-gradient(circle at top, rgba(118, 184, 255, 0.12), transparent 62%),
        rgba(10, 18, 31, 0.92);
}

.enigma-rotation-tile .enigma-tile-arrow {
    width: auto;
    min-width: 72px;
    height: auto;
    padding: 12px 16px;
    font-size: 0.92rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.enigma-rotation-tile.aligned {
    border-color: rgba(92, 228, 170, 0.66);
    box-shadow: 0 0 22px rgba(92, 228, 170, 0.14);
}

.enigma-rotation-target {
    position: absolute;
    right: 10px;
    bottom: 10px;
    padding: 5px 8px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.06);
    color: rgba(228, 241, 255, 0.82);
    font-size: 0.67rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.coop-signal-board {
    position: relative;
    min-height: 360px;
    margin-bottom: 0;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(8, 17, 32, 0.96), rgba(10, 18, 32, 0.84));
    border: 1px solid rgba(104, 160, 255, 0.18);
    overflow: hidden;
}

.coop-signal-svg {
    width: 100%;
    height: 100%;
    display: block;
}

.coop-signal-line {
    stroke-width: 2.25;
    fill: none;
    stroke-linecap: round;
}

.coop-signal-line.blocked {
    stroke: rgba(255, 159, 159, 0.44);
    stroke-dasharray: 3 3;
}

.coop-signal-line.active {
    stroke: rgba(92, 178, 255, 0.86);
    filter: drop-shadow(0 0 8px rgba(92, 178, 255, 0.2));
}

.coop-signal-line.active.partner {
    stroke: rgba(255, 114, 114, 0.82);
    filter: drop-shadow(0 0 8px rgba(255, 114, 114, 0.18));
}

.coop-signal-node {
    position: absolute;
    z-index: 1;
    width: 100px;
    min-height: 48px;
    padding: 10px 10px 8px;
    border-radius: 14px;
    transform: translate(-50%, -50%);
    background: rgba(11, 20, 34, 0.96);
    border: 1px solid rgba(255, 255, 255, 0.09);
    color: #f4fbff;
    display: grid;
    gap: 0.2rem;
    text-align: center;
}

.coop-signal-node.left.controllable {
    border-color: rgba(92, 178, 255, 0.52);
    box-shadow: 0 0 18px rgba(92, 178, 255, 0.12);
}

.coop-signal-node.left.partner {
    opacity: 1;
    border-color: rgba(255, 114, 114, 0.48);
    background: rgba(34, 12, 18, 0.94);
    box-shadow: 0 0 18px rgba(255, 114, 114, 0.1);
}

.coop-signal-node small {
    color: rgba(220, 237, 255, 0.76);
    font-size: 0.67rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.coop-weight-card {
    gap: 0.9rem;
    min-height: 152px;
    background:
        radial-gradient(circle at top left, rgba(97, 156, 255, 0.12), transparent 44%),
        rgba(255, 255, 255, 0.05);
}

.enigma-coop-v2-shell {
    display: grid;
    gap: 0.8rem;
}

.enigma-coop-v2-shell.stage-intro {
    background: linear-gradient(160deg, rgba(86, 160, 255, 0.08), rgba(8, 15, 28, 0.25));
    border-radius: 14px;
    padding: 10px;
}

.enigma-coop-v2-shell.stage-expand {
    background: linear-gradient(160deg, rgba(70, 148, 255, 0.11), rgba(9, 18, 30, 0.3));
    border-radius: 14px;
    padding: 10px;
}

.enigma-coop-v2-shell.stage-constraint {
    background: linear-gradient(160deg, rgba(255, 152, 86, 0.08), rgba(8, 15, 28, 0.25));
    border-radius: 14px;
    padding: 10px;
}

.enigma-coop-v2-shell.stage-master {
    background: linear-gradient(160deg, rgba(255, 86, 86, 0.09), rgba(7, 12, 24, 0.3));
    border-radius: 14px;
    padding: 10px;
}

.enigma-coop-v2-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.72rem;
    color: rgba(193, 220, 255, 0.86);
}

.enigma-coop-v2-family {
    padding: 4px 10px;
    border-radius: 999px;
    background: rgba(81, 153, 255, 0.12);
    border: 1px solid rgba(81, 153, 255, 0.26);
}

.enigma-coop-v2-phase {
    padding: 4px 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.12);
}

.enigma-coop-v2-status {
    font-weight: 700;
    color: #f3f9ff;
}

.enigma-coop-v2-prompt {
    color: var(--epic-text-secondary);
    font-size: 0.83rem;
}

.enigma-coop-v2-progress {
    margin-bottom: 0;
}

.enigma-coop-v2-progress-axis {
    display: grid;
    grid-template-columns: 1fr auto auto;
    align-items: center;
    gap: 0.45rem;
    color: rgba(224, 238, 255, 0.9);
    font-size: 0.75rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.enigma-coop-v2-progress-axis strong {
    color: #f2fbff;
    font-size: 0.85rem;
}

.enigma-coop-v2-progress-axis small {
    font-size: 0.66rem;
    opacity: 0.9;
}

.enigma-coop-v2-progress-axis.trend-up {
    color: rgba(139, 255, 194, 0.92);
}

.enigma-coop-v2-progress-axis.trend-down {
    color: rgba(255, 166, 166, 0.9);
}

.enigma-coop-v2-failure {
    display: grid;
    gap: 0.2rem;
    padding: 9px 10px;
    border-radius: 10px;
    border: 1px solid rgba(255, 114, 114, 0.34);
    background: linear-gradient(160deg, rgba(255, 93, 93, 0.12), rgba(44, 8, 12, 0.45));
    color: rgba(255, 225, 225, 0.95);
}

.enigma-coop-v2-failure strong {
    letter-spacing: 0.05em;
    text-transform: uppercase;
    font-size: 0.73rem;
}

.enigma-coop-v2-failure span {
    font-size: 0.8rem;
}

.enigma-coop-v2-failure small {
    color: rgba(255, 208, 208, 0.85);
    font-size: 0.7rem;
}

.enigma-coop-v2-hud-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
}

.enigma-coop-v2-hud-item {
    display: grid;
    gap: 0.2rem;
    padding: 8px 10px;
    border-radius: 11px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.09);
}

.enigma-coop-v2-hud-icon {
    width: 26px;
    height: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: rgba(81, 153, 255, 0.16);
    border: 1px solid rgba(81, 153, 255, 0.3);
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.05em;
}

.enigma-coop-v2-hud-label {
    color: var(--epic-text-secondary);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.enigma-coop-v2-action-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
}

.enigma-coop-v2-action {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    justify-content: flex-start;
    padding: 9px 10px;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: rgba(12, 22, 36, 0.9);
    color: #eff6ff;
    font-weight: 700;
    font-size: 0.78rem;
}

.enigma-coop-v2-action.active {
    border-color: rgba(89, 225, 162, 0.72);
    box-shadow: 0 0 14px rgba(89, 225, 162, 0.18);
}

.enigma-coop-v2-action.disabled {
    opacity: 0.48;
}

.enigma-coop-v2-action-icon {
    width: 24px;
    height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 7px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.16);
    font-size: 0.6rem;
    letter-spacing: 0.05em;
}

.enigma-coop-v2-action.tone-owner {
    border-color: rgba(92, 178, 255, 0.46);
}

.enigma-coop-v2-action.tone-guest {
    border-color: rgba(255, 124, 124, 0.46);
}

.enigma-coop-v2-action.tone-shared {
    border-color: rgba(215, 175, 255, 0.4);
}

.enigma-coop-depth-panel {
    gap: 18px;
}

.enigma-coop-depth-stage {
    padding-bottom: 18px;
}

.enigma-coop-depth-main {
    display: grid;
    grid-template-columns: minmax(0, 1.45fr) minmax(320px, 0.9fr);
    gap: 18px;
    align-items: start;
}

.enigma-coop-depth-lower {
    display: grid;
    grid-template-columns: minmax(0, 1.45fr) minmax(300px, 0.85fr);
    gap: 18px;
    align-items: start;
}

.enigma-coop-signal-visual-card,
.enigma-coop-systems-visual-card,
.enigma-coop-topology-visual-card,
.enigma-coop-relay-visual-card {
    min-height: 220px;
    border: 1px solid rgba(96, 165, 250, 0.15);
    border-radius: 20px;
    background:
        radial-gradient(circle at 15% 20%, rgba(96, 165, 250, 0.14), transparent 38%),
        linear-gradient(135deg, rgba(8, 15, 36, 0.96), rgba(6, 10, 28, 0.98));
    padding: 18px;
}

.enigma-coop-depth-svg {
    width: 100%;
    height: auto;
    min-height: 184px;
}

.enigma-coop-timing-track {
    position: relative;
    height: 24px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.06);
    overflow: hidden;
    margin-top: 18px;
}

.enigma-coop-timing-window {
    position: absolute;
    top: 0;
    bottom: 0;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(34, 197, 94, 0.4), rgba(125, 211, 252, 0.42));
}

.enigma-coop-timing-marker {
    position: absolute;
    top: -4px;
    width: 12px;
    height: 32px;
    border-radius: 999px;
    background: #f8fafc;
    box-shadow: 0 0 12px rgba(255, 255, 255, 0.5);
    transform: translateX(-50%);
}

.enigma-coop-timing-caption {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    margin-top: 14px;
    color: rgba(226, 232, 240, 0.88);
}

.enigma-coop-tank-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(88px, 1fr));
    gap: 14px;
}

.enigma-coop-tank-card {
    padding: 12px;
    border-radius: 16px;
    border: 1px solid rgba(148, 163, 184, 0.18);
    background: rgba(15, 23, 42, 0.72);
    text-align: center;
}

.enigma-coop-tank-card.stable,
.enigma-coop-layer-band.aligned,
.enigma-coop-bridge-node.active,
.enigma-coop-time-cell.active,
.enigma-coop-deduction-cell.partner,
.enigma-system-metric-card.aligned {
    border-color: rgba(74, 222, 128, 0.45);
    box-shadow: 0 0 0 1px rgba(74, 222, 128, 0.14) inset;
}

.enigma-coop-tank-track {
    position: relative;
    height: 120px;
    margin: 10px auto;
    width: 36px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.06);
    overflow: hidden;
}

.enigma-coop-tank-fill {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(180deg, rgba(96, 165, 250, 0.7), rgba(34, 211, 238, 0.76));
}

.enigma-coop-tank-safe {
    position: absolute;
    left: 4px;
    right: 4px;
    height: 2px;
    background: rgba(248, 250, 252, 0.86);
}

.enigma-coop-layer-stack,
.enigma-coop-depth-intel-grid,
.enigma-coop-time-row-clues {
    display: grid;
    gap: 10px;
}

.enigma-coop-layer-band {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid rgba(148, 163, 184, 0.18);
    background: rgba(15, 23, 42, 0.7);
}

.enigma-coop-bridge-grid {
    display: grid;
    gap: 12px;
}

.enigma-coop-bridge-node,
.enigma-coop-time-cell,
.enigma-coop-deduction-cell {
    min-height: 64px;
    border-radius: 16px;
    border: 1px solid rgba(148, 163, 184, 0.22);
    background: rgba(15, 23, 42, 0.72);
    color: rgba(241, 245, 249, 0.96);
}

.enigma-coop-bridge-node.local {
    border-color: rgba(96, 165, 250, 0.38);
}

.enigma-coop-bridge-node.partner,
.enigma-coop-time-cell.partner,
.enigma-coop-deduction-cell.partner {
    opacity: 0.86;
}

.enigma-coop-time-grid-shell,
.enigma-coop-deduction-board {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.enigma-coop-time-grid,
.enigma-coop-deduction-column {
    display: grid;
    gap: 10px;
}

.enigma-coop-time-grid-board,
.enigma-coop-deduction-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}

.enigma-coop-deduction-cell {
    display: grid;
    place-items: center;
    padding: 10px;
}

.co-op-dual-controls {
    margin-top: 10px;
}

@media (max-width: 1120px) {
    .enigma-coop-depth-main,
    .enigma-coop-depth-lower,
    .enigma-coop-time-grid-shell,
    .enigma-coop-deduction-board {
        grid-template-columns: 1fr;
    }
}

.enigma-signal-row {
    display: grid;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.enigma-timing-window {
    position: absolute;
    top: 0;
    height: 100%;
    background: rgba(46, 204, 113, 0.38);
}

.enigma-timing-marker {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 10px;
    background: linear-gradient(180deg, #ffffff, #d9f4ff);
    transform: translateX(-50%);
    will-change: left;
    box-shadow: 0 0 14px rgba(255, 255, 255, 0.35);
    border-radius: 999px;
}

.enigma-option-grid,
.enigma-direction-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.enigma-flow-control-grid {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.enigma-weight-grid {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.enigma-control-button {
    display: grid;
    gap: 8px;
    justify-items: start;
    align-content: start;
    min-height: 84px;
    text-align: left;
    padding: 14px 16px;
}

.enigma-control-button strong {
    color: var(--epic-text);
    font-size: 0.94rem;
}

.enigma-control-button small {
    color: var(--epic-text-secondary);
    line-height: 1.45;
    font-size: 0.75rem;
}

.enigma-option-grid.compact,
.enigma-direction-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.enigma-sequence-display {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 16px;
}

.enigma-sequence-display span {
    min-width: 42px;
    padding: 10px 12px;
    border-radius: 10px;
    text-align: center;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
    font-weight: 700;
}

.enigma-sequence-display.compact span {
    min-width: 34px;
}

.enigma-direction-sequence {
    gap: 10px;
}

.enigma-direction-token {
    min-width: 46px;
    min-height: 46px;
    display: grid;
    place-items: center;
    font-size: 1.35rem;
    background: rgba(12, 18, 30, 0.92) !important;
    border: 1px solid rgba(103, 180, 255, 0.26) !important;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}

.enigma-direction-token.visible {
    color: #f5fbff;
    background: linear-gradient(180deg, rgba(40, 90, 170, 0.55), rgba(9, 26, 58, 0.95)) !important;
    border-color: rgba(111, 194, 255, 0.58) !important;
    box-shadow: 0 0 22px rgba(74, 144, 255, 0.18);
}

.enigma-direction-token.hidden {
    color: rgba(205, 225, 248, 0.94);
    font-size: 1.1rem;
}

.enigma-tile-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.enigma-tile-button,
.enigma-yarn-node {
    width: 100%;
    min-height: 84px;
    border: 1px solid var(--epic-border);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.04);
    color: var(--epic-text);
    font-size: 1.6rem;
    font-weight: 700;
    transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.enigma-tile-button {
    display: grid;
    place-items: center;
}

.enigma-tile-arrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.05);
    transition: transform 0.24s cubic-bezier(0.22, 1, 0.36, 1), background 0.2s ease, box-shadow 0.2s ease;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
}

.enigma-tile-button:hover .enigma-tile-arrow {
    background: rgba(87, 195, 255, 0.14);
    box-shadow: 0 0 18px rgba(87, 195, 255, 0.14);
}

.enigma-tile-button:hover,
.enigma-yarn-node:hover {
    transform: translateY(-2px);
    border-color: var(--epic-primary);
}

.enigma-arrow-button {
    font-size: 1.3rem;
    font-weight: 800;
}

.enigma-arrow-button:disabled {
    opacity: 0.48;
    cursor: not-allowed;
}

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

.enigma-valve-grid,
.enigma-bit-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.enigma-valve-button,
.enigma-bit-button {
    width: 100%;
    min-height: 96px;
    display: grid;
    gap: 4px;
    align-content: center;
    justify-items: start;
    padding: 16px;
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: var(--epic-text);
    background: linear-gradient(180deg, rgba(15, 22, 32, 0.96), rgba(9, 14, 22, 0.92));
    transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.enigma-valve-button span,
.enigma-bit-button span {
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--epic-text-secondary);
}

.enigma-valve-button strong,
.enigma-bit-button strong {
    font-size: 1.45rem;
    line-height: 1;
}

.enigma-valve-button small,
.enigma-bit-button small {
    color: var(--epic-text-secondary);
}

.enigma-valve-button:hover,
.enigma-bit-button:hover {
    transform: translateY(-2px);
    border-color: rgba(87, 195, 255, 0.42);
    box-shadow: 0 16px 28px rgba(0, 0, 0, 0.22);
}

.enigma-valve-button.open {
    background: linear-gradient(180deg, rgba(16, 60, 58, 0.96), rgba(10, 30, 31, 0.94));
    border-color: rgba(92, 235, 188, 0.36);
    box-shadow: 0 0 0 1px rgba(92, 235, 188, 0.1), 0 18px 32px rgba(4, 24, 22, 0.28);
}

.enigma-bit-button.active {
    background: linear-gradient(180deg, rgba(28, 57, 102, 0.96), rgba(12, 23, 46, 0.94));
    border-color: rgba(95, 162, 255, 0.42);
    box-shadow: 0 0 0 1px rgba(95, 162, 255, 0.12), 0 18px 32px rgba(8, 14, 28, 0.28);
}

.enigma-yarn-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}

.enigma-yarn-node {
    min-height: 72px;
}

.enigma-yarn-node.selected {
    border-color: var(--epic-warning);
    background: rgba(243, 156, 18, 0.15);
}

.enigma-yarn-board {
    position: relative;
    min-height: 384px;
    padding: 54px 0 24px;
    border-radius: 22px;
    border: 1px solid rgba(98, 165, 255, 0.16);
    background:
        radial-gradient(circle at center, rgba(24, 60, 118, 0.2), transparent 52%),
        linear-gradient(180deg, rgba(6, 13, 25, 0.94), rgba(10, 19, 34, 0.98));
    overflow: hidden;
}

.enigma-yarn-svg {
    position: absolute;
    inset: 54px 0 24px;
    width: 100%;
    height: calc(100% - 78px);
}

.enigma-yarn-line {
    fill: none;
    stroke-width: 3.4;
    stroke-linecap: round;
    filter: drop-shadow(0 0 10px rgba(62, 133, 255, 0.18));
    transition: stroke-width 0.18s ease, opacity 0.18s ease, filter 0.18s ease;
}

.enigma-yarn-line.crossed {
    stroke-width: 4.1;
    filter: drop-shadow(0 0 14px rgba(120, 190, 255, 0.26));
}

.enigma-yarn-line.selected {
    stroke-width: 4.8;
    filter: drop-shadow(0 0 18px rgba(255, 186, 88, 0.34));
}

.enigma-yarn-column-label {
    position: absolute;
    top: 18px;
    z-index: 1;
    color: rgba(224, 236, 255, 0.72);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.enigma-yarn-column-label.left {
    left: 24px;
}

.enigma-yarn-column-label.right {
    right: 24px;
}

.enigma-yarn-slot {
    position: absolute;
    right: 22px;
    width: 64px;
    height: 44px;
    border-radius: 14px;
    transform: translateY(-50%);
    display: grid;
    place-items: center;
    color: rgba(210, 225, 248, 0.34);
    font-size: 0.82rem;
    font-weight: 800;
    border: 1px dashed rgba(124, 171, 255, 0.12);
    background: rgba(255, 255, 255, 0.018);
}

.enigma-yarn-anchor {
    position: absolute;
    width: 58px;
    min-height: 48px;
    padding: 6px 8px;
    border-radius: 16px;
    display: grid;
    place-items: center;
    transform: translateY(-50%);
    font-weight: 800;
    z-index: 1;
    line-height: 1.05;
}

.enigma-yarn-anchor.left {
    left: 18px;
    border: 1px solid rgba(134, 180, 245, 0.24);
    background: linear-gradient(180deg, rgba(18, 31, 52, 0.96), rgba(10, 18, 34, 0.96));
    color: #edf5ff;
    box-shadow: 0 12px 24px rgba(4, 10, 22, 0.22);
}

.enigma-yarn-anchor.right {
    right: 25px;
    width: 58px;
    min-height: 58px;
    border: 1px solid rgba(114, 170, 255, 0.3);
    background: linear-gradient(180deg, rgba(21, 39, 73, 0.96), rgba(10, 18, 35, 0.96));
    color: var(--epic-text);
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease, opacity 0.18s ease;
}

.enigma-yarn-anchor.right:hover {
    transform: translateY(-50%) translateX(-3px);
    border-color: rgba(120, 202, 255, 0.48);
    box-shadow: 0 12px 24px rgba(5, 15, 32, 0.3);
}

.enigma-yarn-anchor.right.selected {
    border-color: rgba(243, 156, 18, 0.58);
    background: linear-gradient(180deg, rgba(92, 56, 14, 0.96), rgba(43, 24, 7, 0.96));
    box-shadow: 0 0 0 1px rgba(243, 156, 18, 0.16), 0 12px 24px rgba(44, 22, 2, 0.3);
}

.enigma-yarn-anchor.right[data-crossed="true"] {
    box-shadow: 0 0 0 1px rgba(255, 110, 146, 0.14), 0 12px 24px rgba(8, 16, 30, 0.3);
}

.enigma-yarn-anchor-main {
    display: block;
    font-size: 1rem;
    font-weight: 900;
    color: #f8fbff;
}

.enigma-yarn-anchor-sub {
    display: block;
    margin-top: 2px;
    color: rgba(222, 233, 249, 0.7);
    font-size: 0.6rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.enigma-phase-node,
.enigma-harmonic-node,
.enigma-path-cell,
.enigma-weight-pad,
.enigma-weight-block,
.enigma-connection-line,
.enigma-knot-line,
.enigma-node-anchor {
    position: absolute;
}

.enigma-phase-node,
.enigma-harmonic-node,
.enigma-path-cell,
.enigma-weight-pad,
.enigma-weight-block,
.enigma-node-anchor {
    display: grid;
    place-items: center;
    border-radius: 16px;
    font-weight: 800;
    color: #f7fbff;
    transition: transform 0.18s ease, opacity 0.18s ease, box-shadow 0.22s ease, border-color 0.22s ease, background 0.22s ease, left 0.14s ease, top 0.14s ease;
    will-change: transform, opacity, box-shadow, left, top;
}

.enigma-phase-node {
    z-index: 1;
    background: rgba(112, 123, 145, 0.18);
    border: 2px solid rgba(180, 198, 234, 0.22);
    box-shadow: inset 0 0 30px rgba(0, 0, 0, 0.18);
}

.enigma-phase-node.active {
    background: radial-gradient(circle, rgba(84, 175, 255, 0.65), rgba(17, 56, 102, 0.75));
    border-color: rgba(133, 210, 255, 0.85);
    box-shadow: 0 0 34px rgba(84, 175, 255, 0.34);
    animation: enigmaRelayPulse 1.2s ease-in-out infinite;
}

.enigma-phase-node.complete {
    background: rgba(65, 199, 129, 0.28);
    border-color: rgba(88, 233, 155, 0.55);
    animation: enigmaSolvedSettle 1.8s ease-in-out infinite;
}

.enigma-harmonic-node {
    z-index: 1;
    background: radial-gradient(circle, rgba(162, 96, 255, 0.62), rgba(43, 18, 82, 0.9));
    border: 2px solid rgba(198, 151, 255, 0.58);
    box-shadow: 0 0 26px rgba(130, 86, 255, 0.28);
    font-size: 1.45rem;
    animation: enigmaHarmonicBeat 1.7s ease-in-out infinite;
}

.enigma-path-cell {
    z-index: 1;
    background: rgba(255, 255, 255, 0.04);
    border: 1px dashed rgba(255, 255, 255, 0.08);
    opacity: 0.38;
}

.enigma-path-cell.visible {
    opacity: 1;
    background: linear-gradient(135deg, rgba(65, 240, 171, 0.5), rgba(15, 88, 71, 0.75));
    border-style: solid;
    border-color: rgba(112, 255, 210, 0.7);
    box-shadow: 0 0 22px rgba(56, 235, 173, 0.22);
    animation: enigmaPathReveal 1s ease-in-out infinite;
}

.enigma-path-cell.traced {
    opacity: 1;
    background: rgba(83, 162, 255, 0.35);
    border-color: rgba(112, 190, 255, 0.55);
    animation: enigmaPathTrace 1.6s ease-in-out infinite;
}

.enigma-path-cell.next {
    opacity: 0.92;
    background: rgba(255, 210, 88, 0.26);
    border-color: rgba(255, 222, 131, 0.75);
    animation: enigmaPathNext 0.95s ease-in-out infinite;
}

.enigma-weight-pad {
    z-index: 1;
    border: 2px dashed rgba(255, 255, 255, 0.22);
    background: rgba(255, 255, 255, 0.04);
    animation: enigmaPadHum 2.2s ease-in-out infinite;
}

.enigma-weight-pad.positive {
    border-color: rgba(83, 185, 255, 0.55);
    background: rgba(42, 104, 175, 0.16);
}

.enigma-weight-pad.negative {
    border-color: rgba(255, 122, 154, 0.62);
    background: rgba(146, 37, 63, 0.16);
}

.enigma-weight-block {
    z-index: 3;
    background: linear-gradient(180deg, #f4f7fb, #aab7cd);
    color: #0d1420;
    border: 2px solid rgba(255, 255, 255, 0.46);
    box-shadow: 0 14px 24px rgba(0, 0, 0, 0.28);
    animation: enigmaWeightHover 2.7s ease-in-out infinite;
}

.enigma-zone.waiting {
    background: rgba(174, 111, 255, 0.2);
    border-color: rgba(201, 154, 255, 0.44);
    animation: enigmaWaitingPulse 1.05s ease-in-out infinite;
}

.enigma-zone.recursive {
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    animation: enigmaRecursiveFlux 2.2s ease-in-out infinite;
}

.enigma-zone.complete.recursive {
    background: rgba(74, 189, 124, 0.26);
}

.enigma-connection-line,
.enigma-knot-line {
    z-index: 1;
    height: 6px;
    transform-origin: 0 50%;
    border-radius: 999px;
    overflow: hidden;
}

.enigma-connection-line {
    background: linear-gradient(90deg, rgba(101, 209, 255, 0.2), rgba(101, 209, 255, 0.84));
    box-shadow: 0 0 18px rgba(82, 186, 255, 0.22);
}

.enigma-knot-line {
    background: linear-gradient(90deg, rgba(255, 178, 89, 0.2), rgba(255, 140, 60, 0.84));
    box-shadow: 0 0 16px rgba(255, 154, 88, 0.18);
}

.enigma-connection-line::after,
.enigma-knot-line::after {
    content: "";
    position: absolute;
    inset: 0;
    width: 36%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.78), transparent);
    opacity: 0.7;
}

.enigma-connection-line::after {
    animation: enigmaSignalFlow 1.45s linear infinite;
}

.enigma-knot-line::after {
    animation: enigmaSignalFlow 1.75s linear infinite;
}

.enigma-node-anchor {
    z-index: 2;
    width: 110px;
    height: 56px;
    transform: translate(-50%, -50%);
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(8, 14, 24, 0.82);
    font-size: 0.82rem;
    animation: enigmaAnchorDrift 2.9s ease-in-out infinite;
}

.enigma-node-anchor.left {
    text-align: right;
}

.enigma-node-anchor.right {
    text-align: left;
}

.enigma-puzzle-statements {
    display: grid;
    gap: 10px;
    margin-bottom: 16px;
}

.enigma-statement,
.enigma-mini-stat {
    padding: 12px 14px;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
}

.enigma-statement:hover,
.enigma-mini-stat:hover {
    transform: translateY(-1px);
    border-color: rgba(120, 188, 255, 0.28);
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.18);
}

.enigma-mini-stat-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 16px;
}

.enigma-mini-stat span {
    display: block;
    margin-bottom: 6px;
    color: var(--epic-text-dim);
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.enigma-mini-stat strong {
    display: block;
    font-size: 1.02rem;
}

.enigma-network-grid {
    display: grid;
    gap: 10px;
    margin-bottom: 16px;
}

.enigma-network-tile {
    min-height: 72px;
    border-radius: 14px;
    border: 1px solid rgba(122, 181, 255, 0.22);
    background: rgba(12, 20, 34, 0.85);
    color: #f7fbff;
    font-size: 2rem;
    font-weight: 800;
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
    animation: enigmaTileIdle 2.8s ease-in-out infinite;
    position: relative;
    overflow: hidden;
}

.enigma-network-tile:hover {
    transform: translateY(-2px);
    border-color: rgba(122, 181, 255, 0.5);
    box-shadow: 0 12px 26px rgba(41, 109, 185, 0.22);
}

.enigma-network-tile.cipher {
    display: grid;
    place-items: center;
}

.enigma-network-tile::after {
    content: "";
    position: absolute;
    inset: -20%;
    background: linear-gradient(115deg, transparent 30%, rgba(255, 255, 255, 0.12) 50%, transparent 70%);
    transform: translateX(-120%);
    animation: enigmaTileScan 2.7s ease-in-out infinite;
}

.enigma-cipher-controls {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 12px;
}

.binary-display {
    justify-content: space-between;
}

.binary-display span {
    min-width: 110px;
    font-family: var(--epic-font-mono, "Cascadia Mono", "Consolas", monospace);
    letter-spacing: 0.08em;
    animation: enigmaBinaryGlow 1.6s ease-in-out infinite;
}

.enigma-puzzle-copy,
.enigma-helper,
.enigma-statement,
.enigma-sequence-display span,
.enigma-mini-stat strong,
.enigma-mini-stat,
.enigma-puzzle-status {
    color: var(--epic-text);
}

.enigma-helper {
    line-height: 1.55;
}

.mono-numeric {
    font-family: var(--epic-font-mono, "Cascadia Mono", "Consolas", monospace);
    font-variant-numeric: tabular-nums;
}

.enigma-detail-button {
    display: grid;
    gap: 4px;
    text-align: left;
}

.enigma-detail-button small {
    color: rgba(224, 239, 255, 0.78);
    font-size: 0.72rem;
    letter-spacing: 0.03em;
}

.enigma-harmonic-node.active {
    box-shadow: 0 0 40px rgba(203, 149, 255, 0.48);
    border-color: rgba(232, 208, 255, 0.9);
}

.enigma-path-cell.visible {
    background: linear-gradient(135deg, rgba(102, 255, 196, 0.72), rgba(20, 109, 88, 0.9));
    border-color: rgba(170, 255, 227, 0.86);
    box-shadow: 0 0 28px rgba(56, 235, 173, 0.32);
}

.enigma-knot-line.illusion {
    background: repeating-linear-gradient(90deg, rgba(150, 198, 255, 0.28) 0 12px, rgba(150, 198, 255, 0.02) 12px 22px);
    box-shadow: 0 0 14px rgba(150, 198, 255, 0.14);
}

.enigma-network-tile {
    font-family: var(--epic-font-mono, "Cascadia Mono", "Consolas", monospace);
}

.enigma-network-tile.start {
    border-color: rgba(92, 235, 188, 0.56);
    box-shadow: inset 0 0 0 1px rgba(92, 235, 188, 0.2);
}

.enigma-network-tile.end {
    border-color: rgba(255, 208, 95, 0.56);
    box-shadow: inset 0 0 0 1px rgba(255, 208, 95, 0.2);
}

.enigma-network-tile.cipher-center {
    background: linear-gradient(180deg, rgba(32, 65, 116, 0.96), rgba(13, 26, 51, 0.96));
    border-color: rgba(116, 177, 255, 0.46);
}

.binary-display span {
    font-size: 1.18rem;
}

.enigma-symbol-grid .btn {
    min-height: 70px;
    font-weight: 700;
}

.enigma-word-tile,
.enigma-descriptor-tile {
    position: absolute;
    z-index: 2;
    display: grid;
    place-items: center;
    padding: 12px;
    text-align: center;
    border-radius: 18px;
    font-weight: 800;
    letter-spacing: 0.04em;
    color: var(--epic-text);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.enigma-word-tile {
    border: 1px solid rgba(108, 180, 255, 0.34);
    background: linear-gradient(180deg, rgba(19, 36, 68, 0.96), rgba(8, 18, 36, 0.94));
}

.enigma-word-tile.active {
    border-color: rgba(134, 212, 255, 0.72);
    box-shadow: 0 0 28px rgba(80, 172, 255, 0.28);
    transform: scale(1.03);
}

.enigma-word-tile.solved {
    border-color: rgba(92, 235, 188, 0.52);
    background: linear-gradient(180deg, rgba(17, 63, 59, 0.96), rgba(8, 28, 28, 0.94));
}

.enigma-descriptor-tile {
    border: 1px solid rgba(255, 208, 110, 0.3);
    background: linear-gradient(180deg, rgba(66, 43, 13, 0.96), rgba(33, 21, 7, 0.94));
}

.enigma-descriptor-tile.target {
    border-color: rgba(255, 228, 141, 0.74);
    box-shadow: 0 0 28px rgba(255, 216, 102, 0.26);
    transform: scale(1.03);
}

.enigma-temporal-wheel {
    position: relative;
    width: min(100%, 320px);
    aspect-ratio: 1;
    margin: 0 auto 18px;
    border-radius: 50%;
    background: radial-gradient(circle at center, rgba(8, 14, 24, 0.98) 0%, rgba(9, 17, 31, 0.96) 36%, rgba(18, 31, 56, 0.92) 100%);
    border: 1px solid rgba(120, 181, 255, 0.18);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02), 0 18px 40px rgba(0, 0, 0, 0.24);
    overflow: hidden;
}

.enigma-temporal-ring,
.enigma-temporal-core {
    position: absolute;
    left: 50%;
    top: 50%;
}

.enigma-temporal-ring {
    border-radius: 50%;
    transform: translate(-50%, -50%);
}

.enigma-temporal-ring.outer {
    width: 270px;
    height: 270px;
    border: 1px solid rgba(99, 173, 255, 0.26);
}

.enigma-temporal-ring.middle {
    width: 200px;
    height: 200px;
    border: 1px solid rgba(163, 126, 255, 0.26);
}

.enigma-temporal-ring.inner {
    width: 130px;
    height: 130px;
    border: 1px solid rgba(255, 190, 94, 0.26);
}

.enigma-temporal-sigil {
    position: absolute;
    transform: translate(-50%, -50%);
    min-width: 62px;
    padding: 6px 8px;
    border-radius: 999px;
    background: rgba(10, 18, 31, 0.92);
    border: 1px solid rgba(255, 255, 255, 0.08);
    font-size: 0.72rem;
    text-align: center;
    color: var(--epic-text);
    white-space: nowrap;
}

.enigma-temporal-core {
    transform: translate(-50%, -50%);
    width: 68px;
    height: 68px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: radial-gradient(circle, rgba(49, 115, 214, 0.88), rgba(16, 35, 72, 0.98));
    border: 1px solid rgba(144, 198, 255, 0.36);
    color: var(--epic-text);
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

@keyframes enigmaRelayPulse {
    0%, 100% { transform: scale(1); box-shadow: 0 0 24px rgba(84, 175, 255, 0.24); }
    50% { transform: scale(1.06); box-shadow: 0 0 40px rgba(84, 175, 255, 0.44); }
}

@keyframes enigmaSolvedSettle {
    0%, 100% { transform: scale(1); box-shadow: 0 0 14px rgba(88, 233, 155, 0.14); }
    50% { transform: scale(1.03); box-shadow: 0 0 24px rgba(88, 233, 155, 0.24); }
}

@keyframes enigmaHarmonicBeat {
    0%, 100% { transform: scale(1) rotate(0deg); box-shadow: 0 0 20px rgba(130, 86, 255, 0.2); }
    35% { transform: scale(1.035) rotate(-1deg); }
    65% { transform: scale(0.985) rotate(1deg); box-shadow: 0 0 34px rgba(173, 119, 255, 0.34); }
}

@keyframes enigmaPathReveal {
    0%, 100% { transform: scale(1); box-shadow: 0 0 18px rgba(56, 235, 173, 0.12); }
    50% { transform: scale(1.04); box-shadow: 0 0 30px rgba(56, 235, 173, 0.3); }
}

@keyframes enigmaPathTrace {
    0%, 100% { box-shadow: 0 0 10px rgba(83, 162, 255, 0.14); }
    50% { box-shadow: 0 0 24px rgba(83, 162, 255, 0.3); }
}

@keyframes enigmaPathNext {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.05); box-shadow: 0 0 24px rgba(255, 222, 131, 0.28); }
}

@keyframes enigmaPadHum {
    0%, 100% { box-shadow: inset 0 0 0 rgba(255, 255, 255, 0); }
    50% { box-shadow: inset 0 0 34px rgba(255, 255, 255, 0.06); }
}

@keyframes enigmaWeightHover {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-2px); }
}

@keyframes enigmaWaitingPulse {
    0%, 100% { opacity: 0.86; box-shadow: 0 0 12px rgba(174, 111, 255, 0.12); }
    50% { opacity: 1; box-shadow: 0 0 26px rgba(174, 111, 255, 0.28); }
}

@keyframes enigmaRecursiveFlux {
    0%, 100% { box-shadow: 0 0 0 rgba(122, 181, 255, 0); }
    50% { box-shadow: 0 0 20px rgba(122, 181, 255, 0.14); }
}

@keyframes enigmaSignalFlow {
    from { transform: translateX(-140%); }
    to { transform: translateX(320%); }
}

@keyframes enigmaAnchorDrift {
    0%, 100% { transform: translate(-50%, -50%) translateY(0); }
    50% { transform: translate(-50%, -50%) translateY(-3px); }
}

@keyframes enigmaTileIdle {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-1px); }
}

@keyframes enigmaTileScan {
    0%, 100% { transform: translateX(-120%) rotate(0deg); opacity: 0; }
    18% { opacity: 0.65; }
    50% { transform: translateX(120%) rotate(0deg); opacity: 0.65; }
    100% { opacity: 0; }
}

@keyframes enigmaBinaryGlow {
    0%, 100% { text-shadow: 0 0 0 rgba(120, 188, 255, 0); }
    50% { text-shadow: 0 0 14px rgba(120, 188, 255, 0.24); }
}

@media (prefers-reduced-motion: reduce) {
    .enigma-plate,
    .enigma-zone.current,
    .enigma-phase-node.active,
    .enigma-phase-node.complete,
    .enigma-harmonic-node,
    .enigma-path-cell.visible,
    .enigma-path-cell.traced,
    .enigma-path-cell.next,
    .enigma-weight-pad,
    .enigma-weight-block,
    .enigma-zone.waiting,
    .enigma-zone.recursive,
    .enigma-connection-line::after,
    .enigma-knot-line::after,
    .enigma-node-anchor,
    .enigma-network-tile,
    .enigma-network-tile::after,
    .binary-display span {
        animation: none !important;
    }
}

.reward-copy {
    margin-top: 14px;
}

.enigma-game-message {
    max-width: 620px;
    margin: 80px auto;
    text-align: center;
}

.enigma-game-message .loader {
    margin: 0 auto 16px;
}

.enigma-end-card {
    max-width: 920px;
    margin: 0 auto;
}

.enigma-end-grid.compact {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-top: 14px;
}

.seed-preview {
    display: block;
    white-space: normal;
    overflow-wrap: anywhere;
    font-size: 0.9rem;
}

.enigma-form-block {
    margin-top: 20px;
}

.enigma-end-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 24px;
}

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

    .enigma-room-stage {
        aspect-ratio: 16 / 9;
        min-height: 0;
    }

    .enigma-sidebar {
        grid-template-columns: 1fr;
        grid-template-areas:
            "summary"
            "puzzle";
    }

    .enigma-sidebar-summary {
        position: relative;
        top: auto;
    }

    .enigma-puzzle-guide {
        grid-template-columns: 1fr;
    }

    .coop-puzzle-summary {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .enigma-room-meta,
    .enigma-room-footer,
    .enigma-end-actions {
        flex-direction: column;
    }

    .enigma-room-meta-grid,
    .enigma-stat-grid,
    .enigma-end-grid,
    .enigma-end-grid.compact,
    .enigma-sidebar,
    .enigma-sidebar-summary,
    .enigma-status-metrics {
        grid-template-columns: 1fr;
    }

    .enigma-room-stage {
        aspect-ratio: 16 / 9;
        min-height: 0;
    }

    .coop-puzzle-summary-metrics,
    .coop-puzzle-key-grid {
        grid-template-columns: 1fr;
    }

    .coop-catalog-list-item {
        flex-direction: column;
        align-items: flex-start;
    }

    .enigma-option-grid,
    .enigma-direction-grid,
    .enigma-yarn-grid {
        grid-template-columns: 1fr 1fr;
    }

    .enigma-coop-v2-hud-grid,
    .enigma-coop-v2-action-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 540px) {
    .enigma-sidebar-card,
    .enigma-end-card {
        padding: 18px;
    }

    .enigma-room-hud,
    .enigma-room-banner {
        font-size: 0.75rem;
    }

    .enigma-room-banner {
        min-width: calc(100% - 24px);
        top: 56px;
    }
}

.hero-panel {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
}

.hero-metric-ribbon {
    display: grid;
    grid-template-columns: repeat(3, minmax(120px, 1fr));
    gap: 12px;
    min-width: min(100%, 420px);
}

.hero-metric-ribbon div {
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 18px;
    padding: 14px 16px;
}

.hero-metric-ribbon span,
.profile-eyebrow,
.profile-kicker {
    display: block;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #8fb7ff;
}

.hero-metric-ribbon strong {
    display: block;
    font-size: 1.35rem;
    margin-top: 6px;
}

.profile-shell,
.leaderboard-shell {
    display: grid;
    gap: 24px;
}

.profile-banner,
.leaderboard-banner {
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
    padding: 28px;
    border: 1px solid rgba(124, 166, 255, 0.16);
    border-radius: 28px;
    background:
        radial-gradient(circle at top left, rgba(0, 120, 242, 0.26), transparent 36%),
        linear-gradient(135deg, rgba(16, 24, 38, 0.95), rgba(23, 30, 46, 0.88));
    box-shadow: 0 30px 60px rgba(0, 0, 0, 0.24);
}

.profile-banner h1,
.leaderboard-banner h1 {
    margin: 10px 0 8px;
    font-size: clamp(2rem, 4vw, 3.25rem);
    letter-spacing: -0.04em;
}

.profile-banner p,
.leaderboard-banner p {
    max-width: 720px;
    margin: 0;
    color: var(--epic-text);
    font-size: 1rem;
}

.profile-balance-card {
    min-width: 240px;
    padding: 20px 22px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
}

.app-shell-header {
    gap: 16px;
    justify-content: space-between;
    flex-wrap: wrap;
}

.app-shell-brand,
.app-shell-nav,
.app-shell-account,
.leaderboard-mode-toggle,
.player-podium-metrics,
.leaderboard-player-cell {
    display: flex;
    align-items: center;
    gap: 12px;
}

.app-shell-brand {
    flex-wrap: wrap;
}

.app-shell-brand-copy {
    display: grid;
    gap: 2px;
}

.app-shell-brand-tag {
    color: rgba(255, 255, 255, 0.58);
    font-size: 0.74rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.app-brand-button {
    padding: 0;
    border: none;
    background: none;
    color: var(--epic-text);
    font: inherit;
    font-size: 1.35rem;
    font-weight: 800;
    letter-spacing: -0.04em;
    cursor: pointer;
}

.app-brand-button:hover {
    color: #9ad4ff;
}

.app-shell-nav {
    flex-wrap: wrap;
    padding: 6px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.app-shell-nav .nav-link {
    padding: 10px 14px;
    border-radius: 999px;
    color: rgba(255, 255, 255, 0.68);
    font-size: 0.92rem;
}

.app-shell-nav .nav-link:hover {
    color: #ffffff;
    background: rgba(255, 255, 255, 0.08);
}

.app-shell-nav .nav-link.active {
    color: #06111f;
    background: linear-gradient(135deg, #9bd8ff, #5eb5ff);
    box-shadow: 0 10px 22px rgba(78, 164, 255, 0.18);
}

.app-shell-account {
    position: relative;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.app-shell-balance-chip {
    display: grid;
    gap: 4px;
    min-width: 164px;
    padding: 12px 16px;
    border-radius: 18px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.05);
    color: #ffffff;
    text-align: left;
}

.app-shell-balance-chip span {
    color: rgba(255, 255, 255, 0.62);
    font-size: 0.72rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.app-shell-balance-chip strong {
    font-size: 1rem;
    letter-spacing: -0.03em;
}

.app-shell-user-chip {
    display: grid;
    gap: 2px;
    min-width: 152px;
    padding: 12px 16px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.05);
    color: #ffffff;
    text-align: left;
    cursor: pointer;
}

.app-shell-user-chip strong {
    font-size: 1rem;
    letter-spacing: -0.03em;
}

.app-shell-user-kicker {
    color: rgba(255, 255, 255, 0.62);
    font-size: 0.72rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.app-shell-user-chip:hover {
    border-color: rgba(154, 212, 255, 0.28);
    background: rgba(154, 212, 255, 0.08);
}

.app-shell-account-menu {
    position: absolute;
    top: calc(100% + 12px);
    right: 0;
    min-width: 220px;
    display: grid;
    gap: 8px;
    padding: 10px;
    border-radius: 20px;
    border: 1px solid rgba(143, 183, 255, 0.14);
    background:
        linear-gradient(180deg, rgba(18, 25, 39, 0.98), rgba(10, 14, 24, 0.98));
    box-shadow: 0 22px 44px rgba(0, 0, 0, 0.34);
    z-index: 1010;
}

.app-shell-account-link {
    width: 100%;
    min-height: 46px;
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    padding: 0 14px;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    background: rgba(255, 255, 255, 0.04);
    color: var(--epic-text);
    font: inherit;
    font-weight: 700;
    cursor: pointer;
    transition: transform 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}

.app-shell-account-link:hover {
    transform: translateY(-1px);
    background: rgba(154, 212, 255, 0.09);
    border-color: rgba(154, 212, 255, 0.2);
}

.app-shell-account-link.danger {
    color: #ffd0cb;
    background: rgba(231, 76, 60, 0.12);
    border-color: rgba(231, 76, 60, 0.16);
}

.app-shell-account-link.danger:hover {
    background: rgba(231, 76, 60, 0.2);
    border-color: rgba(231, 76, 60, 0.28);
}

.app-logout-button {
    min-width: 100px;
}

.app-back-button {
    min-width: 84px;
}

.app-shell-content {
    padding-top: 18px;
}

.enigma-modal-backdrop {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(4, 8, 14, 0.76);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
}

.enigma-modal-card {
    width: min(620px, calc(100vw - 32px));
    max-height: calc(100vh - 48px);
    overflow: auto;
    display: grid;
    gap: 16px;
    padding: 28px;
    border-radius: 24px;
    border: 1px solid rgba(143, 183, 255, 0.14);
    background:
        linear-gradient(180deg, rgba(16, 24, 38, 0.98), rgba(10, 14, 24, 0.98));
    box-shadow: 0 28px 60px rgba(0, 0, 0, 0.36);
}

.hero-subcopy {
    margin: 10px 0 0;
    color: var(--epic-text);
    font-size: 0.98rem;
}

.profile-balance-card span,
.profile-balance-card small {
    display: block;
    color: rgba(255, 255, 255, 0.72);
}

.profile-balance-card strong {
    display: block;
    margin: 10px 0 4px;
    font-size: 2.2rem;
    letter-spacing: -0.05em;
}

.profile-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
    gap: 24px;
}

.profile-identity-card,
.profile-stats-panel,
.profile-list-panel,
.profile-maps-panel,
.leaderboard-pagination-panel,
.leaderboard-controls-panel,
.leaderboard-table-panel,
.leaderboard-empty-panel {
    border-radius: 24px;
    padding: 24px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.02), rgba(255, 255, 255, 0.01)),
        #171a22;
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.18);
}

.profile-identity-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 20px;
    align-items: center;
}

.profile-avatar-large,
.chip-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #ffffff;
    background: linear-gradient(135deg, #0c8dff, #00c2ff);
}

.profile-avatar-large {
    width: 84px;
    height: 84px;
    border-radius: 26px;
    font-size: 1.5rem;
    box-shadow: 0 18px 40px rgba(12, 141, 255, 0.24);
}

.profile-identity-card h2,
.profile-stats-panel h2,
.profile-list-panel h2,
.profile-maps-panel h2,
.leaderboard-table-panel h2 {
    margin: 6px 0 8px;
    font-size: 1.45rem;
}

.profile-subcopy {
    margin: 0;
    color: rgba(255, 255, 255, 0.68);
}

.profile-mini-grid,
.podium-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.profile-mini-grid {
    grid-column: 1 / -1;
}

.profile-mini-grid div,
.podium-metrics div,
.owned-map-footer div {
    padding: 14px 16px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.profile-mini-grid span,
.profile-stat-card span,
.podium-metrics span,
.owned-map-footer span,
.leaderboard-map-cell span {
    display: block;
    color: rgba(255, 255, 255, 0.62);
    font-size: 0.82rem;
}

.profile-mini-grid strong,
.profile-stat-card strong,
.podium-metrics strong,
.owned-map-footer strong {
    display: block;
    margin-top: 4px;
    font-size: 1.1rem;
}

.panel-heading,
.maps-heading {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
}

.section-count {
    min-width: 132px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: rgba(12, 141, 255, 0.16);
    color: #a8d4ff;
    font-weight: 700;
    padding: 0 18px;
    letter-spacing: 0.01em;
}

.profile-stat-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.profile-stat-card {
    padding: 18px;
    border-radius: 20px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    background: rgba(255, 255, 255, 0.03);
}

.profile-stat-card strong {
    font-size: 2rem;
    letter-spacing: -0.05em;
}

.accent-blue { box-shadow: inset 0 0 0 1px rgba(12, 141, 255, 0.14); }
.accent-green { box-shadow: inset 0 0 0 1px rgba(46, 204, 113, 0.18); }
.accent-red { box-shadow: inset 0 0 0 1px rgba(231, 76, 60, 0.18); }
.accent-gold { box-shadow: inset 0 0 0 1px rgba(243, 156, 18, 0.18); }

.list-stack {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.list-chip {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.list-chip.pending {
    background: rgba(243, 156, 18, 0.12);
    border-color: rgba(243, 156, 18, 0.18);
}

.chip-avatar {
    width: 36px;
    height: 36px;
    border-radius: 999px;
    font-size: 0.82rem;
}

.chip-avatar.warm {
    background: linear-gradient(135deg, #ff9f43, #f6d365);
    color: #1a1a1a;
}

.empty-state-inline {
    padding: 18px;
    border-radius: 18px;
    color: rgba(255, 255, 255, 0.7);
    background: rgba(255, 255, 255, 0.03);
    border: 1px dashed rgba(255, 255, 255, 0.08);
}

.profile-banner-actions,
.profile-primary-actions,
.profile-request-stack,
.marketplace-shell,
.marketplace-banner-metrics,
.marketplace-top-grid,
.marketplace-bullet-list,
.catalog-card-body,
.catalog-card-meta,
.marketplace-card-footer,
.leaderboard-podium-links {
    display: grid;
    gap: 14px;
}

.marketplace-shell {
    gap: 24px;
}

.marketplace-banner {
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
    padding: 28px;
    border: 1px solid rgba(124, 166, 255, 0.16);
    border-radius: 28px;
    background:
        radial-gradient(circle at top left, rgba(0, 120, 242, 0.26), transparent 36%),
        linear-gradient(135deg, rgba(16, 24, 38, 0.95), rgba(23, 30, 46, 0.88));
    box-shadow: 0 30px 60px rgba(0, 0, 0, 0.24);
}

.marketplace-banner h1 {
    margin: 10px 0 8px;
    font-size: clamp(2rem, 4vw, 3.25rem);
    letter-spacing: -0.04em;
}

.marketplace-banner p {
    max-width: 720px;
    margin: 0;
    color: var(--epic-text);
    font-size: 1rem;
}

.marketplace-banner-metrics {
    grid-template-columns: repeat(4, minmax(140px, 1fr));
    min-width: min(100%, 640px);
}

.marketplace-banner-metrics div {
    padding: 18px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.marketplace-banner-metrics span {
    display: block;
    color: rgba(255, 255, 255, 0.66);
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.marketplace-banner-metrics strong {
    display: block;
    margin-top: 8px;
    font-size: 1.45rem;
}

.profile-banner-actions {
    align-items: end;
    min-width: min(100%, 320px);
}

.profile-primary-actions {
    grid-template-columns: repeat(2, minmax(0, max-content));
    align-items: center;
}

.players-shell,
.players-search-box,
.players-results-grid,
.top-player-metrics {
    display: grid;
    gap: 18px;
}

.players-shell {
    gap: 24px;
}

.players-banner {
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
    padding: 28px;
    border: 1px solid rgba(124, 166, 255, 0.16);
    border-radius: 28px;
    background:
        radial-gradient(circle at top left, rgba(0, 120, 242, 0.26), transparent 36%),
        linear-gradient(135deg, rgba(16, 24, 38, 0.95), rgba(23, 30, 46, 0.88));
    box-shadow: 0 30px 60px rgba(0, 0, 0, 0.24);
}

.players-banner h1 {
    margin: 10px 0 8px;
    font-size: clamp(2rem, 4vw, 3.25rem);
    letter-spacing: -0.04em;
}

.players-banner p {
    max-width: 720px;
    margin: 0;
    color: var(--epic-text);
    font-size: 1rem;
}

.players-banner-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    min-width: min(100%, 420px);
}

.players-banner-metrics div,
.top-player-metrics div {
    padding: 18px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.players-banner-metrics span,
.top-player-metrics span,
.players-search-copy p {
    color: var(--epic-text);
}

.players-banner-metrics strong {
    display: block;
    margin-top: 8px;
    font-size: 1.4rem;
}

.players-search-panel,
.players-top-panel {
    padding: 28px;
}

.players-search-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
}

.players-search-hint {
    margin: 0;
    color: var(--epic-text);
    font-size: 0.9rem;
}

.players-search-status {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    color: var(--epic-text);
}

.map-search-shell {
    display: grid;
    gap: 14px;
}

.map-search-row {
    align-items: start;
}

.map-search-results-grid {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.map-search-result-card {
    width: 100%;
    border: 1px solid rgba(255, 255, 255, 0.07);
    text-align: left;
    color: inherit;
    cursor: pointer;
    transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.map-search-result-card:hover,
.map-search-result-card:focus-visible {
    transform: translateY(-1px);
    border-color: rgba(126, 184, 255, 0.24);
    box-shadow: 0 16px 32px rgba(0, 0, 0, 0.2);
}

.map-search-result-card:focus-visible {
    outline: none;
}

.map-search-card-top {
    align-items: stretch;
}

.map-search-avatar-frame {
    width: 78px;
    min-width: 78px;
    height: 78px;
    padding: 8px;
    border-radius: 18px;
}

.map-search-copy {
    min-width: 0;
}

.map-search-copy strong {
    display: block;
    font-size: 1.08rem;
    line-height: 1.15;
    color: #f8fbff;
}

.map-search-copy p {
    margin: 0;
    font-size: 0.94rem;
    font-weight: 700;
}

.map-search-copy .leaderboard-secondary-text {
    display: block;
    font-size: 0.85rem;
    line-height: 1.35;
}

.map-search-empty-state {
    width: 100%;
    margin-top: 2px;
}

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

.player-search-card {
    position: relative;
    display: grid;
    gap: 16px;
    padding: 20px;
    border-radius: 22px;
    background:
        radial-gradient(circle at top left, rgba(0, 120, 242, 0.14), transparent 40%),
        rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.07);
}

.player-search-card-top {
    display: flex;
    align-items: center;
    gap: 14px;
}

.player-search-avatar {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.05rem;
    font-weight: 800;
    color: #eff8ff;
    background: linear-gradient(135deg, #2f80ed, #56ccf2);
    box-shadow: 0 12px 24px rgba(46, 115, 255, 0.22);
}

.player-search-copy {
    display: grid;
    gap: 4px;
}

.player-search-copy p {
    margin: 0;
    font-size: 0.92rem;
}

.player-search-name {
    font-size: 1.15rem;
    font-weight: 800;
    letter-spacing: -0.03em;
}

.player-search-actions {
    display: flex;
    justify-content: flex-start;
}

.players-empty-state {
    padding: 22px;
    border-radius: 22px;
    border: 1px dashed rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.03);
}

.players-empty-state h3,
.players-empty-state p {
    margin-top: 0;
}

.players-empty-state p {
    color: var(--epic-text);
}

.top-player-grid {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.top-player-card {
    padding-top: 56px;
}

.top-player-rank {
    position: absolute;
    top: 18px;
    right: 18px;
    min-width: 46px;
    height: 46px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: rgba(12, 141, 255, 0.16);
    color: #a8d4ff;
    font-weight: 800;
}

.top-player-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.top-player-metrics strong {
    display: block;
    margin-top: 6px;
    font-size: 1.2rem;
}

.profile-status-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 16px;
    border-radius: 999px;
    font-weight: 700;
    background: rgba(255, 255, 255, 0.08);
    color: #dbe7ff;
}

.profile-status-pill.success {
    background: rgba(46, 204, 113, 0.16);
    color: #9ff2c0;
}

.profile-status-pill.warning {
    background: rgba(243, 156, 18, 0.16);
    color: #ffd18a;
}

.list-chip-button {
    cursor: pointer;
    color: inherit;
    text-align: left;
}

.profile-request-stack {
    gap: 12px;
}

.profile-request-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.catalog-card-grid,
.owned-map-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 320px));
    gap: 18px;
    justify-content: start;
}

.catalog-card,
.owned-map-card,
.marketplace-card {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 14px;
    border-radius: 24px;
    background: #11151e;
    border: 1px solid rgba(255, 255, 255, 0.06);
    box-shadow: 0 16px 36px rgba(0, 0, 0, 0.2);
    max-width: 320px;
    width: 100%;
}

.catalog-card-body {
    align-content: start;
    gap: 10px;
}

.catalog-card-kicker {
    display: block;
    color: #8fb7ff;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.catalog-card-price {
    display: block;
    font-size: 1.55rem;
    letter-spacing: -0.04em;
    color: #ffffff;
}

.catalog-card-meta {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.catalog-card-meta-pill {
    padding: 12px 14px;
    border-radius: 16px;
    font-size: 0.84rem;
    color: rgba(255, 255, 255, 0.72);
    background: rgba(255, 255, 255, 0.04);
    display: inline-flex;
    align-items: center;
}

.catalog-card-meta-pill.limited {
    color: #ffe2a4;
    background: rgba(243, 156, 18, 0.16);
    border: 1px solid rgba(243, 156, 18, 0.22);
}

.catalog-card-meta .difficulty-badge {
    justify-self: start;
    align-self: center;
}

.map-link-button {
    padding: 0;
    margin: 0;
    border: none;
    background: none;
    color: #ffffff;
    font: inherit;
    text-align: left;
    cursor: pointer;
}

.map-link-button:hover {
    color: #9ad4ff;
    text-decoration: underline;
}

.catalog-card-title-button {
    font-size: 1.25rem;
    font-weight: 800;
    letter-spacing: -0.03em;
    line-height: 1.15;
}

.catalog-card-subline {
    margin: 0;
    color: var(--epic-text);
    font-size: 0.9rem;
    min-height: 1.2em;
}

.map-art-frame {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    overflow: hidden;
    padding: 18px;
    border-radius: 22px;
    border: none;
}

.map-art-frame.poster {
    aspect-ratio: 1 / 1;
    max-width: 100%;
    max-height: 320px;
    margin: 0 auto;
    border-radius: 10px;
}

.map-art-frame.thumb {
    width: 88px;
    aspect-ratio: 1 / 1;
    padding: 10px;
    border-radius: 18px;
    border-radius: 10px;
}

.map-art-frame.podium-art {
    aspect-ratio: 1 / 1;
    margin-top: 14px;
    max-height: 280px;
    border-radius: 30px;
}

.map-art-image {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    background: transparent;
    border-radius: 5px;
}

.map-art-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: #ffffff;
    font-weight: 700;
    line-height: 1.3;
    padding: 12px;
    background:
        radial-gradient(circle at top left, rgba(12, 141, 255, 0.44), transparent 34%),
        linear-gradient(135deg, #1f3558, #11151e);
}

.owned-map-media.placeholder,
.leaderboard-thumb.placeholder {
    display: flex;
    align-items: end;
    justify-content: start;
    padding: 16px;
    color: #ffffff;
    font-weight: 700;
    background:
        radial-gradient(circle at top left, rgba(12, 141, 255, 0.44), transparent 34%),
        linear-gradient(135deg, #1f3558, #11151e);
}

.owned-map-body {
    display: grid;
    gap: 16px;
    padding: 20px;
}

.owned-map-header {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 16px;
}

.owned-map-header h3 {
    margin: 0 0 4px;
    font-size: 1.2rem;
}

.owned-map-header p,
.leaderboard-map-cell strong + span {
    margin: 0;
    color: var(--epic-text);
}

.owned-map-meta-row,
.leaderboard-controls-grid {
    display: grid;
    gap: 14px;
}

.owned-map-meta-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.owned-map-meta-row.compact-two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.owned-map-meta-row span {
    padding: 12px 14px;
    border-radius: 16px;
    font-size: 0.84rem;
    color: rgba(255, 255, 255, 0.72);
    background: rgba(255, 255, 255, 0.04);
}

.owned-map-footer {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.leaderboard-controls-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: end;
}

.marketplace-top-grid {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
}

.marketplace-sell-panel-priority {
    display: grid;
    gap: 14px;
    border: 1px solid rgba(128, 178, 255, 0.2);
    background:
        radial-gradient(circle at top right, rgba(92, 150, 255, 0.12), transparent 45%),
        linear-gradient(180deg, rgba(18, 24, 38, 0.92), rgba(12, 17, 27, 0.95));
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.2);
}

.marketplace-seller-copy {
    margin: 6px 0 0;
    color: rgba(204, 220, 243, 0.84);
    font-size: 0.92rem;
}

.marketplace-seller-status-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.marketplace-seller-note {
    margin: 0;
}

.marketplace-protocol-panel {
    display: grid;
    gap: 16px;
}

.marketplace-protocol-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.marketplace-protocol-card {
    display: grid;
    gap: 8px;
    padding: 16px;
    border-radius: 16px;
    border: 1px solid rgba(130, 178, 255, 0.16);
    background:
        radial-gradient(circle at top right, rgba(82, 141, 242, 0.14), transparent 42%),
        rgba(255, 255, 255, 0.03);
}

.marketplace-protocol-kicker {
    display: inline-flex;
    width: fit-content;
    padding: 4px 10px;
    border-radius: 999px;
    background: rgba(56, 111, 203, 0.24);
    border: 1px solid rgba(114, 170, 255, 0.28);
    color: rgba(208, 226, 251, 0.9);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    align-items: center;
    justify-content: center;
    text-align: center;
    line-height: 1.1;
}

.marketplace-protocol-card h3 {
    margin: 0;
    font-size: 1.04rem;
}

.marketplace-protocol-card p {
    margin: 0;
    color: rgba(214, 226, 244, 0.84);
    line-height: 1.45;
}

.marketplace-results-copy {
    margin: 0;
    color: rgba(209, 224, 245, 0.85);
    font-size: 0.94rem;
}

.marketplace-sell-form {
    display: grid;
    gap: 16px;
}

.marketplace-bullet-list div {
    padding: 14px 16px;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.78);
}

.marketplace-card-footer {
    grid-template-columns: minmax(0, 1fr);
    gap: 8px;
}

.marketplace-browse-panel {
    display: grid;
    gap: 18px;
    margin-bottom: 18px;
}

.marketplace-item-filter-panel {
    margin-bottom: 20px;
}

.marketplace-filter-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 14px;
}

.marketplace-filter-grid-map .marketplace-filter-search {
    grid-column: span 2;
}

.marketplace-filter-grid .form-label {
    margin-bottom: 6px;
}

.marketplace-filter-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.marketplace-active-filter-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.marketplace-filter-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid rgba(126, 178, 255, 0.24);
    background: rgba(73, 122, 209, 0.16);
    color: rgba(220, 236, 255, 0.92);
    font-size: 0.8rem;
    font-weight: 700;
    text-align: center;
    line-height: 1.1;
}

.marketplace-filter-pill.muted {
    border-color: rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.04);
    color: rgba(200, 217, 239, 0.78);
}

.marketplace-grid-featured {
    grid-template-columns: minmax(0, 760px);
    justify-content: center;
}

.marketplace-grid-expanded {
    grid-template-columns: repeat(2, minmax(260px, 420px));
}

.marketplace-card-featured {
    max-width: 760px;
    padding: 18px;
}

.marketplace-card-heading-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
}

.marketplace-listed-at-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: rgba(200, 219, 244, 0.9);
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.12);
    text-align: center;
    line-height: 1.1;
}

.marketplace-listing-chip-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}

.marketplace-listing-chip-row .catalog-card-meta-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 0 12px;
    text-align: center;
    line-height: 1.1;
}

.marketplace-listing-chip-row .difficulty-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    line-height: 1.1;
}

.marketplace-price-hero {
    margin-top: 2px;
    font-size: clamp(1.4rem, 2vw, 1.75rem);
}

.marketplace-card-warning {
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid rgba(255, 184, 76, 0.35);
    background: rgba(186, 123, 28, 0.18);
    color: rgba(255, 215, 161, 0.95);
    font-size: 0.85rem;
    line-height: 1.4;
}

.marketplace-last-sale {
    color: rgba(255, 255, 255, 0.62);
    font-size: 0.82rem;
}

.marketplace-owner-tools {
    display: grid;
    gap: 12px;
    margin-top: 4px;
}

.marketplace-owner-stepper .form-label {
    margin-bottom: 6px;
}

.marketplace-owner-actions {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.inline-link-button {
    padding: 0;
    border: none;
    background: none;
    color: #9ad4ff;
    font: inherit;
    text-align: left;
    cursor: pointer;
}

.inline-link-button:hover {
    color: #c3e4ff;
    text-decoration: underline;
}

.inline-link-button.compact {
    font-size: 0.82rem;
    color: rgba(154, 212, 255, 0.9);
}

.leaderboard-user-link {
    width: fit-content;
    font-weight: 600;
}

.leaderboard-actions {
    display: flex;
    justify-content: end;
}

.leaderboard-pagination-panel {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    flex-wrap: wrap;
    margin-top: 20px;
    padding-block: 18px;
}

.leaderboard-pagination-summary {
    margin: 0;
    font-size: 0.98rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    color: rgba(227, 239, 255, 0.88);
}

.leaderboard-pagination {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.leaderboard-page-button {
    min-width: 48px;
    padding-inline: 14px;
}

.leaderboard-mode-toggle {
    margin-bottom: 18px;
    flex-wrap: wrap;
}

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

.player-podium {
    align-items: stretch;
}

.player-podium-card {
    display: grid;
    align-content: start;
    gap: 16px;
    min-height: 420px;
    text-align: left;
}

.player-podium-avatar,
.player-table-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    font-weight: 800;
    letter-spacing: 0.08em;
    color: #ffffff;
    background: linear-gradient(135deg, #0c8dff, #00c2ff);
}

.player-podium-avatar {
    width: 82px;
    height: 82px;
    margin-top: 14px;
    font-size: 1.25rem;
    box-shadow: 0 16px 36px rgba(12, 141, 255, 0.22);
}

.player-table-avatar {
    width: 48px;
    height: 48px;
    font-size: 0.9rem;
}

.podium-card {
    padding: 24px;
    border-radius: 24px;
    background:
        radial-gradient(circle at top right, rgba(255, 255, 255, 0.08), transparent 28%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(17, 21, 30, 0.96));
    border: 1px solid rgba(255, 255, 255, 0.06);
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.22);
}

.podium-card h2 {
    margin: 14px 0 6px;
    font-size: 1.5rem;
}

.podium-map-title {
    margin-top: 14px;
    font-size: 1.45rem;
    font-weight: 800;
    letter-spacing: -0.04em;
}

.podium-card p {
    margin: 0 0 18px;
    color: var(--epic-text);
    line-height: 1.45;
}

.leaderboard-podium-links {
    margin-top: 18px;
}

.podium-best-time-card {
    background: linear-gradient(180deg, rgba(12, 141, 255, 0.14), rgba(255, 255, 255, 0.03));
    box-shadow: inset 0 0 0 1px rgba(12, 141, 255, 0.18);
    min-width: 0;
}

.podium-best-time-card strong {
    font-variant-numeric: tabular-nums;
    font-size: clamp(1.08rem, 1.7vw, 1.3rem);
    line-height: 1.18;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.podium-record-link {
    margin-top: 8px;
}

.podium-rank {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 54px;
    height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    font-weight: 800;
    background: rgba(255, 255, 255, 0.08);
}

.rank-1 { box-shadow: inset 0 0 0 1px rgba(246, 213, 101, 0.28); }
.rank-2 { box-shadow: inset 0 0 0 1px rgba(196, 204, 214, 0.26); }
.rank-3 { box-shadow: inset 0 0 0 1px rgba(255, 159, 67, 0.26); }

.leaderboard-table-wrap {
    overflow-x: auto;
    border-radius: 20px;
    background: rgba(9, 13, 22, 0.75);
}

.leaderboard-table {
    width: 100%;
    border-collapse: collapse;
}

.leaderboard-table th,
.leaderboard-table td {
    padding: 20px 14px;
    text-align: left;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    vertical-align: middle;
    line-height: 1.35;
}

.leaderboard-table th {
    color: rgba(255, 255, 255, 0.74);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.leaderboard-table td {
    color: rgba(255, 255, 255, 0.9);
}

.leaderboard-table tbody tr {
    background: rgba(255, 255, 255, 0.015);
}

.leaderboard-table tbody tr:nth-child(even) {
    background: rgba(255, 255, 255, 0.03);
}

.leaderboard-rank-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 54px;
    height: 34px;
    border-radius: 999px;
    background: rgba(12, 141, 255, 0.12);
    color: #9ad4ff;
    font-weight: 700;
}

.leaderboard-map-cell {
    display: grid;
    grid-template-columns: 84px minmax(0, 1fr);
    gap: 14px;
    align-items: start;
}

.leaderboard-player-cell {
    gap: 16px;
    min-width: 0;
}

.leaderboard-thumb {
    width: 72px;
    height: 72px;
    border-radius: 18px;
    background-size: cover;
    background-position: center;
}

.difficulty-default {
    background: rgba(255, 255, 255, 0.08);
}

.leaderboard-map-copy,
.leaderboard-stat-cell,
.leaderboard-time-cell {
    display: grid;
    gap: 4px;
    min-width: 0;
}

.leaderboard-map-title {
    font-size: 1rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.2;
}

.leaderboard-theme-text {
    color: var(--epic-text);
    font-size: 0.84rem;
}

.leaderboard-secondary-text {
    color: var(--epic-text);
    font-size: 0.82rem;
}

.leaderboard-meta-link {
    width: fit-content;
}

.leaderboard-stat-cell strong,
.leaderboard-time-cell strong {
    font-size: 1.08rem;
    font-variant-numeric: tabular-nums;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.leaderboard-time-cell strong {
    color: #f4fbff;
    line-height: 1.15;
}

.player-podium-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: stretch;
}

.player-podium-metrics div,
.leaderboard-stat-cell,
.leaderboard-time-cell {
    min-height: 112px;
    align-content: start;
}

.leaderboard-table .leaderboard-stat-cell,
.leaderboard-table .leaderboard-time-cell {
    min-height: 0;
}

.leaderboard-table .leaderboard-player-cell .leaderboard-map-copy {
    gap: 6px;
}

@media (max-width: 1120px) {
    .profile-layout,
    .leaderboard-podium,
    .marketplace-top-grid {
        grid-template-columns: 1fr;
    }

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

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

    .marketplace-filter-grid-map .marketplace-filter-search {
        grid-column: 1 / -1;
    }

    .marketplace-banner-metrics {
        grid-template-columns: repeat(2, minmax(140px, 1fr));
        min-width: 0;
    }

    .leaderboard-controls-grid {
        grid-template-columns: 1fr 1fr;
    }

    .leaderboard-actions {
        grid-column: 1 / -1;
        justify-content: stretch;
    }

    .leaderboard-actions .btn {
        width: 100%;
    }
}

@media (max-width: 820px) {
    .app-shell-header,
    .app-shell-brand,
    .app-shell-nav,
    .app-shell-account {
        display: flex;
        flex-direction: column;
        align-items: stretch;
    }

    .app-shell-account {
        width: 100%;
    }

    .app-shell-account-menu {
        position: static;
        width: 100%;
        min-width: 0;
    }

    .app-shell-nav .nav-link {
        width: 100%;
    }

    .app-shell-user-chip,
    .app-shell-balance-chip {
        width: 100%;
    }

    .hero-metric-ribbon,
    .marketplace-banner-metrics,
    .players-banner-metrics,
    .profile-mini-grid,
    .profile-stat-grid,
    .owned-map-meta-row,
    .owned-map-footer,
    .podium-metrics,
    .leaderboard-controls-grid,
    .top-player-metrics {
        grid-template-columns: 1fr;
    }

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

    .profile-primary-actions,
    .players-search-row {
        grid-template-columns: 1fr;
    }

    .marketplace-filter-grid {
        grid-template-columns: 1fr;
    }

    .leaderboard-map-cell {
        grid-template-columns: 72px minmax(0, 1fr);
    }

    .leaderboard-player-cell {
        align-items: flex-start;
    }
}

@media (max-width: 560px) {
    .profile-banner,
    .leaderboard-banner,
    .marketplace-banner,
    .players-banner,
    .profile-identity-card,
    .profile-stats-panel,
    .profile-list-panel,
    .profile-maps-panel,
    .leaderboard-pagination-panel,
    .leaderboard-controls-panel,
    .leaderboard-table-panel,
    .leaderboard-empty-panel,
    .players-search-panel,
    .players-top-panel,
    .podium-card {
        padding: 20px;
        border-radius: 20px;
    }

    .owned-map-grid {
        grid-template-columns: 1fr;
    }
}
.difficulty-easy {
    background: rgba(46, 204, 113, 0.18);
    color: #8df0b7;
}

.difficulty-medium {
    background: rgba(243, 156, 18, 0.18);
    color: #ffd18a;
}

.difficulty-hard {
    background: rgba(231, 76, 60, 0.18);
    color: #ffb1a7;
}
.profile-release-shell,
.profile-maps-stack,
.profile-settings-stack {
    display: grid;
    gap: 24px;
}

.profile-release-banner,
.profile-banner-main,
.profile-banner-tags,
.profile-release-actions-row,
.profile-tabbar,
.marketplace-tabbar,
.profile-map-actions,
.profile-social-chip,
.profile-inventory-grid,
.profile-settings-form,
.profile-avatar-settings-grid,
.profile-avatar-preview-card,
.profile-avatar-controls,
.profile-crop-grid,
.profile-avatar-slider-block,
.profile-settings-actions-row,
.marketplace-shop-grid,
.marketplace-item-card,
.tutorial-progress-row,
.player-podium-avatar-frame,
.player-table-avatar-frame,
.player-search-avatar-frame {
    display: grid;
    gap: 14px;
}

.profile-release-banner {
    align-items: center;
}

.profile-banner-main {
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
}

.profile-banner-tags {
    display: flex;
    flex-wrap: wrap;
}

.profile-chip {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 0 14px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    color: #dce7ff;
    font-size: 0.88rem;
    font-weight: 700;
}

.profile-tabbar {
    grid-template-columns: repeat(auto-fit, minmax(140px, max-content));
}

.profile-map-tools {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(210px, 260px);
    gap: 12px;
    margin-bottom: 16px;
}

.profile-map-section-nav {
    margin: 0 0 14px;
    padding: 12px 14px;
}

.profile-map-section-nav .leaderboard-pagination {
    justify-content: flex-start;
}

.marketplace-tabbar {
    grid-template-columns: repeat(auto-fit, minmax(160px, max-content));
}

.profile-tab {
    min-height: 46px;
    padding: 0 18px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.04);
    color: rgba(255, 255, 255, 0.76);
    font-weight: 700;
}

.profile-tab.active {
    background: linear-gradient(135deg, #9bd8ff, #5eb5ff);
    color: #06111f;
}

.profile-avatar-frame {
    position: relative;
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 28px;
}

.profile-avatar-presence {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 20px;
    height: 20px;
    border-radius: 999px;
    pointer-events: none;
    z-index: 4;
}

.profile-avatar-presence.online {
    background: #33d17a;
    border: 2px solid rgba(7, 15, 25, 0.92);
    box-shadow: 0 0 0 2px rgba(51, 209, 122, 0.2);
}

.profile-avatar-presence.offline {
    background: rgba(8, 14, 24, 0.85);
    border: 2px solid rgba(200, 208, 224, 0.68);
}

.profile-avatar-crop-shell {
    position: relative;
    width: 100%;
    height: 100%;
    aspect-ratio: 1 / 1;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    padding: 0;
    background: rgba(8, 14, 24, 0.38);
}

.profile-avatar-image {
    display: block;
    position: absolute;
    left: var(--avatar-left, 0);
    top: var(--avatar-top, 0);
    width: calc(var(--avatar-scale, 1) * 100%);
    height: calc(var(--avatar-scale, 1) * 100%);
    max-width: none !important;
    max-height: none !important;
    object-fit: cover;
    object-position: top left;
    z-index: 1;
}

.profile-avatar-fallback {
    font-weight: 800;
    letter-spacing: 0.08em;
    color: #ffffff;
}

.profile-avatar-hero {
    width: 126px;
    height: 126px;
    border-radius: 34px;
}

.profile-avatar-hero .profile-avatar-fallback,
.profile-avatar-preview .profile-avatar-fallback,
.profile-avatar-large-frame .profile-avatar-fallback,
.player-podium-avatar-frame .profile-avatar-fallback,
.player-table-avatar-frame .profile-avatar-fallback,
.player-search-avatar-frame .profile-avatar-fallback {
    background: linear-gradient(135deg, #2f80ed, #56ccf2);
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.profile-avatar-large-frame {
    width: 84px;
    height: 84px;
    border-radius: 24px;
}

.profile-avatar-preview {
    width: 220px;
    height: 220px;
    border-radius: 30px;
}

.profile-social-chip {
    align-items: center;
}

.profile-inventory-grid,
.marketplace-shop-grid {
    grid-template-columns: repeat(auto-fit, minmax(260px, 320px));
    justify-content: start;
}

.profile-inventory-group {
    display: grid;
    gap: 18px;
}

.profile-inventory-panel {
    display: grid;
    gap: 28px;
}

.profile-inventory-subheading {
    margin-bottom: 0;
}

.profile-item-card {
    display: grid;
    gap: 14px;
    padding: 20px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.profile-item-card h3,
.marketplace-item-card h3 {
    margin: 0;
    font-size: 1.2rem;
}

.marketplace-item-topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.profile-item-card p,
.marketplace-item-card p,
.profile-settings-copy {
    margin: 0;
    color: var(--epic-text);
}

.profile-item-top,
.profile-item-meta {
    display: grid;
    gap: 10px;
}

.marketplace-item-requirements {
    display: grid;
    gap: 8px;
    padding: 14px;
    border-radius: 18px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    background: rgba(255, 255, 255, 0.03);
}

.marketplace-requirement-row {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 10px;
    align-items: start;
    font-size: 0.92rem;
}

.marketplace-requirement-row span:first-child {
    min-width: 72px;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #ffb2ad;
}

.marketplace-requirement-row.complete span:first-child {
    color: #8df0bf;
}

.marketplace-item-note {
    font-size: 0.9rem;
    line-height: 1.5;
    color: var(--epic-text);
}

.profile-item-meta,
.profile-crop-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.profile-crop-grid label,
.profile-avatar-controls {
    display: grid;
    gap: 8px;
}

.profile-crop-grid label span {
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.82rem;
}

.profile-avatar-slider-block {
    gap: 10px;
}

    .profile-map-actions,
    .profile-settings-actions-row {
        grid-template-columns: repeat(auto-fit, minmax(160px, max-content));
    }

    .profile-map-tools {
        grid-template-columns: 1fr;
    }

.section-count-small {
    min-width: 36px;
    height: 36px;
}

.profile-danger-panel {
    box-shadow: inset 0 0 0 1px rgba(231, 76, 60, 0.2);
}

.danger-link {
    color: #ff928b;
}

.danger-link:hover {
    color: #ffc0bb;
}

.player-search-avatar-frame {
    width: 58px;
    height: 58px;
    border-radius: 18px;
}

.player-podium-avatar-frame {
    width: 82px;
    height: 82px;
    border-radius: 999px;
    margin-top: 14px;
}

.player-table-avatar-frame {
    width: 48px;
    height: 48px;
    border-radius: 999px;
}

.leaderboard-player-cell {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
}

.marketplace-shop-panel {
    padding: 28px;
}

.marketplace-item-card {
    max-width: 320px;
    cursor: pointer;
    transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.marketplace-item-card:hover {
    transform: translateY(-2px);
    border-color: rgba(111, 169, 255, 0.34);
    box-shadow: 0 18px 38px rgba(0, 0, 0, 0.28);
}

.marketplace-item-card:focus-visible {
    outline: 0;
    border-color: rgba(111, 169, 255, 0.52);
    box-shadow: 0 0 0 2px rgba(94, 181, 255, 0.24);
}

.marketplace-item-open-hint {
    color: #8fb8ff;
    border: 1px solid rgba(94, 181, 255, 0.22);
    background: rgba(42, 94, 176, 0.2);
}

.marketplace-buy-owned,
.marketplace-buy-owned:hover,
.marketplace-buy-owned:active {
    background: rgba(155, 164, 181, 0.24);
    border-color: rgba(193, 203, 222, 0.18);
    color: rgba(233, 239, 252, 0.78);
    box-shadow: none;
    transform: none;
}

.marketplace-buy-owned:disabled {
    opacity: 1;
    cursor: not-allowed;
}

.marketplace-item-overlay-backdrop {
    z-index: 2200;
    background: rgba(4, 10, 18, 0.78);
}

.marketplace-item-overlay-card {
    position: relative;
    width: min(760px, calc(100vw - 28px));
    display: grid;
    gap: 20px;
    padding-top: 70px;
}

.marketplace-item-overlay-head,
.marketplace-item-overlay-section,
.marketplace-item-effect-grid,
.marketplace-item-overlay-actions {
    display: grid;
    gap: 12px;
}

.marketplace-item-overlay-head h2 {
    margin: 0;
    font-size: clamp(1.5rem, 2.3vw, 2rem);
    line-height: 1.05;
}

.marketplace-item-overlay-head p {
    margin: 0;
    color: var(--epic-text);
    font-size: 0.98rem;
    line-height: 1.55;
}

.marketplace-item-overlay-section h3 {
    margin: 0;
    font-size: 1.02rem;
    letter-spacing: 0.02em;
}

.marketplace-item-overlay-list {
    margin: 0;
    padding-left: 20px;
    display: grid;
    gap: 8px;
    color: var(--epic-text);
    line-height: 1.5;
}

.marketplace-item-effect-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.marketplace-item-effect-row {
    display: grid;
    gap: 6px;
    padding: 12px 14px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.07);
}

.marketplace-item-effect-row span {
    color: rgba(220, 232, 255, 0.72);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.07em;
}

.marketplace-item-effect-row strong {
    color: var(--epic-text);
    font-size: 1rem;
}

.marketplace-item-overlay-meta {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.marketplace-item-overlay-actions .btn {
    width: 100%;
}

.marketplace-founder-benefits {
    border: 1px solid rgba(243, 195, 95, 0.22);
    background: linear-gradient(180deg, rgba(243, 195, 95, 0.1), rgba(255, 255, 255, 0.02));
    border-radius: 16px;
    padding: 14px 16px;
}

.marketplace-founder-benefits h3 {
    color: #ffe3a9;
}

.marketplace-faq-collapsible {
    border-radius: 18px;
    border: 1px solid rgba(132, 178, 255, 0.2);
    background:
        radial-gradient(circle at top right, rgba(88, 145, 255, 0.12), transparent 44%),
        linear-gradient(180deg, rgba(16, 23, 36, 0.9), rgba(10, 15, 26, 0.92));
    overflow: hidden;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.2);
}

.marketplace-faq-collapsible summary {
    cursor: pointer;
    list-style: none;
    padding: 15px 18px;
    font-weight: 700;
    color: rgba(227, 239, 255, 0.96);
    letter-spacing: 0.01em;
    display: flex;
    align-items: center;
    gap: 10px;
}

.marketplace-faq-collapsible summary::-webkit-details-marker {
    display: none;
}

.marketplace-faq-collapsible summary::before {
    content: ">";
    color: rgba(154, 194, 255, 0.95);
    transition: transform 0.18s ease;
}

.marketplace-faq-collapsible[open] summary::before {
    transform: rotate(90deg);
}

.marketplace-faq-list {
    margin: 0;
    padding: 0 16px 16px;
    display: grid;
    gap: 10px;
    list-style: none;
    counter-reset: marketplace-faq;
}

.marketplace-faq-list li {
    counter-increment: marketplace-faq;
    position: relative;
    padding: 13px 14px 13px 54px;
    border-radius: 14px;
    border: 1px solid rgba(123, 171, 255, 0.14);
    background: rgba(255, 255, 255, 0.03);
}

.marketplace-faq-list li::before {
    content: counter(marketplace-faq);
    position: absolute;
    left: 14px;
    top: 12px;
    width: 26px;
    height: 26px;
    border-radius: 999px;
    border: 1px solid rgba(117, 169, 255, 0.34);
    background: rgba(66, 119, 211, 0.28);
    color: rgba(220, 236, 255, 0.95);
    font-weight: 700;
    font-size: 0.83rem;
    display: grid;
    place-items: center;
}

.marketplace-faq-list li strong {
    display: block;
    color: rgba(239, 245, 255, 0.96);
    font-size: 0.94rem;
    line-height: 1.3;
}

.marketplace-faq-list li p {
    margin: 6px 0 0;
    color: rgba(208, 222, 242, 0.86);
    font-size: 0.9rem;
    line-height: 1.46;
}

@media (max-width: 760px) {
    .marketplace-item-overlay-card {
        width: min(100%, calc(100vw - 20px));
    }

    .marketplace-protocol-grid,
    .marketplace-grid-expanded,
    .marketplace-grid-featured {
        grid-template-columns: 1fr;
    }

    .marketplace-card-featured {
        max-width: 100%;
    }

    .marketplace-item-overlay-meta,
    .marketplace-item-effect-grid {
        grid-template-columns: 1fr;
    }

    .marketplace-faq-collapsible summary {
        padding: 13px 14px;
        font-size: 0.92rem;
    }

    .marketplace-faq-list {
        padding: 0 12px 12px;
    }

    .marketplace-faq-list li {
        padding: 12px 12px 12px 48px;
    }
}

.tutorial-backdrop {
    inset: auto 24px 24px auto;
    justify-content: flex-end;
    align-items: flex-end;
    padding: 0;
    background: none;
    backdrop-filter: none;
    pointer-events: none;
    z-index: 1200;
}

.tutorial-backdrop-game {
    inset: 24px 24px auto auto;
    align-items: flex-start;
}

.tutorial-modal-card {
    width: min(560px, calc(100vw - 24px));
    max-height: min(84vh, 760px);
    overflow-y: auto;
    padding: 22px;
    background: linear-gradient(180deg, rgba(16, 24, 38, 0.98), rgba(10, 14, 24, 0.98));
    pointer-events: auto;
    box-shadow: 0 26px 54px rgba(0, 0, 0, 0.38);
    display: grid;
    gap: 11px;
}

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

.tutorial-step-chip {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 6px 10px;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #c7dcff;
    border: 1px solid rgba(128, 174, 255, 0.3);
    background: rgba(76, 118, 191, 0.2);
}

.tutorial-route-hint {
    display: grid;
    gap: 4px;
    padding: 9px 12px;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.03);
}

.tutorial-route-hint span {
    font-size: 0.74rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 700;
    color: rgba(186, 208, 238, 0.78);
}

.tutorial-route-hint strong {
    color: #eaf3ff;
    font-size: 0.93rem;
    word-break: break-all;
}

.tutorial-step-rail {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 8px;
}

.tutorial-step-pill {
    display: grid;
    gap: 2px;
    align-items: center;
    justify-items: center;
    border-radius: 12px;
    padding: 7px 8px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.03);
    color: rgba(206, 221, 243, 0.86);
    transition: border-color 0.18s ease, transform 0.18s ease, background-color 0.18s ease;
}

.tutorial-step-pill:hover {
    transform: translateY(-1px);
    border-color: rgba(123, 173, 255, 0.45);
}

.tutorial-step-pill.current {
    border-color: rgba(96, 160, 255, 0.5);
    background: rgba(35, 75, 138, 0.34);
}

.tutorial-step-pill.complete {
    border-color: rgba(92, 198, 152, 0.42);
    background: rgba(35, 99, 74, 0.3);
    color: #d8fdef;
}

.tutorial-step-pill.current.complete {
    border-color: rgba(105, 228, 175, 0.62);
    background: rgba(28, 120, 84, 0.38);
}

.tutorial-step-number {
    font-size: 0.69rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 700;
    color: rgba(183, 203, 231, 0.8);
}

.tutorial-step-name {
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1.2;
    text-align: center;
}

.tutorial-progress-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    color: var(--epic-text);
    font-size: 0.86rem;
    gap: 12px;
}

.tutorial-helper-copy {
    margin: 0;
    font-size: 0.92rem;
    line-height: 1.55;
    color: var(--epic-text);
}

.tutorial-objective-card {
    display: grid;
    gap: 8px;
    padding: 12px;
    border-radius: 14px;
    border: 1px solid rgba(125, 177, 255, 0.26);
    background: linear-gradient(180deg, rgba(19, 34, 58, 0.58), rgba(9, 17, 30, 0.6));
}

.tutorial-objective-card p {
    margin: 0;
    color: #e7efff;
    line-height: 1.45;
}

.tutorial-objective-status {
    display: inline-flex;
    width: fit-content;
    align-items: center;
    border-radius: 999px;
    padding: 4px 10px;
    font-size: 0.78rem;
    font-weight: 700;
    color: #c6dbff;
    background: rgba(85, 133, 214, 0.2);
    border: 1px solid rgba(128, 174, 255, 0.3);
}

.tutorial-objective-status.complete {
    color: #d9ffec;
    background: rgba(48, 165, 114, 0.2);
    border-color: rgba(97, 212, 161, 0.35);
}

.tutorial-progress-track {
    width: 100%;
    height: 8px;
    border-radius: 999px;
    background: rgba(83, 121, 188, 0.24);
    overflow: hidden;
}

.tutorial-progress-fill {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #5ea6ff, #84d0ff);
    transition: width 180ms ease;
}

.tutorial-action-row {
    justify-content: flex-end;
    flex-wrap: wrap;
    row-gap: 8px;
}

.profile-retention-note {
    display: grid;
    gap: 6px;
    padding: 14px 18px;
    margin-top: -4px;
    border-radius: 18px;
    border: 1px solid rgba(243, 156, 18, 0.18);
    background: linear-gradient(180deg, rgba(243, 156, 18, 0.12), rgba(255, 255, 255, 0.03));
}

.profile-retention-note p {
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.5;
}

@media (max-width: 840px) {
    .profile-banner-main,
    .profile-avatar-settings-grid,
    .tutorial-progress-row {
        grid-template-columns: 1fr;
    }

    .tutorial-step-rail {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .tutorial-backdrop,
    .tutorial-backdrop-game {
        inset: auto 12px 12px 12px;
    }

    .tutorial-modal-card {
        width: min(100%, calc(100vw - 24px));
    }

    .profile-avatar-preview {
        width: 180px;
        height: 180px;
    }
}

@media (max-width: 520px) {
    .tutorial-step-rail {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@supports not ((backdrop-filter: blur(2px)) or (-webkit-backdrop-filter: blur(2px))) {
    .app-header {
        background:
            linear-gradient(180deg, rgba(9, 13, 23, 0.99), rgba(9, 13, 23, 0.95)),
            var(--epic-sidebar);
    }

    .enigma-room-hud,
    .enigma-room-banner,
    .profile-balance-card {
        background: rgba(8, 12, 18, 0.9);
    }

    .enigma-modal-backdrop {
        background: rgba(4, 8, 14, 0.92);
    }
}

@supports not ((position: sticky) or (position: -webkit-sticky)) {
    .app-header {
        position: relative;
    }
}

@supports not (aspect-ratio: 1 / 1) {
    .game-card-image,
    .menu-card-media {
        height: 220px;
    }

    .enigma-room-stage {
        height: 82vw;
        max-height: 1080px;
        min-height: 480px;
    }

    .enigma-temporal-wheel {
        height: 320px;
    }

    .map-art-frame.poster {
        height: 320px;
    }

    .map-art-frame.thumb {
        height: 88px;
    }

    .map-art-frame.podium-art {
        height: 280px;
    }

    .profile-avatar-crop-shell {
        height: 240px;
    }
}

.play-header-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.coop-shell {
    display: grid;
    gap: 24px;
}

.coop-session-panel {
    display: grid;
    gap: 20px;
}

.coop-banner,
.coop-session-panel,
.coop-create-panel,
.coop-join-panel {
    border-radius: 24px;
    padding: 26px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.02), rgba(255, 255, 255, 0.01)),
        #171a22;
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.18);
}

.coop-banner,
.coop-form-stack,
.coop-grid,
.coop-session-meta,
.coop-player-stack,
.coop-player-card,
.coop-player-meta,
.coop-inline-form,
.coop-catalog-stack,
.coop-catalog-tier,
.coop-invite-card {
    display: grid;
    gap: 16px;
}

.coop-form-stack {
    gap: 20px;
}

.coop-banner {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
}

.coop-banner > .play-header-actions {
    align-self: start;
}

.coop-invite-toast {
    justify-self: start;
    max-width: fit-content;
    margin-top: -8px;
    padding: 8px 14px;
    border-radius: 999px;
    border: 1px solid rgba(120, 176, 255, 0.28);
    background: rgba(56, 108, 190, 0.16);
    color: #deefff;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.16);
}

.coop-session-meta div {
    display: grid;
    gap: 6px;
    padding: 16px 18px;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.coop-grid {
    grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
    align-items: start;
}

.coop-active-grid {
    grid-template-columns: minmax(0, 1fr);
    align-items: stretch;
    max-width: 1360px;
}

.coop-setup-grid {
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.2fr) minmax(0, 0.9fr);
}

.coop-form-grid,
.coop-inline-form {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

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

.coop-create-block {
    display: grid;
    gap: 16px;
    padding: 18px 18px 20px;
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(19, 24, 37, 0.94), rgba(12, 16, 26, 0.98));
    border: 1px solid rgba(116, 170, 255, 0.12);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.coop-create-block-head {
    display: grid;
    gap: 6px;
}

.coop-create-block-head h3 {
    margin: 0;
    font-size: 1.12rem;
    line-height: 1.1;
    color: var(--epic-text);
}

.coop-create-panel .form-label,
.coop-join-panel .form-label {
    margin-bottom: 6px;
    color: rgba(221, 235, 255, 0.82);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.coop-divider {
    position: relative;
    text-align: center;
    color: rgba(255, 255, 255, 0.52);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    font-size: 0.74rem;
}

.coop-divider::before {
    content: "";
    position: absolute;
    inset: 50% 0 auto;
    height: 1px;
    background: rgba(255, 255, 255, 0.08);
}

.coop-divider span {
    position: relative;
    padding: 0 12px;
    background: #171a22;
}

.coop-session-meta {
    grid-template-columns: repeat(4, minmax(140px, 1fr));
    gap: 14px;
}

.coop-session-meta-compact {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
}

.coop-meta-pill {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 50px;
    padding: 8px 16px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.coop-meta-pill span {
    color: rgba(214, 232, 255, 0.74);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.coop-meta-pill strong {
    display: block;
    max-width: 210px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--epic-text);
    font-size: 0.98rem;
    line-height: 1;
}

.coop-meta-pill.map strong {
    max-width: 280px;
}

.coop-player-stack {
    gap: 18px;
}

.coop-player-card {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 22px;
    padding: 22px 24px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.coop-player-card.you {
    border-color: rgba(96, 182, 255, 0.24);
    background: linear-gradient(135deg, rgba(19, 47, 88, 0.34), rgba(18, 25, 39, 0.72));
}

.coop-player-card.partner {
    border-color: rgba(255, 114, 114, 0.2);
    background: linear-gradient(135deg, rgba(66, 18, 18, 0.3), rgba(24, 17, 24, 0.74));
}

.coop-player-main {
    display: grid;
    gap: 6px;
}

.coop-player-main strong {
    margin: 0;
    color: #f7f9ff;
    font-size: 1.16rem;
    line-height: 1.12;
}

.coop-player-context {
    color: rgba(190, 214, 247, 0.8);
    font-size: 0.77rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.coop-player-card.partner .coop-player-context {
    color: rgba(255, 195, 195, 0.78);
}

.coop-invite-card {
    padding: 18px 20px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(94, 181, 255, 0.14);
}

.coop-invite-card .btn {
    justify-self: start;
}

.coop-player-meta {
    min-width: 150px;
    justify-items: end;
    gap: 10px;
    color: rgba(255, 255, 255, 0.74);
    font-size: 0.98rem;
    line-height: 1.1;
}

.coop-setup-grid .coop-join-panel,
.coop-setup-grid .coop-create-panel {
    height: 100%;
}

.coop-session-panel .section-count {
    min-width: auto;
    height: 46px;
    padding: 0 16px;
    border-radius: 16px;
    font-size: 0.96rem;
}

.coop-move-vote {
    padding: 14px 16px;
    border-radius: 16px;
    background: rgba(94, 181, 255, 0.1);
    border: 1px solid rgba(94, 181, 255, 0.2);
    color: #d8ecff;
}

.coop-action-row {
    justify-content: flex-start;
    gap: 16px;
    flex-wrap: wrap;
    margin-top: 6px;
}

.coop-action-row .btn {
    min-width: 150px;
    min-height: 50px;
}

.coop-inline-form {
    grid-template-columns: minmax(0, 1fr) auto;
}

.coop-inline-form .btn {
    min-width: 120px;
}

.coop-invited-strip {
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 50px;
    padding: 0 16px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.07);
}

.coop-invited-strip span {
    color: rgba(214, 232, 255, 0.74);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.coop-invited-strip strong {
    color: var(--epic-text);
    font-size: 0.92rem;
    font-weight: 700;
}

.coop-invite-section {
    display: grid;
    gap: 16px;
    padding: 20px;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.coop-invite-section-head {
    display: grid;
    gap: 4px;
}

.coop-invite-section-head strong {
    color: var(--epic-text);
    font-size: 0.98rem;
    font-weight: 700;
    line-height: 1.2;
}

.coop-invite-choice-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 14px;
}

.coop-invite-choice {
    justify-content: flex-start;
    min-height: 52px;
    padding: 12px 16px;
    border-radius: 14px;
}

.coop-session-note {
    margin-top: 6px;
    padding: 18px 20px;
    border-style: solid;
    border-color: rgba(255, 255, 255, 0.07);
    color: rgba(228, 239, 255, 0.78);
    line-height: 1.55;
    font-size: 1.02rem;
}

.coop-catalog-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.coop-puzzle-card h3 {
    margin: 0;
}

.enigma-coop-card .enigma-stat-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.enigma-player.co-op-peer {
    background: linear-gradient(180deg, #ffd8d8, #df6f7f);
    border-color: rgba(255, 151, 151, 0.6);
    box-shadow: 0 5px 14px rgba(0, 0, 0, 0.18), 0 0 0 1px rgba(189, 72, 102, 0.22);
    opacity: 0.94;
    transition: left 0.03s linear, top 0.03s linear, box-shadow 0.12s ease;
}

.enigma-player.co-op-peer::after {
    background: #2b0c18;
}

.enigma-player-tag {
    position: absolute;
    z-index: 7;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(4, 8, 14, 0.9);
    border: 1px solid rgba(109, 195, 255, 0.28);
    color: #d7efff;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    pointer-events: none;
    transform: translateY(-100%);
    white-space: nowrap;
    transition: left 0.045s linear, top 0.045s linear, opacity 0.12s ease;
}

.enigma-player-tag.partner-tag {
    border-color: rgba(255, 114, 114, 0.32);
    color: #ffe3e3;
    background: rgba(22, 7, 12, 0.92);
}

.play-page-shell {
    color: var(--epic-text);
    max-width: 1440px;
}

.play-page-shell h1,
.play-page-shell h2,
.play-page-shell h3,
.play-page-shell h4,
.play-page-shell strong,
.play-page-shell label {
    color: #f6f8ff;
}

.play-page-shell p,
.play-page-shell span,
.play-page-shell .form-label,
.play-page-shell .validation-message,
.play-page-shell .play-loadout-copy {
    color: var(--epic-text);
}

.play-page-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    align-items: end;
    margin-bottom: 24px;
}

.play-page-banner {
    position: relative;
    overflow: hidden;
    padding: 28px;
    border: 1px solid rgba(124, 166, 255, 0.16);
    border-radius: 28px;
    background:
        radial-gradient(circle at top left, rgba(0, 120, 242, 0.26), transparent 36%),
        linear-gradient(135deg, rgba(16, 24, 38, 0.95), rgba(23, 30, 46, 0.88));
    box-shadow: 0 30px 60px rgba(0, 0, 0, 0.24);
}

.play-page-header-copy {
    display: grid;
    gap: 10px;
}

.play-page-header-copy h1,
.play-page-header-copy p {
    margin: 0;
}

.play-page-header-copy p {
    max-width: 44rem;
}

.play-header-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

@media (max-width: 1240px) {
    .coop-setup-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .play-page-header {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .play-header-actions {
        justify-content: flex-start;
    }
}

.play-header-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    min-width: min(100%, 280px);
}

.play-header-metrics div {
    padding: 14px 16px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.play-header-metrics span {
    display: block;
    color: var(--epic-text);
    font-size: 0.85rem;
}

.play-header-metrics strong {
    display: block;
    margin-top: 6px;
}

.play-setup-grid {
    display: grid;
    grid-template-columns: minmax(320px, 440px) minmax(0, 1fr);
    gap: 24px;
    align-items: start;
}

.home-hero-panel {
    justify-content: center;
}

.home-page-shell {
    padding-bottom: 92px;
}

.home-hero-copy {
    width: min(100%, 960px);
    margin: 0 auto;
    display: grid;
    gap: 12px;
    justify-items: center;
    text-align: center;
}

.home-hero-copy h1,
.home-hero-copy p,
.home-hero-copy .profile-kicker {
    text-align: center;
}

.home-energy-pill {
    position: fixed;
    left: 50%;
    bottom: 22px;
    transform: translateX(-50%);
    z-index: 40;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 46px;
    padding: 0 18px;
    border-radius: 999px;
    border: 1px solid rgba(112, 171, 255, 0.26);
    background:
        radial-gradient(circle at top, rgba(72, 132, 255, 0.18), transparent 68%),
        rgba(11, 16, 26, 0.88);
    box-shadow:
        0 16px 34px rgba(0, 0, 0, 0.34),
        inset 0 1px 0 rgba(255, 255, 255, 0.06);
    color: #f6f9ff;
    font-size: 0.96rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    text-decoration: none;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    transition:
        transform 0.16s ease,
        border-color 0.16s ease,
        background-color 0.16s ease,
        box-shadow 0.16s ease;
}

.home-energy-pill:hover,
.home-energy-pill:focus-visible {
    color: #ffffff;
    border-color: rgba(138, 190, 255, 0.4);
    box-shadow:
        0 20px 38px rgba(0, 0, 0, 0.38),
        0 0 0 1px rgba(138, 190, 255, 0.16),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
    transform: translateX(-50%) translateY(-2px);
}

.home-energy-pill:active {
    transform: translateX(-50%);
}

.play-forms-column {
    min-width: 0;
}

.play-card {
    border-radius: 24px;
    background:
        radial-gradient(circle at top left, rgba(0, 120, 242, 0.10), transparent 38%),
        rgba(17, 21, 30, 0.96);
    border: 1px solid rgba(120, 175, 255, 0.18);
    box-shadow: 0 22px 48px rgba(0, 0, 0, 0.26);
}

.play-card .form-control,
.play-card .form-select,
.play-card .form-control:focus,
.play-card .form-select:focus {
    color: #f2f6ff;
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.12);
}

.play-loadout-heading {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 16px;
}

.play-loadout-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
    margin-top: 16px;
}

.play-item-card {
    display: grid;
    gap: 14px;
    padding: 18px;
    border-radius: 22px;
    background:
        linear-gradient(180deg, rgba(15, 20, 31, 0.96), rgba(11, 16, 26, 0.98));
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.play-item-card.selected {
    border-color: rgba(79, 140, 255, 0.45);
    box-shadow:
        0 0 0 1px rgba(79, 140, 255, 0.2),
        0 18px 36px rgba(0, 0, 0, 0.28);
}

.play-item-card strong {
    display: block;
    margin-bottom: 6px;
    color: #f8fbff;
    font-size: 1.05rem;
    line-height: 1.3;
}

.play-item-card p {
    margin: 0;
    color: #d7e3f7;
    font-size: 0.95rem;
    line-height: 1.55;
}

.play-item-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.play-item-meta span {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: #c9d8f2;
    font-size: 0.82rem;
    font-weight: 700;
    text-transform: capitalize;
}

.play-item-actions {
    display: flex;
    align-items: center;
    gap: 12px;
}

.play-item-actions .btn {
    min-width: 54px;
    min-height: 54px;
    padding: 0;
    border-radius: 16px;
}

.play-item-actions .mono-numeric {
    min-width: 28px;
    color: #eff5ff;
    font-size: 1rem;
    font-weight: 800;
    text-align: center;
}

@media (max-width: 1040px) {
    .play-page-header,
    .play-setup-grid {
        grid-template-columns: 1fr;
    }

    .play-header-actions {
        justify-content: flex-start;
    }

    .play-header-metrics {
        min-width: 0;
    }
}

@media (max-width: 1040px) {
    .coop-banner,
    .coop-grid {
        grid-template-columns: 1fr;
    }

    .coop-session-meta,
    .coop-form-grid,
    .coop-inline-form {
        grid-template-columns: 1fr;
        min-width: 0;
    }
}

.enigma-room-stage {
    aspect-ratio: 16 / 9;
    min-height: 0;
}

.enigma-stage-run-status {
    position: absolute;
    right: 14px;
    bottom: 14px;
    z-index: 12;
    width: min(300px, calc(100% - 28px));
    padding: 12px;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(12, 18, 28, 0.72), rgba(8, 12, 18, 0.78));
    border: 1px solid rgba(122, 181, 255, 0.16);
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.36);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
}

@media (min-width: 1400px) {
    .enigma-room-stage-wrap {
        width: min(calc(100vw - 8px), calc((100vh - 8px) * 16 / 9));
    }
}

@media (max-aspect-ratio: 4/3) {
    .enigma-room-stage-wrap {
        width: min(calc(100vw - 8px), calc((100vh - 8px) * 16 / 9));
    }
}

.enigma-stage-run-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
}

.enigma-stage-goal {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(77, 131, 255, 0.14);
    border: 1px solid rgba(122, 181, 255, 0.18);
    color: #ddecff;
    font-size: 0.78rem;
    font-weight: 700;
    white-space: nowrap;
}

.enigma-stage-run-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.enigma-stage-run-grid div {
    min-height: 68px;
    padding: 10px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.022);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.enigma-stage-run-grid span {
    display: block;
    margin-bottom: 4px;
    color: var(--epic-text-dim);
    font-size: 0.72rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.enigma-stage-run-grid strong {
    color: var(--epic-text);
    font-size: 0.95rem;
}

.enigma-stage-run-items {
    display: grid;
    gap: 8px;
    margin-top: 10px;
}

.enigma-stage-run-items-label {
    color: var(--epic-text-dim);
    font-size: 0.78rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.enigma-stage-run-hotkey-hint {
    color: rgba(213, 232, 255, 0.86);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.02em;
}

.enigma-stage-run-empty {
    padding: 10px 12px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.018);
    border: 1px solid rgba(255, 255, 255, 0.06);
    color: var(--epic-text-secondary);
}

.enigma-stage-run-pill-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.enigma-stage-run-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 36px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(57, 113, 255, 0.16);
    border: 1px solid rgba(122, 181, 255, 0.2);
    color: var(--epic-text);
}

.enigma-stage-run-pill strong {
    font-size: 0.88rem;
}

.enigma-stage-run-pill span {
    color: var(--epic-text-secondary);
    font-size: 0.82rem;
}

.enigma-loadout-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 34px;
    min-height: 22px;
    padding: 0 8px;
    border-radius: 999px;
    background: rgba(111, 166, 255, 0.22);
    border: 1px solid rgba(147, 195, 255, 0.26);
    color: #e4f2ff;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.01em;
}

.enigma-item-use-button {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-height: 28px;
    margin-left: 2px;
    padding: 0 10px;
    border-radius: 999px;
    border: 1px solid rgba(120, 180, 255, 0.42);
    background:
        radial-gradient(circle at top, rgba(144, 192, 255, 0.18), transparent 70%),
        linear-gradient(180deg, rgba(61, 124, 232, 0.94), rgba(35, 86, 171, 0.94));
    color: #eef7ff;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    cursor: pointer;
    transition: transform 0.16s ease, box-shadow 0.16s ease, filter 0.16s ease, opacity 0.16s ease;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.15);
}

.enigma-item-use-button:hover:not(:disabled) {
    transform: translateY(-1px);
    box-shadow: 0 10px 22px rgba(0, 0, 0, 0.26), inset 0 1px 0 rgba(255, 255, 255, 0.2);
    filter: brightness(1.05);
}

.enigma-item-use-button:focus-visible {
    outline: 2px solid rgba(138, 199, 255, 0.72);
    outline-offset: 2px;
}

.enigma-item-use-button:disabled {
    cursor: not-allowed;
    opacity: 0.56;
    filter: saturate(0.68);
}

.enigma-item-use-button kbd {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    min-height: 20px;
    margin: 0;
    padding: 0 6px;
    border-radius: 7px;
    border: 1px solid rgba(210, 231, 255, 0.42);
    background: linear-gradient(180deg, rgba(16, 34, 65, 0.96), rgba(10, 23, 44, 0.98));
    color: #f2f8ff;
    font-size: 0.72rem;
    font-weight: 900;
    font-family: inherit;
    line-height: 1;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15);
}

.enigma-item-passive-tag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 24px;
    margin-left: 2px;
    padding: 0 9px;
    border-radius: 999px;
    border: 1px solid rgba(171, 193, 220, 0.3);
    background: rgba(169, 192, 221, 0.12);
    color: #d9e9ff;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.enigma-puzzle-console {
    position: absolute;
    z-index: 4;
    display: grid;
    place-items: center;
    border: 0;
    padding: 0;
    background: transparent;
    cursor: pointer;
}

.enigma-puzzle-console-screen {
    width: 72%;
    height: 54%;
    border-radius: 14px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0)),
        linear-gradient(180deg, rgb(98, 162, 255), rgb(38, 77, 155));
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.16), 0 0 24px rgba(66, 135, 255, 0.2);
    transition: box-shadow 130ms linear;
}

.enigma-puzzle-console.console-red .enigma-puzzle-console-screen {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0)),
        linear-gradient(180deg, rgb(245, 124, 133), rgb(153, 42, 51));
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.16), 0 0 24px rgba(237, 82, 92, 0.24);
}

.enigma-puzzle-console-base {
    position: absolute;
    bottom: 8%;
    width: 88%;
    height: 24%;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(22, 30, 44, 0.94), rgba(9, 14, 24, 0.98));
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 12px 26px rgba(0, 0, 0, 0.34);
}

.enigma-puzzle-console.nearby .enigma-puzzle-console-screen {
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.18), 0 0 32px rgba(66, 135, 255, 0.38);
}

.enigma-puzzle-console.console-red.nearby .enigma-puzzle-console-screen {
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.2), 0 0 34px rgba(237, 82, 92, 0.4);
}

.enigma-puzzle-console.partner-console {
    cursor: default;
    pointer-events: none;
    opacity: 0.96;
}

.enigma-console-prompt {
    position: absolute;
    z-index: 7;
    min-height: 42px;
    padding: 0 18px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(6, 10, 16, 0.9);
    border: 1px solid rgba(122, 181, 255, 0.24);
    color: #f4f8ff;
    font-weight: 700;
    line-height: 1.2;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
    box-shadow: 0 16px 36px rgba(0, 0, 0, 0.32);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
}

.enigma-world-action-prompt {
    position: absolute;
    z-index: 8;
    min-height: 42px;
    padding: 0 16px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(170deg, rgba(9, 16, 27, 0.92), rgba(5, 10, 18, 0.86));
    border: 1px solid rgba(144, 210, 255, 0.34);
    color: #edf6ff;
    font-size: 0.86rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    line-height: 1.15;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.55);
    box-shadow:
        inset 0 0 0 1px rgba(214, 236, 255, 0.08),
        0 14px 34px rgba(0, 0, 0, 0.36),
        0 0 24px rgba(88, 173, 255, 0.18);
    -webkit-backdrop-filter: blur(9px);
    backdrop-filter: blur(9px);
}

.enigma-world-action-prompt.out-of-range {
    border-color: rgba(181, 203, 242, 0.28);
    color: rgba(229, 237, 250, 0.9);
    box-shadow:
        inset 0 0 0 1px rgba(217, 229, 248, 0.06),
        0 12px 28px rgba(0, 0, 0, 0.34);
}

.enigma-carried-payload {
    position: absolute;
    z-index: 9;
    min-height: 30px;
    padding: 0 10px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(170deg, rgba(12, 21, 34, 0.92), rgba(6, 11, 18, 0.86));
    border: 1px solid rgba(170, 223, 255, 0.44);
    color: #eff8ff;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    box-shadow:
        inset 0 0 0 1px rgba(214, 236, 255, 0.12),
        0 10px 20px rgba(0, 0, 0, 0.34),
        0 0 18px rgba(102, 190, 255, 0.24);
    pointer-events: none;
}

.enigma-room-interaction-progress {
    position: absolute;
    z-index: 7;
    display: grid;
    gap: 8px;
    padding: 10px 12px;
    border-radius: 16px;
    background: rgba(7, 11, 18, 0.68);
    border: 1px solid rgba(122, 181, 255, 0.16);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.28);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
}

.enigma-room-interaction-progress-label {
    display: block;
    color: var(--epic-text);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.enigma-room-interaction-progress-track {
    position: relative;
    width: 100%;
    height: 10px;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.enigma-room-interaction-progress-fill {
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, rgba(101, 170, 255, 0.92), rgba(161, 219, 255, 0.96));
    box-shadow: 0 0 18px rgba(92, 165, 255, 0.28);
    transition: width 0.08s linear;
}

.enigma-coop-inline-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin-top: 6px;
    padding: 16px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--epic-border);
}

.enigma-coop-inline-strip div {
    display: grid;
    gap: 4px;
}

.enigma-coop-inline-strip span {
    color: var(--epic-text-dim);
    font-size: 0.78rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.enigma-coop-inline-strip strong {
    color: var(--epic-text);
    font-size: 0.96rem;
}

.enigma-puzzle-overlay-backdrop {
    position: fixed;
    inset: 0;
    z-index: 2000;
    display: grid;
    place-items: center;
    padding: 12px;
    background:
        radial-gradient(circle at 18% 14%, rgba(88, 144, 255, 0.08), transparent 30%),
        radial-gradient(circle at 82% 84%, rgba(120, 226, 255, 0.06), transparent 28%),
        rgba(3, 7, 14, 0.54);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
}

.enigma-puzzle-overlay-shell {
    position: relative;
    width: min(1480px, calc(100vw - 24px));
    max-height: calc(100dvh - 24px);
    margin: 0;
    display: block;
}

.enigma-puzzle-overlay-shell .enigma-sidebar-summary {
    display: none;
}

.enigma-puzzle-overlay-shell .enigma-puzzle-card {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 18px 20px 20px;
    padding-top: 60px;
    height: calc(100dvh - 24px);
    max-height: none;
    overflow: hidden;
    border-radius: 18px;
    background:
        radial-gradient(circle at top left, rgba(106, 160, 255, 0.12), transparent 24%),
        linear-gradient(180deg, rgba(14, 18, 27, 0.97), rgba(8, 12, 20, 0.985));
    border: 1px solid rgba(188, 210, 246, 0.16);
    box-shadow:
        0 24px 56px rgba(0, 0, 0, 0.46),
        inset 0 0 0 1px rgba(255, 255, 255, 0.03);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
    isolation: isolate;
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum" 1;
}

.enigma-puzzle-overlay-shell .enigma-puzzle-card.enigma-puzzle-card-solo {
    padding: 14px 16px 16px;
    padding-top: 56px;
}

.enigma-puzzle-overlay-shell .enigma-puzzle-status {
    background: rgba(255, 255, 255, 0.035);
    border: 1px solid rgba(255, 255, 255, 0.08);
    min-height: 3.2rem;
    display: flex;
    align-items: center;
}

.enigma-puzzle-overlay-shell .enigma-puzzle-head {
    padding-right: 92px;
    border-bottom-color: rgba(255, 255, 255, 0.06);
}

.enigma-puzzle-overlay-shell .enigma-puzzle-surface {
    gap: 14px;
    min-height: 0;
    overflow: auto;
    padding-right: 8px;
    scrollbar-gutter: stable;
    overscroll-behavior: contain;
}

.enigma-puzzle-overlay-shell .enigma-puzzle-card.enigma-puzzle-card-solo .enigma-puzzle-surface {
    gap: 0;
    padding-right: 6px;
}

.enigma-overlay-close {
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 3;
    min-height: 36px;
    padding: 0 14px;
    border: 0;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.06);
    color: rgba(232, 242, 255, 0.92);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.enigma-overlay-close:hover {
    background: rgba(94, 144, 232, 0.22);
}

@media (max-width: 1280px) {
    .enigma-room-stage {
        min-height: 0;
    }

    .enigma-stage-run-status {
        width: min(280px, calc(100% - 28px));
    }

    .enigma-coop-inline-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 900px) {
    .enigma-game-page {
        width: 100vw;
        max-width: none;
        margin-inline: calc(50% - 50vw);
        padding: 0;
    }

    .enigma-room-stage {
        aspect-ratio: 16 / 9;
        min-height: 0;
    }

    .enigma-stage-run-status {
        right: 10px;
        bottom: 10px;
        width: min(260px, calc(100% - 20px));
        margin: 0;
    }

    .enigma-puzzle-overlay-backdrop {
        padding: 10px;
    }

    .enigma-puzzle-overlay-shell {
        width: calc(100vw - 20px);
        max-height: calc(100dvh - 20px);
    }

    .enigma-puzzle-overlay-shell .enigma-puzzle-card {
        padding: 14px 14px 16px;
        padding-top: 54px;
        height: calc(100dvh - 20px);
        max-height: none;
        border-radius: 16px;
    }

    .enigma-puzzle-overlay-shell .enigma-puzzle-card.enigma-puzzle-card-solo {
        padding: 12px;
        padding-top: 50px;
    }
}

.seo-auth-shell {
    display: grid;
    gap: 24px;
}

.seo-auth-intro,
.seo-page-hero,
.seo-page-section {
    display: grid;
    gap: 14px;
}

.seo-auth-intro {
    padding: 28px 30px;
    background:
        radial-gradient(circle at top left, rgba(79, 143, 255, 0.12), transparent 38%),
        linear-gradient(180deg, rgba(18, 24, 36, 0.96), rgba(12, 16, 24, 0.92));
}

.seo-auth-intro h1,
.seo-page-hero h1 {
    margin: 0;
    font-size: clamp(2.4rem, 4vw, 4rem);
    line-height: 0.96;
    letter-spacing: -0.04em;
}

.seo-auth-intro p,
.seo-page-hero p,
.seo-page-section p {
    margin: 0;
    color: var(--epic-text);
    max-width: 72ch;
    line-height: 1.7;
}

.seo-inline-links {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 4px;
}

.seo-inline-links a {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 0 14px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(122, 181, 255, 0.14);
    color: #dce7ff;
    font-weight: 700;
    text-decoration: none;
    transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}

.seo-inline-links a:hover {
    background: rgba(69, 126, 255, 0.16);
    border-color: rgba(122, 181, 255, 0.28);
    transform: translateY(-1px);
}

.seo-page-shell {
    max-width: 1080px;
    margin: 56px auto 80px;
    display: grid;
    gap: 24px;
}

.seo-page-hero {
    padding: 34px 36px;
    background:
        radial-gradient(circle at top left, rgba(71, 135, 255, 0.14), transparent 34%),
        linear-gradient(180deg, rgba(18, 24, 36, 0.97), rgba(11, 16, 24, 0.94));
}

.seo-page-section {
    padding: 28px 30px;
}

.seo-page-section h2,
.seo-page-section h3,
.seo-page-hero h1 {
    color: var(--epic-text);
}

.seo-page-section h2 {
    margin: 0 0 2px;
    font-size: 1.55rem;
}

.seo-page-section h3 {
    margin: 10px 0 0;
    font-size: 1.04rem;
    letter-spacing: 0.01em;
}

.seo-link-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.seo-link-card {
    display: grid;
    gap: 8px;
    min-height: 152px;
    padding: 20px;
    border-radius: 20px;
    background:
        radial-gradient(circle at top left, rgba(79, 143, 255, 0.08), transparent 34%),
        rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(122, 181, 255, 0.14);
    color: var(--epic-text);
    text-decoration: none;
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.seo-link-card strong {
    font-size: 1.05rem;
    color: #f3f7ff;
}

.seo-link-card span {
    color: var(--epic-text);
    line-height: 1.6;
}

.seo-link-card:hover {
    transform: translateY(-2px);
    border-color: rgba(122, 181, 255, 0.3);
    background:
        radial-gradient(circle at top left, rgba(79, 143, 255, 0.13), transparent 34%),
        rgba(255, 255, 255, 0.04);
}

@media (max-width: 900px) {
    .seo-page-shell {
        margin: 32px auto 56px;
        gap: 18px;
    }

    .seo-auth-intro,
    .seo-page-hero,
    .seo-page-section {
        padding: 22px 20px;
    }

    .seo-link-grid {
        grid-template-columns: 1fr;
    }
}

.staking-shell,
.voting-shell {
    display: grid;
    gap: 20px;
}

.staking-banner,
.voting-banner {
    border-radius: 24px;
    padding: 24px;
    border: 1px solid rgba(94, 181, 255, 0.2);
    background:
        linear-gradient(120deg, rgba(27, 47, 83, 0.72), rgba(22, 28, 43, 0.92)),
        #121725;
    display: grid;
    gap: 14px;
}

.staking-banner h1,
.voting-banner h1 {
    margin: 0;
}

.staking-banner p,
.voting-banner p {
    margin: 0;
    color: rgba(228, 235, 246, 0.78);
}

.staking-banner-meta,
.voting-banner-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.staking-claim-card {
    border-radius: 18px;
    border: 1px solid rgba(120, 176, 255, 0.18);
    background: rgba(17, 24, 39, 0.65);
    padding: 18px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
}

.staking-claim-card p {
    margin: 6px 0 0;
    color: rgba(224, 231, 241, 0.75);
}

.staking-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    align-items: start;
}

.staking-column {
    display: grid;
    gap: 14px;
    align-content: start;
    align-self: start;
}

.staking-map-stack {
    display: grid;
    gap: 10px;
    align-content: start;
    grid-auto-rows: auto;
}

.voting-admin-panel,
.voting-session-panel,
.voting-results-panel,
.voting-empty-panel {
    display: grid;
    gap: 14px;
}

.voting-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.voting-duration-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 160px;
    gap: 10px;
}

.voting-form-span {
    grid-column: 1 / -1;
}

.voting-admin-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}

.voting-session-copy {
    margin: 0;
    color: rgba(224, 232, 244, 0.82);
}

.voting-session-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    color: rgba(214, 223, 236, 0.74);
    font-size: 0.9rem;
}

.voting-vote-row {
    display: grid;
    grid-template-columns: auto 180px auto;
    align-items: center;
    gap: 12px;
}

.voting-vote-row .form-label {
    margin: 0;
}

.voting-mn-input {
    width: 100%;
}

.voting-power-preview {
    color: rgba(145, 198, 255, 0.94);
    font-weight: 700;
}

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

.voting-options-grid.compact {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.voting-option-card {
    border-radius: 14px;
    border: 1px solid rgba(110, 172, 255, 0.18);
    background: rgba(14, 22, 35, 0.9);
    padding: 14px;
    display: grid;
    gap: 10px;
}

.voting-option-card.compact {
    border-color: rgba(255, 255, 255, 0.08);
}

.voting-option-top {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 10px;
}

.voting-option-meta {
    display: flex;
    justify-content: space-between;
    color: rgba(210, 219, 232, 0.76);
    font-size: 0.9rem;
}

.voting-checkbox {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: rgba(220, 230, 244, 0.88);
    font-weight: 600;
}

.voting-entry-block {
    display: grid;
    gap: 8px;
}

.economy-shell {
    display: grid;
    gap: 20px;
}

.economy-banner {
    border-radius: 24px;
    border: 1px solid rgba(92, 146, 255, 0.38);
    background:
        radial-gradient(circle at 12% 0%, rgba(95, 170, 255, 0.16), transparent 52%),
        linear-gradient(118deg, rgba(27, 36, 58, 0.96), rgba(13, 19, 33, 0.96));
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.03),
        0 16px 36px rgba(0, 0, 0, 0.24);
    padding: 24px;
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: flex-start;
}

.economy-banner h1 {
    margin: 6px 0 6px;
}

.economy-banner p {
    margin: 0;
    color: rgba(214, 224, 238, 0.82);
}

.economy-banner-meta {
    display: flex;
    flex-direction: column;
    gap: 8px;
    justify-content: flex-start;
    align-items: flex-end;
    min-width: 220px;
}

.economy-tabbar {
    margin-top: -4px;
}

.economy-kpi-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.economy-kpi-card {
    border-radius: 18px;
    padding: 16px 18px;
    border: 1px solid rgba(255, 255, 255, 0.07);
    background:
        linear-gradient(180deg, rgba(27, 34, 50, 0.86), rgba(14, 18, 29, 0.9));
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.02),
        0 10px 26px rgba(0, 0, 0, 0.26);
    display: grid;
    gap: 6px;
}

.economy-kpi-label {
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(171, 191, 226, 0.78);
}

.economy-kpi-value {
    margin: 0;
    font-size: clamp(1.15rem, 2.1vw, 1.62rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    color: #f3f8ff;
    animation: economy-value-rise 280ms ease-out;
}

.economy-kpi-sub {
    color: rgba(199, 214, 236, 0.72);
    font-size: 0.84rem;
}

@keyframes economy-value-rise {
    from {
        opacity: 0.4;
        transform: translateY(3px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.economy-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.economy-card {
    display: grid;
    gap: 14px;
    border: 1px solid rgba(255, 255, 255, 0.07);
    background:
        linear-gradient(180deg, rgba(25, 30, 45, 0.8), rgba(12, 14, 20, 0.9));
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.02),
        0 10px 28px rgba(0, 0, 0, 0.35);
}

.economy-card h2 {
    margin: 4px 0 0;
    font-size: clamp(1.8rem, 2.8vw, 2.3rem);
    line-height: 1.05;
    letter-spacing: -0.02em;
}

.economy-card-span {
    grid-column: 1 / -1;
}

.economy-donut-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    align-items: start;
}

.economy-donut {
    --slice-a: 50;
    --slice-b: 20;
    width: 160px;
    height: 160px;
    border-radius: 999px;
    position: relative;
    margin-inline: auto;
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.04),
        0 12px 26px rgba(0, 0, 0, 0.3);
}

.economy-donut-mn {
    background:
        conic-gradient(
            #5ba8ff 0 calc(var(--slice-a) * 1%),
            #8f74ff calc(var(--slice-a) * 1%) 100%
        );
}

.economy-donut-maps {
    background:
        conic-gradient(
            #54c8a3 0 calc(var(--slice-a) * 1%),
            #5ba8ff calc(var(--slice-a) * 1%) calc((var(--slice-a) + var(--slice-b)) * 1%),
            #4a5875 calc((var(--slice-a) + var(--slice-b)) * 1%) 100%
        );
}

.economy-donut-core {
    position: absolute;
    inset: 20px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background:
        linear-gradient(180deg, rgba(9, 13, 22, 0.96), rgba(14, 20, 31, 0.94));
    display: grid;
    place-content: center;
    text-align: center;
    gap: 4px;
}

.economy-donut-core span {
    font-size: 0.72rem;
    letter-spacing: 0.11em;
    text-transform: uppercase;
    color: rgba(186, 203, 229, 0.74);
}

.economy-donut-core strong {
    font-size: 1.14rem;
    letter-spacing: -0.02em;
    color: #eef5ff;
}

.economy-donut-legend {
    display: grid;
    gap: 9px;
}

.economy-legend-row {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 10px;
    padding: 9px 10px;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.04);
    color: rgba(222, 234, 248, 0.9);
    font-size: 0.88rem;
}

.economy-legend-row strong {
    white-space: normal;
    text-align: right;
    color: #f3f9ff;
}

.economy-legend-dot {
    width: 11px;
    height: 11px;
    border-radius: 999px;
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.08);
}

.economy-legend-dot.wallets { background: #5ba8ff; }
.economy-legend-dot.bank { background: #8f74ff; }
.economy-legend-dot.listed { background: #54c8a3; }
.economy-legend-dot.staked { background: #5ba8ff; }
.economy-legend-dot.unlisted { background: #4a5875; }

.economy-stat-line {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: baseline;
    color: rgba(214, 224, 238, 0.88);
}

.economy-stat-line span {
    color: rgba(210, 220, 234, 0.7);
}

.economy-progress-stack {
    display: grid;
    gap: 10px;
}

.economy-progress-row {
    display: grid;
    gap: 6px;
}

.economy-progress-label {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: baseline;
    font-size: 0.88rem;
    color: rgba(218, 230, 246, 0.84);
}

.economy-progress-bar {
    width: 100%;
    height: 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    overflow: hidden;
}

.economy-progress-bar span {
    display: block;
    height: 100%;
    width: 0;
    border-radius: inherit;
    background:
        linear-gradient(90deg, rgba(80, 157, 255, 0.95), rgba(116, 199, 255, 0.9));
    box-shadow: 0 0 14px rgba(78, 153, 255, 0.38);
    transition: width 360ms ease;
}

.economy-market-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.economy-market-item {
    display: grid;
    gap: 5px;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    background: rgba(255, 255, 255, 0.03);
    padding: 11px 12px;
}

.economy-market-item span {
    color: rgba(192, 210, 233, 0.74);
    font-size: 0.8rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 700;
}

.economy-market-item strong {
    color: #eef6ff;
    font-size: 1.04rem;
    line-height: 1.2;
}

.economy-market-item em {
    color: rgba(159, 188, 227, 0.82);
    font-style: normal;
    font-size: 0.82rem;
    line-height: 1.25;
}

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

.economy-health-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    background: rgba(255, 255, 255, 0.03);
    color: rgba(216, 228, 246, 0.86);
}

.economy-health-status {
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 0.79rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 800;
}

.economy-health-status.good {
    color: #80f8bf;
    background: rgba(35, 120, 81, 0.34);
}

.economy-health-status.steady {
    color: #a7d0ff;
    background: rgba(54, 93, 147, 0.32);
}

.economy-health-status.low {
    color: #ffc89f;
    background: rgba(136, 83, 46, 0.33);
}

.economy-card-footnote {
    margin: 8px 0 0;
    color: rgba(175, 196, 224, 0.8);
    font-size: 0.88rem;
}

.economy-faq {
    display: grid;
    gap: 12px;
}

.economy-faq-collapsible {
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.03);
    overflow: hidden;
}

.economy-faq-collapsible summary {
    cursor: pointer;
    list-style: none;
    padding: 14px 16px;
    font-weight: 700;
    color: rgba(228, 239, 255, 0.92);
    display: flex;
    align-items: center;
    gap: 10px;
}

.economy-faq-collapsible summary::-webkit-details-marker {
    display: none;
}

.economy-faq-collapsible summary::before {
    content: ">";
    transition: transform 0.18s ease;
    color: rgba(152, 191, 248, 0.94);
}

.economy-faq-collapsible[open] summary::before {
    transform: rotate(90deg);
}

.economy-faq-collapsible .staking-faq-list,
.economy-faq-collapsible .economy-card-footnote {
    margin-left: 16px;
    margin-right: 16px;
}

.economy-faq-collapsible .staking-faq-list {
    margin-top: 2px;
    margin-bottom: 10px;
}

.economy-embedded-shell {
    padding: 0;
    margin: 0;
}

.economy-embedded-state {
    margin: 0;
}

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

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

    .voting-duration-row {
        grid-template-columns: 1fr;
    }

    .voting-vote-row {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .economy-banner {
        flex-direction: column;
    }

    .economy-banner-meta {
        align-items: flex-start;
    }

    .economy-kpi-grid {
        grid-template-columns: 1fr;
    }

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

    .economy-health-grid {
        grid-template-columns: 1fr;
    }

    .economy-market-grid {
        grid-template-columns: 1fr;
    }
}

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

    .economy-banner {
        padding: 18px;
    }

    .economy-card {
        padding: 18px;
    }
}

/* Staking Tab Refresh */
.staking-shell {
    gap: 22px;
}

.staking-banner {
    border: 1px solid rgba(93, 184, 255, 0.26);
    background:
        radial-gradient(circle at 9% 0%, rgba(95, 176, 255, 0.14), transparent 52%),
        linear-gradient(120deg, rgba(25, 42, 74, 0.82), rgba(16, 22, 36, 0.94));
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.02),
        0 12px 32px rgba(0, 0, 0, 0.28);
}

.staking-kpi-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.staking-kpi-card {
    border-radius: 18px;
    padding: 16px 18px;
    border: 1px solid rgba(255, 255, 255, 0.07);
    background:
        linear-gradient(180deg, rgba(16, 23, 39, 0.9), rgba(11, 16, 28, 0.92));
    box-shadow:
        0 0 0 1px rgba(255, 255, 255, 0.02),
        0 8px 22px rgba(0, 0, 0, 0.3);
    display: grid;
    gap: 6px;
}

.staking-kpi-label {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: rgba(178, 200, 232, 0.76);
    font-weight: 700;
}

.staking-kpi-value {
    font-size: clamp(1.15rem, 2vw, 1.55rem);
    font-weight: 800;
    color: #eef7ff;
    letter-spacing: -0.02em;
    animation: staking-kpi-rise 280ms ease-out;
}

@keyframes staking-kpi-rise {
    from {
        opacity: 0.35;
        transform: translateY(3px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.staking-forecast-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}

.staking-forecast-card {
    border-radius: 14px;
    padding: 12px 14px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.03);
    display: grid;
    gap: 6px;
}

.staking-forecast-card span {
    color: rgba(196, 214, 237, 0.76);
    font-size: 0.8rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 700;
}

.staking-forecast-card strong {
    color: #f2f9ff;
    font-size: 1.03rem;
}

.staking-forecast-card em {
    color: rgba(161, 217, 255, 0.92);
    font-style: normal;
    font-size: 0.82rem;
    font-weight: 700;
}

.staking-research-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.staking-research-card {
    display: grid;
    gap: 10px;
}

.staking-research-card h2 {
    margin: 0;
    font-size: 1.18rem;
}

.staking-claim-card {
    position: relative;
    border-radius: 20px;
    border: 1px solid rgba(120, 176, 255, 0.22);
    background:
        linear-gradient(180deg, rgba(18, 25, 39, 0.82), rgba(12, 17, 28, 0.92));
    padding: 18px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 14px;
    overflow: hidden;
}

.staking-claim-card.claim-success {
    box-shadow:
        0 0 0 1px rgba(124, 214, 174, 0.24),
        0 12px 30px rgba(18, 128, 86, 0.26);
}

.staking-claim-copy p {
    margin: 6px 0 0;
    color: rgba(224, 231, 241, 0.78);
}

.staking-claim-ring-wrap {
    display: grid;
    justify-items: center;
    gap: 8px;
}

.staking-claim-ring {
    --claim-progress: 0;
    width: 116px;
    height: 116px;
    border-radius: 999px;
    background:
        conic-gradient(
            #57b0ff 0 calc(var(--claim-progress) * 1%),
            rgba(255, 255, 255, 0.12) calc(var(--claim-progress) * 1%) 100%
        );
    position: relative;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.3);
}

.staking-claim-ring-core {
    position: absolute;
    inset: 14px;
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(11, 17, 29, 0.95), rgba(15, 22, 36, 0.94));
    border: 1px solid rgba(255, 255, 255, 0.08);
    display: grid;
    place-content: center;
    text-align: center;
    gap: 3px;
}

.staking-claim-ring-core strong {
    color: #f0f7ff;
    font-size: 1.12rem;
    line-height: 1;
}

.staking-claim-ring-core span {
    color: rgba(182, 206, 235, 0.78);
    font-size: 0.74rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 700;
}

.staking-claim-countdown {
    display: grid;
    justify-items: center;
    gap: 2px;
}

.staking-claim-countdown strong {
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: rgba(177, 201, 232, 0.82);
}

.staking-claim-countdown span {
    color: #ebf5ff;
    font-weight: 700;
}

.staking-claim-burst {
    position: absolute;
    right: 16px;
    top: 10px;
    color: #8df0b7;
    font-weight: 800;
    font-size: 0.88rem;
    animation: staking-claim-pop 1.2s ease-out;
    pointer-events: none;
}

@keyframes staking-claim-pop {
    0% {
        opacity: 0;
        transform: translateY(8px) scale(0.92);
    }
    20% {
        opacity: 1;
    }
    80% {
        opacity: 0.92;
    }
    100% {
        opacity: 0;
        transform: translateY(-12px) scale(1.02);
    }
}

.staking-breakdown-panel {
    display: grid;
    gap: 12px;
}

.staking-breakdown-layout {
    display: grid;
    grid-template-columns: 210px minmax(0, 1fr);
    gap: 14px;
    align-items: center;
}

.staking-breakdown-donut {
    --yield-breakdown: conic-gradient(#5ba8ff 0 100%);
    width: 180px;
    height: 180px;
    margin-inline: auto;
    border-radius: 999px;
    background: var(--yield-breakdown);
    position: relative;
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.03),
        0 12px 28px rgba(0, 0, 0, 0.32);
}

.staking-breakdown-donut-core {
    position: absolute;
    inset: 18px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: linear-gradient(180deg, rgba(10, 15, 25, 0.95), rgba(14, 20, 31, 0.94));
    display: grid;
    place-content: center;
    text-align: center;
    gap: 4px;
}

.staking-breakdown-donut-core span {
    font-size: 0.74rem;
    color: rgba(180, 203, 232, 0.74);
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.staking-breakdown-donut-core strong {
    color: #f1f8ff;
    font-size: 1.06rem;
    line-height: 1.25;
}

.staking-breakdown-legend {
    display: grid;
    gap: 8px;
}

.staking-breakdown-row {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 10px;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.05);
    background: rgba(255, 255, 255, 0.03);
    padding: 9px 10px;
    color: rgba(215, 227, 244, 0.9);
    font-size: 0.88rem;
}

.staking-breakdown-dot {
    width: 11px;
    height: 11px;
    border-radius: 999px;
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.08);
}

.staking-breakdown-map {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.staking-map-card {
    border-radius: 16px;
    border: 1px solid rgba(120, 176, 255, 0.18);
    background: rgba(16, 23, 36, 0.9);
    padding: 14px;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    align-content: start;
    min-height: 0;
}

.staking-map-card.muted {
    border-color: rgba(255, 255, 255, 0.1);
}

.staking-map-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.staking-map-card-head h3 {
    margin: 0;
    font-size: 1.06rem;
    line-height: 1.2;
}

.staking-map-card-collapsible {
    padding: 0;
    gap: 0;
    overflow: hidden;
}

.staking-map-compact-trigger {
    border: 0;
    width: 100%;
    background: transparent;
    color: inherit;
    padding: 14px;
    display: grid;
    gap: 10px;
    text-align: left;
    cursor: pointer;
    transition: background 0.18s ease;
}

.staking-map-compact-trigger:hover {
    background: rgba(255, 255, 255, 0.025);
}

.staking-map-card-collapsible.expanded .staking-map-compact-trigger {
    border-bottom: 1px solid rgba(130, 175, 241, 0.2);
}

.staking-map-head-meta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    flex-wrap: wrap;
}

.staking-expand-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid rgba(130, 175, 241, 0.28);
    background: rgba(92, 147, 230, 0.14);
    color: rgba(220, 234, 252, 0.94);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
}

.staking-map-compact-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px 12px;
}

.staking-map-compact-grid > div {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    padding: 7px 10px;
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    background: rgba(255, 255, 255, 0.03);
    color: rgba(220, 231, 246, 0.9);
    font-size: 0.84rem;
}

.staking-map-compact-grid > div > span {
    color: rgba(175, 197, 226, 0.8);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.72rem;
    font-weight: 700;
}

.staking-map-compact-progress {
    margin-top: 2px;
}

.staking-map-expanded-body {
    display: grid;
    gap: 10px;
    padding: 12px 14px 14px;
    animation: staking-map-expand 180ms ease-out;
}

@keyframes staking-map-expand {
    from {
        opacity: 0.45;
        transform: translateY(-2px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.staking-map-rows {
    display: grid;
    gap: 6px;
}

.staking-map-rows > div {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    color: rgba(212, 224, 241, 0.84);
    font-size: 0.88rem;
}

.staking-map-rows > div > span {
    color: rgba(180, 199, 224, 0.74);
}

.staking-map-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.staking-yield-label {
    display: block;
    font-size: 0.76rem;
    color: rgba(180, 200, 227, 0.74);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 2px;
}

.staking-yield-value {
    color: #7dd3fc;
    font-weight: 800;
    font-size: 1.08rem;
    text-shadow: 0 0 18px rgba(125, 211, 252, 0.24);
}

.staking-ai-note {
    margin: 0;
    color: rgba(188, 212, 242, 0.82);
    font-size: 0.84rem;
    line-height: 1.35;
}

.staking-milestone-note {
    color: rgba(179, 218, 255, 0.92);
    font-size: 0.82rem;
    font-weight: 700;
}

.staking-report-card {
    border-radius: 12px;
    border: 1px solid rgba(137, 185, 246, 0.22);
    background: rgba(255, 255, 255, 0.03);
    overflow: hidden;
}

.staking-report-card summary {
    cursor: pointer;
    list-style: none;
    padding: 10px 12px;
    color: rgba(229, 240, 255, 0.92);
    font-size: 0.86rem;
    font-weight: 700;
}

.staking-report-card summary::-webkit-details-marker {
    display: none;
}

.staking-report-card[open] {
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.2);
}

.staking-report-card .staking-map-rows,
.staking-report-card .staking-ai-note {
    margin: 0 12px 12px;
}

.staking-empty-state {
    border-radius: 14px;
    border: 1px dashed rgba(155, 189, 238, 0.34);
    background:
        radial-gradient(circle at 10% 10%, rgba(93, 171, 255, 0.1), transparent 46%),
        rgba(255, 255, 255, 0.02);
    padding: 20px 20px 18px;
    display: grid;
    gap: 10px;
    justify-items: start;
    max-width: 100%;
}

.staking-empty-header {
    display: grid;
    gap: 8px;
}

.staking-empty-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 90px;
    height: 28px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid rgba(127, 176, 245, 0.42);
    color: rgba(185, 218, 255, 0.92);
    font-size: 0.7rem;
    letter-spacing: 0.12em;
    font-weight: 800;
}

.staking-empty-state strong {
    font-size: 1rem;
    line-height: 1.35;
}

.staking-empty-state p {
    margin: 0;
    color: rgba(201, 215, 236, 0.74);
    line-height: 1.45;
}

.staking-map-stack-available {
    gap: 12px;
}

.staking-map-card-available {
    background:
        radial-gradient(circle at 92% 8%, rgba(95, 173, 255, 0.12), transparent 42%),
        rgba(16, 23, 36, 0.88);
}

.staking-map-stack-available .staking-map-card-available:only-child {
    max-width: 100%;
}

.staking-map-section-nav {
    margin: 0 0 12px;
    padding: 12px 14px;
}

.staking-map-section-nav .leaderboard-pagination {
    justify-content: flex-start;
}

.staking-faq-collapsible {
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.03);
    overflow: hidden;
}

.staking-faq-collapsible summary {
    cursor: pointer;
    list-style: none;
    padding: 14px 16px;
    font-weight: 700;
    color: rgba(228, 239, 255, 0.92);
    display: flex;
    align-items: center;
    gap: 10px;
}

.staking-faq-collapsible summary::-webkit-details-marker {
    display: none;
}

.staking-faq-collapsible summary::before {
    content: ">";
    transition: transform 0.18s ease;
    color: rgba(152, 191, 248, 0.94);
}

.staking-faq-collapsible[open] summary::before {
    transform: rotate(90deg);
}

.staking-faq-collapsible .staking-faq-list {
    margin-left: 16px;
    margin-right: 16px;
    margin-top: 2px;
    margin-bottom: 12px;
}

.staking-faq-list {
    margin: 0;
    padding-left: 20px;
    display: grid;
    gap: 10px;
    color: rgba(227, 234, 246, 0.86);
}

.difficulty-elite {
    background: rgba(168, 85, 247, 0.22);
    color: #ddb8ff;
}

@media (max-width: 1200px) {
    .staking-forecast-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .staking-research-grid {
        grid-template-columns: 1fr;
    }

    .staking-breakdown-layout {
        grid-template-columns: 1fr;
    }
}

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

    .staking-claim-card {
        grid-template-columns: 1fr;
        justify-items: start;
    }

    .staking-claim-ring-wrap {
        justify-items: start;
    }
}

@media (max-width: 720px) {
    .staking-forecast-grid {
        grid-template-columns: 1fr;
    }

    .staking-map-compact-grid {
        grid-template-columns: 1fr;
    }

    .staking-map-footer {
        flex-direction: column;
        align-items: flex-start;
    }
}

.enigma-solo-panel-shell {
    display: grid;
    gap: 0.8rem;
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum" 1;
}

.enigma-solo-panel-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.8rem;
}

.enigma-solo-panel-status.solved {
    border-color: rgba(88, 236, 170, 0.5);
    box-shadow: inset 0 0 0 1px rgba(88, 236, 170, 0.3);
}

.enigma-solo-panel-status.cooldown,
.enigma-solo-panel-status.resetting,
.enigma-solo-panel-status.failed {
    border-color: rgba(255, 149, 102, 0.5);
    box-shadow: inset 0 0 0 1px rgba(255, 149, 102, 0.26);
}

.enigma-solo-panel-board .enigma-mini-stat span {
    text-transform: lowercase;
}

.enigma-solo-panel-actions {
    max-height: 18.5rem;
    overflow-y: auto;
    padding-right: 0.25rem;
}

.enigma-panel-action.tone-commit {
    border-color: rgba(125, 214, 255, 0.45);
    color: #c3eeff;
}

.enigma-panel-action.tone-hint {
    border-color: rgba(182, 175, 255, 0.45);
    color: #ddd8ff;
}

.enigma-panel-action.tone-reset {
    border-color: rgba(255, 176, 116, 0.45);
    color: #ffe1c1;
}

.enigma-solo-panel-shell {
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.11);
    background:
        radial-gradient(circle at 8% -20%, rgba(120, 166, 255, 0.18), rgba(0, 0, 0, 0) 54%),
        radial-gradient(circle at 100% 0%, rgba(106, 255, 221, 0.05), rgba(0, 0, 0, 0) 24%),
        linear-gradient(165deg, rgba(7, 15, 28, 0.96), rgba(4, 10, 19, 0.95));
    padding: 0.95rem;
    gap: 0.9rem;
    box-shadow:
        0 18px 42px rgba(0, 0, 0, 0.26),
        inset 0 0 0 1px rgba(255, 255, 255, 0.025);
}

.enigma-solo-panel-shell .enigma-solo-panel-title {
    margin: 0.15rem 0 0;
    font-size: 1.05rem;
    line-height: 1.2;
}

.enigma-solo-panel-subtitle {
    margin: 0.2rem 0 0;
    color: rgba(228, 239, 255, 0.92);
    font-size: 0.84rem;
    line-height: 1.35;
}

.enigma-solo-panel-icon {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.07em;
    color: #eaf6ff;
    background: rgba(100, 164, 255, 0.16);
}

.enigma-solo-panel-meta {
    display: flex;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.enigma-solo-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 1.55rem;
    padding: 0 0.58rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.15);
    background: rgba(255, 255, 255, 0.04);
    color: #ddeaf8;
    font-size: 0.71rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 700;
}

.enigma-solo-hud-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
}

.enigma-solo-hud-card {
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.09);
    background: rgba(255, 255, 255, 0.03);
    padding: 0.5rem 0.62rem;
    display: grid;
    gap: 0.18rem;
}

.enigma-solo-hud-card span {
    color: rgba(225, 236, 252, 0.88);
    font-size: 0.69rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.enigma-solo-hud-card strong {
    font-size: 0.95rem;
    color: #f2f8ff;
    text-shadow: 0 1px 8px rgba(93, 163, 255, 0.2);
}

.enigma-solo-hud-card.tone-warning {
    border-color: rgba(255, 196, 127, 0.28);
}

.enigma-solo-hud-card.tone-danger {
    border-color: rgba(255, 131, 131, 0.3);
}

.enigma-solo-hud-card.tone-info {
    border-color: rgba(158, 164, 255, 0.28);
}

.enigma-solo-dial-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 0.55rem;
}

.enigma-solo-dial-card {
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.03);
    padding: 0.5rem;
    display: grid;
    gap: 0.5rem;
}

.enigma-solo-dial-ring {
    --dial-angle: 0deg;
    --dial-target-angle: -1deg;
    width: 86px;
    height: 86px;
    margin: 0 auto;
    border-radius: 50%;
    position: relative;
    display: grid;
    place-items: center;
    background:
        conic-gradient(from -90deg, rgba(124, 204, 255, 0.95) 0 var(--dial-angle), rgba(42, 56, 79, 0.5) var(--dial-angle) 360deg);
    box-shadow:
        inset 0 0 0 9px rgba(6, 14, 24, 0.94),
        0 0 24px rgba(102, 191, 255, 0.2);
}

.enigma-solo-dial-ring::before {
    content: "";
    width: 62px;
    height: 62px;
    border-radius: 50%;
    background: linear-gradient(170deg, rgba(13, 25, 43, 0.98), rgba(7, 14, 24, 0.98));
    border: 1px solid rgba(146, 178, 220, 0.24);
}

.enigma-solo-dial-ring::after {
    content: "";
    position: absolute;
    width: 3px;
    height: 38px;
    top: 5px;
    left: 50%;
    transform-origin: center 38px;
    transform: translateX(-50%) rotate(var(--dial-target-angle));
    background: linear-gradient(180deg, rgba(255, 215, 142, 0.94), rgba(255, 166, 88, 0.42));
    border-radius: 99px;
    opacity: 0.95;
    display: var(--dial-target-visible, block);
}

.enigma-solo-dial-value {
    position: absolute;
    z-index: 1;
    font-size: 0.72rem;
    font-weight: 800;
    color: #edf6ff;
    text-shadow: 0 1px 8px rgba(76, 166, 255, 0.24);
}

.enigma-solo-dial-card header {
    display: flex;
    justify-content: center;
    align-items: center;
    color: rgba(220, 236, 255, 0.88);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.enigma-solo-dial-controls {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.42rem;
}

.enigma-solo-dial-controls .enigma-panel-action {
    min-height: 2rem;
    font-size: 1rem;
    font-weight: 800;
}

.enigma-solo-cell-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(64px, 1fr));
    gap: 0.42rem;
}

.enigma-solo-cell-action {
    min-height: 2.05rem;
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.15);
    background: rgba(11, 23, 40, 0.9);
    color: #dbe8fb;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 0.2rem;
    padding: 0 0.46rem 0 0.5rem;
}

.enigma-solo-cell-glyph {
    font-size: 0.95rem;
    letter-spacing: 0;
    text-shadow: 0 0 12px rgba(97, 199, 255, 0.36);
}

.enigma-solo-cell-action small {
    font-size: 0.63rem;
    color: rgba(215, 235, 255, 0.84);
}

.enigma-solo-cell-action.active {
    border-color: rgba(120, 224, 187, 0.72);
    background: linear-gradient(170deg, rgba(19, 56, 44, 0.95), rgba(8, 29, 22, 0.95));
    color: #d7ffe9;
    box-shadow: 0 0 20px rgba(116, 228, 186, 0.18);
}

.enigma-solo-cell-action.disabled {
    opacity: 0.48;
}

.enigma-solo-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(74px, 1fr));
    gap: 0.42rem;
}

.enigma-solo-card-grid .enigma-panel-action {
    min-height: 2.25rem;
    font-size: 0.74rem;
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 0.2rem;
    padding: 0 0.5rem;
}

.enigma-solo-card-glyph {
    font-size: 0.98rem;
    text-shadow: 0 0 14px rgba(196, 159, 255, 0.34);
}

.enigma-solo-card-grid .enigma-panel-action small {
    font-size: 0.62rem;
    color: rgba(220, 237, 255, 0.82);
}

.enigma-panel-action {
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(10, 21, 37, 0.9);
    color: #e5f0ff;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.02em;
}

.enigma-solo-panel-actions .enigma-panel-action {
    min-height: 2.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.36rem;
}

.enigma-solo-system-glyph {
    font-size: 0.88rem;
    text-shadow: 0 0 12px rgba(106, 180, 255, 0.32);
}

.enigma-panel-action:disabled,
.enigma-puzzle-overlay-shell .btn:disabled {
    opacity: 1;
    cursor: not-allowed;
    color: rgba(230, 238, 249, 0.78);
    -webkit-text-fill-color: rgba(230, 238, 249, 0.78);
    border-color: rgba(181, 198, 222, 0.26);
    background: rgba(24, 34, 50, 0.84);
    box-shadow: none;
}

.enigma-panel-action.is-active {
    border-color: rgba(123, 220, 181, 0.68);
    background: linear-gradient(170deg, rgba(16, 52, 40, 0.95), rgba(8, 28, 20, 0.95));
    box-shadow: 0 0 16px rgba(107, 229, 180, 0.17);
}

.enigma-panel-action.is-disabled {
    opacity: 1;
    color: rgba(230, 238, 249, 0.78);
    -webkit-text-fill-color: rgba(230, 238, 249, 0.78);
    border-color: rgba(181, 198, 222, 0.26);
    background: rgba(24, 34, 50, 0.84);
}

.enigma-panel-action.tone-dial {
    border-color: rgba(120, 186, 255, 0.44);
}

.enigma-panel-action.tone-cell {
    border-color: rgba(143, 220, 188, 0.42);
}

.enigma-panel-action.tone-memory {
    border-color: rgba(190, 156, 255, 0.42);
}

.enigma-panel-action.tone-nav {
    border-color: rgba(141, 161, 255, 0.42);
}

.enigma-solo-panel-shell .enigma-mini-stat strong {
    color: #eef6ff;
}

.enigma-solo-chip.solved {
    border-color: rgba(116, 232, 183, 0.62);
    color: #cbffe6;
    background: rgba(38, 88, 66, 0.44);
}

.enigma-solo-chip.cooldown,
.enigma-solo-chip.failed,
.enigma-solo-chip.resetting {
    border-color: rgba(255, 168, 123, 0.62);
    color: #ffe1cc;
    background: rgba(95, 48, 29, 0.42);
}

.enigma-solo-panel-shell.family-chromatic-lock .enigma-solo-panel-icon,
.enigma-solo-panel-shell.family-fault-line .enigma-solo-panel-icon {
    background: rgba(255, 118, 201, 0.2);
}

.enigma-solo-panel-shell.family-signal-decay .enigma-solo-panel-icon,
.enigma-solo-panel-shell.family-echo-chamber .enigma-solo-panel-icon {
    background: rgba(119, 206, 255, 0.2);
}

.enigma-solo-panel-shell.family-pressure-grid .enigma-solo-panel-icon,
.enigma-solo-panel-shell.family-token-flood .enigma-solo-panel-icon {
    background: rgba(127, 228, 183, 0.2);
}

.enigma-solo-cell-grid.family-token-flood .enigma-solo-cell-action .enigma-solo-cell-glyph {
    color: #b9f8e5;
}

.enigma-solo-panel-shell.family-memory-palace .enigma-solo-panel-icon,
.enigma-solo-panel-shell.family-temporal-grid .enigma-solo-panel-icon {
    background: rgba(182, 152, 255, 0.2);
}

.enigma-solo-panel-shell.stage-intro {
    box-shadow: 0 0 0 1px rgba(138, 196, 255, 0.16), inset 0 0 0 1px rgba(138, 196, 255, 0.08);
}

.enigma-solo-panel-shell.stage-expand {
    box-shadow: 0 0 0 1px rgba(138, 196, 255, 0.14), inset 0 0 0 1px rgba(138, 196, 255, 0.07), 0 12px 28px rgba(41, 88, 158, 0.22);
}

.enigma-solo-panel-shell.stage-constraint {
    box-shadow: 0 0 0 1px rgba(154, 196, 255, 0.18), inset 0 0 0 1px rgba(154, 196, 255, 0.08), 0 14px 30px rgba(40, 95, 175, 0.24);
}

.enigma-solo-panel-shell.stage-master {
    box-shadow: 0 0 0 1px rgba(255, 160, 132, 0.24), inset 0 0 0 1px rgba(255, 160, 132, 0.12), 0 16px 34px rgba(151, 65, 36, 0.3);
}

.enigma-solo-failure-card {
    border-radius: 11px;
    border: 1px solid rgba(255, 140, 120, 0.46);
    background: linear-gradient(165deg, rgba(66, 26, 24, 0.92), rgba(37, 16, 15, 0.94));
    padding: 0.55rem 0.7rem;
    display: grid;
    gap: 0.16rem;
}

.enigma-solo-failure-card strong {
    color: #ffd9cf;
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.enigma-solo-failure-card span {
    color: rgba(255, 225, 214, 0.88);
    font-size: 0.73rem;
    line-height: 1.35;
}

.enigma-solo-progress-axis {
    border-radius: 10px;
    border: 1px solid rgba(144, 196, 255, 0.28);
    background: rgba(12, 24, 43, 0.85);
    min-height: 2.15rem;
    padding: 0.34rem 0.6rem;
    display: grid;
    grid-template-columns: 1fr auto auto;
    align-items: center;
    gap: 0.5rem;
}

.enigma-solo-progress-axis span {
    color: rgba(206, 227, 252, 0.88);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.enigma-solo-progress-axis strong {
    color: #f1f8ff;
    font-size: 0.86rem;
}

.enigma-solo-progress-axis small {
    color: rgba(178, 212, 247, 0.84);
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.enigma-solo-progress-axis.trend-up {
    border-color: rgba(117, 224, 178, 0.44);
}

.enigma-solo-progress-axis.trend-down {
    border-color: rgba(255, 148, 130, 0.52);
}

.enigma-chromatic-panel-shell {
    --chromatic-bg: #07080f;
    --chromatic-surface: #0d0f1c;
    --chromatic-card: #121528;
    --chromatic-border: rgba(104, 123, 180, 0.24);
    --chromatic-text: #eef4ff;
    --chromatic-dim: rgba(214, 226, 246, 0.84);
    --chromatic-accent: #e84393;
    --chromatic-cyan: #00d4ff;
    --chromatic-gold: #f5c518;
    --chromatic-green: #4ade80;
    --chromatic-red: #ef4444;
    display: grid;
    gap: 1rem;
    border-radius: 18px;
    border: 1px solid rgba(255, 255, 255, 0.11);
    background:
        radial-gradient(circle at 10% 0%, rgba(232, 67, 147, 0.14), transparent 34%),
        radial-gradient(circle at 88% 12%, rgba(0, 212, 255, 0.12), transparent 28%),
        linear-gradient(165deg, rgba(7, 10, 19, 0.98), rgba(4, 8, 16, 0.98));
    padding: 0.95rem;
}

.enigma-chromatic-panel-stage {
    display: grid;
    grid-template-columns: minmax(280px, 420px) minmax(0, 1fr);
    gap: 1rem;
    align-items: start;
}

.enigma-chromatic-vault-wrap {
    position: relative;
    aspect-ratio: 1 / 1;
    min-height: 280px;
    border-radius: 22px;
    overflow: hidden;
    background:
        radial-gradient(circle at 30% 20%, rgba(85, 41, 137, 0.12), transparent 34%),
        radial-gradient(circle at 80% 76%, rgba(24, 64, 146, 0.12), transparent 32%),
        linear-gradient(180deg, rgba(8, 10, 18, 0.98), rgba(4, 6, 12, 0.98));
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.enigma-chromatic-vault-wrap::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 24% 28%, rgba(255, 255, 255, 0.07) 0 1px, transparent 1px 100%),
        radial-gradient(circle at 68% 78%, rgba(255, 255, 255, 0.05) 0 1px, transparent 1px 100%),
        radial-gradient(circle at 78% 18%, rgba(255, 255, 255, 0.06) 0 1px, transparent 1px 100%);
    opacity: 0.55;
    pointer-events: none;
}

.enigma-chromatic-vault-svg {
    width: 100%;
    height: 100%;
    display: block;
    touch-action: none;
    user-select: none;
}

.enigma-chromatic-target-blob {
    position: absolute;
    width: 140px;
    height: 140px;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    border-radius: 999px;
    filter: blur(22px);
    opacity: 0.72;
    animation: chromaticBlobPulse 3.2s ease-in-out infinite;
    pointer-events: none;
}

.enigma-chromatic-current-swatch {
    position: absolute;
    right: 0.9rem;
    bottom: 0.9rem;
    width: 58px;
    height: 58px;
    border-radius: 999px;
    border: 2px solid rgba(255, 255, 255, 0.16);
    box-shadow: 0 0 14px rgba(0, 0, 0, 0.35);
    pointer-events: none;
}

.enigma-chromatic-current-swatch::after {
    content: "NOW";
    position: absolute;
    left: 50%;
    bottom: -18px;
    transform: translateX(-50%);
    color: var(--chromatic-dim);
    font-size: 0.62rem;
    letter-spacing: 0.14em;
}

.enigma-chromatic-lockout-flash {
    position: absolute;
    inset: 0;
    background: rgba(239, 68, 68, 0.08);
    opacity: 0;
    transition: opacity 120ms ease;
    pointer-events: none;
}

.enigma-chromatic-lockout-flash.active {
    opacity: 1;
}

.enigma-chromatic-meter-track,
.enigma-chromatic-dial-track,
.enigma-chromatic-dial-fill,
.enigma-chromatic-meter-arc {
    fill: none;
}

.enigma-chromatic-meter-track {
    stroke: rgba(96, 113, 161, 0.32);
    stroke-width: 4;
}

.enigma-chromatic-meter-arc {
    stroke-width: 6;
    stroke-linecap: round;
    transition: stroke-dashoffset 120ms linear, stroke 220ms ease;
    pointer-events: none;
}

.enigma-chromatic-meter-arc.base {
    stroke: rgba(74, 222, 128, 0.8);
}

.enigma-chromatic-meter-arc.near {
    stroke: rgba(245, 197, 24, 0.9);
}

.enigma-chromatic-meter-arc.lock {
    stroke: rgba(74, 222, 128, 1);
    filter: drop-shadow(0 0 10px rgba(74, 222, 128, 0.5));
}

.enigma-chromatic-dial-track {
    stroke: rgba(23, 28, 48, 0.9);
    stroke-width: 36;
    cursor: grab;
}

.enigma-chromatic-dial-track:hover {
    stroke-width: 40;
}

.enigma-chromatic-dial-fill {
    stroke-width: 36;
    stroke-linecap: round;
    pointer-events: none;
}

.enigma-chromatic-dial-fill.hue {
    stroke: #e84393;
}

.enigma-chromatic-dial-fill.sat {
    stroke: #00d4ff;
}

.enigma-chromatic-dial-fill.light {
    stroke: #f5c518;
}

.enigma-chromatic-thumb {
    transition: r 120ms ease;
    filter: drop-shadow(0 0 10px currentColor);
    pointer-events: none;
}

.enigma-chromatic-thumb.hue {
    fill: #e84393;
    color: #e84393;
}

.enigma-chromatic-thumb.sat {
    fill: #00d4ff;
    color: #00d4ff;
}

.enigma-chromatic-thumb.light {
    fill: #f5c518;
    color: #f5c518;
}

.enigma-chromatic-ring-label {
    fill: rgba(214, 227, 249, 0.74);
    font-size: 10px;
    letter-spacing: 2px;
}

.enigma-chromatic-vault-door {
    transform-origin: 210px 210px;
    transition: transform 1.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.enigma-chromatic-vault-door.open {
    transform: rotate(-105deg) translate(-12px, 4px);
}

.enigma-chromatic-door-plate {
    fill: rgba(12, 16, 28, 0.96);
    stroke: rgba(98, 116, 165, 0.42);
    stroke-width: 2;
}

.enigma-chromatic-door-spokes {
    stroke: rgba(98, 116, 165, 0.52);
    stroke-width: 1.5;
}

.enigma-chromatic-door-ring {
    fill: none;
    stroke: rgba(116, 137, 190, 0.42);
    stroke-width: 3;
}

.enigma-chromatic-door-core {
    fill: rgba(13, 18, 32, 0.98);
    stroke: rgba(116, 137, 190, 0.42);
    stroke-width: 2;
}

.enigma-chromatic-door-bolt {
    fill: rgba(96, 113, 161, 0.46);
}

.enigma-chromatic-side-panel {
    display: grid;
    gap: 0.78rem;
}

.enigma-chromatic-title {
    margin: 0;
    color: var(--chromatic-text);
    font-size: 2rem;
    line-height: 0.95;
    letter-spacing: -0.04em;
    font-weight: 800;
}

.enigma-chromatic-round-label {
    margin-top: 0.35rem;
    color: rgba(232, 67, 147, 0.92);
    font-size: 0.7rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.enigma-chromatic-pips {
    display: flex;
    gap: 0.5rem;
    margin-top: 0.55rem;
}

.enigma-chromatic-pip {
    width: 11px;
    height: 11px;
    border-radius: 999px;
    border: 1.5px solid var(--pip-color);
    background: transparent;
    box-shadow: none;
}

.enigma-chromatic-pip.done,
.enigma-chromatic-pip.current {
    background: var(--pip-color);
    box-shadow: 0 0 10px color-mix(in srgb, var(--pip-color) 70%, transparent);
}

.enigma-chromatic-pill-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem;
}

.enigma-chromatic-pill {
    display: inline-flex;
    align-items: center;
    min-height: 1.8rem;
    padding: 0 0.72rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.02);
    color: rgba(228, 237, 255, 0.88);
    font-size: 0.66rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.enigma-chromatic-pill.active,
.enigma-chromatic-pill.ready {
    color: var(--chromatic-text);
    border-color: rgba(255, 255, 255, 0.26);
    box-shadow: 0 0 16px rgba(116, 137, 190, 0.16);
}

.enigma-chromatic-pill.alert {
    border-color: rgba(239, 68, 68, 0.34);
    color: rgba(255, 170, 170, 0.92);
}

.enigma-chromatic-osc-warning {
    display: none;
    align-items: center;
    min-height: 1.8rem;
    padding: 0 0.72rem;
    border-radius: 999px;
    border: 1px solid rgba(232, 67, 147, 0.24);
    background: rgba(232, 67, 147, 0.08);
    color: rgba(232, 67, 147, 0.92);
    font-size: 0.66rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.enigma-chromatic-osc-warning.show {
    display: inline-flex;
}

.enigma-chromatic-summary-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
}

.enigma-chromatic-summary-card,
.enigma-chromatic-channel-row,
.enigma-chromatic-match-section {
    border-radius: 12px;
    border: 1px solid var(--chromatic-border);
    background: rgba(18, 21, 40, 0.92);
}

.enigma-chromatic-summary-card {
    padding: 0.56rem 0.68rem;
    display: grid;
    gap: 0.18rem;
}

.enigma-chromatic-summary-card span {
    color: var(--chromatic-dim);
    font-size: 0.62rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.enigma-chromatic-summary-card strong {
    color: var(--chromatic-text);
    font-size: 1.02rem;
    line-height: 1;
}

.enigma-chromatic-summary-card strong.warn {
    color: rgba(245, 197, 24, 0.96);
}

.enigma-chromatic-summary-card strong.crit {
    color: rgba(239, 68, 68, 0.98);
}

.enigma-chromatic-summary-card strong.lock {
    color: rgba(74, 222, 128, 0.98);
}

.enigma-chromatic-timer-track,
.enigma-chromatic-match-track,
.enigma-chromatic-hold-track {
    border-radius: 999px;
    overflow: hidden;
    background: rgba(47, 57, 90, 0.6);
}

.enigma-chromatic-timer-track {
    height: 5px;
}

.enigma-chromatic-timer-fill {
    height: 100%;
    background: linear-gradient(90deg, rgba(0, 212, 255, 0.86), rgba(91, 226, 255, 0.96));
}

.enigma-chromatic-timer-fill.warn {
    background: linear-gradient(90deg, rgba(245, 197, 24, 0.86), rgba(255, 220, 91, 0.96));
}

.enigma-chromatic-timer-fill.crit {
    background: linear-gradient(90deg, rgba(239, 68, 68, 0.86), rgba(255, 116, 116, 0.96));
}

.enigma-chromatic-channel-stack {
    display: grid;
    gap: 0.55rem;
}

.enigma-chromatic-channel-row {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto auto;
    gap: 0.6rem;
    align-items: center;
    padding: 0.56rem 0.72rem;
}

.enigma-chromatic-channel-row.aligned {
    border-color: color-mix(in srgb, var(--channel-color) 55%, rgba(255, 255, 255, 0.18));
}

.enigma-chromatic-channel-row .label {
    color: var(--chromatic-dim);
    font-size: 0.64rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.enigma-chromatic-channel-row .bar-track {
    height: 7px;
    border-radius: 999px;
    overflow: hidden;
    background: rgba(47, 57, 90, 0.65);
}

.enigma-chromatic-channel-row .bar-fill {
    height: 100%;
    border-radius: 999px;
}

.enigma-chromatic-channel-row .value,
.enigma-chromatic-channel-row .delta {
    color: var(--chromatic-text);
    font-size: 0.74rem;
}

.enigma-chromatic-channel-row .delta.close {
    color: rgba(74, 222, 128, 0.92);
}

.enigma-chromatic-channel-row .delta.mid {
    color: rgba(245, 197, 24, 0.92);
}

.enigma-chromatic-channel-row .delta.far {
    color: rgba(239, 68, 68, 0.92);
}

.enigma-chromatic-match-section {
    padding: 0.68rem 0.75rem;
    display: grid;
    gap: 0.5rem;
}

.enigma-chromatic-match-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 0.6rem;
}

.enigma-chromatic-match-head span {
    color: var(--chromatic-dim);
    font-size: 0.64rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.enigma-chromatic-match-head strong {
    color: rgba(74, 222, 128, 0.92);
    font-size: 1.1rem;
}

.enigma-chromatic-match-head strong.near {
    color: rgba(245, 197, 24, 0.94);
}

.enigma-chromatic-match-head strong.lock {
    color: rgba(74, 222, 128, 1);
}

.enigma-chromatic-match-track {
    height: 10px;
}

.enigma-chromatic-match-fill,
.enigma-chromatic-hold-fill {
    height: 100%;
    border-radius: 999px;
}

.enigma-chromatic-match-fill.base {
    background: linear-gradient(90deg, rgba(28, 90, 58, 0.9), rgba(74, 222, 128, 0.98));
}

.enigma-chromatic-match-fill.near {
    background: linear-gradient(90deg, rgba(130, 78, 10, 0.92), rgba(245, 197, 24, 0.98));
}

.enigma-chromatic-match-fill.lock {
    background: linear-gradient(90deg, rgba(28, 90, 58, 0.95), rgba(118, 255, 164, 1));
    box-shadow: 0 0 14px rgba(74, 222, 128, 0.26);
}

.enigma-chromatic-hold-track {
    height: 5px;
}

.enigma-chromatic-hold-fill {
    background: linear-gradient(90deg, rgba(74, 222, 128, 0.82), rgba(118, 255, 164, 1));
}

.enigma-chromatic-action-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.enigma-chromatic-action-row .enigma-panel-action {
    min-height: 2.2rem;
    min-width: 8rem;
}

@keyframes chromaticBlobPulse {
    0%, 100% {
        transform: translate(-50%, -50%) scale(1);
    }

    50% {
        transform: translate(-50%, -50%) scale(1.08);
    }
}

@media (max-width: 980px) {
    .enigma-chromatic-panel-stage {
        grid-template-columns: 1fr;
    }

    .enigma-chromatic-vault-wrap {
        max-width: 420px;
        margin: 0 auto;
    }
}

@media (max-width: 640px) {
    .enigma-chromatic-summary-strip {
        grid-template-columns: 1fr;
    }

    .enigma-chromatic-channel-row {
        grid-template-columns: auto 1fr;
    }

    .enigma-chromatic-channel-row .value,
    .enigma-chromatic-channel-row .delta {
        justify-self: end;
    }
}

.enigma-signal-decay-monitor {
    display: grid;
    gap: 0.4rem;
    border-radius: 12px;
    border: 1px solid rgba(120, 197, 255, 0.35);
    background: linear-gradient(180deg, rgba(8, 27, 46, 0.82), rgba(6, 20, 36, 0.9));
    padding: 0.55rem 0.65rem;
}

.enigma-signal-waveform {
    position: relative;
    height: 46px;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid rgba(123, 203, 255, 0.28);
    background:
        repeating-linear-gradient(
            to right,
            rgba(148, 210, 255, 0.07) 0px,
            rgba(148, 210, 255, 0.07) 1px,
            transparent 1px,
            transparent 14px
        ),
        linear-gradient(180deg, rgba(5, 19, 34, 0.95), rgba(3, 13, 24, 0.98));
}

.enigma-signal-waveform-trace {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(45% 48% at 12% 50%, rgba(103, 207, 255, calc(0.22 + (var(--signal-noise) * 0.55))), transparent 75%),
        radial-gradient(45% 55% at 38% 50%, rgba(103, 207, 255, calc(0.2 + (var(--signal-noise) * 0.5))), transparent 78%),
        radial-gradient(45% 50% at 64% 50%, rgba(103, 207, 255, calc(0.18 + (var(--signal-noise) * 0.45))), transparent 78%),
        radial-gradient(45% 48% at 90% 50%, rgba(103, 207, 255, calc(0.22 + (var(--signal-noise) * 0.55))), transparent 75%);
    animation: enigma-signal-wave calc(var(--signal-speed, 1s)) linear infinite;
    transform-origin: center;
}

.enigma-signal-readout {
    color: rgba(214, 236, 255, 0.92);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.enigma-signal-align-track {
    position: relative;
    height: 12px;
    border-radius: 999px;
    border: 1px solid rgba(126, 194, 255, 0.25);
    background: rgba(8, 21, 36, 0.88);
    overflow: hidden;
    margin-top: 0.2rem;
}

.enigma-signal-align-window {
    position: absolute;
    top: 1px;
    bottom: 1px;
    left: calc(var(--signal-target) - (var(--signal-window) / 2));
    width: var(--signal-window);
    border-radius: 999px;
    background: rgba(108, 225, 177, 0.24);
    border: 1px solid rgba(108, 225, 177, 0.45);
}

.enigma-signal-align-marker {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 8px;
    left: calc(var(--signal-current) - 4px);
    border-radius: 999px;
    background: linear-gradient(180deg, #d9f7ff, #95daff);
    box-shadow: 0 0 10px rgba(130, 214, 255, 0.65);
}

.enigma-signal-align-track.aligned {
    border-color: rgba(98, 230, 170, 0.7);
}

.enigma-signal-align-track.aligned .enigma-signal-align-marker {
    background: linear-gradient(180deg, #d8ffe8, #8ff4be);
    box-shadow: 0 0 12px rgba(102, 236, 173, 0.8);
}

.enigma-signal-align-track.near {
    border-color: rgba(255, 214, 141, 0.58);
}

.enigma-signal-align-track.off {
    border-color: rgba(255, 144, 144, 0.55);
}

@keyframes enigma-signal-wave {
    0% {
        transform: translateX(0) scaleY(calc(1 + (var(--signal-noise) * 0.55)));
        opacity: calc(0.7 + (var(--signal-noise) * 0.35));
    }
    50% {
        transform: translateX(-2%) scaleY(calc(0.95 + (var(--signal-noise) * 0.7)));
        opacity: calc(0.86 + (var(--signal-noise) * 0.25));
    }
    100% {
        transform: translateX(-4%) scaleY(calc(1 + (var(--signal-noise) * 0.55)));
        opacity: calc(0.7 + (var(--signal-noise) * 0.35));
    }
}

.enigma-signal-console-shell {
    border-radius: 14px;
    border: 1px solid rgba(126, 194, 255, 0.18);
    background:
        radial-gradient(circle at top left, rgba(92, 158, 255, 0.16), transparent 28%),
        radial-gradient(circle at 100% 12%, rgba(103, 248, 210, 0.06), transparent 24%),
        linear-gradient(180deg, rgba(5, 17, 30, 0.97), rgba(4, 12, 22, 0.99));
    padding: 0.95rem;
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.025),
        0 16px 36px rgba(0, 0, 0, 0.22);
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum" 1;
}

.enigma-signal-console-main {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(280px, 0.84fr);
    gap: 0.85rem;
    align-items: start;
}

.enigma-signal-console-left,
.enigma-signal-console-right {
    display: grid;
    gap: 0.8rem;
    align-content: start;
    min-width: 0;
}

.enigma-signal-console-right {
    position: sticky;
    top: 0;
    align-self: start;
}

.enigma-signal-scope-card,
.enigma-signal-level-card,
.enigma-signal-fft-card,
.enigma-signal-stat-card,
.enigma-signal-component-card {
    border-radius: 14px;
    border: 1px solid rgba(138, 191, 255, 0.16);
    background: linear-gradient(180deg, rgba(10, 24, 40, 0.96), rgba(6, 18, 31, 0.98));
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}

.enigma-signal-scope-head,
.enigma-signal-level-card {
    display: grid;
    gap: 0.25rem;
}

.enigma-signal-scope-head {
    grid-template-columns: 1fr auto;
    align-items: center;
    margin-bottom: 0.6rem;
}

.enigma-signal-scope-head strong,
.enigma-signal-level-card strong {
    color: #eef7ff;
    font-size: 0.95rem;
}

.enigma-signal-scope-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 1.8rem;
    min-width: 12.25rem;
    padding: 0 0.7rem;
    border-radius: 999px;
    border: 1px solid rgba(126, 203, 255, 0.28);
    color: #c9e9ff;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.enigma-signal-scope-frame {
    position: relative;
    overflow: hidden;
    min-height: 250px;
    border-radius: 14px;
    border: 1px solid rgba(132, 201, 255, 0.2);
    background:
        linear-gradient(rgba(123, 208, 255, 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(123, 208, 255, 0.05) 1px, transparent 1px),
        linear-gradient(180deg, rgba(4, 15, 28, 0.98), rgba(2, 10, 19, 1));
    background-size: 72px 48px, 72px 48px, 100% 100%;
}

.enigma-signal-scope-frame::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        repeating-linear-gradient(180deg, transparent 0, transparent 3px, rgba(0, 0, 0, 0.12) 3px, rgba(0, 0, 0, 0.12) 4px);
    pointer-events: none;
    opacity: 0.55;
}

.enigma-signal-scope-frame.preview-faded .scope-trace.target {
    opacity: 0;
}

.enigma-signal-scope-svg {
    width: 100%;
    height: auto;
    display: block;
}

.enigma-signal-scope-svg .scope-grid-major {
    stroke: rgba(123, 208, 255, 0.09);
    stroke-width: 1;
}

.enigma-signal-scope-svg .scope-trace {
    fill: none;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.enigma-signal-scope-svg .scope-trace.target {
    stroke: rgba(131, 255, 208, 0.45);
    stroke-width: 2.2;
    filter: drop-shadow(0 0 8px rgba(120, 255, 198, 0.24));
}

.enigma-signal-scope-svg .scope-trace.current {
    stroke: rgba(137, 212, 255, 0.98);
    stroke-width: 3;
    filter: drop-shadow(0 0 12px rgba(120, 204, 255, 0.44));
}

.enigma-signal-scope-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 0.85rem;
    pointer-events: none;
}

.enigma-signal-scope-match,
.enigma-signal-hold-wrap {
    align-self: flex-start;
    display: grid;
    gap: 0.2rem;
    padding: 0.45rem 0.6rem;
    min-width: 8.35rem;
    border-radius: 12px;
    border: 1px solid rgba(129, 198, 255, 0.18);
    background: rgba(4, 15, 26, 0.72);
}

.enigma-signal-scope-match {
    align-self: flex-end;
    text-align: right;
}

.enigma-signal-scope-match span,
.enigma-signal-hold-wrap span,
.enigma-signal-stat-card span {
    color: rgba(197, 223, 251, 0.78);
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.enigma-signal-scope-match strong,
.enigma-signal-hold-wrap strong,
.enigma-signal-stat-card strong {
    color: #eff8ff;
    font-size: 1.02rem;
}

.enigma-signal-hold-bar,
.enigma-signal-timer-track {
    height: 6px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    overflow: hidden;
}

.enigma-signal-hold-fill,
.enigma-signal-timer-fill {
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, rgba(122, 239, 195, 0.95), rgba(126, 202, 255, 0.98));
    box-shadow: 0 0 12px rgba(121, 220, 255, 0.35);
}

.enigma-signal-fft-card,
.enigma-signal-level-card,
.enigma-signal-component-card {
    padding: 0.8rem;
}

.enigma-signal-fft-card header {
    display: grid;
    gap: 0.2rem;
    margin-bottom: 0.65rem;
}

.enigma-signal-fft-bars {
    height: 64px;
    display: grid;
    grid-template-columns: repeat(8, minmax(0, 1fr));
    align-items: end;
    gap: 0.3rem;
}

.enigma-signal-fft-bar {
    min-height: 6px;
    border-radius: 10px 10px 2px 2px;
    background: linear-gradient(180deg, rgba(116, 194, 255, 0.92), rgba(66, 118, 190, 0.55));
}

.enigma-signal-fft-bar.dominant {
    background: linear-gradient(180deg, rgba(255, 214, 127, 0.98), rgba(255, 160, 96, 0.62));
    box-shadow: 0 0 10px rgba(255, 188, 116, 0.32);
}

.enigma-signal-component-stack {
    display: grid;
    gap: 0.65rem;
}

.enigma-signal-component-card {
    display: grid;
    gap: 0.65rem;
    min-height: 13.2rem;
}

.enigma-signal-component-card header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.6rem;
    align-items: center;
    min-height: 2.85rem;
}

.enigma-signal-component-title {
    display: grid;
    gap: 0.16rem;
}

.enigma-signal-component-title strong {
    color: #eef7ff;
    font-size: 0.9rem;
}

.enigma-signal-component-meta {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    justify-self: end;
}

.enigma-signal-component-align {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 4.6rem;
    min-height: 1.7rem;
    padding: 0 0.55rem;
    border-radius: 999px;
    border: 1px solid rgba(126, 192, 255, 0.22);
    background: rgba(8, 18, 30, 0.86);
    color: #eff8ff;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 700;
}

.enigma-signal-component-align.aligned,
.enigma-signal-component-align.near {
    border-color: rgba(111, 236, 182, 0.34);
}

.enigma-signal-component-align.off {
    border-color: rgba(255, 150, 150, 0.22);
}

.enigma-signal-component-card.aligned {
    border-color: rgba(111, 236, 182, 0.34);
    box-shadow: 0 0 0 1px rgba(111, 236, 182, 0.12), inset 0 0 18px rgba(62, 142, 107, 0.18);
}

.enigma-signal-component-card.near {
    border-color: rgba(255, 209, 132, 0.28);
}

.enigma-signal-component-card.off {
    border-color: rgba(255, 150, 150, 0.22);
}

.enigma-signal-component-state {
    color: rgba(198, 221, 248, 0.84);
    font-size: 0.72rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.enigma-signal-wave-buttons {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.45rem;
}

.enigma-signal-wave-button {
    min-height: 2.3rem;
    border-radius: 10px;
    border: 1px solid rgba(126, 192, 255, 0.18);
    background: rgba(6, 16, 28, 0.82);
    color: #e2effd;
    display: grid;
    place-items: center;
    gap: 0.08rem;
}

.enigma-signal-wave-button span {
    font-size: 0.95rem;
    font-weight: 800;
}

.enigma-signal-wave-button small {
    font-size: 0.62rem;
    color: rgba(203, 225, 248, 0.82);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.enigma-signal-wave-button.selected {
    border-color: rgba(119, 223, 181, 0.52);
    background: linear-gradient(180deg, rgba(18, 48, 39, 0.98), rgba(9, 26, 22, 0.98));
    box-shadow: 0 0 14px rgba(104, 230, 179, 0.16);
}

.enigma-signal-slider-grid {
    display: grid;
    gap: 0.55rem;
}

.enigma-signal-slider-grid label {
    display: grid;
    grid-template-columns: 72px 1fr auto;
    align-items: center;
    gap: 0.55rem;
}

.enigma-signal-slider-grid label span {
    color: rgba(197, 220, 245, 0.82);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.enigma-signal-slider-grid label strong {
    color: #eef8ff;
    font-size: 0.8rem;
    min-width: 76px;
    text-align: right;
}

.enigma-signal-slider-grid input[type=range] {
    width: 100%;
    accent-color: #8bd0ff;
}

.enigma-signal-level-card p,
.enigma-signal-level-card small {
    margin: 0;
    color: rgba(206, 226, 247, 0.82);
    line-height: 1.45;
}

.enigma-signal-level-card {
    min-height: 18rem;
    align-content: start;
}

.enigma-signal-level-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 1.8rem;
    width: fit-content;
    padding: 0 0.72rem;
    border-radius: 999px;
    border: 1px solid rgba(126, 194, 255, 0.22);
    background: rgba(8, 18, 30, 0.82);
    color: #dceefe;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 700;
}

.enigma-signal-level-pill.ready {
    border-color: rgba(111, 236, 182, 0.38);
    color: #dffff0;
}

.enigma-signal-level-status {
    min-height: 3.1rem;
    display: block;
}

.enigma-signal-stat-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
}

.enigma-signal-stat-card {
    padding: 0.7rem;
    display: grid;
    gap: 0.2rem;
    min-height: 8.5rem;
    align-content: center;
}

.enigma-signal-preview-pill {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.45rem;
    min-height: 3.35rem;
    padding: 0.55rem 0.7rem;
    border-radius: 999px;
    border: 1px solid rgba(126, 194, 255, 0.18);
    color: #dceefe;
    background: rgba(5, 17, 28, 0.78);
}

.enigma-signal-preview-pill small {
    min-width: 3.2rem;
    text-align: right;
}

.enigma-signal-preview-pill .dot {
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 999px;
    background: #9cecff;
    box-shadow: 0 0 10px rgba(130, 218, 255, 0.56);
}

.enigma-signal-preview-pill.hidden .dot {
    background: #ffac9e;
    box-shadow: 0 0 10px rgba(255, 151, 151, 0.36);
}

.enigma-signal-action-stack {
    display: grid;
    gap: 0.55rem;
    align-content: start;
}

.enigma-signal-action-stack .enigma-panel-action {
    min-height: 2.5rem;
}

@media (max-width: 980px) {
    .enigma-signal-console-main {
        grid-template-columns: 1fr;
    }
}

.enigma-solo-pipe-grid {
    display: grid;
    gap: 0.44rem;
}

.enigma-solo-pipe-tile {
    min-height: 2.55rem;
    border-radius: 10px;
    border: 1px solid rgba(129, 188, 255, 0.25);
    background: linear-gradient(165deg, rgba(12, 25, 45, 0.96), rgba(8, 18, 34, 0.94));
    color: #d8ecff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: transform 120ms ease, border-color 150ms ease, box-shadow 160ms ease;
}

.enigma-solo-pipe-tile:hover {
    transform: translateY(-1px);
    border-color: rgba(152, 212, 255, 0.45);
}

.enigma-solo-pipe-tile.flowing {
    border-color: rgba(126, 241, 196, 0.7);
    box-shadow: inset 0 0 0 1px rgba(126, 241, 196, 0.34), 0 0 16px rgba(126, 241, 196, 0.18);
}

.enigma-solo-pipe-tile.route-active {
    background: linear-gradient(165deg, rgba(12, 43, 44, 0.95), rgba(9, 25, 30, 0.95));
}

.enigma-solo-pipe-tile.source {
    border-color: rgba(120, 180, 255, 0.72);
}

.enigma-solo-pipe-tile.sink {
    border-color: rgba(255, 191, 127, 0.72);
}

.enigma-solo-pipe-tile.disabled {
    opacity: 0.46;
}

.enigma-solo-pipe-glyph {
    font-size: 1.15rem;
    text-shadow: 0 0 16px rgba(105, 212, 255, 0.4);
}

.enigma-solo-hud-card.tone-success {
    border-color: rgba(126, 241, 196, 0.44);
}

.enigma-panel-action.tone-pipe {
    border-color: rgba(117, 214, 185, 0.44);
}

.enigma-advanced-panel-shell {
    --panel-accent: #8fb0ff;
    --panel-border: rgba(143, 176, 255, 0.18);
    display: grid;
    gap: 18px;
    padding: 18px;
    border-radius: 28px;
    border: 1px solid var(--panel-border);
    background:
        radial-gradient(circle at top left, color-mix(in srgb, var(--panel-accent) 22%, transparent), transparent 38%),
        radial-gradient(circle at bottom right, color-mix(in srgb, var(--panel-accent) 10%, transparent), transparent 42%),
        linear-gradient(180deg, rgba(14, 20, 31, 0.98), rgba(8, 12, 21, 0.98));
    box-shadow: 0 24px 56px rgba(0, 0, 0, 0.28);
}

.enigma-advanced-panel-shell.diff-easy {
    --panel-padding-scale: 1.08;
    --panel-guidance-opacity: 0.96;
}

.enigma-advanced-panel-shell.diff-medium {
    --panel-padding-scale: 1;
    --panel-guidance-opacity: 0.84;
}

.enigma-advanced-panel-shell.diff-hard {
    --panel-padding-scale: 0.92;
    --panel-guidance-opacity: 0.66;
}

.enigma-advanced-panel-shell.family-dead_reckoning {
    --panel-accent: #57d2ff;
}

.enigma-advanced-panel-shell.family-cipher_wheel {
    --panel-accent: #f5c84c;
}

.enigma-advanced-panel-shell.family-gravity_well {
    --panel-accent: #73f0c2;
}

.enigma-advanced-panel-shell.family-echo_chamber {
    --panel-accent: #ff6f91;
}

.enigma-advanced-panel-shell.family-fault_line {
    --panel-accent: #ff7e66;
}

.enigma-grid-template.family-pressure_grid {
    --panel-accent: #ff8b5d;
}

.enigma-grid-template.family-temporal_grid {
    --panel-accent: #84f0ff;
}

.enigma-flow-template {
    --panel-accent: #57c6ff;
}

.enigma-memory-template {
    --panel-accent: #ffd479;
}

.enigma-system-template {
    --panel-accent: #7fd3ff;
}

.enigma-advanced-stage-card,
.enigma-dial-bank-card,
.enigma-grid-node,
.enigma-flow-tile,
.enigma-memory-card,
.enigma-advanced-telemetry-grid article,
.enigma-advanced-status-card {
    border-radius: 20px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01)),
        rgba(11, 16, 27, 0.92);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.enigma-advanced-stage-card {
    display: grid;
    gap: 18px;
    padding: calc(22px * var(--panel-padding-scale, 1));
}

.enigma-advanced-stage-head,
.enigma-dial-template-main,
.enigma-grid-template-main,
.enigma-flow-template-main,
.enigma-memory-template-main,
.enigma-advanced-stage-badges,
.enigma-advanced-telemetry-grid,
.enigma-advanced-action-row,
.enigma-advanced-inline-actions,
.enigma-dial-bank,
.enigma-dial-bank-meta,
.enigma-dial-bank-controls {
    display: grid;
    gap: 14px;
}

.enigma-advanced-stage-head {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
}

.enigma-advanced-stage-head strong {
    display: block;
    margin-top: 6px;
    font-size: 1.45rem;
    line-height: 1.05;
    color: #fbfdff;
}

.enigma-advanced-stage-head p,
.enigma-advanced-status-card p {
    margin: 8px 0 0;
    color: rgba(234, 242, 255, 0.9);
    line-height: 1.55;
}

.enigma-advanced-stage-badges {
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    align-content: start;
}

.enigma-advanced-stage-pill {
    min-height: 36px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--panel-accent) 42%, rgba(255, 255, 255, 0.08));
    background: color-mix(in srgb, var(--panel-accent) 12%, rgba(255, 255, 255, 0.02));
    color: #f6fbff;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.enigma-advanced-stage-pill.muted {
    border-color: rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.03);
    color: rgba(236, 244, 255, 0.9);
}

.enigma-dial-template-main,
.enigma-grid-template-main,
.enigma-system-template-main,
.enigma-flow-template-main,
.enigma-memory-template-main {
    grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.8fr);
    align-items: start;
}

.enigma-dial-template-main,
.enigma-system-template-main {
    grid-template-columns: minmax(0, 1.1fr) minmax(300px, 0.72fr);
}

.enigma-dial-visual-card,
.enigma-grid-rail,
.enigma-system-visual-card,
.enigma-flow-board,
.enigma-memory-wall {
    position: relative;
    overflow: hidden;
    border-radius: 22px;
    padding: 18px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background:
        linear-gradient(180deg, rgba(15, 21, 34, 0.98), rgba(8, 12, 20, 0.98));
}

.enigma-dial-visual-card,
.enigma-system-visual-card {
    display: grid;
    place-items: center;
    padding: 14px;
}

.enigma-dial-visual-card::before,
.enigma-grid-rail::before,
.enigma-system-visual-card::before,
.enigma-flow-board::before,
.enigma-memory-wall::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at top left, color-mix(in srgb, var(--panel-accent) 18%, transparent), transparent 34%),
        linear-gradient(180deg, transparent, rgba(255, 255, 255, 0.01));
    pointer-events: none;
}

.enigma-dial-visual-svg {
    display: block;
    width: min(100%, 520px);
    height: auto;
    margin-inline: auto;
}

.enigma-system-visual-svg {
    display: block;
    width: min(100%, 520px);
    height: auto;
    margin-inline: auto;
}

.enigma-dial-visual-svg .grid-line,
.enigma-dial-visual-svg .orbital-track,
.enigma-dial-visual-svg .beam-frame,
.enigma-dial-visual-svg .fault-seam {
    fill: none;
    stroke: rgba(255, 255, 255, 0.12);
    stroke-width: 1.5;
}

.enigma-system-visual-svg .grid-line,
.enigma-system-visual-svg .orbital-track,
.enigma-system-visual-svg .beam-frame,
.enigma-system-visual-svg .fault-seam {
    fill: none;
    stroke: rgba(255, 255, 255, 0.12);
    stroke-width: 1.5;
}

.enigma-dial-visual-svg .route-line.current,
.enigma-dial-visual-svg .beam-path,
.enigma-dial-visual-svg .fault-layer.primary,
.enigma-dial-visual-svg .receiver-line {
    fill: none;
    stroke: var(--panel-accent);
    stroke-width: 3;
    stroke-linecap: round;
    stroke-linejoin: round;
    filter: drop-shadow(0 0 10px color-mix(in srgb, var(--panel-accent) 55%, transparent));
}

.enigma-system-visual-svg .route-line.current,
.enigma-system-visual-svg .beam-path,
.enigma-system-visual-svg .fault-layer.primary {
    fill: none;
    stroke: var(--panel-accent);
    stroke-width: 3;
    stroke-linecap: round;
    stroke-linejoin: round;
    filter: drop-shadow(0 0 10px color-mix(in srgb, var(--panel-accent) 55%, transparent));
}

.enigma-system-visual-svg .fault-layer.secondary {
    fill: none;
    stroke: rgba(255, 255, 255, 0.36);
    stroke-width: 2;
    stroke-dasharray: 5 6;
}

.enigma-dial-visual-svg .route-line.target,
.enigma-dial-visual-svg .wheel-node.target,
.enigma-dial-visual-svg .fault-layer.secondary {
    fill: none;
    stroke: rgba(255, 255, 255, 0.44);
    stroke-width: 2;
    stroke-dasharray: 5 6;
}

.enigma-dial-visual-svg .waypoint.current,
.enigma-dial-visual-svg .wheel-node.current,
.enigma-dial-visual-svg .gravity-body.current,
.enigma-dial-visual-svg .beam-emitter,
.enigma-dial-visual-svg .receiver-node {
    fill: var(--panel-accent);
    filter: drop-shadow(0 0 10px color-mix(in srgb, var(--panel-accent) 70%, transparent));
}

.enigma-system-visual-svg .waypoint.current,
.enigma-system-visual-svg .beam-emitter,
.enigma-system-visual-svg .receiver-node {
    fill: var(--panel-accent);
    filter: drop-shadow(0 0 10px color-mix(in srgb, var(--panel-accent) 70%, transparent));
}

.enigma-dial-visual-svg .center-token,
.enigma-dial-visual-svg .center-caption {
    fill: #f7fbff;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.enigma-dial-visual-svg .center-token {
    font-size: 1.45rem;
}

.enigma-dial-visual-svg .center-caption {
    font-size: 0.72rem;
    opacity: 0.72;
}

.enigma-advanced-telemetry-panel {
    display: grid;
    gap: 14px;
}

.enigma-advanced-telemetry-panel.streamlined {
    gap: 12px;
}

.enigma-system-summary-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
}

.enigma-system-summary-strip article,
.enigma-advanced-status-card {
    padding: 14px 16px;
}

.enigma-system-summary-strip article {
    display: grid;
    gap: 4px;
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.01)),
        rgba(11, 16, 27, 0.88);
}

.enigma-advanced-telemetry-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.enigma-advanced-telemetry-grid article,
.enigma-advanced-status-card {
    padding: 16px;
}

.enigma-system-summary-strip span,
.enigma-advanced-telemetry-grid span,
.enigma-advanced-status-card .enigma-kicker {
    color: rgba(234, 241, 252, 0.94);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.enigma-system-summary-strip strong,
.enigma-advanced-telemetry-grid strong,
.enigma-advanced-status-card strong {
    display: block;
    color: #f7fbff;
    font-size: 1.05rem;
    line-height: 1.1;
}

.enigma-system-status-card {
    display: grid;
    gap: 10px;
}

.enigma-system-status-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
}

.enigma-system-status-card p {
    margin: 0;
    color: rgba(232, 239, 255, 0.92);
    line-height: 1.5;
}

.enigma-system-lock-note {
    color: rgba(214, 230, 255, 0.9);
    font-size: 0.78rem;
    line-height: 1.45;
}

.enigma-system-mutator-chip {
    display: inline-flex;
    align-items: center;
    min-height: 1.8rem;
    padding: 0 0.75rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--panel-accent) 44%, rgba(255, 255, 255, 0.14));
    background: color-mix(in srgb, var(--panel-accent) 10%, rgba(255, 255, 255, 0.03));
    color: #f7fbff;
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
}

.enigma-system-lead-clues,
.enigma-system-metric-strip,
.enigma-system-metric-stack,
.enigma-system-clue-stack {
    display: grid;
    gap: 8px;
}

.enigma-system-metric-strip {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}

.enigma-system-analysis-drawer {
    display: grid;
    gap: 10px;
    padding: 12px 14px;
    border-radius: 18px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.01)),
        rgba(11, 16, 27, 0.82);
}

.enigma-system-analysis-drawer summary {
    cursor: pointer;
    color: rgba(220, 234, 255, 0.86);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.enigma-system-analysis-drawer summary::marker {
    color: rgba(225, 238, 255, 0.78);
}

.enigma-dial-bank {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.enigma-system-control-bank {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
}

.enigma-system-control-bank.streamlined {
    gap: 12px;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.enigma-dial-bank-card {
    padding: 16px;
    display: grid;
    gap: 12px;
}

.enigma-system-control-card,
.enigma-system-metric-card,
.enigma-system-clue-card {
    padding: 16px;
    border-radius: 20px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01)),
        rgba(11, 16, 27, 0.92);
}

.enigma-system-control-card {
    display: grid;
    gap: 12px;
}

.enigma-system-control-card.streamlined {
    gap: 10px;
    padding: 14px;
    border-radius: 18px;
}

.enigma-system-control-card.aligned,
.enigma-system-metric-card.aligned {
    border-color: color-mix(in srgb, var(--panel-accent) 48%, rgba(255, 255, 255, 0.08));
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--panel-accent) 16%, transparent);
}

.enigma-system-control-card header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
}

.enigma-system-control-heading,
.enigma-system-control-reading {
    display: grid;
    gap: 4px;
}

.enigma-system-control-card header span,
.enigma-system-control-card small,
.enigma-system-metric-card span {
    color: rgba(228, 239, 255, 0.88);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.enigma-system-control-card header strong,
.enigma-system-metric-card strong {
    color: #f7fbff;
    font-size: 1rem;
}

.enigma-system-control-reading {
    justify-items: end;
    text-align: right;
}

.enigma-system-control-reading span {
    color: rgba(225, 237, 255, 0.76);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.enigma-system-control-inputs {
    display: grid;
    gap: 10px;
}

.enigma-system-control-track {
    position: relative;
    min-height: 18px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    overflow: hidden;
}

.enigma-system-control-track .fill,
.enigma-system-control-track .band,
.enigma-system-control-track .marker {
    position: absolute;
    top: 0;
    bottom: 0;
    pointer-events: none;
}

.enigma-system-control-track .fill {
    left: 0;
    background: linear-gradient(90deg, color-mix(in srgb, var(--panel-accent) 30%, #0d1524), var(--panel-accent));
}

.enigma-system-control-track .band {
    background: color-mix(in srgb, var(--panel-accent) 18%, rgba(255, 255, 255, 0.14));
    border-left: 1px solid color-mix(in srgb, var(--panel-accent) 58%, rgba(255, 255, 255, 0.18));
    border-right: 1px solid color-mix(in srgb, var(--panel-accent) 58%, rgba(255, 255, 255, 0.18));
}

.enigma-system-control-track .marker {
    width: 2px;
    background: #ffffff;
    box-shadow: 0 0 8px rgba(255, 255, 255, 0.42);
}

.enigma-system-control-track input {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    background: transparent;
    appearance: none;
    cursor: ew-resize;
    touch-action: none;
}

.enigma-system-control-track input::-webkit-slider-runnable-track {
    height: 18px;
    background: transparent;
}

.enigma-system-control-track input::-webkit-slider-thumb {
    appearance: none;
    width: 16px;
    height: 16px;
    margin-top: 1px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.76);
    background: #f7fbff;
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--panel-accent) 18%, transparent);
}

.enigma-system-control-track input::-moz-range-track {
    height: 18px;
    background: transparent;
}

.enigma-system-control-track input::-moz-range-thumb {
    width: 16px;
    height: 16px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.76);
    background: #f7fbff;
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--panel-accent) 18%, transparent);
}

.enigma-system-mutator-note {
    display: block;
    color: rgba(227, 238, 255, 0.86);
    line-height: 1.45;
}

.enigma-system-metric-card.compact {
    padding: 12px 14px;
    border-radius: 16px;
}

.enigma-system-metric-card small,
.enigma-system-clue-card {
    color: rgba(228, 238, 255, 0.88);
    line-height: 1.45;
}

.enigma-system-clue-card {
    padding: 12px 14px;
    border-radius: 16px;
}

@media (max-width: 900px) {
    .enigma-system-summary-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .enigma-system-summary-strip,
    .enigma-system-metric-strip {
        grid-template-columns: 1fr;
    }

    .enigma-system-status-head,
    .enigma-system-control-card header {
        grid-template-columns: 1fr;
        display: grid;
    }

    .enigma-system-control-reading {
        justify-items: start;
        text-align: left;
    }
}

.enigma-dial-bank-card.aligned {
    border-color: color-mix(in srgb, var(--panel-accent) 48%, rgba(255, 255, 255, 0.08));
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--panel-accent) 16%, transparent),
        inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.enigma-dial-bank-card header {
    display: grid;
    gap: 6px;
}

.enigma-dial-bank-card header span,
.enigma-dial-bank-card small {
    color: rgba(228, 239, 255, 0.88);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.enigma-dial-bank-card header strong {
    color: #f7fbff;
    font-size: 1rem;
    line-height: 1.1;
}

.enigma-dial-bank-track {
    position: relative;
    height: 12px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    overflow: hidden;
}

.enigma-dial-bank-track .fill {
    position: absolute;
    inset: 0 auto 0 0;
    width: 0;
    border-radius: inherit;
    background: linear-gradient(90deg, color-mix(in srgb, var(--panel-accent) 30%, #0d1524), var(--panel-accent));
    pointer-events: none;
}

.enigma-dial-bank-track .marker {
    position: absolute;
    top: -2px;
    width: 2px;
    height: 16px;
    background: #ffffff;
    box-shadow: 0 0 10px rgba(255, 255, 255, 0.55);
    pointer-events: none;
}

.enigma-dial-bank-meta {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.enigma-dial-bank-controls {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.enigma-grid-rail {
    display: grid;
    gap: 16px;
}

.enigma-grid-rail-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
}

.enigma-grid-rail-head strong {
    color: #f8fbff;
    font-size: 1rem;
}

.enigma-grid-rail-head small {
    color: rgba(228, 238, 255, 0.88);
}

.enigma-grid-board {
    display: grid;
    grid-template-columns: repeat(var(--grid-cols), minmax(0, 1fr));
    grid-template-rows: repeat(var(--grid-rows), minmax(0, 1fr));
    gap: 12px;
}

.enigma-grid-node {
    position: relative;
    min-height: 88px;
    padding: 12px;
    display: grid;
    gap: 6px;
    text-align: left;
    transition:
        transform 0.16s ease,
        border-color 0.16s ease,
        box-shadow 0.16s ease;
}

.enigma-grid-node:hover,
.enigma-grid-node:focus-visible {
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--panel-accent) 48%, rgba(255, 255, 255, 0.08));
}

.enigma-grid-node.active {
    background:
        radial-gradient(circle at top left, color-mix(in srgb, var(--panel-accent) 18%, transparent), transparent 45%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.02)),
        rgba(11, 16, 27, 0.94);
}

.enigma-grid-node.aligned {
    border-color: color-mix(in srgb, var(--panel-accent) 48%, rgba(255, 255, 255, 0.08));
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--panel-accent) 18%, transparent);
}

.enigma-grid-node-backdrop {
    position: absolute;
    inset: auto 10px 10px auto;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: radial-gradient(circle, color-mix(in srgb, var(--panel-accent) 28%, transparent), transparent 68%);
    opacity: var(--panel-guidance-opacity, 0.8);
}

.enigma-grid-node-label,
.enigma-grid-node small {
    position: relative;
    color: rgba(239, 245, 255, 0.96);
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.enigma-grid-node strong {
    position: relative;
    color: #f7fbff;
    font-size: 1.05rem;
}

.enigma-advanced-inline-actions,
.enigma-advanced-action-row {
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    align-items: center;
}

.enigma-advanced-action-row .btn,
.enigma-advanced-inline-actions .btn,
.enigma-dial-bank-controls .btn {
    min-width: 118px;
}

.enigma-panel-action.tone-dial,
.enigma-panel-action.tone-nav {
    border-color: color-mix(in srgb, var(--panel-accent) 38%, rgba(255, 255, 255, 0.08));
    background: color-mix(in srgb, var(--panel-accent) 10%, rgba(255, 255, 255, 0.02));
}

.enigma-flow-board {
    display: grid;
    grid-template-columns: repeat(var(--flow-cols), minmax(0, 1fr));
    grid-template-rows: repeat(var(--flow-rows), minmax(0, 1fr));
    gap: 12px;
}

.enigma-flow-tile {
    position: relative;
    min-height: 88px;
    padding: 0;
}

.enigma-flow-tile .core,
.enigma-flow-tile .arm {
    position: absolute;
    background: rgba(217, 235, 255, 0.2);
    border-radius: 999px;
    transition: background 0.16s ease, box-shadow 0.16s ease;
}

.enigma-flow-tile .core {
    inset: calc(50% - 10px);
}

.enigma-flow-tile .arm.north,
.enigma-flow-tile .arm.south {
    left: calc(50% - 8px);
    width: 16px;
    height: 34px;
}

.enigma-flow-tile .arm.east,
.enigma-flow-tile .arm.west {
    top: calc(50% - 8px);
    width: 34px;
    height: 16px;
}

.enigma-flow-tile .arm.north { top: 10px; }
.enigma-flow-tile .arm.south { bottom: 10px; }
.enigma-flow-tile .arm.east { right: 10px; }
.enigma-flow-tile .arm.west { left: 10px; }

.enigma-flow-tile.flowing .core,
.enigma-flow-tile.flowing .arm {
    background: var(--panel-accent);
    box-shadow: 0 0 14px color-mix(in srgb, var(--panel-accent) 48%, transparent);
}

.enigma-flow-tile.source,
.enigma-flow-tile.sink {
    border-color: color-mix(in srgb, var(--panel-accent) 54%, rgba(255, 255, 255, 0.08));
}

.enigma-flow-tile.source::after,
.enigma-flow-tile.sink::after {
    position: absolute;
    left: 10px;
    top: 10px;
    color: rgba(233, 243, 255, 0.9);
    font-size: 0.64rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.enigma-flow-tile.source::after { content: "SRC"; }
.enigma-flow-tile.sink::after { content: "SNK"; }

.enigma-memory-wall {
    display: grid;
    grid-template-columns: repeat(var(--memory-cols), minmax(0, 1fr));
    gap: 14px;
}

.enigma-memory-card {
    position: relative;
    min-height: 128px;
    padding: 0;
    perspective: 1200px;
    overflow: hidden;
}

.enigma-memory-card-back,
.enigma-memory-card-face {
    position: absolute;
    inset: 0;
    padding: 16px;
    display: grid;
    align-content: space-between;
    border-radius: inherit;
    transition: transform 0.28s ease, opacity 0.28s ease;
}

.enigma-memory-card-back {
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02)),
        linear-gradient(180deg, rgba(24, 31, 44, 0.98), rgba(10, 14, 24, 0.98));
}

.enigma-memory-card-back small,
.enigma-memory-card-face small {
    color: rgba(230, 239, 255, 0.88);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.enigma-memory-card-back strong,
.enigma-memory-card-face strong {
    color: #f7fbff;
    font-size: 1.05rem;
    line-height: 1.1;
}

.enigma-memory-card-face {
    background:
        radial-gradient(circle at top left, color-mix(in srgb, var(--panel-accent) 22%, transparent), transparent 42%),
        linear-gradient(180deg, rgba(24, 19, 10, 0.98), rgba(12, 10, 7, 0.98));
    transform: rotateY(180deg);
    opacity: 0;
}

.enigma-memory-card.state-open .enigma-memory-card-back,
.enigma-memory-card.state-matched .enigma-memory-card-back {
    transform: rotateY(180deg);
    opacity: 0;
}

.enigma-memory-card.state-open .enigma-memory-card-face,
.enigma-memory-card.state-matched .enigma-memory-card-face {
    transform: rotateY(0deg);
    opacity: 1;
}

.enigma-memory-card.state-matched {
    border-color: color-mix(in srgb, var(--panel-accent) 48%, rgba(255, 255, 255, 0.08));
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--panel-accent) 18%, transparent);
}

@media (max-width: 1180px) {
    .enigma-grid-template-main,
    .enigma-flow-template-main,
    .enigma-memory-template-main {
        grid-template-columns: 1fr;
    }

    .enigma-advanced-stage-head {
        grid-template-columns: 1fr;
    }

    .enigma-advanced-stage-badges,
    .enigma-advanced-action-row,
    .enigma-advanced-inline-actions {
        grid-auto-flow: row;
        grid-auto-columns: 1fr;
    }

    .enigma-dial-visual-svg,
    .enigma-system-visual-svg {
        width: min(100%, 460px);
    }
}

@media (max-width: 1040px) {
    .enigma-dial-template-main,
    .enigma-system-template-main {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .enigma-advanced-panel-shell {
        padding: 14px;
        border-radius: 22px;
    }

    .enigma-advanced-stage-card,
    .enigma-dial-visual-card,
    .enigma-grid-rail,
    .enigma-flow-board,
    .enigma-memory-wall {
        padding: 14px;
    }

    .enigma-dial-bank {
        grid-template-columns: 1fr;
    }

    .enigma-advanced-telemetry-grid {
        grid-template-columns: 1fr 1fr;
    }

    .enigma-memory-wall {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .enigma-dial-visual-svg,
    .enigma-system-visual-svg {
        width: min(100%, 400px);
    }
}

.enigma-dial-stage-note,
.enigma-grid-focus-note {
    display: block;
    margin-top: 10px;
    color: rgba(228, 239, 255, 0.86);
    font-size: 0.82rem;
    line-height: 1.45;
}

.enigma-dial-bank-track.interactive {
    height: 24px;
    padding: 0 8px;
    display: flex;
    align-items: center;
    background: rgba(255, 255, 255, 0.06);
}

.enigma-dial-bank-slider {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    background: transparent;
    appearance: none;
    cursor: ew-resize;
    touch-action: none;
}

.enigma-dial-bank-slider::-webkit-slider-runnable-track {
    height: 24px;
    background: transparent;
}

.enigma-dial-bank-slider::-webkit-slider-thumb {
    appearance: none;
    width: 18px;
    height: 18px;
    margin-top: 3px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.76);
    background: #f7fbff;
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--panel-accent) 18%, transparent);
}

.enigma-dial-bank-slider::-moz-range-track {
    height: 24px;
    background: transparent;
}

.enigma-dial-bank-slider::-moz-range-thumb {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.76);
    background: #f7fbff;
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--panel-accent) 18%, transparent);
}

.enigma-dial-bank-controls.refined {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
    padding: 4px;
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.03);
}

.enigma-dial-bank-controls.refined .btn {
    min-width: 0;
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01));
}

.enigma-dial-bank-controls.refined .btn:hover,
.enigma-dial-bank-controls.refined .btn:focus-visible {
    border-color: color-mix(in srgb, var(--panel-accent) 54%, rgba(255, 255, 255, 0.08));
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--panel-accent) 18%, transparent);
}

.enigma-grid-template-main.concise {
    grid-template-columns: minmax(0, 1.6fr) minmax(250px, 0.7fr);
}

.enigma-grid-rail.simplified {
    gap: 12px;
}

.enigma-grid-directive {
    display: grid;
    gap: 4px;
    padding: 14px 16px;
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.03);
}

.enigma-grid-directive strong {
    color: #f8fbff;
    font-size: 0.98rem;
}

.enigma-grid-directive small {
    color: rgba(229, 238, 252, 0.9);
    line-height: 1.45;
}

.enigma-grid-guide-strip.top {
    display: grid;
    grid-template-columns: 68px repeat(auto-fit, minmax(0, 1fr));
    gap: 10px;
}

.enigma-grid-guide-strip .cap {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: rgba(224, 236, 252, 0.84);
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.enigma-grid-matrix-shell {
    display: grid;
    grid-template-columns: 68px minmax(0, 1fr);
    gap: 10px;
    align-items: start;
}

.enigma-grid-guide-column {
    display: grid;
    gap: 10px;
}

.enigma-grid-guide-chip {
    min-height: 54px;
    padding: 10px 12px;
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.03);
    display: grid;
    align-content: center;
    justify-items: center;
    gap: 3px;
    text-align: center;
}

.enigma-grid-guide-chip.row {
    min-height: 112px;
}

.enigma-grid-guide-chip strong {
    color: #f8fbff;
    font-size: 0.94rem;
    line-height: 1;
}

.enigma-grid-guide-chip small {
    color: rgba(230, 239, 252, 0.9);
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.enigma-grid-guide-chip.aligned {
    border-color: color-mix(in srgb, var(--panel-accent) 42%, rgba(255, 255, 255, 0.08));
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--panel-accent) 16%, transparent);
}

.enigma-grid-board.simplified {
    gap: 10px;
}

.enigma-grid-node.simplified {
    min-height: 112px;
    padding: 14px;
    gap: 10px;
    grid-template-rows: auto 1fr auto;
}

.enigma-grid-node.simplified.mismatch {
    border-color: rgba(255, 176, 121, 0.28);
}

.enigma-grid-node.simplified.focus {
    box-shadow:
        0 0 0 1px rgba(255, 193, 122, 0.22),
        0 0 26px rgba(255, 166, 102, 0.14);
}

.enigma-grid-node-live,
.enigma-grid-node-target {
    display: inline-flex;
    align-self: center;
    justify-self: center;
    border-radius: 999px;
}

.enigma-grid-node-live {
    width: 34px;
    height: 34px;
    border: 2px solid rgba(255, 255, 255, 0.2);
}

.enigma-grid-node-live.on {
    background: var(--panel-accent);
    border-color: color-mix(in srgb, var(--panel-accent) 72%, rgba(255, 255, 255, 0.24));
    box-shadow: 0 0 18px color-mix(in srgb, var(--panel-accent) 38%, transparent);
}

.enigma-grid-node-live.off {
    background: rgba(255, 255, 255, 0.03);
}

.enigma-grid-node-target {
    position: absolute;
    right: 12px;
    top: 12px;
    width: 16px;
    height: 16px;
    border: 2px solid rgba(255, 255, 255, 0.32);
}

.enigma-grid-node-target.on {
    background: rgba(255, 255, 255, 0.88);
    border-color: rgba(255, 255, 255, 0.96);
}

.enigma-grid-node-target.off {
    background: transparent;
}

.enigma-grid-node-legend {
    display: grid;
    gap: 4px;
}

.enigma-grid-node-legend strong {
    color: #f7fbff;
    font-size: 0.9rem;
}

.enigma-grid-node-legend small {
    color: rgba(228, 238, 252, 0.88);
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: none;
}

.enigma-advanced-telemetry-panel.compact,
.enigma-advanced-telemetry-grid.compact {
    gap: 10px;
}

.enigma-advanced-inline-actions.stretch {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.enigma-advanced-inline-actions.stretch .btn,
.enigma-advanced-telemetry-panel.compact .btn {
    min-width: 0;
}

@media (max-width: 920px) {
    .enigma-grid-template-main.concise {
        grid-template-columns: 1fr;
    }

    .enigma-grid-guide-strip.top {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .enigma-grid-guide-strip .cap {
        display: none;
    }

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

    .enigma-grid-guide-column {
        grid-template-columns: repeat(auto-fit, minmax(88px, 1fr));
    }

    .enigma-grid-guide-chip.row {
        min-height: 54px;
    }
}

