/*========================================================
=  Nitro · Simulador (Theme Panel) – Limpieza & Chat Móvil
========================================================*/

/* Variables */
:root {
  --sn-gap: 1rem;
  --sn-left-w: 180px;
  --sn-left-mini: 48px;
  --sn-right-w: 340px;
  --sn-bg: #0e0e0e;
  --sn-btn-bg: #2b2b2b;
  --sn-btn-bg-h: #383838;
  --sn-btn-fg: #d1d1d1;
  --sn-btn-fg-on: #fff;
  --sn-primary: #c90d05;
  --sn-radius: 6px;
}

/* Wrapper */
.sn-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--sn-gap);
  box-sizing: border-box;
}

/* Top Row (Desktop) */
.sn-row-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sn-gap);
  padding-left: 0;
  padding-right: var(--sn-gap);
  box-sizing: border-box;
}

/* Logo */
.sn-logo {
  width: var(--sn-left-w);
  height: 60px;
  background: #0e0e0e !important;
  border-radius: var(--sn-radius);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 0.2rem 0;
  box-sizing: border-box;
}
.sn-logo img {
  max-height: 32px;
  width: auto;
}
.sn-sim-name {
  margin-top: 0.2rem;
  font-size: 0.75rem;
  color: var(--sn-btn-fg);
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  width: 100%;
}

/* Top Menu */
.sn-menu-sup {
  flex: 1 1 auto;
  height: 60px;
  background: #0e0e0e;
  border-radius: var(--sn-radius);
  display: flex;
  align-items: center;
  gap: var(--sn-gap);
  padding: 0 1rem;
  box-sizing: border-box;
  overflow-x: auto;
  white-space: nowrap;
}

/* Right Header */
.sn-header-right {
  flex: 1 1 auto;
  height: 60px;
  background: #0e0e0e;
  border-radius: var(--sn-radius);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--sn-gap);
  padding: 0 1rem;
  box-sizing: border-box;
  overflow: hidden;
}

/* Buttons */
.sn-btn-top,
.sn-btn-left {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.45rem 0.9rem;
  border: none;
  border-radius: var(--sn-radius);
  background: var(--sn-btn-bg);
  color: var(--sn-btn-fg);
  cursor: pointer;
  transition: background 0.2s;
  white-space: nowrap;
  box-sizing: border-box;
}
.sn-btn-top {
  height: 36px;
}
.sn-btn-top:hover,
.sn-btn-left:hover {
  background: var(--sn-btn-bg-h);
}
.sn-btn-top.on,
.sn-btn-left.on {
  background: var(--sn-primary);
  color: var(--sn-btn-fg-on);
}
.sn-btn-top svg,
.sn-btn-left svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
}

/* Left Menu */
.sn-menu-izq {
  width: var(--sn-left-w);
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  padding: var(--sn-gap) 0.5rem;
  background: #0e0e0e;
  border-radius: var(--sn-radius);
  box-sizing: border-box;
}
.sn-btn-left span {
  white-space: nowrap;
}

/* Main Grid */
.sn-main {
  display: grid;
  gap: var(--sn-gap);
  grid-template-columns: var(--sn-left-w) 1fr var(--sn-right-w);
  box-sizing: border-box;
}

/* Desktop Sidebar */
.sn-barra-lat-desktop {
  display: flex;
  flex-direction: column;
  gap: var(--sn-gap);
  box-sizing: border-box;
}

/* Mobile Sidebar (hidden by default) */
.sn-barra-lat-mobile {
  display: none;
  flex-direction: column;
  gap: var(--sn-gap);
  margin-top: var(--sn-gap);
  box-sizing: border-box;
}

/* Desktop Chat (embedded) */
.sn-chat-desktop {
  background: var(--sn-bg);
  border-radius: var(--sn-radius);
  margin-bottom: var(--sn-gap);
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}
.sn-chat-desktop .sn-chat-item {
  width: 100%;
  position: relative;
}

