/* =============================================
   JFF-THEME.CSS — v3.0 FINAL
   Carga DESPUÉS de bootstrap.min.css y styles.css
   Para revertir: quitar el <link> en css_general.blade.php
============================================= */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@700;800&family=Inter:wght@300;400;500&display=swap');

/* =============================================
   1. VARIABLES
============================================= */
:root {
  --jff-pink:    #f0477a;
  --jff-pink2:   #ff6b9d;
  --jff-violet:  #7c5cfc;
  --jff-violet2: #a688ff;
  --jff-gold:    #f5c842;
  --jff-dark:    #0d0d14;
  --jff-dark2:   #13131d;
  --jff-dark3:   #1a1a2e;
  --jff-border:  rgba(255,255,255,0.08);
  --jff-border2: rgba(255,255,255,0.14);
  --jff-text:    #f0eeff;
  --jff-text2:   #b0adc8;
  --jff-text3:   #7a7890;
  --jff-pill:    50rem;
  --jff-radius:  14px;
  --jff-radius-sm: 8px;
}

/* =============================================
   2. BODY & BASE
============================================= */
body {
  background-color: var(--jff-dark) !important;
  color: var(--jff-text) !important;
  font-family: 'Inter', sans-serif !important;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: 'Syne', sans-serif !important;
  letter-spacing: -0.02em;
  color: var(--jff-text) !important;
}

p, span, li, td, th, label, small {
  color: var(--jff-text2);
}

a {
  color: var(--jff-violet2);
  transition: color 0.15s ease;
}
a:hover {
  color: var(--jff-pink2);
  text-decoration: none;
}

::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: #2a2a40; border-radius: 3px; }

hr { border-top: 1px solid var(--jff-border) !important; }

.border            { border-color: var(--jff-border) !important; }
.border-top        { border-top-color: var(--jff-border) !important; }
.border-bottom     { border-bottom-color: var(--jff-border) !important; }
.border-left       { border-left-color: var(--jff-border) !important; }
.border-right      { border-right-color: var(--jff-border) !important; }

.text-muted  { color: var(--jff-text3) !important; }
.text-white  { color: #fff !important; }
.text-primary { color: var(--jff-violet2) !important; }
.text-dark   { color: var(--jff-text) !important; }

.bg-white    { background-color: var(--jff-dark2) !important; }
.bg-light    { background-color: var(--jff-dark3) !important; }
.bg-primary  { background: linear-gradient(135deg, var(--jff-pink), var(--jff-violet)) !important; }
.bg-dark     { background-color: var(--jff-dark) !important; }

/* =============================================
   3. SECCIONES — FIX FONDOS BLANCOS
============================================= */
section,
.section,
.wrap-home {
  background-color: var(--jff-dark) !important;
}

/* =============================================
   4. NAVBAR
   IMPORTANTE: sin backdrop-filter aquí.
   backdrop-filter en el padre rompe el z-index
   del navbar-collapse hijo en mobile.
   Usamos ::before para el efecto blur.
============================================= */
.navbar {
  background: rgba(13,13,20,0.96) !important;
  border-bottom: 1px solid var(--jff-border2) !important;
  /* NO backdrop-filter aquí */
}

/* Blur via pseudo-elemento — no afecta z-index de hijos */
.navbar::before {
  content: '';
  position: absolute;
  inset: 0;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  z-index: -1;
  pointer-events: none;
}

.navbar-brand {
  font-family: 'Syne', sans-serif !important;
  font-weight: 800 !important;
}

.navbar .nav-link:not(.btn) {
  color: var(--jff-text3) !important;
  transition: color 0.15s ease !important;
}
.navbar .nav-link:not(.btn):hover,
.navbar .nav-link:not(.btn).active {
  color: var(--jff-text) !important;
}

/* ---- NAVBAR COLLAPSE MOBILE ---- */
/* styles.css usa position:fixed right:-100% z-index:999999
   Lo superamos con un valor mayor */
@media (max-width: 991px) {
  .navbar .navbar-collapse {
    z-index: 9999999 !important;
    position: fixed !important;
    top: 0 !important;
    right: -100% !important;
    width: 300px !important;
    height: 100% !important;
    background: #0d0d14 !important;
    /* Sin backdrop-filter aquí tampoco */
  }

  .navbar .navbar-collapse.show,
  .navbar .navbar-collapse.collapsing {
    right: 0 !important;
  }

  .navbar .navbar-collapse .nav-link:not(.btn) {
    color: var(--jff-text2) !important;
  }

  #mobileMenuOverlay {
    z-index: 9999998 !important;
  }
}

