/* =========================================================
   VASTRAM HOUSE — Design tokens & base
   ========================================================= */

:root{
  --maroon:#9B2C3E;
  --maroon-deep:#7A1F30;
  --marigold:#F2A93B;
  --marigold-soft:#FBD9A5;
  --blush:#FBE4E4;
  --cream:#FFFBF7;
  --charcoal:#2B2730;
  --muted:#8A8290;
  --green:#3E8E5A;
  --line: rgba(43,39,48,0.10);

  --display:"Marcellus", serif;
  --body:"Poppins", sans-serif;

  --radius: 4px;
  --radius-lg: 14px;
  --container: 1240px;

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

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family:var(--body);
  color:var(--charcoal);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:var(--body); }

.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 32px;
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.01ms !important; transition-duration:.01ms !important; scroll-behavior:auto !important; }
}

/* =========================================================
   TYPOGRAPHY
   ========================================================= */

h1,h2,h3,h4{
  font-family:var(--display);
  font-weight:500;
  line-height:1.12;
  margin:0 0 0.4em;
  color:var(--charcoal);
}
h1{ font-size:clamp(2.6rem, 6vw, 4.6rem); }
h2{ font-size:clamp(1.9rem, 4vw, 3rem); }
h3{ font-size:clamp(1.2rem, 2.2vw, 1.6rem); }

p{ margin:0 0 1em; color:var(--muted); }

.eyebrow{
  font-size:0.74rem;
  font-weight:600;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--maroon);
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-bottom:14px;
}
.eyebrow::before{
  content:"";
  display:block;
  width:28px; height:2px;
  background:var(--marigold);
}

/* =========================================================
   TOP STRIP
   ========================================================= */

.top-strip{
  background:var(--maroon);
  color:var(--blush);
  font-size:0.8rem;
  text-align:center;
  padding:9px 16px;
  letter-spacing:0.04em;
}
.top-strip strong{ color:var(--marigold-soft); }

/* =========================================================
   HEADER / NAV
   ========================================================= */

.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(255,251,247,0.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:18px 32px;
  max-width:var(--container);
  margin:0 auto;
}
.logo{
  font-family:var(--display);
  font-size:1.7rem;
  font-weight:600;
  color:var(--maroon);
  letter-spacing:0.02em;
  white-space:nowrap;
}
.logo span{ color:var(--charcoal); font-weight:400; }

.nav-links{
  display:flex;
  gap:34px;
  list-style:none;
  margin:0; padding:0;
  font-size:0.92rem;
  font-weight:500;
}
.nav-links a{
  position:relative;
  padding-bottom:4px;
  transition:color .25s var(--ease);
}
.nav-links a::after{
  content:"";
  position:absolute; left:0; bottom:0;
  width:100%; height:2px;
  background:var(--marigold);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .3s var(--ease);
}
.nav-links a:hover{ color:var(--maroon); }
.nav-links a.active{ color:var(--maroon); }
.nav-links a.active::after, .nav-links a:hover::after{ transform:scaleX(1); }

.nav-search{
  flex:1;
  max-width:340px;
  display:flex;
  align-items:center;
  background:var(--blush);
  border-radius:999px;
  padding:9px 18px;
  gap:8px;
}
.nav-search input{
  border:none;
  background:none;
  outline:none;
  font-size:0.88rem;
  width:100%;
  color:var(--charcoal);
  font-family:var(--body);
}
.nav-search input::placeholder{ color:var(--muted); }
.nav-search svg{ flex-shrink:0; opacity:0.55; }

.nav-actions{
  display:flex;
  align-items:center;
  gap:18px;
}
.nav-icon-btn{
  position:relative;
  background:none;
  border:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  width:40px; height:40px;
  border-radius:50%;
  transition:background .25s var(--ease);
  color:var(--charcoal);
}
.nav-icon-btn:hover{ background:var(--blush); }
.cart-badge{
  position:absolute;
  top:2px; right:2px;
  background:var(--maroon);
  color:#fff;
  font-size:0.62rem;
  font-weight:700;
  width:18px; height:18px;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  transition:transform .25s var(--ease);
}
.cart-badge.bump{ animation:bump .35s var(--ease); }
@keyframes bump{ 50%{ transform:scale(1.35); } }

