.modal-overlay {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background-color: rgba(0,0,0,0.7); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
    z-index: 1000; display: flex; align-items: center; justify-content: center;
    opacity: 0; visibility: hidden; transition: all 0.4s var(--smooth-curve);
}
.modal-overlay.is-visible { opacity: 1; visibility: visible; }
.modal-content {
    background-color: var(--cream-white); color: var(--black-soft); padding: 35px;
    border-radius: 16px; box-shadow: 0 15px 50px rgba(0,0,0,0.4); width: 90%; max-width: 700px;
    position: relative; transform: scale(0.9) translateY(20px); transition: all 0.4s var(--smooth-curve);
}
.modal-overlay.is-visible .modal-content { transform: scale(1) translateY(0); }
.modal-close {
    position: absolute; top: 15px; right: 20px; background: none; border: none;
    color: var(--black-soft); font-size: 2.2rem; font-weight: 300; cursor: pointer;
    opacity: 0.5; transition: all 0.3s ease; z-index: 10;
}
.modal-close:hover { opacity: 1; transform: scale(1.1) rotate(90deg); }
.modal-body { padding: 10px 0 0 0; }
.modal-grid { display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 40px; }
.modal-logo { height: 70px; width: auto; margin-bottom: 15px; display: block; margin-left: auto; margin-right: auto; }
.modal-text { text-align: left; }
.modal-visual-container { display: flex; align-items: center; justify-content: center; }
.modal-image { width: 100%; max-width: 280px; height: auto; border-radius: 8px; object-fit: cover; }
.modal-text h2 { font-size: 1.7rem; font-weight: 700; color: var(--black-soft); margin-bottom: 20px; text-align: left; line-height: 1.3; }
.modal-text p { font-size: 1rem; color: #333; opacity: 1; margin-bottom: 35px; text-align: left; }
.modal-cta {
    width: auto; padding: 12px 30px; background-color: transparent; color: var(--black-soft);
    border: 2px solid var(--black-soft); box-shadow: none; background-image: none;
    font-weight: 700; transition: all 0.3s var(--smooth-curve); font-size: 0.8rem;
    text-transform: uppercase; letter-spacing: 0.5px;
}
.modal-cta:hover { background-color: var(--black-soft); color: var(--cream-white); transform: translateY(-3px); box-shadow: 0 5px 15px rgba(0,0,0,0.2); }
@media (max-width: 900px) {
    .modal-content { max-width: 500px; padding: 25px; }
    .modal-grid { grid-template-columns: 1fr; gap: 25px; }
    .modal-logo { height: 50px; margin: 0 auto 15px; }
    .modal-text, .modal-text h2, .modal-text p { text-align: center; }
    .modal-text h2 { font-size: 1.6rem; }
    .modal-visual-container { display: flex; margin-top: 20px; }
}
@media (max-width: 768px) {
    .modal-content { padding: 30px 25px; }
    .modal-grid { gap: 15px; }
}