/* ============================================
   VLAM & VLEES — foodtruck website
   Design tokens
   ============================================ */
:root{
  --cream:      #FFF8F0;
  --white:      #FFFFFF;
  --orange:     #E8590C;
  --orange-deep:#C2450A;
  --amber:      #F4A33C;
  --ember:      #B83B1F;
  --char:       #2B1810;
  --char-soft:  #5C4435;

  --font-display: "Unbounded", system-ui, sans-serif;
  --font-body:    "Plus Jakarta Sans", system-ui, sans-serif;
  --font-mono:    "JetBrains Mono", monospace;

  --radius: 22px;
  --container: 1180px;
}

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

html{scroll-behavior:smooth;}

body{
  font-family:var(--font-body);
  background:var(--cream);
  color:var(--char);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}

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

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

.wrap{
  max-width:var(--container);
  margin:0 auto;
  padding:0 28px;
}

h1,h2,h3{
  font-family:var(--font-display);
  line-height:1.08;
  font-weight:700;
  letter-spacing:-0.01em;
}

h2{font-size:clamp(2rem,4vw,2.9rem); color:var(--char);}
h3{font-size:1.3rem;}

.eyebrow{
  font-family:var(--font-mono);
  font-size:0.78rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--orange-deep);
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-bottom:14px;
}
.eyebrow::before{
  content:"";
  width:8px;height:8px;border-radius:50%;
  background:var(--orange);
  box-shadow:0 0 0 4px rgba(232,89,12,0.18);
}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--font-body);
  font-weight:700;
  font-size:0.98rem;
  padding:15px 28px;
  border-radius:100px;
  border:2px solid transparent;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.btn-primary{
  background:var(--orange);
  color:var(--white);
  box-shadow:0 8px 0 0 var(--orange-deep);
}
.btn-primary:hover{transform:translateY(-3px); box-shadow:0 11px 0 0 var(--orange-deep);}
.btn-primary:active{transform:translateY(2px); box-shadow:0 4px 0 0 var(--orange-deep);}

.btn-ghost{
  background:transparent;
  color:var(--char);
  border-color:var(--char);
}
.btn-ghost:hover{background:var(--char); color:var(--cream);}

.btn-light{
  background:var(--white);
  color:var(--orange-deep);
  box-shadow:0 8px 0 0 rgba(0,0,0,0.12);
}
.btn-light:hover{transform:translateY(-3px); box-shadow:0 11px 0 0 rgba(0,0,0,0.12);}

/* ============ HEADER ============ */
header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,248,240,0.92);
  backdrop-filter:blur(8px);
  border-bottom:2px solid rgba(43,24,16,0.06);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 0;
}
.logo{
  display:flex; align-items:center; gap:10px;
  font-family:var(--font-display);
  font-size:1.25rem;
  font-weight:700;
  color:var(--char);
}
.logo .flame{width:34px;height:34px;flex-shrink:0;}

.nav-links{
  display:flex; align-items:center; gap:34px;
  font-weight:600;
  font-size:0.98rem;
}
.nav-links a{position:relative; padding:6px 0;}
.nav-links a::after{
  content:"";
  position:absolute; left:0; bottom:0;
  width:0; height:3px; border-radius:3px;
  background:var(--orange);
  transition:width .2s ease;
}
.nav-links a:hover::after, .nav-links a.active::after{width:100%;}
.nav-links a.active{color:var(--orange-deep);}

.nav-cta{display:flex; align-items:center; gap:20px;}

.nav-toggle{
  display:none;
  background:none; border:none; cursor:pointer;
  flex-direction:column; gap:5px;
}
.nav-toggle span{width:26px;height:3px;background:var(--char);border-radius:3px;}

@media (max-width:880px){
  .nav-links{
    position:fixed; inset:74px 0 0 0;
    background:var(--cream);
    flex-direction:column; justify-content:flex-start;
    padding:36px 28px;
    gap:22px;
    font-size:1.3rem;
    transform:translateX(100%);
    transition:transform .25s ease;
  }
  .nav-links.open{transform:translateX(0);}
  .nav-toggle{display:flex;}
  .nav-cta .btn-primary{padding:11px 18px; font-size:0.85rem;}
}

