/* ══════════════════════════════════════════════════════
   Les Bavards du Boulevard — Site vitrine
   Généré par Saucisse Purée (site-web-restaurant Skill)
   ══════════════════════════════════════════════════════ */

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

:root{
  --primary:#C8934A;
  --primary-dark:#A67832;
  --secondary:#5C7A5C;
  --secondary-dark:#486048;
  --accent:#A0522D;
  --bg:#F5EFE0;
  --bg-alt:#EDE5D3;
  --text:#2A1F14;
  --text-muted:rgba(42,31,20,0.55);
  --white:#FFFFFF;
  --border:rgba(42,31,20,0.1);
}

html{scroll-behavior:smooth;overflow-x:hidden}
body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;font-weight:400;line-height:1.6;overflow-x:hidden}

/* ═══ TYPOGRAPHY ═══ */
h1,h2,h3{font-family:'Playfair Display',serif;font-weight:700;line-height:1.15;letter-spacing:-.01em}
h1{font-size:clamp(32px,5vw,56px)}
h2{font-size:clamp(24px,3.5vw,40px);margin-bottom:24px}
h3{font-size:clamp(18px,2vw,24px)}
p{margin-bottom:16px}
a{color:var(--primary-dark);text-decoration:none;transition:color .25s}
a:hover{color:var(--accent)}

/* ═══ UTILITY ═══ */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:64px 0}
.eyebrow{font-family:'DM Sans',sans-serif;font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px;font-weight:500}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:3px;font-family:'DM Sans',sans-serif;font-size:.85rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;transition:background .25s,transform .2s,color .25s;cursor:pointer;border:none}
.btn-primary{background:var(--primary);color:var(--white)}
.btn-primary:hover{background:var(--primary-dark);color:var(--white);transform:translateY(-1px)}
.btn-outline{background:transparent;border:1px solid var(--text);color:var(--text)}
.btn-outline:hover{background:var(--text);color:var(--bg);transform:translateY(-1px)}
.btn-white{background:var(--white);color:var(--text)}
.btn-white:hover{background:var(--bg);color:var(--text);transform:translateY(-1px)}

/* ═══ NAV ═══ */
nav#main-nav{position:fixed;top:0;left:0;right:0;z-index:9999;display:flex;justify-content:space-between;align-items:center;padding:20px 40px;background:transparent;transition:background .4s,padding .3s,box-shadow .4s}
nav#main-nav.scrolled{background:rgba(245,239,224,.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:14px 40px;box-shadow:0 1px 0 var(--border)}
.nav-logo{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;color:var(--white);text-decoration:none;transition:color .3s}
nav#main-nav.scrolled .nav-logo{color:var(--text)}
.nav-links{display:flex;align-items:center;gap:24px}
.nav-link{font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.7);text-decoration:none;font-weight:500;transition:color .3s}
.nav-link:hover{color:var(--white)}
nav#main-nav.scrolled .nav-link{color:var(--text-muted)}
nav#main-nav.scrolled .nav-link:hover{color:var(--text)}
.nav-cta{background:var(--primary);color:var(--white);font-size:.78rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:10px 22px;border-radius:3px;text-decoration:none;transition:background .25s,transform .2s}
.nav-cta:hover{background:var(--primary-dark);color:var(--white);transform:translateY(-1px)}

