/* === Winterberry Gifting Brand CSS === */

:root{
  /* Brand palette */
  --sand: #E5E3DC;
  --coral: #D4967D;
  --pine: #4C5D5B;
  --berry: #5C1D38;

  /* Neutrals */
  --ink: #1f2625;
  --paper: #fbfaf7;

  /* Surfaces */
  --card: rgba(251,250,247,0.86);
  --line: rgba(76,93,91,0.18);

  /* Shape + depth */
  --radius-lg: 28px;
  --radius-md: 18px;
  --radius-pill: 999px;

  --shadow: 0 18px 42px rgba(31,38,37,0.12);
  --shadow-soft: 0 12px 28px rgba(31,38,37,0.10);

  --container: 1120px;
}

  --sunrise: linear-gradient(90deg,
    rgba(212,150,125,0.0),
    rgba(212,150,125,0.65),
    rgba(229,227,220,0.0)
  );
  --sunrise-strong: linear-gradient(90deg,
    rgba(212,150,125,0.0),
    rgba(212,150,125,0.85),
    rgba(92,29,56,0.18),
    rgba(229,227,220,0.0)
  );

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }


body{
  margin: 0;
  color: var(--ink);
  background:
    radial-gradient(closest-side at 18% 12%, rgba(212,150,125,0.24), transparent 68%),
    radial-gradient(closest-side at 82% 6%, rgba(92,29,56,0.14), transparent 72%),
    radial-gradient(closest-side at 74% 58%, rgba(76,93,91,0.10), transparent 76%),
    linear-gradient(180deg, var(--paper) 0%, rgba(212,217,208,0.80) 58%, var(--paper) 100%);  /* MAIN BACKGROUND COLOR */
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  line-height: 1.55;
}



/* PAPER TEXTURE */
  body::after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
  background-image:
    repeating-radial-gradient(circle at 20% 15%,
      rgba(0,0,0,0.015) 0,
      rgba(0,0,0,0.015) 1px,
      transparent 1px,
      transparent 3px);
  mix-blend-mode:multiply;
}

body::before{
  content:"";
  position:fixed;
  inset:-20%;
  pointer-events:none;
  z-index:0;
  background:
    radial-gradient(closest-side at 10% 20%, rgba(76,93,91,0.07), transparent 65%),
    radial-gradient(closest-side at 80% 10%, rgba(92,29,56,0.05), transparent 70%),
    radial-gradient(closest-side at 70% 60%, rgba(212,150,125,0.06), transparent 72%);
  animation: driftLight 90s linear infinite;
}

@keyframes driftLight{
  from{ transform:translateY(0); }
  to{ transform:translateY(12%); }
}

/* END PAPER TEXTURE */

/* VIGNETTE */

html::after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
  box-shadow: inset 0 0 180px rgba(0,0,0,0.06);
}

/* END VIGNETTE */

/* LIFT CONTENT */

body > *{
  position:relative;
  z-index:1;
}

/* END LIFT CONTENT */


img{ max-width: 100%; height: auto; }

a{ color: inherit; text-decoration: none; }
a:hover{ text-decoration: underline; }

.container{
  width: min(var(--container), calc(100% - 2rem));
  margin: 0 auto;
}

/* Accessibility */
.skip-link{
  position: absolute;
  left: -999px;
  top: 8px;
  background: var(--berry);
  color: #fff;
  padding: 10px 12px;
  border-radius: 12px;
  z-index: 9999;
}
.skip-link:focus{ left: 12px; }

/* Typography */
h1,h2,h3,h4{
  font-family: "Marcellus", serif;
  letter-spacing: 0.2px;
  line-height: 1.15;
  margin: 0 0 0.6rem;
  color: var(--berry);
}
h1{ font-size: clamp(2.1rem, 3.6vw, 3.2rem); }
h2{ font-size: clamp(1.7rem, 2.6vw, 2.35rem); }
h3{ font-size: 1.25rem; }
p{ margin: 0 0 1rem; }

