/* ==========================================================
   WC Product Enquiry Pro — Public Styles
   ========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700&family=DM+Sans:wght@300;400;500;600&display=swap');

:root {
    --wcpe-gold:      #c8a06e;
    --wcpe-gold-dk:   #a8803e;
    --wcpe-dark:      #1a1a1a;
    --wcpe-charcoal:  #2c2c2c;
    --wcpe-medium:    #555;
    --wcpe-light:     #f7f4ef;
    --wcpe-white:     #ffffff;
    --wcpe-border:    #e2ddd6;
    --wcpe-error:     #dc2626;
    --wcpe-success:   #16a34a;
    --wcpe-radius:    10px;
    --wcpe-shadow:    0 25px 60px rgba(0,0,0,.35), 0 8px 20px rgba(0,0,0,.15);
    --wcpe-transition:all 0.25s cubic-bezier(0.4,0,0.2,1);
}

/* ---- Enquiry Trigger Button ---- */
.wcpe-enquiry-wrap {
    margin: 20px 0;
}


/* Placeholder color - light black */
#wcpe-enquiry-form input::placeholder,
#wcpe-enquiry-form textarea::placeholder {
    color: rgba(0, 0, 0, 0.5); /* light black */
}

/*#wcpe-enquiry-form .wcpe-readonly-field {*/
/*    color: rgba(0, 0, 0, 0.5) !important;*/
/*}*/

.wcpe-open-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--wcpe-charcoal);
    color: var(--wcpe-white);
    border: 2px solid transparent;
    padding: 14px 32px;
    font-family: 'DM Sans', sans-serif;
    font-size: 15px;
    font-weight: 500;
    letter-spacing: 0.3px;
    cursor: pointer;
    border-radius: 6px;
    transition: var(--wcpe-transition);
    position: relative;
    overflow: hidden;
    width: 100%;
    justify-content: center;
}

.wcpe-open-btn::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--wcpe-gold);
    transform: translateX(-101%);
    transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
}

.wcpe-open-btn:hover::before { transform: translateX(0); }
.wcpe-open-btn:hover { border-color: var(--wcpe-gold); }
.wcpe-open-btn > * { position: relative; z-index: 1; }
.wcpe-open-btn svg { width: 18px; height: 18px; flex-shrink: 0; }

/* ---- Modal Overlay ---- */
.wcpe-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(15,10,5,.75);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    z-index: 999999;
    display: none; /* Hidden by default */
    align-items: center;
    justify-content: center;
    padding: 16px;
    animation: wcpe-fade-in 0.2s ease;
}

@keyframes wcpe-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* ---- Modal Box ---- */
.wcpe-modal-box {
    background: var(--wcpe-white);
    border-radius: var(--wcpe-radius);
    box-shadow: var(--wcpe-shadow);
    width: 100%;
    max-width: 600px;
    max-height: 90vh;
    overflow-y: auto;
    position: relative;
    animation: wcpe-slide-up 0.3s cubic-bezier(0.34,1.56,0.64,1);
}

