:root{
  --ink:#1D140D;
  --ink-soft:#261A11;
  --card:#2E2016;
  --terracotta:#C1531F;
  --terracotta-light:#DE6A2E;
  --gold:#E0A526;
  --green:#4C7A3F;
  --cream:#F3E9DA;
  --cream-dim:#C9B9A3;
  --line: rgba(243,233,218,0.14);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--ink);
  color:var(--cream);
  font-family:'Work Sans', sans-serif;
  line-height:1.6;
  overflow-x:hidden;
}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *{animation-duration:0.01ms !important; transition-duration:0.01ms !important;}
}
h1,h2,h3{
  font-family:'Anton', sans-serif;
  font-weight:400;
  text-transform:uppercase;
  line-height:1.02;
  letter-spacing:0.01em;
}
a{color:inherit; text-decoration:none;}
img{display:block; max-width:100%;}
button{font-family:inherit; cursor:pointer; border:none; background:none; color:inherit;}
.eyebrow{
  font-family:'Space Mono', monospace;
  font-size:0.72rem;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--gold);
}
.wrap{max-width:1180px; margin:0 auto; padding:0 32px;}
a:focus-visible, button:focus-visible{outline:2px solid var(--gold); outline-offset:3px;}

/* ---------- NAV ---------- */
header{
  position:fixed; top:0; left:0; right:0; z-index:200;
  padding:20px 0;
  transition:background 0.35s ease, padding 0.35s ease, border-color .35s ease;
  border-bottom:1px solid transparent;
}
header.scrolled{
  background:rgba(29,20,13,0.94);
  backdrop-filter:blur(10px);
  padding:13px 0;
  border-bottom:1px solid var(--line);
}
nav{display:flex; align-items:center; justify-content:space-between;}
.logo{
  font-family:'Anton', sans-serif;
  font-size:1.5rem;
  display:flex; flex-direction:column; line-height:1;
}
.logo span.sub{
  font-family:'Space Mono', monospace;
  font-size:0.6rem;
  letter-spacing:0.14em;
  color:var(--gold);
  text-transform:uppercase;
  margin-top:3px;
}
.logo span.stars{
  font-size:0.6rem; letter-spacing:0.2em; color:var(--terracotta-light); margin-top:2px;
}
.nav-links{display:flex; align-items:center; gap:34px;}
.nav-links a{font-size:0.86rem; color:var(--cream-dim); transition:color 0.25s ease;}
.nav-links a:hover{color:var(--cream);}
.cart-btn{
  position:relative;
  display:flex; align-items:center; gap:8px;
  background:var(--terracotta); color:var(--cream);
  padding:11px 18px; border-radius:2px;
  font-family:'Space Mono', monospace; font-size:0.78rem;
  transition:background 0.25s ease, transform 0.25s ease;
}
.cart-btn:hover{background:var(--terracotta-light); transform:translateY(-1px);}
.cart-count{
  background:var(--gold); color:var(--ink);
  border-radius:50%; width:20px; height:20px;
  display:flex; align-items:center; justify-content:center;
  font-size:0.7rem; font-weight:700;
}
.burger{display:none; flex-direction:column; gap:5px; padding:6px;}
.burger span{width:22px; height:2px; background:var(--cream);}

