@import '../theme.css';

/* Container principal da janela */
.application-window {
    display: flex;
    flex-direction: column;
    position: absolute; /* Flutuante por padrão */
    background-color: var(--color-bg-panel);
    border-radius: var(--border-radius-base);
    box-shadow: var(--window-shadow);
    border: var(--window-border-inactive);
    overflow: hidden; /* Conteúdo extra recortado */

    min-width: 200px;
    min-height: 100px;

    transition:
        border-color 0.2s ease-out,
        box-shadow 0.2s ease-out;

    z-index: var(--viewport-z-floating);
}

/* Estado Ativo / Focado */
.application-window--focused {
    border: var(--window-border-active);
}

/* Estado Maximizado */
.application-window--maximized {
    border-radius: 0;
    border: none;
    box-shadow: none;
}

/* * [CORREÇÃO] Ocultar alças de redimensionamento quando maximizado OU em modo aba
 */
.application-window--maximized .window-resize-handle,
.application-window--tabbed .window-resize-handle {
    display: none !important;
}

/* Estado Minimizado (apenas header visível) */
.application-window--minimized {
    height: var(--window-header-height) !important;
    min-height: var(--window-header-height) !important;
    resize: none;
}
.application-window--minimized .application-window__content {
    display: none;
}
.application-window--minimized .window-resize-handle {
    display: none;
}

/* Estado "Always on Top" (Pin) */
.application-window--pinned {
    z-index: var(--viewport-z-always-on-top) !important;
    border-color: var(--color-accent-primary);
}

/* --- Header da Janela --- */
.window-header {
    display: flex;
    align-items: center;
    height: var(--window-header-height);
    background-color: var(--window-header-bg-inactive);
    color: var(--window-header-color-inactive);
    padding: 0 8px;
    user-select: none;
    flex-shrink: 0;
    border-bottom: 1px solid var(--color-border-default);
    cursor: default;
}

.application-window--focused .window-header {
    background-color: var(--window-header-bg-active);
    color: var(--window-header-color-active);
}

/* [CORREÇÃO] Estilo para quando o header é uma aba */
.window-header--tab {
    border-bottom: none;
    /* Outros estilos gerenciados pelo viewport.css */
}

.window-header__title {
    flex-grow: 1;
    font-weight: 600;
    font-size: 0.85rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-right: 8px;
}

.window-header__controls {
    display: flex;
    gap: 4px;
    align-items: center;
}

/* Botões do Header */
.window-header__btn {
    background: transparent;
    border: none;
    color: inherit;
    cursor: pointer;
    padding: 0;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    font-size: 1.1em;
    line-height: 1;
    opacity: 0.7;
    transition:
        background-color 0.2s,
        opacity 0.2s;
}

.window-header__btn:hover {
    background-color: rgba(255, 255, 255, 0.2);
    opacity: 1;
}

.window-header__btn--close:hover {
    background-color: var(--color-feedback-danger);
    color: var(--color-text-on-danger);
}

.application-window--pinned .window-header__btn--pin {
    opacity: 1;
    transform: rotate(45deg);
}

/* --- Conteúdo Interno --- */
.application-window__content {
    flex: 1;
    overflow: auto;
    position: relative;
    background-color: var(--color-bg-panel-content);
    color: var(--color-text-primary);
    display: flex;
    flex-direction: column;
}

.window-resize-handle {
    z-index: 10;
}
