/* ============================================
   COOKERY & FOOD — Design System
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Inter:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap');

:root{
  --ink:#14171A;
  --paper:#F6F5F1;
  --paper-2:#FFFFFF;
  --green:#2F4F3E;
  --green-dark:#1E3428;
  --gold:#B8912E;
  --slate:#5B5F59;
  --line:#E1DFD8;
  --line-dark:#2B302C;

  --serif:'Instrument Serif', Georgia, 'Times New Roman', serif;
  --sans:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --mono:'IBM Plex Mono', 'SF Mono', Consolas, monospace;

  --max:1120px;
  --pad:clamp(24px, 5vw, 64px);
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth; overflow-x:hidden;}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *{animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important;}
}

body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  display:flex;
  flex-direction:column;
  min-height:100vh;
}
.site-footer{margin-top:auto;}

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

.wrap{
  max-width:var(--max);
  margin:0 auto;
  padding-left:var(--pad);
  padding-right:var(--pad);
}

/* ---------- Nav ---------- */
.site-nav{
  position:sticky;
  top:0;
  z-index:102;
  background:rgba(246,245,241,0.78);
  backdrop-filter:saturate(180%) blur(16px);
  -webkit-backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid var(--line);
}
.site-nav .wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:76px;
}
.logo{
  display:inline-flex;
  align-items:center;
  white-space:nowrap;
}
.logo-img{
  height:38px;
  width:auto;
  display:block;
  position:relative;
  top:1px;
}
.site-footer .logo-img{
  height:42px;
  top:0;
}
.nav-links{
  display:flex;
  align-items:center;
  gap:36px;
}
.nav-links a{
  font-size:14.5px;
  font-weight:500;
  color:var(--ink);
  opacity:0.75;
  transition:opacity .2s ease;
  position:relative;
}
.nav-links a:hover{opacity:1;}
.nav-links a.active{opacity:1;}
.nav-links a.active::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-22px;
  height:2px;
  background:var(--gold);
}
.nav-cta{
  border:1px solid var(--ink);
  padding:9px 18px;
  border-radius:999px;
  font-size:14px;
  font-weight:500;
  white-space:nowrap;
  transition:background .2s ease, color .2s ease;
}
.nav-cta:hover{background:var(--ink); color:var(--paper);}
.nav-toggle{display:none;}

.nav-backdrop{
  display:none;
}

@media (max-width: 860px){
  .nav-links{
    position:fixed;
    top:76px; left:0; right:0;
    background:var(--paper-2);
    border-bottom:1px solid var(--line);
    flex-direction:column;
    align-items:flex-start;
    gap:0;
    padding:16px var(--pad) 32px;
    transform:translateY(-8px);
    opacity:0;
    pointer-events:none;
    transition:opacity .2s ease, transform .2s ease;
    z-index:101;
    max-height:calc(100vh - 76px);
    overflow-y:auto;
    box-sizing:border-box;
  }
  .nav-links.open{opacity:1; transform:translateY(0); pointer-events:auto;}
  .nav-links a{padding:14px 0; width:100%; border-bottom:1px solid var(--line); font-size:16px;}
  .nav-links a.active::after{display:none;}
  .nav-links a.nav-cta{
    border-bottom:none;
    width:100%;
    padding:15px 28px;
    margin-top:18px;
    text-align:center;
    display:block;
  }
  .nav-toggle{
    display:flex;
    flex-direction:column;
    gap:5px;
    background:none;
    border:none;
    cursor:pointer;
    padding:8px;
    position:relative;
    z-index:102;
  }
  .nav-toggle span{
    width:22px; height:2px; background:var(--ink); display:block;
    transition:transform .2s ease, opacity .2s ease;
  }
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .nav-toggle.open span:nth-child(2){opacity:0;}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

  .nav-backdrop{
    display:block;
    position:fixed;
    top:76px; left:0; right:0; bottom:0;
    background:rgba(20,23,26,0.4);
    z-index:99;
    opacity:0;
    pointer-events:none;
    transition:opacity .2s ease;
  }
  .nav-backdrop.open{opacity:1; pointer-events:auto;}
}
  .nav-toggle{
    display:flex;
    flex-direction:column;
    gap:5px;
    background:none;
    border:none;
    cursor:pointer;
    padding:8px;
    position:relative;
    z-index:103;
  }
  .nav-toggle span{
    width:22px; height:2px; background:var(--ink); display:block;
    transition:transform .2s ease, opacity .2s ease;
  }
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .nav-toggle.open span:nth-child(2){opacity:0;}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
}