/* Dropdown */
.dropdown-menu {
  background: var(--jff-dark2) !important;
  border: 1px solid var(--jff-border2) !important;
  border-radius: var(--jff-radius) !important;
  box-shadow: 0 16px 40px rgba(0,0,0,0.5) !important;
  z-index: 1055 !important;
}
.dropdown-item {
  color: var(--jff-text2) !important;
  border-radius: var(--jff-radius-sm) !important;
  transition: background 0.12s ease, color 0.12s ease !important;
}
.dropdown-item:hover,
.dropdown-item:focus,
.dropdown-item:active {
  background: rgba(124,92,252,0.12) !important;
  color: var(--jff-text) !important;
}
.dropdown-divider {
  border-top: 1px solid var(--jff-border) !important;
}

/* =============================================
   5. SIDEBAR IZQUIERDO (.menu-left-home)
============================================= */
.menu-left-home {
  position: relative !important;
  z-index: 20 !important;
}

.menu-left-home li > a {
  color: var(--jff-text3) !important;
  font-size: 15px !important;
  border-radius: var(--jff-radius-sm) !important;
  transition: all 0.15s ease !important;
  display: flex !important;
  align-items: center !important;
  padding: 8px 12px !important;
  margin-bottom: 4px !important;
  text-decoration: none !important;
}
.menu-left-home li > a:hover {
  background: rgba(255,255,255,0.05) !important;
  color: var(--jff-text) !important;
}
.menu-left-home li > a.active {
  background: linear-gradient(135deg, var(--jff-pink), var(--jff-violet)) !important;
  color: #fff !important;
}
.menu-left-home li > a i,
.menu-left-home li > a .feather {
  font-size: 18px !important;
  width: 22px !important;
  flex-shrink: 0 !important;
}

/* =============================================
   6. BOTONES
============================================= */

/* Primary */
.btn-primary,
.btn-primary:not(:disabled):not(.disabled) {
  background: linear-gradient(135deg, var(--jff-pink), var(--jff-violet)) !important;
  border: none !important;
  border-radius: var(--jff-pill) !important;
  font-weight: 500 !important;
  color: #fff !important;
  transition: opacity 0.15s ease, box-shadow 0.15s ease !important;
}
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active,
.btn-primary:not(:disabled):not(.disabled):active,
.show > .btn-primary.dropdown-toggle {
  opacity: 0.88 !important;
  box-shadow: 0 8px 24px rgba(240,71,122,0.3) !important;
  background: linear-gradient(135deg, var(--jff-pink), var(--jff-violet)) !important;
  color: #fff !important;
}

/* Success — reemplaza verde */
.btn-success,
.btn-success:not(:disabled):not(.disabled) {
  background: linear-gradient(135deg, var(--jff-pink), var(--jff-violet)) !important;
  border: none !important;
  border-radius: var(--jff-pill) !important;
  color: #fff !important;
  font-weight: 500 !important;
}
.btn-success:hover,
.btn-success:focus,
.btn-success:active {
  opacity: 0.88 !important;
  box-shadow: 0 8px 24px rgba(240,71,122,0.3) !important;
  background: linear-gradient(135deg, var(--jff-pink), var(--jff-violet)) !important;
}

/* Outline primary */
.btn-outline-primary {
  border: 1px solid var(--jff-violet) !important;
  color: var(--jff-violet2) !important;
  border-radius: var(--jff-pill) !important;
  background: transparent !important;
}
.btn-outline-primary:hover,
.btn-outline-primary:focus,
.btn-outline-primary:not(:disabled):not(.disabled):active {
  background: rgba(124,92,252,0.12) !important;
  color: var(--jff-violet2) !important;
  border-color: var(--jff-violet) !important;
}

/* Ghost — outline secondary / light / white */
.btn-outline-secondary,
.btn-outline-light,
.btn-white,
.btn-outline-white {
  border: 1px solid rgba(255,255,255,0.35) !important;
  color: var(--jff-text) !important;
  background: transparent !important;
  border-radius: var(--jff-pill) !important;
}
.btn-outline-secondary:hover,
.btn-outline-light:hover,
.btn-white:hover {
  background: rgba(255,255,255,0.08) !important;
  color: #fff !important;
}

/* Secondary */
.btn-secondary {
  background: var(--jff-dark3) !important;
  border: 1px solid var(--jff-border2) !important;
  color: var(--jff-text2) !important;
  border-radius: var(--jff-pill) !important;
}
.btn-secondary:hover {
  background: #222236 !important;
  color: var(--jff-text) !important;
}

