/* ==========================================================================
   LIF POKER — Dashboard
   Tokens · Layout · Components
   z-index: header(1300) > sidebar(1200) > overlay(1100) > content
   ========================================================================== */

:root{
  /* Marca */
  --primary:#6ECFF0;
  --accent:#1481C0;
  --deep:#002E67;
  --primary-rgb:110,207,240;
  --accent-rgb:20,129,192;
  --deep-rgb:0,46,103;

  /* Superficies */
  --bg:#121212;
  --bg-2:#0d0d0d;
  --surface:#1b1b1b;
  --surface-2:#222;
  --line:rgba(var(--primary-rgb),.10);
  --line-strong:rgba(var(--primary-rgb),.22);

  /* Texto */
  --text:#e0f7fa;
  --text-soft:#bcd0d6;
  --muted:#9fb3bc;

  /* Estado */
  --danger:#ef4444;
  --success:#10b981;
  
  /* Aliases retro-compatibles para vistas que aún usan los nombres viejos */
--card-bg: var(--surface);
--border-color: var(--line-strong);
--menu-bg: rgba(13,13,13,.95);
--info: var(--accent);
--neutral: var(--muted);
--elevation-1: var(--shadow-1);
--elevation-2: var(--shadow-2);
--transition: all var(--t);

  /* Tipografía (alineada al index) */
  --font-display:'Bebas Neue',system-ui,sans-serif;
  --font-body:'Montserrat',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;

  /* Sistema */
  --headerH:88px;
  --sideW:268px;
  --sideW-collapsed:72px;
  --radius:14px;
  --radius-sm:10px;
  --shadow-1:0 6px 18px rgba(0,0,0,.30);
  --shadow-2:0 18px 40px rgba(0,0,0,.40);
  --ring:0 0 0 3px rgba(var(--primary-rgb),.28);
  --ease:cubic-bezier(.2,.8,.25,1);
  --t:.22s var(--ease);
}
@media (max-width:991.98px){ :root{ --headerH:72px; } }

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-body);
  color:var(--text);
  background:var(--bg);
  background-image:
    radial-gradient(900px 500px at 12% -10%, rgba(var(--accent-rgb),.10), transparent 60%),
    radial-gradient(700px 400px at 110% 10%, rgba(var(--primary-rgb),.07), transparent 55%);
  min-height:100vh;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
button{font:inherit;color:inherit}

.hidden{display:none!important}
.mobile-only{display:block}
.desktop-only{display:none}

#dashboard-layout{display:flex;flex-direction:column;min-height:100vh;position:relative;z-index:1}

/* ==========================================================================
   Header — gradiente de marca + lockup + user chip
   ========================================================================== */
.main-header{
  position:sticky; top:0; z-index:1300;
  height:var(--headerH); min-height:var(--headerH);
  display:grid;
  grid-template-columns:minmax(56px, 1fr) auto minmax(56px, 1fr);
  align-items:center;
  padding:0 1.25rem;
  color:var(--deep);
  background:
    linear-gradient(120deg, rgba(255,255,255,.10), transparent 45%),
    linear-gradient(135deg, var(--primary) 0%, var(--accent) 60%, var(--deep) 130%);
  border-bottom:1px solid rgba(0,0,0,.18);
  box-shadow:0 1px 0 rgba(255,255,255,.10) inset, var(--shadow-1);
}

