/* ===========================================================
   MAUVE LONDON — editorial storefront
   Shared stylesheet
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Jost:wght@300;400;500&display=swap');

:root{
  --ivory:#f6f2ec;
  --paper:#fbf9f5;
  --ink:#1c1a18;
  --soft:#6f6862;
  --line:#e2dbd0;
  --mauve:#7c6070;
  --mauve-deep:#5c4555;
  --gold:#b59b6a;
  --max:1280px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Jost',sans-serif;
  font-weight:300;
  color:var(--ink);
  background:var(--ivory);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{display:block;width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:400;line-height:1.1}

.wrap{max-width:var(--max);margin:0 auto;padding:0 32px}
.eyebrow{
  font-family:'Jost',sans-serif;
  font-size:.72rem;font-weight:400;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--mauve);
}

/* ---------- Top bar ---------- */
.announce{
  background:var(--ink);color:var(--ivory);
  text-align:center;font-size:.72rem;letter-spacing:.26em;
  text-transform:uppercase;padding:9px 16px;
}
header.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(246,242,236,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  max-width:var(--max);margin:0 auto;padding:18px 32px;
}
.brand{
  font-family:'Cormorant Garamond',serif;
  font-size:1.7rem;letter-spacing:.42em;
  text-transform:uppercase;padding-left:.42em;
}
.nav-links{display:flex;gap:34px}
.nav-links a{
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink);position:relative;padding-bottom:3px;
}
.nav-links a::after{
  content:'';position:absolute;left:0;bottom:0;width:0;height:1px;
  background:var(--mauve);transition:width .3s ease;
}
.nav-links a:hover::after{width:100%}
.nav-cart{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase}

/* ---------- Hero ---------- */
.hero{
  position:relative;height:88vh;min-height:560px;
  display:flex;align-items:flex-end;
  background-size:cover;background-position:center 22%;
}
.hero::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,18,16,.05) 0%,rgba(20,18,16,.5) 100%);
}
.hero-content{position:relative;z-index:2;color:var(--ivory);padding:0 0 64px}
.hero-content .eyebrow{color:#e7d9e0}
.hero h1{font-size:clamp(3rem,8vw,6.4rem);font-weight:300;letter-spacing:.01em;margin:.18em 0 .35em}
.hero p{max-width:440px;font-size:1rem;color:#f1ebe6;margin-bottom:30px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;font-size:.76rem;letter-spacing:.24em;
  text-transform:uppercase;padding:15px 38px;border:1px solid var(--ink);
  background:var(--ink);color:var(--ivory);transition:.3s;
}
.btn:hover{background:transparent;color:var(--ink)}
.btn-light{border-color:var(--ivory);background:var(--ivory);color:var(--ink)}
.btn-light:hover{background:transparent;color:var(--ivory)}
.btn-ghost{background:transparent;border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--ivory)}

/* ---------- Section scaffolding ---------- */
section{padding:90px 0}
.section-head{text-align:center;max-width:640px;margin:0 auto 56px}
.section-head h2{font-size:clamp(2.2rem,4.5vw,3.4rem);margin:.25em 0 .35em}
.section-head p{color:var(--soft)}

/* ---------- Product grid ---------- */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:36px 28px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.card{display:block;group:card}
.card .ph{
  position:relative;overflow:hidden;background:var(--paper);
  aspect-ratio:3/4;margin-bottom:16px;
}
.card .ph img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .9s cubic-bezier(.2,.7,.2,1);
}
.card:hover .ph img{transform:scale(1.05)}
.card .tag{
  position:absolute;top:14px;left:14px;z-index:2;
  background:var(--ivory);color:var(--ink);
  font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;
  padding:5px 10px;
}
.card .quick{
  position:absolute;left:0;right:0;bottom:0;
  background:rgba(28,26,24,.9);color:var(--ivory);
  text-align:center;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  padding:13px;transform:translateY(100%);transition:transform .4s ease;
}
.card:hover .quick{transform:translateY(0)}
.card h3{font-size:1.32rem;font-weight:400;margin-bottom:2px}
.card .price{font-size:.82rem;letter-spacing:.08em;color:var(--soft)}

