/* Body has CSS zoom on bigger viewports, which interprets vh/vw in
   *layout* pixels — the visual size becomes layout × zoom. Without
   correcting for that, the dim overlay leaks past the viewport and a
   centered modal-box sized in vh overflows top + bottom. We size both
   explicitly using calc(100vX / --desk-zoom) so the visual size always
   matches the actual viewport. */
.modal-bg {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width:  calc(100vw / var(--desk-zoom));
    height: calc(100vh / var(--desk-zoom));
    z-index: 7500;
    background: rgba(0, 0, 0, .6);
    align-items: center;
    justify-content: center;
}

.modal-box {
    background: #fff;
    border: 3px solid var(--dark);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    width: min(520px, 95vw);
    box-shadow: var(--shadow-card);
    max-height: calc(92vh / var(--desk-zoom));
    overflow-y: auto;
}

/* Wider variant for forms with side-by-side groups (e.g. edit profile). */
.modal-box.modal-wide {
    width: min(740px, 95vw);
}

/* ── Edit-profile redesigned modal ──────────────────────────────────
   Tabbed layout (Identity / Titles / Style / Traits) plus a sticky
   live-preview panel on the right. Uses the project's standard tokens
   (Press Start 2P, --pink/--cream/--dark, hard shadows, dashed
   borders) so it reads as the same visual family as the rest of the
   site — the structure is just split into focused panes instead of a
   single long scrolling form. */

.ep-tabs {
    display: flex;
    gap: 4px;
    padding: 0 var(--space-1);
    border-bottom: 2.5px dashed var(--soft);
    margin-bottom: var(--space-3);
}

.ep-tab {
    padding: 7px 12px 6px;
    background: var(--soft);
    border: 2.5px solid var(--dark);
    border-bottom: none;
    border-radius: 10px 10px 0 0;
    font-family: var(--font-display);
    font-size: var(--fs-xs);
    color: var(--dark);
    cursor: pointer;
    letter-spacing: 0.5px;
    transition: background .15s, transform .1s;
}
.ep-tab:hover:not(.on) {
    background: var(--cream);
    transform: translateY(-1px);
}
.ep-tab.on {
    background: var(--pink);
    color: #fff;
    margin-bottom: -2.5px;
    padding-bottom: 8.5px;
}

.ep-body {
    display: grid;
    grid-template-columns: 1fr 220px;
    gap: var(--space-4);
    margin-bottom: var(--space-3);
}

.ep-panes { min-width: 0; }
.ep-pane  { display: none; }
.ep-pane.on { display: block; }

.ep-section {
    background: var(--cream);
    border: 2.5px solid var(--dark);
    border-radius: var(--radius-md);
    padding: var(--space-3);
    margin-bottom: var(--space-3);
    box-shadow: 0 3px 0 var(--dark);
}
.ep-section:last-child { margin-bottom: 0; }

.ep-section-h {
    font-family: var(--font-display);
    font-size: var(--fs-xs);
    color: var(--pink);
    letter-spacing: 1px;
    margin-bottom: var(--space-3);
    display: flex;
    align-items: center;
    gap: var(--space-1);
}
.ep-section-h::before {
    content: '';
    display: inline-block;
    width: 8px;
    height: 8px;
    background: var(--pink);
    border-radius: 2px;
}

.ep-counter {
    font-family: var(--font-display);
    font-size: 8px;
    color: #888;
    text-align: right;
    margin-top: -8px;
    letter-spacing: 0.5px;
}

/* Side-by-side inputs (USERNAME + STATUS) inside a section. Collapses
   to one column when the modal-box itself wraps to a single column. */
.ep-row2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-2);
}
@media (max-width: 720px) {
    .ep-row2 { grid-template-columns: 1fr; }
}

/* Icon grid inside the modal: scroll instead of pushing the section taller. */
.ep-icon-grid {
    max-height: 196px;
    overflow-y: auto;
    margin-bottom: 0 !important;
    padding: var(--space-2);
    background: #fff;
    border: 2px solid var(--dark);
    border-radius: var(--radius-sm);
    justify-content: flex-start;
}

.ep-search-wrap { margin-bottom: var(--space-3); }

