/* ============================================================
   DamiGlamCuts — stylesheet
   Palette: charcoal #1A1410 · terracotta #9C5B3D · bone #FBF8F3
            gold #C9A66B · clay #E8D5C4 · olive #3D5A45
   ============================================================ */

:root{
  --char:#1A1410; --terra:#9C5B3D; --bone:#FBF8F3; --gold:#C9A66B;
  --clay:#E8D5C4; --olive:#3D5A45; --line:rgba(26,20,16,.12);
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost',system-ui,sans-serif;
  --max:1440px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bone);color:var(--char);
  line-height:1.6;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--terra);color:var(--bone)}
.container{max-width:var(--max);margin:0 auto;padding:0 32px}
@media(max-width:640px){.container{padding:0 18px}}

h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.05}
.serif{font-family:var(--serif)}

/* ---------- BUTTONS ---------- */
/* Fill animates via background-position on the button itself, so it
   can never cover the text. Two-stop gradient: bottom half = hover
   colour, top half = base colour; we slide it up on hover. */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;
  gap:9px;border:none;cursor:pointer;
  font-family:var(--sans);font-weight:500;font-size:11.5px;letter-spacing:.16em;
  text-transform:uppercase;padding:17px 32px;border-radius:2px;
  background-size:100% 200%;background-position:0 0;
  transition:background-position .42s cubic-bezier(.16,1,.3,1),
             transform .35s cubic-bezier(.16,1,.3,1),
             box-shadow .35s cubic-bezier(.16,1,.3,1),
             color .3s ease;
  -webkit-tap-highlight-color:transparent}
.btn:hover{background-position:0 100%}
.btn:active{transform:translateY(1px) scale(.99)}

.btn--dark{color:var(--bone);
  background-image:linear-gradient(to bottom,var(--char) 0%,var(--char) 50%,var(--terra) 50%,var(--terra) 100%);
  box-shadow:0 2px 10px rgba(26,20,16,.18)}
.btn--dark:hover{color:#fff;box-shadow:0 8px 24px rgba(156,91,61,.32);
  transform:translateY(-2px)}

.btn--terra{color:var(--bone);
  background-image:linear-gradient(to bottom,var(--terra) 0%,var(--terra) 50%,var(--gold) 50%,var(--gold) 100%);
  box-shadow:0 2px 10px rgba(156,91,61,.25)}
.btn--terra:hover{color:var(--char);box-shadow:0 8px 24px rgba(201,166,107,.4);
  transform:translateY(-2px)}

.btn--ghost{color:var(--bone);background-color:transparent;
  background-image:linear-gradient(to bottom,transparent 0%,transparent 50%,var(--gold) 50%,var(--gold) 100%);
  box-shadow:inset 0 0 0 1px rgba(232,213,196,.4)}
.btn--ghost:hover{color:var(--char);box-shadow:inset 0 0 0 1px var(--gold);
  transform:translateY(-2px)}

.btn--outline{color:var(--terra);background-color:transparent;
  background-image:linear-gradient(to bottom,transparent 0%,transparent 50%,var(--terra) 50%,var(--terra) 100%);
  box-shadow:inset 0 0 0 1px var(--terra)}
.btn--outline:hover{color:#fff;box-shadow:inset 0 0 0 1px var(--terra),
  0 8px 24px rgba(156,91,61,.28);transform:translateY(-2px)}

.btn--full{width:100%}
.btn[disabled]{opacity:.55;cursor:not-allowed;pointer-events:none}
.btn .arrow{transition:transform .35s cubic-bezier(.16,1,.3,1)}
.btn:hover .arrow{transform:translateX(5px)}

/* ============================================================
   HEADER — SOLID, never transparent
   ============================================================ */
.site-header{position:sticky;top:0;z-index:50}

.tribe-bar{background:var(--char);color:var(--clay)}
.tribe-bar__inner{display:flex;align-items:center;justify-content:space-between;
  height:36px;font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.tribe-bar__note{color:rgba(232,213,196,.6)}
.tribe-bar__nav{display:flex;align-items:center;gap:4px}
.tribe-bar__label{color:rgba(232,213,196,.45);margin-right:8px}
.tribe-bar__nav a{font-weight:600;padding:6px;color:var(--clay);transition:color .2s}
.tribe-bar__nav a:hover{color:var(--gold)}
.tribe-bar__perks{color:var(--gold)!important}
.tribe-bar__perks:hover{color:#E0B589!important}
.tribe-bar .dot{color:rgba(232,213,196,.25)}
@media(max-width:640px){
  .tribe-bar__note,.tribe-bar__label{display:none}
  .tribe-bar__inner{justify-content:center}
}

/* MAIN NAV — opaque bone background */
.nav{background:var(--bone);border-bottom:1px solid var(--line);transition:box-shadow .3s}
.nav.scrolled{box-shadow:0 4px 24px rgba(26,20,16,.07)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:72px}

.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;
  cursor:pointer;padding:6px}
.nav__burger span{width:22px;height:2px;background:var(--char);display:block}

.brand{display:flex;flex-direction:column}
.brand__name{font-family:var(--serif);font-weight:600;font-size:24px;
  letter-spacing:-.01em;color:var(--char);line-height:1}
.brand__name em{font-style:italic;color:var(--terra)}
.brand__name--light{color:var(--bone)}
.brand__name--light em{color:var(--gold)}
.brand__tag{font-size:9px;letter-spacing:.38em;text-transform:uppercase;
  color:var(--terra);margin-top:3px}

.nav__links{display:flex;gap:28px}
.nav__links a{font-size:13px;font-weight:500;color:var(--char);padding:8px 0;
  position:relative}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--terra);transition:width .3s}
