/* ═══════════════════════════════════════════════
   WASATCH FRONT FUNGI — Shared Stylesheet
   ═══════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400;1,500&family=Jost:wght@200;300;400&display=swap');

/* ── TOKENS ── */
:root {
  --ink:        #0d0c09;
  --ink-soft:   #141410;
  --parchment:  #f4efe6;
  --cream:      #faf7f2;
  --gold:       #b8955a;
  --gold-light: #d4ae78;
  --gold-dim:   rgba(184,149,90,0.15);
  --moss:       #3a4a30;
  --ash:        #8a8478;
  --ash-dim:    rgba(138,132,120,0.4);
  --border:     rgba(184,149,90,0.18);
  --transition: 0.35s cubic-bezier(0.16,1,0.3,1);
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html, body { margin:0; padding:0; border:0; outline:0; }
html { scroll-behavior: smooth; font-size: 16px; }
body::before { top:0; }

/* ── SMALL OUTLINE BUTTON (hero CTA) ── */
.btn-outline-sm {
  padding: 0.8rem 1.8rem;
  font-size: 0.65rem;
}

/* ── VARIETY CARD PHOTO ── */
.variety-photo {
  width: 180px;
  flex-shrink: 0;
  border-radius: 1px;
  background-size: cover;
  background-position: center;
  min-height: 140px;
  border: 1px solid var(--border);
  align-self: stretch;
}

/* ── TESTIMONIAL INDICATOR ── */
.testimonial-card { cursor: pointer; }
.testimonial-indicator {
  font-size: 0.55rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--gold); opacity: 0.5; margin-top: 0.6rem;
  transition: opacity var(--transition);
}
.testimonial-card:hover .testimonial-indicator { opacity: 1; }

/* ── TESTIMONIAL MODAL ── */
.testimonial-modal {
  position:fixed; inset:0; z-index:1000;
  background:rgba(13,12,9,0.85); backdrop-filter:blur(6px);
  display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none; transition:opacity 0.3s ease;
}
.testimonial-modal.open { opacity:1; pointer-events:all; }
.testimonial-modal-inner {
  background:#181610; border:1px solid var(--border);
  padding:3.5rem; max-width:540px; width:90%;
  position:relative; transform:translateY(20px);
  transition:transform 0.3s ease;
}
.testimonial-modal.open .testimonial-modal-inner { transform:translateY(0); }
.testimonial-close {
  position:absolute; top:1.2rem; right:1.5rem;
  background:none; border:none; color:var(--ash);
  font-size:1.4rem; cursor:pointer; line-height:1;
  transition:color var(--transition);
}
.testimonial-close:hover { color:var(--gold); }
.testimonial-modal-name {
  font-family:'Cormorant Garamond', serif;
  font-size:0.7rem; letter-spacing:0.3em; text-transform:uppercase;
  color:var(--gold); margin-bottom:1.5rem;
}
.testimonial-modal-quote {
  font-family:'Cormorant Garamond', serif;
  font-size:1.4rem; font-style:italic; font-weight:300;
  line-height:1.7; color:var(--parchment);
}
.testimonial-modal-empty {
  font-family:'Cormorant Garamond', serif;
  font-size:1rem; font-style:italic; color:var(--ash); opacity:0.5;
}

html { scroll-behavior: smooth; font-size: 16px; margin:0; padding:0; }
body {
  background: var(--ink);
  color: var(--parchment);
  font-family: 'Jost', sans-serif;
  font-weight: 300;
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  margin:0; padding:0;
}
img { display:block; max-width:100%; }
a { text-decoration:none; color:inherit; }

/* ── LOGO IMAGE ── */
.logo-lockup {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  text-decoration: none;
}
.logo-img {
  height: 32px;
  width: auto;
  display: block;
  flex-shrink: 0;
}
.logo-img-footer {
  height: 26px;
  opacity: 0.85;
}
.hero-logo-bg {
  width: 100%;
  height: auto;
  opacity: 0.07;
  display: block;
}

body::before {
  content:'';
  position:fixed; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events:none; z-index:9999; opacity:0.3;
}