/* Equipped row: dashed pink dropzone-style container with chip(s). */
.ep-eq-row {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-1);
    padding: var(--space-2);
    background: var(--soft);
    border: 2.5px dashed var(--pink);
    border-radius: var(--radius-md);
    min-height: 36px;
    margin-bottom: var(--space-3);
    align-items: center;
}
.ep-eq-empty {
    font-family: var(--font-display);
    font-size: 9px;
    color: var(--hot);
    letter-spacing: 0.5px;
}
.ep-eq-chip {
    padding: 4px 10px;
    border-radius: var(--radius-pill);
    background: var(--pink);
    color: #fff;
    border: 2px solid var(--dark);
    font-family: var(--font-display);
    font-size: 9px;
    letter-spacing: 0.3px;
    cursor: pointer;
    box-shadow: 0 2px 0 var(--dark);
}
.ep-eq-chip:hover { background: var(--hot); }

/* Available titles: scrollable two-column pill grid. */
.ep-nick-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 5px;
    max-height: 200px;
    overflow-y: auto;
    padding-right: 4px;
    margin-bottom: 0 !important;
}
.ep-nick-grid::-webkit-scrollbar       { width: 7px; }
.ep-nick-grid::-webkit-scrollbar-track { background: var(--soft); border-radius: 4px; }
.ep-nick-grid::-webkit-scrollbar-thumb { background: var(--pink); border-radius: 4px; }

.ep-nick-grid .nick-chip {
    text-align: left;
    padding: 5px 9px;
    font-size: 9px;
    margin: 0;
}

.ep-trait-btn { width: 100%; margin-bottom: 0; }

.ep-traits-cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 7px;
    margin-top: var(--space-3);
    font-family: var(--font-display);
    font-size: var(--fs-xs);
    color: #888;
}
.ep-trait-card {
    background: #fff;
    border: 2.5px solid var(--dark);
    border-radius: var(--radius-sm);
    padding: var(--space-2);
    text-align: center;
    box-shadow: 0 2px 0 var(--dark);
}
.ep-trait-card .v {
    font-family: var(--font-display);
    font-size: var(--fs-xs);
    color: var(--pink);
    letter-spacing: 0.5px;
}
.ep-trait-card .l {
    font-family: var(--font-display);
    font-size: 8px;
    color: #888;
    margin-top: 4px;
    letter-spacing: 0.5px;
}
.ep-traits-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: var(--space-2);
    font-family: var(--font-display);
    font-size: 9px;
    color: #888;
    letter-spacing: 0.5px;
}

