:root{
  --cream:        #FFF8EE;
  --cream-deep:   #FFEEDB;
  --ink:          #1B4332;
  --ink-soft:     #5B4B3E;
  --orange:       #F16722;
  --orange-deep:  #D1450C;
  --orange-soft:  #FBD9BC;
  --green:        #004227;
  --plate:        #F4EAD9;
  --line:         rgba(36,26,18,0.12);

  --font-display: "Fraunces", serif;
  --font-script:  "Playfair Display", serif;
  --font-body:    "Plus Jakarta Sans", sans-serif;
  --font-brand:   "Fraunces", serif;
  --green-forest: #004227;

  --container: 1280px;
  --radius: 18px;
  --radius-lg: 32px;
}

*{ margin:0; padding:0; box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  font-family: var(--font-body);
  background: var(--cream);
  color: var(--ink);
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

img{ max-width:100%; display:block; }

a{ color:inherit; text-decoration:none; }

ul{ list-style:none; }

.container{
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 32px;
  box-sizing: border-box;
}

.eyebrow{
  font-family: var(--font-display);
  font-size: 14px;
  letter-spacing: .28em;
  color: var(--orange);
  text-transform: uppercase;
}

.script{
  font-family: var(--font-script);
  font-size: 26px;
  color: var(--orange-deep);
  transform: rotate(-2deg);
  display: inline-block;
}

h1, h2, h3, h4{
  font-family: var(--font-display);
  text-transform: uppercase;
  line-height: 1.02;
  letter-spacing: .01em;
  font-weight: 400;
}

h2{ font-size: clamp(34px, 5vw, 58px); }
h3{ font-size: clamp(22px, 3vw, 32px); }

.section-head{
  text-align:center;
  margin-bottom: 56px;
}
.section-head .eyebrow{ display:block; margin-bottom: 10px; }
.section-head h2{ margin-bottom: 14px; }
.section-head p{
  max-width: 540px;
  margin: 0 auto;
  color: var(--ink-soft);
  font-size: 17px;
}
.underline-squiggle{
  display:block;
  width: 160px;
  height: 14px;
  margin: 14px auto 0;
}

.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 16px 30px;
  border-radius: 999px;
  border: 2px solid transparent;
  cursor: pointer;
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
  white-space: nowrap;
}
.btn-primary{
  background: var(--orange);
  color: #fff;
  box-shadow: 0 10px 24px -10px rgba(242,103,26,.7);
}
.btn-primary:hover{
  transform: translateY(-3px);
  box-shadow: 0 16px 30px -10px rgba(242,103,26,.8);
}
.btn-outline{
  background: transparent;
  color: var(--ink);
  border-color: var(--ink);
}
.btn-outline:hover{
  background: var(--ink);
  color: var(--cream);
  transform: translateY(-3px);
}
.btn-outline.on-dark{
  color:#fff;
  border-color: rgba(255,255,255,.6);
}
.btn-outline.on-dark:hover{
  background:#fff;
  color: var(--orange-deep);
}
.btn-light{
  background:#fff;
  color: var(--orange-deep);
}
.btn-light:hover{
  transform: translateY(-3px);
  box-shadow: 0 14px 28px -12px rgba(0,0,0,.35);
}
.btn svg{ width:16px; height:16px; transition: transform .25s ease; }
.btn:hover svg{ transform: translateX(4px); }

.nav{
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(255,248,238,.85);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}
.nav .container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding-top: 18px;
  padding-bottom: 18px;
}
.logo{
  display:flex;
  align-items:center;
  gap:10px;
  font-family: var(--font-display);
  font-size: 24px;
  letter-spacing: .04em;
  color: var(--ink);
}
.logo svg{ width:38px; height:38px; flex-shrink:0; }
.logo span{ color: var(--orange); }

.nav-links{
  display:flex;
  gap: 38px;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .07em;
  text-transform: uppercase;
}
.nav-links a{
  position: relative;
  padding-bottom: 6px;
  transition: color .2s ease;
}
.nav-links a::after{
  content:"";
  position:absolute;
  left:0; bottom:0;
  width:0; height:3px;
  background: var(--orange);
  border-radius:2px;
  transition: width .25s ease;
}
.nav-links a:hover{ color: var(--orange); }
.nav-links a:hover::after{ width:100%; }
.nav-links a.active{ color: var(--orange); }
.nav-links a.active::after{ width:100%; }

