/* =========================
   Charter Oak Provisions
   Global Design System
   ========================= */

:root{
  /* Palette (pulled from images) */
  --red: #8B1E2D;          /* deli red */
  --red-2: #A52A2A;        /* brick accent */
  --charcoal: #1A1A1A;     /* ink */
  --espresso: #2B1F1A;     /* wood */
  --walnut: #4A3A34;       /* warm brown */
  --cream: #F4EFE9;        /* paper */
  --offwhite: #F9F7F4;     /* marble */
  --gold: #E6A23C;         /* neon warmth (sparingly) */
  --border: rgba(26,26,26,0.14);

  /* Layout */
  --max: 1600px;
  --pad: clamp(18px, 2.5vw, 28px);
  --section: clamp(54px, 6vw, 92px);
  --radius: 10px;

  /* Type */
  --font-body: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-head: Oswald, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  /* Motion */
  --ease: cubic-bezier(.2,.8,.2,1);
  --shadow: 0 18px 40px rgba(0,0,0,0.10);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: var(--font-body);
  color: var(--charcoal);
  background: var(--offwhite);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
p{margin:0 0 14px}
ul{margin:0;padding-left:18px}
small{color:rgba(26,26,26,0.7)}

.container{
  width:100%;
  max-width: var(--max);
  margin:0 auto;
  padding: 0 var(--pad);
}

/* Page Fade-In */
body{
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .8s ease, transform .9s ease;
}

body.page-loaded{
  opacity: 1;
  transform: translateY(0);
}

.hero-container{
  width:100%;
  margin:0 auto;
  padding:0;
}


.section{padding: var(--section) 0}
.section.cream{background: var(--cream)}
.section.dark{background: var(--charcoal); color: var(--offwhite)}
.section.espresso{background: var(--espresso); color: var(--offwhite)}

.hr{
  height:1px;
  background: linear-gradient(90deg, transparent, rgba(26,26,26,0.18), transparent);
  margin: 22px 0;
}
.hr.red{
  background: linear-gradient(90deg, transparent, rgba(139,30,45,0.55), transparent);
}

/* =========================
   Header / Nav
   ========================= */
.site-header{
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(249,247,244,0.92);
  backdrop-filter: none; 
  border-bottom: 1px solid var(--border);
}
.navbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding: 14px 0;
}
.brand{
  display:flex;
  align-items:baseline;
  gap:12px;
}
.brand .mark{
  width:10px;height:10px;border-radius:2px;background: var(--red);
  box-shadow: 0 0 0 3px rgba(139,30,45,0.12);
}
.brand .name{
  font-family: var(--font-head);
  text-transform: uppercase;
  letter-spacing: 1.4px;
  font-size: 20px;
  line-height: 1;
}
.brand .tag{
  font-size: 12px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: rgba(26,26,26,0.70);
}

.nav{
  display:flex;
  align-items:center;
  gap: 18px;
}
.nav a{
  font-size: 12px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 10px 10px;
  border-radius: 8px;
}
.nav a:hover{background: rgba(26,26,26,0.06)}
.nav a.active{
  color: var(--red);
  background: rgba(139,30,45,0.08);
}

.nav-actions{display:flex; align-items:center; gap:10px}

.nav-toggle{
  display:none;
  border: 1px solid var(--border);
  background: transparent;
  padding: 10px 12px;
  border-radius: 10px;
  cursor:pointer;
}
.nav-toggle span{
  display:block; width:18px; height:2px;
  background: var(--charcoal);
  margin: 4px 0;
}

/* Mobile nav */
@media (max-width: 860px){
  .nav{display:none}
  .nav-toggle{display:inline-block}
  .nav.is-open{
    display:flex;
    flex-direction:column;
    position:absolute;
    right: var(--pad);
    top: 64px;
    background: var(--offwhite);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 10px;
    width: min(600px, calc(100vw - 2*var(--pad)));
    box-shadow: var(--shadow);
  }
  .nav a{width:100%}
}

/* =========================
   Buttons
   ========================= */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 12px 16px;
  border-radius: 10px;
  border: 1px solid transparent;
  font-size: 12px;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  cursor:pointer;
  transition: transform .18s var(--ease), background .18s var(--ease), border-color .18s var(--ease), color .18s var(--ease);
  user-select:none;
}
.btn:active{transform: translateY(1px)}

