/* Login overlay + splash spinner */
.login-overlay{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}
.login-stack{display:flex;flex-direction:column;align-items:stretch;gap:24px;max-width:380px;width:100%}
.login-stack .login-card{max-width:none}
.login-stack .site-footer{margin-top:0}
.login-overlay[hidden]{display:none}
.login-card{max-width:380px;width:100%;background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:32px;display:flex;flex-direction:column;gap:14px;box-shadow:0 6px 20px rgba(0,0,0,0.06);font-family:var(--font-sans)}
.login-card h2{font-size:22px;font-weight:600;letter-spacing:-0.01em;color:var(--text);margin:0}
.login-sub{font-size:13px;color:var(--text-2);margin:0 0 8px}
.login-card label{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:0.05em;font-weight:500;display:flex;flex-direction:column;gap:4px}
.login-card input{font-size:14px;padding:10px 12px;border-radius:8px;border:1px solid var(--border-strong);background:var(--panel);color:var(--text);font-family:inherit;text-transform:none;letter-spacing:normal}
.login-card input:focus{outline:2px solid var(--accent);outline-offset:-1px}
.login-card button{margin-top:8px;padding:10px 14px;background:var(--accent);color:var(--accent-text);border:0;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;font-family:inherit}
.login-error{color:var(--err);font-size:12px;min-height:16px}
.login-spinner{width:32px;height:32px;border:3px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;animation:spin 0.8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.wrap[data-pre-auth]{visibility:hidden}

/* Nav drawer (hamburguesa lateral izquierda) */
.nav-toggle{position:fixed;top:20px;left:20px;width:40px;height:40px;border-radius:10px;border:1px solid var(--border-strong);background:var(--panel);color:var(--text);cursor:pointer;z-index:60;display:flex;align-items:center;justify-content:center;font-family:inherit;box-shadow:0 2px 8px rgba(0,0,0,0.04);transition:background 0.15s}
.nav-toggle:hover{background:var(--panel-2)}
.nav-toggle[hidden]{display:none}

.nav-backdrop{position:fixed;inset:0;background:rgba(31,29,25,0.35);z-index:70;opacity:0;transition:opacity 0.2s;pointer-events:none}
.nav-backdrop.open{opacity:1;pointer-events:auto}
.nav-backdrop[hidden]{display:none}

.nav-drawer{position:fixed;top:0;bottom:0;left:0;width:min(280px,84vw);background:var(--panel);border-right:1px solid var(--border);box-shadow:8px 0 24px rgba(0,0,0,0.08);z-index:71;transform:translateX(-100%);transition:transform 0.25s ease;display:flex;flex-direction:column;font-family:var(--font-sans)}
.nav-drawer.open{transform:translateX(0)}
.nav-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid var(--border)}
.nav-header h2{font-size:16px;font-weight:600;letter-spacing:-0.01em;color:var(--text);margin:0}
.nav-close{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:var(--panel);color:var(--text-2);cursor:pointer;font-size:16px;line-height:1;padding:0;font-family:inherit;display:inline-flex;align-items:center;justify-content:center}
.nav-close:hover{background:var(--panel-2);color:var(--text)}
.nav-items{display:flex;flex-direction:column;padding:10px;gap:2px;flex:1}
.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border:0;background:transparent;border-radius:8px;cursor:pointer;font-size:14px;color:var(--text);font-family:inherit;text-align:left;font-weight:500}
.nav-item svg{flex-shrink:0;color:var(--text-2)}
.nav-item:hover:not([disabled]){background:var(--panel-2)}
.nav-item.active{background:var(--accent);color:var(--accent-text)}
.nav-item.active svg{color:var(--accent-text)}
.nav-item[disabled]{color:var(--text-3);cursor:not-allowed}
.nav-item[disabled] svg{color:#b6b0a2}
.nav-item span:first-of-type{flex:1}
.nav-badge{font-size:10px;text-transform:uppercase;letter-spacing:0.05em;background:var(--panel-2);color:var(--text-3);padding:2px 6px;border-radius:999px;font-weight:500}
.nav-footer{padding:10px;border-top:1px solid var(--border)}
.nav-logout{color:var(--err);width:100%}
.nav-logout svg{color:var(--err)}
.nav-logout:hover:not([disabled]){background:rgba(216,90,48,0.08)}

/* Drawer lateral derecho (genérico; lo usa el panel de detalles de cuenta) */
.drawer-backdrop{position:fixed;inset:0;background:rgba(31,29,25,0.35);z-index:50;opacity:0;transition:opacity 0.2s;pointer-events:none}
.drawer-backdrop.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;bottom:0;width:min(380px,92vw);background:var(--panel);border-left:1px solid var(--border);box-shadow:-8px 0 24px rgba(0,0,0,0.08);z-index:51;transform:translateX(100%);transition:transform 0.25s ease;display:flex;flex-direction:column}
.drawer.open{transform:translateX(0)}
.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}
.drawer-header h3{font-size:14px;font-weight:600;letter-spacing:-0.01em;color:var(--text);margin:0}
.drawer-body{padding:20px;display:flex;flex-direction:column;gap:14px;overflow-y:auto}

