/* ══════════════════════════════════════════════════════════
   COTIZADOR DE BODAS · HACIENDA SAN MIGUEL QUERÉTARO
   Design System — Premium Wedding Events 2026
   ══════════════════════════════════════════════════════════ */

/* ── TOKENS ──────────────────────────────────────────────── */
:root {
  --brand-primary:       #C8691A;
  --brand-primary-dk:    #A5530F;
  --brand-primary-lt:    #E8813A;
  --brand-primary-xs:    #FDF0E6;
  --brand-secondary:     #6B3F1E;
  --brand-secondary-dk:  #4A2C14;
  --brand-secondary-lt:  #8B5A34;
  --brand-gold:          #C9A84C;
  --brand-gold-lt:       #E8C97A;
  --brand-gold-xs:       #FAF3E0;

  --gray-50:  #FAFAF9;
  --gray-100: #F5F4F2;
  --gray-150: #EDECEA;
  --gray-200: #E5E3DF;
  --gray-300: #D0CEC9;
  --gray-400: #B0ADA6;
  --gray-500: #8B8780;
  --gray-600: #6B6760;
  --gray-700: #4A4740;
  --gray-800: #2E2C28;
  --gray-900: #1A1916;

  --success:     #2E7D52;
  --success-bg:  #EEF7F2;
  --success-bdr: #A8D5B9;
  --warning:     #B45309;
  --warning-bg:  #FFF8EE;
  --warning-bdr: #F5C47A;
  --danger:      #B91C1C;
  --danger-bg:   #FEF2F2;
  --danger-bdr:  #FECACA;
  --info:        #1D4ED8;
  --info-bg:     #EEF2FF;
  --info-bdr:    #BFDBFE;

  --sidebar-w:   260px;
  --sidebar-col: 68px;
  --topbar-h:    60px;

  --ff-serif: 'Cormorant Garamond','Georgia',serif;
  --ff-sans:  'Inter','Helvetica Neue',sans-serif;

  --sh-xs: 0 1px 3px rgba(0,0,0,.06);
  --sh-sm: 0 2px 8px rgba(0,0,0,.08);
  --sh-md: 0 4px 16px rgba(0,0,0,.10);
  --sh-lg: 0 8px 32px rgba(0,0,0,.12);
  --sh-xl: 0 16px 48px rgba(0,0,0,.16);
  --sh-brand: 0 4px 16px rgba(200,105,26,.25);

  --r-sm:   6px;
  --r-md:   10px;
  --r-lg:   16px;
  --r-xl:   24px;
  --r-full: 9999px;

  --tr-fast: 150ms ease;
  --tr-base: 250ms ease;
  --tr-slow: 400ms ease;

  /* ── ALIASES para compatibilidad con JS ── */
  --brand-primary-xlight: var(--brand-primary-xs);
  --brand-primary-light:  var(--brand-primary-lt);
  --brand-primary-dark:   var(--brand-primary-dk);
  --brand-gold-light:     var(--brand-gold-lt);
  --brand-gold-xlight:    var(--brand-gold-xs);

  --color-success:        var(--success);
  --color-success-bg:     var(--success-bg);
  --color-success-border: var(--success-bdr);
  --color-warning:        var(--warning);
  --color-warning-bg:     var(--warning-bg);
  --color-warning-border: var(--warning-bdr);
  --color-danger:         var(--danger);
  --color-danger-bg:      var(--danger-bg);
  --color-danger-border:  var(--danger-bdr);
  --color-info:           var(--info);
  --color-info-bg:        var(--info-bg);
  --color-info-border:    var(--info-bdr);

  --font-serif:           var(--ff-serif);
  --font-sans:            var(--ff-sans);

  --radius-sm:   var(--r-sm);
  --radius-md:   var(--r-md);
  --radius-lg:   var(--r-lg);
  --radius-xl:   var(--r-xl);
  --radius-full: var(--r-full);

  --shadow-xs:    var(--sh-xs);
  --shadow-sm:    var(--sh-sm);
  --shadow-md:    var(--sh-md);
  --shadow-lg:    var(--sh-lg);
  --shadow-xl:    var(--sh-xl);
  --shadow-brand: var(--sh-brand);

  --topbar-height:     var(--topbar-h);
  --sidebar-width:     var(--sidebar-w);
  --sidebar-collapsed: var(--sidebar-col);
}

/* ── RESET ───────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;scroll-behavior:smooth}
body{font-family:var(--ff-sans);background:var(--gray-100);color:var(--gray-800);line-height:1.6;min-height:100vh;overflow-x:hidden}
h1,h2,h3,h4,h5{font-family:var(--ff-serif);font-weight:500;line-height:1.3}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,select,textarea{font-family:inherit;outline:none}
img{max-width:100%}

/* ── SCROLLBAR ───────────────────────────────────────────── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--gray-100)}
::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}

/* ── UTILS ───────────────────────────────────────────────── */
.hidden{display:none!important}
.w-full{width:100%}
.text-right{text-align:right}
.text-center{text-align:center}
.text-muted{color:var(--gray-500)}
.text-sm{font-size:.85rem}
.text-xs{font-size:.75rem}
.fw-500{font-weight:500}
.fw-600{font-weight:600}
.font-serif{font-family:var(--ff-serif)}
.fade-in{animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ══════════════════════════════════════════════════════════
   LOGIN SCREEN
══════════════════════════════════════════════════════════ */
.login-screen{
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
  background:linear-gradient(145deg,#110D08 0%,#2A1A0A 45%,#1E1308 100%);
}
.login-bg{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 70% 50% at 15% 85%,rgba(200,105,26,.14) 0%,transparent 55%),
    radial-gradient(ellipse 55% 40% at 85% 15%,rgba(201,168,76,.09) 0%,transparent 50%),
    url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23C8691A' fill-opacity='.025'%3E%3Cpath d='M40 40v-6h-2v6h-6v2h6v6h2v-6h6v-2h-6zm0-30V4h-2v6H32v2h6v6h2v-6h6V10h-6zM10 40v-6H8v6H2v2h6v6h2v-6h6v-2h-6zM10 10V4H8v6H2v2h6v6h2v-6h6V10h-6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

.login-wrap{
  position:relative;z-index:1;
  width:100%;max-width:480px;
  padding:24px 16px;
  display:flex;flex-direction:column;align-items:center;gap:24px;
}

/* Brand */
.login-brand{text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}
.login-logo-ring{
  width:96px;height:96px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(201,168,76,.07);
  border:1.5px solid rgba(201,168,76,.28);
  box-shadow:0 0 36px rgba(201,168,76,.15);
  overflow:hidden;
}
.login-logo-img{width:80px;height:80px;object-fit:contain;padding:6px;filter:brightness(1.15)}
.login-logo-fallback{width:80px;height:80px;display:flex;align-items:center;justify-content:center}
.login-logo-fallback i{font-size:32px;color:var(--brand-gold)}
.login-title{
  font-family:var(--ff-serif);font-size:2.3rem;font-weight:400;
  color:#F0E8D8;letter-spacing:.02em;line-height:1.1;
}
.login-subtitle{
  font-size:.71rem;color:rgba(240,232,216,.5);
  letter-spacing:.18em;text-transform:uppercase;
}
.login-ornament{
  font-size:.72rem;color:var(--brand-gold);opacity:.75;
  letter-spacing:.25em;font-family:var(--ff-sans);font-weight:400;
}

/* Card */
.login-card{
  width:100%;background:rgba(255,255,255,.98);
  border-radius:var(--r-xl);padding:36px 34px 28px;
  box-shadow:var(--sh-xl),0 0 0 1px rgba(201,168,76,.12);
}
.login-card-head{margin-bottom:26px}
.login-card-head h2{
  font-size:1.55rem;color:var(--brand-secondary);margin-bottom:5px;
}
.login-card-head p{font-size:.84rem;color:var(--gray-500)}

/* Pass wrap */
.pass-wrap{position:relative}
.pass-wrap .form-input{padding-right:44px}
.btn-eye{
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
  color:var(--gray-400);font-size:.88rem;padding:4px;
  transition:color var(--tr-fast);
}
.btn-eye:hover{color:var(--brand-primary)}

/* Error */
.login-error{
  display:flex;align-items:center;gap:8px;
  padding:11px 14px;margin-bottom:16px;
  background:var(--danger-bg);border:1px solid var(--danger-bdr);
  border-radius:var(--r-md);font-size:.82rem;color:var(--danger);
}

/* Login button */
.btn-login{
  width:100%;padding:13px 24px;
  background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-primary-dk) 100%);
  color:#fff;border-radius:var(--r-md);font-size:.92rem;font-weight:600;
  letter-spacing:.04em;display:flex;align-items:center;justify-content:center;gap:10px;
  transition:all var(--tr-base);box-shadow:var(--sh-brand);margin-bottom:22px;
}
.btn-login:hover{
  background:linear-gradient(135deg,var(--brand-primary-lt) 0%,var(--brand-primary) 100%);
  transform:translateY(-1px);box-shadow:0 6px 24px rgba(200,105,26,.38);
}
.btn-login:active{transform:translateY(0)}
.btn-login:disabled{opacity:.6;cursor:not-allowed;transform:none}

/* Demo section */
.demo-section{border-top:1px solid var(--gray-150);padding-top:18px}
.demo-title{
  font-size:.72rem;color:var(--gray-400);text-transform:uppercase;
  letter-spacing:.12em;margin-bottom:10px;text-align:center;
}
.demo-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:6px;
}
.demo-btn{
  padding:10px 6px 8px;
  background:var(--gray-50);border:1px solid var(--gray-200);
  border-radius:var(--r-sm);
  display:flex;flex-direction:column;align-items:center;gap:4px;
  transition:all var(--tr-fast);cursor:pointer;
}
.demo-btn:hover{
  background:var(--brand-primary-xs);border-color:var(--brand-primary);
}
.demo-icon{font-size:14px;color:var(--gray-400)}
.demo-btn:hover .demo-icon{color:var(--brand-primary)}
.demo-name{font-size:.7rem;font-weight:600;color:var(--gray-700);text-align:center;line-height:1.2}
.demo-email{font-size:.62rem;color:var(--gray-400);text-align:center;line-height:1.2;word-break:break-all}
.demo-btn:hover .demo-name{color:var(--brand-primary-dk)}

.login-footer{
  font-size:.71rem;color:rgba(240,232,216,.28);text-align:center;
}

/* ══════════════════════════════════════════════════════════
   APP SHELL
══════════════════════════════════════════════════════════ */
.app-shell{
  display:flex;height:100vh;overflow:hidden;
}

/* ══════════════════════════════════════════════════════════
   SIDEBAR
══════════════════════════════════════════════════════════ */
.sidebar{
  width:var(--sidebar-w);height:100vh;
  background:linear-gradient(180deg,#1A1410 0%,#2A1B0C 55%,#1E160A 100%);
  display:flex;flex-direction:column;flex-shrink:0;
  overflow:hidden;transition:width var(--tr-slow);
  position:relative;z-index:100;
  box-shadow:4px 0 20px rgba(0,0,0,.22);
}
.sidebar.collapsed{width:var(--sidebar-col)}
.sidebar.collapsed .nav-text,
.sidebar.collapsed .nav-badge,
.sidebar.collapsed .nav-tag,
.sidebar.collapsed .sidebar-brand,
.sidebar.collapsed .sidebar-brand-sub,
.sidebar.collapsed .nav-group-label,
.sidebar.collapsed .su-info{display:none}
.sidebar.collapsed .sidebar-logo{justify-content:center}
.sidebar.collapsed .sidebar-brand-wrap{display:none}
.sidebar.collapsed .sidebar-user-footer{justify-content:center;padding:14px 8px}
.sidebar.collapsed .su-avatar{margin:0}

/* Header */
.sidebar-header{
  padding:18px 16px 14px;
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid rgba(255,255,255,.07);
  flex-shrink:0;
}
.sidebar-logo{display:flex;align-items:center;gap:10px;overflow:hidden;min-width:0}
.sidebar-logo-box{
  width:36px;height:36px;border-radius:9px;flex-shrink:0;overflow:hidden;
  background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-primary-dk) 100%);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 8px rgba(200,105,26,.4);
}
.sidebar-logo-img{width:100%;height:100%;object-fit:contain;padding:4px}
.sidebar-logo-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.sidebar-logo-fallback i{color:#fff;font-size:16px}
.sidebar-brand-wrap{display:flex;flex-direction:column;min-width:0;overflow:hidden}
.sidebar-brand{
  display:block;font-family:var(--ff-serif);font-size:1.1rem;
  color:#F0E8D8;font-weight:400;line-height:1.15;white-space:nowrap;
}
.sidebar-brand-sub{
  display:block;font-size:.68rem;color:rgba(240,232,216,.38);
  letter-spacing:.09em;text-transform:uppercase;white-space:nowrap;
}
.sidebar-collapse-btn{
  color:rgba(240,232,216,.38);font-size:15px;padding:6px;
  border-radius:var(--r-sm);transition:all var(--tr-fast);flex-shrink:0;
}
.sidebar-collapse-btn:hover{color:var(--brand-gold);background:rgba(255,255,255,.06)}

/* Nav */
.sidebar-nav{
  flex:1;overflow-y:auto;padding:10px 9px;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent;
}
.sidebar-nav::-webkit-scrollbar{width:3px}
.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:99px}

