
/* CUSTOM DISPLAY FONT */

@font-face {
  font-family: 'CreamCakeScript';
  src: url('/food-truck/assets/fonts/cream-cake-script.otf') format('opentype');
  font-weight: normal;
  font-style: normal;
}


:root{
  --se-blue:#43586a;
  --se-dark:#243342;
  --se-coral:#df7b64;
  --se-cream:#f7efe4;
  --se-card:#fffaf4;
  --se-text:#243342;
  --se-soft:#5a6670;
  --shadow:0 22px 60px rgba(0,0,0,.12);
}
*{box-sizing:border-box}
body.truck-site{margin:0;background:var(--se-cream);color:var(--se-text);font-family:Inter,system-ui,sans-serif;overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.truck-container{width:min(1180px,calc(100% - 40px));margin:auto}
.truck-topbar{position:sticky;top:0;z-index:99;background:rgba(67,88,106,.96);backdrop-filter:blur(14px)}
.truck-top-inner{width:min(1380px,calc(100% - 40px));margin:auto;min-height:92px;display:flex;align-items:center;justify-content:space-between;gap:30px}
.truck-logo img{width:92px}
.truck-nav{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.truck-nav a{color:white;font-weight:850;padding:11px 15px;border-radius:999px}
.truck-nav a:hover,.truck-nav a.active{background:var(--se-coral)}
.truck-hero{position:relative;min-height:88vh;background:var(--se-dark);color:white;overflow:hidden}
.truck-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(20,28,36,.42),rgba(20,28,36,.14)),linear-gradient(180deg,rgba(0,0,0,.03),rgba(0,0,0,.18));z-index:2}
.truck-hero-bg{position:absolute;inset:0;background:url("/images/food-truck/truck3.jpg") center/cover no-repeat;filter:saturate(1.08) contrast(1.04)}
.truck-hero-content{position:relative;z-index:4;min-height:88vh;display:flex;flex-direction:column;justify-content:center;max-width:820px}
.eyebrow{display:inline-block;text-transform:uppercase;letter-spacing:.18em;color:#f3c2b4;font-size:.8rem;font-weight:900}
h1,h2,h3,h4{font-family:Georgia,serif;letter-spacing:-.04em}
h1{font-size:clamp(3.4rem,8vw,7rem);line-height:.9;margin:18px 0}
h2{font-size:clamp(2.4rem,5vw,4.7rem);line-height:.95;margin:12px 0 18px}
p{line-height:1.75;color:var(--se-soft)}
.truck-hero p{color:rgba(255,255,255,.86);font-size:1.15rem;max-width:680px}
.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:50px;padding:13px 21px;border-radius:999px;border:0;font-weight:900;cursor:pointer}
.btn.primary{background:var(--se-coral);color:white}
.btn.light{background:white;color:var(--se-dark)}
.btn.blue{background:var(--se-blue);color:white}
.btn.disabled{opacity:.5;pointer-events:none}
.section{padding:92px 0}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:var(--se-card);border-radius:32px;box-shadow:var(--shadow);overflow:hidden;border:1px solid rgba(223,123,100,.12)}
.card img{height:260px;width:100%;object-fit:cover}
.card-body{padding:26px}
.live-board{background:var(--se-dark);color:white;border-radius:36px;padding:34px;box-shadow:var(--shadow)}
.live-board p,.live-board li{color:rgba(255,255,255,.78)}
.status-pill{display:inline-flex;background:var(--se-coral);color:white;border-radius:999px;padding:8px 13px;font-weight:900;letter-spacing:.12em;text-transform:uppercase}
.menu-image{background:white;border-radius:34px;padding:16px;box-shadow:var(--shadow)}
.menu-image img{width:100%;max-height:600px;object-fit:contain;border-radius:22px}
.map-frame{padding:20px;border-radius:38px;background:linear-gradient(145deg,#fffaf4,#f3c2b4);border:3px solid var(--se-coral);box-shadow:var(--shadow)}
.map-frame iframe{width:100%;height:520px;border:0;border-radius:26px}
.order-grid{display:grid;grid-template-columns:1fr 370px;gap:34px;align-items:start}
.product-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.truck-product{display:grid;grid-template-columns:145px 1fr;gap:18px;background:var(--se-card);border-radius:28px;padding:15px;box-shadow:var(--shadow)}
.truck-product img{width:145px;height:130px;object-fit:cover;border-radius:22px}
.truck-product h3{margin:0 0 6px;font-size:1.3rem}
.truck-product p{margin:0 0 9px;font-size:.94rem}
.truck-product strong{display:block;color:var(--se-coral);margin-bottom:10px}
.cart{position:sticky;top:115px;background:var(--se-dark);color:white;border-radius:34px;padding:26px;box-shadow:var(--shadow)}
.cart p,.cart span{color:rgba(255,255,255,.72)}
.cart-line{background:rgba(255,255,255,.08);border-radius:18px;padding:13px;margin-bottom:10px}
.qty-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:10px}
.qty-controls button{border:0;border-radius:999px;min-height:30px;padding:6px 10px;font-weight:900}
.totals{border-top:1px solid rgba(255,255,255,.14);margin-top:18px;padding-top:18px;display:grid;gap:10px}
.totals div{display:flex;justify-content:space-between}
.form-card{background:var(--se-card);border-radius:34px;padding:28px;box-shadow:var(--shadow)}
input,textarea,select{width:100%;padding:14px 15px;border:1px solid rgba(36,51,66,.12);border-radius:16px;margin-bottom:12px;font:inherit}
textarea{min-height:130px}
.gallery-track{display:flex;gap:22px;width:max-content;animation:truckScroll 42s linear infinite}
.gallery-track img{width:320px;height:230px;object-fit:cover;border-radius:26px;box-shadow:var(--shadow);flex-shrink:0}
@keyframes truckScroll{to{transform:translateX(-50%)}}
.truck-footer{background:var(--se-dark);color:white;padding:70px 0}
.truck-footer img{width:110px}.truck-footer p,.truck-footer a{color:rgba(255,255,255,.72);display:block;line-height:1.7}.footer-grid{display:grid;grid-template-columns:1fr .7fr 1fr;gap:40px}.credit{font-size:.88rem;color:#f3c2b4!important}
@media(max-width:900px){.truck-top-inner{flex-direction:column;align-items:flex-start;padding:16px 0}.truck-nav{overflow-x:auto;flex-wrap:nowrap;width:100%;padding-bottom:6px}.truck-nav a{white-space:nowrap}.grid-3,.order-grid,.product-grid,.footer-grid{grid-template-columns:1fr}.truck-product{grid-template-columns:1fr}.truck-product img{width:100%;height:220px}.cart{position:relative;top:auto}.map-frame iframe{height:340px}.truck-hero-content{padding:110px 0 80px}}


/* TRACKER HERO SCHEDULE CARD */

.tracker-hero-grid {
  position: relative;
  z-index: 4;
  min-height: 88vh;
  display: grid;
  grid-template-columns: 1fr .82fr;
  gap: 54px;
  align-items: center;
  width: min(1180px, calc(100% - 40px));
  margin: 0 auto;
  padding: 110px 0;
}

.tracker-hero-copy {
  min-height: auto !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

.schedule-hero-card {
  max-width: 520px;
  justify-self: end;
}

.schedule-hero-card img {
  max-height: 560px;
  object-fit: contain;
  background: white;
}

@media (max-width: 1050px) {
  .tracker-hero-grid {
    grid-template-columns: 1fr;
  }

  .schedule-hero-card {
    justify-self: start;
    max-width: 100%;
  }
}


/* TODAY LIVE BOARD REBUILD */

.live-board-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
  margin-bottom: 30px;
}

.live-board-grid,
.daily-board-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 26px;
}

.live-tile,
.daily-card,
.live-message-card,
.live-note {
  border-radius: 30px;
  padding: 28px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 18px 45px rgba(0,0,0,.08);
}

.live-tile h3,
.daily-card h2,
.live-message-card p {
  color: white;
}

.live-tile p,
.daily-card li,
.live-message-card p {
  color: rgba(255,255,255,.76);
}

.live-message-card {
  margin-top: 28px;
}

.daily-card {
  background: #fffaf4;
}

.daily-card h2 {
  color: var(--se-dark);
}

.daily-card ul {
  margin: 20px 0 0;
  padding-left: 22px;
}

.daily-card li {
  color: var(--se-soft);
  font-size: 1.05rem;
  line-height: 1.8;
}

.available-card {
  border-top: 8px solid var(--se-coral);
}

.specials-card {
  border-top: 8px solid var(--se-blue);
}

.soldout-card {
  border-top: 8px solid #1a1410;
}

.live-note {
  background: var(--se-dark);
  color: white;
}

.live-note h2 {
  color: white;
}

.live-note p {
  color: rgba(255,255,255,.76);
  max-width: 760px;
}

@media(max-width:900px) {
  .live-board-grid,
  .daily-board-grid {
    grid-template-columns: 1fr;
  }
}



/* TODAY HERO MENU CARD */

.today-menu-card {
  position: relative;
  z-index: 5;
  width: min(460px, calc(100% - 40px));
  margin: -640px auto 80px auto;
  background: rgba(255,255,255,.92);
  border-radius: 34px;
  padding: 18px;
  box-shadow: 0 30px 70px rgba(0,0,0,.28);
  border: 4px solid rgba(255,255,255,.45);
  backdrop-filter: blur(10px);
}

.today-menu-card img {
  width: 100%;
  max-height: 620px;
  object-fit: contain;
  border-radius: 22px;
  background: white;
}

.today-menu-card .eyebrow {
  display: inline-flex;
  margin-bottom: 14px;
}

@media(max-width:950px){

  .today-menu-card{
    margin: -120px auto 60px auto;
    width: calc(100% - 24px);
  }

}


/* FIX TODAY HERO LAYOUT */

.today-hero-fixed {
  min-height: 88vh;
}

.today-hero-grid {
  position: relative;
  z-index: 5;
  min-height: 88vh;
  display: grid;
  grid-template-columns: 1fr 440px;
  gap: 56px;
  align-items: center;
  padding: 100px 0;
}

.today-hero-copy h1 {
  max-width: 720px;
  color: #fff;
}

.today-hero-copy p {
  max-width: 620px;
  color: rgba(255,255,255,.88);
  font-size: 1.15rem;
}

.today-menu-card {
  margin: 0 !important;
  width: 100% !important;
  max-width: 440px;
  justify-self: end;
  background: rgba(255,255,255,.94);
  border-radius: 34px;
  padding: 18px;
  box-shadow: 0 30px 70px rgba(0,0,0,.28);
  border: 4px solid rgba(255,255,255,.45);
}

.today-menu-card img {
  width: 100%;
  max-height: 560px;
  object-fit: contain;
  border-radius: 22px;
  background: #fff;
}

@media(max-width:950px){
  .today-hero-grid {
    grid-template-columns: 1fr;
    padding: 90px 0 60px;
  }

  .today-menu-card {
    justify-self: start;
    max-width: 100%;
  }
}

/* Enlarge menu card on Menu / Order hero */
.menu-hero-card,
.menu-image.menu-hero-card {
  max-width: 620px !important;
  transform: scale(1.12);
  transform-origin: center right;
}

.menu-hero-card img,
.menu-image.menu-hero-card img {
  max-height: 720px !important;
}

@media(max-width:950px){
  .menu-hero-card,
  .menu-image.menu-hero-card {
    transform: none;
    max-width: 100% !important;
  }
}

/* MASSIVE MENU HERO CARD */

.menu-hero-card,
.menu-image.menu-hero-card {
  max-width: 760px !important;
  width: 760px !important;
  transform: scale(1.22);
  transform-origin: center right;
}

.menu-hero-card img,
.menu-image.menu-hero-card img {
  width: 100% !important;
  max-height: 920px !important;
  object-fit: contain !important;
}

@media(max-width:1100px){
  .menu-hero-card,
  .menu-image.menu-hero-card {
    width: 100% !important;
    max-width: 100% !important;
    transform: none !important;
  }
}

/* Rebalance menu hero layout */

.menu-hero-grid,
.hero-menu-layout,
.truck-menu-hero-grid {
  grid-template-columns: .72fr 1.28fr !important;
  gap: 10px !important;
  align-items: center !important;
}

.menu-hero-copy,
.hero-copy-left {
  max-width: 520px !important;
}

.menu-hero-card,
.menu-image.menu-hero-card {
  justify-self: start !important;
  margin-left: -80px !important;
}

@media(max-width:1100px){

  .menu-hero-grid,
  .hero-menu-layout,
  .truck-menu-hero-grid {
    grid-template-columns: 1fr !important;
  }

  .menu-hero-card,
  .menu-image.menu-hero-card {
    margin-left: 0 !important;
  }

}

/* Slightly reduce oversized menu card */

.menu-hero-card,
.menu-image.menu-hero-card {
  max-width: 680px !important;
  width: 680px !important;
  transform: scale(1.08) !important;
}

.menu-hero-card img,
.menu-image.menu-hero-card img {
  max-height: 820px !important;
}

/* Reduce menu hero headline size */

.menu-hero-copy h1,
.hero-menu-copy h1,
.truck-menu-hero-copy h1 {
  font-size: clamp(4rem, 6vw, 6.2rem) !important;
  line-height: .92 !important;
  max-width: 560px !important;
}

.menu-hero-copy p,
.hero-menu-copy p,
.truck-menu-hero-copy p {
  max-width: 460px !important;
}

/* Further reduce menu hero text */

.menu-hero-copy h1,
.hero-menu-copy h1,
.truck-menu-hero-copy h1 {
  font-size: clamp(3.1rem, 4.7vw, 5rem) !important;
  line-height: .94 !important;
  max-width: 500px !important;
}

.menu-hero-copy p,
.hero-menu-copy p,
.truck-menu-hero-copy p {
  font-size: 1rem !important;
  max-width: 430px !important;
}

/* Make menu hero layout work while keeping menu large */

.menu-hero .order-grid,
.menu-hero .truck-container.order-grid {
  grid-template-columns: .62fr 1.38fr !important;
  gap: 28px !important;
  width: min(1320px, calc(100% - 40px)) !important;
}

.menu-hero-copy h1 {
  font-size: clamp(2.7rem, 4vw, 4.35rem) !important;
  line-height: .92 !important;
  max-width: 430px !important;
}

.menu-hero-copy p {
  font-size: .98rem !important;
  max-width: 420px !important;
}

.menu-hero-card,
.menu-image.menu-hero-card {
  width: 640px !important;
  max-width: 640px !important;
  transform: none !important;
  margin-left: 0 !important;
  justify-self: end !important;
}

.menu-hero-card img,
.menu-image.menu-hero-card img {
  width: 100% !important;
  max-height: 760px !important;
  object-fit: contain !important;
}

@media(max-width:1100px){
  .menu-hero .order-grid,
  .menu-hero .truck-container.order-grid {
    grid-template-columns: 1fr !important;
  }

  .menu-hero-card,
  .menu-image.menu-hero-card {
    width: 100% !important;
    max-width: 100% !important;
    justify-self: start !important;
  }
}

/* Final menu hero left-side cleanup */

.menu-hero .truck-container.order-grid {
  grid-template-columns: .54fr 1.46fr !important;
  gap: 34px !important;
}

.menu-hero-copy {
  max-width: 420px !important;
  align-self: center !important;
}

.menu-hero-copy .eyebrow {
  font-size: .72rem !important;
  letter-spacing: .2em !important;
  margin-bottom: 10px !important;
}

.menu-hero-copy h1 {
  font-size: clamp(2.35rem, 3.45vw, 3.85rem) !important;
  line-height: .94 !important;
  max-width: 390px !important;
  margin: 12px 0 18px !important;
}

.menu-hero-copy p {
  font-size: .95rem !important;
  line-height: 1.65 !important;
  max-width: 390px !important;
}

.menu-hero-copy .actions {
  margin-top: 22px !important;
}

.menu-hero-copy .btn {
  min-height: 46px !important;
  padding: 11px 18px !important;
}

@media(max-width:1100px){
  .menu-hero .truck-container.order-grid {
    grid-template-columns: 1fr !important;
  }

  .menu-hero-copy {
    max-width: 100% !important;
  }

  .menu-hero-copy h1,
  .menu-hero-copy p {
    max-width: 100% !important;
  }
}

/* HARD FIX MENU PAGE HERO LAYOUT */

body.truck-site .truck-hero > .truck-container.order-grid {
  grid-template-columns: 380px 1fr !important;
  gap: 24px !important;
  width: min(1280px, calc(100% - 40px)) !important;
}

body.truck-site .truck-hero > .truck-container.order-grid > div:first-child {
  max-width: 380px !important;
  overflow: visible !important;
}

body.truck-site .truck-hero > .truck-container.order-grid h1 {
  font-size: 3.55rem !important;
  line-height: .92 !important;
  max-width: 360px !important;
  margin: 12px 0 18px !important;
}

body.truck-site .truck-hero > .truck-container.order-grid p {
  font-size: .96rem !important;
  line-height: 1.6 !important;
  max-width: 360px !important;
}

body.truck-site .truck-hero > .truck-container.order-grid .menu-hero-card {
  justify-self: start !important;
  margin-left: 0 !important;
  width: 680px !important;
  max-width: 680px !important;
}

@media(max-width:1100px){
  body.truck-site .truck-hero > .truck-container.order-grid {
    grid-template-columns: 1fr !important;
  }

  body.truck-site .truck-hero > .truck-container.order-grid > div:first-child,
  body.truck-site .truck-hero > .truck-container.order-grid h1,
  body.truck-site .truck-hero > .truck-container.order-grid p {
    max-width: 100% !important;
  }

  body.truck-site .truck-hero > .truck-container.order-grid .menu-hero-card {
    width: 100% !important;
    max-width: 100% !important;
  }
}


/* TRUCK HEADER TICKER */

.truck-ticker {
  width: 100%;
  overflow: hidden;
  background: #243342;
  border-top: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.truck-ticker-track {
  display: flex;
  gap: 34px;
  width: max-content;
  animation: truckTicker 38s linear infinite;
  padding: 8px 0;
  white-space: nowrap;
}

.truck-ticker-track span {
  color: rgba(255,255,255,.78);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.truck-ticker-track strong {
  color: #f3c2b4;
}

@keyframes truckTicker {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}

@media(max-width:900px) {
  .truck-ticker-track {
    animation-duration: 28s;
  }

  .truck-ticker-track span {
    font-size: .68rem;
  }
}




/* MAIN LARGE DISPLAY TEXT */

.truck-site h1,
.truck-site .truck-hero h1,
.truck-site .hero-copy h1,
.truck-site .section-title,
.truck-site .display-title {
  font-family: 'CreamCakeScript', cursive !important;
  font-weight: normal !important;
  letter-spacing: .01em !important;
  line-height: .9 !important;
}

/* KEEP NAV / BODY CLEAN */

.truck-site body,
.truck-site p,
.truck-site a,
.truck-site button,
.truck-site li,
.truck-site span,
.truck-site h3,
.truck-site h4 {
  font-family: 'Plus Jakarta Sans', sans-serif !important;
}



/* MAIN SCRIPT TITLES */

.truck-site h1,
.truck-site .truck-hero h1,
.truck-site .hero-copy h1,
.truck-site .display-title,
.truck-site .section-title,
.truck-site .today-board h2,
.truck-site .menu-hero h1 {
  font-family: 'CreamCakeScript', cursive !important;
  font-weight: normal !important;
  letter-spacing: 0 !important;
  line-height: .92 !important;
}

/* KEEP BODY CLEAN */

.truck-site p,
.truck-site li,
.truck-site span,
.truck-site button,
.truck-site a,
.truck-site h3,
.truck-site h4 {
  font-family: 'Plus Jakarta Sans', sans-serif !important;
}


/* BLACKRUSH DISPLAY FONT */

@font-face {
  font-family: 'Blackrush';
  src: url('/food-truck/assets/fonts/blackrush.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}

.truck-site h1,
.truck-site h2,
.truck-site .truck-hero h1 {
  font-family: 'Blackrush', Georgia, serif !important;
  font-weight: normal !important;
  letter-spacing: 0 !important;
  line-height: .9 !important;
}
