/* ================================================
   AMER FRAGRANCES — Shared Styles (app.css)
   Variables · Reset · Nav · Footer · Buttons · Cards · Utilities
   ================================================ */

/* ── CSS Variables ────────────────────────── */
:root {
    /* 🎨 Change --font-primary here to update font across the ENTIRE site */
    --font-primary:  'Cairo', sans-serif;
    --font-display:  'Cinzel', serif;

    /* Colors */
    --clr-maroon:       #540B13;
    --clr-maroon-light: #6B0F18;
    --clr-maroon-dark:  #3D080E;
    --clr-black:        #050505;
    --clr-black-mid:    #0a0a0a;
    --clr-dark-card:    #0D0D0D;
    --clr-sellers-bg:   #1A0508;
    --clr-about-bg:     #3D080E;
    --clr-white:        #ffffff;
    --clr-gray-1:       rgba(255,255,255,0.9);
    --clr-gray-3:       rgba(255,255,255,0.4);
    --clr-gray-4:       #A1A1A1;
    --clr-gray-5:       #6B7280;
    --clr-gray-6:       #4B5563;
    --clr-border:       rgba(255,255,255,0.06);
    --clr-border-md:    rgba(255,255,255,0.12);
    --clr-border-lg:    rgba(255,255,255,0.25);
    --clr-star:         #FACC15;

    /* Spacing */
    --nav-h:      68px;
    --max-w:      1152px;
    --px:         2rem;
    --section-py: 5rem;

    /* Typography */
    --fs-9:  9px;  --fs-10: 10px; --fs-11: 11px;
    --fs-12: 12px; --fs-14: 14px; --fs-18: 18px;
    --fs-20: 20px; --fs-24: 24px; --fs-30: 30px;
    --fs-48: 48px;

    /* Letter spacing */
    --ls-nav:     0.2em;
    --ls-btn:     0.25em;
    --ls-section: 0.2em;
    --ls-product: 0.15em;
    --ls-footer:  0.3em;
    --ls-wide:    0.1em;
    --ls-wider:   0.15em;
    --ls-widest:  0.2em;

    /* Transitions */
    --t:      0.25s ease;
    --t-slow: 1.5s ease;
    --t-med:  0.7s ease;
}

/* RTL: switch display font to Cairo */
[dir="rtl"] {
    --font-display: 'Cairo', sans-serif;
}

/* ── Reset ────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
    font-family: var(--font-primary);
    background: var(--clr-black);
    color: var(--clr-white);
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
    line-height: 1.6;
}
img { display: block; max-width: 100%; }
a   { text-decoration: none; color: inherit; }
button { cursor: pointer; border: none; background: none; font-family: inherit; color: inherit; }
ul, ol { list-style: none; }
input, textarea, select { font-family: inherit; }

/* ── Scrollbar ────────────────────────────── */
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--clr-black-mid); }
::-webkit-scrollbar-thumb { background: var(--clr-maroon-dark); border-radius: 2px; }
::-webkit-scrollbar-thumb:hover { background: var(--clr-maroon); }

/* ── Container ────────────────────────────── */
.container {
    width: 100%;
    max-width: var(--max-w);
    margin-inline: auto;
    padding-inline: var(--px);
}
@media (min-width: 768px) { .container { padding-inline: 4rem; } }

/* ── Page top padding ─────────────────────── */
.page-top { padding-top: var(--nav-h); }

/* ── Section generic ──────────────────────── */
.section        { padding-block: var(--section-py); }
.section--black { background: var(--clr-black); }
.section--mid   { background: var(--clr-black-mid); }

.section__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 3rem;
}
.section__title {
    font-family: var(--font-display);
    font-size: var(--fs-20);
    font-weight: 700;
    letter-spacing: var(--ls-section);
    text-transform: uppercase;
}
.section__view-all {
    font-size: var(--fs-9);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3em;
    color: var(--clr-gray-5);
    transition: color var(--t);
}
.section__view-all:hover { color: var(--clr-white); }

