
:root{
  --black:#050505;
  --cream:#f5f3ef;
  --white:#fff;
  --text:#0c0908;
  --muted:#6c6862;
  --line:rgba(0,0,0,.12);
}

*{box-sizing:border-box;margin:0;padding:0}

body{
  font-family:"Helvetica Neue", Helvetica, Arial, sans-serif;
  background:var(--cream);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

h1,h2,h3,p,a,span,button,label,input,select,textarea{
  text-shadow:none;
}

a{color:inherit;text-decoration:none}
img{display:block;width:100%;height:100%;object-fit:cover}

.site-header{
  height:96px;
  background:var(--black);
  color:var(--white);
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 48px;
  position:sticky;
  top:0;
  z-index:10;
}

.brand{
  display:flex;
  align-items:center;
  gap:18px;
}

.logo-main{
  font-size:42px;
  font-weight:800;
  letter-spacing:-3px;
  line-height:1;
}

.logo-divider{
  width:1px;
  height:38px;
  background:rgba(255,255,255,.45);
}

.logo-sub{
  font-size:10px;
  line-height:1.6;
  letter-spacing:2.5px;
  text-transform:uppercase;
  font-weight:300;
}

.main-nav{
  display:flex;
  gap:34px;
  align-items:center;
}

.main-nav a{
  font-size:13px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.8px;
}

.main-nav a:hover,
.main-nav a.active{
  border-bottom:1px solid currentColor;
  padding-bottom:5px;
}

.mobile-toggle{
  display:none;
  background:none;
  border:0;
  color:white;
  font-size:30px;
}

.hero{
  min-height:720px;
  background:
    linear-gradient(to right, rgba(0,0,0,.20), rgba(0,0,0,.02)),
    url("../images/hero.jpg") center/cover no-repeat;
  color:white;
  display:flex;
  align-items:center;
  padding:72px 68px;
}

.hero-content{
  max-width:560px;
}

.hero h1{
  font-size:76px;
  line-height:.94;
  letter-spacing:-2px;
  text-transform:uppercase;
}

.eyebrow{
  margin:22px 0 10px;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:2.5px;
  font-weight:700;
}

.lead{
  max-width:420px;
  font-size:18px;
  line-height:1.55;
}

.actions{
  margin-top:34px;
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
  padding:0 28px;
  border:1px solid currentColor;
  font-size:13px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.7px;
  background:transparent;
  font-family:inherit;
  cursor:pointer;
}

.btn.light{background:white;color:#050505;border-color:white}
.btn.dark{background:#050505;color:white;border-color:#050505}

.benefits{
  background:#050505;
  color:white;
  display:grid;
  grid-template-columns:repeat(4,1fr);
}

.benefit{
  padding:34px 42px;
  border-right:1px solid rgba(255,255,255,.15);
}

.benefit:last-child{border-right:0}

.icon-circle{
  width:42px;
  height:42px;
  border:1px solid white;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:16px;
}

.benefit h3{
  font-size:15px;
  text-transform:uppercase;
  margin-bottom:8px;
}

.benefit p{
  color:#d8d8d8;
  font-size:14px;
  line-height:1.55;
}

.section{
  padding:82px 64px;
}

.product-section{
  display:grid;
  grid-template-columns:1fr 2fr;
  gap:52px;
}

.section-kicker{
  display:inline-flex;
  align-items:center;
  gap:16px;
  text-transform:uppercase;
  font-size:13px;
  letter-spacing:2px;
  font-weight:700;
}

.section-kicker:after{
  content:"";
  width:70px;
  height:1px;
  background:#111;
  display:block;
}

h1,h2,h3{font-weight:800}

.product-copy h2,
.page-hero h1,
.story-block h2,
.store-box h1,
.contact-card h1{
  font-size:46px;
  line-height:1.05;
  letter-spacing:-1px;
  text-transform:uppercase;
  margin:18px 0;
}

.product-copy p,
.page-hero p,
.story-block p,
.store-box p,
.contact-card p{
  line-height:1.75;
  font-size:16px;
  margin-bottom:22px;
}

.check-list{
  list-style:none;
  margin:22px 0 32px;
}

.check-list li{
  margin-bottom:12px;
  font-size:15px;
}

.check-list li:before{
  content:"✓";
  width:20px;
  height:20px;
  border:1px solid #111;
  border-radius:50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-right:10px;
  font-size:12px;
}

.product-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.image-card{
  min-height:430px;
  border-radius:14px;
  overflow:hidden;
  position:relative;
  border:1px solid rgba(0,0,0,.08);
}

.image-card span{
  position:absolute;
  left:22px;
  bottom:20px;
  color:white;
  background:rgba(0,0,0,.72);
  padding:8px 10px;
  text-transform:uppercase;
  font-size:12px;
  font-weight:800;
  letter-spacing:.8px;
  text-shadow:none;
}

.story-home{
  background:#050505;
  color:white;
  display:grid;
  grid-template-columns:1fr 1fr;
}

.story-block{
  padding:88px 64px;
}

.story-block p{
  color:#ddd;
}

.story-image{
  min-height:480px;
}

.page-hero{
  background:#050505;
  color:white;
  padding:88px 64px;
}

.page-hero p{
  color:#ddd;
  max-width:780px;
}

.timeline-wrap{
  padding:74px 64px;
}

.timeline-intro{
  max-width:860px;
  margin-bottom:48px;
}

.timeline-intro h2{
  font-size:42px;
  text-transform:uppercase;
  margin:18px 0;
}

.timeline-intro p{
  line-height:1.75;
}

.timeline{
  max-width:920px;
  margin:auto;
  position:relative;
}

.timeline:before{
  content:"";
  position:absolute;
  left:140px;
  top:0;
  bottom:0;
  width:1px;
  background:#111;
}

.timeline-item{
  display:grid;
  grid-template-columns:120px 1fr;
  gap:54px;
  padding-bottom:44px;
  position:relative;
}

.timeline-date{
  font-size:18px;
  font-weight:800;
}

.timeline-content{
  background:white;
  padding:28px;
  border:1px solid var(--line);
}

.timeline-content:before{
  content:"";
  position:absolute;
  left:133px;
  margin-top:8px;
  width:15px;
  height:15px;
  border-radius:50%;
  background:#111;
}

.timeline-content h3{
  text-transform:uppercase;
  margin-bottom:10px;
}

.timeline-content p{
  line-height:1.65;
  color:#333;
}

.store-placeholder{
  min-height:640px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:80px 24px;
}

.store-box{
  max-width:860px;
  background:white;
  border:1px solid #111;
  padding:70px 46px;
}

.shopify-box{
  margin-top:30px;
  background:#f3f3f3;
  border:1px dashed #999;
  padding:34px;
  color:#555;
  line-height:1.6;
}

.blog-list{
  padding:70px 64px;
  max-width:980px;
  margin:auto;
}

.blog-item{
  border-bottom:1px solid rgba(0,0,0,.2);
}

.blog-toggle{
  width:100%;
  border:0;
  background:none;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:28px 0;
  cursor:pointer;
  font-family:inherit;
  text-align:left;
}

.blog-date{
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:1.5px;
  color:#777;
}

.blog-title{
  display:block;
  font-size:28px;
  text-transform:uppercase;
  font-weight:800;
  margin-top:7px;
}

.blog-plus{
  font-size:34px;
  font-weight:200;
}

.blog-content{
  display:none;
  padding:0 0 34px;
  max-width:760px;
  line-height:1.8;
  color:#333;
}

.blog-item.open .blog-content{display:block}
.blog-item.open .blog-plus{transform:rotate(45deg)}

.contact-wrap{
  padding:74px 64px;
  display:grid;
  grid-template-columns:1fr 1.3fr;
  gap:56px;
}

.contact-card,
.contact-form{
  background:white;
  padding:42px;
  border:1px solid var(--line);
}

.form-row{
  margin-bottom:18px;
}

label{
  display:block;
  text-transform:uppercase;
  font-size:12px;
  letter-spacing:1.2px;
  margin-bottom:8px;
  font-weight:700;
}

input,select,textarea{
  width:100%;
  padding:15px;
  border:1px solid #c8c8c8;
  font-family:inherit;
  font-size:15px;
}

textarea{
  min-height:170px;
}

.site-footer{
  background:#f5f3ef;
  padding:46px 64px;
  border-top:1px solid rgba(0,0,0,.08);
  display:grid;
  grid-template-columns:1.4fr 2fr;
  gap:30px;
  align-items:center;
}

.site-footer .logo-sub{color:#111}
.site-footer .logo-divider{background:rgba(0,0,0,.22)}

.footer-links{
  display:flex;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:14px;
  font-size:13px;
  color:#555;
}

@media(max-width:980px){
  .site-header{padding:0 22px}
  .main-nav{display:none;position:absolute;left:0;right:0;top:96px;background:#050505;flex-direction:column;align-items:flex-start;padding:24px}
  .main-nav.open{display:flex}
  .mobile-toggle{display:block}
  .logo-main{font-size:34px}
  .logo-sub,.logo-divider{display:none}
  .hero{padding:48px 24px;min-height:640px}
  .hero h1{font-size:50px}
  .benefits,.product-section,.story-home,.contact-wrap,.site-footer{grid-template-columns:1fr}
  .benefit{border-right:0;border-bottom:1px solid rgba(255,255,255,.14)}
  .section,.page-hero,.timeline-wrap,.blog-list,.contact-wrap{padding:48px 24px}
  .product-grid{grid-template-columns:1fr}
  .image-card{min-height:340px}
  .timeline:before{left:0}
  .timeline-item{grid-template-columns:1fr;gap:16px;padding-left:26px}
  .timeline-content:before{left:-7px}
  .footer-links{justify-content:flex-start}
}


/* Final clean homepage image treatment */
.image-card span{
  display:none !important;
}

.hero h1,
.hero .eyebrow,
.hero .lead,
.product-copy h2,
.product-copy p,
.product-copy li,
.story-block h2,
.story-block p{
  text-shadow:none !important;
  filter:none !important;
}

.hero{
  background-position:center center;
}

.image-card img,
.story-image img{
  filter:none !important;
}


/* ---------- Refinements requested ---------- */

/* Make adapted pants images consistent */
.product-grid{
  align-items:stretch;
}

.image-card{
  height:430px !important;
  min-height:430px !important;
}

.image-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}

/* Header image pages */
.page-hero.image-hero{
  min-height:520px;
  display:flex;
  align-items:center;
  background-size:cover;
  background-position:center;
  position:relative;
  padding:88px 64px;
}

.page-hero.image-hero:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to right, rgba(0,0,0,.72), rgba(0,0,0,.18));
}

.page-hero.image-hero > *{
  position:relative;
  z-index:1;
}

.page-hero.image-hero .page-hero-inner{
  max-width:720px;
  text-align:left;
}

.our-story-hero{
  background-image:url("../images/story.jpg");
}

.blog-hero{
  background-image:url("../images/hero.jpg");
}

.contact-hero{
  background-image:url("../images/contact-header.jpg");
  background-position:center center;
}

/* Minimal expandable timeline */
.timeline{
  max-width:980px;
}

.timeline:before,
.timeline-content:before{
  display:none !important;
}

.timeline-item{
  display:block;
  padding:0;
  border-bottom:1px solid rgba(0,0,0,.18);
}

.timeline-toggle{
  width:100%;
  border:0;
  background:transparent;
  display:grid;
  grid-template-columns:120px 1fr auto;
  gap:28px;
  align-items:center;
  padding:26px 0;
  text-align:left;
  font-family:inherit;
  cursor:pointer;
}

.timeline-date{
  font-size:15px;
  letter-spacing:1.2px;
  text-transform:uppercase;
  color:#777;
}

.timeline-title{
  font-size:24px;
  line-height:1.1;
  text-transform:uppercase;
  font-weight:800;
  letter-spacing:-.3px;
}

.timeline-plus{
  font-size:32px;
  font-weight:200;
  transition:.2s ease;
}

.timeline-content{
  display:none;
  background:transparent;
  border:0;
  padding:0 0 30px 148px;
}

.timeline-item.open .timeline-content{
  display:block;
}

.timeline-item.open .timeline-plus{
  transform:rotate(45deg);
}

/* Blog full post link */
.blog-actions{
  margin-top:22px;
}

.read-full{
  display:inline-flex;
  text-transform:uppercase;
  font-weight:800;
  font-size:13px;
  letter-spacing:.7px;
  border-bottom:1px solid #111;
  padding-bottom:5px;
}

/* Blog post pages */
.post-wrap{
  padding:76px 64px;
  max-width:920px;
  margin:0 auto;
}

.post-meta{
  text-transform:uppercase;
  font-size:13px;
  letter-spacing:1.6px;
  color:#777;
  margin-bottom:18px;
}

.post-wrap h1{
  font-size:56px;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:-1.5px;
  margin-bottom:32px;
}

.post-wrap p{
  font-size:17px;
  line-height:1.85;
  margin-bottom:22px;
  color:#252525;
}

.post-hero-img{
  height:420px;
  border-radius:14px;
  overflow:hidden;
  margin:34px 0;
}

@media(max-width:980px){
  .image-card{
    height:360px !important;
    min-height:360px !important;
  }

  .page-hero.image-hero{
    padding:58px 24px;
    min-height:460px;
  }

  .timeline-toggle{
    grid-template-columns:1fr auto;
    gap:16px;
  }

  .timeline-date{
    grid-column:1/-1;
  }

  .timeline-content{
    padding:0 0 28px 0;
  }

  .post-wrap{
    padding:48px 24px;
  }

  .post-wrap h1{
    font-size:40px;
  }
}


/* Refinement: blog full posts are text-only */
.post-wrap .post-hero-img{
  display:none !important;
}

.contact-hero{
  background-size:cover !important;
  background-repeat:no-repeat !important;
}


/* ---------- Legal pages ---------- */
.legal-wrap{
  max-width:980px;
  margin:0 auto;
  padding:76px 64px;
}

.legal-wrap h1{
  font-size:52px;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:-1.2px;
  margin-bottom:24px;
}

.legal-wrap h2{
  font-size:24px;
  text-transform:uppercase;
  margin:38px 0 14px;
}

.legal-wrap p,
.legal-wrap li{
  font-size:16px;
  line-height:1.8;
  color:#2a2a2a;
  margin-bottom:12px;
}

.legal-wrap ul{
  margin-left:22px;
  margin-bottom:22px;
}

.legal-note{
  padding:18px 20px;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  margin:26px 0;
  font-size:14px;
  color:#555;
}

@media(max-width:980px){
  .legal-wrap{
    padding:48px 24px;
  }

  .legal-wrap h1{
    font-size:38px;
  }
}