/* sutil patrón de cartas (dots discretos) sobre el gradiente */
.main-header::before{
  content:""; position:absolute; inset:0;
  background-image:radial-gradient(rgba(255,255,255,.08) 1px, transparent 1.4px);
  background-size:18px 18px; background-position:0 0;
  opacity:.35; pointer-events:none;
  mask-image:linear-gradient(90deg, transparent 0%, #000 25%, #000 75%, transparent 100%);
  -webkit-mask-image:linear-gradient(90deg, transparent 0%, #000 25%, #000 75%, transparent 100%);
}
.main-header > *{position:relative; z-index:1}

.header-left{justify-self:start; display:flex; align-items:center; gap:.5rem}
.header-right{justify-self:end; display:flex; align-items:center; gap:.5rem}

/* ---------- Brand lockup ---------- */
.brand{
  justify-self:center;
  display:inline-flex; flex-direction:column; align-items:center; gap:6px;
  text-decoration:none; color:inherit;
  padding:6px 14px; border-radius:12px;
  transition:transform var(--t), background var(--t);
}
.brand:hover{ background:rgba(255,255,255,.06); transform:translateY(-1px) }

.brand-mark{
  display:inline-flex; align-items:baseline; gap:.32em;
  font-family:var(--font-display); font-weight:400;
  font-size:clamp(1.7rem, 2.4vw + .9rem, 2.6rem);
  line-height:.9; letter-spacing:.10em;
}
.brand-lif{
  color:#fff;
  text-shadow:
    0 1px 0 rgba(0,0,0,.18),
    0 0 16px rgba(255,255,255,.18);
}
.brand-poker{
  background:linear-gradient(180deg, #ffffff 10%, var(--primary) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  -webkit-text-stroke:.3px rgba(0,0,0,.25);
  text-shadow:0 1px 0 rgba(0,0,0,.15);
}

.brand-tag{
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:var(--font-body); font-weight:700;
  text-transform:uppercase; letter-spacing:.32em;
  font-size:clamp(9px, .55vw + .35rem, 11px);
  color:#ffffff;
  opacity:.85;
  text-shadow:0 1px 2px rgba(0,0,0,.25);
}
.brand-dot{
  width:6px; height:6px; border-radius:50%;
  background:#fff;
  box-shadow:0 0 0 3px rgba(255,255,255,.28);
}

@media (max-width:560px){
  .brand-tag-text{ display:none }
  .brand-dot{ display:none }
}

/* ---------- Icon buttons (hamburguesa, toggle desktop) ---------- */
.icon-btn{
  width:42px; height:42px; border-radius:12px; border:0;
  display:inline-grid; place-items:center; cursor:pointer;
  background:rgba(255,255,255,.18);
  color:var(--deep);
  font-size:1.05rem;
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 2px 0 rgba(0,0,0,.06) inset;
  transition:background var(--t), transform var(--t), box-shadow var(--t);
}
.icon-btn:hover{ background:rgba(255,255,255,.28); }
.icon-btn:active{ transform:translateY(1px); box-shadow:0 1px 0 rgba(0,0,0,.06) inset }
.icon-btn:focus-visible{ outline:none; box-shadow:0 0 0 3px rgba(0,46,103,.35) }

@media (min-width:992px){ #mobile-menu-btn{display:none} }

/* ---------- User chip ---------- */
.user-chip{
  display:inline-flex; align-items:center; gap:.7rem;
  padding:6px 12px 6px 6px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.22);
  color:var(--deep);
  box-shadow:0 2px 0 rgba(0,0,0,.06) inset;
}
.user-avatar{
  width:34px; height:34px; border-radius:50%;
  display:grid; place-items:center;
  font-family:var(--font-body); font-weight:800; font-size:.78rem; letter-spacing:.04em;
  color:#fff;
  background:linear-gradient(145deg, var(--deep), #051a3a);
  border:1px solid rgba(255,255,255,.30);
  box-shadow:0 2px 6px rgba(0,0,0,.20);
}
.user-meta{ display:flex; flex-direction:column; line-height:1.05; gap:2px }
.user-name{
  font-family:var(--font-body); font-weight:800; font-size:.92rem;
  color:#04162a; max-width:14ch; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.user-status{
  display:inline-flex; align-items:center; gap:.35rem;
  font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em;
  color:rgba(4,22,42,.7);
}
.status-dot{
  width:7px; height:7px; border-radius:50%;
  background:#22c55e;
  box-shadow:0 0 0 3px rgba(34,197,94,.25);
  animation:pulse-dot 2.4s ease-in-out infinite;
}
@keyframes pulse-dot{
  0%,100%{ box-shadow:0 0 0 0 rgba(34,197,94,.45) }
  50%   { box-shadow:0 0 0 5px rgba(34,197,94,0)   }
}
@media (max-width:720px){
  .user-meta{ display:none }
  .user-chip{ padding:4px; }
}

/* legacy oculto */
.header-user-info, #logout-button{display:none}

/* ==========================================================================
   Sidebar
   ========================================================================== */
  #side-menu{
  position:fixed; left:0; top:var(--headerH); z-index:1200;
  width:var(--sideW); height:calc(100vh - var(--headerH));
  height:calc(100dvh - var(--headerH));   /* dvh descuenta barra dinámica Chrome/Safari iOS */
  display:flex; flex-direction:column;
  background:linear-gradient(180deg, rgba(var(--deep-rgb),.85), rgba(13,13,13,.95));
  backdrop-filter:blur(12px) saturate(120%);
  border-right:1px solid var(--line);
  transform:translateX(-100%);
  transition:transform var(--t), width var(--t);
  box-shadow:var(--shadow-2);
}
#side-menu.active{transform:translateX(0)}

.side-menu-header{min-height:8px}

#toggle-menu-btn{ display:none }
@media (min-width:992px){
  #toggle-menu-btn{
    position:fixed; top:23px; left:18px; z-index:1400;
    width:38px; height:38px; border-radius:10px;
  }
}

#menu-overlay{
  position:fixed; inset:var(--headerH) 0 0 0; z-index:1100;
  background:rgba(2,6,12,.55);
  opacity:0; pointer-events:none;
  transition:opacity var(--t);
}
#menu-overlay.active{opacity:1; pointer-events:auto}
@media (min-width:992px){ #menu-overlay{display:none} }

/* Navegación */
#side-menu-nav{
  flex:1 1 auto; min-height:0;
  display:flex; flex-direction:column;
  padding:14px 12px 12px;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;   /* scroll suave iOS */
  scrollbar-width:thin;
  scrollbar-color:rgba(var(--primary-rgb),.25) transparent;
}
@media (max-width:991.98px){
  #side-menu-nav{
    padding-bottom:calc(24px + env(safe-area-inset-bottom));
  }
}
#side-menu-nav::-webkit-scrollbar{width:8px}
#side-menu-nav::-webkit-scrollbar-thumb{background:rgba(var(--primary-rgb),.22); border-radius:4px}

#side-menu-nav a{
  position:relative;
  display:flex; align-items:center; gap:.8rem;
  margin-bottom:4px; padding:.78rem .9rem;
  border-radius:10px;
  color:var(--text-soft); font-weight:600; font-size:.96rem;
  text-decoration:none;
  transition:background var(--t), color var(--t), transform var(--t);
}
#side-menu-nav a > i:first-child{
  width:18px; text-align:center; color:var(--muted);
  transition:color var(--t);
}
#side-menu-nav a:hover{ background:rgba(var(--primary-rgb),.06); color:#fff }
#side-menu-nav a:hover > i:first-child{ color:var(--primary) }

#side-menu-nav a.active{
  background:linear-gradient(90deg, rgba(var(--accent-rgb),.22), rgba(var(--accent-rgb),0));
  color:#fff;
}
#side-menu-nav a.active::before{
  content:""; position:absolute; left:-12px; top:8px; bottom:8px;
  width:3px; border-radius:0 3px 3px 0;
  background:linear-gradient(180deg, var(--primary), var(--accent));
}
#side-menu-nav a.active > i:first-child{color:var(--primary)}

