/* East Poultry Co. — styles (original design + responsive layer). Fonts via Google Fonts. */
:root{
  --cream: #f4ede0;
  --cream-2: #ece2cf;
  --paper: #faf6ec;
  --ink: #1a1410;
  --ink-soft: #4a3f33;
  --brick: #7a2e1f;
  --brick-deep: #5a1f12;
  --forest: #3a4a2a;
  --gold: #c7a14a;
  --rule: rgba(26,20,16,.16);

  --serif: "Bodoni Moda", "Bodoni 72", "Didot", "Times New Roman", serif;
  --sans: "Public Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* ─── Layout ─── */
.wrap{max-width:1320px;margin:0 auto;padding:0 32px}
.wrap-narrow{max-width:980px;margin:0 auto;padding:0 32px}

/* ─── Type system ─── */
.eyebrow{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--brick);
}
.eyebrow-ink{color:var(--ink-soft)}
h1,h2,h3{font-family:var(--serif);font-weight:500;letter-spacing:-.01em;margin:0;text-wrap:balance}
h1{font-size:clamp(48px, 8vw, 116px); line-height:.92; font-weight:500; letter-spacing:-.02em}
h2{font-size:clamp(36px, 5vw, 72px); line-height:.98}
h3{font-size:clamp(22px, 2.2vw, 30px); line-height:1.1}
.lead{font-size:clamp(18px,1.6vw,22px); line-height:1.5; color:var(--ink-soft); max-width:60ch; text-wrap:pretty}
.serif-it{font-style:italic; font-family:var(--serif)}

/* ─── Nav ─── */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px 32px;
  transition: background .35s ease, backdrop-filter .35s ease, border-color .35s ease, padding .35s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(244,237,224,.92);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom-color:var(--rule);
  padding:14px 32px;
}
.nav-brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.nav-logo{
  height:64px; width:auto; display:block;
  transition: height .35s ease;
}
.nav.scrolled .nav-logo{height:52px}
.nav-links{display:flex; gap:36px; align-items:center}
.nav-links a{
  font-size:15px; font-weight:500; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink); padding:8px 2px; position:relative;
}
.nav-links a::after{
  content:""; position:absolute; left:0; right:0; bottom:2px; height:2px;
  background:var(--brick); transform:scaleX(0); transform-origin:left; transition:transform .35s ease;
}
.nav-links a:hover::after, .nav-links a.active::after{transform:scaleX(1)}
.nav-cta{
  font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  border:1px solid var(--ink); padding:12px 20px; border-radius:999px; color:var(--ink); background:transparent;
  transition: background .25s ease, color .25s ease;
  font-weight:500;
}
.nav-cta:hover{background:var(--ink); color:var(--cream)}

/* ─── Hero ─── */
.hero{
  min-height:100vh;
  display:grid;
  grid-template-columns: 1.15fr 1fr;
  gap:48px;
  align-items:end;
  padding:140px 32px 64px;
  max-width:1320px; margin:0 auto;
  position:relative;
}
.hero-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:24px}
.hero-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--brick)}
.hero h1{margin-bottom:28px}
.hero h1 em{font-style:italic; color:var(--brick); font-weight:400}
.hero-meta{
  display:flex; flex-direction:column; gap:14px;
  border-top:1px solid var(--rule); padding-top:24px; margin-top:36px;
  max-width:48ch;
}
.hero-meta .row{display:flex; gap:24px; align-items:baseline; font-size:14px}
.hero-meta .row .k{font-family:var(--mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-soft); min-width:88px}
.hero-meta .row .v{color:var(--ink)}

.hero-img-wrap{
  position:relative; aspect-ratio: 3/4; max-height: 80vh;
  background:var(--cream-2);
  overflow:hidden;
  border-radius:2px;
  align-self:end;
}
.hero-img-wrap img{width:100%;height:100%;object-fit:cover; object-position:center}
.hero-img-caption{
  position:absolute; bottom:14px; left:14px; right:14px;
  font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--cream); display:flex; justify-content:space-between; align-items:flex-end;
  text-shadow:0 1px 4px rgba(0,0,0,.4);
}
.hero-img-caption .frame{
  display:inline-flex; gap:6px; padding:4px 8px; border:1px solid rgba(255,255,255,.5);
}

