/* ─────────────────────────────────────────────────────────────────────────────
   Cat-n-Bird Winery — Main Stylesheet
   Where Friends Meet.
───────────────────────────────────────────────────────────────────────────── */

:root {
  --burgundy:  #7A2030;
  --burgundy-2:#9A2840;
  --cream:     #F5EFE6;
  --gold:      #C9A96E;
  --gold-dim:  rgba(201,169,110,0.15);
  --dark:      #1A0A0A;
  --dark-2:    #0F0505;
  --dark-3:    #060202;
  --text-dim:  rgba(245,239,230,0.6);
  --text-muted:rgba(245,239,230,0.35);
  --serif:     'Cormorant Garamond', Georgia, serif;
  --sans:      'Inter', Arial, sans-serif;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }

body {
  font-family: var(--sans);
  background: var(--dark-2);
  color: var(--cream);
  font-size: 16px;
  line-height: 1.6;
}

img { max-width:100%; height:auto; display:block; }
a   { text-decoration:none; color:inherit; }

/* ── UTILITIES ─────────────────────────────────────────────────────────────── */
.container { max-width:1200px; margin:0 auto; padding:0 40px; }
.eyebrow {
  font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--gold); display:flex; align-items:center; gap:12px; margin-bottom:16px;
}
.eyebrow::before { content:''; width:32px; height:1px; background:var(--gold); display:block; }
.eyebrow.dark { color:var(--burgundy); }
.eyebrow.dark::before { background:var(--burgundy); }

.section-title { font-family:var(--serif); font-size:clamp(32px,4vw,52px); font-weight:400; line-height:1.1; }
.section-sub    { font-size:15px; color:var(--text-dim); max-width:560px; line-height:1.8; margin-top:12px; }
.section-sub.dark { color:#5a4a3a; }

.btn-primary {
  display:inline-block; background:var(--burgundy); color:var(--cream);
  padding:14px 30px; border-radius:3px; font-size:11px; font-weight:700;
  text-transform:uppercase; letter-spacing:.1em; border:none; cursor:pointer;
  transition:background .2s;
}
.btn-primary:hover { background:var(--burgundy-2); }
.btn-outline {
  display:inline-block; border:1px solid rgba(201,169,110,.5); color:var(--gold);
  padding:14px 30px; border-radius:3px; background:transparent; font-size:11px;
  font-weight:700; text-transform:uppercase; letter-spacing:.1em; cursor:pointer;
  transition:all .2s;
}
.btn-outline:hover { border-color:var(--gold); background:var(--gold-dim); }
.btn-dark {
  display:inline-block; background:var(--dark); color:var(--cream);
  padding:14px 30px; border-radius:3px; font-size:11px; font-weight:700;
  text-transform:uppercase; letter-spacing:.1em; cursor:pointer; border:none;
  transition:background .2s;
}
.btn-dark:hover { background:#2a0d10; }

/* ── NAV ───────────────────────────────────────────────────────────────────── */
.site-nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:rgba(15,5,5,.96); backdrop-filter:blur(10px);
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 40px;
  border-bottom:1px solid rgba(201,169,110,.12);
  transition:padding .3s;
}
.site-nav.scrolled { padding:10px 40px; }

.nav-logo {
  font-family:var(--serif); font-size:20px; letter-spacing:.18em;
  color:var(--gold); text-transform:uppercase; font-weight:400;
}
.nav-logo span { color:var(--burgundy); }
/* Logo image in nav */
.nav-logo img { height:44px; width:auto; display:block; }
/* Logo image in footer */
.footer-logo img { height:80px; width:auto; display:block; margin-bottom:8px; }

.nav-links { display:flex; align-items:center; gap:28px; }
.nav-links a {
  font-size:11px; color:rgba(245,239,230,.7); text-transform:uppercase;
  letter-spacing:.1em; transition:color .2s;
}
.nav-links a:hover { color:var(--gold); }
.nav-links .nav-cta {
  background:var(--burgundy); color:var(--cream) !important;
  padding:9px 20px; border-radius:3px; font-weight:700;
}
.nav-links .nav-cta:hover { background:var(--burgundy-2); }

.nav-toggle { display:none; background:none; border:none; color:var(--gold); font-size:22px; cursor:pointer; }

/* ── HERO ──────────────────────────────────────────────────────────────────── */
.hero {
  position:relative; min-height:44vh; display:flex; align-items:flex-end;
  overflow:hidden;
}
.hero-bg {
  position:absolute; inset:0;
  background-image:url('https://img1.wsimg.com/isteam/ip/044fe520-ed84-46fa-8ce2-2902341f7bd9/IMG_6364.jpg');
  background-size:cover; background-position:center top;
  transition:transform 8s ease; transform:scale(1.04);
}
.hero-bg.loaded { transform:scale(1); }
.hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(10,3,3,.93) 0%, rgba(10,3,3,.5) 55%, rgba(10,3,3,.18) 100%);
}
.hero-content {
  position:relative; z-index:2;
  padding:0 60px 80px; max-width:760px;
}
.hero-content .eyebrow { margin-bottom:22px; }
.hero-title {
  font-family:var(--serif); font-size:clamp(54px,7vw,90px); font-weight:400;
  line-height:1.0; color:var(--cream); margin-bottom:22px;
}
.hero-title em { color:var(--gold); font-style:italic; }
.hero-sub { font-size:16px; color:var(--text-dim); max-width:480px; line-height:1.8; margin-bottom:36px; }
.hero-btns { display:flex; gap:14px; flex-wrap:wrap; }
.hero-scroll {
  position:absolute; bottom:32px; right:50px; z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:8px; opacity:.4;
}
.scroll-line { width:1px; height:44px; background:var(--gold); }
.scroll-label {
  font-size:9px; color:var(--gold); text-transform:uppercase;
  letter-spacing:.16em; writing-mode:vertical-rl;
}

