  :root{
    --ink:#2B1D14;
    --paper:#FBF3E7;
    --stone:#C17F3E;
    --grey:#8A6F58;
    --line: rgba(43,29,20,0.14);
    --line-on-ink: rgba(251,243,231,0.18);
    --max: 1240px;
  }
  *{box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    margin:0; background:var(--paper); color:var(--ink);
    font-family:'Inter', sans-serif; font-size:16px; line-height:1.6;
    -webkit-font-smoothing:antialiased;
  }
  h1,h2,h3{ font-family:'Fraunces', serif; font-weight:500; line-height:1.08; margin:0; letter-spacing:-0.01em; }
  p{margin:0;}
  a{color:inherit; text-decoration:none;}
  img{max-width:100%; display:block;}
  .wrap{max-width:var(--max); margin:0 auto; padding:0 32px;}
  .eyebrow{ font-family:'IBM Plex Mono', monospace; font-size:12px; letter-spacing:0.16em; text-transform:uppercase; color:var(--grey); }

  .btn{
    display:inline-flex; align-items:center; gap:10px;
    font-family:'IBM Plex Mono', monospace; font-size:12.5px; letter-spacing:0.08em; text-transform:uppercase;
    padding:15px 26px; border:1px solid currentColor; transition:background .2s ease, color .2s ease;
  }
  .btn-ink{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
  .btn-ink:hover{ background:transparent; color:var(--ink); }
  .btn-line{ color:var(--ink); }
  .btn-line:hover{ background:var(--ink); color:var(--paper); }
  .btn-line-on-photo{ color:#fff; border-color:rgba(255,255,255,0.7); }
  .btn-line-on-photo:hover{ background:#fff; color:var(--ink); }

  /* ---------- NAV (épuré, logo gauche / liens droite) ---------- */
  header.site-nav{
    position:fixed; top:0; left:0; right:0; z-index:60;
    padding:26px 32px; display:flex; align-items:center; justify-content:space-between;
    color:#fff; mix-blend-mode:normal;
  }
  header.site-nav.scrolled{ background:rgba(255,255,255,0.96); color:var(--ink); border-bottom:1px solid var(--line); backdrop-filter:blur(6px); }
  .logo{ font-family:'Fraunces', serif; font-weight:600; font-size:19px; letter-spacing:0.02em; }
  nav.links{ display:flex; align-items:center; gap:34px; }
  nav.links a{ font-family:'IBM Plex Mono', monospace; font-size:11.5px; letter-spacing:0.12em; text-transform:uppercase; }
  nav.links button.dropdown-toggle{
    font-family:'IBM Plex Mono', monospace; font-size:11.5px; letter-spacing:0.12em; text-transform:uppercase;
    background:none; border:none; color:inherit; cursor:pointer; padding:0; margin:0;
  }
  .has-dropdown{ position:relative; }
  .dropdown{
    position:absolute; top:calc(100% + 18px); left:50%; transform:translateX(-50%);
    background:var(--paper); color:var(--ink); border:1px solid var(--line);
    display:flex; flex-direction:column; min-width:180px;
    opacity:0; visibility:hidden; transition:opacity .18s ease;
  }
  .has-dropdown:hover .dropdown, .has-dropdown.open .dropdown{ opacity:1; visibility:visible; }
  .dropdown a{ padding:14px 18px; border-bottom:1px solid var(--line); font-size:11px; }
  .dropdown a:last-child{ border-bottom:none; }
  .dropdown a:hover{ background:#f5f3ee; }
  .nav-toggle{ display:none; background:none; border:none; color:inherit; font-size:22px; cursor:pointer; }

  @media (max-width:820px){
    nav.links{
      position:fixed; top:0; right:0; bottom:0; width:78%; max-width:320px;
      background:var(--ink); color:#fff; flex-direction:column; align-items:flex-start; gap:0;
      padding:100px 32px 32px; transform:translateX(100%); transition:transform .25s ease;
    }
    nav.links.open{ transform:translateX(0); }
    nav.links a{ padding:16px 0; border-bottom:1px solid var(--line-on-ink); width:100%; }
    nav.links button.dropdown-toggle{ padding:16px 0; border-bottom:1px solid var(--line-on-ink); width:100%; text-align:left; }
    .dropdown{ position:static; transform:none; opacity:1; visibility:visible; background:transparent; border:none; color:#fff; padding-left:14px; }
    .dropdown a{ border-bottom:none; padding:10px 0; opacity:0.8; }
    .nav-toggle{ display:block; }
  }

  /* ---------- HERO : logo centré au-dessus du texte, bloc unique ---------- */
  .hero{
    position:relative; padding:120px 24px 48px; text-align:center;
    background:#B69F82;
  }
  .hero-inner{
    max-width:640px; margin:0 auto;
    display:flex; flex-direction:column; align-items:center;
  }
  .hero-logo{
    width:120px; margin-bottom:22px;
  }
  .hero-logo img{ width:100%; height:auto; display:block; }
  .hero-logo.is-empty{
    aspect-ratio:1/1;
    background:
      repeating-linear-gradient(135deg, rgba(43,29,20,0.08) 0 2px, transparent 2px 16px),
      #B69F82;
    display:flex; align-items:center; justify-content:center;
  }
  .hero-logo.is-empty::after{
    content:"Logo — depose photos/hero.jpg";
    font-family:'IBM Plex Mono', monospace; font-size:10.5px; color:var(--ink);
    text-align:center; padding:0 10px;
  }
  .hero-content{ color:var(--ink); text-align:center; }
  .hero-content .eyebrow{ color:rgba(43,29,20,0.75); margin-bottom:20px; }
  .hero-content h1{
    font-size:clamp(24px, 3vw, 32px); font-weight:400; font-style:italic;
    letter-spacing:0.01em; line-height:1.4;
  }
  .hero-actions{ margin-top:24px; display:flex; gap:16px; flex-wrap:wrap; justify-content:center; }
  .scroll-cue{
    position:absolute; bottom:20px; left:50%; transform:translateX(-50%);
    z-index:2; color:var(--ink); font-family:'IBM Plex Mono', monospace; font-size:10.5px;
    letter-spacing:0.14em; text-transform:uppercase; opacity:0.7;
  }
  @media (max-width:600px){
    .hero{ padding:105px 20px 40px; }
    .hero-logo{ width:120px; }
  }

  /* ---------- Intro galeries (3 cartes) ---------- */
  .intro{ padding:110px 0 90px; text-align:center; }
  .intro .eyebrow{ margin-bottom:18px; }
  .intro h2{ font-size:clamp(26px,3.6vw,38px); max-width:640px; margin:0 auto 60px; }

  .gallery-cards{ display:grid; grid-template-columns:repeat(2,1fr); gap:2px; background:var(--line); }
  .gallery-card{ position:relative; background:var(--paper); aspect-ratio:3/4; overflow:hidden; display:block; }
  .gallery-card img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
  .gallery-card:hover img{ transform:scale(1.04); }
  .gallery-card.is-empty{
    background:
      repeating-linear-gradient(135deg, rgba(43,29,20,0.07) 0 2px, transparent 2px 16px), #f1e2c9;
  }
  .gallery-card .label{
    position:absolute; left:0; right:0; bottom:0; padding:22px 20px;
    background:linear-gradient(0deg, rgba(0,0,0,0.55), transparent);
    color:#fff; z-index:2;
  }
  .gallery-card.is-empty .label{ background:none; color:var(--ink); }
  .gallery-card .label .eyebrow{ color:inherit; opacity:0.75; }
  .gallery-card .label h3{ font-size:20px; color:inherit; margin-top:6px; }
  @media (max-width:820px){ .gallery-cards{ grid-template-columns:1fr; } }

  /* ---------- SECTIONS PAR CATEGORIE ---------- */
  section.category{ padding:110px 0; border-top:1px solid var(--line); }
  .section-head{ max-width:640px; margin-bottom:56px; }
  .section-head .eyebrow{ margin-bottom:18px; }
  .section-head h2{ font-size:clamp(28px,4vw,42px); margin-bottom:20px; }
  .section-head p{ font-size:16.5px; color:var(--grey); }

  .bullets{ display:flex; gap:28px; flex-wrap:wrap; margin-top:30px; }
  .bullets div{ font-family:'IBM Plex Mono', monospace; font-size:12px; letter-spacing:0.04em; padding:10px 0; border-top:1px solid var(--line); width:190px; color:var(--grey); }

  .grid-photos{ display:grid; grid-template-columns:repeat(4,1fr); gap:2px; margin-top:52px; background:var(--line); }
  .photo-frame{ position:relative; aspect-ratio:4/5; overflow:hidden; background:var(--paper); }
  .photo-frame img{ width:100%; height:100%; object-fit:cover; object-position:center 25%; }
  .photo-frame.is-empty{
    display:flex; align-items:flex-end;
    background:
      repeating-linear-gradient(135deg, rgba(43,29,20,0.07) 0 2px, transparent 2px 16px), #f1e2c9;
  }
  .photo-frame.is-empty::after{
    content:attr(data-label); font-family:'IBM Plex Mono', monospace; font-size:11px;
    letter-spacing:0.03em; padding:12px; color:var(--grey); background:rgba(255,255,255,0.7); width:100%;
  }
  @media (max-width:900px){ .grid-photos{ grid-template-columns:repeat(2,1fr);} }

  /* ---------- TARIFS ---------- */
  .pricing{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; margin-top:56px; background:var(--line); }
  .price-card{ background:var(--paper); padding:34px 28px; display:flex; flex-direction:column; gap:16px; }
  .price-card.featured{ background:#f6ead6; }
  .price-card h3{ font-size:21px; }
  .price-card .price{ font-family:'IBM Plex Mono', monospace; font-size:14px; color:var(--stone); }
  .price-card ul{ list-style:none; margin:0; padding:0; font-size:14px; color:var(--grey); display:flex; flex-direction:column; gap:10px; }
  .price-card li::before{ content:"— "; opacity:0.6; }
  @media (max-width:820px){ .pricing{ grid-template-columns:1fr; } }

  /* ---------- CONTACT / footer style Diribarne ---------- */
  #contact{ background:var(--ink); color:#fff; padding:100px 0 0; }
  #contact .section-head p{ color:rgba(255,255,255,0.7); }
  #contact .section-head .eyebrow{ color:rgba(255,255,255,0.6); }
  .contact-columns{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:48px; padding-bottom:70px; border-bottom:1px solid var(--line-on-ink); }
  .contact-columns h4{ font-family:'IBM Plex Mono', monospace; font-size:11.5px; letter-spacing:0.1em; text-transform:uppercase; color:var(--stone); margin-bottom:16px; }
  .contact-columns p, .contact-columns a{ font-size:14.5px; color:rgba(255,255,255,0.85); }
  .contact-columns a{ border-bottom:1px solid var(--line-on-ink); display:inline-block; }

  form{ display:flex; flex-direction:column; gap:16px; max-width:640px; margin-top:60px; }
  form label{ font-family:'IBM Plex Mono', monospace; font-size:11px; letter-spacing:0.08em; text-transform:uppercase; opacity:0.65; margin-bottom:6px; display:block; }
  form input, form select, form textarea{
    width:100%; padding:13px 14px; font-family:'Inter', sans-serif; font-size:15px;
    border:1px solid var(--line-on-ink); background:transparent; color:#fff;
  }
  form option{ color:#000; }
  form input:focus, form select:focus, form textarea:focus{ outline:2px solid var(--stone); outline-offset:1px; }
  form textarea{ min-height:120px; resize:vertical; }
  form button{ align-self:flex-start; border:none; cursor:pointer; margin-top:8px; }

  footer{ padding:34px 0; background:var(--ink); }
  .footer-inner{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px; font-family:'IBM Plex Mono', monospace; font-size:11.5px; color:rgba(255,255,255,0.55); }
  footer a{ color:rgba(255,255,255,0.8); border-bottom:1px solid var(--line-on-ink); }

  @media (max-width:820px){ .contact-columns{ grid-template-columns:1fr; gap:32px; } }
  @media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto;} *{transition:none !important;} }

  /* ================================================================
     PAGES GALERIES (food.html, corporate.html, mariage.html)
     ================================================================ */

  /* Mini-hero de page (bandeau de titre, plus petit que celui de l'accueil) */
  .page-hero{
    padding:150px 0 60px; border-bottom:1px solid var(--line);
  }
  .page-hero .eyebrow{ margin-bottom:18px; }
  .page-hero h1{ font-size:clamp(30px,4.5vw,48px); max-width:720px; }
  .page-hero p{ margin-top:20px; font-size:16.5px; color:var(--grey); max-width:560px; }
  .page-hero .back-link{
    display:inline-flex; align-items:center; gap:8px; margin-top:28px;
    font-family:'IBM Plex Mono', monospace; font-size:12px; letter-spacing:0.06em; text-transform:uppercase;
    color:var(--grey);
  }
  .page-hero .back-link:hover{ color:var(--ink); }

  /* Grille agrandie, cliquable, pour les pages galerie */
  .lightbox-grid{
    display:grid; grid-template-columns:repeat(3,1fr); gap:4px;
    margin-top:0; padding:70px 0; background:var(--line);
  }
  .lightbox-grid .photo-frame{ cursor:zoom-in; }
  .lightbox-grid .photo-frame.is-empty{ cursor:default; }
  @media (max-width:900px){ .lightbox-grid{ grid-template-columns:repeat(2,1fr); } }
  @media (max-width:560px){ .lightbox-grid{ grid-template-columns:1fr; } }

  /* CTA de fin de page galerie */
  .page-cta{ padding:90px 0; text-align:center; border-top:1px solid var(--line); }
  .page-cta h2{ font-size:clamp(26px,3.6vw,36px); max-width:560px; margin:0 auto 32px; }

  /* ---------- LIGHTBOX (zoom plein écran au clic) ---------- */
  .lightbox-overlay{
    position:fixed; inset:0; z-index:100; background:rgba(20,20,20,0.94);
    display:flex; align-items:center; justify-content:center;
    opacity:0; visibility:hidden; transition:opacity .25s ease;
    padding:40px;
  }
  .lightbox-overlay.open{ opacity:1; visibility:visible; }
  .lightbox-overlay img{
    max-width:100%; max-height:88vh; width:auto; height:auto;
    box-shadow:0 20px 60px rgba(0,0,0,0.5);
  }
  .lightbox-caption{
    position:absolute; left:0; right:0; bottom:18px; text-align:center;
    font-family:'IBM Plex Mono', monospace; font-size:12px; letter-spacing:0.05em;
    color:rgba(255,255,255,0.75);
  }
  .lightbox-close, .lightbox-prev, .lightbox-next{
    position:absolute; background:none; border:none; color:#fff; cursor:pointer;
    font-family:'IBM Plex Mono', monospace;
  }
  .lightbox-close{ top:24px; right:28px; font-size:26px; line-height:1; }
  .lightbox-close:hover{ opacity:0.7; }
  .lightbox-prev, .lightbox-next{
    top:50%; transform:translateY(-50%); font-size:38px; padding:10px 16px;
  }
  .lightbox-prev{ left:8px; }
  .lightbox-next{ right:8px; }
  .lightbox-prev:hover, .lightbox-next:hover{ opacity:0.7; }
  @media (max-width:640px){
    .lightbox-overlay{ padding:16px; }
    .lightbox-prev, .lightbox-next{ font-size:28px; padding:8px 10px; }
    .lightbox-close{ top:14px; right:16px; }
  }