.script{
  font-family: "Bloom", "Simply", "Marcellus", serif;
  letter-spacing: 0.4px;
}

.eyebrow{
  display: inline-flex;
  gap: 10px;
  align-items: center;
  font-size: 1.4rem;
  color: rgba(31,38,37,0.72);
  margin: 0 0 12px;
}
.eyebrow .script{
  color: var(--berry);
  font-family: Simply;
  font-size: 1.8rem;
}

.subhead{
  margin: 0;
  max-width: 62ch;
  color: rgba(31,38,37,0.76);
  font-size: 1.05rem;
}
.lead{
  max-width: 60ch;
  color: rgba(31,38,37,0.80);
  font-size: 1.1rem;
}
.accent{
  color: var(--berry);
  white-space: nowrap;
}

/* Header */
.site-header{
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(251,250,247,0.82);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(76,93,91,0.14);
}
.header-inner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 0;
  gap: 18px;
}
.brand{
  display: flex;
  gap: 10px;
  align-items: center;
  text-decoration: none;
}
.brand-logo{
     width: 200px;
     height: auto;
     display: block;
     filter: drop-shadow(0 2px 6px rgba(92,29,56,.25));
}
.brand-mark{
  width: 38px;
  height: 38px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 30% 30%, rgba(212,150,125,0.42), transparent 60%),
    linear-gradient(135deg, rgba(92,29,56,0.16), rgba(76,93,91,0.08));
  border: 1px solid rgba(92,29,56,0.18);
  color: var(--berry);
  box-shadow: 0 10px 18px rgba(31,38,37,0.08);
}
.brand-text{ display: grid; line-height: 1.1; }
.brand-tag{ font-size: 1rem; color: #5C1D38; }

.nav{
  display: flex;
  align-items: center;
  gap: 14px;
}
.nav-link{
  font-size: 0.95rem;
  color: rgba(31,38,37,0.78);
  padding: 8px 10px;
  border-radius: 14px;
  position: relative; /* allows underline accent */
}
.nav-link:hover{
  background: rgba(229,227,220,0.55);
  text-decoration: none;
}

/* Active pill */
  body.nav-giftshop   .nav a[href="/giftshop.html"],
  body.nav-framework  .nav a[href="/quietcareframework.html"],
  body.nav-subscribe  .nav a[href="/subscriptionbox.html"],
  body.nav-realtors   .nav a[href="/realtors.html"],
  body.nav-corporate  .nav a[href="/corporate.html"],
  body.nav-about      .nav a[href="/our-approach.html"] {
    background: rgba(212,150,125,0.20);
    color: rgba(31,38,37,0.95);
    box-shadow: inset 0 0 0 1px rgba(76,93,91,0.18);
}

/* Subtle “locked in” underline */
  body.nav-giftshop   .nav a[href="/giftshop.html"]::after,
  body.nav-framework  .nav a[href="/quietcareframework.html"]::after,
  body.nav-subscribe  .nav a[href="/subscriptionbox.html"]::after,
  body.nav-realtors   .nav a[href="/realtors.html"]::after,
  body.nav-corporate  .nav a[href="/corporate.html"]::after,
  body.nav-about      .nav a[href="/our-approach.html"]::after {
   content: "";
   position: absolute;
   left: 10px;
   right: 10px;
   bottom: -6px;
   height: 2px;
   border-radius: 99px;
   background: rgba(212,150,125,0.85);
}

.nav-toggle{
  display: none;
  width: 44px;
  height: 44px;
  border-radius: 16px;
  border: 1px solid rgba(76,93,91,0.18);
  background: rgba(251,250,247,0.88);
  box-shadow: 0 10px 18px rgba(31,38,37,0.08);
}
.nav-toggle span{
  display: block;
  height: 2px;
  background: rgba(31,38,37,0.7);
  margin: 7px 10px;
  border-radius: 2px;
}

.mobile-panel{
  border-top: 1px solid rgba(76,93,91,0.14);
  padding: 12px 0 18px;
}
.mobile-link{
  display: block;
  padding: 10px 0;
  color: rgba(31,38,37,0.84);
}

/* Buttons */

.btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 18px;
  border: 1px solid transparent;
  text-decoration: none;
  font-weight: 650;
  cursor: pointer;
  transition: transform 120ms ease, box-shadow 120ms ease, background 120ms ease, border-color 120ms ease;
}

