/* ============================================================
   DTF Order Form v1.0.7 — Hardened CSS
   All values hardcoded (no CSS variables) to prevent
   conflicts with themes/plugins that reset :root vars.
   High-specificity selectors with !important on display
   properties to prevent hidden/collapsed elements.
   ============================================================ */

/* ── Scoped Reset ── */
#dtf-order-form,
#dtf-order-form * {
    box-sizing: border-box !important;
}

#dtf-order-form {
    max-width: 700px !important;
    margin: 0 auto !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    color: #1f2937 !important;
    font-size: 15px !important;
    line-height: 1.5 !important;
}

/* ── Upload Area ── */
#dtf-order-form .dtf-upload-area {
    display: block !important;
    border: 2px dashed #e5e7eb !important;
    border-radius: 10px !important;
    padding: 36px 24px !important;
    text-align: center !important;
    cursor: pointer !important;
    background: #ffffff !important;
    transition: border-color 0.2s, background 0.2s !important;
    margin-bottom: 0 !important;
}

#dtf-order-form .dtf-upload-area:hover,
#dtf-order-form .dtf-upload-area.dtf-drag-over {
    border-color: #f97316 !important;
    background: #fff7ed !important;
}

#dtf-order-form .dtf-upload-icon {
    color: #9ca3af !important;
    margin-bottom: 12px !important;
}
#dtf-order-form .dtf-upload-icon svg {
    display: inline-block !important;
}

#dtf-order-form .dtf-upload-title {
    font-size: 15px !important;
    margin: 0 0 6px !important;
    color: #1f2937 !important;
}
#dtf-order-form .dtf-upload-formats {
    font-size: 13px !important;
    color: #f97316 !important;
    margin: 0 0 4px !important;
}
#dtf-order-form .dtf-upload-meta {
    font-size: 12px !important;
    color: #6b7280 !important;
    margin: 0 !important;
}

/* ── Upload Preview ── */
#dtf-order-form .dtf-upload-preview {
    display: none;  /* hidden by default — JS adds .dtf-show to reveal */
    align-items: center !important;
    justify-content: space-between !important;
    padding: 12px 16px !important;
    border: 1px solid #22c55e !important;
    border-radius: 10px !important;
    background: #f0fdf4 !important;
    margin-top: 8px !important;
}
#dtf-order-form .dtf-upload-preview.dtf-show {
    display: flex !important;
}

#dtf-order-form .dtf-file-info {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    color: #22c55e !important;
    font-size: 14px !important;
}
#dtf-order-form .dtf-file-name { font-weight: 600 !important; color: #1f2937 !important; }
#dtf-order-form .dtf-file-size { color: #6b7280 !important; font-size: 12px !important; }

#dtf-order-form .dtf-remove-file {
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    color: #6b7280 !important;
    padding: 4px !important;
    border-radius: 4px !important;
    display: flex !important;
    align-items: center !important;
}
#dtf-order-form .dtf-remove-file:hover { color: #ef4444 !important; }

/* ── Upload Progress ── */
#dtf-order-form .dtf-upload-progress {
    display: none; /* shown by JS only */
    padding: 12px 0 !important;
    font-size: 13px !important;
    color: #6b7280 !important;
}
#dtf-order-form .dtf-upload-progress.dtf-show {
    display: block !important;
}
#dtf-order-form .dtf-progress-top {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 8px !important;
}
#dtf-order-form .dtf-cancel-upload-btn {
    background: none !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 6px !important;
    padding: 3px 10px !important;
    font-size: 12px !important;
    cursor: pointer !important;
    color: #6b7280 !important;
    transition: all 0.15s !important;
}
#dtf-order-form .dtf-cancel-upload-btn:hover {
    border-color: #ef4444 !important;
    color: #ef4444 !important;
    background: #fef2f2 !important;
}
#dtf-order-form .dtf-progress-bar {
    height: 6px !important;
    background: #e5e7eb !important;
    border-radius: 4px !important;
    overflow: hidden !important;
}
#dtf-order-form .dtf-progress-fill {
    height: 100% !important;
    background: #f97316 !important;
    width: 0% !important;
    transition: width 0.2s ease !important;
}

/* ── Notes ── */
#dtf-order-form .dtf-section {
    margin-bottom: 24px !important;
}
#dtf-order-form .dtf-label {
    display: block !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    margin-bottom: 8px !important;
    color: #1f2937 !important;
}
#dtf-order-form .dtf-optional {
    font-weight: 400 !important;
    color: #6b7280 !important;
}
#dtf-order-form .dtf-textarea {
    display: block !important;
    width: 100% !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 10px !important;
    padding: 10px 14px !important;
    font-size: 14px !important;
    font-family: inherit !important;
    resize: vertical !important;
    color: #1f2937 !important;
    background: #ffffff !important;
    transition: border-color 0.2s !important;
}
#dtf-order-form .dtf-textarea:focus {
    border-color: #f97316 !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(249,115,22,0.1) !important;
}
#dtf-order-form .dtf-hint {
    font-size: 12px !important;
    color: #6b7280 !important;
    margin: 8px 0 0 !important;
    display: flex !important;
    align-items: flex-start !important;
    gap: 6px !important;
    line-height: 1.5 !important;
}