.nav__links a:hover{color:var(--terra)}
.nav__links a:hover::after{width:100%}

.nav__actions{display:flex;align-items:center;gap:10px}
.icon-btn{position:relative;padding:8px;color:var(--char);display:flex;
  background:none;border:none;cursor:pointer;-webkit-appearance:none;appearance:none;
  font:inherit;transition:color .2s}
.icon-btn:hover{color:var(--terra)}
.badge{position:absolute;top:2px;right:2px;background:var(--terra);color:#fff;
  font-size:9px;font-weight:600;width:16px;height:16px;border-radius:50%;
  display:flex;align-items:center;justify-content:center}

.currency-select{font-family:var(--sans);font-size:12px;font-weight:500;
  background:var(--bone);color:var(--char);border:1px solid rgba(26,20,16,.2);
  border-radius:99px;padding:6px 26px 6px 12px;cursor:pointer;
  -webkit-appearance:none;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231A1410' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 8px center}
.currency-select:hover{border-color:var(--terra)}

@media(max-width:980px){
  .nav__links{display:none}
  .nav__burger{display:flex}
  .brand{align-items:center}
}

/* ---------- MOBILE DRAWER (fully opaque) ---------- */
.drawer{position:fixed;inset:0;z-index:60;visibility:hidden}
.drawer.open{visibility:visible}
.drawer__overlay{position:absolute;inset:0;background:rgba(26,20,16,.55);
  opacity:0;transition:opacity .3s}
.drawer.open .drawer__overlay{opacity:1}
.drawer__panel{position:absolute;left:0;top:0;bottom:0;width:84%;max-width:340px;
  background:var(--bone);box-shadow:8px 0 40px rgba(0,0,0,.2);
  transform:translateX(-100%);transition:transform .3s;overflow-y:auto}
.drawer.open .drawer__panel{transform:translateX(0)}
.drawer__head{display:flex;align-items:center;justify-content:space-between;
  height:72px;padding:0 24px;border-bottom:1px solid var(--line)}
.drawer__title{font-family:var(--serif);font-weight:600;font-size:22px}
.drawer__close{background:none;border:none;cursor:pointer;color:var(--char);padding:6px}
.drawer__nav{display:flex;flex-direction:column;padding:24px}
.drawer__nav a{font-size:15px;font-weight:500;color:var(--char);
  padding:14px 0;border-bottom:1px solid var(--line)}
.drawer__group{font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--terra);font-weight:600;margin:24px 0 4px;font-family:var(--sans)}
.drawer__group+a{border-top:none}

/* ============================================================
   HERO — image-driven
   ============================================================ */
.hero{background:var(--char)}
.hero__inner{max-width:var(--max);margin:0 auto;display:grid;
  grid-template-columns:5fr 7fr}
.hero__copy{display:flex;align-items:center;padding:96px 40px}
.hero__kicker{display:inline-block;color:var(--gold);font-size:11px;
  letter-spacing:.4em;text-transform:uppercase;margin-bottom:24px}
.hero__title{color:var(--bone);font-size:clamp(2.8rem,6vw,4.8rem);
  line-height:.95;margin-bottom:24px}
.hero__title em{font-style:italic;color:var(--gold)}
.hero__text{color:rgba(232,213,196,.75);max-width:420px;font-size:15px;
  margin-bottom:36px}
.hero__cta{display:flex;gap:16px;flex-wrap:wrap}
.hero__grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:6px}
.hero__grid figure{overflow:hidden;background:var(--clay)}
.hero__grid figure:first-child{grid-row:span 2}
.hero__grid img{width:100%;height:100%;object-fit:cover;
  transition:transform .8s}
.hero__grid figure:hover img{transform:scale(1.05)}
.hero__grid figure:first-child img{min-height:480px}
.hero__grid figure:not(:first-child) img{min-height:237px}

@media(max-width:980px){
  .hero__inner{grid-template-columns:1fr}
  .hero__copy{padding:56px 24px}
  .hero__grid figure:first-child img{min-height:300px}
  .hero__grid figure:not(:first-child) img{min-height:180px}
}

/* ---------- MARQUEE ---------- */
.marquee{background:var(--terra);color:var(--bone);padding:13px 0;overflow:hidden}
.marquee__track{display:flex;gap:48px;white-space:nowrap;
  animation:marquee 30s linear infinite;width:max-content}
.marquee span{font-size:11px;letter-spacing:.3em;text-transform:uppercase;
  display:flex;align-items:center;gap:48px}
.marquee b{color:var(--clay)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-33.33%)}}

/* ---------- SECTION HEADING ---------- */
.section{max-width:var(--max);margin:0 auto;padding:80px 32px}
@media(max-width:640px){.section{padding:56px 18px}}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;
  flex-wrap:wrap;gap:16px;margin-bottom:36px}
.sec-head__kicker{font-size:11px;letter-spacing:.35em;text-transform:uppercase;
  color:var(--terra);font-weight:500}
.sec-head h2{font-size:clamp(1.9rem,3.5vw,2.8rem);margin-top:8px}
.sec-head__link{display:flex;align-items:center;gap:8px;font-size:12px;
  font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--char)}
.sec-head__link:hover{color:var(--terra)}

/* ---------- PRODUCT GRID ---------- */
.grid-products{display:grid;grid-template-columns:repeat(4,1fr);
  gap:20px 20px}
@media(max-width:980px){.grid-products{grid-template-columns:repeat(2,1fr)}}

.card{cursor:pointer}
.card__media{position:relative;aspect-ratio:3/4;overflow:hidden;
  background:var(--clay)}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.card:hover .card__media img{transform:scale(1.05)}
.card__wish{position:absolute;top:12px;right:12px;width:36px;height:36px;
  border-radius:50%;background:rgba(251,248,243,.95);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 8px rgba(0,0,0,.08);transition:background .2s}