/* Ticker */
.ticker{
  background:var(--brick); color:var(--cream);
  overflow:hidden; white-space:nowrap; padding:14px 0;
  border-top:1px solid rgba(0,0,0,.15); border-bottom:1px solid rgba(0,0,0,.15);
}
.ticker-track{display:inline-flex; gap:48px; padding-left:48px; animation: scroll 38s linear infinite}
.ticker-track span{font-family:var(--serif); font-size:22px; letter-spacing:.02em; font-style:italic; font-weight:400}
.ticker-track .sep{color:rgba(255,255,255,.5)}
@keyframes scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ─── Section base ─── */
section{padding:120px 0; position:relative}
.section-head{
  display:grid; grid-template-columns: 1fr 2fr; gap:48px;
  margin-bottom:64px;
  align-items:end;
}
.section-head .label{display:flex; flex-direction:column; gap:14px}
.section-head .num{font-family:var(--mono); font-size:11px; letter-spacing:.18em; color:var(--ink-soft)}

/* ─── About ─── */
.about{background:var(--paper); border-top:1px solid var(--rule); border-bottom:1px solid var(--rule)}
.about-grid{
  display:grid; grid-template-columns: 1fr 1fr; gap:80px;
  align-items:start;
}
.about-stats{
  display:grid; grid-template-columns:1fr 1fr; gap:1px;
  margin-top:48px; background:var(--rule); border:1px solid var(--rule);
}
.about-stats .stat{background:var(--paper); padding:24px 20px}
.about-stats .n{font-family:var(--serif); font-size:48px; line-height:1; font-weight:500}
.about-stats .l{font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); margin-top:8px}
.about-photo{aspect-ratio: 4/5; background:var(--cream-2); overflow:hidden; position:relative}
.about-photo img{width:100%;height:100%;object-fit:cover}
.about-photo .cap{
  position:absolute; bottom:0; left:0; right:0; padding:16px 18px;
  background:linear-gradient(to top, rgba(0,0,0,.6), transparent);
  color:var(--cream); font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase;
}

/* ─── History timeline ─── */
.history{background:var(--cream)}
.timeline{
  position:relative;
  margin-top:24px;
}
.timeline::before{
  content:""; position:absolute; top:0; bottom:0; left:50%;
  width:1px; background:var(--rule);
}
.tl-entry{
  display:grid; grid-template-columns:1fr 80px 1fr;
  gap:0; align-items:start; position:relative;
  padding:48px 0;
  opacity:0; transform:translateY(24px); transition: opacity .9s ease, transform .9s ease;
}
.tl-entry.in{opacity:1; transform:none}
.tl-year{
  grid-column:2; display:flex; flex-direction:column; align-items:center; gap:10px;
  position:sticky; top:120px;
  align-self:start;
}
.tl-year .y{
  font-family:var(--serif); font-style:italic; font-weight:500; font-size:30px; color:var(--brick);
  background:var(--cream); padding:4px 10px;
}
.tl-year .pin{
  width:11px; height:11px; border-radius:50%; background:var(--brick);
  box-shadow:0 0 0 4px var(--cream), 0 0 0 5px var(--brick);
}
.tl-card{padding:0 48px}
.tl-card.left{grid-column:1; text-align:right}
.tl-card.right{grid-column:3}
.tl-card h3{margin-bottom:12px}
.tl-card p{color:var(--ink-soft); max-width:46ch}
.tl-card.left p{margin-left:auto}
.tl-photo{
  margin-top:18px; background:var(--cream-2); overflow:hidden; aspect-ratio: 4/3;
}
.tl-photo img{width:100%;height:100%;object-fit:cover; transition: transform 1.2s ease}
.tl-card:hover .tl-photo img{transform:scale(1.04)}
.tl-photo.tall{aspect-ratio:3/4}
.tl-photo.wide{aspect-ratio:16/10}
/* Four-generations portrait photo: show the whole thing, no crop */
.tl-photo:has(img[src*="four-generations"]),
.tl-photo[data-fit="contain"]{
  aspect-ratio: 5/4;
  background: #d8d8d6;
}
.tl-photo img[src*="four-generations"],
.tl-photo[data-fit="contain"] img{
  object-fit: contain;
}
.tl-cap{
  font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft);
  margin-top:10px;
}

/* Pull quote between timeline entries */
.pull{
  text-align:center; padding:80px 0; max-width:920px; margin:0 auto;
  font-family:var(--serif); font-style:italic; font-size:clamp(28px,3.5vw,44px); line-height:1.22;
  color:var(--ink);
}
.pull::before, .pull::after{
  content:"—"; display:block; font-family:var(--mono); font-size:14px; color:var(--brick); margin:0 auto 24px;
}
.pull::after{margin:24px auto 0}

