:root.wom-lock,
html.wom-lock,
html.wom-lock body{
  overflow: hidden;
}

.wom-root{
  --wom-z-index: 99999;
  --wom-level-width: 330px;
  --wom-two-level-width: 660px;
  --wom-panel-bg: #ffffff;
  --wom-panel-text: #111111;
  --wom-layout-bp: 1024;

  --wom-btn-offset: 24px;
  --wom-btn-bottom: 24px;
  --wom-btn-size: 44px;
  --wom-btn-radius: 999px;
  --wom-btn-bg: #ffffff;
  --wom-btn-color: #111111;

  position: relative;
  z-index: var(--wom-z-index);
}

.wom-overlay{
  position: fixed;
  inset: 0;
  opacity: 0;
  pointer-events: none;
  background: rgba(0,0,0,.35);
  transition: opacity .22s ease;
  z-index: calc(var(--wom-z-index) - 1);
}

.wom-panel{
  position: fixed;
  top: 0;
  bottom: 0;
  width: var(--wom-level-width);
  max-width: 95vw;
  background: var(--wom-panel-bg);
  color: var(--wom-panel-text);
  z-index: var(--wom-z-index);
  box-shadow: 0 0 24px rgba(0,0,0,.18);
  transform: translateX(-110%);
  will-change: transform, width;
  transition: transform .28s cubic-bezier(.2,.8,.2,1), width .28s cubic-bezier(.2,.8,.2,1);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.wom-panel--right{ right: 0; left: auto; transform: translateX(110%); }
.wom-panel--left{ left: 0; right: auto; transform: translateX(-110%); }

.wom-root.wom-open .wom-overlay{ opacity: 1; pointer-events: auto; }
.wom-root.wom-open .wom-panel--right{ transform: translateX(0); }
.wom-root.wom-open .wom-panel--left{ transform: translateX(0); }

.wom-panel-inner{
  height: 100%;
  display: flex;
  flex-direction: column;
}

.wom-above-logo,
.wom-under-logo,
.wom-footer{
  padding: 14px 28px;
}

.wom-header{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 28px;
}

.wom-root.wom-is-desktop .wom-above-logo,
.wom-root.wom-is-desktop .wom-header,
.wom-root.wom-is-desktop .wom-under-logo,
.wom-root.wom-is-desktop .wom-footer{
  align-self: flex-start;
  width: var(--wom-level-width);
}

.wom-root.wom-is-desktop .wom-hback{ display: none !important; }

.wom-logo{
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  color: inherit;
  line-height: 1;
}

.wom-logo img{ height: 34px; width: auto; display: block; }

.wom-close{
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: inherit;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  line-height: 1;
}

.wom-close:hover{ opacity: .75; }

.wom-hback{
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: inherit;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  line-height: 1;
  visibility: hidden; 
}
.wom-hback:hover{ opacity: .75; }

.wom-root.wom-show-back .wom-hback{ visibility: visible; }
.wom-root.wom-show-back .wom-logo{ display: none; }

.wom-content{
  flex: 1;
  overflow: hidden;
}

.wom-desktop{ display: none; height: 100%; }
.wom-mobile{ display: none; height: 100%; }

.wom-root.wom-is-desktop .wom-desktop{ display: flex; }
.wom-root.wom-is-mobile .wom-mobile{ display: block; }

.wom-col{
  height: 100%;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable;
}
.wom-col--root{ width: var(--wom-level-width); padding: 6px 0 12px; }
.wom-col--sub{
  width: var(--wom-level-width);
  border-left: 1px solid rgba(0,0,0,.08);
  
  opacity: 0;
  pointer-events: none;
  transform: translateX(18px);
  will-change: opacity, transform;
  transition: opacity .28s cubic-bezier(.2,.8,.2,1), transform .28s cubic-bezier(.2,.8,.2,1);
}

.wom-root.wom-is-desktop.wom-has-sub .wom-col--sub{
  opacity: 1;
  pointer-events: auto;
  transform: translateX(0);
}
.wom-root.wom-is-desktop.wom-has-sub .wom-panel{ width: var(--wom-two-level-width); }

.wom-root.wom-is-desktop .wom-col--root .sub-menu{
  display: none !important;
}

.wom-root.wom-sub-animating{
  
}

.wom-mobile-views{
  height: 100%;
  display: flex;
  width: 100%;
  transition: transform .25s ease;
}
.wom-mview{ flex: 0 0 100%; width: 100%; height: 100%; overflow: hidden; display:flex; flex-direction: column; }
.wom-mheader{
  padding: 10px 12px;
}
.wom-mback{
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font-size: 22px;
}
.wom-mbody{ flex: 1; overflow: auto; -webkit-overflow-scrolling: touch; padding: 6px 0 12px; }

.wom-subcontent{ height: 100%; display:flex; flex-direction: column; }
.wom-subheader{ padding: 10px 12px 0; }
.wom-back{
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font-size: 22px;
}

.wom-subbody{ padding: 6px 0 12px; overflow:auto; -webkit-overflow-scrolling: touch; }

/* Level 1 bar (below featured image(s)): back + parent title + view all */
.wom-l1bar{ display:flex; align-items:center; justify-content:space-between; padding: 0 28px 10px; gap: 12px; }
.wom-l1bar__left{ display:flex; align-items:center; min-width:0; }
.wom-l1bar__right{ flex: 0 0 auto; }
.wom-l1bar__back{ display:inline-flex; align-items:center; gap:10px; background:transparent; border:0; padding: 10px 0; cursor:pointer; color: inherit; font: inherit; text-align:left; min-width:0; }
.wom-l1bar__icon{ font-size: 18px; line-height: 1; }
.wom-l1bar__title{ white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.wom-l1bar__viewall{ text-decoration: underline; }


.wom-subimage{ padding: 0 28px 12px; }
.wom-subimage img{ width: 100%; height: auto; display: block; }

/* Submenu top block (0.3.8)
   Minimal, non-opinionated styles: only layout helpers and safe defaults. */
.wom-subtop{ display:block; width:100%; padding: 0 28px 12px; }
.wom-subtop__grid{ display:flex; gap:12px; width:100%; }
.wom-subtop__item{ flex:1 1 0%; min-width:0; }
.wom-subtop__link{ display:block; width:100%; }
.wom-subtop__img{ display:block; width:100%; height:auto; }
.wom-subtop__text{ margin-top:10px; }
.wom-subtop__text-link{ text-decoration:underline; }

@media (max-width: 480px){
  .wom-subtop__grid{ flex-wrap:wrap; }
}

.wom-chapter{ margin: 0; padding: 0; }
.wom-chapter .wom-subimage{ padding: 0 28px 12px; }

.wom-menu,
.wom-menu-root,
.wom-menu-mobile{
  list-style: none;
  margin: 0;
  padding: 0;
}

.wom-menu li,
.wom-menu-root li,
.wom-menu-mobile li{ margin:0; padding:0; }

.wom-menu a,
.wom-menu-root a,
.wom-menu-mobile a{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 28px;
  text-decoration: none;
  color: var(--wom-color, var(--wom-panel-text));
  font-size: var(--wom-font-size, 14px);
  font-weight: var(--wom-font-weight, 500);
  text-transform: var(--wom-text-transform, uppercase);
  letter-spacing: var(--wom-letter-spacing, 0px);
  text-decoration-line: var(--wom-underline, none);
}

.wom-menu a:hover,
.wom-menu-root a:hover,
.wom-menu-mobile a:hover{
  color: var(--wom-hover-color, var(--wom-panel-text));
  text-decoration-line: var(--wom-hover-underline, none);
  opacity: .85;
}

.wom-indicator{
  width: 14px;
  height: 14px;
  position: relative;
  flex: 0 0 14px;
  color: inherit;
  opacity: .65;
}
.wom-indicator:before,
.wom-indicator:after{
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background: currentColor;
  border-radius: 1px;
}
.wom-indicator:before{ width: 12px; height: 2px; }
.wom-indicator:after{ width: 2px; height: 12px; }

.wom-footer{
  border-top: 1px solid rgba(0,0,0,.08);
  margin-top: auto;
  padding: 18px 28px;
}

.wom-footer .idioma-sidebar{ width: 100%; }

.wom-footer .wpml-ls-legacy-list-horizontal ul{
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: center;
  gap: 18px;
}

.wom-footer .wpml-ls-legacy-list-horizontal li{ margin: 0; padding: 0; }

.wom-footer .wpml-ls-legacy-list-horizontal a{
  padding: 0;
  background: transparent;
  border: 0;
  text-decoration: none;
  color: inherit;
  font-size: 12px;
  letter-spacing: 1px;
}

.wom-footer .wpml-ls-current-language a{
  font-weight: 700;
}

.wom-toggle{
  position: fixed;
  bottom: var(--wom-btn-bottom);
  right: var(--wom-btn-offset);
  width: var(--wom-btn-size);
  height: var(--wom-btn-size);
  border: 0;
  border-radius: var(--wom-btn-radius);
  background: var(--wom-btn-bg);
  color: var(--wom-btn-color);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 10px 25px rgba(0,0,0,.18);
  z-index: var(--wom-z-index);
}
.wom-toggle--left{ left: var(--wom-btn-offset); right: auto; }

.wom-icon{
  width: 22px;
  height: 16px;
  display: inline-flex;
  flex-direction: column;
  justify-content: space-between;
}
.wom-icon span{ height: 2px; background: currentColor; border-radius: 2px; display:block; }

@media (prefers-reduced-motion: reduce){
  .wom-overlay, .wom-panel, .wom-mobile-views{ transition: none; }
}

@media (min-width: 0px){
  
}

@media (min-width: 1024px){
  #wom-panel .wom-col--sub .wom-header--sub{
    position:sticky!important;
    top:0!important;
    z-index:30!important;
    background:#fff!important;
    height:var(--wom-root-header-h, 92px)!important;
    display:flex;
    align-items:center!important;
    justify-content:space-between!important;
    padding:0 16px!important;
    border-bottom:1px solid rgba(0,0,0,.08)!important;
  }
  #wom-root.wom-has-sub #wom-panel .wom-col--sub .wom-header--sub .wom-hback{
    display:inline-flex!important;
    visibility:visible!important;
    opacity:1!important;
    pointer-events:auto!important;
    margin-right:auto!important;
  }
  #wom-root:not(.wom-has-sub) #wom-panel .wom-col--sub .wom-header--sub .wom-hback{display:none!important;}
  #wom-panel .wom-col--sub .wom-header--sub .wom-close{
    display:inline-flex!important;
    visibility:visible!important;
    opacity:1!important;
    pointer-events:auto!important;
    margin-left:auto!important;
  }
  #wom-panel .wom-col--sub .wom-subcontent--desktop{padding-top:0!important;margin-top:0!important;}
}
