/* ══════════════════════════════════════════════════════════════
   NexusPhotoEditor v1.0
   ══════════════════════════════════════════════════════════════ */
.photo-editor-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.85);
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px;
    animation: nx-ep-fade 0.18s ease-out;
}
.photo-editor {
    background: var(--bg-raised);
    border-radius: 14px;
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 900px;
    max-height: calc(100vh - 24px);
    overflow: hidden;
    box-shadow: 0 24px 64px rgba(0,0,0,0.5);
}
.pe-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    border-bottom: 0.5px solid var(--border);
    flex-shrink: 0;
}
.pe-title { font-size: 14px; font-weight: 600; color: var(--text-primary); flex-shrink: 0; }
.pe-tools {
    display: flex;
    align-items: center;
    gap: 4px;
    flex: 1;
    flex-wrap: wrap;
}
.pe-tool-btn, .pe-icon-btn {
    width: 32px; height: 32px;
    border-radius: 6px;
    border: 0.5px solid transparent;
    background: none;
    color: var(--text-secondary);
    font-size: 15px;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: background .12s, color .12s;
}
.pe-tool-btn:hover, .pe-icon-btn:hover { background: var(--bg-hover); color: var(--text-primary); }
.pe-tool-btn.active { background: var(--accent-dim); color: var(--accent); border-color: var(--accent); }
.pe-divider { width: 1px; height: 20px; background: var(--border); margin: 0 2px; }
.pe-close-btn {
    width: 28px; height: 28px;
    border-radius: 50%; border: none; background: none;
    color: var(--text-secondary); font-size: 14px; cursor: pointer; flex-shrink: 0;
}
.pe-close-btn:hover { background: rgba(255,59,48,0.15); color: #ff3b30; }
.pe-body {
    display: flex;
    flex: 1;
    overflow: hidden;
    min-height: 0;
}
.pe-canvas-wrap {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #111;
    overflow: hidden;
    padding: 12px;
}
#pe-canvas {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    border-radius: 4px;
    cursor: crosshair;
}
.pe-sidebar {
    width: 180px;
    flex-shrink: 0;
    border-left: 0.5px solid var(--border);
    overflow-y: auto;
    padding: 10px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
@media (max-width: 600px) {
    .pe-sidebar { display: none; }
}
.pe-section { display: flex; flex-direction: column; gap: 6px; }
.pe-label { font-size: 11px; font-weight: 600; color: var(--text-secondary); text-transform: uppercase; letter-spacing: .5px; }
.pe-color-row { display: flex; gap: 4px; flex-wrap: wrap; }
.pe-color-swatch {
    width: 22px; height: 22px; border-radius: 50%;
    border: 2px solid transparent; cursor: pointer;
    transition: transform .12s;
}
.pe-color-swatch:hover { transform: scale(1.2); }
.pe-emoji-row { display: grid; grid-template-columns: repeat(4,1fr); gap: 4px; }
.pe-emoji-btn {
    font-size: 20px; background: none; border: none;
    cursor: pointer; border-radius: 4px; padding: 2px;
}
.pe-emoji-btn:hover { background: var(--bg-hover); }
.pe-footer {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border-top: 0.5px solid var(--border);
    flex-shrink: 0;
}
.pe-quality-wrap {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-left: auto;
}
.pe-footer .btn-primary { flex-shrink: 0; }

/* Crop overlay */
.pe-crop-overlay {
    position: fixed;
    border: 2px dashed var(--accent);
    background: rgba(79, 138, 255, 0.08);
    pointer-events: none;
    z-index: 9999;
    box-shadow: 0 0 0 9999px rgba(0,0,0,0.4);
}