/* Floating Mobile Chat Trigger */
.sn-chat-mobile {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 9999;
}
.sn-chat-toggle {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  border: none;
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.25);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
}
.sn-chat-toggle:hover {
  transform: scale(1.05);
  box-shadow: 0 6px 25px rgba(0, 0, 0, 0.3);
}
.sn-chat-toggle:active {
  transform: scale(0.95);
}
.sn-chat-badge {
  position: absolute;
  top: -5px;
  right: -5px;
  background: #ff4757;
  color: #fff;
  border-radius: 50%;
  width: 20px;
  height: 20px;
  font-size: 12px;
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: sn-chat-pulse 2s infinite;
}
@keyframes sn-chat-pulse {
  50% {
    transform: scale(1.1);
  }
}

/* Mobile Chat Panel (initial hidden, open via .open) */
@media (max-width: 991px) {
  .sn-chat-container {
    position: fixed !important;
    left: 8px !important;
    right: 8px !important;
    bottom: 0 !important;
    top: auto !important;
    width: auto !important;
    max-width: calc(100% - 16px) !important; /* margen visual */
    height: 80vh !important;
    max-height: 80vh !important;
    margin: 0 !important;
    background: #0f1620 !important;
    border-radius: 18px !important; /* ahora todas las esquinas redondeadas */
    box-shadow: 0 -2px 18px rgba(0, 0, 0, 0.4);
    display: flex !important;
    flex-direction: column !important;
    transform: translateY(100%);
    opacity: 0;
    visibility: hidden;
    transition: transform 0.28s ease, opacity 0.25s, bottom 0.25s; /* añadimos bottom */
    z-index: 10000;
  }
  .sn-chat-container.open {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
  .sn-chat-header {
    flex: 0 0 auto !important;
    background: linear-gradient(135deg, #213245, #162330) !important;
    border-bottom: 1px solid #263544 !important;
    padding: 10px 14px !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px;
  }
  .sn-chat-header h4 {
    font-size: 14px !important;
    margin: 0;
    flex: 1;
    font-weight: 600;
  }
  .sn-chat-mobile-wrapper {
    flex: 1 1 auto !important;
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    overflow: hidden !important;
  }
  .sn-chat-mobile-wrapper #nitro-chat-container {
    flex: 1 1 auto !important;
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    background: #0d1421 !important;
    border-radius: 0 !important;
  }
  .sn-chat-mobile-wrapper #nitro-chat-container .chat-header {
    display: none !important;
  }
  .sn-chat-mobile-wrapper #nitro-chat-container .chat-messages {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    padding: 8px 10px !important;
    background: #0d1421 !important;
  }
  .sn-chat-mobile-wrapper #nitro-chat-container .chat-input-container {
    flex: 0 0 auto !important;
    display: block !important;
    background: #141e29 !important;
    border-top: 1px solid #263544 !important;
    padding: 0 !important;
  }
  .sn-chat-mobile-wrapper #nitro-chat-container .chat-input-row {
    display: flex !important;
    gap: 8px !important;
    padding: 8px 10px !important;
    align-items: center;
  }
  .sn-chat-mobile-wrapper #nitro-chat-container .chat-message-input,
  .sn-chat-mobile-wrapper #nitro-chat-container #chat-message-input,
  .sn-chat-mobile-wrapper #nitro-chat-container [id^="chat-message-input-"] {
    flex: 1 1 auto !important;
    min-height: 36px !important;
    border-radius: 16px !important;
    background: #243140 !important;
    border: 1px solid #3b4a59 !important;
    padding: 8px 12px !important;
    font-size: 14px !important;
    color: #e3e8ec !important;
  }
  .sn-chat-mobile-wrapper #nitro-chat-container .chat-send-btn,
  .sn-chat-mobile-wrapper #nitro-chat-container .send-message {
    background: #075e54 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 16px !important;
    padding: 8px 14px !important;
    font-size: 14px !important;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .sn-chat-overlay {
    position: fixed;
    inset: 0;
    background: rgba(10, 14, 20, 0.55);
    backdrop-filter: blur(2px);
    z-index: 9998;
  }
  body.sn-chat-lock {
    /* Evitar bloquear el flujo desde CSS; el JS gestionará position/top inline
       para preservar la posición cuando se abra el chat. */
    overflow: hidden !important;
    position: static !important;
    width: auto !important;
    -webkit-tap-highlight-color: transparent;
    touch-action: auto;
  }
  .sn-chat-toggle.chat-open {
    transform: scale(0.01) !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }
  /* Cuando el teclado esté abierto (JS ajusta --sn-kb-offset) */
  .sn-chat-container.keyboard-open {
    bottom: var(--sn-kb-offset, 0) !important;
  }
  /* Asegura que mensajes no queden tapados: añadir padding extra dinámico */
  .sn-chat-container.keyboard-open .chat-messages {
    padding-bottom: calc(8px + var(--sn-kb-offset, 0)) !important;
  }

  /* NUEVO: asegurar que modales grandes (términos/condiciones) sean scrollables
     y que el botón de aceptar quede visible aun cuando body tenga .sn-chat-lock */
  body.sn-chat-lock [role="dialog"],
  body.sn-chat-lock .modal,
  body.sn-chat-lock .terms-modal,
  body.sn-chat-lock .sn-terms-container,
  body.sn-chat-lock .woocommerce-terms-and-conditions,
  body.sn-chat-lock #sn-terms-container,
  body .sn-terms-container, /* por si el modal se inyecta dentro del DOM fuera de body.sn-chat-lock */
  [role="dialog"].sn-terms,
  .terms-modal.sn-terms {
    position: fixed !important;
    top: 6vh !important;
    left: 8px !important;
    right: 8px !important;
    bottom: 6vh !important;
    max-height: calc(100vh - 12vh) !important;
    overflow: auto !important;
    -webkit-overflow-scrolling: touch !important;
    z-index: 11000 !important; /* más alto que chat overlay */
    background: #0f1620 !important;
    border-radius: 12px !important;
    padding: 12px !important;
    box-sizing: border-box !important;
    touch-action: pan-y !important;
  }

  /* Botón aceptar: sticky y visible */
  body.sn-chat-lock [role="dialog"] .accept,
  body.sn-chat-lock .modal .accept,
  body.sn-chat-lock .terms-accept,
  body.sn-chat-lock .sn-terms-accept,
  body.sn-chat-lock .woocommerce-terms-and-conditions .button,
  body.sn-chat-lock .accept-button,
  body.sn-chat-lock button[data-action="accept"],
  body.sn-chat-lock button[name="accept"],
  body.sn-chat-lock input[type="submit"],
  .sn-terms .accept,
  .sn-terms .accept-button {
    position: sticky !important;
    bottom: 0 !important;
    display: block !important;
    width: calc(100% - 24px) !important;
    margin: 8px 12px 0 12px !important;
    z-index: 11010 !important;
    border-radius: 10px !important;
    box-shadow: 0 -6px 18px rgba(0, 0, 0, 0.35);
    background-color: var(--sn-primary) !important;
    color: var(--sn-btn-fg-on) !important;
  }

  /* Añadir espacio al contenido interno para que el botón sticky no lo tape */
  body.sn-chat-lock [role="dialog"] .modal-content,
  body.sn-chat-lock .modal .modal-content,
  body.sn-chat-lock .sn-terms-container > * {
    padding-bottom: 92px !important;
  }

  /* Header interno sticky para mejorar usabilidad en pantallas muy altas */
  body.sn-chat-lock [role="dialog"] .modal-header,
  body.sn-chat-lock .modal .modal-header {
    position: sticky !important;
    top: 0 !important;
    z-index: 11011 !important;
    background: inherit !important;
  }

  /* Baja prioridad del overlay del chat para permitir modales sobre él */
  .sn-chat-overlay {
    z-index: 10000; /* aseguramos que los modales definidos arriba (11000) estén por encima */
  }
}