/* ── AWARDS BAR ────────────────────────────────────────────────────────────── */
.awards-bar {
  background:var(--burgundy); padding:20px 40px;
  display:flex; align-items:center; justify-content:center;
  gap:40px; flex-wrap:wrap;
}
.award { display:flex; align-items:center; gap:14px; }
.award-icon { font-size:24px; }
.award-text { font-size:12px; color:rgba(245,239,230,.85); line-height:1.5; }
.award-text strong { display:block; font-size:13px; color:#fff; font-weight:700; }
.award-divider { width:1px; height:40px; background:rgba(255,255,255,.2); }
.press-badge {
  font-size:11px; color:rgba(245,239,230,.65);
  border:1px solid rgba(255,255,255,.2); padding:6px 16px;
  border-radius:20px; white-space:nowrap;
}

/* ── EXPLORE BUTTONS ────────────────────────────────────────────────────────── */
.explore-section {
  background:var(--dark-2); padding:70px 60px 80px; text-align:center;
}
.explore-header  { margin-bottom:40px; }
.explore-header .eyebrow {
  justify-content:center; font-size:13px; letter-spacing:.2em; color:var(--gold);
}
.explore-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:20px; max-width:860px; margin:0 auto;
}
.explore-btn {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  background:#2a1a0e; border:1px solid rgba(201,169,110,.25);
  border-radius:14px; padding:34px 24px 30px; text-decoration:none;
  transition:background .2s, border-color .2s, transform .18s, box-shadow .18s;
  cursor:pointer;
}
.explore-btn:hover {
  background:#321f10; border-color:var(--gold);
  transform:translateY(-3px); box-shadow:0 8px 32px rgba(0,0,0,.4);
}
.explore-btn.featured {
  border-color:var(--gold); border-width:2px;
  background:#2f1c0d;
}
.explore-icon  { font-size:36px; margin-bottom:16px; }
.explore-label { font-family:var(--serif); font-size:19px; font-weight:700; color:var(--cream); margin-bottom:8px; line-height:1.2; }
.explore-sub   { font-size:13px; color:rgba(245,239,230,.5); line-height:1.5; }
.explore-arrow { display:none; }

