/* style.css — Rapido Pizza (fond noir, boutons beige, glow blanc sur les cartes) */
:root{
  --bordeaux:#7b1e1e;
  --doré:#d8b676;
  --beige:#f5f1e9;
  --texte:#1f1f1f;
  --muted:#9a9a9a;
  --card-bg: rgba(255,255,255,0.06);
  --radius:12px;
  --shadow: 0 8px 30px rgba(0,0,0,0.35);
}

/* Reset */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family: "Open Sans", system-ui, Arial, sans-serif;
  color: #fff;
  background: #000; /* ✅ Fond noir uniforme */
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* container */
.container{max-width:1100px;margin:0 auto;padding:18px}

/* header */
.site-header{
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(6px);
  position:sticky;top:0;z-index:60;
  box-shadow:var(--shadow)
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;gap:12px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:12px}
.brand-logo{width:56px;height:56px;border-radius:12px;background:var(--bordeaux);display:flex;align-items:center;justify-content:center;font-weight:900;color:#fff;font-size:22px;box-shadow:0 6px 20px rgba(123,30,30,0.3)}
.brand-title{font-weight:800;color:var(--doré);font-family:"Playfair Display",serif}
.nav a{color:#fff;text-decoration:none;margin-right:14px;font-weight:700}
.nav a:hover{color:var(--doré)}
.cart-btn{background:var(--beige);color:var(--bordeaux);padding:8px 14px;border-radius:999px;border:0;font-weight:800;cursor:pointer;transition:transform .12s}

/* splash */
.splash{height:78vh;display:flex;align-items:center;justify-content:center;text-align:center;position:relative}
.splash::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0.35),rgba(0,0,0,0.65))}
.splash-content{position:relative;z-index:2;color:#fff;padding:24px;max-width:920px}
.splash h1{font-family:"Playfair Display",serif;font-size:48px;color:var(--doré);text-shadow:0 6px 30px rgba(0,0,0,0.55);margin-bottom:12px}
.rotating-text{height:26px;overflow:hidden;margin-bottom:10px}
.rotating-text span{display:block;animation:rotateWords 12s linear infinite}
@keyframes rotateWords{
  0%,20%{transform:translateY(0)}
  25%,45%{transform:translateY(-100%)}
  50%,70%{transform:translateY(-200%)}
  75%,95%{transform:translateY(-300%)}
  100%{transform:translateY(0)}
}
.splash p.lead{color:#f3f3f3;margin-bottom:18px;font-size:16px}
.btn-enter{background:var(--beige);color:var(--bordeaux);padding:12px 20px;border-radius:999px;border:0;font-weight:800;cursor:pointer;transition:transform .15s}
.btn-enter:hover{transform:translateY(-3px);background:var(--doré);color:#fff}

/* sections */
.section{background:var(--card-bg);border-radius:12px;padding:20px;margin:20px 0;box-shadow:var(--shadow)}
.section h2{color:var(--doré);font-family:"Playfair Display",serif;margin-bottom:12px}

/* search */
.search-container{display:flex;justify-content:center;margin-bottom:14px}
#search{width:100%;max-width:520px;padding:12px 14px 12px 42px;border-radius:999px;border:none;background:rgba(255,255,255,0.06);color:#fff;font-size:15px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23d8b676' viewBox='0 0 24 24'%3E%3Cpath d='M15.5 14h-.79l-.28-.27A6.471 6.471 0 0016 9.5 6.5 6.5 0 109.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l4.25 4.25a1 1 0 001.42-1.42L15.5 14zM5 9.5C5 7.01 7.01 5 9.5 5S14 7.01 14 9.5 11.99 14 9.5 14 5 11.99 5 9.5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:12px center;background-size:18px;padding-left:44px}
#search::placeholder{color:rgba(255,255,255,0.7)}

/* products list */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px}
.card{
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02));
  border-radius:12px;padding:16px;border:1px solid rgba(255,255,255,0.04);
  transition: transform .18s ease, box-shadow .3s ease;
}
.card:hover{
  transform: translateY(-6px);
  box-shadow: 
    0 10px 25px rgba(255,255,255,0.15),
    0 0 20px rgba(255,255,255,0.08),
    0 0 10px rgba(255,255,255,0.06);
}
.card h3{color:var(--doré);margin-bottom:6px}
.card .desc{color:rgba(255,255,255,0.8);margin-bottom:10px;font-size:14px}
.row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.select-size{padding:8px;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:rgba(0,0,0,0.45);color:#fff}
.qty{width:70px;padding:8px;border-radius:8px;background:rgba(0,0,0,0.45);color:#fff;border:1px solid rgba(255,255,255,0.06)}
.btn-add{background:var(--beige);color:var(--bordeaux);padding:9px 12px;border-radius:10px;border:0;font-weight:800;cursor:pointer;transition:transform .12s}
.btn-add:hover{transform:translateY(-3px);background:var(--doré);color:#fff}

/* pizza image area (only on menu page) */
.card .pimg{width:100%;height:180px;object-fit:cover;border-radius:10px;margin-bottom:10px;overflow:hidden}

/* modal (cart) */
.modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.7);align-items:center;justify-content:center;z-index:500;padding:18px}
.modal-panel{background:linear-gradient(180deg,#141414,#0f0f0f);border-radius:12px;width:100%;max-width:680px;color:#fff;padding:16px;box-shadow:var(--shadow)}
.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.modal-body{max-height:50vh;overflow:auto}
.cart-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.05)}
.cart-row .meta{color:rgba(255,255,255,0.85)}
.input{width:100%;padding:10px;border-radius:8px;background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.04);color:#fff}
.form-row{display:flex;gap:10px;flex-wrap:wrap}
.form-row .half{flex:1;min-width:140px}

/* checkout button in modal */
.checkout-btn{background:var(--beige);color:var(--bordeaux);padding:12px;border-radius:10px;border:0;font-weight:800;width:100%;margin-top:12px;cursor:pointer}
.checkout-btn:hover{background:var(--doré);color:#fff}

/* contact page */
.contact-grid{display:grid;grid-template-columns:1fr 420px;gap:18px}
.map{width:100%;height:320px;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,0.05)}

/* small screens */
@media (max-width:900px){
  .contact-grid{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
  .splash h1{font-size:36px}
}



/* =====================
   Chic Dark Overrides
   (non-breaking; keeps app.js + index intact)
   ===================== */

/* Fonts */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700&family=Poppins:wght@300;400;500;600&display=swap');

html, body {
  background:#000;
  color:#eaeaea;
  font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height:1.6;
}

/* Containers */
.container{max-width:1200px;margin:0 auto;padding:0 20px}

/* Header / Nav */
.site-header{position:sticky;top:0;z-index:50;background:rgba(0,0,0,0.7);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid rgba(255,255,255,0.06)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 10px}
.brand-title{font-family:'Playfair Display', serif; letter-spacing:.3px}
.nav a{
  position:relative;
  color:#f0f0f0;
  text-decoration:none;
  margin:0 12px;
  font-weight:500;
  letter-spacing:.4px;
  transition:color .25s ease;
}
.nav a:hover{ color:#d8b676 }
.nav a::after{
  content:"";
  position:absolute;
  left:0; bottom:-6px;
  width:0%;
  height:2px;
  background:linear-gradient(90deg, #d8b676, rgba(216,182,118,.15));
  transition:width .25s ease;
}
.nav a:hover::after{ width:100% }

/* Buttons */
button, .btn{
  background:transparent;
  color:#f5f1e9;
  border:1px solid rgba(216,182,118,.45);
  border-radius:999px;
  padding:10px 16px;
  font-weight:600;
  letter-spacing:.3px;
  cursor:pointer;
  transition: transform .12s ease, box-shadow .2s ease, border-color .2s ease;
}
button:hover, .btn:hover{
  transform: translateY(-1px);
  border-color:#d8b676;
  box-shadow:0 6px 24px rgba(216,182,118,.18);
}

/* Cards (menu items) */
.card{
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.06);
  border-radius:14px;
  overflow:hidden;
  transition: transform .18s ease, box-shadow .25s ease, border-color .25s ease;
}
.card:hover{
  transform: translateY(-2px);
  border-color: rgba(216,182,118,.35);
  box-shadow: 0 18px 40px rgba(0,0,0,.45);
}
.card .title{font-family:'Playfair Display', serif; font-weight:600; letter-spacing:.2px}

/* Contact form */
.contact-wrap{max-width:820px;margin:40px auto;padding:28px}
.contact-card{
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  padding:28px;
  box-shadow: 0 10px 40px rgba(0,0,0,.35);
}
.contact-title{font-family:'Playfair Display', serif; font-size:28px; margin-bottom:12px; color:#f3f3f3}
.contact-sub{color:#b7b7b7; margin-bottom:20px}
.input{
  width:100%;
  background:rgba(255,255,255,.02);
  color:#f0f0f0;
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  padding:12px 14px;
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.input::placeholder{color:#a7a7a7}
.input:focus{
  border-color:#d8b676;
  box-shadow:0 0 0 4px rgba(216,182,118,.12);
  background:rgba(255,255,255,.04);
}
.form-row{display:flex; gap:12px}
.form-row .input{flex:1}

/* Cart modal */
#cart-modal, #checkout-modal{
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(6px);
}
.modal-content{
  background:linear-gradient(180deg, rgba(24,24,24,.95), rgba(16,16,16,.95));
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  color:#eee;
}
.cart-row{
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 0; border-bottom:1px dashed rgba(255,255,255,.08);
}
.qty-dec, .qty-inc, .qty-del{
  background:transparent;
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  padding:6px 10px;
  margin-left:6px;
  color:#f3f3f3;
}
.qty-del{ border-color: rgba(203, 66, 66, .6) }
.cart-total{ font-family:'Playfair Display', serif; font-size:18px; color:#f6f0e5 }

.checkout-btn{
  display:inline-block;
  width:100%;
  background: #111;
  color:#f5f1e9;
  border:1px solid #d8b676;
  border-radius:14px;
  padding:12px 16px;
  font-weight:700;
  letter-spacing:.4px;
  transition: transform .12s ease, box-shadow .2s ease;
}
.checkout-btn:hover{ transform: translateY(-1px); box-shadow:0 10px 30px rgba(216,182,118,.2) }

/* Badges, small accents */
.badge{
  display:inline-block;
  border:1px solid rgba(216,182,118,.45);
  color:#f5f1e9;
  border-radius:999px;
  padding:4px 10px;
  font-size:12px;
  letter-spacing:.3px;
}

/* Subtle separators */
.hr{ height:1px; background: linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,.12), rgba(255,255,255,0)); margin:24px 0 }



/* v12 fix: preserve header spacing after removing brand */
.brand-spacer{ width:260px; height:56px }

/* v13: center nav links while keeping cart at right */
.header-inner{ position:relative }
.nav{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  white-space:nowrap;
}

/* v13: medium golden hover for menu cards */
.grid .card{
  transition: transform .22s ease, box-shadow .25s ease, border-color .25s ease;
}
.grid .card:hover{
  transform: translateY(-6px);
  border-color: rgba(216,182,118,.48);
  box-shadow:
    0 12px 26px rgba(0,0,0,.55),
    0 0 14px rgba(216,182,118,.42);
}

/* v13: keep left spacing where brand used to be */
.brand-spacer{ width:260px; height:56px }



/* === Bouton Appeler la pizzeria === */
.call-us { text-align:center; margin: 40px 0; }
.call-button {
  display:inline-block; padding:14px 30px;
  background: linear-gradient(90deg, #d8b676, #c9a253);
  color:#0e0e0e; font-size:20px; font-weight:700;
  border-radius:50px; text-decoration:none;
  box-shadow:0 8px 25px rgba(216,182,118,0.3);
  transition: transform .2s ease, box-shadow .25s ease;
}
.call-button:hover { transform: translateY(-3px); box-shadow:0 12px 30px rgba(216,182,118,0.45); }

/* === Smooth entrance for call button === */
.reveal-call{ opacity:0; transform: translateY(8px); animation: callFadeUp .6s ease .15s forwards; }
@keyframes callFadeUp {
  from { opacity:0; transform: translateY(8px); }
  to   { opacity:1; transform: translateY(0); }
}

/* === Mobile nav tweaks v16 (liens alignés à gauche, panier à droite) === */
@media (max-width: 640px){
  .header-inner{ position:relative; }
  .nav{
    position:absolute;
    left:16px; right:auto;
    transform:none;          /* override desktop centering */
    white-space:nowrap;
  }
  .open-cart{                 /* keep cart at right */
    position:absolute; right:12px; top:50%;
    transform: translateY(-50%);
  }
  .brand-spacer{ width:0 !important; }
}


/* --- Avis (carrousel) --- */
.avis{
  padding: 48px 18px;
  background: #0e0e0e;
  color: var(--beige);
  border-top: 1px solid rgba(255,255,255,0.06);
}
.avis h2{
  font-size: clamp(22px, 3vw, 28px);
  text-align:center;
  margin-bottom: 18px;
  letter-spacing: .3px;
}
.avis-rotator{
  position: relative;
  max-width: 900px;
  margin: 0 auto;
  min-height: 110px; /* réserve l’espace pour éviter les sauts */
}
.avis-item{
  position:absolute;
  inset:0;
  opacity:0;
  transform: translateY(6px);
  transition: opacity .35s ease, transform .35s ease;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding: 10px 14px;
}
.avis-item blockquote{
  font-size: clamp(16px, 2.2vw, 20px);
  font-style: italic;
  line-height: 1.5;
}
.avis-item figcaption{
  margin-top:8px;
  font-size: 14px;
  opacity: .85;
}
.avis-item.active{
  opacity:1;
  transform: translateY(0);
}
.avis-source{
  text-align:center;
  margin-top: 16px;
  font-size: 13px;
  opacity:.8;
}
.avis-source a{ color: var(--doré); text-underline-offset:2px }



/* Group headings inside the product grid */
.menu-group-title{
  grid-column: 1 / -1;
  margin-top: 1cm;      /* ~1 cm d'espace avant chaque groupe */
  margin-bottom: 12px;
  text-align: center;
  font-weight: 800;
  letter-spacing: .3px;
  font-size: clamp(20px, 2.6vw, 24px);
  color: var(--beige);
}
.grid > .menu-group-title:first-child{ margin-top: 0 }  /* pas d'espace au tout début */


/* Cart enhancements */
.cart-info{
  background: rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.10);
  padding:10px 12px;
  border-radius:10px;
  margin-bottom:10px;
  font-size:14px;
  line-height:1.35;
}
.cart-left{display:flex;gap:10px;align-items:center;}
.cart-thumb{
  width:54px;height:54px;object-fit:cover;border-radius:8px;
  border:1px solid rgba(255,255,255,0.12);
  flex:0 0 auto;
}
.cart-right{min-width:170px;text-align:right;}
.qty-controls{display:flex;align-items:center;justify-content:flex-end;gap:6px;}
.cart-qty{
  width:52px;text-align:center;padding:6px;border-radius:8px;
  background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.12);color:#fff;
}
.qty-del{background:transparent;color:#fff;border:none;font-weight:bold;cursor:pointer;margin-left:4px;}
.line-total{margin-top:6px;font-weight:800;color:var(--doré);}

/* Payment methods */
.payment-methods{display:flex;gap:12px;flex-wrap:wrap;margin-top:6px;}
.payment-methods label{display:flex;gap:6px;align-items:center;font-size:15px;}

@media (max-width:600px){
  .modal-panel{width:96%;padding:12px;}
  .cart-row{flex-direction:column;align-items:flex-start;gap:8px;}
  .cart-right{width:100%;text-align:left;display:flex;justify-content:space-between;align-items:center;}
  .qty-controls{justify-content:flex-start;}
  .line-total{margin-top:0;}
  .payment-methods{flex-direction:column;gap:8px;}
}