.card__wish:hover{background:#fff}
.card__wish svg{stroke:var(--char)}
.card__wish.active svg{fill:var(--terra);stroke:var(--terra)}
.card__tag{position:absolute;top:12px;left:12px;font-size:10px;font-weight:500;
  letter-spacing:.06em;text-transform:uppercase;background:var(--char);
  color:var(--gold);padding:4px 10px}
.card__add{position:absolute;left:0;right:0;bottom:0;background:var(--char);
  color:var(--bone);border:none;cursor:pointer;padding:14px;font-size:12px;
  font-weight:500;letter-spacing:.18em;text-transform:uppercase;
  transform:translateY(100%);transition:transform .3s,background .2s}
.card:hover .card__add{transform:translateY(0)}
.card__add:hover{background:var(--terra)}
.card__info{padding-top:14px}
.card__row{display:flex;justify-content:space-between;gap:8px;align-items:flex-start}
.card__name{font-family:var(--serif);font-weight:600;font-size:16px;
  letter-spacing:.01em}
.card__price{font-size:14px;font-weight:500;color:var(--terra);white-space:nowrap}
.card__meta{display:flex;justify-content:space-between;margin-top:4px;
  font-size:11px;text-transform:uppercase;letter-spacing:.04em;
  color:rgba(26,20,16,.45)}
.card__rating{display:flex;align-items:center;gap:3px}
.card__swatches{display:flex;gap:7px;margin-top:9px}
.card__swatches span{position:relative;width:15px;height:15px;border-radius:50%;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.14);cursor:pointer;
  transition:transform .25s cubic-bezier(.16,1,.3,1)}
.card__swatches span:hover{transform:scale(1.2)}
.card__swatches span::before{content:attr(data-name);position:absolute;
  bottom:calc(100% + 7px);left:50%;transform:translateX(-50%) translateY(3px);
  background:var(--char);color:var(--bone);font-size:9px;font-weight:500;
  letter-spacing:.06em;text-transform:uppercase;padding:4px 7px;border-radius:3px;
  white-space:nowrap;opacity:0;pointer-events:none;z-index:6;
  transition:opacity .18s ease,transform .18s cubic-bezier(.16,1,.3,1)}
.card__swatches span:hover::before{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---------- HOUSES SPLIT ---------- */
.houses{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:768px){.houses{grid-template-columns:1fr}}
.house{position:relative;height:380px;overflow:hidden;display:block}
.house img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.house:hover img{transform:scale(1.05)}
.house__veil{position:absolute;inset:0;
  background:linear-gradient(to top,rgba(26,20,16,.85),rgba(26,20,16,.15),transparent)}
.house__body{position:absolute;left:0;bottom:0;padding:32px}
.house__kicker{color:var(--gold);font-size:11px;letter-spacing:.35em;
  text-transform:uppercase;font-weight:500}
.house__name{color:var(--bone);font-size:2.6rem;margin-top:4px}
.house__go{display:inline-flex;align-items:center;gap:8px;color:var(--bone);
  font-size:12px;font-weight:500;letter-spacing:.15em;text-transform:uppercase;
  margin-top:8px}

/* ---------- STORY BAND ---------- */
.story{background:var(--char)}
.story__inner{max-width:var(--max);margin:0 auto;display:grid;
  grid-template-columns:1fr 1fr}
.story__img{min-height:480px;overflow:hidden;background:var(--clay)}
.story__img img{width:100%;height:100%;object-fit:cover}
.story__copy{display:flex;align-items:center;padding:64px 56px}
.story__kicker{color:var(--gold);font-size:11px;letter-spacing:.4em;
  text-transform:uppercase;font-weight:500}
.story__quote{color:var(--bone);font-family:var(--serif);font-weight:400;
  font-size:clamp(1.5rem,2.6vw,2.1rem);line-height:1.45;margin:20px 0 32px}
@media(max-width:768px){
  .story__inner{grid-template-columns:1fr}
  .story__img{min-height:300px}
  .story__copy{padding:48px 24px}
}

/* ---------- TRUST ---------- */
.trust{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
@media(max-width:768px){.trust{grid-template-columns:1fr}}
.trust__item{display:flex;gap:16px}
.trust__icon{width:48px;height:48px;border-radius:50%;flex-shrink:0;
  background:rgba(156,91,61,.12);display:flex;align-items:center;
  justify-content:center;color:var(--terra)}
.trust__item h4{font-family:var(--sans);font-weight:600;font-size:15px}
.trust__item p{font-size:13px;color:rgba(26,20,16,.55);margin-top:4px}

/* ---------- NEWSLETTER ---------- */
.newsletter{background:var(--clay);padding:80px 0;text-align:center}
.newsletter__kicker{color:var(--terra);font-size:11px;letter-spacing:.4em;
  text-transform:uppercase;font-weight:500}
.newsletter h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin:12px 0}
.newsletter p{color:rgba(26,20,16,.65);font-size:14px;margin-bottom:28px}
.newsletter__form{display:flex;gap:12px;max-width:440px;margin:0 auto}
.newsletter__form input{flex:1;background:var(--bone);
  border:1px solid var(--line);padding:14px 20px;font-size:14px;
  font-family:var(--sans);color:var(--char)}
.newsletter__form input:focus{outline:none;border-color:var(--terra)}
@media(max-width:560px){.newsletter__form{flex-direction:column}}

/* ============================================================
   SHOP / FILTERS
   ============================================================ */
.crumb{font-size:12px;color:rgba(26,20,16,.45);margin-bottom:16px}
.crumb a:hover{color:var(--terra)}
.page-head h1{font-size:clamp(2.2rem,4vw,3.2rem)}
.page-head p{color:rgba(26,20,16,.55);font-size:14px;margin-top:6px}
.filters{display:flex;flex-wrap:wrap;gap:16px;align-items:center;
  justify-content:space-between;margin:32px 0;padding-bottom:24px;
  border-bottom:1px solid var(--line)}
.search-box{position:relative;max-width:300px;width:100%}
.search-box svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);
  color:rgba(26,20,16,.4)}