/* ── SELF-SELECT MEET GRID ──────────────────────────────────────────────────── */
.meet-select { background:var(--dark-2); padding:90px 0 0; }
.meet-select-header { padding:0 60px 50px; }
.meet-grid { display:grid; grid-template-columns:repeat(4,1fr); }
.meet-card { position:relative; height:400px; overflow:hidden; cursor:pointer; }
.meet-card img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .6s ease; filter:brightness(.5);
}
.meet-card:hover img { transform:scale(1.06); filter:brightness(.65); }
.meet-card-content {
  position:absolute; inset:0; display:flex; flex-direction:column;
  justify-content:flex-end; padding:28px 24px;
}
.meet-card .eyebrow { margin-bottom:6px; }
.meet-card-title { font-family:var(--serif); font-size:26px; color:var(--cream); margin-bottom:8px; }
.meet-card-sub { font-size:12px; color:var(--text-dim); line-height:1.6; margin-bottom:14px; }
.meet-card-arrow {
  font-size:10px; color:var(--gold); text-transform:uppercase; letter-spacing:.12em;
  opacity:0; transition:opacity .2s; display:flex; align-items:center; gap:8px;
}
.meet-card-arrow::after { content:'→'; }
.meet-card:hover .meet-card-arrow { opacity:1; }

/* ── COMMUNITY / FRIENDS SECTION ───────────────────────────────────────────── */
.friends-section { background:var(--cream); padding:90px 60px; }
.friends-section .section-title { color:var(--dark); }
.friends-section .section-sub   { color:#6a4a3a; margin-bottom:40px; }
.friends-grid { display:grid; grid-template-columns:2fr 1fr 1fr; grid-template-rows:220px 220px; gap:4px; }
.friends-grid .f-main { grid-row:span 2; }
.friends-grid img { width:100%; height:100%; object-fit:cover; display:block; }

/* ── WINES SECTION ──────────────────────────────────────────────────────────── */
.wines-section { background:var(--dark); padding:90px 60px; }
.wines-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; margin:40px 0 30px; }
.wine-card {
  background:rgba(201,169,110,.06); border:1px solid rgba(201,169,110,.15);
  padding:32px 28px; transition:background .2s; cursor:pointer;
}
.wine-card:hover { background:rgba(201,169,110,.12); }
.wine-origin { font-size:10px; color:var(--gold); text-transform:uppercase; letter-spacing:.16em; margin-bottom:12px; }
.wine-name   { font-family:var(--serif); font-size:22px; color:var(--cream); margin-bottom:10px; }
.wine-desc   { font-size:12px; color:var(--text-dim); line-height:1.7; margin-bottom:18px; }
.wine-sweetness { display:flex; align-items:center; gap:10px; }
.sweetness-track { flex:1; height:2px; background:rgba(201,169,110,.2); border-radius:1px; position:relative; }
.sweetness-fill  { height:100%; background:var(--gold); border-radius:1px; }
.sweetness-label { font-size:9px; color:rgba(201,169,110,.5); text-transform:uppercase; letter-spacing:.1em; }

/* ── ANIMALS ────────────────────────────────────────────────────────────────── */
.animals-section { background:#2a0d10; padding:90px 60px; position:relative; overflow:hidden; }
.animals-bg {
  position:absolute; inset:0;
  background-image:url('https://img1.wsimg.com/isteam/ip/044fe520-ed84-46fa-8ce2-2902341f7bd9/Untitled2.jpg');
  background-size:cover; background-position:center; opacity:.12;
}
.animals-inner { position:relative; z-index:2; }
.animals-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:40px; }
.animal-card { background:rgba(15,5,5,.75); border:1px solid rgba(201,169,110,.2); overflow:hidden; }
.animal-emoji-wrap {
  height:140px; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg,#1a0505,#3a1015); font-size:64px;
}
.animal-img-wrap { aspect-ratio:1/1; overflow:hidden; }
.animal-img-wrap img { width:100%; height:100%; object-fit:cover; }
.animal-info { padding:18px; }
.animal-name { font-family:var(--serif); font-size:18px; color:var(--gold); margin-bottom:6px; }
.animal-bio  { font-size:12px; color:var(--text-dim); line-height:1.7; }