/* ─── Products ─── */
.products{background:var(--ink); color:var(--cream); border-top:1px solid #000}
.products .eyebrow{color:var(--gold)}
.products h2{color:var(--cream)}
.products .lead{color:rgba(244,237,224,.7)}
.product-grid{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:24px; margin-top:24px;
}
.product{
  background:#221a14; border:1px solid #2b211a; padding:32px;
  position:relative; transition: background .3s ease, transform .3s ease;
  display:flex; flex-direction:column; gap:18px;
  min-height:340px;
}
.product:hover{background:#2a1f17; transform:translateY(-4px)}
.product .num{font-family:var(--mono); font-size:11px; letter-spacing:.18em; color:var(--gold)}
.product h3{color:var(--cream)}
.product p{color:rgba(244,237,224,.65); font-size:14px; flex:1}
.product ul{list-style:none; padding:0; margin:0; display:flex; flex-wrap:wrap; gap:6px}
.product li{
  font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase;
  border:1px solid rgba(244,237,224,.2); padding:5px 8px; color:rgba(244,237,224,.75);
}
.product .arrow{
  position:absolute; top:32px; right:32px; width:28px; height:28px;
  display:flex;align-items:center;justify-content:center; color:var(--gold);
  transition: transform .3s ease;
}
.product:hover .arrow{transform:translate(4px,-4px)}

/* ─── Products: price callout, category accordion, freezer rental ─── */
.price-callout{
  background:#221a14; border:1px solid #2b211a; padding:36px 36px 32px;
  margin-bottom:56px;
}
.pc-eyebrow{
  font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--gold);
}
.pc-grid{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:36px;
  margin-top:24px; padding-top:24px; border-top:1px solid rgba(244,237,224,.1);
}
.pc-block h4{
  font-family:var(--serif); font-size:22px; font-weight:500; color:var(--cream);
  margin:0 0 10px;
}
.pc-block p{
  color:rgba(244,237,224,.7); font-size:14px; line-height:1.55; margin:0;
}
.pc-actions{
  display:flex; gap:14px; flex-wrap:wrap; margin-top:28px; padding-top:28px;
  border-top:1px solid rgba(244,237,224,.1);
}
.pc-btn{
  flex:1; min-width:240px;
  display:flex; flex-direction:column; gap:6px;
  background:transparent; border:1px solid rgba(244,237,224,.25);
  padding:18px 20px; transition: background .25s ease, border-color .25s ease;
}
.pc-btn:hover{background:rgba(244,237,224,.06); border-color:rgba(244,237,224,.4)}
.pc-btn.primary{background:var(--brick); border-color:var(--brick)}
.pc-btn.primary:hover{background:var(--brick-deep, #5a1f12); border-color:var(--brick-deep, #5a1f12)}
.pc-btn-k{font-family:var(--mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:rgba(244,237,224,.7)}
.pc-btn.primary .pc-btn-k{color:rgba(255,255,255,.85)}
.pc-btn-v{font-family:var(--serif); font-size:22px; color:var(--cream)}

/* Category accordion */
.product-cat-list{display:flex; flex-direction:column; gap:0; border-top:1px solid rgba(244,237,224,.12)}
.product-cat{border-bottom:1px solid rgba(244,237,224,.12)}
.product-cat-head{
  width:100%; background:transparent; border:0; color:var(--cream);
  display:flex; align-items:flex-start; justify-content:space-between; gap:24px;
  padding:28px 4px; text-align:left;
  transition: background .25s ease;
}
.product-cat-head:hover{background:rgba(244,237,224,.03)}
.product-cat-lead{display:flex; align-items:flex-start; gap:24px; flex:1}
.product-cat-lead .num{
  font-family:var(--mono); font-size:11px; letter-spacing:.18em; color:var(--gold);
  padding-top:8px; min-width:30px;
}
.product-cat-head h3{
  font-family:var(--serif); font-size:28px; color:var(--cream); font-weight:500; margin:0 0 6px;
}
.product-cat-head p{
  color:rgba(244,237,224,.65); font-size:14px; line-height:1.5; margin:0; max-width:60ch;
}
.product-cat-toggle{
  font-family:var(--serif); font-size:32px; font-weight:300; color:var(--gold);
  line-height:1; min-width:24px; text-align:right;
  transition: transform .3s ease;
}
.product-cat.open .product-cat-toggle{color:var(--cream)}
.product-cat-items{
  padding:4px 4px 32px 58px;
  animation: catFade .35s ease;
}
@keyframes catFade { from{opacity:0; transform:translateY(-6px)} to{opacity:1; transform:none} }
.product-cat-items ul{
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns: repeat(2, 1fr); gap:8px 32px;
}
.product-cat-items li{
  font-size:14px; color:rgba(244,237,224,.78);
  padding:6px 0; border-bottom:1px dashed rgba(244,237,224,.1);
  font-family:var(--sans);
}
.product-cat-items li.has-note{
  display:flex; flex-direction:column; gap:4px;
  padding-bottom:10px;
}
.product-cat-items .item-label{
  display:inline-flex; align-items:center; gap:8px;
  color:var(--cream);
}
.product-cat-items .item-star{
  color:var(--gold); font-size:11px; line-height:1;
}
.product-cat-items .item-note{
  font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--gold); padding-left:18px;
}

/* Freezer rental */
.freezer-rental{
  margin-top:64px; border:1px solid rgba(244,237,224,.2); padding:48px;
  background: linear-gradient(135deg, rgba(199,161,74,.06) 0%, rgba(244,237,224,.02) 100%);
}
.fr-tag{
  font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--gold); margin-bottom:20px;
}
.fr-content{
  display:grid; grid-template-columns: 1.6fr 1fr; gap:32px; align-items:center;
}
.fr-content h3{font-family:var(--serif); font-size:36px; font-weight:500; color:var(--cream); margin:0 0 12px}
.fr-content p{color:rgba(244,237,224,.7); margin:0; max-width:58ch; font-size:15px; line-height:1.6}
.fr-cta{
  justify-self:end;
  font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--cream); padding:18px 26px;
  border:1px solid var(--gold); transition: background .25s ease, color .25s ease;
}
.fr-cta:hover{background:var(--gold); color:var(--ink)}

/* ─── Recipes ─── */
.recipes{background:var(--cream)}
.recipe-grid{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:28px;
}
.recipe{
  cursor:pointer; background:transparent; border:0; padding:0; text-align:left;
  display:flex; flex-direction:column; gap:16px;
}
.recipe:focus-visible{outline:2px solid var(--brick); outline-offset:6px}
.recipe-img{
  aspect-ratio: 4/5; background:var(--cream-2); overflow:hidden; position:relative;
}
.recipe-img img{
  width:100%; height:100%; object-fit:cover; display:block;
  transition: transform 1.2s ease;
}
.recipe:hover .recipe-img img{transform:scale(1.05)}
.recipe-img .ph{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-soft);
  background-image: repeating-linear-gradient(45deg, var(--cream-2) 0 12px, var(--paper) 12px 24px);
}
.recipe-img .meta{
  position:absolute; top:14px; left:14px;
  font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink); background:var(--cream); padding:5px 9px;
}
.recipe-img .like{
  position:absolute; top:14px; right:14px; width:32px; height:32px; border-radius:50%;
  background:rgba(255,255,255,.92); border:0; display:flex; align-items:center; justify-content:center;
  font-size:14px; transition: background .2s ease, transform .2s ease;
}
.recipe-img .like:hover{background:#fff; transform:scale(1.08)}
.recipe-img .like.on{background:var(--brick); color:var(--cream)}
.recipe h3{font-size:24px}
.recipe-info{display:flex; gap:14px; font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft)}
.recipe-info span+span::before{content:"·"; margin-right:14px}