.search-box input{width:100%;background:var(--bone);
  border:1px solid rgba(26,20,16,.2);border-radius:99px;
  padding:10px 16px 10px 36px;font-size:13px;font-family:var(--sans);
  color:var(--char)}
.search-box input:focus{outline:none;border-color:var(--terra)}
.filters__selects{display:flex;gap:12px;flex-wrap:wrap}
.filters select{font-size:13px;font-family:var(--sans);
  border:1px solid rgba(26,20,16,.2);border-radius:99px;
  padding:10px 30px 10px 16px;background:var(--bone);color:var(--char);
  cursor:pointer;-webkit-appearance:none;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231A1410' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center}
.empty-grid{text-align:center;padding:96px 0;color:rgba(26,20,16,.55)}
.empty-grid p:first-child{font-family:var(--serif);font-size:18px}
.empty-grid p:last-child{font-size:13px;margin-top:8px}

/* ============================================================
   PRODUCT DETAIL
   ============================================================ */
.pdp{display:grid;grid-template-columns:1fr 1fr;gap:64px}
@media(max-width:900px){.pdp{grid-template-columns:1fr;gap:40px}}
.pdp__main{aspect-ratio:4/5;overflow:hidden;background:var(--clay);
  margin-bottom:16px}
.pdp__main img{width:100%;height:100%;object-fit:cover}
.pdp__thumbs{display:flex;gap:12px}
.pdp__thumbs button{width:80px;height:96px;overflow:hidden;border:2px solid transparent;
  background:var(--clay);cursor:pointer;padding:0}
.pdp__thumbs button.active{border-color:var(--terra)}
.pdp__thumbs img{width:100%;height:100%;object-fit:cover}
.pdp__kicker{font-size:11px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--terra);font-weight:500}
.pdp__title{font-size:clamp(2.2rem,4vw,3.2rem);margin:8px 0 12px}
.pdp__rating{display:flex;align-items:center;gap:12px;margin-bottom:20px;
  font-size:13px;color:rgba(26,20,16,.55)}
.stars{display:flex}
.pdp__price{font-family:var(--serif);font-size:28px;font-weight:500;
  color:var(--terra)}
.pdp__tax{font-size:12px;color:rgba(26,20,16,.45);margin-bottom:24px}
.pdp__desc{font-size:14px;color:rgba(26,20,16,.7);margin-bottom:24px}
.pdp__label{font-size:12px;letter-spacing:.15em;text-transform:uppercase;
  color:rgba(26,20,16,.6);font-weight:500;margin-bottom:10px}
.swatches{display:flex;gap:14px;margin-bottom:24px;flex-wrap:wrap}
.swatches button{position:relative;width:38px;height:38px;border-radius:50%;
  border:none;cursor:pointer;padding:0;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.12),0 1px 3px rgba(0,0,0,.12);
  transition:transform .3s cubic-bezier(.16,1,.3,1),
             box-shadow .3s cubic-bezier(.16,1,.3,1)}
.swatches button::after{content:"";position:absolute;inset:-5px;border-radius:50%;
  border:1.5px solid var(--terra);
  opacity:0;transform:scale(.8);
  transition:opacity .25s ease,transform .25s cubic-bezier(.16,1,.3,1)}
.swatches button:hover{transform:scale(1.08);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.12),0 4px 12px rgba(0,0,0,.2)}
.swatches button.active{transform:scale(1.05)}
.swatches button.active::after{opacity:1;transform:scale(1)}
.swatches button::before{content:attr(data-name);position:absolute;
  bottom:calc(100% + 9px);left:50%;transform:translateX(-50%) translateY(4px);
  background:var(--char);color:var(--bone);font-family:var(--sans);
  font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;
  padding:5px 9px;border-radius:3px;white-space:nowrap;
  opacity:0;pointer-events:none;
  transition:opacity .2s ease,transform .2s cubic-bezier(.16,1,.3,1);z-index:5}
.swatches button:hover::before{opacity:1;transform:translateX(-50%) translateY(0)}

.pdp__fit{display:inline-block;border:1px solid rgba(26,20,16,.25);
  padding:8px 16px;font-size:13px;margin-bottom:24px}
.pdp__buy{display:flex;gap:12px;margin-bottom:16px}
.pdp__heart{width:56px;border:1px solid rgba(26,20,16,.25);background:var(--bone);
  cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--char)}
.pdp__heart.active svg{fill:var(--terra);stroke:var(--terra)}
.pdp__sku{font-size:12px;color:rgba(26,20,16,.5);margin-bottom:24px}
.tabs{border-top:1px solid var(--line);padding-top:20px}
.tabs__nav{display:flex;gap:24px;margin-bottom:16px}
.tabs__nav button{background:none;border:none;cursor:pointer;
  font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.12em;
  text-transform:uppercase;padding-bottom:8px;border-bottom:2px solid transparent;
  color:rgba(26,20,16,.4)}
.tabs__nav button.active{color:var(--char);border-color:var(--terra)}
.tabs__body{font-size:13px;color:rgba(26,20,16,.65);line-height:1.7}

/* ============================================================
   CART / CHECKOUT
   ============================================================ */
