/* css/popup.css */

/* Styles for general modal popups, feedback form, and cookie consent banner */

/* General Modal Popup Styles (for Feedback Form) */
.popup-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.75); /* Darker overlay for strong focus */
    display: flex; 
    justify-content: center;
    align-items: center;
    z-index: 1000; 
    opacity: 0;
    visibility: hidden; 
    transition: opacity 0.3s ease, visibility 0.3s ease; 
}
.popup-modal[aria-hidden="false"] {
    opacity: 1;
    visibility: visible;
}
.popup-modal-content {
    background-color: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 20px; /* Consistent rounding */
    padding: 2.5rem; /* More padding */
    position: relative;
    max-width: 480px; 
    width: 90%;
    text-align: center;
    box-shadow: 0 15px 40px rgba(0,0,0,0.3); /* Deeper shadow */
    transform: translateY(30px); /* More pronounced slide-in */
    transition: transform 0.3s ease;
}
.popup-modal[aria-hidden="false"] .popup-modal-content {
    transform: translateY(0);
}


.popup-modal-content .close-btn {
    position: absolute;
    top: 0.75rem; 
    right: 0.75rem; 
    background: var(--bg-highlight); 
    border: 1px solid var(--border-color); 
    border-radius: 50%; 
    width: 44px; 
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem; 
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.2s ease-in-out;
    line-height: 1;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1); 
}
.popup-modal-content .close-btn:hover {
    color: var(--text-primary);
    background-color: var(--bg-main); 
    box-shadow: 0 4px 10px rgba(0,0,0,0.15);
    transform: translateY(-1px); 
}

.popup-modal-content .feedback-icon { 
    font-size: 3.5rem;
    color: var(--accent-color);
    margin-bottom: 1rem;
    display: block;
}

.popup-modal-content h3 {
    font-size: var(--fs-xl); 
    font-weight: 700;
    margin-bottom: 0.75rem; 
    color: var(--text-primary);
}

.popup-modal-content p {
    font-size: var(--fs-sm); 
    color: var(--text-secondary);
    margin-bottom: 1.5rem; 
    line-height: 1.5; 
}

.feedback-actions { 
    display: flex;
    justify-content: center;
    gap: 1rem;
    flex-wrap: wrap; 
}
.feedback-actions .btn {
    flex-grow: 1;
    max-width: 200px;
}

/* Feedback Form specific styles */
.feedback-form-container {
    text-align: left; 
}
.feedback-form-container h3, .feedback-form-container p {
    text-align: center; 
}
.feedback-form-container p {
    margin-bottom: 1.5rem; 
}
.feedback-form-container form {
    display: flex;
    flex-direction: column;
    gap: 1rem; 
}
.feedback-form-container .form-group {
    margin-bottom: 0; 
}
.feedback-form-container label {
    font-weight: 600;
    font-size: var(--fs-sm); 
    color: var(--text-primary); 
    margin-bottom: 0.5rem;
}
.feedback-form-container .btn {
    align-self: flex-start; 
    margin-top: 0.75rem; 
}

/* Star Rating Specific Styles */
.rating-section {
    display: flex;
    flex-direction: column;
    align-items: center; 
    margin-bottom: 1rem; 
}
.rating-section label {
    margin-bottom: 1rem; 
    font-size: var(--fs-base); 
    text-align: center;
    width: 100%;
}
.stars {
    display: flex;
    gap: 0.5rem; 
    cursor: pointer;
    font-size: 1.5rem; 
    color: var(--text-secondary); 
    transition: color 0.2s;
}
.stars i {
    transition: color 0.2s, transform 0.1s;
}
.stars i:hover {
    transform: translateY(-2px); 
}
/* Filled stars color */
.stars i.fa-solid.fa-heart {
    color: #ffc107; 
}
html[data-theme="dark"] .stars i.fa-solid.fa-heart {
    color: #ffd700; 
}

/* General sub-Popup styles for Thank You/Loading */
.popup { 
    position: absolute; 
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.75); 
    display: flex; 
    justify-content: center;
    align-items: center;
    z-index: 100; 
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}
.popup[aria-hidden="false"] {
    opacity: 1;
    visibility: visible;
}
.popup .popup-content {
    background-color: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 20px; 
    padding: 2rem; 
    box-shadow: 0 8px 20px rgba(0,0,0,0.2);
    text-align: center;
    max-width: 380px; 
    width: 80%; 
    transform: translateY(20px);
    transition: transform 0.3s ease;
}
.popup[aria-hidden="false"] .popup-content {
    transform: translateY(0);
}
.popup .popup-content h3 {
    font-size: var(--fs-lg); 
    font-weight: 700;
    margin-bottom: 0.75rem; 
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}
.popup .popup-content p {
    font-size: var(--fs-sm); 
    color: var(--text-secondary);
    margin-bottom: 0; 
}
.colorful-text {
    color: var(--accent-color);
}
.colorful-text i {
    font-size: 1.2em; 
    color: var(--accent-color);
}
/* Spinner for loading popup */
.spinner {
    font-size: 3rem; 
    color: var(--accent-color);
    animation: spin 1.5s linear infinite;
    display: block;
    margin: 0 auto 1.5rem auto; 
}

