.pill{display:inline-block;font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;border:1px solid transparent;letter-spacing:.02em;line-height:1.2;}.pill-amber{background:#fef3c7;color:#92400e;border-color:#fde68a;}.pill-blue{background:#dbeafe;color:#1e3a8a;border-color:#bfdbfe;}.pill-green{background:#dcfce7;color:#14532d;border-color:#bbf7d0;}.pill-gray{background:#f1f5f9;color:#475569;border-color:#e2e8f0;}.ctas-state-pill{min-width:96px;text-align:center;}.ctas-card{border:1px solid var(--border);border-radius:12px;transition:box-shadow .15s;}.ctas-card:hover{box-shadow:0 4px 16px rgba(15,23,42,.06);}
:root{--bg:#f8f9fa;--panel:#fff;--text:#212529;--muted:#6c757d;--brand:#dc3545;--brand-2:#c82333;--ok:#28a745;--warn:#ffc107;--error:#dc3545;--prog:#475569;--border:#e9ecef;--border-light:#f1f5f9;--focus-ring:0 0 0 4px rgba(220,53,69,.15);--shadow-sm:0 4px 12px rgba(15,23,42,.04);--shadow-md:0 10px 30px rgba(15,23,42,.06);--shadow-lg:0 22px 50px rgba(15,23,42,.08);--radius-lg:16px;--radius-md:12px;--radius-sm:8px;--sidebar-width:270px;--sidebar-width-collapsed:88px;--transition:180ms cubic-bezier(.3,.9,.3,1);--font-sans:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif}*{box-sizing:border-box}html{height:100%}body{margin:0;font-family:var(--font-sans);font-size:14px;color:var(--text);background:linear-gradient(180deg,#fdfdff,var(--bg));-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100vh;overflow:hidden}#login-screen{position:relative;display:grid;place-items:center;width:100%;height:100vh;overflow:hidden}#particles-js{position:absolute;width:100%;height:100%;top:0;left:0;background-color:#1a1a1a;z-index:1}#login-card{position:relative;z-index:2;background:rgba(33,37,41,.88);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);box-shadow:0 20px 40px -15px rgba(0,0,0,.35);padding:40px;width:100%;max-width:400px;text-align:center;animation:cardIn .5s cubic-bezier(.16,.84,.31,1.02)}@keyframes cardIn{from{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}#login-card .brand{display:flex;flex-direction:column;gap:12px;align-items:center;margin-bottom:24px}#login-card .logo{width:120px;height:120px;background:url(https://onbox-portal.soporte-a90.workers.dev/email-logo.png) center/contain no-repeat;border-radius:20px;background-color:#fff}#login-card h1{color:#fff;margin:0;font-size:24px;font-weight:700}#login-card p{margin:0;color:var(--muted);font-size:14px;font-weight:500}#login-form{display:flex;flex-direction:column;gap:16px;text-align:left}#login-form label{font-weight:600;color:#ced4da;font-size:12px;text-transform:uppercase;letter-spacing:.05em}#login-form input{width:100%;background:rgba(255,255,255,.05);color:#fff;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-sm);padding:10px 12px;font-size:14px;transition:all var(--transition)}#login-form input:focus{outline:0;border-color:var(--brand);background:rgba(255,255,255,.1);box-shadow:var(--focus-ring)}#login-btn{margin-top:8px;width:100%;padding:12px;font-size:15px;background:var(--brand);box-shadow:0 6px 18px -6px rgba(220,53,69,.5)}#login-btn:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 8px 22px -6px rgba(220,53,69,.5)}.layout{display:grid;grid-template-columns:var(--sidebar-width) 1fr;height:100vh;overflow:hidden;transition:grid-template-columns .3s ease-in-out}.layout.sidebar-collapsed{grid-template-columns:var(--sidebar-width-collapsed) 1fr}.main{display:flex;flex-direction:column;min-height:0;overflow:hidden}.content{padding:16px;flex:1 1 0%;min-height:0;overflow-y:auto;overflow-anchor:none}#catalogo{max-width:1500px;margin:0 auto}.footer{padding:20px 16px;color:var(--muted);text-align:center;font-size:12px;border-top:1px solid var(--border);margin-top:auto}.sidebar{background:linear-gradient(180deg,#fff,#fbfcfd);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:14px;gap:8px;overflow-x:hidden;overflow-y:auto;position:sticky;top:0;height:100vh;-ms-overflow-style:none;scrollbar-width:none}.sidebar::-webkit-scrollbar{display:none}.sidebar .brand{display:flex;gap:16px;align-items:center;padding:8px;margin-bottom:8px}.sidebar .logo{width:60px;height:60px;border-radius:var(--radius-md);flex-shrink:0;background:url(https://onbox-portal.soporte-a90.workers.dev/email-logo.png) center/contain no-repeat;background-color:#fff}.brand-text{opacity:1;transition:opacity .2s;white-space:nowrap}.layout.sidebar-collapsed .brand-text{opacity:0;width:0;pointer-events:none}.brand-text h1{margin:0;font-size:18px}.brand-text p{margin:0;font-size:12px;color:var(--muted)}.nav{display:flex;flex-direction:column;gap:6px}.nav-group{font-size:11px;color:#343a40;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin:8px 6px 4px;white-space:nowrap;transition:all .2s ease-in-out}.layout.sidebar-collapsed .nav-group-text{opacity:0}.layout.sidebar-collapsed .nav-group::after{content:"•";display:block;text-align:center;font-size:14px;color:#adb5bd}.nav-sep{height:1px;background:var(--border);margin:6px 0}a.nav-item, button.nav-item{all:unset;box-sizing:border-box;display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-md);cursor:pointer;position:relative;color:var(--prog);transition:all var(--transition)}.layout.sidebar-collapsed a.nav-item, .layout.sidebar-collapsed button.nav-item{justify-content:center}.nav-text{opacity:1;transition:opacity .2s ease-in-out;white-space:nowrap}.layout.sidebar-collapsed .nav-text{opacity:0;width:0;pointer-events:none}a.nav-item:hover, button.nav-item:hover{background:#fdf2f2;color:var(--brand);transform:translateX(5px)}a.nav-item.active, button.nav-item.active{background:linear-gradient(90deg,rgba(220,53,69,.08),rgba(220,53,69,.03));color:var(--brand);font-weight:700;box-shadow:var(--shadow-sm)}a.nav-item.active::before, button.nav-item.active::before{content:"";position:absolute;left:-14px;top:8px;bottom:8px;width:4px;background:var(--brand);border-radius:0 4px 4px 0}.layout.sidebar-collapsed a.nav-item.active::before, .layout.sidebar-collapsed button.nav-item.active::before{left:0}.nav-ico{width:24px;text-align:center;font-size:18px;flex-shrink:0}.sidebar-footer{margin-top:auto;padding-top:10px;display:flex;flex-direction:column;gap:8px;color:var(--muted);text-align:center}#logout-btn .nav-text{display:inline-block}.layout.sidebar-collapsed #logout-btn .nav-text{display:none}#logout-btn .nav-ico{display:none}.layout.sidebar-collapsed #logout-btn .nav-ico{display:inline-block}.topbar{position:sticky;top:0;z-index:10;background:rgba(255,255,255,.75);backdrop-filter:saturate(150%) blur(8px);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;padding:10px 16px;flex-shrink:0}.left,.right{display:flex;align-items:center;gap:12px}#active-seller-display{background:var(--brand);color:#fff;font-size:11px;font-weight:700;padding:4px 8px;border-radius:6px;cursor:pointer;}.icon-btn{all:unset;cursor:pointer;font-size:18px;padding:6px 8px;border-radius:var(--radius-sm);transition:background var(--transition)}.icon-btn:hover{background:var(--border)}.filter-group{display:flex;align-items:center;gap:8px}.filter-group label{font-size:12px;color:var(--muted);font-weight:600}.filter-group input,.filter-group select,.table-tools input[type=search]{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 10px;font-size:13px}#loading-indicator{display:inline-block;width:16px;height:16px;border:2px solid rgba(0,0,0,.1);border-left-color:var(--brand);border-radius:50%;animation:spin 1s linear infinite;text-indent:-9999px;overflow:hidden}@keyframes spin{to{transform:rotate(360deg)}}.user{display:flex;align-items:center;gap:8px}.section{display:none;margin-bottom:16px;flex-shrink:0}.section.show{display:block;animation:fadeIn .3s ease-out}@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.card{background:linear-gradient(180deg,var(--panel),#fdfdff);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:20px}.card.soft{background:linear-gradient(180deg,#fcfdff,#f8f9fa);box-shadow:var(--shadow-sm);border-color:var(--border-light)}.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:12px}.card h3,.card h4{margin:0;font-weight:700;font-size:18px}.card h4{font-size:15px}.hidden{display:none!important}.cat-tab,.cc-tab,.cuenta-tab-content,.proy-tab,.resultados-tab,.inv-tab,.imp-tab{display:none}.cat-tab.show,.cc-tab.show,.cuenta-tab-content.show,.proy-tab.show,.resultados-tab.show,.inv-tab.show,.imp-tab.show{display:block}.table-wrap{overflow:auto;border:1px solid var(--border);border-radius:var(--radius-md)}.table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;font-size:13px}.table thead th{position:sticky;top:0;background:linear-gradient(180deg,#fff,#f8f9fa);font-weight:700;text-align:left;padding:12px 14px;border-bottom:2px solid var(--border);color:var(--brand);font-size:12px;text-transform:uppercase;letter-spacing:.03em}.table tbody td{padding:12px 14px;border-bottom:1px solid var(--border-light);transition:background-color var(--transition)}.table tbody tr{transition:transform var(--transition),box-shadow var(--transition)}.table tbody tr:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);z-index:2;position:relative}.table tbody tr:hover td{background-color:#fff}.table tbody tr.modified td{background:#fff9db}.table tbody tr.warn td{background:#fff7ed;border-left:3px solid #f59e0b}.table tbody tr.warn td:first-child{font-weight:700}.table tbody tr.ok td{background:#f0fdf4;border-left:3px solid #22c55e}.table tbody tr.ok td:first-child{font-weight:700}.table .num{text-align:right}.table.editable-table input{width:100%;min-width:90px;padding:6px;border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;font:inherit}.table.editable-table input:focus{outline:0;border-color:var(--brand);box-shadow:var(--focus-ring)}.btn{all:unset;box-sizing:border-box;cursor:pointer;background:linear-gradient(180deg,var(--brand),var(--brand-2));color:#fff;padding:8px 14px;border-radius:var(--radius-md);font-weight:700;text-align:center;transition:all var(--transition);display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 12px -3px rgba(220,53,69,.4)}.btn:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 7px 15px -4px rgba(220,53,69,.4)}.btn:active{transform:translateY(0);filter:brightness(1)}.btn:disabled{cursor:not-allowed;filter:grayscale(80%);opacity:.6;transform:none;box-shadow:none}.btn.ghost{background:0 0;color:var(--text);border:1px solid var(--border);box-shadow:none}.btn.ghost:hover{background:var(--border);border-color:#dee2e6;color:var(--text)}.btn.small{padding:6px 10px;font-size:12px;border-radius:var(--radius-sm)}.btn.large{padding:12px 20px;font-size:15px}.btn.whatsapp{background:#25d366;box-shadow:0 4px 12px -3px rgba(37,211,102,.4)}.btn.danger{background:var(--error);box-shadow:0 4px 12px -3px rgba(220,53,69,.4)}.btn.success{background:var(--ok);box-shadow:0 4px 12px -3px rgba(40,167,70,.4)}.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px}.kpis-mini{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:16px}.kpi-mini{background:#fff;padding:12px 16px;border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform var(--transition)}.kpi-mini:hover{transform:translateY(-2px)}.kpi-mini span{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.kpi-mini h3{font-size:20px;font-weight:800;margin:4px 0 0;color:var(--text)}.kpi{padding:14px;border-radius:var(--radius-md);background:linear-gradient(180deg,#fdfdff,#f8f9fa);border-left:5px solid var(--brand);box-shadow:var(--shadow-sm)}.kpi span{color:var(--muted);font-weight:600;font-size:13px}.kpi-num{margin:6px 0 0;font-size:26px;font-weight:700;color:#0f172a}.tabs{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding-bottom:8px}.tab{all:unset;padding:8px 12px;border-radius:99px;cursor:pointer;font-weight:600;font-size:13px;transition:all var(--transition)}.tab:hover{background:var(--border);color:var(--text)}.tab.active{background:#fdf2f2;color:var(--brand);box-shadow:0 2px 8px -4px var(--brand)}.table-tools{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}#facturacion-table{table-layout:fixed}#facturacion-table th,#facturacion-table td{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:8px 6px}#facturacion-table td:last-child,#facturacion-table th:last-child{overflow:visible}.filter-bar{padding:12px;background:#f8f9fa;border-radius:var(--radius-md);border:1px solid var(--border-light)}.table-tools .sep{flex-grow:1}.form-grid-item{display:flex;flex-direction:column;gap:6px}.form-grid-item label{font-weight:600;color:var(--muted);font-size:13px}.form-grid-item input, .form-grid-item select{width:100%;border-radius:var(--radius-sm);border:1px solid var(--border);padding:10px;font-size:14px;background:#fff}.form-grid-item input:focus, .form-grid-item select:focus{outline:0;border-color:var(--brand);box-shadow:var(--focus-ring)}.combo-form-main, #edit-product-form{display:grid;gap:16px;grid-template-columns:1fr 1fr}.combo-form-main .form-full-width, #edit-product-form .form-full-width{grid-column:1 / -1}.combo-form-main .ss-main{width:100%}.combo-form-main .ss-main .ss-single-selected{padding:10px;height:auto;border-color:var(--border)}#combo-components-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;max-height:200px;overflow-y:auto;padding:10px;background:#f8f9fa;border-radius:var(--radius-md)}.combo-component-item{display:flex;align-items:center;gap:10px;padding:8px;background:var(--panel);border:1px solid var(--border-light);border-radius:var(--radius-sm)}.combo-component-item .component-name{flex-grow:1}.combo-component-item .component-qty{width:70px;text-align:right;padding:6px;border-radius:var(--radius-sm);border:1px solid var(--border)}.combo-component-item .remove-btn{font-size:14px;padding:4px 6px}#combo-price-preview{margin-top:16px;padding:16px;background:#f8f9fa;border-radius:var(--radius-md);border:1px solid var(--border-light)}.price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px 12px}.price-grid .item{font-size:12px;color:var(--muted);font-weight:600}.price-grid .value{font-weight:700;font-size:15px}.form-control{width:100%;border-radius:var(--radius-sm);border:1px solid var(--border);padding:10px;font-size:14px;background:#fff;transition:border-color var(--transition),box-shadow var(--transition)}.form-control:focus{outline:0;border-color:var(--brand);box-shadow:var(--focus-ring)}.modal{position:fixed;inset:0;display:grid;place-items:center;z-index:100}.modal.hidden{display:none}.modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.3);backdrop-filter:blur(4px)}.modal-card{position:relative;width:min(960px,92vw);max-height:85vh;display:flex;flex-direction:column;background:var(--panel);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:modalIn .3s cubic-bezier(.16,1,.3,1)}.modal-card.modal-wide{width:min(1280px,96vw)}@keyframes modalIn{from{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-head{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.modal-body{padding:20px;overflow-y:auto}.modal-body .seller-item{width:100%;padding:12px;background:#f8f9fa;border:1px solid var(--border-light);border-radius:var(--radius-md);text-align:center;font-weight:600;cursor:pointer;transition:all var(--transition)}.modal-body .seller-item:hover{background:var(--border);transform:scale(1.02)}.modal-actions{padding:14px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;align-items:center;gap:10px;flex-shrink:0}.modal-actions .sep{flex-grow:1}.modal-grid-2,#view-order-div .modal-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}#edit-order-form textarea,#view-order-div textarea{width:100%;border-radius:var(--radius-sm);border:1px solid var(--border);padding:8px;font-family:inherit;min-height:50px}.toast{position:fixed;top:24px;right:24px;transform:translateX(20px);opacity:0;transition:all .4s cubic-bezier(.16,1,.3,1);background:#fff;color:var(--text);padding:16px 20px;border-radius:var(--radius-md);box-shadow:0 10px 40px -10px rgba(0,0,0,0.15);pointer-events:none;z-index:2000;display:flex;align-items:center;gap:12px;min-width:320px;border:1px solid var(--border);font-weight:600;font-size:14px}.toast.show{opacity:1;transform:translateX(0)}.toast.error{border-left:4px solid var(--error)}.toast.success{border-left:4px solid var(--ok)}.toast-icon{font-size:18px}.cc-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;margin-top:16px}.summary-table{margin-top:12px}.summary-table td{padding:10px}.summary-table tr.total td{font-weight:700;color:var(--text);border-top:2px solid var(--border)}.modal-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px}.modal-detail-group h5{margin:0 0 10px;font-size:14px;color:var(--brand);border-bottom:1px solid var(--border);padding-bottom:6px}.modal-detail-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border-light)}.modal-detail-item:last-child{border:0}.modal-label{font-weight:600;color:var(--muted);font-size:13px}.modal-value{font-weight:600;text-align:right}.modal-value.num{letter-spacing:-.5px}.results-detail-container{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));max-height:70vh;overflow-y:auto;padding-top:10px}.result-card{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--panel);transition:all var(--transition)}.result-card:hover{transform:scale(1.02);box-shadow:var(--shadow-md);z-index:5}.result-card-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background-color:#f8f9fa;border-bottom:1px solid var(--border);border-radius:var(--radius-md) var(--radius-md) 0 0}.result-card-id{font-weight:700;font-size:14px}.result-card-body{padding:12px;display:grid;gap:16px}.result-detail-section{display:flex;flex-direction:column;gap:8px}.result-detail-section h5{font-size:12px;font-weight:700;color:var(--brand);margin:0 0 4px;padding-bottom:4px;border-bottom:1px solid var(--border-light);text-transform:uppercase;letter-spacing:.05em}.result-detail-item{display:flex;justify-content:space-between;font-size:13px}.result-detail-label{color:var(--muted)}.result-detail-value{font-weight:600}.result-card-footer{padding:10px 12px;background-color:#f8f9fa;border-top:1px solid var(--border);border-radius:0 0 var(--radius-md) var(--radius-md);display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:700}.result-profit-pct{padding:4px 8px;border-radius:99px;color:#fff}.result-profit-pct.positive{background-color:var(--ok)}.result-profit-pct.negative{background-color:var(--error)}#tbl_costs td{color:var(--muted)}#tbl_costs .ok td{color:var(--ok)}#tbl_costs .error td{color:var(--error)}@media (max-width:900px){.layout:not(.sidebar-collapsed){grid-template-columns:var(--sidebar-width-collapsed) 1fr}.layout:not(.sidebar-collapsed) .brand-text,.layout:not(.sidebar-collapsed) .nav-text{opacity:0;width:0;pointer-events:none}.layout:not(.sidebar-collapsed) .nav-item{justify-content:center}.layout:not(.sidebar-collapsed) .nav-item.active::before{left:0}.cc-summary-grid,.grid-2,.kpis,.results-layout{grid-template-columns:1fr}} .badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:0.02em;text-transform:uppercase;border:1px solid transparent;white-space:nowrap;box-shadow:none;} .badge.warn{background-color:#fff7ed;color:#c2410c;border-color:#fed7aa} .badge.ok{background-color:#f0fdf4;color:#15803d;border-color:#bbf7d0} .badge.error{background-color:#fef2f2;color:#b91c1c;border-color:#fecaca}.integration-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.torre-feed{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;padding:16px;background:#f1f5f9;border-radius:var(--radius-md);max-height:70vh;overflow-y:auto}.torre-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;box-shadow:var(--shadow-sm);transition:all .2s;border-left:4px solid var(--brand)}.torre-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.torre-card-header{display:flex;justify-content:space-between;margin-bottom:12px;font-size:12px;font-weight:700;color:var(--muted)}.torre-card-body h4{margin:0 0 8px;font-size:16px;font-weight:700}.torre-card-body p{margin:0 0 4px;font-size:13px;color:var(--text)}.torre-card-footer{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-light);display:flex;justify-content:flex-end}.torre-new{animation:flash 2s infinite}.integration-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);padding:20px;display:flex;flex-direction:column;gap:16px;transition:all var(--transition);position:relative;overflow:hidden}.integration-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--brand)}.int-logo-area{height:60px;display:flex;align-items:center;margin-bottom:4px}.int-logo-area img{max-height:100%;max-width:140px;object-fit:contain}.int-body{flex-grow:1}.int-body h4{margin:0 0 6px;font-size:16px;font-weight:700}.int-body p{margin:0;font-size:13px;color:var(--muted);line-height:1.4}.int-actions{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:16px;border-top:1px solid var(--border-light)}@keyframes flash{0%,100%{border-color:var(--brand)}50%{border-color:transparent}}
.torre-card-footer{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-light);display:flex;justify-content:flex-end}.torre-new{animation:flash 2s infinite}.integration-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);padding:20px;display:flex;flex-direction:column;gap:16px;transition:all var(--transition);position:relative;overflow:hidden}.integration-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--brand)}.int-logo-area{height:60px;display:flex;align-items:center;margin-bottom:4px}.int-logo-area img{max-height:100%;max-width:140px;object-fit:contain}.int-body{flex-grow:1}.int-body h4{margin:0 0 6px;font-size:16px;font-weight:700}.int-body p{margin:0;font-size:13px;color:var(--muted);line-height:1.4}.int-actions{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:16px;border-top:1px solid var(--border-light)}@keyframes flash{0%,100%{border-color:var(--brand)}50%{border-color:transparent}}
/* Futuristic Dashboard Styles (Light Theme) */
.futuristic-dashboard {
  --neon-primary: #dc3545; /* Brand Red */
  --neon-secondary: #0d6efd; /* Blue Accent */
  --dark-bg: #f8f9fa;
  --card-bg: #ffffff;
  --text-main: #212529;
  --text-muted: #6c757d;
  background: linear-gradient(180deg, #fdfdff, #f8f9fa);
  padding: 24px;
  border-radius: 24px;
  color: var(--text-main);
  box-shadow: 0 10px 30px rgba(0,0,0,0.05);
  min-height: 85vh;
}
.futuristic-dashboard .welcome-header {
  margin-bottom: 32px;
  display: flex;
  justify-content: space-between;
  align-items: end;
}
.futuristic-dashboard h1 {
  font-size: 32px;
  font-weight: 800;
  color: var(--text-main);
  margin: 0;
  letter-spacing: -1px;
}
.futuristic-dashboard .date-display {
  color: var(--neon-primary);
  font-family: monospace;
  font-size: 14px;
  opacity: 0.8;
  font-weight: 600;
}
.fd-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 20px;
  margin-bottom: 24px;
}
.fd-card {
  background: var(--card-bg);
  border: 1px solid rgba(0,0,0,0.05);
  border-radius: 16px;
  padding: 20px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.03);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  position: relative;
  overflow: hidden;
}
.fd-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; width: 100%; height: 4px;
  background: linear-gradient(90deg, var(--neon-primary), var(--neon-secondary));
  opacity: 0;
  transition: opacity 0.3s;
}
.fd-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px -10px rgba(220, 53, 69, 0.15);
  border-color: rgba(220, 53, 69, 0.1);
}
.fd-card:hover::before { opacity: 1; }
.fd-card h3 {
  color: var(--text-muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin: 0 0 12px 0;
  font-weight: 700;
}
.fd-value {
  font-size: 36px;
  font-weight: 800;
  color: var(--text-main);
}
.fd-chart-container {
  background: var(--card-bg);
  border-radius: 16px;
  padding: 24px;
  border: 1px solid rgba(0,0,0,0.05);
  box-shadow: 0 4px 12px rgba(0,0,0,0.03);
  height: 350px;
  position: relative;
}
.fd-row {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 24px;
  margin-bottom: 24px;
}
@media (max-width: 900px) { .fd-row { grid-template-columns: 1fr; } }
.fd-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.fd-list-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid rgba(0,0,0,0.05);
}
.fd-list-item:last-child { border-bottom: none; }
.fd-list-item .item-main { display: flex; gap: 12px; align-items: center; }
.fd-icon {
  width: 32px; height: 32px;
  background: rgba(220, 53, 69, 0.1);
  border-radius: 8px;
  display: grid;
  place-items: center;
  font-size: 16px;
}
.fd-text { color: var(--text-main); font-weight: 600; font-size: 14px; }
.fd-sub { color: var(--text-muted); font-size: 12px; }

