/* ============================================================
   NOVA — Ultra Minimal E-Commerce
   Mobile-first · Responsive · No-framework
   ============================================================ */

:root{
  --bg:        #ffffff;
  --bg-alt:    #f6f6f4;
  --ink:       #0d0d0f;
  --ink-2:     #1a1a1d;
  --muted:     #6b6b73;
  --line:      #e9e9e6;
  --line-2:    #ededea;
  --accent:    #ff5b2e;
  --accent-2:  #111;
  --gold:      #c9a86b;
  --ok:        #16a34a;
  --danger:    #e02424;

  --radius-sm: 10px;
  --radius:    16px;
  --radius-lg: 24px;
  --radius-xl: 32px;

  --shadow-sm: 0 1px 2px rgba(20,20,30,.04), 0 1px 1px rgba(20,20,30,.03);
  --shadow:    0 10px 30px -12px rgba(20,20,30,.18);
  --shadow-lg: 0 30px 60px -25px rgba(20,20,30,.28);

  --t:  .25s cubic-bezier(.2,.7,.2,1);
  --t2: .5s  cubic-bezier(.2,.7,.2,1);

  --container: 1320px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{
  font-family:'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
input,select,textarea{font:inherit;color:inherit}
em{font-family:'Gilroy', 'Inter', sans-serif;font-style:normal;font-weight:800;letter-spacing:-0.02em}

/* Headlines & display use Gilroy */
h1, h2, h3, h4, .display{
  font-family:'Gilroy', 'Inter', sans-serif;
  font-weight:800;
  letter-spacing:-0.025em;
}

.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:20px;
}
@media(min-width:768px){ .container{padding-inline:32px} }

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:999px;
  font-weight:600;font-size:14px;letter-spacing:.01em;
  transition:transform var(--t), background var(--t), color var(--t), box-shadow var(--t);
  white-space:nowrap;
}
.btn:hover{transform:translateY(-1px)}
.btn--dark{background:var(--ink);color:#fff}
.btn--dark:hover{background:#000;box-shadow:var(--shadow)}
.btn--light{background:#fff;color:var(--ink)}
.btn--ghost{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--ink)}
.btn--ghost:hover{background:var(--ink);color:#fff}
.btn--block{width:100%;justify-content:center}
.btn--lg{padding:16px 26px;font-size:15px}

.icon-btn{
  position:relative;
  width:42px;height:42px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--ink);
  transition:background var(--t), color var(--t);
}
.icon-btn:hover{background:var(--bg-alt)}
.icon-btn .ti{font-size:20px}
.badge{
  position:absolute;top:4px;right:4px;
  background:var(--accent);color:#fff;
  font-size:10px;font-weight:700;
  min-width:18px;height:18px;border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  padding:0 5px;
}

.link{
  display:inline-flex;align-items:center;gap:6px;
  font-weight:600;font-size:14px;
  border-bottom:1.5px solid transparent;padding-bottom:2px;
  transition:border-color var(--t);
}
.link:hover{border-color:var(--ink)}

.kicker{
  display:inline-block;
  font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);margin-bottom:10px;
}
.kicker--light{color:rgba(255,255,255,.7)}

/* ============ TOP STRIP ============ */
.topstrip{background:var(--ink);color:#fff;font-size:12.5px}
.topstrip__row{
  display:flex;align-items:center;justify-content:center;gap:28px;
  padding:9px 20px;flex-wrap:wrap;
}
.topstrip__row span{display:inline-flex;align-items:center;gap:6px}
.topstrip .ti{font-size:14px}
@media(max-width:600px){ .hide-sm{display:none} }

/* ============ HEADER ============ */
.header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line);
}
.header__row{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  height:72px;
}
.logo{display:inline-flex;align-items:center;gap:10px;font-weight:800}
.logo__mark{
  width:34px;height:34px;border-radius:10px;
  background:var(--ink);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  font-family:'Gilroy','Inter',sans-serif;font-weight:700;font-size:18px;
}
.logo__text{font-size:22px;letter-spacing:-0.02em}
.logo__text span{color:var(--accent)}
.logo--light .logo__text--light, .logo--light .logo__text{color:#fff}

.nav{display:none;gap:6px}
@media(min-width:980px){ .nav{display:flex} }
.nav__link{
  position:relative;padding:10px 14px;font-size:14.5px;font-weight:500;
  border-radius:999px;color:var(--ink-2);
  transition:background var(--t), color var(--t);
}
.nav__link:hover{background:var(--bg-alt)}
.nav__link.active{background:var(--ink);color:#fff}

.header__actions{display:flex;align-items:center;gap:2px}
.menu-toggle{display:inline-flex}
@media(min-width:980px){ .menu-toggle{display:none} }

/* ============ HERO ============ */
.hero{
  position:relative;
  background:var(--bg-alt);
  overflow:hidden;
}
.hero__slider{position:relative;height:clamp(520px, 78vh, 760px)}
.hero__slide{
  position:absolute;inset:0;
  display:grid;grid-template-columns:1fr;align-items:end;
  opacity:0;pointer-events:none;
  transition:opacity .7s ease;
  background:var(--accent);
  color:#fff;
}
.hero__slide.is-active{opacity:1;pointer-events:auto}
.hero__media{
  position:absolute;inset:0;
}
.hero__media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,.55) 60%, rgba(0,0,0,.85) 100%);
}
.hero__media img{
  width:100%;height:100%;object-fit:cover;
  transform:scale(1.06);transition:transform 8s ease;
}
.hero__slide.is-active .hero__media img{transform:scale(1)}

