@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=Playfair+Display:wght@500;600;700&family=Inter:wght@300;400;500;600&display=swap');

:root{
  --ivory:#FBF7F1;
  --cream:#F4EBDF;
  --gold:#B8924A;
  --gold-dark:#8C6B2F;
  --gold-light:#D9BD86;
  --ink:#2B241C;
  --ink-soft:#5C5347;
  --blush:#E7C8C2;
  --ruby:#A85C56;
  --pearl:#F4F1EA;
  --line:#E3D8C5;
  --maxw:1240px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Inter',sans-serif;
  color:var(--ink);
  background:var(--ivory);
  font-weight:400;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,.serif{
  font-family:'Playfair Display',serif;
  font-weight:600;
  letter-spacing:.01em;
  margin:0;
}
.logo{
  font-family:'Cormorant Garamond',serif;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;}
.eyebrow{
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:11px;
  color:var(--gold-dark);
  font-weight:600;
}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 32px;
  background:var(--ink);
  color:var(--ivory);
  font-size:13px;
  letter-spacing:.12em;
  text-transform:uppercase;
  border:1px solid var(--ink);
  cursor:pointer;
  transition:all .25s ease;
}
.btn:hover{background:transparent;color:var(--ink);}
.btn-outline{
  background:transparent;color:var(--ink);border:1px solid var(--ink);
}
.btn-outline:hover{background:var(--ink);color:var(--ivory);}
.btn-gold{background:var(--gold-dark);border-color:var(--gold-dark);color:var(--ivory);}
.btn-gold:hover{background:transparent;color:var(--gold-dark);}

/* ---------- announcement bar ---------- */
.announce{
  background:var(--ink);color:var(--cream);
  text-align:center;font-size:12px;letter-spacing:.1em;
  padding:9px 0;text-transform:uppercase;
}

/* ---------- header ---------- */
header{
  position:sticky;top:0;z-index:50;
  background:rgba(251,247,241,.92);
  backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 32px;max-width:var(--maxw);margin:0 auto;
}
.nav-links{display:flex;gap:36px;font-size:13px;letter-spacing:.05em;text-transform:uppercase;}
.nav-links a{position:relative;padding-bottom:4px;}
.nav-links a:hover{color:var(--gold-dark);}
.nav-icons{display:flex;gap:22px;font-size:13px;letter-spacing:.05em;text-transform:uppercase;align-items:center;}
.nav-logo{font-size:26px;}
.nav-toggle{display:none;font-size:22px;cursor:pointer;}

/* ---------- search overlay ---------- */
#searchOverlay{display:none;position:fixed;inset:0;background:rgba(20,14,8,0.82);z-index:10000;align-items:flex-start;justify-content:center;padding-top:120px;}
#searchOverlay.active{display:flex;}
.search-box{width:min(640px,90vw);position:relative;}
.search-close{position:absolute;top:-48px;right:0;background:none;border:none;color:#fff;font-size:28px;cursor:pointer;line-height:1;opacity:.8;}
.search-close:hover{opacity:1;}
#searchForm{display:flex;background:#fff;border-radius:2px;overflow:hidden;box-shadow:0 8px 40px rgba(0,0,0,0.4);}
#searchInput{flex:1;border:none;padding:18px 22px;font-size:17px;font-family:inherit;color:var(--ink);outline:none;background:transparent;}
#searchForm button[type="submit"]{border:none;background:var(--gold-dark);color:#fff;padding:0 28px;font-size:13px;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;white-space:nowrap;}
#searchForm button[type="submit"]:hover{background:var(--gold);}

@media (max-width:880px){
  .nav-links{display:none;}
  .nav-toggle{display:block;}
}

/* ---------- hero ---------- */
.hero{
  position:relative;
  min-height:86vh;
  display:flex;align-items:center;
  background:linear-gradient(180deg,var(--cream) 0%, var(--ivory) 100%);
  overflow:hidden;
}
.hero-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:40px;
  max-width:var(--maxw);margin:0 auto;padding:0 32px;
  align-items:center;width:100%;
}
.hero-copy .eyebrow{margin-bottom:18px;}
.hero-copy h1{
  font-size:clamp(40px,6vw,68px);
  line-height:1.05;
  margin-bottom:22px;
}
.hero-copy p{
  font-size:16px;color:var(--ink-soft);max-width:440px;margin-bottom:32px;line-height:1.7;
}
.hero-img{position:relative;}
.hero-img img{
  border-radius:2px;
  box-shadow:0 30px 60px -20px rgba(43,36,28,.35);
}
.hero-img::before{
  content:'';position:absolute;inset:-18px;
  border:1px solid var(--gold);
  z-index:-1;
}
@media (max-width:880px){
  .hero-grid{grid-template-columns:1fr;text-align:center;}
  .hero-copy p{margin:0 auto 32px;}
  .hero{min-height:auto;padding:60px 0;}
}