.nav-right{
  display:flex;
  align-items:center;
  gap:18px;
}
.cart-icon{
  width: 46px; height:46px;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  border: 2px solid var(--ink);
  transition: background .25s ease, color .25s ease, transform .25s ease;
}
.cart-icon:hover{
  background: var(--ink);
  color: var(--cream);
  transform: translateY(-2px) rotate(-6deg);
}
.cart-icon svg{ width:20px; height:20px; }

.nav-toggle{
  display:none;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
  background:none; border:none;
}
.nav-toggle span{
  width:26px; height:3px; border-radius:2px;
  background: var(--ink);
  transition: transform .25s ease, opacity .25s ease;
}

.doodle-field{
  position:absolute;
  inset:0;
  overflow:hidden;
  pointer-events:none;
  z-index: 1;
}
.doodle{
  position:absolute;
  color: var(--orange);
  opacity:.18;
  animation: drift 9s ease-in-out infinite;
}
.doodle.is-green{ color: var(--green); }
.doodle.is-ink{ color: var(--ink); opacity:.10; }
@keyframes drift{
  0%, 100%{ transform: translateY(0) rotate(0deg); }
  50%{ transform: translateY(-22px) rotate(6deg); }
}

.hero{
  position:relative;
  overflow:hidden;
  padding: 70px 0 60px;
}
.hero .container{
  display:grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 40px;
  align-items:center;
  position: relative;
  z-index: 3;
}
.hero-copy .script{ margin-bottom: 6px; }
.hero-title{
  font-size: clamp(38px, 9vw, 108px);
  line-height: .96;
  word-break: break-word;
  overflow-wrap: break-word;
}
.hero-title .line-orange{ color: var(--orange); display:block; }
.hero-title .line-ink{ color: var(--ink); display:block; }
.hero-copy p{
  margin: 26px 0 34px;
  font-size: 17px;
  color: var(--ink-soft);
  max-width: 440px;
}
.hero-copy p strong{ color: var(--orange-deep); }
.hero-ctas{ display:flex; gap:18px; flex-wrap:wrap; }

.hero-visual{
  position: relative;
  display:flex;
  justify-content:center;
  align-items:center;
  min-height: 400px;
}

.hero-plate{
  position:relative;
  z-index: 2;
  width: 100%;
  will-change: transform;
}
.hero-plate img{ width:100%; display:block; object-fit:contain; }

.hero-badge{
  position:absolute;
  top: 4%;
  left: -6%;
  width: 150px;
  z-index: 3;
  animation: spin-slow 18s linear infinite;
}
@keyframes spin-slow{
  from{ transform: rotate(0deg); }
  to{ transform: rotate(360deg); }
}

.hero-badge{
  position:absolute;
  top: 2%;
  left: -8%;
  width: 150px;
  height: 150px;
  z-index: 4;
  color: var(--orange);
}
.hero-badge-ring{
  width:100%; height:100%;
  animation: spin-slow 24s linear infinite;
}
.hero-badge-ring svg{ width:100%; height:100%; }
.hero-badge-center{
  position:absolute; inset:0;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center;
  color: var(--orange-deep);
}
.hero-badge-center strong{
  font-family: var(--font-display);
  font-size: 30px;
  line-height:1;
}
.hero-badge-center span{
  font-size: 10px;
  font-weight:800;
  letter-spacing:.1em;
  text-transform:uppercase;
}

.hero-mark{
  position:absolute;
  z-index: 3;
  color: var(--ink);
}
.hero-mark.mark-1{ top: 6%; right: 0%; width: 60px; }
.hero-mark.mark-2{ bottom: 14%; left: -4%; width: 70px; }

.stats{
  position:relative;
  z-index: 4;
  margin: 0 auto 90px;
  max-width: var(--container);
  padding: 0 32px;
}
.stats-inner{
  background:#fff;
  border-radius: var(--radius-lg);
  box-shadow: 0 26px 60px -36px rgba(36,26,18,.35);
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  padding: 36px 24px;
}
.stat{
  display:flex;
  align-items:center;
  gap:16px;
  padding: 0 18px;
  border-right: 1px dashed var(--line);
}
.stat:last-child{ border-right:none; }
.stat-icon{
  width: 60px; height:60px;
  border-radius:50%;
  border: 2px solid var(--orange);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
  color: var(--orange);
}
.stat-icon svg{ width:26px; height:26px; }
.stat strong{
  display:block;
  font-family: var(--font-display);
  font-size: 21px;
  color: var(--orange);
}
.stat span{
  font-size: 14px;
  color: var(--ink-soft);
  font-weight:600;
}

