/* ===== Design tokens ===== */
:root{
  --charcoal:#1c1b19;
  --charcoal-soft:#2a2824;
  --cream:#f6f1e8;
  --cream-dark:#ece4d6;
  --wood:#7a5230;
  --wood-dark:#5c3c22;
  --ember:#c0703a;
  --ember-dark:#a4582a;
  --text:#2b2520;
  --text-muted:#6b6256;
  --white:#ffffff;
  --border:#ded4c2;
  --radius:2px;
  --serif:'Fraunces', Georgia, serif;
  --sans:'Work Sans', Arial, sans-serif;
  --maxw:1280px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--text);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{margin:0;padding:0;list-style:none;}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;margin:0;letter-spacing:.2px;}
p{margin:0;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 32px;}
section{position:relative;}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 30px;font-family:var(--sans);font-size:13px;font-weight:600;
  letter-spacing:1.5px;text-transform:uppercase;border:1px solid var(--charcoal);
  border-radius:var(--radius);cursor:pointer;transition:all .25s ease;background:transparent;color:var(--charcoal);
}
.btn-dark{background:var(--charcoal);color:var(--cream);border-color:var(--charcoal);}
.btn-dark:hover{background:var(--wood-dark);border-color:var(--wood-dark);}
.btn-ember{background:var(--ember);color:#fff;border-color:var(--ember);}
.btn-ember:hover{background:var(--ember-dark);border-color:var(--ember-dark);}
.btn-outline-light{border-color:#fff;color:#fff;}
.btn-outline-light:hover{background:#fff;color:var(--charcoal);}
.btn-block{width:100%;}

/* ===== Top announcement bar ===== */
.announce-bar{
  background:var(--charcoal);color:var(--cream);
  text-align:center;font-size:12.5px;letter-spacing:.6px;
  padding:9px 16px;font-weight:500;
}
.announce-bar span{color:var(--ember);font-weight:700;}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:500;background:var(--cream);
  border-bottom:1px solid var(--border);
}
.nav-main{
  max-width:var(--maxw);margin:0 auto;padding:18px 32px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.nav-logo{font-family:var(--serif);font-size:26px;font-weight:700;letter-spacing:.5px;white-space:nowrap;}
.nav-logo span{color:var(--ember);}
.nav-links{display:flex;align-items:center;gap:34px;}
.nav-links>li{position:relative;}
.nav-links a{font-size:13.5px;font-weight:600;letter-spacing:.7px;text-transform:uppercase;padding:6px 0;}
.nav-links a:hover{color:var(--ember);}
.nav-right{display:flex;align-items:center;gap:18px;}
.nav-icon-btn{
  background:none;border:none;font-size:18px;cursor:pointer;color:var(--charcoal);
  position:relative;padding:4px;
}
.cart-dot{
  position:absolute;top:-2px;right:-4px;background:var(--ember);color:#fff;
  font-size:10px;font-weight:700;border-radius:50%;width:16px;height:16px;
  display:flex;align-items:center;justify-content:center;
}
.hamburger{display:none;background:none;border:none;font-size:22px;cursor:pointer;}

/* dropdown */
.has-dropdown{position:relative;}
.dropdown{
  position:absolute;top:calc(100% + 18px);left:50%;transform:translateX(-50%);
  background:var(--white);border:1px solid var(--border);min-width:560px;
  display:none;padding:28px;gap:36px;box-shadow:0 18px 40px rgba(0,0,0,.12);
}
.has-dropdown:hover .dropdown{display:flex;}
.dropdown-col h4{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);margin-bottom:14px;}
.dropdown-col a{display:block;font-size:14px;font-weight:500;text-transform:none;letter-spacing:0;padding:6px 0;}
.dropdown-col a:hover{color:var(--ember);}
.dropdown-promo{width:200px;}
.dropdown-promo img{height:130px;object-fit:cover;border-radius:var(--radius);}
.dropdown-promo p{margin-top:10px;font-size:13px;font-weight:600;}

.mobile-nav-overlay{
  position:fixed;inset:0;background:var(--charcoal);z-index:900;
  display:flex;flex-direction:column;gap:22px;padding:90px 32px 32px;
  transform:translateX(-100%);transition:transform .35s ease;
}
.mobile-nav-overlay.open{transform:translateX(0);}
.mobile-nav-overlay a{color:var(--cream);font-size:20px;font-family:var(--serif);}
.mobile-nav-close{position:absolute;top:24px;right:24px;background:none;border:none;color:var(--cream);font-size:28px;cursor:pointer;}

/* ===== Hero ===== */
.hero{
  position:relative;height:88vh;min-height:560px;overflow:hidden;
  display:flex;align-items:center;
}
.hero-slide{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transition:opacity 1s ease;
}
.hero-slide.active{opacity:1;}
.hero-video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,18,15,.45) 0%,rgba(20,18,15,.15) 45%,rgba(20,18,15,.55) 100%);}
.hero-content{position:relative;z-index:2;color:#fff;max-width:var(--maxw);margin:0 auto;padding:0 32px;width:100%;}
.hero-content .eyebrow{display:inline-block;font-size:12.5px;letter-spacing:2.5px;text-transform:uppercase;color:var(--cream);opacity:.85;margin-bottom:18px;}
.hero-content h1{font-size:clamp(38px,6vw,72px);line-height:1.05;max-width:680px;margin-bottom:18px;}
.hero-content p.sub{font-size:18px;max-width:480px;margin-bottom:32px;color:rgba(255,255,255,.9);}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;}
.hero-arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:3;
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.4);color:#fff;
  width:44px;height:44px;border-radius:50%;cursor:pointer;font-size:20px;
}
.hero-arrow.left{left:24px;}.hero-arrow.right{right:24px;}
.hero-dots{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:3;}
.hero-dots span{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;}
.hero-dots span.active{background:#fff;}

/* ===== USP strip ===== */
.usp-strip{background:var(--charcoal);color:var(--cream);}
.usp-strip .container{
  display:grid;grid-template-columns:repeat(4,1fr);
  padding:26px 32px;gap:20px;
}
.usp-item{display:flex;align-items:center;gap:12px;font-size:13px;letter-spacing:.3px;}
.usp-item .icon{font-size:22px;color:var(--ember);}

/* ===== Section heading ===== */
.section-head{text-align:center;max-width:640px;margin:0 auto 48px;}
.section-head .eyebrow{display:block;font-size:12px;letter-spacing:2.5px;text-transform:uppercase;color:var(--ember);font-weight:700;margin-bottom:12px;}
.section-head h2{font-size:clamp(28px,4vw,42px);margin-bottom:14px;}
.section-head p{color:var(--text-muted);font-size:15.5px;line-height:1.6;}

.section-pad{padding:88px 0;}

/* ===== Category grid ===== */
.category-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.category-cell{position:relative;display:block;height:420px;overflow:hidden;border-radius:var(--radius);}
.category-cell .img-box{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .6s ease;}
.category-cell:hover .img-box{transform:scale(1.06);}
.category-cell::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 40%,rgba(0,0,0,.65) 100%);}
.category-cell .cat-label{position:absolute;left:24px;bottom:24px;z-index:2;color:#fff;}
.category-cell .cat-label h3{font-size:24px;margin-bottom:6px;}
.category-cell .cat-label span{font-size:13px;letter-spacing:.6px;text-decoration:underline;}

/* ===== Product grid ===== */
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.product-card{display:block;background:var(--white);border:1px solid var(--border);overflow:hidden;transition:box-shadow .25s ease;}
.product-card:hover{box-shadow:0 16px 32px rgba(0,0,0,.08);}
.product-card .thumb{position:relative;height:280px;overflow:hidden;}
.product-card .thumb img,.product-card .thumb .img-box{width:100%;height:100%;object-fit:cover;background-size:cover;background-position:center;transition:transform .5s ease;}
.product-card:hover .thumb img,.product-card:hover .thumb .img-box{transform:scale(1.05);}
.badge{position:absolute;top:14px;left:14px;background:var(--ember);color:#fff;font-size:11px;font-weight:700;letter-spacing:.6px;padding:5px 10px;border-radius:var(--radius);}
.product-card .info{padding:22px;}
.product-card .cap{font-size:11.5px;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px;}
.product-card h3{font-size:19px;margin-bottom:10px;}
.price-row{display:flex;align-items:baseline;gap:10px;}
.price-now{font-size:18px;font-weight:700;color:var(--wood-dark);}
.price-was{font-size:14px;color:var(--text-muted);text-decoration:line-through;}
.stars{color:var(--ember);font-size:13px;margin-top:8px;}

/* ===== Story / split section ===== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.split .img-box{height:520px;background-size:cover;background-position:center;border-radius:var(--radius);}
.split-text .eyebrow{display:block;font-size:12px;letter-spacing:2.5px;text-transform:uppercase;color:var(--ember);font-weight:700;margin-bottom:14px;}
.split-text h2{font-size:clamp(26px,3.6vw,38px);margin-bottom:18px;line-height:1.15;}
.split-text p{color:var(--text-muted);font-size:15.5px;line-height:1.75;margin-bottom:16px;}
.feature-list{margin-top:24px;display:flex;flex-direction:column;gap:14px;}
.feature-list li{display:flex;gap:12px;font-size:15px;align-items:flex-start;}
.feature-list li .tick{color:var(--ember);font-weight:700;}

.split.reverse{grid-template-columns:1fr 1fr;}
.split.reverse .img-box{order:2;}
.split.reverse .split-text{order:1;}

/* ===== Testimonials ===== */
.testimonial-strip{background:var(--cream-dark);}
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.testimonial-card{background:var(--white);padding:32px;border:1px solid var(--border);}
.testimonial-card .stars{margin-bottom:14px;}
.testimonial-card p.quote{font-size:15px;line-height:1.7;color:var(--text);margin-bottom:20px;}
.testimonial-card .who{font-size:13px;font-weight:700;letter-spacing:.4px;}
.testimonial-card .who span{display:block;font-weight:400;color:var(--text-muted);font-size:12.5px;margin-top:2px;}

/* ===== FAQ ===== */
.faq-list{max-width:760px;margin:0 auto;}
.faq-item{border-bottom:1px solid var(--border);}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:22px 4px;cursor:pointer;font-weight:600;font-size:15.5px;}
.faq-q .plus{font-size:20px;color:var(--ember);transition:transform .25s ease;}
.faq-item.open .faq-q .plus{transform:rotate(45deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.faq-item.open .faq-a{max-height:300px;}
.faq-a p{padding:0 4px 22px;color:var(--text-muted);font-size:14.5px;line-height:1.7;}

/* ===== Newsletter / CTA ===== */
.cta-banner{background:var(--wood-dark);color:var(--cream);text-align:center;padding:80px 32px;}
.cta-banner h2{font-size:clamp(26px,4vw,40px);margin-bottom:16px;color:#fff;}
.cta-banner p{color:rgba(246,241,232,.85);margin-bottom:30px;font-size:15.5px;}
.newsletter-form{display:flex;justify-content:center;gap:0;max-width:460px;margin:0 auto;}
.newsletter-form input{flex:1;padding:15px 18px;border:1px solid transparent;font-size:14px;background:#fff;color:var(--text);}
.newsletter-form button{padding:15px 26px;border:none;background:var(--ember);color:#fff;font-weight:700;letter-spacing:1px;text-transform:uppercase;font-size:12.5px;cursor:pointer;}
.newsletter-form button:hover{background:var(--ember-dark);}

/* ===== Instagram strip ===== */
.insta-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;}
.insta-grid .img-box{height:160px;background-size:cover;background-position:center;}

/* ===== Footer ===== */
.site-footer{background:var(--charcoal);color:rgba(246,241,232,.75);}
.footer-top{padding:72px 32px 48px;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1.3fr;gap:40px;}
.footer-brand h3{color:var(--cream);font-size:24px;margin-bottom:14px;}
.footer-brand p{font-size:13.5px;line-height:1.7;max-width:260px;}
.footer-social{display:flex;gap:14px;margin-top:18px;}
.footer-social a{width:36px;height:36px;border:1px solid rgba(246,241,232,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;}
.footer-social a:hover{background:var(--ember);border-color:var(--ember);}
.footer-col h4{color:var(--cream);font-size:13px;letter-spacing:1px;text-transform:uppercase;margin-bottom:18px;}
.footer-col a{display:block;font-size:14px;padding:6px 0;color:rgba(246,241,232,.75);}
.footer-col a:hover{color:var(--ember);}
.footer-col p{font-size:14px;line-height:1.8;}
.footer-newsletter input{width:100%;padding:13px 14px;border:1px solid rgba(246,241,232,.25);background:transparent;color:var(--cream);font-size:13.5px;margin-bottom:10px;}
.footer-newsletter input::placeholder{color:rgba(246,241,232,.5);}
.footer-bottom{border-top:1px solid rgba(246,241,232,.15);padding:22px 32px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12.5px;}

/* ===== Page header (shop/about/contact) ===== */
.page-header{
  background:linear-gradient(180deg,rgba(20,18,15,.55),rgba(20,18,15,.55)),url('https://images.unsplash.com/photo-1571055107559-3e67626fa8be?q=80&w=1600&auto=format&fit=crop') center/cover;
  padding:120px 32px 60px;color:#fff;text-align:center;
}
.page-header h1{font-size:clamp(32px,5vw,52px);margin-bottom:12px;}
.breadcrumb{font-size:13px;letter-spacing:.6px;opacity:.85;text-transform:uppercase;}
.breadcrumb a{text-decoration:underline;}

/* ===== Shop filters ===== */
.shop-layout{display:grid;grid-template-columns:240px 1fr;gap:40px;}
.filter-block{margin-bottom:32px;}
.filter-block h4{font-size:13px;letter-spacing:.8px;text-transform:uppercase;margin-bottom:14px;}
.filter-block label{display:flex;align-items:center;gap:10px;font-size:14.5px;padding:6px 0;cursor:pointer;}
.shop-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;border-bottom:1px solid var(--border);padding-bottom:18px;}
.shop-toolbar select{padding:8px 12px;border:1px solid var(--border);background:#fff;font-size:13.5px;}
.shop-grid-wrap .product-grid{grid-template-columns:repeat(3,1fr);}

/* ===== Product detail ===== */
.product-detail{display:grid;grid-template-columns:1fr 1fr;gap:56px;padding:64px 0;}
.gallery-main{height:520px;background-size:cover;background-position:center;border-radius:var(--radius);margin-bottom:14px;}
.gallery-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;}
.gallery-thumbs .img-box{height:90px;background-size:cover;background-position:center;cursor:pointer;border:2px solid transparent;}
.gallery-thumbs .img-box.active{border-color:var(--ember);}
.pd-title h1{font-size:30px;margin-bottom:10px;}
.pd-price{display:flex;align-items:baseline;gap:12px;margin:14px 0 18px;}
.pd-price .now{font-size:26px;font-weight:700;color:var(--wood-dark);}
.pd-price .was{font-size:16px;text-decoration:line-through;color:var(--text-muted);}
.pd-save{display:inline-block;background:#e9f3ea;color:#2e6b3a;font-size:12px;font-weight:700;padding:4px 10px;border-radius:var(--radius);margin-bottom:18px;}
.pd-desc{color:var(--text-muted);font-size:14.5px;line-height:1.75;margin-bottom:24px;}
.option-group{margin-bottom:22px;}
.option-group h4{font-size:12.5px;letter-spacing:.8px;text-transform:uppercase;margin-bottom:10px;}
.option-pills{display:flex;gap:10px;flex-wrap:wrap;}
.option-pill{padding:10px 18px;border:1px solid var(--border);font-size:13.5px;cursor:pointer;border-radius:var(--radius);}
.option-pill.active{border-color:var(--charcoal);background:var(--charcoal);color:#fff;}
.qty-row{display:flex;align-items:center;gap:16px;margin:22px 0;}
.qty-control{display:flex;align-items:center;border:1px solid var(--border);}
.qty-control button{width:38px;height:42px;border:none;background:none;font-size:16px;cursor:pointer;}
.qty-control input{width:42px;text-align:center;border:none;font-size:14px;}
.pd-actions{display:flex;flex-direction:column;gap:12px;}
.pd-trust{display:flex;flex-wrap:wrap;gap:18px;margin-top:26px;font-size:13px;color:var(--text-muted);}
.pd-trust span{display:flex;align-items:center;gap:6px;}
.accordion-group{margin-top:32px;border-top:1px solid var(--border);}

/* ===== About ===== */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.value-card{text-align:center;padding:36px 24px;background:var(--white);border:1px solid var(--border);}
.value-card .icon{font-size:30px;color:var(--ember);margin-bottom:16px;}
.value-card h3{font-size:18px;margin-bottom:10px;}
.value-card p{font-size:14px;color:var(--text-muted);line-height:1.7;}

.stats-row{display:grid;grid-template-columns:repeat(4,1fr);text-align:center;}
.stats-row .stat h3{font-size:40px;color:var(--ember);margin-bottom:6px;}
.stats-row .stat p{font-size:13px;letter-spacing:.5px;text-transform:uppercase;color:var(--text-muted);}

/* ===== Contact ===== */
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:56px;}
.contact-form-card{background:var(--white);border:1px solid var(--border);padding:40px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;}
.form-field{margin-bottom:16px;}
.form-field label{display:block;font-size:12.5px;letter-spacing:.5px;text-transform:uppercase;margin-bottom:8px;font-weight:600;}
.form-field input,.form-field textarea,.form-field select{
  width:100%;padding:13px 14px;border:1px solid var(--border);font-size:14.5px;font-family:var(--sans);background:#fff;
}
.contact-info-card{display:flex;flex-direction:column;gap:28px;}
.info-item{display:flex;gap:16px;align-items:flex-start;}
.info-item .icon{font-size:22px;color:var(--ember);margin-top:2px;}
.info-item h4{font-size:15px;margin-bottom:4px;}
.info-item p{font-size:14px;color:var(--text-muted);line-height:1.6;}
.map-box{height:260px;background:#ddd6c6 url('https://images.unsplash.com/photo-1524661135-423995f22d0b?q=80&w=900&auto=format&fit=crop') center/cover;border-radius:var(--radius);}

/* ===== Cart sidebar ===== */
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:998;opacity:0;pointer-events:none;transition:opacity .3s ease;}
.cart-overlay.open{opacity:1;pointer-events:auto;}
.cart-sidebar{
  position:fixed;top:0;right:0;height:100%;width:400px;max-width:92vw;background:#fff;z-index:999;
  transform:translateX(100%);transition:transform .35s ease;display:flex;flex-direction:column;
}
.cart-sidebar.open{transform:translateX(0);}
.cart-header{display:flex;justify-content:space-between;align-items:center;padding:22px 24px;border-bottom:1px solid var(--border);}
.cart-close{background:none;border:none;font-size:26px;cursor:pointer;}
.cart-items{flex:1;overflow-y:auto;padding:20px 24px;}
.cart-empty{color:var(--text-muted);font-size:14px;text-align:center;margin-top:40px;}
.cart-line{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--border);}
.cart-line .img-box{width:74px;height:74px;background-size:cover;background-position:center;border-radius:var(--radius);}
.cart-line .meta{flex:1;}
.cart-line h5{font-size:14px;margin-bottom:4px;}
.cart-line .cl-price{font-size:13.5px;color:var(--text-muted);}
.cart-line .remove{font-size:12px;color:var(--ember);cursor:pointer;text-decoration:underline;margin-top:6px;display:inline-block;}
.cart-footer{padding:22px 24px;border-top:1px solid var(--border);}
.cart-subtotal{display:flex;justify-content:space-between;font-size:15px;font-weight:700;margin-bottom:16px;}

.scroll-top-btn{
  position:fixed;bottom:28px;right:28px;width:46px;height:46px;border-radius:50%;
  background:var(--charcoal);color:#fff;border:none;font-size:18px;cursor:pointer;
  opacity:0;pointer-events:none;transition:opacity .25s ease;z-index:400;
}
.scroll-top-btn.show{opacity:1;pointer-events:auto;}

/* ===== Responsive ===== */
@media(max-width:1024px){
  .product-grid,.category-grid{grid-template-columns:repeat(2,1fr);}
  .footer-top{grid-template-columns:1fr 1fr;}
  .split,.contact-layout,.product-detail{grid-template-columns:1fr;gap:32px;}
  .split .img-box{height:360px;}
  .split.reverse .img-box,.split.reverse .split-text{order:initial;}
  .testimonial-grid,.values-grid{grid-template-columns:1fr;}
  .stats-row{grid-template-columns:repeat(2,1fr);gap:24px;}
  .usp-strip .container{grid-template-columns:repeat(2,1fr);}
  .shop-layout{grid-template-columns:1fr;}
  .insta-grid{grid-template-columns:repeat(3,1fr);}
}
@media(max-width:760px){
  .nav-links,.nav-right .help-link{display:none;}
  .hamburger{display:block;}
  .product-grid,.category-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr;padding:48px 24px;}
  .hero-content h1{font-size:32px;}
}
