  :root{
    /* ── client palette: Seasalt → Dim gray ── */
    --seasalt:   #F8F9FA;
    --platinum:  #E1E2E4;
    --platinum-2:#D2D5D8;
    --french:    #B2B6BA;
    --dim:       #696E71;
    --ink:       #1c1d1f;
    --ink-soft:  #4a4c4f;

    --maxw: 1280px;
    --ease: cubic-bezier(.22,.61,.36,1);
  }

  *{ margin:0; padding:0; box-sizing:border-box; }
  html{ scroll-behavior:smooth; }
  body{
    background:var(--seasalt);
    color:var(--ink);
    font-family:'Jost', system-ui, sans-serif;
    font-weight:300;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  a{ color:inherit; text-decoration:none; }
  img{ display:block; max-width:100%; }
  ::selection{ background:var(--dim); color:#fff; }

  .serif{ font-family:'Cormorant Garamond', Georgia, serif; }
  .wrap{ max-width:var(--maxw); margin:0 auto; padding:0 clamp(1rem,4vw,2.5rem); }

  .caps{ text-transform:uppercase; letter-spacing:.18em; font-size:.72rem; font-weight:400; }

  /* ───────── announcement bar ───────── */
  .announce{
    background:var(--platinum);
    color:var(--ink-soft);
    font-size:.66rem; letter-spacing:.16em; text-transform:uppercase;
    font-weight:400;
  }
  .announce .wrap{
    display:flex; align-items:center; justify-content:space-between;
    height:34px;
  }
  .announce .left span + span::before{ content:'·'; margin:0 .55em; color:var(--french); }
  .announce .right{ display:flex; align-items:center; gap:.4em; }
  @media(max-width:720px){ .announce .left span:not(:first-child){ display:none; } }

  /* ───────── utility bar ───────── */
  .util-bar{
    background:var(--ink); color:rgba(255,255,255,.78);
    font-size:.66rem; letter-spacing:.16em; text-transform:uppercase;
  }
  .util-bar .wrap{
    display:flex; align-items:center; justify-content:space-between;
    padding-top:.62rem; padding-bottom:.62rem; gap:1rem;
  }
  .util-bar .util-promo{ display:flex; align-items:center; gap:.6rem; }
  .util-bar .util-promo .dot{ color:rgba(255,255,255,.4); }
  .util-bar .util-loc{ display:flex; align-items:center; gap:.45rem; white-space:nowrap; }
  .util-bar .util-loc svg{ width:12px; height:12px; }
  @media(max-width:680px){
    .util-bar .util-promo .dot,
    .util-bar .util-promo span:not(:first-child){ display:none; }
    .util-bar{ font-size:.6rem; letter-spacing:.1em; }
  }

  /* ───────── header ───────── */
  header{
    position:sticky; top:0; z-index:50;
    background:rgba(248,249,250,.9);
    backdrop-filter:blur(10px);
    border-bottom:1px solid var(--platinum);
  }
  .header-grid{
    display:grid; grid-template-columns:1fr auto 1fr; align-items:center;
    height:84px;
  }
  .header-left{ display:flex; align-items:center; gap:1.6rem; }
  .header-right{ display:flex; align-items:center; justify-content:flex-end; gap:1.4rem; }

  .menu-btn{ background:none; border:none; cursor:pointer; display:none; color:var(--ink); }
  .menu-btn svg{ width:22px; height:22px; }

  .nav-links{ display:flex; gap:1.7rem; }
  .nav-links a{
    font-size:.74rem; letter-spacing:.13em; text-transform:uppercase; font-weight:400;
    color:var(--ink); position:relative; padding:.3rem 0;
  }
  .nav-links a::after{
    content:''; position:absolute; left:0; bottom:0; height:1px; width:0;
    background:var(--ink); transition:width .35s var(--ease);
  }
  .nav-links a:hover::after{ width:100%; }

  /* logo */
  .logo{ display:flex; flex-direction:column; align-items:center; line-height:1; gap:.28rem; }
  .logo .mono{
    font-family:'Cormorant Garamond', serif; font-weight:500;
    font-size:1.9rem; letter-spacing:.04em; color:var(--ink);
    display:flex; align-items:center; line-height:.8;
  }
  .logo .mono .j{ transform:translateX(.08em); }
  .logo .name{
    font-family:'Cormorant Garamond', serif; font-weight:500;
    font-size:.82rem; letter-spacing:.34em; text-transform:uppercase; color:var(--ink);
    padding-left:.34em;
  }

  .icon-btn{
    background:none; border:none; cursor:pointer; color:var(--ink);
    position:relative; display:grid; place-items:center;
    transition:opacity .3s var(--ease);
  }
  .icon-btn:hover{ opacity:.55; }
  .icon-btn svg{ width:20px; height:20px; }
  .cart-count{
    position:absolute; top:-7px; right:-9px;
    background:var(--ink); color:#fff; font-size:.56rem; font-weight:500;
    width:16px; height:16px; border-radius:50%; display:grid; place-items:center;
    letter-spacing:0;
  }

  @media(max-width:900px){
    .nav-links{ display:none; }
    .menu-btn{ display:grid; place-items:center; }
    .header-grid{ height:70px; }
    .logo .mono{ font-size:1.6rem; }
  }

  /* ───────── hero ───────── */
  .hero{
    position:relative; display:flex; align-items:center;
    min-height:min(86vh,760px);
    background:var(--platinum-2) center/cover no-repeat;
    background-image:
      linear-gradient(100deg, rgba(236,236,234,.96) 0%, rgba(236,236,234,.78) 32%, rgba(236,236,234,.30) 52%, rgba(236,236,234,0) 68%),
      url('https://images.unsplash.com/photo-1522335789203-aabd1fc54bc9?auto=format&fit=crop&w=1800&q=80');
    filter:saturate(.92);
  }
  .hero .wrap{ width:100%; }
  .hero-copy{ max-width:560px; padding:3rem 0; }
  .hero-eyebrow{ display:flex; align-items:center; gap:.85rem; margin-bottom:1.9rem; }
  .hero-eyebrow .orn-line{ width:58px; height:1px; background:var(--ink); opacity:.55; }
  .hero-eyebrow .diamond{ color:var(--ink); font-size:.6rem; opacity:.7; }
  h1.hero-title{
    font-family:'Cormorant Garamond', serif; font-weight:500;
    font-size:clamp(3.2rem,7.2vw,6.4rem); line-height:.92; letter-spacing:.02em;
    text-transform:uppercase; color:var(--ink);
  }
  .hero-tag{
    margin-top:1.8rem; font-size:1rem; letter-spacing:.04em; text-transform:uppercase;
    color:var(--ink); font-weight:400; line-height:1.7;
  }
  .hero-sub{
    margin-top:1.2rem; font-size:.82rem; letter-spacing:.13em; text-transform:uppercase;
    color:var(--dim);
  }

  /* shared button */
  .btn{
    display:inline-flex; align-items:center; gap:.8rem;
    padding:1rem 2.4rem; margin-top:2.6rem;
    font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; font-weight:500;
    color:#fff; background:var(--ink); border:1px solid var(--ink); cursor:pointer;
    position:relative; overflow:hidden; transition:color .4s var(--ease);
  }
  .btn span{ position:relative; z-index:1; transition:color .4s var(--ease); }
  .btn::before{
    content:''; position:absolute; inset:0; background:var(--seasalt);
    transform:translateY(100%); transition:transform .45s var(--ease); z-index:0;
  }
  .btn:hover::before{ transform:translateY(0); }
  .btn:hover span{ color:var(--ink); }
  .btn.ghost{ color:var(--ink); background:transparent; }
  .btn.ghost::before{ background:var(--ink); }
  .btn.ghost:hover span{ color:#fff; }

  @media(max-width:820px){
    .hero{
      min-height:auto; align-items:flex-end;
      background-image:
        linear-gradient(180deg, rgba(236,236,234,.92) 0%, rgba(236,236,234,.55) 40%, rgba(236,236,234,.85) 100%),
        url('https://images.unsplash.com/photo-1522335789203-aabd1fc54bc9?auto=format&fit=crop&w=1200&q=80');
    }
    .hero-copy{ max-width:none; padding:14rem 0 3rem; }
  }

  /* ───────── brand strip ───────── */
  .brand-strip{ border-bottom:1px solid var(--platinum); background:var(--seasalt); }
  .brand-strip .wrap{
    display:flex; align-items:center; justify-content:space-between;
    gap:2rem; flex-wrap:wrap; padding-top:2.2rem; padding-bottom:2.2rem;
  }
  .brand-strip span{
    font-weight:500; letter-spacing:.12em; color:var(--dim); font-size:1rem;
    opacity:.85; transition:opacity .3s var(--ease), color .3s var(--ease); white-space:nowrap;
  }
  .brand-strip span:hover{ opacity:1; color:var(--ink); }

  /* ───────── feature bar ───────── */
  .features{ background:var(--platinum); }
  .features .wrap{
    display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem;
    padding-top:2rem; padding-bottom:2rem;
  }
  .feature{ display:flex; align-items:center; gap:.9rem; }
  .feature svg{ width:26px; height:26px; color:var(--dim); flex-shrink:0; stroke-width:1.3; }
  .feature h4{ font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; font-weight:500; }
  .feature p{ font-size:.72rem; color:var(--dim); }
  @media(max-width:760px){ .features .wrap{ grid-template-columns:repeat(2,1fr); gap:1.4rem; } }

  /* ───────── section heading ───────── */
  section.block{ padding:clamp(3.5rem,7vw,6rem) 0; }
  .sec-head{ text-align:center; position:relative; margin-bottom:clamp(2.4rem,5vw,3.6rem); }
  .sec-head h2{
    font-family:'Cormorant Garamond', serif; font-weight:500;
    font-size:clamp(1.7rem,3.4vw,2.6rem); letter-spacing:.16em; text-transform:uppercase;
  }
  .sec-head .rule{ width:34px; height:1px; background:var(--french); margin:.9rem auto 0; }
  .sec-head .view-all{
    position:absolute; right:0; top:50%; transform:translateY(-50%);
    border:1px solid var(--ink); padding:.7rem 1.5rem;
    font-size:.66rem; letter-spacing:.2em; text-transform:uppercase;
    transition:background .35s var(--ease), color .35s var(--ease);
  }
  .sec-head .view-all:hover{ background:var(--ink); color:#fff; }
  @media(max-width:680px){ .sec-head .view-all{ display:none; } }

  /* ───────── product carousel ───────── */
  .carousel{ position:relative; }
  .track{
    display:grid; grid-auto-flow:column; grid-auto-columns:calc((100% - 4*1.4rem)/5);
    gap:1.4rem; overflow-x:auto; scroll-snap-type:x mandatory;
    scroll-behavior:smooth; padding-bottom:.5rem;
    scrollbar-width:none;
  }
  .track::-webkit-scrollbar{ display:none; }
  @media(max-width:1100px){ .track{ grid-auto-columns:calc((100% - 3*1.4rem)/4); } }
  @media(max-width:860px){ .track{ grid-auto-columns:calc((100% - 2*1.4rem)/3); } }
  @media(max-width:640px){ .track{ grid-auto-columns:calc((100% - 1.4rem)/2); } }
  @media(max-width:420px){ .track{ grid-auto-columns:78%; } }

  .arrow{
    position:absolute; top:34%; transform:translateY(-50%);
    width:42px; height:42px; border-radius:50%; background:var(--seasalt);
    border:1px solid var(--platinum-2); cursor:pointer; display:grid; place-items:center;
    box-shadow:0 4px 18px rgba(0,0,0,.06); z-index:3; color:var(--ink);
    transition:background .3s var(--ease);
  }
  .arrow:hover{ background:var(--platinum); }
  .arrow svg{ width:16px; height:16px; }
  .arrow.prev{ left:-14px; }
  .arrow.next{ right:-14px; }
  @media(max-width:680px){ .arrow{ display:none; } }

  .card{ scroll-snap-align:start; }
  .card-frame{
    position:relative; aspect-ratio:1/1; background:var(--platinum);
    overflow:hidden; margin-bottom:1rem;
  }
  .card-frame img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
  .card:hover .card-frame img{ transform:scale(1.06); }
  .card-badge{
    position:absolute; top:.8rem; right:.8rem;
    background:var(--ink); color:#fff; font-size:.54rem; letter-spacing:.14em;
    text-transform:uppercase; padding:.32rem .6rem; font-weight:500; z-index:2;
  }
  .card-badge.sold{ background:var(--french); }
  .wish{
    position:absolute; bottom:.8rem; right:.8rem; width:34px; height:34px; border-radius:50%;
    background:rgba(248,249,250,.85); border:none; cursor:pointer; display:grid; place-items:center;
    color:var(--ink); opacity:0; transform:translateY(6px);
    transition:opacity .35s var(--ease), transform .35s var(--ease), color .3s;
  }
  .card:hover .wish{ opacity:1; transform:none; }
  .wish svg{ width:16px; height:16px; fill:none; stroke:currentColor; stroke-width:1.4; }
  .wish.active{ color:#c2453f; }
  .wish.active svg{ fill:currentColor; }
  .quick-add{
    position:absolute; left:0; right:0; bottom:0; z-index:2;
    background:rgba(28,29,31,.92); color:#fff; border:none; cursor:pointer;
    padding:.85rem; font-size:.64rem; letter-spacing:.2em; text-transform:uppercase;
    transform:translateY(100%); transition:transform .4s var(--ease);
  }
  .card-frame:hover .quick-add{ transform:translateY(0); }

  .card-brand{ font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--dim); font-weight:500; }
  .card-name{ font-size:.92rem; margin:.25rem 0 .35rem; color:var(--ink); font-weight:400; }
  .card-price{ font-size:.82rem; color:var(--ink-soft); letter-spacing:.04em; }
  .card.sold .card-name, .card.sold .card-price{ color:var(--french); }

  /* ───────── promo split ───────── */
  .promo{ display:grid; grid-template-columns:1fr 1fr; gap:1.4rem; }
  .promo-card{
    position:relative; min-height:340px; overflow:hidden; display:flex;
    align-items:center; padding:clamp(2rem,4vw,3.2rem); background:var(--platinum-2);
  }
  .promo-card img{
    position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
    filter:grayscale(.2); transition:transform 1s var(--ease);
  }
  .promo-card:hover img{ transform:scale(1.05); }
  .promo-card .veil{ position:absolute; inset:0; background:linear-gradient(90deg,rgba(248,249,250,.92),rgba(248,249,250,.35)); }
  .promo-card .pc{ position:relative; z-index:1; max-width:62%; }
  .promo-card .caps{ color:var(--dim); }
  .promo-card h3{
    font-family:'Cormorant Garamond',serif; font-weight:500;
    font-size:clamp(1.6rem,2.6vw,2.2rem); line-height:1.15; margin:.6rem 0 0;
  }
  .promo-card .btn{ margin-top:1.4rem; padding:.8rem 1.8rem; }
  @media(max-width:760px){ .promo{ grid-template-columns:1fr; } .promo-card .pc{ max-width:80%; } }

  /* ───────── our brands grid ───────── */
  .brands-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:1rem; }
  @media(max-width:900px){ .brands-grid{ grid-template-columns:repeat(3,1fr); } }
  @media(max-width:560px){ .brands-grid{ grid-template-columns:repeat(2,1fr); } }
  .brand-card{
    position:relative; aspect-ratio:3/4; overflow:hidden; background:var(--platinum-2);
    display:grid; place-items:center;
  }
  .brand-card img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:grayscale(1) contrast(1.02); transition:transform .8s var(--ease), filter .6s; }
  .brand-card:hover img{ transform:scale(1.06); filter:grayscale(.5); }
  .brand-card span{
    position:relative; z-index:1; color:#fff; font-weight:600; letter-spacing:.06em;
    font-size:1.3rem; text-shadow:0 2px 14px rgba(0,0,0,.45);
  }
  .center-btn{ text-align:center; margin-top:2.6rem; }

  /* ───────── instagram grid ───────── */
  .insta-grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:.7rem; }
  @media(max-width:900px){ .insta-grid{ grid-template-columns:repeat(3,1fr); } }
  .insta-grid a{ position:relative; aspect-ratio:1/1; overflow:hidden; background:var(--platinum); }
  .insta-grid img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.25); transition:transform .7s var(--ease), filter .5s; }
  .insta-grid a:hover img{ transform:scale(1.08); filter:grayscale(0); }

  /* ───────── newsletter ───────── */
  .newsletter{ background:var(--ink); color:var(--seasalt); }
  .newsletter .wrap{
    display:flex; align-items:center; justify-content:space-between; gap:2rem; flex-wrap:wrap;
    padding-top:2.6rem; padding-bottom:2.6rem;
  }
  .nl-left{ display:flex; align-items:center; gap:1.2rem; }
  .nl-left svg{ width:30px; height:30px; color:var(--french); stroke-width:1.2; }
  .nl-left h4{ font-size:.82rem; letter-spacing:.16em; text-transform:uppercase; font-weight:500; }
  .nl-left p{ font-size:.74rem; color:var(--french); }
  .nl-form{ display:flex; flex:1; max-width:420px; min-width:260px; }
  .nl-form input{
    flex:1; background:transparent; border:1px solid var(--dim); border-right:none;
    color:#fff; padding:.85rem 1.1rem; font-family:inherit; font-size:.8rem; outline:none;
  }
  .nl-form input::placeholder{ color:var(--french); }
  .nl-form button{
    background:var(--seasalt); color:var(--ink); border:none; cursor:pointer;
    padding:0 1.6rem; font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; font-weight:500;
  }

  /* ───────── footer ───────── */
  footer{ background:var(--platinum); padding:clamp(3rem,6vw,4.5rem) 0 2rem; }
  .foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr 1fr; gap:2rem; }
  .foot-brand .logo{ align-items:flex-start; }
  .foot-brand .logo .name{ padding-left:0; }
  .foot-brand p{ font-size:.78rem; color:var(--dim); margin-top:1rem; max-width:24ch; }
  .foot-col h5{ font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; margin-bottom:1.1rem; font-weight:500; }
  .foot-col a{ display:block; font-size:.8rem; color:var(--ink-soft); margin-bottom:.55rem; transition:color .3s; }
  .foot-col a:hover{ color:var(--ink); }
  .foot-social{ display:flex; gap:.9rem; margin-top:.2rem; }
  .foot-social a{ color:var(--dim); }
  .foot-social svg{ width:18px; height:18px; }
  .foot-bottom{
    margin-top:3rem; padding-top:1.6rem; border-top:1px solid var(--platinum-2);
    text-align:center; font-size:.7rem; letter-spacing:.1em; color:var(--dim);
  }
  @media(max-width:820px){ .foot-grid{ grid-template-columns:1fr 1fr; } .foot-brand{ grid-column:1/-1; } }

  /* ───────── cart drawer ───────── */
  .overlay{
    position:fixed; inset:0; background:rgba(28,29,31,.45); z-index:90;
    opacity:0; visibility:hidden; transition:opacity .4s var(--ease), visibility .4s;
  }
  .overlay.open{ opacity:1; visibility:visible; }
  .drawer{
    position:fixed; top:0; right:0; bottom:0; width:min(420px,92vw); z-index:100;
    background:var(--seasalt); display:flex; flex-direction:column;
    transform:translateX(100%); transition:transform .45s var(--ease);
  }
  .drawer.open{ transform:none; }
  .drawer-head{
    display:flex; align-items:center; justify-content:space-between;
    padding:1.4rem 1.6rem; border-bottom:1px solid var(--platinum);
  }
  .drawer-head h3{ font-size:.82rem; letter-spacing:.18em; text-transform:uppercase; font-weight:500; }
  .drawer-close{ background:none; border:none; cursor:pointer; font-size:1.4rem; line-height:1; color:var(--ink); }
  .drawer-body{ flex:1; overflow-y:auto; padding:1.2rem 1.6rem; }
  .cart-empty{ text-align:center; color:var(--dim); padding:3rem 1rem; font-size:.85rem; }
  .cart-item{ display:flex; gap:1rem; padding:1rem 0; border-bottom:1px solid var(--platinum); }
  .cart-item img{ width:64px; height:64px; object-fit:cover; background:var(--platinum); flex-shrink:0; }
  .cart-item .ci-name{ font-size:.85rem; }
  .cart-item .ci-brand{ font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; color:var(--dim); }
  .cart-item .ci-price{ font-size:.8rem; color:var(--ink-soft); margin-top:.2rem; }
  .ci-qty{ display:flex; align-items:center; gap:.6rem; margin-top:.5rem; }
  .ci-qty button{ width:22px; height:22px; border:1px solid var(--platinum-2); background:none; cursor:pointer; color:var(--ink); }
  .ci-remove{ background:none; border:none; cursor:pointer; color:var(--dim); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; margin-left:auto; align-self:flex-start; }
  .drawer-foot{ padding:1.4rem 1.6rem; border-top:1px solid var(--platinum); }
  .cart-total{ display:flex; justify-content:space-between; font-size:.9rem; margin-bottom:1rem; }
  .cart-total strong{ font-weight:500; }
  .checkout{
    width:100%; display:flex; align-items:center; justify-content:center; gap:.7rem;
    background:#25D366; color:#fff; border:none; cursor:pointer; padding:1rem;
    font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; font-weight:500;
  }
  .checkout svg{ width:18px; height:18px; }

  /* mobile menu */
  .mobile-menu{
    position:fixed; inset:0; z-index:95; background:var(--seasalt);
    transform:translateX(-100%); transition:transform .4s var(--ease);
    padding:2rem; display:flex; flex-direction:column; gap:1.4rem;
  }
  .mobile-menu.open{ transform:none; }
  .mobile-menu a{ font-size:1rem; letter-spacing:.14em; text-transform:uppercase; }
  .mobile-menu .mm-close{ align-self:flex-end; background:none; border:none; font-size:1.8rem; cursor:pointer; }

  /* toast */
  .toast{
    position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(120%);
    background:var(--ink); color:#fff; padding:.9rem 1.6rem; font-size:.74rem;
    letter-spacing:.1em; z-index:200; transition:transform .4s var(--ease);
  }
  .toast.show{ transform:translateX(-50%) translateY(0); }

  .admin-link{ position:fixed; bottom:14px; left:14px; z-index:80; font-size:.62rem; letter-spacing:.12em; text-transform:uppercase; color:var(--french); opacity:.6; transition:opacity .3s; }
  .admin-link:hover{ opacity:1; color:var(--dim); }

  /* ═══════════════════ MOTION LAYER (level 6) ═══════════════════
     Everything here is gated on .js-motion (set in <head>) and the
     no-preference media query — remove this block to return to level 5. */
  @media (prefers-reduced-motion: no-preference){

    /* ── hero entrance ── */
    .js-motion .hero-copy > *{ opacity:0; transform:translateY(26px); }
    .js-motion.ready .hero-copy > *{ opacity:1; transform:none;
      transition:opacity 1s var(--ease), transform 1s var(--ease); }
    .js-motion.ready .hero-copy > *:nth-child(1){ transition-delay:.12s; }
    .js-motion.ready .hero-copy > *:nth-child(2){ transition-delay:.26s; }
    .js-motion.ready .hero-copy > *:nth-child(3){ transition-delay:.40s; }
    .js-motion.ready .hero-copy > *:nth-child(4){ transition-delay:.54s; }
    .js-motion.ready .hero-copy > *:nth-child(5){ transition-delay:.68s; }
    .js-motion .hero-eyebrow .orn-line{ transform-origin:left center; transform:scaleX(0); }
    .js-motion.ready .hero-eyebrow .orn-line{ transform:scaleX(1); transition:transform .9s var(--ease) .12s; }
    @keyframes spin{ to{ transform:rotate(360deg); } }

    /* ── scroll reveal (hidden until in view) ── */
    .js-motion .sec-head,
    .js-motion .feature,
    .js-motion .promo-card,
    .js-motion .brand-card,
    .js-motion .insta-grid a,
    .js-motion .foot-col,
    .js-motion .center-btn,
    .js-motion .nl-left,
    .js-motion .nl-form,
    .js-motion .track .card{
      opacity:0; transform:translateY(34px);
      transition:opacity .8s var(--ease), transform .8s var(--ease);
    }
    .js-motion .sec-head.in,
    .js-motion .feature.in,
    .js-motion .promo-card.in,
    .js-motion .brand-card.in,
    .js-motion .insta-grid a.in,
    .js-motion .foot-col.in,
    .js-motion .center-btn.in,
    .js-motion .nl-left.in,
    .js-motion .nl-form.in,
    .js-motion .track .card.in{ opacity:1; transform:none; }

    /* stagger within rows */
    .js-motion .feature:nth-child(2){ transition-delay:.08s; }
    .js-motion .feature:nth-child(3){ transition-delay:.16s; }
    .js-motion .feature:nth-child(4){ transition-delay:.24s; }
    .js-motion .promo-card:nth-child(2){ transition-delay:.12s; }
    .js-motion .brand-card:nth-child(2){ transition-delay:.07s; }
    .js-motion .brand-card:nth-child(3){ transition-delay:.14s; }
    .js-motion .brand-card:nth-child(4){ transition-delay:.21s; }
    .js-motion .brand-card:nth-child(5){ transition-delay:.28s; }
    .js-motion .insta-grid a:nth-child(2){ transition-delay:.06s; }
    .js-motion .insta-grid a:nth-child(3){ transition-delay:.12s; }
    .js-motion .insta-grid a:nth-child(4){ transition-delay:.18s; }
    .js-motion .insta-grid a:nth-child(5){ transition-delay:.24s; }
    .js-motion .insta-grid a:nth-child(6){ transition-delay:.30s; }
    .js-motion .track .card:nth-child(2){ transition-delay:.07s; }
    .js-motion .track .card:nth-child(3){ transition-delay:.14s; }
    .js-motion .track .card:nth-child(4){ transition-delay:.21s; }
    .js-motion .track .card:nth-child(5){ transition-delay:.28s; }

    /* ── button polish: lift + glint sweep ── */
    .btn{ transition:color .45s var(--ease), transform .35s var(--ease), box-shadow .45s var(--ease); }
    .btn:hover{ transform:translateY(-3px); box-shadow:0 14px 30px rgba(28,29,31,.18); }
    .btn:active{ transform:translateY(-1px) scale(.99); }
    .btn::after{ content:''; position:absolute; top:0; bottom:0; left:-75%; width:55%; z-index:1;
      background:linear-gradient(100deg, transparent, rgba(255,255,255,.5), transparent);
      transform:skewX(-20deg); pointer-events:none; }
    .btn:hover::after{ animation:btnShine .9s var(--ease); }
    @keyframes btnShine{ from{ left:-75%; } to{ left:135%; } }

    /* ── header, icons, arrows, cart ── */
    header{ transition:box-shadow .4s var(--ease), background .4s var(--ease); }
    header.scrolled{ box-shadow:0 6px 24px rgba(28,29,31,.07); }
    .icon-btn{ transition:transform .35s var(--ease), opacity .3s; }
    .icon-btn:hover{ transform:translateY(-2px) scale(1.08); }
    .cart-count{ transition:transform .3s var(--ease); }
    .cart-count.pop{ animation:countPop .5s var(--ease); }
    @keyframes countPop{ 0%{ transform:scale(1); } 40%{ transform:scale(1.55); } 100%{ transform:scale(1); } }
    .arrow{ transition:background .3s var(--ease), transform .3s var(--ease), box-shadow .3s; }
    .arrow.prev:hover, .arrow.next:hover{ transform:translateY(-50%) scale(1.12); box-shadow:0 8px 22px rgba(0,0,0,.1); }
    .nl-form button:hover{ transform:translateX(2px); opacity:.9; transition:transform .3s var(--ease), opacity .3s; }
    .checkout{ transition:filter .3s, transform .3s var(--ease); }
    .checkout:hover{ filter:brightness(1.06); transform:translateY(-2px); }

    /* ── product + brand card lift ── */
    .card{ transition:transform .45s var(--ease); }
    .card:hover{ transform:translateY(-5px); }
    .brand-card{ transition:transform .45s var(--ease), box-shadow .45s var(--ease); }
    .brand-card:hover{ transform:translateY(-5px); box-shadow:0 18px 36px rgba(28,29,31,.16); }
    .brand-strip span{ transition:opacity .3s var(--ease), color .3s var(--ease), transform .3s var(--ease); }
    .brand-strip span:hover{ transform:translateY(-2px); }
  }
