/* ===================================================================
   KeyCode Calculator — clean light redesign (white, sans-serif)
   All logic-bearing selectors (display toggles, payment hiding,
   wapf hiding, fallback visibility) preserved verbatim.
   =================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* ── Design tokens ── */
:root {
    --kcc-bg:           #ffffff;
    --kcc-bg-raised:    #f6f7f9;
    --kcc-bg-input:     #ffffff;
    --kcc-border:       #e5e7eb;
    --kcc-border-strong:#d0d5dd;
    --kcc-text:         #1f2a37;
    --kcc-text-dim:     #667085;
    --kcc-text-faint:   #98a2b3;
    --kcc-accent:       #2563eb;
    --kcc-accent-2:     #3b82f6;
    --kcc-accent-deep:  #1d4ed8;
    --kcc-glow:         rgba(37,99,235,0.16);
    --kcc-success:      #15803d;
    --kcc-success-bg:   rgba(22,163,74,0.08);
    --kcc-success-bd:   rgba(22,163,74,0.30);
    --kcc-warn:         #b45309;
    --kcc-warn-bg:      rgba(245,158,11,0.10);
    --kcc-warn-bd:      rgba(245,158,11,0.40);
    --kcc-danger:       #dc2626;
    --kcc-radius:       14px;
    --kcc-radius-sm:    10px;
    /* one clean sans for everything — no monospace */
    --kcc-sans:         'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
    --kcc-mono:         var(--kcc-sans);
}

/* ── Clean white card ── */
.kcc-form-wrap {
    position: relative;
    margin: 22px 0 26px;
    padding: 24px 22px 22px;
    font-family: var(--kcc-sans);
    color: var(--kcc-text);
    background: var(--kcc-bg);
    border: 1px solid var(--kcc-border);
    border-radius: var(--kcc-radius);
    box-shadow: 0 1px 3px rgba(16,24,40,0.05), 0 10px 28px -20px rgba(16,24,40,0.18);
    overflow: visible;
}
.kcc-form-wrap::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    border-radius: var(--kcc-radius) var(--kcc-radius) 0 0;
    background: linear-gradient(90deg, var(--kcc-accent), var(--kcc-accent-2));
}

.kcc-form-wrap *, .kcc-form-wrap *::before, .kcc-form-wrap *::after { box-sizing: border-box; }
.kcc-form-wrap, .kcc-form-wrap p, .kcc-form-wrap span,
.kcc-form-wrap label, .kcc-form-wrap button, .kcc-form-wrap small {
    font-family: var(--kcc-sans);
}

/* System-online status line */
#kcc-form-wrap > p:first-child { color: var(--kcc-success) !important; font-weight: 600 !important; }
#kcc-form-wrap > p:first-child span { background: var(--kcc-success) !important; }

/* ── Section spacing ── */
.kcc-section { margin-bottom: 20px; }
.kcc-hidden  { display: none !important; }
.kcc-show    { display: block !important; animation: kcc-in 0.25s ease; }
@keyframes kcc-in { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }

/* ── Section label ── */
.kcc-section-label {
    font-size: 0.74rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--kcc-text-dim); margin-bottom: 11px;
}

/* ── Sequence toggle buttons ── */
.kcc-seq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 8px; }

.kcc-form-wrap .kcc-seq-btn {
    position: relative !important;
    display: flex !important; flex-direction: column !important; align-items: flex-start !important;
    gap: 6px !important;
    padding: 16px 14px !important;
    background: var(--kcc-bg-raised) !important;
    background-color: var(--kcc-bg-raised) !important;
    border: 1px solid var(--kcc-border) !important;
    border-radius: var(--kcc-radius-sm) !important;
    cursor: pointer !important;
    transition: border-color 0.18s, box-shadow 0.18s, background 0.18s !important;
    text-align: left !important; width: 100% !important;
    color: var(--kcc-text) !important;
    box-shadow: none; outline: none !important;
    -webkit-appearance: none !important; appearance: none !important;
    text-transform: none !important; letter-spacing: normal !important; line-height: normal !important;
}
.kcc-form-wrap .kcc-seq-btn:hover {
    border-color: var(--kcc-accent) !important;
    background: #fff !important;
    box-shadow: 0 2px 10px -2px var(--kcc-glow);
    transform: none !important; color: var(--kcc-text) !important;
}
.kcc-form-wrap .kcc-seq-btn.active {
    border-color: var(--kcc-accent) !important;
    background: rgba(37,99,235,0.05) !important;
    box-shadow: 0 0 0 1px var(--kcc-accent), 0 4px 14px -6px var(--kcc-glow);
    color: var(--kcc-text) !important;
}