/* ---------- Split feature ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:0}
.split.reverse .split-img{order:2}
.split-img{aspect-ratio:4/5;overflow:hidden}
.split-img img{width:100%;height:100%;object-fit:cover}
.split-text{padding:0 8%}
.split-text h2{font-size:clamp(2rem,4vw,3rem);margin:.2em 0 .5em}
.split-text p{color:var(--soft);margin-bottom:18px;max-width:460px}

/* ---------- Marquee strip ---------- */
.strip{background:var(--mauve-deep);color:var(--ivory);text-align:center;padding:64px 0}
.strip h2{font-size:clamp(2rem,4vw,3rem);font-weight:300;margin-bottom:14px}
.strip p{color:#e9dde4;max-width:520px;margin:0 auto 26px}

/* ---------- Editorial / lookbook ---------- */
.book{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.book figure{overflow:hidden;position:relative}
.book figure img{width:100%;height:100%;object-fit:cover;transition:transform 1s ease}
.book figure:hover img{transform:scale(1.04)}
.book .span2{grid-column:span 2}
.book .span3{grid-column:span 3}
.book .span4{grid-column:span 4}
.book .tall{aspect-ratio:3/4}
.book .wide{aspect-ratio:16/10}
.book figcaption{
  position:absolute;left:18px;bottom:16px;color:#fff;
  font-family:'Cormorant Garamond',serif;font-size:1.3rem;
  text-shadow:0 1px 12px rgba(0,0,0,.5);
}

/* ---------- About ---------- */
.lede{max-width:760px;margin:0 auto;text-align:center}
.lede h2{font-size:clamp(2rem,4vw,3rem);margin-bottom:.5em}
.lede p{font-size:1.08rem;color:var(--soft);margin-bottom:1.2em}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:64px}
.values .v{text-align:center}
.values .v h3{font-size:1.5rem;margin-bottom:.4em}
.values .v p{color:var(--soft);font-size:.92rem}
blockquote{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:clamp(1.6rem,3.4vw,2.6rem);font-weight:300;
  text-align:center;max-width:860px;margin:0 auto;line-height:1.35;
}
blockquote cite{
  display:block;font-family:'Jost',sans-serif;font-style:normal;
  font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--mauve);margin-top:24px;
}

/* ---------- Forms ---------- */
.form{max-width:560px;margin:0 auto}
.field{margin-bottom:22px}
.field label{display:block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--soft);margin-bottom:8px}
.field input,.field textarea{
  width:100%;padding:14px 16px;border:1px solid var(--line);
  background:var(--paper);font-family:inherit;font-size:.95rem;color:var(--ink);
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--mauve)}
.field textarea{min-height:140px;resize:vertical}

.signup{display:flex;max-width:480px;margin:24px auto 0}
.signup input{flex:1;padding:15px 16px;border:1px solid var(--ivory);background:transparent;color:var(--ivory);font-family:inherit}
.signup input::placeholder{color:#d9cdd4}
.signup button{border:1px solid var(--ivory);background:var(--ivory);color:var(--ink);padding:0 28px;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;cursor:pointer}

/* ---------- Page hero (interior pages) ---------- */
.page-hero{text-align:center;padding:96px 0 40px}
.page-hero h1{font-size:clamp(2.6rem,6vw,4.4rem);font-weight:300;margin:.15em 0 .3em}
.page-hero p{color:var(--soft);max-width:560px;margin:0 auto}

/* ---------- Footer ---------- */
footer{background:var(--ink);color:#cfc7bf;padding:72px 0 36px;font-size:.85rem}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
footer .brand{color:var(--ivory);margin-bottom:18px;display:block}
footer h4{font-family:'Jost',sans-serif;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ivory);margin-bottom:16px;font-weight:400}
footer ul{list-style:none}
footer li{margin-bottom:10px}
footer a:hover{color:var(--ivory)}
footer p{max-width:300px}
.foot-bottom{
  border-top:1px solid #36322e;margin-top:52px;padding-top:24px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:#8b837b;
}

/* ---------- Size table ---------- */
.sizetable{width:100%;border-collapse:collapse;margin:0 auto;font-size:.9rem}
.sizetable th,.sizetable td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--line)}
.sizetable thead th{
  font-family:'Jost',sans-serif;font-weight:400;font-size:.7rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--mauve);
}
.sizetable tbody tr:hover{background:var(--paper)}
.sizetable td:first-child{font-family:'Cormorant Garamond',serif;font-size:1.15rem}
.note{font-size:.85rem;color:var(--soft);margin-top:18px;text-align:center}