/* Folder Herramientas */
.menu-folder{margin:6px 0}
.folder-toggle{cursor:pointer}
.folder-toggle .chev{
  margin-left:auto; transition:transform var(--t);
  color:var(--muted); font-size:.8rem; font-style:normal;
}
.menu-folder.open .folder-toggle .chev{transform:rotate(180deg); color:var(--primary)}

.folder-content{
  padding-left:.75rem; margin:2px 0 4px 18px;
  border-left:1px dashed rgba(var(--primary-rgb),.18);
}
.folder-content[hidden]{display:none}
.folder-content a{font-size:.9rem; padding:.6rem .8rem}

.nav-spacer{flex:1 1 auto; min-height:8px}

/* Logout */
.nav-logout{
  background:linear-gradient(145deg, #d23f3c, #a32220) !important;
  color:#fff !important;
  margin-top:8px;
  justify-content:center;
  font-weight:800 !important;
  box-shadow:0 8px 18px rgba(180,40,40,.30);
}
.nav-logout:hover{filter:brightness(1.06); transform:translateY(-1px)}
.nav-logout::before{display:none !important}

@media (max-width:991.98px){
  /* Sin sticky: el logout fluye al final del scroll natural del nav.
     El sticky contra un contenedor mal dimensionado por 100vh lo
     empujaba fuera del viewport en Chrome/Safari iOS. */
  .nav-logout{ position:relative; bottom:auto; margin-bottom:8px; }
}

/* ==========================================================================
   Main + Views
   ========================================================================== */
.view{
  display:none;
  width:100%;
  max-width:min(1400px, calc(100vw - 2rem));
  margin:0 auto; padding:1.5rem 1rem 2rem;
}
.view.active{display:block; animation:viewIn .35s var(--ease)}
@keyframes viewIn{
  from{opacity:0; transform:translateY(8px)}
  to{opacity:1; transform:translateY(0)}
}

.view-header{margin-bottom:1.75rem}
.view-title{
  display:inline-block;
  font-family:var(--font-display); font-weight:400;
  font-size:clamp(2rem, 1.6vw + 1.4rem, 2.8rem);
  letter-spacing:.08em; text-transform:uppercase;
  color:var(--text);
  padding-bottom:.4rem; margin:0 0 .4rem;
  border-bottom:2px solid transparent;
  border-image:linear-gradient(90deg, var(--primary), var(--accent), transparent) 1;
}
.view-title.saludo{
  font-family:var(--font-body); font-weight:700;
  text-transform:none; letter-spacing:.005em;
  font-size:clamp(1.5rem, 1.4vw + 1rem, 2.1rem);
  color:var(--text);
  border-image:linear-gradient(90deg, var(--primary), transparent) 1;
}

/* ==========================================================================
   Hub Widgets
   ========================================================================== */
.hub-top-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:1.25rem;
  align-items:start;
}

.widget-card{
  position:relative; overflow:hidden;
  display:flex; flex-direction:column; align-items:center; text-align:center;
  padding:1.6rem 1.4rem;
  border-radius:var(--radius);
  background:
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0)),
    var(--surface);
  border:1px solid var(--line);
  box-shadow:var(--shadow-1);
  transition:transform var(--t), border-color var(--t), box-shadow var(--t);
}
.widget-card::before{
  content:""; position:absolute; left:14px; right:14px; top:0; height:1px;
  background:linear-gradient(90deg, transparent, rgba(var(--primary-rgb),.55), transparent);
}
.widget-card::after{
  content:""; position:absolute; inset:auto -40% -60% auto;
  width:280px; height:280px; border-radius:50%;
  background:radial-gradient(circle, rgba(var(--accent-rgb),.18), transparent 70%);
  pointer-events:none;
}
.widget-card:hover{
  transform:translateY(-4px);
  border-color:var(--line-strong);
  box-shadow:var(--shadow-2);
}

.widget-label{
  text-transform:uppercase; letter-spacing:.18em;
  font-size:.72rem; font-weight:700;
  color:var(--muted); margin-bottom:.6rem;
}
.widget-value{
  font-family:var(--font-display); font-weight:400;
  font-size:clamp(2.6rem, 4vw, 3.6rem); line-height:1;
  letter-spacing:.02em;
  background:linear-gradient(180deg, #fff 30%, var(--primary) 110%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  margin:.2rem 0 .5rem;
}
.widget-subtext{font-size:.95rem; color:var(--text-soft); line-height:1.45}
.last-class-info{
  margin-top:.9rem; padding-top:.8rem;
  border-top:1px dashed rgba(var(--primary-rgb),.15);
  width:100%;
}
.widget-actions{
  margin-top:auto; padding-top:1.1rem;
  display:flex; flex-wrap:wrap; gap:.55rem; justify-content:center; width:100%;
}

/* Lista de últimas clases (Widget 3 del hub) */
.recent-classes-list{
  margin-top:1rem;
  width:100%;
  text-align:left;
}
.recent-classes-title{
  font-size:.7rem;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--muted);
  margin:0 0 .55rem;
  font-weight:700;
}
.recent-class-item{
  display:flex; align-items:center; gap:.5rem;
  padding:.45rem .6rem;
  background:rgba(255,255,255,.025);
  border:1px solid var(--line);
  border-radius:8px;
  margin-bottom:.4rem;
  font-size:.78rem;
}

