/* ── RESET & VARS ────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--black:#000;--white:#fff;--beige:#E6D5B8;--beige-light:#F7F2EA;--beige-dark:#C9B89A;--gray:#888;--gray-light:#EBEBEB;--font-ui:'Montserrat',sans-serif;--font-display:'Playfair Display',serif;--ease:cubic-bezier(.16,1,.3,1)}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-ui);
  background:var(--white);
  color:var(--black);
  overflow-x:hidden;
  cursor:auto;
  padding-top:84px; /* pushes content below fixed header */
}
a{text-decoration:none;cursor:pointer}
img{max-width:100%;display:block}
.section{padding:7rem 8rem}.section-dark{background:var(--black)}.section-beige{background:var(--beige-light)}

/* ── CURSOR ── */
.cursor{position:fixed;width:10px;height:10px;background:var(--black);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s,height .3s}
.cursor-ring{position:fixed;width:36px;height:36px;border:1px solid rgba(0,0,0,.4);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:all .2s ease}
body.ch .cursor{width:6px;height:6px}
body.ch .cursor-ring{width:54px;height:54px;border-color:var(--beige-dark)}

/* ── PRELOADER ── */
.preloader{position:fixed;inset:0;background:var(--black);z-index:9000;display:flex;align-items:center;justify-content:center;flex-direction:column;transition:opacity .9s var(--ease),visibility .9s}
.preloader.gone{opacity:0;visibility:hidden;pointer-events:none}
.pl-logo{font-weight:900;font-size:clamp(2rem,6vw,4rem);letter-spacing:.3em;color:var(--white);overflow:hidden}
.pl-logo span{display:inline-block;animation:slideUp .8s var(--ease) .3s both}
.pl-sub{font-size:.6rem;letter-spacing:.4em;color:var(--beige);margin-top:.5rem;opacity:0;animation:fadeIn .6s ease .9s both}
.pl-bar{position:fixed;bottom:0;left:0;height:2px;background:var(--beige);animation:loadBar 1.8s var(--ease) .2s both}
@keyframes loadBar{from{width:0}to{width:100%}}
@keyframes slideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ── ANNOUNCEMENT ── */
.ann{background:var(--black);color:var(--beige);text-align:center;padding:.45rem 1rem;font-size:.6rem;letter-spacing:.25em;font-weight:500}

/* ── HEADER ── */
header{position:fixed;top:0;left:0;right:0;z-index:9999}
.hdr{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 4rem;background:rgba(255,255,255,.97);backdrop-filter:blur(14px);border-bottom:1px solid var(--gray-light);transition:padding .3s}
header.scrolled .hdr{padding:.8rem 4rem;box-shadow:0 2px 30px rgba(0,0,0,.06)}
.logo{font-weight:900;font-size:1.1rem;letter-spacing:.2em;color:var(--black)}
.logo span{color:var(--beige-dark)}
nav{display:flex;gap:2.5rem;align-items:center}
nav a{font-size:.62rem;letter-spacing:.18em;font-weight:600;color:var(--black);transition:color .2s;position:relative;padding-bottom:.2rem}
nav a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--beige-dark);transition:width .3s var(--ease)}
nav a:hover::after,nav a.active::after{width:100%}
.has-dd{position:relative}
.dd{position:absolute;top:calc(100% + .8rem);left:0;background:var(--white);border:1px solid var(--gray-light);min-width:180px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .25s var(--ease);box-shadow:0 10px 30px rgba(0,0,0,.08)}
.has-dd:hover .dd{opacity:1;visibility:visible;transform:none}
.dd a{display:block;padding:.7rem 1.2rem;font-size:.6rem;letter-spacing:.15em;color:var(--black);transition:background .2s;border-bottom:1px solid var(--gray-light)}
.dd a:last-child{border-bottom:none}
.dd a:hover{background:var(--beige-light)}
.hdr-actions{display:flex;align-items:center;gap:1.5rem}
.icon-btn{background:none;border:none;color:var(--black);cursor:pointer;padding:.2rem;position:relative;display:flex;align-items:center;transition:color .2s}
.icon-btn:hover{color:var(--beige-dark)}
.burger{background:none;border:none;cursor:pointer;display:none;flex-direction:column;gap:4px;padding:.3rem}
.burger span{display:block;width:22px;height:1.5px;background:var(--black);transition:transform .3s,opacity .3s}
.mob-menu{display:none}

