/* ==========================================================================
   GoCorte — Panel Admin 2025
   Paleta: blanco (#ffffff), negro (#0b0f19) y acentos azul oscuro (#0d47a1)
   Ultra responsive · Animaciones sutiles · Accesible · Dark Mode
   ========================================================================== */

/* --------------------------- Reset & Base --------------------------- */
*,
*::before,
*::after { box-sizing: border-box; }

:root {
  --bg: #ffffff;
  --text: #0b0f19;         /* negro profundo legible */
  --muted: #6b7280;        /* gris neutro (texto secundario) */
  --card: #ffffff;
  --card-2: #f8fafc;
  --border: #e5e7eb;
  --accent: #0d47a1;       /* azul oscuro */
  --accent-600: #0b3d8a;
  --accent-700: #0a3578;
  --accent-200: #bfdbfe;
  --success: #22c55e;
  --danger: #ef4444;
  --warning: #f59e0b;

  --radius: 16px;
  --shadow-1: 0 8px 24px rgba(2, 6, 23, 0.06);
  --shadow-2: 0 10px 30px rgba(2, 6, 23, 0.10);
  --ring: 0 0 0 3px rgba(13, 71, 161, 0.25);

  --transition: 180ms cubic-bezier(.2,.7,.3,1);
  --transition-slow: 340ms cubic-bezier(.2,.7,.3,1);

  /* Tipografía fluida */
  --fs-base: clamp(14px, 1.1vw, 16px);
  --fs-sm: clamp(12px, .95vw, 14px);
  --fs-lg: clamp(16px, 1.25vw, 18px);
  --fs-xl: clamp(20px, 2vw, 28px);
  --fs-xxl: clamp(28px, 4vw, 40px);

  /* Altura estimada del header p/ sticky sidebar */
  --header-h: 64px;

  /* Bottom nav (solo mobile, pero defino tokens acá) */
  --bn-h: 64px;
}

@media (prefers-reduced-motion: reduce) {
  :root { --transition: 0ms; --transition-slow: 0ms; }
  * { animation: none !important; transition: none !important; }
}

html, body {
  margin: 0;
  padding: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji";
  background: var(--bg);
  color: var(--text);
  font-size: var(--fs-base);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img, svg, video, canvas { max-width: 100%; height: auto; }

a { color: inherit; text-decoration: none; }
button, a, input { transition: all var(--transition); }

/* --------------------------- Dark Mode --------------------------- */
body.dark-mode {
  --bg: #0b0f19;
  --text: #f8fafc;
  --muted: #cbd5e1;
  --card: #0f172a;
  --card-2: #111827;
  --border: #1f2937;
  --accent: #60a5fa;      /* azul claro en dark para contraste */
  --accent-600: #3b82f6;
  --accent-700: #2563eb;
  --accent-200: #93c5fd;
  --shadow-1: 0 8px 24px rgba(0,0,0,.25);
  --shadow-2: 0 10px 30px rgba(0,0,0,.35);
}

/* --------------------------- Utilitarios --------------------------- */
.small { color: var(--muted); font-size: var(--fs-sm); }
.hide-sm { display: inline; }
@media (max-width: 520px) { .hide-sm { display: none; } }

/* Más ancho en desktop: hasta 1440px y márgenes más finos */
.wrap {
  max-width: min(1440px, 96vw);
  margin: 0 auto;
  padding: 20px clamp(10px, 2.5vw, 28px) 24px; /* bottom chico por defecto; en mobile lo ajusto */
}

/* --------------------------- Header --------------------------- */
.header {
  position: sticky; top: 0; z-index: 30;
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  padding: 12px clamp(12px, 3vw, 24px);
  border-bottom: 1px solid var(--border);
  background: color-mix(in srgb, var(--bg) 80%, transparent);
  backdrop-filter: saturate(160%) blur(8px);
}

.brand {
  display: flex; align-items: center; gap: 10px;
  font-weight: 700; letter-spacing: .2px;
  font-size: var(--fs-lg);
}
.dot{
  display:inline-block;width:10px;height:10px;border-radius:50%;
  background: var(--accent);
  box-shadow: 0 0 0 0 rgba(13,71,161,.6);
  animation: pulse 2s infinite;
}
@keyframes pulse {
  0% { box-shadow: 0 0 0 0 rgba(13,71,161,.6);}
  70% { box-shadow: 0 0 0 12px rgba(13,71,161,0);}
  100% { box-shadow: 0 0 0 0 rgba(13,71,161,0);}
}

.head-actions { display:flex; align-items:center; gap:10px; }

/* --------------------------- Botones --------------------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  background: var(--card-2); color: var(--text);
  border: 1px solid var(--border);
  padding: 10px 14px; border-radius: 12px;
  font-weight: 600; cursor: pointer;
  box-shadow: var(--shadow-1);
}
.btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-2); }
.btn:active { transform: translateY(0); }

.btn.dark {
  background: var(--accent); color: #fff; border-color: transparent;
}
.btn.dark:hover { background: var(--accent-600); }
.btn.dark:active { background: var(--accent-700); }

.btn.logout {
  background: transparent; border-color: var(--border);
}
.btn.logout:hover { border-color: var(--accent); color: var(--accent); }

.btn:focus-visible { outline: none; box-shadow: var(--ring); }

/* --------------------------- Campana / Notificaciones --------------------------- */
.bell {
  position: relative;
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--card-2); border: 1px solid var(--border);
  cursor: pointer; box-shadow: var(--shadow-1);
}
.bell:hover { transform: translateY(-1px); box-shadow: var(--shadow-2); }

