/* ============================================================
   XEWALI FASHION — style.css  (complete)
   ============================================================ */
:root {
  --luxe-50:#faf8f5;--luxe-100:#f3ede3;--luxe-200:#e4d5be;
  --luxe-400:#c29975;--luxe-600:#9a6645;--luxe-700:#7d5038;
  --dark:#0f0f0f;--charcoal:#1a1a1a;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',system-ui,sans-serif;color:#111;-webkit-font-smoothing:antialiased}
.font-serif{font-family:'Playfair Display',Georgia,serif}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:600;line-height:1.2}
.section-subtitle{font-size:.875rem;letter-spacing:.15em;text-transform:uppercase;color:var(--luxe-600);font-weight:500}
.section-label{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--luxe-400)}

/* Buttons */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 2rem;background:var(--charcoal);color:#fff;font-size:.875rem;font-weight:600;letter-spacing:.05em;border-radius:.75rem;transition:all .25s ease;cursor:pointer;border:2px solid var(--charcoal);text-decoration:none;white-space:nowrap}
.btn-primary:hover{background:#000;transform:translateY(-1px);box-shadow:0 8px 24px rgba(0,0,0,.18)}
.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}
.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 2rem;background:transparent;color:var(--charcoal);font-size:.875rem;font-weight:600;letter-spacing:.05em;border-radius:.75rem;transition:all .25s ease;cursor:pointer;border:2px solid var(--charcoal);text-decoration:none;white-space:nowrap}
.btn-outline:hover{background:var(--charcoal);color:#fff;transform:translateY(-1px)}
.btn-luxe{display:inline-flex;align-items:center;justify-content:center;padding:.875rem 2rem;background:var(--luxe-600);color:#fff;font-size:.875rem;font-weight:600;letter-spacing:.05em;border-radius:.75rem;transition:all .25s ease;cursor:pointer;border:none;text-decoration:none}
.btn-luxe:hover{background:var(--luxe-700);transform:translateY(-1px);box-shadow:0 8px 24px rgba(154,102,69,.35)}

/* Nav */
.nav-link{font-size:.875rem;font-weight:500;color:#374151;text-decoration:none;position:relative;padding-bottom:2px;transition:color .2s ease}
.nav-link::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1.5px;background:var(--charcoal);transition:width .3s ease}
.nav-link:hover{color:#111}
.nav-link:hover::after{width:100%}
.logo-text{font-family:'Playfair Display',serif;text-decoration:none}

/* Product Cards */
.product-card{position:relative;background:#fff;border-radius:1.25rem;overflow:hidden;transition:transform .35s ease,box-shadow .35s ease;cursor:pointer}
.product-card:hover{transform:translateY(-6px);box-shadow:0 20px 48px rgba(0,0,0,.12)}
.product-card__image-wrap{position:relative;overflow:hidden;background:var(--luxe-50);aspect-ratio:3/4}
.product-card__image-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.product-card:hover .product-card__image-wrap img{transform:scale(1.06)}
.product-card__actions{position:absolute;bottom:0;left:0;right:0;padding:1rem;background:linear-gradient(to top,rgba(0,0,0,.65) 0%,transparent 100%);transform:translateY(100%);transition:transform .35s ease;display:flex;gap:.5rem}
.product-card:hover .product-card__actions{transform:translateY(0)}
.product-card__wishlist{position:absolute;top:.75rem;right:.75rem;width:2rem;height:2rem;background:white;border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .25s ease,transform .25s ease;border:none;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.12)}
.product-card:hover .product-card__wishlist,.product-card__wishlist.active{opacity:1}
.product-card__wishlist:hover{transform:scale(1.15)}
.product-card__wishlist.wishlisted svg{fill:#ef4444;stroke:#ef4444}
.badge{position:absolute;top:.75rem;left:.75rem;padding:.25rem .625rem;border-radius:999px;font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.badge-sale{background:#ef4444;color:white}
.badge-new{background:var(--charcoal);color:white}
.badge-trending{background:var(--luxe-600);color:white}

/* Stars */
.stars{display:flex;gap:1px}
.star{color:#d1d5db;font-size:.8rem}
.star.filled{color:#f59e0b}

/* Hero */
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease}
.hero-slide.active{opacity:1}

/* Glass */
.glass{background:rgba(255,255,255,.75);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.4);border-radius:1.25rem}
.glass-dark{background:rgba(15,15,15,.7);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:1.25rem}

/* Cart badge */
.cart-badge{min-width:1.1rem;height:1.1rem;padding:0 .2rem;font-size:10px;display:flex;align-items:center;justify-content:center}

/* Toast */
#toast-container{position:fixed;bottom:5rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem}
@media(min-width:768px){#toast-container{bottom:2rem;right:2rem}}
.toast{background:var(--charcoal);color:white;padding:.875rem 1.25rem;border-radius:.875rem;font-size:.875rem;font-weight:500;box-shadow:0 8px 24px rgba(0,0,0,.2);display:flex;align-items:center;gap:.5rem;max-width:320px;animation:toastIn .35s ease forwards}
.toast.success{background:#15803d}
.toast.error{background:#dc2626}
.toast.out{animation:toastOut .35s ease forwards}

/* Animations */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes toastIn{from{opacity:0;transform:translateX(100%) scale(.9)}to{opacity:1;transform:translateX(0) scale(1)}}
@keyframes toastOut{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(100%)}}
@keyframes pulseSoft{0%,100%{transform:scale(1)}50%{transform:scale(1.04)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes slideInRight{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}

.animate-fade-up{animation:fadeUp .6s ease both}
.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.stagger-children>*:nth-child(1){animation-delay:.05s}
.stagger-children>*:nth-child(2){animation-delay:.12s}
.stagger-children>*:nth-child(3){animation-delay:.19s}
.stagger-children>*:nth-child(4){animation-delay:.26s}
.stagger-children>*:nth-child(5){animation-delay:.33s}
.stagger-children>*:nth-child(6){animation-delay:.4s}

/* Skeleton */
.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:.75rem}

/* Product detail */
.thumbnail{aspect-ratio:1;border-radius:.75rem;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:border-color .2s ease,opacity .2s ease;opacity:.65}
.thumbnail.active,.thumbnail:hover{border-color:var(--charcoal);opacity:1}
.thumbnail img{width:100%;height:100%;object-fit:cover}
.size-btn{padding:.5rem 1rem;border:1.5px solid #e5e7eb;border-radius:.625rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;background:white;min-width:3.5rem;text-align:center}
.size-btn:hover{border-color:var(--charcoal)}
.size-btn.active{border-color:var(--charcoal);background:var(--charcoal);color:white}
.size-btn.oos{opacity:.35;cursor:not-allowed;text-decoration:line-through}
.color-btn{width:2rem;height:2rem;border-radius:50%;cursor:pointer;border:2.5px solid transparent;outline:2px solid transparent;transition:all .2s ease}
.color-btn.active{outline:2px solid var(--charcoal);outline-offset:2px}
.zoom-container{position:relative;overflow:hidden;cursor:zoom-in}
.zoom-container img{transition:transform .3s ease;transform-origin:var(--mx,50%) var(--my,50%)}
.zoom-container.zoomed{cursor:zoom-out}
.zoom-container.zoomed img{transform:scale(2)}

/* Urgency */
.urgency-bar{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:#fff7ed;border:1px solid #fed7aa;border-radius:.75rem;font-size:.8125rem;color:#9a3412;font-weight:500}
.viewing-badge{display:inline-flex;align-items:center;gap:.375rem;font-size:.8125rem;color:#16a34a;font-weight:500}
.viewing-dot{width:6px;height:6px;border-radius:50%;background:#16a34a;animation:pulseSoft 1.5s ease-in-out infinite}

/* Trust badges */
.trust-badge{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--luxe-50);border-radius:.875rem;font-size:.8125rem;color:#374151}
.trust-badge svg{color:var(--luxe-600);flex-shrink:0}

/* Sticky ATC */
.sticky-atc{position:fixed;bottom:0;left:0;right:0;z-index:50;background:rgba(255,255,255,.97);backdrop-filter:blur(8px);border-top:1px solid #f0f0f0;padding:.875rem 1rem;transform:translateY(100%);transition:transform .35s ease;padding-bottom:calc(.875rem + env(safe-area-inset-bottom))}
.sticky-atc.visible{transform:translateY(0)}

/* Forms */
.form-input{width:100%;padding:.875rem 1rem;border:1.5px solid #e5e7eb;border-radius:.75rem;font-size:.9375rem;font-family:'DM Sans',sans-serif;transition:border-color .2s ease,box-shadow .2s ease;background:white;outline:none}
.form-input:focus{border-color:var(--charcoal);box-shadow:0 0 0 3px rgba(26,26,26,.08)}
.form-input.error{border-color:#ef4444}
.form-label{display:block;font-size:.8125rem;font-weight:600;color:#374151;margin-bottom:.375rem;letter-spacing:.01em}

/* Checkout steps */
.step-num{width:1.75rem;height:1.75rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;background:#e5e7eb;color:#6b7280;flex-shrink:0}
.step-item.active .step-num{background:var(--charcoal);color:white}
.step-item.done .step-num{background:#16a34a;color:white}

/* Reel slider */
.reel-container{display:flex;gap:1rem;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.reel-container::-webkit-scrollbar{display:none}
.reel-item{flex:0 0 calc(50% - .5rem);scroll-snap-align:start;border-radius:1.25rem;overflow:hidden;position:relative;aspect-ratio:9/16;background:var(--luxe-50)}
@media(min-width:640px){.reel-item{flex:0 0 calc(33.333% - .67rem)}}
@media(min-width:1024px){.reel-item{flex:0 0 calc(20% - .8rem)}}
.reel-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.reel-item:hover img{transform:scale(1.05)}
.reel-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 60%);padding:1.5rem 1rem 1rem;color:white}

/* Testimonials */
.testimonial-card{background:white;border-radius:1.25rem;padding:1.75rem;box-shadow:0 4px 24px rgba(0,0,0,.06);border:1px solid #f3f4f6;transition:transform .3s ease,box-shadow .3s ease}
.testimonial-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,0,0,.1)}

/* Admin */
.admin-sidebar{width:260px;min-height:100vh;background:var(--charcoal);position:fixed;top:0;left:0;z-index:40;overflow-y:auto;transition:transform .3s ease}
.admin-content{margin-left:260px;min-height:100vh;background:#f8f9fa}
@media(max-width:1023px){.admin-sidebar{transform:translateX(-100%)}.admin-sidebar.open{transform:translateX(0)}.admin-content{margin-left:0}}
.admin-nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;color:#9ca3af;font-size:.875rem;font-weight:500;text-decoration:none;border-radius:.625rem;margin:.125rem .75rem;transition:all .2s ease}
.admin-nav-item:hover,.admin-nav-item.active{background:rgba(255,255,255,.1);color:white}
.stat-card{background:white;border-radius:1rem;padding:1.5rem;box-shadow:0 2px 12px rgba(0,0,0,.05);border:1px solid #f0f0f0;transition:transform .2s ease}
.stat-card:hover{transform:translateY(-2px)}
.data-table{width:100%;border-collapse:collapse;font-size:.875rem}
.data-table th{text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#6b7280;padding:.75rem 1rem;border-bottom:1px solid #f0f0f0;white-space:nowrap}
.data-table td{padding:.875rem 1rem;border-bottom:1px solid #f9f9f9;color:#374151;vertical-align:middle}
.data-table tbody tr:hover td{background:#fafafa}
.status-badge{display:inline-flex;align-items:center;padding:.2rem .65rem;border-radius:999px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.status-pending{background:#fef3c7;color:#92400e}
.status-confirmed{background:#dbeafe;color:#1e40af}
.status-processing{background:#ede9fe;color:#5b21b6}
.status-shipped{background:#d1fae5;color:#065f46}
.status-delivered{background:#d1fae5;color:#14532d}
.status-cancelled{background:#fee2e2;color:#991b1b}

/* Misc */
.safe-area-pb{padding-bottom:env(safe-area-inset-bottom)}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:999px}
.spinner{display:inline-block;width:1.25rem;height:1.25rem;border:2.5px solid rgba(255,255,255,.3);border-top-color:white;border-radius:50%;animation:spin .7s linear infinite}
.price-current{font-size:1.125rem;font-weight:700;color:#111}
.price-original{font-size:.875rem;color:#9ca3af;text-decoration:line-through}
.price-discount{font-size:.8125rem;font-weight:700;color:#ef4444;background:#fee2e2;padding:.1rem .4rem;border-radius:.375rem}
.progress-bar{height:4px;background:#e5e7eb;border-radius:999px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--luxe-600),var(--luxe-400));border-radius:999px;transition:width .5s ease}

/* ── Additional components ── */
.section-label { font-size:.75rem; letter-spacing:.15em; text-transform:uppercase; color:var(--luxe-300); font-weight:600; display:block; }
.trust-badge { display:flex; align-items:center; gap:.5rem; padding:.75rem 1rem; background:var(--luxe-50); border-radius:.875rem; font-size:.8125rem; color:#374151; }
.reel-overlay { position:absolute; bottom:0; left:0; right:0; background:linear-gradient(to top,rgba(0,0,0,.7),transparent 60%); padding:1.5rem 1rem 1rem; color:white; }
.testimonial-card { background:white; border-radius:1.25rem; padding:1.75rem; box-shadow:0 4px 24px rgba(0,0,0,.06); border:1px solid #f3f4f6; transition:transform .3s,box-shadow .3s; }
.testimonial-card:hover { transform:translateY(-4px); box-shadow:0 12px 36px rgba(0,0,0,.1); }
.urgency-bar { display:flex; align-items:center; gap:.5rem; padding:.625rem 1rem; background:#fff7ed; border:1px solid #fed7aa; border-radius:.75rem; font-size:.8125rem; color:#9a3412; font-weight:500; }
.viewing-badge { display:inline-flex; align-items:center; gap:.375rem; font-size:.8125rem; color:#16a34a; font-weight:500; }
.viewing-dot { width:6px; height:6px; border-radius:50%; background:#16a34a; animation:pulseSoft 1.5s ease-in-out infinite; }
@keyframes pulseSoft { 0%,100%{transform:scale(1)} 50%{transform:scale(1.04)} }
.sticky-atc { position:fixed; bottom:0; left:0; right:0; z-index:50; background:rgba(255,255,255,.97); backdrop-filter:blur(8px); border-top:1px solid #f0f0f0; padding:.875rem 1rem; transform:translateY(100%); transition:transform .35s ease; padding-bottom:calc(.875rem + env(safe-area-inset-bottom)); }
.sticky-atc.visible { transform:translateY(0); }
.size-btn { padding:.5rem 1rem; border:1.5px solid #e5e7eb; border-radius:.625rem; font-size:.875rem; font-weight:500; cursor:pointer; transition:all .2s; background:white; min-width:3.5rem; text-align:center; }
.size-btn:hover { border-color:var(--charcoal); }
.size-btn.active { border-color:var(--charcoal); background:var(--charcoal); color:white; }
.size-btn.oos { opacity:.35; cursor:not-allowed; text-decoration:line-through; }
.color-btn { width:2rem; height:2rem; border-radius:50%; cursor:pointer; border:2.5px solid transparent; outline:2px solid transparent; transition:all .2s; }
.color-btn.active { outline:2px solid var(--charcoal); outline-offset:2px; }
.zoom-container { position:relative; overflow:hidden; cursor:zoom-in; }
.zoom-container img { transition:transform .3s; transform-origin:var(--mx,50%) var(--my,50%); }
.zoom-container.zoomed { cursor:zoom-out; }
.zoom-container.zoomed img { transform:scale(2); }
.price-current  { font-size:1.125rem; font-weight:700; color:#111; }
.price-original { font-size:.875rem; color:#9ca3af; text-decoration:line-through; }
.price-discount { font-size:.8125rem; font-weight:700; color:#ef4444; background:#fee2e2; padding:.1rem .4rem; border-radius:.375rem; }
.progress-bar  { height:4px; background:#e5e7eb; border-radius:999px; overflow:hidden; }
.progress-fill { height:100%; background:linear-gradient(90deg,var(--luxe-600),var(--luxe-400)); border-radius:999px; transition:width .5s ease; }
.thumbnail { aspect-ratio:1; border-radius:.75rem; overflow:hidden; cursor:pointer; border:2px solid transparent; transition:border-color .2s,opacity .2s; opacity:.65; }
.thumbnail.active, .thumbnail:hover { border-color:var(--charcoal); opacity:1; }
.thumbnail img { width:100%; height:100%; object-fit:cover; }
.line-clamp-2 { display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.safe-area-pb { padding-bottom:env(safe-area-inset-bottom); }
.cart-badge { min-width:1.1rem; height:1.1rem; padding:0 .2rem; font-size:10px; display:flex; align-items:center; justify-content:center; }
.form-label { display:block; font-size:.8125rem; font-weight:600; color:#374151; margin-bottom:.375rem; letter-spacing:.01em; }
.toast.success { background:#16a34a; }
.toast.error   { background:#dc2626; }
.status-badge { display:inline-flex; align-items:center; padding:.2rem .65rem; border-radius:999px; font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; }
.status-pending    { background:#fef3c7; color:#92400e; }
.status-confirmed  { background:#dbeafe; color:#1e40af; }
.status-processing { background:#ede9fe; color:#5b21b6; }
.status-shipped    { background:#d1fae5; color:#065f46; }
.status-delivered  { background:#d1fae5; color:#14532d; }
.status-cancelled  { background:#fee2e2; color:#991b1b; }