/* ── SEARCH OVERLAY ── */
.search-ov{position:fixed;inset:0;background:rgba(255,255,255,.98);backdrop-filter:blur(20px);z-index:2000;opacity:0;visibility:hidden;transition:all .3s var(--ease);display:flex;align-items:center;justify-content:center}
.search-ov.open{opacity:1;visibility:visible}
.search-close-btn{position:absolute;top:2rem;right:3rem;background:none;border:none;font-size:2rem;cursor:pointer;color:var(--gray)}
.search-inner{width:min(680px,90vw)}
.s-label{font-size:.6rem;letter-spacing:.3em;font-weight:700;margin-bottom:1rem;color:var(--gray)}
.search-inp{width:100%;border:none;border-bottom:1.5px solid var(--black);font-size:clamp(1.5rem,4vw,2.5rem);font-family:var(--font-ui);font-weight:700;letter-spacing:.05em;outline:none;padding:.5rem 0;color:var(--black);background:transparent}
.s-results{margin-top:2rem;display:grid;gap:.8rem}
.s-item{display:flex;gap:1rem;align-items:center;padding:.8rem;cursor:pointer;border:1px solid var(--gray-light);transition:background .2s}
.s-item:hover{background:var(--beige-light)}
.s-item img{width:48px;height:60px;object-fit:cover;background:#f5f5f5}
.s-item-info{flex:1}.s-item-name{font-size:.78rem;font-weight:600;margin-bottom:.3rem}.s-item-price{font-size:.72rem;color:var(--gray)}
.s-none{font-size:.75rem;color:var(--gray);letter-spacing:.1em}


/* ── NOTIFICATION ── */
.notif{position:fixed;top:5rem;right:2rem;background:var(--black);color:var(--white);padding:.9rem 1.5rem;font-size:.7rem;letter-spacing:.1em;z-index:3000;transform:translateY(-120%);transition:transform .4s var(--ease);max-width:320px}
.notif.show{transform:none}

/* ── BUTTONS ── */
.btn{display:inline-block;padding:.9rem 2rem;font-family:var(--font-ui);font-size:.62rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;border:none;transition:all .25s var(--ease);cursor:pointer}
.btn-black{background:var(--black);color:var(--white)}.btn-black:hover{background:#222}
.btn-white{background:var(--white);color:var(--black)}.btn-white:hover{background:var(--beige-light)}
.btn-ghost{background:transparent;border:1px solid rgba(255,255,255,.4);color:var(--white)}.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.7)}
.btn-outline{background:transparent;border:1px solid var(--black);color:var(--black)}.btn-outline:hover{background:var(--black);color:var(--white)}
.btn:hover{transform:translateY(-1px)}

/* ── FADE IN ANIMATIONS ── */
.fi{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.fi.vis{opacity:1;transform:none}
.fi-1{transition-delay:.12s}.fi-2{transition-delay:.22s}.fi-3{transition-delay:.32s}

/* ── TYPE ── */
.lbl{font-size:.6rem;letter-spacing:.35em;font-weight:700;text-transform:uppercase;color:var(--gray);margin-bottom:.8rem}
.ttl{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);line-height:1.05}
.ttl em{font-style:italic;font-weight:400}
.sec-div{height:1px;background:var(--gray-light);margin:2rem 0}

/* === HERO (match authentic-complete.html) === */
.hero{
  position: relative;
  height: 100vh;
  min-height: 700px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: #000;
  padding-top: 100px; /* space for fixed header + top bar */
}

.hero-bg{
  position:absolute; inset:0;
  background: linear-gradient(135deg,#080808 0%,#181818 50%,#0a0a0a 100%);
}

.hero-texture{
  position:absolute; inset:0;
  background-image:
    radial-gradient(circle at 20% 50%, rgba(230,213,184,.07) 0%, transparent 60%),
    radial-gradient(circle at 80% 20%, rgba(230,213,184,.04) 0%, transparent 50%);
}

.hero-grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 80px 80px;
}

.hero-content{
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 0 2rem;
  max-width: 960px;
  margin: 0 auto;
}

.hero-eyebrow{
  font-size: .6rem;
  letter-spacing: .5em;
  color: #E6D5B8;
  margin-bottom: 2rem;
  text-transform: uppercase;
}

.hero-ttl{
  font-family: "Playfair Display", serif; /* or your display font */
  font-size: clamp(3.5rem, 10vw, 9rem);
  line-height: .95;
  color: #fff;
  margin: 0;
}

.hero-ttl .line{ display:block; }
.hero-ttl .line.accent{
  color:#E6D5B8;
  font-style: italic;
}

.hero-sub{
  font-size: .65rem;
  letter-spacing: .35em;
  color: rgba(255,255,255,.4);
  margin: 2rem 0 3.5rem;
  text-transform: uppercase;
}

.hero-actions{
  display:flex;
  gap: 1rem;
  justify-content: center;
  align-items: center;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 1rem 2.5rem;
  font-size: .6rem;
  letter-spacing: .35em;
  text-transform: uppercase;
  text-decoration:none;
  border: 1px solid rgba(255,255,255,.2);
}

.btn-primary{
  background:#fff;
  color:#000;
  border-color:#fff;
}

