/* Modals — Base, Sizes, Login, Credits, AI Context */

.modal {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(0, 0, 0, 0.6); display: none;
    align-items: center; justify-content: center; z-index: var(--z-modal);
}
.modal.show { display: flex; }

.modal-content {
    background: var(--color-bg-secondary); border-radius: var(--radius);
    width: 400px; max-width: 90%; box-shadow: var(--shadow); animation: modalIn 0.2s ease;
}
.modal-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: var(--space-16) var(--space-20); border-bottom: 1px solid var(--color-border);
}
.modal-header h3 { font-size: var(--font-size-xl); font-weight: var(--font-weight-semibold); }
.modal-close {
    background: transparent; border: none; font-size: var(--font-size-3xl);
    color: var(--color-text-muted); cursor: pointer; transition: color 0.15s;
}
.modal-close:hover { color: var(--color-text-primary); }
.modal-body { padding: var(--space-20); }
.modal-body input[type="text"] {
    width: 100%; padding: var(--space-10) var(--space-14); font-size: var(--font-size-lg);
    background: var(--color-bg-tertiary); border: 1px solid var(--color-border);
    border-radius: var(--radius-sm); color: var(--color-text-primary); font-family: inherit;
}
.modal-body input:focus { outline: none; border-color: var(--color-accent-primary); }
.modal-footer {
    display: flex; justify-content: flex-end; gap: var(--space-12);
    padding: var(--space-16) var(--space-20); border-top: 1px solid var(--color-border);
}
.modal-title-group { display: flex; align-items: center; gap: var(--space-12); }
.modal-large { width: 800px; max-width: 95%; max-height: 85vh; }
.modal-xlarge { width: 1200px; max-width: 95%; max-height: 90vh; }
.modal-login { max-width: 480px; }

/* Login Required */
.login-promo { text-align: center; padding: var(--space-20) 0; }
.login-promo-icon { font-size: var(--font-size-4xl); color: var(--color-accent-primary); margin-bottom: var(--space-16); }
.login-required-message { font-size: var(--font-size-xl); margin-bottom: var(--space-24); color: var(--color-text-primary); }
.login-benefits { display: flex; flex-direction: column; gap: var(--space-12); text-align: left; max-width: 280px; margin: 0 auto; }
.benefit-item { display: flex; align-items: center; gap: var(--space-12); color: var(--color-text-secondary); }
.benefit-item i { color: var(--color-accent-success); width: var(--space-20); }

/* Credits */
.credits-info { margin-bottom: var(--space-8); font-size: var(--font-size-xl); }
.credits-description { color: var(--color-text-secondary); font-size: var(--font-size-lg); margin-bottom: var(--space-16); }
.credit-packages { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-12); margin-top: var(--space-16); }
.credit-package {
    padding: var(--space-16); background: var(--color-bg-tertiary);
    border: 2px solid var(--color-border); border-radius: var(--radius);
    text-align: center; cursor: pointer; transition: var(--transition-normal);
}
.credit-package:hover { border-color: var(--color-accent-primary); transform: translateY(-2px); }
.credit-package h4 { font-size: var(--font-size-xl); color: var(--color-text-primary); margin-bottom: var(--space-8); }
.credit-package .price { font-size: var(--font-size-2xl); font-weight: var(--font-weight-bold); color: var(--color-accent-success); }
.insufficient-credits-message { color: var(--color-text-secondary); font-size: var(--font-size-lg); line-height: var(--line-height-relaxed); }

/* AI Context */
.ai-context-description { margin-bottom: var(--space-16); color: var(--color-text-secondary); font-size: var(--font-size-lg); }
#aiContextInput {
    width: 100%; padding: var(--space-12); background: var(--color-bg-tertiary);
    border: 1px solid var(--color-border); border-radius: var(--radius);
    color: var(--color-text-primary); font-family: inherit; font-size: var(--font-size-lg);
    resize: vertical; min-height: 120px;
}
#aiContextInput:focus { outline: none; border-color: var(--color-accent-primary); }
#aiContextInput::placeholder { color: var(--color-text-muted); }