.categories{ padding: 0 0 110px; position:relative; }
.cat-row{
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 28px;
}
.cat-arrow{
  width: 48px; height:48px;
  border-radius:50%;
  background: transparent;
  border: 2px solid var(--line);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
  flex-shrink:0;
  transition: background .25s ease, border-color .25s ease, transform .2s ease;
  color: var(--ink);
}
.cat-arrow:hover{ border-color: var(--orange); color: var(--orange); transform: scale(1.06); }
.cat-arrow.is-active{ background: var(--orange); border-color: var(--orange); color:#fff; }
.cat-arrow svg{ width:18px; height:18px; }

.cat-list{
  display:flex;
  gap: 44px;
  overflow-x:auto;
  padding: 6px 6px 18px;
  scrollbar-width: none;
}
.cat-list::-webkit-scrollbar{ display:none; }
.cat-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap: 14px;
  flex-shrink:0;
  cursor:pointer;
  transition: transform .25s ease;
}
.cat-item:hover{ transform: translateY(-6px); }
.cat-circle{
  width: 92px; height:92px;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  border: 2px solid var(--line);
  background:#fff;
  transition: background .25s ease, border-color .25s ease, color .25s ease, box-shadow .25s ease;
  color: var(--ink);
}
.cat-circle svg{ width:38px; height:38px; }
.cat-item.is-active .cat-circle{
  background: var(--orange);
  border-color: var(--orange);
  color:#fff;
  box-shadow: 0 16px 30px -14px rgba(242,103,26,.8);
}
.cat-item span{
  font-weight: 800;
  font-size: 15px;
  color: var(--ink-soft);
}
.cat-item.is-active span{ color: var(--orange); }

.featured{
  position:relative;
  padding: 100px 0;
  background: var(--cream-deep);
  overflow:hidden;
}
.feature-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  position:relative;
  z-index:2;
}
.feature-card{
  background:#fff;
  border-radius: var(--radius-lg);
  overflow:hidden;
  box-shadow: 0 24px 50px -32px rgba(36,26,18,.35);
  transition: transform .35s ease, box-shadow .35s ease;
  opacity:1; transform: translateY(0);
}
.feature-card.is-visible{ opacity:1; transform: translateY(0); }
.feature-card:hover{ transform: translateY(-10px); box-shadow: 0 32px 60px -28px rgba(36,26,18,.4); }
.feature-img{
  height: 230px;
  position:relative;
  overflow:hidden;
}
.feature-img .tag{
  position:absolute;
  top:16px; left:16px;
  background: var(--orange);
  color:#fff;
  font-weight:800;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding: 8px 14px;
  border-radius: 999px;
  z-index:2;
}
.feature-body{ padding: 24px 26px 28px; }
.feature-body h4{ font-size: 20px; margin-bottom:8px; }
.feature-body p{ color: var(--ink-soft); font-size: 14.5px; margin-bottom: 16px; }
.feature-foot{
  display:flex; align-items:center; justify-content:space-between;
}
.price{
  font-family: var(--font-display);
  font-size: 22px;
  color: var(--orange-deep);
}
.feature-foot a{
  font-weight:800;
  font-size: 13px;
  letter-spacing:.07em;
  text-transform:uppercase;
  display:flex; align-items:center; gap:6px;
  color: var(--ink);
}
.feature-foot a svg{ width:14px; height:14px; }

