/* ==========================================================================
   FAYOS — Main stylesheet
   Depends on tokens.css (loaded first). Organized: base → layout → components.
   ========================================================================== */

/* ----------------------------- Reset / Base ----------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--fy-font-sans);
  font-size: var(--fy-fs-base);
  line-height: var(--fy-lh-base);
  color: var(--fy-text);
  background: var(--fy-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1, h2, h3, h4 { font-family: var(--fy-font-display); line-height: var(--fy-lh-tight); margin: 0 0 var(--fy-sp-3); color: var(--fy-gray-900); font-weight: 700; }
h1 { font-size: var(--fy-fs-4xl); letter-spacing: -0.02em; }
h2 { font-size: var(--fy-fs-3xl); letter-spacing: -0.01em; }
h3 { font-size: var(--fy-fs-xl); }
p { margin: 0 0 var(--fy-sp-4); }
a { color: var(--fy-primary); text-decoration: none; transition: color var(--fy-dur) var(--fy-ease); }
a:hover { color: var(--fy-secondary); }
img { max-width: 100%; height: auto; display: block; }
ul, ol { margin: 0; padding: 0; list-style: none; }
:focus-visible { outline: 3px solid var(--fy-secondary); outline-offset: 2px; border-radius: 4px; }

/* Skip link (a11y) */
.fy-skip-link {
  position: absolute; left: -999px; top: 0; z-index: var(--fy-z-modal);
  background: var(--fy-primary); color: #fff; padding: 12px 18px; border-radius: 0 0 var(--fy-radius-sm) 0;
}
.fy-skip-link:focus { left: 0; color: #fff; }

/* ------------------------------- Layout --------------------------------- */
.fy-container { width: 100%; max-width: var(--fy-container); margin-inline: auto; padding-inline: var(--fy-sp-4); }
.fy-container--wide { max-width: var(--fy-container-wide); }
.fy-section { padding-block: var(--fy-sp-8); }
.fy-section--alt { background: var(--fy-bg-alt); }
.fy-grid { display: grid; gap: var(--fy-sp-5); }
.fy-section__head { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--fy-sp-4); margin-bottom: var(--fy-sp-5); }
.fy-section__head h2 { margin: 0; }
.fy-section__head .fy-link-more { font-weight: 600; font-size: var(--fy-fs-sm); white-space: nowrap; }