/* Physically define Winterberry button bodies */
.btn{
  padding: 12px 30px;          /* ← THIS is the “30px each side” */
  width: fit-content;
  min-width: 0;
  max-width: 100%;
  white-space: nowrap;
}

.btn-block{
  width: 75%;
  max-width: none;
}

.btn:hover{ text-decoration: none; transform: translateY(-1px); }

.btn-sm{ padding: 10px 12px; border-radius: 16px; font-size: 0.95rem; }

.btn-primary{
  background: linear-gradient(180deg, #6A2544, var(--berry));
  color: #fff;
  box-shadow: 0 14px 30px rgba(92,29,56,0.24);
}
.btn-primary:hover{
  box-shadow: 0 18px 34px rgba(92,29,56,0.28);
}

.btn-secondary{
  background: rgba(212,150,125,0.22);
  border-color: rgba(212,150,125,0.44);
  color: var(--berry);
}
.btn-secondary:hover{
  background: rgba(212,150,125,0.30);
  border-color: rgba(212,150,125,0.52);
}

.btn-ghost{
  background: rgba(251,250,247,0.55);
  border-color: rgba(76,93,91,0.22);
  color: rgba(31,38,37,0.86);
}
.btn-ghost:hover{
  background: rgba(229,227,220,0.55);
}


/* Sections */
.section{
  padding: 10px 0 clamp(44px, 6vw, 80px) 0;
}
.section-soft{
  background:
    radial-gradient(closest-side at 15% 30%, rgba(212,150,125,0.18), transparent 70%),
    linear-gradient(180deg, rgba(229,227,220,0.52) 0%, rgba(251,250,247,0.0) 100%);
  border-top: 1px solid rgba(76,93,91,0.12);
  border-bottom: 1px solid rgba(76,93,91,0.12);
}
.section-head{
  margin-top: 12px;
  margin-bottom: 12px;
  display: grid;
  gap: 10px;
}

/* Hero */
.hero{
  position: relative;
  padding: clamp(36px, 6vw, 72px) 0;
  overflow: hidden;
}
.hero-grid{
  display: grid;
  grid-template-columns: 1.25fr 0.95fr;
  gap: clamp(18px, 4vw, 36px);
  align-items: start;
}
.hero-actions{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 18px 0 18px;
}

/* Hopeful sunrise edge: subtle, warm, not flashy */
.tile,
.product,
.newsletter-card,
.small-card,
.realtor-card,
.moment,
.trust-item,
.hero-card,
.callout,
.point{
  position: relative;
  overflow: hidden; /* keeps the highlight clean with rounded corners */
}

.tile::before,
.product::before,
.newsletter-card::before,
.small-card::before,
.realtor-card::before,
.moment::before,
.trust-item::before,
.hero-card::before,
.callout::before,
.point::before{
  content: "";
  position: absolute;
  left: 14px;
  right: 14px;
  top: 10px;
  height: 2px;
  border-radius: 999px;
  background: var(--sunrise);
  opacity: 0.9;
  pointer-events: none;
}

.tile:hover::before,
.product:hover::before,
.newsletter-card::before,
.small-card:hover::before,
.realtor-card:hover::before,
.moment:hover::before,
.trust-item:hover::before,
.hero-card:hover::before,
.callout:hover::before,
.point:hover::before{
  background: var(--sunrise-strong);
  opacity: 1;
}


.trust{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 18px;
}
.trust-item{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.80), rgba(251,250,247,0.58)),
    radial-gradient(circle at top left, rgba(212,150,125,0.14), transparent 62%);
  border: 1px solid rgba(76,93,91,0.14);
  border-radius: 18px;
  padding: 12px 12px;
  box-shadow: 0 10px 20px rgba(31,38,37,0.06);
}
.trust-kicker{
  display: block;
  font-size: 0.85rem;
  color: rgba(31,38,37,0.64);
}
.trust-val{
  display: block;
  font-size: 0.98rem;
  color: rgba(31,38,37,0.86);
  margin-top: 2px;
}

