/**
 * OTOEKO — Sipariş Sorgulama v8 — "Lumina" Premium Design
 * Light, airy, modern — completely redesigned
 */

/* ═══════════════════════════════
   PAGE
   ═══════════════════════════════ */
body:has(.oi-page) { display: flex; flex-direction: column; min-height: 100vh; }
.site-main:has(.oi-page) { flex: 1; min-height: 0 !important; }
.oi-page {
    padding: var(--page-gap-top) 0 var(--page-gap-bottom);
    background: #fff;
}

/* ═══════════════════════════════
   HERO WRAPPER
   ═══════════════════════════════ */
.oi-hero {
    margin-bottom: 0;
}

/* ── HERO INTRO: Centered vertical ── */
.oi-hero-intro {
    text-align: center;
    max-width: 640px;
    margin: 0 auto 28px;
}

/* Icon */
.oi-hero-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100px; height: 100px;
    border-radius: 28px;
    background: linear-gradient(145deg, #fff7ed, #ffedd5);
    color: var(--color-primary);
    margin-bottom: 20px;
    border: 1px solid #fed7aa;
}
.oi-hero-icon [data-lucide] {
    width: 52px !important; height: 52px !important; stroke-width: 1.6;
}

/* Title */
.oi-hero h1 {
    font-size: 32px;
    font-weight: 800;
    color: #1a1a2e;
    margin: 0 0 10px;
    letter-spacing: -.5px;
    line-height: 1.15;
    font-family: 'Montserrat', sans-serif;
}

.oi-hero-sub {
    font-size: 15px;
    color: #64748b;
    margin: 0;
    line-height: 1.6;
    font-family: 'Montserrat', sans-serif;
    font-weight: 500;
}

/* Admin pill — hidden */
.oi-admin-pill { display: none; }

.oi-auth-notice {
    display: flex; align-items: center; gap: 12px;
    justify-content: center;
    margin-top: 14px;
    font-size: 14px; color: #64748b;
    flex-wrap: wrap;
}
.oi-auth-notice a {
    color: var(--color-primary); font-weight: 700; text-decoration: none;
    padding: 8px 20px; border-radius: 100px;
    border: 1.5px solid #fed7aa; background: #fff7ed;
    transition: background var(--transition-base); font-size: 13px;
}
.oi-auth-notice a:hover {
    background: #ffedd5; border-color: #fdba74;
}

/* ── SEARCH CARD ── */
.oi-search-card {
    max-width: 580px;
    margin: 0 auto;
    background: #ffffff;
    border-radius: 20px;
    padding: 28px 32px;
    box-shadow: var(--shadow-sm);
    border: 1px solid #eef0f4;
    position: relative;
    overflow: hidden;
}

/* Top accent line */
.oi-search-card::before {
    content: '';
    position: absolute; top: 0; left: 0; right: 0;
    height: 3px;
    background: var(--color-primary);
}

.oi-search-label {
    font-size: 12px; font-weight: 700;
    color: #64748b; letter-spacing: .5px;
    text-transform: uppercase;
    margin-bottom: 14px;
    text-align: center;
    font-family: 'Montserrat', sans-serif;
}

.oi-search { max-width: 100%; margin: 0; }
.oi-search-form { margin: 0; }

.oi-search-field {
    display: flex; align-items: center;
    background: #f8f9fb;
    border: 1.5px solid #e2e5ea;
    border-radius: 14px;
    padding: 6px 6px 6px 18px;
    gap: 10px;
    margin-bottom: 12px;
    transition: border-color var(--transition-base);
}
.oi-search-field:focus-within {
    border-color: var(--color-primary);
    background: #fff;
}

.oi-search-ico {
    width: 20px; height: 20px; color: #c8c8d4; flex-shrink: 0;
    transition: all var(--transition-slow);
}
.oi-search-field:focus-within .oi-search-ico { color: var(--color-primary); }