/* Live preview card on the right. */
.ep-preview {
    background: var(--soft);
    border: 2.5px dashed var(--pink);
    border-radius: var(--radius-md);
    padding: var(--space-3);
    align-self: start;
    box-shadow: 0 3px 0 rgba(247, 37, 133, 0.2);
}
.ep-preview-h {
    font-family: var(--font-display);
    font-size: 9px;
    color: var(--hot);
    letter-spacing: 1px;
    text-align: center;
    margin-bottom: var(--space-2);
}
.ep-preview-card {
    background: #fff;
    border: 2.5px solid var(--dark);
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: 0 3px 0 var(--dark);
}
.ep-preview-banner {
    height: 36px;
    background: linear-gradient(110deg, #fff8f0, #ffdcec);
    border-bottom: 2.5px solid var(--dark);
}
.ep-preview-pfp {
    margin: -22px auto 0;
    width: 56px;
    height: 56px;
    border-radius: var(--radius-md);
    border: 2.5px solid var(--dark);
    background: #fff;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 1;
    box-shadow: 0 2px 0 var(--dark);
}
.ep-preview-pfp img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.ep-preview-name {
    font-family: var(--font-display);
    font-size: var(--fs-md);
    text-align: center;
    color: var(--pink);
    margin: 8px 0 0;
    letter-spacing: 0.5px;
    padding: 0 var(--space-2);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.ep-preview-status {
    font-family: var(--font-body);
    font-size: 10px;
    font-weight: 700;
    text-align: center;
    color: var(--hot);
    margin-top: 2px;
    padding: 0 var(--space-2);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-height: 14px;
}

.ep-preview-tag-wrap {
    text-align: center;
    margin: 5px 0;
}
.ep-preview-tag {
    display: inline-block;
    background: var(--pink);
    color: #fff;
    padding: 2px 8px;
    border-radius: var(--radius-pill);
    font-family: var(--font-display);
    font-size: 7px;
    border: 2px solid var(--dark);
    letter-spacing: 0.5px;
    box-shadow: 0 2px 0 var(--dark);
}
.ep-preview-bio {
    font-family: var(--font-body);
    font-size: 11px;
    font-weight: 700;
    text-align: center;
    color: var(--dark);
    padding: var(--space-3) var(--space-2);
    line-height: 1.4;
    border-top: 2px dashed var(--soft);
    margin-top: 8px;
    word-break: break-word;
}

/* Collapse to a single column when too narrow for the side-by-side layout. */
@media (max-width: 720px) {
    .ep-body       { grid-template-columns: 1fr; }
    .ep-nick-grid  { grid-template-columns: 1fr; }
}

.modal-title {
    font-family: var(--font-display);
    font-size: var(--fs-md);
    color: var(--pink);
    margin-bottom: var(--space-4);
    text-align: center;
    letter-spacing: 0.5px;
}

.field-label {
    font-family: var(--font-display);
    font-size: var(--fs-xs);
    color: var(--dark);
    margin-bottom: var(--space-2);
    display: block;
    letter-spacing: 0.5px;
}

.field-hint {
    font-family: var(--font-display);
    font-size: var(--fs-xs);
    color: #888;
    letter-spacing: 0.5px;
    margin-left: var(--space-1);
}


.field-input {
    width: 100%;
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-md);
    border: 2.5px solid var(--pink);
    font-family: var(--font-body);
    font-size: var(--fs-md);
    font-weight: 700;
    outline: none;
    color: var(--dark);
    margin-bottom: var(--space-3);
}

.field-textarea {
    width: 100%;
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-md);
    border: 2.5px solid var(--pink);
    font-family: var(--font-body);
    font-size: var(--fs-md);
    font-weight: 700;
    outline: none;
    color: var(--dark);
    resize: none;
    height: 72px;
    margin-bottom: var(--space-3);
}

.nick-list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-1);
    margin-bottom: var(--space-3);
}

.nick-chip {
    padding: 5px 12px;
    border-radius: var(--radius-pill);
    font-family: var(--font-display);
    font-size: var(--fs-xs);
    border: 2.5px solid var(--dark);
    box-shadow: 0 2px 0 var(--dark);
    cursor: pointer;
    background: #fff;
    color: var(--dark);
    letter-spacing: 0.5px;
}

.nick-chip.sel {
    background: var(--pink);
    color: #fff;
}

.nick-chip.locked {
    opacity: .4;
    cursor: not-allowed;
}

.modal-btns {
    display: flex;
    gap: var(--space-2);
    margin-top: var(--space-4);
}

.btn-save {
    flex: 1;
    background: var(--pink);
    color: #fff;
    border: 2.5px solid var(--dark);
    border-radius: var(--radius-md);
    padding: var(--space-3);
    font-family: var(--font-display);
    font-size: var(--fs-xs);
    cursor: pointer;
    box-shadow: var(--shadow-btn);
    letter-spacing: 0.5px;
}
.btn-save:hover { background: var(--hot); }

.btn-cancel {
    background: #fff;
    color: var(--dark);
    border: 2.5px solid var(--dark);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    font-family: var(--font-display);
    font-size: var(--fs-xs);
    cursor: pointer;
    box-shadow: 0 2px 0 var(--dark);
    letter-spacing: 0.5px;
}
.btn-cancel:hover { background: var(--cream); }

.btn-blue {
    background: var(--blue);
    color: var(--dark);
    border: 2.5px solid var(--dark);
    border-radius: var(--radius-md);
    padding: var(--space-2) var(--space-3);
    font-family: var(--font-display);
    font-size: var(--fs-xs);
    cursor: pointer;
    box-shadow: 0 2px 0 var(--dark);
    margin-bottom: var(--space-2);
    letter-spacing: 0.5px;
}
.btn-blue:hover { background: var(--soft); }
