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

*{margin:0;padding:0;box-sizing:border-box}

:root {
  color-scheme: dark;
  --bg:       #0A0A0B;
  --sidebar:  #111114;
  --card:     #111318;
  --card2:    #161920;
  --accent:   #00C2FF;
  --accent-h: #00d9ff;
  --success:  #7FE832;
  --danger:   #FF4444;
  --warning:  #FF8C00;
  --border:   #1E1E2E;
  --border2:  #2a2a3e;
  --text:     #FFFFFF;
  --muted:    #A0A0B0;
  --radius:   12px;
  --radius-sm:8px;
  --shadow:   0 4px 24px rgba(0,0,0,.4);
  --font-ui:  'Inter', sans-serif;
  --font-hd:  'Space Grotesk', sans-serif;
}

body{font-family:var(--font-ui);background:var(--bg) !important;color:var(--text) !important;font-size:13px;line-height:1.5;overflow-x:hidden;overflow-y:scroll}
a{text-decoration:none;color:inherit}
/* Neutralizar colores de Bootstrap en todos los componentes */
.card,.card-header,.card-body,.card-footer{background:unset;color:var(--text)}
p,span,div,h1,h2,h3,h4,h5,h6,label,th,td,li{color:inherit}
button,input,select,textarea{font-family:var(--font-ui)}

/* ══ LAYOUT ══════════════════════════════════════════════════════════════════ */
.app{display:grid;grid-template-columns:240px 1fr;grid-template-rows:56px 1fr;height:100vh;overflow:hidden}
.app.sidebar-collapsed{grid-template-columns:60px 1fr}

/* ══ HEADER ══════════════════════════════════════════════════════════════════ */
.header{grid-column:1/-1;background:var(--sidebar);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:14px;z-index:200;position:relative;overflow:visible}
.header-logo{font-family:var(--font-hd);font-size:16px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:10px;letter-spacing:-.4px;min-width:200px}
.header-logo-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--accent),#0077a8);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#000;flex-shrink:0}
.header-module{font-size:12px;color:var(--muted);background:var(--card);border:1px solid var(--border);border-radius:6px;padding:3px 10px}
.header-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.header-date{font-size:11px;color:var(--muted);background:var(--card);border:1px solid var(--border);border-radius:6px;padding:4px 10px}

