/* ============================================================
   BOHOME CASA — Design tokens
   Palette pinned by brief: ivory ground, sand/beige, terracotta,
   clay, walnut wood, olive green. Signature: Moorish keyhole arch.
   ============================================================ */
:root{
  --ivory:#FBF7EF;
  --cream:#F4ECDD;
  --beige:#EFE5D3;
  --sand:#E6D6BC;
  --sand-deep:#D8C29F;
  --terracotta:#BC5C3C;
  --terracotta-deep:#A1492C;
  --clay:#9C5A40;
  --olive:#5E6A43;
  --olive-deep:#49532F;
  --walnut:#2C2118;
  --walnut-soft:#5B4A39;
  --ink:#2C2118;
  --line:#E2D6C0;
  --shadow-soft:0 18px 40px -24px rgba(44,33,24,.35);
  --shadow-lift:0 30px 60px -28px rgba(44,33,24,.45);
  --r-arch:160px;
  --maxw:1280px;
  --ff-display:'Playfair Display',Georgia,serif;
  --ff-body:'Inter',system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--ivory);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:500;line-height:1.1;color:var(--walnut)}
:focus-visible{outline:2.5px solid var(--terracotta);outline-offset:3px;border-radius:2px}

/* zellige texture used sparingly as section accent */
.zellige-bg{
  background-color:var(--cream);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cg fill='none' stroke='%23BC5C3C' stroke-opacity='0.09' stroke-width='1'%3E%3Cpath d='M30 4 L38 12 L46 4 L46 16 L56 16 L48 24 L56 30 L48 36 L56 44 L46 44 L46 56 L38 48 L30 56 L22 48 L14 56 L14 44 L4 44 L12 36 L4 30 L12 24 L4 16 L14 16 L14 4 L22 12 Z'/%3E%3C/g%3E%3C/svg%3E");
}

/* ---------- shared layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{
  font-size:.72rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;
  color:var(--terracotta);display:inline-block;
}
.section{padding:96px 0}
.section-head{max-width:640px;margin:0 auto 56px;text-align:center}
.section-head h2{font-size:clamp(2rem,4vw,3rem);margin:14px 0 0}
.section-head p{margin-top:16px;color:var(--walnut-soft);font-size:1.05rem}

/* arch helper — the signature keyhole/horseshoe shape */
.arch-top{border-radius:var(--r-arch) var(--r-arch) 14px 14px;overflow:hidden}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-weight:600;font-size:.86rem;letter-spacing:.06em;text-transform:uppercase;
  padding:16px 30px;border-radius:2px;transition:.35s ease;white-space:nowrap;
}
.btn-primary{background:var(--walnut);color:var(--ivory)}
.btn-primary:hover{background:var(--terracotta);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ivory);border:1.5px solid rgba(251,247,239,.65)}
.btn-ghost:hover{background:var(--ivory);color:var(--walnut)}
.btn-dark-outline{background:transparent;color:var(--walnut);border:1.5px solid var(--walnut)}
.btn-dark-outline:hover{background:var(--walnut);color:var(--ivory)}

/* ============================================================
   ANNOUNCEMENT + HEADER
   ============================================================ */
.announce{
  background:var(--walnut);color:var(--cream);text-align:center;
  font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  padding:10px 16px;position:relative;z-index:60;
}
.announce span{opacity:.92}
.announce b{color:var(--sand);font-weight:600}

header.site{
  position:sticky;top:0;z-index:50;background:rgba(251,247,239,.92);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
  transition:padding .3s ease,box-shadow .3s ease;
}
header.site.shrunk{box-shadow:0 6px 24px -16px rgba(44,33,24,.4)}
.nav-row{display:flex;align-items:center;justify-content:space-between;
  padding:20px 28px;max-width:1400px;margin:0 auto;transition:padding .3s ease}
header.site.shrunk .nav-row{padding:13px 28px}
.brand{font-family:var(--ff-display);font-weight:600;font-size:1.6rem;letter-spacing:.04em;
  color:var(--walnut);display:flex;align-items:baseline;gap:.45em}