/* Hamburger CSS-only */
.nav-toggle{display:none}
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:10px;cursor:pointer;-webkit-tap-highlight-color:transparent;z-index:10000}
.nav-burger span{display:block;width:20px;height:2px;background:var(--white);border-radius:1px;transition:transform .3s,opacity .3s}
nav#main-nav.scrolled .nav-burger span{background:var(--text)}
.nav-toggle:checked ~ .nav-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle:checked ~ .nav-burger span:nth-child(2){opacity:0}
.nav-toggle:checked ~ .nav-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ═══ HERO ═══ */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;background:var(--text);overflow:hidden}
.hero-bg{position:absolute;inset:0;background:var(--secondary);display:flex;align-items:center;justify-content:center}
.hero-bg .img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--text-muted)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(42,31,20,.85) 0%,rgba(42,31,20,.5) 40%,rgba(42,31,20,.2) 70%,transparent 100%);pointer-events:none}
.hero-content{position:relative;z-index:2;padding:0 40px 80px;max-width:700px}
.hero h1{color:var(--white);margin-bottom:16px}
.hero-tagline{font-size:clamp(16px,2vw,20px);color:rgba(245,239,224,.8);margin-bottom:32px;line-height:1.6;max-width:500px}
.hero-cta-wrap{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.hero-hours{display:inline-flex;align-items:center;gap:8px;color:rgba(245,239,224,.6);font-size:.8rem;letter-spacing:.05em}

/* ═══ CONCEPT ═══ */
.concept{background:var(--white)}
.concept-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.concept-text p{color:var(--text-muted);font-size:1rem;line-height:1.75}
.concept-text p:first-of-type{color:var(--text);font-size:1.05rem}
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.feature-card{padding:32px 24px;background:var(--bg);border-radius:4px;text-align:center}
.feature-icon{font-size:32px;margin-bottom:12px}
.feature-title{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:600;margin-bottom:8px}
.feature-desc{font-size:.85rem;color:var(--text-muted);line-height:1.5}

/* ═══ MENU PREVIEW ═══ */
.menu-preview{background:var(--bg)}
.menu-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;flex-wrap:wrap;gap:16px}
.menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.menu-card{background:var(--white);border-radius:4px;overflow:hidden;transition:transform .25s}
.menu-card:hover{transform:translateY(-4px)}
.menu-card-img{aspect-ratio:4/3;background:var(--bg-alt);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.85rem;padding:16px;text-align:center}
.menu-card-body{padding:20px}
.menu-card-name{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:600;margin-bottom:4px}
.menu-card-desc{font-size:.85rem;color:var(--text-muted);line-height:1.5}

/* ═══ GALLERY ═══ */
.gallery{background:var(--white)}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.gallery-item{aspect-ratio:1;background:var(--bg-alt);border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.8rem;text-align:center;padding:16px;overflow:hidden}

/* ═══ REVIEWS ═══ */
.reviews{background:var(--bg)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.review-card{background:var(--white);padding:32px;border-radius:4px}
.review-stars{color:var(--primary);font-size:1.1rem;margin-bottom:12px;letter-spacing:2px}
.review-text{font-size:.95rem;line-height:1.65;color:var(--text);font-style:italic;margin-bottom:16px}
.review-author{font-size:.8rem;color:var(--text-muted);font-weight:500}

/* ═══ LOCATION ═══ */
.location{background:var(--white)}
.location-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.location-map{width:100%;aspect-ratio:4/3;border-radius:8px;overflow:hidden;box-shadow:0 4px 24px rgba(42,31,20,.12)}
.map-iframe{width:100%;height:100%;border:none;display:block}
.location-info h3{margin-bottom:16px}
.location-detail{display:flex;gap:12px;margin-bottom:16px;align-items:flex-start}
.location-detail-icon{font-size:18px;min-width:24px;text-align:center}
.location-detail-text{font-size:.95rem;line-height:1.5}
.location-detail-text a{color:var(--primary-dark);text-decoration:underline;text-underline-offset:2px}
.hours-table{width:100%;border-collapse:collapse;margin-top:8px}
.hours-table td{padding:6px 0;font-size:.9rem;border-bottom:1px solid var(--border)}
.hours-table td:last-child{text-align:right;color:var(--text-muted)}

/* ═══ PRIVATISATION ═══ */
.privatisation{background:var(--bg-alt)}
.privatisation-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.privatisation-text p{color:var(--text-muted);font-size:1rem;line-height:1.75}
.privatisation-text p:first-of-type{color:var(--text);font-size:1.05rem}
.privatisation-img{border-radius:4px;overflow:hidden}
.privatisation-img img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:4px;display:block}

/* ═══ CTA SECTION ═══ */
.cta-section{background:var(--primary);padding:80px 0;text-align:center}
.cta-section h2{color:var(--white);margin-bottom:12px}
.cta-section p{color:rgba(255,255,255,.8);font-size:1.05rem;margin-bottom:32px}
.cta-section .btn-white{font-size:.9rem}

