/* ==========================================================================
   05-modules.css — Modules front.
   Phase 2 : module « Carte de la semaine » + lightbox (porté de docs/index.html).
   Les autres modules (hero, actualités, carte permanente, traiteur…) viennent
   en Phase 4 et s'ajoutent à ce fichier.
   ========================================================================== */

/* --- Conteneur de section ------------------------------------------------- */
.apc-carte{padding:84px 0;background:var(--blanc)}
.apc-carte .wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* --- En-tête de section --------------------------------------------------- */
.apc-carte .eyebrow{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.22em;color:var(--laiton);display:inline-flex;align-items:center;gap:10px}
.apc-carte .eyebrow::before{content:"";width:26px;height:1px;background:var(--laiton);display:inline-block}
.apc-carte .eyebrow.center::after{content:"";width:26px;height:1px;background:var(--laiton);display:inline-block}
.apc-carte .sec-head{text-align:center;max-width:640px;margin:0 auto 50px}
.apc-carte .sec-head h2{font-family:var(--font-titre);font-size:clamp(32px,4.4vw,52px);margin-top:18px;font-weight:400}
.apc-carte .sec-head p{color:var(--muted);margin-top:14px;font-size:16.5px}
.apc-carte .week-label{display:inline-block;margin-top:14px;font-family:var(--font-titre);font-style:italic;font-size:19px;color:var(--laiton)}

/* --- Onglets sur place / à emporter --------------------------------------- */
.apc-carte .switch{display:flex;gap:8px;justify-content:center;margin:0 auto 46px;width:max-content;background:var(--blanc-card);border:1px solid var(--hairline);border-radius:999px;padding:6px}
.apc-carte .switch button{border:0;background:transparent;cursor:pointer;font-weight:600;font-size:14.5px;color:var(--muted);padding:9px 22px;border-radius:999px;transition:.2s;font-family:var(--font-corps)}
.apc-carte .switch button.on{background:var(--noir);color:var(--craie)}

/* --- Titre de catégorie --------------------------------------------------- */
.apc-carte .cat-title{font-family:var(--font-titre);font-style:italic;font-size:26px;color:var(--encre);margin:48px 0 24px;display:flex;align-items:center;gap:16px}
.apc-carte .cat-title::after{content:"";flex:1;height:1px;background:var(--hairline)}
.apc-carte .cat-title:first-of-type{margin-top:0}

