/* ════════════════════════════════════════════════════════════════════
   POSEIDON V2 — OVERHAUL LAYER
   Reorganiza visualmente toda la app SIN tocar markup ni JS.
   Inspiración: Linear, Vercel, Arc Browser, Raycast.
   ════════════════════════════════════════════════════════════════════ */

/* ═══ TOKENS V2 ═══ */
:root {
    --v2-bg: #07090d;
    --v2-bg-rail: #0a0d12;
    --v2-bg-elev-1: #0e1218;
    --v2-bg-elev-2: #131820;
    --v2-bg-elev-3: #181e27;
    --v2-line: rgba(255,255,255,.06);
    --v2-line-strong: rgba(255,255,255,.10);
    --v2-line-accent: rgba(45,212,191,.20);

    --v2-text: #eef1f4;
    --v2-text-2: rgba(238,241,244,.62);
    --v2-text-3: rgba(238,241,244,.40);
    --v2-text-4: rgba(238,241,244,.22);

    --v2-accent: #2dd4bf;
    --v2-accent-2: #5eead4;
    --v2-accent-ink: #022c25;
    --v2-accent-soft: rgba(45,212,191,.12);

    --v2-success: #34d399;
    --v2-warning: #fbbf24;
    --v2-danger: #f87171;

    --v2-rail-w: 64px;
    --v2-rail-w-open: 232px;
    --v2-header-h: 60px;
    --v2-r-sm: 8px;
    --v2-r: 10px;
    --v2-r-lg: 14px;
    --v2-r-pill: 999px;

    --v2-ease: cubic-bezier(.2,.8,.2,1);
    --v2-shadow-sm: 0 1px 2px rgba(0,0,0,.30);
    --v2-shadow: 0 8px 24px rgba(0,0,0,.40), 0 1px 2px rgba(0,0,0,.20);
    --v2-shadow-lg: 0 24px 60px rgba(0,0,0,.55), 0 2px 6px rgba(0,0,0,.30);
}

/* ═══ RESET DE BACKGROUND GLOBAL ═══ */
html, body {
    background: var(--v2-bg) !important;
    color: var(--v2-text) !important;
}

