/* ==========================================================
   NIKKAMI AULAAD — Master Stylesheet
   Streetwear aesthetic / Modern Dark / Editorial layout
   Pairs with /assets/css/dynamic.php (CSS variables)
   ========================================================== */

/* ==========================================================
   1. GLOBAL COMPONENTS & HEADER
   ========================================================== */
.announcement-bar {
    background: var(--color-text-primary);
    color: var(--color-background);
    overflow: hidden;
    height: 32px;
    display: flex;
    align-items: center;
    font-family: var(--font-heading);
    font-size: 13px;
    letter-spacing: 2px;
    border-bottom: 1px solid var(--color-border);
}
.announcement-bar__track {
    display: flex;
    gap: 32px;
    white-space: nowrap;
    animation: scroll-marquee 30s linear infinite;
}
@keyframes scroll-marquee {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}

.site-header {
    position: sticky;
    top: 0;
    z-index: var(--z-sticky);
    background: var(--color-background);
    border-bottom: 1px solid var(--color-border);
    transition: box-shadow var(--transition);
}
.site-header--scrolled { box-shadow: 0 4px 20px rgba(0,0,0,0.5); }
.site-header .navbar { padding: 16px 0; }

.brand-logo {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    color: var(--color-text-primary);
}
.brand-logo__mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    background: var(--color-primary);
    color: #fff;
    font-family: var(--font-heading);
    font-size: 16px;
    letter-spacing: 1px;
    border-radius: var(--radius-sm);
    transform: rotate(-3deg);
    transition: transform var(--transition);
}
.brand-logo:hover .brand-logo__mark { transform: rotate(3deg) scale(1.05); }
.brand-logo__text {
    font-family: var(--font-heading);
    font-size: 20px;
    letter-spacing: 2px;
    color: var(--color-text-primary);
}

.navbar-toggler {
    background: transparent;
    border: 1px solid var(--color-border);
    color: var(--color-text-primary);
    font-size: 20px;
}
.navbar-toggler:focus { box-shadow: 0 0 0 2px var(--color-primary); }

.nav-primary .nav-link {
    font-family: var(--font-heading);
    font-size: 15px;
    letter-spacing: 2px;
    color: var(--color-text-secondary);
    padding: 8px 14px !important;
    transition: color var(--transition-fast);
    position: relative;
}
.nav-primary .nav-link:hover,
.nav-primary .nav-link.active { color: var(--color-text-primary); }
.nav-primary .nav-link::after {
    content: '';
    position: absolute;
    left: 14px;
    right: 14px;
    bottom: 0;
    height: 2px;
    background: var(--color-primary);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform var(--transition);
}
.nav-primary .nav-link:hover::after,
.nav-primary .nav-link.active::after { transform: scaleX(1); }
.nav-link--accent { color: var(--color-primary) !important; }

.search-form { position: relative; margin-right: 12px; }
.search-form i {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-text-muted);
    font-size: 14px;
}
.search-form__input {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-pill);
    padding: 8px 16px 8px 36px;
    color: var(--color-text-primary);
    font-size: 14px;
    width: 220px;
    transition: border-color var(--transition-fast), width var(--transition);
}
.search-form__input:focus {
    outline: none;
    border-color: var(--color-primary);
    width: 280px;
}

.nav-icon {
    font-size: 20px;
    padding: 8px 12px !important;
    color: var(--color-text-primary) !important;
    position: relative;
}
.nav-icon:hover { color: var(--color-primary) !important; }
.cart-count {
    position: absolute;
    top: 2px;
    right: 2px;
    background: var(--color-primary);
    color: #fff;
    font-size: 10px;
    font-weight: var(--font-weight-bold);
    min-width: 18px;
    height: 18px;
    border-radius: 9px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 5px;
}

.dropdown-menu,
.account-dropdown {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 8px;
    min-width: 240px;
    box-shadow: var(--shadow-lg);
}
.account-dropdown .dropdown-header { padding: 12px; color: var(--color-text-primary); }
.dropdown-item {
    color: var(--color-text-secondary);
    padding: 10px 12px;
    border-radius: var(--radius);
    font-size: 14px;
    transition: background var(--transition-fast);
}
.dropdown-item:hover, .dropdown-item:focus {
    background: var(--color-surface-alt);
    color: var(--color-text-primary);
}
.account-dropdown .dropdown-item i { width: 20px; color: var(--color-text-muted); }
.account-dropdown .dropdown-divider { border-color: var(--color-border); }

/* ==========================================================
   2. SHARED UI ELEMENTS (Alerts, Pills, Pagination, Headings)
   ========================================================== */
.alert {
    border-radius: var(--radius-md);
    padding: 14px 18px;
    border-width: 1px;
}
.alert-warning { background: rgba(255, 196, 0, 0.1); border-color: var(--color-warning); color: var(--color-warning); }
.alert-danger  { background: rgba(255, 23, 68, 0.1); border-color: var(--color-danger); color: var(--color-danger); }
.alert-success { background: rgba(0, 230, 118, 0.1); border-color: var(--color-success); color: var(--color-success); }
.alert-info    { background: rgba(0, 176, 255, 0.1); border-color: var(--color-info); color: var(--color-info); }

.flash-container {
    position: fixed;
    top: 24px;
    right: 24px;
    z-index: var(--z-toast);
    display: flex;
    flex-direction: column;
    gap: 10px;
    max-width: 380px;
}
.flash-message {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-left: 4px solid var(--color-primary);
    color: var(--color-text-primary);
    padding: 14px 16px;
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
    display: flex;
    align-items: flex-start;
    gap: 12px;
    animation: flash-in 0.4s cubic-bezier(0.2, 0.8, 0.2, 1) backwards;
}
.flash-message--success { border-left-color: var(--color-success); }
.flash-message--error, .flash-message--danger { border-left-color: var(--color-danger); }
.flash-message--warning { border-left-color: var(--color-warning); }
.flash-message--info    { border-left-color: var(--color-info); }
.flash-message__icon { font-size: 20px; flex-shrink: 0; }
.flash-message--success .flash-message__icon { color: var(--color-success); }
.flash-message--error .flash-message__icon, .flash-message--danger .flash-message__icon { color: var(--color-danger); }
.flash-message--warning .flash-message__icon { color: var(--color-warning); }
.flash-message--info .flash-message__icon    { color: var(--color-info); }
.flash-message__text { flex: 1; font-size: 14px; line-height: 1.5; }
.flash-message__close {
    background: transparent;
    border: none;
    color: var(--color-text-muted);
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
    padding: 0;
    margin: -2px 0 0;
}
.flash-message__close:hover { color: var(--color-text-primary); }
.flash-message--leaving { animation: flash-out 0.3s ease-in forwards; }
@keyframes flash-in { from { opacity: 0; transform: translateX(40px); } to { opacity: 1; transform: translateX(0); } }
@keyframes flash-out { to { opacity: 0; transform: translateX(40px); } }

/* Unified Section Heads */
.section-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 24px;
    padding-bottom: 12px;
    border-bottom: 2px solid var(--color-border);
    flex-wrap: wrap;
    gap: 12px;
}
.section-head--center {
    flex-direction: column;
    align-items: center;
    text-align: center;
}
.section-head__title {
    font-family: var(--font-heading);
    font-size: clamp(28px, 4vw, 44px);
    letter-spacing: 2px;
    margin: 0;
    color: var(--color-text-primary);
    line-height: 1;
}
.section-head__sub {
    color: var(--color-text-secondary);
    margin: 0;
    font-size: 14px;
}
.section-head__link {
    font-family: var(--font-heading);
    font-size: 14px;
    letter-spacing: 2px;
    color: var(--color-primary);
    text-decoration: none;
    transition: opacity var(--transition-fast);
}
.section-head__link:hover { opacity: 0.7; }

/* Unified Status Pills */
.status-pill {
    display: inline-block;
    padding: 4px 10px;
    border-radius: var(--radius-pill);
    font-family: var(--font-heading);
    font-size: 11px;
    font-weight: var(--font-weight-semibold);
    letter-spacing: 1px;
    text-transform: uppercase;
    background: var(--color-surface-alt);
    color: var(--color-text-secondary);
    border: 1px solid var(--color-border);
}
.status-pill--active, .status-pill--approved, .status-pill--delivered, .status-pill--completed { 
    background: rgba(0, 230, 118, 0.15); color: var(--color-success); border-color: var(--color-success); 
}
.status-pill--processing, .status-pill--shipped, .status-pill--confirmed, .status-pill--paid, .status-pill--out_for_delivery { 
    background: rgba(0, 176, 255, 0.15); color: var(--color-info); border-color: var(--color-info); 
}
.status-pill--pending { 
    background: rgba(255, 196, 0, 0.15); color: var(--color-warning); border-color: var(--color-warning); 
}
.status-pill--cancelled, .status-pill--returned, .status-pill--failed, .status-pill--out_of_stock, .status-pill--rejected { 
    background: rgba(255, 23, 68, 0.15); color: var(--color-danger); border-color: var(--color-danger); 
}
.status-pill--draft, .status-pill--archived { 
    background: var(--color-surface-alt); color: var(--color-text-muted); border-color: var(--color-border); 
}

/* Unified Pagination */
.pagination-wrap {
    display: flex;
    justify-content: center;
    margin-top: 32px;
}
.pagination {
    list-style: none;
    display: inline-flex;
    gap: 6px;
    padding: 0;
    margin: 0;
}
.page-item .page-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 12px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    color: var(--color-text-primary);
    border-radius: var(--radius);
    text-decoration: none;
    font-family: var(--font-heading);
    letter-spacing: 1px;
    font-size: 14px;
    transition: all var(--transition-fast);
}
.page-item .page-link:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
}
.page-item.active .page-link {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
}
.page-item.disabled .page-link {
    opacity: 0.4;
    cursor: not-allowed;
    pointer-events: none;
}

