/* =============================================
   modal.css — Worldwide Exporter
   Enquiry, contact, review modal styles.
   Pehle JS mein inline inject hote the —
   ab yahan external file mein hain.
   variables.css + utilities.css ke baad load karo.
   ============================================= */

/* ── MODAL ANIMATIONS ── */
@keyframes modal-fade-in  { from { opacity: 0; } to { opacity: 1; } }
@keyframes modal-slide-in { from { opacity: 0; transform: translateY(16px) scale(0.98); } to { opacity: 1; transform: none; } }

/* ── MODAL BACKDROP ── */
.wwe-modal {
    position: fixed;
    inset: 0;
    width: 100%;
    height: 100%;
    background: var(--bg-overlay);
    backdrop-filter: blur(3px);
    display: flex;
    align-items: flex-start;
    justify-content: center;
    z-index: var(--z-modal);
    padding: 24px 16px;
    box-sizing: border-box;
    font-family: var(--font);
    animation: modal-fade-in 0.2s ease;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}
.wwe-modal *, .wwe-modal *::before, .wwe-modal *::after { box-sizing: border-box; }

/* ── MODAL WRAP ── */
.wwe-modal-wrap {
    background: var(--bg-white);
    border-radius: var(--radius-2xl);
    width: 100%;
    box-shadow: var(--shadow-xl);
    position: relative;
    overflow: hidden;
    animation: modal-slide-in 0.28s cubic-bezier(0.16, 1, 0.3, 1);
    margin: auto;
    max-height: calc(100vh - 48px);
    display: flex;
    flex-direction: column;
}
.wwe-modal-wrap--sm  { max-width: 400px; }
.wwe-modal-wrap--md  { max-width: 480px; }
.wwe-modal-wrap--lg  { max-width: 720px; }

/* ── MODAL HEADER ── */
.wwe-modal-head {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: 18px 22px;
    background: linear-gradient(135deg, var(--primary), var(--primary-hover));
    color: #fff;
}
.wwe-modal-head i    { font-size: 1.3rem; opacity: 0.95; }
.wwe-modal-head h3   { margin: 0; font-size: 1.05rem; font-weight: var(--fw-bold); letter-spacing: 0.2px; }
.wwe-modal-head p    { margin: 1px 0 0; font-size: 0.74rem; opacity: 0.85; font-weight: var(--fw-normal); }

/* ── MODAL CLOSE BUTTON ── */
.wwe-modal-close {
    position: absolute;
    top: 14px;
    right: 16px;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.16);
    border: none;
    border-radius: var(--radius-md);
    font-size: 18px;
    color: #fff;
    cursor: pointer;
    transition: var(--transition-fast);
    line-height: 1;
}
.wwe-modal-close:hover { background: rgba(255, 255, 255, 0.3); }

/* ── MODAL BODY ── */
.wwe-modal-body {
    display: flex;
    gap: 22px;
    flex-wrap: wrap;
    padding: 24px;
    overflow-y: auto;
}
.wwe-modal-body--single {
    flex-direction: column;
    padding: 22px;
}