/* Light */
.btn-light {
  background: var(--jff-dark3) !important;
  border: 1px solid var(--jff-border) !important;
  color: var(--jff-text2) !important;
  border-radius: var(--jff-pill) !important;
}

/* Link */
.btn-link {
  color: var(--jff-violet2) !important;
}
.btn-link:hover {
  color: var(--jff-pink2) !important;
}

/* =============================================
   7. CARDS
============================================= */
.card {
  background: var(--jff-dark2) !important;
  border: 1px solid var(--jff-border) !important;
  border-radius: var(--jff-radius) !important;
  color: var(--jff-text) !important;
  transition: border-color 0.2s ease !important;
}
.card:hover {
  border-color: var(--jff-border2) !important;
}
.card-header {
  background: transparent !important;
  border-bottom: 1px solid var(--jff-border) !important;
}
.card-footer {
  background: transparent !important;
  border-top: 1px solid var(--jff-border) !important;
}
.card-title { color: var(--jff-text) !important; }
.card-text  { color: var(--jff-text2) !important; }

.card-user-profile {
  border-radius: var(--jff-radius) !important;
  overflow: hidden !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
}
.card-user-profile:hover {
  border-color: var(--jff-border2) !important;
  box-shadow: 0 16px 40px rgba(0,0,0,0.35) !important;
}

/* =============================================
   8. FORMULARIOS
============================================= */
.form-control,
.custom-select,
.form-select,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="search"],
textarea {
  background: var(--jff-dark3) !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  color: var(--jff-text) !important;
  border-radius: var(--jff-radius-sm) !important;
}
.form-control:focus,
.custom-select:focus,
textarea:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus {
  background: var(--jff-dark3) !important;
  border-color: var(--jff-violet) !important;
  box-shadow: 0 0 0 3px rgba(124,92,252,0.15) !important;
  color: var(--jff-text) !important;
}
.form-control::placeholder,
textarea::placeholder { color: var(--jff-text3) !important; }

.input-group-text {
  background: var(--jff-dark3) !important;
  border-color: rgba(255,255,255,0.1) !important;
  color: var(--jff-text2) !important;
}
.search-bar {
  background-color: var(--jff-dark3) !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  color: var(--jff-text) !important;
}
.search-bar:focus {
  border-color: var(--jff-violet) !important;
  box-shadow: 0 0 0 3px rgba(124,92,252,0.15) !important;
}
input[type="range"] {
  accent-color: var(--jff-pink) !important;
}
label, .form-label {
  color: var(--jff-text2) !important;
}

/* =============================================
   9. LIST GROUP
============================================= */
.list-group-item {
  background: var(--jff-dark2) !important;
  border-color: var(--jff-border) !important;
  color: var(--jff-text) !important;
}
.list-group-item.active {
  background: linear-gradient(135deg, var(--jff-pink), var(--jff-violet)) !important;
  border-color: transparent !important;
  color: #fff !important;
}
.list-group-item:hover:not(.active) {
  background: var(--jff-dark3) !important;
}

/* =============================================
   10. TABLAS
============================================= */
.table { color: var(--jff-text) !important; }
.table thead th {
  border-bottom: 2px solid var(--jff-border2) !important;
  color: var(--jff-text3) !important;
  font-size: 11px !important;
  letter-spacing: 0.8px !important;
  text-transform: uppercase !important;
  font-weight: 500 !important;
  background: transparent !important;
}
.table td, .table th {
  border-top-color: var(--jff-border) !important;
  vertical-align: middle !important;
}
.table-striped tbody tr:nth-of-type(odd) {
  background-color: rgba(255,255,255,0.02) !important;
}
.table-hover tbody tr:hover {
  background-color: rgba(124,92,252,0.06) !important;
  color: var(--jff-text) !important;
}

/* =============================================
   11. BADGES
============================================= */
.badge-primary, .badge.bg-primary {
  background: linear-gradient(135deg, var(--jff-pink), var(--jff-violet)) !important;
  color: #fff !important;
}
.badge-secondary, .badge.bg-secondary {
  background: var(--jff-dark3) !important;
  color: var(--jff-text2) !important;
}
.badge-success, .badge.bg-success {
  background: rgba(52,211,153,0.15) !important;
  color: #34d399 !important;
}
.badge-danger, .badge.bg-danger {
  background: rgba(226,75,74,0.15) !important;
  color: #ff8080 !important;
}
.badge-warning, .badge.bg-warning {
  background: rgba(245,200,66,0.15) !important;
  color: var(--jff-gold) !important;
}
.notify {
  background: var(--jff-pink) !important;
  color: #fff !important;
}