.page-hero{
  position:relative;
  height: 62vh;
  min-height: 460px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  text-align:center;
  color:#fff;
}
.page-hero-bg{
  position:absolute;
  inset: -10% -10% -10% -10%;
  background: linear-gradient(160deg, var(--orange-deep) 0%, var(--orange) 55%, #ff9856 100%);
  will-change: transform;
  z-index: 1;
}
.page-hero-bg::before,
.page-hero-bg::after{
  content:"";
  position:absolute;
  border-radius:50%;
  background: rgba(255,255,255,.08);
}
.page-hero-bg::before{ width:480px; height:480px; top:-180px; left:-120px; }
.page-hero-bg::after{ width:360px; height:360px; bottom:-140px; right:-80px; }

.page-hero-layer{
  position:absolute;
  inset:0;
  z-index:2;
  will-change: transform;
}
.page-hero-layer .doodle{ color:#fff; opacity:.16; }

.page-hero-content{
  position:relative;
  z-index: 3;
  will-change: transform;
}
.page-hero-content .eyebrow{ color: rgba(255,255,255,.85); }
.page-hero-content h1{
  font-size: clamp(48px, 9vw, 96px);
  margin: 14px 0 18px;
}
.page-hero-content p{
  max-width: 520px;
  margin: 0 auto;
  font-size: 17px;
  color: rgba(255,255,255,.9);
}
.page-hero-shape{
  position:absolute;
  left:0; right:0; bottom:-1px;
  z-index:4;
  line-height:0;
}
.page-hero-shape svg{ width:100%; height:auto; display:block; }
.page-hero-shape path{ fill: var(--cream); }

.section{ padding: 100px 0; position:relative; }
.section.alt{ background: var(--cream-deep); }
.reveal{ opacity:0; transform: translateY(36px); transition: opacity .8s ease, transform .8s ease; }
.reveal.is-visible{ opacity:1; transform: translateY(0); }
.reveal-delay-1.is-visible{ transition-delay:.08s; }
.reveal-delay-2.is-visible{ transition-delay:.16s; }
.reveal-delay-3.is-visible{ transition-delay:.24s; }

.menu-nav{
  display:flex;
  justify-content:center;
  gap: 14px;
  flex-wrap:wrap;
  margin: -40px auto 80px;
  position:relative;
  z-index: 5;
}
.menu-nav a{
  background:#fff;
  border: 2px solid var(--line);
  padding: 12px 26px;
  border-radius: 999px;
  font-weight:800;
  font-size: 13px;
  letter-spacing:.08em;
  text-transform:uppercase;
  transition: all .25s ease;
}
.menu-nav a:hover, .menu-nav a.active{
  background: var(--orange);
  border-color: var(--orange);
  color:#fff;
  transform: translateY(-3px);
}

.menu-category{ padding: 70px 0; position:relative; }
.menu-category-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap: 20px;
  margin-bottom: 44px;
  border-bottom: 3px solid var(--ink);
  padding-bottom: 18px;
}
.menu-category-head h2{ color: var(--ink); }
.menu-category-head h2 span{ color: var(--orange); }
.menu-category-head p{ color: var(--ink-soft); max-width: 320px; text-align:right; font-size:14.5px; }

.dish-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 26px 40px;
}
.dish{
  display:flex;
  gap: 20px;
  align-items:flex-start;
  padding-bottom: 22px;
  border-bottom: 1px dashed var(--line);
}
.dish-icon{
  width:64px; height:64px;
  border-radius: 16px;
  background: var(--plate);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
  color: var(--orange);
}
.dish-icon svg{ width:30px; height:30px; }
.dish-info{ flex:1; }
.dish-head{
  display:flex;
  justify-content:space-between;
  gap: 14px;
  align-items:baseline;
}
.dish-head h4{ font-size:18px; }
.dish-price{
  font-family: var(--font-display);
  color: var(--orange-deep);
  font-size: 18px;
  white-space:nowrap;
}
.dish-info p{ color: var(--ink-soft); font-size: 14px; margin-top:6px; }
.dish-tags{ display:flex; gap:8px; margin-top:8px; }
.dish-tags span{
  font-size: 11px;
  font-weight:800;
  letter-spacing:.05em;
  text-transform:uppercase;
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--orange-soft);
  color: var(--orange-deep);
}
.dish-tags span.green{ background: #E4EFD9; color: var(--green); }

.about-split{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 70px;
  align-items:center;
}
.about-visual{
  position:relative;
  height: 440px;
}
.about-visual .blob{
  position:absolute;
  inset: 0;
  border-radius: 38% 62% 60% 40% / 45% 40% 60% 55%;
  background: linear-gradient(135deg, var(--orange) 0%, var(--orange-deep) 100%);
  will-change: transform;
}
.about-visual .plate-photo{
  position:absolute;
  width: 78%;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  border-radius: 50%;
  overflow:hidden;
  box-shadow: 0 30px 60px -28px rgba(36,26,18,.45);
  border: 10px solid #fff;
  will-change: transform;
}
.about-visual .plate-photo img{ width:100%; }
.about-visual .float-icon{
  position:absolute;
  color: var(--green);
  will-change: transform;
}
.about-text p{ color: var(--ink-soft); margin-bottom: 18px; font-size:16.5px; }
.about-text h2{ margin-bottom: 22px; }

.values-grid{
  display:grid;
  grid-template-columns: repeat(3,1fr);
  gap: 28px;
}
/* Vision, Mission & Core Values — Brand Guideline typeface (Fraunces) */
#vision-mission h2,
#vision-mission h4{
  font-family: var(--font-brand);
  color: var(--green-forest);
}
#vision-mission h4 .amharic{
  color: var(--green-forest);
  opacity:.85;
}
#core-values h2,
#core-values h4,
#core-values .eyebrow{
  font-family: var(--font-brand);
}
#vision-mission .value-card p,
#core-values .value-tile p{
  font-family: var(--font-body);
}