.text-muted-brand { color: var(--color-text-muted) !important; }
.text-primary-brand { color: var(--color-primary) !important; }
.text-warning { color: var(--color-warning, #FFC400) !important; }
.text-success { color: var(--color-success, #00E676) !important; }
.text-danger  { color: var(--color-danger,  #FF1744) !important; }
.opacity-50 { opacity: 0.5; }

/* ==========================================================
   3. PUBLIC HOME & STATIC PAGES
   ========================================================== */
.hp-hero,
.hp-usp-strip,
.hp-product-grid,
.hp-categories,
.hp-banner-split,
.hp-artists,
.hp-lookbook,
.hp-testimonials,
.hp-video,
.hp-instagram,
.hp-newsletter,
.hp-text-block {
    padding: 56px 0;
}
.hp-usp-strip,
.hp-ticker {
    padding: 28px 0;
}

.hero, .hp-hero {
    position: relative;
    min-height: calc(100vh - 110px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    overflow: hidden;
    background-color: var(--color-surface-alt);
    background-size: cover;
    background-position: center;
    color: #fff;
    border-bottom: 1px solid var(--color-border);
}
.hp-hero { min-height: 600px; padding: 0; }
.hero:not([style*="background-image"]), .hp-hero:not([style*="background-image"]) {
    background: linear-gradient(135deg, #0a0a0a 0%, #1a1a1a 50%, var(--color-primary) 150%);
}
.hero__bg {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 15% 30%, rgba(255, 61, 0, 0.18) 0, transparent 40%),
        radial-gradient(circle at 85% 70%, rgba(0, 229, 255, 0.10) 0, transparent 50%),
        repeating-linear-gradient(45deg, transparent 0, transparent 80px, rgba(255,255,255,0.015) 80px, rgba(255,255,255,0.015) 81px);
    pointer-events: none;
}
.hp-hero__overlay, .hero__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.4);
    z-index: 1;
}
.hero__inner, .hp-hero__inner { position: relative; z-index: 2; width: 100%; }
.hero__inner { padding-bottom: 120px; }
.hp-hero__content { max-width: 720px; }
.hp-hero--center .hp-hero__content { margin: 0 auto; text-align: center; }
.hp-hero--right  .hp-hero__content { margin-left: auto; text-align: right; }

.hero__kicker, .hp-hero__kicker {
    font-family: var(--font-heading);
    font-size: 13px;
    letter-spacing: 4px;
    color: var(--color-primary);
    margin-bottom: 24px;
    opacity: 0;
    animation: fade-up 0.6s 0.1s forwards;
}
.hero__title, .hp-hero__title {
    font-family: var(--font-heading);
    font-size: clamp(48px, 10vw, 120px);
    line-height: 0.9;
    letter-spacing: -1px;
    margin: 0 0 24px;
    color: #fff;
}
.hero__title-line {
    display: block;
    opacity: 0;
    transform: translateY(40px);
    animation: fade-up 0.7s forwards;
}
.hero__title-line:nth-child(1) { animation-delay: 0.15s; }
.hero__title-line:nth-child(2) { animation-delay: 0.3s; }
.hero__title-line:nth-child(3) { animation-delay: 0.45s; }
.hero__title-line--accent { color: var(--color-primary); font-style: italic; transform: translateY(40px) skew(-6deg); }
.hero__title-line--accent.fade-up, .hero__title-line--accent { transform: translateY(40px) skew(-6deg); }
.hero__sub, .hp-hero__subtitle {
    font-size: clamp(16px, 2vw, 20px);
    color: rgba(255, 255, 255, 0.85);
    max-width: 540px;
    margin-bottom: 36px;
    opacity: 0;
    animation: fade-up 0.7s 0.6s forwards;
}
.hp-hero--center .hp-hero__subtitle { margin-left: auto; margin-right: auto; }
.hero__cta, .hp-hero__ctas {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    opacity: 0;
    animation: fade-up 0.7s 0.75s forwards;
}
.hp-hero--center .hp-hero__ctas { justify-content: center; }
.hp-hero--right  .hp-hero__ctas { justify-content: flex-end; }

.hero__marquee {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    overflow: hidden;
    background: var(--color-primary);
    color: #fff;
    padding: 14px 0;
    font-family: var(--font-heading);
    font-size: 18px;
    letter-spacing: 4px;
    z-index: 2;
}
.hero__marquee-track { display: flex; gap: 60px; white-space: nowrap; animation: scroll-marquee 25s linear infinite; }
@keyframes fade-up { to { opacity: 1; transform: translateY(0); } }

/* USP & Ticker */
.hp-usp-strip { background: var(--color-surface); border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.usp-item { display: flex; align-items: center; gap: 12px; padding: 6px; }
.usp-item i { font-size: 32px; color: var(--color-primary); flex-shrink: 0; }
.usp-item__text { line-height: 1.3; }
.usp-item__text strong { font-family: var(--font-heading); font-size: 14px; letter-spacing: 1.5px; color: var(--color-text-primary); display: block; }
.usp-item__text small { color: var(--color-text-muted); font-size: 12px; }

.hp-ticker { background: var(--color-primary); color: #fff; overflow: hidden; white-space: nowrap; }
.hp-ticker__track { display: inline-flex; gap: 24px; animation: ticker-scroll 35s linear infinite; font-family: var(--font-heading); letter-spacing: 2px; font-size: 13px; padding-left: 100%; }
.hp-ticker__dot { opacity: 0.6; }
@keyframes ticker-scroll { from { transform: translateX(0); } to { transform: translateX(-100%); } }

/* Categories & Banners */
.category-tile {
    display: block;
    position: relative;
    aspect-ratio: 4 / 5;
    border-radius: var(--radius-md);
    overflow: hidden;
    text-decoration: none;
    background: var(--color-surface-alt);
}
.category-tile img { width: 100%; height: 100%; object-fit: cover; transition: transform 600ms ease; }
.category-tile:hover img { transform: scale(1.06); }
.category-tile__placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--color-surface-alt), var(--color-background)); }
.category-tile__placeholder span { font-family: var(--font-heading); font-size: 64px; letter-spacing: 4px; color: var(--color-primary); }
.category-tile__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.1) 60%); display: flex; flex-direction: column; justify-content: flex-end; padding: 20px; color: #fff; }
.category-tile__name { font-family: var(--font-heading); font-size: clamp(20px, 2.5vw, 28px); letter-spacing: 2px; margin: 0; color: #fff; }
.category-tile__overlay small { color: rgba(255, 255, 255, 0.7); font-size: 12px; }

.split-banner { display: block; position: relative; aspect-ratio: 16 / 10; background-color: var(--color-surface-alt); background-size: cover; background-position: center; border-radius: var(--radius-md); overflow: hidden; text-decoration: none; }
.split-banner:not([style*="background-image"]) { background: linear-gradient(135deg, var(--color-surface-alt), #2a2a2a); }
.split-banner--alt:not([style*="background-image"]) { background: linear-gradient(135deg, var(--color-primary), #FF6E40); }
.split-banner__overlay { position: absolute; inset: 0; background: linear-gradient(to bottom right, rgba(0,0,0,0.4) 0%, rgba(0,0,0,0.7) 100%); }
.split-banner__content { position: relative; height: 100%; padding: 32px; display: flex; flex-direction: column; justify-content: flex-end; color: #fff; }
.split-banner__kicker { font-family: var(--font-heading); font-size: 11px; letter-spacing: 3px; color: var(--color-primary); margin-bottom: 8px; }
.split-banner--alt .split-banner__kicker { color: #fff; }
.split-banner__title { font-family: var(--font-heading); font-size: clamp(28px, 3.5vw, 44px); letter-spacing: 2px; margin: 0 0 12px; color: #fff; line-height: 1; }
.split-banner__cta { font-family: var(--font-heading); font-size: 13px; letter-spacing: 2px; color: #fff; border-bottom: 2px solid var(--color-primary); padding-bottom: 2px; align-self: flex-start; }

/* Lookbook & Testimonials */
.lookbook-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); grid-auto-rows: 240px; gap: 8px; }
.lookbook-item { overflow: hidden; border-radius: var(--radius-sm); display: block; background: var(--color-surface-alt); }
.lookbook-item:nth-child(5n+1) { grid-row: span 2; }
.lookbook-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 400ms ease; }
.lookbook-item:hover img { transform: scale(1.06); }

.hp-testimonials { background: var(--color-surface); }
.testimonial-card { background: var(--color-background); border: 1px solid var(--color-border); border-radius: var(--radius); padding: 24px; height: 100%; }
.testimonial-card__stars { color: #FFC400; font-size: 18px; letter-spacing: 2px; line-height: 1; margin-bottom: 12px; }
.testimonial-card__title { font-size: 16px; font-weight: 600; margin: 0 0 8px; color: var(--color-text-primary); }
.testimonial-card__text { color: var(--color-text-secondary); font-size: 14px; line-height: 1.6; margin: 0 0 16px; font-style: italic; }
.testimonial-card__footer { padding-top: 12px; border-top: 1px solid var(--color-border); font-size: 13px; }
.testimonial-card__footer strong { color: var(--color-text-primary); }
.testimonial-card__footer .text-success { margin-left: 8px; font-size: 11px; }

/* Instagram & Newsletter */
.instagram-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 4px; }
.ig-item { position: relative; aspect-ratio: 1/1; overflow: hidden; display: block; }
.ig-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 400ms ease; }
.ig-item:hover img { transform: scale(1.08); }
.ig-item__overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.5); color: #fff; display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity 200ms ease; font-size: 32px; }
.ig-item:hover .ig-item__overlay { opacity: 1; }

.hp-newsletter { position: relative; background: linear-gradient(135deg, var(--color-primary) 0%, #FF6E40 100%); background-size: cover; background-position: center; color: #fff; text-align: center; padding: 80px 0; }
.hp-newsletter[style*="background-image"] { background: var(--color-surface-alt); background-size: cover; background-position: center; }
.hp-newsletter__overlay { position: absolute; inset: 0; background: rgba(0, 0, 0, 0.55); }
.hp-newsletter__inner { position: relative; z-index: 1; }
.hp-newsletter__title { font-family: var(--font-heading); font-size: clamp(36px, 5vw, 64px); letter-spacing: 2px; margin: 0 0 12px; color: #fff; }
.hp-newsletter__subtitle { color: rgba(255, 255, 255, 0.9); margin-bottom: 24px; font-size: 16px; max-width: 540px; margin-left: auto; margin-right: auto; }
.hp-newsletter__form { display: flex; gap: 8px; max-width: 480px; margin: 0 auto; flex-wrap: wrap; }
.hp-newsletter__form input { flex: 1; min-width: 240px; }

/* Text blocks & Video */
.hp-text-block--surface { background: var(--color-surface); }
.hp-text-block--primary { background: var(--color-primary); color: #fff; }
.hp-text-block__inner { max-width: 800px; margin: 0 auto; }
.hp-text-block--center { text-align: center; }
.hp-text-block--right  { text-align: right; margin-left: auto; }
.hp-text-block__title { font-family: var(--font-heading); font-size: clamp(28px, 4vw, 44px); letter-spacing: 2px; margin: 0 0 16px; }
.hp-text-block__content { color: var(--color-text-secondary); font-size: 16px; line-height: 1.7; }
.hp-text-block--primary .hp-text-block__content { color: rgba(255, 255, 255, 0.95); }

.video-wrap { position: relative; width: 100%; overflow: hidden; border-radius: var(--radius-md); background: #000; }
.video-wrap iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: 0; }

/* Brand Statement */
.brand-statement { padding: 120px 0; background: var(--color-surface); border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); text-align: center; }
.brand-statement__title { font-family: var(--font-heading); font-size: clamp(48px, 8vw, 100px); line-height: 1; letter-spacing: -1px; margin: 0 0 32px; color: var(--color-text-primary); }
.brand-statement__text { font-size: 18px; color: var(--color-text-secondary); max-width: 640px; margin: 0 auto; line-height: 1.7; }

/* Static Pages */
.static-page { padding: 48px 0; }
.static-page__content { max-width: 760px; margin: 0 auto; color: var(--color-text-primary); font-size: 16px; line-height: 1.75; }
.static-page__content h2, .static-page__content h3 { font-family: var(--font-heading); letter-spacing: 1.5px; color: var(--color-text-primary); margin-top: 32px; margin-bottom: 12px; }
.static-page__content h2 { font-size: 26px; border-bottom: 1px solid var(--color-border); padding-bottom: 8px; }
.static-page__content h3 { font-size: 20px; }
.static-page__content p { margin-bottom: 18px; color: var(--color-text-secondary); }
.static-page__content a { color: var(--color-primary); text-decoration: none; border-bottom: 1px solid transparent; transition: border-color 150ms ease; }
.static-page__content a:hover { border-bottom-color: var(--color-primary); }
.static-page__content ul, .static-page__content ol { margin-bottom: 18px; padding-left: 24px; color: var(--color-text-secondary); }
.static-page__content li { margin-bottom: 6px; }
.static-page__content img { max-width: 100%; height: auto; border-radius: var(--radius); margin: 16px 0; }
.static-page__content code { background: var(--color-surface); color: var(--color-primary); padding: 2px 6px; border-radius: 3px; font-size: 0.9em; }
.static-page__content blockquote { border-left: 3px solid var(--color-primary); padding: 6px 16px; margin: 16px 0; background: var(--color-surface-alt); font-style: italic; color: var(--color-text-secondary); }

/* Footer */
.site-footer { background: var(--color-background); color: var(--color-text-secondary); border-top: 1px solid var(--color-border); padding: 60px 0 24px; }
.footer-newsletter { padding-bottom: 48px; margin-bottom: 48px; border-bottom: 1px solid var(--color-border); }
.footer-newsletter__title { font-family: var(--font-heading); font-size: clamp(36px, 5vw, 56px); letter-spacing: 2px; color: var(--color-text-primary); margin: 0 0 8px; }
.footer-newsletter__text { color: var(--color-text-secondary); margin: 0; }
.footer-newsletter__form { display: flex; gap: 8px; margin-top: 16px; }
.footer-newsletter__form input { background: var(--color-surface); border: 1px solid var(--color-border); color: var(--color-text-primary); padding: 14px 18px; border-radius: var(--radius); font-size: 14px; flex: 1; }
.footer-newsletter__form input:focus { outline: none; border-color: var(--color-primary); }
.footer-grid { padding-bottom: 32px; gap: 32px 0; }
.footer-col__brand { padding-bottom: 24px; }
.footer-tagline { margin: 14px 0 20px; color: var(--color-text-secondary); font-size: 14px; }
.footer-social { display: flex; gap: 16px; }
.footer-social a { width: 40px; height: 40px; border-radius: 50%; border: 1px solid var(--color-border); display: inline-flex; align-items: center; justify-content: center; color: var(--color-text-secondary); font-size: 18px; transition: border-color var(--transition-fast), color var(--transition-fast), background var(--transition-fast); }
.footer-social a:hover { border-color: var(--color-primary); color: #fff; background: var(--color-primary); }
.footer-heading { font-family: var(--font-heading); font-size: 14px; letter-spacing: 3px; color: var(--color-text-primary); margin-bottom: 16px; }
.footer-links { list-style: none; padding: 0; margin: 0; }
.footer-links li { margin-bottom: 10px; }
.footer-links a { color: var(--color-text-secondary); font-size: 14px; text-decoration: none; transition: color var(--transition-fast); }
.footer-links a:hover { color: var(--color-primary); }
.footer-bottom { padding-top: 24px; border-top: 1px solid var(--color-border); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; font-size: 13px; color: var(--color-text-muted); }
.footer-bottom p { margin: 0; }
.footer-payment { display: flex; align-items: center; gap: 10px; }
.footer-payment i { font-size: 18px; }

/* ==========================================================
   4. SHOP & PRODUCT CARDS
   ========================================================== */
.shop-hero { background: var(--color-surface); border-bottom: 1px solid var(--color-border); padding: 60px 0 40px; text-align: left; }
.shop-hero__kicker { font-family: var(--font-heading); font-size: 13px; letter-spacing: 4px; color: var(--color-primary); display: inline-block; margin-bottom: 12px; }
.shop-hero__title { font-family: var(--font-heading); font-size: clamp(48px, 8vw, 96px); line-height: 0.9; letter-spacing: 1px; margin: 0 0 16px; color: var(--color-text-primary); }
.shop-hero__count { color: var(--color-text-secondary); font-size: 15px; margin: 0; }

.shop-page { padding: 40px 0 80px; }
.shop-sidebar { padding-right: 32px; margin-bottom: 32px; }
.filter-form { position: sticky; top: 100px; }
.filter-group { padding: 20px 0; border-bottom: 1px solid var(--color-border); }
.filter-group:first-child { padding-top: 0; }
.filter-group__title { font-family: var(--font-heading); font-size: 13px; letter-spacing: 3px; color: var(--color-text-primary); margin: 0 0 14px; }
.filter-list { list-style: none; padding: 0; margin: 0; }
.filter-list__item { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; color: var(--color-text-secondary); text-decoration: none; font-size: 14px; border-bottom: 1px solid transparent; transition: color var(--transition-fast); }
.filter-list__item:hover { color: var(--color-primary); }
.filter-list__item.is-active { color: var(--color-text-primary); font-weight: var(--font-weight-semibold); }
.filter-list__count { color: var(--color-text-muted); font-size: 12px; background: var(--color-surface-alt); padding: 2px 8px; border-radius: var(--radius-pill); min-width: 28px; text-align: center; }
.filter-form .form-select, .filter-form .form-control { background: var(--color-surface); border: 1px solid var(--color-border); color: var(--color-text-primary); padding: 8px 12px; font-size: 14px; }
.filter-form .form-select:focus, .filter-form .form-control:focus { background: var(--color-surface); border-color: var(--color-primary); color: var(--color-text-primary); box-shadow: 0 0 0 2px rgba(255, 61, 0, 0.2); }

.shop-toolbar { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; padding: 16px 0; margin-bottom: 24px; border-bottom: 1px solid var(--color-border); }
.shop-toolbar__results { color: var(--color-text-secondary); font-size: 14px; }
.shop-toolbar__results strong { color: var(--color-text-primary); }
.shop-toolbar__sort { display: flex; align-items: center; gap: 10px; }
.shop-toolbar__sort label { font-family: var(--font-heading); font-size: 12px; letter-spacing: 2px; color: var(--color-text-muted); margin: 0; }
.shop-toolbar__sort .form-select { background: var(--color-surface); border: 1px solid var(--color-border); color: var(--color-text-primary); min-width: 180px; font-size: 13px; }

/* Product Cards (Unified) */
.product-card {
    display: block;
    color: inherit;
    text-decoration: none;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: transform var(--transition), border-color var(--transition);
    height: 100%;
}
.product-card:hover { transform: translateY(-4px); border-color: var(--color-primary); }
.product-card__media {
    aspect-ratio: 3/4;
    overflow: hidden;
    background: var(--color-surface-alt);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}
.hp-product-grid .product-card__media { aspect-ratio: 1/1; }
.product-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; }
.product-card:hover .product-card__media img { transform: scale(1.05); }
.product-card__placeholder { font-family: var(--font-heading); font-size: 48px; color: var(--color-text-muted); letter-spacing: 4px; }
.product-card__badge {
    position: absolute;
    top: 12px;
    z-index: 2;
    font-family: var(--font-heading);
    font-size: 10px;
    letter-spacing: 1.5px;
    padding: 4px 10px;
    border-radius: var(--radius-pill);
    color: #fff;
}
.product-card__badge--new { left: 12px; background: var(--color-text-primary); color: var(--color-background); }
.product-card__badge--sale { right: 12px; background: var(--color-danger); }
.product-card__badge--best { left: 12px; background: #FFC400; color: #000; }

.product-card__info, .product-card__body { padding: 14px 16px; }
.product-card__name {
    font-family: var(--font-body);
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0 0 6px;
    line-height: 1.3;
    letter-spacing: 0.3px;
    text-transform: uppercase;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Fixed Price Discount Alignment */
.product-card__price {
    display: flex;
    gap: 8px;
    align-items: center;
    flex-wrap: wrap;
    margin-top: 4px;
}
.price-now { font-family: var(--font-heading); font-size: 16px; font-weight: bold; color: var(--color-text-primary); letter-spacing: 1px; }
.price-was { font-size: 12px; color: #999; text-decoration: line-through; }

.product-card__rating { margin-top: 6px; font-size: 12px; color: #FFC400; }
.product-card__rating small { color: var(--color-text-muted); margin-left: 4px; }

.empty-state { text-align: center; padding: 80px 20px; border: 1px dashed var(--color-border); border-radius: var(--radius-md); color: var(--color-text-secondary); }
.empty-state i { font-size: 48px; color: var(--color-text-muted); margin-bottom: 16px; display: inline-block; }
.empty-state p { font-family: var(--font-heading); font-size: 24px; letter-spacing: 2px; color: var(--color-text-primary); margin: 0 0 8px; }
.empty-state small { font-size: 13px; color: var(--color-text-muted); }

/* ==========================================================
   5. PRODUCT DETAILS (Single Page)
   ========================================================== */
.product-detail { padding: 32px 0 80px; }
.breadcrumb-nav { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; font-size: 13px; color: var(--color-text-muted); margin-bottom: 32px; padding: 8px 0; }
.breadcrumb-nav a { color: var(--color-text-secondary); text-decoration: none; transition: color var(--transition-fast); }
.breadcrumb-nav a:hover { color: var(--color-primary); }
.breadcrumb-nav .current { color: var(--color-text-primary); font-weight: var(--font-weight-medium); }

.product-gallery { position: sticky; top: 90px; }
.product-gallery__main {
    position: relative;
    aspect-ratio: auto;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.product-gallery__main img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition); }

/* NEW Bullet Slider */
.product-gallery__bullets {
    position: absolute;
    bottom: 16px;
    left: 0;
    right: 0;
    display: flex;
    justify-content: center;
    gap: 8px;
    z-index: 10;
}
.gallery-bullet {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.4);
    border: 1px solid rgba(0,0,0,0.1);
    cursor: pointer;
    padding: 0;
    transition: all var(--transition-fast);
}
.gallery-bullet:hover { background: rgba(255, 255, 255, 0.8); }
.gallery-bullet.is-active { background: var(--color-primary); border-color: var(--color-primary); transform: scale(1.2); }

.product-info { padding-left: 0; }
.product-info__artist { display: inline-block; font-family: var(--font-heading); font-size: 12px; letter-spacing: 3px; color: var(--color-primary); text-decoration: none; margin-bottom: 12px; }
.product-info__title { font-family: var(--font-heading); font-size: clamp(32px, 4vw, 44px); line-height: 1; letter-spacing: 1px; margin: 0 0 16px; color: var(--color-text-primary); }
.product-info__rating { display: flex; align-items: center; gap: 8px; margin-bottom: 16px; }
.product-info__rating .stars { color: #FFC400; font-size: 18px; }
.product-info__rating .rating-count { color: var(--color-text-muted); font-size: 13px; }

.product-info__price { display: flex; align-items: center; flex-wrap: wrap; gap: 12px; padding: 20px 0; margin: 16px 0; border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.product-info__price .price-now { font-family: var(--font-heading); font-size: 32px; color: var(--color-text-primary); letter-spacing: 1px; font-weight: bold; }
.product-info__price .price-was { font-size: 16px; color: var(--color-text-muted); text-decoration: line-through; }
.product-info__price .price-save { background: var(--color-primary); color: #fff; font-family: var(--font-heading); font-size: 12px; letter-spacing: 2px; padding: 4px 10px; border-radius: 3px; }
.product-info__price small { width: 100%; color: var(--color-text-muted); font-size: 12px; }
.product-info__short { color: var(--color-text-secondary); font-size: 15px; line-height: 1.6; margin-bottom: 24px; }

.variation-picker { margin-bottom: 24px; }
.variation-group { margin-bottom: 20px; }
.variation-group__label { display: block; font-family: var(--font-heading); font-size: 13px; letter-spacing: 2px; color: var(--color-text-secondary); margin-bottom: 10px; }
.variation-group__selected { color: var(--color-text-primary); margin-left: 6px; }
.variation-options { display: flex; flex-wrap: wrap; gap: 8px; }
.variation-option { background: var(--color-surface); border: 2px solid var(--color-border); color: var(--color-text-primary); padding: 10px 18px; min-width: 52px; border-radius: var(--radius); font-family: var(--font-heading); font-size: 13px; letter-spacing: 1px; cursor: pointer; transition: all var(--transition-fast); }
.variation-option:hover { border-color: var(--color-text-secondary); }
.variation-option.is-selected { background: var(--color-text-primary); color: var(--color-background); border-color: var(--color-text-primary); }
.variation-option.is-disabled { opacity: 0.3; cursor: not-allowed; text-decoration: line-through; }
.variation-option--color { width: 38px; height: 38px; min-width: 38px; padding: 0; border-radius: 50%; background: var(--swatch, #888); position: relative; }
.variation-option--color.is-selected { background: var(--swatch, #888); border-color: var(--color-primary); box-shadow: 0 0 0 2px var(--color-background), 0 0 0 4px var(--color-primary); }

.qty-and-cart { display: flex; gap: 12px; align-items: stretch; margin-top: 24px; }
.qty-picker { display: inline-flex; align-items: center; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius); overflow: hidden; }
.qty-btn { width: 42px; height: 100%; background: transparent; border: none; color: var(--color-text-primary); font-size: 18px; cursor: pointer; transition: background var(--transition-fast); }
.qty-btn:hover { background: var(--color-surface-alt); }
.qty-input { width: 50px; background: transparent; border: none; color: var(--color-text-primary); text-align: center; font-family: var(--font-heading); font-size: 16px; -moz-appearance: textfield; }
.qty-input::-webkit-inner-spin-button, .qty-input::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
#addToCartBtn:disabled { opacity: 0.5; cursor: not-allowed; }

#wishlistBtn { border-color: var(--color-border) !important; color: var(--color-text-primary); font-family: var(--font-heading); letter-spacing: 2px; font-size: 13px; }
#wishlistBtn:hover { border-color: var(--color-primary) !important; color: var(--color-primary); background: transparent; }
#wishlistBtn.is-active { background: var(--color-primary); border-color: var(--color-primary) !important; color: #fff; }
#wishlistBtn.is-active i { color: #fff; }

.trust-list { list-style: none; padding: 16px 0; margin: 24px 0; border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.trust-list li { display: flex; align-items: center; gap: 12px; padding: 8px 0; color: var(--color-text-secondary); font-size: 14px; }
.trust-list li i { color: var(--color-primary); font-size: 18px; width: 24px; text-align: center; }

.product-tabs { margin-top: 32px; }
.product-tabs .nav-tabs { border-bottom: 2px solid var(--color-border); margin-bottom: 20px; gap: 0; }
.product-tabs .nav-tabs .nav-link { background: transparent; border: none; border-bottom: 2px solid transparent; color: var(--color-text-muted); font-family: var(--font-heading); font-size: 13px; letter-spacing: 2px; padding: 12px 20px; margin-bottom: -2px; transition: all var(--transition-fast); }
.product-tabs .nav-tabs .nav-link:hover { color: var(--color-text-primary); border-color: transparent; }
.product-tabs .nav-tabs .nav-link.active { background: transparent; color: var(--color-text-primary); border-color: var(--color-primary); }
.product-tabs .tab-content { color: var(--color-text-secondary); line-height: 1.7; font-size: 15px; }
.product-tabs .tab-content p { margin-bottom: 12px; }
.details-list { list-style: none; padding: 0; margin: 0; }
.details-list li { padding: 10px 0; border-bottom: 1px solid var(--color-border); color: var(--color-text-secondary); }
.details-list li:last-child { border-bottom: none; }
.details-list li strong { color: var(--color-text-primary); margin-right: 8px; font-weight: var(--font-weight-medium); }


/* ==========================================================
   6. CART & CHECKOUT
   ========================================================== */
.page-header-block { padding: 48px 0 32px; margin-bottom: 24px; border-bottom: 1px solid var(--color-border); }
.page-kicker { font-family: var(--font-heading); font-size: 13px; letter-spacing: 4px; color: var(--color-primary); display: inline-block; margin-bottom: 12px; }
.page-title { font-family: var(--font-heading); font-size: clamp(48px, 8vw, 80px); line-height: 0.95; letter-spacing: 1px; margin: 0 0 12px; color: var(--color-text-primary); }
.page-sub { color: var(--color-text-secondary); font-size: 15px; margin: 0; }

.cart-page { padding-bottom: 80px; }
.cart-items { display: flex; flex-direction: column; gap: 16px; }
.cart-item { display: grid; grid-template-columns: 110px 1fr auto; gap: 20px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 16px; transition: opacity var(--transition), transform var(--transition); }
.cart-item--unavailable { opacity: 0.6; border-color: var(--color-danger); }
.cart-item--loading { opacity: 0.5; pointer-events: none; }
.cart-item__media { aspect-ratio: 1/1; width: 110px; border-radius: var(--radius); overflow: hidden; background: var(--color-surface-alt); display: flex; align-items: center; justify-content: center; }
.cart-item__media img { width: 100%; height: 100%; object-fit: cover; }
.cart-item__info { display: flex; flex-direction: column; justify-content: center; min-width: 0; }
.cart-item__name { color: var(--color-text-primary); text-decoration: none; font-family: var(--font-body); font-weight: var(--font-weight-semibold); font-size: 16px; text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 8px; line-height: 1.3; }
.cart-item__name:hover { color: var(--color-primary); }
.cart-item__attrs { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 6px; }
.cart-item__attr { font-size: 13px; color: var(--color-text-muted); }
.cart-item__attr strong { color: var(--color-text-secondary); font-weight: var(--font-weight-medium); margin-left: 4px; display: inline-flex; align-items: center; gap: 6px; }
.color-dot { width: 14px; height: 14px; border-radius: 50%; border: 1px solid var(--color-border); display: inline-block; }
.cart-item__sku { font-size: 11px; color: var(--color-text-muted); font-family: monospace; letter-spacing: 0.5px; }
.cart-item__warning { margin-top: 8px; font-size: 12px; color: var(--color-danger); display: flex; align-items: center; gap: 6px; }
.cart-item__warning--soft { color: var(--color-warning); }

.cart-item__controls { display: flex; flex-direction: column; align-items: flex-end; justify-content: space-between; gap: 12px; }
.cart-item__price { text-align: right; }
.cart-item__price strong { display: block; font-family: var(--font-heading); font-size: 20px; color: var(--color-text-primary); letter-spacing: 1px; }
.cart-item__price small { color: var(--color-text-muted); font-size: 11px; }
.cart-item__remove { background: transparent; border: 1px solid var(--color-border); color: var(--color-text-muted); width: 36px; height: 36px; border-radius: 50%; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; transition: all var(--transition-fast); }
.cart-item__remove:hover { border-color: var(--color-danger); color: var(--color-danger); }

.qty-picker--sm { padding: 0; }
.qty-picker--sm .qty-btn { width: 32px; height: 32px; font-size: 14px; }
.qty-picker--sm .qty-input { width: 38px; font-size: 14px; }

.continue-shopping { display: inline-block; margin-top: 24px; color: var(--color-text-secondary); text-decoration: none; font-family: var(--font-heading); font-size: 13px; letter-spacing: 2px; transition: color var(--transition-fast); }
.continue-shopping:hover { color: var(--color-primary); }

.cart-summary { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 24px; position: sticky; top: 90px; }
.cart-summary__title { font-family: var(--font-heading); font-size: 18px; letter-spacing: 2px; margin: 0 0 20px; padding-bottom: 16px; border-bottom: 1px solid var(--color-border); color: var(--color-text-primary); }
.cart-summary__coupon { margin-bottom: 20px; }
.cart-summary__coupon .input-group { display: flex; gap: 0; }
.cart-summary__coupon .form-control { background: var(--color-background); border: 1px solid var(--color-border); border-right: none; border-radius: var(--radius) 0 0 var(--radius); color: var(--color-text-primary); font-family: var(--font-body); text-transform: uppercase; letter-spacing: 1px; }
.cart-summary__coupon .form-control:focus { background: var(--color-background); border-color: var(--color-primary); color: var(--color-text-primary); box-shadow: none; z-index: 2; }
.cart-summary__coupon .btn { border-radius: 0 var(--radius) var(--radius) 0; font-family: var(--font-heading); letter-spacing: 2px; font-size: 12px; padding: 0 16px; }

.coupon-applied { display: flex; justify-content: space-between; align-items: center; background: rgba(0, 230, 118, 0.1); border: 1px dashed var(--color-success); border-radius: var(--radius); padding: 12px 14px; }
.coupon-applied strong { font-family: var(--font-heading); letter-spacing: 1px; color: var(--color-success); display: block; }
.coupon-applied small { font-size: 12px; color: var(--color-text-secondary); }
.coupon-message { margin-top: 8px; font-size: 13px; min-height: 18px; }
.coupon-message--error   { color: var(--color-danger); }
.coupon-message--success { color: var(--color-success); }

.cart-summary__line { display: flex; justify-content: space-between; padding: 10px 0; color: var(--color-text-secondary); font-size: 14px; }
.cart-summary__line span:last-child { color: var(--color-text-primary); font-weight: var(--font-weight-medium); }
.cart-summary__line--discount span:last-child { color: var(--color-success); font-weight: var(--font-weight-semibold); }
.free-tag { color: var(--color-success) !important; font-family: var(--font-heading); letter-spacing: 1px; font-size: 13px; }
.free-shipping-tip { background: rgba(255, 196, 0, 0.1); border: 1px dashed var(--color-warning); color: var(--color-warning); border-radius: var(--radius); padding: 10px 14px; margin: 12px 0; font-size: 13px; text-align: center; }
.free-shipping-tip strong { color: var(--color-warning); }

.cart-summary__total { display: flex; justify-content: space-between; align-items: baseline; padding: 16px 0; margin-top: 12px; border-top: 2px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.cart-summary__total span { font-family: var(--font-heading); font-size: 14px; letter-spacing: 2px; color: var(--color-text-secondary); }
.cart-summary__total strong { font-family: var(--font-heading); font-size: 28px; letter-spacing: 1px; color: var(--color-text-primary); }
#checkoutBtn { margin-top: 16px; font-family: var(--font-heading); letter-spacing: 3px; padding: 16px; font-size: 15px; }

.cart-summary__trust { display: flex; justify-content: space-between; margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--color-border); color: var(--color-text-muted); font-size: 11px; letter-spacing: 1px; }
.cart-summary__trust span { display: inline-flex; align-items: center; gap: 6px; }
.cart-summary__trust i { color: var(--color-success); }

/* Checkout Details */
.checkout-page { padding-bottom: 80px; }
.checkout-steps { display: flex; justify-content: center; gap: 8px; padding: 24px 0; margin-bottom: 32px; border-bottom: 1px solid var(--color-border); flex-wrap: wrap; }
.checkout-step { display: inline-flex; align-items: center; gap: 10px; color: var(--color-text-muted); font-family: var(--font-heading); font-size: 12px; letter-spacing: 2px; padding: 8px 16px; }
.checkout-step__num { width: 28px; height: 28px; border-radius: 50%; background: var(--color-surface-alt); color: var(--color-text-muted); display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--color-border); }
.checkout-step.is-active { color: var(--color-text-primary); }
.checkout-step.is-active .checkout-step__num { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }
.checkout-step.is-done { color: var(--color-success); }
.checkout-step.is-done .checkout-step__num { background: var(--color-success); color: #fff; border-color: var(--color-success); }

.checkout-section { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 24px; margin-bottom: 20px; }
.checkout-section__title { font-family: var(--font-heading); font-size: 18px; letter-spacing: 2px; margin: 0 0 16px; padding-bottom: 12px; border-bottom: 1px solid var(--color-border); }

.checkout-form .form-control, .checkout-form .form-select { background: var(--color-background); border: 1px solid var(--color-border); color: var(--color-text-primary); }
.checkout-form .form-control:focus, .checkout-form .form-select:focus { background: var(--color-background); border-color: var(--color-primary); color: var(--color-text-primary); box-shadow: 0 0 0 3px rgba(255, 61, 0, 0.2); }
.checkout-form .form-label { color: var(--color-text-secondary); font-size: 13px; font-weight: var(--font-weight-medium); margin-bottom: 6px; }

.address-card { background: var(--color-background); border: 2px solid var(--color-border); border-radius: var(--radius); padding: 16px; cursor: pointer; margin-bottom: 12px; transition: border-color var(--transition-fast); }
.address-card:hover { border-color: var(--color-text-secondary); }
.address-card.is-selected { border-color: var(--color-primary); }
.address-card__name { font-weight: var(--font-weight-semibold); color: var(--color-text-primary); margin-bottom: 4px; }
.address-card__lines { color: var(--color-text-secondary); font-size: 14px; line-height: 1.5; }

.payment-methods { display: flex; flex-direction: column; gap: 12px; }
.payment-method { background: var(--color-background); border: 2px solid var(--color-border); border-radius: var(--radius); padding: 16px; cursor: pointer; display: flex; align-items: center; gap: 14px; transition: border-color var(--transition-fast); }
.payment-method:hover { border-color: var(--color-text-secondary); }
.payment-method.is-selected { border-color: var(--color-primary); }
.payment-method input { margin: 0; }
.payment-method__icon { font-size: 24px; color: var(--color-primary); width: 32px; text-align: center; }
.payment-method__title { font-family: var(--font-heading); letter-spacing: 1px; color: var(--color-text-primary); font-size: 14px; }
.payment-method__desc { color: var(--color-text-muted); font-size: 12px; }

.order-confirmed { text-align: center; padding: 60px 20px; }
.order-confirmed__icon { width: 80px; height: 80px; border-radius: 50%; background: var(--color-success); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-size: 40px; margin-bottom: 24px; }
.order-confirmed__title { font-family: var(--font-heading); font-size: clamp(40px, 6vw, 64px); letter-spacing: 1px; margin: 0 0 16px; }
.order-confirmed__num { font-family: var(--font-heading); font-size: 18px; letter-spacing: 2px; color: var(--color-primary); margin-bottom: 20px; }


/* ==========================================================
   7. AUTH & ACCOUNT DASHBOARD
   ========================================================== */
.page-auth { background: var(--color-background); }
.auth-page { min-height: calc(100vh - 200px); padding: 60px 0; display: flex; align-items: center; }
.auth-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 40px; box-shadow: var(--shadow-lg); }
.auth-card__header { margin-bottom: 32px; }
.auth-card__kicker { font-family: var(--font-heading); font-size: 13px; letter-spacing: 3px; color: var(--color-primary); }
.auth-card__title { font-family: var(--font-heading); font-size: clamp(36px, 5vw, 48px); letter-spacing: 1px; color: var(--color-text-primary); margin: 8px 0 12px; }
.auth-card__sub { color: var(--color-text-secondary); font-size: 14px; margin: 0; }
.auth-card__error { background: rgba(255, 23, 68, 0.1); border: 1px solid var(--color-danger); color: var(--color-danger); padding: 12px 16px; border-radius: var(--radius); margin-bottom: 20px; display: flex; align-items: center; gap: 10px; font-size: 14px; }
.auth-form .form-control { background: var(--color-background); border: 1px solid var(--color-border); color: var(--color-text-primary); padding: 1.2rem 0.75rem 0.4rem; height: auto; }
.auth-form .form-floating > label { color: var(--color-text-muted); font-size: 14px; }
.auth-form .form-control:focus { background: var(--color-background); border-color: var(--color-primary); color: var(--color-text-primary); box-shadow: 0 0 0 3px rgba(255, 61, 0, 0.2); }
.auth-form .form-control.is-invalid { border-color: var(--color-danger); }
.auth-form .invalid-feedback { color: var(--color-danger); font-size: 12px; margin-top: 4px; }
.auth-form .form-check-input { background-color: var(--color-background); border-color: var(--color-border); }
.auth-form .form-check-input:checked { background-color: var(--color-primary); border-color: var(--color-primary); }
.auth-form .form-check-label, .auth-form label.form-check { color: var(--color-text-secondary); }
.auth-form__footer { margin-top: 24px; text-align: center; color: var(--color-text-secondary); font-size: 14px; }
.auth-link { color: var(--color-primary); text-decoration: none; font-weight: var(--font-weight-semibold); }
.auth-link:hover { text-decoration: underline; color: var(--color-primary); }
.password-wrap { position: relative; }
.password-toggle { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); background: transparent; border: none; color: var(--color-text-muted); cursor: pointer; padding: 8px; z-index: 4; }
.password-toggle:hover { color: var(--color-text-primary); }

.page-account { background: var(--color-background); }
.account-page { padding: 60px 0; }
.account-welcome { margin-bottom: 48px; }
.account-welcome__kicker { font-family: var(--font-heading); font-size: 13px; letter-spacing: 3px; color: var(--color-primary); }
.account-welcome__title { font-family: var(--font-heading); font-size: clamp(40px, 6vw, 72px); line-height: 0.95; letter-spacing: 1px; margin: 12px 0 16px; }
.account-welcome__sub { color: var(--color-text-secondary); margin: 0; font-size: 16px; }
.stat-row { margin-bottom: 48px; }
.stat-tile { display: block; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 28px; color: var(--color-text-primary); text-decoration: none; position: relative; transition: transform var(--transition), border-color var(--transition); }
.stat-tile:hover { transform: translateY(-4px); border-color: var(--color-primary); color: var(--color-text-primary); }
.stat-tile--accent { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }
.stat-tile__num { font-family: var(--font-heading); font-size: 56px; line-height: 1; letter-spacing: 1px; }
.stat-tile__label { font-family: var(--font-heading); font-size: 13px; letter-spacing: 3px; color: var(--color-text-secondary); margin-top: 8px; }
.stat-tile--accent .stat-tile__label { color: rgba(255,255,255,0.8); }
.stat-tile__arrow { position: absolute; top: 24px; right: 24px; font-size: 20px; color: var(--color-text-muted); transition: transform var(--transition); }
.stat-tile--accent .stat-tile__arrow { color: rgba(255,255,255,0.8); }
.stat-tile:hover .stat-tile__arrow { transform: translateX(6px); }
.account-section { margin-bottom: 48px; }

.orders-table-wrap { overflow-x: auto; border: 1px solid var(--color-border); border-radius: var(--radius-md); }
.orders-table { width: 100%; border-collapse: collapse; background: var(--color-surface); }
.orders-table th { background: var(--color-surface-alt); color: var(--color-text-secondary); font-family: var(--font-heading); font-size: 12px; letter-spacing: 2px; padding: 14px 18px; text-align: left; border-bottom: 1px solid var(--color-border); }
.orders-table td { padding: 16px 18px; color: var(--color-text-primary); font-size: 14px; border-bottom: 1px solid var(--color-border); }
.orders-table tr:last-child td { border-bottom: none; }
.orders-table tr:hover td { background: var(--color-surface-alt); }
.btn-link-accent { color: var(--color-primary); text-decoration: none; font-family: var(--font-heading); font-size: 13px; letter-spacing: 2px; }
.btn-link-accent:hover { color: var(--color-primary); opacity: 0.8; }

.action-card { display: flex; align-items: center; gap: 14px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 20px; color: var(--color-text-primary); text-decoration: none; font-family: var(--font-heading); font-size: 14px; letter-spacing: 2px; transition: border-color var(--transition), transform var(--transition); }
.action-card:hover { border-color: var(--color-primary); transform: translateY(-2px); color: var(--color-text-primary); }
.action-card i { font-size: 22px; color: var(--color-primary); }
.action-card--danger:hover { border-color: var(--color-danger); }
.action-card--danger:hover i { color: var(--color-danger); }

/* ==========================================================
   8. PUBLIC ARTIST PAGES (/artists, /artist-profile)
   ========================================================== */
.page-artists { background: var(--color-background); }
.artist-page { padding: 40px 0 80px; }
.artist-search input { background: var(--color-surface); border: 1px solid var(--color-border); color: var(--color-text-primary); padding: 10px 16px; border-radius: var(--radius-pill); font-size: 14px; width: 100%; }
.artist-search input:focus { outline: none; border-color: var(--color-primary); }

.artist-grid { margin-top: 8px; }
.artist-card { display: block; color: inherit; text-decoration: none; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); overflow: hidden; transition: transform var(--transition), border-color var(--transition); height: 100%; }
.artist-card:hover { transform: translateY(-4px); border-color: var(--color-primary); color: inherit; }
.artist-card__media { aspect-ratio: 4/5; overflow: hidden; background: var(--color-surface-alt); position: relative; display: flex; align-items: center; justify-content: center; }
.artist-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; }
.artist-card:hover .artist-card__media img { transform: scale(1.05); }
.artist-card__placeholder { font-family: var(--font-heading); font-size: 64px; letter-spacing: 4px; background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-surface-alt) 100%); width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; color: #fff; opacity: 0.85; }
.artist-card__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, transparent 50%); display: flex; align-items: flex-end; justify-content: center; padding: 20px; opacity: 0; transition: opacity var(--transition); }
.artist-card:hover .artist-card__overlay { opacity: 1; }
.artist-card__cta { font-family: var(--font-heading); font-size: 13px; letter-spacing: 3px; color: #fff; padding: 10px 16px; background: var(--color-primary); border-radius: var(--radius); }
.artist-card__info { padding: 16px; }
.artist-card__name { font-family: var(--font-heading); font-size: 20px; letter-spacing: 1px; margin: 0 0 6px; color: var(--color-text-primary); }
.artist-card__meta { display: flex; flex-wrap: wrap; gap: 12px; font-size: 12px; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 1px; }
.artist-card__ig i { color: var(--color-primary); }

.artist-cta-band { padding: 80px 0; background: var(--color-surface); border-top: 1px solid var(--color-border); }
.artist-cta-band__inner { display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.artist-cta-band__kicker { font-family: var(--font-heading); font-size: 13px; letter-spacing: 3px; color: var(--color-primary); }
.artist-cta-band__title { font-family: var(--font-heading); font-size: clamp(36px, 6vw, 64px); line-height: 0.95; letter-spacing: 1px; margin: 12px 0 16px; color: var(--color-text-primary); }
.artist-cta-band__text { color: var(--color-text-secondary); max-width: 540px; margin: 0; font-size: 15px; line-height: 1.6; }

.page-artist-profile { background: var(--color-background); }
.artist-hero { padding: 60px 0 50px; border-bottom: 1px solid var(--color-border); background: radial-gradient(circle at 15% 30%, rgba(255, 61, 0, 0.10) 0, transparent 40%), var(--color-background); }
.artist-hero__back { font-family: var(--font-heading); font-size: 13px; letter-spacing: 2px; color: var(--color-text-muted); text-decoration: none; display: inline-block; margin-bottom: 24px; transition: color var(--transition-fast); }
.artist-hero__back:hover { color: var(--color-primary); }
.artist-hero__kicker { font-family: var(--font-heading); font-size: 14px; letter-spacing: 4px; color: var(--color-primary); }
.artist-hero__name { font-family: var(--font-heading); font-size: clamp(56px, 10vw, 140px); line-height: 0.9; letter-spacing: -2px; margin: 8px 0 24px; color: var(--color-text-primary); }
.artist-hero__bio { font-size: 18px; line-height: 1.6; color: var(--color-text-secondary); max-width: 640px; margin: 0 0 24px; }
.artist-hero__meta { display: flex; flex-wrap: wrap; gap: 20px; margin-bottom: 24px; }
.artist-hero__meta-item { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-heading); font-size: 14px; letter-spacing: 2px; color: var(--color-text-secondary); }
.artist-hero__meta-item i { color: var(--color-primary); font-size: 18px; }
.artist-hero__socials { display: flex; flex-wrap: wrap; gap: 12px; }
.artist-hero__social { display: inline-flex; align-items: center; gap: 10px; background: var(--color-surface); border: 1px solid var(--color-border); color: var(--color-text-primary); padding: 10px 18px; border-radius: var(--radius); font-size: 14px; text-decoration: none; transition: border-color var(--transition-fast), color var(--transition-fast); }
.artist-hero__social:hover { border-color: var(--color-primary); color: var(--color-primary); }
.artist-hero__social i { font-size: 18px; }
.artist-hero__mark { aspect-ratio: 1/1; background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-surface) 100%); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; font-family: var(--font-heading); font-size: clamp(80px, 12vw, 180px); letter-spacing: 4px; color: #fff; transform: rotate(-3deg); border: 1px solid var(--color-border); box-shadow: var(--shadow-lg); }
.artist-products { padding: 50px 0 80px; }

/* ==========================================================
   9. BLOG (INDEX, SIDEBAR & POSTS)
   ========================================================== */
.blog-index { padding: 40px 0 60px; }
.blog-search { display: flex; gap: 8px; max-width: 600px; margin: 0 auto 32px; }
.blog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 20px; }
.blog-card { display: block; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); overflow: hidden; text-decoration: none; color: inherit; transition: all 200ms ease; }
.blog-card:hover { transform: translateY(-4px); border-color: var(--color-primary); }
.blog-card__media { position: relative; aspect-ratio: 16 / 10; background: var(--color-surface-alt); overflow: hidden; }
.blog-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 400ms ease; }
.blog-card:hover .blog-card__media img { transform: scale(1.05); }
.blog-card__placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--color-surface-alt), var(--color-background)); color: var(--color-text-muted); font-size: 48px; }
.blog-card__category { position: absolute; top: 12px; left: 12px; background: rgba(0, 0, 0, 0.7); color: #fff; font-family: var(--font-heading); font-size: 10px; letter-spacing: 1.5px; padding: 4px 10px; border-radius: var(--radius-pill); backdrop-filter: blur(8px); }
.blog-card__body { padding: 18px; }
.blog-card__title { font-family: var(--font-heading); font-size: 20px; letter-spacing: 1px; margin: 0 0 8px; color: var(--color-text-primary); line-height: 1.2; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.blog-card__excerpt { color: var(--color-text-secondary); font-size: 14px; line-height: 1.5; margin: 0 0 10px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.blog-card__meta { color: var(--color-text-muted); }

.blog-sidebar__block { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius); padding: 20px; margin-bottom: 20px; }
.blog-sidebar__title { font-family: var(--font-heading); font-size: 14px; letter-spacing: 2px; margin: 0 0 14px; color: var(--color-text-primary); border-bottom: 1px solid var(--color-border); padding-bottom: 8px; }
.blog-sidebar__block ul { list-style: none; padding: 0; margin: 0; }
.blog-sidebar__block ul a { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; color: var(--color-text-secondary); text-decoration: none; border-bottom: 1px solid var(--color-border); transition: color 150ms ease; }
.blog-sidebar__block ul a:last-child { border-bottom: 0; }
.blog-sidebar__block ul a:hover, .blog-sidebar__block ul a.is-active { color: var(--color-primary); }
.blog-sidebar__block ul a span { background: var(--color-surface-alt); padding: 2px 8px; border-radius: var(--radius-pill); font-size: 11px; color: var(--color-text-muted); }

.recent-posts li { border-bottom: 1px solid var(--color-border); padding-bottom: 12px; margin-bottom: 12px; }
.recent-posts li:last-child { border-bottom: 0; margin-bottom: 0; padding-bottom: 0; }
.recent-post { display: flex !important; gap: 10px; padding: 0 !important; border: 0 !important; }
.recent-post img { width: 60px; height: 60px; object-fit: cover; border-radius: var(--radius-sm); flex-shrink: 0; }
.recent-post strong { display: block; font-size: 13px; color: var(--color-text-primary); line-height: 1.3; margin-bottom: 4px; }
.recent-post small { color: var(--color-text-muted); font-size: 11px; }

.tag-cloud { display: flex; flex-wrap: wrap; gap: 6px; }
.tag-pill { display: inline-flex; align-items: center; gap: 4px; background: var(--color-surface-alt); color: var(--color-text-primary); border: 1px solid var(--color-border); padding: 4px 10px; border-radius: var(--radius-pill); font-size: 12px; text-decoration: none; transition: all 150ms ease; }
.tag-pill:hover { border-color: var(--color-primary); color: var(--color-primary); }
.tag-pill span { color: var(--color-text-muted); font-size: 10px; }
.rss-link { display: inline-flex; align-items: center; gap: 6px; color: var(--color-text-secondary); text-decoration: none; font-family: var(--font-heading); letter-spacing: 1.5px; font-size: 13px; }
.rss-link:hover { color: var(--color-primary); }

.blog-post { padding-bottom: 60px; }
.blog-post__hero { position: relative; min-height: 480px; background-color: var(--color-surface-alt); background-size: cover; background-position: center; color: #fff; display: flex; align-items: center; overflow: hidden; margin-bottom: 48px; }
.blog-post__hero:not([style*="background-image"]) { background: linear-gradient(135deg, #0a0a0a, #2a2a2a, var(--color-primary)); }
.blog-post__hero-overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(0,0,0,0.3) 0%, rgba(0,0,0,0.8) 100%); z-index: 1; }
.blog-post__hero-inner { position: relative; z-index: 2; padding: 60px 0; width: 100%; }
.blog-post__category-pill { display: inline-block; background: var(--color-primary); color: #fff; text-decoration: none; font-family: var(--font-heading); letter-spacing: 1.5px; font-size: 11px; padding: 6px 14px; border-radius: var(--radius-pill); margin: 16px 0; }
.blog-post__title { font-family: var(--font-heading); font-size: clamp(36px, 6vw, 72px); letter-spacing: 2px; line-height: 1; margin: 12px 0 16px; color: #fff; max-width: 900px; }
.blog-post__meta { color: rgba(255, 255, 255, 0.7); font-size: 14px; display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.blog-post__lead { font-size: 20px; line-height: 1.5; color: var(--color-text-primary); margin-bottom: 32px; padding-bottom: 24px; border-bottom: 1px solid var(--color-border); font-weight: 500; }
.blog-post__content { color: var(--color-text-primary); font-size: 17px; line-height: 1.8; }
.blog-post__content h2, .blog-post__content h3 { font-family: var(--font-heading); letter-spacing: 1.5px; margin: 40px 0 16px; color: var(--color-text-primary); }
.blog-post__content h2 { font-size: 30px; }
.blog-post__content h3 { font-size: 22px; }
.blog-post__content p { margin-bottom: 22px; color: var(--color-text-secondary); }
.blog-post__content a { color: var(--color-primary); text-decoration: none; border-bottom: 1px solid transparent; transition: border-color 150ms ease; }
.blog-post__content a:hover { border-bottom-color: var(--color-primary); }
.blog-post__content ul, .blog-post__content ol { margin-bottom: 22px; padding-left: 28px; color: var(--color-text-secondary); }
.blog-post__content li { margin-bottom: 8px; }
.blog-post__content img { max-width: 100%; height: auto; border-radius: var(--radius); margin: 24px 0; }
.blog-post__content blockquote { border-left: 3px solid var(--color-primary); padding: 8px 24px; margin: 24px 0; background: var(--color-surface); font-style: italic; color: var(--color-text-primary); font-size: 18px; }
.blog-post__content code { background: var(--color-surface); color: var(--color-primary); padding: 2px 6px; border-radius: 3px; font-size: 0.9em; }
.blog-post__tags { display: flex; flex-wrap: wrap; gap: 8px; margin: 40px 0 24px; padding-top: 24px; border-top: 1px solid var(--color-border); }
.blog-post__share { display: flex; align-items: center; gap: 14px; margin-top: 32px; padding: 16px 0; border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.blog-post__share span { font-family: var(--font-heading); letter-spacing: 2px; font-size: 12px; color: var(--color-text-muted); }
.blog-post__share a { color: var(--color-text-secondary); font-size: 20px; transition: color 150ms ease; }
.blog-post__share a:hover { color: var(--color-primary); }
.blog-related { background: var(--color-surface); padding: 60px 0; margin-top: 60px; border-top: 1px solid var(--color-border); }


/* ==========================================================
   10. ADMIN & ARTIST DASHBOARD
   ========================================================== */
.artist-body { background: var(--color-background); min-height: 100vh; }
.artist-topbar { position: sticky; top: 0; z-index: var(--z-sticky); background: var(--color-surface); border-bottom: 1px solid var(--color-border); display: flex; align-items: center; gap: 12px; padding: 0 20px; height: 60px; }
.artist-topbar__toggle { background: transparent; border: 1px solid var(--color-border); color: var(--color-text-primary); width: 38px; height: 38px; display: none; align-items: center; justify-content: center; font-size: 18px; border-radius: var(--radius); cursor: pointer; }
.artist-topbar__toggle:hover { border-color: var(--color-primary); color: var(--color-primary); }
.artist-topbar__brand { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; color: var(--color-text-primary); }
.artist-topbar__spacer { flex: 1; }
.artist-topbar__viewsite { color: var(--color-text-secondary); text-decoration: none; font-family: var(--font-heading); font-size: 12px; letter-spacing: 2px; padding: 8px 14px; border: 1px solid var(--color-border); border-radius: var(--radius); transition: border-color var(--transition-fast), color var(--transition-fast); }
.artist-topbar__viewsite:hover { border-color: var(--color-primary); color: var(--color-primary); }
.artist-topbar__user { background: transparent; border: 1px solid var(--color-border); color: var(--color-text-primary); padding: 8px 14px; border-radius: var(--radius); display: inline-flex; align-items: center; gap: 8px; cursor: pointer; font-size: 14px; }
.artist-topbar__user:hover { border-color: var(--color-primary); }
.artist-topbar__user i { font-size: 18px; }

.artist-layout { display: grid; grid-template-columns: 260px 1fr; min-height: calc(100vh - 60px); }
.artist-main { background: var(--color-background); min-width: 0; }
.artist-content { padding: 32px 28px; max-width: 1400px; }

.artist-sidebar { background: var(--color-surface); border-right: 1px solid var(--color-border); padding: 24px 0; display: flex; flex-direction: column; position: sticky; top: 60px; height: calc(100vh - 60px); overflow-y: auto; }
.artist-sidebar__head { padding: 0 20px 16px; border-bottom: 1px solid var(--color-border); margin-bottom: 12px; }
.artist-sidebar__title { font-family: var(--font-heading); font-size: 22px; letter-spacing: 1px; margin: 4px 0 8px; color: var(--color-text-primary); line-height: 1.1; word-break: break-word; }
.artist-sidebar__nav { flex: 1; padding: 8px 0; }
.artist-sidebar__nav ul { list-style: none; margin: 0; padding: 0; }
.artist-sidebar__nav li { margin: 2px 0; }
.artist-sidebar__link { display: flex; align-items: center; gap: 14px; padding: 12px 20px; color: var(--color-text-secondary); text-decoration: none; border-left: 3px solid transparent; transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast); font-family: var(--font-heading); letter-spacing: 1.5px; font-size: 14px; }
.artist-sidebar__link i { font-size: 18px; width: 24px; text-align: center; color: var(--color-text-muted); transition: color var(--transition-fast); }
.artist-sidebar__link:hover { background: var(--color-surface-alt); color: var(--color-text-primary); }
.artist-sidebar__link:hover i { color: var(--color-primary); }
.artist-sidebar__link.is-active { border-left-color: var(--color-primary); background: var(--color-surface-alt); color: var(--color-text-primary); }
.artist-sidebar__link.is-active i { color: var(--color-primary); }
.artist-sidebar__link--disabled { cursor: not-allowed; opacity: 0.4; }
.artist-sidebar__link--disabled:hover { background: transparent; color: var(--color-text-secondary); }
.artist-sidebar__footer { border-top: 1px solid var(--color-border); padding-top: 12px; margin-top: 8px; }
.artist-sidebar__public { display: flex; align-items: center; gap: 10px; padding: 10px 20px; color: var(--color-primary); text-decoration: none; font-family: var(--font-heading); font-size: 12px; letter-spacing: 2px; border-left: 3px solid transparent; }
.artist-sidebar__public:hover { background: var(--color-surface-alt); color: var(--color-primary); }
.artist-sidebar__public i { font-size: 16px; }
.artist-sidebar__link--logout { color: var(--color-text-muted); }
.artist-sidebar__link--logout i { color: var(--color-text-muted); }
.artist-sidebar__link--logout:hover { color: var(--color-danger); }
.artist-sidebar__link--logout:hover i { color: var(--color-danger); }

.admin-page-header { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: 16px; margin-bottom: 24px; padding-bottom: 20px; border-bottom: 1px solid var(--color-border); }
.admin-kicker { font-family: var(--font-heading); font-size: 12px; letter-spacing: 3px; color: var(--color-primary); display: block; margin-bottom: 6px; }
.admin-title { font-family: var(--font-heading); font-size: clamp(28px, 4vw, 44px); letter-spacing: 1px; margin: 0 0 6px; line-height: 1; }
.admin-subtitle { color: var(--color-text-secondary); margin: 0; font-size: 14px; }

.admin-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 24px; margin-bottom: 20px; }
.admin-card--sticky { position: sticky; top: 80px; }
.admin-card--accent { border-color: var(--color-primary); background: linear-gradient(135deg, var(--color-surface) 0%, rgba(255, 61, 0, 0.05) 100%); }
.admin-card__title { font-family: var(--font-heading); font-size: 14px; letter-spacing: 2px; margin: 0 0 12px; padding-bottom: 10px; border-bottom: 1px solid var(--color-border); color: var(--color-text-primary); display: flex; align-items: center; gap: 8px; }
.admin-card__title i { color: var(--color-primary); }
.admin-card__sub { color: var(--color-text-muted); font-size: 13px; margin: 0 0 14px; line-height: 1.5; }

.form-section-title { font-family: var(--font-heading); font-size: 12px; letter-spacing: 3px; color: var(--color-primary); margin: 24px 0 12px; padding-top: 16px; border-top: 1px dashed var(--color-border); }
.form-section-title:first-child { border-top: none; padding-top: 0; margin-top: 0; }

.admin-table-wrap { overflow-x: auto; }
.admin-table { width: 100%; border-collapse: collapse; }
.admin-table thead { background: var(--color-surface-alt); }
.admin-table thead th { font-family: var(--font-heading); font-size: 11px; letter-spacing: 2px; color: var(--color-text-secondary); padding: 12px 14px; text-align: left; border-bottom: 1px solid var(--color-border); }
.admin-table tbody td { padding: 12px 14px; color: var(--color-text-primary); font-size: 14px; border-bottom: 1px solid var(--color-border); vertical-align: middle; }
.admin-table tbody tr:last-child td { border-bottom: none; }
.admin-table tbody tr:hover td { background: var(--color-surface-alt); }
.admin-table th { color: var(--color-text-secondary); font-weight: var(--font-weight-medium); }

.admin-thumb { width: 48px; height: 48px; background: var(--color-surface-alt); border-radius: var(--radius); overflow: hidden; display: flex; align-items: center; justify-content: center; }
.admin-thumb img { width: 100%; height: 100%; object-fit: cover; }
.admin-thumb span { font-family: var(--font-heading); font-size: 12px; color: var(--color-text-muted); letter-spacing: 1px; }

.admin-filter-bar { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; margin-bottom: 20px; padding: 16px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius); }
.admin-filter-bar .btn-group .btn { font-family: var(--font-heading); letter-spacing: 1px; font-size: 12px; }

.admin-empty { text-align: center; padding: 60px 20px; border: 1px dashed var(--color-border); border-radius: var(--radius-md); background: var(--color-surface); }
.admin-empty i { font-size: 48px; color: var(--color-text-muted); display: block; margin-bottom: 12px; }
.admin-empty p { font-family: var(--font-heading); font-size: 22px; letter-spacing: 2px; color: var(--color-text-primary); margin: 0 0 6px; }
.admin-empty small { color: var(--color-text-muted); display: block; margin-bottom: 8px; }

.admin-stat { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 20px; text-align: center; transition: border-color var(--transition-fast); }
.admin-stat:hover { border-color: var(--color-primary); }
.admin-stat__num { font-family: var(--font-heading); font-size: clamp(20px, 2.5vw, 32px); letter-spacing: 1px; color: var(--color-text-primary); line-height: 1; margin-bottom: 6px; word-break: break-word; }
.admin-stat__label { font-family: var(--font-heading); font-size: 11px; letter-spacing: 2px; color: var(--color-text-muted); }
.admin-stat--warning { border-left: 3px solid var(--color-warning, #FFC400); border-color: var(--color-warning); }
.admin-stat--warning .admin-stat__num { color: var(--color-warning); }
.admin-stat--success { border-left: 3px solid var(--color-success, #00E676); border-color: var(--color-success); }
.admin-stat--success .admin-stat__num { color: var(--color-success); }
.admin-stat--danger  { border-left: 3px solid var(--color-danger,  #FF1744); border-color: var(--color-danger); }
.admin-stat--danger .admin-stat__num  { color: var(--color-danger); }
.admin-stat--primary { border-left: 3px solid var(--color-primary); border-color: var(--color-primary); }
.admin-stat--primary .admin-stat__num { color: var(--color-primary); }

.checklist { list-style: none; margin: 0 0 16px; padding: 0; }
.checklist li { display: flex; align-items: center; gap: 12px; padding: 10px 0; color: var(--color-text-secondary); border-bottom: 1px solid var(--color-border); }
.checklist li:last-child { border-bottom: none; }
.checklist li i { font-size: 20px; color: var(--color-text-muted); }
.checklist li.is-done { color: var(--color-text-primary); text-decoration: line-through; text-decoration-color: var(--color-text-muted); }
.checklist li.is-done i { color: var(--color-success); }

.product-image-card { background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: var(--radius); padding: 8px; position: relative; }
.product-image-card.is-primary { border-color: var(--color-primary); }
.product-image-card img { width: 100%; aspect-ratio: 1/1; object-fit: cover; border-radius: var(--radius-sm); margin-bottom: 8px; background: var(--color-background); }
.product-image-card .badge { position: absolute; top: 12px; left: 12px; font-size: 10px; letter-spacing: 1px; }

.settings-actions { display: flex; align-items: center; gap: 12px; padding-top: 20px; margin-top: 20px; border-top: 1px solid var(--color-border); }
.page-artist-auth .auth-card__kicker { color: var(--color-primary); }



/* Homepage Editor UI */
.homepage-sections-list { display: flex; flex-direction: column; gap: 8px; margin-top: 16px; }
.hp-section-card { display: flex; align-items: center; gap: 14px; padding: 14px 18px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius); transition: border-color 200ms ease, transform 100ms ease; }
.hp-section-card:hover { border-color: var(--color-text-muted); }
.hp-section-card.is-inactive { opacity: 0.55; background: var(--color-surface-alt); border-style: dashed; }
.hp-section-card--ghost { opacity: 0.4; background: var(--color-primary); }
.hp-section-card__handle { cursor: grab; font-size: 20px; color: var(--color-text-muted); line-height: 1; padding: 4px; }
.hp-section-card__handle:hover { color: var(--color-primary); }
.hp-section-card__handle:active { cursor: grabbing; }
.hp-section-card__order { font-family: var(--font-heading); font-size: 18px; color: var(--color-text-muted); width: 32px; text-align: center; letter-spacing: 1px; }
.hp-section-card__body { flex: 1; min-width: 0; }
.hp-section-card__head { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; }
.hp-section-card__type { font-family: var(--font-heading); font-size: 10px; letter-spacing: 2px; color: var(--color-primary); text-transform: uppercase; }
.hp-section-card__name { color: var(--color-text-primary); font-size: 15px; }
.hp-section-card__preview { display: block; font-size: 12px; margin-top: 2px; }
.hp-section-card__status { flex-shrink: 0; }
.hp-section-card__actions { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }

.reorder-status { position: fixed; bottom: 24px; right: 24px; background: #00E676; color: #000; padding: 10px 18px; border-radius: var(--radius-pill); font-family: var(--font-heading); letter-spacing: 1.5px; font-size: 13px; display: inline-flex; align-items: center; gap: 8px; z-index: 1000; box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3); }

.section-type-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 16px; margin-top: 24px; }
.section-type-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius); padding: 24px 20px; text-align: left; cursor: pointer; transition: all 200ms ease; width: 100%; color: inherit; position: relative; overflow: hidden; }
.section-type-card:hover { border-color: var(--color-primary); transform: translateY(-3px); background: var(--color-surface-alt); }
.section-type-card i { font-size: 36px; color: var(--color-primary); display: block; margin-bottom: 12px; }
.section-type-card strong { display: block; font-family: var(--font-heading); font-size: 14px; letter-spacing: 1.5px; color: var(--color-text-primary); margin-bottom: 6px; }
.section-type-card small { display: block; color: var(--color-text-secondary); font-size: 12px; line-height: 1.5; }
.section-type-card__add { position: absolute; top: 12px; right: 12px; background: var(--color-primary); color: #fff; font-size: 10px; letter-spacing: 1.5px; padding: 4px 10px; border-radius: var(--radius-pill); opacity: 0; transition: opacity 200ms ease; }
.section-type-card:hover .section-type-card__add { opacity: 1; }

.hp-image-preview { width: 100%; aspect-ratio: 16 / 9; border-radius: var(--radius); overflow: hidden; background: var(--color-surface-alt); border: 1px solid var(--color-border); }
.hp-image-preview img { width: 100%; height: 100%; object-fit: cover; display: block; }
.hp-image-preview--small { aspect-ratio: 16 / 10; max-width: 300px; }
.hp-image-placeholder { width: 100%; aspect-ratio: 16 / 9; border: 2px dashed var(--color-border); border-radius: var(--radius); background: var(--color-surface-alt); display: flex; flex-direction: column; align-items: center; justify-content: center; color: var(--color-text-muted); text-align: center; }
.hp-image-placeholder i { font-size: 48px; margin-bottom: 8px; opacity: 0.5; }

.hp-image-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 10px; }
.hp-image-list__item { position: relative; aspect-ratio: 1 / 1; border-radius: var(--radius-sm); overflow: hidden; background: var(--color-surface-alt); }
.hp-image-list__item img { width: 100%; height: 100%; object-fit: cover; }
.hp-image-list__remove { position: absolute; top: 4px; right: 4px; margin: 0; }
.hp-image-list__remove button { background: rgba(0, 0, 0, 0.7); color: #fff; border: none; border-radius: 50%; width: 24px; height: 24px; cursor: pointer; display: flex; align-items: center; justify-content: center; line-height: 1; transition: background 150ms ease; }
.hp-image-list__remove button:hover { background: var(--color-danger, #FF1744); }

.usp-item-row { background: var(--color-surface-alt); border-radius: var(--radius-sm); padding: 12px; margin-bottom: 8px; }

/* ==========================================================
   11. CUSTOMER & ADMIN REVIEWS
   ========================================================== */
.star-picker { display: flex; align-items: center; gap: 4px; }
.star-picker__star { background: transparent; border: none; padding: 4px; cursor: pointer; font-size: 36px; line-height: 1; color: var(--color-border); transition: color 120ms ease, transform 120ms ease; }
.star-picker__star:hover { transform: scale(1.1); }
.star-picker__star.is-active { color: #FFC400; }
.star-picker__label { margin-left: 16px; font-family: var(--font-heading); font-size: 14px; letter-spacing: 2px; color: var(--color-text-secondary); }

.fit-picker { display: flex; gap: 8px; flex-wrap: wrap; }
.fit-picker__option { flex: 1 1 130px; cursor: pointer; }
.fit-picker__option input[type="radio"] { position: absolute; opacity: 0; }
.fit-picker__option span { display: block; text-align: center; padding: 12px 8px; border: 1px solid var(--color-border); border-radius: var(--radius); font-size: 13px; color: var(--color-text-secondary); transition: all var(--transition-fast); }
.fit-picker__option:hover span { border-color: var(--color-text-secondary); color: var(--color-text-primary); }
.fit-picker__option input:checked + span { border-color: var(--color-primary); color: var(--color-primary); background: rgba(255, 61, 0, 0.08); }

.review-tips { list-style: none; padding: 0; margin: 0; font-size: 13px; color: var(--color-text-secondary); }
.review-tips li { padding: 6px 0 6px 22px; position: relative; }
.review-tips li::before { content: '→'; position: absolute; left: 0; color: var(--color-primary); }

.review-product-strip { display: flex; align-items: center; gap: 16px; padding: 14px; background: var(--color-surface-alt); border-radius: var(--radius); }
.review-product-strip img { width: 64px; height: 64px; object-fit: cover; border-radius: var(--radius-sm); }

.review-eligible-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 12px; }
.review-eligible-card { display: flex; gap: 12px; padding: 12px; background: var(--color-surface-alt); border-radius: var(--radius); border: 1px solid var(--color-border); }
.review-eligible-card__media { flex-shrink: 0; width: 72px; height: 72px; border-radius: var(--radius-sm); overflow: hidden; background: var(--color-background); }
.review-eligible-card__media img { width: 100%; height: 100%; object-fit: cover; }
.review-eligible-card__name { margin: 0 0 4px; font-size: 14px; font-weight: 600; }

.my-reviews-list { display: flex; flex-direction: column; gap: 16px; }
.my-review { display: flex; gap: 14px; padding: 14px; background: var(--color-surface-alt); border-radius: var(--radius); border: 1px solid var(--color-border); }
.my-review__media { flex-shrink: 0; width: 80px; height: 80px; border-radius: var(--radius-sm); overflow: hidden; background: var(--color-background); }
.my-review__media img { width: 100%; height: 100%; object-fit: cover; }
.my-review__body { flex: 1; min-width: 0; }
.my-review__head { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 4px; }
.my-review__product { color: var(--color-text-primary); text-decoration: none; font-weight: 600; }
.my-review__product:hover { color: var(--color-primary); }
.my-review__stars { color: #FFC400; font-size: 16px; margin-bottom: 4px; letter-spacing: 2px; }
.my-review__title { margin: 6px 0 4px; font-size: 15px; font-weight: 600; }
.my-review__text { color: var(--color-text-secondary); font-size: 14px; line-height: 1.6; margin: 0; }
.my-review__reply { margin-top: 10px; padding: 10px 12px; background: rgba(255, 61, 0, 0.06); border-left: 3px solid var(--color-primary); border-radius: var(--radius-sm); font-size: 13px; }

.product-reviews-section { padding: 48px 0; border-top: 1px solid var(--color-border); }
.empty-reviews { text-align: center; padding: 60px 20px; color: var(--color-text-muted); }
.empty-reviews i { font-size: 48px; margin-bottom: 12px; opacity: 0.4; }
.empty-reviews p { font-family: var(--font-heading); font-size: 20px; letter-spacing: 2px; margin: 0 0 4px; color: var(--color-text-secondary); }

.review-overall { text-align: center; padding: 24px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius); }
.review-overall__score { font-family: var(--font-heading); font-size: 56px; line-height: 1; color: var(--color-text-primary); }
.review-stars { display: inline-flex; gap: 2px; color: #FFC400; }
.review-stars--large { font-size: 22px; margin: 8px 0; }
.review-stars i { line-height: 1; }

.review-histogram { display: flex; flex-direction: column; gap: 6px; }
.review-histogram__row { display: flex; align-items: center; gap: 10px; text-decoration: none; color: var(--color-text-secondary); padding: 4px 6px; border-radius: var(--radius-sm); transition: background var(--transition-fast); }
.review-histogram__row:hover { background: var(--color-surface-alt); }
.review-histogram__row.is-active { background: rgba(255, 61, 0, 0.08); }
.review-histogram__label { width: 30px; font-size: 13px; color: var(--color-text-primary); }
.review-histogram__bar { flex: 1; height: 8px; background: var(--color-border); border-radius: 4px; overflow: hidden; }
.review-histogram__fill { display: block; height: 100%; background: #FFC400; transition: width 500ms ease; }
.review-histogram__count { width: 30px; text-align: right; font-size: 12px; color: var(--color-text-muted); }

.review-fit { padding: 16px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius); }
.review-fit__title { font-family: var(--font-heading); font-size: 13px; letter-spacing: 2px; margin: 0 0 12px; color: var(--color-text-secondary); }
.review-fit__row { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.review-fit__label { flex: 1; font-size: 12px; color: var(--color-text-primary); }
.review-fit__bar { width: 80px; height: 6px; background: var(--color-border); border-radius: 3px; overflow: hidden; }
.review-fit__fill { display: block; height: 100%; background: var(--color-primary); transition: width 500ms ease; }
.review-fit__pct { width: 36px; text-align: right; font-size: 11px; color: var(--color-text-muted); }
.review-fit--empty .review-fit__title { margin-bottom: 6px; }

.review-toolbar { display: flex; align-items: center; gap: 10px; padding: 12px 16px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius); margin-bottom: 16px; }
.review-toolbar__chip { background: rgba(255, 61, 0, 0.12); color: var(--color-primary); border: 1px solid var(--color-primary); padding: 4px 10px; border-radius: var(--radius-pill); font-size: 12px; display: inline-flex; align-items: center; gap: 6px; }
.review-toolbar__chip a { color: inherit; text-decoration: none; font-weight: bold; }

.review-list { display: flex; flex-direction: column; gap: 16px; }
.review-card { padding: 20px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius); }
.review-card__head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 10px; }
.review-card__author { display: flex; gap: 10px; align-items: center; }
.review-card__avatar { width: 40px; height: 40px; background: var(--color-primary); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--font-heading); font-size: 18px; }
.review-card__name { color: var(--color-text-primary); font-size: 14px; }
.review-card__verified { display: inline-block; background: rgba(0, 230, 118, 0.15); color: var(--color-success, #00E676); font-size: 10px; letter-spacing: 1px; padding: 2px 8px; border-radius: var(--radius-pill); margin-left: 6px; }
.review-card__title { margin: 8px 0 6px; font-size: 16px; font-weight: 600; color: var(--color-text-primary); }
.review-card__text { color: var(--color-text-primary); font-size: 14px; line-height: 1.6; margin: 0 0 8px; }
.review-card__fit { color: var(--color-text-muted); font-size: 12px; display: inline-block; margin-right: 12px; }
.review-card__reply { margin-top: 12px; padding: 10px 14px; background: rgba(255, 61, 0, 0.06); border-left: 3px solid var(--color-primary); border-radius: var(--radius-sm); font-size: 13px; color: var(--color-text-secondary); }
.review-card__reply strong { color: var(--color-primary); display: block; margin-bottom: 4px; }
.review-card__actions { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--color-border); }

.review-helpful-btn { background: transparent; border: 1px solid var(--color-border); color: var(--color-text-secondary); padding: 6px 14px; border-radius: var(--radius-pill); font-size: 12px; cursor: pointer; display: inline-flex; align-items: center; gap: 6px; transition: all var(--transition-fast); }
.review-helpful-btn:hover:not(:disabled) { border-color: var(--color-primary); color: var(--color-primary); }
.review-helpful-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.review-helpful-btn.is-voted { background: rgba(255, 61, 0, 0.08); border-color: var(--color-primary); color: var(--color-primary); }
.review-helpful-btn.is-voting { opacity: 0.5; }

/* Admin moderation */
.row-review-pending { background: linear-gradient(90deg, rgba(255, 196, 0, 0.06) 0%, transparent 30%); border-left: 3px solid var(--color-warning); }
.row-review-pending td:first-child { padding-left: 12px; }
.review-stars-mini { color: #FFC400; font-size: 14px; letter-spacing: 1px; line-height: 1; }
.review-stars-display { color: #FFC400; font-size: 22px; letter-spacing: 2px; line-height: 1; }

.review-detail__title { font-size: 20px; font-weight: 600; margin: 0 0 12px; color: var(--color-text-primary); }
.review-detail__text { color: var(--color-text-primary); font-size: 15px; line-height: 1.7; margin-bottom: 16px; white-space: pre-wrap; }
.review-detail__fit { padding: 10px 14px; background: var(--color-surface-alt); border-radius: var(--radius-sm); font-size: 13px; color: var(--color-text-secondary); display: inline-block; }
.review-detail__fit strong { color: var(--color-text-primary); margin-right: 8px; }
.review-detail__meta { display: flex; flex-wrap: wrap; gap: 16px; font-size: 12px; color: var(--color-text-secondary); }
.review-detail__meta strong { color: var(--color-text-primary); }


/* ==========================================================
   12. MEDIA QUERIES (Consolidated)
   ========================================================== */
@media (max-width: 991px) {
    /* Navbar & Shop */
    .nav-primary { padding: 16px 0; border-top: 1px solid var(--color-border); margin-top: 12px; }
    .nav-primary .nav-link { padding: 10px 0 !important; }
    .nav-secondary { flex-direction: row; padding-top: 12px; border-top: 1px solid var(--color-border); }
    .search-form__input { width: 100%; }
    .shop-sidebar { padding-right: 0; }
    .filter-form { position: static; }
    .product-gallery { position: static; }
    .qty-and-cart { flex-wrap: wrap; }
    .qty-and-cart .btn { flex: 1 1 100%; }
    .qty-picker { width: 100%; justify-content: space-between; }

    /* Admin / Artist Dashboard */
    .artist-topbar__toggle { display: inline-flex; }
    .artist-layout { grid-template-columns: 1fr; }
    .artist-sidebar { position: fixed; top: 60px; left: 0; width: 280px; height: calc(100vh - 60px); z-index: var(--z-fixed); transform: translateX(-100%); transition: transform var(--transition); box-shadow: var(--shadow-lg); }
    .artist-sidebar.is-open { transform: translateX(0); }
    .artist-content { padding: 20px 16px; }
    .admin-card--sticky { position: static; }
}

@media (max-width: 767px) {
    /* General Spacing */
    .hp-hero, .hp-product-grid, .hp-categories, .hp-banner-split, .hp-artists, .hp-lookbook, .hp-testimonials, .hp-video, .hp-instagram, .hp-newsletter, .hp-text-block { padding: 36px 0; }
    .hp-hero { min-height: 460px; }
    .lookbook-grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 180px; }
    .instagram-grid { grid-template-columns: repeat(2, 1fr); }
    
    /* Cart & Checkout */
    .cart-item { grid-template-columns: 80px 1fr; grid-template-rows: auto auto; gap: 12px 14px; }
    .cart-item__media { width: 80px; }
    .cart-item__controls { grid-column: 1 / -1; flex-direction: row; justify-content: space-between; align-items: center; padding-top: 12px; border-top: 1px solid var(--color-border); }
    .cart-summary { position: static; margin-top: 20px; }
    .checkout-steps { gap: 4px; padding: 16px 0; }
    .checkout-step { padding: 6px 8px; font-size: 11px; letter-spacing: 1px; }
    .checkout-step__num { width: 24px; height: 24px; font-size: 12px; }

    /* Artist Profile */
    .artist-hero { padding: 40px 0 32px; }
    .artist-hero__bio { font-size: 16px; }
    .artist-cta-band__inner { flex-direction: column; text-align: center; align-items: stretch; }

    /* Blog */
    .blog-post__hero { min-height: 360px; }
    .blog-grid { grid-template-columns: 1fr; }
    .blog-sidebar { margin-top: 32px; }

    /* Admin Editor & Reports */
    .hp-section-card { flex-wrap: wrap; padding: 12px; }
    .hp-section-card__order { display: none; }
    .hp-section-card__actions { width: 100%; justify-content: flex-end; margin-top: 8px; }
    .section-type-grid { grid-template-columns: 1fr 1fr; }
    .report-date-range { flex-direction: column; align-items: flex-start; }
    .report-date-range__info { margin-left: 0; }

    /* Reviews */
    .review-overall { padding: 16px; }
    .review-overall__score { font-size: 42px; }
    .review-toolbar { flex-direction: column; align-items: stretch; }
    .review-toolbar .ms-auto { margin-left: 0 !important; }
    .review-card { padding: 14px; }
    .review-card__head { flex-direction: column; }
    .review-detail__meta { flex-direction: column; gap: 6px; }
    .review-stars-display { font-size: 18px; }
}

@media (max-width: 575px) {
    /* Global & Auth */
    .auth-card { padding: 28px 22px; }
    .footer-newsletter__form { flex-direction: column; }
    .flash-container { left: 16px; right: 16px; max-width: none; }
    
    /* Shop Elements */
    .shop-toolbar { flex-direction: column; align-items: stretch; }
    .shop-toolbar__sort { justify-content: space-between; }
    .product-info__price .price-now { font-size: 26px; }
    .variation-options { gap: 6px; }
    .variation-option { padding: 8px 14px; font-size: 12px; }

    /* Admin / Artist Dashboard Elements */
    .artist-topbar { padding: 0 12px; }
    .artist-topbar__brand .brand-logo__text { display: none; }
    .admin-page-header { flex-direction: column; align-items: stretch; }
    .admin-stat__num { font-size: 18px; }
    .admin-table tbody td { font-size: 13px; padding: 10px; }
}

/* ==========================================================
   BULLETPROOF FIX: CHECKOUT "YOUR ORDER" SUMMARY
   ========================================================== */

#checkoutSummary .review-item {
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
    padding: 12px 0 !important;
    border-bottom: 1px solid var(--color-border) !important;
}

/* Force the image container to stay exactly 64x64 */
#checkoutSummary .review-item__media {
    width: 64px !important;
    height: 64px !important;
    min-width: 64px !important;
    flex-shrink: 0 !important;
    border-radius: var(--radius-sm) !important;
    overflow: hidden !important;
    background: var(--color-surface-alt) !important;
    border: 1px solid var(--color-border) !important;
}

#checkoutSummary .review-item__media img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
}

#checkoutSummary .review-item__info {
    flex: 1 !important;
    min-width: 0 !important;
}

/* Clean up the typography for the checkout layout */
#checkoutSummary .review-item__name {
    font-family: var(--font-body) !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    color: var(--color-text-primary) !important;
    margin: 0 0 4px !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    text-transform: uppercase !important;
    line-height: 1.3 !important;
}

#checkoutSummary .review-item__meta {
    font-size: 11px !important;
    color: var(--color-text-muted) !important;
    line-height: 1.4 !important;
}

#checkoutSummary .review-item__price {
    font-family: var(--font-heading) !important;
    font-size: 14px !important;
    color: var(--color-text-primary) !important;
    text-align: right !important;
    white-space: nowrap !important;
    align-self: center !important;
    margin: 0 !important;
}
/* ==========================================================
   BULLETPROOF FIX: HOMEPAGE ARTISTS (BOOTSTRAP ALIGNED)
   ========================================================== */

/* 1. Restore Bootstrap's native flexbox row */
.hp-artists .row {
    display: flex !important; 
}

/* 2. Stack the card elements cleanly */
.artist-spotlight-card {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    text-decoration: none !important;
    background: transparent !important;
    border: none !important;
}

/* 3. Force the image container to be a responsive, perfect circle */
.artist-spotlight-card__media {
    width: 100% !important; 
    max-width: 160px !important; /* Prevents it from getting too huge on big screens */
    aspect-ratio: 1 / 1 !important; /* Locks it to a perfect square */
    border-radius: 50% !important; /* Turns the square into a circle */
    overflow: hidden !important;
    position: relative !important;
    margin: 0 auto 16px auto !important; /* Centers it and adds breathing room below */
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: var(--color-surface-alt) !important;
}

/* 4. Keep the image contained inside the circle */
.artist-spotlight-card__media img {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

/* 5. Typography styling */
.artist-spotlight-card__name {
    font-family: var(--font-heading) !important;
    font-size: 16px !important;
    letter-spacing: 2px !important;
    margin: 0 0 4px 0 !important;
    color: var(--color-text-primary) !important;
    text-transform: uppercase !important;
}

.artist-spotlight-card small {
    color: var(--color-text-muted) !important;
    font-size: 12px !important;
    margin: 0 !important;
}
/* ==========================================================
   NIKKAMI AULAAD — Phase 13 Part A CSS PATCH
   APPEND to bottom of /assets/css/style.css
   ========================================================== */

/* ==========================================================
   PINCODE CHIPS (admin shipping zones)
   ========================================================== */
.pincode-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 8px;
}
.pincode-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: var(--color-surface-alt);
    color: var(--color-text-primary);
    border: 1px solid var(--color-border);
    padding: 4px 10px;
    border-radius: var(--radius-pill);
    font-family: var(--font-mono, monospace);
    font-size: 13px;
}
.pincode-chip__remove {
    background: transparent;
    border: 0;
    color: var(--color-text-muted);
    cursor: pointer;
    padding: 0 0 0 4px;
    font-size: 16px;
    line-height: 1;
}
.pincode-chip__remove:hover {
    color: var(--color-danger, #FF1744);
}

/* ==========================================================
   RETURN ELIGIBLE CARDS (customer dashboard)
   ========================================================== */
.return-eligible-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 12px;
}
.return-eligible-card {
    background: var(--color-surface-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 14px;
}
.return-eligible-card__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}
.return-eligible-card__body {
    margin-bottom: 12px;
}

/* ==========================================================
   RETURN ITEM ROWS (request form)
   ========================================================== */
.return-item-row {
    display: flex;
    gap: 14px;
    padding: 14px;
    background: var(--color-surface-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    margin-bottom: 10px;
    cursor: pointer;
    transition: border-color 150ms ease;
}
.return-item-row:hover {
    border-color: var(--color-text-muted);
}
.return-item-row.is-selected {
    border-color: var(--color-primary);
    background: rgba(255, 61, 0, 0.08);
}

.return-item-row__check {
    flex-shrink: 0;
    padding-top: 4px;
}
.return-item-row__media {
    flex-shrink: 0;
    width: 72px;
    height: 72px;
    border-radius: var(--radius-sm);
    overflow: hidden;
    background: var(--color-background);
}
.return-item-row__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.return-item-row__body {
    flex: 1;
    min-width: 0;
}
.return-item-row__price {
    text-align: right;
    font-weight: 600;
}

/* ==========================================================
   REFUND METHOD OPTIONS
   ========================================================== */
.refund-method-option {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    padding: 14px;
    background: var(--color-surface-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    margin-bottom: 10px;
    cursor: pointer;
    transition: border-color 150ms ease;
}
.refund-method-option:hover {
    border-color: var(--color-text-muted);
}
.refund-method-option:has(input:checked) {
    border-color: var(--color-primary);
    background: rgba(255, 61, 0, 0.08);
}
.refund-method-option input[type="radio"] {
    margin-top: 4px;
}
.refund-method-option strong {
    display: block;
    margin-bottom: 4px;
}
.refund-method-option small {
    color: var(--color-text-secondary);
    font-size: 12px;
}

/* ==========================================================
   RETURN STATUS TIMELINE
   ========================================================== */
.return-timeline {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}
.return-timeline__step {
    flex: 1 1 140px;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px;
    background: var(--color-surface-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    opacity: 0.5;
}
.return-timeline__step.is-done {
    opacity: 1;
    border-color: var(--color-success, #00E676);
}
.return-timeline__step.is-current {
    opacity: 1;
    border-color: var(--color-primary);
    background: rgba(255, 61, 0, 0.08);
}
.return-timeline__dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--color-border);
    flex-shrink: 0;
}
.return-timeline__step.is-done .return-timeline__dot {
    background: var(--color-success, #00E676);
}
.return-timeline__step.is-current .return-timeline__dot {
    background: var(--color-primary);
    box-shadow: 0 0 0 4px rgba(255, 61, 0, 0.2);
}
.return-timeline__text {
    flex: 1;
    min-width: 0;
}
.return-timeline__text strong {
    display: block;
    font-family: var(--font-heading);
    font-size: 11px;
    letter-spacing: 1.5px;
}
.return-timeline__text small {
    display: block;
    color: var(--color-text-muted);
    font-size: 11px;
    margin-top: 2px;
}

/* Status pills for returns (new statuses) */
.status-pill--requested  { background: rgba(255, 196, 0, 0.15); color: #FFC400; border: 1px solid #FFC400; }
.status-pill--approved   { background: rgba(0, 176, 255, 0.15); color: #00B0FF; border: 1px solid #00B0FF; }
.status-pill--picked_up  { background: rgba(0, 176, 255, 0.15); color: #00B0FF; border: 1px solid #00B0FF; }
.status-pill--received   { background: rgba(156, 39, 176, 0.15); color: #9C27B0; border: 1px solid #9C27B0; }
.status-pill--refunded   { background: rgba(0, 230, 118, 0.15); color: #00E676; border: 1px solid #00E676; }
.status-pill--rejected   { background: rgba(255, 23, 68, 0.15); color: #FF1744; border: 1px solid #FF1744; }

/* Page header back link */
.back-link {
    display: inline-block;
    color: var(--color-text-muted);
    text-decoration: none;
    font-size: 13px;
    margin-bottom: 8px;
}
.back-link:hover { color: var(--color-primary); }
/* ==========================================================
   NIKKAMI AULAAD — Phase 13 Part B CSS PATCH
   APPEND to bottom of /assets/css/style.css
   ========================================================== */

/* Shiprocket panel on order detail */
.shiprocket-panel {
    border-left: 3px solid var(--color-primary);
}

.shiprocket-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.shiprocket-actions form {
    margin: 0;
}
/* ==========================================================
   NIKKAMI AULAAD — Account Pages CSS PATCH
   Profile / Change Password / Addresses / Wishlist / Track
   APPEND to bottom of /assets/css/style.css
   ========================================================== */

/* ==========================================================
   AVATAR (profile page)
   ========================================================== */
.avatar-preview {
    width: 160px;
    height: 160px;
    margin: 0 auto;
    border-radius: 50%;
    overflow: hidden;
    background: var(--color-surface-alt);
    border: 3px solid var(--color-border);
}
.avatar-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.avatar-preview__placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-heading);
    font-size: 56px;
    letter-spacing: 2px;
    color: var(--color-primary);
    background: linear-gradient(135deg, var(--color-surface-alt), var(--color-background));
}

/* ==========================================================
   PASSWORD STRENGTH (change_password)
   ========================================================== */
.password-strength {
    margin-top: 8px;
}
.password-strength__bar {
    height: 4px;
    width: 0;
    background: var(--color-border);
    border-radius: 2px;
    transition: width 200ms ease, background 200ms ease;
    margin-bottom: 4px;
}
.password-strength__label {
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 11px;
}

/* ==========================================================
   ADDRESS CARDS
   ========================================================== */
.address-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 20px;
    height: 100%;
    transition: border-color 150ms ease;
}
.address-card:hover {
    border-color: var(--color-text-muted);
}
.address-card.is-default {
    border-color: var(--color-primary);
    background: rgba(255, 61, 0, 0.03);
}

.address-card__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--color-border);
}
.address-card__label {
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 13px;
    color: var(--color-text-primary);
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.address-card__label i {
    color: var(--color-primary);
}

.address-card__body strong {
    display: block;
    color: var(--color-text-primary);
    margin-bottom: 6px;
}
.address-card__body p {
    color: var(--color-text-secondary);
    font-size: 14px;
    line-height: 1.5;
    margin-bottom: 8px;
}

.address-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid var(--color-border);
}

/* ==========================================================
   WISHLIST CARDS
   ========================================================== */
.wishlist-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    overflow: hidden;
    height: 100%;
    transition: transform 200ms ease, border-color 200ms ease;
}
.wishlist-card:hover {
    transform: translateY(-3px);
    border-color: var(--color-primary);
}

.wishlist-card__media {
    position: relative;
    aspect-ratio: 1 / 1;
    background: var(--color-surface-alt);
    overflow: hidden;
    display: block;
}
.wishlist-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 400ms ease;
}
.wishlist-card:hover .wishlist-card__media img {
    transform: scale(1.05);
}
.wishlist-card__placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-muted);
    font-size: 48px;
}

.wishlist-card__badge {
    position: absolute;
    top: 10px;
    left: 10px;
    background: var(--color-primary);
    color: #fff;
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 10px;
    padding: 4px 10px;
    border-radius: var(--radius-pill);
    z-index: 2;
}
.wishlist-card__badge--soldout {
    background: var(--color-danger, #FF1744);
}
.wishlist-card__badge--best {
    background: #FFC400;
    color: #000;
}

.wishlist-card__remove {
    position: absolute;
    top: 10px;
    right: 10px;
    margin: 0;
    z-index: 2;
}
.wishlist-card__remove button {
    background: rgba(0, 0, 0, 0.7);
    border: 0;
    color: var(--color-primary);
    width: 36px;
    height: 36px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    backdrop-filter: blur(8px);
    transition: background 150ms ease;
}
.wishlist-card__remove button:hover {
    background: var(--color-primary);
    color: #fff;
}

.wishlist-card__body {
    padding: 14px;
}
.wishlist-card__name {
    margin: 0 0 6px;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.3;
}
.wishlist-card__name a {
    color: var(--color-text-primary);
    text-decoration: none;
}
.wishlist-card__name a:hover {
    color: var(--color-primary);
}
.wishlist-card__price {
    display: flex;
    align-items: baseline;
    gap: 8px;
}
.wishlist-card__price .price {
    font-family: var(--font-heading);
    font-size: 18px;
    color: var(--color-text-primary);
    letter-spacing: 1px;
}
.wishlist-card__price .price-was {
    color: var(--color-text-muted);
    text-decoration: line-through;
    font-size: 13px;
}
.wishlist-card__rating {
    color: #FFC400;
    font-size: 12px;
    display: block;
    margin-top: 4px;
}

/* ==========================================================
   TRACK ORDER TIMELINE
   ========================================================== */
.track-timeline {
    list-style: none;
    padding: 0;
    margin: 16px 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.track-timeline__step {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    background: var(--color-surface-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    opacity: 0.45;
    transition: opacity 200ms ease, border-color 200ms ease;
}
.track-timeline__step.is-done {
    opacity: 1;
    border-color: var(--color-success, #00E676);
}
.track-timeline__step.is-current {
    opacity: 1;
    border-color: var(--color-primary);
    background: rgba(255, 61, 0, 0.08);
}
.track-timeline__dot {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--color-border);
    flex-shrink: 0;
}
.track-timeline__step.is-done .track-timeline__dot {
    background: var(--color-success, #00E676);
}
.track-timeline__step.is-current .track-timeline__dot {
    background: var(--color-primary);
    box-shadow: 0 0 0 5px rgba(255, 61, 0, 0.2);
    animation: pulse-ring 2s ease-out infinite;
}
@keyframes pulse-ring {
    0%   { box-shadow: 0 0 0 5px rgba(255, 61, 0, 0.2); }
    50%  { box-shadow: 0 0 0 8px rgba(255, 61, 0, 0.1); }
    100% { box-shadow: 0 0 0 5px rgba(255, 61, 0, 0.2); }
}
.track-timeline__text {
    flex: 1;
    min-width: 0;
}
.track-timeline__text strong {
    display: block;
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 13px;
}
.track-timeline__text small {
    display: block;
    color: var(--color-text-muted);
    font-size: 11px;
    margin-top: 2px;
}

/* ==========================================================
   RESPONSIVE
   ========================================================== */
@media (max-width: 767px) {
    .address-card__actions {
        flex-direction: column;
    }
    .address-card__actions form,
    .address-card__actions a,
    .address-card__actions button {
        width: 100%;
    }
}
/* ==========================================================
   NIKKAMI AULAAD — Account Orders List CSS PATCH
   APPEND to bottom of /assets/css/style.css
   ========================================================== */

.orders-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.order-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    overflow: hidden;
    transition: border-color 200ms ease, transform 200ms ease;
}
.order-card:hover {
    border-color: var(--color-text-muted);
}

/* Head: order #, date, status pill */
.order-card__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 18px;
    background: var(--color-surface-alt);
    border-bottom: 1px solid var(--color-border);
    gap: 12px;
}
.order-card__head-left {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}
.order-card__head-left strong {
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 14px;
    color: var(--color-text-primary);
}
.order-card__head-left small {
    font-size: 12px;
}
.order-card__head-right {
    flex-shrink: 0;
}

/* Body: thumb + details + total */
.order-card__body {
    display: flex;
    gap: 16px;
    padding: 16px 18px;
    align-items: center;
}

/* Media preview */
.order-card__media {
    position: relative;
    width: 72px;
    height: 72px;
    flex-shrink: 0;
    border-radius: var(--radius-sm);
    overflow: hidden;
    background: var(--color-surface-alt);
}
.order-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.order-card__media-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-muted);
    font-size: 24px;
}
.order-card__media-more {
    position: absolute;
    bottom: 4px;
    right: 4px;
    background: rgba(0, 0, 0, 0.85);
    color: var(--color-primary);
    font-family: var(--font-heading);
    font-size: 11px;
    letter-spacing: 1px;
    padding: 2px 6px;
    border-radius: var(--radius-sm);
    backdrop-filter: blur(4px);
}

/* Details */
.order-card__details {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.order-card__product {
    font-weight: 600;
    color: var(--color-text-primary);
    line-height: 1.3;
    word-break: break-word;
}
.order-card__product small {
    display: inline-block;
    margin-left: 6px;
    font-weight: 400;
}
.order-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    font-size: 12px;
    color: var(--color-text-secondary);
}
.order-card__meta span {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.order-card__meta i {
    color: var(--color-text-muted);
}
.order-card__meta code {
    color: var(--color-text-primary);
    background: var(--color-surface-alt);
    padding: 1px 6px;
    border-radius: 3px;
    font-size: 11px;
}

/* Total */
.order-card__total {
    flex-shrink: 0;
    text-align: right;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.order-card__total small {
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 10px;
    color: var(--color-text-muted);
}
.order-card__total strong {
    font-family: var(--font-heading);
    letter-spacing: 1px;
    font-size: 20px;
    color: var(--color-text-primary);
}

/* Actions */
.order-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 12px 18px;
    border-top: 1px solid var(--color-border);
    background: var(--color-background);
}

/* ==========================================================
   RESPONSIVE
   ========================================================== */
@media (max-width: 767px) {
    .order-card__body {
        flex-wrap: wrap;
    }
    .order-card__total {
        text-align: left;
        margin-left: auto;
    }
    .order-card__meta {
        gap: 10px;
        font-size: 11px;
    }
    .order-card__actions {
        padding: 10px 12px;
    }
    .order-card__actions .btn {
        flex: 1 1 calc(50% - 4px);
        font-size: 11px;
    }
}
/* ==========================================================
   NIKKAMI AULAAD — Mobile-First Header CSS
   APPEND to bottom of /assets/css/style.css
   (Replaces old .navbar / .site-header / .nav-* styles)
   ========================================================== */

/* ==========================================================
   ANNOUNCEMENT BAR
   ========================================================== */
.announcement-bar {
    background: var(--color-primary);
    color: #000;
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 11px;
    padding: 8px 0;
    overflow: hidden;
    position: relative;
}
.announcement-bar__track {
    display: flex;
    gap: 24px;
    white-space: nowrap;
    animation: announcement-scroll 30s linear infinite;
}
@keyframes announcement-scroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}
@media (min-width: 992px) {
    .announcement-bar__track {
        justify-content: center;
        animation: none;
    }
}

/* ==========================================================
   STICKY HEADER
   ========================================================== */
.site-header {
    position: sticky;
    top: 0;
    z-index: 1020;
    background: var(--color-background);
    border-bottom: 1px solid var(--color-border);
    transition: box-shadow 200ms ease;
}
.site-header.is-scrolled {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
}

.header-bar {
    display: flex;
    align-items: center;
    gap: 12px;
    height: 56px;
}
@media (min-width: 992px) {
    .header-bar {
        height: 72px;
        gap: 24px;
    }
}

/* ==========================================================
   BRAND LOGO
   ========================================================== */
.brand-logo {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    color: var(--color-text-primary);
    flex-shrink: 0;
}
.brand-logo:hover { color: var(--color-primary); }

.brand-logo__img {
    max-height: 32px;
    width: auto;
    object-fit: contain;
}
@media (min-width: 992px) {
    .brand-logo__img { max-height: 40px; }
}

.brand-logo__mark {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 22px;
    color: var(--color-primary);
    background: var(--color-text-primary);
    padding: 2px 8px;
    border-radius: var(--radius-sm);
    line-height: 1;
}
.brand-logo__text {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 18px;
    color: var(--color-text-primary);
}
@media (min-width: 992px) {
    .brand-logo__text { font-size: 22px; }
}

/* On mobile, center the logo */
@media (max-width: 991px) {
    .header-bar .brand-logo {
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
    }
}

/* ==========================================================
   DESKTOP NAV (centered links)
   ========================================================== */
.header-nav {
    flex: 1;
    justify-content: center;
    gap: 8px;
    align-items: center;
}

.header-nav__link {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 13px;
    color: var(--color-text-secondary);
    text-decoration: none;
    padding: 8px 14px;
    border-radius: var(--radius-sm);
    transition: color 150ms ease, background 150ms ease;
    white-space: nowrap;
}
.header-nav__link:hover,
.header-nav__link.active {
    color: var(--color-text-primary);
    background: var(--color-surface-alt);
}
.header-nav__link--accent {
    color: var(--color-primary);
}
.header-nav__link--accent:hover {
    color: var(--color-primary);
    background: rgba(255, 61, 0, 0.1);
}

/* ==========================================================
   ICON BUTTONS (mobile menu, search, cart, etc.)
   ========================================================== */
.header-icons {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-left: auto;
}
@media (min-width: 992px) {
    .header-icons { gap: 8px; }
}

.header-icon-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: transparent;
    border: 0;
    color: var(--color-text-primary);
    border-radius: var(--radius-sm);
    cursor: pointer;
    text-decoration: none;
    position: relative;
    transition: background 150ms ease, color 150ms ease;
    padding: 0;
}
.header-icon-btn:hover {
    background: var(--color-surface-alt);
    color: var(--color-primary);
}
.header-icon-btn i {
    font-size: 20px;
    line-height: 1;
}
.header-icon-btn--menu i {
    font-size: 26px;
}

/* Dropdown toggle (remove the default Bootstrap caret) */
.header-icon-btn.dropdown-toggle::after {
    display: none;
}

/* ==========================================================
   BADGES (cart count, wishlist count)
   ========================================================== */
.header-icon-btn--with-badge { position: relative; }

.header-badge {
    position: absolute;
    top: 4px;
    right: 4px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    background: var(--color-primary);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    font-family: var(--font-body);
    border-radius: 9px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    border: 2px solid var(--color-background);
    transition: transform 200ms ease;
}
.header-badge.pulse {
    animation: badge-pulse 500ms ease-out;
}
@keyframes badge-pulse {
    0%   { transform: scale(1); }
    50%  { transform: scale(1.4); }
    100% { transform: scale(1); }
}

/* ==========================================================
   DESKTOP SEARCH BAR
   ========================================================== */
.header-search {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--color-surface-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-pill);
    padding: 0 16px;
    height: 40px;
    width: 240px;
    transition: border-color 150ms ease, width 250ms ease;
}
.header-search:focus-within {
    border-color: var(--color-primary);
    width: 300px;
}
.header-search i {
    color: var(--color-text-muted);
    font-size: 16px;
}
.header-search input {
    background: transparent;
    border: 0;
    color: var(--color-text-primary);
    font-size: 14px;
    flex: 1;
    outline: none;
    padding: 0;
    min-width: 0;
}
.header-search input::placeholder {
    color: var(--color-text-muted);
}

/* ==========================================================
   MOBILE SEARCH PANEL (slides down)
   ========================================================== */
.mobile-search-panel {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--color-background);
    border-bottom: 1px solid var(--color-border);
    padding: 12px 16px;
    transform: translateY(-10px);
    opacity: 0;
    transition: all 200ms ease;
    pointer-events: none;
    z-index: 1010;
}
.mobile-search-panel.is-open {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
}

.mobile-search-form {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--color-surface-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-pill);
    padding: 0 12px;
    height: 44px;
}
.mobile-search-form i { color: var(--color-text-muted); font-size: 18px; }
.mobile-search-form input {
    background: transparent;
    border: 0;
    color: var(--color-text-primary);
    font-size: 15px;
    flex: 1;
    outline: none;
    padding: 0;
    min-width: 0;
}
.mobile-search-form input::placeholder {
    color: var(--color-text-muted);
}
.mobile-search-close {
    background: transparent;
    border: 0;
    color: var(--color-text-muted);
    padding: 4px 8px;
    border-radius: var(--radius-sm);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
}
.mobile-search-close:hover { color: var(--color-primary); }

/* ==========================================================
   ACCOUNT DROPDOWN (desktop)
   ========================================================== */
.account-dropdown {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    min-width: 240px;
    padding: 0;
    border-radius: var(--radius);
    margin-top: 8px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4);
}
.account-dropdown .dropdown-header {
    padding: 14px 16px 10px;
    color: var(--color-text-primary);
    font-weight: 400;
}
.account-dropdown .dropdown-header strong {
    color: var(--color-text-primary);
    font-size: 14px;
}
.account-dropdown .dropdown-divider {
    margin: 4px 0;
    border-color: var(--color-border);
}
.account-dropdown .dropdown-item {
    padding: 10px 16px;
    color: var(--color-text-secondary);
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 10px;
    transition: background 100ms ease, color 100ms ease;
}
.account-dropdown .dropdown-item:hover {
    background: var(--color-surface-alt);
    color: var(--color-primary);
}
.account-dropdown .dropdown-item i {
    width: 18px;
    font-size: 14px;
    color: var(--color-text-muted);
}
.account-dropdown .dropdown-item:hover i {
    color: var(--color-primary);
}
.account-dropdown .dropdown-item--danger {
    color: var(--color-danger, #FF1744);
}
.account-dropdown .dropdown-item--danger:hover {
    background: rgba(255, 23, 68, 0.1);
    color: var(--color-danger, #FF1744);
}

/* ==========================================================
   OFF-CANVAS MOBILE DRAWER
   ========================================================== */
.mobile-drawer {
    background: var(--color-background);
    color: var(--color-text-primary);
    width: 85vw !important;
    max-width: 360px;
    border-right: 1px solid var(--color-border);
}

.mobile-drawer__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px;
    border-bottom: 1px solid var(--color-border);
}

.brand-logo--drawer {
    font-size: 16px;
}

/* Logged-in user mini-card */
.mobile-drawer__user {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px;
    background: var(--color-surface);
    text-decoration: none;
    border-bottom: 1px solid var(--color-border);
    color: var(--color-text-primary);
}
.mobile-drawer__user:hover {
    background: var(--color-surface-alt);
    color: var(--color-text-primary);
}
.mobile-drawer__user-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-primary), #FF6E40);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-heading);
    font-size: 20px;
    flex-shrink: 0;
    overflow: hidden;
}
.mobile-drawer__user-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.mobile-drawer__user-info {
    flex: 1;
    min-width: 0;
}
.mobile-drawer__user-info strong {
    display: block;
    font-size: 14px;
    color: var(--color-text-primary);
}
.mobile-drawer__user-info small {
    color: var(--color-text-muted);
    font-size: 12px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
}
.mobile-drawer__user i {
    color: var(--color-text-muted);
    font-size: 14px;
}

/* Auth CTA (guest) */
.mobile-drawer__auth-cta {
    padding: 16px;
    border-bottom: 1px solid var(--color-border);
}

/* Drawer sections */
.mobile-drawer__section {
    padding: 12px 0;
    border-bottom: 1px solid var(--color-border);
}
.mobile-drawer__section:last-child {
    border-bottom: 0;
}
.mobile-drawer__section-title {
    font-family: var(--font-heading);
    letter-spacing: 2.5px;
    font-size: 11px;
    color: var(--color-text-muted);
    padding: 6px 16px 8px;
    margin: 0;
}

/* Drawer links */
.mobile-drawer__link {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    color: var(--color-text-primary);
    text-decoration: none;
    font-size: 14px;
    transition: background 150ms ease, color 150ms ease;
}
.mobile-drawer__link:hover,
.mobile-drawer__link:focus {
    background: var(--color-surface-alt);
    color: var(--color-primary);
}
.mobile-drawer__link i:first-child {
    font-size: 18px;
    width: 22px;
    color: var(--color-text-muted);
    flex-shrink: 0;
}
.mobile-drawer__link:hover i:first-child,
.mobile-drawer__link--accent i:first-child {
    color: var(--color-primary);
}
.mobile-drawer__link i:last-child {
    font-size: 12px;
    color: var(--color-text-muted);
}

.mobile-drawer__link--accent {
    color: var(--color-primary);
}
.mobile-drawer__link--accent:hover {
    color: var(--color-primary);
}

.mobile-drawer__link--danger {
    color: var(--color-danger, #FF1744);
}
.mobile-drawer__link--danger i {
    color: var(--color-danger, #FF1744) !important;
}
.mobile-drawer__link--danger:hover {
    background: rgba(255, 23, 68, 0.08);
    color: var(--color-danger, #FF1744);
}

.mobile-drawer__badge {
    margin-left: auto;
    background: var(--color-primary);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 10px;
    min-width: 22px;
    text-align: center;
}

/* Drawer footer */
.mobile-drawer__brand-footer {
    margin-top: auto;
    padding: 16px;
    border-top: 1px solid var(--color-border);
    text-align: center;
}
.mobile-drawer__brand-footer small {
    display: block;
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 10px;
    color: var(--color-text-secondary);
    margin-bottom: 4px;
}
.mobile-drawer__brand-footer small:last-child {
    color: var(--color-text-muted);
    letter-spacing: 0.5px;
    font-family: var(--font-body);
}

/* Off-canvas backdrop */
.offcanvas-backdrop {
    background: #000;
}
.offcanvas-backdrop.show {
    opacity: 0.7;
}

/* ==========================================================
   SAFE AREA INSETS (iOS notch)
   ========================================================== */
@supports (padding: env(safe-area-inset-left)) {
    .site-header .container-fluid {
        padding-left: max(16px, env(safe-area-inset-left));
        padding-right: max(16px, env(safe-area-inset-right));
    }
    .mobile-drawer {
        padding-left: env(safe-area-inset-left);
    }
}

/* ==========================================================
   PREVENT BODY SCROLL WHEN DRAWER OPEN
   ========================================================== */
body.offcanvas-active {
    overflow: hidden;
}

/* ==========================================================
   HIDE THE OLD NAVBAR STYLES IF STILL PRESENT (defensive)
   ========================================================== */
.site-header .navbar-toggler,
.site-header .navbar-brand,
.site-header .navbar-nav,
.site-header .nav-primary,
.site-header .nav-secondary {
    /* Nothing to do — old structure is gone in the new header,
       but kept here as a guard against stale CSS conflicts. */
}
/* ==========================================================
   NIKKAMI AULAAD — Footer CSS
   APPEND to bottom of /assets/css/style.css
   ========================================================== */

/* ==========================================================
   NEWSLETTER HERO
   ========================================================== */
.footer-newsletter {
    background: linear-gradient(135deg, var(--color-surface) 0%, var(--color-surface-alt) 100%);
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
    padding: 40px 0;
    position: relative;
    overflow: hidden;
}
.footer-newsletter::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -10%;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(255, 61, 0, 0.08), transparent 70%);
    pointer-events: none;
}
@media (min-width: 768px) {
    .footer-newsletter { padding: 60px 0; }
}

.footer-newsletter__inner {
    display: flex;
    flex-direction: column;
    gap: 24px;
    position: relative;
    z-index: 2;
}
@media (min-width: 992px) {
    .footer-newsletter__inner {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: 48px;
    }
}

.footer-newsletter__copy { flex: 1; min-width: 0; }
.footer-newsletter__kicker {
    display: inline-block;
    font-family: var(--font-heading);
    letter-spacing: 3px;
    font-size: 11px;
    color: var(--color-primary);
    margin-bottom: 8px;
}
.footer-newsletter__title {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 32px;
    margin: 0 0 8px;
    color: var(--color-text-primary);
    line-height: 1;
}
@media (min-width: 768px) {
    .footer-newsletter__title { font-size: 48px; }
}
.footer-newsletter__text {
    color: var(--color-text-secondary);
    font-size: 14px;
    margin: 0;
    max-width: 500px;
}
.footer-newsletter__text strong { color: var(--color-primary); }

/* Form */
.footer-newsletter__form {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
    max-width: 460px;
    position: relative;
}
@media (min-width: 480px) {
    .footer-newsletter__form { flex-direction: row; }
}
.footer-newsletter__field {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1;
    background: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-pill);
    padding: 0 18px;
    height: 50px;
    transition: border-color 150ms ease;
}
.footer-newsletter__field:focus-within {
    border-color: var(--color-primary);
}
.footer-newsletter__field i {
    color: var(--color-text-muted);
    font-size: 16px;
}
.footer-newsletter__field input {
    background: transparent;
    border: 0;
    color: var(--color-text-primary);
    font-size: 14px;
    flex: 1;
    outline: none;
    min-width: 0;
    padding: 0;
}
.footer-newsletter__field input::placeholder { color: var(--color-text-muted); }
.footer-newsletter__btn {
    height: 50px;
    border-radius: var(--radius-pill);
    padding: 0 24px;
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 13px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    white-space: nowrap;
    flex-shrink: 0;
}
.footer-newsletter__btn i { font-size: 14px; }

/* Feedback */
.footer-newsletter__feedback {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    padding: 10px 14px;
    border-radius: var(--radius-sm);
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 8px;
    animation: slide-down 250ms ease-out;
}
@keyframes slide-down {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}
.footer-newsletter__feedback--success {
    background: rgba(0, 230, 118, 0.1);
    color: var(--color-success, #00E676);
    border: 1px solid rgba(0, 230, 118, 0.3);
}
.footer-newsletter__feedback--error {
    background: rgba(255, 23, 68, 0.1);
    color: var(--color-danger, #FF1744);
    border: 1px solid rgba(255, 23, 68, 0.3);
}

/* ==========================================================
   MAIN FOOTER
   ========================================================== */
.site-footer {
    background: var(--color-background);
    color: var(--color-text-secondary);
    padding: 40px 0 20px;
}
@media (min-width: 768px) {
    .site-footer { padding: 60px 0 24px; }
}

.footer-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}
@media (min-width: 768px) {
    .footer-grid {
        grid-template-columns: 1.5fr 1fr 1fr 1fr;
        gap: 32px;
        margin-bottom: 40px;
    }
}
@media (min-width: 992px) {
    .footer-grid {
        grid-template-columns: 2fr 1fr 1fr 1fr;
        gap: 48px;
    }
}

/* Brand column */
.footer-col--brand .brand-logo {
    margin-bottom: 14px;
}
.footer-tagline {
    color: var(--color-text-secondary);
    font-size: 14px;
    line-height: 1.5;
    margin: 0 0 18px;
    max-width: 320px;
}

/* Social */
.footer-social {
    display: flex;
    gap: 10px;
    margin-bottom: 18px;
}
.footer-social__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border: 1px solid var(--color-border);
    border-radius: 50%;
    color: var(--color-text-secondary);
    text-decoration: none;
    transition: all 200ms ease;
    position: relative;
}
.footer-social__link::before {
    content: '';
    position: absolute;
    inset: -3px;
    border-radius: 50%;
    border: 2px solid transparent;
    transition: border-color 200ms ease;
    pointer-events: none;
}
.footer-social__link:hover {
    color: var(--color-primary);
    border-color: var(--color-primary);
    transform: translateY(-2px);
}
.footer-social__link:hover::before {
    border-color: rgba(255, 61, 0, 0.3);
}
.footer-social__link i { font-size: 16px; }

/* Contact items */
.footer-contact {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.footer-contact__item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--color-text-secondary);
    text-decoration: none;
    font-size: 13px;
    transition: color 150ms ease;
}
.footer-contact__item:hover { color: var(--color-primary); }
.footer-contact__item i { font-size: 13px; color: var(--color-primary); }