body::before {
    content: '';
    position: fixed; inset: 0; z-index: -2;
    background:
        radial-gradient(ellipse 1100px 600px at 100% 0%, rgba(45,212,191,.05), transparent 55%),
        radial-gradient(ellipse 900px 500px at 0% 100%, rgba(45,212,191,.03), transparent 55%),
        linear-gradient(180deg, #07090d 0%, #05070a 100%);
    pointer-events: none;
}

/* ═══ SIDEBAR → RAIL DE ÍCONOS (64px, expande a 232px en hover) ═══ */
.sidebar {
    position: fixed !important;
    top: 12px !important;
    left: 12px !important;
    bottom: 12px !important;
    width: var(--v2-rail-w-open) !important;
    background: var(--v2-bg-rail) !important;
    border: 1px solid var(--v2-line-strong) !important;
    border-radius: var(--v2-r-lg) !important;
    box-shadow: var(--v2-shadow-lg) !important;
    overflow: hidden !important;
    z-index: 100 !important;
    display: flex !important;
    flex-direction: column !important;
    padding: 14px 8px !important;
    backdrop-filter: blur(20px) saturate(140%);
    transform: none !important;
}
/* Cuando hamburger pinea el sidebar abierto, empuja el main-area */
body:has(.sidebar.open) .main-area {
    padding-left: calc(var(--v2-rail-w-open) + 36px) !important;
}
/* Hamburger \u2192 estado activo cuando sidebar.open */
body:has(.sidebar.open) .hamburger-btn {
    background: var(--v2-accent-soft) !important;
    border-color: var(--v2-line-accent) !important;
    color: var(--v2-accent-2) !important;
}

/* Brand: en rail solo se ve el logo cuadrado; expande, aparece el texto */
.sidebar-brand {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 4px 4px 16px !important;
    border-bottom: 1px solid var(--v2-line) !important;
    margin-bottom: 10px !important;
    min-height: 56px !important;
    position: relative !important;
}
.sidebar-brand > *:first-child {
    flex-shrink: 0;
}
/* Marca premium: un cuadrado teal con monograma P, generado por CSS */
.sidebar-brand::before {
    content: 'P';
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: linear-gradient(135deg, #2dd4bf 0%, #0e7c6e 100%);
    color: #022c25;
    font: 800 19px var(--ps-font-sans, system-ui);
    letter-spacing: -0.02em;
    box-shadow: 0 4px 12px -2px rgba(45,212,191,.45), inset 0 1px 0 rgba(255,255,255,.25);
}
.sidebar-brand-text h1 {
    font: 700 14px var(--ps-font-sans, system-ui) !important;
    color: var(--v2-text) !important;
    margin: 0 !important;
    letter-spacing: -0.01em !important;
    line-height: 1.2 !important;
}
.sidebar-brand-text span {
    font: 500 10.5px var(--ps-font-mono, monospace) !important;
    color: var(--v2-text-3) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
}
.sidebar-brand-text {
    opacity: 1 !important;
    transform: none;
    white-space: nowrap;
}

/* Nav items: 48px alto, ícono centrado, label oculto en rail cerrado */
.sidebar-nav {
    flex: 1 !important;
    overflow-y: auto !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
    padding: 0 !important;
}
/* SECCIÓN TÍTULO en el rail (los <div class="nav-label"> directos de .sidebar-nav) */
.sidebar-nav > .nav-label {
    opacity: 1 !important;
    height: auto !important;
    overflow: hidden !important;
    padding: 14px 12px 6px !important;
    margin: 6px 0 0 !important;
    font-size: 10px !important;
    text-transform: uppercase;
    letter-spacing: 0.10em;
    color: var(--v2-text-4) !important;
    white-space: nowrap;
    font-weight: 700 !important;
    background: none !important;
    border: none !important;
}

.nav-item {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    height: 44px !important;
    padding: 0 14px !important;
    border-radius: var(--v2-r) !important;
    color: var(--v2-text-2) !important;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    transition: background-color 180ms var(--v2-ease), color 180ms var(--v2-ease) !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
    white-space: nowrap;
}
.nav-item svg, .nav-item img {
    flex-shrink: 0;
    width: 18px !important;
    height: 18px !important;
}
.nav-item:hover {
    background: rgba(255,255,255,.04) !important;
    color: var(--v2-text) !important;
}
.nav-item.active {
    background: var(--v2-accent-soft) !important;
    color: var(--v2-accent-2) !important;
    box-shadow: inset 0 0 0 1px rgba(45,212,191,.18) !important;
}
.nav-item.active::before {
    content: '';
    position: absolute;
    left: 0; top: 50%;
    transform: translateY(-50%);
    width: 3px; height: 18px;
    background: var(--v2-accent);
    border-radius: 0 3px 3px 0;
}

/* Label text del nav-item (siempre visible) */
.nav-item > span:not(.nav-badge):not([class*="badge"]),
.nav-item .nav-label {
    opacity: 1 !important;
}

/* Footer del sidebar */
.sidebar-footer {
    border-top: 1px solid var(--v2-line) !important;
    padding: 10px 0 0 !important;
    margin-top: 10px !important;
}
.sidebar-logout {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    width: 100% !important;
    height: 44px !important;
    padding: 0 14px !important;
    background: transparent !important;
    border: none !important;
    border-radius: var(--v2-r) !important;
    color: var(--v2-text-3) !important;
    font: 500 13.5px var(--ps-font-sans, system-ui) !important;
    cursor: pointer;
    transition: background-color 180ms var(--v2-ease), color 180ms var(--v2-ease) !important;
    white-space: nowrap;
}
.sidebar-logout:hover {
    background: rgba(248,113,113,.10) !important;
    color: var(--v2-danger) !important;
}
.sidebar-logout svg { flex-shrink: 0; width: 18px; height: 18px; }

/* ═══ MAIN AREA: el contenido llena todo el espacio a la derecha del sidebar fijo ═══ */
.main-area {
    margin: 0 !important;
    padding: 0 28px 32px calc(var(--v2-rail-w-open) + 36px) !important;
    min-height: calc(100dvh - 24px) !important;
    background: transparent !important;
}
/* Sin max-width: header y contenido aprovechan todo el ancho disponible */
.content-area, .top-header {
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: auto !important;
}

/* ═══ TOP HEADER → command bar flotante ═══ */
.top-header {
    position: sticky !important;
    top: 12px !important;
    z-index: 50 !important;
    height: var(--v2-header-h) !important;
    margin: 12px 0 28px !important;
    padding: 0 18px !important;
    background: rgba(14,18,24,.72) !important;
    border: 1px solid var(--v2-line) !important;
    border-radius: var(--v2-r-lg) !important;
    box-shadow: var(--v2-shadow) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    backdrop-filter: blur(24px) saturate(150%) !important;
    -webkit-backdrop-filter: blur(24px) saturate(150%) !important;
}
.header-left {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
}
.header-left h2, #headerTitle {
    font-size: 16px !important;
    font-weight: 600 !important;
    letter-spacing: -0.01em !important;
    color: var(--v2-text) !important;
    margin: 0 !important;
}
.header-left h2::before, #headerTitle::before {
    content: '/ ';
    color: var(--v2-text-4);
    margin-right: 4px;
    font-weight: 400;
}