.kcc-seq-radio {
    width: 18px; height: 18px; border-radius: 50%;
    border: 2px solid var(--kcc-border-strong);
    display: flex; align-items: center; justify-content: center;
    position: absolute; top: 13px; right: 13px;
    transition: border-color 0.18s, background 0.18s;
    background: #fff; flex-shrink: 0;
}
.kcc-seq-btn.active .kcc-seq-radio { border-color: var(--kcc-accent); background: var(--kcc-accent); }
.kcc-seq-radio-dot { width: 7px; height: 7px; border-radius: 50%; background: #fff; opacity: 0; transition: opacity 0.15s; }
.kcc-seq-btn.active .kcc-seq-radio-dot { opacity: 1; }

.kcc-seq-big {
    font-family: var(--kcc-sans);
    font-size: 1.9rem; font-weight: 800;
    color: var(--kcc-text); line-height: 1;
    transition: color 0.18s; display: block;
}
.kcc-seq-btn:hover .kcc-seq-big, .kcc-seq-btn.active .kcc-seq-big { color: var(--kcc-accent); }

.kcc-seq-text {
    font-size: 0.7rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.05em;
    color: var(--kcc-text-dim); line-height: 1.4; transition: color 0.18s;
}
.kcc-seq-btn:hover .kcc-seq-text, .kcc-seq-btn.active .kcc-seq-text { color: var(--kcc-accent); }

/* Subtle pulse on unselected buttons */
@keyframes kcc-heartbeat {
    0%, 100% { border-color: var(--kcc-border); box-shadow: none; }
    50%      { border-color: var(--kcc-accent); box-shadow: 0 0 0 3px var(--kcc-glow); }
}
.kcc-form-wrap .kcc-seq-btn:not(.active) { animation: kcc-heartbeat 1.8s ease-in-out infinite !important; }
.kcc-form-wrap .kcc-seq-btn.active { animation: none !important; }
.kcc-form-wrap:has(.kcc-seq-btn.active) .kcc-seq-btn:not(.active) { animation: none !important; }

/* ── Labels ── */
.kcc-form-wrap .kcc-label {
    display: flex; align-items: baseline; gap: 6px;
    font-size: 0.74rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.06em;
    color: var(--kcc-text-dim); margin-bottom: 9px;
}
.kcc-form-wrap .kcc-label small { font-size: 0.68rem; font-weight: 500; text-transform: none; letter-spacing: 0; color: var(--kcc-text-faint); }
.kcc-req { color: var(--kcc-danger); }

/* ── Inputs ── */
.kcc-input-wrap { position: relative; }
.kcc-form-wrap input.kcc-input {
    width: 100% !important; height: auto !important;
    padding: 12px 48px 12px 14px !important;
    background: var(--kcc-bg-input) !important; background-color: var(--kcc-bg-input) !important;
    border: 1px solid var(--kcc-border-strong) !important;
    border-radius: var(--kcc-radius-sm) !important;
    font-family: var(--kcc-sans) !important;
    font-size: 0.98rem !important; font-weight: 600 !important;
    color: var(--kcc-text) !important;
    outline: none !important;
    transition: border-color 0.2s, box-shadow 0.2s !important;
    box-shadow: none !important;
    -webkit-appearance: none !important; appearance: none !important;
    letter-spacing: 0.02em !important;
}
.kcc-form-wrap input.kcc-input::placeholder { color: var(--kcc-text-faint) !important; font-weight: 400 !important; letter-spacing: 0 !important; }
.kcc-form-wrap input.kcc-input:focus {
    border-color: var(--kcc-accent) !important;
    box-shadow: 0 0 0 3px var(--kcc-glow) !important;
    background: #fff !important;
}

.kcc-counter {
    position: absolute; right: 13px; top: 50%; transform: translateY(-50%);
    font-size: 0.66rem; font-weight: 600; color: var(--kcc-text-faint);
    pointer-events: none; transition: color 0.2s; font-family: var(--kcc-sans);
}

/* ── Data row ── */
.kcc-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 480px) { .kcc-row { grid-template-columns: 1fr; } }