@keyframes wcpe-slide-up {
    from { opacity: 0; transform: translateY(30px) scale(0.97); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ---- Modal Header ---- */
.wcpe-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 28px 32px 20px;
    border-bottom: 1px solid var(--wcpe-border);
    background: var(--wcpe-light);
    border-radius: var(--wcpe-radius) var(--wcpe-radius) 0 0;
}

.wcpe-modal-header h2 {
    font-family: 'Playfair Display', serif;
    font-size: 22px;
    font-weight: 700;
    color: var(--wcpe-dark);
    margin: 0 0 4px;
}

.wcpe-modal-subtitle {
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    color: var(--wcpe-gold-dk);
    font-weight: 500;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 5px;
}

.wcpe-modal-subtitle::before {
    content: '🪑';
    font-size: 14px;
}

.wcpe-modal-close-btn {
    background: none;
    border: none;
    font-size: 28px;
    line-height: 1;
    cursor: pointer;
    color: #999;
    padding: 0;
    transition: var(--wcpe-transition);
    margin-top: -4px;
}

.wcpe-modal-close-btn:hover { color: var(--wcpe-dark); transform: rotate(90deg); }

/* ---- Modal Body ---- */
.wcpe-modal-body {
    padding: 28px 32px 32px;
}

/* ---- Form Layout ---- */
.wcpe-form-row { margin-bottom: 18px; }

.wcpe-form-two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

@media (max-width: 520px) {
    .wcpe-form-two-col { grid-template-columns: 1fr; }
    .wcpe-modal-header, .wcpe-modal-body { padding-left: 20px; padding-right: 20px; }
}

.wcpe-field-wrap { display: flex; flex-direction: column; gap: 6px; }

.wcpe-field-wrap label {
    font-family: 'DM Sans', sans-serif;
    font-size: 12.5px;
    font-weight: 600;
    color: var(--wcpe-charcoal);
    text-transform: uppercase;
    letter-spacing: 0.6px;
}

.wcpe-required { color: var(--wcpe-gold); }
.wcpe-optional { color: #aaa; font-weight: 400; text-transform: none; letter-spacing: 0; }

.wcpe-field-wrap input,
.wcpe-field-wrap textarea {
    font-family: 'DM Sans', sans-serif;
    font-size: 14.5px;
    padding: 11px 14px;
    border: 1.5px solid var(--wcpe-border);
    border-radius: 6px;
    background: #fafaf8;
    color: var(--wcpe-dark);
    transition: var(--wcpe-transition);
    outline: none;
    width: 100%;
    box-sizing: border-box;
}

.wcpe-field-wrap input:focus,
.wcpe-field-wrap textarea:focus {
    border-color: var(--wcpe-gold);
    background: var(--wcpe-white);
    box-shadow: 0 0 0 3px rgba(200,160,110,0.15);
}

.wcpe-field-wrap input.wcpe-readonly-field {
    background: #f0ede8;
    color: var(--wcpe-medium) !important;
    cursor: not-allowed;
}

.wcpe-field-wrap textarea { resize: vertical; min-height: 100px; }

.wcpe-field-error {
    font-size: 12px;
    color: var(--wcpe-error);
    min-height: 16px;
    display: block;
}

.wcpe-field-wrap input.wcpe-error { border-color: var(--wcpe-error); }

/* ---- reCAPTCHA Note ---- */
.wcpe-recaptcha-note {
    font-size: 12px;
    color: #888;
    margin-bottom: 16px;
    font-family: 'DM Sans', sans-serif;
}

/* ---- Submit Button ---- */
.wcpe-form-footer { margin-top: 8px; }

.wcpe-submit-btn {
    width: 100%;
    padding: 15px;
    background: var(--wcpe-gold);
    color: var(--wcpe-white);
    border: none;
    border-radius: 6px;
    font-family: 'DM Sans', sans-serif;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 0.3px;
    cursor: pointer;
    transition: var(--wcpe-transition);
    position: relative;
    overflow: hidden;
}

.wcpe-submit-btn:hover:not(:disabled) { background: var(--wcpe-gold-dk); transform: translateY(-1px); box-shadow: 0 6px 20px rgba(200,160,110,0.4); }
.wcpe-submit-btn:disabled { opacity: 0.65; cursor: not-allowed; transform: none; }

/* ---- Form Message ---- */
.wcpe-form-msg {
    margin-top: 14px;
    padding: 12px 16px;
    border-radius: 6px;
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    font-weight: 500;
}

.wcpe-form-msg.wcpe-msg-success { background: #f0fdf4; color: var(--wcpe-success); border: 1px solid #bbf7d0; }
.wcpe-form-msg.wcpe-msg-error   { background: #fef2f2; color: var(--wcpe-error);   border: 1px solid #fecaca; }

/* ---- Success Screen ---- */
.wcpe-success-screen {
    text-align: center;
    padding: 32px 0;
    animation: wcpe-fade-in 0.3s ease;
}

.wcpe-success-icon { font-size: 52px; margin-bottom: 16px; }

.wcpe-success-screen h3 {
    font-family: 'Playfair Display', serif;
    font-size: 24px;
    color: var(--wcpe-dark);
    margin: 0 0 10px;
}

.wcpe-success-screen p {
    font-family: 'DM Sans', sans-serif;
    color: var(--wcpe-medium);
    margin-bottom: 24px;
}

.wcpe-new-enquiry-btn {
    background: transparent;
    border: 2px solid var(--wcpe-gold);
    color: var(--wcpe-gold-dk);
    padding: 10px 24px;
    border-radius: 6px;
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: var(--wcpe-transition);
}
.wcpe-new-enquiry-btn:hover { background: var(--wcpe-gold); color: var(--wcpe-white); }

/* ---- Scrollbar ---- */
.wcpe-modal-box::-webkit-scrollbar { width: 5px; }
.wcpe-modal-box::-webkit-scrollbar-thumb { background: var(--wcpe-border); border-radius: 4px; }