.brand small{font-size:.58rem;letter-spacing:.42em;text-transform:uppercase;color:var(--terracotta);font-family:var(--ff-body);font-weight:600}

/* main nav */
.mainnav{display:flex;gap:30px}
.mainnav>li>a,.mainnav>li>button{
  font-size:.82rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;
  padding:14px 2px;display:inline-flex;align-items:center;gap:6px;position:relative;color:var(--walnut)
}
.mainnav>li>a::after,.mainnav>li>button::after{
  content:"";position:absolute;left:0;bottom:6px;height:1.5px;width:0;background:var(--terracotta);transition:width .3s ease
}
.mainnav>li:hover>a::after,.mainnav>li:hover>button::after,.mainnav>li.open>button::after{width:100%}
.mainnav .tag-new{color:var(--terracotta);font-weight:600}

/* mega menu */
.has-mega{position:static}
.mega{
  position:absolute;left:0;right:0;top:100%;background:var(--ivory);
  border-top:1px solid var(--line);box-shadow:var(--shadow-soft);
  opacity:0;visibility:hidden;transform:translateY(8px);transition:.28s ease;
  padding:46px 0;z-index:45;
}
.has-mega.open .mega{opacity:1;visibility:visible;transform:translateY(0)}
.mega-grid{display:grid;grid-template-columns:repeat(4,1fr) 1.3fr;gap:40px;max-width:var(--maxw);margin:0 auto;padding:0 28px}
.mega-col h4{font-family:var(--ff-body);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--terracotta);margin-bottom:16px;font-weight:600}
.mega-col li{margin-bottom:11px}
.mega-col a{font-size:.95rem;color:var(--walnut-soft);transition:.2s}
.mega-col a:hover{color:var(--terracotta);padding-left:5px}
.mega-feature{background:var(--cream);border-radius:6px;overflow:hidden;position:relative;min-height:220px;display:flex;align-items:flex-end}
.mega-feature img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.mega-feature .cap{position:relative;padding:22px;background:linear-gradient(transparent,rgba(44,33,24,.85));width:100%;color:var(--cream)}
.mega-feature .cap span{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sand)}
.mega-feature .cap p{font-family:var(--ff-display);font-size:1.25rem;margin-top:4px;color:#fff}

/* header icons */
.icons{display:flex;align-items:center;gap:8px}
.icon-btn{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;position:relative;transition:.25s;color:var(--walnut)}
.icon-btn:hover{background:var(--cream)}
.icon-btn svg{width:21px;height:21px}
.badge{position:absolute;top:4px;right:4px;background:var(--terracotta);color:#fff;font-size:.62rem;font-weight:700;
  min-width:17px;height:17px;border-radius:9px;display:grid;place-items:center;padding:0 4px;transform:scale(0);transition:transform .25s}
.badge.show{transform:scale(1)}
.burger{display:none}

/* search bar */
.searchbar{position:absolute;left:0;right:0;top:100%;background:var(--ivory);border-top:1px solid var(--line);
  box-shadow:var(--shadow-soft);padding:26px 0;transform:translateY(-12px);opacity:0;visibility:hidden;transition:.28s;z-index:48}
.searchbar.open{transform:translateY(0);opacity:1;visibility:visible}
.search-inner{max-width:760px;margin:0 auto;padding:0 28px}
.search-field{display:flex;align-items:center;gap:14px;border-bottom:2px solid var(--walnut);padding-bottom:12px}
.search-field input{flex:1;border:none;background:none;font-family:var(--ff-display);font-size:1.5rem;color:var(--walnut)}
.search-field input::placeholder{color:var(--sand-deep)}
.search-field input:focus{outline:none}
.autocomplete{margin-top:22px;display:grid;gap:4px}
.ac-item{display:flex;align-items:center;gap:14px;padding:10px;border-radius:6px;transition:.2s}
.ac-item:hover{background:var(--cream)}
.ac-item img{width:48px;height:48px;border-radius:4px;object-fit:cover;background:var(--sand)}
.ac-item .nm{font-weight:500}
.ac-item .ct{font-size:.78rem;color:var(--walnut-soft);margin-left:auto}
.ac-empty{color:var(--walnut-soft);font-size:.9rem;padding:10px}

/* ============================================================
   HERO — arch-framed lifestyle image (signature)
   ============================================================ */
.hero{position:relative;padding:72px 0 90px;overflow:hidden}
.hero::before{content:"";position:absolute;top:-10%;right:-12%;width:540px;height:540px;border-radius:50%;
  background:radial-gradient(circle,rgba(188,92,60,.14),transparent 68%);z-index:0}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1.05fr;gap:60px;align-items:center;max-width:var(--maxw);margin:0 auto;padding:0 28px}