/* ---------- HERO ---------- */
.hero{
  position:relative; min-height:100vh;
  display:flex; align-items:center;
  padding-top:90px; padding-bottom:60px;
}
.hero-bg{
  position:absolute; inset:0;
  background-image:
    linear-gradient(115deg, rgba(29,20,13,0.94) 15%, rgba(29,20,13,0.55) 55%, rgba(29,20,13,0.85) 100%),
    url('../img/food_fish.jpg');
  background-size:cover; background-position:70% 40%;
  filter:saturate(1.05);
}
.hero-content{position:relative; z-index:2; max-width:640px;}
.quality-badge{
  position:absolute; right:48px; bottom:48px; z-index:3;
  width:112px; height:112px; border-radius:50%;
  background:var(--ink); border:3px solid var(--gold);
  display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center;
  box-shadow:0 10px 26px rgba(0,0,0,0.45);
}
.quality-badge .qb-num{font-family:'Anton', sans-serif; font-size:1.6rem; color:var(--gold); line-height:1;}
.quality-badge .qb-label{font-family:'Space Mono', monospace; font-size:0.62rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--cream); margin-top:4px;}
.quality-badge .qb-sub{font-family:'Space Mono', monospace; font-size:0.5rem; color:var(--terracotta-light); margin-top:2px;}
@media (max-width:900px){
  .quality-badge{display:none;}
}
.hero .eyebrow{display:flex; align-items:center; gap:10px; margin-bottom:20px;}
.hero .eyebrow::before{content:''; width:26px; height:1px; background:var(--gold);}
.hero h1{
  font-size:clamp(2.6rem, 6.4vw, 5.2rem);
  color:var(--cream);
}
.hero h1 .accent{color:var(--terracotta-light);}
.hero p.lead{
  margin-top:24px; max-width:46ch; color:var(--cream-dim); font-size:1.05rem;
}
.hero-actions{margin-top:38px; display:flex; gap:16px; flex-wrap:wrap;}
.btn{
  font-family:'Space Mono', monospace; font-size:0.8rem; letter-spacing:0.03em;
  padding:15px 28px; border-radius:2px;
  display:inline-flex; align-items:center; gap:10px;
  transition:transform 0.25s ease, background 0.25s ease, border-color .25s ease;
}
.btn-primary{background:var(--terracotta); color:var(--cream);}
.btn-primary:hover{background:var(--terracotta-light); transform:translateY(-2px);}
.btn-ghost{border:1px solid var(--line); color:var(--cream);}
.btn-ghost:hover{border-color:var(--gold); transform:translateY(-2px);}
.hero-tags{
  margin-top:44px; display:flex; gap:28px; flex-wrap:wrap;
  padding-top:26px; border-top:1px solid var(--line);
}
.hero-tags div{font-family:'Space Mono', monospace; font-size:0.72rem; color:var(--cream-dim); display:flex; align-items:center; gap:8px;}
.hero-tags div::before{content:'●'; color:var(--green); font-size:0.5rem;}

/* ---------- SECTION GENERIC ---------- */
section{padding:110px 0;}
.section-head{max-width:640px; margin-bottom:56px;}
.section-head h2{font-size:clamp(2rem, 3.6vw, 3rem); margin-top:14px;}
.section-head p{color:var(--cream-dim); margin-top:16px; max-width:52ch;}

.divider{display:flex; align-items:center; justify-content:center; opacity:0.6;}
.divider svg{width:200px; height:14px;}

/* ---------- MENU / ORDER ---------- */
.menu-section{background:var(--ink-soft);}
.menu-tabs{display:flex; gap:10px; margin-bottom:40px; flex-wrap:wrap;}
.menu-tab{
  font-family:'Space Mono', monospace; font-size:0.76rem;
  padding:10px 18px; border:1px solid var(--line); border-radius:2px;
  color:var(--cream-dim); transition:all 0.25s ease;
}
.menu-tab.active, .menu-tab:hover{border-color:var(--gold); color:var(--gold);}

.menu-list{display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line);}
.menu-dish{
  background:var(--ink-soft); padding:28px; display:flex; gap:18px; align-items:flex-start;
}
.menu-dish img{width:84px; height:84px; object-fit:cover; border-radius:3px; flex-shrink:0;}
.menu-dish-info{flex:1;}
.menu-dish-info h3{font-family:'Work Sans',sans-serif; text-transform:none; font-size:1.05rem; font-weight:600; letter-spacing:0; margin-bottom:6px;}
.menu-dish-info p{color:var(--cream-dim); font-size:0.85rem; margin-bottom:14px;}
.menu-dish-bottom{display:flex; align-items:center; justify-content:space-between;}
.menu-dish-price{font-family:'Space Mono', monospace; color:var(--gold); font-size:0.95rem;}
.add-btn{
  font-family:'Space Mono', monospace; font-size:0.72rem;
  background:var(--terracotta); color:var(--cream);
  padding:8px 14px; border-radius:2px;
  transition:background 0.2s ease, transform 0.2s ease;
}
.add-btn:hover{background:var(--terracotta-light); transform:translateY(-1px);}
.add-btn.added{background:var(--green);}
.menu-dish-price-tbd{color:var(--cream-dim); font-size:0.8rem; font-style:italic;}
.add-btn-ghost{background:none; border:1px solid var(--line); color:var(--cream);}
.add-btn-ghost:hover{border-color:var(--gold); color:var(--gold); background:none;}