.btn-outline{
  background: transparent;
  color:#fff;
}

.hero-scroll{
  margin-top: 3.5rem;
  font-size: .55rem;
  letter-spacing: .5em;
  color: rgba(255,255,255,.35);
  text-transform: uppercase;
}

.hero-scroll .scroll-line{
  width: 1px;
  height: 50px;
  background: rgba(255,255,255,.2);
  margin: .75rem auto 0;
}

/* Mobile */
@media(max-width:768px){
  .hero{ min-height: 640px; padding-top: 90px; }
  .hero-content{ padding: 0 1.25rem; }
  .hero-actions{ flex-direction: column; }
  .btn{ width: 240px; }
}

/* ── MARQUEE ── */
.marquee-wrap{overflow:hidden;border-top:1px solid var(--gray-light);border-bottom:1px solid var(--gray-light);padding:.8rem 0}
.marquee-track{display:flex;gap:0;animation:marquee 25s linear infinite;width:max-content}
.mq-item{padding:.2rem 2.5rem;font-size:.6rem;letter-spacing:.3em;font-weight:700;color:var(--gray);text-transform:uppercase;border-right:1px solid var(--gray-light)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── PRODUCT CARDS ── */
.pgrid,.pgrid-shop{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.pgrid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}

/* ── HOMEPAGE: CATEGORY BANNERS ─────────────────────────────── */
.home-banners{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.hb{position:relative;display:block;border:1px solid var(--gray-light);overflow:hidden;min-height:320px;background:#f6f6f6}
.hb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.02);transition:transform .8s var(--ease)}
.hb::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.10) 0%,rgba(0,0,0,.55) 100%)}
.hb:hover img{transform:scale(1.08)}
.hb-ov{position:relative;z-index:2;padding:2rem;display:flex;flex-direction:column;justify-content:flex-end;height:100%;color:#fff}
.hb-kicker{font-size:.58rem;letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,.75);margin-bottom:.6rem;font-weight:700}
.hb-title{font-family:var(--font-display);font-size:2.1rem;line-height:1.05}
.hb-sub{margin-top:.6rem;font-size:.78rem;letter-spacing:.12em;color:rgba(255,255,255,.85);text-transform:uppercase}

/* ── HOMEPAGE: PROMO ───────────────────────────────────────── */
.promo{display:grid;grid-template-columns:1.2fr .8fr;gap:2.5rem;align-items:center}
.promo-text{font-size:.9rem;line-height:2;color:rgba(255,255,255,.55);margin:1.2rem 0 2rem}
.promo-ctas{display:flex;gap:1rem;flex-wrap:wrap}
.promo-art{position:relative;border:1px solid #222;background:linear-gradient(135deg,#090909 0%,#141414 55%,#0a0a0a 100%);min-height:340px;display:flex;align-items:center;justify-content:center}
.promo-chip{position:absolute;bottom:1.2rem;right:1.2rem;font-size:.55rem;letter-spacing:.22em;text-transform:uppercase;color:#222;background:var(--beige);padding:.55rem .8rem}

/* ── HOMEPAGE: SEO BLOCK ───────────────────────────────────── */
.seo-block{max-width:1100px;margin:0 auto}
.seo-copy{margin-top:1.5rem;display:grid;gap:1rem}
.seo-copy p{font-size:.92rem;line-height:2;color:#333}
.pcard{cursor:pointer;position:relative}
.pcard-img{position:relative;overflow:hidden;background:#f5f5f5;aspect-ratio:3/4}
.pcard-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.pcard:hover .pcard-img img{transform:scale(1.04)}
.ptag{position:absolute;top:.8rem;left:.8rem;background:var(--black);color:var(--white);font-size:.5rem;letter-spacing:.2em;padding:.3rem .7rem;font-weight:700;z-index:2}
.ptag.gold{background:var(--beige-dark);color:var(--black)}
.pcard-ov{position:absolute;bottom:0;left:0;right:0;padding:1rem;background:linear-gradient(to top,rgba(0,0,0,.6),transparent);opacity:0;transform:translateY(5px);transition:all .3s var(--ease);z-index:3}
.pcard:hover .pcard-ov{opacity:1;transform:none}
.pwish{position:absolute;top:.8rem;right:.8rem;background:rgba(255,255,255,.9);border:none;width:32px;height:32px;border-radius:50%;font-size:.9rem;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .3s;z-index:3}
.pcard:hover .pwish{opacity:1}.pwish.faved{color:red}
.pcard-info{padding:1rem 0 .5rem}
.pcard-name{font-size:.78rem;font-weight:600;letter-spacing:.05em;margin-bottom:.5rem}
.pcard-meta{display:flex;align-items:center;justify-content:space-between}
.pcard-price{font-size:.82rem;font-weight:700}
.cdots{display:flex;gap:.3rem}.cdot{width:12px;height:12px;border-radius:50%;border:1px solid transparent}

/* ── BRAND STORY ── */
.brand-story-grid{display:grid;grid-template-columns:1fr 1fr;gap:8rem;align-items:center;padding:7rem 8rem}
.bs-imgs{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.bs-img{overflow:hidden}.bs-img:nth-child(2){margin-top:3rem}
.bs-img img{width:100%;aspect-ratio:2/3;object-fit:cover;transition:transform .8s var(--ease)}
.bs-img:hover img{transform:scale(1.03)}

/* ── LOOKBOOK STRIP ── */
.lb-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-top:3rem}
.lb-item{position:relative;overflow:hidden;cursor:pointer;aspect-ratio:2/3;display:block}
.lb-item-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.lb-item:hover .lb-item-img img{transform:scale(1.06)}
.lb-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.6),transparent);display:flex;align-items:flex-end;padding:1.2rem;opacity:0;transition:opacity .3s}
.lb-item:hover .lb-ov{opacity:1}
.lb-cap{font-size:.6rem;letter-spacing:.25em;color:var(--white);font-weight:700}

/* ── CUSTOM TEASER ── */
.ct-grid{display:grid;grid-template-columns:1fr 1fr;gap:8rem;align-items:center}
.ct-visual{display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.03);padding:4rem}