/* Link columns */
.footer-col--links { min-width: 0; }

.footer-heading {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 14px;
    color: var(--color-text-primary);
    background: transparent;
    border: 0;
    padding: 16px 0;
    margin: 0;
    text-align: left;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
    border-bottom: 1px solid var(--color-border);
}
@media (min-width: 768px) {
    .footer-heading {
        padding: 0;
        margin-bottom: 18px;
        cursor: default;
        border-bottom: 0;
    }
}
.footer-heading__chevron {
    transition: transform 250ms ease;
    font-size: 14px;
    color: var(--color-text-muted);
}
@media (min-width: 768px) {
    .footer-heading__chevron { display: none; }
}
.footer-heading[aria-expanded="true"] .footer-heading__chevron {
    transform: rotate(180deg);
}

/* Mobile accordion */
.footer-links {
    list-style: none;
    padding: 0;
    margin: 0;
    max-height: 0;
    overflow: hidden;
    transition: max-height 300ms ease;
}
.footer-links.is-open {
    max-height: 400px;
    padding: 8px 0 16px;
}
@media (min-width: 768px) {
    .footer-links {
        max-height: none;
        padding: 0;
        overflow: visible;
    }
}

.footer-links li { margin: 0; }
.footer-links a {
    display: block;
    color: var(--color-text-secondary);
    text-decoration: none;
    font-size: 14px;
    padding: 6px 0;
    transition: color 150ms ease, padding-left 150ms ease;
}
.footer-links a:hover {
    color: var(--color-primary);
    padding-left: 4px;
}

