/* ===== FACEs Portal ” Design System ===== */
:root {
  --navy: #0B1F3A; --corp-blue: #1A3A5C; --violet: #7C5CFC; --light-blue: #4DA8DA;
  --white: #FFFFFF; --off-white: #F4F6F9; --gray: #8899AA; --light-gray: #E2E8F0;
  --dark-text: #1E293B; --shadow: 0 4px 24px rgba(11,31,58,0.10);
  --shadow-lg: 0 8px 40px rgba(11,31,58,0.15); --radius: 14px; --transition: .25s ease;
  --sidebar-w: 260px; --header-h: 68px;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: 'Inter', system-ui, sans-serif; background: var(--off-white); color: var(--dark-text); min-height: 100vh; display: flex; flex-direction: column; }
a { text-decoration: none; color: inherit; }
button { cursor: pointer; font-family: inherit; border: none; background: none; }
input, textarea, select { font-family: inherit; font-size: .95rem; }
.hidden { display: none !important; }
#main-header { position: fixed; top: 0; left: 0; right: 0; height: var(--header-h); background: var(--navy); display: flex; align-items: center; justify-content: space-between; padding: 0 28px; z-index: 1000; box-shadow: 0 2px 20px rgba(0,0,0,.25); }
.header-left { display: flex; align-items: center; gap: 16px; }
.hamburger-btn { display: none; flex-direction: column; gap: 5px; padding: 6px; }
.hamburger-btn span { display: block; width: 22px; height: 2px; background: var(--white); border-radius: 2px; transition: var(--transition); }
.brand { display: flex; align-items: center; gap: 14px; }
.brand-logo { width: 42px; height: 42px; background: linear-gradient(135deg, var(--violet), var(--light-blue)); border-radius: 10px; display: flex; align-items: center; justify-content: center; }
.logo-icon { color: var(--white); font-size: 20px; font-weight: 700; }
.brand-logo img { width: 100%; height: 100%; object-fit: cover; border-radius: 10px; }
.brand-title { font-size: 1.5rem; font-weight: 800; color: var(--white); letter-spacing: 2px; }
.brand-subtitle { font-size: .7rem; color: var(--gray); line-height: 1.3; letter-spacing: .5px; }
.header-right { display: flex; align-items: center; gap: 16px; }
.btn-login { background: linear-gradient(135deg, var(--violet), var(--light-blue)); color: var(--white); padding: 9px 26px; border-radius: 8px; font-weight: 600; font-size: .88rem; transition: var(--transition); }
.btn-login:hover { transform: translateY(-1px); box-shadow: 0 4px 18px rgba(124,92,252,.4); }
.user-info { display: flex; align-items: center; gap: 10px; color: var(--white); font-size: .9rem; }
.user-avatar { width: 34px; height: 34px; border-radius: 50%; background: linear-gradient(135deg, var(--violet), var(--light-blue)); display: flex; align-items: center; justify-content: center; font-size: .8rem; color: white; overflow: hidden; }
.user-avatar img { width: 100%; height: 100%; object-fit: cover; }
.btn-ghost { color: var(--gray); font-size: .85rem; padding: 6px 14px; border-radius: 6px; transition: var(--transition); }
.btn-ghost:hover { color: var(--white); background: rgba(255,255,255,.1); }
.sidebar { position: fixed; top: var(--header-h); left: 0; bottom: 0; width: var(--sidebar-w); background: var(--white); border-right: 1px solid var(--light-gray); padding: 24px 0; display: flex; flex-direction: column; z-index: 900; transition: transform var(--transition); overflow-y: auto; }
.sidebar-close { display: none; position: absolute; top: 12px; right: 12px; font-size: 1.2rem; color: var(--gray); padding: 4px 8px; }
.nav-list { list-style: none; flex: 1; }
.nav-item { display: flex; align-items: center; gap: 12px; padding: 13px 28px; color: var(--corp-blue); font-size: .92rem; font-weight: 500; transition: var(--transition); border-left: 3px solid transparent; }
.nav-item:hover { background: var(--off-white); color: var(--violet); }
.nav-item.active { background: linear-gradient(90deg, rgba(124,92,252,.08), transparent); color: var(--violet); border-left-color: var(--violet); font-weight: 600; }
.nav-icon { font-size: 1.15rem; width: 24px; text-align: center; }
.sidebar-footer { padding: 20px 28px; border-top: 1px solid var(--light-gray); text-align: center; }
.sidebar-brand { font-weight: 800; font-size: 1.1rem; color: var(--navy); letter-spacing: 1.5px; }
.sidebar-footer small { color: var(--gray); font-size: .75rem; }
.sidebar-rights { margin-top: 6px; color: #8B6DFF; font-size: .62rem; font-weight: 400; line-height: 1.15; text-align: center; letter-spacing: 0; }
.sidebar-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.4); z-index: 899; backdrop-filter: blur(2px); }
.main-content { margin-top: var(--header-h); margin-left: var(--sidebar-w); padding: 36px 40px 40px; flex: 1; min-height: calc(100vh - var(--header-h) - 80px); transition: margin var(--transition); }
#main-footer { margin-left: var(--sidebar-w); padding: 24px; text-align: center; border-top: 1px solid var(--light-gray); background: var(--white); color: var(--gray); font-size: .85rem; transition: margin var(--transition); }
.footer-brand { font-weight: 700; color: var(--navy); letter-spacing: 1px; margin-top: 2px; }
.modal { position: fixed; inset: 0; z-index: 2000; display: flex; align-items: center; justify-content: center; }
.modal-overlay { position: absolute; inset: 0; background: rgba(11,31,58,.6); backdrop-filter: blur(6px); }
.modal-content { position: relative; background: var(--white); border-radius: var(--radius); padding: 40px; max-width: 420px; width: 90%; box-shadow: var(--shadow-lg); animation: modalIn .3s ease; }
@keyframes modalIn { from { opacity: 0; transform: translateY(20px) scale(.96); } to { opacity: 1; transform: none; } }
.modal-close { position: absolute; top: 14px; right: 18px; font-size: 1.2rem; color: var(--gray); transition: var(--transition); }
.modal-close:hover { color: var(--dark-text); }
.modal-logo { font-size: 2rem; text-align: center; width: 56px; height: 56px; margin: 0 auto 16px; background: linear-gradient(135deg, var(--violet), var(--light-blue)); border-radius: 14px; display: flex; align-items: center; justify-content: center; color: white; }
.modal-content h2 { text-align: center; font-size: 1.4rem; color: var(--navy); margin-bottom: 4px; }
.modal-subtitle { text-align: center; color: var(--gray); font-size: .88rem; margin-bottom: 28px; }
.form-group { margin-bottom: 18px; }
.form-group label { display: block; font-weight: 600; font-size: .85rem; color: var(--corp-blue); margin-bottom: 6px; }
.form-group input, .form-group textarea, .form-group select { width: 100%; padding: 11px 14px; border: 1.5px solid var(--light-gray); border-radius: 8px; font-size: .92rem; transition: var(--transition); background: var(--off-white); }
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { outline: none; border-color: var(--violet); box-shadow: 0 0 0 3px rgba(124,92,252,.12); background: var(--white); }
.form-group textarea { resize: vertical; min-height: 100px; }
.form-error { background: #FEF2F2; color: #DC2626; padding: 10px 14px; border-radius: 8px; font-size: .85rem; margin-bottom: 16px; }
.form-success { background: #F0FDF4; color: #16A34A; padding: 10px 14px; border-radius: 8px; font-size: .85rem; margin-bottom: 16px; }
.btn-primary { background: linear-gradient(135deg, var(--violet), var(--light-blue)); color: var(--white); padding: 12px 28px; border-radius: 8px; font-weight: 600; font-size: .95rem; transition: var(--transition); }
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 4px 18px rgba(124,92,252,.35); }
.btn-full { width: 100%; }
.btn-secondary { background: var(--off-white); color: var(--corp-blue); padding: 10px 22px; border-radius: 8px; font-weight: 600; font-size: .88rem; border: 1.5px solid var(--light-gray); transition: var(--transition); }
.btn-secondary:hover { border-color: var(--violet); color: var(--violet); }
.btn-danger { background: #FEF2F2; color: #DC2626; padding: 8px 18px; border-radius: 8px; font-weight: 600; font-size: .85rem; transition: var(--transition); }
.btn-danger:hover { background: #DC2626; color: white; }
.btn-sm { padding: 7px 16px; font-size: .84rem; }
.card { background: var(--white); border-radius: var(--radius); padding: 28px; box-shadow: var(--shadow); transition: var(--transition); }
.card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.section-header { margin-bottom: 36px; }
.section-header h2 { font-size: 1.8rem; font-weight: 700; color: var(--navy); margin-bottom: 6px; }
.section-header p { color: var(--gray); font-size: 1rem; }
.section-divider { width: 50px; height: 3px; background: linear-gradient(90deg, var(--violet), var(--light-blue)); border-radius: 3px; margin-top: 10px; }
.hero { text-align: center; padding: 60px 20px; }
.hero h2 { font-size: 2.8rem; font-weight: 800; color: var(--navy); margin-bottom: 16px; line-height: 1.2; }
.hero h2 .accent { background: linear-gradient(135deg, var(--violet), var(--light-blue)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.hero p { font-size: 1.15rem; color: var(--gray); max-width: 600px; margin: 0 auto 36px; line-height: 1.7; }
.hero-cards { display: grid; grid-template-columns: repeat(4, minmax(220px, 1fr)); gap: 20px; max-width: 1220px; margin: 0 auto; }
.hero-card { background: var(--white); border-radius: var(--radius); padding: 30px 20px; box-shadow: var(--shadow); transition: var(--transition); text-align: center; border-top: 3px solid transparent; }
.hero-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-top-color: var(--violet); }
.hero-card .hc-icon { font-size: 2.4rem; margin-bottom: 12px; }
.hero-3d-icon { width: 100px; height: 100px; object-fit: contain; filter: drop-shadow(0 10px 20px rgba(124,92,252,0.2)); transition: transform var(--transition); }
.hero-card:hover .hero-3d-icon { transform: scale(1.1) translateY(-5px); filter: drop-shadow(0 15px 25px rgba(124,92,252,0.3)); }
.hero-card h4 { color: var(--navy); margin-bottom: 6px; font-size: 1rem; }
.hero-card p { color: var(--gray); font-size: .85rem; }
.nosotros-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: start; }
.nosotros-text { text-align: justify; color: var(--dark-text); line-height: 1.8; font-size: .95rem; }
.partner-card { background: var(--white); border-radius: var(--radius); padding: 28px; box-shadow: var(--shadow); text-align: center; margin-bottom: 20px; transition: var(--transition); }
.partner-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.partner-photo { width: 100px; height: 100px; border-radius: 50%; margin: 0 auto 16px; background: linear-gradient(135deg, var(--violet), var(--light-blue)); display: flex; align-items: center; justify-content: center; font-size: 2rem; color: white; overflow: hidden; }
.partner-photo img { width: 100%; height: 100%; object-fit: cover; }
.partner-card h4 { color: var(--navy); margin-bottom: 8px; font-size: 1.05rem; }
.partner-card p { color: var(--gray); font-size: .88rem; line-height: 1.6; text-align: justify; }
.soluciones-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 24px; }
.solucion-card { background: var(--white); border-radius: var(--radius); padding: 32px 26px; box-shadow: var(--shadow); transition: var(--transition); border-top: 3px solid transparent; }
.solucion-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-top-color: var(--violet); }
.solucion-card .sc-icon { font-size: 2.2rem; margin-bottom: 14px; }
.solucion-card h3 { color: var(--navy); margin-bottom: 10px; font-size: 1.1rem; }
.solucion-card p { color: var(--gray); font-size: .88rem; line-height: 1.65;  text-align: justify;}
.recursos-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 24px; }
.recurso-card { background: var(--white); border-radius: var(--radius); padding: 28px; box-shadow: var(--shadow); transition: var(--transition); cursor: pointer; border-top: 3px solid transparent; }
.recurso-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); border-top-color: var(--violet); }
.recurso-card .rc-icon { font-size: 2rem; margin-bottom: 12px; }
.recurso-card h3 { color: var(--navy); margin-bottom: 8px; font-size: 1.05rem; }
.recurso-card p { color: var(--gray); font-size: .86rem; line-height: 1.6;  text-align: justify;}
.contacto-layout { display: grid; grid-template-columns: 1.2fr .8fr; gap: 40px; }
.contact-info-card { background: var(--navy); border-radius: var(--radius); padding: 36px; color: var(--white); }
.contact-info-card h3 { font-size: 1.3rem; margin-bottom: 24px; }
.contact-info-item { display: flex; align-items: flex-start; gap: 14px; margin-bottom: 22px; }
.contact-info-item .ci-icon { font-size: 1.3rem; min-width: 24px; text-align: center; }
.contact-info-item .ci-label { font-size: .8rem; color: var(--gray); margin-bottom: 2px; }
.contact-info-item .ci-value { font-size: .92rem; }
.contact-form-card { background: var(--white); border-radius: var(--radius); padding: 36px; box-shadow: var(--shadow); }
.tools-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 24px; }
.tool-card { background: var(--white); border-radius: var(--radius); padding: 32px; box-shadow: var(--shadow); transition: var(--transition); position: relative; overflow: hidden; cursor: pointer; border-top: 3px solid transparent; }
.tool-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); border-top-color: var(--violet); }
.tool-card.locked { opacity: .85; }
.tool-card .tc-icon { font-size: 2.6rem; margin-bottom: 14px; }
.tool-card h3 { color: var(--navy); margin-bottom: 8px; font-size: 1.15rem; }
.tool-card p { color: var(--gray); font-size: .88rem; line-height: 1.6; margin-bottom: 16px;  text-align: justify;}
.tool-badge { display: inline-block; padding: 5px 14px; border-radius: 20px; font-size: .78rem; font-weight: 600; }
.badge-access { background: rgba(124,92,252,.1); color: var(--violet); }
.badge-locked { background: rgba(220,38,38,.08); color: #DC2626; }
.tool-construction { text-align: center; padding: 60px 20px; }
.tool-construction h2 { color: var(--navy); margin-bottom: 10px; }
.tool-construction p { color: var(--gray); }
.admin-tabs { display: flex; gap: 4px; margin-bottom: 28px; background: var(--off-white); padding: 5px; border-radius: 10px; flex-wrap: wrap; }
.admin-tab { padding: 10px 22px; border-radius: 8px; font-weight: 600; font-size: .88rem; color: var(--gray); transition: var(--transition); }
.admin-tab.active { background: var(--white); color: var(--violet); box-shadow: var(--shadow); }
.admin-tab:hover { color: var(--violet); }
.admin-panel { background: var(--white); border-radius: var(--radius); padding: 32px; box-shadow: var(--shadow); }
.admin-table { width: 100%; border-collapse: collapse; }
.admin-table th { text-align: left; padding: 12px 16px; font-size: .84rem; color: var(--gray); text-transform: uppercase; letter-spacing: .5px; border-bottom: 2px solid var(--light-gray); }
.admin-table td { padding: 14px 16px; border-bottom: 1px solid var(--light-gray); font-size: .9rem; vertical-align: middle; }
.admin-table tr:hover td { background: var(--off-white); }
.admin-actions { display: flex; gap: 8px; }
.admin-form { max-width: 500px; }
.admin-form .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.checkbox-group { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 10px; margin-top: 8px; }
.checkbox-group label { min-height: 54px; display: grid; grid-template-columns: 24px minmax(0, 1fr); align-items: center; gap: 10px; font-size: .88rem; line-height: 1.25; padding: 10px 12px; background: var(--off-white); border-radius: 7px; cursor: pointer; transition: var(--transition); }
.checkbox-group label:hover { background: rgba(124,92,252,.08); }
.checkbox-group input[type="checkbox"] { width: 16px; height: 16px; margin: 0; justify-self: center; accent-color: var(--violet); }
.admin-form-actions { display: flex; gap: 8px; margin-top: 16px; align-items: center; }
.admin-form-actions .btn-primary, .admin-form-actions .btn-secondary { min-width: 96px; padding: 8px 18px; border-radius: 8px; font-size: .84rem; font-weight: 600; box-shadow: none; }
.profile-photo-upload { width: 100px; height: 100px; border-radius: 50%; background: var(--off-white); border: 2px dashed var(--light-gray); display: flex; align-items: center; justify-content: center; cursor: pointer; margin-bottom: 16px; overflow: hidden; transition: var(--transition); }
.profile-photo-upload:hover { border-color: var(--violet); }
.profile-photo-upload img { width: 100%; height: 100%; object-fit: cover; }
.chatbot { position: fixed; bottom: 24px; right: 24px; z-index: 1500; }
.chatbot-toggle { width: 58px; height: 58px; border-radius: 50%; background: linear-gradient(135deg, var(--violet), var(--light-blue)); color: white; font-size: 1.5rem; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 20px rgba(124,92,252,.4); transition: var(--transition); position: relative; }
.chatbot-toggle:hover { transform: scale(1.08); }
.chatbot-badge { position: absolute; top: -2px; right: -2px; width: 20px; height: 20px; background: #DC2626; border-radius: 50%; font-size: .7rem; display: flex; align-items: center; justify-content: center; font-weight: 700; }
.chatbot-window { position: absolute; bottom: 70px; right: 0; width: 360px; max-height: 480px; background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow-lg); display: flex; flex-direction: column; overflow: hidden; animation: modalIn .3s ease; }
.chatbot-header { background: var(--navy); color: white; padding: 16px 20px; display: flex; justify-content: space-between; align-items: center; }
.chatbot-header-info { display: flex; align-items: center; gap: 10px; font-weight: 600; font-size: .92rem; }
.chatbot-status-dot { width: 8px; height: 8px; background: #22C55E; border-radius: 50%; }
.chatbot-close-btn { color: var(--gray); font-size: 1.1rem; transition: var(--transition); }
.chatbot-close-btn:hover { color: white; }
.chatbot-messages { flex: 1; overflow-y: auto; padding: 20px; display: flex; flex-direction: column; gap: 14px; max-height: 320px; }
.chat-message { display: flex; gap: 10px; align-items: flex-start; }
.chat-message.user { flex-direction: row-reverse; }
.chat-avatar { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, var(--violet), var(--light-blue)); display: flex; align-items: center; justify-content: center; font-size: .7rem; color: white; flex-shrink: 0; }
.chat-message.user .chat-avatar { background: var(--navy); }
.chat-bubble { background: var(--off-white); padding: 10px 16px; border-radius: 12px 12px 12px 4px; font-size: .88rem; line-height: 1.5; color: var(--dark-text); max-width: 240px; }
.chat-message.user .chat-bubble { background: var(--violet); color: white; border-radius: 12px 12px 4px 12px; }
.chatbot-input { display: flex; border-top: 1px solid var(--light-gray); padding: 12px 16px; gap: 10px; }
.chatbot-input input { flex: 1; border: 1.5px solid var(--light-gray); border-radius: 8px; padding: 9px 14px; font-size: .88rem; }
.chatbot-input input:focus { outline: none; border-color: var(--violet); }
.chatbot-send { color: var(--violet); font-size: 1.2rem; padding: 4px 8px; transition: var(--transition); }
.chatbot-send:hover { transform: scale(1.15); }
@media (max-width: 1024px) {
  .nosotros-layout, .contacto-layout { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .sidebar { transform: translateX(-100%); }
  .sidebar.open { transform: translateX(0); box-shadow: var(--shadow-lg); }
  .sidebar-close { display: block; }
  .sidebar-overlay.active { display: block; }
  .hamburger-btn { display: flex; }
  .main-content { margin-left: 0; padding: 24px 18px; }
  #main-footer { margin-left: 0; }
  .hero h2 { font-size: 1.8rem; }
  .soluciones-grid, .recursos-grid, .tools-grid { grid-template-columns: 1fr; }
  .hero-cards { grid-template-columns: 1fr 1fr; }
  .chatbot-window { width: calc(100vw - 32px); right: -8px; }
  .admin-table { font-size: .84rem; }
  .admin-table th, .admin-table td { padding: 10px 8px; }
  .admin-tabs { gap: 2px; }
  .admin-tab { padding: 8px 14px; font-size: .84rem; }
  .brand-title { font-size: 1.2rem; }
  .brand-subtitle { font-size: .62rem; }
}
@media (max-width: 480px) {
  .hero-cards { grid-template-columns: 1fr; }
  .admin-form .form-row { grid-template-columns: 1fr; }
  .header-right { gap: 8px; }
  .btn-login { padding: 8px 16px; font-size: .84rem; }
  #main-header { padding: 0 14px; }
}


/* Corporate icon system */
.faces-icon { --icon-bg: linear-gradient(145deg, rgba(255,255,255,.96), #F2F7FC); --icon-fg: var(--corp-blue); --icon-fill: rgba(77,168,218,.13); --icon-ring: rgba(26,58,92,.10); display: inline-flex; align-items: center; justify-content: center; border-radius: 14px; background: var(--icon-bg); color: var(--icon-fg); box-shadow: inset 0 0 0 1px var(--icon-ring), 0 8px 18px rgba(11,31,58,.055); flex-shrink: 0; transition: transform var(--transition), box-shadow var(--transition), color var(--transition), background var(--transition); }
.faces-icon svg { width: 61%; height: 61%; overflow: visible; }
.faces-icon-fill { fill: var(--icon-fill); stroke: none; }
.faces-icon-xs { width: 20px; height: 20px; border-radius: 50%; box-shadow: none; background: transparent; color: currentColor; }
.faces-icon-sm { width: 36px; height: 36px; border-radius: 11px; }
.faces-icon-md { width: 50px; height: 50px; }
.faces-icon-lg { width: 62px; height: 62px; border-radius: 17px; }
.faces-icon-xl { width: 82px; height: 82px; border-radius: 22px; }
.faces-icon-nav { width: 27px; height: 27px; border-radius: 10px; box-shadow: inset 0 0 0 1px rgba(26,58,92,.08); background: linear-gradient(145deg, #FFFFFF, #F4F8FC); }
.faces-icon-tab { width: 23px; height: 23px; border-radius: 8px; margin-right: 8px; box-shadow: none; background: rgba(26,58,92,.06); }
.faces-icon-brand { width: 30px; height: 30px; border-radius: 9px; background: transparent; color: white; box-shadow: none; --icon-fill: rgba(255,255,255,.18); }
.faces-icon-blue { --icon-bg: linear-gradient(145deg, #F9FCFF, #EAF4FF); --icon-fg: #155E8C; --icon-fill: rgba(77,168,218,.16); --icon-ring: rgba(77,168,218,.18); }
.faces-icon-green { --icon-bg: linear-gradient(145deg, #FAFFFC, #EAFBF3); --icon-fg: #08765A; --icon-fill: rgba(16,185,129,.14); --icon-ring: rgba(16,185,129,.16); }
.faces-icon-violet { --icon-bg: linear-gradient(145deg, #FCFBFF, #F0ECFF); --icon-fg: #6650D8; --icon-fill: rgba(124,92,252,.14); --icon-ring: rgba(124,92,252,.16); }
.faces-icon-amber { --icon-bg: linear-gradient(145deg, #FFFDF8, #FFF4DB); --icon-fg: #A86B14; --icon-fill: rgba(245,158,11,.16); --icon-ring: rgba(245,158,11,.16); }
.faces-icon-cyan { --icon-bg: linear-gradient(145deg, #F8FEFF, #E8F8FB); --icon-fg: #0E7490; --icon-fill: rgba(6,182,212,.14); --icon-ring: rgba(6,182,212,.16); }
.faces-icon-rose { --icon-bg: linear-gradient(145deg, #FFF9FB, #FFEAF1); --icon-fg: #BE426D; --icon-fill: rgba(244,114,182,.15); --icon-ring: rgba(244,114,182,.16); }
.faces-icon-soft { --icon-bg: linear-gradient(145deg, #FFFFFF, #F5F8FB); --icon-fg: var(--corp-blue); --icon-fill: rgba(26,58,92,.08); --icon-ring: rgba(11,31,58,.08); }
.faces-icon-dark { --icon-bg: rgba(255,255,255,.08); --icon-fg: #FFFFFF; --icon-fill: rgba(255,255,255,.16); --icon-ring: rgba(255,255,255,.14); box-shadow: inset 0 0 0 1px var(--icon-ring); }
.faces-icon-plain { background: transparent; box-shadow: none; color: currentColor; --icon-fill: rgba(255,255,255,.14); }
.nav-icon { display: inline-flex; align-items: center; justify-content: center; width: 30px; }
.nav-item:hover .faces-icon-nav, .nav-item.active .faces-icon-nav { background: linear-gradient(145deg, rgba(255,255,255,.95), rgba(236,242,255,.95)); color: var(--violet); box-shadow: inset 0 0 0 1px rgba(124,92,252,.16), 0 8px 18px rgba(124,92,252,.10); }
.hero-card .hc-icon, .solucion-card .sc-icon, .recurso-card .rc-icon, .tool-card .tc-icon { display: flex; justify-content: center; margin-bottom: 16px; }
.solucion-card .sc-icon, .recurso-card .rc-icon, .tool-card .tc-icon { justify-content: flex-start; }
.hero-card:hover .faces-icon, .solucion-card:hover .faces-icon, .recurso-card:hover .faces-icon, .tool-card:hover .faces-icon { transform: translateY(-3px); box-shadow: inset 0 0 0 1px var(--icon-ring), 0 14px 26px rgba(11,31,58,.10); }
.admin-tab { display: inline-flex; align-items: center; gap: 0; }
.contact-info-item .ci-icon { min-width: 36px; }
.chatbot-icon { display: inline-flex; align-items: center; justify-content: center; }
.chatbot-toggle .faces-icon { color: white; background: transparent; box-shadow: none; --icon-fill: rgba(255,255,255,.18); }
.chatbot-send { display: inline-flex; align-items: center; justify-content: center; }
.construction-icon { display: flex; justify-content: center; margin-bottom: 20px; }








/* BancoX */
.bancox { max-width: 1500px; margin: 0 auto; padding: 0 10px 30px; }
.bancox-top { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin-bottom: 22px; }
.bancox-top h2 { color: var(--navy); font-size: 1.55rem; margin: 0; }
.bancox-top p { color: var(--gray); margin: 4px 0 0; }
.bancox-top select, .bancox input, .bancox select, .bancox textarea { border: 1px solid var(--light-gray); border-radius: 8px; padding: 10px 12px; background: var(--white); color: var(--dark-text); width: 100%; }
.bancox-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 18px; border-bottom: 1px solid var(--light-gray); }
.bancox-tabs button { padding: 11px 16px; color: var(--corp-blue); border-bottom: 2px solid transparent; font-weight: 700; }
.bancox-tabs button.active { color: var(--violet); border-bottom-color: var(--violet); }
.bancox-grid.kpis { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 14px; margin-bottom: 18px; }
.bancox-kpi, .bancox-panel { background: var(--white); border: 1px solid var(--light-gray); border-radius: 8px; box-shadow: var(--shadow); }
.bancox-kpi { padding: 18px; border-left: 4px solid var(--light-blue); }
.bancox-kpi.ok { border-left-color: #16A34A; }
.bancox-kpi.warn { border-left-color: #D97706; }
.bancox-kpi.bad { border-left-color: #DC2626; }
.bancox-kpi span { display: block; color: var(--gray); font-size: .84rem; margin-bottom: 8px; }
.bancox-kpi strong { color: var(--navy); font-size: 1.45rem; }
.bancox-panel { padding: 20px; margin-bottom: 16px; }
.bancox-panel h3 { color: var(--navy); font-size: 1rem; margin-bottom: 12px; }
.bancox-stepper { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; align-items: stretch; }
.bancox-upload-card { min-width: 0; margin-bottom: 0; }
.bancox-upload-card input[type="file"] { width: 100%; max-width: 100%; margin: 8px 0; }
.bancox-card-note { color: var(--gray); font-size: .8rem; line-height: 1.45; min-height: 38px; margin-bottom: 4px; }
.bancox-ai-card { display: flex; flex-direction: column; justify-content: flex-start; gap: 10px; text-align: center; }
.bancox-ai-head { display: grid; grid-template-columns: auto minmax(0, 1fr); gap: 12px; align-items: center; justify-content: center; }
.bancox-ai-head h3 { margin-bottom: 0; white-space: nowrap; }
.bancox-ai-toggle { display: inline-flex !important; grid-template-columns: none; align-items: center; justify-content: center; gap: 8px !important; min-width: 0; color: var(--corp-blue); line-height: 1.35; text-align: left; }
.bancox-ai-toggle input { width: auto; margin: 0; accent-color: var(--violet); }
.bancox-run-row { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 7px; margin-top: 2px; }
.bancox-run-row .btn-primary { width: 168px; padding: 11px 18px; transition: none; transform: none; }
.bancox-run-row .btn-primary:hover { transform: none; box-shadow: none; }
.bancox-ai-status { display: flex; align-items: center; justify-content: center; width: 100%; padding: 0; margin: 0; min-height: 18px; color: var(--gray); font-weight: 800; text-align: center; }
.bancox-ai-status.ok, .bancox-ai-status.ok span { color: #16A34A; font-weight: 900; }
.bancox-upload-results { margin-top: 18px; }
.bancox-results-placeholder { min-height: 300px; }
.bancox-settings { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 12px; align-items: end; }
.bancox label { display: grid; gap: 6px; color: var(--corp-blue); font-size: .84rem; font-weight: 700; }
.bancox-label-text { display: inline-flex; align-items: center; gap: 6px; min-height: 18px; }
.bancox-help { position: relative; display: inline-flex; align-items: center; justify-content: center; width: 16px; height: 16px; border-radius: 50%; background: rgba(77,168,218,.12); color: var(--corp-blue); border: 1px solid rgba(77,168,218,.25); font-size: .68rem; font-weight: 800; cursor: help; outline: none; }
.bancox-tooltip { position: absolute; left: 50%; bottom: calc(100% + 10px); transform: translateX(-50%) translateY(4px); width: min(280px, 72vw); padding: 10px 12px; border-radius: 8px; background: var(--navy); color: var(--white); font-size: .76rem; line-height: 1.45; font-weight: 500; box-shadow: var(--shadow-lg); opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .18s ease, transform .18s ease, visibility .18s ease; z-index: 20; }
.bancox-tooltip::after { content: ""; position: absolute; left: 50%; top: 100%; transform: translateX(-50%); border: 6px solid transparent; border-top-color: var(--navy); }
.bancox-help:hover .bancox-tooltip, .bancox-help:focus .bancox-tooltip { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.bancox textarea { min-height: 86px; resize: vertical; }
.bancox-table-wrap { overflow: auto; max-height: 420px; border: 1px solid var(--light-gray); border-radius: 8px; }
.bancox-preview { max-height: 260px; margin-top: 12px; }
.bancox-table th { position: sticky; top: 0; background: var(--white); z-index: 1; }
.bancox-table td { min-width: 110px; }
.bancox-table tr.ok td { background: rgba(22, 163, 74, .06); }
.bancox-table tr.warn td { background: rgba(217, 119, 6, .08); }
.bancox-results { display: grid; grid-template-columns: 1fr 1.15fr 1fr; gap: 14px; align-items: start; }
.bancox-chip { display: inline-flex; align-items: center; padding: 5px 10px; border-radius: 999px; background: rgba(124,92,252,.1); color: var(--violet); font-weight: 700; font-size: .78rem; }
.bancox-alert { margin-bottom: 14px; border-radius: 8px; padding: 12px 14px; background: rgba(217,119,6,.09); color: #92400E; border: 1px solid rgba(217,119,6,.18); }
.bancox-alert.ok { background: rgba(22,163,74,.09); color: #166534; border-color: rgba(22,163,74,.18); }
.bancox-note, .bancox-empty { color: var(--gray); padding: 14px 0; }
.bancox-actions { display: flex; justify-content: flex-end; gap: 10px; margin-bottom: 12px; }
@media (max-width: 1200px) { .bancox-stepper { grid-template-columns: 1fr; } .bancox-ai-head { grid-template-columns: 1fr; } }
@media (max-width: 1000px) { .bancox-results { grid-template-columns: 1fr; } .bancox-top { align-items: stretch; flex-direction: column; } }
@media (max-width: 560px) { .bancox-run-row .btn-primary { width: 100%; } }

/* FACEs Analytics: Analyzer and Estados Financieros */
.analytics-app { display: flex; flex-direction: column; gap: 12px; }
.analytics-app .bancox-top { display: grid; grid-template-columns: minmax(0, 1fr) minmax(280px, 360px); align-items: start; gap: 20px; margin-bottom: 0; }
.analytics-logo-wrap { min-height: 84px; display: flex; align-items: flex-start; }
.analytics-logo-wrap img { width: 220px; max-width: 34vw; height: auto; display: block; object-fit: contain; }
.analytics-side { display: grid; gap: 8px; }
.analytics-app #analytics-tenant label { display: block; color: var(--navy); font-size: .84rem; margin-bottom: 5px; }
.analytics-app #analytics-tenant select { min-height: 36px; padding: 8px 12px; }
.analytics-app .bancox-alert { margin: 0; padding: 8px 11px; }
.analytics-app .bancox-navrow { align-items: center; margin-top: 0; margin-bottom: 10px; }
.analytics-upload-mini { display: grid; grid-template-columns: auto minmax(0, 1fr) 34px; align-items: center; gap: 7px; }
.analytics-upload-mini > span { color: var(--navy); font-size: .78rem; font-weight: 700; white-space: nowrap; }
.analytics-file-mini { min-width: 0; height: 32px; display: flex; align-items: center; border: 1px solid var(--light-gray); border-radius: 999px; padding: 0 10px; background: rgba(255,255,255,.72); cursor: pointer; }
.analytics-file-mini em { color: var(--gray); font-size: .78rem; font-style: normal; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.analytics-power-btn { width: 34px; height: 34px; display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; color: var(--white); background: linear-gradient(135deg, var(--violet), var(--light-blue)); box-shadow: 0 8px 16px rgba(80, 70, 229, .18); font-size: 1rem; line-height: 1; }
.analytics-power-btn:disabled { opacity: .78; cursor: progress; }
.analytics-dots { display: inline-flex; align-items: center; gap: 3px; height: 12px; }
.analytics-dots i { width: 4px; height: 4px; border-radius: 50%; background: currentColor; animation: analyticsDot 900ms infinite ease-in-out; }
.analytics-dots i:nth-child(2) { animation-delay: 140ms; }
.analytics-dots i:nth-child(3) { animation-delay: 280ms; }
@keyframes analyticsDot { 0%, 80%, 100% { opacity: .35; transform: translateY(0); } 40% { opacity: 1; transform: translateY(-2px); } }
.analytics-kpis { grid-template-columns: repeat(5, minmax(145px, 1fr)); }
.analytics-dashboard-grid { display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr); gap: 16px; align-items: stretch; }
.analytics-dashboard-grid > .bancox-panel { min-width: 0; height: 100%; display: flex; flex-direction: column; }
.analytics-dashboard-grid > .bancox-panel > .bancox-table-wrap,
.analytics-dashboard-grid > .bancox-panel > .analytics-list { flex: 1 1 auto; min-height: 0; }
.analytics-dashboard-grid > .bancox-panel > .bancox-table-wrap { max-height: 430px; }
.analytics-table th { text-align: center !important; }
.analytics-table td.num, .analytics-table .num { text-align: right; font-variant-numeric: tabular-nums; white-space: nowrap; }
.analytics-table td strong { font-weight: 800; color: var(--navy); }
.analytics-table td.num strong { display: inline-block; text-align: right; }
.analytics-resizable th { min-width: 96px; overflow: visible; resize: horizontal; }
.analytics-amount { color: var(--navy); font-variant-numeric: tabular-nums; }
.analytics-amount.negative { color: #DC2626; }
.analytics-amount.zero { color: var(--gray); }
.analytics-list { display: grid; gap: 10px; }
.analytics-list.tall { max-height: 560px; overflow: auto; padding-right: 4px; }
.analytics-list > div { display: grid; grid-template-columns: minmax(0, 1fr) minmax(112px, auto); align-items: center; gap: 14px; border: 1px solid var(--light-gray); border-radius: 8px; padding: 11px 12px; }
.analytics-list span { color: var(--corp-blue); font-size: .84rem; font-weight: 700; overflow-wrap: anywhere; min-width: 0; }
.analytics-list strong { text-align: right; white-space: nowrap; }
.analytics-slicer-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: 12px; }
.analytics-slicer-grid label { display: grid; gap: 7px; color: var(--corp-blue); font-size: .76rem; font-weight: 400; }
.analytics-slicer-grid select { width: 100%; min-height: 40px; border: 1px solid var(--light-gray); border-radius: 8px; background: var(--white); color: var(--dark-text); font-size: .84rem; padding: 0 10px; font-weight: 400; }
.analytics-dynamic-panel h3, .analytics-dynamic-panel .bancox-chip { font-weight: 400; }
.analytics-subtitle { color: var(--corp-blue); margin: 16px 0 8px; font-size: .9rem; }
.tc-logo-icon { width: 48px; height: 48px; object-fit: contain; display: block; border-radius: 10px; mix-blend-mode: multiply; }
.analytics-filter-th { position: sticky; top: 0; overflow: visible !important; z-index: 5; }
.analytics-filter-btn { width: 100%; display: inline-flex; align-items: center; justify-content: center; gap: 6px; color: var(--gray); font-size: .78rem; font-weight: 800; text-transform: uppercase; }
.analytics-filter-btn span { min-width: 0; overflow: hidden; text-overflow: ellipsis; }
.analytics-filter-btn svg { width: 13px; height: 13px; fill: var(--violet); flex: 0 0 auto; opacity: .82; }
.analytics-filter-pop { position: absolute; top: calc(100% + 6px); left: 8px; min-width: 190px; padding: 10px; border: 1px solid rgba(124,92,252,.18); border-radius: 8px; background: var(--white); box-shadow: var(--shadow-lg); display: none; z-index: 40; }
.analytics-filter-pop.open { display: grid; gap: 8px; }
.analytics-filter-pop input { height: 34px; padding: 8px 10px; border: 1px solid var(--light-gray); border-radius: 8px; color: var(--dark-text); background: var(--white); }
.analytics-filter-pop button { justify-self: end; color: var(--violet); font-weight: 700; font-size: .78rem; }
.analytics-detail-head { gap: 14px; }
.analytics-search { margin-left: auto; min-width: 260px; }
.analytics-search input { width: 100%; min-height: 34px; border: 1px solid var(--light-gray); border-radius: 999px; padding: 0 13px; color: var(--dark-text); background: var(--white); }
@media (max-width: 1180px) { .analytics-kpis { grid-template-columns: repeat(3, minmax(160px, 1fr)); } .analytics-dashboard-grid { grid-template-columns: 1fr; } }
@media (max-width: 1000px) { .analytics-app .bancox-top { grid-template-columns: 1fr; } }
@media (max-width: 640px) { .analytics-kpis { grid-template-columns: 1fr; } .analytics-upload-mini { grid-template-columns: 1fr 34px; } .analytics-upload-mini > span { grid-column: 1 / -1; } .analytics-search { min-width: 0; width: 100%; } }


/* BancoX visual refinements */
.bancox-top { align-items: flex-start; margin-bottom: 12px; }
.bancox-brand { display: flex; align-items: center; min-height: 78px; }
.bancox-brand img { width: 168px; max-width: 36vw; height: auto; object-fit: contain; display: block; }
.bancox-navrow { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; margin-bottom: 18px; border-bottom: 1px solid var(--light-gray); }
.bancox-navrow .bancox-tabs { margin-bottom: 0; border-bottom: 0; }
.bancox-back { margin-bottom: 7px; }
.bancox-workflow .btn-primary { margin-top: 18px; }
.bancox-hidden-file { position: absolute; width: 1px !important; height: 1px; opacity: 0; pointer-events: none; }
.bancox-file-control { display: flex !important; grid-template-columns: none !important; flex-direction: row; align-items: center; gap: 8px !important; width: 100%; border: 1px solid var(--light-gray); border-radius: 8px; padding: 9px 12px; background: var(--white); cursor: pointer; font-weight: 500 !important; color: var(--dark-text) !important; margin: 8px 0; }
.bancox-file-control span { border: 1px solid #9CA3AF; border-radius: 4px; padding: 3px 8px; color: #111827; background: #F8FAFC; white-space: nowrap; }
.bancox-file-control em { color: var(--gray); font-style: normal; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bancox-table tbody tr { cursor: default; }
.bancox-results .bancox-table tbody tr { cursor: pointer; }
.bancox-table tr.selected td { box-shadow: inset 0 0 0 9999px rgba(124,92,252,.08); }
.bancox-match-detail { margin-top: 16px; }
.bancox-detail-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.bancox-detail-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.bancox-detail-grid h4 { color: var(--corp-blue); font-size: .92rem; margin-bottom: 10px; }
.bancox-detail-grid p { color: var(--dark-text); font-size: .86rem; line-height: 1.55; margin-bottom: 6px; }
.bancox-detail-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 14px; }
@media (max-width: 900px) { .bancox-detail-grid { grid-template-columns: 1fr; } .bancox-navrow { align-items: stretch; flex-direction: column-reverse; } .bancox-back { align-self: flex-start; } }


/* BancoX selected match refinements */
.bancox-file-control { min-height: 42px; padding: 8px 10px; }
.bancox-file-control span { min-width: 108px; text-align: center; display: inline-flex; align-items: center; justify-content: center; min-height: 26px; }
.bancox-table tr.selected td,
.bancox-table tr.selected-linked td {
  background: #F1EDFF !important;
  box-shadow: inset 3px 0 0 rgba(124,92,252,.55);
}
.bancox-table tr.selected:hover td,
.bancox-table tr.selected-linked:hover td {
  background: #ECE6FF !important;
}
.bancox-match-detail {
  width: 68.5%;
  max-width: 100%;
}
@media (max-width: 1000px) {
  .bancox-match-detail { width: 100%; }
}


/* BancoX logo replacement and selected-row alignment polish */
.bancox-brand {
  background: transparent;
}
.bancox-brand img {
  width: 176px;
  mix-blend-mode: multiply;
  filter: contrast(1.04) saturate(.96);
}
.bancox-table tr.selected td,
.bancox-table tr.selected-linked td {
  outline: 1px solid rgba(124,92,252,.28);
  outline-offset: -1px;
}


/* BancoX coincidencias, filtros y controles homogéneos */
.bancox-file-control {
  min-height: 44px;
  height: 44px;
  padding: 8px 10px;
  align-items: center;
}
.bancox-file-control span {
  width: 126px;
  min-width: 126px;
  max-width: 126px;
  height: 28px;
  min-height: 28px;
  padding: 0;
  font-size: .84rem;
  line-height: 1;
}
.bancox-match-table th,
.bancox-match-table td {
  min-width: 92px;
}
.bancox-match-table th:nth-child(2),
.bancox-match-table td:nth-child(2),
.bancox-match-table th:nth-child(4),
.bancox-match-table td:nth-child(4) {
  min-width: 140px;
}
.bancox-filter-th {
  position: sticky;
  top: 0;
  overflow: visible;
}
.bancox-filter-trigger {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--gray);
  font-size: .78rem;
  font-weight: 800;
  text-transform: uppercase;
}
.bancox-filter-trigger span {
  color: var(--violet);
  font-size: .78rem;
}
.bancox-filter-pop {
  position: absolute;
  top: calc(100% + 6px);
  left: 8px;
  min-width: 180px;
  padding: 10px;
  border: 1px solid rgba(124,92,252,.18);
  border-radius: 8px;
  background: var(--white);
  box-shadow: var(--shadow-lg);
  display: none;
  z-index: 30;
}
.bancox-filter-pop.open {
  display: grid;
  gap: 8px;
}
.bancox-filter-pop input {
  height: 34px;
  padding: 8px 10px;
}
.bancox-filter-pop button {
  justify-self: end;
  color: var(--violet);
  font-weight: 700;
  font-size: .78rem;
}
.bancox-brand img {
  filter: sepia(.08) saturate(.92) hue-rotate(174deg) contrast(1.05) brightness(.92);
}


/* BancoX executive dashboard */
.bancox-exec { display: flex; flex-direction: column; gap: 16px; }
.bancox-exec-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 18px; background: var(--white); border: 1px solid var(--light-gray); border-radius: 8px; box-shadow: var(--shadow); padding: 18px 20px; }
.bancox-exec-head h2 { color: var(--navy); font-size: 1.35rem; margin: 2px 0 6px; letter-spacing: 0; }
.bancox-exec-head p { color: var(--gray); line-height: 1.45; max-width: 780px; }
.bancox-eyebrow { color: var(--violet) !important; font-size: .75rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0; margin: 0; }
.bancox-exec-head .btn-primary { min-width: 126px; margin-bottom: 2px; }
.bancox-exec-kpis { margin-bottom: 0; grid-template-columns: repeat(6, minmax(145px, 1fr)); }
.bancox-kpi em { display: block; color: var(--gray); font-size: .76rem; font-style: normal; margin-top: 6px; }
.bancox-kpi.pay { border-left-color: var(--violet); }
.bancox-exec-main { display: grid; grid-template-columns: minmax(0, 1.6fr) minmax(260px, .7fr); gap: 16px; align-items: stretch; }
.bancox-exec-bottom { display: grid; grid-template-columns: minmax(0, 1.55fr) minmax(260px, .75fr); gap: 16px; align-items: start; }
.bancox-panel-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.bancox-panel-head h3 { margin-bottom: 0; }
.bancox-model-state { display: inline-flex; align-items: center; gap: 4px; border-radius: 999px; padding: 6px 10px; background: rgba(124,92,252,.08); color: var(--gray); font-size: .78rem; font-weight: 700; white-space: nowrap; }
.bancox-model-state.active strong { color: #16A34A; }
.bancox-model-state.local strong { color: var(--navy); }
.bancox-flow { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr; align-items: center; gap: 10px; min-height: 128px; }
.bancox-flow-step { height: 92px; border: 1px solid rgba(124,92,252,.2); border-radius: 8px; background: linear-gradient(180deg, rgba(124,92,252,.08), rgba(74,163,223,.07)); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; text-align: center; }
.bancox-flow-step span { width: 28px; height: 28px; border-radius: 999px; background: var(--violet); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-weight: 800; }
.bancox-flow-step strong { color: var(--navy); font-size: .9rem; }
.bancox-flow-arrow { color: var(--violet); font-size: 1.3rem; font-weight: 800; }
.bancox-donut-panel { display: flex; flex-direction: column; align-items: center; justify-content: space-between; }
.bancox-donut-panel h3 { align-self: flex-start; }
.bancox-donut { width: 174px; height: 174px; border-radius: 50%; background: conic-gradient(#16A34A 0 calc(var(--ok) * 1%), #D97706 calc(var(--ok) * 1%) calc((var(--ok) + var(--warn)) * 1%), #DC2626 calc((var(--ok) + var(--warn)) * 1%) 100%); display: grid; place-items: center; margin: 8px auto 12px; }
.bancox-donut > div { width: 112px; height: 112px; border-radius: 50%; background: var(--white); display: flex; flex-direction: column; align-items: center; justify-content: center; box-shadow: inset 0 0 0 1px rgba(226,232,240,.9); }
.bancox-donut strong { color: var(--navy); font-size: 1.55rem; }
.bancox-donut span { color: var(--gray); font-size: .76rem; }
.bancox-donut-legend { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; }
.bancox-donut-legend span { border-radius: 999px; padding: 5px 9px; font-size: .75rem; font-weight: 800; }
.bancox-donut-legend .ok, .bancox-mini-status.ok { background: rgba(22,163,74,.1); color: #166534; }
.bancox-donut-legend .warn, .bancox-mini-status.warn { background: rgba(217,119,6,.1); color: #92400E; }
.bancox-donut-legend .bad { background: rgba(220,38,38,.1); color: #991B1B; }
.bancox-dashboard-table { max-height: 250px; }
.bancox-mini-status { display: inline-flex; align-items: center; border-radius: 999px; padding: 4px 8px; font-size: .72rem; font-weight: 800; }
.bancox-alert-list { display: grid; gap: 10px; }
.bancox-alert-list > div { min-height: 60px; border-radius: 8px; border: 1px solid var(--light-gray); padding: 12px 14px; display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.bancox-alert-list span { color: var(--gray); font-weight: 700; font-size: .84rem; }
.bancox-alert-list strong { color: var(--navy); font-size: 1.3rem; }
.bancox-alert-list .ok { background: rgba(22,163,74,.06); border-color: rgba(22,163,74,.16); }
.bancox-alert-list .warn { background: rgba(217,119,6,.07); border-color: rgba(217,119,6,.18); }
.bancox-alert-list .bad { background: rgba(220,38,38,.06); border-color: rgba(220,38,38,.16); }
@media (max-width: 1200px) {
  .bancox-exec-kpis { grid-template-columns: repeat(3, minmax(160px, 1fr)); }
  .bancox-exec-main, .bancox-exec-bottom { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .bancox-exec-head { align-items: stretch; flex-direction: column; }
  .bancox-exec-kpis { grid-template-columns: 1fr; }
  .bancox-flow { grid-template-columns: 1fr; }
  .bancox-flow-arrow { transform: rotate(90deg); justify-self: center; }
  .bancox-panel-head { align-items: flex-start; flex-direction: column; }
}


/* BancoX exact supplied logo */
.bancox-brand img {
  filter: none !important;
  mix-blend-mode: normal !important;
}


/* NóminaX native module */
.nominax-native .bancox-grid-2{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.5fr);gap:16px;margin-top:16px}
.nominax-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.nominax-form .btn-primary,.nominax-form .nominax-check{grid-column:1/-1}
.nominax-inline{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.nominax-param-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.nominax-param-grid label{font-size:.78rem;font-weight:800;color:var(--navy)}
.nominax-check{display:flex;align-items:center;gap:8px;font-size:.84rem;color:var(--navy);font-weight:700}
@media (max-width: 980px){.nominax-native .bancox-grid-2,.nominax-param-grid{grid-template-columns:1fr}.nominax-form{grid-template-columns:1fr}}


/* ImpuestoX native module */
.impuestox .impuestox-top { align-items: flex-start; }
.impuestox-brand { display: grid; grid-template-columns: 128px minmax(0,1fr); gap: 18px; align-items: start; }
.impuestox-brand img { width: 128px; height: auto; display: block; object-fit: contain; border-radius: 0; box-shadow: none; }
.impuestox-brand .bancox-eyebrow { margin-top: 4px; margin-bottom: 8px; }
.impuestox-tenant { margin: 0 0 14px; display: flex; align-items: center; gap: 10px; }
.impuestox-tenant label { min-width: 76px; }
.impuestox-form { display: grid; gap: 16px; }
.impuestox-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 12px; }
.impuestox-grid label, .impuestox-tenant label { display: grid; gap: 6px; color: var(--corp-blue); font-size: .84rem; font-weight: 700; }
.impuestox-supports { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 10px; }
.impuestox-filters { display: grid; grid-template-columns: minmax(150px,.7fr) minmax(130px,.7fr) 1fr auto; gap: 10px; align-items: center; }
.impuestox-result { border-left: 4px solid var(--violet); }
.impuestox-suggestions { display: grid; gap: 10px; }
.impuestox-suggestions p { border: 1px solid var(--light-gray); border-radius: 8px; padding: 12px; color: var(--corp-blue); background: rgba(124,92,252,.04); font-size: .86rem; line-height: 1.45; }
.impuestox .btn-primary[disabled] { opacity: .55; cursor: not-allowed; }
@media (max-width: 980px) { .impuestox-grid, .impuestox-supports, .impuestox-filters { grid-template-columns: 1fr; } .impuestox-brand { grid-template-columns: 86px minmax(0,1fr); } .impuestox-brand img { width: 86px; } }


.impuestox-section-title { grid-column: 1 / -1; margin: 8px 0 2px; padding: 10px 12px; border-radius: 8px; background: rgba(11,31,58,.05); color: var(--navy); font-weight: 900; letter-spacing: .02em; text-transform: uppercase; font-size: .76rem; }
.impuestox-grid small { color: var(--gray); font-weight: 600; line-height: 1.35; }
.impuestox-switch { display: flex !important; grid-template-columns: none !important; align-items: center; gap: 8px !important; min-height: 42px; padding: 0 12px; border: 1px solid var(--light-gray); border-radius: 8px; background: #fff; }
.impuestox-disclaimer { color: var(--gray); font-size: .86rem; line-height: 1.5; background: rgba(11,31,58,.035); }
.impuestox-result h4 { margin: 16px 0 8px; color: var(--navy); }
.impuestox-formulas { margin: 0; padding-left: 18px; color: var(--corp-blue); line-height: 1.55; font-size: .9rem; }

/* Financial statements visual refresh */
.analytics-exec-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(190px, 1fr));
  gap: 18px;
  margin-bottom: 18px;
}
.analytics-exec-kpis .bancox-kpi {
  min-height: 116px;
  padding: 20px 22px;
  border-left-width: 0;
  border-radius: 12px;
  background: rgba(255,255,255,.84);
  backdrop-filter: blur(8px);
  box-shadow: 0 10px 22px rgba(15,23,42,.08);
}
.analytics-exec-kpis .bancox-kpi.ok { border: 1px solid rgba(16,185,129,.32); }
.analytics-exec-kpis .bancox-kpi.warn { border: 1px solid rgba(244,63,94,.22); }
.analytics-exec-kpis .bancox-kpi.bad { border: 1px solid rgba(139,92,246,.34); }
.analytics-exec-kpis .bancox-kpi span {
  color: #94a3b8;
  font-size: .78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .03em;
}
.analytics-exec-kpis .bancox-kpi strong {
  color: #1e1b4b;
  font-size: 1.55rem;
  line-height: 1.15;
}
.analytics-exec-kpis .bancox-kpi em { color: #64748b; font-weight: 700; }
.analytics-exec-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(320px, .65fr);
  gap: 18px;
  align-items: stretch;
}
.analytics-chart-panel,
.analytics-indicators,
.analytics-detail-panel,
.analytics-statements-grid > .bancox-panel {
  border-radius: 12px;
  background: rgba(255,255,255,.84);
  backdrop-filter: blur(8px);
  box-shadow: 0 10px 22px rgba(15,23,42,.08);
}
.analytics-chart-panel h3,
.analytics-indicators h3,
.analytics-statements-grid h3 {
  margin: 0 0 18px;
  color: #334155;
  font-size: 1rem;
}
.analytics-chart-area {
  position: relative;
  min-height: 300px;
  display: grid;
  grid-template-columns: repeat(5, minmax(80px, 1fr));
  gap: 18px;
  align-items: stretch;
  padding: 8px 8px 0;
}
.analytics-chart-area::before {
  content: '';
  position: absolute;
  left: 8px;
  right: 8px;
  top: 50%;
  border-top: 1px solid rgba(100,116,139,.24);
}
.analytics-chart-col {
  position: relative;
  display: grid;
  grid-template-rows: 1fr auto;
  min-width: 0;
  text-align: center;
}
.analytics-chart-track {
  position: relative;
  min-height: 260px;
}
.analytics-chart-track i {
  position: absolute;
  left: 50%;
  width: min(72%, 130px);
  border-radius: 8px;
  transform: translateX(-50%);
  box-shadow: 0 8px 18px rgba(15,23,42,.08);
}
.analytics-chart-track i.positive { bottom: 50%; }
.analytics-chart-track i.negative { top: 50%; }
.analytics-chart-col span {
  color: #64748b;
  font-size: .78rem;
  font-weight: 700;
  padding-top: 8px;
}
.analytics-indicators {
  display: flex;
  flex-direction: column;
}
.analytics-indicator {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 20px 0;
  border-bottom: 1px solid #e2e8f0;
}
.analytics-indicator:last-child { border-bottom: 0; }
.analytics-indicator strong {
  display: block;
  color: #94a3b8;
  text-transform: uppercase;
  font-size: .78rem;
  font-weight: 800;
}
.analytics-indicator em {
  display: block;
  color: #94a3b8;
  font-size: .78rem;
  font-style: normal;
  margin-top: 4px;
}
.analytics-indicator b {
  color: #1e293b;
  font-size: 1.15rem;
  font-variant-numeric: tabular-nums;
  text-align: right;
}
.analytics-detail-title {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  margin-bottom: 26px;
}
.analytics-detail-title h3 { margin: 0 0 4px; color: #1e293b; font-size: 1.15rem; }
.analytics-detail-title p { margin: 0; color: #64748b; font-size: .86rem; }
.analytics-pillbar {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.analytics-pill {
  min-width: 74px;
  min-height: 36px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid #e2e8f0;
  background: rgba(255,255,255,.78);
  color: #1e293b;
  font-size: .84rem;
  font-weight: 800;
  transition: var(--transition);
}
.analytics-pill:hover { border-color: rgba(30,27,75,.28); color: #1e1b4b; }
.analytics-pill.active {
  background: #1e1b4b;
  color: #fff;
  border-color: #1e1b4b;
  box-shadow: 0 10px 20px rgba(30,27,75,.16);
}
.analytics-detail-panel .bancox-table-wrap,
.analytics-statements-grid .bancox-table-wrap {
  max-height: 560px;
  border-radius: 12px;
}
.analytics-detail-panel .analytics-table th,
.analytics-statements-grid .analytics-table th {
  background: #f8fafc;
  color: #64748b;
  letter-spacing: .05em;
}
.analytics-detail-panel .analytics-table td,
.analytics-statements-grid .analytics-table td {
  padding: 14px 16px;
}
.analytics-statement-table td:last-child,
.analytics-statement-table th:last-child { text-align: right; }
.analytics-statement-line.is-expandable { cursor: pointer; }
.analytics-statement-line.is-expandable:hover td { background: rgba(16,185,129,.04); }
.analytics-statement-line.expanded td { background: rgba(30,27,75,.045); }
.analytics-drill-row { display: none; }
.analytics-drill-row.open { display: table-row; }
.analytics-drill-row > td {
  background: #f8fafc !important;
  padding: 10px 16px 18px !important;
}
.analytics-drill-box {
  max-height: 260px;
  overflow: auto;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  background: #fff;
}
.analytics-drill-box table { width: 100%; border-collapse: collapse; font-size: .84rem; }
.analytics-drill-box th,
.analytics-drill-box td { padding: 10px 12px; border-bottom: 1px solid #edf2f7; }
.analytics-drill-box th { color: #64748b; text-transform: uppercase; font-size: .72rem; background: #fff; }
.analytics-drill-empty { color: #64748b; font-size: .84rem; padding: 10px; }
@media (max-width: 1180px) {
  .analytics-exec-kpis { grid-template-columns: repeat(2, minmax(180px, 1fr)); }
  .analytics-exec-grid { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .analytics-exec-kpis { grid-template-columns: 1fr; }
  .analytics-detail-title { display: grid; }
  .analytics-pillbar { justify-content: flex-start; }
  .analytics-chart-area { grid-template-columns: repeat(5, minmax(54px, 1fr)); gap: 8px; }
}


/* Detail balance alignment refinements */
.analytics-detail-panel .analytics-table th {
  text-align: center !important;
  vertical-align: middle;
}
.analytics-detail-panel .analytics-table td:nth-child(1),
.analytics-detail-panel .analytics-table td:nth-child(2) {
  text-align: center !important;
}
.analytics-detail-panel .analytics-table td:nth-child(3) {
  text-align: left !important;
}
.analytics-detail-panel .analytics-table td:nth-child(4),
.analytics-detail-panel .analytics-table td:nth-child(5),
.analytics-detail-panel .analytics-table td:nth-child(6),
.analytics-detail-panel .analytics-table td:nth-child(7) {
  text-align: right !important;
  font-variant-numeric: tabular-nums;
}
.analytics-detail-panel .analytics-table th:nth-child(1),
.analytics-detail-panel .analytics-table td:nth-child(1) { width: 8%; }
.analytics-detail-panel .analytics-table th:nth-child(2),
.analytics-detail-panel .analytics-table td:nth-child(2) { width: 9%; }
.analytics-detail-panel .analytics-table th:nth-child(3),
.analytics-detail-panel .analytics-table td:nth-child(3) { width: 36%; }
.analytics-detail-panel .analytics-table th:nth-child(4),
.analytics-detail-panel .analytics-table td:nth-child(4),
.analytics-detail-panel .analytics-table th:nth-child(5),
.analytics-detail-panel .analytics-table td:nth-child(5),
.analytics-detail-panel .analytics-table th:nth-child(6),
.analytics-detail-panel .analytics-table td:nth-child(6),
.analytics-detail-panel .analytics-table th:nth-child(7),
.analytics-detail-panel .analytics-table td:nth-child(7) { width: 11.75%; }
.analytics-pill {
  font-weight: 400;
}

/* KPI comparison, tooltips and top navigation */
.analytics-side-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
}
.analytics-back-top {
  min-height: 30px;
  padding: 6px 12px;
  border-radius: 8px;
  font-size: .78rem;
  font-weight: 500;
  color: var(--corp-blue);
  background: rgba(255,255,255,.55);
  border: 1px solid rgba(148,163,184,.28);
  box-shadow: none;
  align-self: end;
  margin-top: 18px;
}
.analytics-back-top:hover {
  background: rgba(255,255,255,.86);
  color: var(--violet);
}
.analytics-trend {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-weight: 800;
  font-size: .78rem;
}
.analytics-trend.trend-up { color: #10b981; }
.analytics-trend.trend-down { color: #ef4444; }
.analytics-chart-track i {
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
}
.analytics-chart-track i b {
  opacity: 0;
  pointer-events: none;
  color: #fff;
  background: rgba(15,23,42,.72);
  border-radius: 999px;
  padding: 5px 8px;
  font-size: .72rem;
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
  transform: scale(.96);
  transition: opacity .16s ease, transform .16s ease;
}
.analytics-chart-track i:hover b {
  opacity: 1;
  transform: scale(1);
}
.analytics-indicator b {
  position: relative;
  cursor: help;
  outline: none;
}
.analytics-indicator b small {
  position: absolute;
  right: 0;
  top: calc(100% + 10px);
  width: min(320px, 70vw);
  padding: 11px 12px;
  border-radius: 10px;
  background: #1e1b4b;
  color: #fff;
  box-shadow: 0 16px 32px rgba(15,23,42,.22);
  font-size: .76rem;
  font-weight: 500;
  line-height: 1.45;
  text-align: left;
  white-space: normal;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-3px);
  transition: opacity .16s ease, transform .16s ease, visibility .16s ease;
  z-index: 30;
}
.analytics-indicator b:hover small,
.analytics-indicator b:focus small {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
@media (max-width: 640px) {
  .analytics-side-head { grid-template-columns: 1fr; }
  .analytics-back-top { justify-self: end; margin-top: 0; }
}

/* Tool card access states */
.tool-card {
  padding-bottom: 64px;
}
.tool-badge {
  position: absolute;
  bottom: 24px;
  right: 24px;
  min-width: 132px;
  text-align: center;
  border-radius: 999px;
  padding: 7px 14px;
  font-size: .78rem;
  font-weight: 500;
}
.tool-badge.badge-login {
  color: var(--violet);
  background: rgba(124,92,252,.10);
}
.tool-badge.badge-locked {
  color: #64748b;
  background: rgba(100,116,139,.10);
}
.tool-card:not(.locked)::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  border: 1px solid transparent;
  transition: var(--transition);
}
.tool-card:not(.locked):hover::after {
  border-color: rgba(124,92,252,.18);
}

/* Zoom FS PDF archive */
.zoomfs-files .bancox-panel-head {
  align-items: flex-start;
  gap: 16px;
}
.zoomfs-files .bancox-panel-head p {
  margin: 5px 0 0;
  color: var(--gray);
  font-size: .86rem;
}
.zoomfs-file-admin {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.zoomfs-action-btn {
  min-width: 0;
  width: auto;
  padding: 7px 13px;
  min-height: 34px;
  font-size: .82rem;
  line-height: 1;
}
.zoomfs-file-note {
  color: var(--gray);
  font-size: .84rem;
  background: rgba(100,116,139,.08);
  border: 1px solid rgba(100,116,139,.12);
  border-radius: 999px;
  padding: 8px 12px;
}
.zoomfs-file-grid {
  display: grid;
  grid-template-columns: 128px minmax(0, 1fr);
  gap: 16px;
  min-height: 620px;
}
.zoomfs-year-pills {
  display: grid;
  gap: 8px;
  margin-bottom: 12px;
}
.zoomfs-year-pill {
  border: 1px solid rgba(124,92,252,.18);
  background: rgba(124,92,252,.07);
  color: var(--violet);
  border-radius: 999px;
  padding: 9px 12px;
  font-size: .84rem;
  font-weight: 500;
  cursor: pointer;
}
.zoomfs-year-pill.active {
  background: var(--violet);
  color: white;
  box-shadow: 0 8px 18px rgba(124,92,252,.18);
}
.zoomfs-file-list {
  display: grid;
  gap: 9px;
  max-height: 620px;
  overflow: auto;
  padding-right: 4px;
}
.zoomfs-file-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 4px 10px;
  align-items: center;
  text-align: left;
  border: 1px solid var(--light-gray);
  background: rgba(255,255,255,.76);
  border-radius: 10px;
  padding: 12px;
  transition: var(--transition);
}
.zoomfs-file-item:hover,
.zoomfs-file-item.active {
  border-color: rgba(124,92,252,.36);
  background: rgba(124,92,252,.06);
}
.zoomfs-file-item strong {
  color: var(--violet);
  font-size: .78rem;
  grid-row: span 2;
}
.zoomfs-file-item span {
  color: var(--navy);
  font-size: .83rem;
  font-weight: 700;
  overflow-wrap: anywhere;
}
.zoomfs-file-item em {
  color: var(--gray);
  font-size: .74rem;
  font-style: normal;
}
.zoomfs-pdf-view {
  min-height: 620px;
  border: 1px solid var(--light-gray);
  border-radius: 12px;
  overflow: hidden;
  background: var(--off-white);
  position: relative;
}
.zoomfs-pdf-view iframe {
  width: 100%;
  height: 100%;
  min-height: 620px;
  border: 0;
  display: none;
  background: white;
}
@media (max-width: 980px) {
  .zoomfs-file-grid { grid-template-columns: 1fr; }

.zoomfs-file-list { max-height: 260px; }
}

/* Zoom FS: ampliar composición de saldos y ocultar indicadores clave */
.analytics-exec-grid {
  grid-template-columns: 1fr;
}
.analytics-exec-grid .analytics-indicators {
  display: none !important;
}
.analytics-exec-grid .analytics-chart-panel .analytics-chart-area {
  min-height: 390px;
}
.analytics-exec-grid .analytics-chart-panel .analytics-chart-track {
  min-height: 340px;
}

/* Zoom FS: barras de composición siempre hacia arriba con valores absolutos */
.analytics-chart-track i.positive,
.analytics-chart-track i.negative {
  top: auto !important;
  bottom: 0 !important;
}
.analytics-chart-area::before {
  top: auto;
  bottom: 0;
}

/* Partner portraits */
.partner-card {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 28px;
  align-items: start;
  text-align: left;
  padding: 28px 24px;
}
.partner-card:hover {
  transform: none;
}
.partner-media {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
}
.partner-photo {
  width: 188px;
  height: 188px;
  margin: 0;
  border-radius: 50%;
  background: var(--off-white);
  color: var(--navy);
  font-size: 2rem;
  box-shadow: 0 10px 28px rgba(12, 37, 64, .12);
}
.partner-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.partner-photo-jose-luis-mero img {
  object-position:  50% 34%;
}
.partner-photo-gustavo-mero img {
  object-position:   50% 6%;
}
.partner-photo-btn {
  margin-top: 14px;
  margin-bottom: 0 !important;
}
.partner-info h4,
.partner-card h4 {
  text-align: left;
  margin-top: 0;
}
.partner-info p,
.partner-card p {
  text-align: justify;
}
.partner-desc-input {
  width: 100%;
  min-height: 80px;
  padding: 10px;
  border: 1.5px solid var(--light-gray);
  border-radius: 8px;
  font-size: .86rem;
  margin-top: 8px;
  resize: vertical;
}
@media (max-width: 900px) {
  .partner-card {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .partner-info h4,
  .partner-card h4 {
    text-align: center;
  }
  .partner-media {
    align-items: center;
  }
}

.nosotros-text p { margin: 0 0 18px; }
.nosotros-text p:last-child { margin-bottom: 0; }

/* Analytics - Ratios */
.analytics-ratio-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 12px;
  margin: 12px 0 24px;
}
.analytics-ratio-card {
  background: var(--white);
  border: 1px solid var(--light-gray);
  border-radius: 10px;
  padding: 14px;
  transition: var(--transition);
}
.analytics-ratio-card:hover { box-shadow: var(--shadow); }
.analytics-ratio-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
  margin-bottom: 8px;
}
.analytics-ratio-head strong {
  font-size: .85rem;
  color: var(--dark-text);
  flex: 1;
}
.analytics-ratio-head span {
  white-space: nowrap;
  font-size: .9rem;
  font-weight: 600;
}
.analytics-ratio-head span b { color: inherit; }
.analytics-ratio-card.good .analytics-ratio-head span { color: #10b981; }
.analytics-ratio-card.warning .analytics-ratio-head span { color: #f59e0b; }
.analytics-ratio-card.bad .analytics-ratio-head span { color: #ef4444; }
.analytics-ratio-bar {
  height: 6px;
  background: var(--light-gray);
  border-radius: 3px;
  overflow: hidden;
  margin: 6px 0 8px;
}
.analytics-ratio-bar i {
  display: block;
  height: 100%;
  border-radius: 3px;
  transition: width .6s ease;
}
.analytics-ratio-card em {
  display: block;
  font-size: .72rem;
  color: var(--gray);
  font-style: normal;
  margin-bottom: 4px;
}
.analytics-ratio-card small {
  font-size: .75rem;
  color: var(--gray);
  line-height: 1.4;
}
.analytics-subtitle {
  font-size: .9rem;
  font-weight: 600;
  color: var(--corp-blue);
  margin: 20px 0 8px;
  padding-bottom: 4px;
  border-bottom: 2px solid var(--light-gray);
}

/* Analytics - Comparison */
.analytics-upload-mini {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.analytics-upload-mini .analytics-file-mini {
  display: inline-block;
  padding: 6px 14px;
  background: var(--off-white);
  border: 1.5px dashed var(--gray);
  border-radius: 8px;
  cursor: pointer;
  font-size: .82rem;
  color: var(--gray);
  transition: var(--transition);
}
.analytics-upload-mini .analytics-file-mini:hover {
  border-color: var(--violet);
  color: var(--violet);
}

/* Analytics - Source files */
.bancox-btn-sm {
  padding: 4px 12px;
  font-size: .8rem;
  background: var(--violet);
  color: var(--white);
  border-radius: 6px;
  transition: var(--transition);
}
.bancox-btn-sm:hover { opacity: .85; }
.bancox-btn-sm:disabled { opacity: .5; cursor: not-allowed; }

/* Modern Upload UI */
.analytics-remote-upload-container { display: flex; flex-direction: column; gap: 10px; }
.analytics-remote-upload-container .analytics-pillbar { display: flex; flex-wrap: wrap; gap: 8px; }
.analytics-remote-rows { display: flex; flex-direction: column; gap: 6px; margin: 4px 0; }
.analytics-remote-row-year { display: flex; align-items: center; gap: 12px; }
.analytics-remote-row-year strong { font-size: 0.95rem; color: #1e293b; width: 45px; flex-shrink: 0; }
.modern-processing-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.6); backdrop-filter: blur(4px); z-index: 9999; display: flex; flex-direction: column; align-items: center; justify-content: center; color: white; font-family: inherit; }
.modern-spinner { width: 50px; height: 50px; border: 4px solid rgba(255,255,255,0.3); border-top-color: white; border-radius: 50%; animation: modern-spin 1s linear infinite; margin-bottom: 20px; }
@keyframes modern-spin { to { transform: rotate(360deg); } }
.modern-toast { position: fixed; bottom: -100px; left: 50%; transform: translateX(-50%); background: #333; color: white; padding: 12px 24px; border-radius: 30px; box-shadow: 0 4px 12px rgba(0,0,0,0.15); transition: bottom 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275); z-index: 10000; font-weight: 500; }
.modern-toast.show { bottom: 30px; }
