/*
Theme Name: Nature's Labels
Theme URI: https://example.com
Author: Nature's Labels
Author URI: https://example.com
Description: Truly organic private-label skincare/haircare/supplements landing theme. Converted from a static design into a WordPress theme.
Version: 1.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: natures-labels
*/

:root{
  --green-950:#0f2417;
  --green-900:#14301f;
  --green-800:#1a3a27;
  --gold:#c9a13b;
  --gold-light:#d9b869;
  --sage:#b7d3ac;
  --cream:#f2ece0;
  --cream-2:#efe9dd;
  --ink:#1c2b1f;
  --ink-soft:#4b5750;
  --line:rgba(255,255,255,0.14);
  --white:#ffffff;
}
*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Poppins', sans-serif;
  color:var(--ink);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3{font-family:'Playfair Display', serif; font-weight:600; line-height:1.15;}
a{text-decoration:none; color:inherit;}
ul{list-style:none;}
img{max-width:100%; display:block;}
.wrap{max-width:1180px; margin:0 auto; padding:0 32px;}
.eyebrow{
  display:flex; align-items:center; gap:14px;
  text-transform:uppercase; letter-spacing:.18em; font-size:12.5px;
  font-weight:600; color:var(--gold);
}
.eyebrow::before{content:""; width:34px; height:2px; background:var(--gold); display:block;}
.eyebrow.center{justify-content:center;}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:15px 30px; font-size:12.5px; font-weight:600; letter-spacing:.12em;
  text-transform:uppercase; border-radius:2px; cursor:pointer; transition:.25s ease;
  border:1.5px solid transparent; white-space:nowrap;
}
.btn-gold{background:linear-gradient(180deg,#d6b158,var(--gold)); color:#25200a;}
.btn-gold:hover{filter:brightness(1.06); transform:translateY(-1px);}
.btn-outline-light{border-color:rgba(255,255,255,.55); color:var(--white);}
.btn-outline-light:hover{background:rgba(255,255,255,.08);}
.btn-outline-dark{border-color:var(--green-900); color:var(--green-900);}

/* ---------- HEADER ---------- */
header.site-header{
  position:sticky; top:0; z-index:50; background:#fff;
  border-bottom:1px solid #eee7d8;
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 32px; max-width:1180px; margin:0 auto;
}
.logo{display:flex; align-items:center; gap:10px;}
.logo .mark{
  width:38px; height:38px; border-radius:50%; border:1.5px solid var(--green-900);
  display:flex; align-items:center; justify-content:center;
  font-family:'Playfair Display'; color:var(--green-900); font-size:18px;
}
.logo .word{font-family:'Playfair Display'; font-weight:700; font-size:15px; letter-spacing:.06em; color:var(--green-900); line-height:1.1;}
.logo .word span{display:block; font-family:'Poppins'; font-weight:400; font-size:9.5px; letter-spacing:.3em; color:var(--ink-soft);}
.nav-links{display:flex; gap:38px; align-items:center;}
.nav-links ul{display:flex; gap:38px; align-items:center;}
.nav-links a{font-size:13.5px; color:var(--ink); font-weight:400; position:relative;}
.nav-links a:hover{color:var(--gold);}
.nav .btn-dark-pill{
  background:var(--green-900); color:#fff; padding:12px 26px; border-radius:22px;
  font-size:12.5px; font-weight:500; letter-spacing:.02em;
}
.nav .btn-dark-pill:hover{background:var(--green-800);}

/* ---------- HERO ---------- */
.hero{
  background:radial-gradient(120% 140% at 15% 0%, #1a3a26 0%, var(--green-900) 45%, var(--green-950) 100%);
  color:#fff; padding:78px 0 0;
  position:relative;
}
.hero-grid{
  display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center;
  padding-bottom:60px;
}
.hero h1{font-size:52px; color:#fff; margin-top:20px;}
.hero p{margin-top:22px; color:rgba(255,255,255,.72); font-size:15.5px; line-height:1.75; max-width:430px; font-weight:300;}
.hero-btns{display:flex; gap:16px; margin-top:34px; flex-wrap:wrap;}
.hero-art{display:flex; align-items:center; justify-content:center; padding:20px 0;}
.hero-art img{width:100%; max-width:480px; filter:drop-shadow(0 30px 45px rgba(0,0,0,.5));}

.stats-band{background:var(--sage);}
.stats-inner{
  max-width:1180px; margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr);
  text-align:center;
}
.stats-inner div{padding:22px 10px; border-left:1px solid rgba(20,48,31,.18);}
.stats-inner div:first-child{border-left:none;}
.stats-inner strong{display:block; font-size:14px; letter-spacing:.06em; color:var(--green-950); font-weight:600;}
.stats-inner span{display:block; font-size:11px; letter-spacing:.08em; color:var(--ink-soft); margin-top:4px;}

/* ---------- SERVICES ---------- */
.services{padding:100px 0 90px; text-align:center;}
.services h2{font-size:38px; color:var(--green-950); margin-top:16px;}
.services > .wrap > p{max-width:560px; margin:16px auto 0; color:var(--ink-soft); font-size:14.5px; line-height:1.8; font-weight:300;}
.service-cards{
  display:grid; grid-template-columns:1fr 1fr; gap:32px; margin-top:56px; text-align:left;
}
.service-card{
  background:linear-gradient(160deg,#1a3a26,var(--green-950));
  border-radius:20px; padding:44px 40px 40px; color:#fff;
}
.service-card h3{color:var(--gold-light); font-size:26px; margin-bottom:26px;}
.service-row{
  display:flex; justify-content:space-between; align-items:center;
  padding:14px 0; border-bottom:1px solid var(--line);
  font-size:12px; letter-spacing:.1em; text-transform:uppercase;
}
.service-row span:first-child{color:rgba(255,255,255,.55); font-weight:400;}
.service-row span:last-child{font-weight:600; color:#fff;}
.service-card .btn{margin-top:32px;}

/* ---------- STEPS ---------- */
.steps{background:var(--cream); padding:100px 0;}
.steps-head{text-align:center;}
.steps-head h2{font-size:38px; color:var(--green-950);}
.steps-head h2.accent{color:var(--gold); font-size:40px; margin-top:2px;}
.steps-head p{max-width:560px; margin:18px auto 0; color:var(--ink-soft); font-size:14.5px; line-height:1.8; font-weight:300;}
.step-cards{display:grid; grid-template-columns:repeat(4,1fr); gap:26px; margin-top:56px;}
.step-card{background:#fff; border-radius:4px; overflow:hidden; box-shadow:0 12px 30px rgba(20,40,25,.06);}
.step-card .img{height:150px; width:100%; overflow:hidden;}
.step-card .img img{width:100%; height:100%; object-fit:cover;}
.step-card .body{padding:22px 22px 26px;}
.step-card h4{font-family:'Playfair Display'; font-size:18px; color:var(--green-950); margin-bottom:10px; font-weight:600;}
.step-card p{font-size:12.5px; color:var(--ink-soft); line-height:1.7; font-weight:300;}

/* ---------- PRODUCTS ---------- */
.products{
  background:linear-gradient(180deg,var(--green-950),#0c1e13);
  color:#fff; text-align:center; padding:90px 0 0; overflow:hidden;
}
.products h2{font-size:40px; color:#fff;}
.products h2 em{font-style:normal; color:var(--gold-light);}
.products p{max-width:520px; margin:18px auto 0; color:rgba(255,255,255,.65); font-size:14.5px; font-weight:300; line-height:1.8;}
.products .btn{margin-top:30px;}
.product-row{display:flex; align-items:flex-end; justify-content:center; gap:0; margin-top:60px; padding:0 10px;}

/* ---------- BRANDS ---------- */
.brands{padding:100px 0 70px; text-align:center;}
.brands h2{font-size:32px; color:var(--green-950);}
.brand-quotes{display:grid; grid-template-columns:1fr 1fr; gap:40px; margin-top:56px; text-align:left;}
.brand-quote{border-left:3px solid var(--gold); padding:6px 0 6px 26px;}
.brand-quotes .brand-quote:nth-child(2){border-left-color:#c9663b;}
.brand-quote h4{font-family:'Playfair Display'; font-size:16px; letter-spacing:.05em; color:var(--green-950); margin-bottom:8px;}
.brand-quote p{font-style:italic; color:var(--ink-soft); font-size:14px; line-height:1.7; font-weight:300;}
.brands .cta-line{margin-top:60px; font-family:'Playfair Display'; font-style:italic; font-size:19px; color:var(--green-950);}

/* ---------- FAQ ---------- */
.faq{padding:20px 0 100px;}
.faq h2{text-align:center; font-size:32px; color:var(--green-950); margin-bottom:50px;}
.faq-list{max-width:760px; margin:0 auto; border-top:1px solid #e6e0d2;}
.faq-item{border-bottom:1px solid #e6e0d2;}
.faq-q{
  display:flex; justify-content:space-between; align-items:center;
  padding:20px 4px; cursor:pointer; font-size:15px; color:var(--green-950); font-weight:500;
}
.faq-q .chev{transition:transform .25s ease; color:var(--gold); font-size:14px;}
.faq-item.open .chev{transform:rotate(180deg);}
.faq-a{max-height:0; overflow:hidden; transition:max-height .3s ease;}
.faq-a p{padding:0 4px 20px; color:var(--ink-soft); font-size:13.5px; line-height:1.8; font-weight:300; max-width:640px;}

/* ---------- CTA BAND ---------- */
.cta-band{background:var(--cream-2); text-align:center; padding:70px 0;}
.cta-band h2{font-size:32px; color:var(--green-950);}
.cta-band p{margin-top:10px; color:var(--ink-soft); font-size:13.5px; font-weight:300;}
.cta-btns{display:flex; gap:16px; justify-content:center; margin-top:30px;}

/* ---------- FOOTER ---------- */
footer.site-footer{background:var(--green-950); color:rgba(255,255,255,.75); padding:56px 0 26px;}
.footer-grid{display:grid; grid-template-columns:1.3fr 1fr 1fr 1.1fr; gap:30px; padding-bottom:36px; border-bottom:1px solid var(--line);}
.footer-logo{display:flex; align-items:center; gap:10px; margin-bottom:14px;}
.footer-logo .mark{width:34px; height:34px; border-radius:50%; border:1.5px solid var(--gold-light); display:flex; align-items:center; justify-content:center; color:var(--gold-light); font-family:'Playfair Display';}
.footer-logo .word{font-family:'Playfair Display'; font-weight:700; font-size:14px; color:#fff; letter-spacing:.04em;}
.footer-col h5{font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-light); margin-bottom:14px;}
.footer-col p, .footer-col a{display:block; font-size:13px; color:rgba(255,255,255,.7); margin-bottom:10px; line-height:1.6;}
.newsletter{display:flex; margin-top:10px; max-width:260px;}
.newsletter input{flex:1; padding:11px 12px; border:none; font-size:12.5px; border-radius:2px 0 0 2px;}
.newsletter button{background:var(--gold); border:none; padding:0 16px; border-radius:0 2px 2px 0; cursor:pointer; font-weight:700; color:#25200a;}
.footer-bottom{text-align:center; padding-top:22px; font-size:12px; color:rgba(255,255,255,.45);}

@media (max-width: 900px){
  .nav-links{display:none;}
  .hero-grid{grid-template-columns:1fr;}
  .hero h1{font-size:38px;}
  .service-cards, .step-cards, .brand-quotes{grid-template-columns:1fr;}
  .stats-inner{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
}