.hamburger-btn {
    width: 32px !important; height: 32px !important;
    background: transparent !important;
    border: 1px solid var(--v2-line) !important;
    border-radius: var(--v2-r-sm) !important;
    color: var(--v2-text-2) !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    cursor: pointer;
    transition: all 180ms var(--v2-ease) !important;
}
.hamburger-btn:hover {
    background: rgba(255,255,255,.04) !important;
    border-color: var(--v2-line-strong) !important;
    color: var(--v2-text) !important;
}

.header-right {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
}

/* ═══ NOTIFICATION BELL → pill con badge inline ═══ */
.notification-bell {
    position: relative;
    width: 36px !important;
    height: 36px !important;
    border-radius: var(--v2-r-pill) !important;
    background: rgba(255,255,255,.04) !important;
    border: 1px solid var(--v2-line) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: var(--v2-text-2) !important;
    cursor: pointer;
    transition: all 200ms var(--v2-ease) !important;
}
.notification-bell:hover {
    background: var(--v2-accent-soft) !important;
    border-color: var(--v2-line-accent) !important;
    color: var(--v2-accent-2) !important;
}
.notification-badge {
    position: absolute !important;
    top: -4px !important; right: -4px !important;
    min-width: 18px !important;
    height: 18px !important;
    padding: 0 5px !important;
    background: var(--v2-danger) !important;
    color: #fff !important;
    border-radius: 9px !important;
    border: 2px solid var(--v2-bg) !important;
    font: 700 10px var(--ps-font-mono, monospace) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-variant-numeric: tabular-nums;
}
.notification-badge.hidden, .notification-badge:empty { display: none !important; }