/* Recipe modal */
.modal-back{
  position:fixed; inset:0; background:rgba(15,12,8,.55); z-index:100;
  display:flex; align-items:center; justify-content:center; padding:32px;
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  animation: fade .25s ease;
}
@keyframes fade { from{opacity:0} to{opacity:1} }
.modal{
  background:var(--cream); max-width:1100px; width:100%; max-height:90vh; overflow:auto;
  display:grid; grid-template-columns: 1.1fr 1fr;
  animation: rise .35s cubic-bezier(.2,.7,.2,1);
}
@keyframes rise { from{opacity:0; transform:translateY(20px)} to{opacity:1; transform:none} }
.modal-img{background:var(--cream-2); min-height:520px; position:relative; overflow:hidden}
.modal-img img{width:100%; height:100%; object-fit:cover; display:block}
.modal-img .ph{position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-soft);
  background-image: repeating-linear-gradient(45deg, var(--cream-2) 0 14px, var(--paper) 14px 28px);
}
.modal-body{padding:48px 44px; display:flex; flex-direction:column; gap:20px}
.modal-body h3{font-size:38px}
.modal-stats{display:flex; gap:24px; padding:16px 0; border-top:1px solid var(--rule); border-bottom:1px solid var(--rule)}
.modal-stats .ms{display:flex; flex-direction:column; gap:4px}
.modal-stats .ms .l{font-family:var(--mono); font-size:9px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft)}
.modal-stats .ms .v{font-family:var(--serif); font-size:20px}
.modal-cols{display:grid; grid-template-columns: 1fr 1fr; gap:32px}
.modal-cols h4{font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; margin:0 0 12px; color:var(--brick)}
.modal-cols ul{margin:0; padding-left:18px; font-size:14px; color:var(--ink-soft); display:flex; flex-direction:column; gap:6px}
.modal-cols ol{margin:0; padding-left:18px; font-size:14px; color:var(--ink-soft); display:flex; flex-direction:column; gap:10px}
.modal-x{
  position:absolute; top:18px; right:18px; width:36px; height:36px; border-radius:50%;
  background:rgba(255,255,255,.9); border:0; font-size:16px; display:flex; align-items:center; justify-content:center;
}