/* ---------- divider motif ---------- */
.motif{
  text-align:center;color:var(--gold);
  font-size:20px;letter-spacing:.5em;
  padding:6px 0;
}

/* ---------- story strip ---------- */
.story{
  padding:100px 0;text-align:center;
}
.story .wrap{max-width:760px;}
.story h2{font-size:clamp(28px,4vw,40px);margin-bottom:24px;}
.story p{color:var(--ink-soft);line-height:1.9;font-size:16px;}

/* ---------- category tiles ---------- */
.categories{padding:40px 0 100px;}
.section-head{text-align:center;margin-bottom:50px;}
.section-head .eyebrow{display:block;margin-bottom:12px;}
.section-head h2{font-size:clamp(26px,4vw,38px);}
.cat-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
.cat-tile{
  position:relative;aspect-ratio:3/4;overflow:hidden;
  background:var(--cream);
}
.cat-tile img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;}
.cat-tile:hover img{transform:scale(1.06);}
.cat-tile .label{
  position:absolute;bottom:0;left:0;right:0;
  padding:22px 18px;
  background:linear-gradient(180deg,rgba(43,36,28,0) 0%,rgba(43,36,28,.65) 100%);
  color:var(--ivory);
}
.cat-tile .label h3{font-size:18px;color:var(--ivory);}
.cat-tile .label span{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-light);}
@media (max-width:880px){.cat-grid{grid-template-columns:repeat(2,1fr);}}

/* ---------- product grid ---------- */
.products{padding:40px 0 100px;}
.product-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:30px 24px;
}
.card{display:block;}
.card-img{
  position:relative;background:var(--cream);overflow:hidden;aspect-ratio:1/1.1;margin-bottom:16px;
}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.card:hover .card-img img{transform:scale(1.05);}
.card-tag{
  position:absolute;top:12px;left:12px;
  background:var(--ivory);color:var(--ink);
  font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  padding:5px 10px;
}
.card h3{font-size:16px;margin-bottom:6px;font-weight:600;font-family:'Playfair Display',serif;}
.card .price{font-size:14px;color:var(--ink-soft);}
.card .price .strike{text-decoration:line-through;opacity:.5;margin-right:8px;font-size:13px;}
.card .meta{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-dark);margin-bottom:6px;}
@media (max-width:880px){.product-grid{grid-template-columns:repeat(2,1fr);}}

/* ---------- trust strip ---------- */
.trust{
  background:var(--cream);padding:54px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center;}
.trust-grid .ic{font-size:24px;margin-bottom:10px;color:var(--gold-dark);}
.trust-grid h4{font-size:13px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;}
.trust-grid p{font-size:13px;color:var(--ink-soft);margin:0;}
@media (max-width:880px){.trust-grid{grid-template-columns:repeat(2,1fr);}}

/* ---------- newsletter ---------- */
.newsletter{padding:90px 0;text-align:center;}
.newsletter h2{font-size:clamp(26px,4vw,36px);margin-bottom:14px;}
.newsletter p{color:var(--ink-soft);margin-bottom:30px;}
.nl-form{display:flex;justify-content:center;gap:0;max-width:440px;margin:0 auto;}
.nl-form input{
  flex:1;padding:14px 18px;border:1px solid var(--ink);background:transparent;font-family:inherit;font-size:14px;
}
.nl-form button{border-left:none;}

/* ---------- footer ---------- */
footer{background:var(--ink);color:var(--cream);padding:70px 0 30px;}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:50px;}
.foot-grid h4{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--gold-light);margin-bottom:18px;}
.foot-grid p,.foot-grid a{font-size:14px;color:#CFC6B6;line-height:2;display:block;}
.foot-logo{font-size:24px;color:var(--ivory);margin-bottom:14px;}
.foot-bottom{
  border-top:1px solid rgba(255,255,255,.1);padding-top:24px;
  display:flex;justify-content:space-between;font-size:12px;color:#8C8470;
}
@media (max-width:880px){.foot-grid{grid-template-columns:1fr 1fr;}.foot-bottom{flex-direction:column;gap:10px;text-align:center;}}

/* ---------- breadcrumb / page header ---------- */
.page-head{padding:50px 0 30px;text-align:center;border-bottom:1px solid var(--line);}
.page-head .eyebrow{display:block;margin-bottom:10px;}
.page-head h1{font-size:clamp(28px,4vw,42px);}
.crumb{font-size:12px;color:var(--ink-soft);margin-bottom:14px;}
.crumb a:hover{color:var(--gold-dark);}

/* ---------- shop layout ---------- */
.shop-layout{display:grid;grid-template-columns:240px 1fr;gap:40px;padding:60px 0 100px;}
.filters h4{font-size:12px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px;color:var(--ink-soft);}
.filter-group{margin-bottom:32px;}
.filter-group label{display:flex;gap:10px;align-items:center;font-size:14px;margin-bottom:10px;cursor:pointer;color:var(--ink-soft);}
.filter-group input{accent-color:var(--gold-dark);}
.shop-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;font-size:13px;color:var(--ink-soft);}
.shop-toolbar select{border:1px solid var(--line);background:var(--ivory);padding:8px 12px;font-family:inherit;}
@media (max-width:880px){.shop-layout{grid-template-columns:1fr;}}