/* Toggle shift (desktop open) */
.sn-chat-toggle.chat-open {
  transform: translateY(60px) scale(0.8);
  opacity: 0.7;
}
.sn-chat-toggle.chat-open:hover {
  transform: translateY(60px) scale(0.85);
}

/* Mobile reposition of toggle */
@media (max-width: 991px) {
  .sn-chat-mobile {
    bottom: 80px;
    right: 15px;
  }
}

/* Very small screens */
@media (max-width: 480px) {
  .sn-chat-mobile {
    bottom: 100px;
    right: 10px;
  }
}

/* Desktop / Mobile visibility switches */
@media (min-width: 992px) {
  .sn-chat-desktop {
    display: block !important;
  }
  .sn-chat-mobile {
    display: none !important;
  }
  .sn-barra-lat-desktop {
    display: flex;
  }
  .sn-barra-lat-mobile {
    display: none;
  }
}
@media (max-width: 991px) {
  .sn-chat-desktop {
    display: none !important;
  }
  .sn-chat-mobile {
    display: block;
  }
  .sn-barra-lat-desktop {
    display: none;
  }
  .sn-barra-lat-mobile {
    display: flex;
  }
}

/* Mobile Header / Menus Adjustments */
.sn-header-mobile {
  display: none;
}
.sn-header-desktop {
  display: flex;
}
.sn-menu-izq-desktop {
  display: flex;
}
.sn-menu-izq-mobile {
  display: none;
}