/* ═══ NOTIFICATION PANEL → popover top-right ═══ */
.notification-panel {
    position: fixed !important;
    top: 84px !important;
    right: 24px !important;
    width: min(400px, calc(100vw - 32px)) !important;
    max-height: min(560px, calc(100dvh - 110px)) !important;
    background: var(--v2-bg-elev-2) !important;
    border: 1px solid var(--v2-line-strong) !important;
    border-radius: var(--v2-r-lg) !important;
    box-shadow: var(--v2-shadow-lg) !important;
    display: none !important;
    flex-direction: column !important;
    overflow: hidden !important;
    z-index: 200 !important;
    backdrop-filter: blur(28px) saturate(150%) !important;
}
.notification-panel.active, .notification-panel.open, .notification-panel.show {
    display: flex !important;
    animation: v2-slide-in 240ms var(--v2-ease) !important;
}
@keyframes v2-slide-in {
    from { opacity: 0; transform: translateY(-8px) scale(.98); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}
.notification-panel-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 14px 16px !important;
    border-bottom: 1px solid var(--v2-line) !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--v2-text) !important;
    letter-spacing: -0.005em !important;
    gap: 10px !important;
}
.notification-panel-header > div {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    flex-shrink: 0 !important;
}
#clearAllNotifications {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    background: rgba(248,113,113,0.14) !important;
    border: 1px solid rgba(248,113,113,0.35) !important;
    color: #fca5a5 !important;
    border-radius: 999px !important;
    padding: 6px 12px !important;
    font: 700 11.5px var(--ps-font-sans, system-ui) !important;
    letter-spacing: 0.02em !important;
    cursor: pointer !important;
    transition: all 160ms var(--v2-ease) !important;
    white-space: nowrap !important;
    visibility: visible !important;
    opacity: 1 !important;
}
#clearAllNotifications:disabled {
    opacity: 0.4 !important;
    cursor: not-allowed !important;
}
.notification-panel-body {
    flex: 1 !important;
    overflow-y: auto !important;
    padding: 8px !important;
}
.notification-item {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
    padding: 12px 14px !important;
    margin: 4px 0 !important;
    background: var(--v2-bg-elev-1) !important;
    border: 1px solid transparent !important;
    border-radius: var(--v2-r) !important;
    transition: all 160ms var(--v2-ease) !important;
}
.notification-item:hover {
    background: var(--v2-bg-elev-3) !important;
    border-color: var(--v2-line) !important;
}
/* Segunda fila del item (status pill + acciones) — la generamos via el cluster div */
.notification-item > div:last-child {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
}
.notification-item-info { min-width: 0 !important; flex: 1 1 100% !important; }
.notification-item-title {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--v2-text) !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.notification-item.expired { border-left: 2px solid var(--v2-danger) !important; }
.notification-item.expiring { border-left: 2px solid var(--v2-warning) !important; }
.notification-item-title {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--v2-text) !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.notification-item-detail {
    font: 500 11px var(--ps-font-mono, monospace) !important;
    color: var(--v2-text-3) !important;
    margin-top: 2px;
    font-variant-numeric: tabular-nums;
}
.notification-item-status {
    font-size: 10px !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 3px 8px !important;
    border-radius: var(--v2-r-pill) !important;
    white-space: nowrap;
}
.notification-item-status.expired { background: rgba(248,113,113,.14) !important; color: var(--v2-danger) !important; }
.notification-item-status.expiring { background: rgba(251,191,36,.14) !important; color: var(--v2-warning) !important; }
.notification-empty {
    padding: 32px 16px !important;
    text-align: center !important;
    color: var(--v2-text-4) !important;
    font-size: 13px !important;
}

/* ═══ CONTENT AREA & SECTIONS ═══ */
.content-area {
    padding: 0 !important;
    max-width: none !important;
    margin: 0 !important;
    width: auto !important;
}
.content-section {
    display: none !important;
    animation: v2-fade 320ms var(--v2-ease);
}
.content-section.active { display: block !important; }
@keyframes v2-fade {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ═══ STATS → cards premium con tint por estado y elevación ═══ */
[style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]),
[style*="grid-template-columns:repeat(4,1fr)"]:has([id^="statTotal"]) {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 16px !important;
    margin-bottom: 28px !important;
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    box-shadow: none !important;
}