/* Campana de notificaciones */
.notif-btn{position:relative;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--card);border:1px solid var(--border);border-radius:9px;cursor:pointer;transition:border-color .15s,background .15s;color:var(--muted)}
.notif-btn:hover{border-color:var(--accent);background:rgba(0,194,255,.06);color:var(--accent)}
.notif-badge{position:absolute;top:-5px;right:-5px;background:var(--danger);color:#fff;font-size:9px;font-weight:700;width:18px;height:18px;border-radius:50%;display:none;align-items:center;justify-content:center;border:2px solid var(--bg);line-height:1}
.notif-badge.show{display:flex;animation:popIn .2s ease}
@keyframes popIn{0%{transform:scale(0)}70%{transform:scale(1.2)}100%{transform:scale(1)}}

/* Panel de notificaciones */
.notif-panel{position:fixed;top:56px;right:0;width:360px;height:calc(100vh - 56px);background:var(--sidebar);border-left:1px solid var(--border);z-index:300;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .25s ease}
.notif-panel.open{transform:translateX(0)}
.notif-panel-head{padding:16px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.notif-panel-title{font-family:var(--font-hd);font-weight:600;font-size:14px}
.notif-panel-body{flex:1;overflow-y:auto;padding:8px 0}
.notif-item{padding:12px 18px;border-bottom:1px solid rgba(30,30,46,.6);cursor:pointer;transition:background .1s;display:flex;gap:10px;align-items:flex-start}
.notif-item:hover{background:rgba(255,255,255,.03)}
.notif-item.notif-clickable:hover{background:rgba(0,194,255,.07)}
.notif-item.unread{background:rgba(0,194,255,.04)}
.notif-item.unread .notif-dot{background:var(--accent)}
.notif-dot{width:8px;height:8px;border-radius:50%;background:transparent;border:1.5px solid var(--muted);flex-shrink:0;margin-top:4px;transition:background .15s}
.notif-msg{font-size:12px;line-height:1.4;color:var(--text)}
.notif-time{font-size:10px;color:var(--muted);margin-top:3px}
.notif-panel-footer{padding:12px 18px;border-top:1px solid var(--border)}

/* Avatar */
.user-pill{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--border);border-radius:20px;padding:4px 12px 4px 4px;cursor:pointer;transition:border-color .15s}
.user-pill:hover{border-color:var(--border2)}
.avatar{width:28px;height:28px;background:linear-gradient(135deg,var(--accent),#0077a8);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#000;flex-shrink:0}
.user-name{font-size:12px;color:var(--muted)}

/* ══ SIDEBAR ════════════════════════════════════════════════════════════════ */
.sidebar{background:var(--sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;padding:10px 0 0}
.nav-section{padding:0 14px;margin:16px 0 5px;font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1.2px;white-space:nowrap;overflow:hidden}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 14px;margin:1px 8px;border-radius:9px;cursor:pointer;color:var(--muted);transition:all .12s;font-size:13px;border:1px solid transparent;text-decoration:none;white-space:nowrap;overflow:hidden}
.nav-item:hover{background:var(--card);color:var(--text);border-color:var(--border)}
.nav-item.active{background:rgba(0,194,255,.1);color:var(--accent);border-color:rgba(0,194,255,.25);font-weight:500;box-shadow:inset 3px 0 0 var(--accent)}
.nav-icon{font-size:16px;flex-shrink:0;opacity:.6}
.nav-item:hover .nav-icon,.nav-item.active .nav-icon{opacity:1}
.nav-label{overflow:hidden;text-overflow:ellipsis}
.nav-badge{margin-left:auto;background:var(--danger);color:#fff;border-radius:10px;padding:1px 7px;font-size:10px;font-weight:600}
.nav-bottom{margin-top:auto;border-top:1px solid var(--border);padding:10px 0 8px}

/* Sidebar collapsed */
.app.sidebar-collapsed .nav-label,.app.sidebar-collapsed .nav-section,.app.sidebar-collapsed .nav-badge{display:none}
.app.sidebar-collapsed .nav-item{justify-content:center;padding:10px 0;margin:2px 8px}
.app.sidebar-collapsed .header-logo span{display:none}

/* ══ CONTENT ════════════════════════════════════════════════════════════════ */
.content{background:var(--bg);overflow-y:auto;padding:22px 24px}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:12px;flex-wrap:wrap}
.page-title{font-family:var(--font-hd);font-size:20px;font-weight:600;letter-spacing:-.5px;line-height:1.2}
.page-sub{font-size:12px;color:var(--muted);margin-top:3px}

/* ══ KPI CARDS ══════════════════════════════════════════════════════════════ */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
.kpi-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;transition:border-color .15s,transform .15s}
.kpi-card:hover{border-color:var(--border2);transform:translateY(-1px)}
.kpi-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;font-weight:600;margin-bottom:10px}
.kpi-value{font-family:var(--font-hd);font-size:24px;font-weight:700;line-height:1;letter-spacing:-.5px}
.kpi-value.accent{color:var(--accent)}
.kpi-value.success{color:var(--success)}
.kpi-value.danger{color:var(--danger)}
.kpi-value.warning{color:var(--warning)}
.kpi-sub{font-size:11px;color:var(--muted);margin-top:6px}

/* ══ CARD ═══════════════════════════════════════════════════════════════════ */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);background:var(--card2);color:var(--text)}
.card-title{font-family:var(--font-hd);font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px;color:var(--text)}
.card-title-accent{font-size:10px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:1px;padding-bottom:2px;border-bottom:2px solid rgba(0,194,255,.3)}
.card-body{padding:18px 20px}

