/* =============================================
   CUSTOMER ORDERS PORTAL — orders.css
   ============================================= */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
    --c-dark: #1a1410;
    --c-mid: #5a4a3a;
    --c-muted: #8a7a6a;
    --c-gold: #c9a96e;
    --c-gold-lt: #e8d5b0;
    --c-silk: #8b5c8b;
    --c-warm: #f5efe6;
    --c-white: #fffdf9;
    --c-bg: #faf6f0;
    --ff-serif: 'Cormorant Garamond', Georgia, serif;
    --ff-sans: 'Inter', sans-serif;
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --shadow-sm: 0 2px 8px rgba(0,0,0,.06);
    --shadow-md: 0 4px 20px rgba(0,0,0,.08);
    --trans: .25s ease;
}

html { font-size: 15px; }
body { font-family: var(--ff-sans); background: var(--c-bg); color: var(--c-dark); min-height: 100vh; }

/* ── Buttons ── */
.btn { display: inline-flex; align-items: center; gap: .4rem; font-family: var(--ff-sans); font-size: .85rem; font-weight: 600; border: none; border-radius: var(--radius-sm); padding: .6rem 1.25rem; cursor: pointer; transition: all var(--trans); text-decoration: none; }
.btn--primary { background: linear-gradient(135deg, var(--c-silk) 0%, #6a3d6a 100%); color: #fff; }
.btn--primary:hover { opacity: .9; transform: translateY(-1px); }
.btn--ghost { background: transparent; border: 1.5px solid var(--c-gold-lt); color: var(--c-mid); }
.btn--ghost:hover { border-color: var(--c-silk); color: var(--c-silk); }
.btn--sm { padding: .4rem .9rem; font-size: .8rem; }
.btn--lg { padding: .7rem 1.5rem; font-size: .9rem; }

/* ── Nav ── */
.nav { background: var(--c-white); border-bottom: 1px solid var(--c-gold-lt); padding: .85rem 2rem; position: sticky; top: 0; z-index: 50; }
.nav__inner { max-width: 1200px; margin: 0 auto; display: flex; align-items: center; gap: 1.5rem; }
.nav__logo { font-family: var(--ff-serif); font-size: 1.15rem; color: var(--c-dark); text-decoration: none; display: flex; align-items: center; gap: .4rem; }
.nav__logo-icon { color: var(--c-gold); font-size: .9rem; }
.nav__right { margin-left: auto; display: flex; align-items: center; gap: 1rem; }
.nav__link { font-size: .85rem; color: var(--c-muted); text-decoration: none; transition: color var(--trans); }
.nav__link:hover { color: var(--c-silk); }
.nav__user-info { display: flex; align-items: center; gap: .5rem; }
.nav__user-avatar { width: 28px; height: 28px; border-radius: 50%; background: linear-gradient(135deg, var(--c-silk) 0%, #6a3d6a 100%); color: #fff; font-size: .7rem; font-weight: 700; display: flex; align-items: center; justify-content: center; }
.nav__user-name { font-size: .8rem; color: var(--c-mid); font-weight: 500; max-width: 120px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ── Page Loader ── */
.page-loader { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 60vh; gap: 1rem; color: var(--c-muted); }
.page-loader__spinner { font-size: 2rem; color: var(--c-gold); animation: spin 2s linear infinite; }
@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }

/* ── Auth Required ── */
.auth-required { display: flex; align-items: center; justify-content: center; min-height: 70vh; }
.auth-required__card { text-align: center; background: var(--c-white); border: 1px solid var(--c-gold-lt); border-radius: var(--radius-lg); padding: 3rem; max-width: 400px; box-shadow: var(--shadow-md); }
.auth-required__icon { font-size: 2.5rem; display: block; margin-bottom: 1rem; }
.auth-required__card h2 { font-family: var(--ff-serif); font-size: 1.5rem; font-weight: 400; margin-bottom: .5rem; }
.auth-required__card p { font-size: .9rem; color: var(--c-muted); margin-bottom: 1.5rem; }

/* ── Orders Page ── */
.orders-page { max-width: 900px; margin: 0 auto; padding: 2.5rem 1.5rem 4rem; }
.orders-page__header { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 1.5rem; gap: 1rem; flex-wrap: wrap; }
.orders-page__title { font-family: var(--ff-serif); font-size: 2rem; font-weight: 400; color: var(--c-dark); }
.orders-page__subtitle { font-size: .9rem; color: var(--c-muted); margin-top: .15rem; }

/* ── Filter pills ── */
.orders-filters { display: flex; gap: .5rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.filter-pill { font-family: var(--ff-sans); font-size: .8rem; font-weight: 600; padding: .4rem 1rem; border: 1.5px solid var(--c-gold-lt); border-radius: 100px; background: var(--c-white); color: var(--c-muted); cursor: pointer; transition: all var(--trans); }
.filter-pill:hover { border-color: var(--c-silk); color: var(--c-silk); }
.filter-pill.active { background: var(--c-silk); border-color: var(--c-silk); color: #fff; }

/* ── Orders list ── */
.orders-list { display: flex; flex-direction: column; gap: 1rem; }

/* ── Order card ── */
.order-card { background: var(--c-white); border: 1px solid var(--c-gold-lt); border-radius: var(--radius-md); overflow: hidden; transition: border-color var(--trans), box-shadow var(--trans); }
.order-card:hover { border-color: var(--c-gold); box-shadow: var(--shadow-sm); }

.order-card__header { padding: 1.25rem 1.5rem; display: flex; align-items: center; gap: 1rem; cursor: pointer; }
.order-card__info { flex: 1; min-width: 0; }
.order-card__date { font-size: .78rem; color: var(--c-muted); margin-bottom: .2rem; }
.order-card__summary { font-weight: 600; font-size: .95rem; color: var(--c-dark); }
.order-card__meta { font-size: .8rem; color: var(--c-muted); margin-top: .15rem; }
.order-card__arrow { font-size: 1rem; color: var(--c-muted); transition: transform var(--trans); }
.order-card.expanded .order-card__arrow { transform: rotate(180deg); }

/* Status badge */
.status-badge { font-size: .68rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; padding: .2rem .65rem; border-radius: 100px; white-space: nowrap; }
.status-badge--pending { background: rgba(251,191,36,.12); color: #b8860b; }
.status-badge--quoted { background: rgba(96,165,250,.12); color: #2563eb; }
.status-badge--paid { background: rgba(74,222,128,.12); color: #15803d; }
.status-badge--rejected { background: rgba(248,113,113,.12); color: #dc2626; }
.status-badge--in-production { background: rgba(139,92,139,.12); color: #8b5c8b; }
.status-badge--shipped { background: rgba(45,212,191,.12); color: #0d9488; }
.status-badge--completed { background: rgba(74,222,128,.18); color: #15803d; }

/* ── Order details (expandable) ── */
.order-card__body { display: none; padding: 0 1.5rem 1.5rem; border-top: 1px solid var(--c-warm); }
.order-card.expanded .order-card__body { display: block; }

/* Timeline */
.order-timeline { display: flex; align-items: center; gap: 0; margin: 1.25rem 0; padding: 0; }
.timeline-step { display: flex; flex-direction: column; align-items: center; gap: .35rem; flex: 1; position: relative; }
.timeline-step__dot { width: 28px; height: 28px; border-radius: 50%; border: 2px solid var(--c-gold-lt); background: var(--c-white); display: flex; align-items: center; justify-content: center; font-size: .65rem; color: var(--c-muted); position: relative; z-index: 1; transition: all var(--trans); }
.timeline-step.active .timeline-step__dot { background: linear-gradient(135deg, var(--c-silk), #6a3d6a); border-color: var(--c-silk); color: #fff; box-shadow: 0 3px 12px rgba(139,92,139,.3); }
.timeline-step.done .timeline-step__dot { background: var(--c-gold); border-color: var(--c-gold); color: #fff; }
.timeline-step__label { font-size: .7rem; font-weight: 500; color: var(--c-muted); text-align: center; }
.timeline-step.active .timeline-step__label,
.timeline-step.done .timeline-step__label { color: var(--c-dark); font-weight: 600; }
.timeline-line { flex: 0 0 1; width: 100%; height: 2px; background: var(--c-gold-lt); margin-top: -20px; }
.timeline-line.done { background: var(--c-gold); }

/* Detail sections */
.order-detail { margin-top: 1rem; }
.order-detail__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.order-detail__section { }
.order-detail__label { font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--c-silk); margin-bottom: .5rem; }
.order-detail__row { font-size: .85rem; color: var(--c-mid); line-height: 1.8; }
.order-detail__row strong { color: var(--c-dark); font-weight: 600; }

/* Quote / payment box */
.order-quote-box { margin-top: 1rem; background: rgba(139,92,139,.05); border: 1px solid rgba(139,92,139,.15); border-radius: var(--radius-sm); padding: 1rem 1.25rem; }
.order-quote-box__price { font-family: var(--ff-serif); font-size: 1.5rem; color: var(--c-dark); font-weight: 400; margin-bottom: .25rem; }
.order-quote-box__detail { font-size: .82rem; color: var(--c-muted); margin-bottom: .15rem; }
.order-quote-box__actions { margin-top: .75rem; display: flex; gap: .5rem; }

/* Design images */
.order-images { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: .75rem; }
.order-images img { width: 80px; height: 80px; object-fit: cover; border-radius: var(--radius-sm); border: 1px solid var(--c-gold-lt); }

/* Payment confirmed */
.payment-confirmed { margin-top: 1rem; background: rgba(74,222,128,.06); border: 1px solid rgba(74,222,128,.2); border-radius: var(--radius-sm); padding: 1rem 1.25rem; display: flex; align-items: center; gap: .75rem; }
.payment-confirmed__icon { font-size: 1.5rem; }
.payment-confirmed__text { font-size: .9rem; color: #15803d; font-weight: 600; }
.payment-confirmed__amount { font-family: var(--ff-serif); font-size: 1.25rem; color: #15803d; }

/* ── Empty state ── */
.orders-empty { text-align: center; padding: 4rem 2rem; }
.orders-empty__icon { font-size: 3rem; margin-bottom: 1rem; }
.orders-empty h3 { font-family: var(--ff-serif); font-size: 1.4rem; font-weight: 400; margin-bottom: .5rem; }
.orders-empty p { font-size: .9rem; color: var(--c-muted); margin-bottom: 1.5rem; }

/* ── Responsive ── */
@media (max-width: 768px) {
    .orders-page__header { flex-direction: column; align-items: flex-start; }
    .order-detail__grid { grid-template-columns: 1fr; }
    .nav__user-name { display: none; }
    .order-timeline { flex-wrap: wrap; gap: .25rem; }
    .timeline-line { display: none; }
    .timeline-step { flex: none; width: auto; }
}