/* ── VENUE SPLIT ────────────────────────────────────────────────────────────── */
.venue-split { display:grid; grid-template-columns:1fr 1fr; min-height:580px; background:var(--cream); }
.venue-img { overflow:hidden; }
.venue-img img { width:100%; height:100%; object-fit:cover; display:block; }
.venue-copy { padding:80px 60px; display:flex; flex-direction:column; justify-content:center; }
.venue-copy .section-title { color:var(--dark); }
.venue-copy p { font-size:14px; color:#5a4a3a; line-height:1.9; margin:16px 0 24px; max-width:440px; }
.venue-features { display:grid; grid-template-columns:1fr 1fr; gap:10px 24px; margin-bottom:28px; }
.venue-feat {
  font-size:12px; color:#5a4a3a; display:flex; align-items:center; gap:8px;
}
.venue-feat::before { content:'✓'; color:var(--burgundy); font-weight:700; font-size:13px; }
.venue-pricing { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:28px; }
.price-pill {
  background:var(--burgundy); color:var(--cream); padding:6px 14px;
  border-radius:20px; font-size:11px; font-weight:600;
}

/* ── SPITTING LLAMA ──────────────────────────────────────────────────────────── */
.llama-section { background:var(--dark-2); padding:80px 60px; }
.llama-inner { display:grid; grid-template-columns:220px 1fr; gap:70px; align-items:center; }
.llama-logo img { border-radius:10px; width:100%; }
.llama-copy .section-title { margin-bottom:10px; }
.beers-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:28px; }
.beer-card {
  background:rgba(201,169,110,.07); border:1px solid rgba(201,169,110,.2);
  padding:20px 18px;
}
.beer-name  { font-family:var(--serif); font-size:17px; color:var(--gold); margin-bottom:5px; }
.beer-style { font-size:9px; color:var(--text-dim); text-transform:uppercase; letter-spacing:.1em; margin-bottom:10px; }
.beer-desc  { font-size:12px; color:var(--text-dim); line-height:1.6; margin-bottom:12px; }
.beer-price { font-size:12px; color:var(--gold); font-weight:600; }