/* =============================================
   12. PAGINACIÓN
============================================= */
.page-link {
  background: var(--jff-dark2) !important;
  border-color: var(--jff-border) !important;
  color: var(--jff-text2) !important;
  border-radius: var(--jff-radius-sm) !important;
  transition: all 0.15s ease !important;
}
.page-link:hover {
  background: var(--jff-dark3) !important;
  color: var(--jff-text) !important;
  border-color: var(--jff-border2) !important;
}
.page-item.active .page-link {
  background: linear-gradient(135deg, var(--jff-pink), var(--jff-violet)) !important;
  border-color: transparent !important;
  color: #fff !important;
}
.page-item.disabled .page-link {
  background: var(--jff-dark2) !important;
  opacity: 0.35 !important;
}

/* =============================================
   13. TABS
============================================= */
.nav-pills .nav-link {
  background: var(--jff-dark3) !important;
  color: var(--jff-text3) !important;
  border-radius: var(--jff-pill) !important;
  transition: all 0.15s ease !important;
}
.nav-pills .nav-link:hover {
  background: rgba(255,255,255,0.06) !important;
  color: var(--jff-text) !important;
}
.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
  background: linear-gradient(135deg, var(--jff-pink), var(--jff-violet)) !important;
  color: #fff !important;
}

.nav-tabs {
  border-bottom: 1px solid var(--jff-border) !important;
}
.nav-tabs .nav-link {
  color: var(--jff-text3) !important;
  border: none !important;
  border-bottom: 2px solid transparent !important;
  border-radius: 0 !important;
  background: none !important;
  transition: all 0.15s ease !important;
}
.nav-tabs .nav-link:hover {
  color: var(--jff-text) !important;
  border-bottom-color: var(--jff-border2) !important;
}
.nav-tabs .nav-link.active {
  color: var(--jff-text) !important;
  border-bottom: 2px solid var(--jff-pink) !important;
  background: none !important;
}

.nav-profile li.active {
  border-bottom: 3px solid var(--jff-pink) !important;
}
.nav-profile a { color: var(--jff-text3) !important; }
.nav-profile li.active a { color: var(--jff-text) !important; }

/* =============================================
   14. MODALES
============================================= */
.modal-content {
  background: var(--jff-dark2) !important;
  border: 1px solid var(--jff-border2) !important;
  border-radius: var(--jff-radius) !important;
  color: var(--jff-text) !important;
}
.modal-header { border-bottom: 1px solid var(--jff-border) !important; }
.modal-footer { border-top: 1px solid var(--jff-border) !important; }
.modal-title  { color: var(--jff-text) !important; }
.close {
  color: var(--jff-text3) !important;
  opacity: 1 !important;
  text-shadow: none !important;
}
.close:hover { color: var(--jff-text) !important; }

/* =============================================
   15. ALERTS
============================================= */
.alert { border-radius: var(--jff-radius-sm) !important; }
.alert-primary {
  background: rgba(124,92,252,0.1) !important;
  color: var(--jff-violet2) !important;
  border-color: rgba(124,92,252,0.25) !important;
}
.alert-danger {
  background: rgba(226,75,74,0.1) !important;
  border-color: rgba(226,75,74,0.25) !important;
  color: #ff8080 !important;
}
.alert-success {
  background: rgba(52,211,153,0.1) !important;
  border-color: rgba(52,211,153,0.25) !important;
  color: #34d399 !important;
}
.alert-warning {
  background: rgba(245,200,66,0.1) !important;
  border-color: rgba(245,200,66,0.25) !important;
  color: var(--jff-gold) !important;
}

/* =============================================
   16. PROGRESS BARS
============================================= */
.progress {
  background: var(--jff-dark3) !important;
  border-radius: var(--jff-pill) !important;
  height: 8px !important;
}
.progress-bar {
  background: linear-gradient(90deg, var(--jff-pink), var(--jff-violet)) !important;
}

/* =============================================
   17. SWEET ALERT
============================================= */
.sweet-alert {
  background: var(--jff-dark2) !important;
  border-radius: var(--jff-radius) !important;
  border: 1px solid var(--jff-border2) !important;
}
.sweet-alert h2 { color: var(--jff-text) !important; }
.sweet-alert p  { color: var(--jff-text2) !important; }
.sweet-alert .sa-icon.sa-success .sa-fix,
.sweet-alert .sa-icon.sa-success::after,
.sweet-alert .sa-icon.sa-success::before {
  background: var(--jff-dark2) !important;
}