/* ── Breadcrumb ───────────────────────────── */
.breadcrumb {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding-block: 1.25rem;
}
.breadcrumb__link {
    font-size: var(--fs-10);
    letter-spacing: var(--ls-wide);
    color: var(--clr-gray-3);
    transition: color var(--t);
}
.breadcrumb__link:hover { color: var(--clr-white); }
.breadcrumb__sep  { font-size: var(--fs-10); color: rgba(255,255,255,0.15); }
.breadcrumb__current { font-size: var(--fs-10); color: var(--clr-maroon); letter-spacing: var(--ls-wide); }

/* ── Navigation ───────────────────────────── */
.nav {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 50;
    background: rgba(0,0,0,0.4);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    transition: background var(--t);
    height: var(--nav-h);
}
.nav.is-scrolled { background: rgba(0,0,0,0.88); }

.nav__grid {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    height: 100%;
}
.nav__grid.container { max-width: 1400px; } /* Widen header only */

.nav__left { display: flex; align-items: center; justify-self: start; }

.nav__logo { display: flex; align-items: center; gap: 0.75rem; }
.nav__logo-img { height: 65px; width: auto; object-fit: contain; }
.nav__logo:hover .nav__logo-img { opacity: 0.8; }
.nav__logo-name {
    font-family: var(--font-display);
    font-size: var(--fs-11);
    font-weight: 700;
    letter-spacing: 0.35em;
    text-transform: uppercase;
}
.nav__logo-sub { font-size: 7px; letter-spacing: 0.4em; color: rgba(255,255,255,0.32); text-transform: uppercase; }

.nav__links { display: none; align-items: center; gap: 1.75rem; justify-self: center; }
@media (min-width: 1024px) { .nav__links { display: flex; } }

.nav__link {
    font-size: var(--fs-10);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: var(--ls-nav);
    color: var(--clr-gray-5);
    transition: color var(--t);
}
.nav__link:hover, .nav__link.is-active { color: var(--clr-white); }

.nav__icons { display: flex; align-items: center; gap: 1.25rem; justify-self: end; }
.nav__icon-btn {
    display: flex; align-items: center; justify-content: center;
    color: var(--clr-gray-4);
    transition: color var(--t);
    position: relative;
}
.nav__icon-btn:hover { color: var(--clr-white); }
.nav__icon-btn.is-active { color: var(--clr-maroon); }
.nav__icon-btn svg { width: 16px; height: 16px; }

.nav__mobile-btn { display: flex; align-items: center; color: var(--clr-gray-4); transition: color var(--t); }
.nav__mobile-btn:hover { color: var(--clr-white); }
.nav__mobile-btn svg { width: 20px; height: 20px; }
@media (min-width: 1024px) { .nav__mobile-btn { display: none; } }

@media (max-width: 1024px) {
    .nav__grid {
        display: flex !important;
        justify-content: space-between !important;
        padding: 0 1rem !important;
    }
    .nav__left {
        flex: 0 0 auto !important;
        order: 1;
    }
    .nav__icons {
        flex: 0 0 auto !important;
        order: 2;
    }
    [dir="rtl"] .nav__left {
        order: 2;
    }
    [dir="rtl"] .nav__icons {
        order: 1;
    }
}

.nav__mobile-menu {
    display: none;
    position: fixed;
    top: var(--nav-h); left: 0; right: 0;
    z-index: 40;
    background: rgba(0,0,0,0.96);
    backdrop-filter: blur(12px);
    padding: 1.5rem 2.5rem;
    flex-direction: column;
    gap: 1.25rem;
}
.nav__mobile-menu.is-open { display: flex; }
.nav__mobile-link {
    font-size: var(--fs-11);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: var(--clr-gray-5);
    transition: color var(--t);
}
.nav__mobile-link:hover, .nav__mobile-link.is-active { color: var(--clr-white); }



[dir="rtl"] .nav { /* order is reversed automatically by dir="rtl" */ }
[dir="rtl"] .nav__left { flex-direction: row-reverse; }
[dir="rtl"] .nav__links { flex-direction: row-reverse; }
[dir="rtl"] .nav__icons { flex-direction: row-reverse; }