.hero-copy .eyebrow{margin-bottom:20px}
.hero-copy h1{font-size:clamp(2.6rem,5.4vw,4.6rem);font-weight:500;letter-spacing:-.01em}
.hero-copy h1 em{font-style:italic;color:var(--terracotta)}
.hero-copy p{font-size:1.15rem;color:var(--walnut-soft);max-width:440px;margin:26px 0 36px}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero-cta .btn-ghost{color:var(--walnut);border-color:var(--walnut)}
.hero-cta .btn-ghost:hover{background:var(--walnut);color:var(--ivory)}
.hero-stats{display:flex;gap:38px;margin-top:48px;padding-top:30px;border-top:1px solid var(--line)}
.hero-stats div b{font-family:var(--ff-display);font-size:1.9rem;color:var(--terracotta);display:block;line-height:1}
.hero-stats div span{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--walnut-soft)}

.hero-frame{position:relative}
.arch-img{position:relative;aspect-ratio:4/5;border-radius:280px 280px 18px 18px;overflow:hidden;
  box-shadow:var(--shadow-lift);background:linear-gradient(160deg,var(--sand),var(--clay))}
.arch-img img{width:100%;height:100%;object-fit:cover}
.arch-img::after{content:"";position:absolute;inset:0;border-radius:inherit;
  box-shadow:inset 0 0 0 7px rgba(251,247,239,.55), inset 0 0 0 9px rgba(188,92,60,.4)}
.hero-tag{position:absolute;bottom:30px;left:-26px;background:var(--ivory);border-radius:6px;
  box-shadow:var(--shadow-soft);padding:16px 20px;display:flex;align-items:center;gap:14px;max-width:230px}
.hero-tag .dot{width:36px;height:36px;border-radius:50%;background:var(--olive);display:grid;place-items:center;color:#fff;flex-shrink:0}
.hero-tag .dot svg{width:18px;height:18px}
.hero-tag p{font-size:.8rem;color:var(--walnut);line-height:1.35;margin:0}
.hero-tag b{display:block;font-family:var(--ff-display);font-size:.95rem}

/* small zellige strip divider */
.tile-strip{height:14px;background-repeat:repeat-x;background-size:24px 14px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='14'%3E%3Cpath d='M0 7 L6 0 L12 7 L18 0 L24 7 L18 14 L12 7 L6 14 Z' fill='%23BC5C3C' fill-opacity='0.35'/%3E%3C/svg%3E")}

/* ============================================================
   SHOP BY CATEGORY — arch-top cards
   ============================================================ */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.cat-card{position:relative;display:block;transition:transform .4s ease}
.cat-card:hover{transform:translateY(-7px)}
.cat-media{aspect-ratio:3/4;border-radius:140px 140px 10px 10px;overflow:hidden;position:relative;
  background:linear-gradient(155deg,var(--sand),var(--clay));box-shadow:var(--shadow-soft)}
.cat-media img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.cat-card:hover .cat-media img{transform:scale(1.07)}
.cat-media::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(44,33,24,.55))}
.cat-label{position:absolute;left:0;right:0;bottom:22px;text-align:center;color:#fff;z-index:2}
.cat-label h3{color:#fff;font-size:1.4rem}
.cat-label span{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sand);opacity:.9}
.cat-grid .span2{grid-column:span 2}
.cat-grid .span2 .cat-media{aspect-ratio:auto;height:100%;border-radius:140px 10px 10px 140px}

/* ============================================================
   FEATURED COLLECTIONS — alternating
   ============================================================ */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-bottom:90px}