/* =============================================
   18. FOOTER
============================================= */
footer,
.footer_background_color {
  background-color: var(--jff-dark2) !important;
  border-top: 1px solid var(--jff-border) !important;
}
footer p, footer span, footer li {
  color: var(--jff-text3) !important;
}
footer h5, footer h6,
footer .h5, footer .h6 {
  color: var(--jff-text) !important;
  font-size: 11px !important;
  letter-spacing: 1.2px !important;
  text-transform: uppercase !important;
  margin-bottom: 14px !important;
}
.link-footer {
  color: var(--jff-text3) !important;
  transition: color 0.15s ease !important;
}
.link-footer:hover {
  color: var(--jff-text) !important;
  text-decoration: none !important;
}
footer hr { border-color: var(--jff-border) !important; }

/* =============================================
   19. MENU MOBILE BOTTOM
   Sin backdrop-filter — misma razón que navbar
============================================= */
.menuMobile {
  background: rgba(13,13,20,0.97) !important;
  border-top: 1px solid var(--jff-border) !important;
  z-index: 1040 !important;
  /* Sin backdrop-filter */
}
.btn-mobile {
  color: var(--jff-text3) !important;
  border-radius: var(--jff-radius-sm) !important;
  transition: all 0.15s ease !important;
}
.btn-mobile:hover {
  color: var(--jff-pink2) !important;
  background: rgba(240,71,122,0.08) !important;
  text-decoration: none !important;
}

/* =============================================
   20. HOMEPAGE PÚBLICA
============================================= */
.wrap-home h2,
.wrap-home h3,
.wrap-home p {
  color: var(--jff-text) !important;
}

.bg-gradient h1,
.bg-gradient h2,
.bg-gradient h3,
.bg-gradient p {
  color: #fff !important;
}
.bg-gradient .btn-outline-primary,
.bg-gradient .btn-outline-secondary {
  border-color: rgba(255,255,255,0.45) !important;
  color: #fff !important;
  background: transparent !important;
}
.bg-gradient .btn-outline-primary:hover,
.bg-gradient .btn-outline-secondary:hover {
  background: rgba(255,255,255,0.1) !important;
}

/* =============================================
   21. FEED / POSTS
============================================= */
.card .card-body a:not(.btn):not(.pulse-btn):not(.img-link) {
  color: var(--jff-violet2) !important;
}
.card .card-body a:not(.btn):not(.pulse-btn):not(.img-link):hover {
  color: var(--jff-pink2) !important;
}
.pulse-btn {
  color: var(--jff-text3) !important;
  transition: color 0.15s ease !important;
}
.pulse-btn:hover { color: var(--jff-pink2) !important; }
.card + .card    { margin-top: 12px !important; }
.content-locked {
  background: rgba(124,92,252,0.08) !important;
  border: 1px solid var(--jff-border2) !important;
}

/* =============================================
   22. UNREAD / ACTIVE STATES
============================================= */
.unread-chat {
  background-color: rgba(124,92,252,0.07) !important;
}
.msg-inbox .active {
  background: linear-gradient(135deg,
    rgba(240,71,122,0.15),
    rgba(124,92,252,0.15)) !important;
  border-color: var(--jff-border2) !important;
}

/* =============================================
   23. SELECT2
============================================= */
.select2-container--default .select2-selection--multiple,
.select2-container--default .select2-selection--single {
  background-color: var(--jff-dark3) !important;
  border-color: rgba(255,255,255,0.1) !important;
  color: var(--jff-text) !important;
}
.select2-results__option {
  color: var(--jff-text2) !important;
  background: var(--jff-dark2) !important;
}
.select2-results__option--highlighted {
  background: rgba(124,92,252,0.15) !important;
  color: var(--jff-text) !important;
}
.select2-dropdown {
  background: var(--jff-dark2) !important;
  border-color: var(--jff-border2) !important;
  border-radius: var(--jff-radius-sm) !important;
}

/* =============================================
   24. UTILITY
============================================= */
.text-gradient-jff {
  background: linear-gradient(135deg, var(--jff-pink), var(--jff-violet2));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ------------------------------------------
   FIX DEFINITIVO: NAVBAR COLLAPSE MOBILE
   styles.css línea 585 sobreescribe z-index
   cuando body tiene clase .sidebar-overlay
------------------------------------------ */
.sidebar-overlay .navbar .navbar-collapse {
  z-index: 9999999 !important;
}