/* ------------------------------- Buttons -------------------------------- */
.fy-btn {
  --_bg: var(--fy-primary); --_fg: #fff;
  display: inline-flex; align-items: center; justify-content: center; gap: var(--fy-sp-2);
  font-family: var(--fy-font-sans); font-weight: 600; font-size: var(--fy-fs-sm);
  padding: 0.75rem 1.4rem; border: 0; border-radius: var(--fy-radius-pill);
  background: var(--_bg); color: var(--_fg); cursor: pointer;
  transition: transform var(--fy-dur) var(--fy-ease), box-shadow var(--fy-dur) var(--fy-ease), background var(--fy-dur);
  text-decoration: none; line-height: 1;
}
.fy-btn:hover { transform: translateY(-2px); box-shadow: var(--fy-shadow); color: #fff; }
.fy-btn:active { transform: translateY(0); }
.fy-btn--secondary { --_bg: var(--fy-secondary); }
.fy-btn--secondary:hover { background: var(--fy-secondary-600); }
.fy-btn--ghost { --_bg: transparent; --_fg: var(--fy-primary); border: 1.5px solid var(--fy-border); }
.fy-btn--ghost:hover { --_fg: var(--fy-primary); background: var(--fy-primary-050); color: var(--fy-primary); }
.fy-btn--lg { padding: 1rem 2rem; font-size: var(--fy-fs-base); }
.fy-btn--block { width: 100%; }

/* -------------------------------- Header -------------------------------- */
.fy-header { position: sticky; top: 0; z-index: var(--fy-z-header); background: var(--fy-white); border-bottom: 1px solid var(--fy-border); }
.fy-header__top { background: var(--fy-primary); color: #fff; font-size: var(--fy-fs-xs); }
.fy-header__top .fy-container { display: flex; align-items: center; justify-content: space-between; min-height: 36px; }
.fy-header__top a { color: rgba(255,255,255,.9); }
.fy-header__top a:hover { color: #fff; }
.fy-header__main { display: flex; align-items: center; gap: var(--fy-sp-5); min-height: var(--fy-header-h); }
.fy-logo { font-family: var(--fy-font-display); font-weight: 800; font-size: 1.6rem; letter-spacing: -0.03em; color: var(--fy-primary); display: inline-flex; align-items: center; }
.fy-logo span { color: var(--fy-secondary); }
.fy-logo:hover { color: var(--fy-primary); }

/* Search bar */
.fy-search { flex: 1; max-width: 640px; position: relative; }
.fy-search form { display: flex; border: 2px solid var(--fy-primary); border-radius: var(--fy-radius-pill); overflow: hidden; background: #fff; }
.fy-search input[type="search"] { flex: 1; border: 0; padding: 0.7rem 1.1rem; font-size: var(--fy-fs-sm); outline: none; }
.fy-search button { border: 0; background: var(--fy-secondary); color: #fff; padding-inline: 1.3rem; cursor: pointer; font-weight: 600; }
.fy-search button:hover { background: var(--fy-secondary-600); }

/* Instant-search dropdown panel */
.fy-search__panel {
  position: absolute; top: calc(100% + 8px); left: 0; right: 0; z-index: var(--fy-z-drawer);
  background: #fff; border: 1px solid var(--fy-border); border-radius: var(--fy-radius);
  box-shadow: var(--fy-shadow-lg); padding: var(--fy-sp-3); max-height: 70vh; overflow-y: auto;
}
.fy-search__group { padding: var(--fy-sp-2) 0; }
.fy-search__group + .fy-search__group { border-top: 1px solid var(--fy-border); margin-top: var(--fy-sp-2); }
.fy-search__label { display: block; font-size: var(--fy-fs-xs); text-transform: uppercase; letter-spacing: .04em; color: var(--fy-text-muted); font-weight: 700; padding: 4px 8px; }
.fy-search__chips { display: flex; flex-wrap: wrap; gap: 6px; padding: 4px 8px; }
.fy-search__chip { background: var(--fy-gray-050); border: 1px solid var(--fy-border); border-radius: var(--fy-radius-pill); padding: 5px 12px; font-size: var(--fy-fs-sm); color: var(--fy-gray-700); }
.fy-search__chip:hover, .fy-search__chip.is-active { background: var(--fy-primary-050); color: var(--fy-primary); border-color: var(--fy-primary-050); }
.fy-search__item { display: flex; align-items: center; gap: var(--fy-sp-3); padding: 8px; border-radius: var(--fy-radius-sm); }
.fy-search__item:hover, .fy-search__item.is-active, .fy-search__cat:hover, .fy-search__cat.is-active, .fy-search__all.is-active { background: var(--fy-gray-050); }
.fy-search__item img { width: 44px; height: 44px; object-fit: cover; border-radius: var(--fy-radius-sm); background: var(--fy-gray-100); }
.fy-search__item-text { display: flex; flex-direction: column; min-width: 0; }
.fy-search__item-title { font-size: var(--fy-fs-sm); font-weight: 600; color: var(--fy-gray-900); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.fy-search__item-price { font-size: var(--fy-fs-xs); color: var(--fy-primary); font-weight: 700; }
.fy-search__cat { display: flex; align-items: center; justify-content: space-between; padding: 8px; border-radius: var(--fy-radius-sm); font-size: var(--fy-fs-sm); color: var(--fy-gray-700); }
.fy-search__count { color: var(--fy-text-muted); font-size: var(--fy-fs-xs); }
.fy-search__all { display: block; text-align: center; padding: 10px; font-weight: 600; font-size: var(--fy-fs-sm); color: var(--fy-primary); border-top: 1px solid var(--fy-border); margin-top: var(--fy-sp-2); }
.fy-search__empty { padding: var(--fy-sp-4); text-align: center; color: var(--fy-text-muted); font-size: var(--fy-fs-sm); }
.fy-search__loading { padding: var(--fy-sp-2); }

/* Header actions */
.fy-header__actions { display: flex; align-items: center; gap: var(--fy-sp-4); margin-left: auto; }
.fy-iconbtn { position: relative; display: inline-flex; flex-direction: column; align-items: center; gap: 2px; color: var(--fy-gray-700); font-size: var(--fy-fs-xs); font-weight: 500; }
.fy-iconbtn:hover { color: var(--fy-primary); }
.fy-iconbtn svg { width: 24px; height: 24px; }
.fy-badge { position: absolute; top: -6px; right: -8px; background: var(--fy-secondary); color: #fff; font-size: 10px; font-weight: 700; min-width: 18px; height: 18px; border-radius: var(--fy-radius-pill); display: grid; place-items: center; padding-inline: 4px; }

/* Primary nav */
.fy-nav { border-top: 1px solid var(--fy-border); background: var(--fy-white); }
.fy-nav__list { display: flex; gap: var(--fy-sp-5); align-items: center; min-height: 48px; overflow-x: auto; }
.fy-nav__list a { color: var(--fy-gray-700); font-size: var(--fy-fs-sm); font-weight: 600; white-space: nowrap; padding-block: 4px; border-bottom: 2px solid transparent; }
.fy-nav__list a:hover { color: var(--fy-primary); border-color: var(--fy-secondary); }
.fy-nav__deals { color: var(--fy-secondary) !important; }

/* Mobile menu toggle */
.fy-menu-toggle { display: none; background: none; border: 0; cursor: pointer; color: var(--fy-gray-900); }
.fy-menu-toggle svg { width: 28px; height: 28px; }

/* -------------------------------- Hero ---------------------------------- */
.fy-hero { display: grid; grid-template-columns: 1fr; gap: var(--fy-sp-5); padding-block: var(--fy-sp-6); }
.fy-hero__main {
  position: relative; border-radius: var(--fy-radius-lg); overflow: hidden; min-height: 380px;
  background: linear-gradient(120deg, var(--fy-primary) 0%, var(--fy-primary-700) 60%, #07243f 100%);
  color: #fff; display: flex; align-items: center; padding: var(--fy-sp-8);
}
.fy-hero__main::after { content: ""; position: absolute; right: -80px; top: -80px; width: 360px; height: 360px; border-radius: 50%; background: radial-gradient(circle, rgba(255,122,0,.35), transparent 70%); }
.fy-hero__content { position: relative; max-width: 520px; z-index: 1; }
.fy-hero__eyebrow { display: inline-block; background: rgba(255,255,255,.14); padding: 6px 14px; border-radius: var(--fy-radius-pill); font-size: var(--fy-fs-xs); font-weight: 600; letter-spacing: .04em; text-transform: uppercase; margin-bottom: var(--fy-sp-4); }
.fy-hero__content h1 { color: #fff; font-size: clamp(2rem, 4vw, 3rem); margin-bottom: var(--fy-sp-4); }
.fy-hero__content p { color: rgba(255,255,255,.85); font-size: var(--fy-fs-lg); margin-bottom: var(--fy-sp-5); }

/* ------------------------------ Category pills/cards -------------------- */
.fy-cats { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--fy-sp-4); }
.fy-cat-card { display: flex; flex-direction: column; align-items: center; gap: var(--fy-sp-2); padding: var(--fy-sp-5) var(--fy-sp-3); background: var(--fy-white); border: 1px solid var(--fy-border); border-radius: var(--fy-radius); text-align: center; transition: transform var(--fy-dur) var(--fy-ease), box-shadow var(--fy-dur) var(--fy-ease), border-color var(--fy-dur); }
.fy-cat-card:hover { transform: translateY(-4px); box-shadow: var(--fy-shadow); border-color: var(--fy-primary-050); }
.fy-cat-card__icon { width: 56px; height: 56px; border-radius: 50%; background: var(--fy-primary-050); color: var(--fy-primary); display: grid; place-items: center; }
.fy-cat-card__icon svg { width: 28px; height: 28px; }
.fy-cat-card span { font-size: var(--fy-fs-sm); font-weight: 600; color: var(--fy-gray-900); }

/* ------------------------------ Product card ---------------------------- */
.fy-products { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--fy-sp-5); }
.fy-product {
  position: relative; background: var(--fy-white); border: 1px solid var(--fy-border); border-radius: var(--fy-radius);
  overflow: hidden; display: flex; flex-direction: column;
  transition: transform var(--fy-dur) var(--fy-ease), box-shadow var(--fy-dur) var(--fy-ease);
}
.fy-product:hover { transform: translateY(-6px); box-shadow: var(--fy-shadow-lg); }
.fy-product__media { position: relative; aspect-ratio: 1 / 1; background: var(--fy-gray-050); overflow: hidden; }
.fy-product__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 400ms var(--fy-ease); }
.fy-product:hover .fy-product__media img { transform: scale(1.06); }
.fy-product__tag { position: absolute; top: 10px; left: 10px; background: var(--fy-secondary); color: #fff; font-size: var(--fy-fs-xs); font-weight: 700; padding: 4px 10px; border-radius: var(--fy-radius-pill); }
.fy-product__wish { position: absolute; top: 10px; right: 10px; width: 38px; height: 38px; border-radius: 50%; background: rgba(255,255,255,.92); border: 0; display: grid; place-items: center; cursor: pointer; box-shadow: var(--fy-shadow-xs); color: var(--fy-gray-600); transition: color var(--fy-dur), transform var(--fy-dur); }
.fy-product__wish:hover { color: var(--fy-danger); transform: scale(1.08); }
.fy-product__body { padding: var(--fy-sp-4); display: flex; flex-direction: column; gap: var(--fy-sp-2); flex: 1; }
.fy-product__brand { font-size: var(--fy-fs-xs); color: var(--fy-text-muted); text-transform: uppercase; letter-spacing: .03em; }
.fy-product__title { font-size: var(--fy-fs-sm); font-weight: 600; color: var(--fy-gray-900); line-height: 1.35; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: 2.7em; }
.fy-product__rating { display: flex; align-items: center; gap: 4px; font-size: var(--fy-fs-xs); color: var(--fy-text-muted); }
.fy-product__stars { color: var(--fy-secondary); letter-spacing: 1px; }
.fy-product__price { display: flex; align-items: baseline; gap: var(--fy-sp-2); margin-top: auto; }
.fy-product__price .now { font-family: var(--fy-font-display); font-weight: 700; font-size: var(--fy-fs-lg); color: var(--fy-primary); }
.fy-product__price .was { font-size: var(--fy-fs-sm); color: var(--fy-text-muted); text-decoration: line-through; }
.fy-product__cta { margin-top: var(--fy-sp-3); }

/* ---------------------------- Flash sale strip -------------------------- */
.fy-flash { background: linear-gradient(100deg, #1a1320, #2a1206); color: #fff; border-radius: var(--fy-radius-lg); padding: var(--fy-sp-6); }
.fy-flash__head { display: flex; align-items: center; gap: var(--fy-sp-4); flex-wrap: wrap; margin-bottom: var(--fy-sp-5); }
.fy-flash__head h2 { color: #fff; margin: 0; display: flex; align-items: center; gap: 8px; }
.fy-countdown { display: flex; gap: 6px; }
.fy-countdown span { background: rgba(255,255,255,.12); border-radius: var(--fy-radius-sm); padding: 6px 10px; font-weight: 700; font-variant-numeric: tabular-nums; min-width: 40px; text-align: center; }

/* ------------------------------- Skeleton ------------------------------- */
.fy-skel { background: linear-gradient(90deg, var(--fy-gray-100) 25%, var(--fy-gray-050) 37%, var(--fy-gray-100) 63%); background-size: 400% 100%; animation: fy-shimmer 1.4s ease infinite; border-radius: var(--fy-radius-sm); }
@keyframes fy-shimmer { 0% { background-position: 100% 0; } 100% { background-position: 0 0; } }

/* Reveal on scroll */
.fy-reveal { opacity: 0; transform: translateY(18px); transition: opacity .6s var(--fy-ease), transform .6s var(--fy-ease); }
.fy-reveal.is-visible { opacity: 1; transform: none; }

/* -------------------------------- Footer -------------------------------- */
.fy-footer { background: var(--fy-gray-900); color: var(--fy-gray-300); padding-block: var(--fy-sp-8) var(--fy-sp-5); margin-top: var(--fy-sp-10); }
.fy-footer a { color: var(--fy-gray-300); font-size: var(--fy-fs-sm); }
.fy-footer a:hover { color: var(--fy-secondary); }
.fy-footer__grid { display: grid; grid-template-columns: 1.4fr repeat(3, 1fr); gap: var(--fy-sp-6); }
.fy-footer h4 { color: #fff; font-size: var(--fy-fs-base); margin-bottom: var(--fy-sp-4); }
.fy-footer ul li { margin-bottom: var(--fy-sp-2); }
.fy-footer__brand .fy-logo { color: #fff; }
.fy-footer__brand p { color: var(--fy-gray-400); font-size: var(--fy-fs-sm); max-width: 320px; }
.fy-footer__bottom { border-top: 1px solid rgba(255,255,255,.08); margin-top: var(--fy-sp-6); padding-top: var(--fy-sp-4); display: flex; justify-content: space-between; gap: var(--fy-sp-4); flex-wrap: wrap; font-size: var(--fy-fs-xs); color: var(--fy-gray-400); }
.fy-pay-badges { display: flex; gap: var(--fy-sp-2); align-items: center; }
.fy-pay-badges span { background: rgba(255,255,255,.08); border-radius: 6px; padding: 4px 8px; font-size: 10px; font-weight: 600; letter-spacing: .03em; }

/* ------------------------------ Newsletter ------------------------------ */
.fy-newsletter { background: linear-gradient(120deg, var(--fy-secondary), var(--fy-secondary-600)); color: #fff; border-radius: var(--fy-radius-lg); padding: var(--fy-sp-8); display: grid; gap: var(--fy-sp-4); text-align: center; }
.fy-newsletter h2 { color: #fff; }
.fy-newsletter form { display: flex; gap: var(--fy-sp-2); max-width: 480px; margin-inline: auto; width: 100%; }
.fy-newsletter input { flex: 1; border: 0; border-radius: var(--fy-radius-pill); padding: 0.85rem 1.2rem; font-size: var(--fy-fs-sm); }
.fy-newsletter .fy-btn { background: var(--fy-gray-900); }

/* ------------------------------ Mobile drawer --------------------------- */
.fy-drawer { position: fixed; inset: 0 30% 0 0; max-width: 340px; background: #fff; z-index: var(--fy-z-drawer); transform: translateX(-100%); transition: transform var(--fy-dur) var(--fy-ease); padding: var(--fy-sp-5); overflow-y: auto; box-shadow: var(--fy-shadow-lg); }
.fy-drawer.is-open { transform: none; }
.fy-overlay { position: fixed; inset: 0; background: rgba(16,24,40,.5); z-index: var(--fy-z-header); opacity: 0; visibility: hidden; transition: opacity var(--fy-dur); }
.fy-overlay.is-open { opacity: 1; visibility: visible; }
.fy-drawer__nav a { display: block; padding: var(--fy-sp-3) 0; border-bottom: 1px solid var(--fy-border); font-weight: 600; color: var(--fy-gray-900); }

/* ------------------------------- Utilities ------------------------------ */
.fy-visually-hidden { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.fy-text-center { text-align: center; }
.fy-mt-0 { margin-top: 0; }

/* ------------------------------ Breadcrumbs ----------------------------- */
.fy-breadcrumbs { font-size: var(--fy-fs-sm); color: var(--fy-text-muted); padding-block: var(--fy-sp-4); }
.fy-breadcrumbs a { color: var(--fy-text-muted); }
.fy-breadcrumbs a:hover { color: var(--fy-primary); }
.fy-breadcrumbs .sep { margin-inline: 6px; }

/* ------------------------------ Responsive ------------------------------ */
@media (min-width: 600px) {
  .fy-cats { grid-template-columns: repeat(3, 1fr); }
  .fy-products { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 768px) {
  .fy-hero { grid-template-columns: 2fr 1fr; }
}
@media (min-width: 992px) {
  .fy-cats { grid-template-columns: repeat(6, 1fr); }
  .fy-products { grid-template-columns: repeat(4, 1fr); }
}

/* Mobile: collapse desktop nav, show toggle */
@media (max-width: 860px) {
  .fy-nav { display: none; }
  .fy-search { order: 3; max-width: none; flex-basis: 100%; }
  .fy-header__main { flex-wrap: wrap; }
  .fy-menu-toggle { display: inline-flex; }
  .fy-footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 520px) {
  h1 { font-size: var(--fy-fs-3xl); }
  h2 { font-size: var(--fy-fs-2xl); }
  .fy-products { grid-template-columns: repeat(2, 1fr); }
  .fy-footer__grid { grid-template-columns: 1fr; }
  .fy-header__top { display: none; }
}