/* ─── Contact ─── */
.contact{background:var(--paper); border-top:1px solid var(--rule)}
.contact-grid{display:grid; grid-template-columns: 1.1fr 1fr; gap:64px; align-items:start}
.contact-card{
  border:1px solid var(--rule); background:var(--cream); padding:36px; display:flex; flex-direction:column; gap:24px;
}
.contact-card h3{font-size:30px}
.contact-row{display:flex; flex-direction:column; gap:6px; padding:18px 0; border-top:1px solid var(--rule)}
.contact-row:first-of-type{border-top:0; padding-top:0}
.contact-row .k{font-family:var(--mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-soft)}
.contact-row .v{font-family:var(--serif); font-size:22px; color:var(--ink); font-weight:500}
.contact-row .v.small{font-size:18px}

.map-wrap{aspect-ratio: 4/5; background:var(--cream-2); position:relative; overflow:hidden; border:1px solid var(--rule)}
.map-wrap iframe{
  width:100%; height:100%; display:block;
  /* Subtle warm tone over Google's map so it sits in the design */
  filter: saturate(.85) contrast(.95);
}
.map-grid{
  position:absolute; inset:0;
  background:
    linear-gradient(var(--rule) 1px, transparent 1px) 0 0/40px 40px,
    linear-gradient(90deg, var(--rule) 1px, transparent 1px) 0 0/40px 40px,
    var(--cream);
  opacity:.7;
}
.map-street{
  position:absolute; background:var(--cream-2);
}
.map-pin{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-100%);
  display:flex; flex-direction:column; align-items:center; gap:6px;
}
.map-pin .tip{
  width:14px; height:14px; background:var(--brick); border-radius:50% 50% 50% 0;
  transform: rotate(-45deg); box-shadow:0 4px 12px rgba(122,46,31,.4);
}
.map-pin .lbl{
  font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase;
  background:var(--ink); color:var(--cream); padding:5px 10px;
}

/* Reviews */
.reviews{padding-top:0}
.reviews-rail{
  display:flex; gap:24px; overflow-x:auto; padding:8px 32px 32px;
  scroll-snap-type:x mandatory;
}
.reviews-rail::-webkit-scrollbar{height:6px}
.reviews-rail::-webkit-scrollbar-thumb{background:var(--rule); border-radius:3px}
.review{
  flex:0 0 380px; scroll-snap-align:start;
  background:var(--paper); border:1px solid var(--rule); padding:28px;
  display:flex; flex-direction:column; gap:16px;
}
.review .stars{color:var(--brick); letter-spacing:2px}
.review blockquote{
  margin:0; font-family:var(--serif); font-size:20px; line-height:1.35; font-style:italic; color:var(--ink);
}
.review .who{display:flex; flex-direction:column; gap:2px; margin-top:auto}
.review .who .n{font-weight:600; font-size:14px}
.review .who .m{font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft)}

/* ─── Footer ─── */
.footer{
  background:var(--ink); color:var(--cream);
  padding:80px 0 32px;
}
.footer-grid{display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap:48px; padding-bottom:64px; border-bottom:1px solid rgba(244,237,224,.15)}
.footer h4{font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin:0 0 18px; font-weight:500}
.footer ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px}
.footer a{color:rgba(244,237,224,.75); font-size:14px}
.footer a:hover{color:var(--cream)}
.footer-brand{display:flex; flex-direction:column}
.footer-logo{
  height:auto; width:240px; max-width:100%;
  display:block; margin-left:-6px;
}
.footer-brand p{color:rgba(244,237,224,.6); font-size:14px; max-width:32ch; margin:0}
.footer-bottom{display:flex; justify-content:space-between; align-items:center; padding-top:32px; font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:rgba(244,237,224,.5)}

/* ─── Reveal on scroll ─── */
.reveal{opacity:0; transform:translateY(28px); transition: opacity .9s ease, transform .9s ease}
.reveal.in{opacity:1; transform:none}

/* Floating chicken ornament */
.ornament{
  position:absolute; pointer-events:none; opacity:.06;
  font-family:var(--serif); font-style:italic;
}