/* ── Status messages ── */
.kcc-status {
    display: none; align-items: flex-start; gap: 9px;
    margin-top: 8px; padding: 11px 14px;
    border-radius: var(--kcc-radius-sm);
    font-size: 0.82rem; font-weight: 500; line-height: 1.5; border: 1px solid;
}
.kcc-status.show { display: flex; animation: kcc-in 0.2s ease; }
.kcc-status svg { width: 15px; height: 15px; flex-shrink: 0; margin-top: 1px; }
.kcc-status--checking { background: rgba(37,99,235,0.06); border-color: rgba(37,99,235,0.30); color: var(--kcc-accent); }
.kcc-status--found    { background: var(--kcc-success-bg); border-color: var(--kcc-success-bd); color: var(--kcc-success); }
.kcc-status--warning  { background: var(--kcc-warn-bg);    border-color: var(--kcc-warn-bd);    color: var(--kcc-warn); }
.kcc-status--checking svg { animation: kcc-spin 1.2s linear infinite; }
@keyframes kcc-spin { to { transform: rotate(360deg); } }

/* ── VIN confirmed box ── */
.kcc-vin-confirmed-box { padding: 13px 16px; background: var(--kcc-success-bg); border: 1px solid var(--kcc-success-bd); border-radius: var(--kcc-radius-sm); margin-bottom: 6px; }
.kcc-vin-confirmed-info { width: 100%; }
.kcc-vin-confirmed-val { font-size: 1.02rem; font-weight: 700; color: var(--kcc-text); letter-spacing: 0.02em; font-family: var(--kcc-sans); word-break: break-all; overflow-wrap: anywhere; display: block; }
.kcc-vin-confirmed-sub { font-size: 0.7rem; font-weight: 500; color: var(--kcc-text-dim); margin-top: 4px; display: block; }
.kcc-vin-confirmed-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 0.66rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--kcc-success); white-space: nowrap; margin-bottom: 5px; font-family: var(--kcc-sans); }
.kcc-vin-confirmed-badge svg { width: 13px; height: 13px; }

.kcc-change-vin {
    background: none; border: none; padding: 0;
    font-family: var(--kcc-sans); font-size: 0.74rem; font-weight: 600;
    color: var(--kcc-accent); text-decoration: underline; cursor: pointer; margin-top: 8px; display: inline-block;
}
.kcc-change-vin:hover { color: var(--kcc-accent-deep); }

/* Inline-style overrides for sub-panels */
#kcc-vin-picker-manual-input, #kcc-vin-fallback {
    background: var(--kcc-bg-input) !important; border: 1px solid var(--kcc-border-strong) !important;
    color: var(--kcc-text) !important; font-family: var(--kcc-sans) !important; border-radius: var(--kcc-radius-sm) !important;
}
#kcc-lookup-notfound p, #kcc-lookup-override p, #kcc-picker-override-wrap p {
    background: var(--kcc-warn-bg) !important; border: 1px solid var(--kcc-warn-bd) !important; color: var(--kcc-warn) !important; border-radius: var(--kcc-radius-sm) !important;
}
#kcc-lookup-notfound label, #kcc-lookup-override label, #kcc-picker-override-wrap label { color: var(--kcc-text-dim) !important; }
#kcc-fallback-cnt, #kcc-override-cnt, #kcc-picker-manual-cnt { color: var(--kcc-text-faint) !important; }
#kcc-picker-cancel-manual, #kcc-cancel-override, #kcc-picker-manual { color: var(--kcc-accent) !important; }
#kcc-vin-picker-list > * { background: var(--kcc-bg-raised) !important; border: 1px solid var(--kcc-border) !important; color: var(--kcc-text) !important; border-radius: var(--kcc-radius-sm) !important; }

