:root{
  --brand-primary:#20a3e5;
  --brand-dark:#602b69;
  --brand-green:#10b981;
  --brand-sky:#e90e5b;
  --ink:#1a1a1a;
  --rail:#e9e4d8;
}

.menu-iconico-izquierdo{
  position: fixed;
  top: 0;
  left: 0;
  width: 64px;
  height: 100vh;
  background-color: #ffffff;
  border-right: 1px solid var(--rail);
  transition: width 0.3s;
  z-index: 1000;
  display: flex;
  flex-direction: column;
  align-items: center;
  overflow: hidden;
}

.menu-iconico-izquierdo:hover{ width: 240px; }

.menu-iconico-izquierdo .logo-menu{ padding: 1rem; }

.menu-iconico-izquierdo .logo-menu img{
  width: 32px;
  height: auto;
  transition: transform 0.3s;
}

.navegacion-iconos{
  list-style: none;
  padding: 0;
  margin: 1rem 0;
  width: 100%;
  flex: 1;
}

.navegacion-iconos li{ width: 100%; }

.navegacion-iconos li a{
  display: flex;
  align-items: center;
  padding: 0.8rem 1rem;
  gap: 1rem;
  text-decoration: none;
  color: #111;
  transition: background 0.3s;
}

.navegacion-iconos li:hover{ background-color: #f0f0f0; }

.navegacion-iconos i{ font-size: 1.2rem; }

.texto{
  opacity: 0;
  transition: opacity 0.3s;
  white-space: nowrap;
}

.menu-iconico-izquierdo .texto{ opacity: 0; transition: opacity 0.3s; }
.menu-iconico-izquierdo:hover .texto{ opacity: 1; }

.separador{
  width: 80%;
  border: 0;
  height: 1px;
  background-color: #ccc;
  margin: 1rem auto;
}

.panel-clientes{
  margin-top: auto;
  padding: 6px 0 10px;
  width: 100%;
}

.panel-clientes a.cta{
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 4px 8px;
  padding: 10px 12px;
  border-radius: 10px;
  font-weight: 600;
  text-decoration: none;
  color: #111;
}

.panel-clientes a.cta:hover{ filter: brightness(0.98); }

.panel-clientes a .ico{ width: 26px; text-align: center; }

.panel-clientes .texto{
  opacity: 0;
  transition: opacity 0.3s;
  white-space: nowrap;
}

.menu-iconico-izquierdo:hover .panel-clientes .texto{ opacity: 1; }

.panel-separator{
  height: 1px;
  background: rgba(0, 0, 0, 0.12);
  margin: 0.4rem 0.8rem;
}

.cta-portal{ background:#f4eaff; color:var(--brand-dark); }
.cta-portal .ico{ color:var(--brand-dark); }

.cta-tarjetas{ background:#e6f6ff; color:var(--brand-primary); }
.cta-tarjetas .ico{ color:var(--brand-primary); }

.cta-whatsapp{ background:#e9f9f0; color:#1d7f52; }
.cta-whatsapp .ico{ color:#1d7f52; }

.cta-admin{
  background: linear-gradient(135deg, #602b69, #3f1f52);
  color: #fff;
}
.cta-admin .ico{ color:#fff; }
.cta-admin span{ color:#fff; }

.navegacion-iconos li a.menu-item{
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px 12px 14px;
  color: var(--ink);
  text-decoration: none;
}
.navegacion-iconos li a.menu-item .ico{ width: 26px; text-align: center; font-size: 1.15rem; }

.navegacion-iconos li a.menu-item::after{
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%) scaleY(0);
  width: 4px;
  height: 70%;
  border-radius: 999px;
  background: currentColor;
  opacity: .14;
  transition: transform .22s ease, opacity .22s ease;
}

.navegacion-iconos li:hover a.menu-item::after,
.navegacion-iconos li a.menu-item.is-active::after,
.navegacion-iconos li a.menu-item[aria-current="page"]::after{
  transform: translateY(-50%) scaleY(1);
  opacity: .9;
}

.navegacion-iconos li a.menu-item:hover{ background:#f6f6f6; }

.navegacion-iconos li.servicios  a .ico{ color:var(--brand-primary); }
.navegacion-iconos li.nosotros   a .ico{ color:var(--brand-dark); }
.navegacion-iconos li.galeria    a .ico{ color:var(--brand-sky); }
.navegacion-iconos li.contacto   a .ico{ color:var(--brand-green); }

.navegacion-iconos li.servicios  a{ color:var(--brand-primary); }
.navegacion-iconos li.nosotros   a{ color:var(--brand-dark); }
.navegacion-iconos li.galeria    a{ color:var(--brand-sky); }
.navegacion-iconos li.contacto   a{ color:var(--brand-green); }

.menu-iconico-izquierdo:hover .navegacion-iconos li a{ color:var(--ink); }
.menu-iconico-izquierdo:hover .navegacion-iconos li.servicios a .ico{ color:var(--brand-primary); }
.menu-iconico-izquierdo:hover .navegacion-iconos li.nosotros  a .ico{ color:var(--brand-dark); }
.menu-iconico-izquierdo:hover .navegacion-iconos li.galeria   a .ico{ color:var(--brand-sky); }
.menu-iconico-izquierdo:hover .navegacion-iconos li.contacto  a .ico{ color:var(--brand-green); }

.menu-iconico-izquierdo a:focus-visible,
.menu-lateral a:focus-visible{
  outline: 3px solid var(--brand-primary);
  outline-offset: 2px;
  border-radius: 10px;
}

@media (min-width: 768px){
  .boton-menu{ display: none !important; }
  .menu-lateral{ display: none; }
}

@media (max-width: 768px){
  .menu-iconico-izquierdo{ display: none; }
}

/* Banner superior movil */
.mobile-top-banner{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 64px;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1001;
  box-shadow: 0 8px 20px rgba(0,0,0,0.08);
  transition: transform 0.25s ease, opacity 0.2s ease;
}
.mobile-top-banner__link{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 6px 16px;
}
.mobile-top-banner img{
  height: 36px;
  width: auto;
}
.mobile-top-banner.is-hidden{
  transform: translateY(-120%);
  opacity: 0;
}

/* Barra inferior de iconos (movil) */
.mobile-icon-bar{
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  height: 76px;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: space-around;
  gap: 4px;
  padding: 0 8px calc(env(safe-area-inset-bottom, 0));
  z-index: 1001;
  box-shadow: 0 -8px 20px rgba(0,0,0,0.08);
}
.mobile-icon-bar__item{
  flex: 1;
  height: 56px;
  border-radius: 12px;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  color: #111;
  text-decoration: none;
  border: none;
  background: transparent;
}
.mobile-icon-bar__item i{
  font-size: 1.05rem;
}
.mobile-icon-bar__label{
  display: block;
  font-size: 0.56rem;
  line-height: 1;
  font-weight: 800;
  letter-spacing: 0.01em;
  white-space: nowrap;
  color: currentColor;
}
.mobile-icon-bar__item--servicios{ color: var(--brand-primary); }
.mobile-icon-bar__item--nosotros{ color: var(--brand-dark); }
.mobile-icon-bar__item--galeria{ color: var(--brand-sky); }
.mobile-icon-bar__item--contacto{ color: var(--brand-green); }
.mobile-icon-bar__item.is-active{
  background: rgba(0,0,0,0.05);
}
.mobile-icon-bar__menu{
  background: #111;
  color: #fff;
  box-shadow: 0 10px 18px rgba(0,0,0,0.2);
}

.mobile-icon-bar--home{
  height: 88px;
}

.mobile-icon-bar--home .mobile-icon-bar__item{
  height: 64px;
  gap: 4px;
}

.mobile-icon-bar--home .mobile-icon-bar__item i{
  font-size: 1.47rem;
}

.mobile-icon-bar--home .mobile-icon-bar__label{
  font-size: 0.78rem;
}

@media (min-width: 769px){
  .mobile-top-banner,
  .mobile-icon-bar{
    display: none;
  }
}

@media (max-width: 768px){
  .page-wrapper{
    padding-top: 72px;
    padding-bottom: 88px;
  }
}

.menu-lateral{
  background: #fff;
  padding-bottom: calc(16px + env(safe-area-inset-bottom, 0));
}

.menu-lateral ul li a{
  padding: 10px 18px;
  display: flex;
  align-items: center;
  gap: 14px;
}

.menu-lateral ul li i{
  width: 26px;
  text-align: center;
}

.menu-lateral hr{
  border: none;
  border-top: 1px solid #e0e0e0;
  margin: 10px 20px;
}

.menu-lateral .cliente-links{ position: sticky; bottom: 0; background: linear-gradient(#fff,#fff); padding: 4px 0 6px; }
.menu-lateral .cliente-links a{ display: flex; align-items: center; gap: 10px; margin: 4px 16px; padding: 10px 12px; border-radius: 12px; font-weight: 700; text-decoration: none; }
.menu-lateral .cliente-links a.cta-portal{ background: rgba(96,43,105,0.12); color:var(--brand-dark); }
.menu-lateral .cliente-links a.cta-tarjetas{ background: rgba(32,163,229,0.12); color:var(--brand-primary); }
.menu-lateral .cliente-links a.cta-whatsapp{ background: rgba(29,127,82,0.12); color:#1d7f52; }
.menu-lateral .cliente-links a.cta-admin{ background: linear-gradient(135deg, rgba(96,43,105,0.92), rgba(63,31,82,0.92)); color:#fff; }

.menu-iconico-izquierdo .panel-clientes a.cta-portal{ background: rgba(96,43,105,0.12); }
.menu-iconico-izquierdo .panel-clientes a.cta-tarjetas{ background: rgba(32,163,229,0.12); }
.menu-iconico-izquierdo .panel-clientes a.cta-whatsapp{ background: rgba(29,127,82,0.12); }
.menu-iconico-izquierdo .panel-clientes a.cta-admin{ color:#fff; }

.panel-clientes .panel-separator,
.menu-lateral .panel-separator{
  height: 1px;
  background: rgba(0,0,0,0.12);
  margin: 0.25rem 1rem;
}

/* Botón menú móvil con icono */
.boton-menu{
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #111;
  color: #fff;
  box-shadow: 0 8px 16px rgba(0,0,0,0.18);
}
.boton-menu i{ font-size: 1.1rem; }

.menu-lateral .cta-admin{ color:#fff; }
.menu-lateral .cta-admin i{ color:#fff; }
.menu-lateral .cta-admin span{ color:#fff; }

.menu-lateral .servicios i{ color:var(--brand-primary); }
.menu-lateral .nosotros  i{ color:var(--brand-dark); }
.menu-lateral .galeria   i{ color:var(--brand-sky); }
.menu-lateral .contacto  i{ color:var(--brand-green); }

@media (prefers-reduced-motion: reduce){
  .menu-iconico-izquierdo, .texto, .navegacion-iconos li a.menu-item::after{ transition:none !important; }
}