/* ── NEWSLETTER ── */
.nl-form{display:flex;max-width:460px;margin:0 auto}
.nl-input{flex:1;padding:1rem 1.2rem;border:1px solid var(--gray-light);font-family:var(--font-ui);font-size:.6rem;letter-spacing:.15em;outline:none;transition:border-color .2s}
.nl-input:focus{border-color:var(--black)}
.nl-btn{padding:1rem 1.5rem;background:var(--black);color:var(--white);border:none;font-family:var(--font-ui);font-size:.6rem;letter-spacing:.2em;font-weight:700;cursor:pointer;transition:background .2s}
.nl-btn:hover{background:#222}

/* ── PAGE HERO ── */
.page-hero{position:relative;height:350px;background:var(--black);display:flex;align-items:flex-end;overflow:hidden;padding:4rem 8rem}
.phero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:60px 60px}
.phero-content{position:relative;z-index:2}
.phero-content h1{font-family:var(--font-display);font-size:clamp(2.5rem,6vw,5rem);color:var(--white);line-height:1}
.breadcrumb{padding:.8rem 8rem;background:var(--beige-light);font-size:.58rem;letter-spacing:.12em;color:var(--gray);display:flex;gap:.5rem;align-items:center}
.breadcrumb a{color:var(--gray);transition:color .2s}.breadcrumb a:hover{color:var(--black)}

/* ── SHOP LAYOUT ── */
.shop-layout{display:grid;grid-template-columns:260px 1fr;gap:3rem;padding:3rem 5rem;min-height:60vh}
.shop-sb{position:sticky;top:140px;height:fit-content}
.fg{margin-bottom:1.5rem}.fg-title{font-size:.6rem;letter-spacing:.25em;font-weight:700;text-transform:uppercase;margin-bottom:.8rem}
.fopt{display:flex;align-items:center;gap:.6rem;margin-bottom:.4rem}
.fopt input[type="checkbox"]{width:14px;height:14px;accent-color:var(--black);cursor:pointer}
.fopt label{font-size:.68rem;letter-spacing:.08em;cursor:pointer;color:var(--gray);transition:color .2s}
.fopt label:hover{color:var(--black)}
.fdiv{height:1px;background:var(--gray-light);margin:1.5rem 0}
.clear-btn{font-size:.58rem;letter-spacing:.12em;color:var(--gray)}.clear-btn:hover{color:var(--black)}
.shop-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--gray-light)}
.res-count{font-size:.62rem;color:var(--gray);letter-spacing:.1em}
.sort-sel{padding:.5rem .8rem;border:1px solid var(--gray-light);font-family:var(--font-ui);font-size:.62rem;background:var(--white);cursor:pointer;outline:none}
.mob-filter-btn{display:none}
.status-filter-btn{padding:.4rem .8rem;font-size:.6rem;letter-spacing:.12em;border:1px solid var(--gray-light);background:var(--white);cursor:pointer;transition:all .2s}
.status-filter-btn.active,.status-filter-btn:hover{background:var(--black);color:var(--white);border-color:var(--black)}