.oi-search-field input {
    flex: 1; border: none; outline: none;
    font-size: 15px; font-family: 'Montserrat', sans-serif; font-weight: 500;
    color: #1e293b; background: transparent; padding: 12px 0; min-width: 0;
}
.oi-search-field input::placeholder { color: #94a3b8; font-weight: 400; }

/* Type tag */
.oi-input-tag {
    display: none; align-items: center; gap: 4px;
    padding: 4px 11px; border-radius: 10px;
    font-size: 10px; font-weight: 800;
    white-space: nowrap; flex-shrink: 0;
    animation: tagPop .25s cubic-bezier(.4,0,.2,1);
    text-transform: uppercase; letter-spacing: .6px;
}
.oi-input-tag.show { display: inline-flex; }
.oi-input-tag--email { background: #eff6ff; color: #2563eb; }
.oi-input-tag--order { background: #ecfdf5; color: #059669; }
.oi-input-tag--phone { background: #fff7ed; color: var(--color-primary-hover); }
@keyframes tagPop {
    from { opacity: 0; transform: scale(.85) translateX(6px); }
    to { opacity: 1; transform: scale(1) translateX(0); }
}

/* CTA Button */
.oi-search-btn {
    display: flex; align-items: center; justify-content: center; gap: 10px;
    width: 100%; padding: 15px 24px;
    background: var(--color-primary);
    color: #fff;
    border: none; border-radius: 12px;
    font-size: 15px; font-weight: 700;
    font-family: 'Montserrat', sans-serif;
    cursor: pointer;
    transition: background var(--transition-base);
}
.oi-search-btn [data-lucide] { width: 18px; height: 18px; }
.oi-search-btn:hover { background: var(--color-primary-hover); }
.oi-search-btn:disabled { opacity: .4; cursor: not-allowed; }

/* Phone extra */
.oi-phone-extra { margin: 10px 0; animation: slideIn .3s ease; }
.oi-phone-extra-field {
    display: flex; align-items: center;
    background: #f8f9fb; border: 2px solid #eeeff3;
    border-radius: 14px; padding: 6px 16px; transition: all var(--transition-slow);
}
.oi-phone-extra-field:focus-within { border-color: var(--color-primary); background: #fff; }
.oi-phone-extra-field input {
    flex: 1; border: none; outline: none;
    font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: 500;
    color: #1a1a2e; background: transparent; padding: 11px 0 11px 10px;
}
.oi-phone-extra-field input::placeholder { color: #c0c0cc; }

@keyframes slideIn {
    from { opacity: 0; transform: translateY(-8px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Search hints */
.oi-hints {
    display: flex; align-items: center; gap: 16px;
    justify-content: center;
    margin-top: 14px;
    font-size: 13px; color: #64748b; font-weight: 600;
    text-transform: uppercase; letter-spacing: .3px;
}
.oi-hints span { display: inline-flex; align-items: center; gap: 6px; }
.oi-hints [data-lucide] { width: 14px; height: 14px; }
.oi-hints-sep { opacity: .4; font-size: 8px; }

/* ═══════════════════════════════
   JOURNEY SECTION (Process Steps)
   ═══════════════════════════════ */
.oi-journey {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    max-width: 100%;
    margin: 28px 0 0;
    position: relative;
    background: #fafbfc;
    border-radius: 18px;
    overflow: hidden;
    border: 1px solid #f0f0f5;
}

.oi-journey-step {
    padding: 24px 22px;
    display: flex; align-items: flex-start; gap: 14px;
    position: relative;
}
.oi-journey-step:not(:last-child)::after {
    content: '';
    position: absolute; right: 0; top: 20%; bottom: 20%;
    width: 1px;
    background: #eef0f4;
}

.oi-journey-num {
    width: 34px; height: 34px;
    border-radius: 10px;
    background: #fff7ed;
    color: var(--color-primary);
    display: flex; align-items: center; justify-content: center;
    font-size: 14px; font-weight: 800;
    font-family: 'Montserrat', sans-serif;
    flex-shrink: 0;
    border: 1px solid #fed7aa;
}

.oi-journey-text h3 {
    font-size: 14px; font-weight: 700;
    color: #1e293b; margin: 0 0 3px;
    font-family: 'Montserrat', sans-serif;
    text-transform: uppercase;
}
.oi-journey-text p {
    font-size: 13px; color: #64748b;
    line-height: 1.5; margin: 0;
    font-family: 'Montserrat', sans-serif;
}


/* ═══════════════════════════════
   STEPS
   ═══════════════════════════════ */
.oi-step { display: none; }
.oi-step.active { display: block; animation: fadeUp .4s cubic-bezier(.4,0,.2,1); }
@keyframes fadeUp {
    from { opacity: 0; transform: translateY(18px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ═══════════════════════════════
   ALERT
   ═══════════════════════════════ */
.oi-alert-area:empty { display: none; }
.oi-alert-area {
    max-width: 580px;
    margin: 12px auto 0;
}
.oi-alert {
    padding: 14px 22px; border-radius: 14px;
    font-size: 14px; font-weight: 600;
    margin: 0;
    display: flex; align-items: center; gap: 10px;
    animation: fadeUp .3s ease;
    font-family: 'Montserrat', sans-serif;
    box-shadow: var(--shadow-sm);
}
.oi-alert--error   { background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; }
.oi-alert--success { background: #f0fdf4; color: #16a34a; border: 1px solid #bbf7d0; }
.oi-alert--info    { background: #fffbeb; color: #d97706; border: 1px solid #fde68a; }

/* ═══════════════════════════════
   CARDS — OTP / VERIFY
   ═══════════════════════════════ */
.oi-card {
    background: #ffffff;
    border-radius: 20px;
    padding: 40px 36px;
    border: 1px solid #eef0f4;
    box-shadow: var(--shadow-sm);
}
.oi-card--center {
    max-width: 480px;
    margin: 0 auto;
    text-align: center;
}

.oi-card-badge {
    display: inline-flex; align-items: center; justify-content: center;
    width: 100px; height: 100px;
    border-radius: 28px;
    background: linear-gradient(145deg, #fff7ed, #ffedd5);
    color: var(--color-primary);
    margin-bottom: 20px;
    border: 1px solid #fed7aa;
}
.oi-card-badge [data-lucide] { width: 52px !important; height: 52px !important; stroke-width: 1.6; }

.oi-card h2 {
    font-size: 26px; font-weight: 900;
    color: #1a1a2e; margin: 0 0 10px;
    letter-spacing: -.6px;
    font-family: 'Montserrat', sans-serif;
}
.oi-card-desc {
    font-size: 14px; color: #64748b;
    margin: 0 0 32px; line-height: 1.7;
    font-family: 'Montserrat', sans-serif;
}
.oi-card-desc strong { color: #1a1a2e; font-weight: 700; }

/* OTP Inputs */
.oi-otp-wrap {
    display: flex; gap: 10px; justify-content: center;
    margin: 32px 0 20px;
}
.oi-otp-digit {
    width: 56px; height: 66px;
    text-align: center;
    font-size: 26px; font-weight: 900;
    font-family: 'Montserrat', monospace;
    border: 2px solid #e5e7eb;
    border-radius: 16px; outline: none;
    color: #1a1a2e; background: #f9fafb;
    transition: all var(--transition-base);
    caret-color: var(--color-primary);
}
.oi-otp-digit:nth-child(3) { margin-right: 14px; }
.oi-otp-digit:focus {
    border-color: var(--color-primary); background: #fff;
}
.oi-otp-digit.error {
    border-color: #ef4444; background: #fef2f2;
    animation: otpShake .45s ease;
}
@keyframes otpShake {
    0%,100% { transform: translateX(0); }
    20%,60% { transform: translateX(-5px); }
    40%,80% { transform: translateX(5px); }
}

.oi-timer {
    font-size: 20px; font-weight: 800; color: var(--color-primary);
    font-family: 'Montserrat', monospace;
    margin-bottom: 24px; letter-spacing: 4px;
}
.oi-timer.expired { color: #c0c0cc; font-size: 15px; letter-spacing: 0; }

.oi-btn-main {
    display: inline-flex; align-items: center; justify-content: center;
    gap: 8px; width: 100%; padding: 16px 28px;
    background: linear-gradient(135deg, #1a1a2e 0%, #2d2d44 100%);
    color: #fff;
    border: none; border-radius: 16px;
    font-size: 15px; font-weight: 800;
    font-family: 'Montserrat', sans-serif;
    cursor: pointer; letter-spacing: .3px; transition: all var(--transition-base);
    box-shadow: 0 4px 16px rgba(26,26,46,.15);
}
.oi-btn-main:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 28px rgba(26,26,46,.2);
}
.oi-btn-main:disabled { opacity: .35; cursor: not-allowed; transform: none; box-shadow: none; }

.oi-card-links {
    display: flex; align-items: center; justify-content: center;
    gap: 12px; margin-top: 14px;
}
.oi-card-links-sep { display: none; }
.oi-text-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    padding: 10px 24px; border-radius: 100px;
    font-size: 13px; font-weight: 700;
    font-family: 'Montserrat', sans-serif;
    cursor: pointer; transition: all var(--transition-base);
    border: 1.5px solid #fca5a5; background: #fef2f2; color: #dc2626;
}
.oi-text-btn:hover { background: #fecaca; border-color: #ef4444; color: #b91c1c; }
.oi-text-btn:disabled { opacity: .4; cursor: not-allowed; background: #f8f9fa; border-color: #e5e7eb; color: #b0b0b8; }
#oi-resend-btn { border-color: #86efac; background: #f0fdf4; color: #16a34a; }
#oi-resend-btn:hover { background: #bbf7d0; border-color: #22c55e; color: #15803d; }
#oi-resend-btn:disabled { opacity: .4; background: #f8f9fa; border-color: #e5e7eb; color: #b0b0b8; }

.oi-block-banner {
    margin-top: 20px; padding: 14px 20px;
    background: #fef2f2; color: #dc2626;
    border-radius: 14px; font-size: 14px; font-weight: 700;
    border: 1px solid #fecaca;
    font-family: 'Montserrat', sans-serif;
}

/* Verify options */
.oi-verify-opt { display: flex; flex-direction: column; gap: 10px; margin-top: 24px; text-align: center; }
.oi-verify-opt button {
    display: flex; align-items: center; justify-content: center; gap: 16px;
    width: 100%; padding: 18px 22px;
    border: 2px solid #eeeff3; border-radius: 16px;
    background: #f9fafb;
    font-size: 14px; font-weight: 700;
    font-family: 'Montserrat', sans-serif; color: #3a3a4e;
    cursor: pointer; transition: all var(--transition-base);
}
.oi-verify-opt button i { color: #c0c0cc; transition: color var(--transition-base); }
.oi-verify-opt button:hover {
    border-color: var(--color-primary); background: #fff7ed; color: #1a1a2e;
    transform: translateX(4px);
    box-shadow: 0 4px 16px rgba(249,115,22,.06);
}
.oi-verify-opt button:hover i { color: var(--color-primary); }

/* ═══════════════════════════════
   BACK PILL
   ═══════════════════════════════ */
.oi-back-pill {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 22px; background: #fff7ed;
    border: 1.5px solid #fdba74; border-radius: 100px;
    font-size: 13px; font-weight: 700;
    font-family: 'Montserrat', sans-serif; color: var(--color-primary-hover);
    cursor: pointer; transition: all var(--transition-base);
    box-shadow: 0 1px 4px rgba(249,115,22,.1);
}
.oi-back-pill [data-lucide] { width: 14px; height: 14px; }
.oi-back-pill:hover {
    background: #fed7aa; border-color: var(--color-primary);
    color: #c2410c;
    transform: translateX(-3px);
}
#oi-detail-back { display: none; }
#oid-hero-back {
    background: #fef2f2; border-color: #fca5a5; color: #dc2626;
    box-shadow: 0 1px 4px rgba(220,38,38,.1);
    padding: 8px 12px; flex-shrink: 0;
}
#oid-hero-back:hover {
    background: #fecaca; border-color: #ef4444; color: #b91c1c;
    transform: translateX(-3px);
}

/* ═══════════════════════════════
   ORDER LIST
   ═══════════════════════════════ */
.oi-list-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 24px; padding-bottom: 20px;
    border-bottom: 2px solid #f0f0f5;
}
.oi-list-header h2 {
    font-size: 26px; font-weight: 900;
    color: #1a1a2e; margin: 0; letter-spacing: -.5px;
    font-family: 'Montserrat', sans-serif;
    display: flex; align-items: center; gap: 12px;
}
.oi-list-header h2 [data-lucide] {
    width: 28px; height: 28px; color: var(--color-primary);
}

.oi-order-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}
/* 1 sipariş: tam genişlik */
.oi-order-grid[data-count="1"] { grid-template-columns: 1fr; }
/* 2 sipariş: yarı yarıya */
.oi-order-grid[data-count="2"] { grid-template-columns: repeat(2, 1fr); }
/* 3 sipariş: 3 kolon (default) */
/* 4 sipariş: üst 3 + alt 1 tam genişlik */
.oi-order-grid[data-count="4"] > .oi-order-card:last-child { grid-column: 1 / -1; }
/* 5 sipariş: üst 3 + alt 2 (yarı yarıya) — 6-kolon trick */
.oi-order-grid[data-count="5"] { grid-template-columns: repeat(6, 1fr); }
.oi-order-grid[data-count="5"] > .oi-order-card { grid-column: span 2; }
.oi-order-grid[data-count="5"] > .oi-order-card:nth-child(n+4) { grid-column: span 3; }

.oi-order-card {
    display: flex; align-items: center;
    gap: 18px; padding: 20px 24px;
    background: #ffffff; border-radius: 18px;
    cursor: pointer; transition: all var(--transition-slow);
    border: 1.5px solid #f0f0f5;
    position: relative; overflow: hidden;
    box-shadow: var(--shadow-sm);
}

.oi-order-card::before {
    content: ''; position: absolute;
    left: 0; top: 0; bottom: 0; width: 4px;
    background: linear-gradient(180deg, #fdba74, var(--color-primary));
    opacity: 0; transform: scaleY(.3);
    transition: all var(--transition-slow);
}
.oi-order-card:hover::before { opacity: 1; transform: scaleY(1); }
.oi-order-card:hover {
    border-color: #fde7cd;
    background: #fffcf9;
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.oi-order-card-img {
    width: 52px; height: 52px; flex-shrink: 0;
    border-radius: 14px; object-fit: cover;
    border: 1.5px solid #f0f0f5; background: #f9fafb;
    transition: all var(--transition-slow);
}
.oi-order-card:hover .oi-order-card-img {
    border-color: #fed7aa; transform: scale(1.05);
}

.oi-order-card-icon {
    display: flex; align-items: center; justify-content: center;
    width: 52px; height: 52px; flex-shrink: 0;
    border-radius: 14px;
    background: linear-gradient(145deg, #fff7ed, #ffedd5);
    border: 1px solid #fed7aa;
    color: var(--color-primary);
    transition: all var(--transition-slow);
}
.oi-order-card-icon [data-lucide] { width: 24px; height: 24px; stroke-width: 1.8; }
.oi-order-card:hover .oi-order-card-icon {
    background: linear-gradient(145deg, #ffedd5, #fed7aa);
    transform: scale(1.05);
}

/* Stacked product thumbnails */
.oi-order-card-imgs {
    display: flex; align-items: center; flex-shrink: 0;
}
.oi-order-card-thumb {
    width: 64px; height: 64px; border-radius: 14px;
    object-fit: cover; border: 2.5px solid #fff;
    box-shadow: 0 2px 8px rgba(0,0,0,.08);
    flex-shrink: 0; background: #f5f1ec;
}
.oi-order-card-thumb:not(:first-child) { margin-left: -18px; }

.oi-order-card-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 8px; }

.oi-order-card-row {
    display: flex; align-items: center; justify-content: space-between; gap: 12px;
}

.oi-order-card-num {
    font-size: 16px; font-weight: 800; color: #1a1a2e;
    letter-spacing: .3px; font-family: 'Montserrat', monospace;
}
.oi-order-card-date {
    font-size: 12px; color: #94a3b8;
    display: inline-flex; align-items: center; gap: 5px; font-weight: 600;
}
.oi-order-card-date [data-lucide] { width: 13px; height: 13px; }

.oi-order-card-total {
    font-family: 'Montserrat', sans-serif;
    font-size: 20px; font-weight: 900; color: #1a1a2e; letter-spacing: -.4px;
}

.oi-status-pill {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 5px 14px; border-radius: 100px;
    font-size: 11px; font-weight: 800;
    white-space: nowrap; letter-spacing: .3px;
    font-family: 'Montserrat', sans-serif;
}
.oi-status-pill [data-lucide] { width: 13px; height: 13px; }

.oi-order-card-arrow {
    display: flex; align-items: center; justify-content: center;
    width: 36px; height: 36px; flex-shrink: 0;
    border-radius: 50%;
    background: #f8f9fb;
    color: #c0c0cc;
    transition: all var(--transition-slow);
}
.oi-order-card-arrow [data-lucide] { width: 18px; height: 18px; }
.oi-order-card:hover .oi-order-card-arrow {
    background: #fff7ed; color: var(--color-primary);
    transform: translateX(3px);
}

/* ═══════════════════════════════
   ORDER DETAIL
   ═══════════════════════════════ */

/* Light gradient hero instead of dark */
.oi-detail-hero {
    border-radius: 24px;
    background: linear-gradient(135deg, #fffcf7 0%, #fff7ed 40%, #ffedd5 100%);
    border: 1.5px solid #fde7cd;
    position: relative;
    overflow: hidden;
}
.oi-detail-hero::before {
    content: ''; position: absolute;
    top: 0; left: 0; right: 0; height: 4px;
    background: linear-gradient(90deg, #fdba74, var(--color-primary), var(--color-primary-hover), var(--color-primary), #fdba74);
}
.oi-detail-hero::after {
    content: ''; position: absolute;
    top: -80px; right: -80px; width: 300px; height: 300px;
    background: radial-gradient(ellipse, rgba(249,115,22,.08) 0%, transparent 70%);
    pointer-events: none;
}

.oi-detail-hero-top {
    display: flex; justify-content: space-between;
    align-items: flex-start; flex-wrap: wrap; gap: 20px;
    position: relative; z-index: 1;
    padding: 32px 36px 24px;
    border-bottom: 1px solid rgba(249,115,22,.1);
}
.oi-detail-order-num {
    font-size: 24px; font-weight: 900;
    color: #1a1a2e; letter-spacing: .4px;
    font-family: 'Montserrat', monospace;
    text-transform: uppercase;
}
.oi-detail-meta { display: flex; gap: 20px; margin-top: 10px; flex-wrap: wrap; }
.oi-detail-meta span {
    font-size: 13px; color: #9e8e7e;
    display: flex; align-items: center; gap: 6px; font-weight: 600;
}
.oi-detail-meta i { font-size: 11px; color: #e0a060; }
.oi-detail-total {
    font-family: 'Montserrat', sans-serif;
    font-size: 30px; font-weight: 900;
    color: #1a1a2e; letter-spacing: -.5px; text-align: right;
}

.oi-detail-actions {
    display: flex; gap: 8px; padding: 18px 36px;
    position: relative; z-index: 1; flex-wrap: wrap;
}
.oi-act {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 20px; border-radius: 12px;
    font-size: 12px; font-weight: 800;
    cursor: pointer; font-family: 'Montserrat', sans-serif;
    transition: all var(--transition-base); letter-spacing: .4px; text-transform: uppercase;
    background: rgba(255,255,255,.7);
    border: 1.5px solid rgba(249,115,22,.2);
    color: #9e7050;
    backdrop-filter: blur(4px);
}
.oi-act i { font-size: 12px; }
.oi-act:hover {
    background: #fff;
    border-color: var(--color-primary);
    color: var(--color-primary-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(249,115,22,.1);
}
.oi-act--blue, .oi-act--teal, .oi-act--violet {
    background: rgba(255,255,255,.7);
    border-color: rgba(249,115,22,.2);
    color: #9e7050;
}
.oi-act--blue:hover, .oi-act--teal:hover, .oi-act--violet:hover {
    background: #fff; color: var(--color-primary-hover); border-color: var(--color-primary);
}

/* ═══════════════════════════════
   TIMELINE
   ═══════════════════════════════ */
.oi-timeline-wrap {
    margin-top: 12px; padding: 30px 36px;
    background: #fff; border-radius: 20px;
    border: 1.5px solid #f0f0f5;
    box-shadow: var(--shadow-sm);
}
.oi-timeline {
    display: flex; justify-content: space-between;
    position: relative; align-items: flex-start;
}
.oi-timeline::before {
    content: ''; position: absolute;
    top: 22px; left: 32px; right: 32px;
    height: 3px;
    background: #f0f0f5;
    border-radius: 3px;
    z-index: 0;
}
.oi-tl-step {
    display: flex; flex-direction: column; align-items: center;
    position: relative; z-index: 1; flex: 1; min-width: 0;
}
.oi-tl-dot {
    width: 44px; height: 44px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 14px;
    background: #fff; color: #d0d0da;
    border: 2.5px solid #e5e7eb; transition: all var(--transition-slow);
    font-family: 'Montserrat', monospace; font-weight: 900;
    box-shadow: var(--shadow-sm);
}
.oi-tl-step--done .oi-tl-dot {
    background: linear-gradient(135deg, #1a1a2e, #2d2d44);
    color: #fff; border-color: #1a1a2e;
    box-shadow: 0 4px 12px rgba(26,26,46,.15);
}
.oi-tl-step--active .oi-tl-dot {
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));
    color: #fff; border-color: var(--color-primary);
    animation: tlPulse 2.5s ease-in-out infinite;
    box-shadow: 0 4px 16px rgba(249,115,22,.25);
}
@keyframes tlPulse {
    0%, 100% { box-shadow: 0 4px 16px rgba(249,115,22,.25), 0 0 0 0 rgba(249,115,22,.15); }
    50% { box-shadow: 0 4px 16px rgba(249,115,22,.25), 0 0 0 10px rgba(249,115,22,0); }
}
.oi-tl-label {
    font-size: 10px; font-weight: 800; color: #c0c0cc;
    margin-top: 12px; text-align: center;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    max-width: 100%; text-transform: uppercase; letter-spacing: .6px;
    font-family: 'Montserrat', sans-serif;
}
.oi-tl-step--done .oi-tl-label { color: #6a6a7e; }
.oi-tl-step--active .oi-tl-label { color: var(--color-primary); font-weight: 900; }
.oi-tl-date { font-size: 10px; color: #c0c0cc; margin-top: 4px; white-space: nowrap; }
.oi-cancelled-bar {
    margin-top: 12px; padding: 16px 24px; border-radius: 14px;
    display: flex; align-items: center; gap: 10px;
    font-weight: 800; font-size: 14px;
}

/* ═══════════════════════════════
   SECTIONS
   ═══════════════════════════════ */
.oi-section {
    margin-top: 12px; background: #fff;
    border-radius: 20px; overflow: hidden;
    border: 1.5px solid #f0f0f5;
    box-shadow: var(--shadow-sm);
}
.oi-section-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px 28px;
    background: linear-gradient(135deg, #fafbfc, #f5f6f8);
    border-bottom: 1px solid #f0f0f5;
    font-size: 11px; font-weight: 800; color: #6a6a7e;
    letter-spacing: 1.3px; text-transform: uppercase;
    font-family: 'Montserrat', sans-serif;
}
.oi-section-header i { margin-right: 9px; color: #d0d0da; }
.oi-section-badge {
    font-size: 11px; font-weight: 800;
    padding: 4px 12px; border-radius: 100px;
    background: #f5f6f8; color: #8b8b9e;
    border: 1px solid #eeeff3;
    text-transform: lowercase; letter-spacing: 0;
}

/* Products */
.oi-product {
    display: flex; align-items: center; gap: 18px;
    padding: 18px 28px; border-bottom: 1px solid #f8f8fb;
    transition: background var(--transition-base);
}
.oi-product:last-child { border-bottom: none; }
.oi-product:hover { background: #fdfcfb; }
.oi-product-img {
    width: 60px; height: 60px; border-radius: 14px;
    object-fit: cover; border: 1.5px solid #f0f0f5;
    flex-shrink: 0; background: #f9fafb;
}
.oi-product-body { flex: 1; min-width: 0; }
.oi-product-name {
    font-size: 14px; font-weight: 700; color: #1a1a2e;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    font-family: 'Montserrat', sans-serif;
}
.oi-product-meta { font-size: 12px; color: #b0b0be; margin-top: 4px; }
.oi-product-amount {
    font-size: 17px; font-weight: 900; color: #1a1a2e;
    white-space: nowrap; flex-shrink: 0;
    font-family: 'Montserrat', sans-serif;
}

/* Receipt */
.oi-receipt { padding: 20px 28px; background: #fdfcfb; }
.oi-receipt-row {
    display: flex; justify-content: space-between;
    padding: 7px 0; font-size: 14px; color: #6a6a7e;
    font-family: 'Montserrat', sans-serif;
}
.oi-receipt-row.discount { color: #dc2626; }
.oi-receipt-row.free { color: #16a34a; }
.oi-receipt-row.grand {
    border-top: 2px solid #f0f0f5;
    padding-top: 16px; margin-top: 12px;
    font-size: 22px; font-weight: 900; color: #1a1a2e; letter-spacing: -.5px;
}

/* Cargo */
.oi-cargo { display: flex; align-items: center; gap: 18px; padding: 20px 28px; }
.oi-cargo-logo {
    width: 50px; height: 50px; object-fit: contain;
    border-radius: 14px; border: 1.5px solid #f0f0f5;
    padding: 7px; background: #fff; flex-shrink: 0;
}
.oi-cargo-info { flex: 1; }
.oi-cargo-provider { font-size: 15px; font-weight: 800; color: #1a1a2e; font-family: 'Montserrat', sans-serif; }
.oi-cargo-track-num {
    font-size: 12px; color: #b0b0be; margin-top: 4px;
    font-family: 'Montserrat', monospace; letter-spacing: .6px;
}
.oi-cargo-btn {
    padding: 10px 20px; border-radius: 12px;
    font-size: 12px; font-weight: 800;
    border: 1.5px solid #eeeff3; cursor: pointer;
    font-family: 'Montserrat', sans-serif;
    background: #f9fafb; color: #6a6a7e;
    transition: all var(--transition-base); letter-spacing: .4px; text-transform: uppercase;
}
.oi-cargo-btn:hover {
    background: #fff7ed; border-color: #fed7aa; color: var(--color-primary-hover);
    transform: translateY(-1px);
}
.oi-cargo-movements {
    max-height: 0; overflow: hidden; transition: max-height var(--transition-slow);
    border-top: 1px solid #f8f8fb;
}
.oi-cargo-movements.show { max-height: 500px; }
.oi-cargo-movement {
    display: flex; justify-content: space-between; align-items: flex-start;
    padding: 12px 28px; font-size: 13px; border-bottom: 1px solid #f8f8fb;
}
.oi-cargo-movement:last-child { border-bottom: none; }
.oi-cargo-movement-status { font-weight: 700; color: #3a3a4e; }
.oi-cargo-movement-date { font-size: 11px; color: #c0c0cc; margin-top: 3px; }
.oi-cargo-movement-location { font-size: 12px; color: #9898a8; text-align: right; }
.oi-cargo-toggle {
    display: flex; align-items: center; justify-content: center; gap: 7px;
    width: 100%; padding: 12px; background: #fafbfc;
    border: none; border-top: 1px solid #f0f0f5;
    font-size: 11px; font-weight: 800; color: #b0b0be;
    cursor: pointer; font-family: 'Montserrat', sans-serif;
    transition: all var(--transition-base); letter-spacing: .8px; text-transform: uppercase;
}
.oi-cargo-toggle:hover { background: #f5f6f8; color: #6a6a7e; }
.oi-cargo-toggle i { transition: transform var(--transition-slow); }
.oi-cargo-toggle.open i { transform: rotate(180deg); }

/* Address */
.oi-address-content { padding: 20px 28px; }
.oi-address-name {
    font-size: 16px; font-weight: 800; color: #1a1a2e;
    margin-bottom: 10px; font-family: 'Montserrat', sans-serif;
}
.oi-address-line {
    font-size: 13px; color: #6a6a7e; line-height: 2;
    display: flex; align-items: center; gap: 10px;
}
.oi-address-line i { font-size: 10px; color: #d0d0da; width: 14px; text-align: center; }

/* Invoice modal */
.oi-invoice-overlay {
    position: fixed; inset: 0; z-index: var(--z-modal);
    background: rgba(26,26,46,.25);
    backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
    display: flex; align-items: center; justify-content: center;
    padding: 24px 20px;
}
.oi-invoice-box {
    position: relative; background: #fff; max-width: 960px; width: 100%;
    border-radius: 24px; overflow: hidden;
    border: 1px solid #eeeff3;
    box-shadow: var(--shadow-xl);
    height: 90vh; display: flex; flex-direction: column;
}
.oi-invoice-content { flex: 1; min-height: 0; overflow: hidden; }
.oi-invoice-actions {
    display: flex; justify-content: center; gap: 12px;
    padding: 18px; background: #fafbfc; border-top: 1px solid #f0f0f5;
}
.oi-invoice-actions button {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    padding: 10px 24px; border-radius: 100px;
    font-size: 13px; font-weight: 700; font-style: normal; cursor: pointer;
    font-family: 'Montserrat', sans-serif;
    border: 1.5px solid; transition: all var(--transition-base);
}
.oi-invoice-actions button i { font-style: normal; }
.oi-invoice-actions button svg { width: 15px; height: 15px; flex-shrink: 0; }
.oi-invoice-print {
    background: #f0fdf4; color: #16a34a; border-color: #86efac;
}
.oi-invoice-print:hover { background: #bbf7d0; border-color: #22c55e; color: #15803d; }
.oi-invoice-close { background: #fef2f2; color: #dc2626; border-color: #fca5a5; }
.oi-invoice-close:hover { background: #fecaca; border-color: #ef4444; color: #b91c1c; }

/* Loading */
.oi-loading-state { text-align: center; padding: 100px 0; }
.oi-loading-state p {
    font-size: 11px; color: #b0b0be; margin-top: 26px;
    font-weight: 800; letter-spacing: 2px; text-transform: uppercase;
    font-family: 'Montserrat', sans-serif;
}
.oi-pulse-ring {
    width: 48px; height: 48px; margin: 0 auto;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));
    position: relative;
}
.oi-pulse-ring::before, .oi-pulse-ring::after {
    content: ''; position: absolute; inset: 0; border-radius: 50%;
    border: 2px solid var(--color-primary); animation: pulseOut 1.6s ease-out infinite;
}
.oi-pulse-ring::after { animation-delay: .8s; }
@keyframes pulseOut {
    0% { transform: scale(1); opacity: .5; }
    100% { transform: scale(2.8); opacity: 0; }
}

/* Print */
@media print {
    body > *:not(.oi-invoice-overlay) { display: none !important; }
    .oi-invoice-overlay { position: static; background: none; padding: 0; backdrop-filter: none; }
    .oi-invoice-box { box-shadow: none; border-radius: 0; max-width: 100%; border: none; }
    .oi-invoice-actions { display: none !important; }
}

/* ═══════════════════════════════
   ORDER DETAIL — Redesigned (oid- prefix)
   ═══════════════════════════════ */
@keyframes oidFadeUp {
    from { opacity: 0; transform: translateY(16px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ── Hero Card ── */
.oid-hero {
    position: relative; border-radius: 16px; overflow: hidden;
    background: #fff; border: 1px solid rgba(0,0,0,.06);
    margin-bottom: 10px;
    box-shadow: var(--shadow-sm);
    animation: oidFadeUp .5s ease both;
}
.oid-hero-accent { height: 5px; background: linear-gradient(90deg, var(--color-primary-light), var(--color-primary), var(--color-primary-hover)); }
.oid-hero-body { padding: 26px 32px 24px; }
.oid-hero-top {
    display: flex; align-items: center; justify-content: space-between;
    gap: 20px; flex-wrap: wrap;
}
.oid-hero-left { display: flex; align-items: center; gap: 16px; flex: 1; min-width: 0; }
.oid-order-icon {
    width: 52px; height: 52px; border-radius: 14px;
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));
    display: flex; align-items: center; justify-content: center;
    color: #fff; flex-shrink: 0;
    box-shadow: 0 4px 16px rgba(249,115,22,.3);
}
.oid-order-icon [data-lucide] { width: 26px !important; height: 26px !important; }
.oid-order-num {
    font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: 800;
    color: #1a1611; margin: 0; letter-spacing: -.3px; line-height: 1;
}
.oid-hero-meta {
    display: flex; align-items: center;
    gap: 14px; flex-wrap: wrap; padding: 0; margin-top: 6px;
    font-family: 'Montserrat', sans-serif; font-size: 13px; color: #92816f;
}
.oid-hero-meta span {
    display: inline-flex; align-items: center; gap: 5px;
}
.oid-hero-meta [data-lucide] { width: 13px; height: 13px; opacity: .6; }
.oid-hero-meta-dot {
    width: 5px; height: 5px; border-radius: 50%; background: #a09688; opacity: .4; flex-shrink: 0;
}
.oid-hero-right {
    display: flex; flex-direction: column; align-items: flex-end; gap: 10px; flex-shrink: 0;
}
.oid-status-pill {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 8px 18px; border-radius: 100px;
    font-family: 'Montserrat', sans-serif; font-size: 15px; font-weight: 700;
}
.oid-status-pill [data-lucide] { width: 14px; height: 14px; }
.oid-hero-total {
    font-family: 'Montserrat', sans-serif; font-size: 30px; font-weight: 800;
    color: var(--color-primary-hover); letter-spacing: -.5px; line-height: 1;
}

/* Hero Actions */
.oid-hero-actions {
    padding: 16px 0 0; margin-top: 18px;
    border-top: 1px solid rgba(0,0,0,.06);
    display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.oid-chip {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 22px; border-radius: 10px;
    font-family: 'Montserrat', sans-serif; font-size: 14px; font-weight: 600;
    cursor: pointer; transition: all var(--transition-base); white-space: nowrap;
    background: #f5f1ec; color: #6b6056; border: none;
}
.oid-chip [data-lucide] { width: 14px; height: 14px; opacity: .85; }
.oid-chip:hover { background: #fff7ed; color: var(--color-primary-hover); transform: translateY(-1px); }

/* ── JS compat: oid-hero-row1 / oid-back / oid-hero-price / oid-act ── */
.oid-hero-row1 {
    display: flex; align-items: center; gap: 14px;
    padding: 26px 32px 0;
}
.oid-back {
    width: 52px; height: 52px; border-radius: 14px;
    background: #f5f1ec; border: 1.5px solid #e8e0d6;
    color: #6b6056;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0; cursor: pointer;
    transition: all var(--transition-base);
    padding: 0;
}
.oid-back:hover { background: #fff7ed; border-color: #fdba74; color: var(--color-primary); transform: translateX(-2px); }
.oid-back [data-lucide] { width: 24px !important; height: 24px !important; stroke-width: 2; }
.oid-hero-price {
    text-align: center; padding: 18px 32px 14px;
    font-family: 'Montserrat', sans-serif; font-size: 34px; font-weight: 900;
    color: var(--color-primary-hover); letter-spacing: -.5px; line-height: 1;
}
.oid-act {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 10px 22px; border-radius: 10px;
    background: #f5f1ec; border: none;
    font-family: 'Montserrat', sans-serif; font-size: 14px; font-weight: 600;
    color: #6b6056; cursor: pointer;
    transition: all var(--transition-base); white-space: nowrap;
}
.oid-act [data-lucide] { width: 14px !important; height: 14px !important; opacity: .7; }
.oid-act:hover { background: #fff7ed; color: var(--color-primary-hover); transform: translateY(-1px); }
.oid-act--primary {
    background: var(--color-primary); color: #fff; font-weight: 700;
}
.oid-act--primary [data-lucide] { opacity: 1; }
.oid-act--primary:hover { background: var(--color-primary-hover); color: #fff; }

/* ── JS compat: product name row + qty inline ── */
.oid-product-name-row {
    display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; margin-bottom: 6px;
}
.oid-product-qty-inline {
    font-family: 'Montserrat', sans-serif; font-size: 15px; font-weight: 600;
    color: #6b6056; white-space: nowrap; flex-shrink: 0;
}

/* ── Timeline ── */
.oid-timeline {
    display: flex; align-items: flex-start;
    background: #fff; border-radius: 16px; padding: 26px 24px 22px;
    margin-bottom: 10px;
    box-shadow: var(--shadow-sm);
    border: 1px solid rgba(0,0,0,.06); overflow-x: auto;
    animation: oidFadeUp .5s ease .05s both;
}
.oid-tl-step {
    display: flex; flex-direction: column; align-items: center;
    position: relative; flex: 1; min-width: 90px;
}
.oid-tl-dot {
    width: 44px; height: 44px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 10px; position: relative; z-index: 2; transition: all var(--transition-slow);
}
.oid-tl-dot [data-lucide] { width: 18px; height: 18px; }
.oid-tl-step--done .oid-tl-dot { background: #ffedd5; color: var(--color-primary-hover); border: 2.5px solid #fdba74; }
.oid-tl-step--active .oid-tl-dot {
    background: linear-gradient(135deg, #16a34a, #22c55e); color: #fff; border: 2.5px solid #16a34a;
    box-shadow: 0 0 0 5px rgba(22,163,74,.15), 0 4px 14px rgba(22,163,74,.25);
    animation: oidPulseGreen 2s infinite;
}
@keyframes oidPulseGreen {
    0%,100% { box-shadow: 0 0 0 5px rgba(22,163,74,.15), 0 4px 14px rgba(22,163,74,.25); }
    50% { box-shadow: 0 0 0 10px rgba(22,163,74,0), 0 4px 14px rgba(22,163,74,.25); }
}
.oid-tl-step--waiting .oid-tl-dot { background: #f5f1ec; color: #a09688; border: 2.5px solid #e0d6cc; }
.oid-tl-label {
    font-family: 'Montserrat', sans-serif; font-size: 13px; font-weight: 700;
    text-align: center; line-height: 1.3; max-width: 90px;
}
.oid-tl-step--done .oid-tl-label { color: #6b6056; }
.oid-tl-step--active .oid-tl-label { color: #16a34a; }
.oid-tl-step--waiting .oid-tl-label { color: #a09688; }
.oid-tl-connector {
    position: absolute; top: 22px; left: calc(50% + 24px);
    width: calc(100% - 48px); height: 3px; border-radius: 3px; z-index: 1;
}
.oid-tl-step--done .oid-tl-connector { background: linear-gradient(90deg, var(--color-primary-light), #fdba74); }
.oid-tl-step--active .oid-tl-connector { background: linear-gradient(90deg, #16a34a, #e0d6cc); }
.oid-tl-step--waiting .oid-tl-connector { background: #e0d6cc; }

/* Cancelled */
.oid-cancelled-bar {
    display: flex; align-items: center; gap: 12px;
    border-radius: 14px; padding: 20px 28px; margin-bottom: 10px;
    font-family: 'Montserrat', sans-serif; font-size: 17px; font-weight: 700;
    animation: oidFadeUp .5s ease .05s both;
}
.oid-cancelled-bar [data-lucide] { width: 22px; height: 22px; }

/* ── Cargo ── */
.oid-cargo {
    display: flex; align-items: center; gap: 20px;
    background: linear-gradient(135deg, #fff9f5 0%, #ffedd5 100%);
    border: 1.5px solid #fed7aa; border-radius: 16px;
    padding: 22px 28px; margin-bottom: 10px;
    box-shadow: 0 2px 8px rgba(249,115,22,.06);
    animation: oidFadeUp .5s ease .1s both;
}
.oid-cargo-icon-wrap {
    width: 56px; height: 56px; border-radius: 14px;
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover)); color: #fff;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0; box-shadow: 0 4px 12px rgba(249,115,22,.25); overflow: hidden;
}
.oid-cargo-icon-wrap [data-lucide] { width: 22px; height: 22px; }
.oid-cargo-brand { width: 100%; height: 100%; object-fit: contain; padding: 8px; filter: brightness(0) invert(1); }
.oid-cargo-detail { flex: 1; min-width: 0; }
.oid-cargo-eyebrow {
    display: block; font-family: 'Montserrat', sans-serif;
    font-size: 11px; font-weight: 800; color: var(--color-primary-hover);
    text-transform: uppercase; letter-spacing: 1.2px; margin-bottom: 6px;
}
.oid-cargo-info { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.oid-cargo-provider { font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: 700; color: #1a1611; }
.oid-cargo-track-num {
    font-size: 16px; font-weight: 700; color: #6b6056;
    font-family: 'Montserrat', monospace; letter-spacing: .5px;
    background: rgba(249,115,22,.08); padding: 4px 12px; border-radius: 6px;
}
.oid-cargo-btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 12px 24px; border-radius: 12px;
    font-family: 'Montserrat', sans-serif; font-size: 15px; font-weight: 700;
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover)); color: #fff;
    border: none; cursor: pointer; white-space: nowrap; transition: all var(--transition-base);
    box-shadow: 0 4px 14px rgba(249,115,22,.3);
}
.oid-cargo-btn [data-lucide] { width: 15px; height: 15px; }
.oid-cargo-btn:hover { background: linear-gradient(135deg, var(--color-primary-hover), #c2410c); transform: translateY(-2px); }

/* ── Main Grid ── */
.oid-main-grid {
    display: grid; grid-template-columns: 3fr 2fr; gap: 16px;
    align-items: start; margin-bottom: 16px;
    animation: oidFadeUp .5s ease .15s both;
}

/* Products Panel */
.oid-products-panel {
    background: #fff; border: 1px solid rgba(0,0,0,.06); border-radius: 16px;
    overflow: hidden; box-shadow: var(--shadow-sm);
}
.oid-panel-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 20px 28px; border-bottom: 1px solid rgba(0,0,0,.06);
}
.oid-panel-title {
    display: flex; align-items: center; gap: 10px;
    font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: 700; color: #1a1611;
}
.oid-panel-title [data-lucide] { width: 17px; height: 17px; color: var(--color-primary); }
.oid-badge-count {
    background: #fff7ed; border: 1px solid #fed7aa; color: var(--color-primary-hover);
    padding: 5px 16px; border-radius: 100px;
    font-family: 'Montserrat', sans-serif; font-size: 14px; font-weight: 700;
}
.oid-product-list { padding: 6px 0; }
.oid-product {
    display: flex; align-items: center; gap: 20px;
    padding: 20px 28px; border-bottom: 1px solid rgba(0,0,0,.04);
    transition: background var(--transition-fast);
    animation: oidFadeUp .35s ease-out both;
    animation-delay: calc(var(--oid-i, 0) * 60ms + 250ms);
}
.oid-product:last-child { border-bottom: none; }
.oid-product:hover { background: #faf8f5; }

.oid-product-img-wrap { position: relative; flex-shrink: 0; }
.oid-product-rank {
    position: absolute; top: -5px; left: -5px;
    width: 26px; height: 26px; border-radius: 8px;
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light)); color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-family: 'Montserrat', sans-serif; font-size: 12px; font-weight: 800;
    z-index: 1; box-shadow: 0 3px 8px rgba(249,115,22,.3);
}
.oid-product-img {
    width: 88px; height: 88px; border-radius: 12px; overflow: hidden;
    border: 1.5px solid rgba(0,0,0,.06); background: #f5f1ec;
    display: flex; align-items: center; justify-content: center;
}
.oid-product-img img { width: 100%; height: 100%; object-fit: cover; }
.oid-product-body { flex: 1; min-width: 0; }
.oid-product-name {
    display: block; font-family: 'Montserrat', sans-serif;
    font-size: 17px; font-weight: 700; color: #1a1611;
    line-height: 1.4; margin-bottom: 8px;
}
.oid-product-meta { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.oid-product-sku {
    font-size: 13px; color: #a09688; background: #f5f1ec;
    padding: 4px 12px; border-radius: 6px; font-weight: 600;
    font-family: 'Montserrat', monospace;
}
.oid-product-qty { font-family: 'Montserrat', sans-serif; font-size: 15px; font-weight: 600; color: #6b6056; }
.oid-product-unit { font-family: 'Montserrat', sans-serif; font-size: 15px; color: #92816f; font-weight: 600; }
.oid-product-price-col { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; flex-shrink: 0; }
.oid-product-amount {
    font-family: 'Montserrat', sans-serif; font-size: 22px; font-weight: 800;
    color: var(--color-primary-hover); white-space: nowrap; letter-spacing: -.3px;
}

/* ── Sidebar ── */
.oid-sidebar { display: flex; flex-direction: column; gap: 16px; }

/* Receipt Card */
.oid-receipt-card {
    background: #fff; border: 1px solid rgba(0,0,0,.06); border-radius: 16px;
    overflow: hidden; box-shadow: var(--shadow-sm);
}
.oid-receipt-header {
    display: flex; align-items: center; gap: 12px;
    padding: 22px 28px; border-bottom: 1px solid rgba(0,0,0,.06);
    font-family: 'Montserrat', sans-serif; font-size: 19px; font-weight: 700; color: #1a1611;
}
.oid-receipt-header [data-lucide] { width: 20px; height: 20px; color: var(--color-primary); }

/* Quick Info */
.oid-quick-info { padding: 16px 28px; border-bottom: 1px solid rgba(0,0,0,.06); }
.oid-qi-row {
    display: flex; justify-content: space-between; align-items: center; padding: 12px 0;
}
.oid-qi-row + .oid-qi-row { border-top: 1px solid rgba(0,0,0,.04); }
.oid-qi-label {
    font-family: 'Montserrat', sans-serif; font-size: 15px; font-weight: 600; color: #92816f;
    display: flex; align-items: center; gap: 10px;
}
.oid-qi-label [data-lucide] { width: 16px; height: 16px; color: #a09688; }
.oid-qi-value {
    font-family: 'Montserrat', sans-serif; font-size: 15px; font-weight: 700; color: #1a1611;
    display: flex; align-items: center; gap: 8px;
}
.oid-qi-badge {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 5px 14px; border-radius: 100px; font-size: 12px; font-weight: 700;
}

/* Financial */
.oid-receipt-body { padding: 16px 28px; display: flex; flex-direction: column; }
.oid-rcpt-line {
    display: flex; justify-content: space-between; align-items: center;
    padding: 12px 0; font-family: 'Montserrat', sans-serif; font-size: 15px; color: #6b6056;
    border-bottom: 1px dashed rgba(0,0,0,.06);
}
.oid-rcpt-line:last-child { border-bottom: none; }
.oid-rcpt-line span:first-child { display: flex; align-items: center; gap: 10px; }
.oid-rcpt-line span:first-child [data-lucide] { width: 16px; height: 16px; color: #a09688; }
.oid-rcpt-line span:last-child { font-weight: 700; color: #1a1611; font-size: 16px; }
.oid-rcpt-line--tax span:last-child { color: #dc2626; }
.oid-rcpt-line--discount span:last-child { color: #16a34a; font-weight: 700; }
.oid-rcpt-line--discount span:first-child [data-lucide] { color: #16a34a; }
.oid-rcpt-line--free span:last-child {
    color: #16a34a; font-weight: 700; font-size: 13px;
    background: #f0fdf4; padding: 4px 12px; border-radius: 6px;
}

/* Grand Total */
.oid-receipt-total {
    display: flex; justify-content: space-between; align-items: center;
    padding: 22px 28px; border-top: 2.5px solid #1a1611;
    font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: 700; color: #1a1611;
}
.oid-receipt-grand {
    font-family: 'Montserrat', sans-serif; font-size: 28px; font-weight: 800;
    color: var(--color-primary-hover); letter-spacing: -.5px;
}

/* Note Card */
.oid-note-card {
    background: #fff; border: 1px solid rgba(0,0,0,.06);
    border-left: 4px solid #fbbf24; border-radius: 16px; overflow: hidden;
}
.oid-note-header {
    display: flex; align-items: center; gap: 10px;
    padding: 16px 22px 0; font-family: 'Montserrat', sans-serif;
    font-size: 16px; font-weight: 700; color: #1a1611;
}
.oid-note-header [data-lucide] { width: 18px; height: 18px; color: #fbbf24; }
.oid-note-text {
    margin: 0; padding: 12px 22px 18px;
    font-family: 'Montserrat', sans-serif; font-size: 15px;
    color: #6b6056; line-height: 1.6; font-style: italic;
}

/* ── Address Cards ── */
/* ── Bank Accounts (same as confirmation page) ── */
.oid-bank-wrapper {
    border: 1px solid rgba(0,0,0,.06); border-radius: 16px; overflow: hidden;
    background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.04); margin-top: 12px;
}
.oid-bank-wrapper-title {
    display: flex; align-items: center; gap: 10px;
    padding: 16px 20px; font-family: 'Montserrat', sans-serif;
    font-size: 17px; font-weight: 700; color: #1a1611;
    border-bottom: 1px solid rgba(0,0,0,.06);
}
.oid-bank-wrapper-title [data-lucide] { width: 18px !important; height: 18px !important; color: #ea580c; }
.oid-bank-wrapper .co-bank-info-note { margin: 16px 20px 0; }
.oid-bank-wrapper .co-bank-accounts { padding: 0 20px 20px; margin-top: 12px; }
.co-bank-info-note {
    display: flex; gap: 12px; padding: 14px 16px;
    background: linear-gradient(135deg, #fff7ed 0%, #ffedd5 100%);
    border: 1px solid #fed7aa; border-radius: 12px; margin-bottom: 12px;
}
.co-bank-info-icon {
    width: 36px; height: 36px; min-width: 36px;
    background: linear-gradient(135deg, #f97316, #ea580c);
    border-radius: 10px; display: flex; align-items: center; justify-content: center; color: #fff;
}
.co-bank-info-icon [data-lucide] { width: 16px !important; height: 16px !important; }
.co-bank-info-content { flex: 1; font-size: 12.5px; font-weight: 500; color: #92400e; line-height: 1.7; }
.co-bank-info-content strong { font-weight: 700; color: #7c2d12; }
.co-bank-info-total { font-weight: 700; color: #ea580c; font-size: 14px; }
.co-bank-accounts { display: flex; flex-direction: column; gap: 10px; }
.co-bank-account { border: 1px solid #e5e7eb; border-radius: 14px; overflow: hidden; transition: border-color .2s; }
.co-bank-account:hover { border-color: #fdba74; }
.co-bank-account-left {
    display: flex; align-items: center; gap: 10px; padding: 12px 16px;
    background: linear-gradient(135deg, #fefce8 0%, #fff7ed 100%); border-bottom: 1px solid #fde68a;
}
.co-bank-account-icon {
    width: 32px; height: 32px; min-width: 32px;
    background: linear-gradient(135deg, #f97316, #ea580c);
    border-radius: 8px; display: flex; align-items: center; justify-content: center;
    color: #fff; box-shadow: 0 2px 6px rgba(249,115,22,.25);
}
.co-bank-account-icon [data-lucide] { width: 14px !important; height: 14px !important; }
.co-bank-account-name { font-size: 14px; font-weight: 700; color: #1e293b; letter-spacing: .3px; }
.co-bank-account-details { padding: 6px 16px 12px; }
.co-bank-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; }
.co-bank-row + .co-bank-row { border-top: 1px solid #f3f4f6; }
.co-bank-label { font-size: 11px; font-weight: 600; color: #94a3b8; text-transform: uppercase; letter-spacing: .5px; flex-shrink: 0; }
.co-bank-val { font-size: 13px; font-weight: 600; color: #1e293b; text-align: right; }
.co-bank-row-iban { flex-wrap: wrap; }
.co-bank-iban-group { display: flex; align-items: center; gap: 8px; }
.co-bank-iban-text { letter-spacing: .3px; }
.co-iban-copy {
    display: inline-flex; align-items: center; justify-content: center;
    width: 30px; height: 30px; border: 1.5px solid #ea580c; border-radius: 8px;
    background: #fff7ed; color: #ea580c; cursor: pointer; transition: all .2s; flex-shrink: 0;
}
.co-iban-copy:hover { background: #ea580c; color: #fff; box-shadow: 0 2px 8px rgba(249,115,22,.3); }
.co-iban-copy [data-lucide] { width: 13px !important; height: 13px !important; }

.oid-addresses {
    animation: oidFadeUp .5s ease .2s both;
    display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}
.oid-addr {
    background: #fff; border: 1px solid rgba(0,0,0,.06); border-radius: 16px;
    overflow: hidden; box-shadow: var(--shadow-sm);
    transition: border-color var(--transition-base);
}
.oid-addr:hover { border-color: rgba(0,0,0,.12); }
.oid-addr-head {
    display: flex; align-items: center; gap: 12px;
    padding: 18px 24px; border-bottom: 1px solid rgba(0,0,0,.06);
}
.oid-addr-head h4 {
    margin: 0; font-family: 'Montserrat', sans-serif; font-size: 17px; font-weight: 700; color: #1a1611;
}
.oid-addr-icon {
    width: 42px; height: 42px; border-radius: 11px;
    background: linear-gradient(135deg, #fff7ed, #ffedd5); color: var(--color-primary-hover);
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.oid-addr-icon [data-lucide] { width: 17px; height: 17px; }
.oid-addr-body {
    display: flex; flex-direction: column; gap: 6px;
    padding: 18px 24px 20px;
    font-family: 'Montserrat', sans-serif; font-size: 15px; color: #6b6056; line-height: 1.55;
}
.oid-addr-name { font-size: 18px; font-weight: 700; color: #1a1611; margin-bottom: 2px; }
.oid-addr-company {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: 15px; font-weight: 700; color: #c2410c;
    background: #fff7ed; padding: 6px 14px; border-radius: 8px; width: fit-content;
}
.oid-addr-company [data-lucide] { width: 13px; height: 13px; opacity: .7; }
.oid-addr-lines { display: flex; flex-direction: column; gap: 4px; margin: 4px 0; }
.oid-addr-line {
    font-size: 15px; color: #6b6056; display: flex; align-items: flex-start; gap: 8px; line-height: 1.5;
}
.oid-addr-line [data-lucide] { width: 13px; height: 13px; color: #a09688; margin-top: 4px; flex-shrink: 0; }
.oid-addr-contact {
    display: flex; flex-wrap: wrap; gap: 16px; margin-top: 8px;
    padding-top: 10px; border-top: 1px solid rgba(0,0,0,.05);
}
.oid-addr-contact span {
    display: flex; align-items: center; gap: 8px;
    font-size: 14px; color: #92816f; font-weight: 600;
}
.oid-addr-contact [data-lucide] { width: 13px; height: 13px; color: var(--color-primary-hover); }

/* ── Digital Download Chips ── */
.od-product-download {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
}
.od-dl-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 10px;
    border-radius: 8px;
    border: 1.5px solid #e0d6cc;
    background: linear-gradient(135deg, #fefcfa, #faf6f1);
    color: #5c4f42;
    font-size: 12px;
    font-weight: 600;
    line-height: 1;
    box-sizing: border-box;
    font-family: 'Montserrat', sans-serif;
    cursor: pointer;
    transition: all var(--transition-base);
    text-decoration: none;
    white-space: nowrap;
}
.od-dl-chip svg { width: 14px !important; height: 14px !important; flex-shrink: 0; color: var(--color-primary-hover); }
.od-dl-chip:hover {
    background: linear-gradient(135deg, #fff7ed, #ffedd5);
    border-color: #fdba74;
    color: #c2410c;
    box-shadow: 0 2px 8px rgba(249,115,22,.12);
    transform: translateY(-1px);
    text-decoration: none;
}
.od-dl-chip--copy:active { transform: scale(0.96); }
.od-dl-chip--copy.copied {
    background: linear-gradient(135deg, #f0fdf4, #dcfce7);
    border-color: #86efac;
    color: #16a34a;
}
.od-dl-chip--copy.copied svg { color: #16a34a; animation: od-check-pop .4s ease; }
@keyframes od-check-pop { 0% { transform: scale(0.5); opacity: 0; } 50% { transform: scale(1.25); } 100% { transform: scale(1); opacity: 1; } }
