/* ═══════════════════════════════════════════════════════
   de'Finnitive Cacao — Shared Stylesheet
   Used by: index.html, gocacao.html, chocolates.html, pods.html
   ═══════════════════════════════════════════════════════ */

:root {
  --cream: #f7f2eb;
  --parchment: #ede5d8;
  --brown: #3b1f0f;
  --mid: #6b3a22;
  --copper: #a0522d;
  --amber: #c47a2b;
  --gold: #d4a853;
  --warm: #faf8f5;
  --green: #182e1e;
  --green-light: #6fa882;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background:var(--cream);
  color:var(--brown);
  font-family:'Outfit', sans-serif;
  font-weight:300;
  overflow-x:hidden;
  line-height:1.7;
}

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  display:flex; justify-content:space-between; align-items:center;
  padding:1rem 5rem;
  background:rgba(247,242,235,0.96); backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(59,31,15,0.08);
}
.nav-logo img { height:38px; }
.nav-links { display:flex; gap:2.5rem; list-style:none; }
.nav-links a {
  text-decoration:none; color:var(--brown);
  font-size:0.75rem; letter-spacing:0.12em; text-transform:uppercase;
  font-weight:500; transition:color 0.2s;
}
.nav-links a:hover { color:var(--copper); }
.nav-links a.active { color:var(--copper); border-bottom:1.5px solid var(--copper); padding-bottom:2px; }

/* ── SHARED ── */
section { padding:6rem 5rem; }
.slabel {
  font-family:'DM Mono', monospace; font-size:0.65rem;
  letter-spacing:0.25em; text-transform:uppercase;
  color:var(--copper); display:block; margin-bottom:1rem;
}
h2 {
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(2rem,3.5vw,3.2rem);
  font-weight:700; line-height:1.15; margin-bottom:1.5rem;
}
h2 em { font-style:italic; color:var(--copper); }
p { color:var(--mid); margin-bottom:1.2rem; font-size:0.95rem; }
p:last-child { margin-bottom:0; }
hr {
  border:none; height:1px;
  background:linear-gradient(to right,transparent,rgba(59,31,15,0.15),transparent);
  margin:0 5rem;
}

/* ── BUTTONS ── */
.btn {
  display:inline-block; padding:0.9rem 2rem;
  background:var(--brown); color:var(--cream);
  text-decoration:none; font-size:0.75rem;
  letter-spacing:0.12em; text-transform:uppercase;
  font-weight:500; transition:background 0.3s,transform 0.2s;
  border:1.5px solid var(--brown);
}
.btn:hover { background:var(--copper); border-color:var(--copper); transform:translateY(-2px); }
.btn-o { background:transparent; color:var(--brown); }
.btn-o:hover { background:var(--brown); color:var(--cream); }

/* ── FOOTER ── */
footer { background:var(--brown); color:var(--cream); padding:5rem 5rem 3rem; }
.footer-grid {
  display:grid; grid-template-columns:2fr 1fr 1fr;
  gap:4rem; margin-bottom:4rem;
}
.footer-brand img { height:42px; opacity:0.9; display:block; margin-bottom:1.5rem; object-fit:contain; }
.footer-brand p { font-size:0.85rem; color:rgba(247,242,235,0.55); max-width:280px; }
.fc h4 {
  font-family:'DM Mono', monospace; font-size:0.6rem;
  letter-spacing:0.2em; text-transform:uppercase;
  color:var(--gold); margin-bottom:1.5rem;
}
.fc a {
  display:block; text-decoration:none;
  color:rgba(247,242,235,0.55); font-size:0.85rem;
  margin-bottom:0.75rem; transition:color 0.2s;
}
.fc a:hover { color:var(--cream); }
.footer-bottom {
  display:flex; justify-content:space-between; padding-top:2rem;
  border-top:1px solid rgba(247,242,235,0.08);
  flex-wrap:wrap; gap:0.5rem;
}
.footer-bottom p {
  font-family:'DM Mono', monospace; font-size:0.6rem;
  letter-spacing:0.1em; color:rgba(247,242,235,0.3); margin-bottom:0;
}