/* Contenido del drawer de detalles de cuenta */
.account-row{display:flex;flex-direction:column;gap:4px}
.account-row label{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:0.05em;font-weight:500}
.account-row input{font-size:14px;padding:8px 12px;height:38px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--panel);color:var(--text);font-family:inherit}
.account-row input:focus{outline:2px solid var(--accent);outline-offset:-1px}
.account-hint{font-size:12px;color:var(--text-3);margin:0}
.account-kind-tag{display:inline-block;font-size:11px;text-transform:uppercase;letter-spacing:0.06em;font-weight:500;color:var(--text-2);background:var(--panel-2);border:1px solid var(--border);border-radius:999px;padding:4px 12px;align-self:flex-start}
.drawer[data-kind="account"] .account-row[data-kind="credit_card"]{display:none}
.drawer[data-kind="credit_card"] .account-row[data-kind="account"]{display:none}
.drawer:not([data-kind]) .account-row[data-kind]{display:none}
.account-row input[readonly]{background:var(--panel-2);color:var(--text-2);cursor:not-allowed}

/* Toast (notificaciones de estado) */
.toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%,12px);z-index:100;padding:10px 16px;font-size:13px;font-weight:500;background:var(--accent);color:var(--accent-text);border-radius:10px;box-shadow:0 6px 20px rgba(0,0,0,0.18);max-width:calc(100vw - 32px);text-align:center;opacity:0;pointer-events:none;transition:opacity 0.2s, transform 0.2s;font-family:var(--font-sans)}
.toast.show{opacity:1;transform:translate(-50%,0)}
.toast[hidden]{display:none}
.toast.ok{background:var(--ok)}
.toast.err{background:var(--err)}
@media(max-width:640px){
  .toast{bottom:16px;font-size:12px;padding:9px 14px}
}

/* Dataset multi-select (popover con checkboxes) */
.dataset-multi{position:relative}
.dataset-multi-toggle{display:inline-flex;align-items:center;gap:8px;font-size:12px;padding:5px 10px;height:28px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--panel);color:var(--text-2);cursor:pointer;font-family:inherit;max-width:240px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dataset-multi-toggle:hover,.dataset-multi-toggle[aria-expanded="true"]{color:var(--text)}
.dataset-multi-toggle #dataset-label{overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1;text-align:left}
.dataset-multi-caret{font-size:10px;color:var(--text-3);flex-shrink:0}
.dataset-multi-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:240px;max-width:320px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:0 4px 12px rgba(0,0,0,0.08);padding:4px;z-index:40;display:flex;flex-direction:column;max-height:60vh;overflow-y:auto}
.dataset-multi-menu[hidden]{display:none}
.dataset-option{display:flex;align-items:center;gap:10px;padding:8px 10px;font-size:13px;color:var(--text);cursor:pointer;border-radius:var(--radius-sm);font-family:inherit;border:0;background:transparent;text-align:left;width:100%}
.dataset-option:hover{background:var(--panel-2)}
.dataset-option input[type=checkbox]{flex-shrink:0;accent-color:var(--accent);cursor:pointer}
.dataset-option span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Modal genérico (para upload form) */
.modal-backdrop{position:fixed;inset:0;background:rgba(31,29,25,0.45);z-index:200;opacity:0;transition:opacity 0.2s;pointer-events:none}
.modal-backdrop[hidden]{display:none}
.modal-backdrop.open{opacity:1;pointer-events:auto}
.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,calc(-50% + 12px));z-index:201;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 12px 40px rgba(0,0,0,0.18);max-width:420px;width:calc(100vw - 32px);opacity:0;transition:opacity 0.2s, transform 0.2s;font-family:var(--font-sans)}
.modal[hidden]{display:none}
.modal.open{opacity:1;transform:translate(-50%,-50%)}
.modal-header{padding:18px 20px 12px;border-bottom:1px solid var(--border)}
.modal-header h3{font-size:15px;font-weight:600;letter-spacing:-0.01em;color:var(--text);margin:0}
.modal-body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:14px}
.modal-hint{font-size:13px;color:var(--text-2);margin:0;line-height:1.5}
.modal-field{display:flex;flex-direction:column;gap:4px}
.modal-field[hidden]{display:none}
.modal-field label{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:0.05em;font-weight:500}
.modal-field input,.modal-field select{font-size:14px;padding:8px 12px;height:38px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--panel);color:var(--text);font-family:inherit}
.modal-field input:focus,.modal-field select:focus{outline:2px solid var(--accent);outline-offset:-1px}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}
