/* ══════════════════════════════════════════════
   Orchid Product Widget — Complete Standalone CSS
   All classes prefixed with od-pw-
   ══════════════════════════════════════════════ */

:root {
    --od-pw-ink:      #1a1814;
    --od-pw-ink-mid:  #3d3a35;
    --od-pw-ink-soft: #8c887f;
    --od-pw-cream:    #faf8f4;
    --od-pw-warm:     #f2ede4;
    --od-pw-border:   #e4e0d8;
    --od-pw-orchid:   #6b21a8;
    --od-pw-orchid-m: #9333ea;
    --od-pw-orchid-p: #f3e8ff;
    --od-pw-gold:     #b45309;
    --od-pw-white:    #ffffff;
    --od-pw-green:    #15803d;
    --od-pw-green-p:  #f0fdf4;
    --od-pw-red:      #dc2626;
}

.od-pw-wrap {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    font-size: 14px;
    color: var(--od-pw-ink);
    box-sizing: border-box;
}
.od-pw-wrap *, .od-pw-wrap *::before, .od-pw-wrap *::after { box-sizing: border-box; }

/* ── Layout ── */
.od-pw-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start; }
.od-pw-layout-stacked .od-pw-inner,
.od-pw-layout-form-only .od-pw-inner { grid-template-columns: 1fr; }
.od-pw-layout-form-only .od-pw-gallery { display: none; }

/* ── Placeholder ── */
.od-pw-placeholder { background: var(--od-pw-warm); border: 2px dashed var(--od-pw-border); border-radius: 16px; padding: 48px 24px; text-align: center; color: var(--od-pw-ink-soft); }

/* ── Loading ── */
.od-pw-loading-spinner { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 32px; height: 32px; border: 3px solid var(--od-pw-border); border-top-color: var(--od-pw-orchid); border-radius: 50%; animation: od-pw-spin .7s linear infinite; z-index: 11; }
@keyframes od-pw-spin { to { transform: translate(-50%,-50%) rotate(360deg); } }