/* ---------- TRAITEUR ---------- */
.traiteur-section{background:var(--terracotta); color:var(--cream);}
.traiteur-inner{
  display:flex; align-items:center; justify-content:space-between; gap:36px; flex-wrap:wrap;
}
.traiteur-inner .eyebrow{color:var(--ink);}
.traiteur-inner h2{font-size:clamp(1.8rem, 3vw, 2.6rem); margin-top:10px;}
.traiteur-inner p{margin-top:16px; max-width:56ch; color:rgba(243,233,218,0.9);}
.traiteur-inner .btn-primary{background:var(--ink); color:var(--cream); flex-shrink:0;}
.traiteur-inner .btn-primary:hover{background:var(--ink-soft);}

/* ---------- CART DRAWER ---------- */
.cart-overlay{
  position:fixed; inset:0; background:rgba(10,7,4,0.55);
  z-index:300; opacity:0; pointer-events:none; transition:opacity 0.3s ease;
}
.cart-overlay.open{opacity:1; pointer-events:auto;}
.cart-drawer{
  position:fixed; top:0; right:0; height:100vh; width:min(440px, 92vw);
  background:var(--ink-soft); z-index:310;
  transform:translateX(100%); transition:transform 0.4s ease;
  display:flex; flex-direction:column;
  border-left:1px solid var(--line);
}
.cart-drawer.open{transform:translateX(0);}
.cart-header{
  padding:26px 28px; border-bottom:1px solid var(--line);
  display:flex; align-items:center; justify-content:space-between;
}
.cart-header h3{font-size:1.3rem;}
.cart-close{font-size:1.4rem; color:var(--cream-dim); line-height:1;}
.cart-close:hover{color:var(--cream);}
.cart-items{flex:1; overflow-y:auto; padding:20px 28px;}
.cart-empty{color:var(--cream-dim); font-size:0.9rem; text-align:center; padding:60px 0;}
.cart-item{
  display:flex; gap:14px; padding:16px 0; border-bottom:1px solid var(--line);
}
.cart-item img{width:56px; height:56px; object-fit:cover; border-radius:3px; flex-shrink:0;}
.cart-item-info{flex:1;}
.cart-item-info h4{font-size:0.92rem; font-weight:500; margin-bottom:6px;}
.cart-item-row{display:flex; align-items:center; justify-content:space-between;}
.qty-control{display:flex; align-items:center; gap:10px; font-family:'Space Mono', monospace;}
.qty-control button{
  width:22px; height:22px; border:1px solid var(--line); border-radius:2px; font-size:0.85rem;
  display:flex; align-items:center; justify-content:center; color:var(--cream);
}
.qty-control button:hover{border-color:var(--gold);}
.cart-item-price{font-family:'Space Mono', monospace; color:var(--gold); font-size:0.85rem;}
.remove-btn{color:var(--cream-dim); font-size:0.72rem; font-family:'Space Mono', monospace; margin-top:6px;}
.remove-btn:hover{color:var(--terracotta-light);}
.cart-footer{padding:24px 28px; border-top:1px solid var(--line);}
.cart-total-row{display:flex; justify-content:space-between; margin-bottom:18px; font-family:'Space Mono', monospace;}
.cart-total-row strong{color:var(--gold); font-size:1.15rem;}
.cart-footer .btn{width:100%; justify-content:center;}

/* ---------- CHECKOUT MODAL ---------- */
.modal-overlay{
  position:fixed; inset:0; background:rgba(10,7,4,0.7);
  z-index:400; display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none; transition:opacity 0.3s ease; padding:20px;
}
.modal-overlay.open{opacity:1; pointer-events:auto;}
.modal{
  background:var(--ink-soft); border:1px solid var(--line); border-radius:4px;
  max-width:460px; width:100%; padding:36px; max-height:88vh; overflow-y:auto;
  position:relative;
}
.modal h3{font-size:1.4rem; margin-bottom:6px;}
.modal .eyebrow{margin-bottom:16px; display:block;}
.field{margin-bottom:16px;}
.field label{display:block; font-family:'Space Mono', monospace; font-size:0.7rem; letter-spacing:0.06em; color:var(--cream-dim); text-transform:uppercase; margin-bottom:8px;}
.field input, .field select{
  width:100%; background:var(--card); border:1px solid var(--line); color:var(--cream);
  padding:12px 14px; border-radius:2px; font-family:'Work Sans', sans-serif; font-size:0.92rem;
}
.field input:focus, .field select:focus{outline:none; border-color:var(--gold);}
.mode-toggle{display:flex; gap:10px; margin-bottom:20px;}
.mode-toggle button{
  flex:1; padding:12px; border:1px solid var(--line); border-radius:2px;
  font-family:'Space Mono', monospace; font-size:0.76rem; color:var(--cream-dim);
}
.mode-toggle button.active{border-color:var(--gold); color:var(--gold); background:rgba(224,165,38,0.08);}
.modal .btn{width:100%; justify-content:center; margin-top:8px;}
.modal-close{position:absolute; top:20px; right:24px; font-size:1.3rem; color:var(--cream-dim);}
.form-error{
  background:rgba(193,83,31,0.14); border:1px solid var(--terracotta);
  color:var(--cream); font-size:0.82rem; padding:12px 14px; border-radius:3px; margin-bottom:16px;
}
.confirm-view{text-align:center; padding:20px 0;}
.confirm-icon{
  width:60px; height:60px; border-radius:50%; background:var(--green);
  display:flex; align-items:center; justify-content:center; margin:0 auto 22px;
  font-size:1.6rem;
}
.confirm-note{
  margin-top:18px; padding:14px; background:var(--card); border-radius:3px;
  font-size:0.8rem; color:var(--cream-dim); text-align:left;
}