.nav-group-label{
  font-size:.62rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(240,232,216,.26);padding:14px 10px 5px;white-space:nowrap;overflow:hidden;
}
.nav-link{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;border-radius:var(--r-md);
  color:rgba(240,232,216,.58);font-size:.86rem;font-weight:400;
  transition:all var(--tr-fast);white-space:nowrap;position:relative;margin-bottom:2px;
}
.nav-link:hover{background:rgba(255,255,255,.07);color:rgba(240,232,216,.9)}
.nav-link.active{
  background:linear-gradient(135deg,rgba(200,105,26,.28) 0%,rgba(200,105,26,.16) 100%);
  color:#fff;font-weight:500;
}
.nav-link.active::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:60%;background:var(--brand-primary);border-radius:0 2px 2px 0;
}
.nav-icon{
  width:18px;font-size:15px;text-align:center;flex-shrink:0;
  color:rgba(240,232,216,.42);transition:color var(--tr-fast);
}
.nav-link:hover .nav-icon,.nav-link.active .nav-icon{color:var(--brand-primary-lt)}
.nav-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}
.nav-badge{
  margin-left:auto;background:var(--brand-primary);color:#fff;
  font-size:.62rem;font-weight:700;min-width:18px;height:18px;padding:0 5px;
  border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.nav-badge-alert{background:var(--danger);animation:pulseBadge 2s infinite}
@keyframes pulseBadge{0%,100%{box-shadow:0 0 0 0 rgba(185,28,28,.4)}50%{box-shadow:0 0 0 5px rgba(185,28,28,0)}}
.nav-tag{
  margin-left:auto;background:rgba(124,58,237,.22);color:#C4B5FD;
  font-size:.6rem;font-weight:600;padding:2px 7px;border-radius:var(--r-full);
  letter-spacing:.04em;flex-shrink:0;
}

/* User footer */
.sidebar-user-footer{
  padding:12px 14px;border-top:1px solid rgba(255,255,255,.07);
  display:flex;align-items:center;gap:10px;background:rgba(0,0,0,.2);flex-shrink:0;
}
.su-avatar{
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-secondary) 100%);
  color:#fff;font-size:.73rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:.03em;
}
.su-info{flex:1;overflow:hidden;display:flex;flex-direction:column;gap:1px}
.su-name{
  font-size:.82rem;font-weight:500;color:rgba(240,232,216,.88);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.su-role{font-size:.68rem;color:rgba(240,232,216,.38);white-space:nowrap}
.su-logout{
  color:rgba(240,232,216,.3);font-size:14px;padding:6px;
  border-radius:var(--r-sm);transition:all var(--tr-fast);flex-shrink:0;
}
.su-logout:hover{color:var(--danger);background:rgba(185,28,28,.12)}

/* Role-based nav visibility */
.nav-admin-hidden{display:none!important}
.nav-catalog-hidden{display:none!important}
.nav-reports-hidden{display:none!important}

/* Avatar role colors */
.av-admin,.avatar-admin       {background:linear-gradient(135deg,#C8691A,#A5530F)!important;color:#fff!important}
.av-director,.avatar-director {background:linear-gradient(135deg,#1D4ED8,#1e40af)!important;color:#fff!important}
.av-lider,.avatar-lider       {background:linear-gradient(135deg,#2E7D52,#166534)!important;color:#fff!important}
.av-ventas,.avatar-ventas     {background:linear-gradient(135deg,#7C3AED,#5B21B6)!important;color:#fff!important}

/* ══════════════════════════════════════════════════════════
   MAIN AREA
══════════════════════════════════════════════════════════ */
.app-main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--gray-100)}

/* Topbar */
.topbar{
  height:var(--topbar-h);background:#fff;
  border-bottom:1px solid var(--gray-150);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 22px;flex-shrink:0;z-index:50;box-shadow:var(--sh-xs);
}
.topbar-left{display:flex;align-items:center;gap:12px}
.topbar-menu-btn{
  color:var(--gray-500);font-size:15px;padding:8px;border-radius:var(--r-sm);
  transition:all var(--tr-fast);
}
.topbar-menu-btn:hover{color:var(--brand-primary);background:var(--brand-primary-xs)}
.topbar-breadcrumb{display:flex;align-items:center;gap:6px}
.tb-brand{
  font-family:var(--ff-serif);font-size:.9rem;font-weight:500;
  color:var(--brand-primary);letter-spacing:.02em;
}
.tb-sep{font-size:9px;opacity:.35;color:var(--gray-500)}
.tb-module{font-size:.95rem;font-weight:600;color:var(--gray-800)}

.topbar-right{display:flex;align-items:center;gap:12px}

/* Search */
.topbar-search-wrap{
  display:flex;align-items:center;gap:8px;
  background:var(--gray-100);border:1.5px solid var(--gray-200);
  border-radius:var(--r-full);padding:0 14px;height:36px;
  min-width:220px;transition:all var(--tr-fast);
}
.topbar-search-wrap:focus-within{
  border-color:var(--brand-primary);background:#fff;
  box-shadow:0 0 0 3px rgba(200,105,26,.1);
}
.topbar-search-wrap i{color:var(--gray-400);font-size:.78rem;flex-shrink:0}
.topbar-search-wrap input{
  border:none;background:none;font-size:.83rem;color:var(--gray-700);width:100%;
}
.topbar-search-wrap input::placeholder{color:var(--gray-400)}

/* Notif */
.notif-wrap{position:relative}
.notif-btn{
  width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--gray-500);font-size:15px;
  transition:all var(--tr-fast);position:relative;
}
.notif-btn:hover{background:var(--gray-100);color:var(--brand-primary)}
.notif-dot{
  position:absolute;top:7px;right:7px;
  width:8px;height:8px;background:var(--danger);
  border-radius:50%;border:2px solid #fff;
}
.notif-panel{
  position:absolute;top:calc(100% + 10px);right:0;
  width:340px;background:#fff;border-radius:var(--r-lg);
  box-shadow:var(--sh-xl);border:1px solid var(--gray-150);z-index:200;overflow:hidden;
}
.notif-panel-head{
  padding:13px 17px;display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid var(--gray-100);font-size:.86rem;font-weight:600;color:var(--gray-800);
}
.notif-read-all{font-size:.74rem;color:var(--brand-primary);font-weight:500}
.notif-read-all:hover{text-decoration:underline}
.notif-list{max-height:320px;overflow-y:auto}
.notif-item{
  padding:12px 17px;border-bottom:1px solid var(--gray-100);
  display:flex;gap:11px;cursor:pointer;transition:background var(--tr-fast);
}
.notif-item:hover{background:var(--gray-50)}
.notif-item.unread{background:var(--brand-primary-xs)}
.notif-icon{
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;
}
.notif-text{flex:1;min-width:0}
.notif-text-title{font-size:.81rem;font-weight:500;color:var(--gray-800)}
.notif-text-desc{font-size:.75rem;color:var(--gray-500);margin-top:1px}
.notif-text-time{font-size:.7rem;color:var(--gray-400);margin-top:2px}
.notif-empty{padding:28px 17px;text-align:center;color:var(--gray-400);font-size:.84rem}

/* User chip */
.user-chip{
  display:flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:var(--r-full);
  border:1.5px solid var(--gray-200);cursor:pointer;
  transition:all var(--tr-fast);background:var(--gray-50);
}
.user-chip:hover{background:var(--brand-primary-xs);border-color:var(--brand-primary)}
.user-chip-avatar{
  width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-secondary) 100%);
  color:#fff;font-size:.7rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.user-chip-info{display:flex;flex-direction:column;line-height:1.2}
.user-chip-info span{font-size:.83rem;font-weight:500;color:var(--gray-700)}
.user-chip-info small{font-size:.68rem;color:var(--gray-400)}

/* Page content */
.page-content{flex:1;overflow-y:auto;padding:26px}

/* ══════════════════════════════════════════════════════════
   PAGE STRUCTURE
══════════════════════════════════════════════════════════ */
.page-header{
  display:flex;align-items:flex-start;justify-content:space-between;
  margin-bottom:24px;gap:14px;flex-wrap:wrap;
}
.page-title{
  font-family:var(--ff-serif);font-size:1.85rem;color:var(--gray-900);
  font-weight:400;line-height:1.2;margin-bottom:4px;
}
.page-title-accent{color:var(--brand-primary)}
.page-subtitle{font-size:.84rem;color:var(--gray-500)}
.page-header-actions{display:flex;gap:9px;align-items:center;flex-wrap:wrap}
.page-loading{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:80px 20px;gap:14px;color:var(--gray-400);font-size:.88rem;
}
.loading-spinner{
  width:36px;height:36px;border:3px solid var(--gray-200);
  border-top-color:var(--brand-primary);border-radius:50%;
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* Empty state */
.empty-state{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:64px 20px;text-align:center;
}
.empty-state-icon{font-size:40px;color:var(--gray-300);margin-bottom:14px;display:block}
.empty-state-title{font-size:1.1rem;font-weight:500;color:var(--gray-600);margin-bottom:7px}
.empty-state-desc{font-size:.85rem;color:var(--gray-400);max-width:360px;line-height:1.6;margin-bottom:18px}

/* ══════════════════════════════════════════════════════════
   FORMS
══════════════════════════════════════════════════════════ */
.form-group{margin-bottom:16px}
.form-label{
  display:block;font-size:.79rem;font-weight:500;
  color:var(--gray-700);margin-bottom:6px;letter-spacing:.02em;
}
.form-label i{margin-right:4px;color:var(--brand-primary);font-size:.73rem}
.form-input,.form-select,.form-textarea{
  width:100%;padding:10px 13px;
  border:1.5px solid var(--gray-200);border-radius:var(--r-md);
  font-size:.88rem;color:var(--gray-800);background:#fff;
  transition:border-color var(--tr-fast),box-shadow var(--tr-fast);
}
.form-input:focus,.form-select:focus,.form-textarea:focus{
  border-color:var(--brand-primary);background:#fff;
  box-shadow:0 0 0 3px rgba(200,105,26,.1);
}
.form-input:disabled,.form-select:disabled{background:var(--gray-100);color:var(--gray-500);cursor:not-allowed}
.form-textarea{resize:vertical;min-height:80px}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%238B8780' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}

/* Grid helpers */
.fg-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.fg-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}

/* Form section */
.form-section{
  background:#fff;border-radius:var(--r-md);
  border:1px solid var(--gray-150);padding:18px 20px;margin-bottom:14px;
}
.form-section-title{
  font-size:.76rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--brand-primary);margin-bottom:14px;padding-bottom:8px;
  border-bottom:1px solid var(--gray-150);display:flex;align-items:center;gap:7px;
}
.form-section-title i{font-size:.88rem}

/* ══════════════════════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:10px 19px;border-radius:var(--r-md);font-size:.86rem;font-weight:500;
  transition:all var(--tr-base);white-space:nowrap;cursor:pointer;
}
.btn:disabled{opacity:.55;cursor:not-allowed!important;transform:none!important;box-shadow:none!important}

.btn-primary{
  background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-primary-dk) 100%);
  color:#fff;box-shadow:0 2px 8px rgba(200,105,26,.26);
}
.btn-primary:hover:not(:disabled){
  background:linear-gradient(135deg,var(--brand-primary-lt) 0%,var(--brand-primary) 100%);
  transform:translateY(-1px);box-shadow:0 4px 16px rgba(200,105,26,.32);
}
.btn-secondary{
  background:#fff;color:var(--gray-700);
  border:1.5px solid var(--gray-200);box-shadow:var(--sh-xs);
}
.btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-300);color:var(--gray-900)}
.btn-outline{
  background:transparent;color:var(--gray-600);
  border:1.5px solid var(--gray-300);
}
.btn-outline:hover:not(:disabled){background:var(--gray-100);color:var(--gray-800);border-color:var(--gray-400)}
.btn-ghost{background:transparent;color:var(--gray-600);border:1.5px solid transparent}
.btn-ghost:hover:not(:disabled){background:var(--gray-100);color:var(--gray-800)}
.btn-danger{background:var(--danger-bg);color:var(--danger);border:1.5px solid var(--danger-bdr)}
.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff}
.btn-success{background:var(--success-bg);color:var(--success);border:1.5px solid var(--success-bdr)}
.btn-success:hover:not(:disabled){background:var(--success);color:#fff}
.btn-warning{background:var(--warning-bg);color:var(--warning);border:1.5px solid var(--warning-bdr)}
.btn-warning:hover:not(:disabled){background:var(--warning);color:#fff}

.btn-sm{padding:7px 13px;font-size:.79rem}
.btn-xs{padding:5px 10px;font-size:.74rem}
.btn-lg{padding:13px 26px;font-size:.94rem}

.btn-icon{
  width:34px;height:34px;padding:0;border-radius:var(--r-sm);
  border:1px solid var(--gray-200);background:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--gray-500);font-size:.82rem;cursor:pointer;
  transition:all var(--tr-fast);
}
.btn-icon:hover{border-color:var(--brand-primary);color:var(--brand-primary);background:var(--brand-primary-xs)}
.btn-icon.danger:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-bg)}

/* ══════════════════════════════════════════════════════════
   CARDS
══════════════════════════════════════════════════════════ */
.card{
  background:#fff;border-radius:var(--r-lg);
  border:1px solid var(--gray-150);box-shadow:var(--sh-sm);overflow:hidden;
}
.card-header{
  padding:16px 20px 13px;border-bottom:1px solid var(--gray-100);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.card-title{
  font-family:var(--ff-serif);font-size:1.1rem;color:var(--gray-800);font-weight:500;
}
.card-body{padding:20px}
.card-footer{padding:13px 20px;border-top:1px solid var(--gray-100);background:var(--gray-50)}

/* Stat card */
.stat-card{
  background:#fff;border-radius:var(--r-lg);border:1px solid var(--gray-150);
  box-shadow:var(--sh-sm);padding:18px 20px;
}

/* KPI grid */
.kpi-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(215px,1fr));
  gap:16px;margin-bottom:24px;
}
.kpi-card{
  background:#fff;border-radius:var(--r-lg);padding:20px;
  border:1px solid var(--gray-150);box-shadow:var(--sh-sm);
  display:flex;align-items:flex-start;gap:14px;
  transition:all var(--tr-base);position:relative;overflow:hidden;cursor:default;
}
.kpi-card::before{
  content:'';position:absolute;top:0;left:0;right:0;
  height:3px;background:linear-gradient(90deg,var(--brand-primary),var(--brand-gold));
}
.kpi-card:hover{box-shadow:var(--sh-md);transform:translateY(-1px)}
.kpi-icon{
  width:42px;height:42px;border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;
}
.kpi-icon.orange{background:rgba(200,105,26,.12);color:var(--brand-primary)}
.kpi-icon.green {background:rgba(46,125,82,.12); color:var(--success)}
.kpi-icon.gold  {background:rgba(201,168,76,.12);color:#92650A}
.kpi-icon.red   {background:rgba(185,28,28,.1);  color:var(--danger)}
.kpi-icon.blue  {background:rgba(29,78,216,.1);  color:var(--info)}
.kpi-icon.purple{background:rgba(124,58,237,.1); color:#7C3AED}
.kpi-info{flex:1;min-width:0}
.kpi-label{font-size:.76rem;color:var(--gray-500);font-weight:500;margin-bottom:4px;text-transform:uppercase;letter-spacing:.05em}
.kpi-value{
  font-family:var(--ff-serif);font-size:2rem;font-weight:500;
  color:var(--gray-900);line-height:1;margin-bottom:5px;
}
.kpi-trend{font-size:.74rem;color:var(--gray-400);display:flex;align-items:center;gap:4px}
.kpi-trend.up{color:var(--success)}
.kpi-trend.down{color:var(--danger)}
.kpi-trend.neutral{color:var(--gray-400)}

/* ══════════════════════════════════════════════════════════
   TABLES
══════════════════════════════════════════════════════════ */
.table-container{
  background:#fff;border-radius:var(--r-lg);border:1px solid var(--gray-150);
  box-shadow:var(--sh-sm);overflow:auto;
}
.data-table{width:100%;border-collapse:collapse;font-size:.84rem}
.data-table thead tr{background:var(--gray-50)}
.data-table th{
  padding:11px 14px;font-size:.72rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.07em;color:var(--gray-500);text-align:left;
  border-bottom:1.5px solid var(--gray-200);white-space:nowrap;
}
.data-table td{
  padding:11px 14px;border-bottom:1px solid var(--gray-100);
  vertical-align:middle;
}
.data-table tr:last-child td{border-bottom:none}
.data-table tbody tr:hover td{background:var(--gray-50)}
.data-table .text-right{text-align:right}

/* ══════════════════════════════════════════════════════════
   BADGES & STATUS
══════════════════════════════════════════════════════════ */
.badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 9px;border-radius:var(--r-full);
  font-size:.71rem;font-weight:600;white-space:nowrap;
}
.badge-borrador  {background:#F3F4F6;color:#6B7280}
.badge-pendiente {background:#FFFBEB;color:#D97706;border:1px solid #FDE68A}
.badge-aprobada  {background:#ECFDF5;color:#059669;border:1px solid #A7F3D0}
.badge-rechazada {background:#FEF2F2;color:#DC2626;border:1px solid #FECACA}
.badge-expirada  {background:#F9FAFB;color:#9CA3AF;border:1px solid #E5E7EB}
.badge-contrato  {background:#F5F3FF;color:#7C3AED;border:1px solid #DDD6FE}
.badge-success   {background:var(--success-bg);color:var(--success);border:1px solid var(--success-bdr)}
.badge-warning   {background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning-bdr)}
.badge-danger    {background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-bdr)}
.badge-info      {background:var(--info-bg);color:var(--info);border:1px solid var(--info-bdr)}
.badge-neutral   {background:var(--gray-100);color:var(--gray-600);border:1px solid var(--gray-200)}

/* Role chips */
.role-chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 9px;border-radius:var(--r-full);font-size:.71rem;font-weight:600;
}
.role-admin   {background:rgba(200,105,26,.12);color:var(--brand-primary-dk)}
.role-director{background:rgba(29,78,216,.1);  color:var(--info)}
.role-lider   {background:rgba(5,150,105,.1);  color:var(--success)}
.role-ventas  {background:rgba(124,58,237,.1); color:#7C3AED}

/* Folio badge */
.folio-badge{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 11px;background:var(--brand-secondary-dk);
  color:var(--brand-gold-lt);border-radius:var(--r-full);
  font-family:var(--ff-serif);font-size:.92rem;font-weight:500;letter-spacing:.03em;
}
.folio-badge i{font-size:.76rem;color:var(--brand-gold)}

/* ══════════════════════════════════════════════════════════
   FILTER ROW
══════════════════════════════════════════════════════════ */
.filters-row{
  display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:18px;
}
.search-bar{
  display:flex;align-items:center;gap:9px;flex:1;min-width:200px;
  background:#fff;border:1.5px solid var(--gray-200);border-radius:var(--r-full);
  padding:0 14px;height:38px;transition:all var(--tr-fast);
}
.search-bar:focus-within{border-color:var(--brand-primary);box-shadow:0 0 0 3px rgba(200,105,26,.1)}
.search-icon{color:var(--gray-400);font-size:.78rem;flex-shrink:0}
.search-bar input{border:none;background:none;font-size:.85rem;color:var(--gray-700);width:100%}
.search-bar input::placeholder{color:var(--gray-400)}
.filter-select{
  height:38px;padding:0 32px 0 12px;border:1.5px solid var(--gray-200);
  border-radius:var(--r-full);font-size:.83rem;color:var(--gray-600);
  background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%238B8780' d='M1 1l4 4 4-4'/%3E%3C/svg%3E") no-repeat right 12px center;
  appearance:none;cursor:pointer;transition:all var(--tr-fast);
}
.filter-select:focus{outline:none;border-color:var(--brand-primary);box-shadow:0 0 0 3px rgba(200,105,26,.1)}

/* ══════════════════════════════════════════════════════════
   MODAL
══════════════════════════════════════════════════════════ */
.modal-overlay{
  position:fixed;inset:0;background:rgba(26,25,22,.6);backdrop-filter:blur(3px);
  display:flex;align-items:center;justify-content:center;z-index:500;padding:20px;
  animation:fadeIn .2s ease;
}
.modal-box{
  background:#fff;border-radius:var(--r-xl);box-shadow:var(--sh-xl);
  width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;
  animation:slideUp .25s ease;overflow:hidden;
}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.modal-sm .modal-box{max-width:420px}
.modal-md .modal-box{max-width:560px}
.modal-lg .modal-box{max-width:760px}
.modal-xl .modal-box{max-width:960px}
.modal-head{
  padding:18px 22px 14px;border-bottom:1px solid var(--gray-150);
  display:flex;align-items:center;justify-content:space-between;flex-shrink:0;
}
.modal-title{font-size:1.2rem;color:var(--gray-800)}
.modal-close{
  width:32px;height:32px;border-radius:50%;color:var(--gray-400);font-size:14px;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--tr-fast);
}
.modal-close:hover{background:var(--gray-100);color:var(--gray-700)}
.modal-body{padding:20px 22px;overflow-y:auto;flex:1}
.modal-foot{
  padding:14px 22px;border-top:1px solid var(--gray-100);background:var(--gray-50);
  display:flex;gap:10px;justify-content:flex-end;flex-shrink:0;flex-wrap:wrap;
}

/* ══════════════════════════════════════════════════════════
   TOASTS
══════════════════════════════════════════════════════════ */
.toast-container{
  position:fixed;bottom:24px;right:24px;z-index:9999;
  display:flex;flex-direction:column;gap:8px;pointer-events:none;
}
.toast{
  display:flex;align-items:flex-start;gap:11px;
  padding:13px 16px;border-radius:var(--r-md);
  background:#fff;box-shadow:0 4px 20px rgba(0,0,0,.14);
  border-left:4px solid;min-width:280px;max-width:380px;
  pointer-events:all;animation:slideInRight .3s ease;
}
@keyframes slideInRight{from{opacity:0;transform:translateX(24px)}to{opacity:1;transform:none}}
.toast.removing{animation:slideOutRight .3s ease forwards}
@keyframes slideOutRight{to{opacity:0;transform:translateX(24px)}}
.toast.success{border-color:var(--success)}
.toast.error  {border-color:var(--danger)}
.toast.warning{border-color:var(--warning)}
.toast.info   {border-color:var(--info)}
.toast-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.toast.success .toast-icon{color:var(--success)}
.toast.error   .toast-icon{color:var(--danger)}
.toast.warning .toast-icon{color:var(--warning)}
.toast.info    .toast-icon{color:var(--info)}
.toast-content{flex:1;min-width:0}
.toast-title{font-size:.84rem;font-weight:600;color:var(--gray-800)}
.toast-msg{font-size:.78rem;color:var(--gray-500);margin-top:2px;line-height:1.4}
.toast-close{
  color:var(--gray-400);font-size:12px;flex-shrink:0;cursor:pointer;padding:2px;
  transition:color var(--tr-fast);
}
.toast-close:hover{color:var(--gray-700)}

/* ══════════════════════════════════════════════════════════
   TABS
══════════════════════════════════════════════════════════ */
.tabs-nav{
  display:flex;gap:2px;margin-bottom:20px;
  border-bottom:2px solid var(--gray-200);
}
.tab-btn{
  padding:10px 18px;font-size:.85rem;font-weight:500;color:var(--gray-500);
  border-bottom:2px solid transparent;margin-bottom:-2px;
  display:flex;align-items:center;gap:7px;transition:all var(--tr-fast);
}
.tab-btn:hover{color:var(--gray-700)}
.tab-btn.active{color:var(--brand-primary);border-bottom-color:var(--brand-primary)}
.tab-count{
  background:var(--gray-200);color:var(--gray-600);font-size:.68rem;
  padding:1px 6px;border-radius:var(--r-full);font-weight:600;
}
.tab-btn.active .tab-count{background:var(--brand-primary-xs);color:var(--brand-primary)}

/* ══════════════════════════════════════════════════════════
   LINE ITEMS (COTIZACIONES)
══════════════════════════════════════════════════════════ */
.line-items-table{width:100%;border-collapse:collapse;font-size:.82rem}
.line-items-table thead tr{background:var(--gray-50)}
.line-items-table th{
  padding:9px 10px;font-size:.7rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.07em;color:var(--gray-500);border-bottom:1.5px solid var(--gray-200);
  white-space:nowrap;
}
.line-items-table td{
  padding:8px 10px;border-bottom:1px solid var(--gray-100);vertical-align:middle;
}
.line-items-table tr:last-child td{border-bottom:none}
.line-items-table tr:hover td{background:var(--gray-50)}
.line-items-table input[type=number],
.line-items-table input[type=text]{
  padding:5px 8px;border:1.5px solid var(--gray-200);
  border-radius:var(--r-sm);font-size:.82rem;background:#fff;
  transition:border-color var(--tr-fast);
}
.line-items-table input:focus{border-color:var(--brand-primary);outline:none;box-shadow:0 0 0 2px rgba(200,105,26,.1)}
.line-items-table .btn-icon-sm{
  width:26px;height:26px;border-radius:var(--r-sm);border:1px solid var(--gray-200);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:.72rem;cursor:pointer;transition:all var(--tr-fast);color:var(--gray-400);
}
.line-items-table .btn-icon-sm:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-bg)}

/* Totals panel */
.totals-panel{
  background:var(--brand-secondary-dk);border-radius:var(--r-md);
  padding:18px 22px;color:#F0E8D8;
}
.totals-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:5px 0;font-size:.85rem;border-bottom:1px solid rgba(255,255,255,.08);
}
.totals-row:last-child{border-bottom:none}
.totals-row-label{opacity:.65;font-size:.8rem}
.totals-grand{
  font-size:1.35rem;font-family:var(--ff-serif);color:var(--brand-gold-lt);font-weight:500;
}

/* Discount bar */
.disc-bar-wrap{
  background:var(--gray-50);border-radius:var(--r-md);border:1px solid var(--gray-150);padding:12px 14px;
}
.disc-bar{height:6px;background:var(--gray-200);border-radius:var(--r-full);overflow:hidden;margin-bottom:5px}
.disc-bar-fill{height:100%;border-radius:var(--r-full);transition:width var(--tr-base)}
.disc-bar-fill.safe{background:var(--success)}
.disc-bar-fill.warn{background:var(--warning)}
.disc-bar-fill.over{background:var(--danger)}
.disc-bar-labels{display:flex;justify-content:space-between;font-size:.72rem;color:var(--gray-500)}

/* ══════════════════════════════════════════════════════════
   DASHBOARD
══════════════════════════════════════════════════════════ */
.dash-alert{
  background:var(--warning-bg);border:1px solid var(--warning-bdr);
  border-radius:var(--r-md);padding:14px 18px;margin-bottom:20px;
  display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
}
.dash-alert-body{display:flex;align-items:center;gap:12px}
.dash-alert-icon{
  width:38px;height:38px;background:rgba(180,83,9,.12);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:var(--warning);font-size:15px;flex-shrink:0;
}

/* ══════════════════════════════════════════════════════════
   APPROVALS
══════════════════════════════════════════════════════════ */
.approval-card{
  background:#fff;border-radius:var(--r-md);border:1px solid var(--gray-150);
  overflow:hidden;margin-bottom:12px;transition:box-shadow var(--tr-base);
}
.approval-card:hover{box-shadow:var(--sh-sm)}
.approval-card-header{
  display:flex;justify-content:space-between;align-items:flex-start;
  padding:16px 18px 0;gap:12px;
}
.approval-card-body{padding:12px 18px 14px}
.approval-card-footer{
  padding:12px 18px;border-top:1px solid var(--gray-100);background:var(--gray-50);
  display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap;
}
.approval-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:4px}
.approval-meta-item{font-size:.76rem;color:var(--gray-500);display:flex;align-items:center;gap:3px}
.approval-meta-item i{color:var(--gray-400);font-size:.7rem}

/* Price comparison */
.price-comparison{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  padding:12px 14px;background:var(--gray-50);border-radius:var(--r-md);
  border:1px solid var(--gray-150);
}
.price-comp-item{text-align:center;flex:1;min-width:80px}
.price-comp-label{font-size:.7rem;color:var(--gray-400);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}
.price-comp-value{font-size:1.1rem;font-family:var(--ff-serif);font-weight:500}
.price-comp-item.old .price-comp-value{color:var(--gray-500);text-decoration:line-through}
.price-comp-item.new .price-comp-value{color:var(--success)}
.price-comp-item.diff .price-comp-value{color:var(--warning)}
.price-comp-arrow{color:var(--gray-300);font-size:18px}

/* ══════════════════════════════════════════════════════════
   IMPORT MODULE
══════════════════════════════════════════════════════════ */
.file-drop-zone{
  border:2.5px dashed var(--gray-300);border-radius:var(--r-lg);
  padding:48px 20px;text-align:center;cursor:pointer;
  transition:all var(--tr-base);background:var(--gray-50);
}
.file-drop-zone:hover,.file-drop-zone.drag-over{
  border-color:var(--brand-primary);background:var(--brand-primary-xs);
}
.file-drop-icon{font-size:40px;color:var(--gray-400);margin-bottom:12px;line-height:1}
.file-drop-zone:hover .file-drop-icon,.file-drop-zone.drag-over .file-drop-icon{color:var(--brand-primary)}
.file-drop-title{font-size:1rem;font-weight:500;color:var(--gray-700);margin-bottom:5px}
.file-drop-sub{font-size:.8rem;color:var(--gray-400);margin-bottom:14px}
.file-drop-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:9px 18px;border-radius:var(--r-md);border:1.5px solid var(--gray-300);
  background:#fff;font-size:.83rem;font-weight:500;color:var(--gray-600);
  cursor:pointer;transition:all var(--tr-fast);
}
.file-drop-btn:hover{border-color:var(--brand-primary);color:var(--brand-primary);background:var(--brand-primary-xs)}

/* ══════════════════════════════════════════════════════════
   VERSION TIMELINE
══════════════════════════════════════════════════════════ */
.version-timeline{list-style:none;position:relative;padding-left:22px}
.version-timeline::before{
  content:'';position:absolute;left:7px;top:8px;bottom:0;
  width:2px;background:var(--gray-150);
}
.version-item{position:relative;padding-bottom:18px}
.version-item::before{
  content:'';position:absolute;left:-18px;top:6px;
  width:10px;height:10px;border-radius:50%;
  background:var(--brand-primary);border:2px solid #fff;
  box-shadow:0 0 0 2px var(--brand-primary);
}
.version-item:last-child{padding-bottom:0}
.version-item-title{font-size:.86rem;font-weight:500;color:var(--gray-800)}
.version-item-meta{font-size:.74rem;color:var(--gray-400);margin-top:2px}
.version-item-desc{font-size:.79rem;color:var(--gray-600);margin-top:3px}

/* ══════════════════════════════════════════════════════════
   PDF PREVIEW
══════════════════════════════════════════════════════════ */
.pdf-modal{
  position:fixed;inset:0;z-index:600;
  display:flex;flex-direction:column;background:var(--gray-900);
}
.pdf-toolbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:11px 22px;background:var(--gray-800);
  border-bottom:1px solid rgba(255,255,255,.07);flex-shrink:0;
}
.pdf-toolbar-title{color:rgba(255,255,255,.82);font-size:.88rem;font-weight:500}
.pdf-toolbar-actions{display:flex;gap:9px}
.pdf-preview-area{
  flex:1;overflow-y:auto;padding:32px;
  display:flex;align-items:flex-start;justify-content:center;
}

/* PDF Document */
.pdf-document{
  width:210mm;min-height:297mm;background:#fff;
  box-shadow:0 8px 40px rgba(0,0,0,.35);border-radius:3px;
  padding:20mm 18mm 16mm;font-family:'Inter',sans-serif;
  font-size:10pt;color:#1A1916;
}
.pdf-header{
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:2px solid #C8691A;padding-bottom:13px;margin-bottom:16px;
}
.pdf-logo-area{display:flex;align-items:center;gap:13px}
.pdf-logo-area img{width:58px;height:58px;object-fit:contain}
.pdf-company-name{font-family:'Cormorant Garamond',serif;font-size:15pt;font-weight:500;color:#6B3F1E;line-height:1.2}
.pdf-company-sub{font-size:7pt;color:#8B8780;letter-spacing:.15em;text-transform:uppercase;margin-top:2px}
.pdf-folio-area{text-align:right}
.pdf-folio-label{font-size:7pt;letter-spacing:.1em;text-transform:uppercase;color:#8B8780}
.pdf-folio-number{font-family:'Cormorant Garamond',serif;font-size:17pt;color:#C8691A;font-weight:500;line-height:1.2}
.pdf-folio-date{font-size:7.5pt;color:#8B8780}
.pdf-section-title{
  font-size:7pt;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:#C8691A;margin-bottom:7px;border-bottom:1px solid #E5E3DF;padding-bottom:3px;
}
.pdf-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px 20px;margin-bottom:14px}
.pdf-info-item{display:flex;flex-direction:column;gap:1px}
.pdf-info-label{font-size:7pt;text-transform:uppercase;letter-spacing:.08em;color:#8B8780}
.pdf-info-value{font-size:9pt;color:#2E2C28;font-weight:500}
.pdf-table{width:100%;border-collapse:collapse;margin-bottom:14px}
.pdf-table th{
  background:#3D2A12;color:#F0E8D8;font-size:7pt;font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;padding:6px 9px;text-align:left;
}
.pdf-table th:last-child,.pdf-table td:last-child{text-align:right}
.pdf-table td{padding:6px 9px;font-size:8.5pt;border-bottom:1px solid #E5E3DF}
.pdf-table tr:nth-child(even) td{background:#FAFAF9}
.pdf-table tr:last-child td{border-bottom:none}
.pdf-totals{margin-left:auto;width:250px;margin-bottom:14px}
.pdf-totals-row{display:flex;justify-content:space-between;padding:4px 0;font-size:8.5pt;border-bottom:1px solid #E5E3DF}
.pdf-totals-row:last-child{border-bottom:none}
.pdf-totals-total{font-weight:700;font-size:11pt;color:#2E2C28;border-top:2px solid #C8691A;padding-top:7px}
.pdf-seller-section{
  display:flex;gap:24px;margin-bottom:14px;padding:11px 13px;
  background:#FDF0E6;border-radius:5px;border:1px solid rgba(232,129,58,.2);flex-wrap:wrap;
}
.pdf-seller-label{font-size:7pt;color:#8B8780;text-transform:uppercase;letter-spacing:.08em}
.pdf-seller-value{font-size:9pt;color:#2E2C28;font-weight:500}
.pdf-obs{
  font-size:8.5pt;color:#4A4740;line-height:1.6;
  background:#FAFAF9;border:1px solid #E5E3DF;border-radius:4px;
  padding:9px 12px;margin-bottom:14px;
}
.pdf-footer{
  text-align:center;font-size:7pt;color:#B0ADA6;
  border-top:1px solid #E5E3DF;padding-top:9px;line-height:1.9;
}

/* ══════════════════════════════════════════════════════════
   ALERTS / BANNERS
══════════════════════════════════════════════════════════ */
.alert{
  padding:11px 14px;border-radius:var(--r-md);font-size:.83rem;
  display:flex;align-items:flex-start;gap:8px;
}
.alert i{flex-shrink:0;margin-top:1px}
.alert-warning{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning-bdr)}
.alert-danger {background:var(--danger-bg); color:var(--danger); border:1px solid var(--danger-bdr)}
.alert-success{background:var(--success-bg);color:var(--success);border:1px solid var(--success-bdr)}
.alert-info   {background:var(--info-bg);   color:var(--info);   border:1px solid var(--info-bdr)}

/* ══════════════════════════════════════════════════════════
   CONTRACT MODULE
══════════════════════════════════════════════════════════ */
.contract-banner{
  background:linear-gradient(135deg,#1A0A3A 0%,#2D1560 100%);
  border-radius:var(--r-lg);padding:26px 28px;
  display:flex;align-items:center;gap:22px;
  border:1px solid rgba(124,58,237,.3);margin-bottom:22px;
}
.contract-banner-icon{
  width:58px;height:58px;background:rgba(124,58,237,.2);border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;font-size:22px;color:#C4B5FD;flex-shrink:0;
}
.contract-banner-title{font-family:var(--ff-serif);font-size:1.25rem;color:#E9D5FF;margin-bottom:4px}
.contract-banner-desc{font-size:.83rem;color:rgba(196,181,253,.6);line-height:1.6}

/* ══════════════════════════════════════════════════════════
   HOVER EFFECTS
══════════════════════════════════════════════════════════ */
.hover-lift{transition:transform var(--tr-base),box-shadow var(--tr-base)}
.hover-lift:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}

/* ══════════════════════════════════════════════════════════
   PRINT
══════════════════════════════════════════════════════════ */
@media print {
  body>*{display:none}
  .pdf-modal{display:flex!important;position:static!important;background:#fff}
  .pdf-toolbar{display:none!important}
  .pdf-preview-area{padding:0!important;display:block!important}
  .pdf-document{width:100%;box-shadow:none;padding:10mm 14mm;min-height:auto}
  @page{size:A4;margin:0}
}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════ */
@media(max-width:900px){
  .topbar-search-wrap{display:none}
  .fg-3,.fg-4{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .sidebar{position:fixed;z-index:200;transform:translateX(-100%)}
  .sidebar.mobile-open{transform:translateX(0)}
  .page-content{padding:16px}
  .fg-2,.fg-3,.fg-4{grid-template-columns:1fr}
  .demo-grid{grid-template-columns:repeat(3,1fr)}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .pdf-document{width:100%;padding:8mm}
  .login-card{padding:24px 18px}
  .login-container{padding:14px}
}
@media(max-width:400px){
  .demo-grid{grid-template-columns:1fr 1fr}
}

/* ══════════════════════════════════════════════════════════
   ALIAS HELPERS – Compatibilidad entre módulos JS y CSS
══════════════════════════════════════════════════════════ */

/* Page header left */
.page-header-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

/* Form row aliases (.form-row-2/.form-row-3 → .fg-2/.fg-3) */
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
@media(max-width:700px){
  .form-row-2,.form-row-3{grid-template-columns:1fr}
}

/* Totals panel aliases */
.totals-panel-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:5px 0;font-size:.85rem;border-bottom:1px solid rgba(255,255,255,.08);
}
.totals-panel-row:last-child{border-bottom:none}
.totals-panel-label{opacity:.65;font-size:.8rem}
.totals-panel-total{
  font-size:1.35rem;font-family:var(--ff-serif);color:var(--brand-gold-lt);font-weight:500;
}

/* Discount progress (alias for disc-bar) */
.discount-progress{height:6px;background:var(--gray-200);border-radius:var(--r-full);overflow:hidden;margin-bottom:5px}
.discount-progress-fill{height:100%;border-radius:var(--r-full);transition:width var(--tr-base)}
.discount-progress-fill.safe{background:var(--success)}
.discount-progress-fill.warning{background:var(--warning)}
.discount-progress-fill.danger{background:var(--danger)}
.discount-rules-bar{background:var(--gray-50);border-radius:var(--r-md);border:1px solid var(--gray-150);padding:12px 14px}
.discount-rules-text{display:flex;justify-content:space-between;font-size:.72rem;color:var(--gray-500)}

/* Btn icon danger */
.btn-icon-danger:hover{border-color:var(--danger)!important;color:var(--danger)!important;background:var(--danger-bg)!important}

/* PDF observations alias */
.pdf-observations{
  font-size:8.5pt;color:#4A4740;line-height:1.6;
  background:#FAFAF9;border:1px solid #E5E3DF;border-radius:4px;
  padding:9px 12px;margin-bottom:14px;
}

/* Notif item parts (in renderNotifPanel) */
.notif-item-icon{
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;
}
.notif-item-text{flex:1;min-width:0}
.notif-item-title{font-size:.81rem;font-weight:500;color:var(--gray-800)}
.notif-item-desc{font-size:.75rem;color:var(--gray-500);margin-top:1px}
.notif-item-time{font-size:.7rem;color:var(--gray-400);margin-top:2px}

/* Plan card option */
.plan-card-opt{transition:all var(--tr-base)!important}
.plan-card-opt:hover{border-color:var(--brand-primary)!important;background:var(--brand-primary-xs)!important}

/* Add concept row */
.add-concept-row{padding-top:6px;border-top:1px dashed var(--gray-200);margin-top:4px}

/* Config module */
.config-section{
  background:#fff;border-radius:var(--r-lg);border:1px solid var(--gray-150);
  box-shadow:var(--sh-sm);overflow:hidden;margin-bottom:20px;
}
.config-section-header{
  padding:16px 20px 13px;border-bottom:1px solid var(--gray-100);
  display:flex;align-items:center;gap:9px;background:var(--gray-50);
  font-size:.76rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--brand-primary);
}
.config-section-title{font-size:.76rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--brand-primary)}
.config-section-body{padding:6px 0}
.config-row{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:13px 20px;border-bottom:1px solid var(--gray-100);
}
.config-row:last-child{border-bottom:none}
.config-row-label{font-size:.87rem;font-weight:500;color:var(--gray-700)}
.config-row-desc{font-size:.76rem;color:var(--gray-400);margin-top:2px}
.config-row-control{min-width:200px;max-width:280px;display:flex;align-items:center;gap:8px}

/* Data table helper classes */
.col-folio{font-family:var(--ff-serif);font-size:.95rem;color:var(--brand-primary)}
.col-name{font-weight:500;color:var(--gray-800)}
.col-amount{font-family:var(--ff-serif);font-size:1rem;color:var(--gray-800)}

/* Badge aliases */
.badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 9px;border-radius:var(--r-full);font-size:.72rem;font-weight:600;
}
.badge-success  {background:var(--success-bg);color:var(--success);border:1px solid var(--success-bdr)}
.badge-warning  {background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning-bdr)}
.badge-danger   {background:var(--danger-bg); color:var(--danger); border:1px solid var(--danger-bdr)}
.badge-info     {background:var(--info-bg);   color:var(--info);   border:1px solid var(--info-bdr)}

/* Status-specific badges */
.estado-borrador           {background:#F5F4F2;color:#6B6760;border:1px solid #E5E3DF}
.estado-pendiente_aprobacion{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning-bdr)}
.estado-aprobada           {background:var(--success-bg);color:var(--success);border:1px solid var(--success-bdr)}
.estado-rechazada          {background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-bdr)}
.estado-expirada           {background:#F5F4F2;color:#8B8780;border:1px solid #E5E3DF}
.estado-convertida_contrato{background:var(--info-bg);color:var(--info);border:1px solid var(--info-bdr)}

/* Role chip */
.role-chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 10px;border-radius:var(--r-full);font-size:.73rem;font-weight:600;
}
.role-admin   {background:rgba(200,105,26,.12);color:var(--brand-primary);border:1px solid rgba(200,105,26,.25)}
.role-director{background:rgba(29,78,216,.1);  color:var(--info);         border:1px solid rgba(29,78,216,.2)}
.role-lider   {background:rgba(46,125,82,.1);  color:var(--success);      border:1px solid rgba(46,125,82,.2)}
.role-ventas  {background:rgba(124,58,237,.1); color:#7C3AED;             border:1px solid rgba(124,58,237,.2)}

/* ══════════════════════════════════════════════════════════
   PERFIL DE USUARIO · Mi Perfil
   ══════════════════════════════════════════════════════════ */
.profile-layout{
  display:grid;
  grid-template-columns:300px 1fr;
  gap:24px;
  align-items:start;
}
@media(max-width:900px){
  .profile-layout{grid-template-columns:1fr}
}

/* ── Card Identidad ────────────────────────────────────── */
.profile-identity-card{
  position:sticky;top:calc(var(--topbar-h) + 16px);
}
.profile-avatar-area{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:24px 24px 12px;
  border-bottom:1px solid var(--gray-150);
}
.profile-avatar-ring{
  width:88px;height:88px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  border:3px solid var(--brand-primary);
  box-shadow:0 0 0 5px rgba(200,105,26,.12);
}
.profile-avatar-inner{
  width:76px;height:76px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.7rem;font-weight:700;font-family:var(--ff-sans);
  letter-spacing:.02em;
}
/* Colores de avatar según rol */
.avatar-admin   .profile-avatar-inner{background:linear-gradient(135deg,#C8691A,#A5530F);color:#fff}
.avatar-director.profile-avatar-ring  {border-color:var(--info)}
.avatar-director.profile-avatar-ring  {box-shadow:0 0 0 5px rgba(29,78,216,.1)}
.avatar-director .profile-avatar-inner{background:linear-gradient(135deg,#1D4ED8,#1e40af);color:#fff}
.avatar-lider   .profile-avatar-inner{background:linear-gradient(135deg,#2E7D52,#16623d);color:#fff}
.avatar-ventas  .profile-avatar-inner{background:linear-gradient(135deg,#7C3AED,#5b21b6);color:#fff}

.profile-rol-badge{
  display:flex;align-items:center;gap:6px;
  font-size:.8rem;font-weight:600;color:var(--gray-600);
}
.profile-info-block{
  padding:16px 20px;border-bottom:1px solid var(--gray-150);
}
.profile-name{
  font-size:1.1rem;font-weight:700;color:var(--gray-800);margin:0 0 4px;
  font-family:var(--ff-serif);
}
.profile-email,.profile-phone,.profile-last-access{
  font-size:.83rem;color:var(--gray-500);margin:3px 0;
  display:flex;align-items:center;gap:6px;
}
.profile-email i,.profile-phone i,.profile-last-access i{
  color:var(--brand-primary);width:14px;
}

/* ── Datos vendedor ─────────────────────────────────── */
.profile-seller-info{padding:16px 20px}
.profile-seller-title{
  font-size:.78rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.07em;color:var(--gray-500);margin-bottom:10px;
  display:flex;align-items:center;gap:6px;
}
.profile-seller-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:5px 0;border-bottom:1px dashed var(--gray-150);font-size:.82rem;
}
.profile-seller-row:last-child{border:none}
.profile-seller-label{color:var(--gray-500)}
.profile-seller-value{font-weight:600;color:var(--gray-700);max-width:180px;text-align:right;word-break:break-all}

/* ── Tabs ────────────────────────────────────────────── */
.profile-tabs{
  display:flex;gap:6px;flex-wrap:wrap;
  margin-bottom:16px;
}
.profile-tab{
  padding:7px 14px;border-radius:var(--r-md);
  border:1px solid var(--gray-200);background:var(--gray-50);
  font-size:.82rem;font-weight:500;color:var(--gray-600);
  cursor:pointer;transition:all .15s;
  display:flex;align-items:center;gap:6px;
}
.profile-tab:hover{background:var(--brand-primary-xs);color:var(--brand-primary);border-color:rgba(200,105,26,.3)}
.profile-tab.active{
  background:var(--brand-primary);color:#fff;border-color:var(--brand-primary);
  box-shadow:0 2px 8px rgba(200,105,26,.3);
}

/* ── Tabla de permisos ──────────────────────────────── */
.perm-table{width:100%;border-collapse:collapse;font-size:.83rem}
.perm-table th{
  padding:8px 14px;text-align:left;
  background:var(--gray-100);color:var(--gray-600);
  font-size:.73rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  border-bottom:1px solid var(--gray-200);
}
.perm-table td{
  padding:8px 14px;color:var(--gray-700);
  border-bottom:1px solid var(--gray-100);vertical-align:middle;
}
.perm-table tr:last-child td{border:none}
.perm-table tr:hover td{background:var(--gray-50)}
.perm-category{
  font-weight:700;color:var(--brand-primary);
  background:var(--brand-primary-xs)!important;
  font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;
}
.perm-yes{color:var(--success);font-size:.9rem}
.perm-no {color:var(--gray-300);font-size:.9rem}

/* ── Tabla de auditoría ─────────────────────────────── */
.audit-table{width:100%;border-collapse:collapse;font-size:.83rem}
.audit-table th{
  padding:8px 14px;text-align:left;
  background:var(--gray-100);color:var(--gray-600);
  font-size:.73rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  border-bottom:1px solid var(--gray-200);
}
.audit-table td{
  padding:9px 14px;color:var(--gray-700);
  border-bottom:1px solid var(--gray-100);vertical-align:middle;
}
.audit-table tr:last-child td{border:none}
.audit-table tr:hover td{background:var(--gray-50)}
.audit-accion{
  display:inline-flex;align-items:center;gap:5px;
  padding:2px 8px;border-radius:var(--r-full);font-size:.75rem;font-weight:600;
}
.audit-login    {background:var(--success-bg);color:var(--success)}
.audit-logout   {background:var(--gray-100);color:var(--gray-600)}
.audit-error    {background:var(--danger-bg);color:var(--danger)}
.audit-password {background:var(--info-bg);color:var(--info)}
.audit-edit     {background:var(--warning-bg);color:var(--warning)}

/* ── Password strength ──────────────────────────────── */
.pass-strength{display:flex;align-items:center;gap:8px;margin-top:6px}
.pass-strength-track{flex:1;height:5px;border-radius:var(--r-full);background:var(--gray-200);overflow:hidden}
.pass-strength-fill{height:100%;border-radius:var(--r-full);transition:width .3s,background .3s}
.pass-strength-label{font-size:.75rem;font-weight:600;min-width:60px;text-align:right}

/* ── Shake animation (login error) ─────────────────── */
@keyframes shake{
  0%,100%{transform:translateX(0)}
  20%{transform:translateX(-8px)}
  40%{transform:translateX(8px)}
  60%{transform:translateX(-5px)}
  80%{transform:translateX(5px)}
}
.shake{animation:shake .5s ease}

/* ══════════════════════════════════════════════════════════
   USUARIOS · Módulo Admin
   ══════════════════════════════════════════════════════════ */
.users-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:20px;
}
.user-card{
  background:#fff;border-radius:var(--r-lg);
  border:1px solid var(--gray-150);
  padding:20px;
  transition:box-shadow .2s,border-color .2s;
  position:relative;
}
.user-card:hover{
  box-shadow:0 4px 16px rgba(0,0,0,.08);
  border-color:rgba(200,105,26,.3);
}
.user-card-head{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.user-card-avatar{
  width:48px;height:48px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;font-weight:700;flex-shrink:0;
}
.user-card-avatar.avatar-admin   {background:linear-gradient(135deg,#C8691A,#A5530F);color:#fff}
.user-card-avatar.avatar-director{background:linear-gradient(135deg,#1D4ED8,#1e40af);color:#fff}
.user-card-avatar.avatar-lider   {background:linear-gradient(135deg,#2E7D52,#16623d);color:#fff}
.user-card-avatar.avatar-ventas  {background:linear-gradient(135deg,#7C3AED,#5b21b6);color:#fff}
.user-card-name{font-weight:700;font-size:.95rem;color:var(--gray-800)}
.user-card-email{font-size:.8rem;color:var(--gray-500);margin-top:2px}
.user-card-body{font-size:.83rem;color:var(--gray-600);margin-bottom:14px}
.user-card-body p{margin:4px 0;display:flex;align-items:center;gap:6px}
.user-card-body i{color:var(--brand-primary);width:14px}
.user-card-footer{
  display:flex;align-items:center;justify-content:space-between;
  border-top:1px solid var(--gray-100);padding-top:12px;
}
.user-inactive{opacity:.55}
.user-inactive::after{
  content:"Inactivo";position:absolute;top:12px;right:12px;
  font-size:.7rem;font-weight:700;text-transform:uppercase;
  background:var(--danger-bg);color:var(--danger);
  padding:2px 8px;border-radius:var(--r-full);
}
.user-card-status{
  font-size:.78rem;font-weight:600;
  display:flex;align-items:center;gap:4px;
}
.status-dot{width:7px;height:7px;border-radius:50%}
.status-dot.active  {background:var(--success)}
.status-dot.inactive{background:var(--danger)}
.user-card-actions{display:flex;gap:6px}

/* ── Tabla de bitácora de usuarios ─────────────────── */
.audit-log-badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:2px 8px;border-radius:var(--r-full);font-size:.73rem;font-weight:600;
}
.audit-log-create{background:var(--success-bg);color:var(--success)}
.audit-log-edit  {background:var(--warning-bg);color:var(--warning)}
.audit-log-delete{background:var(--danger-bg);color:var(--danger)}
.audit-log-toggle{background:var(--info-bg);color:var(--info)}
.audit-log-login {background:var(--success-bg);color:var(--success)}
.audit-log-logout{background:var(--gray-100);color:var(--gray-500)}

/* ══════════════════════════════════════════════════════════
   USUARIOS · Cards de usuario
   ══════════════════════════════════════════════════════════ */
.user-card-status-bar{
  height:4px;border-radius:var(--r-lg) var(--r-lg) 0 0;margin:-1px -1px 0;
}
.user-card-status-bar.status-active  {background:linear-gradient(90deg,var(--success),#16a34a)}
.user-card-status-bar.status-inactive{background:var(--gray-200)}
.user-card-inactive{opacity:.7}
.user-me-badge{
  position:absolute;bottom:-4px;right:-4px;
  background:var(--brand-primary);color:#fff;
  font-size:.58rem;font-weight:800;padding:1px 5px;
  border-radius:var(--r-full);border:2px solid #fff;
}
.sidebar-user-avatar{
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-family:var(--ff-sans);color:#fff;position:relative;
  flex-shrink:0;
}
.sidebar-user-avatar.avatar-admin   {background:linear-gradient(135deg,#C8691A,#A5530F)}
.sidebar-user-avatar.avatar-director{background:linear-gradient(135deg,#1D4ED8,#1e40af)}
.sidebar-user-avatar.avatar-lider   {background:linear-gradient(135deg,#2E7D52,#16623d)}
.sidebar-user-avatar.avatar-ventas  {background:linear-gradient(135deg,#7C3AED,#5b21b6)}
.user-contact-row{
  display:flex;justify-content:space-between;gap:8px;flex-wrap:wrap;
  margin-top:12px;padding-top:10px;border-top:1px solid var(--gray-100);
  font-size:.78rem;color:var(--gray-500);
}
.user-contact-row i{color:var(--brand-primary);width:13px}
.user-perm-chips{
  display:flex;flex-wrap:wrap;gap:5px;margin-top:8px;
}
.perm-chip{
  font-size:.68rem;font-weight:600;padding:2px 7px;
  border-radius:var(--r-full);border:1px solid;
}
.perm-chip-allow{background:var(--success-bg);color:var(--success);border-color:var(--success-bdr)}
.perm-chip-deny {background:var(--gray-100);color:var(--gray-400);border-color:var(--gray-200)}
.user-perm-chip{
  display:inline-flex;align-items:center;gap:4px;
  font-size:.68rem;font-weight:600;padding:2px 7px;
  border-radius:var(--r-full);
}

/* ── Tabla de permisos por rol ──────────────────────── */
.perm-group{margin-bottom:0}
.perm-group-label{
  font-size:.73rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;
  color:var(--brand-primary);background:var(--brand-primary-xs);
  padding:8px 16px;display:flex;align-items:center;gap:6px;
  border-bottom:1px solid rgba(200,105,26,.15);
}
.perm-table{width:100%;border-collapse:collapse}
.perm-row td{
  padding:8px 16px;border-bottom:1px solid var(--gray-100);
  vertical-align:middle;
}
.perm-row:last-child td{border:none}
.perm-row:hover td{background:var(--gray-50)}
.perm-label{font-size:.83rem;color:var(--gray-700);font-weight:500}
.perm-val{text-align:right;white-space:nowrap}
.perm-allow{
  display:inline-flex;align-items:center;gap:4px;
  font-size:.78rem;font-weight:600;color:var(--success);
}
.perm-deny{
  display:inline-flex;align-items:center;gap:4px;
  font-size:.78rem;font-weight:600;color:var(--gray-300);
}
.perm-value-num{
  font-size:.82rem;font-weight:700;
  color:var(--brand-primary);
  background:var(--brand-primary-xs);
  padding:2px 8px;border-radius:var(--r-full);
}

/* ── Colores de texto por rol ───────────────────────── */
.color-admin   {color:var(--brand-primary)!important}
.color-director{color:var(--info)!important}
.color-lider   {color:var(--success)!important}
.color-ventas  {color:#7C3AED!important}

/* ── Page Loading ────────────────────────────────────── */
.page-loading{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:12px;padding:80px 20px;color:var(--gray-500);font-size:.9rem;
}
.loading-spinner{
  width:36px;height:36px;border-radius:50%;
  border:3px solid var(--gray-200);
  border-top-color:var(--brand-primary);
  animation:spin .7s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ══════════════════════════════════════════════════════════
   COTIZACIONES · Módulo Principal
   ══════════════════════════════════════════════════════════ */

/* ── KPIs Row ──────────────────────────────────────── */
.cot-kpi-row{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
  gap:14px;
  margin-bottom:20px;
}
.cot-kpi-card{
  background:#fff;border-radius:var(--r-lg);
  border:1px solid var(--gray-150);
  padding:16px;
  display:flex;align-items:center;gap:14px;
  box-shadow:var(--sh-xs);
  transition:box-shadow .2s,border-color .2s;
}
.cot-kpi-card:hover{
  box-shadow:var(--sh-sm);
  border-color:rgba(200,105,26,.2);
}
.cot-kpi-card.cot-kpi-money{
  background:linear-gradient(135deg,var(--brand-gold-xs),#fff);
  border-color:rgba(201,168,76,.3);
}
.cot-kpi-icon{
  width:42px;height:42px;border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;flex-shrink:0;
}
.cot-kpi-num{
  font-size:1.6rem;font-weight:800;color:var(--gray-800);
  line-height:1;letter-spacing:-.02em;
}
.cot-kpi-label{
  font-size:.73rem;color:var(--gray-400);font-weight:500;
  margin-top:2px;text-transform:uppercase;letter-spacing:.04em;
}

/* ── Filtros ─────────────────────────────────────────── */
.cot-filters{
  display:flex;align-items:center;gap:10px;
  flex-wrap:wrap;margin-bottom:16px;
}
.cot-search-wrap{
  position:relative;flex:1;min-width:240px;
}
.cot-search-icon{
  position:absolute;left:12px;top:50%;transform:translateY(-50%);
  color:var(--gray-400);font-size:.85rem;pointer-events:none;
}
.cot-search-input{
  width:100%;padding:8px 36px 8px 34px;
  border:1.5px solid var(--gray-200);border-radius:var(--r-md);
  font-size:.87rem;color:var(--gray-800);
  background:#fff;
  transition:border-color .15s,box-shadow .15s;
}
.cot-search-input:focus{
  outline:none;
  border-color:var(--brand-primary);
  box-shadow:0 0 0 3px rgba(200,105,26,.1);
}
.cot-search-clear{
  position:absolute;right:10px;top:50%;transform:translateY(-50%);
  background:none;border:none;cursor:pointer;
  color:var(--gray-400);font-size:.8rem;
  padding:4px;line-height:1;
  transition:color .15s;
}
.cot-search-clear:hover{color:var(--gray-700)}

/* ── Folio & Estado badges ───────────────────────────── */
.cot-folio{
  font-family:var(--ff-sans);font-weight:700;font-size:.85rem;
  color:var(--brand-primary);letter-spacing:.04em;
  background:var(--brand-primary-xs);
  padding:3px 10px;border-radius:var(--r-full);
  border:1px solid rgba(200,105,26,.2);
  white-space:nowrap;
}
.cot-version-badge{
  font-size:.68rem;font-weight:800;
  color:var(--info);background:var(--info-bg);
  border:1px solid var(--info-bdr);
  padding:1px 7px;border-radius:var(--r-full);
}
.cot-estado-badge{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 10px;border-radius:var(--r-full);
  font-size:.75rem;font-weight:700;
  white-space:nowrap;letter-spacing:.02em;
}
.cot-estado-dot{
  width:8px;height:8px;border-radius:50%;flex-shrink:0;
}

/* ── Table rows ─────────────────────────────────────── */
.row-expired{opacity:.8}
.row-expired td:first-child::before{
  content:'';display:block;height:2px;
  background:var(--danger);
  margin-bottom:4px;border-radius:2px;
}

/* ── Form Layout ────────────────────────────────────── */
.cot-form-layout{
  display:grid;
  grid-template-columns:1fr 320px;
  gap:24px;
  align-items:start;
}
@media(max-width:1100px){
  .cot-form-layout{grid-template-columns:1fr}
}
.cot-form-left{display:flex;flex-direction:column;gap:20px}
.cot-form-right{
  position:sticky;top:calc(var(--topbar-h) + 20px);
  display:flex;flex-direction:column;gap:14px;
}

/* ── Sections ───────────────────────────────────────── */
.cot-section{
  background:#fff;border-radius:var(--r-lg);
  border:1px solid var(--gray-150);
  padding:20px 22px;
  box-shadow:var(--sh-xs);
}
.form-section-hd{
  display:flex;align-items:center;gap:8px;
  font-weight:700;font-size:.9rem;color:var(--gray-700);
  margin-bottom:16px;
}
.form-section-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;
  background:var(--brand-primary);color:#fff;
  font-size:.72rem;font-weight:800;flex-shrink:0;
}
.form-section-opt{
  font-weight:400;font-size:.78rem;color:var(--gray-400);
  margin-left:4px;
}

/* ── Planes Grid ────────────────────────────────────── */
.cot-planes-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
  gap:10px;
}
.cot-plan-tile{
  border:2px solid var(--gray-200);border-radius:var(--r-md);
  padding:12px 10px;text-align:center;cursor:pointer;
  transition:border-color .15s,background .15s,transform .15s,box-shadow .15s;
  font-size:.82rem;
}
.cot-plan-tile:hover{
  border-color:var(--brand-primary);
  background:var(--brand-primary-xs);
  transform:translateY(-2px);
  box-shadow:var(--sh-sm);
}
.cot-plan-tile.active{
  border-color:var(--brand-primary);
  background:var(--brand-primary-xs);
  box-shadow:0 0 0 3px rgba(200,105,26,.15);
}
.cot-plan-tile.cot-plan-none.active{
  border-color:var(--gray-400);
  background:var(--gray-100);
  box-shadow:none;
}
.cot-plan-tile-name{font-weight:700;color:var(--gray-800);margin-bottom:3px}
.cot-plan-tile-info{font-size:.72rem;color:var(--gray-400);margin-bottom:4px}
.cot-plan-tile-price{font-size:.75rem;font-weight:700;color:var(--brand-primary)}

/* ── Items / Conceptos Table ────────────────────────── */
.cot-items-count{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:22px;height:22px;padding:0 6px;
  background:var(--brand-primary);color:#fff;
  border-radius:var(--r-full);font-size:.72rem;font-weight:800;
}
.cot-empty-items{
  text-align:center;padding:40px 20px;
  border:2px dashed var(--gray-200);border-radius:var(--r-md);
  color:var(--gray-500);
}
.cot-items-table-wrap{
  overflow-x:auto;border-radius:var(--r-md);
  border:1px solid var(--gray-200);
}
.cot-items-table{
  width:100%;border-collapse:collapse;font-size:.83rem;
  min-width:700px;
}
.cot-items-table thead tr{background:var(--gray-50)}
.cot-items-table th{
  padding:10px 12px;text-align:left;
  font-size:.71rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;color:var(--gray-500);
  border-bottom:2px solid var(--gray-200);white-space:nowrap;
}
.cot-items-table td{
  padding:10px 12px;
  border-bottom:1px solid var(--gray-100);
  vertical-align:middle;
}
.cot-items-table tbody tr:last-child td{border-bottom:none}
.cot-items-table tbody tr:hover td{background:var(--gray-50)}
.cot-item-row{transition:background .1s}
.cot-item-name{font-weight:600;color:var(--gray-800);font-size:.85rem}
.cot-item-cat{font-size:.72rem;color:var(--gray-400);margin-top:1px}
.cot-item-notes{font-size:.72rem;color:var(--brand-primary);font-style:italic;margin-top:2px}
.cot-item-action{
  background:none;border:1px solid var(--gray-200);
  border-radius:var(--r-sm);padding:2px 6px;cursor:pointer;
  font-size:.72rem;color:var(--gray-400);
  transition:color .15s,border-color .15s;
}
.cot-item-action:hover{color:var(--brand-primary);border-color:var(--brand-primary)}
.cot-cell-input{
  border:1px solid var(--gray-200);border-radius:var(--r-sm);
  padding:4px 6px;font-size:.82rem;color:var(--gray-800);
  width:70px;transition:border-color .15s;
}
.cot-cell-input:focus{
  outline:none;border-color:var(--brand-primary);
  box-shadow:0 0 0 2px rgba(200,105,26,.1);
}
.cot-cell-center{text-align:center}
.cot-cell-right{text-align:right}
.cot-remove-btn{
  background:none;border:none;cursor:pointer;
  color:var(--gray-300);font-size:.8rem;padding:4px;
  border-radius:var(--r-sm);
  transition:color .15s,background .15s;
}
.cot-remove-btn:hover{color:var(--danger);background:var(--danger-bg)}
.cot-add-row-btn{
  width:100%;margin-top:12px;
  background:none;border:2px dashed var(--gray-200);
  border-radius:var(--r-md);padding:10px;
  color:var(--gray-400);font-size:.83rem;cursor:pointer;
  transition:color .15s,border-color .15s,background .15s;
  display:flex;align-items:center;justify-content:center;gap:6px;
}
.cot-add-row-btn:hover{
  color:var(--brand-primary);
  border-color:var(--brand-primary);
  background:var(--brand-primary-xs);
}

/* ── Totals Panel ───────────────────────────────────── */
.cot-totals-panel{
  background:linear-gradient(145deg,var(--brand-secondary),var(--brand-secondary-dk));
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--sh-md);
}
.cot-totals-hd{
  padding:14px 18px 12px;
  color:rgba(255,255,255,.85);
  font-size:.82rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  display:flex;align-items:center;gap:8px;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.cot-totals-body{padding:14px 18px}
.cot-totals-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:5px 0;font-size:.88rem;color:rgba(255,255,255,.8);
}
.cot-totals-divider{
  border-top:1px solid rgba(255,255,255,.15);
  margin:8px 0;
}
.cot-totals-final{
  color:#fff!important;font-weight:800;font-size:1.15rem;
  padding-top:6px;
}
.cot-totals-note{
  padding:8px 18px 12px;
  font-size:.7rem;color:rgba(255,255,255,.5);
  text-align:center;
}

/* ── Side Cards ─────────────────────────────────────── */
.cot-side-card{
  background:#fff;border-radius:var(--r-lg);
  border:1px solid var(--gray-150);
  padding:16px 18px;
  box-shadow:var(--sh-xs);
}

/* ── Discount Bar ───────────────────────────────────── */
.cot-discount-wrap{padding:4px 0}
.cot-discount-bar{margin-top:10px}
.cot-discount-track{
  height:8px;background:var(--gray-100);border-radius:var(--r-full);
  position:relative;overflow:visible;
}
.cot-discount-fill{
  height:100%;border-radius:var(--r-full);
  transition:width .3s,background .3s;
  position:relative;z-index:1;
}
.cot-discount-fill.safe      {background:var(--success)}
.cot-discount-fill.near-limit{background:var(--warning)}
.cot-discount-fill.over-limit{background:var(--danger)}
.cot-discount-limit{
  position:absolute;top:-3px;width:2px;height:14px;
  background:var(--warning);border-radius:2px;
  z-index:2;transform:translateX(-50%);
}
.cot-discount-labels{
  display:flex;justify-content:space-between;
  font-size:.7rem;color:var(--gray-400);margin-top:4px;
}

/* ── Toggle (IVA) ───────────────────────────────────── */
.cot-toggle-label{
  display:flex;align-items:center;gap:12px;cursor:pointer;
  padding:6px 0;
}
.cot-toggle-wrap{position:relative;width:42px;height:24px;flex-shrink:0}
.cot-toggle-wrap input{opacity:0;width:0;height:0;position:absolute}
.cot-toggle-slider{
  position:absolute;inset:0;background:var(--gray-300);
  border-radius:var(--r-full);cursor:pointer;
  transition:background .2s;
}
.cot-toggle-slider::before{
  content:'';position:absolute;
  width:18px;height:18px;border-radius:50%;
  left:3px;top:3px;background:#fff;
  transition:transform .2s;
  box-shadow:0 1px 3px rgba(0,0,0,.2);
}
.cot-toggle-wrap input:checked + .cot-toggle-slider{background:var(--brand-primary)}
.cot-toggle-wrap input:checked + .cot-toggle-slider::before{transform:translateX(18px)}

/* ── Quick Actions ──────────────────────────────────── */
.cot-quick-actions{
  display:flex;flex-direction:column;gap:8px;
}
.cot-quick-actions .btn{
  font-size:.83rem;padding:9px 14px;
}

/* ── Catalog Modal ──────────────────────────────────── */
.cot-cat-modal{padding:0 2px}
.cot-cat-tabs{
  display:flex;gap:2px;
  border-bottom:2px solid var(--gray-200);
  margin-bottom:0;
}
.cot-cat-tab{
  background:none;border:none;cursor:pointer;
  padding:9px 16px;font-size:.85rem;font-weight:600;
  color:var(--gray-500);border-radius:var(--r-md) var(--r-md) 0 0;
  transition:color .15s,background .15s;
  position:relative;bottom:-2px;border-bottom:2px solid transparent;
}
.cot-cat-tab.active{
  color:var(--brand-primary);
  border-bottom-color:var(--brand-primary);
  background:var(--brand-primary-xs);
}
.cot-cat-content{padding-bottom:4px}
.cot-cat-group{margin-bottom:6px}
.cot-cat-group-hd{
  display:flex;align-items:center;gap:6px;
  font-size:.73rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  color:var(--brand-primary);background:var(--brand-primary-xs);
  padding:6px 12px;border-radius:var(--r-sm);
  margin-bottom:2px;
}
.cot-cat-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:9px 12px;border-radius:var(--r-md);cursor:pointer;
  transition:background .1s;gap:10px;
}
.cot-cat-item:hover{background:var(--gray-50)}
.cot-cat-item-body{flex:1;min-width:0}
.cot-cat-item-name{font-weight:600;font-size:.85rem;color:var(--gray-800)}
.cot-cat-item-desc{font-size:.74rem;color:var(--gray-400);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:260px}
.cot-cat-item-price{text-align:right;flex-shrink:0;font-weight:700;
  font-size:.84rem;color:var(--brand-primary)}

/* ── Detalle Layout ─────────────────────────────────── */
.cot-detalle-layout{
  display:grid;
  grid-template-columns:1fr 300px;
  gap:24px;
  align-items:start;
}
@media(max-width:1000px){
  .cot-detalle-layout{grid-template-columns:1fr}
}
.cot-detalle-main{display:flex;flex-direction:column;gap:20px}
.cot-detalle-side{
  position:sticky;top:calc(var(--topbar-h) + 16px);
  display:flex;flex-direction:column;gap:14px;
}

/* ── Info Grid (detalle) ────────────────────────────── */
.cot-info-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:12px;
}
.cot-info-chip{
  background:var(--gray-50);border:1px solid var(--gray-150);
  border-radius:var(--r-md);padding:10px 14px;
}
.cot-info-chip-label{
  font-size:.68rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--gray-400);
  display:flex;align-items:center;gap:4px;margin-bottom:3px;
}
.cot-info-chip-val{
  font-size:.88rem;font-weight:600;color:var(--gray-800);
  word-break:break-word;
}

/* ── Observations ───────────────────────────────────── */
.cot-obs-text{
  font-size:.88rem;color:var(--gray-700);line-height:1.6;
  white-space:pre-wrap;
}

/* ── State Menu Dropdown ────────────────────────────── */
.cot-state-menu{
  position:absolute;right:0;top:calc(100% + 6px);
  background:#fff;border:1px solid var(--gray-200);
  border-radius:var(--r-md);box-shadow:var(--sh-lg);
  min-width:180px;z-index:200;
  overflow:hidden;
}
.cot-state-menu-item{
  display:flex;align-items:center;gap:8px;
  width:100%;padding:10px 14px;
  background:none;border:none;cursor:pointer;
  font-size:.85rem;color:var(--gray-700);
  transition:background .1s;text-align:left;
}
.cot-state-menu-item:hover{background:var(--gray-50);color:var(--gray-900)}

/* ── Timeline ───────────────────────────────────────── */
.cot-timeline{list-style:none;padding:0;margin:0;position:relative}
.cot-timeline::before{
  content:'';position:absolute;left:7px;top:8px;bottom:8px;
  width:2px;background:var(--gray-200);border-radius:2px;
}
.cot-timeline-item{
  display:flex;gap:12px;padding:8px 0;position:relative;
}
.cot-timeline-dot{
  width:16px;height:16px;border-radius:50%;flex-shrink:0;
  border:2.5px solid #fff;box-shadow:0 0 0 1.5px var(--gray-200);
  margin-top:2px;position:relative;z-index:1;
}
.cot-timeline-body{flex:1}
.cot-timeline-title{font-weight:600;font-size:.85rem;color:var(--gray-800)}
.cot-timeline-meta{font-size:.73rem;color:var(--gray-400);margin-top:2px}
.cot-timeline-desc{font-size:.76rem;color:var(--gray-500);margin-top:4px;font-style:italic}

/* ── Btn Icon variants para cotizaciones ────────────── */
.btn-icon{
  width:30px;height:30px;border-radius:var(--r-sm);
  background:none;border:1px solid var(--gray-200);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:.8rem;color:var(--gray-500);cursor:pointer;
  transition:all .15s;
}
.btn-icon:hover{background:var(--gray-50);color:var(--gray-800);border-color:var(--gray-300)}
.btn-icon-pdf:hover{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}
.btn-icon-danger:hover{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}

/* ── Form grid helpers ──────────────────────────────── */
.form-grid-3{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:14px;margin-bottom:14px;
}
@media(max-width:768px){
  .form-grid-3{grid-template-columns:1fr}
}
.w-full{width:100%}
.req{color:var(--danger);font-weight:700;margin-left:2px}

/* ── Input states ───────────────────────────────────── */
.input-error{
  border-color:var(--danger)!important;
  box-shadow:0 0 0 3px rgba(185,28,28,.1)!important;
}
.input-valid{
  border-color:var(--success)!important;
}

/* ── PDF Preview Modal (IDs) ────────────────────────── */
#pdfPreviewContent{
  flex:1;overflow-y:auto;padding:32px;
  display:flex;flex-direction:column;align-items:center;
}

/* ── Contrato Beta badge ────────────────────────────── */
.beta-badge{
  font-size:.62rem;font-weight:800;text-transform:uppercase;
  background:var(--warning-bg);color:var(--warning);
  border:1px solid var(--warning-bdr);
  padding:1px 6px;border-radius:var(--r-full);margin-left:4px;
  letter-spacing:.05em;
}

/* ══════════════════════════════════════════════════════════
   APROBACIONES · Módulo de Gestión de Solicitudes
   ══════════════════════════════════════════════════════════ */

/* ── KPIs Row ──────────────────────────────────────── */
.aprob-kpi-row{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
  gap:14px;
  margin-bottom:20px;
}
.aprob-kpi-card{
  background:#fff;border-radius:var(--r-lg);
  border:1px solid var(--gray-150);
  padding:14px;
  display:flex;align-items:center;gap:12px;
  box-shadow:var(--sh-xs);
  transition:box-shadow .2s,border-color .2s,transform .15s;
}
.aprob-kpi-card:hover{
  box-shadow:var(--sh-sm);
  border-color:rgba(200,105,26,.2);
  transform:translateY(-2px);
}
.aprob-kpi-icon{
  width:40px;height:40px;border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;flex-shrink:0;
}
.aprob-kpi-num{
  font-size:1.5rem;font-weight:800;color:var(--gray-800);
  line-height:1;letter-spacing:-.02em;
}
.aprob-kpi-label{
  font-size:.72rem;color:var(--gray-400);font-weight:500;
  margin-top:2px;text-transform:uppercase;letter-spacing:.04em;
}

/* ── Filtros ─────────────────────────────────────────── */
.aprob-filters{
  display:flex;align-items:center;gap:10px;
  flex-wrap:wrap;margin-bottom:16px;
}
.aprob-search-wrap{
  position:relative;flex:1;min-width:240px;
}
.aprob-search-wrap .fas{
  position:absolute;left:12px;top:50%;transform:translateY(-50%);
  color:var(--gray-400);font-size:.85rem;pointer-events:none;
}
.aprob-search-input{
  width:100%;padding:8px 36px 8px 34px;
  border:1.5px solid var(--gray-200);border-radius:var(--r-md);
  font-size:.87rem;color:var(--gray-800);
  background:#fff;
  transition:border-color .15s,box-shadow .15s;
}
.aprob-search-input:focus{
  outline:none;
  border-color:var(--brand-primary);
  box-shadow:0 0 0 3px rgba(200,105,26,.1);
}

/* ── Card de Solicitud ──────────────────────────────── */
.aprob-card{
  background:#fff;border-radius:var(--r-lg);
  border:1px solid var(--gray-150);
  margin-bottom:16px;
  box-shadow:var(--sh-xs);
  transition:box-shadow .2s,border-color .2s;
  overflow:hidden;
}
.aprob-card:hover{
  box-shadow:var(--sh-md);
  border-color:rgba(200,105,26,.2);
}

/* ── Header ─────────────────────────────────────────── */
.aprob-card-header{
  padding:16px 20px;
  border-bottom:1px solid var(--gray-100);
  display:flex;align-items:flex-start;justify-content:space-between;
  gap:16px;flex-wrap:wrap;
  background:linear-gradient(to bottom,#fff,var(--gray-50));
}
.aprob-card-title-area{
  display:flex;align-items:flex-start;gap:14px;flex:1;min-width:0;
}
.aprob-card-icon{
  width:46px;height:46px;border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;flex-shrink:0;
}
.aprob-card-title{
  font-weight:700;font-size:.95rem;color:var(--gray-800);
  margin-bottom:4px;
}
.aprob-card-meta{
  display:flex;align-items:center;gap:12px;
  flex-wrap:wrap;font-size:.76rem;color:var(--gray-500);
}
.aprob-card-meta span{
  display:inline-flex;align-items:center;gap:4px;
}
.aprob-card-meta .fas{
  font-size:.7rem;color:var(--gray-400);
}
.aprob-card-badges{
  display:flex;align-items:center;gap:8px;flex-shrink:0;
}
.aprob-estado-badge{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 12px;border-radius:var(--r-full);
  font-size:.75rem;font-weight:700;
  white-space:nowrap;letter-spacing:.02em;
}
.aprob-prio-badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:2px 8px;border-radius:var(--r-full);
  font-size:.68rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;
}

/* ── Body ───────────────────────────────────────────── */
.aprob-card-body{
  padding:18px 20px;
}

/* ── Motivo ─────────────────────────────────────────── */
.aprob-motivo{
  margin-bottom:16px;
}
.aprob-motivo-label{
  font-size:.75rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;color:var(--gray-400);
  margin-bottom:6px;display:flex;align-items:center;gap:6px;
}
.aprob-motivo-text{
  font-size:.88rem;color:var(--gray-700);line-height:1.5;
  font-style:italic;background:var(--gray-50);
  padding:10px 14px;border-radius:var(--r-md);
  border-left:3px solid var(--brand-primary);
}

/* ── Comparación de valores ─────────────────────────── */
.aprob-comparison{
  display:grid;
  grid-template-columns:1fr auto 1fr auto 1fr;
  gap:14px;
  align-items:center;
  padding:14px;
  background:var(--gray-50);
  border-radius:var(--r-md);
  margin-bottom:16px;
  border:1px solid var(--gray-150);
}
@media(max-width:768px){
  .aprob-comparison{
    grid-template-columns:1fr;gap:10px;
  }
  .aprob-comp-arrow{display:none}
}
.aprob-comp-item{
  text-align:center;
}
.aprob-comp-label{
  font-size:.7rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.06em;color:var(--gray-400);
  margin-bottom:4px;
}
.aprob-comp-value{
  font-size:1.2rem;font-weight:800;color:var(--gray-800);
  letter-spacing:-.02em;
}
.aprob-comp-old .aprob-comp-value{
  color:var(--gray-500);text-decoration:line-through;
}
.aprob-comp-new .aprob-comp-value{
  color:var(--brand-primary);
}
.aprob-comp-diff .aprob-comp-value{
  font-size:1rem;
}
.aprob-comp-arrow{
  font-size:1.5rem;color:var(--gray-300);
}

/* ── Resolución (cuando ya fue resuelta) ───────────── */
.aprob-resolucion{
  padding:14px 16px;border-radius:var(--r-md);
  border:1px solid;
  margin-bottom:16px;
  font-size:.85rem;
}
.aprob-resol-notas{
  margin-top:8px;padding-top:8px;
  border-top:1px solid rgba(0,0,0,.08);
  color:var(--gray-600);font-size:.82rem;
  font-style:italic;
}

/* ── Historial de acciones ──────────────────────────── */
.aprob-historial{
  margin-top:16px;padding-top:16px;
  border-top:1px solid var(--gray-150);
}
.aprob-historial-title{
  font-size:.8rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;color:var(--gray-400);
  margin-bottom:12px;display:flex;align-items:center;gap:6px;
}
.aprob-historial-item{
  display:flex;align-items:flex-start;gap:12px;
  margin-bottom:10px;position:relative;
}
.aprob-historial-item::before{
  content:'';position:absolute;left:7px;top:20px;bottom:-10px;
  width:2px;background:var(--gray-200);
}
.aprob-historial-item:last-child::before{display:none}
.aprob-historial-dot{
  width:16px;height:16px;border-radius:50%;
  border:2.5px solid #fff;
  box-shadow:0 0 0 1.5px var(--gray-200);
  flex-shrink:0;margin-top:2px;z-index:1;position:relative;
}
.aprob-historial-content{flex:1}
.aprob-historial-desc{
  font-size:.85rem;font-weight:600;color:var(--gray-800);
}
.aprob-historial-meta{
  font-size:.73rem;color:var(--gray-400);margin-top:2px;
}
.aprob-historial-comment{
  font-size:.78rem;color:var(--gray-600);margin-top:6px;
  font-style:italic;background:var(--gray-50);
  padding:8px 12px;border-radius:var(--r-sm);
  border-left:2px solid var(--gray-300);
}

/* ── Footer con acciones ────────────────────────────── */
.aprob-card-footer{
  padding:14px 20px;
  border-top:1px solid var(--gray-100);
  background:var(--gray-50);
}
.aprob-actions{
  display:flex;align-items:center;justify-content:flex-end;
  gap:10px;flex-wrap:wrap;
}
.aprob-actions .btn{
  font-size:.85rem;
}