/* ── Buttons ──────────────────────────────── */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    font-family: var(--font-primary);
    font-weight: 600;
    font-size: var(--fs-10);
    text-transform: uppercase;
    letter-spacing: var(--ls-btn);
    cursor: pointer;
    border-radius: 2px;
    white-space: nowrap;
    transition: background var(--t), border-color var(--t), color var(--t);
}
.btn--primary  { background: var(--clr-maroon); color: var(--clr-white); padding: 0.75rem 3rem; border: none; }
.btn--primary:hover { background: var(--clr-maroon-light); }
.btn--outline  { background: transparent; color: var(--clr-white); padding: 0.65rem 1.5rem; border: 1px solid var(--clr-border-lg); }
.btn--outline:hover { border-color: var(--clr-white); }
.btn--white    { background: var(--clr-white); color: #000; padding: 6px 14px; font-size: var(--fs-9); border: none; }
.btn--white:hover { background: #e5e5e5; }
.btn--pill     { border-radius: 9999px; }
.btn--full     { width: 100%; }
.btn--buy-now  { background: var(--clr-maroon); color: var(--clr-white); padding: 0.65rem 1.5rem; border: none; }
.btn--buy-now:hover { background: var(--clr-maroon-light); }

/* ── Product Card (shared across pages) ───── */
.product-grid { display: grid; grid-template-columns: 1fr; gap: 2rem 2rem; }
@media (min-width: 768px) { .product-grid { grid-template-columns: repeat(3, 1fr); } }
.product-grid--gap-lg { row-gap: 3rem; }

.product-card {
    position: relative;
    background: rgba(28, 28, 30, 0.4);
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.05);
    transition: transform var(--t), box-shadow var(--t), border-color var(--t);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.product-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.3);
    border-color: rgba(255, 255, 255, 0.1);
}

.product-card__wish-btn {
    position: absolute;
    top: 1rem; right: 1rem;
    z-index: 10;
    width: 32px;
    height: 32px;
    background: var(--clr-white);
    color: var(--clr-gray-6);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 10px rgba(0,0,0,0.15);
    opacity: 0.9;
    transition: transform var(--t), opacity var(--t), color var(--t);
}
[dir="rtl"] .product-card__wish-btn { right: auto; left: 1rem; }
.product-card__wish-btn:hover { transform: scale(1.1); opacity: 1; }
.product-card__wish-btn svg { width: 16px; height: 16px; }
.product-card__wish-btn.is-wished { color: #e11d48; opacity: 1; }
.product-card__wish-btn.is-wished svg { fill: currentColor; }

.product-card__img-wrap {
    aspect-ratio: 1/1;
    background: #252527;
    border-bottom: 1px solid var(--clr-border);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
}
.product-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--t-slow);
}
.product-card:hover .product-card__img { transform: scale(1.1); }

.product-card__info {
    padding: 1.25rem 1.25rem 1.25rem 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}
.product-card__name {
    font-family: var(--font-display);
    font-size: var(--fs-12);
    font-weight: 700;
    letter-spacing: var(--ls-product);
    text-transform: uppercase;
}
.product-card__desc {
    font-size: var(--fs-9);
    color: var(--clr-gray-5);
    letter-spacing: 0.1em;
    font-weight: 300;
    margin-bottom: 1rem;
}
.product-card__footer { display: flex; align-items: center; justify-content: space-between; }
[dir="rtl"] .product-card__footer { flex-direction: row-reverse; }
.product-card__price { font-size: var(--fs-16); font-weight: 600; }

/* ── Stars ────────────────────────────────── */
.stars { display: flex; align-items: center; gap: 2px; }
.star { width: 14px; height: 14px; }
.star--filled { color: var(--clr-star); }
.star--empty  { color: var(--clr-gray-6); }