/* ---------- FAQ accordion ---------- */
.faq{max-width:760px;margin:0 auto}
.faq details{border-bottom:1px solid var(--line);padding:6px 0}
.faq summary{
  list-style:none;cursor:pointer;padding:20px 4px;
  font-family:'Cormorant Garamond',serif;font-size:1.4rem;
  display:flex;justify-content:space-between;align-items:center;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';color:var(--mauve);font-size:1.4rem;transition:transform .3s}
.faq details[open] summary::after{content:'–'}
.faq details p{padding:0 4px 22px;color:var(--soft);max-width:680px}

/* ---------- Sold-out state on cards ---------- */
.tag-soldout{left:auto;right:14px;background:var(--ink);color:var(--ivory)}
.card.is-soldout .ph img{opacity:.5}
.card.is-soldout .price{color:var(--soft)}

/* ---------- Cart badge ---------- */
.nav-cart{position:relative}
.cart-count{
  display:none;margin-left:6px;font-size:.7rem;letter-spacing:.05em;
  background:var(--mauve);color:#fff;border-radius:999px;
  padding:1px 7px;vertical-align:middle;
}
.cart-count.show{display:inline-block}

/* ---------- Cart drawer ---------- */
.drawer-overlay{
  position:fixed;inset:0;background:rgba(20,18,16,.45);
  opacity:0;visibility:hidden;transition:.35s;z-index:90;
}
.drawer-overlay.open{opacity:1;visibility:visible}
.drawer{
  position:fixed;top:0;right:0;height:100%;width:420px;max-width:90vw;
  background:var(--ivory);z-index:100;display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .4s cubic-bezier(.2,.7,.2,1);
  box-shadow:-12px 0 40px rgba(0,0,0,.12);
}
.drawer.open{transform:translateX(0)}
.drawer-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:24px 28px;border-bottom:1px solid var(--line);
}
.drawer-head h3{font-size:1.5rem}
.drawer-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--ink);line-height:1}
.drawer-body{flex:1;overflow-y:auto;padding:8px 28px}
.drawer-empty{text-align:center;color:var(--soft);padding:60px 0}
.line{display:flex;gap:16px;padding:20px 0;border-bottom:1px solid var(--line)}
.line img{width:72px;height:96px;object-fit:cover;flex-shrink:0;background:var(--paper)}
.line .info{flex:1;font-size:.9rem}
.line .info h4{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:400;margin-bottom:2px}
.line .info .opt{color:var(--soft);font-size:.78rem;letter-spacing:.04em;margin-bottom:8px}
.line .info .row{display:flex;justify-content:space-between;align-items:center}
.line .remove{background:none;border:none;color:var(--soft);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;padding:0}
.line .remove:hover{color:var(--mauve)}
.drawer-foot{padding:24px 28px;border-top:1px solid var(--line)}
.drawer-foot .subtotal{display:flex;justify-content:space-between;font-size:.95rem;margin-bottom:6px}
.drawer-foot .subtotal strong{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:500}
.drawer-foot .ship{font-size:.78rem;color:var(--soft);margin-bottom:18px}
.drawer-foot .btn{width:100%;text-align:center;cursor:pointer;border:none}

/* ---------- Product page (PDP) ---------- */
.pdp{display:grid;grid-template-columns:1.1fr 1fr;gap:56px;padding:48px 0 90px}
.pdp-gallery{display:grid;grid-template-columns:1fr;gap:14px}
.pdp-gallery img{width:100%;object-fit:cover;background:var(--paper)}
.pdp-info{position:sticky;top:120px;align-self:start}
.pdp-info .eyebrow{color:var(--mauve)}
.pdp-info h1{font-size:clamp(2rem,4vw,3rem);font-weight:300;margin:.2em 0 .25em}
.pdp-price{font-size:1.2rem;color:var(--ink);margin-bottom:28px}
.pdp-field{margin-bottom:22px}
.pdp-field label{display:block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--soft);margin-bottom:8px}
.pdp-field select{
  width:100%;padding:14px 16px;border:1px solid var(--line);background:var(--paper);
  font-family:inherit;font-size:.95rem;color:var(--ink);appearance:none;cursor:pointer;
}
.pdp-field select:focus{outline:none;border-color:var(--mauve)}
.pdp .btn{width:100%;text-align:center;cursor:pointer;border:none;margin-top:6px}
.pdp-desc{margin-top:32px;padding-top:28px;border-top:1px solid var(--line);color:var(--soft);font-size:.95rem}
.pdp-desc p{margin-bottom:12px}
.pdp-note{font-size:.8rem;color:var(--soft);margin-top:14px;text-align:center}
.pdp-loading{text-align:center;padding:120px 0;color:var(--soft)}

@media(max-width:768px){
  .drawer{width:100%}
  .pdp{grid-template-columns:1fr;gap:28px;padding-top:24px}
  .pdp-info{position:static}
}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .grid{grid-template-columns:repeat(3,1fr)}
  .book{grid-template-columns:repeat(4,1fr)}
}
@media(max-width:768px){
  .nav-links{display:none}
  .grid,.grid.cols-3{grid-template-columns:repeat(2,1fr);gap:24px 16px}
  .split,.values,.foot-grid{grid-template-columns:1fr}
  .split.reverse .split-img{order:0}
  .split-text{padding:40px 32px}
  .book{grid-template-columns:repeat(2,1fr)}
  .book .span3,.book .span4{grid-column:span 2}
  section{padding:64px 0}
}
@media(max-width:480px){
  .grid{grid-template-columns:1fr}
  .brand{font-size:1.35rem;letter-spacing:.3em}
  .wrap{padding:0 20px}
}