/* ---------- product detail ---------- */
.pdp{padding:60px 0 100px;}
.pdp-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;}
.pdp-gallery-main{background:var(--cream);aspect-ratio:1/1;margin-bottom:14px;overflow:hidden;cursor:zoom-in;}
.pdp-gallery-main img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s ease;}
.pdp-gallery-main:hover img{transform:scale(1.08);}
.pdp-thumbs{display:flex;gap:12px;}
.pdp-thumbs div{width:78px;height:78px;background:var(--cream);border:1px solid var(--line);cursor:pointer;overflow:hidden;}
.pdp-thumbs img{width:100%;height:100%;object-fit:cover;}
.pdp-info .eyebrow{display:block;margin-bottom:10px;}
.pdp-info h1{font-size:clamp(26px,3.4vw,36px);margin-bottom:14px;}
.pdp-rating{font-size:13px;color:var(--gold-dark);margin-bottom:18px;}
.pdp-price{font-size:24px;font-family:'Playfair Display',serif;margin-bottom:6px;}
.pdp-price .strike{font-size:16px;text-decoration:line-through;color:var(--ink-soft);margin-right:10px;}
.pdp-tax{font-size:12px;color:var(--ink-soft);margin-bottom:28px;}
.pdp-desc{color:var(--ink-soft);line-height:1.8;margin-bottom:28px;font-size:15px;}
.pdp-row{display:flex;gap:14px;margin-bottom:28px;}
.qty{display:flex;align-items:center;border:1px solid var(--ink);}
.qty button{width:40px;height:48px;background:none;border:none;cursor:pointer;font-size:16px;}
.qty span{width:36px;text-align:center;font-size:14px;}
.pdp-actions{display:flex;gap:14px;margin-bottom:36px;}
.pdp-actions .btn{flex:1;justify-content:center;}
.spec-table{width:100%;border-collapse:collapse;font-size:14px;margin-bottom:30px;}
.spec-table tr{border-bottom:1px solid var(--line);}
.spec-table td{padding:12px 0;color:var(--ink-soft);}
.spec-table td:first-child{width:160px;text-transform:uppercase;letter-spacing:.06em;font-size:11px;color:var(--ink);}
.trust-mini{display:flex;gap:24px;font-size:12px;color:var(--ink-soft);flex-wrap:wrap;}
.trust-mini span{display:flex;align-items:center;gap:6px;}
@media (max-width:880px){.pdp-grid{grid-template-columns:1fr;}}

/* ---------- about page ---------- */
.about-hero{padding:70px 0;text-align:center;}
.about-hero h1{font-size:clamp(34px,5vw,54px);margin-bottom:18px;}
.about-hero p{color:var(--ink-soft);max-width:600px;margin:0 auto;line-height:1.8;}
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;padding:60px 0;}
.about-split img{aspect-ratio:4/5;object-fit:cover;width:100%;}
.about-split.reverse{direction:rtl;}
.about-split.reverse > *{direction:ltr;}
.about-split h2{font-size:clamp(24px,3.4vw,32px);margin-bottom:18px;}
.about-split p{color:var(--ink-soft);line-height:1.85;font-size:15px;}
@media (max-width:880px){.about-split,.about-split.reverse{grid-template-columns:1fr;direction:ltr;}}

.values{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;padding:30px 0 100px;}
.value-card{text-align:center;padding:40px 24px;border:1px solid var(--line);}
.value-card .ic{font-size:26px;color:var(--gold-dark);margin-bottom:14px;}
.value-card h3{font-size:17px;margin-bottom:10px;}
.value-card p{font-size:14px;color:var(--ink-soft);line-height:1.7;}
@media (max-width:880px){.values{grid-template-columns:1fr;}}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;padding:70px 0 100px;}
.contact-form label{display:block;font-size:12px;letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px;color:var(--ink-soft);}
.contact-form input,.contact-form textarea{
  width:100%;padding:13px 14px;margin-bottom:22px;border:1px solid var(--line);
  background:var(--ivory);font-family:inherit;font-size:14px;
}
.contact-info h3{margin-bottom:14px;font-size:20px;}
.contact-info p{color:var(--ink-soft);line-height:1.9;margin-bottom:26px;font-size:15px;}
.contact-info .item{margin-bottom:22px;}
.contact-info .item span{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--gold-dark);margin-bottom:4px;}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr;}}

/* ---------- whatsapp float ---------- */
.float-wa{
  position:fixed;bottom:24px;right:24px;z-index:60;
  width:54px;height:54px;border-radius:50%;
  background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;box-shadow:0 8px 20px rgba(0,0,0,.2);
}