/* ---------- COMMENT COMMANDER ---------- */
.steps-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:32px;}
.step-number{
  width:40px; height:40px; border-radius:50%; background:var(--terracotta); color:var(--cream);
  display:flex; align-items:center; justify-content:center;
  font-family:'Anton', sans-serif; font-size:1.1rem; margin-bottom:16px;
}
.step-card h3{font-family:'Work Sans',sans-serif; text-transform:none; font-size:1.05rem; font-weight:600; letter-spacing:0; margin-bottom:8px;}
.step-card p{color:var(--cream-dim); font-size:0.9rem;}

/* ---------- INFO ---------- */
.info-section{background:var(--ink-soft);}
.info-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:40px;}
.info-card h3{font-family:'Work Sans',sans-serif; text-transform:none; font-size:1.3rem; font-weight:600; letter-spacing:0; margin-bottom:14px;}
.info-card-title-icon{display:flex; align-items:center; gap:8px;}
.info-card-title-icon svg{width:20px; height:20px; color:var(--terracotta); flex-shrink:0;}
.info-card p, .info-card address{color:var(--cream-dim); font-style:normal; font-size:0.94rem;}
.hours-row{display:flex; justify-content:space-between; padding:8px 0; border-bottom:1px dashed var(--line); font-size:0.88rem;}
.hours-row:last-child{border-bottom:none;}
.hours-row span:last-child{font-family:'Space Mono', monospace; color:var(--cream-dim);}

footer{border-top:1px solid var(--line); padding:44px 0 30px;}
.footer-row{display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:20px;}
.footer-links{display:flex; gap:26px;}
.footer-links a{color:var(--cream-dim); font-size:0.85rem;}
.footer-links a:hover{color:var(--gold);}
.footer-bottom{margin-top:26px; padding-top:20px; border-top:1px solid var(--line); display:flex; justify-content:space-between; color:var(--cream-dim); font-size:0.76rem; font-family:'Space Mono', monospace; flex-wrap:wrap; gap:10px;}

.reveal{opacity:0; transform:translateY(22px); transition:opacity 0.7s ease, transform 0.7s ease;}
.reveal.in{opacity:1; transform:translateY(0);}

@media (max-width:900px){
  .menu-list{grid-template-columns:1fr;}
  .info-grid{grid-template-columns:1fr; gap:36px;}
  .steps-grid{grid-template-columns:1fr 1fr; gap:28px;}
  .nav-links{
    position:fixed; top:0; right:0; height:100vh; width:min(78vw,320px);
    background:var(--ink-soft); flex-direction:column; justify-content:center;
    align-items:flex-start; padding:0 40px; gap:26px;
    transform:translateX(100%); transition:transform 0.35s ease;
    border-left:1px solid var(--line); z-index:250;
  }
  .nav-links.open{transform:translateX(0);}
  .burger{display:flex;}
}
@media (max-width:600px){
  section{padding:76px 0;}
  .wrap{padding:0 20px;}
  .menu-dish{flex-direction:column;}
  .menu-dish img{width:100%; height:150px;}
  .steps-grid{grid-template-columns:1fr;}
}

/* ---------- WHATSAPP FAB ---------- */
.whatsapp-fab{
  position:fixed; right:22px; bottom:22px; z-index:260;
  width:56px; height:56px; border-radius:50%;
  background:#25D366; color:#0b3d1f;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 22px rgba(0,0,0,0.35);
  transition:transform 0.2s ease;
}
.whatsapp-fab:hover{transform:scale(1.08);}