/* ── Legacy drag upload zone ── */
.kcc-upload { position: relative; border: 1px dashed var(--kcc-border-strong); border-radius: var(--kcc-radius-sm); background: var(--kcc-bg-raised); min-height: 100px; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: border-color 0.2s, background 0.2s; overflow: hidden; }
.kcc-upload:hover { border-color: var(--kcc-accent); background: rgba(37,99,235,0.04); }
.kcc-upload-idle { display: flex; flex-direction: column; align-items: center; gap: 6px; padding: 20px; text-align: center; pointer-events: none; }
.kcc-upload-idle svg { width: 30px; height: 30px; color: var(--kcc-text-faint); transition: color 0.2s; }
.kcc-upload:hover .kcc-upload-idle svg { color: var(--kcc-accent); }
.kcc-upload-idle span { font-size: 0.85rem; font-weight: 500; color: var(--kcc-text-dim); }
.kcc-upload-idle span strong { color: var(--kcc-text); font-weight: 700; }
.kcc-upload-idle small { font-size: 0.7rem; color: var(--kcc-text-faint); font-weight: 500; text-transform: uppercase; letter-spacing: 0.06em; }
.kcc-upload-preview { position: relative; width: 100%; padding: 10px; display: flex; align-items: center; justify-content: center; }
.kcc-upload-preview img { max-height: 140px; max-width: 100%; border-radius: 6px; border: 1px solid var(--kcc-border); display: block; }
#kcc-remove-img { position: absolute; top: 12px; right: 12px; width: 26px; height: 26px; border-radius: 50%; background: rgba(220,38,38,0.1); border: 1px solid var(--kcc-danger); color: var(--kcc-danger); cursor: pointer; display: flex; align-items: center; justify-content: center; z-index: 3; transition: background 0.15s; }
#kcc-remove-img:hover { background: rgba(220,38,38,0.2); }
#kcc-remove-img svg { width: 13px; height: 13px; }

/* ── Hint text ── */
.kcc-hint { font-size: 0.72rem; font-weight: 500; color: var(--kcc-text-faint); margin-top: 8px; }

/* ── Hide Acowebs fields (FUNCTIONAL, keep) ── */
.wapf-field-wrapper, .wapf-field, .wapf-group, #wapf-form-wrap, .wapf-form-wrap,
[class*="wapf"], .product-addon, .product-addon-container,
#product-addons-total, .woocommerce-product-addons { display: none !important; }

.kcc-counter { cursor: help; }
.kcc-vin-rules { font-size: 0.68rem; font-weight: 500; color: var(--kcc-text-faint); margin: 5px 0 0; line-height: 1.4; }

/* ── VIN validity ── */
.kcc-form-wrap input.kcc-input.vin-valid { border-color: var(--kcc-success) !important; box-shadow: 0 0 0 3px var(--kcc-success-bg) !important; }
.kcc-form-wrap input.kcc-input.vin-invalid { border-color: var(--kcc-danger) !important; box-shadow: 0 0 0 3px rgba(220,38,38,0.10) !important; }