.hero__content{position:relative;z-index:2;padding-block:60px 100px}
.hero__eyebrow{
  display:inline-block;padding:6px 14px;
  border-radius:999px;border:1px solid rgba(255,255,255,.3);
  background:rgba(255,255,255,.08);backdrop-filter:blur(8px);
  font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  margin-bottom:18px;
}
.hero__title{
  font-family:'Gilroy','Inter',sans-serif;
  font-size:clamp(38px, 7vw, 84px);
  line-height:1;letter-spacing:-0.02em;font-weight:700;
  max-width:14ch;margin-bottom:18px;
}
.hero__desc{
  max-width:46ch;font-size:clamp(15px, 1.6vw, 17px);
  color:rgba(255,255,255,.85);margin-bottom:28px;
}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap}
.hero__cta .btn--ghost{color:#fff;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.6)}
.hero__cta .btn--ghost:hover{background:#fff;color:var(--ink)}
.hero__cta .btn--dark{background:#fff;color:var(--ink)}

.hero__meta{
  display:flex;gap:36px;margin-top:36px;
  padding-top:24px;border-top:1px solid rgba(255,255,255,.18);
  max-width:520px;
}
.hero__meta div{display:flex;flex-direction:column}
.hero__meta strong{font-size:22px;font-family:'Gilroy','Inter',sans-serif}
.hero__meta span{font-size:12px;color:rgba(255,255,255,.7);letter-spacing:.06em;text-transform:uppercase}

.hero__controls{
  position:absolute;left:0;right:0;bottom:20px;z-index:3;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
}
.hero__btn{
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.15);color:#fff;
  backdrop-filter:blur(10px);
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.25);
  transition:background var(--t), transform var(--t);
}
.hero__btn:hover{background:#fff;color:var(--ink);transform:scale(1.05)}
.hero__btn .ti{font-size:20px}
.hero__dots{display:flex;gap:8px}
.hero__dot{
  width:30px;height:4px;border-radius:4px;
  background:rgba(255,255,255,.35);cursor:pointer;
  transition:background var(--t), width var(--t);
}
.hero__dot.is-active{background:#fff;width:46px}

/* ============ FEATURES ============ */
.features{
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px;
  padding-block:34px;
}
@media(min-width:768px){ .features{grid-template-columns:repeat(4,1fr);gap:20px} }
.feature{
  display:flex;align-items:center;gap:14px;
  padding:18px;border-radius:var(--radius);
  background:var(--bg-alt);
  transition:transform var(--t), box-shadow var(--t);
}
.feature:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.feature .ti{font-size:26px;color:var(--ink)}
.feature strong{display:block;font-size:14px;font-weight:600}
.feature span{font-size:12.5px;color:var(--muted)}

/* ============ SECTION ============ */
.section{padding-block:64px}
.section--alt{background:var(--bg-alt)}
.section__head{
  display:flex;align-items:flex-end;justify-content:space-between;gap:20px;
  margin-bottom:36px;flex-wrap:wrap;
}
.section__head--center{
  flex-direction:column;align-items:center;text-align:center;
}
.section__title{
  font-family:'Gilroy','Inter',sans-serif;font-weight:700;
  font-size:clamp(28px, 4vw, 44px);letter-spacing:-0.02em;line-height:1.1;
}
.section__sub{color:var(--muted);max-width:50ch;margin-top:8px}

/* ============ CATEGORY GRID ============ */
.cat-grid{
  display:grid;gap:14px;
  grid-template-columns:1fr 1fr;
}
@media(min-width:768px){
  .cat-grid{
    grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;
  }
  .cat-card--lg{grid-column:span 2;grid-row:span 2}
}
.cat-card{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:1/1;
  isolation:isolate;
  transition:transform var(--t), box-shadow var(--t);
}
@media(min-width:768px){ .cat-card{aspect-ratio:auto;height:100%} }
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.cat-card img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;z-index:-1;
  transition:transform var(--t2);
}
.cat-card:hover img{transform:scale(1.08)}
.cat-card::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg, rgba(0,0,0,0) 30%, rgba(0,0,0,.7) 100%);
}
.cat-card__body{
  position:absolute;left:0;right:0;bottom:0;
  padding:18px;color:#fff;
}
.cat-card__count{
  display:inline-block;font-size:11px;font-weight:600;
  padding:4px 10px;border-radius:999px;
  background:rgba(255,255,255,.18);backdrop-filter:blur(6px);
  margin-bottom:8px;letter-spacing:.05em;
}
.cat-card__body h3{
  font-family:'Gilroy','Inter',sans-serif;font-weight:700;
  font-size:clamp(20px, 2.4vw, 30px);letter-spacing:-0.01em;
}
.cat-card__cta{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:8px;font-weight:600;font-size:13px;
  opacity:0;transform:translateY(6px);
  transition:opacity var(--t), transform var(--t);
}
.cat-card:hover .cat-card__cta{opacity:1;transform:translateY(0)}