/* ══ TABLE ══════════════════════════════════════════════════════════════════ */
.table-toolbar{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--card2);flex-wrap:wrap}
.search-wrap{position:relative;flex:1;min-width:200px;max-width:320px}
.search-wrap i{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:14px}
.search-input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 12px 8px 32px;color:var(--text);font-size:13px;outline:none;transition:border-color .15s}
.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,194,255,.12)}
.search-input::placeholder{color:var(--muted)}
table{width:100%;border-collapse:collapse;color:var(--text)}
thead tr{border-bottom:1px solid var(--border);background:var(--card2)}
th{color:var(--muted);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;padding:10px 14px}
th{padding:9px 14px;text-align:left;font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;white-space:nowrap}
td{padding:10px 14px;border-bottom:1px solid rgba(30,30,46,.7);font-size:13px;vertical-align:middle}
tr:last-child td{border-bottom:none}
tbody tr{transition:background .08s}
tbody tr:hover td{background:rgba(255,255,255,.015)}
.td-mono{font-family:'Courier New',monospace;font-size:12px}
.td-muted{color:var(--muted);font-size:12px}
.td-actions{display:flex;gap:5px;align-items:center;white-space:nowrap;overflow:visible}
td:has(.td-actions){overflow:visible}
.btn-icon-sm{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}

/* Paginación */
.pag-bar{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-top:1px solid var(--border);gap:8px;flex-wrap:wrap}
.pag-info{font-size:12px;color:var(--muted)}