/* ── Badge ────────────────────────────────── */
.badge {
    font-size: var(--fs-9);
    font-weight: 700;
    letter-spacing: 0.1em;
    padding: 3px 10px;
    text-transform: uppercase;
    border-radius: 2px;
}
.badge--in-stock  { background: rgba(84,11,19,0.8); color: #ff8a95; }
.badge--out-stock { background: rgba(60,60,60,0.8); color: #888; }

/* ── Size Selector ────────────────────────── */
.size-group { display: flex; align-items: center; gap: 0.75rem; }
.size-btn {
    border: 1px solid var(--clr-border-md);
    color: var(--clr-white);
    font-family: var(--font-primary);
    font-size: var(--fs-10);
    padding: 5px 14px;
    letter-spacing: 0.1em;
    transition: all var(--t);
    cursor: pointer;
    background: transparent;
    border-radius: 2px;
}
.size-btn:hover, .size-btn.is-active { border-color: var(--clr-white); background: var(--clr-white); color: #000; }

/* ── Quantity Selector ────────────────────── */
.qty { display: flex; align-items: center; }
.qty__btn {
    width: 32px; height: 32px;
    display: flex; align-items: center; justify-content: center;
    border: 1px solid var(--clr-border-md);
    color: var(--clr-white);
    font-size: 16px;
    cursor: pointer;
    transition: all var(--t);
    background: transparent;
}
.qty__btn:hover { border-color: var(--clr-white); background: rgba(255,255,255,0.05); }
.qty__display {
    width: 40px; height: 32px;
    display: flex; align-items: center; justify-content: center;
    border-top: 1px solid var(--clr-border-md);
    border-bottom: 1px solid var(--clr-border-md);
    font-size: var(--fs-12);
    font-weight: 600;
}

/* ── Also Like Slider ─────────────────────── */
.also-like { }
.also-like__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 2rem; }
.also-like__title { font-family: var(--font-display); font-size: var(--fs-14); font-weight: 700; letter-spacing: var(--ls-widest); text-transform: uppercase; }
.also-like__btn { color: var(--clr-gray-5); transition: color var(--t); }
.also-like__btn:hover { color: var(--clr-white); }
.also-like__btn svg { width: 20px; height: 20px; }
.also-like__slider { display: flex; gap: 1.5rem; overflow-x: auto; scroll-behavior: smooth; scrollbar-width: none; }
.also-like__slider::-webkit-scrollbar { display: none; }
.also-like__card { flex-shrink: 0; width: 220px; }

/* ── Footer ───────────────────────────────── */
.site-footer { background: var(--clr-black); padding-top: 4rem; padding-bottom: 2rem; position: relative; overflow: hidden; }
.site-footer__decor {
    position: absolute; right: 0; bottom: 0;
    width: 260px; opacity: 0.06; pointer-events: none; user-select: none;
}
[dir="rtl"] .site-footer__decor { right: auto; left: 0; }
.site-footer__grid { display: grid; grid-template-columns: 1fr; gap: 3rem; margin-bottom: 3rem; }
@media (min-width: 768px) { .site-footer__grid { grid-template-columns: repeat(3, 1fr); } }

.site-footer__logo { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 0.75rem; }
.site-footer__logo-icon { width: 48px; height: 48px; opacity: 0.8; }
.site-footer__logo-name { font-family: var(--font-display); font-size: var(--fs-18); font-weight: 700; letter-spacing: 0.4em; text-transform: uppercase; }
.site-footer__logo-sub  { font-size: 7px; letter-spacing: 0.45em; color: rgba(255,255,255,0.28); text-transform: uppercase; }
.site-footer__tagline { font-size: var(--fs-9); color: var(--clr-gray-6); text-transform: uppercase; letter-spacing: 0.3em; max-width: 180px; line-height: 1.8; }

.site-footer__nav-heading { font-family: var(--font-display); font-size: var(--fs-10); font-weight: 700; letter-spacing: 0.3em; text-transform: uppercase; margin-bottom: 1.25rem; }
.site-footer__nav { display: flex; flex-direction: column; gap: 0.75rem; }
.site-footer__nav-link { font-size: var(--fs-9); text-transform: uppercase; letter-spacing: 0.25em; color: var(--clr-gray-5); font-weight: 500; transition: color var(--t); }
.site-footer__nav-link:hover { color: var(--clr-white); }

.site-footer__contact-heading { font-family: var(--font-display); font-size: var(--fs-10); font-weight: 700; letter-spacing: 0.3em; text-transform: uppercase; margin-bottom: 1.25rem; }
.site-footer__contact-list { display: flex; flex-direction: column; gap: 0.75rem; }
.site-footer__contact-item { display: flex; align-items: flex-start; gap: 0.75rem; }
.site-footer__contact-icon { flex-shrink: 0; margin-top: 2px; opacity: 0.2; }
.site-footer__contact-icon svg { width: 14px; height: 14px; }
.site-footer__contact-text { font-size: var(--fs-9); color: var(--clr-gray-5); text-transform: uppercase; letter-spacing: 0.15em; line-height: 1.8; }
.site-footer__social { display: flex; align-items: center; gap: 1rem; margin-top: 0.75rem; }
.site-footer__social-link { color: var(--clr-gray-6); transition: color var(--t); }
.site-footer__social-link:hover { color: var(--clr-white); }
.site-footer__social-link svg { width: 18px; height: 18px; }

.site-footer__bottom { border-top: 1px solid var(--clr-border); padding-top: 1.5rem; text-align: center; }
.site-footer__copy { font-size: 8px; color: var(--clr-gray-6); text-transform: uppercase; letter-spacing: var(--ls-footer); }

[dir="rtl"] .site-footer__contact-item { flex-direction: row-reverse; }
[dir="rtl"] .site-footer__social { flex-direction: row-reverse; }

/* ── About Section Component ──────────────── */
.about { background: var(--clr-about-bg); position: relative; overflow: hidden; }
.about-page { padding-top: 1.5rem; } /* Keep some padding if needed, but remove background override */
.about__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 4rem;
    align-items: center;
}
@media (min-width: 1024px) { .about__grid { grid-template-columns: repeat(2, 1fr); } }

.about__img-wrap { position: relative; aspect-ratio: 4/5; overflow: hidden; border-radius: 8px; }
.about__img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1); opacity: 0.8; transition: filter 1s ease, opacity 1s ease; }
.about__img-wrap:hover .about__img { filter: grayscale(0); opacity: 1; }