.hero-card{
  position: relative;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.88), rgba(251,250,247,0.70)),
    radial-gradient(circle at 22% 18%, rgba(212,150,125,0.18), transparent 65%);
  border: 1px solid rgba(92,29,56,0.16);
  margin-bottom: 4px;
  box-shadow: var(--shadow);
}

.hero-card-inner{
  text-align:center; 
  margin-top: 20px;
  margin-bottom: 10px;
}

.card-script{
  margin: 0 0 6px;
  color: var(--berry);
  font-family: "Bloom", "Simply", serif;
  font-size: 1.35rem;
}
.card-title{
  margin: 0 0 12px;
  font-size: 1.28rem;
}
.picker{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 12px 0 18px;
}
.picker-center{
  justify-content: center;
}
.pill{
  padding: 10px 12px;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(212,150,125,0.48);
  background: rgba(212,150,125,0.22);
  color: rgba(31,38,37,0.86);
  font-weight: 650;
}
.pill:hover{
  background: rgba(212,150,125,0.30);
  border-color: rgba(212,150,125,0.58);
  text-decoration: none;
}
.fineprint{
  border-top: 1px dashed rgba(76,93,91,0.22);
  padding-top: 14px;
}
.microcopy{
  font-size: 0.9rem;
  color: rgba(31,38,37,0.66);
  margin-top: 10px;
}

.hero-wash{
  position: absolute;
  inset: -200px -200px auto -200px;
  height: 520px;
  background:
    radial-gradient(closest-side at 18% 40%, rgba(212,150,125,0.24), transparent 70%),
    radial-gradient(closest-side at 65% 45%, rgba(92,29,56,0.12), transparent 72%),
    radial-gradient(closest-side at 80% 10%, rgba(76,93,91,0.12), transparent 75%);
  pointer-events: none;
  filter: blur(6px);
  opacity: 0.95;
}

/* Grids */
.grid-3{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.grid-2{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

/* Soft card system */
.tile, .product, .newsletter-card, .small-card, .realtor-card{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.88), rgba(251,250,247,0.70)),
    radial-gradient(circle at top left, rgba(212,150,125,0.16), transparent 62%);
  border: 1px solid rgba(76,93,91,0.14);
  border-radius: var(--radius-lg);
  padding: 20px;
  box-shadow:
    var(--shadow-soft),
    inset 0 1px 0 rgba(255,255,255,0.45);
}
.tile-top{ margin-bottom: 10px; }
.tile-eyebrow{
  font-size: 0.9rem;
  color: rgba(31,38,37,0.64);
  margin: 0 0 6px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.tile-desc{ color: rgba(31,38,37,0.76); }

.checklist{
  list-style: none;
  padding: 0;
  margin: 12px 0 16px;
  display: grid;
  gap: 8px;
}
.checklist li{
  padding-left: 26px;
  position: relative;
  color: rgba(31,38,37,0.84);
}
.checklist li::before{
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--coral);
  opacity: 0.95;
  font-weight: 900;
}
.tile-actions{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

/* Tea Subscription Product Image */

.img-ph{
  max-width: 360px;
  margin: 24px auto;
  aspect-ratio: 1/1;  /* Makes it square */
  border-radius: 18px;
  overflow: hidden;
  background: rgba(229,227,220,0.45);
  box-shadow: 0 12px 30px rgba(31,38,37,0.18);
  display: flex;
  align-items: center;
  justify-content: center;
}

.img-ph img{
  width: 100%;
  height: 100%;
  Object-fit: cover; /* fills the square, trims edges if needed */
  display: block;
}

/* Moments */
.moments{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}
.moment{
  display: grid;
  grid-template-columns: 54px 1fr;
  gap: 12px;
  align-items: start;
  padding: 16px;
  border-radius: calc(var(--radius-lg) + 6px);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.88), rgba(251,250,247,0.70)),
    radial-gradient(circle at 18% 18%, rgba(212,150,125,0.14), transparent 62%);
  border: 1px solid rgba(92,29,56,0.14);
  box-shadow:
    var(--shadow-soft),
    inset 0 1px 0 rgba(255,255,255,0.40);
}
.moment-badge{
  width: 44px;
  height: 44px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 35% 30%, rgba(212,150,125,0.22), transparent 60%),
    rgba(92,29,56,0.08);
  border: 1px solid rgba(92,29,56,0.16);
  color: var(--berry);
  font-family: "Marcellus", serif;
}
.moment-tag{
  margin: 0 0 6px;
  color: rgba(31,38,37,0.70);
}
.moment-copy{
  margin: 0 0 12px;
  color: rgba(31,38,37,0.86);
}
.moment-actions{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}
.link{
  color: var(--pine);
  font-weight: 750;
}
.link:hover{ text-decoration: underline; }