.feature:last-child{margin-bottom:0}
.feature.flip .feat-media{order:2}
.feat-media{position:relative}
.feat-media .arch-top{aspect-ratio:5/4;background:linear-gradient(160deg,var(--sand),var(--olive));box-shadow:var(--shadow-lift)}
.feat-media .arch-top img{width:100%;height:100%;object-fit:cover}
.feat-media .num{position:absolute;top:-22px;left:-12px;font-family:var(--ff-display);font-size:5rem;color:var(--sand-deep);z-index:-1;font-style:italic}
.feat-copy .eyebrow{margin-bottom:14px}
.feat-copy h3{font-size:clamp(1.8rem,3.4vw,2.6rem);margin-bottom:18px}
.feat-copy p{color:var(--walnut-soft);font-size:1.06rem;max-width:430px;margin-bottom:28px}
.feat-copy a{font-weight:600;letter-spacing:.06em;text-transform:uppercase;font-size:.84rem;color:var(--terracotta);
  border-bottom:1.5px solid var(--terracotta);padding-bottom:4px;transition:.25s}
.feat-copy a:hover{color:var(--walnut);border-color:var(--walnut)}

/* ============================================================
   BEST SELLERS — filterable product grid
   ============================================================ */
.filters{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:44px}
.filter{font-size:.8rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;padding:10px 20px;
  border-radius:40px;border:1px solid var(--line);color:var(--walnut-soft);transition:.25s;background:var(--ivory)}
.filter:hover{border-color:var(--terracotta);color:var(--terracotta)}
.filter.active{background:var(--walnut);color:var(--ivory);border-color:var(--walnut)}
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.card{position:relative;display:flex;flex-direction:column}
.card-media{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;background:var(--cream);box-shadow:var(--shadow-soft)}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.card:hover .card-media img{transform:scale(1.06)}
.card-flag{position:absolute;top:14px;left:14px;background:var(--terracotta);color:#fff;font-size:.66rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;border-radius:3px;z-index:2}
.card-flag.olive{background:var(--olive)}
.wish{position:absolute;top:12px;right:12px;width:38px;height:38px;border-radius:50%;background:rgba(251,247,239,.92);
  display:grid;place-items:center;z-index:2;transition:.25s;box-shadow:0 4px 14px -6px rgba(44,33,24,.5)}
.wish:hover{background:#fff;transform:scale(1.08)}
.wish svg{width:19px;height:19px;stroke:var(--walnut);fill:none;transition:.2s}
.wish.active svg{fill:var(--terracotta);stroke:var(--terracotta)}
.quick{position:absolute;left:14px;right:14px;bottom:14px;background:var(--walnut);color:var(--ivory);
  font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:13px;border-radius:4px;
  opacity:0;transform:translateY(10px);transition:.3s;z-index:2}
.card:hover .quick{opacity:1;transform:translateY(0)}
.quick:hover{background:var(--terracotta)}
.card-info{padding:16px 2px 0}
.card-cat{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--olive);font-weight:600}
.card-name{font-family:var(--ff-display);font-size:1.18rem;margin:5px 0 7px}
.stars{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--walnut-soft);margin-bottom:9px}
.stars .s{color:var(--terracotta);letter-spacing:1px}
.price{font-weight:600;font-size:1.05rem;color:var(--walnut)}
.price .was{color:var(--sand-deep);text-decoration:line-through;font-weight:400;margin-left:8px;font-size:.92rem}

