/* ══════════════════════════════════════════════════════════════════════════════
   GENERATION STUDIO — Design Tokens
   Единая точка управления всеми размерами, цветами и отступами.
   Подключается ПОСЛЕ style.css чтобы дополнить/переопределить переменные.
   ══════════════════════════════════════════════════════════════════════════════ */

:root {
    /* ── Global UI state (Controlled by Settings) ────────────────────────── */
    --gs-ui-brightness:   1.0;
    --gs-border-alpha:    0.06;
    --gs-gap:             16px;
    --gs-padding:         16px;

    /* ── Range Slider Custom Styling Tokens ─────────────────────────────── */
    --slider-track-h:     4px;
    --slider-thumb-size:  16px;
    --slider-thumb-bg:    #fff;
    --slider-track-bg:    rgba(255, 255, 255, 0.1);
    --slider-track-fill:  rgba(255, 255, 255, 0.3);

    /* ── Modal sizes ─────────────────────────────────────────────────────── */
    --modal-width-xs:   420px;
    --modal-width-sm:   560px;
    --modal-width-md:   860px;
    --modal-width-lg:  1400px;
    --modal-width-xl:  1650px;
    --modal-max-h:      85vh;
    --modal-max-h-lg:   92vh;
    --modal-radius:     16px;
    --modal-padding:    28px;
    --modal-padding-sm: 20px;

    /* ── Colors (Dynamic based on brightness) ────────────────────────────── */
    --text-primary:    rgba(255, 255, 255, calc(0.9 * var(--gs-ui-brightness)));
    --text-secondary:  rgba(255, 255, 255, calc(0.55 * var(--gs-ui-brightness)));
    --text-muted:      rgba(255, 255, 255, calc(0.25 * var(--gs-ui-brightness)));
    
    --border-subtle:   rgba(255, 255, 255, var(--gs-border-alpha));
    --border-glow:     rgba(255, 255, 255, calc(var(--gs-border-alpha) * 2));
    
    --bg-surface:      rgba(255, 255, 255, 0.04);
    --bg-surface-elev: rgba(255, 255, 255, 0.08);

    /* ── Generation panels ───────────────────────────────────────────────── */
    --gen-left-w:     310px;
    --gen-right-w:    320px;
    --gen-gap:         var(--gs-gap);

    /* ── Inputs ──────────────────────────────────────────────────────────── */
    --input-bg:       rgba(255, 255, 255, 0.03);
    --input-bg-dark:  rgba(0, 0, 0, 0.2);
    --input-radius:   8px;
    --input-padding:  10px 14px;
    --input-border:   1px solid var(--border-subtle);
    --input-color:    var(--text-primary);
    --input-focus-border: 1px solid rgba(255, 255, 255, 0.15);

    /* ── Buttons ─────────────────────────────────────────────────────────── */
    --btn-icon-size:   34px;
    --btn-radius:      8px;
    --btn-radius-sm:   6px;
    --btn-padding:     10px 20px;

    /* ── Typography ──────────────────────────────────────────────────────── */
    --label-size:     0.72rem;
    --label-weight:   600;
    --label-spacing:  0.06em;
    --body-size:      0.85rem;
    --body-line:      1.55;

    /* ── Semantic Colors (Neutralized) ─────────────────────────────────── */
    --color-danger:       #ef4444;
    --color-success:      rgba(255, 255, 255, 0.9);
    --color-accent-blue:  rgba(255, 255, 255, 0.4);
    --accent-blue:        rgba(255, 255, 255, 0.4);
    
    /* ── Z-index stack ───────────────────────────────────────────────────── */
    --z-modal:      2000;
    --z-modal-gen:  3000;
    --z-lightbox:   4000;
    --z-toast:      9000;
    --z-menu:       8000;
}

/* ══════════════════════════════════════════════════════════════════════════════
   UTILITY CLASSES
   ══════════════════════════════════════════════════════════════════════════════ */