/* Cada stat card: superficie elevada con halo de color en hover */
[style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]) > div,
[style*="grid-template-columns:repeat(4,1fr)"]:has([id^="statTotal"]) > div {
    background: linear-gradient(180deg, var(--v2-bg-elev-2) 0%, var(--v2-bg-elev-1) 100%) !important;
    border: 1px solid var(--v2-line) !important;
    border-radius: var(--v2-r-lg) !important;
    padding: 18px 20px !important;
    position: relative !important;
    overflow: hidden !important;
    box-shadow: var(--v2-shadow-sm) !important;
    transition: transform 220ms var(--v2-ease), border-color 220ms var(--v2-ease), box-shadow 220ms var(--v2-ease) !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    min-height: 108px !important;
}
/* Línea de acento superior por stat */
[style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]) > div::before,
[style*="grid-template-columns:repeat(4,1fr)"]:has([id^="statTotal"]) > div::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    opacity: 0.85;
}
/* Glow radial sutil por color */
[style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]) > div::after,
[style*="grid-template-columns:repeat(4,1fr)"]:has([id^="statTotal"]) > div::after {
    content: '';
    position: absolute;
    top: -40%; right: -20%;
    width: 200px; height: 200px;
    border-radius: 50%;
    opacity: 0.12;
    pointer-events: none;
    filter: blur(40px);
}
[style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]) > div:nth-child(1)::before { background: linear-gradient(90deg, var(--v2-accent), transparent); }
[style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]) > div:nth-child(2)::before { background: linear-gradient(90deg, var(--v2-success), transparent); }
[style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]) > div:nth-child(3)::before { background: linear-gradient(90deg, var(--v2-warning), transparent); }
[style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]) > div:nth-child(4)::before { background: linear-gradient(90deg, var(--v2-danger), transparent); }
[style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]) > div:nth-child(1)::after { background: var(--v2-accent); }
[style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]) > div:nth-child(2)::after { background: var(--v2-success); }
[style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]) > div:nth-child(3)::after { background: var(--v2-warning); }
[style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]) > div:nth-child(4)::after { background: var(--v2-danger); }
[style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]) > div:hover {
    transform: translateY(-2px) !important;
    border-color: var(--v2-line-strong) !important;
    box-shadow: 0 14px 32px -12px rgba(0,0,0,.55), 0 2px 4px rgba(0,0,0,.20) !important;
}
/* Layout interno: label arriba, número y chip-icon en una fila inferior */
[style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]) > div > *:not(script) {
    position: relative;
    z-index: 1;
}
[style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]) > div > div:nth-child(2),
[style*="grid-template-columns:repeat(4,1fr)"]:has([id^="statTotal"]) > div > div:nth-child(2) {
    display: flex !important;
    align-items: flex-end !important;
    justify-content: space-between !important;
    gap: 12px !important;
}

/* La label dentro de stat (text-transform uppercase) */
[style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]) [style*="text-transform"] {
    font-size: 10.5px !important;
    color: var(--v2-text-3) !important;
    font-weight: 600 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
}
/* Stat numbers — tipográficamente premium */
#statTotalUsers, #statActiveAccounts, #statExpiringSoon, #statExpiredAccounts {
    font-size: 34px !important;
    font-weight: 700 !important;
    letter-spacing: -0.03em !important;
    line-height: 1.1 !important;
    margin-top: 8px !important;
    font-variant-numeric: tabular-nums !important;
    font-feature-settings: "tnum", "ss01" !important;
}
#statTotalUsers { color: var(--v2-accent-2) !important; }
#statActiveAccounts { color: var(--v2-success) !important; }
#statExpiringSoon { color: var(--v2-warning) !important; }
#statExpiredAccounts { color: var(--v2-danger) !important; }

/* Quita el icon box de la derecha del stat (lo reduce a chip más sutil) */
[style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]) [style*="border-radius: 12px"][style*="padding: 10px"] {
    padding: 6px !important;
    background: rgba(255,255,255,.03) !important;
    border-radius: 8px !important;
    opacity: 0.7;
}

/* ═══ CARDS → superficie limpia con hairline ═══ */
.card {
    background: var(--v2-bg-elev-1) !important;
    border: 1px solid var(--v2-line) !important;
    border-radius: var(--v2-r-lg) !important;
    padding: 24px !important;
    box-shadow: var(--v2-shadow-sm) !important;
    transition: border-color 220ms var(--v2-ease), box-shadow 220ms var(--v2-ease), transform 220ms var(--v2-ease) !important;
    margin-bottom: 20px !important;
}
.card:hover {
    border-color: var(--v2-line-strong) !important;
}

.card-title {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--v2-text) !important;
    letter-spacing: -0.005em !important;
    margin-bottom: 18px !important;
    padding-bottom: 14px !important;
    border-bottom: 1px solid var(--v2-line) !important;
    display: flex;
    align-items: center;
    gap: 10px;
}

/* Grid-2: stack on mobile, side-by-side on desktop */
.grid-2 {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(420px, 1fr)) !important;
    gap: 20px !important;
}