/* Drift Carousel (reusable) */

.drift-carousel{
  width: 100%;
  overflow: hidden;
  margin: 24px 0;
}

.carousel-track{
  display: flex;
  gap: 18px;
  animation: driftScroll 36s linear infinite;
}

.carousel-item{
  width: 200px;
  border-radius: 15%;
  overflow: hidden;
  box-shadow: 0 12px 30px rgba(31,38,37,0.18);
  flex: 0 0 200px;
  background: #fff;
}

.carousel-item img{
  width: 100%;
  height: auto;
  display: block;
}

/* pause on hover */
.drift-carousel:hover .carousel-track{
  animation-play-state: paused;
}

@keyframes driftScroll{
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}


/* Callout */
.callout{
  margin-top: 20px;
  border-radius: var(--radius-lg);
  background:
    radial-gradient(closest-side at 20% 30%, rgba(212,150,125,0.22), transparent 70%),
    linear-gradient(135deg, rgba(212,150,125,0.16), rgba(229,227,220,0.18)),
    rgba(251,250,247,0.70);
  border: 1px solid rgba(212,150,125,0.34);
  box-shadow: var(--shadow-soft);
}
.callout-inner{
  padding: 18px;
  display: grid;
  gap: 10px;
}
.callout-inner p{
  color: rgba(31,38,37,0.78);
  max-width: 70ch;
}

/* Realtor section */
.section-berry{
  background:
    radial-gradient(closest-side at 70% 20%, rgba(212,150,125,0.16), transparent 72%),
    linear-gradient(180deg, rgba(92,29,56,0.08) 0%, rgba(229,227,220,0.36) 70%, rgba(251,250,247,0.0) 100%);
  border-top: 1px solid rgba(92,29,56,0.10);
  border-bottom: 1px solid rgba(92,29,56,0.10);
}
.realtor-grid{
  display: grid;
  grid-template-columns: 1.25fr 0.85fr;
  gap: 16px;
  align-items: start;
}
.realtor-points{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin: 16px 0 18px;
}
.point{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.78), rgba(251,250,247,0.60)),
    radial-gradient(circle at top left, rgba(212,150,125,0.12), transparent 62%);
  border: 1px solid rgba(76,93,91,0.12);
  border-radius: 20px;
  padding: 12px;
  box-shadow: 0 10px 20px rgba(31,38,37,0.06);
}
.point h3{ margin-bottom: 6px; font-size: 1.05rem; }
.point p{ margin: 0; color: rgba(31,38,37,0.74); }