/* ── Simple upload button + menu ── */
.kcc-upload-simple { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; }
.kcc-upload-btn {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 11px 18px; background: rgba(37,99,235,0.06);
    border: 1px solid var(--kcc-accent); border-radius: var(--kcc-radius-sm);
    color: var(--kcc-accent); font-family: var(--kcc-sans);
    font-size: 0.82rem; font-weight: 600; cursor: pointer;
    transition: background 0.15s; white-space: nowrap;
}
.kcc-upload-btn:hover { background: rgba(37,99,235,0.12); }
#kcc-upload-menu { background: #fff !important; border: 1px solid var(--kcc-border-strong) !important; z-index: 60 !important; box-shadow: 0 12px 30px -10px rgba(16,24,40,0.25) !important; }
#kcc-upload-menu label { color: var(--kcc-text) !important; border-color: var(--kcc-border) !important; }
#kcc-upload-menu label:hover { background: var(--kcc-bg-raised) !important; }
#kcc-file-name { color: var(--kcc-text-faint) !important; }
#kcc-upload-progress > div:last-child { background: var(--kcc-bg-raised) !important; }
#kcc-upload-bar { background: var(--kcc-accent) !important; }
#kcc-upload-ok { color: var(--kcc-success) !important; }
#kcc-upload-error { color: var(--kcc-danger) !important; }
#kcc-preview-img { border-color: var(--kcc-border) !important; }

/* ── VIN section toggles (FUNCTIONAL, keep) ── */
#kcc-vin-normal { display: none; }
#kcc-vin-lookup { display: none; }
#kcc-vin-normal.kcc-active { display: block; }
#kcc-vin-lookup.kcc-active { display: block; }

/* ── Submit button ── */
.kcc-submit-btn {
    width: 100%; padding: 16px 24px;
    background: var(--kcc-accent); color: #fff;
    border: 1px solid var(--kcc-accent); border-radius: var(--kcc-radius-sm);
    font-family: var(--kcc-sans); font-size: 0.86rem; font-weight: 700;
    cursor: pointer; letter-spacing: 0.06em; text-transform: uppercase;
    transition: background 0.2s, transform 0.05s;
}
.kcc-submit-btn:hover { background: var(--kcc-accent-deep); }
.kcc-submit-btn:active { transform: translateY(1px); }
.kcc-submit-btn:disabled { background: var(--kcc-border-strong); border-color: var(--kcc-border-strong); color: #fff; cursor: not-allowed; }

#kcc-lookup-notfound .kcc-status { margin-bottom: 14px; }
#kcc-lookup-notfound .kcc-input-wrap,
#kcc-lookup-notfound input.kcc-input { display: block !important; visibility: visible !important; opacity: 1 !important; height: auto !important; overflow: visible !important; }

/* Hide Google Pay / Buy now for 2+ flow (FUNCTIONAL, keep) */
.kcc-hide-payment .wc-block-components-product-button,
.kcc-hide-payment .wp-block-woocommerce-product-button,
.kcc-hide-payment #payment_request_button_separator,
.kcc-hide-payment .woocommerce-PaymentRequestButton,
.kcc-hide-payment #wc-stripe-payment-request-button-separator,
.kcc-hide-payment [id*="payment-request"],
.kcc-hide-payment .buynow,
.kcc-hide-payment a.buy-now,
.kcc-hide-payment .wc-ppec-mini-cart,
.kcc-hide-payment .ppcp-button-apm,
.kcc-hide-payment .ppc-button-wrapper { display: none !important; }

.kcc-seq-additional-active .wcpay-express-checkout-wrapper,
.kcc-seq-additional-active .ts-buy-now-button,
.kcc-seq-additional-active .single-product-buttons,
.kcc-seq-additional-active a.ts-buy-now-button { display: none !important; }

/* Fallback VIN input always renders (FUNCTIONAL, keep) */
#kcc-vin-fallback-wrap { display: block !important; margin-top: 4px; }
#kcc-vin-fallback { display: block !important; width: 100% !important; }
#kcc-vin-fallback-wrap, #kcc-vin-fallback-wrap * { height: auto !important; min-height: 0 !important; max-height: none !important; overflow: visible !important; clip: auto !important; clip-path: none !important; }
#kcc-vin-fallback {
    display: block !important; height: 48px !important; width: 100% !important;
    padding: 12px 48px 12px 14px !important;
    background: var(--kcc-bg-input) !important; border: 1px solid var(--kcc-border-strong) !important;
    border-radius: var(--kcc-radius-sm) !important; font-size: 0.98rem !important; font-family: var(--kcc-sans) !important;
    color: var(--kcc-text) !important; visibility: visible !important; opacity: 1 !important;
    position: relative !important; z-index: 10 !important;
}

