:root{
  --bg: #F6EFE5;       /* warm creamy beige */
  --bg-2:#FBF8F4;
  --text:#1e1e1e;
  --muted:#6b6b6b;
  --card:#ffffff;
  --accent:#9CC6A3;    /* soft green for CTAs */
  --shadow: 0 20px 40px rgba(0,0,0,.06);
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; scroll-behavior: smooth;}
body{
  font-family: Inter, system-ui, -apple-system, sans-serif;
  line-height:1.6;
  color:var(--text);
  background: radial-gradient(1200px 600px at 50% -200px, var(--bg-2), var(--bg));
}

h1,h2,h3,.h1,.h2{ font-family: "Plus Jakarta Sans", Inter, sans-serif; letter-spacing:-.02em; }
.h1{ font-size: clamp(2.2rem, 4.2vw, 3.6rem); line-height:1.15; margin:.4rem 0 1rem; }
.h2{ font-size: clamp(1.6rem, 2.6vw, 2.2rem); margin:0 0 1rem; }
.p-lg{ font-size:1.1rem; color:var(--muted); }

.container{ max-width:1150px; margin:0 auto; padding:0 18px; }

/* NAV */
.nav{ position:sticky; top:0; z-index:50; background:#fff8; backdrop-filter:saturate(140%) blur(8px); border-bottom:1px solid #eee; }
.nav__row{ display:flex; align-items:center; justify-content:space-between; height:68px; }
.logo img{ height:70px; display:block; }
.menu{ display:flex; gap:22px; }
.menu a{ color:var(--text); text-decoration:none; font-size:.95rem; }
.menu a:hover{ opacity:.7; }
.hamburger{ display:none; background:none; border:0; padding:8px; }
.hamburger span{ display:block; width:22px; height:2px; background:#222; margin:4px 0; }

/* add once in style.css */
section[id] {
  scroll-margin-top: 80px; /* navbar (68) + a little breathing space */
}

/* Buttons */
.btn{ display:inline-block; padding:.9rem 1.6rem; border-radius:28px; text-decoration:none; font-weight:600; }
.btn--black{ background:#000; color:#fff; box-shadow:0 10px 24px rgba(0,0,0,.08); transition:.25s; }
.btn--black:hover{ transform:translateY(-2px); background:#111; }
.btn--outline{ border:1px solid #e3e3e3; background:#fff; color:#222; }
.btn--pill{ background:#f3d89c; color:#000; }

/* HERO */
.hero{ position:relative; padding: clamp(3rem, 6vw, 5rem) 0; overflow:hidden; }
.hero__grid{ display:grid; grid-template-columns: 1.05fr .95fr; gap: clamp(1.5rem, 3vw, 2.5rem); align-items:center; }
.sub{ color:var(--muted); max-width:46ch; }
.cta-row{ display:flex; gap:12px; align-items:center; margin:18px 0 8px; }
.link{ color:#2c2c2c; text-decoration:none; border-bottom:1px solid #cfcfcf; padding-bottom:2px; }
.link:hover{ opacity:.75; }

/* cluster of product images */
.cluster{ position:relative; width:100%; min-height:420px; }
.cluster .p{ position:absolute; filter: drop-shadow(var(--shadow)); width: 42%; max-width: 300px; }
.p--blue{ left:6%; top:20%; transform: rotate(-8deg); }
.p--green{ right:6%; top:0; transform: rotate(8deg); }
.p--pink{ left:32%; bottom:6%; transform: rotate(2deg); }

/* decor */
.decor{ position:absolute; pointer-events:none; opacity:.9; filter: drop-shadow(0 10px 20px rgba(0,0,0,.08)); }
.decor--leaf1{ right:14%; top:-10px; width:80px; }
.decor--leaf2{ right:0; top:160px; width:70px; }
.decor--oil{ right:12%; top:220px; width:64px; transform: rotate(-10deg); }

/* MISSION / IDEOLOGY */
.mission{ background: #fff; padding: 4.5rem 0; }
.mission__grid{ display:grid; grid-template-columns: 1.1fr .9fr; gap: 2.5rem; align-items:center; }
.values{ padding:0; margin:1rem 0; }
.values li{ list-style:none; margin:.4rem 0; }
.mission__art{ position:relative; }
.mission__art img{ width:100%; max-width:420px; border-radius:24px; box-shadow: var(--shadow); }
.decor--leaf3{ left:-28px; bottom:-18px; width:80px; position:absolute; }
.decor--oil2{ right:-18px; top:-24px; width:56px; position:absolute; }

/* ==== Ideology Page ==== */
.ideology-hero {
  background: linear-gradient(to bottom, #f9f6f1, #fff);  padding: 5rem 0 3rem;  text-align: center;}
.ideology-hero .intro {  max-width: 750px;  margin: 1rem auto 0;  font-size: 1.15rem;  color: #444;  line-height: 1.8;}

.ideology-body {  background: #fff;  padding: 5rem 0;}
.ideology-body .grid-2 {  display: grid;  grid-template-columns: 1.1fr .9fr;  gap: 2.5rem;  align-items: center;}
.ideology-body .image img {  width: 100%;  max-width: 400px;  border-radius: 24px;  box-shadow: var(--shadow);}

.ideology-vision {  background: linear-gradient(to bottom, #faf7f2, #f6efe5);  text-align: center;  padding: 5rem 0;}
.ideology-vision p {  max-width: 700px;  margin: 1rem auto 2rem;  font-size: 1.1rem;  color: #333;}


/* VARIETIES */
.varieties{ background: var(--bg-2); padding:4.5rem 0; }
.grid-3{ display:grid; grid-template-columns: repeat(3, 1fr); gap:18px; }
.card{ background:#fff; border:1px solid #eee; border-radius:16px; padding:18px; text-align:center; box-shadow: var(--shadow); }
.card img{ width:100%; max-width:220px; display:block; margin:0 auto 10px; }
.card h3{ margin:.4rem 0 .2rem; font-size:1rem; }
.muted{ color:var(--muted); }
.center{ text-align:center; }

/* ANYWHERE */
.anywhere{ background:#fff; padding:4.5rem 0; }
.anywhere__grid{ display:grid; grid-template-columns: 1.1fr .9fr; gap: 2.5rem; align-items:center; }
.anywhere__photo img{ width:100%; max-width:380px; filter: drop-shadow(var(--shadow)); border-radius:18px; }
.bullets{ padding-left:1.2rem; }
.bullets li{ margin:.4rem 0; }

/* HOW TO USE */
/* .how{ background:#fff; padding:4.5rem 0; }
.steps{ display:grid; grid-template-columns: repeat(3, 1fr); gap:18px; }
.step{ background:#fff; border:1px solid #eee; border-radius:16px; padding:20px; box-shadow: var(--shadow); }
.step__num{ width:34px; height:34px; border-radius:50%; background:#f1e8d6; display:inline-flex; align-items:center; justify-content:center; font-weight:700; margin-bottom:8px; } */

.how {
  background: #fff;
  padding: 5rem 0;
  text-align: center;
}

.how .h2 {
  font-size: 2rem;
  color: #111;
  margin-bottom: 2rem;
  letter-spacing: -0.02em;
}

.steps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 24px;
  max-width: 1000px;
  margin: 0 auto;
}

.step {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 18px;
  padding: 2rem 1.5rem;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.05);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.step:hover {
  transform: translateY(-6px);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.07);
}

.step__num {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: #f3eadc;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  margin-bottom: 1rem;
  color: #333;
  font-size: 0.9rem;
}

.step__img {
  width: 100px;
  height: auto;
  margin: 0 auto 1.2rem;
  border-radius: 12px;
  object-fit: contain;
  display: block;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.step h3 {
  font-size: 1.1rem;
  color: #111;
  margin-bottom: 0.5rem;
}

.step p {
  font-size: 0.95rem;
  color: #555;
  line-height: 1.6;
  max-width: 240px;
  margin: 0 auto;
}


/* BUY */
.buy{ background:#fff; padding:4.5rem 0; }

/* CONTACT */
.contact{ background:#fff; padding:4.5rem 0; }
.contact__grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items:start; }
.form{ background:#fff; border:1px solid #eee; padding:18px; border-radius:16px; box-shadow: var(--shadow); }
.form input,.form textarea{ width:100%; padding:.9rem 1rem; border:1px solid #ddd; border-radius:12px; margin-bottom:.8rem; font: inherit; }
.form button{ width:100%; }

/* FOOTER */
.footer{ background:#fff; border-top:1px solid #eee; }
.footer__row{ display:flex; align-items:center; justify-content:space-between; padding:18px 0; }
.footer__links a{ color:#333; text-decoration:none; margin-left:14px; }
.footer__links a:hover{ opacity:.7; }

/* ===== BLOG ===== */
.blog-hero{
  background: linear-gradient(to bottom, #faf6ef, #fff);
  padding: 4.5rem 0 2rem;
}
.blog-controls{
  margin-top: 1.4rem;
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 14px;
  align-items: center;
}
.tabs{ display: flex; flex-wrap: wrap; gap: 8px; }
.tab{
  border: 1px solid #eadfd1;
  background: #fff;
  padding: .55rem .9rem;
  border-radius: 999px;
  font-weight: 600;
  cursor: pointer;
}
.tab.is-active{ background: #f3d89c; border-color: #f3d89c; }
.search input{
  width: 100%;
  padding: .7rem .9rem;
  border: 1px solid #e1ded8;
  border-radius: 12px;
  font: inherit;
  background: #fff;
}

.blog-grid{ background:#fff; padding: 2rem 0 4.5rem; }
.post-card{
  background:#fff;
  border:1px solid #eee;
  border-radius:18px;
  overflow:hidden;
  box-shadow: var(--shadow);
  transition: transform .2s ease;
}
.post-card:hover{ transform: translateY(-4px); }
.post-card img{ width:100%; height:180px; object-fit:contain; background:#fbf7f1; }
.post-body{ padding:14px; }
.post-body h3{ margin:.4rem 0 .2rem; font-size:1.05rem; }
.badge{
  display:inline-block; font-size:.75rem; font-weight:700; letter-spacing:.02em;
  background:#e9f4eb; color:#234; border-radius:999px; padding:.32rem .6rem;
}

/* active state in nav */
.menu a.active{ border-bottom:2px solid #222; padding-bottom:2px; }

@media (max-width: 980px){
  .blog-controls{ grid-template-columns: 1fr; }
  .post-card img{ height:160px; }
}


.post-hero{ background:linear-gradient(to bottom,#faf6ef,#fff); padding:3.5rem 0 1rem; }
.post-body{ background:#fff; padding:2rem 0 4rem; }
.post-body h3{ margin-top:1.2rem; }
.callout{
  margin-top:1.6rem; padding:1.2rem; border:1px solid #eee; border-radius:16px; background:#fbf7f1;
  display:flex; gap:12px; align-items:center; justify-content:space-between; flex-wrap:wrap;
}
.callout .btn{ padding:.6rem 1rem; }


/* ===== Oil Post ===== */
.oil-hero{ background: linear-gradient(to bottom, #faf6ef, #fff); padding: 1rem 0 0; }
.oil-hero__wrap{ display:grid; grid-template-columns: 1.2fr .8fr; gap: 16px; align-items:center; min-height: 70vh;}
.oil-hero__art{ position: relative; }
.oil-hero__art img{ width: 90%; max-width: 420px; border-radius: 18px; box-shadow: var(--shadow); display:block; }
.oil-hero__art .overlay{ position:absolute; right:-18px; bottom:-18px; width:120px; filter: drop-shadow(0 8px 20px rgba(0,0,0,.08)); }

/* quick facts grid */
.facts{
  display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 10px; margin: 1rem 0 1.4rem;
}
.facts div{ background:#fbf7f1; border:1px solid #efe6da; padding: 10px 12px; border-radius:12px; }
.facts span{ display:block; font-size:.8rem; color:#7a746b; }
.facts strong{ font-size:.95rem; }

/* pros/cons */
.grid-2.gap{ display:grid; grid-template-columns: repeat(2,1fr); gap: 18px; }
.card-soft{ background:#fff; border:1px solid #eee; border-radius:16px; padding:16px; box-shadow: var(--shadow); }
.list-tick li{ list-style: "✔  "; margin:.45rem 0; }
.list-cross li{ list-style: "✖  "; margin:.45rem 0; }

/* step cards with images */
.use-with{ background:#fff; padding: 2rem 0 3rem; }
.steps-img{ display:grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
.step-card{ background:#fff; border:1px solid #eee; border-radius:16px; overflow:hidden; box-shadow: var(--shadow); }
.step-card img{ width:100%; height:170px; object-fit:cover; background:#f5efe3; }
.step-card h4{ margin:.6rem 0 .2rem; padding: 0 12px; }
.step-card p{ padding: 0 12px 10px; color:#444; }

/* related */
.related{ background:#fff; padding: 2rem 0 4rem; }

/* ===== Oil theme accents (based on body[data-theme]) ===== */
body[data-theme="lavender"] .badge,
body[data-theme="lavender"] .step-card img{ background:#f5effa; }
body[data-theme="lavender"] .btn--black:hover{ background:#6e5aa6; }
body[data-theme="lavender"] .h1{ color:#2a233d; }

body[data-theme="peppermint"] .badge,
body[data-theme="peppermint"] .step-card img{ background:#e9f7f2; }
body[data-theme="peppermint"] .btn--black:hover{ background:#1d6f5a; }

body[data-theme="lemon"] .badge,
body[data-theme="lemon"] .step-card img{ background:#fff7d6; }
body[data-theme="lemon"] .btn--black:hover{ background:#b88b00; }

body[data-theme="eucalyptus"] .badge,
body[data-theme="eucalyptus"] .step-card img{ background:#e7f3ef; }
body[data-theme="eucalyptus"] .btn--black:hover{ background:#2a6b56; }

body[data-theme="rose"] .badge,
body[data-theme="rose"] .step-card img{ background:#fde8ee; }
body[data-theme="rose"] .btn--black:hover{ background:#a13d5c; }

@media (max-width: 980px){
  .oil-hero__wrap{ grid-template-columns: 1fr; }
  .facts{ grid-template-columns: 1fr 1fr; }
  .grid-2.gap{ grid-template-columns: 1fr; }
  .steps-img{ grid-template-columns: 1fr; }
}


/* RESPONSIVE */
@media (max-width: 980px){
  .hero__grid,
  .mission__grid,
  .anywhere__grid,
  .contact__grid{ grid-template-columns: 1fr; }
  .grid-3, .steps{ grid-template-columns: 1fr 1fr; }
  .menu{ display:none; }
  .hamburger{ display:block; }
  .cluster{ min-height: 360px; }
}
@media (max-width: 620px){
  .grid-3, .steps{ grid-template-columns: 1fr; }
  .footer__row{ flex-direction:column; gap:8px; }
}


