/* modal.css - Universal Theme Support */

.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--bg-overlay);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 2000;
    opacity: 1;
    transition: opacity 0.2s ease-in-out;
}

.modal-overlay.hidden {
    opacity: 0;
    pointer-events: none;
}

.modal-container {
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
    width: 90%;
    max-width: 780px;
    min-height: 70vh;
    max-height: 95vh;
    overflow-y: auto;
    box-shadow: var(--shadow-xl);
    position: relative;
    animation: slideIn 0.3s ease;
}

.modal-overlay.hidden .modal-container {
    transform: scale(0.95);
}

.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--border-primary);
    padding: 16px 24px;
}

.modal-header h3 {
    margin: 0;
    font-size: 1.25rem;
    color: var(--text-primary);
}

.modal-body {
    padding: 24px;
    font-size: 1rem;
    color: var(--text-secondary);
    line-height: 1.5;
}

.modal-actions {
    padding: 0 24px 24px;
    display: flex;
    justify-content: flex-end;
    gap: 12px;
}

.modal-actions button {
    font-family: inherit;
    font-size: 0.9rem;
    padding: 0.6rem 1.2rem;
    border-radius: var(--radius-md);
    border: 1px solid transparent;
    cursor: pointer;
    transition:
        background-color 0.2s,
        border-color 0.2s;
}

.modal-btn-primary {
    background-color: var(--brand-primary);
    color: var(--text-inverse);
    border-color: var(--brand-primary);
}

.modal-btn-primary:hover {
    background-color: var(--brand-primary-hover);
    border-color: var(--brand-primary-hover);
}

.modal-btn-secondary {
    background-color: transparent;
    color: var(--text-secondary);
    border-color: var(--border-primary);
}

.modal-btn-secondary:hover {
    background-color: var(--bg-tertiary);
    border-color: var(--border-secondary);
}

/* --- Стили для модального окна Share --- */

.modal-close-btn {
    background: none;
    border: none;
    padding: 0;
    font-size: 28px;
    color: var(--text-tertiary);
    cursor: pointer;
    transition: color 0.2s;
    line-height: 1;
}
.modal-close-btn:hover {
    color: var(--text-primary);
}

.input-label {
    display: block;
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin-bottom: 0.25rem;
    font-weight: 500;
}

.input-field {
    width: 100%;
    height: 38px;
    box-sizing: border-box;
    border: 1px solid var(--border-primary);
    border-radius: var(--radius-md);
    padding: 0.375rem 0.75rem;
    font-family: inherit;
    font-size: 1rem;
    background-color: var(--bg-secondary);
    color: var(--text-primary);
    transition: all 0.2s ease;
}

.input-field:focus {
    outline: 2px solid var(--brand-primary);
    outline-offset: 1px;
    background-color: var(--bg-primary);
    border-color: var(--brand-primary);
}

.shared-user-item {
    transition: background-color 0.2s;
}
.shared-user-item:last-child {
    border-bottom: none;
}
.shared-user-item:hover {
    background-color: var(--bg-tertiary);
}

.flat-button {
    background: none;
    border: none;
    color: var(--color-error);
    cursor: pointer;
    font-weight: 500;
    font-size: 0.9rem;
    padding: 4px 8px;
    border-radius: var(--radius-sm);
    transition:
        background-color 0.2s,
        color 0.2s;
}
.flat-button:hover {
    background-color: var(--color-error-light);
    color: var(--color-error-hover);
}

/* Повышенный z-index для confirmation и alert модальных окон */
.modal-overlay.confirmation-modal {
    z-index: 2100;
}

.modal-overlay.alert-modal {
    z-index: 2100;
}

.modal-overlay.critical-modal {
    z-index: 2200;
}

/* Remove min-height for small modals (prompt, alert, confirmation, custom-prompt) */
.modal-overlay.prompt-modal .modal-container,
.modal-overlay.alert-modal .modal-container,
.modal-overlay.confirmation-modal .modal-container,
.modal-overlay.custom-prompt-modal .modal-container,
#share-activity-modal-container {
    min-height: auto;
}

/* --- Стили для prompt модального окна --- */
.modal-body .modal-prompt-label {
    margin-bottom: 8px;
    display: block;
    color: var(--text-primary);
}

.modal-body .modal-prompt-textarea {
    width: 100%;
    min-height: 120px;
    padding: 0.5rem 0.75rem;
    font-family: inherit;
    font-size: 1rem;
    border: 1px solid var(--border-primary);
    border-radius: var(--radius-md);
    resize: vertical;
    box-sizing: border-box;
    background-color: var(--bg-secondary);
    color: var(--text-primary);
}