/* ── VIN Decode Card ── */
.kcc-vin-decode { margin-top: 8px; border-radius: var(--kcc-radius-sm); overflow: hidden; font-size: 0.82rem; }
.kcc-vin-decode-inner { display: flex; align-items: center; gap: 10px; padding: 11px 13px; background: rgba(37,99,235,0.05); border: 1px solid rgba(37,99,235,0.22); border-radius: var(--kcc-radius-sm); }
.kcc-vin-decode-inner.kcc-decode-error { background: var(--kcc-warn-bg); border-color: var(--kcc-warn-bd); color: var(--kcc-warn); }
.kcc-vin-decode-inner.kcc-decode-loading { background: var(--kcc-bg-raised); border-color: var(--kcc-border); color: var(--kcc-text-dim); }
.kcc-decode-icon { font-size: 1.3rem; flex-shrink: 0; line-height: 1; }
.kcc-decode-info { flex: 1; }
.kcc-decode-vehicle { font-weight: 700; color: var(--kcc-accent); font-size: 0.9rem; letter-spacing: 0.01em; }
.kcc-decode-inner.kcc-decode-error .kcc-decode-vehicle { color: var(--kcc-warn); }
.kcc-decode-meta { color: var(--kcc-text-dim); font-size: 0.78rem; margin-top: 1px; }
.kcc-decode-spinner { width: 16px; height: 16px; border: 2px solid var(--kcc-border-strong); border-top-color: var(--kcc-accent); border-radius: 50%; animation: kcc-spin 0.7s linear infinite; flex-shrink: 0; }

/* ── Login prompt (guest) ── */
.kcc-login-prompt { padding: 0; background: none; border: none; margin-bottom: 16px; font-size: 0.97rem; color: inherit; line-height: 1.6; }
.kcc-login-prompt strong { font-size: 1.05rem; display: block; margin-bottom: 2px; }
.kcc-login-link {
    display: inline-block; margin-top: 8px; padding: 14px 32px;
    background: var(--kcc-accent); color: #fff !important;
    font-weight: 700; border-radius: var(--kcc-radius-sm); text-decoration: none !important;
    font-size: 0.86rem; letter-spacing: 0.06em; text-transform: uppercase;
    border: 1px solid var(--kcc-accent); cursor: pointer; font-family: var(--kcc-sans);
    transition: background 0.2s;
}
.kcc-login-link:hover { background: var(--kcc-accent-deep) !important; }