/* ═══ FOOTER ═══ */
footer{background:var(--text);color:rgba(245,239,224,.6);padding:56px 0 32px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;margin-bottom:40px}
.footer-brand{font-family:'Playfair Display',serif;font-size:20px;color:var(--bg);margin-bottom:12px}
.footer-desc{font-size:.88rem;line-height:1.6;max-width:300px}
.footer-title{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(245,239,224,.4);margin-bottom:16px;font-weight:500}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-links a{color:rgba(245,239,224,.6);font-size:.88rem;text-decoration:none;transition:color .25s}
.footer-links a:hover{color:var(--primary)}
.footer-bottom{border-top:1px solid rgba(245,239,224,.1);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-size:.78rem}
.footer-credit a{color:var(--primary);text-decoration:none}
.footer-credit a:hover{text-decoration:underline}

/* ═══ IMAGE PLACEHOLDER ═══ */
.img-placeholder{background:var(--bg-alt);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.85rem;text-align:center;padding:16px}

/* ═══ REVEAL ANIMATION ═══ */
.rv{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.rv.visible{opacity:1;transform:translateY(0)}
.rv-d1{transition-delay:.1s}.rv-d2{transition-delay:.2s}.rv-d3{transition-delay:.3s}.rv-d4{transition-delay:.4s}

/* ═══ CARTE PAGE ═══ */
.page-header{padding:140px 0 60px;background:var(--text);text-align:center}
.page-header h1{color:var(--white);margin-bottom:12px}
.page-header p{color:rgba(245,239,224,.6);font-size:1rem}
.carte-section{background:var(--white);padding:64px 0}
.carte-category{margin-bottom:48px}
.carte-category h2{font-size:clamp(20px,2.5vw,28px);padding-bottom:12px;border-bottom:2px solid var(--primary);display:inline-block;margin-bottom:24px}
.carte-item{display:flex;justify-content:space-between;align-items:baseline;padding:12px 0;border-bottom:1px solid var(--border)}
.carte-item-info{flex:1}
.carte-item-name{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:600}
.carte-item-desc{font-size:.85rem;color:var(--text-muted);margin-top:2px}
.carte-item-price{font-family:'DM Sans',sans-serif;font-size:1rem;font-weight:500;color:var(--primary-dark);white-space:nowrap;margin-left:24px}
.carte-item-badge{font-size:.75rem;margin-left:8px}
.carte-note{font-size:.88rem;color:var(--text-muted);font-style:italic;margin-top:48px;text-align:center}

/* ═══ CONTACT PAGE ═══ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.contact-map{width:100%;aspect-ratio:1;border-radius:8px;overflow:hidden;box-shadow:0 4px 24px rgba(42,31,20,.12)}
.contact-info{padding:24px 0}
.contact-block{margin-bottom:32px}
.contact-block h3{margin-bottom:12px;font-size:1.1rem}
.phone-link{font-size:1.3rem;font-weight:600;color:var(--primary-dark);text-decoration:none;display:inline-flex;align-items:center;gap:8px}
.phone-link:hover{color:var(--accent)}

/* ═══ MENTIONS LEGALES ═══ */
.legal-content{max-width:800px;margin:0 auto;padding:40px 24px}
.legal-content h2{font-size:1.3rem;margin-top:32px;margin-bottom:12px}
.legal-content p{font-size:.92rem;color:var(--text-muted);line-height:1.7}

/* ═══ RESPONSIVE ═══ */
@media(max-width:1024px){
  .concept-grid{grid-template-columns:1fr;gap:40px}
  .privatisation-grid{grid-template-columns:1fr;gap:40px}
  .location-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}

@media(max-width:768px){
  .section{padding:48px 0}
  nav#main-nav{padding:16px 20px}
  nav#main-nav.scrolled{padding:12px 20px}
  .nav-links{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(245,239,224,.98);flex-direction:column;justify-content:center;align-items:center;gap:32px;z-index:9999}
  .nav-toggle:checked ~ .nav-links{display:flex}
  .nav-toggle:checked ~ .nav-links .nav-link{color:var(--text);font-size:1rem}
  .nav-toggle:checked ~ .nav-burger span{background:var(--text)}
  .nav-burger{display:flex}
  .hero-content{padding:0 20px 56px}
  .features{grid-template-columns:1fr}
  .menu-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .reviews-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;text-align:center}
  .container{padding:0 20px}
}