.btn.primary{
  background: var(--red);
  color: var(--offwhite);
}
.btn.primary:hover{background: #6F1622}

.btn.secondary{
  background: transparent;
  border-color: rgba(26,26,26,0.42);
  color: var(--charcoal);
}
.btn.secondary:hover{
  background: var(--charcoal);
  color: var(--offwhite);
  border-color: var(--charcoal);
}
.btn.ghost{
  background: rgba(249,247,244,0.12);
  border-color: rgba(249,247,244,0.22);
  color: var(--offwhite);
}
.btn.ghost:hover{
  background: rgba(249,247,244,0.22);
  border-color: rgba(249,247,244,0.32);
}

.kicker{
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(243, 241, 241, 0.596);
  margin:auto;
}

.kicker-2{
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(4, 4, 4, 0.596);
  margin:auto;
}

.kicker-3{
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(243, 241, 241, 0.596);
  margin:auto;
}



.dark .kicker, .espresso .kicker{color: rgba(249,247,244,0.70)}

.h1, h1{
  font-family: var(--font-head);
  text-transform: uppercase;
  letter-spacing: 1.2px;
  line-height: 1.05;
  margin: 10px 0 12px;
  font-size: clamp(40px, 5vw, 64px);
  text-align:left;
}
.h2, h2{
  font-family: var(--font-head);
  text-transform: uppercase;
  letter-spacing: 1.1px;
  margin: 0 0 12px;
  font-size: clamp(28px, 3.4vw, 42px);
}
.lead{
  font-size: clamp(16px, 1.25vw, 18px);
  color: rgba(255, 255, 255, 0.856);
  max-width: 62ch;
}
.lead-2{
  font-size: clamp(16px, 1.25vw, 18px);
  color: rgba(0, 0, 0, 0.856);
  max-width: 62ch;
}
.lead-{
  font-size: clamp(16px, 1.25vw, 18px);
  color: rgba(255, 255, 255, 0.856);
  max-width: 62ch;
}


.dark .lead, .espresso .lead{color: rgba(249,247,244,0.78)}

/* =========================
   Hero
   ========================= */
.hero{
  position:relative;
  min-height: 60vh;
  display:flex;
  align-items:flex-end;
  overflow:hidden;
  background: var(--charcoal);
}
.hero .bg{
  position:absolute; inset:0;
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
}
.hero .overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.25), rgba(0,0,0,0.45));
}
.hero .content{
  position:relative;
  width:100%;
  padding: calc(var(--section) * 0.85) 0 calc(var(--section) * 0.75);
  color: var(--offwhite);
}
.hero .lead{max-width: 64ch; margin:auto;}
.hero .meta{
  margin-top: 18px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}
.badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(249,247,244,0.24);
  background: rgba(0,0,0,0.18);
  font-size: 12px;
  letter-spacing: 1.2px;
  text-transform: uppercase;
}

/* Hero Logo */
.hero-logo-wrap{
  display:flex;
  align-items:center;
  gap:16px;
  margin-bottom: 22px;
}


.hero-divider{
  height: 1px;
  width: 300px;
  background: rgba(249,247,244,0.4);
}
/* HERO LAYOUT */
.hero .content{
  text-align:center;
}

.hero-header{
  display:flex;
  align-items:center;
  justify-content:center;   /* centers logo + h1 block */
  /* gap:32px; */
  flex-wrap:wrap;
  margin-bottom:18px;
}

.hero-logo-inline{
  max-height:250px;   /* balanced size */
  width:auto;
}

.hero-header h1{
  margin:0;
  max-width:900px;
}

.hero .meta{
  justify-content:center;
}
/* Centered Hero Layout */
.hero .content{
  text-align:center;
}

.hero-center{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:18px;
  margin-bottom:20px;
}

.hero h1{
  margin:0;
}

.hero .meta{
  justify-content:center;
  color:white;
}

.hero .content > .container > div:last-of-type{
  justify-content:center;
}

.hero-buttons{
  margin-top:18px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:center;   /* centers buttons */
}
.striphero{
    background-color:rgba(24, 23, 23, 0.678);
    padding:20px;
}
/* =========================
   Grids / Cards
   ========================= */
.grid{
  display:grid;
  gap: 18px;
}
.grid.cols-3{grid-template-columns: repeat(3, 1fr)}
.grid.cols-2{grid-template-columns: repeat(2, 1fr)}
@media (max-width: 920px){
  .grid.cols-3{grid-template-columns: 1fr}
  .grid.cols-2{grid-template-columns: 1fr}
}

.card{
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--offwhite);
  overflow:hidden;
}
.card .media{
  aspect-ratio: 16/9;
  background: #ddd;
  background-size: cover;
  background-position: center;
}
.card .body{padding: 18px}
.card h3{
  margin: 0 0 8px;
  font-family: var(--font-head);
  text-transform: uppercase;
  letter-spacing: 1px;
  font-size: 20px;
}
.card p{color: rgba(26,26,26,0.76)}

.iconline{
  display:flex;
  align-items:flex-start;
  gap: 12px;
}
.dot{
  width:10px; height:10px; border-radius: 2px; background: var(--red);
  margin-top: 6px;
  flex: 0 0 auto;
}

/* =========================
   Split / Feature Blocks
   ========================= */