.value-card{
  background:#fff;
  border-radius: var(--radius-lg);
  padding: 38px 30px;
  text-align:center;
  box-shadow: 0 24px 50px -36px rgba(36,26,18,.3);
}
.value-card .v-icon{
  width: 72px; height:72px;
  margin: 0 auto 20px;
  border-radius:50%;
  background: var(--orange-soft);
  color: var(--orange-deep);
  display:flex; align-items:center; justify-content:center;
}
.value-card .v-icon svg{ width:32px; height:32px; }
.value-card h4{ margin-bottom:10px; font-size:19px; }
.value-card p{ color: var(--ink-soft); font-size:14.5px; margin-bottom:14px; }
.value-card p:last-child{ margin-bottom:0; }
.value-card p.amharic{ color: var(--ink-soft); opacity:.8; font-size:14px; }
h2 .amharic{ display:block; font-size:0.55em; color: var(--orange); margin-top:4px; }
.value-card h4 .amharic{ display:block; font-size:0.7em; color: var(--orange); margin-top:4px; font-weight:600; }
.values-grid-2{ grid-template-columns:repeat(2,1fr); max-width:920px; margin:0 auto; }
@media (max-width: 720px){
  .values-grid-2{ grid-template-columns:1fr; }
}

.timeline{
  max-width: 760px;
  margin: 0 auto;
  position:relative;
  padding-left: 40px;
  border-left: 3px dashed var(--orange);
}
.timeline-item{
  position:relative;
  padding-bottom: 48px;
}
.timeline-item:last-child{ padding-bottom:0; }
.timeline-item::before{
  content:"";
  position:absolute;
  left: -49px; top:4px;
  width: 18px; height:18px;
  border-radius:50%;
  background: var(--orange);
  border: 4px solid var(--cream);
  box-shadow: 0 0 0 2px var(--orange);
}
.timeline-item .year{
  font-family: var(--font-display);
  color: var(--orange);
  font-size: 18px;
  margin-bottom:6px;
  display:block;
}
.timeline-item h4{ margin-bottom:8px; font-size:19px; }
.timeline-item p{ color: var(--ink-soft); font-size:15px; max-width:480px; }

.locations-grid{
  display:grid;
  grid-template-columns: repeat(3,1fr);
  gap: 28px;
}
.location-card{
  background:#fff;
  border-radius: var(--radius-lg);
  overflow:hidden;
  box-shadow: 0 24px 50px -36px rgba(36,26,18,.3);
  transition: transform .3s ease, box-shadow .3s ease;
}
.location-card:hover{ transform: translateY(-8px); box-shadow: 0 30px 60px -30px rgba(36,26,18,.4); }
.location-map{
  height: 160px;
  background: var(--plate);
  position:relative;
  overflow:hidden;
}
.location-map svg{ width:100%; height:100%; }
.location-body{ padding: 26px 28px 30px; }
.location-body .loc-tag{
  display:inline-block;
  background: var(--orange-soft);
  color: var(--orange-deep);
  font-weight:800;
  font-size: 11px;
  letter-spacing:.07em;
  text-transform:uppercase;
  padding: 6px 12px;
  border-radius: 999px;
  margin-bottom: 12px;
}
.location-body h4{ font-size:20px; margin-bottom:10px; }
.location-body .loc-row{
  display:flex; gap:12px; align-items:flex-start;
  margin-bottom:8px; color: var(--ink-soft); font-size:14.5px;
}
.location-body .loc-row svg{ width:18px; height:18px; flex-shrink:0; margin-top:2px; color: var(--orange); }

.franchise-stats{
  display:grid;
  grid-template-columns: repeat(4,1fr);
  gap: 24px;
  text-align:center;
}
.franchise-stats .f-stat strong{
  font-family: var(--font-display);
  font-size: 44px;
  color: var(--orange);
  display:block;
}
.franchise-stats .f-stat span{ color: var(--ink-soft); font-weight:700; font-size:14px; }