/* ============================================================
   SHOP THE LOOK — interactive hotspots
   ============================================================ */
.look{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:16/9;background:linear-gradient(150deg,var(--sand),var(--clay));box-shadow:var(--shadow-lift)}
.look>img{width:100%;height:100%;object-fit:cover}
.hotspot{position:absolute;width:34px;height:34px;border-radius:50%;background:rgba(251,247,239,.95);
  border:2px solid var(--terracotta);display:grid;place-items:center;cursor:pointer;transform:translate(-50%,-50%);z-index:3}
.hotspot::before{content:"";position:absolute;inset:-7px;border-radius:50%;border:2px solid rgba(251,247,239,.7);
  animation:pulse 2.2s ease-out infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.9}100%{transform:scale(1.7);opacity:0}}
.hotspot span{font-size:1.2rem;font-weight:700;color:var(--terracotta);line-height:1}
.hs-pop{position:absolute;background:var(--ivory);border-radius:8px;box-shadow:var(--shadow-lift);
  padding:14px;display:none;gap:13px;align-items:center;width:250px;z-index:5;transform:translate(-50%,-115%)}
.hs-pop.show{display:flex}
.hs-pop img{width:58px;height:58px;border-radius:5px;object-fit:cover;background:var(--sand)}
.hs-pop .nm{font-family:var(--ff-display);font-size:1.02rem;line-height:1.15}
.hs-pop .pr{font-weight:600;color:var(--terracotta);font-size:.92rem;margin-top:2px}
.hs-pop button{font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  color:var(--walnut);border-bottom:1.5px solid var(--terracotta);padding-bottom:2px;margin-top:6px;display:inline-block}

/* ============================================================
   WHY CHOOSE US
   ============================================================ */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.why-card{text-align:center;padding:40px 26px;background:var(--ivory);border-radius:10px;border:1px solid var(--line);transition:.35s}
.why-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-soft);border-color:transparent}
.why-icon{width:64px;height:64px;margin:0 auto 22px;border-radius:50% 50% 50% 50%/60% 60% 40% 40%;
  background:var(--cream);display:grid;place-items:center;color:var(--terracotta)}
.why-icon svg{width:30px;height:30px}
.why-card h4{font-size:1.22rem;margin-bottom:10px}
.why-card p{font-size:.92rem;color:var(--walnut-soft)}

/* ============================================================
   INSPIRATION GALLERY — masonry
   ============================================================ */
.masonry{columns:4;column-gap:18px}
.masonry figure{break-inside:avoid;margin-bottom:18px;border-radius:8px;overflow:hidden;position:relative;
  background:linear-gradient(150deg,var(--sand),var(--olive));box-shadow:var(--shadow-soft)}
.masonry img{width:100%;display:block;transition:transform .6s ease}
.masonry figure:hover img{transform:scale(1.06)}
.masonry figcaption{position:absolute;left:0;right:0;bottom:0;padding:18px 16px 14px;
  background:linear-gradient(transparent,rgba(44,33,24,.78));color:var(--cream);font-size:.82rem;letter-spacing:.1em;
  text-transform:uppercase;opacity:0;transition:.3s}
.masonry figure:hover figcaption{opacity:1}

/* ============================================================
   BRAND STORY
   ============================================================ */