/* ==========================================================
   TRUST STRIP
   ========================================================== */
.footer-trust {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    padding: 24px 0;
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
    margin: 24px 0;
}
@media (min-width: 768px) {
    .footer-trust {
        grid-template-columns: repeat(4, 1fr);
        gap: 24px;
        padding: 32px 0;
        margin: 40px 0 32px;
    }
}

.footer-trust__item {
    display: flex;
    align-items: center;
    gap: 12px;
}
.footer-trust__item i {
    font-size: 24px;
    color: var(--color-primary);
    flex-shrink: 0;
}
.footer-trust__item strong {
    display: block;
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 12px;
    color: var(--color-text-primary);
    line-height: 1.2;
}
.footer-trust__item small {
    display: block;
    color: var(--color-text-muted);
    font-size: 11px;
    margin-top: 2px;
    line-height: 1.3;
}

/* ==========================================================
   FOOTER BOTTOM
   ========================================================== */
.footer-bottom {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding-top: 8px;
}
@media (min-width: 768px) {
    .footer-bottom {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }
}
.footer-bottom__copyright {
    color: var(--color-text-muted);
    font-size: 12px;
    margin: 0;
}
.footer-bottom__made {
    display: block;
    margin-top: 4px;
    color: var(--color-text-muted);
}
@media (min-width: 768px) {
    .footer-bottom__made {
        display: inline-block;
        margin-left: 16px;
        margin-top: 0;
    }
    .footer-bottom__made::before {
        content: '·';
        margin-right: 16px;
        color: var(--color-text-muted);
    }
}