/* Responsive */
@media (max-width: 960px){
  .hero{grid-template-columns:1fr; padding-top:120px}
  .hero-img-wrap{aspect-ratio: 4/5; max-height:none}
  .about-grid{grid-template-columns:1fr; gap:48px}
  .section-head{grid-template-columns:1fr; gap:16px}
  .product-grid{grid-template-columns:1fr}
  .recipe-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr; gap:32px}
  .footer-grid{grid-template-columns:1fr 1fr; gap:32px}
  .modal{grid-template-columns:1fr; max-height:94vh}
  .modal-img{min-height:280px}
  .tl-entry{grid-template-columns:32px 1fr; padding:32px 0}
  .timeline::before{left:16px}
  .tl-year{grid-column:1; position:relative; top:auto; align-items:flex-start}
  .tl-year .y{font-size:22px; padding:2px 8px; background:var(--cream)}
  .tl-card.left, .tl-card.right{grid-column:2; padding:0 0 0 24px; text-align:left}
  .tl-card.left p{margin-left:0}
  .nav-links{display:none}
  .pc-grid{grid-template-columns:1fr; gap:24px}
  .product-cat-items ul{grid-template-columns:1fr}
  .product-cat-items{padding-left:0}
  .fr-content{grid-template-columns:1fr; gap:24px}
  .fr-cta{justify-self:start}
  .price-callout{padding:24px}
}


/* ===================== EP multi-page + responsive layer ===================== */
/* Appended after the original design CSS. Fixes the mobile cut-off (the original
   only had ONE breakpoint and hid the nav on phones) and keeps content visible
   when JS is off. The look above is unchanged from the original site. */
/* Headline font: Fraunces (replaces Bodoni Moda everywhere headlines appear) */
:root{ --serif: "Fraunces", "Georgia", "Times New Roman", serif; }

body{overflow-x:clip}
.footer a{overflow-wrap:anywhere}  /* long emails wrap instead of overflowing */

/* Sticky, always-legible nav — works on every page, not just over the hero. */
.nav{position:sticky; background:rgba(244,237,224,.9); -webkit-backdrop-filter:blur(14px) saturate(140%); backdrop-filter:blur(14px) saturate(140%); border-bottom:1px solid var(--rule); padding:14px 32px}
.nav .nav-logo{height:50px}
/* Slightly tighter desktop nav so "Freezer & Cooler Rental" fits on one row */
.nav-links{gap:24px}
.nav-links a{font-size:14px; letter-spacing:.04em; white-space:nowrap}
.nav.scrolled{box-shadow:0 6px 24px rgba(26,20,16,.07)}
.nav-cta-m{display:none}
.nav-toggle{display:none}

/* Hero now flows beneath a sticky (not fixed) nav. */
.hero{min-height:auto; padding:64px 32px 64px}
.hero h1{overflow-wrap:break-word}

/* No-JS safety: content is visible unless JS turns the animation on. */
.reveal{opacity:1; transform:none}
.tl-entry{opacity:1; transform:none}
.js .reveal{opacity:0; transform:translateY(28px)}
.js .reveal.in{opacity:1; transform:none}
.js .tl-entry{opacity:0; transform:translateY(24px)}
.js .tl-entry.in{opacity:1; transform:none}

/* Product accordion: open by default (crawlable, no-JS safe); JS collapses it. */
.product-cat-items{display:block}
.js .product-cat-items{display:none}
.js .product-cat.open .product-cat-items{display:block}

/* Recipe pop-up hidden until opened. */
.modal-back{display:none}
.modal-back.open{display:flex}

/* Home: "the counter" — separated, bold, high-impact product boxes */
.counter-teaser{background:var(--cream)}
.teaser-cats{display:grid; grid-template-columns:1fr 1fr; gap:14px; margin:8px 0 40px}
.teaser-cats a{
  display:flex; align-items:center; gap:18px;
  background:var(--cream); border:3px solid var(--ink); border-radius:2px;
  padding:20px 26px; color:var(--ink);
  transition:transform .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease;
}
.teaser-cats a:hover{background:var(--ink); color:var(--cream); transform:translateX(8px); box-shadow:7px 7px 0 var(--brick)}
.teaser-cats .tc-num{font-family:var(--mono); font-size:14px; font-weight:700; color:var(--brick); min-width:30px}
.teaser-cats .tc-name{flex:1; font-family:var(--serif); font-size:25px; font-weight:700; letter-spacing:-.01em; line-height:1.1}
.teaser-cats .tc-arrow{font-family:var(--serif); font-size:26px; font-weight:700; color:var(--brick)}
.teaser-cats a:hover .tc-num,.teaser-cats a:hover .tc-arrow{color:var(--gold)}