/* ── PRODUCT INFO PANEL (enquiry modal left side) ── */
.wwe-product-info {
    flex: 1 1 200px;
    max-width: 210px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-3);
}
.wwe-product-img-frame {
    width: 100%;
    aspect-ratio: 1;
    border: 1px solid var(--border);
    border-radius: var(--radius-xl);
    background: linear-gradient(160deg, #fbfbfc, #f4f5f7);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    padding: 14px;
}
.wwe-product-img-frame img { width: 100%; height: 100%; object-fit: contain; }
.wwe-product-name { font-weight: var(--fw-bold); font-size: 1rem; color: var(--text-heading); line-height: var(--lh-snug); }
.wwe-verified-tag {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 0.72rem;
    font-weight: var(--fw-semi);
    color: #16a34a;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    padding: 3px 10px;
    border-radius: var(--radius-full);
}

/* ── MODAL FORM ── */
.wwe-form {
    flex: 2 1 360px;
    display: flex;
    flex-direction: column;
}
.wwe-form-field { margin-bottom: 14px; }
.wwe-form label {
    font-weight: var(--fw-semi);
    display: block;
    margin-bottom: 6px;
    color: var(--text-body);
    font-size: 0.82rem;
}
.wwe-form input,
.wwe-form textarea,
.wwe-form select {
    width: 100%;
    padding: var(--input-padding);
    font-size: var(--input-font);
    font-family: var(--font);
    color: var(--input-color);
    border: 1.5px solid var(--input-border);
    border-radius: var(--input-radius);
    outline: none;
    background: var(--input-bg);
    transition: var(--transition-fast);
    box-sizing: border-box;
}
.wwe-form input::placeholder,
.wwe-form textarea::placeholder { font-family: var(--font); color: var(--input-placeholder); }
.wwe-form input:focus,
.wwe-form textarea:focus,
.wwe-form select:focus {
    border-color: var(--input-border-focus);
    box-shadow: var(--input-shadow-focus);
}
.wwe-form input:disabled { background: var(--bg-light); color: var(--text-muted); }
.wwe-form textarea     { resize: vertical; min-height: 92px; }
.wwe-phone-group       { display: flex; gap: var(--space-2); }
.wwe-phone-group select { max-width: 140px; flex-shrink: 0; }
.wwe-phone-group input  { flex-grow: 1; }
.wwe-form-actions { display: flex; justify-content: flex-end; gap: var(--space-2); margin-top: 6px; }
.wwe-form-actions .btn { flex: 1; justify-content: center; }

/* ── MODAL PRIVACY NOTE ── */
.wwe-privacy {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.72rem;
    color: var(--text-subtle);
    margin-top: var(--space-3);
}
.wwe-privacy i { color: var(--primary); }

/* ── CONTACT MODAL (simple) ── */
.wwe-contact-modal .wwe-modal-wrap { max-width: 400px; }
.wwe-contact-modal .wwe-modal-head h3 { font-size: 16px; }

/* ── REVIEW MODAL ── */
.wwe-review-modal .wwe-modal-wrap { max-width: 420px; }

/* Rating Stars */
.rating-stars {
    margin: 10px 0 18px;
    font-size: 18px;
    display: flex;
    flex-direction: row-reverse;
    gap: 5px;
    width: 80px;
    user-select: none;
}
.rating-stars input  { display: none; }
.rating-stars label  { cursor: pointer; color: #ccc; transition: var(--transition-fast); }
.rating-stars label:hover,
.rating-stars label:hover ~ label,
.rating-stars input:checked ~ label { color: var(--primary); }

/* Like/Dislike group */
.like-group { margin-bottom: 18px; }
.like-group > div  { display: flex; align-items: center; margin-bottom: 8px; gap: 8px; }
.like-group > div span { min-width: 75px; font-weight: var(--fw-semi); font-size: 13px; }
.like-group label  { display: flex; align-items: center; cursor: pointer; font-size: 13px; }
.like-group input[type="radio"] { margin-right: 4px; accent-color: var(--primary); }

/* Form steps */
.form-step { display: block; }

/* ── STEP BUTTONS ── */
.wwe-form .btn-cancel-modal {
    background: var(--btn-neutral-bg);
    color: var(--btn-neutral-color);
    border: 1.5px solid var(--btn-neutral-border);
    padding: var(--btn-padding-sm);
    border-radius: var(--btn-radius-sm);
    font-size: var(--btn-font-sm);
    font-weight: var(--btn-fw);
    font-family: var(--font);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    transition: var(--btn-transition);
}
.wwe-form .btn-cancel-modal:hover { background: var(--btn-neutral-bg-hover); }

/* ── RESPONSIVE ── */
@media (max-width: 600px) {
    .wwe-modal-body { flex-direction: column; }
    .wwe-product-info { max-width: 100%; flex-direction: row; text-align: left; gap: 14px; }
    .wwe-product-img-frame { width: 84px; height: 84px; flex-shrink: 0; }
    .wwe-modal { padding: 16px 12px; }
}