.story{position:relative;background:var(--walnut);color:var(--cream);overflow:hidden}
.story .tile-strip{opacity:.5}
.story-grid{display:grid;grid-template-columns:1.1fr 1fr;align-items:center;gap:60px;max-width:var(--maxw);margin:0 auto;padding:96px 28px}
.story-media .arch-top{aspect-ratio:4/5;background:linear-gradient(160deg,var(--clay),var(--olive-deep))}
.story-media .arch-top img{width:100%;height:100%;object-fit:cover}
.story-copy .eyebrow{color:var(--sand)}
.story-copy h2{color:#fff;font-size:clamp(2rem,4vw,3.1rem);margin:16px 0 22px}
.story-copy p{color:rgba(244,236,221,.85);font-size:1.08rem;max-width:460px;margin-bottom:18px}
.story-sign{font-family:var(--ff-display);font-style:italic;font-size:1.5rem;color:var(--sand);margin-top:26px}

/* ============================================================
   NEWSLETTER
   ============================================================ */
.news{text-align:center}
.news-inner{max-width:560px;margin:0 auto}
.news h2{font-size:clamp(2rem,4vw,2.9rem)}
.news p{color:var(--walnut-soft);margin:14px 0 32px;font-size:1.05rem}
.news-form{display:flex;gap:12px;max-width:480px;margin:0 auto}
.news-form input{flex:1;padding:16px 20px;border:1.5px solid var(--sand-deep);border-radius:3px;background:var(--ivory);font-family:inherit;font-size:.98rem}
.news-form input:focus{outline:none;border-color:var(--terracotta)}
.news-mini{margin-top:16px;font-size:.78rem;color:var(--walnut-soft)}

/* ============================================================
   FOOTER
   ============================================================ */
footer{background:var(--cream);padding-top:72px;border-top:1px solid var(--line)}
.foot-grid{display:grid;grid-template-columns:1.6fr repeat(4,1fr);gap:40px;max-width:var(--maxw);margin:0 auto;padding:0 28px 60px}
.foot-brand .brand{margin-bottom:18px}
.foot-brand p{color:var(--walnut-soft);font-size:.94rem;max-width:280px;margin-bottom:22px}
.socials{display:flex;gap:10px}
.socials a{width:40px;height:40px;border-radius:50%;border:1px solid var(--sand-deep);display:grid;place-items:center;transition:.25s}
.socials a:hover{background:var(--walnut);color:var(--ivory);border-color:var(--walnut)}
.socials svg{width:18px;height:18px}
.foot-col h4{font-family:var(--ff-body);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--terracotta);margin-bottom:18px;font-weight:600}
.foot-col li{margin-bottom:11px}
.foot-col a{font-size:.92rem;color:var(--walnut-soft);transition:.2s}
.foot-col a:hover{color:var(--terracotta)}
.foot-bottom{border-top:1px solid var(--line)}
.foot-bottom-in{max-width:var(--maxw);margin:0 auto;padding:24px 28px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.foot-bottom p{font-size:.82rem;color:var(--walnut-soft)}
.pay{display:flex;gap:8px;align-items:center}
.pay .chip{font-size:.62rem;font-weight:700;letter-spacing:.04em;color:var(--walnut-soft);background:var(--ivory);
  border:1px solid var(--sand-deep);border-radius:4px;padding:6px 9px}
.trust{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.trust span{display:flex;align-items:center;gap:7px;font-size:.78rem;color:var(--walnut-soft)}
.trust svg{width:16px;height:16px;color:var(--olive)}

/* ============================================================
   CART DRAWER + OVERLAY
   ============================================================ */
.overlay{position:fixed;inset:0;background:rgba(44,33,24,.45);backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:.3s;z-index:70}
.overlay.show{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;height:100%;width:420px;max-width:92vw;background:var(--ivory);z-index:80;
  transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.drawer.open{transform:translateX(0)}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:24px 26px;border-bottom:1px solid var(--line)}
.drawer-head h3{font-size:1.4rem}
.drawer-close{width:38px;height:38px;border-radius:50%;display:grid;place-items:center}
.drawer-close:hover{background:var(--cream)}
.drawer-body{flex:1;overflow-y:auto;padding:8px 26px}
.cart-empty{text-align:center;padding:70px 20px;color:var(--walnut-soft)}
.cart-empty svg{width:46px;height:46px;color:var(--sand-deep);margin-bottom:16px}
.cart-item{display:flex;gap:14px;padding:20px 0;border-bottom:1px solid var(--line)}
.cart-item img{width:74px;height:74px;border-radius:6px;object-fit:cover;background:var(--cream);flex-shrink:0}
.ci-body{flex:1;min-width:0}
.ci-name{font-family:var(--ff-display);font-size:1.05rem;line-height:1.2}
.ci-cat{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--olive);margin:3px 0 8px}
.ci-foot{display:flex;align-items:center;justify-content:space-between}
.qty{display:flex;align-items:center;border:1px solid var(--sand-deep);border-radius:30px;overflow:hidden}
.qty button{width:30px;height:30px;font-size:1.1rem;color:var(--walnut);display:grid;place-items:center}
.qty button:hover{background:var(--cream)}
.qty span{min-width:26px;text-align:center;font-size:.9rem;font-weight:600}
.ci-price{font-weight:600;color:var(--walnut)}
.ci-remove{font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--walnut-soft);margin-top:6px}
.ci-remove:hover{color:var(--terracotta)}
.drawer-foot{padding:22px 26px;border-top:1px solid var(--line);background:var(--cream)}
.subtotal{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.subtotal b{font-family:var(--ff-display);font-size:1.5rem;color:var(--walnut)}
.ship-note{font-size:.8rem;color:var(--walnut-soft);margin-bottom:16px}
.drawer-foot .btn{width:100%;justify-content:center}

/* toast */
.toast{position:fixed;bottom:26px;left:50%;transform:translate(-50%,120%);background:var(--walnut);color:var(--ivory);
  padding:15px 26px;border-radius:6px;font-size:.9rem;z-index:120;box-shadow:var(--shadow-lift);transition:transform .4s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:10px}
.toast.show{transform:translate(-50%,0)}
.toast svg{width:18px;height:18px;color:var(--sand)}

/* reveal animation */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   MOBILE NAV
   ============================================================ */
.mobile-nav{position:fixed;inset:0 0 0 auto;width:340px;max-width:88vw;background:var(--ivory);z-index:90;
  transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);overflow-y:auto;padding:26px}