/* ── Size Row ── */
#dtf-order-form .dtf-size-row {
    display: block !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 10px !important;
    padding: 16px !important;
    background: #ffffff !important;
    position: relative !important;
    margin-bottom: 16px !important;
}

/* ── Toggle Buttons ── */
#dtf-order-form .dtf-size-toggle {
    display: flex !important;
    gap: 2px !important;
    background: #f9fafb !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 8px !important;
    padding: 3px !important;
    width: fit-content !important;
    margin-bottom: 14px !important;
}
#dtf-order-form .dtf-toggle-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 7px 16px !important;
    border: 1px solid transparent !important;
    background: transparent !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: #6b7280 !important;
    transition: all 0.2s !important;
    line-height: 1 !important;
    text-decoration: none !important;
}
#dtf-order-form .dtf-toggle-btn.dtf-toggle-active {
    background: #ffffff !important;
    color: #1f2937 !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1) !important;
    border-color: #e5e7eb !important;
}
#dtf-order-form .dtf-toggle-btn svg {
    display: inline-block !important;
    vertical-align: middle !important;
    flex-shrink: 0 !important;
}

/* ── POPULAR SIZE DROPDOWN — most important fix ── */
#dtf-order-form .dtf-popular-select {
    display: block !important;      /* CRITICAL: prevent theme hiding this */
    visibility: visible !important; /* CRITICAL: prevent theme hiding this */
    opacity: 1 !important;          /* CRITICAL: prevent theme hiding this */
    width: 100% !important;
    height: auto !important;
    min-height: 42px !important;
    padding: 10px 14px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    font-family: inherit !important;
    color: #1f2937 !important;
    background: #ffffff !important;
    background-image: none !important;
    cursor: pointer !important;
    margin-bottom: 14px !important;
    -webkit-appearance: auto !important;
    -moz-appearance: auto !important;
    appearance: auto !important;
    overflow: visible !important;
    position: static !important;
    z-index: auto !important;
    max-height: none !important;
    clip: auto !important;
    clip-path: none !important;
    transform: none !important;
}
#dtf-order-form .dtf-popular-select:focus {
    border-color: #f97316 !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(249,115,22,0.1) !important;
}
#dtf-order-form .dtf-popular-select option {
    display: block !important;
    color: #1f2937 !important;
    background: #ffffff !important;
    padding: 4px 8px !important;
}

/* ── Custom size hint ── */
#dtf-order-form .dtf-custom-size-hint {
    font-size: 12px !important;
    color: #f97316 !important;
    margin: 0 0 12px !important;
}
#dtf-order-form .dtf-custom-size-hint a,
#dtf-order-form .dtf-pop-link {
    color: #f97316 !important;
    text-decoration: underline !important;
    cursor: pointer !important;
}

#dtf-order-form .dtf-no-pops {
    display: block !important;
    color: #e67e22 !important;
    font-size: 13px !important;
    margin: 8px 0 12px !important;
    padding: 10px !important;
    background: #fff8e1 !important;
    border-radius: 6px !important;
    border: 1px solid #ffe082 !important;
}

/* ── Row Fields Grid ── */
#dtf-order-form .dtf-row-fields {
    display: grid !important;
    grid-template-columns: 1fr auto 1fr 100px 1fr !important;
    gap: 12px !important;
    align-items: end !important;
}
/* Popular mode: only Qty + Price */
#dtf-order-form .dtf-row-fields-popular {
    display: grid !important;
    grid-template-columns: 120px 1fr !important;
    gap: 12px !important;
    align-items: end !important;
    margin-top: 4px !important;
}
#dtf-order-form .dtf-field-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
}
#dtf-order-form .dtf-field-group label {
    display: block !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    color: #6b7280 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    margin: 0 0 4px !important;
}