.steps-grid{
  display:grid;
  grid-template-columns: repeat(4,1fr);
  gap: 26px;
}
.step-card{
  background:#fff;
  border-radius: var(--radius-lg);
  padding: 36px 26px;
  box-shadow: 0 24px 50px -36px rgba(36,26,18,.3);
  position:relative;
}
.step-card .step-num{
  font-family: var(--font-display);
  font-size: 46px;
  color: var(--orange-soft);
  -webkit-text-stroke: 1.5px var(--orange);
  margin-bottom: 14px;
}
.step-card h4{ font-size:18px; margin-bottom:10px; }
.step-card p{ color: var(--ink-soft); font-size:14.5px; }

.cta-banner{
  position:relative;
  border-radius: var(--radius-lg);
  overflow:hidden;
  padding: 64px 50px;
  text-align:center;
  background: linear-gradient(135deg, var(--orange) 0%, var(--orange-deep) 100%);
  color:#fff;
}
.cta-banner h2{ margin-bottom:18px; }
.cta-banner p{ max-width:480px; margin: 0 auto 30px; color: rgba(255,255,255,.9); }
.cta-banner .doodle{ color:#fff; opacity:.15; }

.contact-grid{
  display:grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 60px;
}
.contact-info h3{ margin-bottom: 18px; }
.contact-info p{ color: var(--ink-soft); margin-bottom: 30px; }
.contact-row{
  display:flex; gap:18px; align-items:flex-start;
  margin-bottom: 26px;
}
.contact-row .c-icon{
  width:52px; height:52px;
  border-radius:50%;
  background: var(--orange-soft);
  color: var(--orange-deep);
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.contact-row .c-icon svg{ width:22px; height:22px; }
.contact-row h4{ font-size:15px; margin-bottom:4px; text-transform:uppercase; letter-spacing:.06em; font-family: var(--font-body); font-weight:800; }
.contact-row p{ color: var(--ink-soft); font-size:14.5px; margin:0; }

.contact-form{
  background:#fff;
  border-radius: var(--radius-lg);
  padding: 44px;
  box-shadow: 0 30px 60px -36px rgba(36,26,18,.35);
}
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:20px; }
.field{ display:flex; flex-direction:column; gap:8px; }
.field.full{ grid-column: 1 / -1; }
.field label{ font-weight:800; font-size:13px; letter-spacing:.05em; text-transform:uppercase; color: var(--ink-soft); }
.field input, .field textarea{
  border: 2px solid var(--line);
  border-radius: 12px;
  padding: 14px 16px;
  font-family: var(--font-body);
  font-size: 15px;
  background: var(--cream);
  color: var(--ink);
  transition: border-color .2s ease, background .2s ease;
  resize: vertical;
}
.field input:focus, .field textarea:focus{
  outline:none;
  border-color: var(--orange);
  background:#fff;
}
.contact-form .btn{ width:100%; justify-content:center; margin-top:6px; }

.footer{
  background: var(--ink);
  color: var(--cream);
  padding: 80px 0 30px;
  position:relative;
  overflow:hidden;
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
  gap: 50px;
  padding-bottom: 50px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.footer .logo{ color:#fff; margin-bottom:18px; }
.footer .logo-img{ filter: brightness(0) invert(1); }
.footer .logo span{ color: var(--orange); }
.footer-col p{ color: rgba(255,248,238,.6); font-size:14.5px; max-width:280px; }
.footer-col h4{
  font-family: var(--font-body);
  font-weight:800;
  font-size:13px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color: var(--orange);
  margin-bottom: 18px;
}
.footer-col ul li{ margin-bottom:12px; }
.footer-col ul a{
  color: rgba(255,248,238,.7);
  font-size:14.5px;
  transition: color .2s ease, padding-left .2s ease;
}
.footer-col ul a:hover{ color:#fff; padding-left:4px; }
.footer-social{ display:flex; gap:12px; margin-top:18px; }
.footer-social a{
  width:40px; height:40px;
  border-radius:50%;
  border: 1px solid rgba(255,255,255,.2);
  display:flex; align-items:center; justify-content:center;
  transition: background .2s ease, border-color .2s ease, transform .2s ease;
}
.footer-social a:hover{ background: var(--orange); border-color: var(--orange); transform: translateY(-3px); }
.footer-social svg{ width:18px; height:18px; }
.footer-bottom{
  display:flex; justify-content:space-between; align-items:center;
  padding-top: 26px;
  font-size: 13px;
  color: rgba(255,248,238,.5);
  flex-wrap:wrap;
  gap: 12px;
}
.footer-bottom a:hover{ color:#fff; }

@media (max-width: 1024px){
  .hero .container{ grid-template-columns:1fr; text-align:center; }
  .hero-copy p{ margin-inline:auto; }
  .hero-visual{ order:-1; min-height:380px; }
  .stats-inner{ grid-template-columns: repeat(2,1fr); gap:28px; }
  .stat{ border-right:none; border-bottom:1px dashed var(--line); padding-bottom:20px; }
  .feature-grid, .values-grid, .locations-grid, .steps-grid{ grid-template-columns: repeat(2,1fr); }
  .franchise-stats{ grid-template-columns: repeat(2,1fr); gap:36px; }
  .about-split, .contact-grid{ grid-template-columns:1fr; gap:50px; }
  .about-visual{ height:360px; }
  .dish-grid{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns: 1fr 1fr; gap:40px; }
}

@media (max-width: 720px){
    .nav-links{
    position:absolute; top:100%; left:0; right:0;
    background: var(--cream);
    flex-direction:column;
    padding: 24px 32px;
    gap: 20px;
    border-bottom: 1px solid var(--line);
    transform: translateY(-12px);
    opacity:0; visibility:hidden;
    transition: opacity .25s ease, transform .25s ease, visibility .25s ease;
  }
  .nav-links.is-open{ opacity:1; visibility:visible; transform: translateY(0); }
  .nav-toggle{ display:flex; }
  .nav-toggle.is-active span:nth-child(1){ transform: translateY(8px) rotate(45deg); }
  .nav-toggle.is-active span:nth-child(2){ opacity:0; }
  .nav-toggle.is-active span:nth-child(3){ transform: translateY(-8px) rotate(-45deg); }
  .logo-img{ height:48px !important; }
  .nav .container{ padding-top:12px; padding-bottom:12px; }

    .page-hero{ height:44vh; }
  .page-hero-content h1{ font-size: clamp(30px,10vw,52px); }
  .page-hero-content p{ font-size:14px; }

    .hero{ padding:36px 0 32px; }
  .hero .container{ grid-template-columns:1fr; text-align:center; gap:20px; }
  .hero-copy p{ margin-inline:auto; }
  .hero-visual{ order:-1; min-height:260px; }
  .hero-title{ font-size: clamp(38px,12vw,68px); }
  .hero-ctas{ justify-content:center; flex-direction:column; align-items:center; }
  .hero-ctas .btn{ width:100%; max-width:300px; text-align:center; justify-content:center; }

    .stats-inner{ grid-template-columns: repeat(2,1fr); }
  .stat{ border-right:none; border-bottom:1px dashed var(--line); padding-bottom:16px; }
  .stat:nth-child(odd){ border-right:1px dashed var(--line); }

    .cat-list{ flex-wrap:nowrap; overflow-x:auto; padding-bottom:8px; -webkit-overflow-scrolling:touch; scrollbar-width:none; gap:10px; }
  .cat-list::-webkit-scrollbar{ display:none; }
  .cat-item{ flex-shrink:0; }
  .cat-arrow{ display:none; }

    .feature-grid, .values-grid, .locations-grid, .steps-grid, .franchise-stats{ grid-template-columns:1fr; }
  .feature-img{ height:200px; }

    .menu-nav{ flex-wrap:wrap; gap:8px 12px; justify-content:center; }
  .menu-nav a{ font-size:13px; padding:7px 14px; }
  .dish-grid{ grid-template-columns:1fr; }
  .dish{ gap:14px; }
  .dish-image{ width:54px; height:54px; }
  .menu-category-head{ flex-direction:column; align-items:flex-start; gap:6px; }
  .menu-category-head p{ text-align:left; }

    .about-split{ grid-template-columns:1fr; gap:32px; }
  .about-visual{ height:280px; }
  .timeline{ padding-left:20px; }
  .timeline-item{ padding-left:20px; margin-bottom:28px; }

    .franchise-stats{ grid-template-columns: repeat(2,1fr); gap:24px; }
  .f-stat strong{ font-size: clamp(28px,8vw,44px); }

    .loc-row{ flex-direction:column; gap:12px; }
  .location-card{ padding:24px 20px; }
  .location-map{ height:200px; border-radius:12px; }

    .contact-grid{ grid-template-columns:1fr; gap:36px; }
  .form-row{ grid-template-columns:1fr; }
  .contact-info{ padding-bottom:0; }
  .field input, .field textarea, .field select{ font-size:16px; } 
    .cta-banner{ padding:40px 20px; }
  .cta-banner h2{ font-size: clamp(26px,8vw,44px); }

    .footer-grid{ grid-template-columns:1fr; gap:32px; }
  .footer{ padding:56px 0 24px; }

    .section, .section.alt{ padding-top:48px; padding-bottom:48px; }
  .section-head{ margin-bottom:36px; }
  .eyebrow{ font-size:11px; }

    .hero{ overflow:hidden; }
  .hero-visual{ overflow:hidden; min-height:220px; }

  .hero-plate{ width:84%; }
  .hero-mark.mark-2{ display:none; }
  .hero-mark.mark-1{ width:44px; right:2%; }

    .hero .doodle-field{ display:none; }

    .stats-inner{ grid-template-columns: repeat(2,1fr); gap:0; }
  .stat{ padding:20px 12px; border-right:none; border-bottom:1px dashed var(--line); }
  .stat:nth-child(odd){ border-right:1px dashed var(--line); }
  .stat:nth-last-child(-n+2){ border-bottom:none; }
  .stat strong{ font-size:18px; white-space:nowrap; }
  .stat span{ font-size:12px; white-space:nowrap; }
  .stat .stat-icon{ width:36px; height:36px; }

    .nav-links{ display:none; }
  .nav-links.is-open{ display:flex; }

    body{ overflow-x:hidden; }
  .hero, .stats, section, .container{ max-width:100%; }
  img{ max-width:100%; }

}

@media (max-width: 430px){
    .container{ padding:0 16px; }

    .hero-title{ font-size: clamp(36px, 11vw, 52px); line-height:1.0; }
  .script{ font-size:17px; }
  .hero{ padding:28px 0 24px; }
  .hero-visual{ min-height:200px; }
  .hero-plate{ width:80%; }

    .hero-ctas{ gap:12px; }
  .hero-ctas .btn{ width:100%; max-width:100%; font-size:14px; padding:13px 20px; }

    .stats{ padding:0 16px; margin-bottom:56px; }
  .stats-inner{ padding:20px 8px; }
  .stat{ padding:14px 8px; gap:10px; }
  .stat strong{ font-size:16px; }
  .stat span{ font-size:11px; }
  .stat .stat-icon{ width:30px; height:30px; }

    .cat-circle{ width:52px; height:52px; }
  .cat-item span{ font-size:11px; }

    .feature-body{ padding:18px 16px; }
  .feature-body h4{ font-size:17px; }
  .feature-img{ height:180px; }

    .menu-nav a{ font-size:12px; padding:6px 12px; }

    .page-hero{ height:38vh; }
  .page-hero-content h1{ font-size: clamp(26px, 9vw, 40px); }

    .section-head h2{ font-size: clamp(26px, 8vw, 40px); }

    .cta-banner{ padding:36px 16px; }
  .cta-banner h2{ font-size: clamp(24px, 8vw, 36px); }
  .cta-banner p{ font-size:14px; }
  .cta-banner .btn{ width:100%; max-width:100%; }

    .footer{ padding:44px 0 20px; }
  .footer-bottom{ flex-direction:column; gap:8px; text-align:center; font-size:12px; }

    .dish{ gap:12px; }
  .dish-image{ width:48px; height:48px; }
  .dish-info h4{ font-size:14px; }
  .dish-info p{ font-size:13px; }

    .about-visual{ height:240px; }

    .section, .section.alt{ padding-top:40px; padding-bottom:40px; }
  .eyebrow{ font-size:10px; letter-spacing:.1em; }
  p{ font-size:14px; }
 
  .hero-mark.mark-2{ display:none; }
  .hero-mark.mark-1{ width:44px; right:2%; }

  .hero-visual{ overflow:hidden; }
}

@media (prefers-reduced-motion: reduce){
  *{ animation: none !important; transition: none !important; }
  .page-hero-bg, .page-hero-layer, .page-hero-content,
  .hero-splash, .hero-plate, .about-visual .blob, .about-visual .plate-photo, .about-visual .float-icon{
    transform: none !important;
  }
}

.dish-image{
  width:64px; height:64px;
  border-radius:16px;
  overflow:hidden;
  flex-shrink:0;
}
.dish-image img{ width:100%; height:100%; object-fit:cover; display:block; }

.hero-video-bg video,
.hero-vid-badge-inner video,
.story-vid-main video,
.story-vid-accent video { will-change: opacity; }

#gallery, .photo-strip, .video-strip,
.vg-bento, .vg-strip,
.ps-item, .vs-item, .vg-item, .vg-strip-item {
  contain: layout paint;
}

img { content-visibility: auto; }

.feature-card, .value-card, .value-tile {
  transform: translateZ(0);
}