.badge {
  position: absolute; top: -6px; right: -4px;
  min-width: 18px; height: 18px; padding: 0 4px;
  background: var(--danger); color: #fff; font-size: 11px; font-weight: 800;
  border-radius: 999px; display: inline-flex; align-items: center; justify-content: center;
  border: 2px solid var(--bg);
}

.dropdown {
  display: none;
  position: absolute; right: 0; top: calc(100% + 10px);
  width: min(92vw, 380px);
  background: var(--card); border: 1px solid var(--border);
  border-radius: 14px; box-shadow: var(--shadow-2);
  overflow: hidden;
  animation: dropFade var(--transition-slow);
}
@keyframes dropFade {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.dropdown .toolbar {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 12px 14px; border-bottom: 1px solid var(--border);
  background: var(--card-2);
}
.note {
  padding: 12px 14px; border-bottom: 1px solid var(--border);
}
.note:last-child { border-bottom: 0; }
.note .row { display:flex; align-items:center; justify-content:space-between; gap:12px; }
.note .small { color: var(--muted); }

/* --------------------------- Switch (modo) --------------------------- */
.switch { position: relative; display: inline-block; width: 56px; height: 30px; }
.switch input { display:none; }
.slider {
  position: absolute; inset: 0; border-radius: 999px;
  background: var(--card-2); border: 1px solid var(--border);
  box-shadow: inset 0 0 0 2px rgba(0,0,0,0.02);
  cursor: pointer;
}
.slider::before {
  content:""; position: absolute; top: 50%; left: 4px; translate: 0 -50%;
  width: 22px; height: 22px; border-radius: 50%;
  background: #fff; border: 1px solid var(--border);
  box-shadow: var(--shadow-1);
  transition: all var(--transition);
}
.switch input:checked + .slider {
  background: color-mix(in srgb, var(--accent) 14%, var(--card-2));
  border-color: color-mix(in srgb, var(--accent) 40%, var(--border));
}
.switch input:checked + .slider::before { left: 30px; background: #fff; }

/* --------------------------- Cards / Contenedores --------------------------- */
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: clamp(14px, 2.2vw, 20px);
  margin: 14px 0;
  box-shadow: var(--shadow-1);
  animation: fadeUp var(--transition-slow);
}
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* --------------------------- KPIs --------------------------- */
.kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 14px;
}
.kpi {
  background: var(--card-2);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 14px;
  position: relative;
  overflow: hidden;
}
.kpi::after{
  content:""; position:absolute; inset: -1px; border-radius: 14px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 22%, transparent), transparent);
  translate: -100% 0;
  animation: shimmer 3.5s infinite;
  opacity:.25; pointer-events:none;
}
@keyframes shimmer { to { translate: 100% 0; } }

.kpi h4 { margin: 0 0 6px; font-size: var(--fs-sm); color: var(--muted); }
.kpi .num {
  font-size: clamp(26px, 4vw, 34px);
  font-weight: 800; letter-spacing: -0.5px;
}

/* --------------------------- Logros --------------------------- */
.achv {
  display: none;
  background: linear-gradient(90deg, color-mix(in srgb, var(--accent) 10%, var(--card)), var(--card));
  border: 1px solid color-mix(in srgb, var(--accent) 30%, var(--border));
  border-left: 5px solid var(--accent);
  border-radius: var(--radius);
  padding: 14px;
  margin: 14px 0;
  box-shadow: var(--shadow-1);
}
.achv.show { display: block; animation: slideIn var(--transition-slow); }
@keyframes slideIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* --------------------------- Acciones rápidas --------------------------- */
.quick {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 10px;
}
.quick .btn { width: 100%; padding: 12px 14px; }