.list{
  margin: 10px 0 0;
  padding-left: 18px;
  color: rgba(31,38,37,0.82);
}

/* About */
.about{
  display: grid;
  grid-template-columns: 1.2fr 0.85fr;
  gap: 16px;
  align-items: start;
  margin-top: 0;
}
.quote{
  border-left: 3px solid rgba(212,150,125,0.60);
  padding-left: 14px;
  color: rgba(31,38,37,0.82);
  margin: 16px 0 18px;
}
.link-grid{
  display: grid;
  gap: 10px;
  padding-top: 6px;
}

/* Footer */
.site-footer{
  padding: 15px 0 22px;
  border-top: 1px solid rgba(76,93,91,0.16);
  background:
    radial-gradient(closest-side at 18% 10%, rgba(212,150,125,0.20), transparent 68%),
    radial-gradient(closest-side at 82% 0%, rgba(92,29,56,0.12), transparent 70%),
    linear-gradient(180deg, rgba(229,227,220,0.78), rgba(251,250,247,0.86));
}
.footer-inner{
  display: grid;
  grid-template-columns: 1.1fr 1.4fr;
  gap: 18px;
  align-items: flex-start;
  padding-top: 15px;
}
.brand-mini{
  display: flex;
  gap: 10px;
  align-items: center;
}
.footer-cols{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 0;
}
.footer-cols h4{
  margin: 0 0 8px;
  font-size: 1.05rem;
}
.footer-cols a{
  display: block;
  padding: 6px 0;
  color: rgba(31,38,37,0.78);
}
.footer-bottom{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid rgba(76,93,91,0.12);
  color: rgba(31,38,37,0.70);
  font-size: 0.95rem;
}

.newsletter{
  margin: 0 auto;
  text-align: center; 
}

.newsletter-card{
  margin: 18px auto 0;
  width: min(520px, 30%);
  max-width: 100%;
  border-radius: var(--radius-lg);
  background:
    radial-gradient(closest-side at 70% 20%, rgba(212,150,125,0.16), transparent 72%),
    linear-gradient(180deg, rgba(92,29,56,0.08) 0%, rgba(229,227,220,0.36) 70%, rgba(251,250,247,0.0) 100%);
  box-shadow: var(--shadow);
}


/* START CONTACT PAGE */
/* Show form by default, hide thank-you until success */
#thank-you-block { 
  display: none; 
}

/* Optional: when we flip, keep the thank-you centered */
#thank-you-block {
  justify-content: center;
  align-items: center;
}
#thank-you-block .thank-you-container {
  max-width: 720px;
  width: 100%;
  margin: 0 auto;
  text-align: center;

  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;

  padding: 30px 20px;
}


.contact-intro-section {
}

.contact-inner {
  font-family: 'Bloom', serif;
  font-size: 18px;
  line-height: 1.6;
  font-weight: 400;
  color: #6E3847;
}

/* CONTACT PAGE */

.contact-block{
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  gap: 28px;
  background-color:#E5E3DC;
  padding:60px 20px;
  font-family:'Marcellus', serif;
  color:#4C5D5B;
}

.contact-left,
.contact-right{
  flex:1 1 420px;            /* keeps it from getting too skinny */
  padding:1rem;
  box-sizing:border-box;
}

.contact-left h2{
  font-size:2.5rem;
  color:#6E3847;
  margin:0 0 12px 0;
}

.contact-intro{
  text-align:center;
  margin: 0 auto;
  max-width: 42ch;
  color:#4C5D5B;
  line-height:1.6;
}

/* Form layout */
.contact-right form{
  display:flex;
  flex-direction:column;
  gap: 14px;
}

/* This is the big fix: label above input */
.contact-right .field{
  display:flex;
  flex-direction:column;
  gap: 6px;
}

.contact-right label{
  display:block;
  font-size: 0.95rem;
  color:#6E3847;
}