.nav-toggle{
  display:none;
  background:none; border:none;
  font-size:1.6rem;
  cursor:pointer;
  color:var(--charcoal);
}

@media (max-width:980px){
  .nav-search{ display:none; }
}
@media (max-width:860px){
  .nav-links{ display:none; }
  .nav-toggle{ display:block; }
  .nav-links.open{
    display:flex;
    flex-direction:column;
    position:absolute;
    top:100%; left:0; right:0;
    background:var(--cream);
    padding:22px 32px;
    gap:18px;
    border-bottom:1px solid var(--line);
  }
}

/* =========================================================
   HERO
   ========================================================= */

.hero{
  background:linear-gradient(120deg, var(--blush) 0%, var(--cream) 55%);
  padding:80px 0;
  position:relative;
  overflow:hidden;
}
.hero::after{
  content:"";
  position:absolute;
  top:-120px; right:-120px;
  width:380px; height:380px;
  border-radius:50%;
  background:radial-gradient(circle, var(--marigold-soft) 0%, transparent 70%);
  opacity:0.7;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:60px;
  align-items:center;
  position:relative; z-index:1;
}
.hero h1{ color:var(--charcoal); }
.hero h1 em{
  font-style:italic;
  color:var(--maroon);
}
.hero-sub{
  max-width:440px;
  font-size:1.05rem;
}
.hero-actions{
  display:flex;
  gap:16px;
  margin-top:32px;
  flex-wrap:wrap;
}