/* ── PRODUCT DETAIL ── */
.pd-layout{display:grid;grid-template-columns:1fr 1fr;gap:5rem;padding:3rem 5rem 5rem}
.gal-main{overflow:hidden;background:#f5f5f5;aspect-ratio:3/4}
.gal-main img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.gal-main:hover img{transform:scale(1.03)}
.gal-thumbs{display:flex;gap:.5rem;margin-top:.5rem;overflow-x:auto}
.gthumb{width:70px;height:88px;object-fit:cover;cursor:pointer;opacity:.5;transition:opacity .2s;border:1px solid transparent;flex-shrink:0;background:#f5f5f5}
.gthumb.active,.gthumb:hover{opacity:1;border-color:var(--black)}
.pd-bc{font-size:.58rem;letter-spacing:.1em;color:var(--gray);margin-bottom:1rem;display:flex;gap:.4rem;flex-wrap:wrap}
.pd-bc a{color:var(--gray);transition:color .2s}.pd-bc a:hover{color:var(--black)}
.pd-cat{font-size:.6rem;letter-spacing:.3em;color:var(--beige-dark);font-weight:700;margin-bottom:.5rem}
.pd-name{font-size:clamp(1.8rem,3vw,2.5rem);font-weight:900;letter-spacing:-.01em;line-height:1.1;margin-bottom:1rem}
.pd-price{font-size:1.5rem;font-weight:900;margin-bottom:.5rem;display:flex;align-items:baseline;gap:.8rem}
.pd-rating{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem}
.stars{color:#C9B89A;font-size:.9rem;letter-spacing:.1em}.rev-count{font-size:.58rem;color:var(--gray);letter-spacing:.1em}
.opt-lbl{font-size:.6rem;letter-spacing:.25em;font-weight:700;text-transform:uppercase;margin-bottom:.8rem;display:flex;justify-content:space-between;align-items:center}
.opt-lbl a{font-size:.58rem;color:var(--gray);text-decoration:underline;letter-spacing:.08em;cursor:pointer}
.clr-opts{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.5rem}
.csw{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .2s}
.csw.sel{transform:scale(1.2);outline:2px solid var(--black);outline-offset:2px}
.sz-opts{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.5rem}
.sz-btn{padding:.5rem 1rem;border:1px solid var(--gray-light);background:var(--white);font-family:var(--font-ui);font-size:.65rem;letter-spacing:.1em;cursor:pointer;transition:all .2s}
.sz-btn:hover,.sz-btn.sel{background:var(--black);color:var(--white);border-color:var(--black)}
.qty-row{display:flex;gap:.8rem;align-items:center;margin-bottom:1rem}
.qty-ctrl{display:flex;align-items:center;border:1px solid var(--gray-light)}
.qty-btn{width:40px;height:44px;background:none;border:none;font-size:1.1rem;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center}
.qty-btn:hover{background:var(--black);color:var(--white)}
.qty-val{width:50px;text-align:center;border:none;border-left:1px solid var(--gray-light);border-right:1px solid var(--gray-light);font-family:var(--font-ui);font-size:.75rem;font-weight:600;-moz-appearance:textfield}
.qty-val::-webkit-outer-spin-button,.qty-val::-webkit-inner-spin-button{-webkit-appearance:none}
.atc-btn{flex:1;padding:1rem;text-align:center}
.buy-btn{border:none;letter-spacing:.18em;font-size:.62rem;font-weight:700;font-family:var(--font-ui)}
.pd-features{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:2rem 0}
.feat-item{display:flex;gap:.8rem;align-items:flex-start}
.feat-icon{font-size:1.2rem;flex-shrink:0}
.feat-text{font-size:.65rem;line-height:1.7;color:var(--gray)}
.feat-text strong{display:block;color:var(--black);font-size:.68rem}
.pd-tabs{margin-top:2rem}
.tab-nav{display:flex;border-bottom:1px solid var(--gray-light);gap:0;margin-bottom:1.5rem}
.tab-btn{background:none;border:none;border-bottom:2px solid transparent;padding:.7rem 1.2rem;font-family:var(--font-ui);font-size:.6rem;letter-spacing:.15em;font-weight:700;cursor:pointer;color:var(--gray);transition:all .2s;margin-bottom:-1px}
.tab-btn.active{color:var(--black);border-bottom-color:var(--black)}
.tab-panel{display:none;font-size:.78rem;line-height:1.9;color:var(--gray)}.tab-panel.active{display:block}
.tab-tbl{width:100%;border-collapse:collapse}
.tab-tbl th,.tab-tbl td{padding:.6rem .8rem;font-size:.68rem;border-bottom:1px solid var(--gray-light);text-align:left}
.tab-tbl th{font-weight:600;color:var(--black);width:30%;background:#fafafa}

/* ── RELATED ── */
.rel-section{padding:5rem;background:var(--beige-light)}

/* ── LOOKBOOK PAGE ── */
.lb-hero{position:relative;height:100vh;max-height:800px;overflow:hidden}
.lb-hero-bg{position:absolute;inset:0;background:rgba(0,0,0,.5);z-index:1}
.lb-hero-img{position:absolute;inset:0}.lb-hero-img img{width:100%;height:100%;object-fit:cover}
.lb-hero-cnt{position:absolute;bottom:5rem;left:8rem;z-index:2}
.lb-hero-cnt h1{font-family:var(--font-display);font-size:clamp(3rem,7vw,6rem);color:var(--white);line-height:1}
.lb-filters{display:flex;gap:.5rem;flex-wrap:wrap;padding:2rem 5rem;border-bottom:1px solid var(--gray-light);position:sticky;top:80px;background:rgba(255,255,255,.97);backdrop-filter:blur(10px);z-index:10}
.ftab{background:none;border:1px solid var(--gray-light);padding:.45rem 1rem;font-family:var(--font-ui);font-size:.58rem;letter-spacing:.2em;cursor:pointer;transition:all .2s}
.ftab.active,.ftab:hover{background:var(--black);color:var(--white);border-color:var(--black)}
.masonry{columns:3;column-gap:.5rem;padding:2rem 5rem 5rem}
.m-item{break-inside:avoid;margin-bottom:.5rem;position:relative;overflow:hidden;cursor:pointer}
.m-img{width:100%;display:block;transition:transform .8s var(--ease)}
.m-item:hover .m-img{transform:scale(1.04)}
.m-tag{position:absolute;top:.6rem;left:.6rem;background:rgba(0,0,0,.7);color:rgba(255,255,255,.8);font-size:.5rem;letter-spacing:.2em;padding:.25rem .6rem;font-weight:700}
.m-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);opacity:0;transition:opacity .3s;display:flex;flex-direction:column;justify-content:flex-end;padding:1rem}
.m-item:hover .m-ov{opacity:1}
.m-title{font-size:.75rem;font-weight:700;color:var(--white);letter-spacing:.08em}.m-sub{font-size:.6rem;color:rgba(255,255,255,.6);margin-top:.2rem}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:2000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .3s var(--ease)}
.lightbox.open{opacity:1;visibility:visible}
.lb-inner{display:flex;gap:0;max-width:900px;max-height:90vh;width:90vw}
.lb-img{max-height:90vh;max-width:55%;object-fit:contain}
.lb-info{flex:1;background:var(--white);padding:3rem;display:flex;flex-direction:column;justify-content:center}
.lb-tag{font-size:.55rem;letter-spacing:.3em;color:var(--beige-dark);margin-bottom:.5rem}
.lb-ttl{font-family:var(--font-display);font-size:2rem;margin-bottom:.5rem}
.lb-st{font-size:.72rem;color:var(--gray);letter-spacing:.08em;margin-bottom:2rem}
.lb-close{position:absolute;top:2rem;right:2rem;background:none;border:none;color:rgba(255,255,255,.6);font-size:2rem;cursor:pointer;line-height:1}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:var(--white);font-size:2rem;padding:.5rem 1rem;cursor:pointer;transition:background .2s}
.lb-prev{left:1rem}.lb-next{right:1rem}.lb-nav:hover{background:rgba(255,255,255,.2)}