.narrow{max-width:1100px;margin:0 auto;padding:48px 32px}
@media(max-width:640px){.narrow{padding:32px 18px}}
.cart-layout{display:grid;grid-template-columns:2fr 1fr;gap:40px}
@media(max-width:880px){.cart-layout{grid-template-columns:1fr}}
.cart-item{display:flex;gap:16px;padding-bottom:20px;
  border-bottom:1px solid var(--line);margin-bottom:20px}
.cart-item__img{width:96px;height:128px;flex-shrink:0;overflow:hidden;
  background:var(--clay)}
.cart-item__img img{width:100%;height:100%;object-fit:cover}
.cart-item__body{flex:1}
.cart-item__top{display:flex;justify-content:space-between;gap:8px}
.cart-item__name{font-family:var(--serif);font-weight:600;font-size:16px}
.cart-item__rm{background:none;border:none;cursor:pointer;
  color:rgba(26,20,16,.4)}
.cart-item__rm:hover{color:var(--terra)}
.cart-item__sub{font-size:12px;color:rgba(26,20,16,.5);margin-top:2px}
.cart-item__foot{display:flex;justify-content:space-between;align-items:center;
  margin-top:12px}
.qty{display:flex;align-items:center;border:1px solid rgba(26,20,16,.2);
  border-radius:99px}
.qty button{background:none;border:none;cursor:pointer;padding:6px 12px;
  color:var(--char);display:flex}
.qty span{padding:0 8px;font-size:13px}
.summary{background:rgba(232,213,196,.45);border:1px solid var(--line);
  padding:24px;height:fit-content}
.summary h3{font-family:var(--serif);font-weight:600;font-size:18px;
  margin-bottom:20px}
.promo{display:flex;gap:8px;margin-bottom:20px}
.promo input{flex:1;background:var(--bone);border:1px solid rgba(26,20,16,.2);
  padding:10px 12px;font-size:13px;font-family:var(--sans);color:var(--char)}
.promo button{background:var(--char);color:var(--bone);border:none;cursor:pointer;
  padding:0 16px;font-size:12px;font-weight:500;letter-spacing:.05em;
  text-transform:uppercase}
.promo button:hover{background:var(--terra)}
.promo-ok{font-size:12px;color:var(--olive);margin-bottom:12px}
.sum-rows{border-top:1px solid var(--line);padding-top:16px;
  display:flex;flex-direction:column;gap:10px;font-size:13px}
.sum-row{display:flex;justify-content:space-between}
.sum-row span:first-child{color:rgba(26,20,16,.6)}
.sum-row--total{border-top:1px solid var(--line);padding-top:12px;
  margin-top:2px}
.sum-row--total span:first-child{font-weight:600;font-size:15px;color:var(--char)}
.sum-row--total span:last-child{font-weight:600;font-size:16px;color:var(--terra)}
.summary .btn{margin-top:20px}
.summary__hint{font-size:11px;color:rgba(26,20,16,.45);text-align:center;
  margin-top:12px}

/* checkout */
.steps{display:flex;gap:20px;margin:8px 0 32px;font-size:12px;font-weight:500;
  letter-spacing:.08em;text-transform:uppercase}
.step{display:flex;align-items:center;gap:8px;color:rgba(26,20,16,.35)}
.step.active{color:var(--terra)}
.step__num{width:20px;height:20px;border-radius:50%;display:flex;
  align-items:center;justify-content:center;font-size:10px;
  background:rgba(26,20,16,.12);color:rgba(26,20,16,.5)}