/* ---------- Type scale ---------- */
.eyebrow{
  font-family:var(--mono);
  font-size:12.5px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--gold);
  margin:0 0 18px;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.eyebrow::before{
  content:"";
  width:16px; height:1px;
  background:var(--gold);
  display:inline-block;
  flex:none;
}

h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:400;
  color:var(--ink);
  margin:0;
  line-height:1.05;
}
h1{font-size:clamp(40px, 6.2vw, 76px); letter-spacing:-0.01em;}
h2{font-size:clamp(30px, 4.2vw, 48px); line-height:1.1;}
h3{font-size:clamp(22px, 2.4vw, 27px); line-height:1.25;}

p{margin:0 0 20px; color:var(--slate); max-width:62ch;}
p:last-child{margin-bottom:0;}
p.lede{font-size:19px; line-height:1.65;}

.section{padding:104px 0;}
.section.tight{padding:72px 0;}
.section-divider{border:none; border-top:1px solid var(--line); margin:0;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:15px 28px;
  border-radius:999px;
  font-size:15px;
  font-weight:500;
  transition:transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.btn-primary{background:var(--ink); color:var(--paper);}
.btn-primary:hover{background:var(--green-dark); transform:translateY(-1px);}
.btn-ghost{border:1px solid var(--ink); color:var(--ink);}
.btn-ghost:hover{background:var(--ink); color:var(--paper); transform:translateY(-1px);}
.btn-gold{background:var(--gold); color:var(--ink);}
.btn-gold:hover{transform:translateY(-1px);}
.btn-row{display:flex; gap:16px; flex-wrap:wrap;}

.on-dark .btn-ghost{border-color:rgba(246,245,241,0.5); color:var(--paper);}
.on-dark .btn-ghost:hover{background:var(--paper); color:var(--ink);}
.on-dark .btn-primary{background:var(--gold); color:var(--ink);}
.on-dark .btn-primary:hover{background:#cba53c;}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  padding:120px 0 96px;
  overflow:hidden;
}
.hero-rings{
  position:absolute;
  top:-140px; right:-160px;
  width:620px; height:620px;
  pointer-events:none;
  z-index:0;
}
.hero .wrap{position:relative; z-index:1;}
.hero h1{max-width:16ch; margin-bottom:28px;}
.hero p.lede{max-width:58ch; margin-bottom:40px;}

.page-hero{padding:72px 0 56px;}
.page-hero h1{max-width:20ch;}

/* ---------- Rings motif ---------- */
.rings-mark circle{fill:none; stroke-width:1.4;}

/* ---------- Pillars (Invest / Operate / Scale) ---------- */
.pillars{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
  border-radius:20px;
  overflow:hidden;
}
.pillar{
  background:var(--paper-2);
  padding:40px 34px;
}
.pillar-ring{width:34px; height:34px; margin-bottom:22px;}
.pillar h3{margin-bottom:12px;}
.pillar p{margin-bottom:0; max-width:none;}
@media (max-width: 760px){
  .pillars{grid-template-columns:1fr;}
}

/* ---------- Feature list (label + text rows) ---------- */
.rows{border-top:1px solid var(--line);}
.row{
  display:grid;
  grid-template-columns:280px 1fr;
  gap:40px;
  padding:36px 0;
  border-bottom:1px solid var(--line);
}
.row h3{color:var(--ink); margin-bottom:0;}
.row p{margin-bottom:0; max-width:60ch;}
@media (max-width: 760px){
  .row{grid-template-columns:1fr; gap:10px;}
}

/* ---------- Bullet list ---------- */
.list-clean{list-style:none; margin:0; padding:0;}
.list-clean li{
  position:relative;
  padding:14px 0 14px 28px;
  border-bottom:1px solid var(--line);
  color:var(--slate);
}
.list-clean li:first-child{padding-top:0;}
.list-clean li::before{
  content:"";
  position:absolute;
  left:0; top:23px;
  width:6px; height:6px;
  border-radius:50%;
  background:var(--gold);
}

/* ---------- Two column ---------- */
.two-col{
  display:grid;
  grid-template-columns:0.85fr 1.15fr;
  gap:64px;
  align-items:start;
}
@media (max-width: 860px){
  .two-col{grid-template-columns:1fr; gap:28px;}
}

/* ---------- Timeline (Our Journey) ---------- */
.timeline{position:relative; padding-left:52px;}
.timeline::before{
  content:"";
  position:absolute;
  left:9px; top:6px; bottom:6px;
  width:1px;
  background:var(--line);
}
.tl-item{position:relative; padding-bottom:64px;}
.tl-item:last-child{padding-bottom:0;}
.tl-dot{
  position:absolute;
  left:-52px; top:6px;
  width:20px; height:20px;
  border-radius:50%;
  background:var(--paper);
  border:1.5px solid var(--gold);
}
.tl-dot::after{
  content:"";
  position:absolute; inset:5px;
  border-radius:50%;
  background:var(--gold);
}
.tl-year{
  font-family:var(--mono);
  font-size:13px;
  letter-spacing:0.08em;
  color:var(--gold);
  text-transform:uppercase;
  margin-bottom:8px;
  display:block;
}
.tl-item h3{margin-bottom:14px;}
.tl-item ul{margin:0; padding-left:20px; color:var(--slate);}
.tl-item li{margin-bottom:6px;}

/* ---------- Portfolio card ---------- */
.brand-card{
  border:1px solid var(--line);
  border-radius:20px;
  padding:44px;
  background:var(--paper-2);
}
.brand-card-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:20px;
  margin-bottom:28px;
  flex-wrap:wrap;
}
.brand-card-head h3{font-size:clamp(24px,3vw,30px);}
.tag{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--green);
  background:rgba(47,79,62,0.08);
  padding:6px 12px;
  border-radius:999px;
}
.outlet{
  display:grid;
  grid-template-columns:1fr auto;
  gap:16px;
  padding:16px 0;
  border-top:1px solid var(--line);
}
.outlet:first-of-type{border-top:none;}
.outlet-name{font-weight:600; color:var(--ink);}
.outlet-date{
  font-family:var(--mono);
  font-size:13px;
  color:var(--slate);
  white-space:nowrap;
}
@media (max-width: 560px){
  .outlet{
    grid-template-columns:1fr;
    gap:6px;
  }
  .outlet-date{white-space:normal;}
}