/* ============ HERO ============ */
.hero{
  position:relative;
  padding:84px 0 110px;
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.15fr 0.85fr;
  gap:50px;
  align-items:center;
}
.hero h1{
  font-size:clamp(2.6rem,5.6vw,4.4rem);
  margin-bottom:22px;
}
.hero h1 .accent{color:var(--orange);}
.hero p.lead{
  font-size:1.18rem;
  color:var(--char-soft);
  max-width:520px;
  margin-bottom:34px;
}
.hero-actions{display:flex; gap:16px; flex-wrap:wrap;}
.hero-art{position:relative;}

@media (max-width:880px){
  .hero-grid{grid-template-columns:1fr; text-align:left;}
  .hero-art{order:-1; max-width:280px; margin:0 auto 10px;}
}

/* ============ WAVE DIVIDERS — the signature flowing orange/white motif ============ */
.wave{
  display:block; width:100%; line-height:0;
  position:relative;
  transform:translateY(1px);
}
.wave svg{width:100%; height:auto; display:block;}

/* ============ SECTIONS ============ */
section{position:relative;}
.section-pad{padding:96px 0;}
.bg-orange{background:var(--orange); color:var(--white);}
.bg-orange h2, .bg-orange .eyebrow{color:var(--white);}
.bg-char{background:var(--char); color:var(--cream);}
.bg-char h2{color:var(--cream);}

.stats-row{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:28px;
  text-align:center;
}
.stat-num{
  font-family:var(--font-display);
  font-size:clamp(2.4rem,5vw,3.4rem);
  color:var(--white);
}
.stat-label{font-size:0.95rem; opacity:0.9; margin-top:4px;}
@media (max-width:700px){.stats-row{grid-template-columns:1fr; gap:36px;}}

/* ============ TICKET CARDS (signature component) ============ */
.tickets{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:26px;
  margin-top:50px;
}
.ticket{
  position:relative;
  background:var(--white);
  border-radius:18px;
  padding:30px 26px 26px;
  box-shadow:0 14px 30px -16px rgba(43,24,16,0.25);
  border:2px solid rgba(43,24,16,0.06);
  transition:transform .2s ease, box-shadow .2s ease;
}
.ticket:hover{transform:translateY(-6px); box-shadow:0 22px 36px -16px rgba(43,24,16,0.32);}
.ticket::before, .ticket::after{
  content:""; position:absolute;
  width:22px; height:22px; border-radius:50%;
  background:var(--cream);
  top:50%; transform:translateY(-50%);
}
.ticket::before{left:-11px;}
.ticket::after{right:-11px;}
.ticket-num{
  font-family:var(--font-mono);
  font-size:0.85rem;
  color:var(--orange-deep);
  letter-spacing:0.06em;
}
.ticket h3{margin:8px 0 10px;}
.ticket p{color:var(--char-soft); font-size:0.96rem; margin-bottom:14px;}
.ticket .perf{
  border-top:2px dashed rgba(43,24,16,0.18);
  margin:16px 0;
}
.chip-row{display:flex; flex-wrap:wrap; gap:8px; margin-bottom:6px;}
.chip{
  font-family:var(--font-mono);
  font-size:0.74rem;
  padding:5px 11px;
  border-radius:100px;
  background:var(--cream);
  color:var(--char-soft);
  border:1px solid rgba(43,24,16,0.1);
}
.ticket a.ticket-link{
  display:inline-flex; align-items:center; gap:6px;
  font-weight:700; color:var(--orange-deep);
  margin-top:8px; font-size:0.92rem;
}

/* full detail ticket on formules page */
.ticket-full{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:30px;
  align-items:start;
  padding:38px;
}
.ticket-full .tnum{
  font-family:var(--font-display);
  font-size:2.6rem;
  color:var(--orange);
  line-height:1;
}
@media (max-width:640px){
  .ticket-full{grid-template-columns:1fr; gap:14px;}
}