/* Payment pills */
.footer-payments {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.footer-payments__label {
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 10px;
    color: var(--color-text-muted);
}
.footer-payments__icons {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}
.footer-payment-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--color-surface-alt);
    border: 1px solid var(--color-border);
    color: var(--color-text-secondary);
    font-family: var(--font-body);
    font-size: 10px;
    font-weight: 700;
    padding: 4px 9px;
    border-radius: var(--radius-sm);
    letter-spacing: 0.5px;
    transition: border-color 150ms ease, color 150ms ease;
}
.footer-payment-pill:hover {
    border-color: var(--color-primary);
    color: var(--color-text-primary);
}
.footer-payment-pill--cod {
    background: rgba(255, 196, 0, 0.1);
    border-color: rgba(255, 196, 0, 0.4);
    color: #FFC400;
}

/* ==========================================================
   BACK TO TOP BUTTON
   ========================================================== */
.back-to-top {
    position: fixed;
    bottom: 24px;
    right: 24px;
    width: 48px;
    height: 48px;
    background: var(--color-primary);
    color: #fff;
    border: 0;
    border-radius: 50%;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    box-shadow: 0 8px 20px rgba(255, 61, 0, 0.35);
    z-index: 1000;
    opacity: 0;
    transform: translateY(10px);
    transition: all 250ms cubic-bezier(0.22, 1, 0.36, 1);
}
.back-to-top.is-visible {
    opacity: 1;
    transform: translateY(0);
}
.back-to-top:hover {
    transform: translateY(-3px) scale(1.05);
    box-shadow: 0 12px 24px rgba(255, 61, 0, 0.5);
}
.back-to-top:active {
    transform: translateY(0) scale(0.98);
}