/* ═══ FORMS → bottom-hairline style (Material-ish) ═══ */
.form-group {
    margin-bottom: 16px !important;
}
.form-label {
    display: block !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    color: var(--v2-text-3) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    margin-bottom: 8px !important;
}
.form-input, .form-textarea, .form-select,
input[type="text"]:not(.search-input),
input[type="email"], input[type="password"], input[type="number"],
textarea, select {
    width: 100% !important;
    padding: 11px 14px !important;
    background: var(--v2-bg) !important;
    border: 1px solid var(--v2-line) !important;
    border-radius: var(--v2-r) !important;
    color: var(--v2-text) !important;
    font: 500 13.5px var(--ps-font-sans, system-ui) !important;
    transition: border-color 180ms var(--v2-ease), background-color 180ms var(--v2-ease), box-shadow 180ms var(--v2-ease) !important;
}
.form-input:focus, .form-textarea:focus, .form-select:focus,
input:focus:not([type="checkbox"]):not([type="radio"]), textarea:focus, select:focus {
    outline: none !important;
    border-color: var(--v2-accent) !important;
    background: var(--v2-bg-elev-1) !important;
    box-shadow: 0 0 0 3px var(--v2-accent-soft) !important;
}
.form-input::placeholder, textarea::placeholder {
    color: var(--v2-text-4) !important;
}

/* Inputs con icon-prefix (padding-left inline 38px) — ajustar el icono */
input[style*="padding-left: 38px"], input[style*="padding-left:38px"] {
    background: var(--v2-bg) !important;
}

/* ═══ BUTTONS → SOLO .btn recibe pill; íconos sueltos respetan su tamaño ═══ */
.btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    min-height: 38px !important;
    padding: 9px 18px !important;
    border-radius: var(--v2-r-pill) !important;
    font: 600 13px var(--ps-font-sans, system-ui) !important;
    letter-spacing: -0.005em !important;
    cursor: pointer;
    border: 1px solid transparent !important;
    background: rgba(255,255,255,.04) !important;
    color: var(--v2-text) !important;
    transition: transform 160ms var(--v2-ease), background-color 180ms var(--v2-ease), color 180ms var(--v2-ease), border-color 180ms var(--v2-ease), box-shadow 220ms var(--v2-ease) !important;
    white-space: nowrap;
    text-decoration: none;
}
.btn-primary {
    background: var(--v2-accent) !important;
    color: var(--v2-accent-ink) !important;
    border-color: transparent !important;
    box-shadow: 0 1px 0 rgba(255,255,255,.18) inset, 0 8px 20px -8px rgba(45,212,191,.55) !important;
}
.btn-primary:hover:not(:disabled) {
    background: var(--v2-accent-2) !important;
    transform: translateY(-1px);
    box-shadow: 0 1px 0 rgba(255,255,255,.22) inset, 0 12px 28px -8px rgba(45,212,191,.70) !important;
}
.btn-secondary, .btn-info {
    background: rgba(255,255,255,.04) !important;
    color: var(--v2-text) !important;
    border-color: var(--v2-line-strong) !important;
}
.btn-secondary:hover:not(:disabled), .btn-info:hover:not(:disabled) {
    background: rgba(255,255,255,.08) !important;
    border-color: var(--v2-line-accent) !important;
    color: var(--v2-accent-2) !important;
}
.btn-danger {
    background: rgba(248,113,113,.10) !important;
    color: var(--v2-danger) !important;
    border-color: rgba(248,113,113,.30) !important;
}
.btn-danger:hover:not(:disabled) {
    background: rgba(248,113,113,.18) !important;
}
.btn-block { width: 100% !important; }
.btn:active:not(:disabled) {
    transform: translateY(0) scale(.985) !important;
}
.btn:disabled {
    opacity: 0.45 !important;
    cursor: not-allowed !important;
}

/* Botones de íconos pequeños — mantenerlos compactos */
.action-button, .action-buttons button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 32px !important;
    height: 32px !important;
    padding: 0 !important;
    background: rgba(255,255,255,.03) !important;
    border: 1px solid var(--v2-line) !important;
    border-radius: var(--v2-r-sm) !important;
    color: var(--v2-text-2) !important;
    cursor: pointer;
    transition: all 160ms var(--v2-ease) !important;
}
.action-button:hover:not(:disabled), .action-buttons button:hover:not(:disabled) {
    background: rgba(255,255,255,.06) !important;
    border-color: var(--v2-line-strong) !important;
    color: var(--v2-text) !important;
}
.action-button:disabled {
    opacity: 0.3 !important;
    cursor: not-allowed !important;
}