.step.active .step__num{background:var(--terra);color:#fff}
.field{margin-bottom:18px}
.field label{font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(26,20,16,.55);font-weight:500}
.field input,.field textarea{width:100%;background:var(--bone);
  border:1px solid rgba(26,20,16,.2);padding:12px 16px;margin-top:6px;
  font-size:14px;font-family:var(--sans);color:var(--char)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--terra)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field-row--3{grid-template-columns:1fr 1fr 1fr}
@media(max-width:560px){.field-row,.field-row--3{grid-template-columns:1fr}}
.pay-opt{display:flex;align-items:center;gap:12px;border:1px solid rgba(26,20,16,.2);
  padding:14px 16px;font-size:14px;cursor:pointer;margin-bottom:12px;
  background:var(--bone);width:100%;text-align:left;color:rgba(26,20,16,.7)}
.pay-opt.active{border-color:var(--terra);background:rgba(156,91,61,.08);
  color:var(--char)}
.pay-opt__dot{width:16px;height:16px;border-radius:50%;
  border:2px solid rgba(26,20,16,.3)}
.pay-opt.active .pay-opt__dot{border-color:var(--terra);background:var(--terra)}

/* confirmation */
.confirm{max-width:640px;margin:0 auto;padding:96px 24px;text-align:center}
.confirm__check{width:64px;height:64px;border-radius:50%;background:var(--olive);
  display:flex;align-items:center;justify-content:center;margin:0 auto 24px;
  color:#fff}
.confirm h1{font-size:2.4rem;margin-bottom:12px}
.confirm p{color:rgba(26,20,16,.65);font-size:14px;margin-bottom:8px}
.confirm__cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;
  margin-top:24px}

/* ---------- EMPTY STATE ---------- */
.empty{max-width:480px;margin:0 auto;padding:112px 24px;text-align:center}
.empty__icon{width:64px;height:64px;border-radius:50%;background:var(--clay);
  display:flex;align-items:center;justify-content:center;margin:0 auto 24px;
  color:var(--terra)}
.empty h1{font-size:1.9rem;margin-bottom:8px}
.empty p{color:rgba(26,20,16,.55);font-size:14px;margin-bottom:28px}

/* ============================================================
   ACCOUNT / TRACKING / FAQ / BLOG / ABOUT
   ============================================================ */
.account{display:grid;grid-template-columns:1fr 3fr;gap:32px}
@media(max-width:768px){.account{grid-template-columns:1fr}}
.account__nav{display:flex;flex-direction:column;gap:4px}
.account__nav button{text-align:left;padding:12px 16px;font-size:13px;
  font-weight:500;font-family:var(--sans);background:none;border:none;
  cursor:pointer;color:var(--char)}
.account__nav button.active{background:var(--terra);color:#fff}
.account__nav button:not(.active):hover{background:rgba(232,213,196,.55)}
.order-row{border:1px solid var(--line);padding:20px;display:flex;
  justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
  margin-bottom:16px}
.order-row__id{font-weight:600;font-size:15px}
.order-row__item{font-size:13px;color:rgba(26,20,16,.55)}
.pill{font-size:11px;font-weight:500;letter-spacing:.05em;text-transform:uppercase;
  padding:4px 12px}
.pill--ok{background:rgba(61,90,69,.12);color:var(--olive)}
.pill--transit{background:rgba(201,166,107,.25);color:var(--terra)}
.stub{border:1px dashed rgba(26,20,16,.25);padding:40px;text-align:center}
.stub h3{font-family:var(--serif);font-weight:600;font-size:18px;margin-bottom:8px}
.stub p{font-size:13px;color:rgba(26,20,16,.55)}

.track-step{display:flex;gap:16px}
.track-step__col{display:flex;flex-direction:column;align-items:center}
.track-step__dot{width:32px;height:32px;border-radius:50%;display:flex;
  align-items:center;justify-content:center;font-size:12px;font-weight:500;
  background:rgba(26,20,16,.12);color:rgba(26,20,16,.45)}
.track-step__dot.done{background:var(--terra);color:#fff}
.track-step__line{width:1px;height:48px;background:rgba(26,20,16,.15)}
.track-step__line.done{background:var(--terra)}
.track-step__label{font-size:15px;color:rgba(26,20,16,.4);padding-top:4px}
.track-step__label.done{color:var(--char);font-weight:600}
.track-step__sub{font-size:12px;color:var(--terra);margin-top:2px}

.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;
  background:none;border:none;cursor:pointer;padding:20px 0;text-align:left;
  font-size:15px;font-weight:500;font-family:var(--sans);color:var(--char)}
.faq-q svg{flex-shrink:0;color:var(--terra);transition:transform .2s}
.faq-item.open .faq-q svg{transform:rotate(45deg)}
.faq-a{font-size:14px;color:rgba(26,20,16,.65);line-height:1.7;
  max-height:0;overflow:hidden;transition:max-height .3s,padding .3s}
.faq-item.open .faq-a{max-height:240px;padding-bottom:20px}

.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:768px){.blog-grid{grid-template-columns:1fr}}
.blog-card img{aspect-ratio:4/3;object-fit:cover;width:100%;
  transition:transform .7s}
.blog-card:hover img{transform:scale(1.03)}
.blog-card__tag{font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--terra);font-weight:500;display:block;margin:12px 0 6px}
.blog-card h3{font-size:19px;font-weight:600}
.blog-card:hover h3{color:var(--terra)}
.blog-card p{font-size:13px;color:rgba(26,20,16,.55);margin-top:6px}

.about-hero{position:relative;height:420px}
.about-hero img{width:100%;height:100%;object-fit:cover}
.about-hero__veil{position:absolute;inset:0;background:rgba(26,20,16,.6)}
.about-hero__body{position:absolute;inset:0;display:flex;align-items:center;
  justify-content:center;text-align:center;padding:24px}
.about-hero__body h1{color:var(--bone);font-size:clamp(2.4rem,5vw,3.6rem);
  margin-top:16px}
.about-hero__body h1 em{font-style:italic;color:var(--gold)}
.about-hero__kicker{color:var(--gold);font-size:11px;letter-spacing:.4em;
  text-transform:uppercase;font-weight:500}
.prose{max-width:760px;margin:0 auto;padding:64px 24px}
.prose p{font-size:15px;color:rgba(26,20,16,.7);line-height:1.85;
  margin-bottom:24px}
.stats{max-width:1100px;margin:0 auto;padding:0 24px 80px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;text-align:center}
@media(max-width:560px){.stats{grid-template-columns:1fr}}
.stat{border:1px solid var(--line);padding:40px 16px}
.stat b{font-family:var(--serif);font-weight:500;font-size:3rem;color:var(--terra);
  display:block}
.stat span{font-size:12px;letter-spacing:.15em;text-transform:uppercase;
  color:rgba(26,20,16,.55);font-weight:500}

/* perks */
.perks-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  margin:0 0 40px}
@media(max-width:640px){.perks-grid{grid-template-columns:1fr}}
.perk{border:1px solid var(--line);padding:24px}
.perk h3{font-family:var(--serif);font-weight:600;font-size:16px;margin-bottom:6px}
.perk p{font-size:13px;color:rgba(26,20,16,.55)}

/* ---------- FOOTER ---------- */
.footer{background:var(--char);color:var(--clay);padding:64px 0 32px}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:40px;
  padding-bottom:48px}
@media(max-width:880px){.footer__grid{grid-template-columns:1fr 1fr}}
.footer__brand p{font-size:13px;color:rgba(232,213,196,.55);margin-top:12px;
  line-height:1.6}
.footer__ig{display:inline-flex;align-items:center;gap:8px;margin-top:16px;
  font-size:12px;color:var(--gold)}
