/* ============================================================
   Profile Picture Editor  —  in-panel + nav display
   ============================================================ */

/* ── Nav button ASCII display ─────────────────────────────── */

.nav-ascii-pic {
    font-family: 'Courier New', Courier, monospace;
    font-size: 2px;
    line-height: 1;
    white-space: pre;
    color: #33ff33;
    margin: 0;
    display: block;
    max-width: 40px;
    max-height: 36px;
    overflow: hidden;
}

/* ── Avatar circle (top of settings) ─────────────────────── */

.ppe-avatar-section {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.ppe-avatar-circle {
    width: 75%;
    max-width: 340px;
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    border: 2px solid #ff69b4;
    box-shadow: 0 0 12px rgba(255, 105, 180, 0.35);
    background: rgba(255, 105, 180, 0.05);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
}

.ppe-avatar-pre {
    font-family: 'Courier New', Courier, monospace;
    /* font-size set dynamically by JS */
    font-size: 4px;
    line-height: 1;
    white-space: pre;
    color: #33ff33;
    margin: 0;
}

.ppe-avatar-placeholder {
    font-size: 1.6rem;
    color: rgba(255, 105, 180, 0.3);
    font-family: monospace;
    user-select: none;
}

.ppe-edit-btn {
    font-size: 0.8rem;
}

/* ── Editor root ──────────────────────────────────────────── */

#profilePicEditorRoot {
    font-family: 'Roboto Mono', monospace;
}

/* ── Mode tabs ────────────────────────────────────────────── */

.ppe-tabs {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 0.85rem;
}

.ppe-tab {
    background: transparent;
    border: 1px solid rgba(51, 255, 51, 0.35);
    color: rgba(51, 255, 51, 0.55);
    padding: 0.35rem 0.85rem;
    border-radius: 4px;
    cursor: pointer;
    font-family: inherit;
    font-size: 0.78rem;
    letter-spacing: 0.05em;
    transition: all 0.15s;
}

.ppe-tab--active,
.ppe-tab:hover {
    border-color: #33ff33;
    color: #33ff33;
    background: rgba(51, 255, 51, 0.07);
}

/* ── Resolution row ───────────────────────────────────────── */

.ppe-res-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.85rem;
}

.ppe-res-label {
    color: rgba(51, 255, 51, 0.65);
    font-size: 0.78rem;
    white-space: nowrap;
    flex-shrink: 0;
}

.ppe-slider {
    flex: 1;
    accent-color: #33ff33;
    cursor: pointer;
}

/* ── Square container ─────────────────────────────────────── */

.ppe-square-wrap {
    position: relative;
    width: 100%;
    aspect-ratio: 1 / 1;
    background: rgba(0, 0, 0, 0.45);
    border: 1px solid rgba(51, 255, 51, 0.45);
    border-radius: 4px;
    overflow: hidden;
    transition: border-color 0.2s, box-shadow 0.2s;
}

.ppe-square-wrap:focus-within {
    border-color: #33ff33;
    box-shadow: 0 0 6px rgba(51, 255, 51, 0.18);
}

/* Pink glow when content overflows */
.ppe-square-wrap--overflow {
    border-color: #ff69b4 !important;
    box-shadow: 0 0 8px rgba(255, 105, 180, 0.45) !important;
}

/* ── Overflow warning ─────────────────────────────────────── */

.ppe-overflow-warn {
    color: #ff69b4;
    font-size: 0.72rem;
    line-height: 1.4;
    margin-top: 0.4rem;
    padding: 0.45rem 0.6rem;
    background: rgba(255, 105, 180, 0.07);
    border: 1px solid rgba(255, 105, 180, 0.3);
    border-radius: 4px;
}

/* ── Draw panel ───────────────────────────────────────────── */

.ppe-draw-ta {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    background: transparent;
    border: none;
    color: #33ff33;
    font-family: 'Courier New', Courier, monospace;
    line-height: 1;
    padding: 0.4rem;
    box-sizing: border-box;
    resize: none;
    white-space: pre;
    overflow: auto;
    tab-size: 1;
    outline: none;
    /* Pink scrollbars */
    scrollbar-color: #ff69b4 rgba(255, 105, 180, 0.08); /* Firefox */
    scrollbar-width: thin;
}

.ppe-draw-ta::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

.ppe-draw-ta::-webkit-scrollbar-thumb {
    background: #ff69b4;
    border-radius: 3px;
}

.ppe-draw-ta::-webkit-scrollbar-track {
    background: rgba(255, 105, 180, 0.08);
}

.ppe-draw-ta::-webkit-scrollbar-corner {
    background: rgba(255, 105, 180, 0.08);
}

.ppe-draw-hint {
    color: rgba(51, 255, 51, 0.38);
    font-size: 0.7rem;
    margin-top: 0.3rem;
}

/* ── Camera panel ─────────────────────────────────────────── */

.ppe-cam-columns {
    display: flex;
    gap: 0.6rem;
    margin-bottom: 0.6rem;
    align-items: flex-start;
}

.ppe-cam-col {
    flex: 1;
    min-width: 0;
}

.ppe-cam-sublabel {
    color: rgba(51, 255, 51, 0.45);
    font-size: 0.65rem;
    letter-spacing: 0.08em;
    margin-bottom: 0.25rem;
}

.ppe-cam-video {
    display: block;
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    object-position: center;
    border: 1px solid rgba(51, 255, 51, 0.35);
    border-radius: 4px;
    transform: scaleX(-1);
}

.ppe-ascii-live {
    position: absolute;
    inset: 0;
    margin: 0;
    padding: 0.2rem;
    box-sizing: border-box;
    font-family: 'Courier New', Courier, monospace;
    line-height: 1;
    color: #33ff33;
    white-space: pre;
    overflow: hidden;
}

.ppe-cam-err {
    color: #ff4444;
    font-size: 0.82rem;
    margin-bottom: 0.5rem;
}

.ppe-capture-btn {
    margin-bottom: 0;
}

/* ── Footer ───────────────────────────────────────────────── */

.ppe-footer {
    margin-top: 1rem;
    border-top: 1px solid rgba(51, 255, 51, 0.18);
    padding-top: 0.9rem;
    display: flex;
    align-items: flex-end;
    gap: 1rem;
    flex-wrap: wrap;
}

.ppe-preview-wrap {
    flex-shrink: 0;
}

.ppe-preview-label {
    color: rgba(51, 255, 51, 0.45);
    font-size: 0.68rem;
    margin-bottom: 0.3rem;
    letter-spacing: 0.06em;
}

/* Mimics the nav button shape */
.ppe-preview-btn-sim {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    background: rgba(51, 255, 51, 0.06);
    border: 1px solid rgba(51, 255, 51, 0.28);
    border-radius: 5px;
    overflow: hidden;
}

.ppe-preview-pre {
    font-family: 'Courier New', Courier, monospace;
    font-size: 3px;
    line-height: 1;
    white-space: pre;
    color: #33ff33;
    margin: 0;
    overflow: hidden;
    max-width: 46px;
    max-height: 46px;
}

.ppe-save-row {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    flex-wrap: wrap;
    flex: 1;
}

.ppe-status     { font-size: 0.78rem; color: rgba(51, 255, 51, 0.65); }
.ppe-status--ok  { color: #33ff33; }
.ppe-status--err { color: #ff4444; }