/* ── Modal sizes ──────────────────────────────────────────────────────────── */
.modal-xs  { max-width: var(--modal-width-xs); }
.modal-sm  { max-width: var(--modal-width-sm); }
.modal-md  { max-width: var(--modal-width-md); }
.modal-lg  { max-width: var(--modal-width-lg);  max-height: var(--modal-max-h-lg); }
.modal-xl  { max-width: var(--modal-width-xl);  max-height: var(--modal-max-h-lg); }

/* ── Standard glass panel for modals ─────────────────────────────────────── */
.glass-panel {
    background: var(--bg-surface, #131722);
    border: 1px solid var(--border-subtle, #1e2436);
    border-radius: var(--modal-radius);
    padding: var(--modal-padding);
    position: relative;
    width: 90%;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.glass-panel.scrollable {
    overflow-y: auto;
    max-height: var(--modal-max-h);
}
.glass-panel.scrollable-lg {
    overflow-y: auto;
    max-height: var(--modal-max-h-lg);
}

/* ── Modal header ─────────────────────────────────────────────────────────── */
.modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px;
    flex-shrink: 0;
}
.modal-header h2,
.modal-header h3 {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--text-primary, #e8eaf6);
}
.modal-header .modal-close {
    width: var(--btn-icon-size);
    height: var(--btn-icon-size);
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 1px solid var(--border-subtle, #1e2436);
    border-radius: var(--btn-radius-sm);
    color: var(--text-secondary, #8e9bb0);
    cursor: pointer;
    transition: color 0.2s, border-color 0.2s, background 0.2s;
    flex-shrink: 0;
}
.modal-header .modal-close:hover {
    color: var(--text-primary, #e8eaf6);
    border-color: rgba(255, 255, 255, 0.2);
    background: rgba(255, 255, 255, 0.06);
}

/* ── Section label ────────────────────────────────────────────────────────── */
.section-label {
    font-size: var(--label-size);
    font-weight: var(--label-weight);
    letter-spacing: var(--label-spacing);
    text-transform: uppercase;
    color: var(--text-secondary, #8e9bb0);
    margin-bottom: 8px;
}

/* ── Unified dark inputs ──────────────────────────────────────────────────── */
.input-dark,
.textarea-dark {
    background: var(--input-bg-dark);
    border: var(--input-border);
    border-radius: var(--input-radius);
    color: var(--input-color);
    padding: var(--input-padding);
    font-size: var(--body-size);
    font-family: inherit;
    width: 100%;
    outline: none;
    transition: border-color 0.2s;
    box-sizing: border-box;
}
.textarea-dark {
    resize: none;
    line-height: var(--body-line);
    min-height: 80px;
}
.input-dark:focus,
.textarea-dark:focus {
    border: var(--input-focus-border);
}
.input-dark::placeholder,
.textarea-dark::placeholder {
    color: rgba(142, 155, 176, 0.5);
}

/* ── Gen workspace layout ─────────────────────────────────────────────────── */
.gen-workspace {
    display: flex;
    gap: var(--gen-gap);
    align-items: stretch;
    width: 100%;
}
.gen-left-panel {
    width: var(--gen-left-w);
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.gen-right-panel {
    width: var(--gen-right-w);
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.gen-center-panel {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
}

/* ── Storage indicator ────────────────────────────────────────────────────── */
.storage-indicator {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    cursor: pointer;
    padding: 5px 10px;
    border-radius: var(--btn-radius-sm);
    white-space: nowrap;
    user-select: none;
    transition: opacity 0.2s;
}
.storage-indicator:hover { opacity: 0.8; }
.storage-indicator.storage-ok {
    background: var(--storage-ok-bg);
    border: 1px solid var(--storage-ok-border);
    color: var(--storage-ok-color);
}
.storage-indicator.storage-warn {
    background: var(--storage-warn-bg);
    border: 1px solid var(--storage-warn-border);
    color: var(--storage-warn-color);
}

/* ── Entity card (Character / Location) ──────────────────────────────────── */
.entity-item {
    border: none;
    background: transparent;
    padding: 0;
    margin-bottom: 30px;
    position: relative;
    text-align: left;
    width: 100%;
}

/* ── Overlay icon buttons (viewport) ─────────────────────────────────────── */
.overlay-icon-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.6);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: var(--btn-radius-sm);
    padding: 6px;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s;
}
.overlay-icon-btn:hover {
    background: rgba(255, 255, 255, 0.15);
    border-color: rgba(255, 255, 255, 0.25);
}

/* ── NEW badge for models ─────────────────────────────────────────────────── */
.model-badge-new {
    display: inline-block;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.04em;
    padding: 1px 5px;
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.6);
    border: 1px solid rgba(255, 255, 255, 0.12);
    vertical-align: middle;
    margin-left: 4px;
}

/* ── Responsive: collapse gen panels on small screens ────────────────────── */
@media (max-width: 1100px) {
    .gen-left-panel  { width: 280px; }
    .gen-right-panel { width: 260px; }
}
@media (max-width: 860px) {
    .gen-workspace { flex-direction: column; }
    .gen-left-panel, .gen-right-panel { width: 100%; }
}

/* ── Lightbox Z-index classes ─────────────────────────────────────────────── */
.lightbox            { z-index: var(--z-modal); }
.lightbox-viewer     { z-index: var(--z-lightbox) !important; }
#generationModal     { z-index: var(--z-modal-gen) !important; }
#videoGenModal       { z-index: var(--z-modal-gen) !important; }

/* ── Generation Modal utilities (added in refactor Block 2) ─────────────── */
.prompt-panel { flex:1; display:flex; flex-direction:column; background:rgba(0,0,0,0.3); border:1px solid var(--border-subtle,#1e2436); border-radius:8px; overflow:hidden; }
.prompt-tools { display:flex; justify-content:flex-end; gap:8px; padding:8px 12px; border-top:1px solid var(--border-subtle,#1e2436); background:rgba(0,0,0,0.2); }

/* ── Additional utility classes (Block 2.3) ──────────────────────────────── */
.tool-icon-btn { background:none; border:none; cursor:pointer; color:var(--text-secondary,#8e9bb0); transition:color 0.2s; padding:4px; display:flex; align-items:center; }
.tool-icon-btn:hover { color: #fff; }
.modal-title-row { color:var(--text-primary); display:flex; align-items:center; gap:8px; margin:0; border:none; padding:0; }
.dropdown-item { display:block; padding:8px 12px; color:var(--text-primary); text-decoration:none; border-radius:4px; transition:background 0.2s; }
.dropdown-item:hover { background:rgba(59,130,246,0.1); }

/* ── Range Slider Custom Styling (Webkit/Moz) ───────────────────────────── */
input[type="range"] {
    -webkit-appearance: none;
    appearance: none;
    background: transparent;
    cursor: pointer;
    width: 100%;
}
input[type="range"]::-webkit-slider-runnable-track {
    background: var(--slider-track-bg);
    height: var(--slider-track-h);
    border-radius: 2px;
}
input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    margin-top: calc((var(--slider-thumb-size) / -2) + (var(--slider-track-h) / 2));
    background-color: var(--slider-thumb-bg);
    height: var(--slider-thumb-size);
    width: var(--slider-thumb-size);
    border-radius: 50%;
    box-shadow: 0 0 10px rgba(0,0,0,0.5);
    transition: transform 0.1s;
}
input[type="range"]:active::-webkit-slider-thumb {
    transform: scale(1.2);
}
input[type="range"]::-moz-range-track {
    background: var(--slider-track-bg);
    height: var(--slider-track-h);
    border-radius: 2px;
}
input[type="range"]::-moz-range-thumb {
    background-color: var(--slider-thumb-bg);
    border: none;
    height: var(--slider-thumb-size);
    width: var(--slider-thumb-size);
    border-radius: 50%;
}

/* ── Final Layout Adjustments ────────────────────────────────────────────── */
.studio-layout {
    gap: var(--gs-gap) !important;
    padding: var(--gs-padding) !important;
}
.studio-center {
    gap: var(--gs-gap) !important;
}