.split{
  display:grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 22px;
  align-items:center;
}
@media (max-width: 920px){
  .split{grid-template-columns: 1fr}
}
.frame{
  border-radius: var(--radius);
  overflow:hidden;
  /* border: 1px solid var(--border); */
  box-shadow: none;
}
.frame img{width:60%; height:100%; object-fit:cover; margin:auto;}

.frame{
  border-radius: var(--radius);
  overflow:hidden;
  /* border: 1px solid var(--border); */
  box-shadow: none;
}
.frame-2 img{width:80%; height:100%; object-fit:cover; margin:auto; border-radius:20px; border-right:2px solid var(--gold); border-bottom: 2px solid var(--gold);}


.note{
  padding: 14px 16px;
  border-left: 3px solid var(--red);
  border-right: 3px solid var(--red);
  background: rgba(139,30,45,0.06);
  border-radius: 10px;
}
.dark .note, .espresso .note{
  background: rgba(249,247,244,0.08);
  border-left-color: var(--gold);
}



/* =========================
   Form
   ========================= */
form .row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 760px){
  form .row{grid-template-columns:1fr}
}
label{
  display:block;
  font-size: 12px;
  letter-spacing: 1.3px;
  text-transform: uppercase;
  margin: 0 0 8px;
  color: rgba(26,26,26,0.70);
}
input, textarea, select{
  width:100%;
  padding: 12px 12px;
  border-radius: 10px;
  border: 1px solid rgba(26,26,26,0.20);
  background: #fff;
  font: inherit;
}
textarea{min-height: 140px; resize: vertical}

/* =========================
   Footer
   ========================= */
footer{
  padding: 34px 0;
  background: var(--charcoal);
  color: var(--offwhite);
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr 1fr;
  gap: 18px;
}
@media (max-width: 920px){
  .footer-grid{grid-template-columns: 1fr}
  #deli-sign{ display:none;}
  #brand-strip {display:none;}
  h1 {font-size:1.8rem; text-align:center;}
  .lead {font-size:.8rem;}
  #menu-contact{display:none}
  .split{
    grid-template-columns: 1fr;
  }

    .social-grid{
      grid-template-columns: 1fr;
      gap:18px;
    }
  
    .social-item{
      padding:12px 0;
    }
  
  .section {
    padding:10px;
  }

  .info-block{
    order:1;
  }

  .form-block{
    order:2;
  }
  #contact-logo{
    display:none;
  }

}
footer a{color: rgba(249,247,244,0.82)}
footer a:hover{color: var(--offwhite)}
.footer-mini{
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid rgba(249,247,244,0.14);
  color: rgba(249,247,244,0.70);
  font-size: 13px;
}

/* Footer Mini Signup */


.footer-signup h4{
  font-family: var(--font-head);
  text-transform: uppercase;
  letter-spacing: 1px;
  font-size: 14px;
  /* margin-bottom:10px; */
}

.mini-form{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.mini-form input{
  flex:1;
  min-width:180px;
  padding:10px 12px;
  border-radius:8px;
  border:1px solid rgba(249,247,244,0.3);
  background: rgba(255,255,255,0.08);
  color: var(--offwhite);
}

.mini-form input::placeholder{
  color: rgba(249,247,244,0.6);
}

footer .mini-form .btn{
  padding:10px 14px;
}

/* Effects */
.btn{
  position:relative;
  overflow:hidden;
}

.btn::after{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(255,255,255,0.08);
  opacity:0;
  transition:opacity .3s ease;
}

.btn:hover::after{
  opacity:1;
}

.btn:hover{
  transform: translateY(-2px);
}


.reveal{
  opacity:0;
  transform: translateY(30px) scale(.98);
  transition:
    opacity .8s var(--ease),
    transform .8s var(--ease);
}

.reveal.is-visible{
  opacity:1;
  transform: translateY(0) scale(1);
}

.hero .bg{
  will-change: transform;
}

.card{
  transition:
    transform .4s var(--ease),
    box-shadow .4s var(--ease);
}

.card:hover{
  transform: translateY(-6px);
  box-shadow: 0 28px 60px rgba(0,0,0,0.12);
}

.card .media{
  transition: transform .6s var(--ease);
}

.card:hover .media{
  transform: scale(1.04);
}

/* =========================
   Contact Social Grid
   ========================= */

   .social-grid{
    display:grid;
    grid-template-columns: repeat(3, auto);
    justify-content:center;
    gap:28px;
    margin-top:14px;
  }
  
  .social-item{
    display:flex;
    align-items:center;
    justify-content:center;
    color: var(--walnut);
    transition: transform .3s var(--ease), opacity .3s var(--ease);
  }
  
  .social-item svg{
    width:42px;
    height:42px;
  }
  
  .social-item:hover{
    transform: translateY(-4px);
    opacity:.8;
  }