/* ── Lightbox ── */
.od-pw-lightbox { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.9); z-index: 99999; align-items: center; justify-content: center; }
.od-pw-lightbox.open { display: flex; }
.od-pw-lightbox img { max-width: 90vw; max-height: 90vh; object-fit: contain; border-radius: 8px; }
.od-pw-lightbox-close { position: absolute; top: 20px; right: 24px; color: #fff; font-size: 32px; cursor: pointer; background: none; border: none; line-height: 1; }

/* ══ GALLERY ══ */
.od-pw-gallery { position: sticky; top: 100px; }
.od-pw-main-image-wrap { border-radius: 20px; overflow: hidden; background: var(--od-pw-warm); aspect-ratio: 1/1; position: relative; border: 1px solid var(--od-pw-border); cursor: zoom-in; margin-bottom: 12px; }
.od-pw-main-image-wrap img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s ease; }
.od-pw-main-image-wrap:hover img { transform: scale(1.04); }
.od-pw-badge-wrap { position: absolute; top: 16px; left: 16px; display: flex; flex-direction: column; gap: 6px; z-index: 2; }
.od-pw-badge { display: inline-block; font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 4px 10px; border-radius: 999px; }
.od-pw-badge-sale { background: var(--od-pw-red); color: #fff; }
.od-pw-badge-instock { background: var(--od-pw-green); color: #fff; }
.od-pw-badge-outstock { background: #6b7280; color: #fff; }
.od-pw-thumb-row { display: flex; gap: 8px; flex-wrap: wrap; }
.od-pw-thumb { width: 72px; height: 72px; border-radius: 10px; overflow: hidden; border: 2px solid var(--od-pw-border); cursor: pointer; transition: border-color .18s; flex-shrink: 0; }
.od-pw-thumb.active { border-color: var(--od-pw-orchid); }
.od-pw-thumb:hover { border-color: var(--od-pw-orchid-m); }
.od-pw-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ══ INFO ══ */
.od-pw-sp-cats { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
.od-pw-sp-cats a { font-size: 11px; font-weight: 700; letter-spacing: .1em; color: var(--od-pw-orchid); text-decoration: none; background: var(--od-pw-orchid-p); padding: 10px 25px; border-radius: 999px; border: 1px solid #ddd6fe; }
.od-pw-sp-cats a:hover { background: var(--od-pw-orchid); color: #fff; }
.od-pw-title { font-size: clamp(20px,2.8vw,30px); font-weight: 700; color: var(--od-pw-ink); line-height: 1.2; margin: 0 0 12px; }
.od-pw-rating-row { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.od-pw-stars { color: #fbbf24; font-size: 14px; letter-spacing: 1px; }
.od-pw-rating-count { font-size: 13px; color: var(--od-pw-ink-soft); }
.od-pw-short-desc { font-size: 14px; color: var(--od-pw-ink-mid); line-height: 1.8; margin-bottom: 24px; padding-left: 14px; border-left: 3px solid var(--od-pw-orchid-m); }

/* ══ PRICE BLOCK ══ */
.od-pw-price-wrap { display: flex; flex-direction: column; gap: 14px; background: #fff; border-radius: 14px; padding: 20px 24px; margin-bottom: 24px; border: 1px solid #e5e5e5; }
.od-pw-price-row { display: flex; align-items: flex-end; gap: 10px; }
.od-pw-sp-price { font-size: 28px; font-weight: 600; color: #1a1a1a; line-height: 1.1; }
.od-pw-regular-price { font-size: 15px; color: #999; text-decoration: line-through; padding-bottom: 2px; }
.od-pw-price-note { font-size: 12px; color: #777; margin-top: 3px; }
.od-pw-variant-price-list { border: 1px solid #e5e5e5; border-radius: 8px; overflow: hidden; width: 100%; }
.od-pw-variant-header { font-size: 11px; font-weight: 600; letter-spacing: .05em; text-transform: uppercase; color: #888; padding: 8px 14px; background: #f7f7f7; border-bottom: 1px solid #e5e5e5; }
.od-pw-variant-row { display: flex; justify-content: space-between; align-items: center; padding: 10px 14px; border-bottom: 1px solid #f0f0f0; transition: background .15s; gap: 12px; }
.od-pw-variant-row:last-child { border-bottom: none; }
.od-pw-variant-row:hover { background: #fafafa; }
.od-pw-variant-name { font-size: 13px; color: #555; }
.od-pw-variant-price { font-size: 14px; font-weight: 600; color: #1a1a1a; }
.od-pw-variant-price del { font-size: 11px; color: #999; font-weight: 400; margin-right: 3px; }
.od-pw-variant-price ins { text-decoration: none; color: var(--od-pw-red); }

/* ══ ENQUIRY WRAP ══ */
.od-pw-enquiry-wrap { background: var(--od-pw-cream); border: 1.5px solid var(--od-pw-border); border-radius: 16px; padding: 24px; margin-bottom: 24px; }
.od-pw-enquiry-header { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 20px; padding-bottom: 18px; border-bottom: 1px solid var(--od-pw-border); }
.od-pw-enquiry-icon { font-size: 28px; flex-shrink: 0; margin-top: 2px; }
.od-pw-enquiry-title { font-size: 15px; font-weight: 700; color: var(--od-pw-ink); margin-bottom: 3px; }
.od-pw-enquiry-sub { font-size: 12.5px; color: var(--od-pw-ink-soft); }

/* ── Form shared ── */
.od-pw-form-row { margin-bottom: 16px; }
.od-pw-form-label { font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--od-pw-ink-soft); margin-bottom: 6px; display: block; }
.od-pw-form-select {
    width: 100%; padding: 11px 16px;
    border: 1.5px solid var(--od-pw-border) !important;
    border-radius: 10px !important;
    font-size: 14px; color: var(--od-pw-ink); background: var(--od-pw-white);
    appearance: none; -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238c887f' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: right 14px center;
    cursor: pointer; font-family: inherit; outline: none;
}
.od-pw-form-select:focus { border-color: var(--od-pw-orchid) !important; }
.od-pw-step-label { font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--od-pw-orchid); background: var(--od-pw-orchid-p); border: 1px solid #ddd6fe; padding: 6px 14px; margin-bottom: 14px; display: inline-block; border-radius: 999px; }
.od-pw-divider { border: none; border-top: 1px dashed var(--od-pw-border); margin: 20px 0; }
.od-pw-form-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.od-pw-form-input,
.od-pw-form-textarea {
    width: 100%;
    padding: 11px 14px !important;
    border: 1.5px solid var(--od-pw-border) !important;
    border-radius: 10px !important;
    font-size: 14px !important;
    color: var(--od-pw-ink);
    background: var(--od-pw-white);
    font-family: inherit;
    outline: none;
    display: block;
    box-shadow: none !important;
    height: auto !important;
    margin: 0 !important;
    line-height: normal !important;
}
.od-pw-form-input:focus,
.od-pw-form-textarea:focus { border-color: var(--od-pw-orchid) !important; box-shadow: 0 0 0 3px rgba(107,33,168,.08) !important; }
.od-pw-form-input.error { border-color: var(--od-pw-red) !important; }
.od-pw-form-textarea { resize: vertical; }
.od-pw-req { color: var(--od-pw-red); }

/* ══ SQFT CALCULATOR ══ */
.od-pw-unit-row { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.od-pw-unit-label { font-size: 12px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--od-pw-ink-soft); flex-shrink: 0; }
.od-pw-unit-toggle { display: flex; background: var(--od-pw-warm); border-radius: 8px; padding: 3px; gap: 3px; }
.od-pw-unit-btn { padding: 6px 16px; border-radius: 6px; border: none; font-size: 13px; font-weight: 600; cursor: pointer; font-family: inherit; color: var(--od-pw-ink-soft); background: none; transition: all .15s; box-shadow: none; }
.od-pw-unit-btn.active { background: #fff; color: var(--od-pw-orchid); box-shadow: 0 1px 4px rgba(0,0,0,.12); }
.od-pw-dim-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 16px; }
.od-pw-calc-label { display: flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--od-pw-ink-soft); margin-bottom: 8px; flex-wrap: wrap; }
.od-pw-calc-range { font-size: 11px; font-weight: 500; color: var(--od-pw-gold); letter-spacing: 0; text-transform: none; }

/* ── Input row (stepper + input + badge) ── */
.od-pw-input-row {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    flex-wrap: nowrap !important;
}
.od-pw-step-btn {
    flex-shrink: 0 !important;
    flex-grow: 0 !important;
    width: 40px !important;
    min-width: 40px !important;
    height: 44px !important;
    background: var(--od-pw-warm) !important;
    border: 1.5px solid var(--od-pw-border) !important;
    border-radius: 8px !important;
    font-size: 20px !important;
    cursor: pointer !important;
    color: var(--od-pw-ink-mid) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    margin: 0 !important;
    line-height: 1 !important;
    box-shadow: none !important;
    transition: background .15s !important;
}
.od-pw-step-btn:hover { background: var(--od-pw-border) !important; }
.od-pw-num-input {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    width: auto !important;
    height: 44px !important;
    text-align: center !important;
    border: 1.5px solid var(--od-pw-border) !important;
    border-radius: 8px !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--od-pw-ink) !important;
    font-family: inherit !important;
    outline: none !important;
    background: #fff !important;
    padding: 0 6px !important;
    margin: 0 !important;
    display: block !important;
    box-shadow: none !important;
    -moz-appearance: textfield !important;
}
.od-pw-num-input::-webkit-outer-spin-button,
.od-pw-num-input::-webkit-inner-spin-button { -webkit-appearance: none !important; }
.od-pw-num-input:focus { border-color: var(--od-pw-orchid) !important; }
.od-pw-num-input.readonly { background: #f9f7f4 !important; cursor: default !important; font-size: 16px !important; }
.od-pw-unit-badge { font-size: 13px; font-weight: 600; color: var(--od-pw-orchid); background: var(--od-pw-orchid-p); padding: 6px 10px; border-radius: 6px; flex-shrink: 0; min-width: 34px; text-align: center; white-space: nowrap; }
.od-pw-conv { font-size: 12px; color: var(--od-pw-ink-soft); margin-top: 5px; padding-left: 4px; }

/* ══ RESULT CARD ══ */
.od-pw-result { background: linear-gradient(135deg,#1a1814 0%,#2a1f0e 100%); border-radius: 14px; padding: 18px 20px; margin: 8px 0 16px; }
.od-pw-result-row { display: flex; justify-content: space-between; align-items: center; font-size: 14px; color: rgba(255,255,255,.7); padding: 6px 0; border-bottom: 1px solid rgba(255,255,255,.08); }
.od-pw-result-row:last-child { border-bottom: none; }
.od-pw-result-row.od-pw-total { font-size: 20px; font-weight: 700; color: #fbbf24; padding-top: 12px; margin-top: 4px; border-top: 1px solid rgba(255,255,255,.15); border-bottom: none; }

/* ── Disclaimer ── */
.od-pw-disclaimer { background: #fffbeb; border: 1px solid #fde68a; border-radius: 10px; padding: 14px 16px; font-size: 12px; color: #92400e; line-height: 1.7; margin-bottom: 4px; }
.od-pw-disclaimer li { margin-bottom: 6px; }

/* ── No price ── */
.od-pw-noprice { background: #f1f5f9; border: 1px solid #cbd5e1; border-radius: 10px; padding: 14px 16px; font-size: 13px; color: #475569; margin-bottom: 16px; }

/* ══ STICKER CALCULATOR ══ */
.od-pw-sheet-badge { display: inline-flex; align-items: center; gap: 6px; background: var(--od-pw-orchid-p); border: 1px solid #ddd6fe; border-radius: 8px; padding: 8px 14px; font-size: 12.5px; font-weight: 600; color: var(--od-pw-orchid); margin-bottom: 18px; }
.od-pw-stk-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 18px; }
.od-pw-stk-pricing-label { font-size: 12px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--od-pw-ink-soft); margin-bottom: 10px; display: block; }
.od-pw-stk-options { display: flex; flex-direction: column; gap: 8px; margin-bottom: 18px; }
.od-pw-stk-option { display: flex; align-items: center; gap: 12px; border: 1.5px solid var(--od-pw-border); border-radius: 10px; padding: 12px 14px; cursor: pointer; transition: border-color .15s,background .15s; background: #fff; }
.od-pw-stk-option:hover { border-color: var(--od-pw-orchid-m); background: var(--od-pw-orchid-p); }
.od-pw-stk-option.is-selected { border-color: var(--od-pw-orchid); background: var(--od-pw-orchid-p); }
.od-pw-stk-option input[type="radio"] { position: absolute; opacity: 0; pointer-events: none; width: 0; height: 0; }
.od-pw-radio-dot { width: 18px; height: 18px; border-radius: 50%; border: 2px solid var(--od-pw-border); flex-shrink: 0; display: flex; align-items: center; justify-content: center; transition: border-color .15s; }
.od-pw-stk-option.is-selected .od-pw-radio-dot { border-color: var(--od-pw-orchid); }
.od-pw-radio-dot::after { content: ''; width: 8px; height: 8px; border-radius: 50%; background: var(--od-pw-orchid); opacity: 0; transition: opacity .15s; }
.od-pw-stk-option.is-selected .od-pw-radio-dot::after { opacity: 1; }
.od-pw-stk-opt-text { flex: 1; font-size: 13.5px; color: var(--od-pw-ink); font-weight: 500; }
.od-pw-stk-opt-price { font-size: 14px; font-weight: 700; color: var(--od-pw-orchid); flex-shrink: 0; }
.od-pw-stk-qty-note { font-size: 11.5px; color: var(--od-pw-ink-soft); margin-top: 6px; line-height: 1.5; }
.od-pw-moq-badge { background: var(--od-pw-green-p); border: 1px solid #86efac; border-radius: 8px; padding: 10px 14px; font-size: 12.5px; color: #14532d; line-height: 1.6; margin-bottom: 16px; }
.od-pw-moq-badge strong { color: #166534; }
.od-pw-gst-note { font-size: 11px; color: rgba(255,255,255,.4); margin-top: 2px; }

/* ══ BUTTONS ══ */
.od-pw-btn-enquiry {
    width: 100%;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px;
    background: var(--od-pw-orchid) !important;
    color: #fff !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    padding: 14px 24px !important;
    border-radius: 10px !important;
    border: none !important;
    cursor: pointer !important;
    font-family: inherit !important;
    transition: background .18s, transform .15s !important;
    margin-top: 4px !important;
    text-decoration: none !important;
    box-shadow: none !important;
}
.od-pw-btn-enquiry:hover { background: #581c87 !important; transform: translateY(-1px); }
.od-pw-btn-enquiry:disabled { background: var(--od-pw-border) !important; color: var(--od-pw-ink-soft) !important; cursor: not-allowed !important; transform: none !important; }
.od-pw-spinner { width: 16px; height: 16px; border: 2px solid rgba(255,255,255,.3); border-top-color: #fff; border-radius: 50%; animation: od-pw-spin .7s linear infinite; display: none; flex-shrink: 0; }
.od-pw-btn-enquiry.loading .od-pw-spinner { display: block; }
.od-pw-btn-enquiry.loading .od-pw-btn-text { opacity: .7; }
.od-pw-wa-btn { display: flex; align-items: center; justify-content: center; gap: 8px; background: #25d366; color: #fff; font-size: 14px; font-weight: 600; padding: 12px 20px; border-radius: 10px; text-decoration: none; margin-top: 10px; transition: background .18s; }
.od-pw-wa-btn:hover { background: #128c7e; color: #fff; }
.od-pw-success { background: var(--od-pw-green-p); border: 1.5px solid #86efac; border-radius: 10px; padding: 14px 18px; font-size: 14px; color: #14532d; margin-top: 14px; line-height: 1.6; }
.od-pw-error { background: #fef2f2; border: 1.5px solid #fca5a5; border-radius: 10px; padding: 14px 18px; font-size: 14px; color: #7f1d1d; margin-top: 14px; }
.od-pw-error a { color: var(--od-pw-orchid); font-weight: 600; }

/* ══ TRUST ══ */
.od-pw-trust-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin-top: 24px; }
.od-pw-trust-item { background: var(--od-pw-warm); border: 1px solid var(--od-pw-border); border-radius: 12px; padding: 12px 10px; text-align: center; }
.od-pw-trust-icon { font-size: 22px; margin-bottom: 4px; }
.od-pw-trust-text { font-size: 11px; font-weight: 600; color: var(--od-pw-ink-mid); line-height: 1.3; }

/* ══ META ══ */
.od-pw-meta { margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--od-pw-border); display: flex; flex-direction: column; gap: 8px; }
.od-pw-meta-row { display: flex; gap: 10px; font-size: 13px; }
.od-pw-meta-label { color: var(--od-pw-ink-soft); font-weight: 500; min-width: 80px; flex-shrink: 0; }
.od-pw-meta-value { color: var(--od-pw-ink-mid); }
.od-pw-meta-value a { color: var(--od-pw-orchid); text-decoration: none; }

/* ══ RESPONSIVE ══ */
@media (max-width: 768px) {
    .od-pw-inner { grid-template-columns: 1fr !important; gap: 32px; }
    .od-pw-gallery { position: static !important; }
    .od-pw-stk-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
    .od-pw-form-2col { grid-template-columns: 1fr !important; }
    .od-pw-stk-grid { grid-template-columns: 1fr !important; }
    .od-pw-dim-grid { grid-template-columns: 1fr !important; }
    .od-pw-enquiry-wrap { padding: 18px 16px; }
}