.footer__ig:hover{color:#E0B589}
.footer__col h4{font-family:var(--sans);font-weight:600;font-size:11px;
  letter-spacing:.25em;text-transform:uppercase;color:var(--gold);
  margin-bottom:16px}
.footer__col a{display:block;font-size:13px;color:rgba(232,213,196,.65);
  padding:5px 0}
.footer__col a:hover{color:var(--bone)}
.footer__bar{border-top:1px solid rgba(232,213,196,.12);padding-top:24px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:12px;color:rgba(232,213,196,.45)}

/* ---------- ANIMATIONS ---------- */
@keyframes rise{from{opacity:0;transform:translateY(24px)}
  to{opacity:1;transform:translateY(0)}}
.rise{animation:rise .7s cubic-bezier(.16,1,.3,1) both}
.rise-2{animation-delay:.08s}
.rise-3{animation-delay:.16s}
.rise-4{animation-delay:.24s}

/* image fade-in on load */
.lazy-img{background:var(--clay)}
.lazy-img img{opacity:0;transition:opacity .5s}
.lazy-img img.loaded{opacity:1}

/* ---------- TOAST ---------- */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--char);color:var(--bone);padding:14px 24px;font-size:13px;
  letter-spacing:.05em;opacity:0;pointer-events:none;transition:.3s;z-index:200;
  display:flex;align-items:center;gap:10px}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ============================================================
   CART DRAWER (slide-in)
   ============================================================ */
.cart-drawer{position:fixed;inset:0;z-index:70;visibility:hidden}
.cart-drawer.open{visibility:visible}
.cart-drawer__overlay{position:absolute;inset:0;background:rgba(26,20,16,.55);
  opacity:0;transition:opacity .3s}
.cart-drawer.open .cart-drawer__overlay{opacity:1}
.cart-drawer__panel{position:absolute;right:0;top:0;bottom:0;width:90%;
  max-width:420px;background:var(--bone);display:flex;flex-direction:column;
  box-shadow:-8px 0 40px rgba(0,0,0,.2);
  transform:translateX(100%);transition:transform .35s cubic-bezier(.16,1,.3,1)}
.cart-drawer.open .cart-drawer__panel{transform:translateX(0)}
.cart-drawer__head{display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;border-bottom:1px solid var(--line);flex-shrink:0}
.cart-drawer__title{font-family:var(--serif);font-weight:600;font-size:20px}
.cart-drawer__body{flex:1;overflow-y:auto;padding:20px 24px}
.cart-drawer__foot{flex-shrink:0;border-top:1px solid var(--line);
  padding:20px 24px;background:var(--bone)}

.cd-item{display:flex;gap:14px;padding-bottom:18px;margin-bottom:18px;
  border-bottom:1px solid var(--line)}
.cd-item:last-child{border-bottom:none;margin-bottom:0}
.cd-item__img{width:78px;height:104px;flex-shrink:0;overflow:hidden;
  background:var(--clay)}
.cd-item__img img{width:100%;height:100%;object-fit:cover}
.cd-item__body{flex:1;min-width:0}
.cd-item__top{display:flex;justify-content:space-between;gap:8px}
.cd-item__name{font-family:var(--serif);font-weight:600;font-size:16px}
.cd-item__rm{background:none;border:none;cursor:pointer;color:rgba(26,20,16,.4);
  flex-shrink:0;padding:2px}