/* ── CUSTOM PAGE ── */
.cust-hero{position:relative;min-height:60vh;background:var(--black);display:flex;align-items:flex-end;padding:8rem;overflow:hidden}
.cust-hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 0% 100%,#1a1200,#000)}
.steps-wrap{padding:7rem 8rem}
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;margin-top:4rem}
.step-card{padding:2.5rem;border:1px solid var(--gray-light);transition:transform .3s,box-shadow .3s}
.step-card:hover{transform:translateY(-4px);box-shadow:0 10px 30px rgba(0,0,0,.08)}
.step-num{font-size:.6rem;letter-spacing:.3em;color:var(--beige-dark);font-weight:700;margin-bottom:1rem}
.step-name{font-size:.85rem;font-weight:700;margin-bottom:.5rem}
.step-desc{font-size:.72rem;color:var(--gray);line-height:1.7}
.config-wrap{padding:5rem 8rem;background:var(--beige-light)}
.config-grid{display:grid;grid-template-columns:1fr 380px;gap:4rem;align-items:start}
.cfg-sec{background:var(--white);padding:2rem;margin-bottom:1rem}
.cfg-lbl{font-size:.6rem;letter-spacing:.25em;font-weight:700;text-transform:uppercase;margin-bottom:1.2rem;padding-bottom:.8rem;border-bottom:1px solid var(--gray-light)}
.cfg-inp{width:100%;padding:.8rem 1rem;border:1px solid var(--gray-light);font-family:var(--font-ui);font-size:.75rem;outline:none;transition:border-color .2s}
.cfg-inp:focus{border-color:var(--black)}
.cfg-sel{width:100%;padding:.8rem 1rem;border:1px solid var(--gray-light);font-family:var(--font-ui);font-size:.75rem;outline:none;background:var(--white);cursor:pointer}
.cfg-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.cfg-ta{width:100%;padding:.8rem 1rem;border:1px solid var(--gray-light);font-family:var(--font-ui);font-size:.75rem;resize:vertical;min-height:80px;outline:none}
.type-btns{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}
.type-btn{padding:1.2rem;border:1px solid var(--gray-light);background:var(--white);font-family:var(--font-ui);font-size:.62rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:center;letter-spacing:.05em;line-height:1.7}
.type-btn small{font-size:.55rem;color:var(--gray);font-weight:400;letter-spacing:.1em}
.type-btn.sel,.type-btn:hover{border-color:var(--black);background:var(--black);color:var(--white)}
.type-btn.sel small,.type-btn:hover small{color:var(--beige)}
.type-icon{display:block;font-size:1.5rem;margin-bottom:.3rem}
.clr-btns{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.8rem}
.clr-pick{display:flex;align-items:center;gap:.4rem;padding:.4rem .8rem;border:1px solid var(--gray-light);background:var(--white);font-family:var(--font-ui);font-size:.62rem;cursor:pointer;transition:all .2s;letter-spacing:.05em}
.clr-pick.sel,.clr-pick:hover{border-color:var(--black)}
.upload-area{border:2px dashed var(--gray-light);padding:2.5rem;text-align:center;cursor:pointer;transition:border-color .2s;position:relative}
.upload-area:hover{border-color:var(--black)}
.upload-area input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.up-icon{font-size:2rem;display:block;margin-bottom:.5rem}
.up-txt{font-size:.65rem;font-weight:700;letter-spacing:.2em;margin-bottom:.4rem}
.up-hint{font-size:.6rem;color:var(--gray);letter-spacing:.1em}
.pl-tabs{display:flex;gap:.5rem;flex-wrap:wrap}
.pl-tab{padding:.45rem .9rem;border:1px solid var(--gray-light);background:var(--white);font-family:var(--font-ui);font-size:.6rem;cursor:pointer;transition:all .2s;letter-spacing:.1em}
.pl-tab.sel{background:var(--black);color:var(--white);border-color:var(--black)}
.price-preview{background:var(--black);color:var(--white);padding:1.5rem}
.pline{display:flex;justify-content:space-between;font-size:.68rem;padding:.4rem 0;border-bottom:1px solid #1f1f1f}
.pline:last-child{border-bottom:none;padding-top:.8rem;margin-top:.3rem;font-weight:700;font-size:.75rem;color:var(--beige)}
.preview-panel{position:sticky;top:140px}
.preview-canvas{background:var(--black);aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}

/* ── ABOUT ── */
.about-hero{display:grid;grid-template-columns:1fr 1fr;min-height:80vh;background:var(--black)}
.ah-text{padding:8rem;display:flex;flex-direction:column;justify-content:center}
.ah-img{overflow:hidden}.ah-img img{width:100%;height:100%;object-fit:cover}
.vals-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3rem;margin-top:4rem;padding:0 8rem}
.val-item{padding:3rem;border:1px solid var(--gray-light)}
.val-num{font-size:.6rem;letter-spacing:.3em;color:var(--beige-dark);margin-bottom:1rem}
.val-name{font-size:1rem;font-weight:700;margin-bottom:.8rem}
.val-desc{font-size:.75rem;color:var(--gray);line-height:1.8}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;min-height:80vh;background:var(--black)}
.contact-info{padding:8rem;display:flex;flex-direction:column;justify-content:center}
.cm{display:flex;gap:1.5rem;align-items:flex-start;margin-bottom:2.5rem}
.cm-icon{font-size:1.5rem;flex-shrink:0;margin-top:.3rem}
.cm-lbl{font-size:.55rem;letter-spacing:.25em;color:rgba(255,255,255,.35);margin-bottom:.3rem}
.cm-val{font-size:.85rem;font-weight:600;color:var(--white)}
.cm-sub{font-size:.62rem;color:rgba(255,255,255,.4);margin-top:.2rem}
.contact-form{background:var(--white);padding:6rem}
.cf-field{margin-bottom:1.2rem}
.cf-field label{display:block;font-size:.58rem;letter-spacing:.2em;font-weight:700;color:var(--gray);margin-bottom:.5rem;text-transform:uppercase}
.cf-field input,.cf-field select,.cf-field textarea{width:100%;padding:.85rem 1rem;border:1px solid var(--gray-light);font-family:var(--font-ui);font-size:.78rem;outline:none;transition:border-color .2s;background:var(--white)}
.cf-field input:focus,.cf-field select:focus,.cf-field textarea:focus{border-color:var(--black)}
.cf-field textarea{resize:vertical;min-height:100px}