/* --- Cookie Consent Banner --- */
.cookie-consent-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    /* NEW: Solid background to ensure it covers content below */
    background-color: var(--bg-card); 
    border-top: 1px solid var(--border-color); 
    /* NEW: More generous and consistent padding */
    padding: 1.5rem 2.5rem; 
    display: flex; 
    justify-content: space-between;
    align-items: center;
    gap: 2rem; 
    box-shadow: 0 -8px 25px rgba(0, 0, 0, 0.15); /* NEW: Stronger shadow from bottom */
    /* NEW: Ensure it's on top of everything else */
    z-index: 9999; 
    font-size: var(--fs-base); 
    flex-wrap: wrap; 
    /* Initial state for CSS transition */
    opacity: 0;
    transform: translateY(100%);
    visibility: hidden; /* Start hidden */
    transition: opacity 0.5s ease-out, transform 0.5s ease-out; /* Removed visibility from transition to manage via JS directly */
}
/* This class is added by JS to trigger the transition */
.cookie-consent-banner[aria-hidden="false"] {
    opacity: 1;
    transform: translateY(0);
    /* visibility is managed by JS directly, not via transition */
}

.cookie-consent-banner .banner-content {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    flex-grow: 1; 
}
.cookie-consent-banner p {
    margin: 0;
    color: var(--text-primary);
    flex-grow: 1; 
    line-height: 1.6; 
}
.cookie-consent-banner p a {
    color: var(--accent-color);
    text-decoration: underline;
    font-weight: 500;
}
.cookie-consent-banner .banner-actions {
    display: flex;
    gap: 0.75rem; 
    flex-shrink: 0;
}
.cookie-consent-banner .btn {
    flex-shrink: 0; 
    padding: 0.7rem 1.4rem; 
    font-size: var(--fs-sm); 
    border-radius: 8px; 
}
/* Ensure buttons inherit consistent styling */
.cookie-consent-banner .btn-primary {
    background-color: var(--btn-primary-bg);
    color: var(--btn-primary-text);
    border-color: var(--btn-primary-bg);
}
.cookie-consent-banner .btn-primary:hover {
    background-color: var(--btn-primary-hover);
    border-color: var(--btn-primary-hover);
}
.cookie-consent-banner .btn-outlined {
    background-color: transparent;
    color: var(--btn-outlined-text);
    border-color: var(--btn-outlined-border);
}
.cookie-consent-banner .btn-outlined:hover {
    background-color: var(--btn-outlined-hover-bg);
    color: var(--btn-outlined-text);
}


/* Responsive adjustments for popups */
@media (max-width: 768px) {
    .popup-modal-content {
        padding: 2rem; 
    }
    .popup-modal-content h3 {
        font-size: var(--fs-xl); 
    }
    .popup-modal-content p {
        font-size: var(--fs-sm); 
    }
    .feedback-actions {
        flex-direction: column;
        gap: 0.75rem;
    }
    .feedback-actions .btn {
        max-width: 100%;
    }
    .popup .popup-content {
        padding: 1.5rem; 
    }
    .popup .popup-content h3 {
        font-size: var(--fs-base); 
    }
    .popup .popup-content p {
        font-size: var(--fs-sm); 
    }

    /* Cookie Banner Responsive */
    .cookie-consent-banner {
        flex-direction: column;
        text-align: center;
        gap: 1.5rem; 
        padding: 1.5rem; 
        font-size: var(--fs-sm); 
    }
    .cookie-consent-banner .banner-content {
        flex-direction: column;
        gap: 0.75rem; 
    }
    .cookie-consent-banner p {
        margin-bottom: 0.5rem;
    }
    .cookie-consent-banner .banner-actions {
        width: 100%;
        justify-content: center;
        gap: 0.5rem; 
    }
    .cookie-consent-banner .btn {
        flex-grow: 1; 
    }
}
@media (max-width: 576px) {
    .popup-modal-content {
        padding: 1.5rem;
    }
    .popup-modal-content h3 {
        font-size: var(--fs-lg);
    }
    .popup-modal-content p {
        font-size: var(--fs-xs);
    }
    .feedback-actions .btn {
        max-width: 100%;
    }
    .popup .popup-content {
        padding: 1.2rem;
    }
    .popup .popup-content h3 {
        font-size: var(--fs-sm);
    }
    .popup .popup-content p {
        font-size: var(--fs-xs);
    }
    .spinner {
        font-size: 2.5rem;
        margin-bottom: 1rem;
    }
    
    /* Cookie Banner */
    .cookie-consent-banner {
        padding: 1rem;
        font-size: var(--fs-xs); 
    }
    .cookie-consent-banner .btn {
        padding: 0.5rem 1rem; 
        font-size: var(--fs-xs); 
    }
}