/* ============================================================
   Bekef26 — Système de design « Premium éditorial sombre »
   ============================================================ */
   :root{
    --bg:#0e0d0b;
    --bg-2:#15120d;
    --bg-3:#1c1812;
    --paper:#1f1a14;
    --line:rgba(201,168,76,.20);
    --line-soft:rgba(255,255,255,.07);
    --gold:#c9a84c;
    --gold-bright:#e3c878;
    --text:#f3eede;
    --text-dim:#a8a08e;
    --text-faint:#76705f;
    --serif:'Cormorant Garamond',Georgia,serif;
    --sans:'Manrope',system-ui,sans-serif;
    --maxw:1180px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{background:var(--bg);color:var(--text);font-family:var(--sans);font-weight:300;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
  .eyebrow{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:12px;white-space:nowrap}
  .eyebrow::before{content:"";width:28px;height:1px;background:var(--gold);opacity:.6}
  .eyebrow.center{justify-content:center}
  .eyebrow.nobar::before{display:none}
  h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.1;letter-spacing:-.01em}
  .gold{color:var(--gold)}
  em.gold,.serif-em{font-style:italic;color:var(--gold)}
  
  /* placeholder */
  .ph{position:relative;overflow:hidden;background:repeating-linear-gradient(135deg,#171410,#171410 11px,#1c1812 11px,#1c1812 22px);border:1px solid var(--line-soft);display:flex;align-items:center;justify-content:center;text-align:center}
  .ph span{font-family:'SFMono-Regular',ui-monospace,Menlo,monospace;font-size:11px;letter-spacing:.05em;color:var(--text-faint);background:var(--bg);padding:5px 11px;border:1px solid var(--line-soft);border-radius:3px}
  .fill{position:absolute;inset:0}
  
  /* buttons */
  .btn{display:inline-flex;align-items:center;gap:10px;font-size:13px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:15px 26px;border-radius:2px;cursor:pointer;transition:.2s;border:1px solid transparent}
  .btn-gold{background:var(--gold);color:var(--bg)}
  .btn-gold:hover{background:var(--gold-bright)}
  .btn-ghost{border-color:var(--line);color:var(--text)}
  .btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
  .btn .arr{font-size:15px;transition:transform .2s}
  .btn:hover .arr{transform:translateX(4px)}
  .actions{display:flex;gap:16px;flex-wrap:wrap}
  
  /* ---------- header / nav ---------- */
  header.site{position:sticky;top:0;z-index:60;background:rgba(14,13,11,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line-soft)}
  .nav{display:flex;align-items:center;gap:34px;height:74px}
  .brand{font-family:var(--serif);font-size:27px;font-weight:600;letter-spacing:.02em;color:var(--text);display:inline-flex;align-items:center}
  .brand b{color:var(--gold);font-weight:600}
  .brand img{height:42px;width:auto;display:block}
  .foot-brand .brand img{height:52px}
  .nav .links{display:flex;gap:26px;list-style:none;margin-left:auto}
  .nav .links a{font-size:13px;font-weight:500;letter-spacing:.02em;color:var(--text-dim);transition:color .2s}
  .nav .links a:hover{color:var(--text)}
  .nav .links a.active{color:var(--gold)}
  .nav .cta{font-size:12.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--bg);background:var(--gold);padding:11px 20px;border-radius:2px;transition:background .2s}
  .nav .cta:hover{background:var(--gold-bright)}
  .burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:0;padding:10px 8px}
  .burger span{width:24px;height:1.5px;background:var(--text);transition:.25s}
  .mobile-menu{display:none;flex-direction:column;background:var(--bg-2);border-bottom:1px solid var(--line-soft)}
  .mobile-menu.open{display:flex}
  .mobile-menu a{padding:16px 32px;font-size:15px;color:var(--text-dim);border-bottom:1px solid var(--line-soft)}
  .mobile-menu a.active{color:var(--gold)}
  .mobile-menu .cta{color:var(--gold);font-weight:600}
  
  /* ---------- hero ---------- */
  .hero{position:relative;padding:110px 0 92px;border-bottom:1px solid var(--line-soft);overflow:hidden}
  .hero::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 78% 12%,rgba(201,168,76,.10),transparent 60%);pointer-events:none}
  .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;position:relative;z-index:2}
  .hero-grid > *{min-width:0}
  .hero h1{font-size:clamp(38px,4.4vw,58px);line-height:1.14;margin:22px 0 30px}
  .hero h1 em{font-style:italic;color:var(--gold)}
  .hero .lead{font-size:18px;font-weight:300;color:var(--text-dim);max-width:480px;line-height:1.65}
  .hero .actions{margin-top:36px}
  .hero-visual{position:relative;aspect-ratio:4/5;border-radius:4px}
  .hero-visual .ph{position:absolute;inset:0;border-radius:4px}
  .hero-visual .ph img, .hero-visual .ph picture, .hero-visual .ph picture img {width: 100%;height: 100%;display: block;}
  .hero-visual .ph picture img, .hero-visual .ph img {object-fit: cover;border-radius: 4px;}
  .hero-badge{position:absolute;left:-26px;bottom:34px;z-index:3;background:var(--bg-2);border:1px solid var(--line);border-radius:4px;padding:18px 22px;width:212px;box-shadow:0 24px 60px rgba(0,0,0,.5)}
  .hero-badge .k{font-family:var(--serif);font-size:32px;color:var(--gold);line-height:1}
  .hero-badge .l{font-size:12px;color:var(--text-dim);margin-top:6px;letter-spacing:.02em}
  .hero-strip{display:flex;gap:34px;flex-wrap:wrap;margin-top:60px;padding-top:32px;border-top:1px solid var(--line-soft);position:relative;z-index:2}
  .hero-strip div{font-size:13px;color:var(--text-dim);display:flex;align-items:center;gap:9px}
  .hero-strip b{color:var(--text);font-weight:500}
  .dot{width:5px;height:5px;border-radius:50%;background:var(--gold);flex:none}
  
  /* Hero uniquement de la sandwicherie */
  .sandwich-hero .hero-visual .ph picture img,
  .sandwich-hero .hero-visual .ph img {object-position: 80% center;}
  
  /* ---------- section frame ---------- */
  section.blk{padding:100px 0;border-bottom:1px solid var(--line-soft)}
  .blk.alt{background:var(--bg-2)}
  .sec-head{max-width:680px;margin-bottom:52px}
  .sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
  .sec-head h2{font-size:clamp(32px,4.2vw,52px);margin:18px 0 16px}
  .sec-head p{font-size:17px;color:var(--text-dim);font-weight:300}
  
  /* ---------- universe cards (home) ---------- */
  .universe{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .uni{position:relative;border:1px solid var(--line-soft);border-radius:5px;overflow:hidden;min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;transition:.25s}
  .uni .ph{position:absolute;inset:0;border:0}
  .uni:hover{border-color:var(--line);transform:translateY(-5px);box-shadow:0 26px 56px rgba(0,0,0,.45)}
  .uni .veil{position:absolute;inset:0;background:linear-gradient(0deg,rgba(14,13,11,.94) 8%,rgba(14,13,11,.35) 55%,transparent);z-index:2}
  .uni .body{position:relative;z-index:3;padding:28px 30px 30px}
  .uni .k{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600}
  .uni h3{font-size:30px;margin:8px 0 8px}
  .uni p{font-size:14px;color:var(--text-dim);font-weight:300}
  .uni .go{margin-top:16px;display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--gold)}
  .uni .go .arr{transition:transform .2s}
  .uni:hover .go .arr{transform:translateX(4px)}
  .uni.tall{grid-row:span 2;min-height:auto}
  
  /* ---------- product grid ---------- */
  .prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .prod{background:var(--bg-3);border:1px solid var(--line-soft);border-radius:5px;overflow:hidden;transition:.25s}
  .prod:hover{border-color:var(--line);transform:translateY(-4px)}
  .prod .img{aspect-ratio:3/2;position:relative}
  .prod .img .ph{position:absolute;inset:0;border:0;border-bottom:1px solid var(--line-soft)}
  .prod .img .ph img{width: 100%;height: 100%;object-fit: cover;display: block;}
  .prod .img .tag{position:absolute;top:12px;left:12px;z-index:3;background:rgba(14,13,11,.82);backdrop-filter:blur(6px);border:1px solid var(--line);color:var(--gold);font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;padding:5px 11px;border-radius:999px}
  .prod .txt{padding:22px 24px 26px}
  .prod .txt h3{font-size:24px;margin-bottom:7px}
  .prod .txt p{font-size:13.5px;color:var(--text-dim);font-weight:300}
  .prod .txt .pr{margin-top:14px;font-family:var(--serif);font-size:20px;color:var(--gold)}
  .prod .txt .pr small{font-family:var(--sans);font-size:12px;color:var(--text-faint);font-weight:300}
  
  /* ---------- split ---------- */
  .split{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--line);border-radius:5px;overflow:hidden}
  .split .pane{padding:52px 50px;background:var(--bg-3)}
  .split .pane h2{font-size:clamp(30px,3.6vw,42px);margin:16px 0 16px}
  .split .pane p{color:var(--text-dim);font-size:16px;font-weight:300}
  .split .visual{position:relative;min-height:420px}
  .split .visual .ph{position:absolute;inset:0;border:0}
  .pill-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
  .pill{font-size:13px;color:var(--text);border:1px solid var(--line);border-radius:999px;padding:9px 18px;background:rgba(201,168,76,.05)}
  
  /* ---------- feature list ---------- */
  .lines{margin-top:26px;display:flex;flex-direction:column}
  .lines div{display:flex;align-items:center;gap:14px;padding:13px 0;border-bottom:1px solid var(--line-soft);font-size:15.5px;color:var(--text)}
  .lines div:last-child{border-bottom:0}
  .lines .b{width:7px;height:7px;flex:none;border:1px solid var(--gold);transform:rotate(45deg)}
  
  /* ---------- info card ---------- */
  .info-card{background:var(--bg-3);border:1px solid var(--line);border-radius:5px;padding:36px 40px}
  .info-row{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--line-soft)}
  .info-row:last-child{border-bottom:0;padding-bottom:0}
  .info-row:first-child{padding-top:0}
  .info-row .ic{width:34px;height:34px;flex:none;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:15px}
  .info-row .k{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-faint);font-weight:600}
  .info-row .v{font-size:15.5px;color:var(--text);margin-top:3px}
  .info-row .v small{color:var(--text-dim);font-weight:300}
  .seal,.kosher-seal{display:inline-flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:999px;padding:8px 16px;font-size:12px;color:var(--gold);letter-spacing:.04em}
  
  /* ---------- order channels (sur place / uber / deliveroo) ---------- */
  .channels{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
  .channel{display:flex;flex-direction:column;gap:8px;background:var(--bg-3);border:1px solid var(--line-soft);border-radius:6px;padding:26px 26px 24px;transition:.22s}
  .channel:hover{border-color:var(--line);transform:translateY(-3px)}
  .channel .ch-tag{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--text-faint)}
  .channel h3{font-size:22px;display:flex;align-items:center;gap:10px}
  .channel .ch-dot{width:9px;height:9px;border-radius:50%;flex:none}
  .channel p{font-size:13.5px;color:var(--text-dim);font-weight:300}
  .channel .ch-link{margin-top:6px;font-size:12.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:8px}
  .channel .ch-link .arr{transition:transform .2s}
  .channel:hover .ch-link .arr{transform:translateX(4px)}
  
  /* ---------- reviews ---------- */
  /*.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}*/ 
  .reviews-carousel {
    overflow: hidden;
    mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
    -webkit-mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
  }
  
  .reviews-track {
    display: flex;
    gap: 22px;
    animation: scroll-reviews 18s linear infinite;
    width: max-content;
  }
  
  .reviews-track:hover {
    animation-play-state: paused;
  }
  
  .reviews-track .rev {
    width: 340px;
    flex-shrink: 0;
  }
  
  @keyframes scroll-reviews {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
  }
  .rev{background:var(--bg-3);border:1px solid var(--line-soft);border-radius:5px;padding:28px 28px 26px}
  .rev .stars{color:var(--gold);letter-spacing:3px;font-size:14px}
  .rev p{font-size:15px;color:var(--text);font-weight:300;margin:14px 0 16px;line-height:1.6;font-family:var(--serif);font-style:italic;letter-spacing:.01em}
  .rev .who{font-size:12.5px;color:var(--text-faint);letter-spacing:.04em}
  
  /* ---------- form ---------- */
  .form-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:start}
  .form{background:var(--bg-3);border:1px solid var(--line);border-radius:6px;padding:40px 42px}
  .fieldset{margin-bottom:28px}
  .fieldset legend{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:10px}
  .fieldset legend .n{width:22px;height:22px;border:1px solid var(--line);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:13px}
  .frow{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
  .frow.one{grid-template-columns:1fr}
  .field{display:flex;flex-direction:column;gap:7px}
  .field label{font-size:12px;color:var(--text-dim);letter-spacing:.03em}
  .field input,.field select,.field textarea{background:var(--bg);border:1px solid var(--line-soft);border-radius:3px;padding:13px 14px;color:var(--text);font-family:var(--sans);font-size:14px;font-weight:300;transition:border-color .2s}
  .field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
  .field textarea{resize:vertical;min-height:96px}
  .field input::placeholder,.field textarea::placeholder{color:var(--text-faint)}
  .choice-row{display:flex;flex-wrap:wrap;gap:10px}
  .choice{position:relative}
  .choice input{position:absolute;opacity:0;inset:0;cursor:pointer}
  .choice span{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line-soft);border-radius:999px;padding:10px 18px;font-size:13px;color:var(--text-dim);cursor:pointer;transition:.2s}
  .choice input:checked + span{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,.07)}
  .form-foot{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:8px}
  .form-note{font-size:12.5px;color:var(--text-faint);display:flex;align-items:center;gap:8px}
  .summary{background:var(--bg-3);border:1px solid var(--line);border-radius:6px;padding:34px 36px;position:sticky;top:96px}
  .summary h3{font-size:26px;margin-bottom:6px}
  .summary .sub{font-size:13.5px;color:var(--text-dim);margin-bottom:22px}
  .sum-row{display:flex;justify-content:space-between;gap:14px;padding:14px 0;border-bottom:1px solid var(--line-soft);font-size:14px}
  .sum-row:last-of-type{border-bottom:0}
  .sum-row .k{color:var(--text-dim)}
  .sum-row .v{color:var(--text);text-align:right}
  .step-list{list-style:none;display:flex;flex-direction:column;gap:16px;margin-top:6px}
  .step-list li{display:flex;gap:14px;font-size:14px;color:var(--text-dim)}
  .step-list .num{width:26px;height:26px;flex:none;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold);font-family:var(--serif);font-size:14px}
  
  /* ---------- band / cta ---------- */
  .cta-band{text-align:center;padding:96px 0}
  .cta-band h2{font-size:clamp(32px,4.4vw,56px);margin-bottom:18px}
  .cta-band p{font-size:17px;color:var(--text-dim);max-width:520px;margin:0 auto 32px;font-weight:300}
  .cta-band .actions{justify-content:center}
  
  /* ---------- footer ---------- */
  footer.site{background:var(--bg-2);padding:70px 0 34px}
  .foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:46px;border-bottom:1px solid var(--line-soft)}
  .foot-brand .brand{margin-bottom:16px;display:inline-block}
  .foot-brand p{font-size:14px;color:var(--text-dim);font-weight:300;max-width:280px}
  footer.site h4{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:18px}
  footer.site ul{list-style:none;display:flex;flex-direction:column;gap:11px}
  footer.site ul a{font-size:14px;color:var(--text-dim);font-weight:300;display:block;padding:10px 0}
  footer.site ul a:hover{color:var(--text)}
  .foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;gap:18px;flex-wrap:wrap}
  .foot-bottom span{font-size:12.5px;color:var(--text-faint)}
  
  /* ---------- utilities ---------- */
  .center{text-align:center}
  .mt-0{margin-top:0}
  .note{font-size:12.5px;color:var(--text-faint);display:flex;align-items:center;gap:8px}
  
  /* ---------- lang switch ---------- */
  .lang-switch{display:flex;align-items:center;gap:6px;margin-left:8px}
  .lang-btn{background:none;border:none;font-size:12px;font-weight:600;letter-spacing:.06em;color:var(--text-dim);cursor:pointer;padding:12px 6px;transition:color .2s;font-family:var(--sans)}
  .lang-btn:hover{color:var(--text)}
  .lang-btn.active{color:var(--gold)}
  .lang-sep{color:var(--line);font-size:10px}
  
  
  /* ---------- responsive ---------- */
  @media(max-width:940px){
    .nav .links,.nav .cta{display:none}
    .burger{display:flex;margin-left:auto}
    .hero-grid,.split,.form-grid,.foot-grid{grid-template-columns:1fr}
    .hero-visual{aspect-ratio:16/11;order:-1}
    .hero-badge{left:auto;right:18px;bottom:-22px}
    .universe,.prod-grid,.reviews{grid-template-columns:1fr 1fr}
    .uni.tall{grid-row:auto}
    .split .visual{min-height:260px;order:-1}
    .summary{position:static}
    .channels{grid-template-columns:1fr}
  }
  @media(max-width:600px){
    .wrap{padding:0 20px}
    section.blk{padding:70px 0}
    .hero{padding:66px 0 60px}
    .universe,.prod-grid,.reviews{grid-template-columns:1fr}
    .split .pane,.info-card,.form{padding:30px 24px}
    .frow{grid-template-columns:1fr}
    .foot-grid{grid-template-columns:1fr 1fr}
    .eyebrow{white-space:normal}
  
    /* ── hero mobile ── */
    .hero-visual{aspect-ratio:4/3;margin:0 -20px;border-radius:0}
    .hero-visual .ph{border-radius:0}
    .hero-visual .ph img{border-radius:0}
    
    .sandwich-hero .hero-visual .ph picture img,
    .sandwich-hero .hero-visual .ph img {object-position: 30% center;}

    .img--home-hero{object-position: center 40%;}

    .hero-badge{right:36px;bottom:16px;width:160px;padding:12px 14px}
    .hero-badge .k{font-size:22px}
    .hero-badge .l{font-size:11px}

    #contact .wrap{display:block !important;}
    #contact .actions{flex-direction:column;}
    #contact .actions .btn{width:100%;justify-content:center;}
    #contact .info-card{margin-top:28px;padding:22px 20px;border-radius:12px;background:linear-gradient(135deg, rgba(201,168,76,.10), rgba(255,255,255,.03));}
    #contact .info-row{padding:14px 0;gap:12px;}
    #contact .info-row .ic{width:30px;height:30px;font-size:13px;}
    #contact iframe{height:190px;}
    .contact-map{margin-top:24px !important;}

    .visual .ph img[src*="menu-sandwich"] {
      object-fit: cover;
      object-position: 50% 15%;
      height: 100%;
      width: 100%;
    }

      /* Fix overflow widget Elfsight */
    [class*="elfsight-app"] { max-width: 100%; overflow: hidden; }
    .eapps-widget-toolbar { display: none !important; }
    .eapps-widget-toolbar-panel-wrapper { display: none !important; }

    .lang-sep { font-size: 12px; }
    .eyebrow   { font-size: 12px; }
    .l         { font-size: 12px; }
    .k         { font-size: 12px; }
    footer h4  { font-size: 12px; }

  }
  
  
  /* Masquer les images uniquement sur la page épicerie */
  .no-images .img {
    display: none;
  }