.recent-class-info{flex:1; min-width:0;}
.recent-class-tema{
  font-weight:700;
  color:var(--text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.recent-class-meta{
  font-size:.7rem;
  color:var(--text-soft);
  margin-top:2px;
}
.recent-class-actions{
  display:flex; gap:.3rem; flex-shrink:0;
}
.recent-class-link{
  display:inline-flex; align-items:center; justify-content:center;
  width:28px; height:28px;
  border-radius:6px;
  background:rgba(var(--primary-rgb),.06);
  border:1px solid rgba(var(--primary-rgb),.2);
  color:var(--primary);
  text-decoration:none;
  font-size:.8rem;
  transition:all var(--t);
}
.recent-class-link:hover{
  background:rgba(var(--primary-rgb),.12);
  border-color:rgba(var(--primary-rgb),.4);
  transform:translateY(-1px);
}

/* Barra de progreso del paquete (Widget 2 del hub) */
.package-progress{
  margin-top:.6rem;
  width:100%;
}
.progress-bar-bg{
  width:100%;
  height:8px;
  background:rgba(255,255,255,.06);
  border-radius:4px;
  overflow:hidden;
  position:relative;
}
.progress-bar-fill{
  height:100%;
  background:linear-gradient(90deg, var(--accent), var(--primary));
  border-radius:4px;
  box-shadow:0 0 12px rgba(var(--primary-rgb),.4);
  transition:width .6s cubic-bezier(0.16,1,0.3,1);
}
.progress-label{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-top:.5rem;
  font-size:.72rem;
  color:var(--text-soft);
}
.progress-label strong{
  color:var(--primary);
  font-weight:700;
}
.package-name{
  margin-top:.6rem;
  margin-bottom:0;
  font-size:.7rem;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.1em;
}

/* ==========================================================================
   Botones
   ========================================================================== */
.widget-button,
.cta-button{
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  padding:.7rem 1.1rem;
  border:1px solid rgba(var(--primary-rgb),.25);
  border-radius:11px;
  font-weight:700; font-size:.9rem; letter-spacing:.01em;
  color:var(--text);
  background:rgba(var(--primary-rgb),.06);
  cursor:pointer;
  transition:transform var(--t), background var(--t), border-color var(--t), box-shadow var(--t);
}
.widget-button:hover,
.cta-button:hover{
  background:rgba(var(--primary-rgb),.12);
  border-color:rgba(var(--primary-rgb),.45);
  transform:translateY(-1px);
}
.widget-button:focus-visible,
.cta-button:focus-visible{outline:none; box-shadow:var(--ring)}

.cta-button{
  background:linear-gradient(135deg, var(--primary), var(--accent));
  color:var(--deep);
  border-color:transparent;
  box-shadow:0 8px 22px rgba(var(--accent-rgb),.35);
}
.cta-button:hover{
  filter:brightness(1.05);
  box-shadow:0 12px 28px rgba(var(--accent-rgb),.45);
}

.widget-button.cancel{
  background:rgba(239,68,68,.08);
  border-color:rgba(239,68,68,.35);
  color:#ffd9d9;
}
.widget-button.cancel:hover{
  background:rgba(239,68,68,.15);
  border-color:rgba(239,68,68,.55);
}

/* ============================================================================
   Próximas clases (toggle expandible)
   ============================================================================ */

/* Chevron al lado del label en el widget de próxima clase */
.toggle-upcoming-chevron{
  background:rgba(var(--primary-rgb),.06);
  border:1px solid rgba(var(--primary-rgb),.25);
  color:var(--accent);
  border-radius:50%;
  width:22px; height:22px;
  padding:0; margin-left:.5rem;
  cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center;
  font-size:.7rem;
  vertical-align:middle;
  transition:background var(--t), border-color var(--t), transform var(--t);
}
.toggle-upcoming-chevron:hover{
  background:rgba(var(--primary-rgb),.12);
  border-color:rgba(var(--primary-rgb),.45);
  transform:translateY(-1px);
}
.toggle-upcoming-chevron:focus-visible{outline:none; box-shadow:var(--ring)}

/* Lista expandida */
.upcoming-classes-list{
  width:100%;
  margin-top:.9rem;
  text-align:left;
}
.upcoming-divider{
  border:none;
  border-top:1px dashed rgba(var(--primary-rgb),.15);
  margin:.6rem 0 .8rem;
}
.upcoming-title{
  font-size:.7rem;
  text-transform:uppercase; letter-spacing:.14em;
  color:var(--muted);
  margin:0 0 .55rem;
  font-weight:700;
}

/* Card por cada clase próxima */
.upcoming-class-item{
  display:flex; align-items:center; justify-content:space-between;
  gap:.6rem;
  padding:.55rem .7rem;
  background:rgba(255,255,255,.025);
  border:1px solid var(--line);
  border-radius:10px;
  margin-bottom:.45rem;
  transition:background var(--t), border-color var(--t);
}
.upcoming-class-item:hover{
  background:rgba(var(--primary-rgb),.05);
  border-color:var(--line-strong);
}
.upcoming-class-item:last-child{margin-bottom:0}

.upcoming-class-info{flex:1; min-width:0}
.upcoming-class-date{
  margin:0;
  font-size:.85rem; font-weight:700;
  color:var(--text);
  letter-spacing:.01em;
}
.upcoming-class-meta{
  margin:.15rem 0 0;
  font-size:.72rem;
  color:var(--text-soft);
}

.upcoming-class-actions{
  display:flex; gap:.3rem;
  flex-shrink:0;
}

/* Botones chicos para acciones por item */
.widget-button.small{
  padding:.4rem .6rem;
  font-size:.8rem;
  border-radius:8px;
  min-width:auto;
}
.widget-button.small i{margin:0}


.whatsapp-container{display:flex; justify-content:center; width:100%; margin-top:auto; padding-top:1rem}
.whatsapp-link{
  background:linear-gradient(145deg,#25D366,#128C7E);
  color:#fff;
  border-color:transparent;
  border-radius:999px;
  padding:.7rem 1.2rem;
  box-shadow:0 8px 20px rgba(37,211,102,.25);
}
.whatsapp-link:hover{
  background:linear-gradient(145deg,#25D366,#128C7E);
  filter:brightness(1.06);
  border-color:transparent;
}

/* ==========================================================================
   Glossary / Help / Open shove / Risk-Variance — sin cambios respecto a v1
   ========================================================================== */
.glossary-frame-wrap{
  width:100%;
  height:calc(100vh - var(--headerH) - 160px);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--surface);
  box-shadow:var(--shadow-1);
}
.glossary-frame{width:100%; height:100%; border:0; background:var(--surface)}

.help-badge{
  display:inline-grid; place-items:center;
  width:18px; height:18px; margin-left:6px;
  border-radius:50%; font-size:11px; font-weight:800;
  background:rgba(var(--primary-rgb),.10); color:var(--primary);
  border:1px solid rgba(var(--primary-rgb),.30);
  cursor:help; user-select:none; position:relative;
}
.help-badge[data-tip]:hover::after,
.help-badge[data-tip]:focus-visible::after{
  content:attr(data-tip);
  position:absolute; left:50%; top:calc(100% + 6px);
  transform:translateX(-50%);
  white-space:normal; max-width:280px;
  background:#0d141b; color:#e6f5ff;
  border:1px solid #2a3b4a; border-radius:8px;
  padding:8px 10px; font-size:12px; line-height:1.3; font-weight:500;
  box-shadow:var(--shadow-2);
  z-index:9999; pointer-events:none;
}

.open-shove-view .osv-grid-wrap{ overflow-x:auto; -webkit-overflow-scrolling:touch }
.open-shove-view .osv-grid{
  display:grid;
  grid-template-columns:repeat(13, var(--cell));
  grid-auto-rows:var(--cell);
  gap:var(--gap, 2px);
  width:max-content; min-width:max-content;
}
@media (orientation:portrait){ .open-shove-view{ --cell:34px } }
@media (max-width:360px){ .open-shove-view{ --cell:32px } }
.view:not(#open-shove-view) .open-shove-view,
.view:not(#open-shove-view) .open-shove-root{display:none}

#risk-variance-view{max-width:min(1600px, calc(100vw - 2rem))}
#risk-variance-view .rvlab-host{width:100%}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (min-width:992px){
  .mobile-only{display:none}
  .desktop-only{display:block}

  #side-menu{transform:translateX(0); border-right:1px solid var(--line)}
  #side-menu.retracted{width:var(--sideW-collapsed)}
  #side-menu.retracted #side-menu-nav a{justify-content:center; padding:.8rem .5rem}
  #side-menu.retracted #side-menu-nav a > span,
  #side-menu.retracted .chev{display:none}
  #side-menu.retracted .folder-content{margin-left:0; border-left:0; padding-left:0}

  #main-content{margin-left:var(--sideW); transition:margin-left var(--t)}
  #main-content.retracted{margin-left:var(--sideW-collapsed)}
}
@media (max-width:991.98px){
  #main-content{margin-left:0; padding-top:.25rem}
}

@media (prefers-reduced-motion:reduce){
  *, *::before, *::after{animation-duration:.001ms!important; transition-duration:.001ms!important}
}


/* ── Ocultar secciones que requieren cuenta paga ────────────────────────────
   Cuando el body tiene mode-free-user, los items con data-requires="paid"
   se ocultan completamente. Cualquier otro modo (alumno/admin/coach) los muestra.
   --------------------------------------------------------------------------- */
body.mode-free-user [data-requires="paid"] {
  display: none !important;
}


/* ── Banner FREE_USER (en el hub) ───────────────────────────────────────────
   Banner sutil que aparece arriba del dashboard solo para usuarios free.
   Diseño: gradient cyan/accent, glow sutil, CTA WhatsApp.
   --------------------------------------------------------------------------- */
.free-user-banner {
  background: linear-gradient(135deg,
    rgba(var(--accent-rgb), 0.15),
    rgba(var(--primary-rgb), 0.08));
  border: 1px solid rgba(var(--primary-rgb), 0.3);
  border-radius: 14px;
  padding: 22px 28px;
  margin: 0 0 28px;
  box-shadow: 0 6px 28px rgba(var(--primary-rgb), 0.12);
}

.free-user-banner-content {
  display: flex;
  align-items: center;
  gap: 22px;
  flex-wrap: wrap;
}

.free-user-banner-icon {
  font-size: 2.4rem;
  color: var(--primary);
  filter: drop-shadow(0 0 12px rgba(var(--primary-rgb), 0.4));
  flex: 0 0 auto;
}

.free-user-banner-text {
  flex: 1 1 280px;
  min-width: 220px;
}

.free-user-banner-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.3rem;
  letter-spacing: 0.04em;
  color: var(--primary);
  margin: 0 0 4px;
  text-transform: uppercase;
}

.free-user-banner-subtitle {
  font-size: 0.92rem;
  color: var(--text);
  opacity: 0.85;
  margin: 0;
  line-height: 1.5;
}

.free-user-banner .cta-button {
  flex: 0 0 auto;
  background: linear-gradient(135deg, #25D366, #128C7E);
  color: #fff;
  font-weight: 700;
  padding: 11px 22px;
  border-radius: 10px;
  border: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  transition: all 0.2s;
  font-size: 0.95rem;
  box-shadow: 0 4px 12px rgba(37, 211, 102, 0.3);
}

.free-user-banner .cta-button:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(37, 211, 102, 0.45);
}

.free-user-banner .cta-button i {
  font-size: 1.1rem;
}

/* Mobile: stack vertical */
@media (max-width: 700px) {
  .free-user-banner-content {
    flex-direction: column;
    text-align: center;
  }
  .free-user-banner-text {
    flex: 1 1 100%;
  }
  .free-user-banner .cta-button {
    width: 100%;
    justify-content: center;
  }
}


/* ── Grid de herramientas en hub para FREE_USER ─────────────────────────────
   Cards clickeables para acceder a las herramientas principales.
   Reemplaza visualmente la grid de widgets de paquetes/clases.
   --------------------------------------------------------------------------- */
.hub-tools-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
  margin-top: 12px;
}

.hub-tool-card {
  cursor: pointer;
  transition: all 0.2s;
  text-align: center;
  padding: 24px 18px;
}

.hub-tool-card:hover {
  transform: translateY(-2px);
  border-color: rgba(var(--primary-rgb), 0.5);
  box-shadow: 0 8px 24px rgba(var(--primary-rgb), 0.2);
}

.hub-tool-icon {
  font-size: 2.2rem;
  color: var(--primary);
  margin-bottom: 10px;
  filter: drop-shadow(0 0 10px rgba(var(--primary-rgb), 0.3));
}

.hub-tool-card .widget-label {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.15rem;
  letter-spacing: 0.04em;
  color: var(--primary);
  margin: 0 0 6px;
  text-transform: uppercase;
}

.hub-tool-card .widget-subtext {
  font-size: 0.85rem;
  color: var(--muted);
  margin: 0;
  line-height: 1.4;
}


/* ── view-subtitle (estilo coherente con view-title) ────────────────────────
   Usada en el header del hub para FREE_USER.
   --------------------------------------------------------------------------- */
.view-subtitle {
  font-size: 0.95rem;
  color: var(--muted);
  margin: 6px 0 0;
  line-height: 1.5;
}


/* ── Modal upgrade (se muestra cuando FREE_USER toca tool bloqueada) ────────── */
.lif-upgrade-modal {
  position: fixed;
  inset: 0;
  z-index: 99000;
  display: grid;
  place-items: center;
  animation: lif-upgrade-fade-in 0.2s ease-out;
}

.lif-upgrade-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.75);
  backdrop-filter: blur(6px);
  cursor: pointer;
}