/* btn-info / btn-accounts en tabla — chip mediano (no pill enorme) */
.btn-info, .btn-accounts, button.manage-emails-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    height: 30px !important;
    padding: 0 12px !important;
    border-radius: var(--v2-r) !important;
    font: 600 12px var(--ps-font-sans, system-ui) !important;
    cursor: pointer;
    transition: all 160ms var(--v2-ease) !important;
}

/* Sub-user toggle chip — teal pequeño, no se infla */
.sub-user-toggle {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
    height: 24px !important;
    padding: 0 9px !important;
    background: var(--v2-accent-soft) !important;
    color: var(--v2-accent-2) !important;
    border: 1px solid var(--v2-line-accent) !important;
    border-radius: var(--v2-r-pill) !important;
    font: 700 11px var(--ps-font-mono, monospace) !important;
    letter-spacing: 0.02em;
    cursor: pointer;
    transition: all 160ms var(--v2-ease) !important;
    font-variant-numeric: tabular-nums;
}
.sub-user-toggle:hover {
    background: rgba(45,212,191,.20) !important;
    border-color: rgba(45,212,191,.40) !important;
    transform: translateY(-1px);
}
.sub-user-toggle .toggle-chevron { width: 11px !important; height: 11px !important; }

/* ═══ SAFETY: sub-user-row debe poder mostrarse cuando JS la activa ═══ */
/* JS hace `row.style.display = 'table-row'` — el inline gana, no necesita !important aquí */
tr.sub-user-row { background: rgba(45,212,191,.04) !important; }
tr.sub-user-row:hover { background: rgba(45,212,191,.08) !important; }
tr.sub-user-row td:first-child { padding-left: 32px !important; }
tr.grandchild-row td:first-child { padding-left: 56px !important; }

/* btn-renew (chip pequeño, dentro de notifications) */
.btn-renew {
    height: 26px !important;
    padding: 0 10px !important;
    font: 700 10.5px var(--ps-font-mono, monospace) !important;
    letter-spacing: 0.04em !important;
    background: var(--v2-accent) !important;
    color: var(--v2-accent-ink) !important;
    border: none !important;
    border-radius: var(--v2-r-pill) !important;
    cursor: pointer;
    transition: all 180ms var(--v2-ease) !important;
}
.btn-renew:hover { background: var(--v2-accent-2) !important; transform: translateY(-1px); }

/* ═══ TABLES → borderless con hover row ═══ */
.table-container, [class*="table-wrap"] {
    background: var(--v2-bg-elev-1) !important;
    border: 1px solid var(--v2-line) !important;
    border-radius: var(--v2-r-lg) !important;
    overflow-x: auto !important;
    overflow-y: visible !important;
}
table {
    width: 100% !important;
    border-collapse: collapse !important;
    font-size: 13px !important;
}
table thead {
    background: var(--v2-bg) !important;
}
table thead th {
    padding: 12px 16px !important;
    font: 600 10.5px var(--ps-font-sans, system-ui) !important;
    color: var(--v2-text-3) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    text-align: left !important;
    border-bottom: 1px solid var(--v2-line) !important;
    white-space: nowrap;
}
table tbody td {
    padding: 14px 16px !important;
    color: var(--v2-text) !important;
    border-bottom: 1px solid var(--v2-line) !important;
    font-variant-numeric: tabular-nums;
}
table tbody tr:last-child td { border-bottom: none !important; }
table tbody tr {
    transition: background-color 140ms var(--v2-ease) !important;
}
table tbody tr:hover { background: rgba(45,212,191,.04) !important; }

/* ═══ TABS (Expiradas / Por Vencer) ═══ */
.tab-btn, [id^="tab"][style*="border"] {
    background: transparent !important;
    color: var(--v2-text-2) !important;
    border: 1px solid var(--v2-line) !important;
    border-radius: var(--v2-r-pill) !important;
    padding: 7px 16px !important;
    font: 500 12.5px var(--ps-font-sans, system-ui) !important;
    cursor: pointer;
    transition: all 180ms var(--v2-ease) !important;
}
.tab-btn:hover, [id^="tab"]:hover {
    background: rgba(255,255,255,.04) !important;
    color: var(--v2-text) !important;
}
.tab-btn.active, [id^="tab"][style*="background"][style*="rgba(45,212"] {
    background: var(--v2-accent-soft) !important;
    color: var(--v2-accent-2) !important;
    border-color: var(--v2-line-accent) !important;
}