@media (max-width: 575px) {
    .back-to-top {
        bottom: 16px;
        right: 16px;
        width: 44px;
        height: 44px;
        font-size: 18px;
    }
}

@supports (padding: env(safe-area-inset-bottom)) {
    .back-to-top {
        bottom: max(24px, env(safe-area-inset-bottom));
    }
}
/* ==========================================================
   NIKKAMI AULAAD — Search Page CSS
   APPEND to bottom of /assets/css/style.css
   ========================================================== */

/* ==========================================================
   SEARCH HERO
   ========================================================== */
.search-hero {
    background: linear-gradient(135deg, var(--color-surface) 0%, var(--color-surface-alt) 100%);
    border-bottom: 1px solid var(--color-border);
    padding: 40px 0 32px;
    position: relative;
    overflow: hidden;
}
.search-hero::before {
    content: '';
    position: absolute;
    top: -30%;
    right: -10%;
    width: 500px;
    height: 500px;
    background: radial-gradient(circle, rgba(255, 61, 0, 0.06), transparent 70%);
    pointer-events: none;
}
@media (min-width: 768px) {
    .search-hero { padding: 56px 0 48px; }
}

.search-hero__inner {
    position: relative;
    z-index: 2;
    max-width: 800px;
}

.search-hero__kicker {
    display: inline-block;
    font-family: var(--font-heading);
    letter-spacing: 3px;
    font-size: 11px;
    color: var(--color-primary);
    margin-bottom: 8px;
}