.lif-upgrade-card {
  position: relative;
  width: min(90vw, 460px);
  background: linear-gradient(160deg, var(--surface), var(--bg));
  border: 1px solid rgba(var(--primary-rgb), 0.3);
  border-radius: 18px;
  padding: 36px 32px 28px;
  box-shadow:
    0 24px 60px rgba(0, 0, 0, 0.5),
    0 0 0 1px rgba(var(--primary-rgb), 0.1) inset,
    0 0 60px rgba(var(--primary-rgb), 0.08);
  text-align: center;
  animation: lif-upgrade-slide-up 0.3s var(--ease);
}

.lif-upgrade-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: none;
  background: rgba(255, 255, 255, 0.04);
  color: var(--muted);
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: all 0.2s;
}

.lif-upgrade-close:hover {
  background: rgba(255, 255, 255, 0.1);
  color: var(--text);
}

.lif-upgrade-icon {
  width: 72px;
  height: 72px;
  margin: 0 auto 18px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  display: grid;
  place-items: center;
  font-size: 1.8rem;
  color: var(--deep);
  box-shadow:
    0 8px 24px rgba(var(--primary-rgb), 0.4),
    0 0 40px rgba(var(--primary-rgb), 0.2);
}

.lif-upgrade-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.8rem;
  letter-spacing: 0.06em;
  color: var(--primary);
  margin: 0 0 4px;
  text-transform: uppercase;
}