/* ═══ CHECKBOXES & toggles ═══ */
input[type="checkbox"] {
    width: 16px !important;
    height: 16px !important;
    accent-color: var(--v2-accent) !important;
    cursor: pointer;
}
.form-checkbox-label, label[for], label.checkbox-label {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    color: var(--v2-text-2) !important;
    font-size: 13px !important;
    cursor: pointer;
}

/* ═══ TYPOGRAPHY V2 — solo body, cascada hace el resto (más rápido) ═══ */
body, button, input, select, textarea {
    font-family: 'Geist', -apple-system, BlinkMacSystemFont, 'Inter', system-ui, sans-serif !important;
}
code, pre, kbd, samp, .mono, [class*="mono"], .notification-item-detail {
    font-family: 'Geist Mono', 'JetBrains Mono', 'SF Mono', ui-monospace, monospace !important;
}
table td, table th { font-variant-numeric: tabular-nums; }

/* ═══ MOBILE: rail desaparece bajo hamburger ═══ */
@media (max-width: 900px) {
    .sidebar {
        transform: translateX(-110%) !important;
        transition: transform 280ms var(--v2-ease) !important;
        width: var(--v2-rail-w-open) !important;
    }
    .sidebar.open, .sidebar.expanded {
        transform: translateX(0) !important;
    }
    .sidebar:hover { width: var(--v2-rail-w-open) !important; }
    /* En mobile el rail es un drawer: el contenido ocupa todo el ancho,
       sin el padding-left reservado para el rail fijo del desktop. */
    .main-area {
        margin: 0 !important;
        padding: 0 14px calc(20px + env(safe-area-inset-bottom)) 14px !important;
        padding-left: calc(14px + env(safe-area-inset-left)) !important;
        padding-right: calc(14px + env(safe-area-inset-right)) !important;
    }
    /* El drawer abierto NO debe empujar el contenido en mobile (queda como overlay) */
    body:has(.sidebar.open) .main-area {
        padding-left: calc(14px + env(safe-area-inset-left)) !important;
    }
    .sidebar-overlay {
        position: fixed; inset: 0; background: rgba(0,0,0,.55); z-index: 90;
        backdrop-filter: blur(4px);
        opacity: 0; pointer-events: none;
        transition: opacity 220ms var(--v2-ease);
    }
    .sidebar-overlay.active, .sidebar.open ~ .sidebar-overlay {
        opacity: 1; pointer-events: auto;
    }
    /* En mobile el rail abierto siempre muestra labels */
    .sidebar-brand-text, .nav-item > span, .nav-section-title {
        opacity: 1 !important;
    }
    .notification-panel {
        top: auto !important;
        bottom: 12px !important;
        left: 12px !important;
        right: 12px !important;
        width: auto !important;
    }
    [style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]),
    [style*="grid-template-columns:repeat(4,1fr)"]:has([id^="statTotal"]) {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    [style*="grid-template-columns: repeat(4, 1fr)"]:has([id^="statTotal"]) > div:nth-child(2),
    [style*="grid-template-columns:repeat(4,1fr)"]:has([id^="statTotal"]) > div:nth-child(2) {
        border-right: none !important;
    }
}

/* ═══ Reduced motion ═══ */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
    }
    body::before { display: none; }
}

/* ═══ Mata cualquier background púrpura/indigo restante ═══ */
[style*="rgba(99,102,241"], [style*="rgba(139,92,246"], [style*="rgba(168,85,247"] {
    background: transparent !important;
    background-color: transparent !important;
}

/* ─── Dismiss button hover ─── */
.notification-dismiss:hover {
    background: rgba(248,113,113,0.12) !important;
    border-color: rgba(248,113,113,0.35) !important;
    color: #f87171 !important;
}
#clearAllNotifications:hover {
    background: rgba(248,113,113,0.18) !important;
    border-color: rgba(248,113,113,0.40) !important;
}