.cd-item__rm:hover{color:var(--terra)}
.cd-item__opts{font-size:12px;color:rgba(26,20,16,.55);margin-top:3px;
  display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.cd-item__sw{width:11px;height:11px;border-radius:50%;
  border:1px solid rgba(0,0,0,.2);display:inline-block}
.cd-item__foot{display:flex;justify-content:space-between;align-items:center;
  margin-top:10px}
.cd-item__price{font-size:14px;font-weight:500;color:var(--terra)}
.cd-empty{text-align:center;padding:48px 0;color:rgba(26,20,16,.55)}
.cd-empty svg{margin:0 auto 16px;color:var(--terra)}
.cd-empty p:first-of-type{font-family:var(--serif);font-size:18px;color:var(--char)}
.cd-empty p:last-of-type{font-size:13px;margin-top:6px}
.cd-sum{display:flex;justify-content:space-between;font-size:14px;
  margin-bottom:6px}
.cd-sum--total{font-size:16px;font-weight:600;color:var(--char);
  padding-top:10px;margin-top:6px;border-top:1px solid var(--line)}
.cd-sum--total span:last-child{color:var(--terra)}
.cd-note{font-size:11px;color:rgba(26,20,16,.5);text-align:center;
  margin:10px 0 0}
.cart-drawer__foot .btn{margin-top:14px}

/* ============================================================
   SIZE SELECTOR (product detail)
   ============================================================ */
.sizes{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.sizes button{min-width:64px;padding:10px 14px;border:1px solid rgba(26,20,16,.25);
  background:var(--bone);cursor:pointer;font-family:var(--sans);font-size:13px;
  color:var(--char);transition:.2s}
.sizes button:hover{border-color:var(--terra)}
.sizes button.active{border-color:var(--terra);background:var(--char);
  color:var(--bone)}
.select-hint{font-size:12px;color:#9C5B3D;margin:4px 0 18px;min-height:16px}
.select-hint.ok{color:var(--olive)}

/* quick-add modal for choosing variant from grid */
.qa-modal{position:fixed;inset:0;z-index:80;visibility:hidden;
  display:flex;align-items:center;justify-content:center;padding:20px}
.qa-modal.open{visibility:visible}
.qa-modal__overlay{position:absolute;inset:0;background:rgba(26,20,16,.55);
  opacity:0;transition:opacity .3s}
.qa-modal.open .qa-modal__overlay{opacity:1}
.qa-modal__box{position:relative;background:var(--bone);max-width:420px;width:100%;
  padding:28px;transform:scale(.95);opacity:0;
  transition:transform .25s,opacity .25s;max-height:90vh;overflow-y:auto}
.qa-modal.open .qa-modal__box{transform:scale(1);opacity:1}
.qa-modal__close{position:absolute;top:14px;right:14px;background:none;
  border:none;cursor:pointer;color:var(--char)}
.qa-modal__head{display:flex;gap:14px;margin-bottom:20px}
.qa-modal__img{width:72px;height:96px;object-fit:cover;background:var(--clay);
  flex-shrink:0}
.qa-modal__name{font-family:var(--serif);font-weight:600;font-size:18px}
.qa-modal__price{color:var(--terra);font-size:14px;margin-top:2px}

/* ============================================================
   SHOP + PRODUCT DETAIL  (Stage 3)
   ============================================================ */

/* breadcrumb */
.crumb{font-size:12px;letter-spacing:.04em;color:rgba(26,20,16,.5);
  margin-bottom:24px}
.crumb a{color:rgba(26,20,16,.5);transition:color .2s}
.crumb a:hover{color:var(--terra)}
.crumb span{margin:0 6px}

/* page head */
.page-head{display:flex;align-items:baseline;gap:16px;flex-wrap:wrap;
  margin-bottom:28px}
.page-head h1{font-family:var(--serif);font-weight:500;
  font-size:clamp(2rem,4vw,2.9rem)}
.page-head p{font-size:13px;color:rgba(26,20,16,.5);letter-spacing:.03em}

/* filter bar */
.filters{display:flex;gap:24px;flex-wrap:wrap;align-items:flex-end;
  padding-bottom:28px;margin-bottom:36px;border-bottom:1px solid var(--line)}
.filters__group{display:flex;flex-direction:column;gap:6px}
.filters__group label{font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(26,20,16,.45);font-weight:500}
.filters select{font-family:var(--sans);font-size:13px;color:var(--char);
  background:var(--bone);border:1px solid var(--line);border-radius:2px;
  padding:9px 30px 9px 12px;cursor:pointer;min-width:170px;
  -webkit-appearance:none;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231A1410' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center}
.filters select:hover{border-color:var(--terra)}

.empty-grid{padding:64px 0;text-align:center;font-size:14px;
  color:rgba(26,20,16,.5)}

/* ---------- PRODUCT DETAIL ---------- */
.pdp__grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;
  align-items:start}
@media(max-width:860px){.pdp__grid{grid-template-columns:1fr;gap:32px}}

.pdp__main{aspect-ratio:4/5;overflow:hidden;background:var(--clay);
  border-radius:2px}
.pdp__main img{width:100%;height:100%;object-fit:cover}
.pdp__thumbs{display:flex;gap:10px;margin-top:10px}
.pdp__thumb{width:72px;height:90px;padding:0;border:1px solid var(--line);
  background:var(--clay);cursor:pointer;overflow:hidden;border-radius:2px;
  transition:border-color .2s}
.pdp__thumb img{width:100%;height:100%;object-fit:cover}
.pdp__thumb.active{border-color:var(--char)}
.pdp__thumb:hover{border-color:var(--terra)}

.pdp__house{font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--terra);font-weight:500;margin-bottom:8px}
.pdp__name{font-family:var(--serif);font-weight:500;
  font-size:clamp(1.9rem,3.5vw,2.6rem);line-height:1.1;margin-bottom:12px}
.pdp__rating{display:flex;align-items:center;gap:8px;font-size:12px;
  color:rgba(26,20,16,.55);margin-bottom:16px}
.pdp__stars{color:var(--gold);letter-spacing:2px;font-size:14px}
.pdp__price{font-family:var(--serif);font-size:1.7rem;color:var(--terra);
  margin-bottom:20px}
.pdp__desc{font-size:14px;line-height:1.75;color:rgba(26,20,16,.7);
  margin-bottom:16px}
.pdp__length{font-size:13px;color:rgba(26,20,16,.6);margin-bottom:24px}

.pdp__option{margin-bottom:22px}
.pdp__option-label{font-size:12px;letter-spacing:.06em;text-transform:uppercase;
  color:rgba(26,20,16,.55);font-weight:500;margin-bottom:10px}
.pdp__option-label span{color:var(--char);font-weight:600}

/* size buttons */
.sizes{display:flex;gap:10px;flex-wrap:wrap}
.size-btn{min-width:52px;padding:11px 14px;font-family:var(--sans);font-size:13px;
  font-weight:500;color:var(--char);background:var(--bone);
  border:1px solid var(--line);border-radius:2px;cursor:pointer;
  transition:border-color .2s,background .2s,color .2s}
.size-btn:hover:not(:disabled){border-color:var(--terra)}
.size-btn.active{background:var(--char);color:var(--bone);border-color:var(--char)}
.size-btn--out{opacity:.35;cursor:not-allowed;text-decoration:line-through}

.pdp__stockNote{font-size:12.5px;color:var(--terra);min-height:18px;
  margin-bottom:16px}

.pdp__actions{display:flex;gap:12px;margin-bottom:18px}
.pdp__actions .btn{flex:1}
.pdp__wish{width:52px;flex-shrink:0;display:flex;align-items:center;
  justify-content:center;background:var(--bone);border:1px solid var(--line);
  border-radius:2px;cursor:pointer;color:var(--char);transition:.2s}
.pdp__wish:hover{border-color:var(--terra);color:var(--terra)}
.pdp__wish.active{background:var(--terra);border-color:var(--terra);color:#fff}
.pdp__wish.active svg{fill:currentColor}

.pdp__sku{font-size:11px;letter-spacing:.08em;color:rgba(26,20,16,.4)}

/* not-found / empty */
.empty-state{text-align:center;padding:80px 20px}
.empty-state h1{font-family:var(--serif);font-weight:500;font-size:2rem;
  margin-bottom:10px}
.empty-state p{font-size:14px;color:rgba(26,20,16,.55);margin-bottom:24px}