.mobile-nav.open{transform:translateX(0)}
.mn-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}
.mobile-nav details{border-bottom:1px solid var(--line)}
.mobile-nav summary{padding:16px 2px;font-size:1.05rem;font-weight:500;list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.mobile-nav summary::-webkit-details-marker{display:none}
.mobile-nav summary::after{content:"+";font-size:1.4rem;color:var(--terracotta)}
.mobile-nav details[open] summary::after{content:"–"}
.mobile-nav .sub{padding:0 0 14px 10px}
.mobile-nav .sub a{display:block;padding:9px 0;color:var(--walnut-soft)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1080px){
  .mainnav,.icons .desk-only{display:none}
  .burger{display:grid}
  .cat-grid,.prod-grid,.why-grid{grid-template-columns:repeat(2,1fr)}
  .masonry{columns:3}
  .mega-grid{grid-template-columns:repeat(3,1fr)}
  .mega-feature{display:none}
}
@media(max-width:820px){
  .section{padding:70px 0}
  .hero-grid,.feature,.feature.flip,.story-grid{grid-template-columns:1fr;gap:40px}
  .feature.flip .feat-media{order:0}
  .hero-frame{max-width:420px;margin:0 auto}
  .hero-copy{text-align:center}
  .hero-copy p{margin-left:auto;margin-right:auto}
  .hero-cta,.hero-stats{justify-content:center}
  .foot-grid{grid-template-columns:repeat(2,1fr)}
  .foot-brand{grid-column:1/-1}
  .masonry{columns:2}
  .cat-grid .span2{grid-column:auto}
  .cat-grid .span2 .cat-media{border-radius:140px 140px 10px 10px;aspect-ratio:3/4}
}
@media(max-width:520px){
  .wrap,.nav-row{padding-left:18px;padding-right:18px}
  .cat-grid,.prod-grid,.why-grid,.foot-grid{grid-template-columns:1fr}
  .masonry{columns:1}
  .news-form{flex-direction:column}
  .hero-stats{gap:22px}
  .brand{font-size:1.35rem}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}