/* ── THIS SATURDAY ───────────────────────────────────────────────────────────── */
.saturday-section { background:var(--burgundy); padding:50px 60px; }
.saturday-inner { display:flex; align-items:center; gap:60px; flex-wrap:wrap; }
.saturday-label { font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:rgba(245,239,230,.7); margin-bottom:8px; }
.saturday-title { font-family:var(--serif); font-size:32px; color:#fff; }
.saturday-items { display:flex; gap:40px; flex:1; flex-wrap:wrap; }
.saturday-item { }
.saturday-item-label { font-size:9px; text-transform:uppercase; letter-spacing:.14em; color:rgba(245,239,230,.6); margin-bottom:4px; }
.saturday-item-value { font-size:16px; color:#fff; font-weight:600; }
.saturday-item-time  { font-size:12px; color:rgba(245,239,230,.7); }
.saturday-note { font-size:13px; color:rgba(245,239,230,.8); margin-top:6px; font-style:italic; }

/* ── EVENTS PREVIEW ──────────────────────────────────────────────────────────── */
.events-section { background:var(--dark-2); padding:90px 60px; }
.events-list { margin-top:40px; }
.event-row {
  display:flex; align-items:center; gap:24px; padding:22px 0;
  border-bottom:1px solid rgba(201,169,110,.12);
}
.event-row:last-child { border-bottom:none; }
.event-date-block { width:56px; text-align:center; flex-shrink:0; }
.event-day   { font-family:var(--serif); font-size:36px; color:var(--gold); line-height:1; }
.event-month { font-size:10px; color:rgba(201,169,110,.6); text-transform:uppercase; letter-spacing:.1em; margin-top:2px; }
.event-divider { width:1px; height:48px; background:rgba(201,169,110,.15); flex-shrink:0; }
.event-info { flex:1; }
.event-title { font-family:var(--serif); font-size:20px; color:var(--cream); margin-bottom:4px; }
.event-details { font-size:12px; color:var(--text-dim); }
.event-tag {
  font-size:9px; text-transform:uppercase; letter-spacing:.1em;
  padding:4px 12px; border-radius:20px; flex-shrink:0;
}
.tag-music  { background:rgba(122,32,48,.4); color:#e88a9a; }
.tag-food   { background:rgba(201,169,110,.15); color:var(--gold); }
.tag-special{ background:rgba(42,110,58,.3); color:#6ec98a; }

/* ── WINE CLUB CTA ───────────────────────────────────────────────────────────── */
.wine-club-section {
  position:relative; overflow:hidden;
  background-image:url('https://img1.wsimg.com/isteam/ip/044fe520-ed84-46fa-8ce2-2902341f7bd9/IMG_8840.jpeg');
  background-size:cover; background-position:center;
  background-attachment:fixed;
}
.wine-club-overlay { background:rgba(10,3,3,.88); padding:100px 60px; }
.wine-club-inner { max-width:580px; margin:0 auto; text-align:center; }
.wine-club-inner .eyebrow { justify-content:center; }
.wine-club-inner .eyebrow::before { display:none; }
.wine-club-inner .section-title { margin-bottom:14px; }
.wine-club-inner p { font-size:15px; color:var(--text-dim); line-height:1.9; margin-bottom:36px; }
.club-form { display:flex; gap:10px; max-width:480px; margin:0 auto 16px; }
.club-input {
  flex:1; background:rgba(255,255,255,.08); border:1px solid rgba(201,169,110,.3);
  color:var(--cream); padding:14px 20px; border-radius:3px; font-size:13px;
  font-family:var(--sans);
}
.club-input::placeholder { color:rgba(245,239,230,.35); }
.club-input:focus { outline:none; border-color:var(--gold); }
.club-submit {
  background:var(--burgundy); color:var(--cream); padding:14px 24px; border:none;
  border-radius:3px; font-size:11px; font-weight:700; text-transform:uppercase;
  letter-spacing:.1em; cursor:pointer; white-space:nowrap; transition:background .2s;
}
.club-submit:hover { background:var(--burgundy-2); }
.club-note { font-size:11px; color:var(--text-muted); letter-spacing:.05em; }

/* ── FOOTER ──────────────────────────────────────────────────────────────────── */
.site-footer { background:var(--dark-3); padding:60px 60px 30px; }
.footer-top { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:50px; margin-bottom:50px; }
.footer-logo    { font-family:var(--serif); font-size:22px; color:var(--gold); letter-spacing:.16em; text-transform:uppercase; margin-bottom:8px; }
.footer-tagline { font-size:14px; color:rgba(245,239,230,.4); margin-bottom:20px; font-style:italic; }
.footer-contact p { font-size:12px; color:rgba(245,239,230,.4); margin-bottom:5px; }
.footer-contact a { color:rgba(245,239,230,.55); transition:color .2s; }
.footer-contact a:hover { color:var(--gold); }
.footer-socials { display:flex; gap:10px; margin-top:20px; }
.footer-socials a {
  width:34px; height:34px; border:1px solid rgba(201,169,110,.25); border-radius:50%;
  display:flex; align-items:center; justify-content:center; font-size:12px;
  color:rgba(245,239,230,.5); transition:all .2s;
}
.footer-socials a:hover { border-color:var(--gold); color:var(--gold); }
.footer-col-head {
  font-size:10px; color:var(--gold); text-transform:uppercase;
  letter-spacing:.14em; margin-bottom:18px;
}
.footer-col a {
  display:block; font-size:13px; color:rgba(245,239,230,.45);
  margin-bottom:10px; transition:color .2s;
}
.footer-col a:hover { color:rgba(245,239,230,.8); }
.footer-bottom {
  border-top:1px solid rgba(201,169,110,.1); padding-top:22px;
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:10px;
}
.footer-bottom span { font-size:11px; color:var(--text-muted); }

/* ── PAGE HERO (inner pages) ──────────────────────────────────────────────────── */
.page-hero {
  position:relative; height:60vh; min-height:380px;
  display:flex; align-items:flex-end; overflow:hidden;
}
.page-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; }
.page-hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(10,3,3,.9) 0%, rgba(10,3,3,.4) 60%, rgba(10,3,3,.15) 100%);
}
.page-hero-content { position:relative; z-index:2; padding:0 60px 60px; }
.page-hero-content .section-title { color:var(--cream); }

/* ── WINE CATALOG (wines page) ────────────────────────────────────────────────── */
.wines-catalog-section { background:var(--dark); padding:80px 60px; }
.wines-catalog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:40px; }
.wine-catalog-card {
  background:rgba(201,169,110,.06); border:1px solid rgba(201,169,110,.15);
  overflow:hidden; transition:border-color .2s;
}
.wine-catalog-card:hover { border-color:rgba(201,169,110,.4); }
.wine-catalog-thumb { height:220px; overflow:hidden; background:linear-gradient(135deg,#1a0505,#3a1015); display:flex; align-items:center; justify-content:center; }
.wine-catalog-thumb img { width:100%; height:100%; object-fit:cover; }
.wine-catalog-body { padding:24px; }

/* ── VENUE PAGE ───────────────────────────────────────────────────────────────── */
.packages-section { background:var(--cream); padding:80px 60px; }
.packages-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:40px; }
.package-card { border:2px solid var(--burgundy); padding:36px 30px; transition:border-color .2s; background:var(--dark); color:var(--cream); }
.package-name  { font-family:var(--serif); font-size:26px; margin-bottom:6px; }
.package-price { font-size:32px; font-weight:700; color:var(--gold); margin-bottom:4px; }
.package-guests { font-size:13px; margin-bottom:20px; opacity:.7; }
.package-includes { list-style:none; }
.package-includes li { font-size:13px; padding:5px 0; border-bottom:1px solid rgba(255,255,255,.08); display:flex; gap:8px; }
.package-includes li::before { content:'✓'; color:var(--gold); font-weight:700; }

/* ── INQUIRY FORM ─────────────────────────────────────────────────────────────── */
.inquiry-section { background:var(--dark-2); padding:80px 60px; }
.inquiry-inner { max-width:700px; margin:0 auto; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:36px; }
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-group.full { grid-column:span 2; }
.form-group label { font-size:11px; text-transform:uppercase; letter-spacing:.1em; color:var(--gold); }
.form-group input,
.form-group select,
.form-group textarea {
  background:rgba(255,255,255,.06); border:1px solid rgba(201,169,110,.25);
  color:var(--cream); padding:13px 16px; border-radius:3px; font-size:14px;
  font-family:var(--sans); transition:border-color .2s;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { outline:none; border-color:var(--gold); }
.form-group textarea { resize:vertical; min-height:120px; }
.form-group select option { background:var(--dark); color:var(--cream); }
.form-submit { margin-top:20px; }

/* ── TEAM GRID ────────────────────────────────────────────────────────────────── */
.team-section { background:var(--cream); padding:80px 60px; }
.team-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:40px; }
.team-card { background:#fff; }
.team-photo { height:200px; overflow:hidden; background:#e8ddd0; }
.team-photo img { width:100%; height:100%; object-fit:cover; }
.team-body { padding:18px; }
.team-name { font-family:var(--serif); font-size:18px; color:var(--dark); margin-bottom:3px; }
.team-role { font-size:11px; text-transform:uppercase; letter-spacing:.1em; color:var(--burgundy); margin-bottom:10px; }
.team-bio  { font-size:12px; color:#5a4a3a; line-height:1.7; margin-bottom:10px; }
.team-wine { font-size:11px; color:var(--burgundy); }
.team-wine::before { content:'🍷 Favorite: '; }

/* ── GALLERY GRID ─────────────────────────────────────────────────────────────── */
.gallery-section { background:var(--dark-2); padding:80px 60px; }
.gallery-tabs { display:flex; gap:0; margin-bottom:30px; border-bottom:1px solid rgba(201,169,110,.15); }
.gallery-tab {
  padding:10px 22px; font-size:11px; text-transform:uppercase; letter-spacing:.1em;
  color:rgba(245,239,230,.5); cursor:pointer; border-bottom:2px solid transparent;
  margin-bottom:-1px; transition:all .2s;
}
.gallery-tab.active { color:var(--gold); border-bottom-color:var(--gold); }
.gallery-masonry { columns:3; gap:4px; }
.gallery-masonry img { width:100%; margin-bottom:4px; display:block; break-inside:avoid; }

/* ── VISIT PAGE ───────────────────────────────────────────────────────────────── */
.visit-info { background:var(--cream); padding:80px 60px; }
.visit-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; margin-top:40px; }
.info-block h3 { font-family:var(--serif); font-size:24px; color:var(--dark); margin-bottom:14px; }
.info-block p  { font-size:14px; color:#5a4a3a; line-height:1.8; margin-bottom:8px; }
.info-block .big-hours { font-family:var(--serif); font-size:48px; color:var(--burgundy); line-height:1; margin-bottom:8px; }

/* ── MAP EMBED PLACEHOLDER ────────────────────────────────────────────────────── */
.map-section { background:var(--dark-2); padding:80px 60px; }
.map-embed { width:100%; height:420px; border:none; border-radius:4px; margin-top:30px; }

/* ── RESPONSIVE ───────────────────────────────────────────────────────────────── */
@media (max-width:1024px) {
  .meet-grid         { grid-template-columns:repeat(2,1fr); }
  .wines-grid        { grid-template-columns:repeat(2,1fr); }
  .animals-grid      { grid-template-columns:repeat(2,1fr); }
  .team-grid         { grid-template-columns:repeat(2,1fr); }
  .packages-grid     { grid-template-columns:1fr; }
  .wines-catalog-grid{ grid-template-columns:repeat(2,1fr); }
  .beers-grid        { grid-template-columns:1fr; }
  .footer-top        { grid-template-columns:1fr 1fr; }
  .llama-inner       { grid-template-columns:1fr; gap:30px; }
  .llama-logo        { max-width:180px; }
}

@media (max-width:768px) {
  .site-nav       { padding:14px 20px; }
  .nav-links      { display:none; flex-direction:column; position:absolute; top:100%; left:0; right:0; background:var(--dark-2); padding:20px; gap:16px; }
  .nav-links.open { display:flex; }
  .nav-toggle     { display:block; }
  .hero-content   { padding:0 20px 60px; }
  .hero-title     { font-size:42px; }
  .explore-section   { padding:50px 20px 60px; }
  .explore-grid      { grid-template-columns:repeat(2,1fr); }
  .container, .friends-section, .wines-section, .animals-section,
  .llama-section, .wine-club-overlay, .events-section, .packages-section,
  .inquiry-section, .team-section, .gallery-section, .visit-info,
  .map-section, .saturday-section { padding-left:20px; padding-right:20px; }
  .meet-grid      { grid-template-columns:1fr; }
  .meet-card      { height:280px; }
  .friends-grid   { grid-template-columns:1fr 1fr; grid-template-rows:auto; }
  .friends-grid .f-main { grid-row:span 1; }
  .wines-grid     { grid-template-columns:1fr; }
  .animals-grid   { grid-template-columns:1fr 1fr; }
  .venue-split    { grid-template-columns:1fr; }
  .venue-img      { height:320px; }
  .venue-copy     { padding:40px 20px; }
  .form-grid      { grid-template-columns:1fr; }
  .form-group.full{ grid-column:span 1; }
  .team-grid      { grid-template-columns:1fr 1fr; }
  .gallery-masonry{ columns:2; }
  .visit-grid     { grid-template-columns:1fr; }
  .footer-top     { grid-template-columns:1fr; gap:30px; }
  .footer-bottom  { flex-direction:column; text-align:center; }
  .awards-bar     { flex-direction:column; gap:20px; }
  .award-divider  { width:80px; height:1px; }
  .club-form      { flex-direction:column; }
  .beers-grid     { grid-template-columns:1fr; }
  .saturday-inner { flex-direction:column; gap:24px; }
}