/* ============ STEPS ============ */
.steps{
  display:grid; grid-template-columns:repeat(3,1fr); gap:30px;
  margin-top:50px;
}
.step{position:relative; padding-left:0;}
.step-num{
  font-family:var(--font-display);
  font-size:2.6rem;
  color:rgba(232,89,12,0.3);
  margin-bottom:10px;
}
@media (max-width:780px){.steps{grid-template-columns:1fr; gap:36px;}}

/* ============ CTA BAND ============ */
.cta-band{
  text-align:center;
  padding:90px 0;
}
.cta-band h2{margin-bottom:18px;}
.cta-band p{max-width:520px; margin:0 auto 30px; color:var(--char-soft); font-size:1.08rem;}

/* ============ FOOTER ============ */
footer{
  background:var(--char);
  color:var(--cream);
  padding:60px 0 30px;
}
.footer-grid{
  display:grid; grid-template-columns:1.4fr 1fr 1fr;
  gap:40px;
  padding-bottom:40px;
  border-bottom:1px solid rgba(255,248,240,0.12);
}
.footer-grid h4{
  font-family:var(--font-display);
  font-size:0.95rem;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--amber);
  margin-bottom:16px;
}
.footer-grid p, .footer-grid a{
  color:rgba(255,248,240,0.78);
  font-size:0.95rem;
  display:block;
  margin-bottom:10px;
}
.footer-grid a:hover{color:var(--amber);}
.foot-bottom{
  display:flex; justify-content:space-between; align-items:center;
  padding-top:22px;
  font-size:0.84rem;
  color:rgba(255,248,240,0.55);
  flex-wrap:wrap; gap:10px;
}
@media (max-width:780px){.footer-grid{grid-template-columns:1fr; gap:30px;}}

/* ============ FORMS ============ */
.form-card{
  background:var(--white);
  border-radius:var(--radius);
  padding:44px;
  box-shadow:0 20px 50px -24px rgba(43,24,16,0.3);
}
.form-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:22px;
}
.field{display:flex; flex-direction:column; gap:8px; margin-bottom:22px;}
.field.full{grid-column:1/-1;}
.field label{
  font-weight:700; font-size:0.92rem;
}
.field .hint{font-size:0.8rem; color:var(--char-soft); font-weight:400;}
input, select, textarea{
  font-family:var(--font-body);
  font-size:1rem;
  padding:13px 16px;
  border-radius:12px;
  border:2px solid rgba(43,24,16,0.14);
  background:var(--cream);
  color:var(--char);
  outline:none;
  transition:border-color .15s ease, background .15s ease;
}
input:focus, select:focus, textarea:focus{
  border-color:var(--orange);
  background:var(--white);
}
textarea{resize:vertical; min-height:130px; font-family:var(--font-body);}
@media (max-width:700px){.form-grid{grid-template-columns:1fr;}}

.form-note{
  display:flex; gap:12px; align-items:flex-start;
  background:var(--cream);
  border:1px dashed rgba(232,89,12,0.4);
  border-radius:14px;
  padding:16px 18px;
  font-size:0.9rem;
  color:var(--char-soft);
  margin-top:6px;
}

.form-success, .form-error{
  display:none;
  padding:18px 22px; border-radius:14px;
  font-weight:600; margin-bottom:24px;
}
.form-success{background:#E8F5E8; color:#2A6B2A;}
.form-error{background:#FBE6E2; color:var(--ember);}

/* ============ CONTACT PAGE ============ */
.contact-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:50px;
  align-items:start;
}
.contact-card{
  background:var(--white);
  border-radius:var(--radius);
  padding:34px;
  margin-bottom:20px;
  box-shadow:0 14px 30px -18px rgba(43,24,16,0.22);
}
.contact-card .eyebrow{margin-bottom:8px;}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr;}}

/* ============ PAGE HEADER (sub-pages) ============ */
.page-hero{
  padding:60px 0 80px;
  text-align:left;
}
.page-hero h1{font-size:clamp(2.2rem,4.6vw,3.4rem);}
.page-hero p{color:var(--char-soft); font-size:1.1rem; max-width:560px; margin-top:16px;}

/* ============ UTIL ============ */
.text-center{text-align:center;}
.mt-0{margin-top:0;}
.reveal{opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease;}
.reveal.in{opacity:1; transform:translateY(0);}