/* --- Grille de plats ------------------------------------------------------ */
.apc-carte .dishes{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.apc-carte .dish{background:var(--blanc-card);border:1px solid var(--hairline);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease}
.apc-carte .dish:hover{transform:translateY(-2px);box-shadow:0 18px 38px -22px rgba(20,20,20,.4)}
.apc-carte .dish-photo{position:relative;width:100%;aspect-ratio:16/9;border:0;padding:0;cursor:zoom-in;display:block;overflow:hidden}
.apc-carte .dish-photo .grad{position:absolute;inset:0;transition:transform .4s ease}
.apc-carte .dish:hover .dish-photo .grad{transform:scale(1.05)}
.apc-carte .dish-photo .dish-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.apc-carte .dish:hover .dish-photo .dish-img{transform:scale(1.05)}
.apc-carte .dish-photo .leaf{position:absolute;inset:0;opacity:.2;display:grid;place-items:center}
.g-1{background:linear-gradient(150deg,#2B2B2B,#141414 55%,#3A3026)}
.g-2{background:linear-gradient(150deg,#3A352E,#171717 55%,#262626)}
.g-3{background:linear-gradient(150deg,#4A3D28,#1A1A1A 60%,#2E2A22)}
.apc-carte .zoom{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;background:rgba(10,10,10,.55);color:var(--craie);display:grid;place-items:center;opacity:0;transition:opacity .2s;backdrop-filter:blur(2px)}
.apc-carte .dish-photo:hover .zoom,.apc-carte .dish-photo:focus-visible .zoom{opacity:1}
/* Image par défaut : non agrandissable (pas de curseur ni de zoom au survol). */
.apc-carte .dish-photo--static{cursor:default}
.apc-carte .dish:hover .dish-photo--static .dish-img{transform:none}
.apc-carte .dish-body{padding:20px 22px 24px}
.apc-carte .dish-top{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:8px}
.apc-carte .dish-name{font-family:var(--font-titre);font-size:21px;font-weight:500;color:var(--encre);letter-spacing:-.01em}
.apc-carte .dish-price{font-family:var(--font-titre);font-size:19px;color:var(--laiton);font-variant-numeric:tabular-nums;text-align:right}
.apc-carte .dish-price-amount{white-space:nowrap}
.apc-carte .dish-price-detail{display:inline-block;font-family:var(--font-corps,inherit);font-size:12px;font-weight:400;color:var(--muted);letter-spacing:0}
.apc-carte .dish-desc{font-size:14.5px;color:var(--muted);line-height:1.55}
.apc-carte .tag{display:inline-block;font-size:10.5px;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--laiton);border:1px solid var(--laiton);padding:3px 10px;border-radius:999px;margin-top:12px}

/* --- Panneaux ------------------------------------------------------------- */
.apc-carte .panel{display:none}
.apc-carte .panel.on{display:block;animation:apc-fade .35s ease}
@keyframes apc-fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* --- Lightbox ------------------------------------------------------------- */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(10,10,10,.92);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;padding:24px}
.lightbox.open{display:flex;animation:apc-fade .25s ease}
/* Zoom photo : carte = la photo seule, agrandie et bornée à l'écran (la source
   apc_dish fait 1280×720, donc nette jusqu'à ~1000px de large). */
.lb-card{background:var(--blanc-card);border-radius:18px;overflow:hidden;width:min(960px,92vw,calc((100vh - 48px) * 16 / 9));position:relative}
.lb-img{aspect-ratio:16/9;position:relative}
.lb-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.lb-close{position:absolute;top:14px;right:14px;width:40px;height:40px;border-radius:50%;border:0;cursor:pointer;background:rgba(10,10,10,.55);color:var(--craie);display:grid;place-items:center;backdrop-filter:blur(2px);transition:background .2s}
.lb-close:hover{background:#000}

/* --- Carte : responsive de base ------------------------------------------ */
@media (max-width:640px){
  .apc-carte{padding:60px 0}
  .apc-carte .wrap{padding:0 20px}
  .apc-carte .dishes{grid-template-columns:1fr}
}

/* ==========================================================================
   Module Actualités
   ========================================================================== */
/* Écart bas resserré pour ce module uniquement (le global reste 84px). */
section.block.news{padding-bottom:48px}
.apc-cover-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.news-feature{display:grid;grid-template-columns:1.05fr .95fr;gap:0;border:1px solid var(--hairline);border-radius:18px;overflow:hidden;background:var(--blanc-card);margin-bottom:26px}
.nf-img{position:relative;aspect-ratio:16/9;overflow:hidden}
.nf-img .grad{position:absolute;inset:0}
.nf-img .leaf{position:absolute;inset:0;opacity:.2;display:grid;place-items:center}
.nf-body{padding:40px 42px;display:flex;flex-direction:column;justify-content:center}
.nf-body h3{font-size:32px;margin:16px 0 12px;font-weight:400}
.nf-body p{color:var(--muted);font-size:16px;margin-bottom:24px}
/* Badge (date) : largeur auto alignée à gauche (sinon étiré par le flex column). */
.nf-body .badge{align-self:flex-start}
.nf-body .btn{align-self:flex-start}
.news-row{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.news-card{background:var(--blanc-card);border:1px solid var(--hairline);border-radius:16px;overflow:hidden;transition:transform .18s ease,box-shadow .18s ease}
.news-card:hover{transform:translateY(-2px);box-shadow:0 16px 34px -22px rgba(20,20,20,.4)}
.news-card .nc-img{position:relative;aspect-ratio:16/9;overflow:hidden}
.news-card .nc-img .leaf{position:absolute;inset:0;opacity:.2;display:grid;place-items:center}
.news-card .nc-body{padding:22px 24px 26px}
.news-card h4{font-family:var(--font-titre);font-size:21px;font-weight:500;margin:14px 0 8px}
.news-card p{color:var(--muted);font-size:14.5px}
.news-card .nc-btn{margin-top:16px}

/* ==========================================================================
   Module Carte permanente (fond noir)
   ========================================================================== */
.permanent{background:var(--noir);color:var(--craie)}
.permanent .sec-head h2{color:var(--craie)}
.permanent .sec-head p{color:var(--muted-dark)}
.perm-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.perm{background:var(--noir-700);border:1px solid var(--hairline-dark);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease}
.perm:hover{transform:translateY(-2px);box-shadow:0 18px 38px -22px rgba(0,0,0,.6)}
.perm-photo{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden}
.perm-photo .grad{position:absolute;inset:0}
.perm-photo .leaf{position:absolute;inset:0;opacity:.2;display:grid;place-items:center}
.perm-body{padding:18px 20px 22px;text-align:left}
.perm h4{color:var(--craie);font-size:18px;font-weight:500;margin-bottom:5px}
.perm p{font-size:13.5px;color:var(--muted-dark);line-height:1.5}
.perm .px{font-family:var(--font-titre);color:var(--laiton-clair);font-size:15px;margin-top:10px;display:block}

/* ==========================================================================
   Module Réservation + horaires
   ========================================================================== */
.reserve{background:var(--blanc)}
.res-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:start}
.res-grid .apc-form-wrap{max-width:none}
.info{padding-top:6px}
.info h3{font-size:25px;margin-bottom:24px}
.hours{border-top:1px solid var(--hairline)}
.hours .row{display:flex;justify-content:space-between;gap:16px;padding:15px 0;border-bottom:1px solid var(--hairline)}
.hours .row span:first-child{font-weight:600;color:var(--encre)}
.hours .kind{font-family:var(--font-titre);font-style:italic;color:var(--laiton);font-size:18px;margin:26px 0 4px}
.hours .kind:first-child{margin-top:0}

/* ==========================================================================
   Module Où sommes-nous (carte Google)
   ========================================================================== */
.locate{background:var(--blanc);border-top:1px solid var(--hairline)}
.map-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:34px;align-items:stretch}
.map-frame{border-radius:18px;overflow:hidden;border:1px solid var(--hairline);min-height:440px;position:relative}
.map-frame iframe{width:100%;height:100%;border:0;display:block;position:absolute;inset:0}
.map-placeholder{position:absolute;inset:0;display:grid;place-items:center;background:linear-gradient(150deg,#403828,#121212)}
.map-info{background:var(--noir);color:var(--craie);border-radius:18px;padding:34px;display:flex;flex-direction:column}
.map-info .eyebrow{color:var(--laiton-clair)}
.map-info .eyebrow::before{background:var(--laiton-clair)}
.map-info h3{color:var(--craie);font-size:26px;margin:14px 0 18px;font-weight:400}
.map-info .line{display:flex;gap:13px;align-items:flex-start;padding:13px 0;border-top:1px solid var(--hairline-dark);font-size:15px;color:var(--muted-dark)}
.map-info .line:first-of-type{border-top:0}
.map-info .line svg{flex-shrink:0;margin-top:3px;color:var(--laiton-clair)}
.map-info .line b{color:var(--craie);font-weight:600;display:block}
.map-info .btn{margin-top:auto;align-self:flex-start}

/* ==========================================================================
   Module Traiteur (fond noir)
   ========================================================================== */
.traiteur{background:var(--noir);color:var(--craie);position:relative;overflow:hidden}
.traiteur::after{content:"";position:absolute;inset:0;background:radial-gradient(700px 360px at 12% 120%,rgba(176,137,76,.16),transparent 60%)}
.tr-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;position:relative;z-index:1}
.tr-grid h2{font-size:clamp(30px,4vw,46px);font-weight:400;color:var(--craie)}
.tr-grid p{color:var(--muted-dark);margin-top:18px;font-size:16px}
.tr-visual{aspect-ratio:5/4;border-radius:var(--r);background:linear-gradient(150deg,#403828,#121212);border:1px solid var(--hairline-dark);position:relative;overflow:hidden;display:grid;place-items:center}
.tr-visual .leaf{position:absolute;inset:0;opacity:.16;display:grid;place-items:center}
.tr-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* ==========================================================================
   Module Galerie
   ========================================================================== */
.apc-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.apc-gallery__item{position:relative;margin:0;border-radius:12px;overflow:hidden;border:1px solid var(--hairline);aspect-ratio:4/5}
.apc-gallery__item img{width:100%;height:100%;object-fit:cover}
.apc-gallery__cap{position:absolute;left:0;right:0;bottom:0;padding:24px 14px 10px;font-family:var(--font-titre,"Fraunces",serif);font-size:.95rem;line-height:1.2;color:#fff;background:linear-gradient(to top,rgba(0,0,0,.62),rgba(0,0,0,0))}

/* ==========================================================================
   Module Texte + image
   ========================================================================== */
.apc-ti--noir{background:var(--noir);color:var(--craie)}
.apc-ti--noir h2{color:var(--craie)}
.apc-ti--noir .apc-ti__body{color:var(--muted-dark)}
.apc-ti__grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.apc-ti--noimg .apc-ti__grid{grid-template-columns:1fr;gap:0}
.apc-ti--reverse .apc-ti__visual{order:-1}
.apc-ti__text h2{font-size:clamp(28px,3.6vw,44px);font-weight:400;margin:16px 0 0}
.apc-ti__body{margin-top:18px;color:var(--muted);font-size:16.5px}
.apc-ti__body p{margin-bottom:14px}
.apc-ti__visual{aspect-ratio:5/4;border-radius:var(--r);overflow:hidden;background:linear-gradient(150deg,#403828,#121212);border:1px solid var(--hairline-dark);position:relative;display:grid;place-items:center}
.apc-ti__visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* ==========================================================================
   Page d'actualité : fil d'ariane, couverture, commande, retour
   ========================================================================== */
.crumb{background:var(--blanc);border-bottom:1px solid var(--hairline)}
.crumb .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:16px;padding-bottom:16px}
.crumb .path{font-size:13.5px;color:var(--muted)}
.crumb .path b{color:var(--encre);font-weight:600}
.crumb .home{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;font-weight:600;color:var(--encre)}
.crumb .home svg{color:var(--laiton)}

.cover{position:relative;min-height:clamp(380px,56vh,520px);display:flex;align-items:flex-end;overflow:hidden;color:var(--craie)}
.cover .bg{position:absolute;inset:0;background:linear-gradient(150deg,#4A3D28,#141414 60%,#2E2A22)}
.cover .veil{position:absolute;inset:0;background:linear-gradient(0deg,rgba(10,10,10,.86) 0%,rgba(10,10,10,.35) 55%,rgba(10,10,10,.15) 100%)}
.cover-inner{position:relative;z-index:2;padding:0 0 48px;width:100%}
.cover h1{font-size:clamp(38px,5.6vw,68px);font-weight:400;letter-spacing:-.015em;margin:16px 0 14px;max-width:18ch}
.cover .dates{display:flex;gap:22px;flex-wrap:wrap;color:var(--muted-dark);font-size:14.5px}
.cover .dates span{display:inline-flex;align-items:center;gap:8px}
.cover .dates svg{color:var(--laiton-clair)}

.order{background:var(--blanc-card);border-top:1px solid var(--hairline)}
.order-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:50px;align-items:start}
.order-grid .apc-form-wrap{max-width:none;background:var(--blanc)}
.order-info h2{font-size:clamp(28px,3.6vw,40px);font-weight:400;margin-bottom:16px}
.order-info p{color:var(--muted);font-size:16px;margin-bottom:14px}
.order-info .pts{margin-top:20px}
.order-info .pt{display:flex;gap:12px;align-items:flex-start;padding:11px 0;font-size:15px;color:var(--encre)}
.order-info .pt svg{flex-shrink:0;margin-top:3px;color:var(--laiton)}

.back-bottom{text-align:center;padding:50px 0 10px}
.back-bottom a{display:inline-flex;align-items:center;gap:10px;color:var(--encre);font-weight:600}
.back-bottom svg{color:var(--laiton)}

/* Encadré « menu de l'offre » (page d'actualité) */
.narrow{max-width:760px;margin:0 auto;padding:0 28px}
.menu-box{background:var(--noir);color:var(--craie);border-radius:18px;padding:42px 44px;margin:8px 0}
.menu-box .eyebrow{color:var(--laiton-clair)}
.menu-box .eyebrow::before{background:var(--laiton-clair)}
.menu-box h2{color:var(--craie);font-size:30px;margin:14px 0 28px;font-weight:400}
.course{padding:20px 0;border-top:1px solid var(--hairline-dark)}
.course:first-of-type{border-top:0}
.course .lab{font-size:11.5px;text-transform:uppercase;letter-spacing:.18em;color:var(--laiton-clair);font-weight:700;margin-bottom:7px}
.course .nm{font-family:var(--font-titre);font-size:21px;color:var(--craie);margin-bottom:5px}
.course .ds{color:var(--muted-dark);font-size:14.5px}
.menu-price{display:flex;align-items:baseline;justify-content:space-between;gap:14px;margin-top:26px;padding-top:22px;border-top:1px solid var(--hairline-dark)}
.menu-price span{color:var(--muted-dark);font-size:14px}
.menu-price b{font-family:var(--font-titre);font-size:30px;color:var(--laiton-clair);font-weight:500}
@media (max-width:640px){.narrow{padding:0 20px}.menu-box{padding:30px 24px}}

/* Corps de l'article (texte riche, post_content) */
.apc-actu-corps{font-size:16.5px;line-height:1.75;color:var(--encre)}
.apc-actu-corps>:first-child{margin-top:0}
.apc-actu-corps p{margin:0 0 18px}
.apc-actu-corps h2,.apc-actu-corps h3{font-family:var(--font-titre);font-weight:500;line-height:1.2;margin:30px 0 12px}
.apc-actu-corps h2{font-size:28px}
.apc-actu-corps h3{font-size:22px}
.apc-actu-corps ul,.apc-actu-corps ol{margin:0 0 18px;padding-left:22px}
.apc-actu-corps li{margin-bottom:7px}
.apc-actu-corps a{color:var(--laiton);text-decoration:underline}
.apc-actu-corps blockquote{border-left:3px solid var(--laiton);padding-left:18px;margin:20px 0;color:var(--muted);font-style:italic}
.apc-actu-corps img{max-width:100%;height:auto;border-radius:12px;margin:14px 0}