/* --------------------------- Actividad reciente --------------------------- */
.item {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 10px 0; border-bottom: 1px dashed var(--border);
}
.item:last-child { border-bottom: 0; }

/* --------------------------- Grid de columnas --------------------------- */
.grid {
  display: grid; gap: 14px; margin: 14px 0;
  grid-template-columns: repeat(12, 1fr);
}
@media (max-width: 960px) {
  .grid { grid-template-columns: 1fr; }
  .grid > .card { grid-column: auto !important; }
}

/* --------------------------- Copybox (inputs de links) --------------------------- */
.copybox {
  background: var(--card-2);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 10px;
}
.copybox input[type="text"]{
  width: 100%;
  border: 1px dashed var(--border);
  background: transparent; color: var(--text);
  padding: 10px 12px; border-radius: 10px;
  font-family: inherit; font-size: var(--fs-base);
}
.copybox input[type="text"]:focus { outline: none; box-shadow: var(--ring); border-color: var(--accent); }

/* --------------------------- Bottom Navigation (solo mobile) --------------------------- */
@media (max-width: 919.98px){
  :root{
    --safe: env(safe-area-inset-bottom, 0px);
  }

  /* El contenido deja espacio real para la barra + safe-area */
  .wrap{
    padding-bottom: calc(var(--bn-h) + var(--safe) + 24px);
  }

  .bottom-nav{
    position: fixed; left: 0; right: 0; bottom: 0;
    height: var(--bn-h);
    background: color-mix(in srgb, var(--card) 85%, transparent);
    border-top: 1px solid var(--border);
    display: grid; grid-template-columns: repeat(3, 1fr);
    align-items: stretch;
    z-index: 9999;
    backdrop-filter: saturate(160%) blur(8px);
    will-change: transform; transform: translateZ(0);
    contain: layout paint size;
    touch-action: manipulation;
  }

  .bottom-nav::after{
    content:"";
    position:absolute; left:0; right:0;
    bottom: calc(-1 * var(--safe));
    height: var(--safe);
    background: inherit;
    border-top: inherit;
    pointer-events: none;
  }

  .nav-item{
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    gap: 4px; color: var(--muted); font-weight: 600; position: relative;
  }
  .nav-item:hover { color: var(--text); }
  .nav-item.active { color: var(--accent); }
  .nav-icon { font-size: 18px; line-height: 1; }
  .nav-label { font-size: 12px; }
}

/* Desktop: oculto bottom-nav y no reservo espacio extra */
@media (min-width: 920px){
  .bottom-nav{ display:none !important; }
}

/* --------------------------- Formularios (genérico) --------------------------- */
input, select, textarea {
  background: var(--card-2);
  border: 1px solid var(--border);
  border-radius: 10px;
  color: var(--text);
  padding: 10px 12px;
}
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--accent); box-shadow: var(--ring); }

/* --------------------------- Tablas (si aparecen) --------------------------- */
table { width: 100%; border-collapse: collapse; }
th, td { padding: 10px 12px; border-bottom: 1px solid var(--border); }
th { text-align:left; color: var(--muted); font-weight: 700; font-size: var(--fs-sm); }

/* --------------------------- Helpers de layout --------------------------- */
h1, h2, h3, h4 { margin: 0 0 8px; }
h2 { font-size: var(--fs-xl); letter-spacing: -0.3px; }
h4 { font-size: var(--fs-lg); }

.row { display:flex; align-items:center; gap:10px; }
.center { display:flex; align-items:center; justify-content:center; }

/* --------------------------- Estados --------------------------- */
.badge-state {
  display:inline-flex; align-items:center; gap:6px;
  font-size: 11px; font-weight: 800; padding: 4px 8px;
  border-radius: 999px; border: 1px solid var(--border);
  background: var(--card-2); color: var(--text);
}
.badge-state.paid { border-color: color-mix(in srgb, var(--success) 40%, var(--border)); color: var(--success); }
.badge-state.unpaid { border-color: color-mix(in srgb, var(--danger) 40%, var(--border)); color: var(--danger); }

/* --------------------------- Toast liviano (para “Copiado”) --------------------------- */
#copiadoMsg {
  font-weight: 700;
  animation: popIn 1.2s ease;
}
@keyframes popIn {
  0% { opacity: 0; transform: translateY(6px) scale(.98); }
  40% { opacity: 1; transform: translateY(0) scale(1); }
  100% { opacity: 0; transform: translateY(-4px) scale(.98); }
}