/* ── PAGE HERO BANNER ── */
.page-hero {
  min-height:60vh; display:flex; align-items:flex-end;
  padding:0 5rem 5rem; padding-top:8rem;
  position:relative; overflow:hidden;
  background:var(--cream);
}
.page-hero-content { position:relative; z-index:2; max-width:700px; }
.page-hero h1 {
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(3.5rem,6vw,6rem); font-weight:700;
  line-height:0.95; margin-bottom:1.5rem;
}
.page-hero h1 em { font-style:italic; color:var(--copper); display:block; }
.page-hero-bg {
  position:absolute; top:0; left:0; right:0; bottom:0;
  background-size:cover; background-position:center;
  opacity:0.12;
}

/* ── IMAGE GRID ── */
.img-grid { display:grid; gap:2px; }
.img-grid img {
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform 0.5s ease;
}
.img-grid img:hover { transform:scale(1.02); }
.img-grid-2 { grid-template-columns:1fr 1fr; }
.img-grid-3 { grid-template-columns:1fr 1fr 1fr; }
.img-grid-2-1 { grid-template-columns:2fr 1fr; }
.img-grid-masonry { grid-template-columns:repeat(3,1fr); }

.img-frame {
  overflow:hidden;
  position:relative;
  background:var(--parchment);
}
.img-frame.tall { aspect-ratio:3/4; }
.img-frame.square { aspect-ratio:1/1; }
.img-frame.wide { aspect-ratio:16/9; }
.img-frame.short { aspect-ratio:4/3; }

/* ── GALLERY STRIP ── */
.gallery-strip {
  display:flex; gap:2px; overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.gallery-strip::-webkit-scrollbar { display:none; }
.gallery-strip .img-frame {
  flex:0 0 300px; scroll-snap-align:start;
}

/* ── SHOP ── */
.shop { background:var(--parchment); }
.shop-header { margin-bottom:3rem; }
.shop-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:2px; background:rgba(59,31,15,0.08);
}
.si { background:var(--cream); padding:2.5rem 2rem; transition:background 0.3s; }
.si:hover { background:var(--warm); }
.si-tag {
  font-family:'DM Mono', monospace; font-size:0.6rem;
  letter-spacing:0.15em; text-transform:uppercase;
  color:var(--copper); display:block; margin-bottom:1rem;
}
.si h3 { font-family:'Cormorant Garamond', serif; font-size:1.6rem; font-weight:600; margin-bottom:0.6rem; }
.si p { font-size:0.85rem; max-width:none; margin-bottom:1.5rem; }
.si-price { font-family:'Cormorant Garamond', serif; font-size:2rem; font-weight:700; color:var(--brown); }
.si-img { width:100%; aspect-ratio:4/3; object-fit:cover; margin-bottom:1.5rem; display:block; }
.add-btn {
  display:block; width:100%; margin-top:1.2rem; padding:0.85rem;
  background:var(--brown); color:var(--cream); border:none;
  font-family:'Outfit', sans-serif; font-size:0.72rem;
  letter-spacing:0.12em; text-transform:uppercase;
  font-weight:500; cursor:pointer; transition:background 0.3s;
}
.add-btn:hover { background:var(--copper); }
.shop-note { margin-top:2rem; font-style:italic; font-size:0.85rem; color:var(--mid); opacity:0.7; }

/* ── REVEAL ANIMATION ── */
.reveal { opacity:0; transform:translateY(20px); transition:opacity 0.65s ease,transform 0.65s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ── MOBILE ── */
@media(max-width:900px) {
  nav { padding:1rem 1.5rem; }
  .nav-links { display:none; }
  section { padding:4rem 1.5rem; }
  hr { margin:0 1.5rem; }
  .page-hero { padding:6rem 1.5rem 3rem; min-height:50vh; }
  .footer-grid { grid-template-columns:1fr; gap:2.5rem; }
  .img-grid-2, .img-grid-3, .img-grid-2-1, .img-grid-masonry { grid-template-columns:1fr; }
  .shop-grid { grid-template-columns:1fr 1fr; }
}