.about__content { display: flex; flex-direction: column; gap: 3rem; }
.about__heading {
    font-family: var(--font-display);
    font-size: clamp(2rem, 5vw, 3rem);
    font-weight: 700;
    letter-spacing: 0.2em;
}
.about__body { display: flex; align-items: flex-start; gap: 2.5rem; }
[dir="rtl"] .about__body { flex-direction: row-reverse; }

.about__amer { display: flex; align-items: flex-start; gap: 0.75rem; }
.about__amer-letters { display: flex; flex-direction: column; align-items: center; gap: 1rem; }
.about__amer-letter { font-family: var(--font-display); font-size: 1.875rem; font-weight: 700; line-height: 1; }
.about__label-side {
    font-family: var(--font-display);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.6em;
    writing-mode: vertical-rl;
    opacity: 0.35;
    font-weight: 700;
    color: var(--clr-white);
    margin-top: 2px;
}

.about__text-block {
    border-left: 1px solid rgba(255,255,255,0.18);
    padding-left: 2.5rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}
[dir="rtl"] .about__text-block { border-left: none; border-right: 1px solid rgba(255,255,255,0.18); padding-left: 0; padding-right: 2.5rem; }
.about__sub   { font-size: var(--fs-12); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; }
.about__para  { font-size: var(--fs-11); color: rgba(255,255,255,0.55); line-height: 1.9; font-weight: 300; letter-spacing: 0.05em; max-width: 22rem; }

.about__decor-img {
    position: absolute;
    bottom: -2.5rem; right: -2.5rem;
    width: min(18rem, 30vw);
    opacity: 0.18;
    transform: rotate(12deg);
    pointer-events: none;
}
[dir="rtl"] .about__decor-img { right: auto; left: -2.5rem; transform: rotate(-12deg); }