@media (max-width: 600px) {
  .sn-header-desktop {
    display: none !important;
  }
  .sn-header-mobile {
    display: block;
    width: 100%;
  }
  .sn-row-top {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 0;
    background: none;
  }
  .sn-header-bar-mobile {
    display: flex;
    align-items: center;
    background: #0e0e0e;
    border-radius: var(--sn-radius);
    height: 48px;
    margin: 0 0 2px 0;
    padding: 0 0.3rem;
    width: 100%;
    box-sizing: border-box;
  }
  .sn-logo {
    width: 44px;
    min-width: 44px;
    max-width: 44px;
    height: 44px;
    background: none;
    border-radius: 0;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .sn-logo img {
    max-height: 26px;
  }
  .sn-sim-name {
    display: none;
  }
  .sn-header-right {
    flex: 1 1 auto;
    height: 44px;
    background: none;
    padding: 0 0.2rem;
    gap: 0.3rem;
    margin-left: 0.5rem;
  }
  .sn-menu-sup {
    height: 44px;
    padding: 0 0.2rem;
    background: #0e0e0e;
    gap: 0.2rem;
    overflow-x: auto;
  }
  .sn-menu-izq-desktop {
    display: none !important;
  }
  .sn-menu-izq-mobile {
    display: flex !important;
    flex-direction: row;
    width: 100%;
    height: 44px;
    padding: 0 0.2rem;
    background: #0e0e0e;
    border-radius: var(--sn-radius);
    align-items: center;
    gap: 0.2rem;
    overflow-x: auto;
    white-space: nowrap;
    position: relative;
    z-index: 2;
  }
  .sn-btn-left {
    justify-content: center;
    padding: 0.4rem 0.7rem;
    min-height: 34px;
    height: 34px;
    background: var(--sn-btn-bg);
  }
  .sn-btn-left.on {
    background: var(--sn-primary);
    color: var(--sn-btn-fg-on);
  }
  .sn-btn-left svg {
    width: 17px;
    height: 17px;
  }
  .sn-header-mobile,
  .sn-menu-sup,
  .sn-menu-izq-mobile,
  .sn-content,
  .sn-banner {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }
  .sn-menu-sup,
  .sn-menu-izq-mobile {
    min-height: 44px !important;
    max-height: 44px !important;
    line-height: 44px !important;
  }
  .sn-content {
    padding-left: 0.1rem !important;
    padding-right: 0.1rem !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .sn-wrapper {
    margin-left: 0.1rem !important;
    margin-right: 0.1rem !important;
    margin-top: 0 !important;
    padding: 0 !important;
  }
  .sn-main {
    grid-template-columns: 1fr;
    gap: 0.18rem;
  }
  .sn-barra-lat-desktop {
    display: none !important;
  }
  .sn-barra-lat-mobile {
    display: flex !important;
  }
}

/* Event shortcode exception layout */
@media (max-width: 700px) {
  #sn-eventos-container,
  #sn-eventos-container .sn-panel,
  #sn-eventos-container .sn-serie,
  #sn-eventos-container .sn-wrapper {
    padding: 0 !important;
    margin: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
    background: none !important;
  }
}

/* Chat Close Button */
.sn-chat-close {
  background: none;
  border: none;
  color: #fff;
  cursor: pointer;
  padding: 2px;
  border-radius: 4px;
  transition: background-color 0.2s;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sn-chat-close svg {
  width: 16px;
  height: 16px;
}
.sn-chat-close:hover {
  background-color: rgba(255, 255, 255, 0.1);
}

/* Fix: ocultar header interno duplicado del plugin dentro del panel móvil */
@media (max-width: 991px) {
  #sn-chat-container .chat-header {
    display: none !important;
  }
}

/* === FIX DEFINITIVO MODAL TÉRMINOS v2 === */
@media (max-width: 991px) {
  .sn-chat-container.sn-has-terms {
    overflow: hidden !important;
    touch-action: none !important;
  }
  .sn-terms-modal-fix {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: 100% !important;
    max-height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    background: #0f1620 !important;
    z-index: 12050 !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    border-radius: 18px 18px 0 0;
  }
  .sn-terms-modal-fix * {
    -webkit-overflow-scrolling: touch;
  }
  .sn-terms-modal-fix .sn-terms-scroll-area {
    flex: 1 1 auto;
    overflow-y: auto !important;
    overscroll-behavior: contain;
    padding: 18px 18px 160px;
    scrollbar-width: thin;
  }
  .sn-terms-modal-fix .sn-terms-float-bar {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 14px 16px calc(14px + env(safe-area-inset-bottom));
    background: linear-gradient(
      180deg,
      rgba(15, 22, 32, 0) 0%,
      rgba(15, 22, 32, 0.9) 25%,
      #0f1620 90%
    );
    display: flex;
    gap: 10px;
    z-index: 12060;
  }
  .sn-terms-modal-fix .sn-terms-float-bar button,
  .sn-terms-modal-fix .sn-terms-float-bar .accept,
  .sn-terms-modal-fix .sn-terms-float-bar .agree,
  .sn-terms-modal-fix .sn-terms-float-bar input[type="submit"] {
    flex: 1 1 auto;
    background: var(--sn-primary) !important;
    color: #fff !important;
    border: none;
    border-radius: 12px;
    padding: 0.9rem 1rem;
    font-weight: 600;
    font-size: 15px;
    line-height: 1.1;
    cursor: pointer;
  }
  .sn-terms-modal-fix .sn-terms-float-bar .sn-terms-secondary {
    background: #2d3a46 !important;
  }
  body.sn-no-scroll {
    overflow: hidden !important;
    touch-action: none !important;
  }
}
/* === FIN FIX DEFINITIVO MODAL TÉRMINOS v2 === */

/* === EXTRA: Overlay & body lock para términos (v2.1) === */
@media (max-width: 991px) {
  .sn-terms-lock-overlay {
    position: fixed !important;
    inset: 0 !important;
    background: rgba(0, 0, 0, 0.55);
    backdrop-filter: blur(2px);
    z-index: 12040 !important; /* debajo del modal (12050) */
    touch-action: none !important;
  }
  body.sn-no-scroll-fixed {
    position: fixed !important;
    width: 100% !important;
    overflow: hidden !important;
    overscroll-behavior: none !important;
    touch-action: none !important;
  }
}
/* === FIN EXTRA === */