/* Inputs full-width */
.contact-right input,
.contact-right textarea{
  width:100%;
  font-family:inherit;
  font-size:1rem;
  padding:0.75rem;
  border:1px solid #6E3847;
  border-radius:8px;
  background:#fff;
  box-sizing:border-box;
}

.contact-right textarea{
  resize: vertical;
  min-height: 140px;
}

.contact-right button{
  font-size:1rem;
  background-color:#6E3847;
  color:#fff;
  border:none;
  padding:0.85rem 1.5rem;
  border-radius:8px;
  cursor:pointer;
  transition:background-color 0.2s ease;
  align-self:flex-start; /* keeps it from stretching full width */
}

.contact-right button:hover{
  background-color:#5C1D38;
}

/* Status line */
.form-status {
  font-size: 0.95rem;
  margin-top: 12px;
  color: #6E3847;
}

/* Thank you block centered */
#thank-you-block{
  display:none;              /* hidden until JS turns it on */
  justify-content:center;
  align-items:center;
  text-align:center;
}

.thank-you-container{
  width:100%;
  max-width:720px;
  margin:0 auto;
  text-align:center;
  padding:30px 20px;
}

.newsletter-embed{
  margin-top:18px;
}

/* Responsive */
@media screen and (max-width: 768px){
  .contact-block{
    flex-direction:column;
    padding: 44px 18px;
  }

  .contact-right button{
    align-self: stretch;     /* on mobile, make button full width */
    text-align:center;
  }
}

.contact-footer {
  padding: 10px 35px;
}

.footer-row {
  display: flex;
  justify-content: space-between; /* pushes items to opposite sides */
  align-items: center;
}


/* END CONTACT PG */

/* ====================================================================
   Index: one continuous background (eliminates visible section breaks)
   (keeps header + footer unchanged)
==================================================================== */

body.bg-continuous .section-soft,
body.bg-continuous .section-berry{
  background: transparent !important;
}

/* Optional: keep a gentle “band” cue without breaking the background */
body.bg-continuous .section-soft,
body.bg-continuous .section-berry{
  position: relative;
}

body.bg-continuous .section-soft::before,
body.bg-continuous .section-berry::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background: rgba(229,227,220,0.18); /* whisper-light wash */
}

/* Ensure the content sits above the wash */
body.bg-continuous .section-soft > .container,
body.bg-continuous .section-berry > .container{
  position: relative;
  z-index: 1;
}


/* Soft hover lift (subtle) */
.tile:hover,
.product:hover,
.newsletter-card:hover,
.moment:hover,
.small-card:hover,
.realtor-card:hover,
.point:hover,
.trust-item:hover{
  transform: translateY(-2px);
  box-shadow:
    0 26px 60px rgba(31,38,37,0.16),
    inset 0 1px 0 rgba(255,255,255,0.55);
  transition: transform 140ms ease, box-shadow 140ms ease;
}

/* Responsive */
@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; }
  .trust{ grid-template-columns: 1fr; }
  .grid-3{ grid-template-columns: 1fr; }
  .grid-2{ grid-template-columns: 1fr; }
  .moments{ grid-template-columns: 1fr; }
  .newsletter-card{
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    margin-left: auto;
    margin-right: auto;
  }
  .realtor-grid{ grid-template-columns: 1fr; }
  .realtor-points{ grid-template-columns: 1fr; }
  .about{ grid-template-columns: 1fr; }
  .footer-inner{ grid-template-columns: 1fr; }
  .footer-cols{ grid-template-columns: 1fr; }

  .nav{ display: none; }
  .nav-toggle{ display: inline-block; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  .btn{ transition: none; }
  .btn:hover{ transform: none; }
  .tile:hover,
  .product:hover,
  .newsletter-card:hover,
  .moment:hover,
  .small-card:hover,
  .realtor-card:hover,
  .point:hover,
  .trust-item:hover{
    transform: none;
    box-shadow:
      var(--shadow-soft),
      inset 0 1px 0 rgba(255,255,255,0.45);
  }
}