/* ============================================================
   OBJECTILE MEGA MENU — Front-end CSS v2.5
   Un seul <nav> dans le DOM, CSS adapte desktop/mobile
   ============================================================ */

:root {
  --omm-orange:       #F26522;
  --omm-orange-dark:  #d9551a;
  --omm-orange-light: #fff0e8;
  --omm-black:        #0f0f0f;
  --omm-grey-dark:    #1e1e1e;
  --omm-grey-mid:     #6b6b6b;
  --omm-white:        #ffffff;
  --omm-border:       rgba(0,0,0,.07);
  --omm-nav-h:        72px;
  --omm-ease:         .25s cubic-bezier(.4,0,.2,1);
  --omm-drawer-w:     320px;
}

.omm-wrap *, .omm-wrap *::before, .omm-wrap *::after { box-sizing: border-box; }
.omm-wrap a { text-decoration: none; }
.omm-wrap ul { list-style: none; margin: 0; padding: 0; }

/* ============================================================
   DESKTOP ≥ 1025px — mega-menu horizontal
   ============================================================ */
@media (min-width: 1025px) {

  /* Cacher les éléments mobile */
  .omm-mobile-bar    { display: none !important; }
  .omm-overlay       { display: none !important; }
  .omm-drawer-header { display: none !important; }
  /* Neutraliser les overrides Elementor Kit sur les éléments du plugin (sauf burger) */
  .omm-wrap button:not(.omm-burger),
  .omm-wrap button:not(.omm-burger):hover,
  .omm-wrap button:not(.omm-burger):focus {
    background-color: transparent !important;
    font-size: inherit !important;
    line-height: inherit !important;
    padding: unset !important;
    font-family: inherit !important;
    font-weight: inherit !important;
    border-radius: unset !important;
  }

  /* Nav : barre horizontale */
  .omm-nav {
    position: static !important;
    transform: none !important;
    width: 100%;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
    display: block !important;
    flex-direction: unset !important;
  }

  .omm-menu {
    display: flex; align-items: center; gap: 4px;
    flex-direction: row;
  }
  .omm-item { position: relative; }

  .omm-link {
    font-family: 'Syne', sans-serif;
    font-weight: 600; font-size: 13.5px; letter-spacing: .3px;
    color: var(--omm-grey-dark);
    padding: 8px 14px; border-radius: 8px;
    display: flex; align-items: center; gap: 5px;
    transition: color var(--omm-ease), background var(--omm-ease);
    white-space: nowrap; cursor: pointer;
    border-bottom: none !important;
    background: transparent !important;
  }
  .omm-item:hover > .omm-link { color: var(--omm-orange) !important; background: var(--omm-orange-light) !important; }

  .omm-chevron { width: 14px; height: 14px; flex-shrink: 0; transition: transform var(--omm-ease); }
  .omm-item:hover > .omm-link .omm-chevron { transform: rotate(180deg); }

  /* Panels desktop */
  .omm-panel {
    position: fixed !important;
    top: var(--omm-nav-h); left: 0; right: 0; width: 100vw;
    background: var(--omm-white);
    border-bottom: 2px solid var(--omm-orange);
    box-shadow: 0 16px 48px rgba(0,0,0,.10);
    padding: 36px calc((100vw - 1200px) / 2 + 32px) 40px;
    opacity: 0; pointer-events: none;
    transform: translateY(-10px);
    transition: opacity var(--omm-ease), transform var(--omm-ease);
    z-index: 9990;
    max-height: none !important; overflow: visible !important;
  }
  .omm-panel::before {
    content: ''; position: absolute;
    top: -20px; left: 0; right: 0; height: 20px; background: transparent;
  }
  .omm-item:hover > .omm-panel,
  .omm-panel:hover { opacity: 1; pointer-events: all; transform: translateY(0); }
  .omm-item:hover::after {
    content: '';
    position: fixed; top: var(--omm-nav-h); left: 0; right: 0; bottom: 0;
    background: rgba(15,15,15,.20); backdrop-filter: blur(2px);
    z-index: 9980; pointer-events: none;
  }
  .omm-panel-inner { position: relative; z-index: 1; }

  /* PRODUITS */
  .omm-produits { display: flex; flex-wrap: nowrap; gap: 0; align-items: flex-start; }
  .omm-col { flex: 1 1 160px; min-width: 140px; max-width: 220px; padding: 0 20px 0 0; border-right: 1px solid var(--omm-border); }
  .omm-col:last-child { border-right: none; padding-right: 0; }
  .omm-col--featured { flex: 0 0 190px; max-width: 190px; }
  .omm-col-title {
    font-family: 'Syne', sans-serif; font-size: 11px; font-weight: 700;
    letter-spacing: 1.2px; text-transform: uppercase; color: var(--omm-grey-mid);
    padding: 0 0 12px; margin-bottom: 10px; border-bottom: 1px solid var(--omm-border);
    display: flex; align-items: center; gap: 6px; transition: color var(--omm-ease); white-space: nowrap;
  }
  .omm-col-title:hover { color: var(--omm-orange); }
  .omm-col-title--featured {
    background: var(--omm-orange) !important; color: var(--omm-white) !important;
    border-radius: 14px; padding: 16px !important; font-size: 14px !important;
    font-weight: 800; letter-spacing: 0; text-transform: none;
    border-bottom: none !important; margin-bottom: 12px; min-height: 140px;
    display: flex !important; flex-direction: column;
    align-items: flex-start; justify-content: space-between;
    position: relative; overflow: hidden; gap: 12px;
    transition: transform var(--omm-ease), box-shadow var(--omm-ease);
  }
  .omm-col-title--featured:hover { color: var(--omm-white) !important; transform: scale(1.02); box-shadow: 0 8px 24px rgba(242,101,34,.35); background: var(--omm-orange-dark) !important; }
  .omm-featured-emoji { font-size: 28px; line-height: 1; flex-shrink: 0; }
  .omm-featured-text { margin-top: auto; line-height: 1.25; word-break: break-word; }
  .omm-col-links li a {
    font-size: 13.5px; color: var(--omm-grey-dark); padding: 5px 8px; border-radius: 6px;
    display: block; white-space: nowrap;
    transition: color var(--omm-ease), background var(--omm-ease), padding-left var(--omm-ease);
    border-bottom: none !important;
  }
  .omm-col-links li a:hover { color: var(--omm-orange); background: var(--omm-orange-light); padding-left: 12px; }

  /* OFFRE */
  .omm-offre { display: flex; flex-wrap: wrap; gap: 0 32px; }
  .omm-offre-bloc { flex: 1 1 200px; min-width: 180px; max-width: 260px; margin-bottom: 28px; }
  .omm-offre-header { display: flex; align-items: center; gap: 12px; padding-bottom: 12px; margin-bottom: 10px; border-bottom: 2px solid var(--omm-orange-light); transition: border-color var(--omm-ease); }
  .omm-offre-header:hover { border-color: var(--omm-orange); }
  .omm-offre-icon { width: 40px; height: 40px; background: var(--omm-orange-light); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 20px; flex-shrink: 0; transition: background var(--omm-ease); }
  .omm-offre-header:hover .omm-offre-icon { background: var(--omm-orange); }
  .omm-offre-title { font-family: 'Syne', sans-serif; font-size: 14px; font-weight: 700; color: var(--omm-black); }
  .omm-offre-links li a { font-size: 13px; color: var(--omm-grey-mid); padding: 4px 8px; border-radius: 6px; display: flex; align-items: center; gap: 6px; transition: color var(--omm-ease), background var(--omm-ease), padding-left var(--omm-ease); border-bottom: none !important; }
  .omm-offre-links li a::before { content: '→'; font-size: 11px; opacity: 0; transform: translateX(-4px); transition: opacity var(--omm-ease), transform var(--omm-ease); }
  .omm-offre-links li a:hover { color: var(--omm-orange); background: var(--omm-orange-light); padding-left: 12px; }
  .omm-offre-links li a:hover::before { opacity: 1; transform: translateX(0); }

  /* MARQUAGE */
  .omm-marquage { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
  .omm-marquage-card { border: 1.5px solid var(--omm-border); border-radius: 14px; padding: 22px 20px; display: flex; flex-direction: column; gap: 8px; transition: border-color var(--omm-ease), box-shadow var(--omm-ease), transform var(--omm-ease); }
  .omm-marquage-card:hover { border-color: var(--omm-orange); box-shadow: 0 8px 32px rgba(242,101,34,.12); transform: translateY(-3px); }
  .omm-marquage-icon { font-size: 28px; }
  .omm-marquage-title { font-family: 'Syne', sans-serif; font-size: 15px; font-weight: 700; color: var(--omm-black); }
  .omm-marquage-desc { font-size: 12.5px; color: var(--omm-grey-mid); line-height: 1.5; }

} /* fin desktop */


/* ============================================================
   MOBILE ≤ 1024px — nav = drawer latéral
   ============================================================ */
@media (max-width: 1024px) {

  /* Neutraliser Elementor Kit sur mobile aussi — sauf le burger */
  .omm-wrap button:not(.omm-burger) {
    background-color: transparent !important;
    font-size: inherit !important;
    line-height: inherit !important;
    padding: unset !important;
    border-radius: unset !important;
  }

  /* ── Burger ── */
  .omm-mobile-bar { display: flex !important; align-items: center; justify-content: flex-end; }

  .omm-burger {
    display: flex !important; flex-direction: column !important;
    justify-content: center !important; align-items: center !important; gap: 5px !important;
    width: 44px !important; height: 44px !important;
    background: #F5C400 !important;
    border: none !important; border-radius: 10px !important;
    cursor: pointer !important; padding: 10px !important;
    transition: background .2s ease, box-shadow .2s ease !important;
    box-shadow: 0 2px 10px rgba(245,196,0,.45) !important;
  }
  .omm-burger:hover { background: #e0b300 !important; box-shadow: 0 4px 16px rgba(245,196,0,.6) !important; }
  .omm-burger-line {
    display: block !important; height: 2.5px !important; width: 22px !important;
    background: #0f0f0f !important; border-radius: 2px !important;
    transition: transform .3s ease, opacity .2s ease !important;
    transform-origin: center !important; flex-shrink: 0 !important;
  }
  .omm-burger--open .omm-burger-line:nth-child(1) { transform: translateY(7px) rotate(45deg) !important; }
  .omm-burger--open .omm-burger-line:nth-child(2) { opacity: 0 !important; transform: scaleX(0) !important; }
  .omm-burger--open .omm-burger-line:nth-child(3) { transform: translateY(-7px) rotate(-45deg) !important; }

  /* ── Overlay ── */
  .omm-overlay {
    display: block !important;
    position: fixed; inset: 0; background: rgba(0,0,0,.45);
    backdrop-filter: blur(3px); z-index: 10000;
    opacity: 0; pointer-events: none; transition: opacity .3s ease;
  }
  .omm-overlay--show { opacity: 1 !important; pointer-events: all !important; }

  /* ── Header du drawer ── */
  .omm-drawer-header {
    display: flex !important; align-items: center; justify-content: space-between;
    padding: 18px 20px; border-bottom: 1px solid var(--omm-border); flex-shrink: 0;
  }
  .omm-drawer-title { font-family: 'Syne', sans-serif; font-size: 16px; font-weight: 800; color: var(--omm-black); letter-spacing: .5px; }
  .omm-drawer-close {
    display: flex; align-items: center; justify-content: center;
    width: 36px; height: 36px; border-radius: 8px;
    border: none; background: var(--omm-orange-light); color: var(--omm-orange);
    cursor: pointer; transition: background var(--omm-ease), color var(--omm-ease);
  }
  .omm-drawer-close:hover { background: var(--omm-orange); color: var(--omm-white); }
  .omm-drawer-close svg { width: 16px; height: 16px; }

  /* ── Nav = drawer latéral ── */
  .omm-nav {
    position: fixed !important; top: 0 !important; right: 0 !important; bottom: 0 !important;
    width: var(--omm-drawer-w) !important; max-width: 92vw !important;
    background: var(--omm-white) !important; z-index: 10001 !important;
    display: flex !important; flex-direction: column !important;
    transform: translateX(110%) !important;
    transition: transform .35s cubic-bezier(.4,0,.2,1) !important;
    box-shadow: -8px 0 48px rgba(0,0,0,.15) !important;
    overflow: hidden !important;
  }
  .omm-nav.omm-nav--open {
    transform: translateX(0) !important;
  }

  /* Menu scrollable à l'intérieur du drawer */
  .omm-menu {
    display: flex !important; flex-direction: column !important;
    overflow-y: scroll !important;
    -webkit-overflow-scrolling: touch !important;
    flex: 1 1 0 !important; min-height: 0 !important;
  }

  /* Items niveau 1 */
  .omm-menu > .omm-item > .omm-link {
    font-family: 'Syne', sans-serif; font-weight: 700; font-size: 14px; color: var(--omm-black);
    padding: 16px 20px; border-bottom: 1px solid var(--omm-border);
    display: flex; align-items: center; justify-content: space-between;
    transition: color var(--omm-ease), background var(--omm-ease);
    background: transparent;
  }
  .omm-menu > .omm-item > .omm-link:hover,
  .omm-menu > .omm-item.omm-open > .omm-link { color: var(--omm-orange); background: var(--omm-orange-light); }

  .omm-chevron { width: 16px; height: 16px; flex-shrink: 0; transition: transform .25s ease; }
  .omm-item.omm-open > .omm-link .omm-chevron { transform: rotate(180deg); }

  /* Panel accordéon */
  .omm-panel {
    max-height: 0 !important; overflow: hidden !important;
    transition: max-height .4s ease !important;
    background: #faf9f7; border-bottom: 1px solid var(--omm-border);
    position: static !important; transform: none !important;
    opacity: 1 !important; pointer-events: all !important;
    box-shadow: none !important; padding: 0 !important;
    width: auto !important;
  }
  .omm-item.omm-open > .omm-panel { max-height: 4000px !important; }
  .omm-panel-inner { padding: 0; }

  /* PRODUITS mobile */
  .omm-produits { display: flex; flex-direction: column; }
  .omm-col { border-right: none; padding: 0; }
  .omm-col-title {
    font-family: 'Syne', sans-serif; font-size: 11px; font-weight: 700;
    letter-spacing: .8px; text-transform: uppercase; color: var(--omm-grey-mid);
    padding: 11px 20px; display: flex; align-items: center; gap: 8px;
    border-bottom: 1px solid var(--omm-border); background: var(--omm-white);
    transition: color var(--omm-ease); white-space: normal;
  }
  .omm-col-title:hover { color: var(--omm-orange); }
  .omm-col--featured .omm-col-title--featured {
    background: var(--omm-orange) !important; color: var(--omm-white) !important;
    border-radius: 10px; margin: 10px 16px; padding: 14px 16px !important;
    font-size: 13px !important; font-weight: 800; letter-spacing: 0; text-transform: none;
    border-bottom: none !important; flex-direction: row !important; min-height: auto;
    align-items: center; gap: 8px;
    box-shadow: 0 4px 16px rgba(242,101,34,.25);
  }
  .omm-col--featured .omm-col-title--featured:hover { background: var(--omm-orange-dark) !important; color: var(--omm-white) !important; }
  .omm-featured-emoji { font-size: 18px; flex-shrink: 0; }
  .omm-featured-text { line-height: 1.2; }
  .omm-col-links { background: var(--omm-white); }
  .omm-col-links li a { display: block; padding: 10px 20px 10px 28px; font-size: 13.5px; color: var(--omm-grey-dark); border-bottom: 1px solid var(--omm-border); transition: color var(--omm-ease), background var(--omm-ease), padding-left var(--omm-ease); }
  .omm-col-links li a:hover { color: var(--omm-orange); background: var(--omm-orange-light); padding-left: 32px; }
  .omm-col-links li:last-child a { border-bottom: none; }

  /* OFFRE mobile */
  .omm-offre { display: flex; flex-direction: column; }
  .omm-offre-bloc { border-bottom: 1px solid var(--omm-border); }
  .omm-offre-bloc:last-child { border-bottom: none; }
  .omm-offre-header { display: flex; align-items: center; gap: 12px; padding: 12px 20px; transition: background var(--omm-ease); }
  .omm-offre-header:hover { background: var(--omm-orange-light); }
  .omm-offre-icon { width: 36px; height: 36px; flex-shrink: 0; background: var(--omm-orange-light); border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 18px; transition: background var(--omm-ease); }
  .omm-offre-header:hover .omm-offre-icon { background: var(--omm-orange); }
  .omm-offre-title { font-family: 'Syne', sans-serif; font-size: 14px; font-weight: 700; color: var(--omm-black); }
  .omm-offre-links { background: var(--omm-white); }
  .omm-offre-links li a { display: block; padding: 9px 20px 9px 68px; font-size: 13px; color: var(--omm-grey-mid); border-top: 1px solid var(--omm-border); transition: color var(--omm-ease), background var(--omm-ease); }
  .omm-offre-links li a:hover { color: var(--omm-orange); background: var(--omm-orange-light); }

  /* MARQUAGE mobile */
  .omm-marquage { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; padding: 12px 16px; }
  .omm-marquage-card { display: flex; flex-direction: column; gap: 6px; border: 1.5px solid var(--omm-border); border-radius: 12px; padding: 14px 12px; background: var(--omm-white); transition: border-color var(--omm-ease), box-shadow var(--omm-ease); }
  .omm-marquage-card:hover { border-color: var(--omm-orange); box-shadow: 0 4px 16px rgba(242,101,34,.12); }
  .omm-marquage-icon { font-size: 22px; }
  .omm-marquage-title { font-family: 'Syne', sans-serif; font-size: 12.5px; font-weight: 700; color: var(--omm-black); line-height: 1.2; }
  .omm-marquage-desc { display: none; }

} /* fin mobile */

@media (max-width: 480px) {
  .omm-marquage { grid-template-columns: 1fr; }
}