.search-hero__title {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 32px;
    color: var(--color-text-primary);
    line-height: 1;
    margin: 0 0 20px;
}
@media (min-width: 768px) {
    .search-hero__title { font-size: 52px; }
}
.search-hero__title .text-primary-brand { color: var(--color-primary); }

/* Hero search form */
.search-hero__form {
    display: flex;
    flex-direction: column;
    gap: 10px;
    max-width: 640px;
}
@media (min-width: 576px) {
    .search-hero__form { flex-direction: row; }
}

.search-hero__field {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
    background: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-pill);
    padding: 0 18px;
    height: 54px;
    transition: border-color 150ms ease, box-shadow 150ms ease;
    position: relative;
    min-width: 0;
}
.search-hero__field:focus-within {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 4px rgba(255, 61, 0, 0.1);
}
.search-hero__field > i {
    color: var(--color-text-muted);
    font-size: 18px;
}
.search-hero__field input {
    background: transparent;
    border: 0;
    color: var(--color-text-primary);
    font-size: 16px;
    flex: 1;
    outline: none;
    min-width: 0;
    padding: 0;
}
.search-hero__field input::placeholder { color: var(--color-text-muted); }

/* Clear button */
.search-hero__clear {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--color-surface-alt);
    color: var(--color-text-muted);
    border: 0;
    cursor: pointer;
    transition: all 150ms ease;
    text-decoration: none;
    flex-shrink: 0;
}
.search-hero__clear:hover {
    background: var(--color-primary);
    color: #fff;
}
.search-hero__clear i { font-size: 13px; }

.search-hero__submit {
    height: 54px;
    border-radius: var(--radius-pill);
    padding: 0 28px;
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 14px;
    white-space: nowrap;
    flex-shrink: 0;
}

/* Result summary */
.search-hero__summary {
    color: var(--color-text-secondary);
    font-size: 14px;
    margin: 16px 0 0;
}
.search-hero__summary strong { color: var(--color-text-primary); }

/* ==========================================================
   SEARCH PAGE BODY
   ========================================================== */
.search-page {
    padding: 32px 0 60px;
}
@media (min-width: 768px) {
    .search-page { padding: 48px 0 80px; }
}

/* ==========================================================
   EMPTY STATE BLOCKS
   ========================================================== */
.search-empty-state {
    max-width: 1100px;
}

.search-empty-block {
    margin-bottom: 40px;
}

.search-empty-block__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.search-empty-block__title {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 16px;
    color: var(--color-text-primary);
    margin: 0;
}
@media (min-width: 768px) {
    .search-empty-block__title { font-size: 18px; }
}

.search-empty-block__more,
.search-empty-block__clear {
    color: var(--color-primary);
    text-decoration: none;
    font-size: 13px;
    background: transparent;
    border: 0;
    cursor: pointer;
    padding: 0;
    font-family: var(--font-body);
}
.search-empty-block__more:hover,
.search-empty-block__clear:hover {
    text-decoration: underline;
}

/* ==========================================================
   SEARCH CHIPS (popular / recent)
   ========================================================== */
.search-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.search-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 16px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-pill);
    color: var(--color-text-secondary);
    text-decoration: none;
    font-size: 13px;
    transition: all 150ms ease;
    cursor: pointer;
}
.search-chip:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
    background: rgba(255, 61, 0, 0.06);
    transform: translateY(-1px);
}
.search-chip i {
    font-size: 12px;
}
.search-chip--recent i {
    color: var(--color-text-muted);
}
.search-chip--recent:hover i {
    color: var(--color-primary);
}

/* ==========================================================
   CATEGORY GRID (empty state)
   ========================================================== */
.search-categories-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
}
@media (min-width: 576px) {
    .search-categories-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}
@media (min-width: 992px) {
    .search-categories-grid {
        grid-template-columns: repeat(6, 1fr);
        gap: 16px;
    }
}

.search-category-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 24px 12px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    color: var(--color-text-primary);
    text-decoration: none;
    text-align: center;
    transition: all 200ms ease;
    aspect-ratio: 1.2;
}
.search-category-card:hover {
    border-color: var(--color-primary);
    background: rgba(255, 61, 0, 0.04);
    transform: translateY(-2px);
    color: var(--color-text-primary);
}
.search-category-card i {
    font-size: 28px;
    color: var(--color-primary);
    margin-bottom: 4px;
}
.search-category-card strong {
    font-family: var(--font-heading);
    letter-spacing: 1px;
    font-size: 13px;
    color: var(--color-text-primary);
    line-height: 1.2;
}
.search-category-card small {
    color: var(--color-text-muted);
    font-size: 11px;
}

/* ==========================================================
   FILTERS SIDEBAR
   ========================================================== */
.search-sidebar { position: relative; }

.search-filter-toggle {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    color: var(--color-text-primary);
    padding: 10px 18px;
    border-radius: var(--radius-pill);
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 12px;
    cursor: pointer;
    margin-bottom: 16px;
    transition: all 150ms ease;
}
.search-filter-toggle:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
}
.search-filter-toggle i { font-size: 14px; }

.search-filters {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 24px;
}
@media (max-width: 991px) {
    .search-filters {
        position: fixed;
        top: 0;
        left: 0;
        bottom: 0;
        width: 85vw;
        max-width: 360px;
        border-radius: 0;
        border-right: 1px solid var(--color-border);
        z-index: 1050;
        overflow-y: auto;
        transform: translateX(-100%);
        transition: transform 280ms cubic-bezier(0.22, 1, 0.36, 1);
    }
    .search-filters.is-open {
        transform: translateX(0);
        box-shadow: 4px 0 30px rgba(0, 0, 0, 0.4);
    }
}

.search-filters__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--color-border);
}
.search-filters__title {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 18px;
    color: var(--color-text-primary);
    margin: 0;
}
.search-filters__close {
    background: transparent;
    border: 0;
    color: var(--color-text-muted);
    cursor: pointer;
    font-size: 18px;
    padding: 4px 8px;
}
.search-filters__close:hover { color: var(--color-primary); }

/* Filter groups */
.search-filters .filter-group {
    margin-bottom: 20px;
}
.search-filters .filter-group__title {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 12px;
    color: var(--color-text-muted);
    margin: 0 0 10px;
}

/* ==========================================================
   SEARCH TOOLBAR
   ========================================================== */
.search-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 16px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--color-border);
}

.search-toolbar__results {
    font-size: 14px;
    color: var(--color-text-secondary);
}
.search-toolbar__results strong {
    color: var(--color-text-primary);
    font-size: 16px;
}

.search-toolbar__sort {
    display: flex;
    align-items: center;
    gap: 10px;
}
.search-toolbar__sort label {
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 11px;
    color: var(--color-text-muted);
    margin: 0;
}
.search-toolbar__sort select {
    min-width: 160px;
}

/* ==========================================================
   ACTIVE FILTER PILLS
   ========================================================== */
.search-active-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 20px;
}

.search-active-filter {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(255, 61, 0, 0.1);
    border: 1px solid rgba(255, 61, 0, 0.3);
    color: var(--color-primary);
    padding: 5px 12px;
    border-radius: var(--radius-pill);
    font-size: 12px;
    text-decoration: none;
    transition: all 150ms ease;
}
.search-active-filter:hover {
    background: var(--color-primary);
    color: #fff;
}
.search-active-filter i {
    font-size: 14px;
    margin-left: 2px;
}

/* ==========================================================
   HIGHLIGHTED QUERY IN RESULTS
   ========================================================== */
.search-highlight {
    background: rgba(255, 196, 0, 0.3);
    color: var(--color-text-primary);
    padding: 1px 2px;
    border-radius: 2px;
    font-weight: 600;
}

/* ==========================================================
   NO RESULTS STATE
   ========================================================== */
.search-no-results {
    text-align: center;
    padding: 40px 20px;
    max-width: 800px;
    margin: 0 auto;
}

.search-no-results__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: var(--color-surface);
    border: 2px dashed var(--color-border);
    margin: 0 auto 20px;
}
.search-no-results__icon i {
    font-size: 32px;
    color: var(--color-text-muted);
}

.search-no-results__title {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 28px;
    color: var(--color-text-primary);
    margin: 0 0 12px;
}
@media (min-width: 768px) {
    .search-no-results__title { font-size: 36px; }
}

.search-no-results__text {
    color: var(--color-text-secondary);
    font-size: 15px;
    margin-bottom: 24px;
}
.search-no-results__text strong { color: var(--color-text-primary); }

.search-no-results__tips {
    display: inline-flex;
    flex-direction: column;
    gap: 8px;
    text-align: left;
    margin: 0 auto 24px;
    padding: 16px 24px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
}

.search-no-results__tip {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    color: var(--color-text-secondary);
}
.search-no-results__tip i {
    color: var(--color-success, #00E676);
    font-size: 16px;
    flex-shrink: 0;
}

/* ==========================================================
   PAGINATION (reuse shop styles if present, polish for search)
   ========================================================== */
.search-page .pagination-wrap {
    margin-top: 40px;
    display: flex;
    justify-content: center;
}

/* ==========================================================
   MOBILE OVERLAY (for filter drawer backdrop)
   ========================================================== */
@media (max-width: 991px) {
    .search-filters.is-open::before {
        content: '';
        position: fixed;
        top: 0;
        left: 100%;
        right: 0;
        bottom: 0;
        width: 100vw;
        background: rgba(0, 0, 0, 0.7);
        z-index: -1;
    }
}
/* ==========================================================
   1. GLOBAL HEADER & ANNOUNCEMENT BAR
   ========================================================== */
.announcement-bar {
    background: var(--color-primary);
    color: #000;
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 11px;
    padding: 8px 0;
    overflow: hidden;
    position: relative;
    border-bottom: 1px solid var(--color-border);
}
.announcement-bar__track {
    display: flex;
    gap: 32px;
    white-space: nowrap;
    /* FIXED: Ensures it scrolls on both mobile AND desktop */
    animation: scroll-marquee 25s linear infinite; 
}
@keyframes scroll-marquee {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}
/* FIXED: SWIPEABLE GALLERY TRACK */
.gallery-track {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    width: 100%;
    height: 100%;
}
.gallery-track::-webkit-scrollbar { display: none; }
.gallery-track__slide {
    flex: 0 0 100%;
    width: 100%;
    height: 100%;
    object-fit: cover;
    scroll-snap-align: start;
}

.gallery-bullets { position: absolute; bottom: 16px; left: 0; right: 0; display: flex; justify-content: center; gap: 8px; z-index: 10; }
.gallery-bullet { width: 10px; height: 10px; border-radius: 50%; background: rgba(255, 255, 255, 0.4); border: 1px solid rgba(0,0,0,0.1); cursor: pointer; padding: 0; transition: all var(--transition-fast); }
.gallery-bullet.is-active { background: var(--color-primary); border-color: var(--color-primary); transform: scale(1.2); }
.gallery-counter { position: absolute; top: 16px; right: 16px; background: rgba(0,0,0,0.6); color: #fff; padding: 4px 10px; border-radius: var(--radius-pill); font-size: 12px; font-family: var(--font-heading); z-index: 10; }

.product-info__title { font-family: var(--font-heading); font-size: clamp(32px, 4vw, 44px); line-height: 1; margin: 0 0 16px; }
.product-info__price { display: flex; gap: 12px; align-items: center; padding: 20px 0; margin: 16px 0; border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }

/* ==========================================================
   NIKKAMI AULAAD — Contact + About Pages CSS
   APPEND to bottom of /assets/css/style.css
   ========================================================== */

/* ==========================================================
   SHARED — section kickers and titles
   ========================================================== */
.contact-section-kicker,
.about-section-kicker {
    display: inline-block;
    font-family: var(--font-heading);
    letter-spacing: 3px;
    font-size: 11px;
    color: var(--color-primary);
    margin-bottom: 8px;
}
.about-section-kicker--center {
    display: block;
    text-align: center;
}

.contact-section-title,
.about-section-title {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 28px;
    color: var(--color-text-primary);
    margin: 0 0 24px;
    line-height: 1.1;
}
@media (min-width: 768px) {
    .contact-section-title,
    .about-section-title { font-size: 40px; }
}
.about-section-title--center {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
}

.text-primary-brand { color: var(--color-primary); }


/* ==========================================================
   CONTACT — HERO
   ========================================================== */
.contact-hero {
    background: linear-gradient(135deg, var(--color-surface) 0%, var(--color-surface-alt) 100%);
    border-bottom: 1px solid var(--color-border);
    padding: 48px 0 40px;
    position: relative;
    overflow: hidden;
}
.contact-hero::before {
    content: '';
    position: absolute;
    top: -40%;
    right: -10%;
    width: 500px;
    height: 500px;
    background: radial-gradient(circle, rgba(255, 61, 0, 0.08), transparent 70%);
    pointer-events: none;
}
@media (min-width: 768px) {
    .contact-hero { padding: 72px 0 56px; }
}
.contact-hero__inner {
    position: relative;
    z-index: 2;
    max-width: 700px;
}
.contact-hero__kicker {
    display: inline-block;
    font-family: var(--font-heading);
    letter-spacing: 3px;
    font-size: 12px;
    color: var(--color-primary);
    margin-bottom: 10px;
}
.contact-hero__title {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 40px;
    color: var(--color-text-primary);
    line-height: 1;
    margin: 0 0 16px;
}
@media (min-width: 768px) {
    .contact-hero__title { font-size: 64px; }
}
.contact-hero__text {
    font-size: 16px;
    color: var(--color-text-secondary);
    margin: 0;
    line-height: 1.5;
}
.contact-hero__text strong { color: var(--color-text-primary); }


/* ==========================================================
   CONTACT — QUICK SUPPORT CATEGORIES
   ========================================================== */
.contact-categories {
    padding: 40px 0 16px;
}
@media (min-width: 768px) {
    .contact-categories { padding: 56px 0 24px; }
}

.contact-cat-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 24px 14px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    color: var(--color-text-primary);
    text-decoration: none;
    text-align: center;
    transition: all 200ms ease;
    height: 100%;
    min-height: 130px;
}
.contact-cat-card:hover {
    border-color: var(--color-primary);
    background: rgba(255, 61, 0, 0.04);
    transform: translateY(-2px);
    color: var(--color-text-primary);
}
.contact-cat-card i {
    font-size: 28px;
    color: var(--color-primary);
    margin-bottom: 4px;
}
.contact-cat-card strong {
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 13px;
    color: var(--color-text-primary);
}
.contact-cat-card small {
    color: var(--color-text-muted);
    font-size: 11px;
}


/* ==========================================================
   CONTACT — MAIN (form + info)
   ========================================================== */
.contact-main {
    padding: 32px 0 40px;
}
@media (min-width: 768px) {
    .contact-main { padding: 48px 0 64px; }
}

/* Form card */
.contact-form-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 24px;
    height: 100%;
}
@media (min-width: 768px) {
    .contact-form-card { padding: 36px; }
}

.contact-form-card__head { margin-bottom: 24px; }
.contact-form-card__kicker {
    display: inline-block;
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 11px;
    color: var(--color-primary);
    margin-bottom: 6px;
}
.contact-form-card__title {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 24px;
    color: var(--color-text-primary);
    margin: 0 0 8px;
}
@media (min-width: 768px) {
    .contact-form-card__title { font-size: 30px; }
}
.contact-form-card__sub {
    color: var(--color-text-secondary);
    font-size: 14px;
    margin: 0;
}

/* Honeypot */
.contact-form__honeypot {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.contact-form__label {
    display: block;
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 11px;
    color: var(--color-text-muted);
    margin-bottom: 6px;
}

.contact-form__counter {
    font-size: 12px;
    color: var(--color-text-muted);
}
.contact-form__submit {
    height: 50px;
    padding: 0 32px;
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 13px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

/* Success card */
.contact-success-card {
    text-align: center;
    padding: 40px 20px;
    background: rgba(0, 230, 118, 0.05);
    border: 1px solid rgba(0, 230, 118, 0.3);
    border-radius: var(--radius-md);
}
.contact-success-card__icon i {
    font-size: 64px;
    color: var(--color-success, #00E676);
}
.contact-success-card h3 {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 24px;
    color: var(--color-text-primary);
    margin: 16px 0 8px;
}
.contact-success-card p {
    color: var(--color-text-secondary);
    font-size: 14px;
}


/* Info card */
.contact-info-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 24px;
    height: 100%;
}
@media (min-width: 768px) {
    .contact-info-card { padding: 30px; }
}

.contact-info-card__title {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 18px;
    color: var(--color-text-primary);
    margin: 0 0 20px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--color-border);
}

.contact-info-item {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 12px 0;
    text-decoration: none;
    transition: all 150ms ease;
    border-bottom: 1px solid var(--color-border);
}
.contact-info-item:last-of-type { border-bottom: 0; }

.contact-info-item:not(.contact-info-item--static):hover {
    background: var(--color-surface-alt);
    margin: 0 -16px;
    padding: 12px 16px;
    border-radius: var(--radius-sm);
}
.contact-info-item:not(.contact-info-item--static):hover .contact-info-item__icon {
    background: var(--color-primary);
    color: #fff;
    transform: scale(1.05);
}

.contact-info-item__icon {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: rgba(255, 61, 0, 0.1);
    color: var(--color-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all 200ms ease;
}
.contact-info-item__icon i { font-size: 18px; }

.contact-info-item__body { flex: 1; min-width: 0; }
.contact-info-item__body strong {
    display: block;
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 11px;
    color: var(--color-text-muted);
    margin-bottom: 2px;
}
.contact-info-item__body span {
    display: block;
    color: var(--color-text-primary);
    font-size: 14px;
    font-weight: 500;
    word-break: break-word;
}
.contact-info-item__body small {
    display: block;
    color: var(--color-text-muted);
    font-size: 12px;
    margin-top: 2px;
}

.contact-info-item--whatsapp .contact-info-item__icon {
    background: rgba(37, 211, 102, 0.15);
    color: #25D366;
}
.contact-info-item--whatsapp:hover .contact-info-item__icon {
    background: #25D366 !important;
}

.contact-info-card__social {
    margin-top: 24px;
    padding-top: 20px;
    border-top: 1px solid var(--color-border);
}
.contact-info-card__social > strong {
    display: block;
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 11px;
    color: var(--color-text-muted);
    margin-bottom: 12px;
}
.contact-social {
    display: flex;
    gap: 10px;
}
.contact-social__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: var(--color-surface-alt);
    border: 1px solid var(--color-border);
    color: var(--color-text-secondary);
    text-decoration: none;
    transition: all 200ms ease;
}
.contact-social__link:hover {
    border-color: var(--color-primary);
    background: var(--color-primary);
    color: #fff;
    transform: translateY(-2px);
}
.contact-social__link i { font-size: 16px; }


/* ==========================================================
   CONTACT — FAQ
   ========================================================== */
.contact-faq {
    padding: 40px 0 60px;
    background: var(--color-surface);
}
@media (min-width: 768px) {
    .contact-faq { padding: 64px 0 80px; }
}
.contact-faq__head {
    text-align: center;
    margin-bottom: 32px;
}
.contact-faq__head .contact-section-title { margin-bottom: 8px; }

.contact-faq__accordion {
    max-width: 800px;
    margin: 0 auto;
}

.contact-faq__item {
    background: var(--color-background) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md) !important;
    margin-bottom: 10px;
    overflow: hidden;
}
.contact-faq__item .accordion-button {
    background: var(--color-background);
    color: var(--color-text-primary);
    font-weight: 600;
    font-size: 15px;
    padding: 16px 20px;
    border: 0;
    box-shadow: none;
    text-align: left;
}
.contact-faq__item .accordion-button:not(.collapsed) {
    background: var(--color-surface-alt);
    color: var(--color-primary);
    box-shadow: none;
}
.contact-faq__item .accordion-button:focus {
    box-shadow: none;
    border-color: var(--color-primary);
}
.contact-faq__item .accordion-button::after {
    filter: invert(60%) sepia(80%) saturate(2000%) hue-rotate(0deg);
}
.contact-faq__item .accordion-body {
    padding: 0 20px 16px;
    color: var(--color-text-secondary);
    font-size: 14px;
    line-height: 1.6;
}
.contact-faq__item .accordion-body a { color: var(--color-primary); }


/* ==========================================================
   ABOUT — HERO
   ========================================================== */
.about-hero {
    padding: 56px 0 48px;
    position: relative;
    overflow: hidden;
    background: var(--color-background);
}
@media (min-width: 768px) {
    .about-hero { padding: 100px 0 80px; }
}

.about-hero__bg-glow {
    position: absolute;
    top: -20%;
    right: -10%;
    width: 700px;
    height: 700px;
    background: radial-gradient(circle, rgba(255, 61, 0, 0.12), transparent 70%);
    pointer-events: none;
}