/* Home: freezer band (prominent) + contact band */
.home-freezer{background:var(--brick); color:var(--cream)}
.home-freezer-in{max-width:1320px; margin:0 auto; padding:64px 32px; display:grid; grid-template-columns:1.7fr 1fr; gap:32px; align-items:center}
.home-freezer h2{color:var(--cream); margin:12px 0 14px}
.home-freezer p{color:rgba(244,237,224,.85); max-width:62ch; margin:0}
.home-freezer-cta{justify-self:end; font-family:var(--mono); font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:var(--cream); border:1px solid rgba(244,237,224,.6); padding:16px 26px; white-space:nowrap; transition:background .2s ease, color .2s ease}
.home-freezer-cta:hover{background:var(--cream); color:var(--brick)}
.home-contact{background:var(--ink); color:var(--cream); text-align:center}
.home-contact-in{max-width:760px; margin:0 auto; padding:84px 32px}
.home-contact h2{color:var(--cream); margin:14px 0 16px}
.home-contact p{color:rgba(244,237,224,.72); margin:0 0 28px; font-family:var(--mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase}
.home-contact-cta{display:flex; gap:14px; justify-content:center; flex-wrap:wrap}
.btn-cream-pill{background:var(--cream); color:var(--ink); font-family:var(--mono); font-size:13px; letter-spacing:.14em; text-transform:uppercase; padding:15px 26px; border-radius:999px}
.btn-cream-pill:hover{background:#fff}
.btn-outline-pill{border:1px solid rgba(244,237,224,.6); color:var(--cream); font-family:var(--mono); font-size:13px; letter-spacing:.14em; text-transform:uppercase; padding:15px 26px; border-radius:999px}
.btn-outline-pill:hover{background:rgba(244,237,224,.12)}
@media (max-width:760px){
  .home-freezer-in{grid-template-columns:1fr; gap:22px; padding:48px 20px}
  .home-freezer-cta{justify-self:start}
  .home-contact-in{padding:60px 20px}
}

/* ===== Light "bold box" theme for the Products page + Freezer page ===== */
/* Recolors the original dark Products/Freezer section to cream and turns the
   category accordion + buttons into the same bold, animated boxes as the home
   counter list. */
.products{background:var(--cream); color:var(--ink); border-top:1px solid var(--rule)}
.products .eyebrow{color:var(--brick)}
.products h2{color:var(--ink)}
.products .lead{color:var(--ink-soft)}

/* Price / info callout -> bold light card */
.price-callout{background:var(--paper); border:3px solid var(--ink); border-radius:2px}
.pc-eyebrow{color:var(--brick)}
.pc-grid{border-top:1px solid var(--rule)}
.pc-block h4{color:var(--ink)}
.pc-block p{color:var(--ink-soft)}
.pc-actions{border-top:1px solid var(--rule)}
.pc-btn{border:2px solid var(--ink); transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease}
.pc-btn:hover{background:var(--cream); border-color:var(--ink); transform:translateX(6px); box-shadow:6px 6px 0 var(--brick)}
.pc-btn.primary{background:var(--brick); border-color:var(--brick)}
.pc-btn.primary:hover{background:var(--brick-deep); border-color:var(--brick-deep); transform:translateX(6px); box-shadow:6px 6px 0 var(--ink)}
.pc-btn-k{color:var(--ink-soft)}
.pc-btn.primary .pc-btn-k{color:rgba(255,255,255,.85)}
.pc-btn-v{color:var(--ink)}
.pc-btn.primary .pc-btn-v{color:var(--cream)}

/* Category accordion -> separated bold boxes (matches the home counter) */
.product-cat-list{display:flex; flex-direction:column; gap:14px; border-top:0; margin-top:8px}
.product-cat{border:3px solid var(--ink); border-radius:2px; background:var(--cream); transition:transform .18s ease, box-shadow .18s ease}
.product-cat:not(.open):hover{transform:translateX(8px); box-shadow:7px 7px 0 var(--brick)}
.product-cat-head{color:var(--ink); padding:22px 24px; transition:background .18s ease, color .18s ease}
.product-cat-head:hover{background:transparent}
.product-cat:not(.open):hover .product-cat-head{background:var(--ink); color:var(--cream)}
.product-cat-lead .num{color:var(--brick)}
.product-cat-head h3{color:var(--ink); font-weight:700}
.product-cat-head p{color:var(--ink-soft)}
.product-cat-toggle{color:var(--brick)}
.product-cat:not(.open):hover .product-cat-head h3{color:var(--cream)}
.product-cat:not(.open):hover .product-cat-head p{color:rgba(244,237,224,.72)}
.product-cat:not(.open):hover .product-cat-lead .num,
.product-cat:not(.open):hover .product-cat-toggle{color:var(--gold)}
.product-cat.open .product-cat-toggle{color:var(--ink)}

/* Open category items -> readable on cream */
.product-cat-items li{color:var(--ink-soft); border-bottom:1px dashed var(--rule); font-weight:500}
.product-cat-items .item-label{color:var(--ink)}
.product-cat-items .item-star{color:var(--brick)}
.product-cat-items .item-note{color:var(--brick)}

@media (max-width:600px){
  .product-cat:not(.open):hover{transform:translateX(5px); box-shadow:5px 5px 0 var(--brick)}
  .price-callout{padding:24px}
}

@media (prefers-reduced-motion: reduce){
  .reveal,.tl-entry{transition:none !important}
  .ticker-track{animation:none}
}

/* ---- Real mobile menu (the original simply hid .nav-links on phones) ---- */
@media (max-width:960px){
  .nav-toggle{display:inline-flex; flex-direction:column; gap:5px; background:transparent; border:0; padding:8px; z-index:60}
  .nav-toggle span{width:24px; height:2px; background:var(--ink); display:block; transition:transform .25s ease, opacity .25s ease}
  .nav-cta{display:none}
  .nav-links{
    display:flex; position:fixed; inset:0 0 0 auto; height:100vh; width:min(82vw,330px);
    flex-direction:column; align-items:stretch; gap:0; background:var(--cream);
    border-left:1px solid var(--rule); padding:90px 26px 26px; transform:translateX(106%);
    transition:transform .3s ease; box-shadow:-24px 0 60px rgba(0,0,0,.16); overflow-y:auto; z-index:55;
  }
  .nav.open .nav-links{transform:none}
  .nav-links a{font-family:var(--serif); font-size:23px; text-transform:none; letter-spacing:0; padding:15px 0; border-bottom:1px solid var(--rule); color:var(--ink)}
  .nav-links a::after{display:none}
  .nav-links a.active{color:var(--brick)}
  .nav-cta-m{display:inline-block; margin-top:22px; align-self:flex-start; font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; border:1px solid var(--ink); padding:13px 22px; border-radius:999px}
  .nav.open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav.open .nav-toggle span:nth-child(2){opacity:0}
  .nav.open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  body.nav-open{overflow:hidden}
}

/* ---- Phone breakpoint (original had nothing below 960) ---- */
@media (max-width:600px){
  .wrap,.wrap-narrow{padding:0 20px}
  section{padding:64px 0}
  .nav{padding:12px 20px}
  .nav .nav-logo{height:44px}
  .hero{padding:36px 20px 44px; gap:30px}
  .hero h1{font-size:clamp(33px,9vw,46px); line-height:1.04}
  .hero h1 br{display:none}
  .ticker{padding:11px 0}
  .ticker-track span{font-size:17px}
  h2{font-size:clamp(30px,7.5vw,42px)}
  .section-head{margin-bottom:36px}
  .about-stats{grid-template-columns:1fr 1fr}
  .teaser-cats{grid-template-columns:1fr}
  .teaser-cats a{padding:16px 18px; gap:12px}
  .teaser-cats .tc-name{font-size:20px}
  .recipe-grid{grid-template-columns:1fr}
  .pc-grid{grid-template-columns:1fr; gap:24px}
  .pc-btn{min-width:0}
  .product-cat-head{padding:22px 2px; gap:14px}
  .product-cat-head h3{font-size:21px}
  .product-cat-head p{font-size:13px}
  .product-cat-toggle{font-size:28px}
  .product-cat-items ul{grid-template-columns:1fr}
  .product-cat-items{padding-left:0}
  .freezer-rental{padding:28px}
  .fr-content{grid-template-columns:1fr; gap:22px}
  .fr-cta{justify-self:start}
  .pull{font-size:24px; padding:48px 0}
  .modal-cols{grid-template-columns:1fr}
  .modal-body{padding:28px 22px}
  .modal-stats{gap:16px}
  .review{flex-basis:288px}
  .footer-grid{grid-template-columns:1fr 1fr; gap:28px}
  .footer-brand{grid-column:1 / -1}
  .footer-bottom{flex-direction:column; gap:6px; align-items:flex-start}
  .contact-grid{gap:28px}
  /* Contact card: keep BOTH the email and phone each on one line, inside the box */
  .contact-card{padding:20px}
  .contact-row .v{font-size:19px}
  .contact-row .v.small{font-size:16px}
  .contact-row .v:not(.small){white-space:nowrap}
  .contact-row a[href^="mailto:"]{white-space:nowrap; font-size:clamp(12px,4vw,16px)}
}
@media (max-width:380px){
  .hero h1{font-size:30px}
  .footer-grid{grid-template-columns:1fr}
}
