/* =========================================================
   Sweeter Things LLC — shared stylesheet
   Brand palette pulled from the logo:
   sky blue, leaf green, soft pink heart, sunny gold, cream
   ========================================================= */

:root{
  --green-deep:#2f6b3d;
  --green:#5b9a3e;
  --green-soft:#dff0d2;
  --sky:#8fd0e8;
  --sky-soft:#dff1f8;
  --sky-pale:#eef9fc;
  --pink:#ef93bd;
  --pink-deep:#e2729f;
  --gold:#f6d35b;
  --cream:#fbfdf8;
  --ink:#274432;
  --ink-soft:#4f6b58;
  --white:#ffffff;
  --shadow:0 10px 30px rgba(47,107,61,.12);
  --shadow-sm:0 4px 14px rgba(47,107,61,.10);
  --radius:18px;
  --radius-lg:28px;
  --maxw:1180px;
  --font-head:'Quicksand',system-ui,sans-serif;
  --font-body:'Nunito Sans',system-ui,sans-serif;
  --font-script:'Dancing Script',cursive;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:17px;
}
img{max-width:100%;display:block}
a{color:var(--green-deep);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--font-head);color:var(--green-deep);line-height:1.2;margin:0 0 .5em}
h1{font-size:clamp(2rem,4.5vw,3.2rem);font-weight:700}
h2{font-size:clamp(1.6rem,3.2vw,2.4rem);font-weight:700}
h3{font-size:1.3rem;font-weight:600}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.script{font-family:var(--font-script);color:var(--pink-deep)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;
  font-family:var(--font-head);
  font-weight:700;
  padding:.85em 1.8em;
  border-radius:999px;
  border:none;
  cursor:pointer;
  font-size:1rem;
  letter-spacing:.3px;
  transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;
  text-decoration:none;
}
.btn:hover{text-decoration:none;transform:translateY(-3px)}
.btn:active{transform:translateY(-1px)}
.btn-primary{background:linear-gradient(135deg,var(--green),var(--green-deep));color:#fff;
  box-shadow:0 8px 20px rgba(47,107,61,.32)}
.btn-primary:hover{filter:brightness(1.05);box-shadow:0 12px 26px rgba(47,107,61,.40)}
.btn-pink{background:linear-gradient(135deg,var(--pink),var(--pink-deep));color:#fff;
  box-shadow:0 8px 20px rgba(226,114,159,.36)}
.btn-pink:hover{filter:brightness(1.04);box-shadow:0 12px 26px rgba(226,114,159,.44)}
.btn-ghost{background:rgba(255,255,255,.95);color:var(--green-deep);border:2px solid var(--green-soft);
  box-shadow:0 6px 16px rgba(47,107,61,.12)}