/* Drape visual */
.drape-stack{
  position:relative;
  height:420px;
}
.drape{
  position:absolute;
  border-radius:var(--radius-lg);
  box-shadow:0 24px 50px -20px rgba(43,39,48,0.35);
  overflow:hidden;
  display:flex;
  align-items:flex-end;
  padding:22px;
}
.drape::before{
  content:"";
  position:absolute;
  top:0; right:0;
  width:60px; height:60px;
  background:rgba(255,255,255,0.18);
  clip-path:polygon(100% 0, 0 0, 100% 100%);
}
.drape span{
  font-family:var(--display);
  font-style:italic;
  color:#fff;
  font-size:1.05rem;
}
.drape--1{
  width:64%; height:340px;
  background:linear-gradient(150deg,var(--maroon),var(--maroon-deep));
  top:0; left:0; z-index:2;
}
.drape--2{
  width:50%; height:220px;
  background:linear-gradient(150deg,var(--marigold),#C97F1F);
  bottom:0; right:0; z-index:1;
}
@media (max-width:980px){
  .hero-grid{ grid-template-columns:1fr; gap:40px; }
  .drape-stack{ height:300px; }
}

/* =========================================================
   BUTTONS
   ========================================================= */

.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:14px 30px;
  font-size:0.9rem;
  font-weight:600;
  letter-spacing:0.02em;
  border-radius:999px;
  border:1px solid transparent;
  cursor:pointer;
  transition:all .25s var(--ease);
}
.btn-primary{ background:var(--maroon); color:#fff; }
.btn-primary:hover{ background:var(--maroon-deep); transform:translateY(-2px); }
.btn-outline{ border-color:var(--charcoal); color:var(--charcoal); }
.btn-outline:hover{ background:var(--charcoal); color:#fff; }
.btn-light{ background:#fff; color:var(--charcoal); }
.btn-light:hover{ background:var(--blush); }
.btn-sm{ padding:9px 20px; font-size:0.8rem; }
.btn-block{ width:100%; justify-content:center; }
.btn:disabled{ opacity:0.5; cursor:not-allowed; }

/* =========================================================
   SECTIONS
   ========================================================= */

.section{ padding:80px 0; }
.section--tight{ padding:56px 0; }
.section--blush{ background:var(--blush); }
.section--maroon{ background:var(--maroon); color:#fff; }
.section--maroon h2{ color:#fff; }
.section--maroon p{ color:rgba(255,255,255,0.75); }

.section-head{ max-width:600px; margin-bottom:48px; }
.section-head--center{ margin-left:auto; margin-right:auto; text-align:center; }
.section-head--center .eyebrow{ justify-content:center; }
.section-head--center .eyebrow::before{ display:none; }
.section-head--row{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:24px;
  flex-wrap:wrap;
}

/* =========================================================
   CATEGORY STRIP
   ========================================================= */

.cat-strip{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:16px;
}
.cat-pill{
  background:var(--blush);
  border-radius:var(--radius-lg);
  padding:26px 16px;
  text-align:center;
  transition:transform .25s var(--ease), background .25s var(--ease);
}
.cat-pill:hover{ transform:translateY(-4px); background:var(--marigold-soft); }
.cat-pill .cat-icon{
  width:48px; height:48px;
  margin:0 auto 12px;
  border-radius:50%;
  background:#fff;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--display);
  font-style:italic;
  color:var(--maroon);
  font-size:1.2rem;
}
.cat-pill h4{
  font-family:var(--body);
  font-size:0.85rem;
  font-weight:600;
  margin:0;
  color:var(--charcoal);
}
@media (max-width:980px){ .cat-strip{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:560px){ .cat-strip{ grid-template-columns:repeat(2,1fr); } }

/* =========================================================
   PRODUCT GRID & CARD
   ========================================================= */

.product-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:28px;
}
@media (max-width:1100px){ .product-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:800px){ .product-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .product-grid{ grid-template-columns:1fr; } }

.product-card{
  background:#fff;
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid var(--line);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
  display:flex;
  flex-direction:column;
}
.product-card:hover{
  transform:translateY(-5px);
  box-shadow:0 18px 40px -22px rgba(43,39,48,0.3);
}
.product-media{
  position:relative;
  aspect-ratio: 3/4;
  background:linear-gradient(150deg, var(--drape-a, var(--maroon)), var(--drape-b, var(--maroon-deep)));
  display:flex;
  align-items:flex-end;
  padding:18px;
  overflow:hidden;
}
/* drape-peel signature hover effect */
.product-media::before{
  content:"";
  position:absolute;
  top:-40%; right:-40%;
  width:90px; height:90px;
  background:rgba(255,255,255,0.16);
  clip-path:polygon(100% 0, 0 0, 100% 100%);
  transition:transform .4s var(--ease);
}
.product-card:hover .product-media::before{
  transform:translate(-14px,14px) scale(1.15);
}
.product-media span.fabric-label{
  font-family:var(--display);
  font-style:italic;
  color:#fff;
  font-size:1rem;
  position:relative; z-index:1;
}
.product-badge{
  position:absolute;
  top:14px; left:14px;
  background:var(--marigold);
  color:var(--charcoal);
  font-size:0.7rem;
  font-weight:700;
  letter-spacing:0.05em;
  padding:5px 12px;
  border-radius:999px;
  z-index:2;
}
.product-badge--sale{ background:var(--maroon); color:#fff; }
.wishlist-btn{
  position:absolute;
  top:12px; right:12px;
  width:34px; height:34px;
  border-radius:50%;
  background:rgba(255,255,255,0.85);
  border:none;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
  z-index:2;
  transition:background .25s var(--ease), transform .2s var(--ease);
  color:var(--maroon);
}
.wishlist-btn:hover{ transform:scale(1.08); }
.wishlist-btn.active{ background:var(--maroon); color:#fff; }

.product-info{ padding:18px 18px 20px; display:flex; flex-direction:column; gap:6px; flex:1; }
.product-cat{ font-size:0.72rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--muted); }
.product-name{ font-family:var(--display); font-size:1.1rem; margin:0; color:var(--charcoal); }
.product-price{
  display:flex; align-items:baseline; gap:8px;
  margin-top:4px;
}
.price-now{ font-size:1.05rem; font-weight:700; color:var(--maroon); }
.price-was{ font-size:0.85rem; color:var(--muted); text-decoration:line-through; }
.price-off{ font-size:0.78rem; color:var(--green); font-weight:600; }

.product-actions{ margin-top:auto; padding-top:12px; }
.add-cart-btn{
  width:100%;
  padding:11px;
  border-radius:999px;
  background:var(--charcoal);
  color:#fff;
  border:none;
  font-size:0.84rem;
  font-weight:600;
  letter-spacing:0.03em;
  cursor:pointer;
  transition:background .25s var(--ease);
}
.add-cart-btn:hover{ background:var(--maroon); }
.add-cart-btn.added{ background:var(--green); }

/* =========================================================
   FILTERS (shop page)
   ========================================================= */

.filter-bar{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:36px;
}
.filter-chip{
  padding:9px 22px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  font-size:0.85rem;
  font-weight:500;
  cursor:pointer;
  transition:all .2s var(--ease);
}
.filter-chip:hover{ border-color:var(--maroon); }
.filter-chip.active{
  background:var(--maroon);
  color:#fff;
  border-color:var(--maroon);
}

/* =========================================================
   FEATURE / TRUST STRIP
   ========================================================= */

.trust-strip{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
}
.trust-item{
  display:flex;
  align-items:center;
  gap:14px;
}
.trust-item .icon{
  width:46px; height:46px;
  flex-shrink:0;
  border-radius:50%;
  background:var(--blush);
  display:flex; align-items:center; justify-content:center;
  color:var(--maroon);
  font-family:var(--display);
  font-style:italic;
}
.trust-item h4{ font-family:var(--body); font-size:0.92rem; font-weight:600; margin:0; }
.trust-item p{ font-size:0.82rem; margin:0; }
@media (max-width:900px){ .trust-strip{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .trust-strip{ grid-template-columns:1fr; } }

/* =========================================================
   TESTIMONIALS
   ========================================================= */

.testi{
  background:#fff;
  border-radius:var(--radius-lg);
  padding:28px;
  border:1px solid var(--line);
}
.testi-stars{ color:var(--marigold); font-size:0.9rem; margin-bottom:12px; letter-spacing:2px; }
.testi p{ font-family:var(--display); font-style:italic; font-size:1.05rem; color:var(--charcoal); }
.testi-meta strong{ display:block; font-size:0.9rem; }
.testi-meta span{ font-size:0.78rem; color:var(--muted); }

/* =========================================================
   GRID HELPERS
   ========================================================= */

.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:28px; }
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
@media (max-width:900px){ .grid-2, .grid-3{ grid-template-columns:1fr; } }

/* =========================================================
   FORMS
   ========================================================= */

label{
  display:block;
  font-size:0.75rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:8px;
  font-weight:600;
}
input, select, textarea{
  width:100%;
  padding:13px 16px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:#fff;
  font-family:var(--body);
  font-size:0.92rem;
  color:var(--charcoal);
  transition:border-color .25s var(--ease);
}
input:focus, select:focus, textarea:focus{ outline:none; border-color:var(--maroon); }
textarea{ resize:vertical; min-height:110px; }
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.form-grid .full{ grid-column:1/-1; }
@media (max-width:700px){ .form-grid{ grid-template-columns:1fr; } .form-grid .full{ grid-column:1; } }

/* =========================================================
   PAGE HERO (non-home)
   ========================================================= */

.page-hero{
  background:var(--blush);
  padding:64px 0;
}
.page-hero p{ max-width:540px; }

/* =========================================================
   FOOTER
   ========================================================= */

.site-footer{
  background:var(--charcoal);
  color:rgba(255,251,247,0.6);
  padding-top:64px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.3fr 1fr 1fr 1fr;
  gap:40px;
  padding-bottom:48px;
}
.footer-grid .logo{ color:#fff; margin-bottom:14px; }
.footer-grid .logo span{ color:var(--marigold-soft); }
.footer-grid h4{
  color:#fff;
  font-size:0.8rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  margin-bottom:16px;
}
.footer-grid ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:9px; font-size:0.88rem; }
.footer-grid ul a:hover{ color:var(--marigold-soft); }
.footer-bottom{
  border-top:1px solid rgba(255,251,247,0.1);
  padding:20px 0;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
  font-size:0.78rem;
}
@media (max-width:860px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .footer-grid{ grid-template-columns:1fr; } }

/* =========================================================
   CART DRAWER
   ========================================================= */

.cart-overlay{
  position:fixed; inset:0;
  background:rgba(43,39,48,0.45);
  z-index:200;
  opacity:0;
  visibility:hidden;
  transition:opacity .3s var(--ease), visibility .3s var(--ease);
}
.cart-overlay.open{ opacity:1; visibility:visible; }

.cart-drawer{
  position:fixed;
  top:0; right:0;
  height:100%;
  width:400px;
  max-width:92vw;
  background:#fff;
  z-index:201;
  display:flex;
  flex-direction:column;
  transform:translateX(100%);
  transition:transform .35s var(--ease);
  box-shadow:-12px 0 40px rgba(43,39,48,0.15);
}
.cart-drawer.open{ transform:translateX(0); }

.cart-header{
  display:flex; align-items:center; justify-content:space-between;
  padding:22px 24px;
  border-bottom:1px solid var(--line);
}
.cart-header h3{ margin:0; }
.cart-close{
  background:none; border:none; cursor:pointer;
  font-size:1.4rem; color:var(--charcoal);
  width:36px; height:36px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  transition:background .2s var(--ease);
}
.cart-close:hover{ background:var(--blush); }

.cart-items{
  flex:1;
  overflow-y:auto;
  padding:8px 24px;
}
.cart-empty{
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  height:100%; text-align:center; gap:14px; padding:40px;
}

.cart-item{
  display:flex; gap:14px;
  padding:18px 0;
  border-bottom:1px solid var(--line);
}
.cart-item-media{
  width:72px; height:90px;
  border-radius:8px;
  flex-shrink:0;
  background:linear-gradient(150deg, var(--drape-a, var(--maroon)), var(--drape-b, var(--maroon-deep)));
}
.cart-item-info{ flex:1; display:flex; flex-direction:column; gap:4px; }
.cart-item-info h4{ font-family:var(--display); font-size:0.98rem; margin:0; }
.cart-item-info .cart-item-cat{ font-size:0.72rem; color:var(--muted); text-transform:uppercase; letter-spacing:0.06em; }
.cart-item-price{ font-weight:700; color:var(--maroon); font-size:0.92rem; }
.cart-item-controls{
  display:flex; align-items:center; justify-content:space-between;
  margin-top:auto;
}
.qty-control{
  display:flex; align-items:center; gap:0;
  border:1px solid var(--line);
  border-radius:999px;
  overflow:hidden;
}
.qty-control button{
  width:28px; height:28px;
  border:none; background:none;
  cursor:pointer; font-size:1rem;
  display:flex; align-items:center; justify-content:center;
  color:var(--charcoal);
  transition:background .2s var(--ease);
}
.qty-control button:hover{ background:var(--blush); }
.qty-control span{ font-size:0.85rem; min-width:28px; text-align:center; }
.cart-item-remove{
  background:none; border:none; cursor:pointer;
  color:var(--muted); font-size:0.78rem;
  text-decoration:underline;
  transition:color .2s var(--ease);
}
.cart-item-remove:hover{ color:var(--maroon); }

.cart-footer{
  padding:20px 24px 26px;
  border-top:1px solid var(--line);
}
.cart-subtotal{
  display:flex; justify-content:space-between;
  font-size:0.95rem; font-weight:600;
  margin-bottom:16px;
}
.cart-subtotal strong{ color:var(--maroon); font-family:var(--display); font-size:1.2rem; }
.cart-note{ font-size:0.78rem; color:var(--muted); margin-top:10px; text-align:center; }

/* =========================================================
   REVEAL
   ========================================================= */

.reveal{
  opacity:0; transform:translateY(20px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
}
.reveal.is-visible{ opacity:1; transform:translateY(0); }

/* =========================================================
   QUICK VIEW / EMPTY STATES
   ========================================================= */

.empty-icon{
  width:64px; height:64px;
  border-radius:50%;
  background:var(--blush);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--display);
  font-style:italic;
  font-size:1.6rem;
  color:var(--maroon);
}