.lif-upgrade-tool-name {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 18px;
  letter-spacing: 0.02em;
}

.lif-upgrade-body {
  font-size: 0.92rem;
  color: var(--text-soft);
  line-height: 1.55;
  margin: 0 0 26px;
  padding: 0 8px;
}

.lif-upgrade-actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.lif-upgrade-cta-primary {
  width: 100%;
  background: linear-gradient(135deg, #25D366, #128C7E);
  color: #fff;
  font-weight: 700;
  padding: 13px 22px;
  border-radius: 10px;
  border: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  cursor: pointer;
  transition: all 0.2s;
  font-size: 0.95rem;
  box-shadow: 0 4px 14px rgba(37, 211, 102, 0.35);
}

.lif-upgrade-cta-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(37, 211, 102, 0.5);
}

.lif-upgrade-cta-primary i {
  font-size: 1.15rem;
}

.lif-upgrade-cta-secondary {
  width: 100%;
  background: transparent;
  color: var(--text-soft);
  font-weight: 600;
  padding: 11px 22px;
  border-radius: 10px;
  border: 1px solid rgba(var(--primary-rgb), 0.2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  cursor: pointer;
  transition: all 0.2s;
  font-size: 0.88rem;
}

.lif-upgrade-cta-secondary:hover {
  border-color: rgba(var(--primary-rgb), 0.5);
  color: var(--text);
  background: rgba(var(--primary-rgb), 0.04);
}

@keyframes lif-upgrade-fade-in {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes lif-upgrade-slide-up {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Cuando el modal está abierto, bloquear scroll del body */
body.lif-upgrade-open {
  overflow: hidden;
}

@media (max-width: 480px) {
  .lif-upgrade-card {
    padding: 30px 22px 22px;
  }
  .lif-upgrade-title {
    font-size: 1.5rem;
  }
  .lif-upgrade-body {
    font-size: 0.88rem;
    padding: 0;
  }
}


/* ── Icono candado en sidebar (tools bloqueadas para free_user) ─────────────── */
.lif-lock-icon {
  margin-left: auto;
  font-size: 0.75rem;
  color: var(--muted);
  opacity: 0.6;
  transition: all 0.2s;
}

.nav-link.lif-tool-locked {
  position: relative;
}

.nav-link.lif-tool-locked:hover .lif-lock-icon {
  color: var(--primary);
  opacity: 1;
}

/* En el sidebar retraído (desktop colapsado), ocultar el candado igual que el texto */
#side-menu.retracted .lif-lock-icon {
  display: none;
}

/* ============================================================
   Tier System Badge (header)
   ============================================================ */

.user-tier-badge{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 16px;
  margin-right:.6rem;
  border-radius:999px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.15);
  color:var(--text);
  font-family:'Montserrat',sans-serif;
  font-size:.85rem;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  cursor:pointer;
  transition:all .2s ease;
  white-space:nowrap;
}
.user-tier-badge:hover{ transform:translateY(-1px); }

.tier-badge-icon{ font-size:1.25rem; line-height:1; }
.tier-badge-name{ font-size:.85rem; line-height:1; }

/* Colores por tier */
.user-tier-badge.tier-bronce  { background:rgba(205,127,50,.10);  border-color:rgba(205,127,50,.40);  color:#D78E5C; }
.user-tier-badge.tier-silver  { background:rgba(192,192,192,.08); border-color:rgba(192,192,192,.35); color:#D3D1C7; }
.user-tier-badge.tier-gold    { background:rgba(239,159,39,.10);  border-color:rgba(239,159,39,.40);  color:#FAC775; }
.user-tier-badge.tier-diamond { background:rgba(110,207,240,.10); border-color:rgba(110,207,240,.40); color:#6ECFF0; }
.user-tier-badge.tier-elite   { background:rgba(212,83,126,.10);  border-color:rgba(212,83,126,.45);  color:#ED93B1; }

/* Tooltip */
.tier-tooltip{
  position:absolute;
  top:calc(100% + 8px);
  right:0;
  width:320px;
  padding:14px 16px;
  background:rgba(13,13,13,.95);
  border:1px solid rgba(var(--primary-rgb),.25);
  border-radius:12px;
  box-shadow:0 8px 24px rgba(0,0,0,.4);
  backdrop-filter:blur(8px);
  opacity:0;
  visibility:hidden;
  transform:translateY(-4px);
  transition:opacity .18s ease, transform .18s ease, visibility .18s;
  z-index:200;
  text-align:left;
  text-transform:none;
  letter-spacing:normal;
  font-weight:400;
  pointer-events:none;
}
.user-tier-badge:hover .tier-tooltip,
.user-tier-badge.show-tooltip .tier-tooltip{
  opacity:1; visibility:visible; transform:translateY(0); pointer-events:auto;
}

.tier-tooltip-header{
  display:flex; align-items:center; gap:10px;
  margin-bottom:12px;
}
.tier-tooltip-icon{ font-size:1.6rem; line-height:1; }
.tier-tooltip-name{
  font-family:'Bebas Neue',sans-serif;
  letter-spacing:.1em;
  font-size:1.1rem;
  color:var(--primary);
}
.tier-tooltip-hours{
  font-size:.7rem;
  color:rgba(255,255,255,.55);
}
.tier-tooltip-hours-bought{
  color:rgba(255,255,255,.35);
  font-style:italic;
}

.tier-tooltip-progress{ margin:8px 0 4px; }
.tier-tooltip-progress-bar{
  width:100%; height:6px;
  background:rgba(255,255,255,.08);
  border-radius:3px; overflow:hidden;
}
.tier-tooltip-progress-fill{
  height:100%; border-radius:3px;
  background:linear-gradient(90deg, var(--accent), var(--primary));
  transition:width .4s ease;
}
.tier-fill-bronce  { background:linear-gradient(90deg, #8B5A2B, #D78E5C); }
.tier-fill-silver  { background:linear-gradient(90deg, #888780, #D3D1C7); }
.tier-fill-gold    { background:linear-gradient(90deg, #BA7517, #FAC775); }
.tier-fill-diamond { background:linear-gradient(90deg, var(--accent), var(--primary)); }
.tier-fill-elite   { background:linear-gradient(90deg, #993556, #ED93B1); }

.tier-tooltip-progress-labels{
  display:flex; justify-content:space-between;
  font-size:.65rem;
  color:rgba(255,255,255,.5);
  margin-top:5px;
  margin-bottom:10px;
}

.tier-tooltip-message{
  font-size:.78rem;
  color:rgba(255,255,255,.85);
  line-height:1.5;
  margin:0 0 6px;
}
.tier-tooltip-message strong{ font-weight:700; }
.tier-tooltip-elite{ color:var(--primary); font-weight:700; font-size:.9rem; }

.tier-tooltip-prize{
  font-size:.72rem;
  color:rgba(255,255,255,.65);
  margin:0;
  padding-top:8px;
  border-top:1px dashed rgba(255,255,255,.08);
}

/* Colores de "tier name" inline en el tooltip */
.tier-text-bronce  { color:#D78E5C; }
.tier-text-silver  { color:#D3D1C7; }
.tier-text-gold    { color:#FAC775; }
.tier-text-diamond { color:#6ECFF0; }
.tier-text-elite   { color:#ED93B1; }

/* Mobile: badge más compacto (solo ícono visible) */
@media (max-width:768px){
  .tier-badge-name{ display:none; }
  .user-tier-badge{ padding:9px 12px; }
  .tier-tooltip{
    right:auto;
    left:50%;
    transform:translateX(-50%) translateY(-4px);
    width:290px;
  }
  .user-tier-badge:hover .tier-tooltip,
  .user-tier-badge.show-tooltip .tier-tooltip{
    transform:translateX(-50%) translateY(0);
  }
}
/* ============================================================
   FREE User Badge (header)
   ============================================================ */

.user-free-badge{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 16px;
  margin-right:.6rem;
  border-radius:999px;
  background:rgba(var(--primary-rgb),.10);
  border:1px solid rgba(var(--primary-rgb),.40);
  color:#fff;
  font-family:'Montserrat',sans-serif;
  font-size:.85rem;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  cursor:pointer;
  transition:all .2s ease;
  white-space:nowrap;
}
.user-free-badge:hover{ transform:translateY(-1px); }

.free-badge-icon{ font-size:1.05rem; color:var(--primary); line-height:1; }
.free-badge-name{ font-size:.85rem; line-height:1; }

/* Tooltip */
.free-tooltip{
  position:absolute;
  top:calc(100% + 8px);
  right:0;
  width:300px;
  padding:14px 16px;
  background:rgba(13,13,13,.95);
  border:1px solid rgba(var(--primary-rgb),.3);
  border-radius:12px;
  box-shadow:0 8px 24px rgba(0,0,0,.4);
  backdrop-filter:blur(8px);
  opacity:0;
  visibility:hidden;
  transform:translateY(-4px);
  transition:opacity .18s ease, transform .18s ease, visibility .18s;
  z-index:200;
  text-align:left;
  text-transform:none;
  letter-spacing:normal;
  font-weight:400;
  pointer-events:none;
}
.user-free-badge:hover .free-tooltip,
.user-free-badge.show-tooltip .free-tooltip{
  opacity:1; visibility:visible; transform:translateY(0); pointer-events:auto;
}

.free-tooltip-header{
  display:flex; align-items:center; gap:10px;
  margin-bottom:10px;
  padding-bottom:10px;
  border-bottom:1px dashed rgba(255,255,255,.08);
}
.free-tooltip-header > i{
  font-size:1.4rem;
  color:var(--primary);
}
.free-tooltip-name{
  font-family:'Bebas Neue',sans-serif;
  letter-spacing:.1em;
  font-size:1.05rem;
  color:var(--primary);
  line-height:1;
}
.free-tooltip-sub{
  font-size:.7rem;
  color:rgba(255,255,255,.55);
  margin-top:3px;
}

.free-tooltip-message{
  font-size:.78rem;
  color:rgba(255,255,255,.85);
  margin:0 0 8px;
}

.free-tooltip-benefits{
  list-style:none;
  padding:0;
  margin:0 0 12px;
  font-size:.75rem;
  color:rgba(255,255,255,.8);
  line-height:1.6;
}
.free-tooltip-benefits li{
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:5px;
}
.free-tooltip-benefits li i{
  color:#22c55e;
  font-size:.7rem;
  flex-shrink:0;
}

.free-tooltip-cta{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  width:100%;
  padding:9px;
  background:linear-gradient(135deg, #25D366, #128C7E);
  color:#fff;
  border:none;
  border-radius:8px;
  font-weight:700;
  font-size:.8rem;
  text-decoration:none;
  cursor:pointer;
  transition:all .2s ease;
}
.free-tooltip-cta:hover{
  filter:brightness(1.05);
  transform:translateY(-1px);
}

/* Mobile: badge más compacto (solo ícono visible) */
@media (max-width:768px){
  .free-badge-name{ display:none; }
  .user-free-badge{ padding:9px 12px; }
  .free-tooltip{
    right:auto;
    left:50%;
    transform:translateX(-50%) translateY(-4px);
    width:280px;
  }
  .user-free-badge:hover .free-tooltip,
  .user-free-badge.show-tooltip .free-tooltip{
    transform:translateX(-50%) translateY(0);
  }
}
/* Fix: el atributo `hidden` debe ganarle al display:inline-flex de los badges */
.user-tier-badge[hidden],
.user-free-badge[hidden]{
  display:none;
}

/* ============================================================
   Staff Role Badge (header) — FOUNDER / HEAD_COACH / COACH / SELLER
   Convención marca LIF: solo texto + cyan unificado, sin emoji
   ============================================================ */

.user-role-badge{
  position:relative;
  display:inline-flex;
  align-items:center;
  padding:10px 16px;
  margin-right:.6rem;
  border-radius:999px;
  background:rgba(var(--primary-rgb),.10);
  border:1px solid rgba(var(--primary-rgb),.40);
  color:var(--primary);
  font-family:'Montserrat',sans-serif;
  font-size:.85rem;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  cursor:default;
  transition:transform .2s ease;
  white-space:nowrap;
}
.user-role-badge:hover{ transform:translateY(-1px); }

.role-badge-name{
  font-size:.85rem;
  line-height:1;
}

/* Fix: el atributo `hidden` debe ganarle al display:inline-flex */
.user-role-badge[hidden]{ display:none; }

/* Iniciales: ocultas en desktop, visibles en mobile */
.role-badge-initials{ display:none; }

/* Mobile: badge circular con iniciales (texto completo se oculta) */
@media (max-width:768px){
  .user-role-badge{
    padding:0;
    width:38px;
    height:38px;
    border-radius:50%;
    justify-content:center;
  }
  .role-badge-name{ display:none; }
  .role-badge-initials{
    display:inline-flex;
    font-size:.85rem;
    font-weight:800;
    letter-spacing:0;
    line-height:1;
  }
}

/* ============================================================
   Founder-only folders (Administración / Facturación)
   Visibles SOLO cuando body tiene mode-founder.
   Mismo patrón que body.mode-free-user [data-requires="paid"].
   ============================================================ */
.founder-only{ display:none; }
body.mode-founder .founder-only{ display:block; }

/* Separador interno dentro de los folder-content */
.folder-divider{
  height:1px;
  margin:8px 12px 8px 0;
  background:linear-gradient(90deg,
    rgba(var(--primary-rgb),.22),
    rgba(var(--primary-rgb),.04) 70%,
    transparent);
}