/* ══════════════════════
   NAVIGATION
══════════════════════ */
.site-nav {
  position:fixed; top:0; left:0; right:0;
  z-index:500;
  display:flex; justify-content:space-between; align-items:center;
  padding:1.8rem 4rem;
  transition: background 0.4s, padding 0.4s;
}
.site-nav::before {
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(to bottom, rgba(13,12,9,0.92) 0%, transparent 100%);
  pointer-events:none;
  transition: opacity 0.4s;
}
.site-nav.scrolled::before {
  background: rgba(13,12,9,0.97);
  backdrop-filter: blur(8px);
}
.nav-logo {
  font-family:'Cormorant Garamond', serif;
  font-size:1rem; font-weight:400;
  letter-spacing:0.2em; text-transform:uppercase;
  color:var(--gold); position:relative;
  transition: opacity var(--transition);
}
.nav-logo:hover { opacity:0.75; }
.nav-links {
  display:flex; gap:2.8rem; list-style:none; position:relative;
}
.nav-links a {
  font-size:0.68rem; letter-spacing:0.22em; text-transform:uppercase;
  color:var(--parchment); opacity:0.6;
  transition: opacity var(--transition), color var(--transition);
  position:relative;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-4px; left:0; right:0;
  height:1px; background:var(--gold);
  transform:scaleX(0); transform-origin:left;
  transition:transform var(--transition);
}
.nav-links a:hover, .nav-links a.active { opacity:1; color:var(--gold-light); }
.nav-links a:hover::after, .nav-links a.active::after { transform:scaleX(1); }
.nav-toggle {
  display:none; flex-direction:column; gap:5px; cursor:pointer;
  position:relative; z-index:1; padding:4px;
  background:none; border:none; outline:none;
}
.nav-toggle span { display:block; width:24px; height:1px; background:var(--parchment); transition:var(--transition); }

/* ══════════════════════
   FOOTER
══════════════════════ */
.site-footer {
  border-top:1px solid var(--border);
  padding:3rem 4rem;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:2rem;
}
.footer-logo {
  font-family:'Cormorant Garamond', serif;
  font-size:0.95rem; font-weight:400;
  letter-spacing:0.18em; color:var(--gold); text-transform:uppercase;
}
.footer-tagline {
  font-family:'Cormorant Garamond', serif;
  font-style:italic; font-size:0.9rem; color:var(--ash);
  text-align:center;
}
.footer-copy {
  font-size:0.62rem; letter-spacing:0.15em;
  color:var(--ash); opacity:0.45; text-align:right;
}
.footer-nav {
  display:flex; gap:2rem; list-style:none;
  justify-content:flex-end; margin-top:1.2rem;
  grid-column:1/-1;
  border-top:1px solid var(--border); padding-top:1.5rem;
  justify-content:center;
}
.footer-nav a {
  font-size:0.62rem; letter-spacing:0.2em; text-transform:uppercase;
  color:var(--ash); opacity:0.5; transition:opacity var(--transition);
}
.footer-nav a:hover { opacity:1; color:var(--gold-light); }

/* ══════════════════════
   MARQUEE
══════════════════════ */
.marquee-wrapper {
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:1.2rem 0; overflow:hidden;
  background:rgba(184,149,90,0.03);
}
.marquee-track {
  display:flex; animation:marquee 35s linear infinite; white-space:nowrap;
}
.marquee-item {
  font-size:0.6rem; letter-spacing:0.3em; text-transform:uppercase;
  color:var(--ash); padding:0 2.5rem; flex-shrink:0;
}
.marquee-dot { color:var(--gold); padding:0 0.4rem; }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ══════════════════════
   PAGE HERO (inner pages)
══════════════════════ */
.page-hero {
  min-height:42vh; display:flex; align-items:flex-end;
  padding:8rem 4rem 5rem; position:relative; overflow:hidden;
}

