
:root{
  --cream:#f7f0dd;
  --paper:#fffaf0;
  --ink:#17231c;
  --green:#294f3b;
  --green-dark:#183325;
  --gold:#c79a43;
  --line:rgba(23,35,28,.14);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial,Helvetica,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.58;
}
a{color:inherit}
.hero{
  background:
    radial-gradient(circle at 85% 10%,rgba(199,154,67,.24),transparent 28%),
    linear-gradient(135deg,#f7f0dd,#efe3c6);
}
.nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 6vw;
  gap:20px;
}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;font-weight:900;font-size:1.25rem}
.brand img{width:58px;height:58px;object-fit:contain}
.navlinks{display:flex;gap:20px;font-weight:800}
.navlinks a{text-decoration:none}
.hero-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:42px;
  align-items:center;
  padding:34px 6vw 74px;
  max-width:1440px;
  margin:auto;
}
.eyebrow{
  color:var(--green);
  font-size:.86rem;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin:0 0 10px;
}
h1,h2,h3{font-family:Georgia,"Times New Roman",serif;color:var(--green-dark)}
h1{
  font-size:clamp(2.8rem,6vw,5.8rem);
  line-height:.95;
  margin:0 0 22px;
  max-width:820px;
}
h2{font-size:clamp(2rem,4vw,3.6rem);line-height:1.02;margin:0 0 18px}
h3{font-size:1.45rem;margin:28px 0 8px}
.lead{font-size:clamp(1.08rem,2vw,1.38rem);max-width:760px}
.hero-img{
  width:100%;
  height:min(650px,72vw);
  object-fit:cover;
  border-radius:28px;
  box-shadow:0 24px 60px rgba(23,35,28,.24);
}
.buttons{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}
.button{
  display:inline-block;
  border:2px solid var(--green-dark);
  border-radius:999px;
  padding:12px 19px;
  text-decoration:none;
  font-weight:900;
  background:#fff;
}
.button.primary{background:var(--green-dark);color:#fff}
.section{max-width:1260px;margin:auto;padding:64px 6vw}
.quick-facts{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  margin-top:-28px;
  position:relative;
  z-index:2;
}
.fact{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:22px;
  box-shadow:0 10px 28px rgba(23,35,28,.07);
}
.fact strong{display:block;font-family:Georgia,"Times New Roman",serif;font-size:1.35rem;color:var(--green-dark)}
.fact span{display:block;margin-top:6px}
.story,.visit{display:grid;grid-template-columns:1fr 1fr;gap:38px;align-items:center}
.story img{
  width:100%;
  border-radius:24px;
  box-shadow:0 18px 42px rgba(23,35,28,.16);
}
.story p,.story li,.menu p,.visit p,.seo-text p{font-size:1.08rem}
.story ul{padding-left:22px}
.gallery{background:#f1e7cf;max-width:none}
.gallery>h2,.gallery>.eyebrow,.photo-grid{max-width:1260px;margin-left:auto;margin-right:auto}
.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.photo-grid img{
  width:100%;
  height:330px;
  object-fit:cover;
  border-radius:20px;
  box-shadow:0 10px 26px rgba(23,35,28,.12);
}
.section-heading{display:flex;justify-content:space-between;gap:24px;align-items:flex-end;margin-bottom:24px}
.section-heading>div{max-width:820px}
.menu-image{
  width:100%;
  max-height:1080px;
  object-fit:contain;
  background:#fff;
  border-radius:22px;
  box-shadow:0 12px 34px rgba(23,35,28,.15);
}
.visit{
  background:var(--green);
  color:#fff;
  max-width:1260px;
  border-radius:28px;
  padding:48px;
  margin-top:30px;
  margin-bottom:50px;
}
.visit h2,.visit .eyebrow{color:#fff}
.visit a{color:inherit}
.visit .button{border-color:#fff}
.visit .button.primary{background:#fff;color:var(--green-dark)}
.location-card{
  background:#fff;
  color:var(--ink);
  border-radius:24px;
  padding:28px;
  text-align:center;
}
.location-card img{width:min(260px,75%);display:block;margin:auto}
.location-card a{font-weight:900;color:var(--green)}
.hours{border-left:4px solid var(--gold);padding-left:18px}
.seo-text{border-top:1px solid var(--line)}
footer{
  text-align:center;
  background:var(--green-dark);
  color:#fff;
  padding:42px 6vw;
}
footer img{width:96px}
footer p{margin:8px 0}
footer a{color:#fff}
@media(max-width:900px){
  .hero-grid,.story,.visit{grid-template-columns:1fr}
  .quick-facts{grid-template-columns:1fr 1fr;margin-top:0}
  .photo-grid{grid-template-columns:1fr 1fr}
  .section-heading{align-items:flex-start;flex-direction:column}
  .visit{border-radius:0;margin-bottom:0}
}
@media(max-width:560px){
  .nav{align-items:flex-start}
  .navlinks{font-size:.88rem;gap:12px;flex-wrap:wrap;justify-content:flex-end}
  .brand span{display:none}
  .brand img{width:52px;height:52px}
  .hero-grid{padding:18px 5vw 48px}
  .section{padding:46px 5vw}
  .quick-facts,.photo-grid{grid-template-columns:1fr}
  .photo-grid img{height:auto}
  .visit{padding:40px 5vw}
  .buttons .button{width:100%;text-align:center}
}


/* V2 refinements */
.visit .button:not(.primary){
  background:#fff;
  color:var(--green-dark);
  border-color:#fff;
}

.contact-buttons{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  max-width:620px;
}

.contact-buttons .button{
  width:100%;
  text-align:center;
  margin:0;
}

.menu .section-heading .button{
  flex:0 0 auto;
  white-space:nowrap;
}

@media(max-width:900px){
  .contact-buttons{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media(max-width:560px){
  .brand-large-mobile img{
    width:68px;
    height:68px;
  }

  .contact-buttons{
    grid-template-columns:1fr 1fr;
    width:100%;
  }

  .contact-buttons .button{
    width:100%;
  }

  .menu .section-heading .button{
    width:auto;
    align-self:flex-start;
  }
}


/* V3 logo sizing */
.brand img{
  width:88px;
  height:88px;
}

.location-card img{
  width:min(340px,82%);
}

footer img{
  width:150px;
}

@media(max-width:560px){
  .brand-large-mobile img{
    width:78px;
    height:78px;
  }

  footer img{
    width:130px;
  }
}


/* V4 transparent logo */
.brand img{
  width:150px;
  height:auto;
  object-fit:contain;
}

.location-card img{
  width:min(420px,90%);
  height:auto;
}

footer img{
  width:220px;
  height:auto;
}

@media(max-width:560px){
  .brand-large-mobile img{
    width:125px;
    height:auto;
  }

  footer img{
    width:180px;
  }
}


/* V5 header bigger, no text, blue logo in visit card */
.brand{
  gap:0;
}

.brand img{
  width:300px;
  height:auto;
  display:block;
}

.location-card img{
  width:min(460px,96%);
  height:auto;
}

@media(max-width:900px){
  .brand img{
    width:240px;
  }
}

@media(max-width:560px){
  .brand-large-mobile img,
  .brand img{
    width:180px;
    height:auto;
  }
}


/* V6 latest requested layout fixes */
:root{
  --logo-blue:#0b2946;
}

.nav{
  padding:12px 6vw 4px;
  align-items:flex-start;
}

.brand img{
  width:240px;
  height:auto;
  display:block;
}

.hero-grid{
  align-items:start;
  padding:6px 6vw 64px;
  gap:34px;
}

.hero-copy{
  padding-top:18px;
}

.visit{
  grid-template-columns:1.08fr .92fr;
  padding:36px 40px;
  gap:28px;
}

.location-card{
  padding:22px 22px 20px;
  border-radius:22px;
  max-width:430px;
  width:100%;
  margin-left:auto;
}

.location-card img{
  width:min(245px,78%);
  height:auto;
  display:block;
  margin:0 auto 14px;
}

.location-card p{
  margin:8px 0 12px;
}

footer{
  background:var(--logo-blue);
  padding:34px 6vw 38px;
}

footer img{
  width:170px;
  height:auto;
  display:block;
  margin:0 auto 10px;
}

@media(max-width:900px){
  .brand img{
    width:210px;
  }
  .hero-grid{
    padding:0 6vw 56px;
  }
  .hero-copy{
    padding-top:0;
  }
  .visit{
    grid-template-columns:1fr;
    padding:34px 28px;
  }
  .location-card{
    margin:0 auto;
    max-width:460px;
  }
}

@media(max-width:560px){
  .nav{
    padding:10px 5vw 0;
  }
  .brand-large-mobile img,
  .brand img{
    width:160px;
    height:auto;
  }
  .hero-grid{
    padding:0 5vw 42px;
    gap:22px;
  }
  .hero-copy{
    padding-top:0;
  }
  .visit{
    padding:28px 5vw;
    gap:22px;
  }
  .location-card{
    padding:18px 16px 16px;
  }
  .location-card img{
    width:min(210px,82%);
  }
  footer img{
    width:150px;
  }
}


/* V6 layout tightening and content polish */
:root{
  --navy:#0c2b49;
}

.hero{
  padding-bottom: 0;
}

.nav{
  padding: 14px 6vw 6px;
}

.hero-grid{
  gap: 30px;
  padding: 8px 6vw 42px;
}

.hero-copy .eyebrow{
  margin-bottom: 8px;
}

h1{
  margin: 0 0 16px;
}

.lead{
  margin: 0;
}

.section{
  padding: 42px 6vw;
}

.quick-facts{
  gap: 14px;
  margin-top: -18px;
}

.fact{
  padding: 18px 20px;
}

.story, .visit{
  gap: 28px;
}

.story{
  padding-top: 28px;
}

.story h2,
.gallery h2,
.menu h2,
.visit h2,
.seo-text h2{
  margin-bottom: 14px;
}

.gallery{
  padding-top: 38px;
  padding-bottom: 38px;
}

.menu{
  padding-top: 38px;
  padding-bottom: 38px;
}

.visit{
  padding: 34px 42px;
  margin-top: 18px;
  margin-bottom: 24px;
}

.contact-buttons{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  max-width: 560px;
}

.contact-buttons .button{
  width: auto;
  min-width: 148px;
  padding: 10px 16px;
  font-size: 0.98rem;
  line-height: 1.2;
}

.location-card{
  padding: 20px 22px;
}

.location-card img{
  width: min(250px, 72%);
  height: auto;
  margin-bottom: 10px;
}

.location-card p{
  margin: 6px 0 10px;
}

.seo-text{
  padding-top: 34px;
  padding-bottom: 34px;
}

footer{
  background: var(--navy);
  padding: 28px 6vw 30px;
}

footer img{
  width: 148px;
  height: auto;
}

footer p{
  margin: 6px 0;
}

@media(max-width:900px){
  .nav{
    padding: 14px 5vw 8px;
  }

  .hero-grid{
    padding: 8px 5vw 34px;
    gap: 24px;
  }

  .section{
    padding: 34px 5vw;
  }

  .visit{
    padding: 30px 24px;
    margin-top: 12px;
    margin-bottom: 18px;
  }

  .location-card img{
    width: min(220px, 68%);
  }

  .contact-buttons{
    max-width: 100%;
  }
}

@media(max-width:560px){
  .nav{
    padding: 12px 5vw 4px;
  }

  .brand-large-mobile img,
  .brand img{
    width: 160px;
  }

  .hero-grid{
    padding: 4px 5vw 26px;
    gap: 18px;
  }

  .section{
    padding: 28px 5vw;
  }

  .quick-facts{
    gap: 12px;
    margin-top: 0;
  }

  .story{
    padding-top: 22px;
  }

  .gallery, .menu{
    padding-top: 30px;
    padding-bottom: 30px;
  }

  .visit{
    padding: 24px 5vw;
  }

  .contact-buttons{
    gap: 10px;
  }

  .contact-buttons .button{
    min-width: calc(50% - 5px);
    flex: 1 1 calc(50% - 5px);
    padding: 10px 14px;
  }

  .location-card{
    padding: 18px;
  }

  .location-card img{
    width: min(200px, 70%);
  }

  .seo-text{
    padding-top: 28px;
    padding-bottom: 28px;
  }

  footer{
    padding: 24px 5vw 26px;
  }

  footer img{
    width: 128px;
  }
}


/* V8 desktop hero alignment */
@media(min-width:901px){
  .nav{
    max-width:1440px;
    margin:0 auto;
    padding:12px 6vw 0;
    align-items:center;
  }

  .brand img{
    width:240px;
  }

  .navlinks{
    align-self:center;
    margin-top:0;
    padding-top:0;
  }

  .hero-grid{
    max-width:1440px;
    grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);
    align-items:center;
    gap:38px;
    padding:0 6vw 42px;
    margin-top:-8px;
  }

  .hero-copy{
    padding-top:0;
    align-self:center;
  }

  .hero-img{
    height:620px;
  }
}

/* V9 header / hero cohesion fixes based on latest feedback */
@media(min-width:901px){
  .nav{
    max-width:1260px;
    margin:0 auto;
    padding:16px 6vw 0;
    align-items:flex-end;
  }

  .navlinks{
    gap:26px;
    padding-bottom:16px;
  }

  .hero-grid{
    max-width:1260px;
    grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
    align-items:start;
    gap:32px;
    padding:0 6vw 36px;
    margin-top:-6px;
  }

  .hero-copy{
    padding-top:10px;
  }

  .hero-img{
    height:600px;
    margin-top:0;
  }
}

@media(max-width:900px){
  .nav{
    flex-direction:column;
    align-items:flex-start;
    gap:8px;
    padding:12px 5vw 2px;
  }

  .navlinks{
    justify-content:flex-start;
    align-self:flex-start;
    gap:18px;
    row-gap:10px;
    font-size:.95rem;
    flex-wrap:wrap;
  }

  .hero-grid{
    align-items:start;
    padding:8px 5vw 28px;
    gap:20px;
  }

  .hero-copy{
    padding-top:0;
  }

  .hero-img{
    height:auto;
    max-height:560px;
  }

  .buttons{
    margin-top:18px;
  }

  .section{
    padding:24px 5vw;
  }

  .story{
    padding-top:18px;
    gap:20px;
  }

  .gallery,
  .menu{
    padding-top:24px;
    padding-bottom:24px;
  }

  .visit{
    padding:22px 5vw;
    margin-top:10px;
    margin-bottom:16px;
    gap:18px;
  }

  .contact-buttons{
    gap:10px;
  }

  .contact-buttons .button{
    min-width:122px;
    padding:9px 12px;
    font-size:.93rem;
    line-height:1.15;
  }

  .location-card{
    padding:16px;
  }

  .location-card img{
    width:min(190px,64%);
  }

  .seo-text{
    padding-top:24px;
    padding-bottom:24px;
  }

  footer{
    padding:22px 5vw 24px;
  }
}

@media(max-width:560px){
  .brand-large-mobile img,
  .brand img{
    width:150px;
  }

  .navlinks{
    gap:16px;
    font-size:.9rem;
  }

  .hero-grid{
    padding:8px 5vw 24px;
    gap:16px;
  }

  h1{
    margin-bottom:12px;
  }

  .lead{
    font-size:1.02rem;
  }
}


/* V10 unified hero: navigation anchored to the pizza image */
.hero-shell{
  max-width:1260px;
  margin:0 auto;
  padding:16px 6vw 38px;
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
  gap:34px;
  align-items:start;
}

.hero-left{
  display:flex;
  flex-direction:column;
  gap:14px;
}

.hero-left .brand{
  display:block;
  width:max-content;
}

.hero-left .brand img{
  width:235px;
  height:auto;
  display:block;
}

.hero-left .hero-copy{
  padding-top:0;
}

.hero-visual{
  position:relative;
  padding-top:0;
}

.hero-nav{
  position:absolute;
  z-index:2;
  top:18px;
  right:18px;
  display:flex;
  align-items:center;
  gap:20px;
  padding:11px 16px;
  border-radius:999px;
  background:rgba(255,250,240,.93);
  box-shadow:0 8px 24px rgba(23,35,28,.16);
  backdrop-filter:blur(5px);
}

.hero-nav a{
  text-decoration:none;
  font-weight:900;
  white-space:nowrap;
}

.hero-shell .hero-img{
  width:100%;
  height:620px;
  object-fit:cover;
  border-radius:28px;
}

@media(max-width:900px){
  .hero-shell{
    padding:12px 5vw 30px;
    grid-template-columns:1fr;
    gap:20px;
  }

  .hero-left{
    gap:10px;
  }

  .hero-left .brand img{
    width:190px;
  }

  .hero-visual{
    display:flex;
    flex-direction:column;
    gap:12px;
  }

  .hero-nav{
    position:static;
    align-self:flex-start;
    padding:0;
    border-radius:0;
    background:transparent;
    box-shadow:none;
    backdrop-filter:none;
  }

  .hero-shell .hero-img{
    height:auto;
    max-height:560px;
  }
}

@media(max-width:560px){
  .hero-shell{
    padding:10px 5vw 24px;
    gap:16px;
  }

  .hero-left .brand img{
    width:165px;
  }

  .hero-nav{
    gap:16px;
    font-size:.9rem;
    flex-wrap:wrap;
  }
}