/* --------------------------- Accesibilidad --------------------------- */
:focus-visible { outline: none; box-shadow: var(--ring); border-radius: 10px; }
[role="button"], .btn, .bell { -webkit-tap-highlight-color: transparent; }

/* --------------------------- Extras pro --------------------------- */
.card:hover{
  border-color: color-mix(in srgb, var(--accent) 18%, var(--border));
}
@media (hover: hover) and (pointer: fine) {
  .card:hover { transform: translateY(-2px); box-shadow: var(--shadow-2); }
}

/* Micro-anim en enlaces de acción dentro de .quick */
.quick .btn::after{
  content: "→"; opacity: 0; transform: translateX(-6px);
  transition: transform var(--transition), opacity var(--transition);
}
.quick .btn:hover::after{ opacity: .9; transform: translateX(4px); }

/* --------------------------- Compat móvil “notch” --------------------------- */
@supports(padding:max(0px)) {
  .header { padding-left: max(12px, env(safe-area-inset-left)); padding-right: max(12px, env(safe-area-inset-right)); }
}

/* --------------------------- Responsivo fino --------------------------- */
@media (max-width: 820px){
  .header { gap: 8px; }
  .brand { font-size: 16px; }
  .btn { padding: 10px 12px; }
}
@media (max-width: 420px){
  .btn { padding: 9px 10px; border-radius: 10px; }
  .kpi .num { font-size: 22px; }
}

/* =======================================================================
   Sidebar izquierda (solo desktop) para "Acciones principales"
   No rompe mobile · Paleta original · Degradé azul para cabecera
   ======================================================================= */
