/* ==========================================================================
   Index (landing) — mobile-first hero + PWA hint
   Relies on global.css tokens and glass styles.
   ========================================================================== */

.hero{
  padding: 24px 0 10px;
}
.hero-wrap{
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--gap);
}
@media (min-width: 960px){
  .hero-wrap{
    grid-template-columns: 1.2fr 0.8fr;
    align-items: center;
  }
}

.hero-title{
  font: 700 32px/1.15 var(--ui-head);
  margin: 6px 0 10px;
}
.hero-title .spark{ font-size: .9em; }

.hero-sub{
  color: var(--muted);
  font-size: 15px;
  line-height: 1.5;
  margin: 0 0 14px;
  max-width: 52ch;
}

.hero-ctas{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom: 10px; }
.hero-btn{ min-width: 140px; justify-content: center; }

.hero-points{
  list-style: none; padding:0; margin: 6px 0 0;
  display:grid; gap:8px;
}
.hero-points li{
  display:flex; align-items:center; gap:8px;
  background: var(--glass-2);
  border: 1px solid var(--glass-br);
  border-radius: 12px;
  padding: 8px 10px;
  font-size: 14px;
}
.hero-points .material-symbols-outlined{ font-size: 18px; }

.hero-right{
  padding: 12px;
}
.preview{
  border-radius: 14px;
  border: 1px solid var(--glass-br);
  background: var(--glass-2);
  padding: 12px;
}
.preview .row{ margin-bottom: 10px; }
.preview .tag{
  display:inline-block; padding:4px 8px; border-radius: 999px;
  background: rgba(255,255,255,.18); border:1px solid var(--glass-br);
  font-size:12px;
}
.preview .it{
  margin-top:6px;
  display:flex; align-items:center; gap:8px;
  padding:8px 10px; border-radius: 12px;
  background: rgba(255,255,255,.12); border:1px solid var(--glass-br);
}
.preview .it.in{ background: rgba(34,197,94,.18); }
.preview .dot{
  width:10px; height:10px; border-radius:50%;
  background: rgba(255,255,255,.75);
}
.preview .foot{
  margin-top: 8px; display:flex; align-items:center; gap:8px;
  color: var(--muted); font-size: 12px;
}

/* PWA hint strip */
.install-hint{ padding: 6px 0 24px; }
.hint-wrap{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding: 10px 12px;
}
.hint-wrap .left{ display:flex; align-items:center; gap:10px; }
.hint-title{ font-weight: 700; }
.hint-sub{ font-size: 12px; color: var(--muted); }

@media (max-width: 540px){
  .hero-title{ font-size: 26px; }
  .hero-sub{ font-size: 14px; }
}

/* ========================================================================
   4. FRESH PRODUCE PICTURE SECTIONS
   ======================================================================== */
.produce-hero-card{
  position: relative;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.40);
  background: linear-gradient(180deg, rgba(255,255,255,.18), rgba(255,255,255,.10));
  box-shadow: 0 14px 45px rgba(14,33,60,.28);
  min-height: 320px;
}
.produce-hero-card img{
  width: 100%;
  height: 420px;
  object-fit: cover;
  display: block;
  filter: saturate(1.06) contrast(1.05);
}
.produce-hero-overlay{
  position: absolute;
  left: 16px; right: 16px; bottom: 16px;
  display: flex; gap: 10px; flex-wrap: wrap;
}
.pchip{
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.92);
  color: #1d3356; font-weight: 700; padding: 8px 12px;
  border-radius: 999px; border: 1px solid rgba(255,255,255,.40);
}

/* --- Gallery grid --- */
.produce-gallery{ margin: 10px 0 6px; }
.produce-grid{
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
}
@media (max-width: 1100px){ .produce-grid{ grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 620px){ .produce-grid{ grid-template-columns: repeat(2, 1fr); } }

.produce-tile{
  position: relative; min-height: 160px;
  border-radius: 16px; overflow: hidden;
  border: 1px solid rgba(255,255,255,.40);
  background: #cfe8ff;
  box-shadow: 0 14px 45px rgba(14,33,60,.28);
}
.produce-tile img{
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  filter: saturate(1.06) contrast(1.05);
}
.produce-label{
  position: absolute; left: 10px; bottom: 10px;
  padding: 6px 10px; font-weight: 700;
  background: rgba(255,255,255,.92); color: #1e3254;
  border: 1px solid rgba(255,255,255,.40); border-radius: 999px;
}

/* Keep hero image heights consistent */
.produce-hero-card img { height: 420px; object-fit: cover; }

/* Tiles behave like background-cover */
.produce-tile img { width: 100%; height: 100%; object-fit: cover; }