.btn-ghost:hover{border-color:var(--green);box-shadow:0 10px 22px rgba(47,107,61,.18)}

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(251,253,248,.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid #e8f0e2;
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  gap:18px;padding:10px 22px;max-width:var(--maxw);margin:0 auto;
}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none}
.brand img{width:90px;height:90px}
.brand-text{display:flex;flex-direction:column;line-height:1.08}
.brand-text .name{font-family:var(--font-head);font-weight:700;color:var(--green-deep);font-size:1.5rem;letter-spacing:.6px}
.brand-text .tag{font-family:var(--font-script);font-weight:700;color:var(--pink-deep);font-size:1.2rem}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0}
.nav-links a{
  font-family:var(--font-head);font-weight:600;color:var(--ink);
  padding:.5em .85em;border-radius:999px;font-size:.98rem;
}
.nav-links a:hover{background:var(--green-soft);text-decoration:none}
.nav-links a.active{background:var(--green);color:#fff}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:26px;height:3px;background:var(--green-deep);border-radius:3px;margin:5px 0;transition:.2s}

/* ---------- Hero (two-column: text panel + full photo) ---------- */
.hero{
  position:relative;overflow:hidden;
  /* Floral meadow background. Drop the image at assets/images/hero-bg.png.
     The gradient below shows as a fallback until the file is in place. */
  background:
    url('images/hero-bg.jpg') center bottom / cover no-repeat,
    linear-gradient(180deg, #f5faef 0%, #e7f2da 100%);
}
.hero::before{content:none}
.hero::after{content:none}
.hero-grid{
  position:relative;z-index:1;
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1.05fr 1fr;align-items:center;gap:8px;
}
.hero-text{align-self:center;padding:60px 44px;color:var(--ink);max-width:600px}
.hero-text h1{color:var(--green-deep);text-shadow:0 1px 0 rgba(255,255,255,.45)}
.hero-text .lead{font-size:1.18rem;margin:.4em 0 1.4em;color:#4a5f3f}
.hero-text .script-tag{font-family:var(--font-script);font-size:1.9rem;color:var(--pink-deep);display:block;margin-bottom:.05em}
.hero-btns{display:flex;flex-wrap:wrap;gap:12px}
.hero-photo{position:relative;display:flex;align-items:center;justify-content:center;padding:48px}
/* clean white photo frame */
.photo-frame{
  position:relative;z-index:1;width:min(470px,100%);
  background:#fff;padding:12px;border-radius:22px;
  box-shadow:0 24px 50px rgba(60,90,60,.22);
}
.photo-frame img{display:block;width:100%;height:auto;border-radius:14px}
.photo-frame::after{content:none}

/* ---------- Page banner (interior pages) ---------- */
.page-banner{
  background:linear-gradient(120deg,var(--sky-soft),var(--green-soft));
  padding:54px 0 46px;text-align:center;
}
.page-banner h1{margin-bottom:.15em}
.page-banner p{margin:0;color:var(--ink-soft);font-size:1.1rem}

/* ---------- Sections ---------- */
section{padding:60px 0}
.section-sky{background:var(--sky-pale)}
.section-green{background:var(--green-soft)}
.section-tight{padding:42px 0}
.center{text-align:center}
.lead{font-size:1.12rem;color:var(--ink-soft)}
.eyebrow{font-family:var(--font-head);font-weight:700;letter-spacing:2px;text-transform:uppercase;
  color:var(--pink-deep);font-size:.82rem;margin-bottom:.4em}

/* ---------- Value badges / "What we stand for" ---------- */
.stand-section{
  background:linear-gradient(180deg,#ffffff 0%, #f3f7ec 100%);
  padding:70px 0;
}
.stand-card{
  position:relative;overflow:hidden;
  max-width:960px;margin:0 auto;text-align:center;
  background:#fff;border:1px solid #e9f0e0;border-radius:30px;
  box-shadow:0 22px 50px rgba(47,107,61,.12);
  padding:52px 40px;
}
.stand-card::before{ /* faint sage accent corner */
  content:"";position:absolute;z-index:0;width:260px;height:260px;border-radius:50%;
  background:radial-gradient(circle, rgba(143,208,232,.16), transparent 70%);
  top:-90px;right:-80px;
}
.stand-card > *{position:relative;z-index:1}
.badges{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:22px}
.badge{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;border:1px solid var(--green-soft);color:var(--green-deep);
  font-family:var(--font-head);font-weight:600;font-size:.95rem;
  padding:.6em 1.25em;border-radius:999px;
  box-shadow:0 6px 16px rgba(47,107,61,.10);
  transition:transform .15s ease,box-shadow .15s ease;
}
.badge::before{content:"";width:8px;height:8px;border-radius:50%;
  background:linear-gradient(135deg,var(--green),var(--gold));flex-shrink:0}
.badge:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(47,107,61,.16)}

/* ---------- Curved section transitions ---------- */
.curve-top{
  position:relative;
  border-top-left-radius:46px;border-top-right-radius:46px;
  margin-top:-44px;
}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:26px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.card{
  background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);border:1px solid #eef3ea;
  display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease;
}
.card:hover{transform:translateY(-4px);box-shadow:0 16px 38px rgba(47,107,61,.18)}
.card img{width:100%;height:240px;object-fit:cover;object-position:center}
.card img.img-top{object-position:center top}
.card img.img-upper{object-position:center 28%}
.card-body{padding:22px;flex:1;display:flex;flex-direction:column}
.card-body h3{color:var(--green-deep)}
.card-body p{color:var(--ink-soft);margin:.2em 0 1em}
.card-body .btn{margin-top:auto;align-self:flex-start}

/* category list cards */
.cat-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);
  border:1px solid #eef3ea;padding:26px 26px 22px}
.cat-card h3{display:flex;align-items:center;gap:10px;border-bottom:2px solid var(--green-soft);padding-bottom:.4em}
.cat-card ul{list-style:none;margin:14px 0 0;padding:0}
.cat-card li{padding:.5em 0;border-bottom:1px dashed #e7eede;display:flex;justify-content:space-between;align-items:center}
.cat-card li:last-child{border-bottom:none}
.cat-card li span{font-family:var(--font-head);font-weight:600}
.pill-soon{background:var(--sky-soft);color:#2b7a96;font-size:.72rem;font-weight:700;
  font-family:var(--font-head);padding:.2em .7em;border-radius:999px;letter-spacing:.5px}
.pill-live{background:#e7f8ee;color:#1f8b4c;font-size:.72rem;font-weight:700;
  font-family:var(--font-head);padding:.2em .7em;border-radius:999px;letter-spacing:.3px;white-space:nowrap}
/* product sub-lists inside category cards */
.product-list{list-style:none;margin:16px 0 0;padding:0}
.product-list li{padding:.5em 0;border-bottom:1px dashed #e7eede}
.product-list li:last-child{border-bottom:none}
.product-list a{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-head);
  font-weight:600;color:var(--green-deep);text-decoration:none}
.product-list a::before{content:"❖";color:var(--pink-deep);font-size:.85em}
.product-list a:hover{color:var(--green);text-decoration:underline}
.cat-empty{margin:16px 0 0;color:#8aa18f;font-style:italic}

/* ---------- Blog ---------- */
.cat-tag{display:inline-block;font-family:var(--font-head);font-weight:700;font-size:.72rem;
  letter-spacing:1px;text-transform:uppercase;color:var(--green-deep);
  background:var(--green-soft);padding:.32em .85em;border-radius:999px}
.post-card-meta{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.post-date{font-size:.82rem;color:var(--ink-soft)}
.card .excerpt{color:var(--ink-soft);margin:.2em 0 1.1em}
/* blog post article */
.post-figure{margin:0 0 30px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.post-figure img{width:100%;height:auto;display:block;max-height:440px;object-fit:cover}
.post-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:0 0 10px}
.post-body{max-width:760px;margin:0 auto}
.post-body h2{margin-top:1.5em;margin-bottom:.4em;color:var(--green-deep);font-size:1.5rem}
.post-body p{font-size:1.08rem;line-height:1.7;margin:0 0 1.15em;color:var(--ink)}
.post-body ul{margin:0 0 1.2em;padding-left:1.3em}
.post-body li{margin:.4em 0;font-size:1.05rem;line-height:1.6}
.post-body .lead{font-size:1.18rem;color:var(--ink-soft);margin-bottom:1.4em}
.post-nav{display:flex;justify-content:space-between;gap:16px;margin:38px auto 0;max-width:760px;flex-wrap:wrap}
/* comments */
.comments-wrap{max-width:760px;margin:48px auto 0;padding-top:34px;border-top:1px solid #e7eede}
.comments-title{color:var(--green-deep);font-size:1.6rem;margin-bottom:.15em}
.comments-sub{color:var(--ink-soft);margin:0 0 22px}
.cat-card li a{font-family:var(--font-head);font-weight:600;color:var(--green-deep);text-decoration:none}
.cat-card li a:hover{color:var(--green);text-decoration:underline}
.disclosure{font-size:.82rem;color:var(--ink-soft);font-style:italic;line-height:1.5}

/* featured brand banner card */
.brand-feature{
  background:#fff;border:1px solid #eef3ea;border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden;max-width:720px;margin:30px auto 0;
}
.brand-banner{display:block;line-height:0;transition:opacity .15s}
.brand-banner:hover{opacity:.92}
.brand-banner img{width:100%;height:auto;display:block}
.brand-feature-body{padding:24px 26px}

/* ---------- Split feature ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
.split img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;height:100%;object-fit:cover;max-height:420px}
.split.reverse .split-text{order:2}

/* ---------- Scripture sections (unified, centered, consistent everywhere) ---------- */
.verse-strip{
  position:relative;overflow:hidden;
  background:
    radial-gradient(700px 360px at 50% 0%, rgba(255,255,255,.10), transparent 60%),
    linear-gradient(120deg,var(--green-deep),var(--green));
  color:#fff;padding:66px 0;
}
.verse-list{
  position:relative;z-index:1;
  max-width:760px;margin:0 auto;padding:0 24px;
  display:flex;flex-direction:column;gap:0;text-align:center;
}
.verse-list::before{ /* decorative opening quote */
  content:"\201C";display:block;font-family:var(--font-script);font-weight:700;
  font-size:4.2rem;line-height:.5;color:rgba(255,255,255,.4);margin-bottom:10px;
}
.verse-item{margin:0;padding:30px 0}
.verse-item + .verse-item{position:relative}
.verse-item + .verse-item::before{ /* soft divider between verses */
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:46px;height:2px;border-radius:2px;background:rgba(216,239,206,.45);
}
.verse-text{
  font-family:var(--font-script);font-size:clamp(1.6rem,2.6vw,2rem);line-height:1.45;
  color:#fff;margin:0 0 .4em;
}
.verse-ref{
  font-family:var(--font-head);font-weight:700;letter-spacing:1.5px;
  text-transform:uppercase;font-size:.8rem;color:#d8efce;margin:0;
}
@media(max-width:480px){
  .verse-text{font-size:1.45rem}
}

/* ---------- Mission text block ---------- */
.prose{max-width:760px;margin:0 auto}
.prose p{margin:0 0 1.2em;font-size:1.1rem}
.prose .pullquote,
.pullquote{font-family:var(--font-script);font-size:clamp(1.3rem,2.75vw,1.9rem);font-weight:700;
  color:#c44f82;-webkit-text-stroke:.5px #c44f82;text-shadow:0 1px 1px rgba(0,0,0,.08);
  text-align:center;margin:1.1em auto;line-height:1.4;letter-spacing:.4px;max-width:860px}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:start}
.form-field{margin-bottom:18px}
.form-field label{display:block;font-family:var(--font-head);font-weight:600;margin-bottom:6px;color:var(--green-deep)}
.form-field input,.form-field textarea{
  width:100%;padding:13px 15px;border:1.5px solid #d8e6cf;border-radius:12px;
  font-family:var(--font-body);font-size:1rem;background:#fff;color:var(--ink);transition:border .15s;
}
.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--green)}
.form-field textarea{min-height:140px;resize:vertical}
.contact-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:30px;border:1px solid #eef3ea}
.contact-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.contact-row .ic{width:44px;height:44px;border-radius:50%;background:var(--sky-soft);
  display:grid;place-items:center;flex-shrink:0;color:var(--green-deep)}
.contact-row a{font-weight:600;overflow-wrap:anywhere}
.contact-row > div{min-width:0}
.socials{display:flex;gap:12px;margin-top:8px}
.socials a{width:46px;height:46px;border-radius:50%;background:var(--green-soft);display:grid;place-items:center;
  color:var(--green-deep);transition:transform .15s,background .15s}
.socials a:hover{transform:translateY(-3px);background:var(--green);color:#fff}
.socials svg{width:22px;height:22px}

/* ---------- Bee mascot ---------- */
.bee-mascot{
  width:140px;height:140px;border-radius:50%;object-fit:cover;
  border:5px solid #fff;box-shadow:var(--shadow);
  display:block;margin:0 auto 16px;
}
@media(max-width:480px){ .bee-mascot{width:110px;height:110px} }

/* ---------- Newsletter / CTA band ---------- */
.cta-band{background:linear-gradient(120deg,var(--sky),var(--green-soft));text-align:center}
.cta-band .inner{max-width:680px;margin:0 auto}

/* ---------- Footer ---------- */
.site-footer{background:var(--green-deep);color:#dff0d6;padding:48px 0 26px;margin-top:0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px}
.site-footer h4{color:#fff;font-size:1.05rem;margin-bottom:.7em}
.site-footer a{color:#dff0d6}
.site-footer a:hover{color:#fff}
.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.footer-brand img{width:140px;height:140px;background:#fff;border-radius:50%;padding:4px}
.footer-links{list-style:none;margin:0;padding:0}
.footer-links li{margin:.35em 0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.18);margin-top:34px;padding-top:18px;
  text-align:center;font-size:.88rem;color:#bcdcb2}
.footer-socials{display:flex;gap:10px;margin-top:10px}
.footer-socials a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.12);
  display:grid;place-items:center}
.footer-socials a:hover{background:rgba(255,255,255,.25)}
.footer-socials svg{width:20px;height:20px;fill:#fff}

/* ---------- Helpers ---------- */
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.note{background:var(--sky-soft);border-left:4px solid var(--sky);padding:14px 18px;border-radius:10px;color:#2b6076;font-size:.95rem}

/* ---------- Responsive ---------- */
@media(max-width:880px){
  .nav-links{
    position:fixed;top:112px;right:0;left:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--cream);border-bottom:1px solid #e8f0e2;
    padding:8px 16px 16px;box-shadow:var(--shadow);
    transform:translateY(-150%);transition:transform .25s ease;
  }
  .nav-links.open{transform:translateY(0)}
  .nav-links a{padding:.8em 1em;border-radius:12px}
  .nav-toggle{display:block}
  .grid-3,.grid-2{grid-template-columns:1fr}
  .split{grid-template-columns:1fr;gap:26px}
  .split.reverse .split-text{order:0}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:24px;text-align:center}
  .footer-brand{justify-content:center}
  .footer-socials{justify-content:center}
  .hero-grid{grid-template-columns:1fr}
  .hero-text{padding:40px 22px 26px;max-width:none;text-align:center;order:2}
  .hero-btns{justify-content:center}
  .hero-photo{order:1}
  .hero-photo img{max-height:60vh;object-fit:contain;width:100%;margin:0 auto}
}
@media(max-width:480px){
  body{font-size:16px}
  .brand img{width:73px;height:73px}
  .brand-text .name{font-size:1.2rem}
  .brand-text .tag{display:none}
  .nav-links{top:96px}
  section{padding:46px 0}
}