@media (min-width:1024px){
  /* 2 columnas: sidebar + contenido (sidebar más generosa) */
  .wrap{
    display:grid;
    grid-template-columns: 320px minmax(0,1fr);
    gap:18px;
    align-items:start;
  }

  /* Header arriba, a todo lo ancho */
  .wrap > .header{ grid-column:1 / -1; }

  /* Por defecto, las cards van en la columna de contenido */
  .wrap > .card{ grid-column:2; }

  /* La card que contiene .quick pasa a ser la barra izquierda fija */
  .wrap > .card:has(.quick){
    grid-column:1;
    grid-row:2 / span 999;
    position:sticky;
    top:calc(var(--header-h) + 12px);
    max-height:calc(100vh - var(--header-h) - 24px);
    overflow:auto;
    padding:0;
    border:1px solid var(--border);
    border-radius:18px;
    background:var(--card);
    box-shadow:var(--shadow-2);
  }

  /* Oculta el “Acciones principales” dentro de esa card */
  .wrap > .card:has(.quick) > .small{ display:none; }

  /* Cabecera fija de la barra (marcamos que estás en el panel) */
  .wrap > .card:has(.quick)::before{
    content:"🏠 Panel (Inicio)";
    display:block;
    position:sticky; top:0; z-index:2;
    padding:16px 18px;
    font-weight:800; color:#fff; letter-spacing:.2px;
    background: linear-gradient(135deg,
                 color-mix(in srgb, var(--accent) 10%, #08142b) 0%,
                 var(--accent-700) 48%,
                 var(--accent) 100%);
    border-top-left-radius:18px;
    border-top-right-radius:18px;
    box-shadow: inset 0 -1px rgba(255,255,255,.08);
  }

  /* Pila vertical de accesos */
  .wrap > .card:has(.quick) .quick{
    display:flex;
    flex-direction:column;
    gap:6px;
    padding:10px;
  }

  /* Ítems del menú (scopeado para NO pisar otros .btn) */
  .wrap > .card:has(.quick) .quick .btn{
    all:unset;
    display:flex; align-items:center; gap:10px;
    padding:12px 14px;
    border-radius:12px;
    border:1px solid var(--border);
    background:var(--card-2);
    color:var(--text);
    cursor:pointer;
    position:relative;
    transition: background var(--transition), border-color var(--transition), box-shadow var(--transition), transform var(--transition);
  }
  .wrap > .card:has(.quick) .quick .btn:hover{
    background: color-mix(in srgb, var(--accent) 8%, var(--card-2));
    border-color: color-mix(in srgb, var(--accent) 38%, var(--border));
    box-shadow: inset 4px 0 0 0 var(--accent);
    transform: translateX(1px);
  }

  /* Activo (agregar class="is-active" o aria-current="page") */
  .wrap > .card:has(.quick) .quick .btn.is-active,
  .wrap > .card:has(.quick) .quick .btn[aria-current="page"]{
    background:
      linear-gradient(0deg, color-mix(in srgb, var(--accent) 14%, transparent),
                           color-mix(in srgb, var(--accent) 14%, transparent)),
      var(--card-2);
    border-color: color-mix(in srgb, var(--accent) 55%, var(--border));
    box-shadow: inset 4px 0 0 0 var(--accent-700);
  }

  /* Evito que el “→” de tu micro-animación aparezca dentro del menú */
  .wrap > .card:has(.quick) .quick .btn::after{ content:none; }

  /* Dark mode del menú */
  .dark-mode .wrap > .card:has(.quick){
    background:var(--card);
    border-color:var(--border);
    box-shadow:0 14px 36px rgba(0,0,0,.35);
  }
  .dark-mode .wrap > .card:has(.quick) .quick .btn{
    background:#0f172a; border-color:var(--border); color:var(--text);
  }
  .dark-mode .wrap > .card:has(.quick) .quick .btn:hover{
    background: color-mix(in srgb, var(--accent) 18%, #0f172a);
    border-color: color-mix(in srgb, var(--accent) 45%, var(--border));
    box-shadow: inset 4px 0 0 0 var(--accent-600);
  }
  .dark-mode .wrap > .card:has(.quick) .quick .btn.is-active,
  .dark-mode .wrap > .card:has(.quick) .quick .btn[aria-current="page"]{
    background:
      linear-gradient(0deg, color-mix(in srgb, var(--accent) 24%, transparent),
                           color-mix(in srgb, var(--accent) 24%, transparent)),
      #0b1224;
    border-color: color-mix(in srgb, var(--accent) 60%, var(--border));
    box-shadow: inset 4px 0 0 0 var(--accent-600);
  }
}



/* FIX: evita scroll infinito por span exagerado en la sidebar */
@media (min-width:1024px){
  .wrap { 
    grid-auto-rows: min-content;        /* filas implícitas compactas */
  }
  .wrap > .card:has(.quick){
    grid-row: 2 / span 15 !important;   /* antes: span 999 */
  }
}




/* Iconos consistentes en bottom-nav */
.bottom-nav .nav-icon svg{
  width: 22px; height: 22px;
  stroke: currentColor; fill: none;
  stroke-width: 1.8;
  stroke-linecap: round; stroke-linejoin: round;
}




/* ====== Bottom-nav móvil: 4 columnas, colores neutros ====== */
@media (max-width: 919.98px){
  .bottom-nav{ grid-template-columns: repeat(4, 1fr); } /* antes: 3 */
  .bottom-nav .nav-item{ color: var(--muted); }         /* todos iguales */
  .bottom-nav .nav-item.active{ color: var(--muted); }  /* sin azul en activo */
  .bottom-nav .nav-label{ font-size: 11px; }            /* ayuda a que entren 4 */
  
  /* Ocultar "Acciones principales" en mobile, pero sin borrar */
  .card:has(.quick){ display: none; }
}

/* Iconos SVG consistentes (ya los tenés, lo refuerzo por si falta en algún build) */
.bottom-nav .nav-icon svg{
  width: 22px; height: 22px;
  stroke: currentColor; fill: none;
  stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round;
}

/* ====== Drawer de Accesos (solo mobile) ====== */
@media (max-width: 919.98px){
  body.noscroll{ overflow: hidden; }

  .m-drawer{
    position: fixed; inset: 0; z-index: 10000; display: none;
  }
  .m-drawer.open{ display: block; }

  .m-drawer__overlay{
    position: absolute; inset: 0;
    background: rgba(0,0,0,.40);
    backdrop-filter: blur(2px);
  }
  .m-drawer__panel{
    position: absolute; top: 0; right: 0; height: 100%;
    width: min(86vw, 360px);
    background: var(--card);
    border-left: 1px solid var(--border);
    box-shadow: var(--shadow-2);
    display: flex; flex-direction: column;
    transform: translateX(100%);
    transition: transform var(--transition-slow);
  }
  .m-drawer.open .m-drawer__panel{ transform: translateX(0); }

  .m-drawer__header{
    padding: 14px 16px; border-bottom: 1px solid var(--border);
    display: flex; align-items: center; justify-content: space-between;
  }
  .m-drawer__title{ font-weight: 800; }

  .m-drawer__list{
    padding: 10px; display: flex; flex-direction: column; gap: 8px;
    overflow: auto; -webkit-overflow-scrolling: touch;
  }
  .m-drawer__item{
    display: flex; align-items: center; gap: 10px;
    padding: 12px 12px; border-radius: 12px;
    border: 1px solid var(--border);
    background: var(--card-2); color: var(--text); font-weight: 600;
  }
  .m-drawer__item:hover{
    background: color-mix(in srgb, var(--accent) 8%, var(--card-2));
    border-color: color-mix(in srgb, var(--accent) 38%, var(--border));
  }
}

/* ==== FIX: que el drawer NO aparezca en desktop ==== */
.m-drawer{ display: none; }  /* oculto por defecto en todos los tamaños */

/* En mobile lo controlo con la clase .open */
@media (max-width: 919.98px){
  .m-drawer{
    display: none;            /* base oculto */
    position: fixed; inset: 0;
    z-index: 10000;
  }
  .m-drawer.open{ display: block; }
}

/* Cinturón y tirantes: incluso si queda .open en desktop, que no se vea */
@media (min-width: 920px){
  .m-drawer,
  .m-drawer.open{ display: none !important; visibility: hidden !important; }
}
/* ====== Bottom nav móvil: fija en iOS/Android sin JS ====== */
@media (max-width: 919.98px){
  /* reserva de espacio real para la barra + safe-area */
  .wrap{
    padding-bottom: calc(var(--bn-h) + env(safe-area-inset-bottom) + 16px) !important;
  }

  .bottom-nav{
    position: fixed; left: 0; right: 0; bottom: 0;
    height: var(--bn-h);
    z-index: 9999;
    background: color-mix(in srgb, var(--card) 85%, transparent);
    border-top: 1px solid var(--border);

    /* IMPORTANTES: 4 columnas y sin transformaciones */
    display: grid; grid-template-columns: repeat(4, 1fr);
    align-items: center;
    will-change: auto; transform: none;
    padding-bottom: 0; /* no depender del safe-area aquí */
  }

  /* Pinta el safe-area sin empujar la barra */
  .bottom-nav::after{
    content:"";
    position:absolute; left:0; right:0;
    bottom: calc(-1 * env(safe-area-inset-bottom));
    height: env(safe-area-inset-bottom);
    background: inherit; border-top: inherit;
    pointer-events: none;
  }

  .nav-item{ min-width: 0; }
  .nav-icon{ line-height: 0; }
}

/* Quitar el azul del activo para que todos queden parejos */
.bottom-nav .nav-item.active{ color: var(--muted); }  /* o usa var(--text) si querés más contraste */
.bottom-nav .nav-item:hover{ color: var(--text); }





/* Todos los tabs con mismo color (sin azul distinto) */
.bottom-nav .nav-item.active{ color: inherit; }

/* ====== PC ONLY: Link público igual en largo/alto que las demás tarjetas ====== */
@media (min-width: 920px){
  /* Selecciona la card que contiene el input #perfilLink y fuerza full row */
  .grid .card:has(#perfilLink){
    grid-column: 1 / -1 !important;   /* pisa el inline "span 7" */
    min-height: 120px;                 /* alto mínimo prolijo */
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  /* Layout interno parejito */
  .grid .card:has(#perfilLink) .copybox{
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 10px;                  /* separa del título */
  }

  /* Input a todo el ancho y botón alineado */
  .grid .card:has(#perfilLink) .copybox input{
    flex: 1 1 auto;
    height: 44px;
  }
  .grid .card:has(#perfilLink) .copybox > div{
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    gap: 8px;
  }

  /* Opcional: misma “skin” que los KPI (sutil) */
  .grid .card:has(#perfilLink) .copybox{
    background: linear-gradient(90deg, rgba(13,71,161,0.06), transparent 60%);
    padding: 12px;
    border-radius: 10px;
  }
}



/* ===== Notificaciones: estable y CENTRADA en móvil, sin animaciones ===== */
.header .bell{ position: relative; z-index: 1001; }

.header .dropdown{
  display:none;
  position:absolute;          /* desktop */
  right:0; top:calc(100% + 10px);
  width: clamp(260px, 92vw, 380px);
  max-height: min(60vh, 520px);
  overflow:auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: var(--shadow-2);
  animation: none !important;
  transition: none !important;
  will-change: auto !important;
}

/* En móvil: fixed y centrada, y con z-index alto */
@media (max-width: 919.98px){
  .header .dropdown{
    position: fixed;
    left: 50%;
    right: auto;
    transform: translateX(-50%);
    top: calc(var(--header-h, 64px) + 8px);
    width: min(92vw, 380px);
    max-height: calc(100vh - var(--header-h, 64px) - var(--bn-h, 64px) - env(safe-area-inset-bottom) - 16px);
    z-index: 10050;
  }
}

/* Backdrop para capturar toques fuera (solo visible al abrir) */
#notifBackdrop{
  position: fixed; inset: 0; z-index: 10040;
  display: none; background: transparent;
}
#notifBackdrop.show{ display:block; }

/* Bloqueo de desplazamiento del fondo cuando está el dropdown abierto */
body.noscroll{ overflow: hidden; touch-action: none; }

.header .dropdown{
    display:none;
    position:absolute; right:0; top:calc(100% + 10px);
    width: clamp(260px, 92vw, 380px);
    max-height: 520px;
    overflow:auto; -webkit-overflow-scrolling:touch; overscroll-behavior:contain;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 14px;
    box-shadow: var(--shadow-2);
  }
  @media (max-width: 919.98px){
    .header .dropdown{
      position:fixed; left:50%; right:auto; transform:translateX(-50%);
      top: calc(var(--header-h, 64px) + 8px);
      width: min(92vw, 380px);
      max-height: calc(100vh - var(--header-h, 64px) - var(--bn-h, 64px) - env(safe-area-inset-bottom) - 16px);
      z-index: 10050;
    }
  }
/* ===== Bloquear scroll del fondo cuando el drawer está abierto ===== */
/* Ya estás agregando body.noscroll desde JS, sólo faltaba el CSS */
html.noscroll,
body.noscroll{
  overflow: hidden !important;
  height: 100% !important;
}

/* iOS: “congelar” fondo con position:fixed (sin JS extra) */
body.noscroll{
  position: fixed;
  width: 100%;
  overscroll-behavior: none;     /* evita elastic scroll */
  touch-action: none;            /* ignora gestos sobre el fondo */
}

/* Permitir interacción/scroll sólo dentro del panel del drawer */
.m-drawer{
  position: fixed;
  inset: 0;
  z-index: 10040;                /* por encima del header */
  pointer-events: none;          /* bloquea clics si no está abierto */
}

.m-drawer.open{
  pointer-events: auto;
}

.m-drawer__overlay{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.35);
  opacity: 0;
  transition: opacity .18s ease;
  /* Captura toques para que no “pase” al fondo */
  touch-action: none;
}

.m-drawer.open .m-drawer__overlay{
  opacity: 1;
}

/* Panel centrado con scroll propio, sin afectar al body */
.m-drawer__panel{
  position: absolute;
  left: 50%;
  transform: translate(-50%, 12px);
  width: min(92vw, 420px);
  max-height: calc(100dvh - 24px);
  overflow: auto;
  -webkit-overflow-scrolling: touch; /* suave en iOS */
  overscroll-behavior: contain;      /* no propaga scroll */
  background: var(--card, #fff);
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 14px;
  box-shadow: 0 10px 30px rgba(0,0,0,.15);
  transition: transform .18s ease;
}

.m-drawer.open .m-drawer__panel{
  transform: translate(-50%, 0);
}

/* Evitar que el #bn tape el drawer en mobile */
@media (max-width: 919.98px){
  .m-drawer{ z-index: 10060; }
}

/* ===== Bottom Nav al 50% en mobile (32px) ===== */
@media (max-width: 919.98px){
  :root{ --bn-h: 32px; }

  #bn{
    height: var(--bn-h) !important;
    padding-bottom: calc(env(safe-area-inset-bottom) * 1); /* mantiene safe-area */
  }

  #bn .nav-item{
    padding: 2px 0;
    gap: 2px;
  }

  #bn .nav-icon svg{
    width: 18px;
    height: 18px;
  }

  #bn .nav-label{
    font-size: 10px;
    line-height: 1;
  }
}