/* ── FOOTER ── */
.site-footer{background:var(--black);color:var(--white);padding:5rem 8rem 3rem}
.ft-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:4rem;padding-bottom:4rem;border-bottom:1px solid #1f1f1f}
.ft-brand p{font-size:.72rem;color:rgba(255,255,255,.4);line-height:1.9;max-width:240px;margin-top:.5rem}
.ft-social{display:flex;gap:.8rem;margin-top:1.5rem}
.soc-link{padding:.5rem .7rem;border:1px solid #333;font-size:.58rem;letter-spacing:.2em;color:rgba(255,255,255,.5);transition:all .2s}
.soc-link:hover{background:var(--white);color:var(--black);border-color:var(--white)}
.ft-col h4{font-size:.6rem;letter-spacing:.3em;font-weight:700;color:rgba(255,255,255,.3);margin-bottom:1.2rem;text-transform:uppercase}
.ft-col a{display:block;font-size:.7rem;color:rgba(255,255,255,.5);margin-bottom:.6rem;letter-spacing:.05em;transition:color .2s}
.ft-col a:hover{color:var(--white)}
.ft-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:2rem;font-size:.58rem;letter-spacing:.1em;color:rgba(255,255,255,.2)}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .pgrid,.pgrid-shop{grid-template-columns:repeat(2,1fr)}
  .ct-grid,.brand-story-grid,.about-hero{grid-template-columns:1fr}
  .hero{padding:9rem 3rem 4rem}
  .section{padding:5rem 3rem}
  .brand-story-grid,.steps-wrap,.config-wrap,.vals-grid{padding:4rem 3rem}
  .lb-strip{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr}
  .ft-top{grid-template-columns:1fr 1fr}
  .site-footer{padding:4rem 3rem 2rem}
  .masonry{columns:2}
  .shop-layout{grid-template-columns:1fr}
  .shop-sb{display:none;position:fixed;inset:0;z-index:900;background:var(--white);overflow-y:auto;padding:2rem}
  .shop-sb.open{display:block}
  .mob-filter-btn{display:flex;align-items:center;gap:.5rem;margin:1rem 5rem 0;padding:.7rem 1.2rem;border:1px solid var(--black);background:none;font-family:var(--font-ui);font-size:.62rem;letter-spacing:.15em;font-weight:600;cursor:pointer}
  .pd-layout{grid-template-columns:1fr;gap:2rem;padding:2rem 2rem 4rem}
  .config-grid{grid-template-columns:1fr}
  .pgrid-4{grid-template-columns:repeat(2,1fr)}
  /* Homepage: category cards should be 2-column on tablet/mobile */
  .home-banners{grid-template-columns:repeat(2,1fr);gap:1rem}
  .home-banners .hb:last-child{grid-column:1 / -1}
  .hb{min-height:240px}
  .promo{grid-template-columns:1fr}
  .promo-art{min-height:280px}
}
@media(max-width:768px){
  nav{display:none}
  .burger{display:flex}
  .mob-menu{display:flex;flex-direction:column;gap:0;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--black);z-index:900;padding:5rem 3rem;opacity:0;visibility:hidden;transition:all .3s}
  .mob-menu.open{opacity:1;visibility:visible}
  .mob-menu a{font-size:1.5rem;font-weight:900;color:var(--white);padding:1rem 0;border-bottom:1px solid #1f1f1f}
  .hdr{padding:.8rem 1.5rem}
  .hero{padding:7rem 2rem 3rem}
  .steps-grid{grid-template-columns:1fr 1fr}
  .lb-strip,.pgrid{grid-template-columns:1fr 1fr}
  .page-hero,.lb-hero{height:250px;padding:2rem 2rem 2.5rem}
  .lb-hero-cnt{left:2rem;bottom:2rem}
  .masonry{columns:2;padding:1.5rem 2rem}
  .ft-top{grid-template-columns:1fr}
  .section{padding:4rem 2rem}
}
@media(max-width:480px){
  /* Mobile density tweaks for grids */
  .pcard-info{padding:.75rem 0 .35rem}
  .pcard-name{font-size:.72rem;line-height:1.35;margin-bottom:.4rem}
  .pcard-price{font-size:.78rem}
  .pcard-meta{gap:.5rem}
  .cdots{display:none}

  .home-banners{gap:.9rem}
  .hb{min-height:180px}
  .hb-ov{padding:1.25rem}
  .hb-title{font-size:1.45rem}
  .hb-sub{font-size:.68rem;letter-spacing:.18em}
  /* Keep homepage product grids 2-column on small phones */
  .pgrid,.pgrid-shop,.lb-strip{grid-template-columns:1fr}
  .pgrid-4{grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem}
  .steps-grid,.bs-imgs{grid-template-columns:1fr}
  .nl-form{flex-direction:column}
  .hero-ttl{font-size:3rem}
  .masonry{columns:1}
  .breadcrumb{padding:.8rem 2rem}
}