/* ============ TABS ============ */
.tabs{
  display:flex;gap:6px;padding:5px;
  background:#fff;border-radius:999px;border:1px solid var(--line);
  overflow-x:auto;max-width:100%;
}
.tab{
  padding:9px 16px;border-radius:999px;
  font-size:13px;font-weight:600;color:var(--muted);
  white-space:nowrap;
  transition:background var(--t), color var(--t);
}
.tab:hover{color:var(--ink)}
.tab.is-active{background:var(--ink);color:#fff}

/* ============ PRODUCT GRID ============ */
.product-grid{
  display:grid;gap:18px;
  grid-template-columns:repeat(auto-fill, minmax(240px, 1fr));
}
.card{
  position:relative;background:#fff;border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid var(--line);
  transition:transform var(--t), box-shadow var(--t), border-color var(--t);
  display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.card__media{
  position:relative;aspect-ratio:1/1;background:var(--bg-alt);
  overflow:hidden;
}
.card__media img{
  width:100%;height:100%;object-fit:cover;
  transition:transform var(--t2);
}
.card:hover .card__media img{transform:scale(1.06)}
.card__tags{
  position:absolute;top:12px;left:12px;display:flex;gap:6px;flex-wrap:wrap;
}
.tag{
  font-size:10.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  padding:5px 10px;border-radius:999px;background:#fff;color:var(--ink);
}
.tag--sale{background:var(--accent);color:#fff}
.tag--new{background:var(--ink);color:#fff}
.tag--top{background:var(--gold);color:#fff}

.card__fav{
  position:absolute;top:12px;right:12px;
  width:36px;height:36px;border-radius:50%;background:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-sm);
  transition:color var(--t), transform var(--t);
}
.card__fav:hover{transform:scale(1.08);color:var(--accent)}

.card__add{
  position:absolute;left:12px;right:12px;bottom:12px;
  padding:11px 14px;border-radius:999px;
  background:var(--ink);color:#fff;font-weight:600;font-size:13px;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  transform:translateY(120%);opacity:0;
  transition:transform var(--t), opacity var(--t), background var(--t);
}
.card:hover .card__add{transform:translateY(0);opacity:1}
.card__add:hover{background:var(--accent)}

.card__body{padding:16px;display:flex;flex-direction:column;gap:6px;flex:1}
.card__cat{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.card__title{font-size:15px;font-weight:600;color:var(--ink)}
.card__rating{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--muted)}
.card__rating .stars{color:var(--gold);letter-spacing:1px}
.card__price{display:flex;align-items:baseline;gap:8px;margin-top:6px}
.card__price strong{font-size:18px;font-family:'Gilroy','Inter',sans-serif}
.card__price del{font-size:13px;color:var(--muted)}

/* ============ BANNER ============ */
.banner{padding-block:64px}
.banner__wrap{
  position:relative;border-radius:var(--radius-xl);overflow:hidden;
  padding:60px 24px;color:#fff;isolation:isolate;
  min-height:380px;display:flex;align-items:center;
}
.banner__bg{
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(60% 80% at 80% 20%, rgba(255,91,46,.55), transparent 60%),
    radial-gradient(50% 70% at 10% 100%, rgba(80,80,200,.5), transparent 60%),
    linear-gradient(135deg, #111 0%, #1c1c22 100%);
}
.banner__bg::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(2px 2px at 20% 30%, rgba(255,255,255,.5), transparent 50%),
    radial-gradient(1px 1px at 80% 60%, rgba(255,255,255,.4), transparent 50%),
    radial-gradient(1.5px 1.5px at 60% 80%, rgba(255,255,255,.35), transparent 50%);
}
.banner__content{max-width:680px}
.banner h2{
  font-family:'Gilroy','Inter',sans-serif;
  font-size:clamp(30px, 5vw, 56px);
  line-height:1.05;letter-spacing:-0.02em;margin-bottom:16px;
}
.banner h2 em{color:var(--accent)}
.banner p{color:rgba(255,255,255,.8);font-size:16px;margin-bottom:28px;max-width:50ch}
.banner__cta{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.banner__timer{
  display:flex;gap:10px;
}
.banner__timer div{
  min-width:62px;padding:10px 8px;border-radius:14px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.15);
  text-align:center;backdrop-filter:blur(8px);
}
.banner__timer strong{
  display:block;font-size:22px;font-family:'Gilroy','Inter',sans-serif;
  font-weight:700;letter-spacing:-0.01em;
}
.banner__timer span{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.7)}

/* ============ TESTIMONIALS ============ */
.testi-grid{
  display:grid;gap:18px;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
}
.testi{
  background:var(--bg-alt);border-radius:var(--radius-lg);padding:28px;
  transition:transform var(--t), box-shadow var(--t);
}
.testi:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.testi__stars{color:var(--gold);letter-spacing:3px;font-size:18px;margin-bottom:14px}
.testi p{font-size:15.5px;color:var(--ink-2);margin-bottom:22px;line-height:1.6}
.testi__user{display:flex;align-items:center;gap:12px}
.testi__user img{width:44px;height:44px;border-radius:50%;object-fit:cover}
.testi__user strong{display:block;font-size:14px}
.testi__user span{font-size:12.5px;color:var(--muted)}

/* ============ NEWSLETTER ============ */
.newsletter{padding-block:30px 80px}
.newsletter__wrap{
  background:var(--ink);color:#fff;
  border-radius:var(--radius-xl);
  padding:48px 32px;
  display:grid;gap:28px;
  grid-template-columns:1fr;
}
@media(min-width:900px){
  .newsletter__wrap{grid-template-columns:1.1fr 1fr;align-items:center;padding:56px}
}
.newsletter h2{
  font-family:'Gilroy','Inter',sans-serif;font-size:clamp(26px, 3.5vw, 38px);
  letter-spacing:-0.02em;margin-bottom:8px;
}
.newsletter p{color:rgba(255,255,255,.7)}
.newsletter__form{
  position:relative;display:flex;gap:10px;flex-wrap:wrap;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  border-radius:999px;padding:6px;
}
.newsletter__form input{
  flex:1;min-width:180px;border:0;background:transparent;color:#fff;
  padding:0 18px;outline:0;
}
.newsletter__form input::placeholder{color:rgba(255,255,255,.5)}
.newsletter__form .btn--dark{background:#fff;color:var(--ink)}
.newsletter__form .ok{
  position:absolute;left:50%;bottom:-32px;transform:translateX(-50%);
  font-size:13px;color:#7fffaa;display:none;align-items:center;gap:6px;
}
.newsletter__form .ok.show{display:flex}

/* ============ FOOTER ============ */
.footer{background:#0a0a0c;color:#cfcfd3;padding-top:64px}
.footer__grid{
  display:grid;gap:36px;
  grid-template-columns:1fr;
  padding-bottom:48px;
}
@media(min-width:680px){ .footer__grid{grid-template-columns:repeat(2,1fr)} }
@media(min-width:1024px){ .footer__grid{grid-template-columns:1.6fr 1fr 1fr 1fr 1.2fr} }

.footer__brand p{max-width:34ch;color:#9b9ba2;margin:14px 0 20px;font-size:14.5px}
.footer__social{display:flex;gap:8px}
.footer__social a{
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.06);
  display:inline-flex;align-items:center;justify-content:center;
  color:#fff;transition:background var(--t), transform var(--t);
}
.footer__social a:hover{background:var(--accent);transform:translateY(-2px)}
.footer__social .ti{font-size:18px}

.footer__col h4{
  color:#fff;font-size:14px;font-weight:600;letter-spacing:.04em;
  margin-bottom:16px;text-transform:uppercase;
}
.footer__col a, .footer__col p{
  display:flex;align-items:center;gap:8px;
  color:#9b9ba2;font-size:14px;margin-bottom:10px;
  transition:color var(--t);
}
.footer__col a:hover{color:#fff}

.footer__bottom{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding-block:22px;border-top:1px solid rgba(255,255,255,.06);
  flex-wrap:wrap;color:#7a7a83;font-size:13px;
}
.footer__pay{display:flex;gap:10px;font-size:24px;color:#aaa}
.footer__legal{display:flex;gap:18px}
.footer__legal a{color:#7a7a83;transition:color var(--t)}
.footer__legal a:hover{color:#fff}

/* ============ DRAWER (MOBILE MENU) ============ */
.drawer{
  position:fixed;inset:0;z-index:80;
  pointer-events:none;visibility:hidden;
}
.drawer.is-open{pointer-events:auto;visibility:visible}
.drawer__overlay{
  position:absolute;inset:0;background:rgba(0,0,0,.4);
  opacity:0;transition:opacity var(--t);
}
.drawer.is-open .drawer__overlay{opacity:1}
.drawer__panel{
  position:absolute;top:0;bottom:0;left:0;
  width:min(86vw, 340px);background:#fff;
  display:flex;flex-direction:column;
  transform:translateX(-100%);transition:transform .35s cubic-bezier(.2,.7,.2,1);
}
.drawer.is-open .drawer__panel{transform:translateX(0)}
.drawer__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 20px;border-bottom:1px solid var(--line);
}
.drawer__nav{display:flex;flex-direction:column;padding:14px 12px;gap:2px;flex:1}
.drawer__nav a{
  display:flex;align-items:center;gap:12px;
  padding:14px 14px;border-radius:12px;font-weight:500;
  transition:background var(--t);
}
.drawer__nav a:hover{background:var(--bg-alt)}
.drawer__nav .ti{font-size:20px;color:var(--muted)}
.drawer__foot{padding:18px 20px;border-top:1px solid var(--line)}

/* ============ CART DRAWER ============ */
.cart{
  position:fixed;inset:0;z-index:90;
  pointer-events:none;visibility:hidden;
}
.cart.is-open{pointer-events:auto;visibility:visible}
.cart__overlay{
  position:absolute;inset:0;background:rgba(10,10,15,.5);
  backdrop-filter:blur(4px);
  opacity:0;transition:opacity var(--t);
}
.cart.is-open .cart__overlay{opacity:1}
.cart__panel{
  position:absolute;top:0;bottom:0;right:0;
  z-index:2;
  width:min(94vw, 460px);background:#fff;
  display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .4s cubic-bezier(.2,.7,.2,1);
  box-shadow:-30px 0 60px -25px rgba(0,0,0,.4);
}
.cart.is-open .cart__panel{transform:translateX(0)}

.cart__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 22px 14px;
}
.cart__head h3{
  font-family:'Gilroy','Inter',sans-serif;font-size:24px;font-weight:700;
}
.cart__head span{font-size:13px;color:var(--muted)}

.cart__progress{
  margin:0 18px 14px;
  padding:14px 16px;
  border-radius:16px;
  background:linear-gradient(135deg, #f0fdf4 0%, #ecfccb 100%);
  border:1px solid #d4f0d9;
  position:relative;overflow:hidden;
}
.cart__progress.is-done{
  background:linear-gradient(135deg, #dcfce7 0%, #bbf7d0 100%);
  border-color:#86efac;
}
.cart__progress-head{
  display:flex;align-items:center;gap:12px;
  margin-bottom:10px;
}
.cart__progress-icon{
  width:38px;height:38px;border-radius:10px;
  background:#fff;color:var(--ok);
  display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;
  box-shadow:0 4px 10px -2px rgba(22,163,74,.25);
}
.cart__progress.is-done .cart__progress-icon{
  background:var(--ok);color:#fff;
  animation:bounce .6s ease;
}
@keyframes bounce{
  0%,100%{transform:scale(1)}
  40%{transform:scale(1.15) rotate(-6deg)}
  70%{transform:scale(.95) rotate(3deg)}
}
.cart__progress-icon .ti{font-size:20px}
.cart__progress-text{flex:1;min-width:0;line-height:1.3}
.cart__progress-text strong{
  display:block;font-size:13px;font-weight:700;color:var(--ink);
  margin-bottom:1px;
}
.cart__progress-text span{font-size:11.5px;color:var(--muted)}
.cart__progress-text b{color:var(--ok);font-weight:700;font-family:'Gilroy','Inter',sans-serif}
.cart__progress-pct{
  font-family:'Gilroy','Inter',sans-serif;font-weight:800;font-size:15px;
  color:var(--ok);
  padding:4px 10px;border-radius:999px;
  background:rgba(255,255,255,.7);
  border:1px solid rgba(22,163,74,.15);
  flex-shrink:0;
}

.cart__progress-bar{
  position:relative;
  height:8px;border-radius:999px;
  background:rgba(255,255,255,.6);
  box-shadow:inset 0 1px 2px rgba(0,0,0,.04);
  overflow:visible;
}
.cart__progress-bar > span{
  position:relative;
  display:block;height:100%;
  background:linear-gradient(90deg, #22c55e 0%, #16a34a 50%, #15803d 100%);
  border-radius:999px;
  transition:width .8s cubic-bezier(.2,.7,.2,1);
  box-shadow:0 1px 4px rgba(22,163,74,.4);
  overflow:hidden;
}
.cart__progress-glow{
  position:absolute;inset:0;
  background:linear-gradient(
    90deg,
    transparent 0%,
    rgba(255,255,255,.55) 50%,
    transparent 100%
  );
  animation:shimmer 1.8s linear infinite;
}
@keyframes shimmer{
  0%{transform:translateX(-100%)}
  100%{transform:translateX(100%)}
}
.cart__progress-flag{
  position:absolute;top:50%;
  transform:translate(-50%, -50%);
  width:22px;height:22px;border-radius:50%;
  background:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 2px 8px rgba(0,0,0,.15);
  border:2px solid var(--ok);
  transition:left .8s cubic-bezier(.2,.7,.2,1);
}
.cart__progress-flag .ti{font-size:11px;color:var(--ok)}
.cart__progress.is-done .cart__progress-flag{
  background:var(--ok);
}
.cart__progress.is-done .cart__progress-flag .ti{color:#fff}

.cart__items{
  flex:1;overflow-y:auto;padding:14px 22px;
  display:flex;flex-direction:column;gap:14px;
}
.cart-item{
  display:grid;grid-template-columns:78px 1fr auto;gap:14px;align-items:center;
  padding:12px;border-radius:var(--radius);background:var(--bg-alt);
  transition:transform var(--t);
}
.cart-item:hover{transform:translateY(-2px)}
.cart-item__img{
  width:78px;height:78px;border-radius:12px;overflow:hidden;background:#fff;
}
.cart-item__img img{width:100%;height:100%;object-fit:cover}
.cart-item__title{font-size:14px;font-weight:600;margin-bottom:4px}
.cart-item__meta{font-size:12px;color:var(--muted);margin-bottom:8px}
.cart-item__qty{
  display:inline-flex;align-items:center;gap:0;background:#fff;border-radius:999px;
  padding:3px;border:1px solid var(--line);
}
.cart-item__qty button{
  width:26px;height:26px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  transition:background var(--t);
}
.cart-item__qty button:hover{background:var(--bg-alt)}
.cart-item__qty span{min-width:24px;text-align:center;font-size:13px;font-weight:600}
.cart-item__right{
  display:flex;flex-direction:column;align-items:flex-end;gap:8px;
  font-family:'Gilroy','Inter',sans-serif;
}
.cart-item__price{font-size:16px;font-weight:700}
.cart-item__remove{
  font-size:11px;color:var(--muted);font-family:'Inter',sans-serif;
  display:inline-flex;align-items:center;gap:3px;
  transition:color var(--t);
}
.cart-item__remove:hover{color:var(--danger)}

.cart__suggest{padding:18px 22px;border-top:1px solid var(--line)}
.cart__suggest h4{font-size:13px;font-weight:600;margin-bottom:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.cart__suggest-list{display:flex;gap:10px;overflow-x:auto;scrollbar-width:none}
.cart__suggest-list::-webkit-scrollbar{display:none}
.sug{
  flex:0 0 110px;border-radius:14px;background:var(--bg-alt);
  padding:8px;cursor:pointer;transition:transform var(--t);
}
.sug:hover{transform:translateY(-3px)}
.sug img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:10px;margin-bottom:6px}
.sug strong{display:block;font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sug span{font-size:12px;color:var(--muted);font-family:'Gilroy','Inter',sans-serif}

.cart__foot{
  padding:20px 22px;border-top:1px solid var(--line);
  background:#fff;
}
.cart__sum{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.cart__sum div{display:flex;justify-content:space-between;align-items:center;font-size:13.5px;color:var(--muted)}
.cart__sum strong{color:var(--ink);font-weight:600}
.cart__total{padding-top:10px;border-top:1px dashed var(--line);font-size:15px !important;color:var(--ink) !important}
.cart__total strong{font-size:22px !important;font-family:'Gilroy','Inter',sans-serif}
.cart__continue{
  width:100%;text-align:center;padding:12px;margin-top:8px;
  font-size:13px;color:var(--muted);
  transition:color var(--t);
}
.cart__continue:hover{color:var(--ink)}


/* ============================================================
   AUTH DRAWER — ULTRA
   ============================================================ */
.auth{
  position:fixed;inset:0;z-index:100;
  pointer-events:none;visibility:hidden;
}
.auth.is-open{pointer-events:auto;visibility:visible}
.auth__overlay{
  position:absolute;inset:0;
  background:rgba(8,8,12,.5);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  opacity:0;transition:opacity var(--t);
}
.auth.is-open .auth__overlay{opacity:1}

.auth__box{
  position:absolute;top:0;bottom:0;right:0;
  z-index:2;
  width:min(100vw, 540px);
  background:#fff;
  display:flex;flex-direction:column;
  box-shadow:-30px 0 80px -20px rgba(0,0,0,.4);
  transform:translateX(100%);
  transition:transform .45s cubic-bezier(.2,.7,.2,1);
  overflow:hidden;
}
.auth.is-open .auth__box{transform:translateX(0)}

.auth__close{
  position:absolute;top:14px;right:14px;z-index:5;
  background:rgba(255,255,255,.95);
  box-shadow:0 4px 12px rgba(0,0,0,.15);
}

/* ===== TOP BRAND STRIP ===== */
.auth__left{
  position:relative;
  background:#0a0a0d;color:#fff;
  padding:22px 26px 20px;
  display:flex;flex-direction:column;gap:18px;
  overflow:hidden;isolation:isolate;
  flex-shrink:0;
}

.auth__bg{position:absolute;inset:0;z-index:-1;overflow:hidden}
.auth__blob{
  position:absolute;border-radius:50%;
  filter:blur(60px);opacity:.55;
  animation:blob 18s ease-in-out infinite;
}
.auth__blob--1{
  width:240px;height:240px;top:-100px;right:-60px;
  background:radial-gradient(circle, #ff5b2e 0%, transparent 70%);
}
.auth__blob--2{
  width:200px;height:200px;bottom:-80px;left:-40px;
  background:radial-gradient(circle, #6366f1 0%, transparent 70%);
  animation-delay:-6s;
}
.auth__blob--3{
  width:180px;height:180px;top:40%;left:40%;
  background:radial-gradient(circle, #c9a86b 0%, transparent 70%);
  animation-delay:-12s;opacity:.35;
}
@keyframes blob{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(30px,-20px) scale(1.1)}
  66%{transform:translate(-20px,30px) scale(.95)}
}
.auth__grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:32px 32px;
  mask-image:radial-gradient(ellipse 100% 80% at 50% 50%, #000 30%, transparent 80%);
}

.auth__left-top{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.auth__badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:600;letter-spacing:.06em;
  padding:6px 10px;border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.85);
}
.auth__badge .ti{color:#7fffaa;font-size:14px}

.auth__hero{
  font-size:clamp(22px, 3vw, 28px);
  letter-spacing:-0.025em;line-height:1.1;
  margin-bottom:6px;color:#fff;
}
.auth__hero em{color:var(--accent);font-weight:800}
#authSub{color:rgba(255,255,255,.7);font-size:13px;line-height:1.5;margin:0}
#authSub strong{color:#fff;font-weight:600}

.auth__perks{list-style:none;display:flex;flex-direction:column;gap:14px}
.auth__perks li{
  display:flex;align-items:center;gap:12px;
  font-size:13.5px;
  padding:10px;border-radius:14px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);
  transition:background var(--t), transform var(--t);
}
.auth__perks li:hover{background:rgba(255,255,255,.07);transform:translateX(4px)}
.perk__ico{
  width:38px;height:38px;border-radius:10px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, rgba(255,91,46,.2), rgba(255,91,46,.05));
  color:var(--accent);
}
.perk__ico .ti{font-size:20px}
.auth__perks strong{display:block;font-size:13.5px;font-weight:600;color:#fff;margin-bottom:2px}
.auth__perks span{font-size:12px;color:rgba(255,255,255,.55)}

.auth__left-bot{
  display:flex;align-items:center;gap:12px;
  padding-top:14px;border-top:1px solid rgba(255,255,255,.08);
}
.auth__avatars{display:flex}
.auth__avatars img{
  width:28px;height:28px;border-radius:50%;
  border:2px solid #0a0a0d;object-fit:cover;
}
.auth__avatars img:not(:first-child){margin-left:-9px}
.auth__stars{
  font-size:12px;color:var(--gold);letter-spacing:1.5px;
  display:flex;align-items:center;gap:6px;margin-bottom:1px;
}
.auth__stars span{color:#fff;font-family:'Inter',sans-serif;letter-spacing:0;font-weight:600;font-size:11.5px}
.auth__quote{font-size:11.5px;color:rgba(255,255,255,.6);margin:0}

/* ===== FORMS BODY ===== */
.auth__right{
  padding:24px 28px 28px;
  overflow-y:auto;
  flex:1;
  display:flex;flex-direction:column;
  scrollbar-width:thin;
}
.auth__right::-webkit-scrollbar{width:6px}
.auth__right::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}

/* Tabs */
.auth__tabs{
  position:relative;display:flex;
  background:var(--bg-alt);
  border-radius:14px;padding:5px;margin-bottom:24px;
}
.auth__tab{
  flex:1;padding:11px 14px;border-radius:10px;
  font-size:14px;font-weight:600;color:var(--muted);
  z-index:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  transition:color var(--t);
}
.auth__tab.is-active{color:#fff}
.auth__tab .ti{font-size:18px}
.auth__indicator{
  position:absolute;top:5px;left:5px;
  width:calc(50% - 5px);height:calc(100% - 10px);
  background:var(--ink);border-radius:10px;
  box-shadow:0 6px 16px -4px rgba(0,0,0,.3);
  transition:transform .4s cubic-bezier(.2,.7,.2,1);
}
.auth__tabs[data-tab="register"] .auth__indicator{transform:translateX(100%)}

.auth__form{display:none;flex-direction:column;gap:14px;flex:1}
.auth__form.is-active{display:flex;animation:fadeUp .4s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

.auth__welcome h3{
  font-size:22px;letter-spacing:-0.02em;margin-bottom:4px;
}
.auth__welcome p{font-size:13.5px;color:var(--muted);margin-bottom:8px}

/* Field */
.field{display:flex;flex-direction:column;gap:6px}
.field__label{
  display:flex;align-items:center;justify-content:space-between;
  font-size:12.5px;font-weight:600;color:var(--ink-2);
  padding-left:2px;
}
.field__hint{font-size:12px;color:var(--muted);font-weight:500;transition:color var(--t)}
.field__hint:hover{color:var(--accent)}

.field__box{
  position:relative;
  display:flex;align-items:center;
  background:var(--bg-alt);
  border:1.5px solid transparent;
  border-radius:12px;
  height:50px;padding:0 14px;gap:8px;
  transition:border-color var(--t), background var(--t), box-shadow var(--t);
}
.field__box:focus-within{
  border-color:var(--ink);
  background:#fff;
  box-shadow:0 0 0 4px rgba(0,0,0,.04);
}
.field__icon{font-size:18px;color:var(--muted);flex-shrink:0}
.field__box input{
  flex:1;border:0;background:transparent;outline:0;
  font-size:14.5px;font-weight:500;height:100%;min-width:0;
}
.field__box input::placeholder{color:#b8b8be}
.field__valid{
  font-size:18px;color:var(--ok);opacity:0;
  transition:opacity var(--t);
}
.field__box input:valid:not(:placeholder-shown) ~ .field__valid{opacity:1}
.field__eye{
  width:30px;height:30px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--muted);
  transition:background var(--t), color var(--t);
}
.field__eye:hover{background:rgba(0,0,0,.05);color:var(--ink)}

.field__box--phone{padding-left:6px;gap:0}
.field__ccode{
  border:0;background:transparent;outline:0;
  font-size:14px;font-weight:600;
  padding:0 8px;height:100%;cursor:pointer;
  border-right:1px solid var(--line);margin-right:10px;
}

.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* Password strength */
.strength{
  display:flex;align-items:center;gap:10px;
  margin-top:4px;padding-left:2px;
}
.strength__bars{
  display:flex;gap:4px;flex:1;
}
.strength__bars span{
  flex:1;height:4px;border-radius:3px;
  background:var(--line);
  transition:background var(--t);
}
.strength[data-level="1"] .strength__bars span:nth-child(-n+1){background:#e02424}
.strength[data-level="2"] .strength__bars span:nth-child(-n+2){background:#f59e0b}
.strength[data-level="3"] .strength__bars span:nth-child(-n+3){background:#84cc16}
.strength[data-level="4"] .strength__bars span{background:#16a34a}
.strength__label{font-size:11.5px;font-weight:600;color:var(--muted);min-width:64px;text-align:right}
.strength[data-level="1"] .strength__label{color:#e02424}
.strength[data-level="2"] .strength__label{color:#f59e0b}
.strength[data-level="3"] .strength__label{color:#84cc16}
.strength[data-level="4"] .strength__label{color:#16a34a}

.strength__rules{
  list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:4px 12px;
  margin-top:6px;padding-left:2px;
}
.strength__rules li{
  display:flex;align-items:center;gap:6px;
  font-size:11.5px;color:var(--muted);
  transition:color var(--t);
}
.strength__rules .ti{font-size:14px}
.strength__rules li.ok{color:var(--ok)}
.strength__rules li.ok .ti::before{content:"\f704"} /* ti-circle-check */

.auth__row{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  font-size:13px;
}
.auth__secure{
  display:inline-flex;align-items:center;gap:5px;
  font-size:11.5px;font-weight:500;color:var(--ok);
}
.auth__secure .ti{font-size:14px}

/* Submit button with spinner */
.auth__submit{position:relative;overflow:hidden}
.auth__submit.is-loading .auth__submit-text,
.auth__submit.is-loading .ti{opacity:0}
.auth__submit.is-loading .auth__spinner{
  position:absolute;left:50%;top:50%;
  width:20px;height:20px;
  border:2.5px solid rgba(255,255,255,.3);
  border-top-color:#fff;border-radius:50%;
  transform:translate(-50%,-50%);
  animation:spin .7s linear infinite;
}
@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}

.auth__sep{
  display:flex;align-items:center;gap:12px;margin:6px 0;
  color:var(--muted);font-size:11.5px;text-transform:uppercase;letter-spacing:.1em;font-weight:600;
}
.auth__sep::before, .auth__sep::after{
  content:"";flex:1;height:1px;background:var(--line);
}

.auth__social{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.soc{
  padding:12px 8px;border-radius:12px;
  background:#fff;border:1.5px solid var(--line);
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-size:13px;font-weight:600;
  transition:background var(--t), border-color var(--t), transform var(--t);
}
.soc:hover{background:var(--bg-alt);border-color:var(--ink);transform:translateY(-2px)}
.soc .ti{font-size:18px}
.soc--apple .ti{font-size:20px}

.auth__switch{
  text-align:center;font-size:13px;color:var(--muted);
  margin-top:auto;padding-top:10px;
}
.auth__switch a{color:var(--ink);font-weight:600;border-bottom:1.5px solid var(--ink);padding-bottom:1px}

.auth__legal{
  position:relative;
  display:flex;align-items:flex-start;gap:10px;
  margin-top:16px;padding:12px 14px;
  background:linear-gradient(135deg, #f0fdf4 0%, #f6f6f4 100%);
  border:1px solid #d4f0d9;
  border-radius:12px;
  font-size:11.5px;color:var(--muted);line-height:1.55;
}
.auth__legal::before{
  content:"";
  position:absolute;left:0;top:12px;bottom:12px;width:3px;
  background:var(--ok);border-radius:0 3px 3px 0;
}
.auth__legal > .ti{
  font-size:18px;color:var(--ok);flex-shrink:0;
  margin-top:1px;
}
.auth__legal strong{color:var(--ink);font-weight:600}

/* Check */
.check{
  display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:var(--muted);
}
.check input{display:none}
.check span{
  width:18px;height:18px;border-radius:6px;border:1.5px solid var(--line);
  display:inline-flex;align-items:center;justify-content:center;
  flex-shrink:0;
  transition:background var(--t), border-color var(--t);
}
.check input:checked + span{background:var(--ink);border-color:var(--ink)}
.check input:checked + span::after{
  content:"";width:9px;height:5px;border-left:2px solid #fff;border-bottom:2px solid #fff;
  transform:rotate(-45deg) translate(1px,-1px);
}
.check--block{display:flex;width:100%;align-items:flex-start;gap:10px}
.check--block span{margin-top:2px}
.check--block small{font-size:12.5px;line-height:1.5}
.check--block a{color:var(--ink);text-decoration:underline}

/* ===== STEPPER ===== */
.stepper{
  display:flex;align-items:center;gap:8px;
  margin-bottom:20px;
}
.step{display:flex;align-items:center;gap:8px;color:var(--muted)}
.step__dot{
  width:30px;height:30px;border-radius:50%;
  background:var(--bg-alt);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;
  border:1.5px solid transparent;
  transition:all var(--t);
}
.step span{font-size:12.5px;font-weight:600}
.step__line{
  flex:1;height:2px;background:var(--bg-alt);border-radius:2px;
  transition:background var(--t);
}
.step.is-active{color:var(--ink)}
.step.is-active .step__dot{background:var(--ink);color:#fff}
.step.is-done{color:var(--ok)}
.step.is-done .step__dot{background:var(--ok);color:#fff}
.step.is-done .step__dot::before{
  content:"\f704";font-family:'tabler-icons';font-size:18px;
}
.step.is-done .step__dot{font-size:0}
.step__line.is-done{background:var(--ok)}

/* Step panels */
.step-panel{display:none;flex-direction:column;gap:14px;flex:1}
.step-panel.is-active{display:flex;animation:fadeUp .4s ease}

/* OTP */
.otp{
  display:grid;grid-template-columns:repeat(6,1fr);gap:10px;
  margin:8px 0;
}
.otp input{
  aspect-ratio:1;width:100%;
  border:1.5px solid var(--line);border-radius:12px;
  background:var(--bg-alt);
  text-align:center;font-size:22px;font-weight:700;
  outline:0;
  font-family:'Gilroy','Inter',sans-serif;
  transition:border-color var(--t), background var(--t), transform var(--t);
}
.otp input:focus{
  border-color:var(--ink);background:#fff;
  box-shadow:0 0 0 4px rgba(0,0,0,.04);
}
.otp input.filled{
  border-color:var(--ok);background:#f0fdf4;color:var(--ok);
  animation:pop .3s ease;
}
@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.08)}100%{transform:scale(1)}}

.otp__meta{
  display:flex;align-items:center;justify-content:center;gap:6px;
  font-size:13px;color:var(--muted);
}
.otp__resend{
  font-weight:600;color:var(--ink);
  transition:color var(--t);
}
.otp__resend:disabled{color:var(--muted);cursor:not-allowed}
.otp__resend:not(:disabled):hover{color:var(--accent)}

.auth__actions{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px;
}
.auth__actions .btn{justify-content:center;width:100%}

/* SUCCESS */
.success{text-align:center;padding:20px 0;display:flex;flex-direction:column;align-items:center;gap:14px}
.success__ring{width:72px;height:72px;margin-bottom:6px}
.success__circle{
  stroke-dasharray:151;stroke-dashoffset:151;
  animation:draw 1s ease forwards;
}
.success__check{
  stroke-dasharray:50;stroke-dashoffset:50;
  animation:draw .5s .8s ease forwards;
}
@keyframes draw{to{stroke-dashoffset:0}}

.success h3{font-size:24px;letter-spacing:-0.02em}
.success > p{font-size:14px;color:var(--muted);max-width:38ch;line-height:1.55}
.success strong{color:var(--ink)}

.reward{
  display:flex;align-items:center;gap:14px;
  width:100%;padding:14px 18px;
  border-radius:14px;
  background:linear-gradient(135deg, #fff7ed 0%, #ffedd5 100%);
  border:1.5px dashed var(--accent);
  margin:6px 0;
}
.reward > .ti{font-size:28px;color:var(--accent)}
.reward div{flex:1;text-align:left}
.reward strong{
  display:block;font-family:'Gilroy','Inter',sans-serif;font-size:20px;
  letter-spacing:0.1em;color:var(--ink);
}
.reward span{font-size:12px;color:var(--muted)}
.reward__copy{
  width:38px;height:38px;border-radius:10px;
  background:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--ink);
  transition:background var(--t), transform var(--t);
}
.reward__copy:hover{background:var(--ink);color:#fff;transform:scale(1.05)}

/* Mobile tweaks */
@media(max-width:600px){
  .auth__box{width:100vw}
  .auth__left{padding:20px 20px 16px}
  .auth__right{padding:20px}
  .field-grid{grid-template-columns:1fr}
  .auth__social{grid-template-columns:1fr 1fr}
  .auth__social .soc--phone{grid-column:span 2}
  .stepper .step span{display:none}
  .otp{gap:6px}
  .otp input{font-size:18px;border-radius:10px}
}
.toast{
  position:fixed;left:50%;bottom:30px;
  transform:translate(-50%, 60px);opacity:0;
  background:var(--ink);color:#fff;
  padding:12px 20px;border-radius:999px;
  display:inline-flex;align-items:center;gap:8px;
  font-size:14px;font-weight:500;
  z-index:200;
  box-shadow:var(--shadow);
  transition:transform .35s cubic-bezier(.2,.7,.2,1), opacity var(--t);
  pointer-events:none;
}
.toast.show{transform:translate(-50%, 0);opacity:1}
.toast .ti{color:#7fffaa;font-size:18px}

/* ============================================================
   SEARCH OVERLAY
   ============================================================ */
.search{
  position:fixed;inset:0;z-index:110;
  pointer-events:none;visibility:hidden;
}
.search.is-open{pointer-events:auto;visibility:visible}
.search__overlay{
  position:absolute;inset:0;
  background:rgba(10,10,15,.55);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  opacity:0;transition:opacity var(--t);
}
.search.is-open .search__overlay{opacity:1}
.search__panel{
  position:absolute;top:0;left:0;right:0;
  background:#fff;
  border-bottom-left-radius:28px;
  border-bottom-right-radius:28px;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.35);
  transform:translateY(-100%);
  transition:transform .45s cubic-bezier(.2,.7,.2,1);
  max-height:92vh;
  display:flex;flex-direction:column;
  overflow:hidden;
}
.search.is-open .search__panel{transform:translateY(0)}

.search__head{
  display:flex;align-items:center;gap:12px;
  padding:18px 20px;
  border-bottom:1px solid var(--line);
}
.search__input-wrap{
  flex:1;position:relative;
  display:flex;align-items:center;gap:10px;
  background:var(--bg-alt);
  border:1.5px solid transparent;
  border-radius:16px;
  padding:0 14px;height:56px;
  transition:border-color var(--t), background var(--t);
}
.search__input-wrap:focus-within{
  border-color:var(--ink);background:#fff;
  box-shadow:0 0 0 4px rgba(0,0,0,.04);
}
.search__input-wrap > .ti{font-size:22px;color:var(--muted)}
.search__input-wrap input{
  flex:1;border:0;background:transparent;outline:0;
  font-size:16px;font-weight:500;height:100%;
}
.search__input-wrap input::placeholder{color:var(--muted)}
.search__clear{
  width:32px;height:32px;border-radius:50%;
  display:none;align-items:center;justify-content:center;
  color:var(--muted);
  transition:background var(--t), color var(--t);
}
.search__clear:hover{background:var(--line);color:var(--ink)}
.search__clear.show{display:inline-flex}
.search__input-wrap kbd{
  font-family:'Inter',sans-serif;font-size:11px;font-weight:600;
  color:var(--muted);
  background:#fff;border:1px solid var(--line);
  border-radius:6px;padding:3px 8px;
  letter-spacing:.06em;
}
@media(max-width:600px){ .search__input-wrap kbd{display:none} }

.search__body{
  flex:1;overflow-y:auto;
  padding:24px 20px 32px;
}

.search__default{
  display:grid;gap:32px;
  grid-template-columns:1fr;
}
@media(min-width:880px){
  .search__default{grid-template-columns:1fr 1.1fr;gap:48px}
}
.search__col h4{
  display:flex;align-items:center;gap:8px;
  font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);margin-bottom:14px;
  font-family:'Inter',sans-serif;
}
.search__col h4 .ti{font-size:16px;color:var(--accent)}

.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  padding:9px 14px;border-radius:999px;
  background:var(--bg-alt);
  font-size:13px;font-weight:500;color:var(--ink-2);
  transition:background var(--t), color var(--t), transform var(--t);
  border:1px solid transparent;
}
.chip:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.chip.is-active{background:var(--ink);color:#fff}

.recent{display:flex;flex-direction:column;gap:4px}
.recent__item{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:12px;
  font-size:14px;cursor:pointer;
  transition:background var(--t);
}
.recent__item:hover{background:var(--bg-alt)}
.recent__item .ti-history{font-size:18px;color:var(--muted)}
.recent__item span{flex:1}
.recent__item .ti-x{font-size:16px;color:var(--muted);opacity:0;transition:opacity var(--t)}
.recent__item:hover .ti-x{opacity:1}
.recent__empty{font-size:13px;color:var(--muted);padding:8px 12px}

.search-cats{
  display:grid;grid-template-columns:1fr 1fr;gap:8px;
}
.search-cat{
  display:flex;align-items:center;gap:10px;
  padding:14px;border-radius:14px;
  background:var(--bg-alt);
  font-size:14px;font-weight:500;
  transition:background var(--t), transform var(--t);
}
.search-cat:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.search-cat .ti{font-size:20px}
.search-cat span{
  margin-left:auto;font-size:11px;font-weight:600;
  background:#fff;color:var(--muted);
  padding:2px 8px;border-radius:999px;
}
.search-cat:hover span{background:rgba(255,255,255,.2);color:#fff}

.search__featured{
  display:grid;grid-template-columns:repeat(2,1fr);gap:10px;
}
.sf{
  display:flex;align-items:center;gap:10px;
  padding:10px;border-radius:14px;background:var(--bg-alt);
  cursor:pointer;
  transition:background var(--t), transform var(--t);
}
.sf:hover{background:#fff;box-shadow:var(--shadow-sm);transform:translateY(-2px)}
.sf img{width:52px;height:52px;border-radius:10px;object-fit:cover;flex-shrink:0}
.sf__t{font-size:13px;font-weight:600;line-height:1.3;margin-bottom:2px;
  display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.sf__p{font-size:13px;color:var(--ink);font-weight:700;font-family:'Gilroy','Inter',sans-serif}
.sf__c{font-size:11px;color:var(--muted)}

/* Results */
.search__results-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:18px;gap:12px;flex-wrap:wrap;
}
.search__results-head > span{font-size:14px;color:var(--muted)}
.search__results-head strong{color:var(--ink);font-weight:700}
.search__filters{display:flex;gap:6px;flex-wrap:wrap}

.search__grid{
  display:grid;gap:12px;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
}
.sr{
  display:grid;grid-template-columns:80px 1fr auto;gap:14px;align-items:center;
  padding:12px;border-radius:16px;
  background:var(--bg-alt);
  cursor:pointer;
  transition:background var(--t), transform var(--t), box-shadow var(--t);
}
.sr:hover{background:#fff;box-shadow:var(--shadow);transform:translateY(-2px)}
.sr__img{width:80px;height:80px;border-radius:12px;overflow:hidden;background:#fff}
.sr__img img{width:100%;height:100%;object-fit:cover}
.sr__title{font-size:14px;font-weight:600;margin-bottom:3px;
  display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.sr__cat{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.sr__rating{font-size:12px;color:var(--muted)}
.sr__rating .stars{color:var(--gold);letter-spacing:1px;margin-right:4px}
.sr__price{font-family:'Gilroy','Inter',sans-serif;font-weight:800;font-size:16px;text-align:right}
.sr__price del{display:block;font-size:11px;color:var(--muted);font-weight:500}
.sr mark{
  background:rgba(255,91,46,.18);color:var(--ink);
  padding:0 2px;border-radius:3px;
}

.search__empty{
  text-align:center;padding:48px 20px;color:var(--muted);
}
.search__empty .ti{font-size:48px;opacity:.4;display:block;margin-bottom:12px}
.search__empty h3{font-size:18px;color:var(--ink);margin-bottom:6px}
.search__empty p{font-size:14px}