/* === FIX BOTTOM NAV - Igual al Panel, centrada y más alta === */
@media (max-width: 919.98px){
  :root{ --bn-h: 56px !important; } /* altura cómoda (puedes subir a 60/64) */

  /* La barra en 4 columnas, centrada y sin transforms raros */
  .bottom-nav,
  #bn{
    position: fixed !important;
    left: 0 !important; right: 0 !important; bottom: 0 !important; top: auto !important;
    height: var(--bn-h) !important;
    z-index: 9999 !important;
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    align-items: center !important;
    justify-items: center !important;
    background: color-mix(in srgb, var(--card, #fff) 85%, transparent) !important;
    border-top: 1px solid var(--border, #e5e7eb) !important;
    transform: none !important; -webkit-transform: none !important; will-change: auto !important;
    padding-bottom: 0 !important;
  }

  /* Reserva real de espacio para que no se “pise” el contenido */
  .wrap{
    padding-bottom: calc(var(--bn-h) + env(safe-area-inset-bottom) + 12px) !important;
  }

  /* Safe-area pintado, sin empujar la barra */
  .bottom-nav::after,
  #bn::after{
    content: "";
    position: absolute; left: 0; right: 0;
    bottom: calc(-1 * env(safe-area-inset-bottom));
    height: env(safe-area-inset-bottom);
    background: inherit; border-top: inherit; pointer-events: none;
  }

  /* Ítems centrados y respirando */
  #bn .nav-item,
  .bottom-nav .nav-item{
    display: flex !important; flex-direction: column !important;
    align-items: center !important; justify-content: center !important;
    gap: 4px !important; min-width: 0 !important;
    color: var(--muted, #6b7280) !important;
    padding: 6px 0 !important;
  }
  #bn .nav-item.active,
  .bottom-nav .nav-item.active{ color: var(--muted, #6b7280) !important; }

  #bn .nav-icon svg,
  .bottom-nav .nav-icon svg{ width: 22px !important; height: 22px !important; }

  #bn .nav-label,
  .bottom-nav .nav-label{ font-size: 12px !important; line-height: 1 !important; }
}

/* En desktop, no mostrar bottom-nav (como en panel) */
@media (min-width: 920px){
  .bottom-nav, #bn{ display: none !important; }
}
/* ================= Bottom-Nav UNIVERSAL (móvil) ================= */
:root{ --bn-h:56px; } /* altura única (podés subir a 60/64 si querés) */

@media (max-width: 919.98px){
  /* Barra fija, 4 columnas, centrada y con blur, igual en todas */
  #bn, .bottom-nav{
    position: fixed !important;
    left: 0 !important; right: 0 !important; bottom: 0 !important; top: auto !important;
    height: var(--bn-h) !important;
    z-index: 2147483647 !important;

    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    align-items: center !important;
    justify-items: center !important;

    background: color-mix(in srgb, var(--card, #fff) 88%, transparent) !important;
    border-top: 1px solid var(--border, #e5e7eb) !important;
    backdrop-filter: saturate(160%) blur(8px) !important;
    -webkit-backdrop-filter: saturate(160%) blur(8px) !important;

    padding: 0
      max(12px, env(safe-area-inset-left))
      max(env(safe-area-inset-bottom), 0)
      max(12px, env(safe-area-inset-right)) !important;

    transform: none !important;
    -webkit-transform: none !important;
    will-change: auto !important;
    contain: layout paint size !important;
    isolation: isolate !important; /* evita que herede efectos raros */
  }

  /* Safe-area “pintado” (no empuja la barra) */
  #bn::after, .bottom-nav::after{
    content:""; position:absolute; left:0; right:0;
    bottom: calc(-1 * env(safe-area-inset-bottom));
    height: env(safe-area-inset-bottom);
    background: inherit; border-top: inherit; pointer-events:none;
  }

  /* Ítems: siempre iguales (color neutro, mismo gap) */
  #bn .nav-item, .bottom-nav .nav-item{
    display:flex !important; flex-direction:column !important;
    align-items:center !important; justify-content:center !important;
    min-width:0 !important; gap:3px !important; /* <- espaciado uniforme */
    padding: 6px 2px !important;
    color: var(--muted, #6b7280) !important;
    text-align:center; font-weight:700;
    -webkit-tap-highlight-color: transparent;
  }
  /* Todos parejos (sin azul distinto). Cambiá a var(--accent) si querés resaltar */
  #bn .nav-item.active, .bottom-nav .nav-item.active{
    color: var(--muted, #6b7280) !important;
  }

  /* Íconos y labels consistentes */
  #bn .nav-icon svg, .bottom-nav .nav-icon svg{
    width:22px !important; height:22px !important;
    stroke: currentColor; fill: none; stroke-width: 1.8;
    stroke-linecap: round; stroke-linejoin: round;
  }
  #bn .nav-label, .bottom-nav .nav-label{
    font-size: 11px !important; line-height: 1 !important; margin-top: 0 !important;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }

  /* Reserva de espacio para el contenido (todas las vistas usan .wrap) */
  .wrap{ padding-bottom: calc(var(--bn-h) + env(safe-area-inset-bottom) + 8px) !important; }
}

/* En desktop: ocultar barra y quitar el padding extra si molestara */
@media (min-width: 920px){
  #bn, .bottom-nav{ display: none !important; }
  .wrap{ padding-bottom: 24px !important; } /* opcional */
}