/* ── PAGE HERO IMAGE ── */
.page-hero-img {
  position:absolute; inset:0; z-index:0;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
/* Dark overlay sits on top of image, keeps text readable */
.page-hero-bg {
  position:absolute; inset:0; z-index:1;
  background:
    radial-gradient(ellipse 70% 80% at 30% 60%, rgba(58,74,48,0.18) 0%, transparent 70%),
    radial-gradient(ellipse 50% 60% at 80% 30%, rgba(184,149,90,0.06) 0%, transparent 60%),
    linear-gradient(160deg, rgba(13,12,9,0.88) 0%, rgba(13,12,9,0.75) 60%, rgba(13,12,9,0.9) 100%);
}
.page-hero-content { position:relative; z-index:2; }
.page-eyebrow {
  font-size:0.62rem; letter-spacing:0.35em; text-transform:uppercase;
  color:var(--gold); margin-bottom:1rem;
  opacity:0; animation:fadeUp 0.8s ease 0.1s forwards;
}
.page-title {
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(3rem,6vw,5.5rem); font-weight:300; line-height:1.0;
  opacity:0; animation:fadeUp 1s ease 0.2s forwards;
}
.page-title em { font-style:italic; color:var(--gold-light); }

/* ══════════════════════
   SHARED LAYOUT
══════════════════════ */
.container { max-width:1280px; margin:0 auto; padding:0 4rem; }
.section { padding:7rem 0; }
.section-sm { padding:4rem 0; }
.section-label {
  font-size:0.6rem; letter-spacing:0.35em; text-transform:uppercase;
  color:var(--gold); margin-bottom:1.2rem; display:block;
}
.section-title {
  font-family:'Cormorant Garamond', serif;
  font-size:clamp(2.2rem,4vw,3.4rem); font-weight:300; line-height:1.1;
  margin-bottom:2.5rem;
}
.section-title em { font-style:italic; color:var(--gold-light); }
.divider {
  width:50px; height:1px; background:var(--gold); margin:2rem 0;
}
.body-text {
  font-size:0.88rem; line-height:2; color:var(--ash);
}
.body-text p { margin-bottom:1.4rem; }
.body-text p:last-child { margin-bottom:0; }

/* ══════════════════════
   BUTTONS & LINKS
══════════════════════ */
.btn-outline {
  display:inline-block;
  border:1px solid var(--gold); color:var(--gold);
  font-size:0.68rem; letter-spacing:0.28em; text-transform:uppercase;
  padding:1.1rem 3rem; position:relative; overflow:hidden;
  transition:color var(--transition);
}
.btn-outline::before {
  content:''; position:absolute; inset:0;
  background:var(--gold);
  transform:translateX(-101%); transition:transform var(--transition);
}
.btn-outline:hover { color:var(--ink); }
.btn-outline:hover::before { transform:translateX(0); }
.btn-outline span { position:relative; z-index:1; }

.text-link {
  display:inline-flex; align-items:center; gap:0.8rem;
  font-size:0.68rem; letter-spacing:0.25em; text-transform:uppercase;
  color:var(--parchment); border-bottom:1px solid var(--gold);
  padding-bottom:0.3rem;
  transition:color var(--transition), gap var(--transition);
}
.text-link::after { content:'→'; font-size:0.85rem; }
.text-link:hover { color:var(--gold-light); gap:1.4rem; }

/* ══════════════════════
   ANIMATIONS
══════════════════════ */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(28px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes fadeIn {
  from { opacity:0; } to { opacity:1; }
}

.reveal {
  opacity:0; transform:translateY(24px);
  transition:opacity 0.8s ease, transform 0.8s ease;
}
.reveal.visible { opacity:1; transform:translateY(0); }

/* ══════════════════════
   RESPONSIVE
══════════════════════ */
@media (max-width:900px) {
  .site-nav { padding:1.4rem 1.5rem; }
  .nav-links { display:none; flex-direction:column; gap:0;
    position:fixed; top:0; left:0; right:0; bottom:0;
    background:rgba(13,12,9,0.98); backdrop-filter:blur(12px);
    justify-content:center; align-items:center;
    z-index:400;
  }
  .nav-links.open { display:flex; }
  .nav-links li { padding:1.2rem 0; }
  .nav-links a { font-size:0.85rem; letter-spacing:0.25em; opacity:0.8; }
  .nav-toggle { display:flex; }
  .container { padding:0 1.5rem; }
  .page-hero { padding:6rem 1.5rem 4rem; min-height:36vh; }
  .section { padding:5rem 0; }
  .site-footer { grid-template-columns:1fr; gap:1rem; padding:2.5rem 1.5rem; }
  .footer-copy { text-align:left; }
  .footer-nav { justify-content:flex-start; flex-wrap:wrap; gap:1.2rem; }
}