.modal-body .modal-prompt-textarea:focus {
    background-color: var(--bg-primary);
    color: var(--text-primary);
    outline: 2px solid var(--brand-primary);
    outline-offset: 1px;
}

.modal-body .modal-prompt-input {
    width: 100%;
    height: 38px;
    box-sizing: border-box;
    border: 1px solid var(--border-primary);
    border-radius: var(--radius-md);
    padding: 0.375rem 0.75rem;
    font-family: inherit;
    font-size: 1rem;
    background-color: var(--bg-secondary);
    color: var(--text-primary);
}

.modal-body .modal-prompt-input:focus {
    background-color: var(--bg-primary);
    color: var(--text-primary);
    outline: 2px solid var(--brand-primary);
    outline-offset: 1px;
}

/* ================================================= */
/* СТИЛИ ДЛЯ КНОПОК В МОДАЛЬНЫХ ОКНАХ               */
/* ================================================= */

.btn-primary {
    background-color: var(--brand-primary);
    color: var(--text-inverse);
    border: none;
    padding: 0.6rem 1.2rem;
    border-radius: var(--radius-md);
    cursor: pointer;
    font-size: 0.9rem;
    font-weight: 500;
    transition: background-color 0.2s ease;
}

.btn-primary:hover {
    background-color: var(--brand-primary-hover);
}

.btn-secondary {
    background-color: var(--bg-tertiary);
    color: var(--text-primary);
    border: none;
    padding: 0.6rem 1.2rem;
    border-radius: var(--radius-md);
    cursor: pointer;
    font-size: 0.9rem;
    font-weight: 500;
    margin-right: 0.5rem;
    transition: background-color 0.2s ease;
}

.btn-secondary:hover {
    background-color: var(--bg-hover);
}

/* Стили для Paywall Modal */
.paywall-container {
    max-width: 650px;
}
.pricing-cards {
    display: flex;
    gap: 1.5rem;
    margin-top: 1rem;
    margin-bottom: 1rem;
}
.pricing-card {
    flex: 1;
    border: 1px solid var(--border-primary);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
    text-align: left;
    background-color: var(--bg-primary);
}
.pricing-card h4 {
    font-size: 1.2rem;
    font-weight: 600;
    margin: 0 0 0.5rem;
    color: var(--text-primary);
}
.pricing-card .price {
    font-size: 1.8rem;
    font-weight: bold;
    margin: 0 0 1rem;
    color: var(--text-primary);
}
.pricing-card .price span {
    font-size: 1rem;
    font-weight: normal;
    color: var(--text-secondary);
}
.pricing-card ul {
    list-style-type: '✓  ';
    padding-left: 1.2rem;
    margin: 0 0 1.5rem;
    color: var(--text-secondary);
}
.pricing-card ul li {
    margin-bottom: 0.5rem;
}
.discount-note {
    text-align: center;
    color: var(--text-secondary);
    font-size: 0.9rem;
}
/* ModalService overlay z-index hierarchy:
   - #modal-service-overlay (new ID): 10100 - above resume-parser-overlay (10000)
   - #modal-overlay fallback for ModalService: 2100 - standard modal level
   Note: step-by-step module has its own #modal-overlay with different z-index */
#modal-service-overlay {
    z-index: 10100 !important;
}

/* ================================================= */
/* TOAST NOTIFICATIONS                               */
/* ================================================= */

.modal-service-toast {
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%) translateY(100px);
    padding: 12px 24px;
    border-radius: var(--radius-lg);
    font-size: 14px;
    font-weight: 500;
    z-index: 1999;
    opacity: 0;
    transition:
        transform 0.3s ease,
        opacity 0.3s ease;
    box-shadow: var(--shadow-lg);
    max-width: 400px;
    text-align: center;
}

.modal-service-toast.show {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
}

.modal-service-toast-success {
    background: var(--color-success);
    color: var(--text-inverse);
}

.modal-service-toast-error {
    background: var(--color-error);
    color: var(--text-inverse);
}

.modal-service-toast-warning {
    background: var(--color-warning);
    color: var(--text-inverse);
}

.modal-service-toast-info {
    background: var(--color-info);
    color: var(--text-inverse);
}

/* Modal close button (X) */
.modal-close {
    background: none;
    border: none;
    padding: 4px;
    cursor: pointer;
    color: var(--text-tertiary);
    transition: color 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
}

.modal-close:hover {
    color: var(--text-primary);
}

.modal-close .material-icons {
    font-size: 24px;
}