.about-hero__inner {
    position: relative;
    z-index: 2;
    max-width: 700px;
}
.about-hero__kicker {
    display: inline-block;
    font-family: var(--font-heading);
    letter-spacing: 3px;
    font-size: 12px;
    color: var(--color-primary);
    margin-bottom: 12px;
}
.about-hero__title {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 48px;
    color: var(--color-text-primary);
    line-height: 0.95;
    margin: 0 0 20px;
}
@media (min-width: 768px) {
    .about-hero__title { font-size: 84px; }
}
@media (min-width: 1200px) {
    .about-hero__title { font-size: 100px; }
}
.about-hero__text {
    font-size: 16px;
    color: var(--color-text-secondary);
    max-width: 540px;
    line-height: 1.6;
    margin: 0;
}


/* ==========================================================
   ABOUT — STORY
   ========================================================== */
.about-story {
    padding: 40px 0;
    background: var(--color-surface);
}
@media (min-width: 768px) {
    .about-story { padding: 80px 0; }
}

.about-story__image {
    position: relative;
    padding-bottom: 100%;
    background: linear-gradient(135deg, var(--color-primary) 0%, #FF6E40 100%);
    border-radius: var(--radius-md);
    overflow: hidden;
}
.about-story__image-card {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #000;
    text-align: center;
    padding: 20px;
}
.about-story__image-card i {
    font-size: 64px;
    margin-bottom: 12px;
}
.about-story__image-label {
    font-family: var(--font-heading);
    letter-spacing: 3px;
    font-size: 12px;
    background: #000;
    color: var(--color-primary);
    padding: 4px 12px;
    border-radius: var(--radius-pill);
    margin-bottom: 16px;
}
.about-story__image-card strong {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 36px;
    line-height: 1;
    margin-bottom: 8px;
}
.about-story__image-card small {
    font-size: 12px;
    opacity: 0.7;
}

.about-story__lead {
    font-size: 18px;
    color: var(--color-text-primary);
    line-height: 1.5;
    margin-bottom: 16px;
    font-weight: 500;
}
.about-story p {
    color: var(--color-text-secondary);
    font-size: 15px;
    line-height: 1.7;
}
.about-story p strong { color: var(--color-text-primary); }


/* ==========================================================
   ABOUT — MISSION
   ========================================================== */
.about-mission {
    padding: 60px 0;
    text-align: center;
    background: var(--color-background);
    position: relative;
    overflow: hidden;
}
.about-mission::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 20% 30%, rgba(255, 61, 0, 0.06), transparent 50%),
        radial-gradient(circle at 80% 70%, rgba(0, 229, 255, 0.06), transparent 50%);
    pointer-events: none;
}
@media (min-width: 768px) {
    .about-mission { padding: 100px 0; }
}
.about-mission__inner {
    position: relative;
    z-index: 2;
    max-width: 900px;
    margin: 0 auto;
}
.about-mission__manifesto {
    font-size: 18px;
    line-height: 1.7;
    color: var(--color-text-secondary);
    margin: 24px 0;
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
}
@media (min-width: 768px) {
    .about-mission__manifesto { font-size: 20px; }
}
.about-mission__manifesto strong { color: var(--color-text-primary); }


/* ==========================================================
   ABOUT — PILLARS
   ========================================================== */
.about-pillars {
    padding: 60px 0;
}
@media (min-width: 768px) {
    .about-pillars { padding: 80px 0; }
}
.about-pillars__head {
    text-align: center;
    margin-bottom: 40px;
}

.about-pillar {
    height: 100%;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 24px 20px;
    position: relative;
    transition: all 200ms ease;
}
@media (min-width: 768px) {
    .about-pillar { padding: 32px 24px; }
}
.about-pillar:hover {
    border-color: var(--color-primary);
    transform: translateY(-3px);
    box-shadow: 0 10px 30px rgba(255, 61, 0, 0.1);
}
.about-pillar__num {
    position: absolute;
    top: 16px;
    right: 16px;
    font-family: var(--font-heading);
    letter-spacing: 1px;
    font-size: 32px;
    color: var(--color-primary);
    opacity: 0.2;
}
.about-pillar > i {
    display: block;
    font-size: 36px;
    color: var(--color-primary);
    margin-bottom: 16px;
}
.about-pillar h3 {
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 16px;
    color: var(--color-text-primary);
    margin: 0 0 8px;
}
.about-pillar p {
    color: var(--color-text-secondary);
    font-size: 13px;
    line-height: 1.6;
    margin: 0;
}


/* ==========================================================
   ABOUT — STATS
   ========================================================== */
.about-stats {
    padding: 40px 0;
    background: var(--color-primary);
    color: #000;
}
@media (min-width: 768px) {
    .about-stats { padding: 60px 0; }
}

.about-stat {
    text-align: center;
    padding: 12px;
}
.about-stat strong {
    display: block;
    font-family: var(--font-heading);
    letter-spacing: 1px;
    font-size: 40px;
    color: #000;
    line-height: 1;
    margin-bottom: 6px;
}
@media (min-width: 768px) {
    .about-stat strong { font-size: 56px; }
}
.about-stat span {
    display: block;
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 11px;
    color: #000;
    opacity: 0.7;
}
@media (min-width: 768px) {
    .about-stat span { font-size: 13px; }
}


/* ==========================================================
   ABOUT — CRAFT / PROCESS
   ========================================================== */
.about-craft {
    padding: 60px 0;
    background: var(--color-surface);
}
@media (min-width: 768px) {
    .about-craft { padding: 80px 0; }
}
.about-craft__head {
    text-align: center;
    margin-bottom: 40px;
}

.about-craft__steps {
    display: flex;
    flex-direction: column;
    gap: 20px;
}
@media (min-width: 768px) {
    .about-craft__steps {
        flex-direction: row;
        align-items: stretch;
        gap: 8px;
    }
}

.about-craft__step {
    flex: 1;
    background: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 24px 20px;
    text-align: center;
    position: relative;
}
.about-craft__step-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    background: var(--color-primary);
    color: #fff;
    border-radius: 50%;
    font-family: var(--font-heading);
    letter-spacing: 1px;
    font-size: 18px;
    margin-bottom: 16px;
}
.about-craft__step strong {
    display: block;
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 14px;
    color: var(--color-text-primary);
    margin-bottom: 8px;
}
.about-craft__step p {
    color: var(--color-text-secondary);
    font-size: 13px;
    line-height: 1.6;
    margin: 0;
}

.about-craft__step-arrow {
    display: none;
    font-size: 24px;
    color: var(--color-primary);
    align-items: center;
    justify-content: center;
    padding: 0 4px;
}
@media (min-width: 768px) {
    .about-craft__step-arrow { display: flex; }
}


/* ==========================================================
   ABOUT — ARTISTS
   ========================================================== */
.about-artists {
    padding: 60px 0;
}
@media (min-width: 768px) {
    .about-artists { padding: 80px 0; }
}
.about-artists__head {
    text-align: center;
    margin-bottom: 40px;
}

.about-artist-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    padding: 24px 16px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    text-decoration: none;
    text-align: center;
    transition: all 200ms ease;
    height: 100%;
}
.about-artist-card:hover {
    border-color: var(--color-primary);
    transform: translateY(-3px);
}
.about-artist-card__avatar {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-primary), #FF6E40);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-heading);
    font-size: 32px;
    overflow: hidden;
    border: 3px solid var(--color-background);
    box-shadow: 0 0 0 1px var(--color-border);
}
.about-artist-card__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.about-artist-card strong {
    font-family: var(--font-heading);
    letter-spacing: 1px;
    font-size: 14px;
    color: var(--color-text-primary);
}
.about-artist-card small {
    font-size: 11px;
    color: var(--color-primary);
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
}


/* ==========================================================
   ABOUT — FOUNDER NOTE
   ========================================================== */
.about-founder {
    padding: 40px 0 60px;
    background: var(--color-surface);
}
@media (min-width: 768px) {
    .about-founder { padding: 80px 0; }
}
.about-founder__card {
    max-width: 800px;
    margin: 0 auto;
    background: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 32px 24px;
    position: relative;
    text-align: center;
}
@media (min-width: 768px) {
    .about-founder__card { padding: 48px 56px; }
}
.about-founder__quote-mark {
    font-family: var(--font-heading);
    font-size: 80px;
    color: var(--color-primary);
    line-height: 0.6;
    margin-bottom: 8px;
    opacity: 0.4;
}
.about-founder__quote {
    font-size: 17px;
    line-height: 1.7;
    color: var(--color-text-secondary);
    font-style: italic;
    margin-bottom: 20px;
}
@media (min-width: 768px) {
    .about-founder__quote { font-size: 20px; }
}
.about-founder__quote em {
    color: var(--color-primary);
    font-style: italic;
}
.about-founder__sign strong {
    display: block;
    font-family: var(--font-heading);
    letter-spacing: 2px;
    color: var(--color-text-primary);
    font-size: 14px;
    margin-bottom: 4px;
}
.about-founder__sign small {
    color: var(--color-text-muted);
    font-size: 12px;
}


/* ==========================================================
   ABOUT — CTA STRIP
   ========================================================== */
.about-cta {
    padding: 40px 0 60px;
}
@media (min-width: 768px) {
    .about-cta { padding: 60px 0 100px; }
}

.about-cta__card {
    padding: 32px 24px;
    border-radius: var(--radius-md);
    height: 100%;
    border: 1px solid var(--color-border);
}
@media (min-width: 768px) {
    .about-cta__card { padding: 48px 36px; }
}

.about-cta__card--shop {
    background: linear-gradient(135deg, var(--color-primary) 0%, #FF6E40 100%);
    color: #000;
    border: 0;
}
.about-cta__card--shop .about-cta__kicker {
    color: #000;
    opacity: 0.7;
}
.about-cta__card--shop h3,
.about-cta__card--shop p { color: #000; }
.about-cta__card--shop .btn-primary {
    background: #000;
    border-color: #000;
    color: var(--color-primary);
}
.about-cta__card--shop .btn-primary:hover {
    background: #161616;
    border-color: #161616;
}

.about-cta__card--artist {
    background: var(--color-surface);
}

.about-cta__kicker {
    display: inline-block;
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 11px;
    color: var(--color-primary);
    margin-bottom: 8px;
}
.about-cta__card h3 {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 22px;
    color: var(--color-text-primary);
    margin: 0 0 12px;
}
@media (min-width: 768px) {
    .about-cta__card h3 { font-size: 28px; }
}
.about-cta__card p {
    color: var(--color-text-secondary);
    margin-bottom: 20px;
}


/* ==========================================================
   AUTH LINK (reusable in FAQ answers)
   ========================================================== */
.auth-link {
    color: var(--color-primary);
    text-decoration: underline;
}
.auth-link:hover { color: var(--color-text-primary); }

/* ==========================================================
   NIKKAMI AULAAD — 404 Page CSS
   APPEND to bottom of /assets/css/style.css
   ========================================================== */

/* ==========================================================
   SHARED — section heads
   ========================================================== */
.page404-section-kicker {
    display: inline-block;
    font-family: var(--font-heading);
    letter-spacing: 3px;
    font-size: 11px;
    color: var(--color-primary);
    margin-bottom: 6px;
}
.page404-section-title {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 26px;
    color: var(--color-text-primary);
    margin: 0;
    line-height: 1.1;
}
@media (min-width: 768px) {
    .page404-section-title { font-size: 36px; }
}

/* ==========================================================
   HERO — the BIG SECTION
   ========================================================== */
.page404-hero {
    padding: 40px 0 60px;
    position: relative;
    overflow: hidden;
    background: var(--color-background);
}
@media (min-width: 768px) {
    .page404-hero { padding: 60px 0 80px; }
}

/* Subtle grid background */
.page404-bg-grid {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255, 61, 0, 0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 61, 0, 0.04) 1px, transparent 1px);
    background-size: 50px 50px;
    pointer-events: none;
    mask-image: radial-gradient(circle at 50% 30%, black 0%, transparent 70%);
    -webkit-mask-image: radial-gradient(circle at 50% 30%, black 0%, transparent 70%);
}

.page404-hero__inner {
    position: relative;
    z-index: 2;
    text-align: center;
    max-width: 700px;
    margin: 0 auto;
}

/* ==========================================================
   THE GIANT 404 — with glitch effect
   ========================================================== */
.page404-number {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    font-family: var(--font-heading);
    color: var(--color-text-primary);
    line-height: 1;
    margin-bottom: 16px;
    user-select: none;
}
@media (min-width: 768px) {
    .page404-number { gap: 8px; margin-bottom: 24px; }
}

.page404-number__digit,
.page404-number__zero {
    font-size: 96px;
    line-height: 0.85;
    position: relative;
    display: inline-block;
}
@media (min-width: 576px) {
    .page404-number__digit,
    .page404-number__zero { font-size: 140px; }
}
@media (min-width: 768px) {
    .page404-number__digit,
    .page404-number__zero { font-size: 200px; }
}
@media (min-width: 992px) {
    .page404-number__digit,
    .page404-number__zero { font-size: 260px; }
}

/* Glitch — twin layers in cyan and orange */
.page404-number__digit::before,
.page404-number__digit::after {
    content: attr(data-text);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    line-height: inherit;
}
.page404-number__digit::before {
    color: var(--color-secondary, #00E5FF);
    transform: translate(-3px, 0);
    clip-path: polygon(0 0, 100% 0, 100% 33%, 0 33%);
    animation: glitch-top 2.5s infinite linear alternate-reverse;
    mix-blend-mode: screen;
}
.page404-number__digit::after {
    color: var(--color-primary);
    transform: translate(3px, 0);
    clip-path: polygon(0 67%, 100% 67%, 100% 100%, 0 100%);
    animation: glitch-bottom 2s infinite linear alternate-reverse;
    mix-blend-mode: screen;
}

@keyframes glitch-top {
    0%, 90%, 100% { transform: translate(-3px, 0); }
    20% { transform: translate(-5px, -1px); }
    40% { transform: translate(-2px, 1px); }
    60% { transform: translate(-4px, 0); }
    80% { transform: translate(0, 0); opacity: 0.5; }
}
@keyframes glitch-bottom {
    0%, 85%, 100% { transform: translate(3px, 0); }
    15% { transform: translate(5px, 1px); }
    35% { transform: translate(2px, -1px); }
    55% { transform: translate(4px, 0); }
    75% { transform: translate(0, 0); opacity: 0.5; }
}

/* The dizzy "0" replacement */
.page404-number__zero {
    color: var(--color-primary);
    position: relative;
}
.page404-number__inner {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1em;
    height: 1em;
    border: 0.12em solid var(--color-primary);
    border-radius: 50%;
    animation: zero-spin 8s infinite linear;
    box-sizing: border-box;
}
.page404-number__inner i {
    font-size: 0.55em;
    color: var(--color-primary);
    animation: zero-shake 0.5s infinite ease-in-out alternate;
}
@keyframes zero-spin {
    0%   { transform: rotate(0); }
    100% { transform: rotate(360deg); }
}
@keyframes zero-shake {
    0%   { transform: rotate(-8deg); }
    100% { transform: rotate(8deg); }
}

/* ==========================================================
   TAGLINES
   ========================================================== */
.page404-kicker {
    display: inline-block;
    font-family: var(--font-heading);
    letter-spacing: 3px;
    font-size: 12px;
    color: var(--color-primary);
    margin-bottom: 12px;
    animation: blink 1.5s infinite step-start;
}
@keyframes blink {
    0%, 80%, 100% { opacity: 1; }
    90%           { opacity: 0.3; }
}

.page404-title {
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 32px;
    color: var(--color-text-primary);
    line-height: 1;
    margin: 0 0 16px;
}
@media (min-width: 768px) {
    .page404-title { font-size: 52px; }
}

.page404-sub {
    font-size: 15px;
    line-height: 1.6;
    color: var(--color-text-secondary);
    max-width: 560px;
    margin: 0 auto 24px;
}
@media (min-width: 768px) {
    .page404-sub { font-size: 16px; margin-bottom: 32px; }
}

/* ==========================================================
   RECEIPT (terminal-style)
   ========================================================== */
.page404-receipt {
    display: inline-block;
    background: rgba(0, 0, 0, 0.5);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 12px 16px;
    margin: 0 auto 28px;
    max-width: 480px;
    width: 100%;
    text-align: left;
    font-family: 'Space Grotesk', 'Courier New', monospace;
    font-size: 11px;
    backdrop-filter: blur(4px);
}
@media (min-width: 576px) {
    .page404-receipt { padding: 14px 20px; font-size: 12px; }
}

.page404-receipt__line {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 4px 0;
    color: var(--color-text-secondary);
}
.page404-receipt__line--head {
    border-bottom: 1px dashed var(--color-border);
    padding-bottom: 8px;
    margin-bottom: 6px;
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
}
.page404-receipt__line--head > span:first-child { color: var(--color-primary); }
.page404-receipt__line--head > span:last-child {
    color: var(--color-danger, #FF1744);
}
.page404-receipt__label {
    color: var(--color-text-muted);
    font-weight: 600;
    flex-shrink: 0;
}
.page404-receipt__value {
    color: var(--color-text-primary);
    word-break: break-all;
    text-align: right;
    flex: 1;
    min-width: 0;
}
.page404-receipt__value--err {
    color: var(--color-danger, #FF1744);
    text-decoration: line-through;
}

/* ==========================================================
   SEARCH FORM
   ========================================================== */
.page404-search {
    display: flex;
    flex-direction: column;
    gap: 10px;
    max-width: 480px;
    margin: 0 auto 24px;
}
@media (min-width: 576px) {
    .page404-search { flex-direction: row; }
}

.page404-search__field {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-pill);
    padding: 0 18px;
    height: 50px;
    transition: border-color 150ms ease, box-shadow 150ms ease;
}
.page404-search__field:focus-within {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 4px rgba(255, 61, 0, 0.1);
}
.page404-search__field i {
    color: var(--color-text-muted);
    font-size: 16px;
}
.page404-search__field input {
    background: transparent;
    border: 0;
    color: var(--color-text-primary);
    font-size: 14px;
    flex: 1;
    outline: none;
    min-width: 0;
    padding: 0;
}
.page404-search__field input::placeholder { color: var(--color-text-muted); }

.page404-search__btn {
    height: 50px;
    padding: 0 28px;
    border-radius: var(--radius-pill);
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 13px;
    white-space: nowrap;
    flex-shrink: 0;
}

/* ==========================================================
   ACTIONS
   ========================================================== */
.page404-actions {
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: center;
    justify-content: center;
}
@media (min-width: 576px) {
    .page404-actions { flex-direction: row; gap: 12px; }
}
.page404-actions .btn {
    min-width: 200px;
    font-family: var(--font-heading);
    letter-spacing: 2px;
    font-size: 13px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}
.page404-actions .btn i { font-size: 16px; }

/* ==========================================================
   ESCAPE ROUTES
   ========================================================== */
.page404-routes {
    padding: 32px 0;
    background: var(--color-surface);
}
@media (min-width: 768px) {
    .page404-routes { padding: 56px 0; }
}

.page404-routes__head {
    text-align: center;
    margin-bottom: 28px;
}
@media (min-width: 768px) {
    .page404-routes__head { margin-bottom: 40px; }
}

.page404-route-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 24px 14px;
    background: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    color: var(--color-text-primary);
    text-decoration: none;
    text-align: center;
    transition: all 200ms ease;
    height: 100%;
    min-height: 140px;
    position: relative;
    overflow: hidden;
}
.page404-route-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, transparent 0%, rgba(255, 61, 0, 0) 100%);
    transition: background 300ms ease;
    pointer-events: none;
}
.page404-route-card:hover {
    border-color: var(--color-primary);
    transform: translateY(-3px);
    color: var(--color-text-primary);
}
.page404-route-card:hover::before {
    background: linear-gradient(135deg, transparent 0%, rgba(255, 61, 0, 0.08) 100%);
}
.page404-route-card i {
    font-size: 28px;
    color: var(--color-primary);
    margin-bottom: 4px;
    position: relative;
    z-index: 1;
}
.page404-route-card strong {
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 13px;
    color: var(--color-text-primary);
    position: relative;
    z-index: 1;
}
.page404-route-card small {
    color: var(--color-text-muted);
    font-size: 11px;
    position: relative;
    z-index: 1;
}

/* ==========================================================
   CATEGORIES
   ========================================================== */
.page404-categories {
    padding: 32px 0;
}
@media (min-width: 768px) {
    .page404-categories { padding: 56px 0; }
}

.page404-cat-card {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 20px 18px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    color: var(--color-text-primary);
    text-decoration: none;
    transition: all 200ms ease;
    height: 100%;
    min-height: 140px;
    position: relative;
    overflow: hidden;
}
.page404-cat-card:hover {
    border-color: var(--color-primary);
    background: rgba(255, 61, 0, 0.04);
    color: var(--color-text-primary);
}
.page404-cat-card:hover .page404-cat-card__arrow {
    transform: translateX(6px);
    color: var(--color-primary);
}
.page404-cat-card__count {
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 10px;
    color: var(--color-text-muted);
}
.page404-cat-card strong {
    font-family: var(--font-heading);
    letter-spacing: 1.5px;
    font-size: 18px;
    color: var(--color-text-primary);
    margin: auto 0 8px;
}
.page404-cat-card__arrow {
    display: inline-block;
    font-size: 20px;
    color: var(--color-text-secondary);
    transition: all 200ms ease;
}

/* ==========================================================
   POPULAR PRODUCTS
   ========================================================== */
.page404-products {
    padding: 32px 0;
    background: var(--color-surface);
}
@media (min-width: 768px) {
    .page404-products { padding: 56px 0 64px; }
}

/* ==========================================================
   BOTTOM REASSURANCE
   ========================================================== */
.page404-bottom {
    padding: 30px 0 60px;
    background: var(--color-background);
}
.page404-bottom__card {
    max-width: 700px;
    margin: 0 auto;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-left: 3px solid var(--color-primary);
    border-radius: var(--radius-md);
    padding: 18px 24px;
    display: flex;
    align-items: flex-start;
    gap: 14px;
}
.page404-bottom__card i {
    font-size: 22px;
    color: var(--color-primary);
    flex-shrink: 0;
    margin-top: 2px;
}
.page404-bottom__card p {
    margin: 0;
    color: var(--color-text-secondary);
    font-size: 14px;
    line-height: 1.6;
}
.page404-bottom__card strong {
    color: var(--color-text-primary);
}
.page404-bottom__card .auth-link {
    color: var(--color-primary);
    font-weight: 600;
}