:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}html,body{margin:0;padding:0;min-width:320px;height:100%;overflow:hidden}#root{height:100%;padding:0;margin:0;max-width:none}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-page{height:100vh;min-height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fff,#fff5f5,#ffe5e5);padding:1rem;overflow:hidden;box-sizing:border-box}.login-container{width:100%;max-width:340px;text-align:center;margin:0 auto;padding:1.25rem}.login-title{margin:0 0 .25rem;font-size:1.75rem;font-weight:700;color:#b91c1c;letter-spacing:-.02em}.login-subtitle{margin:0 0 1.75rem;font-size:.9375rem;color:#991b1b;opacity:.85}.login-error{margin-bottom:1rem;padding:.625rem .875rem;font-size:.875rem;font-weight:500;color:#7f1d1d;background:#fef2f2;border:2px solid #fecaca;border-radius:.75rem}.login-form{display:flex;flex-direction:column;gap:.875rem;text-align:left}.login-field{display:flex;flex-direction:column;gap:.5rem}.login-field label{font-size:.875rem;font-weight:600;color:#7f1d1d}.login-field input{width:100%;padding:.5rem .875rem;font-size:.9375rem;font-family:inherit;color:#1f2937;background-color:#fff;border:2px solid #fecaca;border-radius:9999px;box-sizing:border-box;outline:none;transition:border-color .2s,background-color .2s}.login-field input::placeholder{color:#9ca3af}.login-field input:hover{border-color:#f87171}.login-field input:focus{border-color:#dc2626;background-color:#fff}.login-button{margin-top:.25rem;padding:.5rem 1rem;font-size:.9375rem;font-weight:600;font-family:inherit;color:#fff;background-color:#b91c1c;border:2px solid #b91c1c;border-radius:9999px;cursor:pointer;transition:background-color .2s,border-color .2s}.login-button:hover{background-color:#991b1b;border-color:#991b1b}.login-button:focus{outline:none}.login-button:focus-visible{outline:2px solid #dc2626;outline-offset:2px}.dashboard-page{--dashboard-bg: linear-gradient(135deg, #ffffff 0%, #fff5f5 50%, #ffe5e5 100%);--dashboard-primary: #b91c1c;--dashboard-primary-hover: #991b1b;--dashboard-text: #7f1d1d;--dashboard-border: #fecaca;--dashboard-border-hover: #f87171}.dashboard-page{height:100vh;min-height:100vh;display:flex;flex-direction:column;background:var(--dashboard-bg);padding:0;box-sizing:border-box;position:relative;overflow:hidden}.dashboard-overlay{display:none;position:fixed;inset:0;background:#00000059;z-index:10;opacity:0;transition:opacity .25s ease}.dashboard-overlay--visible{display:block;opacity:1}.dashboard-sidebar{position:fixed;top:0;left:0;width:260px;height:100vh;background:#fff;border-right:2px solid var(--dashboard-border);box-shadow:4px 0 12px #b91c1c14;z-index:20;display:flex;flex-direction:column;transition:transform .25s ease}.dashboard-sidebar-avatar-wrap{flex-shrink:0;width:44px;height:44px;border-radius:50%;overflow:hidden;background:var(--dashboard-border)}.dashboard-sidebar-avatar{width:100%;height:100%;object-fit:cover;display:block}.dashboard-sidebar-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;color:var(--dashboard-primary);background:#fff5f5}.dashboard-sidebar-back{display:none;align-items:center;justify-content:center;width:40px;height:40px;min-width:40px;min-height:40px;padding:0;margin-left:auto;color:var(--dashboard-text);background:transparent;border:none;border-radius:50%;cursor:pointer;transition:background-color .2s,color .2s;flex-shrink:0}.dashboard-sidebar-back:hover{background:#fff5f5;color:var(--dashboard-primary)}.dashboard-sidebar-nav{padding:1rem 0;display:flex;flex-direction:column;gap:.25rem}.dashboard-sidebar-link{display:block;padding:.625rem 1.25rem;font-size:.9375rem;font-weight:600;color:var(--dashboard-text);text-decoration:none;transition:background-color .2s,color .2s;border-left:3px solid transparent;margin-left:0}.dashboard-sidebar-link:hover{background:#fff5f5;color:var(--dashboard-primary)}.dashboard-sidebar-link--active{color:var(--dashboard-primary);background:#fff5f5;border-left-color:var(--dashboard-primary)}.dashboard-sidebar-user-block{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem 1rem;border-bottom:1px solid var(--dashboard-border);background:#fffbfb;flex-shrink:0}.dashboard-sidebar-user-info{flex:1;min-width:0}.dashboard-sidebar-greeting{margin:0 0 .25rem;font-size:.9375rem;font-weight:700;color:var(--dashboard-primary)}.dashboard-sidebar-greeting--truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.dashboard-sidebar-user-nivel{margin:0;font-size:.8125rem;color:var(--dashboard-text);opacity:.85}.dashboard-sidebar-footer{margin-top:auto;padding:1rem 1.25rem 1.25rem;border-top:1px solid var(--dashboard-border);background:#fffbfb}.dashboard-sidebar-logout{width:100%;padding:.5rem 1rem;font-size:.875rem;font-weight:600;font-family:inherit;color:var(--dashboard-primary);background:#fff;border:2px solid var(--dashboard-border);border-radius:9999px;cursor:pointer;transition:background-color .2s,border-color .2s,color .2s}.dashboard-sidebar-logout:hover{background:#fef2f2;border-color:var(--dashboard-border-hover);color:var(--dashboard-primary-hover)}.dashboard-logout-modal-overlay{position:fixed;inset:0;background:#0006;z-index:50;display:flex;align-items:center;justify-content:center;padding:1rem;box-sizing:border-box}.dashboard-logout-modal{background:#fff;border:2px solid var(--dashboard-border);border-radius:1rem;padding:1.5rem;max-width:340px;width:100%;box-shadow:0 8px 24px #b91c1c1f}.dashboard-logout-modal-title{margin:0 0 .75rem;font-size:1.25rem;font-weight:700;color:var(--dashboard-primary)}.dashboard-logout-modal-text{margin:0 0 1.25rem;font-size:.9375rem;color:var(--dashboard-text);line-height:1.5}.dashboard-logout-modal-text--small{margin-bottom:.75rem;font-size:.8125rem;color:#6b7280}.dashboard-modal-password-default .dashboard-logout-modal-actions{flex-wrap:wrap}.dashboard-logout-modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.dashboard-logout-modal-btn{padding:.5rem 1rem;font-size:.875rem;font-weight:600;font-family:inherit;border-radius:9999px;cursor:pointer;transition:background-color .2s,border-color .2s,color .2s}.dashboard-logout-modal-btn--cancel{color:var(--dashboard-text);background:#fff;border:2px solid var(--dashboard-border)}.dashboard-logout-modal-btn--cancel:hover{background:#fff5f5;border-color:var(--dashboard-border-hover);color:var(--dashboard-primary)}.dashboard-logout-modal-btn--confirm{color:#fff;background:var(--dashboard-primary);border:2px solid var(--dashboard-primary)}.dashboard-logout-modal-btn--confirm:hover{background:var(--dashboard-primary-hover);border-color:var(--dashboard-primary-hover)}.dashboard-main{flex:1;min-height:0;margin-left:260px;padding:1.5rem 1.25rem 5rem;overflow-y:auto;-webkit-overflow-scrolling:touch}.dashboard-header{margin-bottom:1rem}.dashboard-main-title{margin:0;font-size:1.5rem;font-weight:700;color:var(--dashboard-primary);letter-spacing:-.02em}.dashboard-content{background:#fff;border:2px solid var(--dashboard-border);border-radius:1rem;padding:1.5rem;color:var(--dashboard-text)}.dashboard-welcome{margin:0;font-size:.9375rem;line-height:1.5;opacity:.9}.dashboard-bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:56px;background:#fff;border-top:1px solid var(--dashboard-border);box-shadow:0 -2px 8px #b91c1c0d;z-index:30;align-items:center;justify-content:space-around;padding:0 .5rem;padding-bottom:env(safe-area-inset-bottom,0);box-sizing:border-box}.dashboard-bottom-link{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;padding:.35rem .75rem;font-size:.6875rem;font-weight:600;color:var(--dashboard-text);text-decoration:none;background:transparent;border:none;cursor:pointer;font-family:inherit;border-radius:9999px;transition:background-color .2s,color .2s;min-width:56px;flex:1;max-width:100px}.dashboard-bottom-link:hover{background:#fff5f5;color:var(--dashboard-primary)}.dashboard-bottom-link--active{color:var(--dashboard-primary);background:#fff5f5}.dashboard-bottom-link--active .dashboard-bottom-icon{color:var(--dashboard-primary)}.dashboard-bottom-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;line-height:1;color:inherit;flex-shrink:0}.dashboard-bottom-icon svg{width:20px;height:20px;flex-shrink:0}@media(max-width:768px){.dashboard-sidebar{transform:translate(-100%);box-shadow:4px 0 20px #0000001f;box-sizing:border-box}.dashboard-sidebar--open{transform:translate(0);z-index:35}.dashboard-sidebar-back{display:flex}.dashboard-main{margin-left:0;padding-bottom:4.25rem}.dashboard-bottom-nav{display:flex}}@media(min-width:769px){.dashboard-overlay{display:none!important}.dashboard-sidebar{transform:none}.dashboard-sidebar-back{display:none}.dashboard-main{padding-bottom:1.5rem}.dashboard-bottom-nav{display:none}}.inicio-welcome{margin-bottom:1.5rem}.inicio-loading{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2rem;color:var(--dashboard-text)}.inicio-loading .usuarios-loading-spinner{width:32px;height:32px;border:3px solid var(--dashboard-border);border-top-color:var(--dashboard-primary);border-radius:50%;animation:inicio-spin .8s linear infinite}@keyframes inicio-spin{to{transform:rotate(360deg)}}.inicio-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:2rem}.inicio-stat-card{background:#fff;border:2px solid var(--dashboard-border);border-radius:1rem;padding:1.25rem;box-shadow:0 2px 12px #b91c1c0f;display:flex;flex-direction:column;align-items:center;text-align:center}.inicio-stat-card--wide{grid-column:1 / -1;align-items:stretch;text-align:left}.inicio-stat-card--nivel{background:linear-gradient(135deg,#fffbfb,#fff5f5);border-color:var(--dashboard-border-hover)}.inicio-nivel-title{margin:0 0 .25rem;font-size:1.0625rem;font-weight:700;color:var(--dashboard-primary)}.inicio-nivel-desc{margin:0 0 1rem;font-size:.8125rem;color:var(--dashboard-text);opacity:.9}.inicio-stat-value{font-size:2rem;font-weight:700;color:var(--dashboard-primary);line-height:1.2}.inicio-stat-label{font-size:.875rem;color:var(--dashboard-text);margin-top:.25rem}.inicio-stat-card--wide .inicio-stat-label{margin-top:0;margin-bottom:.5rem}.inicio-nivel-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.inicio-nivel-row{display:grid;grid-template-columns:minmax(100px,auto) 1fr minmax(70px,auto);align-items:center;gap:.75rem 1rem}.inicio-nivel-name{font-size:.9375rem;font-weight:600;color:var(--dashboard-text)}.inicio-nivel-bar-wrap{height:8px;background:var(--dashboard-border);border-radius:9999px;overflow:hidden;min-width:0}.inicio-nivel-bar{display:block;height:100%;min-width:4px;background:var(--dashboard-primary);border-radius:9999px;transition:width .3s ease}.inicio-nivel-count{font-size:.875rem;font-weight:600;color:var(--dashboard-primary);text-align:right;white-space:nowrap}@media(max-width:380px){.inicio-nivel-row{grid-template-columns:1fr auto;gap:.35rem .75rem}.inicio-nivel-bar-wrap{grid-column:1 / -1}}.inicio-charts{display:grid;grid-template-columns:1fr;gap:2rem}@media(min-width:900px){.inicio-charts{grid-template-columns:1.2fr 1fr}}.inicio-chart-block{background:#fff;border:2px solid var(--dashboard-border);border-radius:1rem;padding:1.25rem;box-shadow:0 2px 12px #b91c1c0f}.inicio-chart-title{font-size:1rem;font-weight:600;color:var(--dashboard-primary);margin:0 0 1rem}.inicio-chart-wrap{min-height:260px}.inicio-chart-wrap--bar{width:100%}.inicio-chart-wrap--pie{display:flex;justify-content:center;align-items:center}.usuarios-page{--dashboard-primary: #b91c1c;--dashboard-primary-hover: #991b1b;--dashboard-text: #7f1d1d;--dashboard-border: #fecaca;--dashboard-border-hover: #f87171}.usuarios-page{width:100%;max-width:720px;margin:0 auto}.usuarios-header{margin-bottom:1.25rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}.usuarios-header-text{min-width:0}.usuarios-title{margin:0 0 .25rem;font-size:1.5rem;font-weight:700;color:var(--dashboard-primary);letter-spacing:-.02em}.usuarios-subtitle{margin:0;font-size:.875rem;color:var(--dashboard-text);opacity:.9}.usuarios-btn-crear{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;font-family:inherit;color:#fff;background:var(--dashboard-primary);border:2px solid var(--dashboard-primary);border-radius:9999px;cursor:pointer;transition:background-color .2s,border-color .2s;flex-shrink:0}.usuarios-btn-crear:hover{background:var(--dashboard-primary-hover);border-color:var(--dashboard-primary-hover)}.usuarios-btn-crear-icon{display:flex;align-items:center;justify-content:center}.usuarios-toast{position:fixed;bottom:5rem;left:50%;transform:translate(-50%);padding:.625rem 1rem;background:var(--dashboard-primary);color:#fff;font-size:.875rem;font-weight:600;border-radius:9999px;box-shadow:0 4px 12px #b91c1c59;z-index:60;animation:usuarios-toast-in .25s ease}@keyframes usuarios-toast-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.usuarios-content{background:#fff;border:2px solid var(--dashboard-border);border-radius:1rem;padding:1rem;min-height:200px}.usuarios-filtros{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.75rem 1.25rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--dashboard-border)}.usuarios-filtro-label{display:flex;flex-direction:column;gap:.25rem;min-width:0}.usuarios-filtro-text{font-size:.8125rem;font-weight:600;color:var(--dashboard-text)}.usuarios-filtro-input{width:100%;min-width:200px;max-width:280px;padding:.5rem .75rem;font-size:.875rem;font-family:inherit;border:2px solid var(--dashboard-border);border-radius:.5rem;color:var(--dashboard-text);background:#fff}.usuarios-filtro-input:focus{outline:none;border-color:var(--dashboard-primary)}.usuarios-filtro-input::placeholder{color:var(--dashboard-text);opacity:.7}.usuarios-filtro-buscar-wrap{position:relative;display:block;width:100%;min-width:0}.usuarios-filtro-input--con-clear{padding-right:2.25rem;box-sizing:border-box}.usuarios-filtro-clear-busqueda{position:absolute;right:.375rem;top:50%;transform:translateY(-50%);padding:.35rem;border:none;background:transparent;cursor:pointer;color:var(--dashboard-text);border-radius:.375rem;display:flex;align-items:center;justify-content:center;transition:color .2s,background-color .2s}.usuarios-filtro-clear-busqueda:hover{color:var(--dashboard-primary);background:#b91c1c14}.usuarios-filtro-clear-busqueda:focus{outline:none;color:var(--dashboard-primary);background:#b91c1c1f}.usuarios-filtro-select{min-width:160px;padding:.5rem .75rem;font-size:.875rem;font-family:inherit;border:2px solid var(--dashboard-border);border-radius:.5rem;color:var(--dashboard-text);background:#fff;cursor:pointer}.usuarios-filtro-select:focus{outline:none;border-color:var(--dashboard-primary)}.usuarios-filtro-btn-fecha{display:inline-flex;align-items:center;gap:.5rem;width:100%;min-width:0;padding:.5rem .75rem;font-size:.875rem;font-family:inherit;font-weight:500;color:var(--dashboard-text);background:#fff;border:2px solid var(--dashboard-border);border-radius:.5rem;cursor:pointer;transition:border-color .2s,background-color .2s;text-align:left}.usuarios-filtro-btn-fecha:hover{border-color:var(--dashboard-border-hover);background:snow}.usuarios-filtro-btn-fecha:focus{outline:none;border-color:var(--dashboard-primary)}.usuarios-filtro-btn-fecha-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.usuarios-filtro-btn-fecha-icon{flex-shrink:0;opacity:.8}.usuarios-modal--filtro-fecha .usuarios-filtro-fecha-desc{margin:0 0 1rem;font-size:.875rem;color:var(--dashboard-text);opacity:.9}.usuarios-filtro-fecha-campos{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.25rem}.usuarios-filtro-fecha-campos .usuarios-create-input{width:100%;box-sizing:border-box}@media(max-width:480px){.usuarios-filtros{flex-direction:column;align-items:stretch}.usuarios-filtro-label{width:100%;flex:1 1 100%}.usuarios-filtro-input,.usuarios-filtro-input--date{min-width:0;max-width:none;width:100%;box-sizing:border-box}.usuarios-filtro-select{min-width:0;width:100%;max-width:none;box-sizing:border-box}.usuarios-filtro-btn-fecha,.usuarios-filtro-btn-limpiar{width:100%}}.usuarios-filtro-btn-limpiar{padding:.5rem 1rem;font-size:.875rem;font-weight:600;font-family:inherit;color:var(--dashboard-text);background:#fff;border:2px solid var(--dashboard-border);border-radius:.5rem;cursor:pointer;transition:border-color .2s,background-color .2s;white-space:nowrap}.usuarios-filtro-btn-limpiar:hover{border-color:var(--dashboard-border-hover);background:snow}.usuarios-filtro-btn-limpiar:focus{outline:none;border-color:var(--dashboard-primary)}.usuarios-filtro-text--hidden{visibility:hidden;margin:0;padding:0;min-height:1.2em;font-size:.8125rem}.usuarios-filtro-label--btn{justify-content:flex-end}.usuarios-paginacion-bar{display:flex;flex-wrap:nowrap;align-items:center;gap:.5rem .75rem;margin-top:.75rem;padding-top:.625rem;border-top:1px solid var(--dashboard-border);min-width:0}.usuarios-paginacion-info{font-size:.8125rem;color:var(--dashboard-text);white-space:nowrap;flex-shrink:0}.usuarios-paginacion-label{display:inline-flex;align-items:center;gap:.25rem;font-size:.8125rem;font-weight:600;color:var(--dashboard-text);flex-shrink:0}.usuarios-paginacion-label-text{white-space:nowrap}.usuarios-paginacion-select{padding:.25rem .4rem;font-size:.8125rem;font-family:inherit;color:var(--dashboard-text);border:1px solid var(--dashboard-border);border-radius:.375rem;background:#fff;cursor:pointer;min-width:2.5rem}.usuarios-paginacion-select:focus{outline:none;border-color:var(--dashboard-primary)}.usuarios-paginacion-btns{display:flex;flex-wrap:nowrap;align-items:center;gap:.25rem;margin-left:auto;flex-shrink:0}.usuarios-paginacion-num{font-size:.75rem;color:var(--dashboard-text);padding:0 .35rem;white-space:nowrap}.usuarios-paginacion-btn{padding:.25rem .4rem;font-size:.75rem;font-weight:600;font-family:inherit;color:var(--dashboard-primary);background:#fff;border:1px solid var(--dashboard-border);border-radius:.375rem;cursor:pointer;transition:background-color .2s,border-color .2s,color .2s;line-height:1.2;min-width:1.75rem}.usuarios-paginacion-btn:hover:not(:disabled){background:#fff5f5;border-color:var(--dashboard-border-hover)}.usuarios-paginacion-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:420px){.usuarios-paginacion-bar{gap:.4rem .5rem;font-size:.75rem}.usuarios-paginacion-info{font-size:.75rem}.usuarios-paginacion-num{font-size:.6875rem}}.usuarios-loading,.usuarios-error,.usuarios-empty,.usuarios-sin-resultados{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2rem;text-align:center;color:var(--dashboard-text);font-size:.9375rem}.usuarios-sin-resultados{margin:0;padding:1rem 0}.usuarios-loading-spinner{width:32px;height:32px;border:3px solid var(--dashboard-border);border-top-color:var(--dashboard-primary);border-radius:50%;animation:usuarios-spin .8s linear infinite}@keyframes usuarios-spin{to{transform:rotate(360deg)}}.usuarios-error{color:var(--dashboard-primary)}.usuarios-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.usuarios-list-item{margin:0}.user-card{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1rem;background:#fffbfb;border:1px solid var(--dashboard-border);border-radius:.75rem;transition:border-color .2s,box-shadow .2s}.user-card:hover{border-color:var(--dashboard-border-hover);box-shadow:0 2px 8px #b91c1c0f}.user-card-main{display:flex;align-items:flex-start;gap:.875rem;min-width:0;flex:1}.user-card-avatar{width:44px;height:44px;min-width:44px;min-height:44px;border-radius:50%;background:linear-gradient(135deg,var(--dashboard-primary) 0%,var(--dashboard-primary-hover) 100%);color:#fff;font-size:1.125rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.user-card-avatar-btn{width:100%;height:100%;padding:0;margin:0;border:none;border-radius:50%;background:none;cursor:pointer;display:block;overflow:hidden}.user-card-avatar-btn:focus{outline:2px solid var(--dashboard-primary);outline-offset:2px}.user-card-avatar-img{width:100%;height:100%;object-fit:cover;display:block}.user-card-avatar-letter{display:block}.user-card-info{min-width:0;flex:1}.user-card-name{margin:0 0 .2rem;font-size:1rem;font-weight:700;color:var(--dashboard-text);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-card-doc{margin:0 0 .35rem;font-size:.8125rem;color:var(--dashboard-text);opacity:.85}.user-card-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem;font-size:.8125rem;color:var(--dashboard-text);opacity:.9}.user-card-creado-por{margin:.35rem 0 0;font-size:.75rem;color:var(--dashboard-text);opacity:.8}.user-card-nivel--admin .user-card-badge{display:inline-block;padding:.2rem .5rem;background:var(--dashboard-primary);color:#fff;font-weight:600;font-size:.75rem;border-radius:9999px}.user-card-estado{padding:.15rem .45rem;border-radius:9999px;font-weight:600;font-size:.75rem}.user-card-estado--activo{background:#dcfce7;color:#166534}.user-card-estado--inactivo{background:#fee2e2;color:#b91c1c}.user-card-actions{position:relative;flex-shrink:0}.user-card-menu-trigger{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:none;background:transparent;color:var(--dashboard-text);border-radius:50%;cursor:pointer;transition:background-color .2s,color .2s}.user-card-menu-trigger:hover{background:#fff5f5;color:var(--dashboard-primary)}.user-card-floating-menu{position:absolute;top:100%;right:0;margin-top:.25rem;min-width:160px;padding:.35rem;background:#fff;border:2px solid var(--dashboard-border);border-radius:.5rem;box-shadow:0 8px 24px #b91c1c1f;z-index:40;animation:usuarios-menu-in .2s ease}@keyframes usuarios-menu-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.user-card-menu-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .65rem;font-size:.875rem;font-weight:500;font-family:inherit;color:var(--dashboard-text);background:transparent;border:none;border-radius:.35rem;cursor:pointer;text-align:left;transition:background-color .2s,color .2s}.user-card-menu-item:hover{background:#fff5f5;color:var(--dashboard-primary)}.user-card-menu-item--danger:hover{background:#fef2f2;color:#dc2626}.user-card-menu-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.usuarios-modal-overlay{position:fixed;inset:0;background:#0006;z-index:50;display:flex;align-items:center;justify-content:center;padding:1rem;box-sizing:border-box}.usuarios-modal{background:#fff;border:2px solid var(--dashboard-border);border-radius:1rem;padding:1.5rem;max-width:380px;width:100%;box-shadow:0 8px 24px #b91c1c1f}.usuarios-modal-title{margin:0 0 1rem;font-size:1.25rem;font-weight:700;color:var(--dashboard-primary)}.usuarios-modal-dl{margin:0 0 1.25rem;font-size:.9375rem;color:var(--dashboard-text)}.usuarios-modal-dl dt{margin-top:.5rem;font-weight:600;color:var(--dashboard-primary)}.usuarios-modal-photo-wrap{margin:0 0 1rem;display:flex;justify-content:center}.usuarios-modal-photo{width:96px;height:96px;border-radius:50%;object-fit:cover;border:2px solid var(--dashboard-border)}.usuarios-modal-overlay--photo{background:#0009}.usuarios-modal--photo{max-width:min(420px,92vw);text-align:center}.usuarios-modal-title--photo{margin-bottom:.75rem}.usuarios-modal-photo-wrap--large{margin-bottom:1.25rem;border-radius:.75rem;overflow:hidden;background:#fafafa;border:2px solid var(--dashboard-border)}.usuarios-modal-photo--large{width:100%;max-width:320px;height:auto;max-height:70vh;border-radius:0;border:none;display:block;margin:0 auto}.usuarios-modal-dl dt:first-child{margin-top:0}.usuarios-modal-dl dd{margin:.15rem 0 0}.usuarios-modal--info{max-width:380px}.usuarios-modal-info-body{display:flex;flex-direction:column}.usuarios-modal-dl--info .usuarios-modal-dl-group{margin-top:.5rem}.usuarios-modal-dl--info .usuarios-modal-dl-group:first-child{margin-top:0}.usuarios-modal-dl--info .usuarios-modal-dl-group dt{margin-top:0;margin-bottom:.15rem}@media(min-width:768px){.usuarios-modal--info{max-width:560px}.usuarios-modal-info-body{display:grid;grid-template-columns:auto 1fr;gap:1rem 2rem;align-items:start}.usuarios-modal--info .usuarios-modal-photo-wrap{margin:0;grid-row:1 / -1}.usuarios-modal-dl--info{display:grid;grid-template-columns:1fr 1fr;gap:.5rem 1.5rem;margin:0;min-width:0}.usuarios-modal-dl--info .usuarios-modal-dl-group{margin:0;min-width:0}}.usuarios-modal-text{margin:0 0 1.25rem;font-size:.9375rem;color:var(--dashboard-text);line-height:1.5}.usuarios-modal-btn{padding:.5rem 1rem;font-size:.875rem;font-weight:600;font-family:inherit;color:#fff;background:var(--dashboard-primary);border:2px solid var(--dashboard-primary);border-radius:9999px;cursor:pointer;transition:background-color .2s,border-color .2s}.usuarios-modal-btn:hover{background:var(--dashboard-primary-hover);border-color:var(--dashboard-primary-hover)}.usuarios-modal--create{max-width:420px}.usuarios-create-form{display:flex;flex-direction:column;gap:1rem}.usuarios-create-label{display:flex;flex-direction:column;gap:.35rem;font-size:.875rem;font-weight:600;color:var(--dashboard-text)}.usuarios-create-required{color:var(--dashboard-primary)}.usuarios-create-input,.usuarios-create-select{padding:.5rem .75rem;font-size:.9375rem;font-family:inherit;color:var(--dashboard-text);border:2px solid var(--dashboard-border);border-radius:.5rem;background:#fff;transition:border-color .2s}.usuarios-create-input:focus,.usuarios-create-select:focus{outline:none;border-color:var(--dashboard-primary)}.usuarios-create-photo-wrap{position:relative;border:2px dashed var(--dashboard-border);border-radius:.5rem;padding:.75rem 1rem;background:#fffbfb;transition:border-color .2s,background-color .2s}.usuarios-create-photo-wrap:hover{border-color:var(--dashboard-border-hover);background:#fff5f5}.usuarios-create-file{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer;font-size:0}.usuarios-create-photo-text{display:block;font-size:.875rem;color:var(--dashboard-text);pointer-events:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.usuarios-modal-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:flex-end;margin-top:.5rem}.usuarios-modal-btn--cancel{background:transparent;color:var(--dashboard-primary);border-color:var(--dashboard-border)}.usuarios-modal-btn--cancel:hover{background:#fff5f5;border-color:var(--dashboard-border-hover)}.usuarios-modal-btn--danger{background:#dc2626;border-color:#dc2626;color:#fff}.usuarios-modal-btn--danger:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c}.usuarios-modal-btn:disabled{opacity:.7;cursor:not-allowed}.usuarios-create-label--row{flex-direction:row;align-items:center;gap:.5rem}.usuarios-create-label--row input[type=checkbox]{width:auto}.usuarios-modal--permisos{max-width:440px}.usuarios-modal-text--user{margin-bottom:.75rem}.usuarios-modal-text--small{font-size:.875rem;margin-bottom:1rem;color:var(--dashboard-text);opacity:.9}.usuarios-modal-actions--column{flex-direction:column;align-items:stretch}.usuarios-modal-btn--whatsapp{background:#25d366;border-color:#25d366;color:#fff}.usuarios-modal-btn--whatsapp:hover{background:#20bd5a;border-color:#20bd5a}.usuarios-modal--success,.usuarios-modal--password{max-width:400px}.usuarios-permisos-resumen{margin:0 0 1rem;padding:.75rem 1rem;background:#fffbfb;border:1px solid var(--dashboard-border);border-radius:.5rem;font-size:.9375rem;color:var(--dashboard-text)}.usuarios-permisos-resumen p{margin:.25rem 0}.usuarios-permisos-historial{margin:0 0 1rem}.usuarios-permisos-historial-title{margin:0 0 .5rem;font-size:.9375rem;font-weight:700;color:var(--dashboard-text)}.usuarios-permisos-sin-historial{margin:0;font-size:.875rem;color:var(--dashboard-text);opacity:.85}.usuarios-permisos-lista{margin:0;padding:0;list-style:none;max-height:160px;overflow-y:auto;border:1px solid var(--dashboard-border);border-radius:.5rem;background:#fff}.usuarios-permisos-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.875rem;color:var(--dashboard-text);border-bottom:1px solid var(--dashboard-border)}.usuarios-permisos-item:last-child{border-bottom:none}.usuarios-permisos-item-cant{flex-shrink:0;font-weight:700;color:var(--dashboard-primary)}.usuarios-permisos-item-info{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.usuarios-permisos-form{margin-top:.5rem}.usuarios-permisos-form .usuarios-create-label{margin-bottom:.5rem}@media(max-width:640px){.usuarios-header{position:relative;padding-right:0;align-items:flex-start}.usuarios-header-text{padding-right:6.5rem;min-width:0}.usuarios-btn-crear{position:absolute;top:0;right:0}}@media(max-width:480px){.user-card{flex-direction:column;align-items:stretch;gap:.75rem}.user-card-actions{align-self:flex-end}.user-card-floating-menu{right:0;left:auto}}.mi-info-content .mi-info-grid{display:block}@media(min-width:769px){.mi-info-content .mi-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}}.mi-info-card{max-width:420px;padding:1.5rem;background:#fff;border:2px solid var(--dashboard-border);border-radius:1rem;box-shadow:0 2px 12px #b91c1c0f}@media(min-width:769px){.mi-info-content .mi-info-card{max-width:none}}.mi-info-photo-wrap{margin:0 0 1rem;display:flex;justify-content:center}.mi-info-photo{width:96px;height:96px;border-radius:50%;object-fit:cover;border:2px solid var(--dashboard-border)}.mi-info-dl{margin:0;font-size:.9375rem;color:var(--dashboard-text)}.mi-info-dl dt{margin-top:.5rem;font-weight:600;color:var(--dashboard-primary)}.mi-info-dl dt:first-of-type{margin-top:0}.mi-info-dl dd{margin:.15rem 0 0}.mi-info-password-card{margin-top:1.5rem;max-width:420px}@media(min-width:769px){.mi-info-password-card{max-width:none}}.mi-info-password-title{margin:0 0 .5rem;font-size:1.125rem;font-weight:700;color:var(--dashboard-primary)}.mi-info-password-desc{margin:0 0 1rem;font-size:.9375rem;color:var(--dashboard-text);line-height:1.5}.mi-info-password-msg{margin-bottom:1rem;padding:.5rem .75rem;border-radius:.5rem;font-size:.875rem;font-weight:500}.mi-info-password-msg--ok{background:#dcfce7;color:#166534;border:1px solid #86efac}.mi-info-password-msg--error{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca}.mi-info-password-form{display:flex;flex-direction:column;gap:.75rem;max-width:320px}.mi-info-password-label{display:flex;flex-direction:column;gap:.25rem;font-size:.875rem;font-weight:600;color:var(--dashboard-text)}.mi-info-password-input{padding:.5rem .75rem;font-size:.9375rem;font-family:inherit;border:2px solid var(--dashboard-border);border-radius:.5rem;color:var(--dashboard-text);background:#fff}.mi-info-password-input:focus{outline:none;border-color:var(--dashboard-primary)}.mi-info-password-input:disabled{opacity:.8;cursor:not-allowed}.mi-info-password-btn{align-self:flex-start;padding:.5rem 1.25rem;font-size:.9375rem;font-weight:600;font-family:inherit;color:#fff;background:var(--dashboard-primary);border:2px solid var(--dashboard-primary);border-radius:9999px;cursor:pointer;transition:background-color .2s,border-color .2s}.mi-info-password-btn:hover:not(:disabled){background:var(--dashboard-primary-hover);border-color:var(--dashboard-primary-hover)}.mi-info-password-btn:disabled{opacity:.7;cursor:not-allowed}