/* ---------- Stat band ---------- */
.stat-band{
  background:var(--ink);
  color:var(--paper);
  position:relative;
  overflow:hidden;
}
.stat-band .wrap{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:40px;
  position:relative; z-index:1;
}
.stat{padding:0;}
.stat-num{
  font-family:var(--serif);
  font-size:clamp(40px,5vw,64px);
  color:var(--paper);
  display:block;
  margin-bottom:8px;
}
.stat-label{
  font-family:var(--mono);
  font-size:12.5px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:rgba(246,245,241,0.55);
}
@media (max-width: 760px){
  .stat-band .wrap{grid-template-columns:1fr; gap:32px;}
}

/* ---------- CTA band ---------- */
.cta-band{
  background:var(--green-dark);
  color:var(--paper);
}
.cta-band h2{color:var(--paper); max-width:16ch; margin-bottom:20px;}
.cta-band p{color:rgba(246,245,241,0.75); max-width:52ch;}
.cta-band-inner{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:40px;
  flex-wrap:wrap;
}

/* ---------- Contact ---------- */
.contact-block{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:56px 0;
  margin:40px 0;
}
.contact-email{
  font-family:var(--serif);
  font-size:clamp(28px,4vw,42px);
  color:var(--green);
  display:inline-block;
  border-bottom:1px solid var(--green);
  padding-bottom:4px;
  transition:opacity .2s ease;
}
.contact-email:hover{opacity:0.7;}

/* ---------- Footer ---------- */
.site-footer{
  background:var(--paper);
  border-top:1px solid var(--line);
  padding:72px 0 32px;
}
.footer-top{
  display:flex;
  justify-content:space-between;
  gap:40px;
  flex-wrap:wrap;
  padding-bottom:40px;
}
.footer-brand p{margin-top:14px; max-width:32ch;}
.footer-links{
  display:flex;
  gap:64px;
  flex-wrap:wrap;
}
.footer-col{display:flex; flex-direction:column; gap:12px;}
.footer-col-title{
  font-family:var(--mono);
  font-size:11.5px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:4px;
}
.footer-col a{color:var(--slate); font-size:14.5px; transition:color .2s ease;}
.footer-col a:hover{color:var(--ink);}
.footer-col a.footer-email{color:var(--green); font-weight:600;}
.footer-col a.footer-email:hover{color:var(--green-dark);}
.footer-bottom{
  border-top:1px solid var(--line);
  padding-top:24px;
  font-size:13px;
  color:var(--slate);
}

/* ---------- Reveal on scroll ---------- */
.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .7s ease, transform .7s ease;
}
.reveal.is-visible{opacity:1; transform:translateY(0);}

/* ---------- Utility ---------- */
.center{text-align:center;}
.mx-auto{margin-left:auto; margin-right:auto;}
.mt-56{margin-top:56px;}
.small-caps{
  font-family:var(--mono);
  font-size:13px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--slate);
}