/* Login modal accents → blue */
.kcc-modal-box .woocommerce-form-login .woocommerce-button { background: var(--kcc-accent) !important; border-color: var(--kcc-accent) !important; color: #fff !important; }
.kcc-modal-box .woocommerce-form-login .woocommerce-button:hover { background: var(--kcc-accent-deep) !important; border-color: var(--kcc-accent-deep) !important; color: #fff !important; }
.kcc-modal-register { border-color: var(--kcc-accent) !important; color: var(--kcc-accent) !important; }
.kcc-modal-register:hover { background: var(--kcc-accent) !important; color: #fff !important; }

/* ── Order status summary (2+ flow) ── */
.kcc-order-summary { border: 1px solid var(--kcc-border); border-radius: var(--kcc-radius-sm); overflow: hidden; margin-bottom: 14px; font-size: 0.92rem; background: #fff; }
.kcc-order-summary-header { background: var(--kcc-accent); color: #fff; padding: 9px 14px; font-weight: 700; font-size: 0.78rem; letter-spacing: 0.06em; text-transform: uppercase; }
.kcc-order-summary-row { display: flex; align-items: center; padding: 11px 14px; border-bottom: 1px solid var(--kcc-border); gap: 10px; }
.kcc-order-summary-row:last-child { border-bottom: none; }
.kcc-order-summary-label { color: var(--kcc-text-dim); font-weight: 700; font-size: 0.74rem; width: 55px; flex-shrink: 0; text-transform: uppercase; letter-spacing: 0.05em; }
.kcc-order-summary-val { font-weight: 700; font-size: 0.95rem; letter-spacing: 0.02em; font-family: var(--kcc-sans); word-break: break-all; color: var(--kcc-text); }
.kcc-order-status { font-weight: 700; font-size: 0.78rem; padding: 4px 12px; border-radius: 99px; display: inline-block; }
.kcc-status-confirmed { background: var(--kcc-success-bg); color: var(--kcc-success); border: 1px solid var(--kcc-success-bd); }
.kcc-status-warning   { background: var(--kcc-warn-bg);    color: var(--kcc-warn);    border: 1px solid var(--kcc-warn-bd); }
.kcc-status-manual    { background: rgba(59,130,246,0.10); color: var(--kcc-accent); border: 1px solid rgba(59,130,246,0.40); }

/* ── Hide add to cart until sequence chosen (FUNCTIONAL, keep) ── */
.kcc-awaiting-seq .single_add_to_cart_button,
.kcc-awaiting-seq .quantity,
.kcc-awaiting-seq .wcpay-express-checkout-wrapper,
.kcc-awaiting-seq .ts-buy-now-button,
.kcc-awaiting-seq a.ts-buy-now-button,
.kcc-awaiting-seq .wp-block-woocommerce-product-button,
.kcc-awaiting-seq .wc-block-components-checkout-place-order-button { display: none !important; }

/* ── Loop/archive button replacement ── */
.kcc-loop-btn {
    background: var(--kcc-accent) !important; color: #fff !important;
    border: 1px solid var(--kcc-accent) !important; border-radius: var(--kcc-radius-sm) !important;
    font-weight: 700 !important; padding: 10px 24px !important; text-decoration: none !important;
    display: inline-block !important; transition: background 0.2s !important;
}
.kcc-loop-btn:hover { background: var(--kcc-accent-deep) !important; }

/* ── Hide express checkout on product page only (FUNCTIONAL, keep) ── */
.single-product .wcpay-express-checkout-wrapper,
.single-product .ts-buy-now-button,
.single-product a.ts-buy-now-button,
.single-product .woocommerce-PaymentRequestButton,
.single-product #wc-stripe-payment-request-button-separator,
.single-product [id*="payment-request-button"],
.single-product .ppcp-button-apm,
.single-product .ppc-button-wrapper { display: none !important; }

#kcc-additional-result { color: var(--kcc-text); }

/* ── Auto-detect status block (replaces 1 / 2+ boxes) ── */
.kcc-autodetect {
    display: block;
    padding: 13px 15px;
    border-radius: var(--kcc-radius-sm);
    border: 1px solid var(--kcc-border);
    background: var(--kcc-bg-raised);
    font-size: 0.9rem;
}
.kcc-autodetect-main { display: flex; align-items: flex-start; gap: 9px; color: var(--kcc-text); line-height: 1.45; }
.kcc-autodetect-icon { flex-shrink: 0; font-weight: 700; font-size: 0.95rem; line-height: 1.4; }
.kcc-autodetect-first { border-color: rgba(37,99,235,0.30); background: rgba(37,99,235,0.05); }
.kcc-autodetect-first .kcc-autodetect-icon { color: var(--kcc-accent); }
.kcc-autodetect-additional { border-color: var(--kcc-success-bd); background: var(--kcc-success-bg); }
.kcc-autodetect-additional .kcc-autodetect-icon { color: var(--kcc-success); }
.kcc-autodetect-checking { display: flex; align-items: center; gap: 10px; color: var(--kcc-text-dim); }
.kcc-autodetect-spinner {
    width: 16px; height: 16px;
    border: 2px solid var(--kcc-border-strong);
    border-top-color: var(--kcc-accent);
    border-radius: 50%;
    animation: kcc-spin 0.7s linear infinite;
    flex-shrink: 0;
}
.kcc-autodetect-switch {
    display: inline-block; margin-top: 10px; padding: 0;
    background: none; border: none; cursor: pointer;
    font-family: var(--kcc-sans); font-size: 0.78rem; font-weight: 600;
    color: var(--kcc-accent); text-decoration: underline; text-align: left; line-height: 1.4;
}
.kcc-autodetect-switch:hover { color: var(--kcc-accent-deep); }

/* ── Product gallery: always visible, no zoom trigger (image was hidden until WC gallery JS ran) ── */
.woocommerce-product-gallery { opacity: 1 !important; }
.woocommerce-product-gallery__trigger { display: none !important; }
.woocommerce-product-gallery__image a { pointer-events: none; cursor: default; }

/* ── Product reviews / comment form (match the clean look) ── */
#reviews #respond textarea,
#reviews #respond input[type="text"],
#reviews #respond input[type="email"],
#reviews #respond input[type="url"],
#reviews #respond select {
    width: 100%;
    max-width: 100%;
    padding: 11px 14px;
    border: 1px solid var(--kcc-border-strong);
    border-radius: var(--kcc-radius-sm);
    font-family: var(--kcc-sans);
    font-size: 0.95rem;
    color: var(--kcc-text);
    background: #fff;
    box-sizing: border-box;
    line-height: 1.5;
}
#reviews #respond select { width: auto; min-width: 150px; padding-right: 30px; }
#reviews #respond textarea { min-height: 130px; resize: vertical; }
#reviews #respond textarea:focus,
#reviews #respond input:focus,
#reviews #respond select:focus {
    border-color: var(--kcc-accent);
    outline: none;
    box-shadow: 0 0 0 3px var(--kcc-glow);
}
#reviews label { font-weight: 600; color: var(--kcc-text-dim); font-size: 0.9rem; }
#reviews .comment-form-rating,
#reviews .comment-form-author,
#reviews .comment-form-email,
#reviews .comment-form-comment { margin: 0 0 16px; }
#reviews .comment-form-rating label { display: inline-block; margin-right: 10px; }
#reviews #respond .form-submit input,
#reviews #respond input#submit {
    background: var(--kcc-accent);
    color: #fff;
    border: 1px solid var(--kcc-accent);
    border-radius: var(--kcc-radius-sm);
    font-family: var(--kcc-sans);
    font-weight: 700;
    padding: 12px 26px;
    font-size: 0.9rem;
    cursor: pointer;
    transition: background 0.2s;
}
#reviews #respond .form-submit input:hover,
#reviews #respond input#submit:hover { background: var(--kcc-accent-deep); }
#reviews #comments .woocommerce-Reviews-title,
#reviews #reply-title { font-weight: 800; color: var(--kcc-text); }

/* ── Registration form notices + tweaks ── */
.kcc-register-wrap textarea.kcc-input { padding-right: 14px !important; min-height: 84px; resize: vertical; }
.kcc-register-wrap select.kcc-input { padding-right: 30px !important; }
.kcc-register-wrap input[type="file"] {
    font-family: var(--kcc-sans); font-size: 0.9rem; color: var(--kcc-text);
    padding: 10px; border: 1px dashed var(--kcc-border-strong); border-radius: var(--kcc-radius-sm);
    width: 100%; background: var(--kcc-bg-input);
}
.kcc-reg-notice { padding: 13px 16px; border-radius: var(--kcc-radius-sm); margin-bottom: 18px; font-size: 0.92rem; }
.kcc-reg-ok { background: var(--kcc-success-bg); border: 1px solid var(--kcc-success-bd); color: var(--kcc-success); }
.kcc-reg-err { background: rgba(220,38,38,0.07); border: 1px solid rgba(220,38,38,0.35); color: #b42318; }
.kcc-reg-err ul { margin: 8px 0 0; padding-left: 18px; }
.kcc-reg-err li { margin: 2px 0; }
