/* ==================================================================
   The Longevity Edge — Express Checkout (PDP 1-Click button + modal)
   ================================================================== */

/* Container — sits below Add to Cart in the WCSO buy box */
.le-express { margin: var(--s-4) 0 0; }

.le-express-divider { display: flex; align-items: center; gap: var(--s-3); margin: var(--s-3) 0; color: var(--ink-500); font-family: var(--font-body); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--ls-widest); font-weight: 700; }
.le-express-divider::before, .le-express-divider::after { content: ""; flex: 1; height: 1px; background: var(--navy-100); }
.le-express-divider span { white-space: nowrap; }

/* The button itself — secondary style, gold accent so it reads as an express path */
.le-express-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; width: 100%; height: 52px; padding: 0 var(--s-4); font-family: var(--font-body); font-size: var(--fs-base); font-weight: 700; color: var(--navy-900); background: var(--surface); border: 1.5px solid var(--gold-600); border-radius: var(--r-md); cursor: pointer; transition: background 180ms var(--ease-out), color 180ms var(--ease-out), box-shadow 180ms var(--ease-out), transform 180ms var(--ease-out); }
.le-express-btn:hover, .le-express-btn:focus-visible { background: var(--gold-50); box-shadow: 0 4px 12px rgba(196, 156, 88, 0.18); outline: none; transform: translateY(-1px); }
.le-express-btn svg { color: var(--gold-600); flex-shrink: 0; }
.le-express-btn-label { letter-spacing: -0.005em; }

.le-express-helper { margin: 8px 0 0; font-size: var(--fs-xs); color: var(--ink-500); line-height: var(--lh-normal); text-align: center; }

/* ============================================================
   Modal
   ============================================================ */
.le-express-modal { position: fixed; inset: 0; z-index: 9999; display: none; align-items: center; justify-content: center; padding: var(--s-4); }
.le-express-modal.is-open { display: flex; animation: leExpressFade 200ms var(--ease-out); }
body.le-express-open { overflow: hidden; }

.le-express-modal-backdrop { position: absolute; inset: 0; background: rgba(14, 26, 43, 0.55); backdrop-filter: blur(2px); }

.le-express-modal-card { position: relative; z-index: 1; background: var(--surface); border-radius: var(--r-lg); box-shadow: 0 24px 48px rgba(14, 26, 43, 0.32); width: 100%; max-width: 480px; padding: var(--s-7); animation: leExpressSlideUp 220ms var(--ease-out); }
.le-express-modal-close { position: absolute; top: var(--s-3); right: var(--s-3); background: transparent; border: 0; color: var(--ink-500); cursor: pointer; padding: 8px; border-radius: var(--r-sm); transition: color 180ms var(--ease-out), background 180ms var(--ease-out); }
.le-express-modal-close:hover, .le-express-modal-close:focus-visible { color: var(--navy-900); background: var(--navy-50); outline: none; }

.le-express-modal-title { font-family: var(--font-display); font-weight: 700; font-size: var(--fs-2xl); color: var(--navy-900); margin: 0 0 var(--s-2); letter-spacing: var(--ls-tight); line-height: var(--lh-tight); }
.le-express-modal-sub { font-size: var(--fs-sm); color: var(--ink-700); margin: 0 0 var(--s-5); line-height: var(--lh-relaxed); }

.le-express-summary { margin: 0 0 var(--s-5); padding: 0; display: flex; flex-direction: column; gap: 0; }
.le-express-summary-row { display: grid; grid-template-columns: 90px 1fr; gap: var(--s-4); padding: var(--s-3) 0; border-bottom: 1px solid var(--navy-100); align-items: baseline; margin: 0; }
.le-express-summary-row:last-child { border-bottom: 0; }
.le-express-summary-row dt { font-size: var(--fs-xs); color: var(--ink-500); font-weight: 700; letter-spacing: var(--ls-wide); text-transform: uppercase; margin: 0; }
.le-express-summary-row dd { margin: 0; font-size: var(--fs-base); color: var(--navy-900); font-weight: 600; }
.le-express-summary-total { font-size: var(--fs-xl) !important; font-weight: 700 !important; color: var(--gold-600) !important; font-feature-settings: "tnum","lnum"; display: flex; flex-direction: column; gap: 2px; }
.le-express-summary-meta { font-size: var(--fs-xs); color: var(--ink-500); font-weight: 500; letter-spacing: 0; text-transform: none; }
.le-express-badge { display: inline-block; margin-left: 6px; padding: 2px 8px; border-radius: var(--r-pill); font-size: 10px; font-weight: 700; letter-spacing: var(--ls-wide); text-transform: uppercase; background: var(--success-50); color: var(--success); vertical-align: middle; }
.le-express-badge--ot { background: var(--navy-50); color: var(--navy-700); }

.le-express-modal-actions { display: flex; gap: var(--s-3); margin: 0 0 var(--s-4); }
.le-express-modal-actions .btn { flex: 1; }
.le-express-modal-actions .le-express-cancel { background: var(--surface); color: var(--navy-900); border: 1.5px solid var(--navy-100); }
.le-express-modal-actions .le-express-cancel:hover { border-color: var(--gold-600); color: var(--gold-600); }
.le-express-confirm { position: relative; }
.le-express-confirm-spinner { display: none; width: 18px; height: 18px; border: 2px solid rgba(255,255,255,0.4); border-top-color: #fff; border-radius: 50%; animation: leExpressSpin 700ms linear infinite; }
.le-express-confirm.is-loading .le-express-confirm-spinner { display: inline-block; }
.le-express-confirm.is-loading { opacity: 0.85; cursor: progress; }

.le-express-modal-fine { font-size: var(--fs-xs); color: var(--ink-500); margin: 0; text-align: center; line-height: var(--lh-relaxed); }

@keyframes leExpressFade { from { opacity: 0; } to { opacity: 1; } }
@keyframes leExpressSlideUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
@keyframes leExpressSpin { to { transform: rotate(360deg); } }

@media (max-width: 560px) {
	.le-express-modal-card { padding: var(--s-5); }
	.le-express-modal-actions { flex-direction: column; }
	.le-express-summary-row { grid-template-columns: 1fr; gap: 4px; }
	.le-express-summary-row dt { font-size: 10px; }
}

/* ============================================================
   Checkout-page-side banner when ?express=1
   ============================================================ */
.le-express-checkout-banner { display: flex; align-items: center; gap: var(--s-3); padding: var(--s-3) var(--s-4); margin: 0 0 var(--s-5); background: var(--gold-50); border: 1px solid var(--gold-100); border-left: 4px solid var(--gold-600); border-radius: var(--r-md); }
.le-express-checkout-banner-icon { color: var(--gold-600); flex-shrink: 0; }
.le-express-checkout-banner-text { font-size: var(--fs-sm); color: var(--navy-900); line-height: var(--lh-normal); }
.le-express-checkout-banner-text strong { display: block; font-weight: 700; margin-bottom: 2px; }