/* Flex modal (Nuevo Envío) */
.modal-overlay{position:fixed;inset:0;z-index:3000;display:grid;place-items:center;background:rgba(15,23,42,.3);backdrop-filter:blur(4px)}
.modal-overlay.hidden{display:none!important}
.modal-content{width:min(560px,92vw);max-height:85vh;display:flex;flex-direction:column;overflow:hidden;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}
.modal-header h3{margin:0;font-size:16px;font-weight:800}
.close-btn{all:unset;cursor:pointer;font-size:22px;line-height:1;padding:6px 10px;border-radius:var(--radius-sm)}
.close-btn:hover{background:var(--border)}
.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:12px 16px;border-top:1px solid var(--border)}
.inp-grp{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.inp-grp label{font-weight:700;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.clean-inp{width:100%;border-radius:var(--radius-sm);border:1px solid var(--border);padding:10px;font-size:14px;background:#fff}
.clean-inp:focus{outline:0;border-color:var(--brand);box-shadow:var(--focus-ring)}
.btn-accent{all:unset;box-sizing:border-box;cursor:pointer;background:linear-gradient(180deg,var(--brand),var(--brand-2));color:#fff;padding:10px 14px;border-radius:var(--radius-md);font-weight:800;text-align:center;transition:all var(--transition);display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 12px -3px rgba(220,53,69,.4)}
.btn-accent:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 7px 15px -4px rgba(220,53,69,.4)}
.btn-accent.full{width:100%}