/* ── Number Spinners ── */
#dtf-order-form .dtf-number-input {
    display: flex !important;
    align-items: center !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    height: 42px !important;
    background: #ffffff !important;
}
#dtf-order-form .dtf-number-input .dtf-inp {
    width: 52px !important;
    text-align: center !important;
    border: none !important;
    outline: none !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    padding: 0 !important;
    background: transparent !important;
    color: #1f2937 !important;
    -moz-appearance: textfield !important;
    flex: 1 !important;
}
#dtf-order-form .dtf-number-input .dtf-inp::-webkit-outer-spin-button,
#dtf-order-form .dtf-number-input .dtf-inp::-webkit-inner-spin-button { -webkit-appearance: none !important; }
#dtf-order-form .dtf-number-input .dtf-minus,
#dtf-order-form .dtf-number-input .dtf-plus {
    width: 34px !important;
    min-width: 34px !important;
    height: 42px !important;
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    font-size: 18px !important;
    color: #6b7280 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background 0.15s, color 0.15s !important;
    padding: 0 !important;
    line-height: 1 !important;
}
#dtf-order-form .dtf-number-input .dtf-minus:hover,
#dtf-order-form .dtf-number-input .dtf-plus:hover {
    background: #f9fafb !important;
    color: #f97316 !important;
}

/* ── Link/Unlink button ── */
#dtf-order-form .dtf-link-icon {
    display: flex !important;
    align-items: flex-end !important;
    padding-bottom: 6px !important;
}
#dtf-order-form .dtf-link-btn {
    background: none !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    padding: 5px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: border-color 0.2s, background 0.2s !important;
    width: 32px !important;
    height: 32px !important;
}
#dtf-order-form .dtf-link-btn:hover {
    border-color: #f97316 !important;
    background: #fff7ed !important;
}
#dtf-order-form .dtf-link-btn.dtf-linked {
    border-color: #f97316 !important;
    background: #fff7ed !important;
}
#dtf-order-form .dtf-link-btn.dtf-linked svg {
    stroke: #f97316 !important;
    opacity: 1 !important;
}

/* ── Price display ── */
#dtf-order-form .dtf-price-cell { text-align: right !important; }
#dtf-order-form .dtf-unit-price {
    font-size: 13px !important;
    color: #6b7280 !important;
    margin: 0 0 2px !important;
    display: block !important;
}
#dtf-order-form .dtf-row-total {
    font-size: 17px !important;
    font-weight: 700 !important;
    color: #1f2937 !important;
    margin: 0 !important;
    display: block !important;
}

/* ── Remove row btn ── */
#dtf-order-form .dtf-remove-row-btn {
    position: absolute !important;
    top: 12px !important;
    right: 12px !important;
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    color: #6b7280 !important;
    padding: 4px !important;
    border-radius: 4px !important;
    display: flex !important;
    align-items: center !important;
}
#dtf-order-form .dtf-remove-row-btn:hover { color: #ef4444 !important; }

/* ── Add row / price note ── */
#dtf-order-form .dtf-add-row-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    background: none !important;
    border: none !important;
    color: #f97316 !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    padding: 0 !important;
    margin-bottom: 10px !important;
    text-decoration: none !important;
}
#dtf-order-form .dtf-add-row-btn:hover { text-decoration: underline !important; }
#dtf-order-form .dtf-price-note {
    display: flex !important;
    align-items: flex-start !important;
    gap: 6px !important;
    font-size: 12px !important;
    color: #6b7280 !important;
    margin: 0 !important;
}

/* ── Grand Total ── */
#dtf-order-form .dtf-grand-total {
    display: flex !important;
    justify-content: flex-end !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 12px 16px !important;
    background: #fff7ed !important;
    border-radius: 8px !important;
    margin: 0 0 16px !important;
    border: 1px solid #fed7aa !important;
}
#dtf-order-form .dtf-grand-total-label { font-size: 14px !important; color: #6b7280 !important; }
#dtf-order-form .dtf-grand-total-amount { font-size: 20px !important; font-weight: 800 !important; color: #f97316 !important; }

/* ── Add to Cart Button ── */
#dtf-order-form .dtf-add-to-cart-btn {
    display: flex !important;
    width: 100% !important;
    padding: 16px 24px !important;
    background: #f97316 !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 12px !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    transition: background 0.2s !important;
    text-decoration: none !important;
}
#dtf-order-form .dtf-add-to-cart-btn:hover:not(:disabled) { background: #ea6c0a !important; }
#dtf-order-form .dtf-add-to-cart-btn:disabled { opacity: 0.65 !important; cursor: not-allowed !important; }
#dtf-order-form .dtf-btn-price::before { content: '— ' !important; }
#dtf-order-form .dtf-btn-price { font-weight: 700 !important; }

/* ── Responsive ── */
@media (max-width: 600px) {
    #dtf-order-form .dtf-row-fields {
        grid-template-columns: 1fr 1fr !important;
        grid-template-rows: auto auto auto !important;
    }
    #dtf-order-form .dtf-row-fields-popular {
        grid-template-columns: 1fr 1fr !important;
    }
    #dtf-order-form .dtf-link-icon { display: none !important; }
    #dtf-order-form .dtf-price-cell { grid-column: 1 / -1 !important; text-align: left !important; }
}