/* ══ BADGES DE ESTADO ════════════════════════════════════════════════════════ */
.badge-estado{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}
.badge-estado::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}
.badge-pagada    {background:rgba(127,232,50,.12);color:var(--success);border:1px solid rgba(127,232,50,.3)}
.badge-transito  {background:rgba(255,140,0,.12);color:var(--warning);border:1px solid rgba(255,140,0,.3)}
.badge-vencida   {background:rgba(255,68,68,.12);color:var(--danger);border:1px solid rgba(255,68,68,.3)}
.badge-cancelada {background:rgba(160,160,176,.1);color:var(--muted);border:1px solid rgba(160,160,176,.2)}
.badge-renovada  {background:rgba(0,194,255,.12);color:var(--accent);border:1px solid rgba(0,194,255,.3)}
.badge-emitida   {background:rgba(0,194,255,.08);color:#7ab8cc;border:1px solid rgba(0,194,255,.2)}
.badge-por-vencer{background:rgba(255,140,0,.18);color:#ffaa33;border:1px solid rgba(255,140,0,.4)}

/* ══ BUTTONS ════════════════════════════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:var(--radius-sm);border:none;font-size:13px;font-weight:500;cursor:pointer;font-family:var(--font-ui);transition:all .12s;white-space:nowrap;text-decoration:none;line-height:1}
.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}
.btn-primary{background:var(--accent);color:#000;font-weight:600}
.btn-primary:hover:not(:disabled){background:var(--accent-h)}
.btn-success{background:var(--success);color:#000;font-weight:600}
.btn-success:hover:not(:disabled){background:#8fff33}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover:not(:disabled){background:#ff6666}
.btn-warning{background:var(--warning);color:#000;font-weight:600}
.btn-warning:hover:not(:disabled){background:#ffaa33}
.btn-ghost{background:var(--card);border:1px solid var(--border);color:var(--muted)}
.btn-ghost:hover:not(:disabled){color:var(--text);border-color:var(--border2);background:var(--card2)}
.btn-sm{padding:5px 11px;font-size:12px;border-radius:6px}
.btn-xs{padding:3px 8px;font-size:11px;border-radius:5px}
.btn-icon{padding:7px;border-radius:8px}
.btn-icon-sm{padding:5px;border-radius:6px;font-size:14px}
.btn-block{width:100%;justify-content:center}

/* ══ FORMS ══════════════════════════════════════════════════════════════════ */
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:11px;color:var(--muted);margin-bottom:5px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.form-control,.form-select{width:100%;background:var(--card2) !important;border:1px solid var(--border) !important;border-radius:var(--radius-sm);padding:9px 12px;color:var(--text) !important;font-size:13px;font-family:var(--font-ui);outline:none;transition:border-color .15s;-webkit-text-fill-color:var(--text) !important;color-scheme:dark}
.form-control:focus,.form-select:focus{border-color:var(--accent) !important;background:var(--card) !important;box-shadow:0 0 0 3px rgba(0,194,255,.1) !important}
.form-control::placeholder{color:var(--muted) !important;-webkit-text-fill-color:var(--muted) !important}
.form-control[readonly]{opacity:.55;cursor:default}
.form-select{appearance:none;cursor:pointer}
.form-select option{background:var(--card);color:var(--text)}
.form-hint{font-size:11px;color:var(--muted);margin-top:4px}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}

/* ══ MODAL ══════════════════════════════════════════════════════════════════ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);display:none;align-items:center;justify-content:center;z-index:1000}
.modal-overlay.show{display:flex;animation:fadeIn .15s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{display:block;background:var(--card);border:1px solid var(--border2);border-radius:16px;padding:26px 28px;width:520px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow);animation:slideUp .18s ease;position:relative;z-index:auto}
.modal-lg{width:680px}
.modal-xl{width:900px}
@keyframes slideUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.modal-head{font-family:var(--font-hd);font-size:16px;font-weight:600;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;padding-bottom:14px;border-bottom:1px solid var(--border)}
.modal-close{cursor:pointer;color:var(--muted);font-size:20px;background:none;border:none;padding:0;transition:color .12s;line-height:1}
.modal-close:hover{color:var(--text)}
.modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}

/* ══ FILTROS ════════════════════════════════════════════════════════════════ */
.filters-bar{display:flex;gap:8px;flex-wrap:wrap;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--card2);align-items:flex-end}
.filter-group{display:flex;flex-direction:column;gap:4px}
.filter-label{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.filter-control{background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:7px 10px;color:var(--text);font-size:12px;outline:none;font-family:var(--font-ui);min-width:120px;transition:border-color .15s}
.filter-control:focus{border-color:var(--accent)}
.filter-control option{background:var(--card)}
.filter-btn-active{background:rgba(0,194,255,.1);border-color:rgba(0,194,255,.3);color:var(--accent)}

/* ══ TABLAS DETALLE ══════════════════════════════════════════════════════════ */
.detail-row{display:flex;gap:8px;padding:8px 0;border-bottom:1px solid rgba(30,30,46,.5);font-size:13px;align-items:baseline}
.detail-row:last-child{border-bottom:none}
.detail-label{color:var(--muted);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;min-width:140px;flex-shrink:0}

/* ══ CHIP/PILL ═══════════════════════════════════════════════════════════════ */
.chip{display:inline-block;background:rgba(0,194,255,.08);border:1px solid rgba(0,194,255,.2);border-radius:5px;padding:2px 8px;font-size:11px;color:var(--accent)}
.pill{display:inline-flex;align-items:center;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:500;gap:4px}
.pill-success{background:rgba(127,232,50,.12);color:var(--success);border:1px solid rgba(127,232,50,.25)}
.pill-danger {background:rgba(255,68,68,.12);color:var(--danger);border:1px solid rgba(255,68,68,.25)}
.pill-muted  {background:rgba(160,160,176,.1);color:var(--muted);border:1px solid rgba(160,160,176,.2)}

/* ══ EMPTY STATE ════════════════════════════════════════════════════════════ */
.empty-state{text-align:center;padding:48px 20px;color:var(--muted)}
.empty-state i{font-size:40px;margin-bottom:12px;display:block;opacity:.4}
.empty-state p{font-size:13px}

/* ══ LOADER ══════════════════════════════════════════════════════════════════ */
.loader{display:inline-block;width:16px;height:16px;border:2px solid rgba(0,194,255,.2);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-row td{text-align:center;padding:32px;color:var(--muted)}

/* ══ ALERTS INLINE ══════════════════════════════════════════════════════════ */
.alert{padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.alert-danger {background:rgba(255,68,68,.1);border:1px solid rgba(255,68,68,.25);color:#ff8080}
.alert-success{background:rgba(127,232,50,.1);border:1px solid rgba(127,232,50,.25);color:var(--success)}
.alert-warning{background:rgba(255,140,0,.1);border:1px solid rgba(255,140,0,.25);color:var(--warning)}
.alert-info   {background:rgba(0,194,255,.1);border:1px solid rgba(0,194,255,.25);color:var(--accent)}

/* ══ TOGGLE SIDEBAR ═════════════════════════════════════════════════════════ */
.sidebar-toggle{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:8px;cursor:pointer;color:var(--muted);background:var(--card);transition:all .15s;flex-shrink:0}
.sidebar-toggle:hover{border-color:var(--accent);color:var(--accent)}

/* ══ RESPONSIVE ══════════════════════════════════════════════════════════════ */
@media(max-width:992px){
  .app{grid-template-columns:1fr;grid-template-rows:56px 1fr}
  .sidebar{position:fixed;left:-240px;top:56px;height:calc(100vh - 56px);width:240px;z-index:150;transition:left .25s ease}
  .sidebar.mobile-open{left:0}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .form-grid-2,.form-grid-3{grid-template-columns:1fr}
  .notif-panel{width:100%;max-width:360px}
}
@media(max-width:576px){
  .kpi-grid{grid-template-columns:1fr}
  .content{padding:14px}
  .page-title{font-size:17px}
  .modal{padding:18px}
}

/* ══ KPI CARD VARIANTS ════════════════════════════════════════════════════════ */
.kpi-accent  { border-left: 3px solid var(--accent); }
.kpi-success { border-left: 3px solid var(--success); }
.kpi-danger  { border-left: 3px solid var(--danger); }
.kpi-warning { border-left: 3px solid var(--warning); }
.kpi-row { display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px }
.kpi-icon-box { width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0 }
.kpi-icon-accent  { background:rgba(0,194,255,.12);color:var(--accent) }
.kpi-icon-success { background:rgba(127,232,50,.12);color:var(--success) }
.kpi-icon-danger  { background:rgba(255,68,68,.12);color:var(--danger) }
.kpi-icon-warning { background:rgba(255,140,0,.12);color:var(--warning) }

/* ══ FILTER SEARCH WRAP ══════════════════════════════════════════════════════ */
.filter-search-wrap { position:relative }
.filter-search-wrap i { position:absolute;left:9px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:13px;pointer-events:none }
.filter-search-wrap .filter-control { padding-left:29px }

/* ══ LOADING / EMPTY STATES ══════════════════════════════════════════════════ */
.loading-state { text-align:center;padding:40px;color:var(--muted) }

/* ══ SCROLLBAR CUSTOM ════════════════════════════════════════════════════════ */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:var(--muted)}

/* ══ TOOLTIPS SIMPLES ════════════════════════════════════════════════════════ */
[data-tip]{position:relative}
[data-tip]:hover::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);top:auto;left:50%;transform:translateX(-50%);background:var(--card2);border:1px solid var(--border);border-radius:6px;padding:5px 10px;font-size:11px;color:var(--text);white-space:nowrap;pointer-events:none;z-index:9999;box-shadow:var(--shadow)}
.header [data-tip]:hover::after{bottom:auto;top:calc(100% + 6px)}

/* ══ NOVA IA ══════════════════════════════════════════════════════════════════ */
.nova-fab{position:fixed;bottom:1.5rem;right:1.5rem;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#1565C0,#7C3AED);border:none;color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px rgba(21,101,192,.4);z-index:1050;transition:transform .2s,box-shadow .2s}
.nova-fab:hover{transform:scale(1.08);box-shadow:0 8px 28px rgba(21,101,192,.5)}
.nova-fab .nova-pulse{position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(21,101,192,.5);animation:nova-pulse 2s infinite}
@keyframes nova-pulse{0%{transform:scale(1);opacity:1}100%{transform:scale(1.5);opacity:0}}
.nova-panel{position:fixed;bottom:5rem;right:1.5rem;width:300px;max-height:480px;background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:0 12px 40px rgba(0,0,0,.25);display:none;flex-direction:column;z-index:1051;overflow:hidden}
.nova-panel.open{display:flex}
.nova-header{background:linear-gradient(135deg,#1565C0,#7C3AED);color:#fff;padding:.65rem 1rem;display:flex;align-items:center;gap:.6rem}
.nova-header-icon{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.nova-header-text strong{display:block;font-size:.9rem}
.nova-header-text small{font-size:.73rem;opacity:.8}
.nova-close{margin-left:auto;background:none;border:none;color:#fff;opacity:.7;cursor:pointer;padding:4px;border-radius:6px;line-height:1;display:flex;align-items:center;justify-content:center}
.nova-close:hover{opacity:1;background:rgba(255,255,255,.1)}
.nova-body{padding:1rem;overflow-y:auto;flex:1}
.nova-greeting{font-size:.82rem;color:var(--text-muted);margin-bottom:.75rem}
.nova-topics{display:flex;flex-direction:column;gap:.4rem}
.nova-topic-btn{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;background:var(--card2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.8rem;text-align:left;cursor:pointer;transition:background .15s,border-color .15s,color .15s;width:100%}
.nova-topic-btn:hover{background:rgba(21,101,192,.07);border-color:#1565C0;color:#1565C0}
.nova-topic-btn i{font-size:1rem;color:#1565C0;flex-shrink:0}
.nova-step-view{display:none;flex-direction:column}
.nova-step-view.active{display:flex}
.nova-back{background:none;border:none;color:var(--text-muted);font-size:.78rem;padding:0;cursor:pointer;display:flex;align-items:center;gap:.35rem;margin-bottom:.65rem}
.nova-back:hover{color:var(--text)}
.nova-step-title{font-weight:600;font-size:.88rem;margin-bottom:.75rem;color:var(--text)}
.nova-steps-list{display:flex;flex-direction:column;gap:.5rem}
.nova-step-item{display:flex;gap:.65rem;align-items:flex-start}
.nova-step-num{width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,#1565C0,#7C3AED);color:#fff;font-size:.65rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.nova-step-text{font-size:.8rem;color:var(--text);line-height:1.4}
.nova-step-text strong{color:#1565C0}
.nova-step-text code{background:var(--card2);padding:1px 4px;border-radius:4px;font-size:.75rem}
.nova-step-link{display:inline-flex;align-items:center;gap:.4rem;margin-top:.75rem;padding:.45rem .85rem;background:linear-gradient(135deg,#1565C0,#7C3AED);color:#fff;border-radius:8px;font-size:.8rem;text-decoration:none;transition:opacity .15s}
.nova-step-link:hover{opacity:.88;color:#fff}

/* ===== LICENSE BANNERS & ACTIVATION ===== */
.license-banner{padding:.45rem 1rem;font-size:13px;font-weight:500;text-align:center;width:100%;position:sticky;top:0;z-index:2000}
.license-banner--trial{background:#0c2a4a;color:#7ec8f8}
.license-banner--grace{background:#3a0f0f;color:#ff8080}
.lic-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:28px 32px;width:100%;max-width:380px;box-shadow:0 8px 32px rgba(0,0,0,.4)}
.lic-input{width:100%;padding:.55rem .85rem;background:var(--card2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:14px;font-family:monospace;box-sizing:border-box;margin-bottom:12px}
.lic-input:focus{outline:none;border-color:var(--accent)}
.lic-btn{width:100%;padding:.6rem;background:var(--accent);color:#000;border:none;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer}
.lic-btn:hover{opacity:.88}
.lic-alert{padding:.5rem .85rem;border-radius:8px;font-size:13px;margin-bottom:12px}
.lic-alert--warn{background:#2a1f00;color:#f8c040}
