:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-neutral-50: #f8fafc;--color-neutral-100: #f1f5f9;--color-neutral-200: #e2e8f0;--color-neutral-300: #cbd5e1;--color-neutral-400: #94a3b8;--color-neutral-500: #64748b;--color-neutral-600: #475569;--color-neutral-700: #334155;--color-neutral-800: #1e293b;--color-neutral-900: #0f172a;--color-neutral-950: #020617;--color-secondary: #0f172a;--color-secondary-hover: #020617;--color-primary: #06b6d4;--color-primary-hover: #0891b2;--color-primary-active: #0e7490;--color-primary-muted: rgba(6, 182, 212, .15);--color-success: #16a34a;--color-success-muted: rgba(22, 163, 74, .12);--color-error: #dc2626;--color-danger: #dc2626;--color-danger-subtle: #e57373;--color-error-muted: rgba(220, 38, 38, .1);--color-warning: #f59e0b;--color-warning-muted: rgba(245, 158, 11, .12);--color-info: #2563eb;--color-info-muted: rgba(37, 99, 235, .1);--color-text: #0f172a;--color-text-muted: #475569;--color-text-muted-soft: #94a3b8;--color-bg: #f1f5f9;--color-bg-secondary: #f8fafc;--color-bg-surface: #ffffff;--color-bg-header: #ffffff;--color-bg-sidebar: #0f172a;--color-border: #e2e8f0;--color-sidebar-text: rgba(255, 255, 255, .65);--color-sidebar-text-hover: rgba(255, 255, 255, .92);--color-sidebar-text-active: #06b6d4;--color-sidebar-bg-hover: rgba(255, 255, 255, .06);--color-sidebar-bg-active: rgba(6, 182, 212, .12);--color-sidebar-border: rgba(255, 255, 255, .08);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 2.5rem;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.75rem;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--transition-fast: .15s ease;--transition-normal: .2s ease;--bp-mobile: 480px;--bp-tablet: 768px;--bp-desktop: 1024px}:root{color:var(--color-text);background-color:var(--color-bg)}a{font-weight:500;color:var(--color-primary);text-decoration:inherit}a:hover{color:var(--color-primary-hover)}body{margin:0;min-width:320px;min-height:100vh}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:var(--color-bg-surface);cursor:pointer;transition:border-color .2s,background-color .2s}button:hover{border-color:var(--color-primary)}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,a:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button:focus:not(:focus-visible),input:focus:not(:focus-visible),select:focus:not(:focus-visible),textarea:focus:not(:focus-visible),a:focus:not(:focus-visible){outline:none}#root{min-height:100vh}.login-page{display:flex;min-height:100vh}.login-panel-brand{display:none;flex:1;overflow:hidden;position:relative}@media(min-width:900px){.login-panel-brand{display:block}}.login-panel-cover{width:100%;height:100%;object-fit:cover;object-position:center center;display:block}.login-panel-brand-tagline{text-align:center}.login-panel-brand-tagline h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:#fff}.login-panel-brand-tagline p{margin:0;font-size:.95rem;color:#ffffff8c;line-height:1.6}.login-panel-form{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem 2rem;background:var(--color-bg-surface);flex:1;min-width:0}@media(min-width:900px){.login-panel-form{max-width:480px;padding:3rem}}.login-card{width:100%;max-width:380px}.login-brand{display:flex;justify-content:center;margin-bottom:2rem}.login-brand img{max-width:100%;height:auto}.login-card h1{margin:0 0 .35rem;font-size:1.5rem;font-weight:700;color:var(--color-text)}.login-subtitle{margin:0 0 1.75rem;font-size:.9rem;color:var(--color-text-muted)}.login-form .form-group{margin-bottom:1rem}.login-form .form-group:last-of-type{margin-bottom:1.5rem}.login-success{margin-bottom:1rem;padding:.6rem 1rem;background:var(--color-success-muted);color:var(--color-success);border-radius:var(--radius-sm);font-size:.9rem}.login-error{margin-bottom:1rem;padding:.6rem 1rem;background:var(--color-error-muted);border:1px solid var(--color-error);border-radius:var(--radius-sm);color:var(--color-error);font-size:var(--font-size-sm)}.login-form .btn-primary{width:100%;padding:.65rem 1rem;font-size:.95rem}.login-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-lg);background:var(--color-bg);gap:var(--spacing-xl)}.app-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-layout-body{display:flex;flex:1;min-height:0;overflow:hidden}.app-layout-main{flex:1;overflow:auto;padding:1.75rem 2rem;background:var(--color-bg)}.owner-mode-banner{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.35rem 1rem;font-size:.78rem;background:var(--color-primary);color:#fff;flex-wrap:wrap}.owner-mode-banner-text{min-width:0;flex:1}.owner-mode-banner-btn{background:#fff3;border:none;color:#fff;border-radius:6px;padding:.2rem .65rem;font-size:.75rem;cursor:pointer;font-weight:600;flex-shrink:0}@media(max-width:480px){.owner-mode-banner{flex-direction:column;align-items:stretch;text-align:center}.owner-mode-banner-btn{align-self:center}}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:56px;background:var(--color-bg-header);border-bottom:1px solid var(--color-border);flex-shrink:0;z-index:10}.app-header-brand{display:flex;align-items:center;gap:.75rem}.app-header-title{margin:0;font-size:1rem;font-weight:600;color:var(--color-text)}.app-header-title-short{display:none}.app-header-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;min-width:0}.app-header-user{display:flex;align-items:center;gap:.5rem}.app-header-name{font-size:.875rem;font-weight:500;color:var(--color-text);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-header-role-badge{font-size:.7rem;padding:.2em .55em;background:var(--color-primary-muted);border-radius:4px;color:var(--color-primary-active);font-weight:600;letter-spacing:.02em}.app-header-btn-logout{padding:.4em .9em;font-size:.825rem;background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:6px;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.app-header-btn-logout:hover{background:var(--color-bg);color:var(--color-text);border-color:var(--color-neutral-300)}.app-sidebar{width:240px;flex-shrink:0;background:var(--color-bg-sidebar);display:flex;flex-direction:column;overflow:hidden}.app-sidebar-brand{padding:1.25rem 1rem 1rem;border-bottom:1px solid var(--color-sidebar-border);display:flex;justify-content:center}.app-sidebar-brand .brand-logo-wrap img,.app-sidebar-brand .brand-logo{max-width:100%;max-height:52px;object-fit:contain}.app-sidebar-nav{display:flex;flex-direction:column;padding:.75rem .5rem;gap:2px;flex:1;overflow-y:auto;min-height:0}.app-sidebar-link{display:flex;align-items:center;gap:.6rem;padding:.6rem .875rem;border-radius:var(--radius-md);color:var(--color-sidebar-text);text-decoration:none;font-size:.875rem;font-weight:500;background:transparent;transition:background var(--transition-fast),color var(--transition-fast)}button.app-sidebar-link{border:none;cursor:pointer;text-align:left;width:100%;font:inherit}.app-sidebar-link:hover{background:var(--color-sidebar-bg-hover);color:var(--color-sidebar-text-hover)}.app-sidebar-link.active{background:var(--color-sidebar-bg-active);color:var(--color-sidebar-text-active)}.app-sidebar-icon{display:flex;align-items:center;flex-shrink:0;opacity:.85}.app-sidebar-link.active .app-sidebar-icon{opacity:1}.brand-logo-wrap{display:inline-block}.brand-logo-wrap .brand-logo-dark{display:none}.app-footer{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.5rem 1rem;background:var(--color-bg-header);border-top:1px solid var(--color-border);font-size:var(--font-size-xs);color:var(--color-text-muted-soft)}.app-footer-text{font-weight:500}.super-admin-layout{flex-direction:column}.super-admin-main{flex:1;min-height:0;overflow:auto;padding:1.75rem 2rem;background:var(--color-bg)}.super-admin-support-banner{display:flex;align-items:center;gap:.75rem;padding:.5rem 1.5rem;background:#f59e0b14;border-bottom:1px solid rgba(245,158,11,.25);font-size:.875rem;color:var(--color-text)}.super-admin-support-banner strong{color:var(--color-warning)}.super-admin-btn-volver{padding:.3em .75em;font-size:.825rem;background:transparent;border:1px solid rgba(245,158,11,.4);color:var(--color-warning);border-radius:6px;cursor:pointer}.super-admin-btn-volver:hover{background:#f59e0b1a}.super-admin-header-nav{display:flex;gap:.25rem;margin-left:1.5rem}.super-admin-nav-link{padding:.4rem .75rem;color:var(--color-text-muted);text-decoration:none;border-radius:6px;font-size:.875rem;transition:background var(--transition-fast),color var(--transition-fast)}.super-admin-nav-link:hover{color:var(--color-text);background:var(--color-bg)}.super-admin-nav-link.active{color:var(--color-primary-active);background:var(--color-primary-muted);font-weight:600}.super-admin-dashboard{max-width:1200px}.super-admin-header{margin-bottom:1.5rem}.super-admin-header h1{margin:0 0 .25rem;font-size:1.75rem;font-weight:700;color:var(--color-text)}.super-admin-subtitle{margin:0;color:var(--color-text-muted);font-size:.95rem}.super-admin-header-top{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}.super-admin-btn-super-admin{padding:.5rem 1rem;background:var(--color-primary);color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer}.super-admin-btn-super-admin:hover{background:var(--color-primary-hover)}.form-super-admin-hint{margin:0 0 1rem;font-size:.9rem;color:var(--color-text-muted)}.super-admin-stats{margin-bottom:2rem}.super-admin-stats h2,.super-admin-tenants h2{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.super-admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.super-admin-stat-card{padding:1.25rem 1rem;background:var(--color-bg-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:0 1px 3px #0000000a}.super-admin-stat-value{display:block;font-size:1.875rem;font-weight:700;color:var(--color-primary-active);line-height:1;margin-bottom:.375rem}.super-admin-stat-label{font-size:.8rem;color:var(--color-text-muted)}.super-admin-tenants{margin-bottom:2rem}.super-admin-hint{margin:0 0 1rem;font-size:.875rem;color:var(--color-text-muted)}.super-admin-table-wrap{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-surface);box-shadow:0 1px 3px #0000000a;-webkit-overflow-scrolling:touch}.super-admin-table{width:100%;border-collapse:collapse;font-size:.875rem}.super-admin-table th,.super-admin-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--color-border)}.super-admin-table th{background:var(--color-bg);font-weight:600;font-size:.775rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted)}.super-admin-table tbody tr:last-child td{border-bottom:none}.super-admin-table tbody tr:hover{background:#00000005}.super-admin-slug{font-size:.775rem;color:var(--color-text-muted-soft)}.super-admin-badge{display:inline-block;padding:.2em .55em;border-radius:4px;font-size:.75rem;font-weight:600}.super-admin-badge-active{background:var(--color-success-muted);color:var(--color-success)}.super-admin-badge-expired,.super-admin-badge-suspended{background:var(--color-error-muted);color:var(--color-error)}.super-admin-badge-none{color:var(--color-text-muted-soft)}.super-admin-btn-entrar{padding:.35em .8em;font-size:.825rem;background:var(--color-primary);color:#fff;border:none;border-radius:6px;cursor:pointer}.super-admin-btn-entrar:hover{background:var(--color-primary-hover)}.super-admin-empty{color:var(--color-text-muted);padding:1.5rem;text-align:center}.super-admin-tenants-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.75rem}.super-admin-tenants-header h2{margin:0}.super-admin-btn-nuevo{padding:.45em 1em;font-size:.875rem;background:var(--color-primary);color:#fff;border:none;border-radius:6px;cursor:pointer}.super-admin-btn-nuevo:hover{background:var(--color-primary-hover)}.super-admin-empty-state{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2.5rem;color:var(--color-text-muted)}.super-admin-license-cell{display:flex;flex-direction:column;gap:.15rem}.super-admin-license-date{font-size:.8rem;color:var(--color-text-muted)}.super-admin-license-days{font-size:.775rem;color:var(--color-success);font-weight:500}.super-admin-license-days-warn{color:var(--color-warning)}.super-admin-btn-editar-fecha{margin-top:.25rem;padding:.2em .4em;font-size:.75rem;background:transparent;border:none;color:var(--color-primary);cursor:pointer;text-decoration:underline}.super-admin-btn-editar-fecha:hover{color:var(--color-primary-hover)}.super-admin-inactivity-cell{display:flex;flex-direction:column;gap:.2rem}.super-admin-badge-inactive-1{background:var(--color-warning-muted);color:#92400e}.super-admin-badge-inactive-3{background:var(--color-error-muted);color:var(--color-error)}.super-admin-btn-export{padding:.3em .65em;font-size:.775rem;background:var(--color-info-muted);color:var(--color-info);border:1px solid rgba(37,99,235,.25);border-radius:4px;cursor:pointer}.super-admin-btn-export:hover{background:#2563eb26}.super-admin-btn-delete-tenant{padding:.3em .65em;font-size:.775rem;background:var(--color-error-muted);color:var(--color-error);border:1px solid rgba(220,38,38,.25);border-radius:4px;cursor:pointer}.super-admin-btn-delete-tenant:hover{background:#dc262626}.super-admin-actions{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}.super-admin-btn-toggle,.super-admin-btn-admin{padding:.3em .65em;font-size:.775rem;background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:4px;cursor:pointer}.super-admin-btn-toggle:hover,.super-admin-btn-admin:hover{background:var(--color-bg);color:var(--color-text)}.super-admin-btn-export:disabled,.super-admin-btn-delete-tenant:disabled{opacity:.5;cursor:not-allowed}.form-super-admin .form-group,.form-super-admin .form-group-checkbox{margin-bottom:1rem}.modal-admin-content{display:flex;flex-direction:column;gap:1.5rem}.modal-admin-resumen{margin-top:.5rem;padding-top:1.5rem;border-top:1px solid var(--color-border)}.modal-admin-resumen-title{margin:0 0 .75rem;font-size:1rem;font-weight:600}.modal-admin-resumen-loading,.modal-admin-resumen-empty{margin:0;font-size:.9rem;color:var(--color-text-muted)}.modal-admin-table-wrap{overflow-x:auto;max-height:200px;overflow-y:auto;border-radius:6px;border:1px solid var(--color-border)}.modal-admin-table{width:100%;border-collapse:collapse;font-size:.85rem}.modal-admin-table th,.modal-admin-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--color-border)}.modal-admin-table th{background:var(--color-bg);font-weight:600;color:var(--color-text-muted)}.modal-admin-table tbody tr:last-child td{border-bottom:none}.modal-admin-row-actions{display:flex;gap:.75rem}.super-admin-plans{max-width:1000px}.super-admin-plans-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.super-admin-plans-header h1{margin:.5rem 0 .25rem;font-size:1.5rem}.super-admin-back-link{display:inline-flex;align-items:center;gap:.25rem;color:var(--color-primary);text-decoration:none;font-size:.875rem;margin-bottom:.25rem}.super-admin-back-link:hover{text-decoration:underline}.super-admin-views-summary{display:block;color:var(--color-text-muted);font-size:.85rem;margin-top:.25rem}.super-admin-btn-change-plan{padding:.35rem .75rem;font-size:.85rem;background:var(--color-primary);color:#fff;border:none;border-radius:6px;cursor:pointer}.super-admin-btn-change-plan:hover{background:var(--color-primary-hover)}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem;max-width:360px}.toast{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:8px;box-shadow:0 4px 16px #0000001a;cursor:pointer;animation:toast-in .25s ease-out}@keyframes toast-in{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-success{background:var(--color-success-muted);border:1px solid rgba(22,163,74,.3);color:#15803d}.toast-error{background:var(--color-error-muted);border:1px solid rgba(220,38,38,.3);color:#b91c1c}.toast-warning{background:var(--color-warning-muted);border:1px solid rgba(245,158,11,.3);color:#b45309}.toast-info{background:var(--color-info-muted);border:1px solid rgba(37,99,235,.3);color:#1d4ed8}.toast-icon{font-size:1.1rem;flex-shrink:0}.toast-message{flex:1;font-size:.875rem}.toast-close{background:none;border:none;font-size:1.1rem;cursor:pointer;opacity:.6;padding:0 .25rem;line-height:1}.toast-close:hover{opacity:1}.modal-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#0f172ab8;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);padding:var(--spacing-md);animation:modal-overlay-in var(--transition-normal) ease-out}.modal-box{background:var(--color-bg-surface);border-radius:var(--radius-lg);max-width:540px;width:90vw;max-height:88vh;overflow-y:auto;padding:1.5rem;box-shadow:0 16px 56px #00000040;border:1px solid var(--color-border);animation:modal-content-in var(--transition-normal) ease-out}.modal{background:var(--color-bg-surface);border-radius:var(--radius-lg);width:90vw;max-height:88vh;overflow-y:auto;box-shadow:0 16px 56px #00000040;border:1px solid var(--color-border);animation:modal-content-in var(--transition-normal) ease-out}.modal-footer{padding:1rem 1.25rem;border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:.5rem}.modal-confirm{background:var(--color-bg-surface);border-radius:var(--radius-lg);max-width:400px;width:90vw;padding:1.5rem;box-shadow:0 16px 56px #00000040;border:1px solid var(--color-border);animation:modal-content-in var(--transition-normal) ease-out}.modal-confirm-msg{margin:0 0 1.25rem;font-size:.9375rem;color:var(--color-text);line-height:1.5}.modal-subtitle{margin:-.25rem 0 1rem;font-size:.85rem;color:var(--color-text-muted)}.form-hint{display:block;margin-top:.25rem;font-size:.78rem;color:var(--color-text-muted-soft)}@keyframes modal-overlay-in{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--color-bg-surface);border-radius:var(--radius-lg);max-width:90vw;max-height:90vh;overflow:auto;box-shadow:0 8px 40px #00000026;animation:modal-content-in var(--transition-normal) ease-out;border:1px solid var(--color-border)}@keyframes modal-content-in{0%{opacity:0;transform:scale(.96) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border)}.modal-title{margin:0;font-size:1.1rem;font-weight:600;color:var(--color-text)}.modal-close{background:none;border:none;font-size:1.25rem;cursor:pointer;opacity:.5;padding:.25rem;line-height:1;border-radius:4px;transition:opacity var(--transition-fast),background var(--transition-fast)}.modal-close:hover{opacity:1;background:var(--color-bg)}.modal-body{padding:1.25rem}.modal-form-responsive{min-width:0;width:100%;max-width:360px;box-sizing:border-box}.pagination{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.pagination-btn{padding:.45em 1em;font-size:.875rem;background:var(--color-primary);color:#fff;border:none;border-radius:6px;cursor:pointer}.pagination-btn:hover:not(:disabled){background:var(--color-primary-hover)}.pagination-btn:disabled{opacity:.45;cursor:not-allowed}.pagination-info{font-size:.875rem;color:var(--color-text-muted)}.auth-loading{display:flex;align-items:center;justify-content:center;min-height:100vh}.auth-loading p{color:var(--color-text-muted)}.spinner{display:inline-flex;align-items:center;justify-content:center}.spinner-inner{width:100%;height:100%;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spinner-rotate .7s linear infinite}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.table-skeleton-wrap{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-surface)}.table-skeleton{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.table-skeleton th,.table-skeleton td{padding:.6rem 1rem;text-align:left;border-bottom:1px solid var(--color-border)}.table-skeleton th{background:var(--color-bg)}.skeleton-line{display:inline-block;height:.875rem;background:linear-gradient(90deg,var(--color-neutral-200) 25%,var(--color-neutral-100) 50%,var(--color-neutral-200) 75%);background-size:200% 100%;border-radius:4px;animation:skeleton-shimmer 1.2s ease-in-out infinite}.skeleton-header{width:80%}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-2xl);color:var(--color-text-muted)}.loading-state-inline{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg);color:var(--color-text-muted)}.license-expired{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--color-bg)}.license-expired-card{max-width:420px;padding:2rem;background:var(--color-bg-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);text-align:center;box-shadow:0 4px 24px #0000000f}.license-expired-brand{margin-bottom:1rem}.license-expired-icon{font-size:2.5rem;margin-bottom:1rem}.license-expired h1{font-size:1.375rem;margin:0 0 .75rem;color:var(--color-text)}.license-expired-message{color:var(--color-text-muted);line-height:1.6;margin-bottom:1.5rem}.license-expired-details{text-align:left;background:var(--color-bg);padding:1rem;border-radius:var(--radius-md);margin-bottom:1.5rem}.license-expired-details p{margin:.25rem 0;color:var(--color-text);font-size:.9rem}.license-expired-user{font-size:.875rem;color:var(--color-text-muted);margin-bottom:1.5rem}.license-expired-btn{padding:.6em 1.5em;background:var(--color-primary);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem}.license-expired-btn:hover{background:var(--color-primary-hover)}.form-group label{display:block;margin-bottom:.35rem;font-size:.8125rem;font-weight:500;color:var(--color-text-muted)}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.5rem .75rem;font-size:.9375rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-surface);color:var(--color-text);box-sizing:border-box;font-family:inherit;transition:border-color var(--transition-fast)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-muted)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-text-muted-soft)}.form-group input.input-readonly,.form-group input:disabled{background:var(--color-neutral-100);color:var(--color-text-muted);cursor:not-allowed}.form-group.has-error input,.form-group.has-error select,.form-group.has-error textarea{border-color:var(--color-error)}.form-error{margin-top:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-error)}.form-hint{display:block;margin-top:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-text-muted)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group-checkbox label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.form-group-checkbox input[type=checkbox]{width:auto}.form-checkboxes{display:flex;flex-wrap:wrap;gap:.75rem 1.5rem}.form-checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem}.form-checkbox-label input[type=checkbox]{width:auto}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border);flex-wrap:wrap}.btn-primary{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-danger{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-danger);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;cursor:pointer;transition:opacity var(--transition-fast),transform var(--transition-fast)}.btn-danger.btn-danger-subtle{background:var(--color-danger-subtle)}.btn-danger.btn-danger-subtle:hover:not(:disabled){background:#d32f2f}.btn-danger:hover:not(:disabled){opacity:.9}.btn-danger:active:not(:disabled){transform:scale(.98)}.btn-danger:disabled{opacity:.55;cursor:not-allowed}.btn-secondary{padding:var(--spacing-sm) var(--spacing-md);background:transparent;color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.btn-secondary:hover{background:var(--color-bg);border-color:var(--color-neutral-300)}.btn-link{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:.875rem;padding:0;text-decoration:underline}.btn-link:hover{color:var(--color-primary-hover)}.btn-link-danger{color:var(--color-error)}.btn-link-danger:hover{color:#b91c1c}.btn-link-danger:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:.35rem .75rem;font-size:.825rem}.btn-excedente{background:#b3e5fc;color:#006064;border:1px solid #80deea;border-radius:var(--radius-sm);padding:.35rem .75rem;font-size:.825rem;cursor:pointer;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.btn-excedente:hover:not(:disabled){background:#4dd0e1;border-color:#26c6da;box-shadow:0 0 0 2px #00bcd440}.btn-excedente:disabled{opacity:.6;cursor:not-allowed}.badge{display:inline-block;padding:.2em .55em;font-size:.72rem;border-radius:4px;font-weight:600}.badge-active{background:var(--color-success-muted);color:var(--color-success)}.badge-inactive{background:var(--color-error-muted);color:var(--color-error)}.badge-estado-activa{background:var(--color-success-muted);color:var(--color-success)}.badge-estado-vencida{background:var(--color-error-muted);color:var(--color-error)}.badge-estado-congelada{background:var(--color-warning-muted);color:#92400e}.badge-estado-cancelada{background:var(--color-neutral-100);color:var(--color-neutral-600)}.view-socios,.view-planes,.view-buscar-membresias,.view-usuarios{max-width:1200px}.view-socios-header,.view-planes-header,.view-usuarios-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.view-socios-header h2,.view-planes-header h2,.view-usuarios-header h2{margin:0;font-size:1.375rem;font-weight:700}.view-socios-toolbar,.view-planes-toolbar,.view-usuarios-toolbar{margin-bottom:1rem}.view-socios-filter,.view-planes-filter,.view-usuarios-filter{max-width:320px}.view-socios-filter .input-filter,.view-planes-filter .input-filter,.view-usuarios-filter .input-filter,.view-buscar-membresias-filter .input-filter{width:100%;padding:.5rem .75rem;font-size:.9375rem;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-surface);color:var(--color-text);box-sizing:border-box}.view-usuarios-filter label,.view-buscar-membresias-filter label{display:block;margin-bottom:.25rem;font-size:.8125rem;color:var(--color-text-muted)}.view-socios-table-wrap,.view-planes-table-wrap,.view-usuarios-table-wrap,.view-buscar-membresias-table-wrap{overflow-x:auto;margin-bottom:1rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-surface);box-shadow:0 1px 3px #0000000a;-webkit-overflow-scrolling:touch}@media(max-width:768px){.view-socios-table-wrap:before,.view-planes-table-wrap:before,.view-usuarios-table-wrap:before,.view-buscar-membresias-table-wrap:before{content:"Desliza la tabla → para ver más columnas";display:block;padding:.4rem .75rem;font-size:.75rem;color:var(--color-text-muted);background:var(--color-bg);border-bottom:1px solid var(--color-border)}.table-scroll-hint{display:block;margin:0 0 .5rem;font-size:.75rem;color:var(--color-text-muted)}}.table-scroll-hint{display:none}.view-socios-table,.view-planes-table,.view-usuarios-table,.view-buscar-membresias-table{width:100%;border-collapse:collapse;font-size:.875rem;min-width:600px}.view-socios-table th,.view-socios-table td,.view-planes-table th,.view-planes-table td,.view-usuarios-table th,.view-usuarios-table td,.view-buscar-membresias-table th,.view-buscar-membresias-table td{padding:.65rem 1rem;text-align:left;border-bottom:1px solid var(--color-border)}.view-socios-table th,.view-planes-table th,.view-usuarios-table th,.view-buscar-membresias-table th{background:var(--color-bg);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted)}.view-socios-table tbody tr:last-child td,.view-planes-table tbody tr:last-child td,.view-usuarios-table tbody tr:last-child td,.view-buscar-membresias-table tbody tr:last-child td{border-bottom:none}.view-socios-table tbody tr:hover,.view-planes-table tbody tr:hover,.view-usuarios-table tbody tr:hover,.view-buscar-membresias-table tbody tr:hover{background:#00000005}.view-socios-loading,.view-socios-empty,.view-planes-loading,.view-planes-empty,.view-usuarios-loading,.view-usuarios-empty,.view-buscar-membresias-loading,.view-buscar-membresias-empty{padding:2rem;text-align:center;color:var(--color-text-muted)}.view-buscar-membresias-header{margin-bottom:1.5rem}.view-buscar-membresias-header h2{margin:0;font-size:1.375rem;font-weight:700}.view-buscar-membresias-toolbar{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end;margin-bottom:1.5rem}.view-buscar-membresias-filter{min-width:140px}.view-buscar-membresias-actions{display:flex;gap:.5rem}.view-usuarios-sep{margin:0 .35rem;color:var(--color-text-muted);font-weight:400}.view-usuarios-permisos{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--color-border)}.view-usuarios-permisos-title{margin:0 0 .5rem;font-size:1.125rem}.view-usuarios-permisos-desc{margin:0 0 1rem;font-size:.875rem;color:var(--color-text-muted)}.view-usuarios-permisos-table-wrap{overflow-x:auto;margin-bottom:1rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-surface)}.view-usuarios-permisos-table{width:100%;border-collapse:collapse;font-size:.875rem}.view-usuarios-permisos-table th,.view-usuarios-permisos-table td{padding:.6rem 1rem;text-align:left;border-bottom:1px solid var(--color-border)}.view-usuarios-permisos-table th{background:var(--color-bg);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted)}.view-usuarios-permisos-table td{vertical-align:middle}.view-usuarios-permisos-check{display:inline-flex;align-items:center;cursor:pointer}.view-usuarios-permisos-check input:disabled{cursor:not-allowed;opacity:.7}.view-usuarios-permisos-actions{margin-top:.75rem}.form-socio,.form-plan,.form-usuario{min-width:400px}.form-usuario select{width:100%;padding:.5rem .75rem;font-size:.9375rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-surface);color:var(--color-text)}.form-usuario select:focus{outline:none;border-color:var(--color-primary)}.view-nueva-membresia{max-width:560px}.view-nueva-membresia-header{margin-bottom:1.5rem}.view-nueva-membresia-header h2{margin:0;font-size:1.375rem;font-weight:700}.form-nueva-membresia .form-row-socio{display:flex;gap:.75rem;align-items:flex-start}.form-nueva-membresia .form-row-socio input{flex:1}.form-nueva-membresia select{width:100%;padding:.5rem .75rem;font-size:.9375rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-surface);color:var(--color-text)}.form-nueva-membresia select:focus{outline:none;border-color:var(--color-primary)}.form-group-dias .dias-info{font-size:.875rem;color:var(--color-text-muted)}.form-group-dias .dias-warning{color:var(--color-warning)}.form-nueva-membresia .form-row-precio{display:flex;gap:.75rem;align-items:flex-start}.form-nueva-membresia .form-row-precio input{flex:1}.btn-calculadora{white-space:nowrap}.modal-buscar-socio{min-width:480px}.modal-buscar-socio-filter{margin-bottom:1rem}.modal-buscar-socio-filter .input-filter{width:100%;padding:.5rem .75rem;font-size:.9375rem;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-surface);color:var(--color-text);box-sizing:border-box}.modal-buscar-socio-table-wrap{overflow-x:auto;margin-bottom:1rem;max-height:320px;overflow-y:auto;border-radius:8px;border:1px solid var(--color-border)}.modal-buscar-socio-table{width:100%;border-collapse:collapse;font-size:.875rem}.modal-buscar-socio-table th,.modal-buscar-socio-table td{padding:.6rem 1rem;text-align:left;border-bottom:1px solid var(--color-border)}.modal-buscar-socio-table th{background:var(--color-bg);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted)}.modal-buscar-socio-table tbody tr:hover{background:#00000005}.modal-buscar-socio-loading,.modal-buscar-socio-empty{padding:2rem;text-align:center;color:var(--color-text-muted)}.modal-calculadora{min-width:260px}.modal-calculadora-display{font-size:1.75rem;font-weight:600;text-align:right;padding:.75rem 1rem;margin-bottom:1rem;background:var(--color-bg);border-radius:8px;font-variant-numeric:tabular-nums}.modal-calculadora-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-bottom:1rem}.modal-calculadora-btn{padding:.75rem;font-size:1rem;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-surface);color:var(--color-text);cursor:pointer;transition:background var(--transition-fast)}.modal-calculadora-btn:hover{background:var(--color-bg)}.modal-calculadora-btn-op{background:var(--color-primary-muted);color:var(--color-primary-active);border-color:#06b6d433}.modal-calculadora-btn-op:hover{background:#06b6d433}.modal-calculadora-actions{display:flex;gap:.75rem;justify-content:flex-end}.modal-detalle-membresia{min-width:360px}.modal-detalle-membresia-dl{display:grid;gap:.75rem 1.5rem;margin:0 0 1.5rem}.modal-detalle-membresia-dl>div{display:grid;grid-template-columns:140px 1fr;gap:.5rem;align-items:baseline}.modal-detalle-membresia-dl dt{margin:0;font-size:.8125rem;color:var(--color-text-muted)}.modal-detalle-membresia-dl dd{margin:0;font-size:.9375rem}.modal-detalle-membresia-loading,.modal-detalle-membresia-empty{padding:1.5rem;text-align:center;color:var(--color-text-muted)}.modal-detalle-membresia-actions{display:flex;justify-content:flex-end}.view-placeholder{max-width:600px}.view-placeholder h2{margin:0 0 .5rem;font-size:1.375rem;color:var(--color-text)}.view-placeholder p{color:var(--color-text-muted);margin:0}.home-container h2{margin:0 0 .75rem;font-size:1.375rem;color:var(--color-text)}.home-container p{margin:.25rem 0;color:var(--color-text-muted)}@media(max-width:768px){.app-layout-main,.super-admin-main{padding:var(--spacing-md)}.view-socios-header,.view-planes-header,.view-usuarios-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.view-socios-header h2,.view-planes-header h2,.view-usuarios-header h2{font-size:var(--font-size-xl)}.form-row{grid-template-columns:1fr}.view-buscar-membresias-toolbar{flex-direction:column;align-items:stretch}.view-buscar-membresias-filter{min-width:100%}.modal-content{max-width:95vw;margin:var(--spacing-sm)}.modal-buscar-socio{min-width:auto;width:100%}.form-socio,.form-plan,.form-usuario{min-width:auto}.modal-body{padding:.875rem 1rem}.form-actions{gap:.5rem}.form-actions .btn-primary,.form-actions .btn-secondary{min-width:0}.pagination{flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}.pagination-btn{flex:1}}@media(max-width:768px){.app-header{padding:0 .75rem;gap:.5rem;flex-wrap:wrap}.app-header-brand{min-width:0}.app-header-title-full{display:none}.app-header-title-short{display:inline}.app-header-actions{gap:.5rem;justify-content:flex-end}.header-btn-novedades-text{display:none}.header-btn-novedades{padding:.4rem!important}.app-header-name{max-width:100px}.app-header-role-badge{font-size:.65rem;padding:.15em .4em}}@media(max-width:480px){.app-header{padding:var(--spacing-sm) var(--spacing-md);flex-wrap:wrap}.app-header-user{order:3;width:100%;margin-top:var(--spacing-sm)}.app-header-name{max-width:none}.view-socios-table-wrap,.view-planes-table-wrap,.view-buscar-membresias-table-wrap,.view-usuarios-table-wrap{margin-left:-.5rem;margin-right:-.5rem;border-radius:0}.super-admin-stats-grid{grid-template-columns:1fr 1fr}.super-admin-actions{flex-direction:column}}.icon-btn{position:relative;background:none;border:none;padding:.375rem;border-radius:6px;cursor:pointer;color:var(--color-text-muted);display:inline-flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast)}.icon-btn:hover{background:var(--color-neutral-100);color:var(--color-text)}.icon-btn.icon-btn-danger:hover{background:var(--color-error-muted);color:var(--color-error)}.icon-btn.icon-btn-success:hover{background:var(--color-success-muted);color:var(--color-success)}.icon-btn[data-tip]:after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);white-space:nowrap;background:var(--color-secondary);color:#fff;font-size:.7rem;font-weight:500;padding:.2rem .45rem;border-radius:4px;opacity:0;pointer-events:none;transition:opacity .12s;z-index:200}.icon-btn[data-tip]:hover:after{opacity:1}.icon-btn-group{display:inline-flex;align-items:center;gap:.125rem}.sa-page{padding:0}.sa-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.sa-page-title{margin:0 0 .25rem;font-size:1.375rem;font-weight:700;color:var(--color-text)}.sa-page-subtitle{margin:0;font-size:.875rem;color:var(--color-text-muted)}.sa-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.sa-kpi-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem 1.25rem;box-shadow:0 1px 3px #0000000a}.sa-kpi-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:.375rem}.sa-kpi-value{font-size:1.75rem;font-weight:700;color:var(--color-text);font-variant-numeric:tabular-nums}.sa-kpi-sub{font-size:.8rem;color:var(--color-text-muted-soft);margin-top:.125rem}.sa-section{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.25rem;margin-bottom:1.25rem;box-shadow:0 1px 3px #0000000a}.sa-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.sa-section-title{margin:0;font-size:1rem;font-weight:600;color:var(--color-text)}.sa-chart{display:flex;flex-direction:column;gap:.625rem;max-width:100%;min-width:0}.sa-chart-row{display:grid;grid-template-columns:130px 1fr 60px;align-items:center;gap:.75rem;font-size:.82rem;min-width:0}.sa-chart-label{color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.sa-chart-bar-bg{height:8px;background:var(--color-neutral-100);border-radius:99px;overflow:hidden}.sa-chart-bar-fill{height:100%;background:var(--color-primary);border-radius:99px;transition:width .4s ease}.sa-chart-bar-fill.bar-success{background:var(--color-success)}.sa-chart-bar-fill.bar-warning{background:var(--color-warning)}.sa-chart-bar-fill.bar-neutral{background:var(--color-neutral-300)}.sa-chart-value{font-size:.8rem;font-weight:600;color:var(--color-text);text-align:right;font-variant-numeric:tabular-nums}.sa-table-wrap{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-surface);box-shadow:0 1px 3px #0000000a}.sa-table{width:100%;border-collapse:collapse;font-size:.875rem}.sa-table th{padding:.65rem 1rem;text-align:left;background:var(--color-bg);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap}.sa-table td{padding:.65rem 1rem;text-align:left;border-bottom:1px solid var(--color-border);vertical-align:middle}.sa-table tbody tr:last-child td{border-bottom:none}.sa-table tbody tr:hover{background:#00000005}.sa-name-cell{font-weight:600;color:var(--color-text)}.sa-name-cell small{display:block;font-weight:400;font-size:.78rem;color:var(--color-text-muted);margin-top:.1rem}.sa-license-cell{font-size:.82rem}.sa-license-cell .license-date{font-weight:600;color:var(--color-text)}.sa-license-cell .license-days{font-size:.75rem;color:var(--color-text-muted-soft)}.sa-inactivity-cell{font-size:.82rem;color:var(--color-text-muted)}.sa-novedades-header h2{margin:0 0 .25rem;font-size:1.375rem}.sa-novedades-desc{margin:0 0 1rem;font-size:.9rem;color:var(--color-text-muted)}.sa-novedades-toolbar{margin-bottom:1rem}.sa-novedades-toolbar .form-group{margin:0}.sa-novedades-empty{padding:2rem;text-align:center;color:var(--color-text-muted)}.sa-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.125rem 1.25rem;margin-bottom:.875rem;box-shadow:0 1px 3px #0000000a}.sa-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.sa-card-key{font-size:.82rem;color:var(--color-text-muted)}.sa-metrics-grid{display:flex;flex-wrap:wrap;gap:.75rem 1.5rem;margin-top:.5rem}.sa-metric{display:flex;flex-direction:column;gap:.1rem}.sa-metric-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted-soft)}.sa-metric-value{font-size:.9rem;font-weight:600;color:var(--color-text)}.sa-dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.25rem}.badge-warning{background:var(--color-warning-muted);color:#92400e}.badge-info{background:var(--color-info-muted);color:var(--color-info)}.badge-success{background:var(--color-success-muted);color:var(--color-success)}.badge-error{background:var(--color-error-muted);color:var(--color-error)}.badge-neutral{background:var(--color-neutral-100);color:var(--color-neutral-600)}.badge-primary{background:var(--color-primary-muted);color:var(--color-primary-active)}.badge-sin-registros{background:transparent;color:var(--color-text)}.tier-pills{display:flex;flex-wrap:wrap;gap:.25rem}.tier-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .5rem;border-radius:99px;font-size:.72rem;font-weight:600;border:1px solid transparent;background:var(--color-neutral-100);color:var(--color-neutral-600)}.tier-pill-active{background:var(--color-primary-muted);color:var(--color-primary-active);border-color:#06b6d433}.tier-pill-pending{background:var(--color-warning-muted);color:#92400e}.tier-pill-inactive{background:var(--color-neutral-100);color:var(--color-neutral-500)}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.8125rem;font-weight:600;color:var(--color-text-muted);margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.03em}.form-input{width:100%;padding:.5rem .75rem;font-size:.9375rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-surface);color:var(--color-text);box-sizing:border-box;font-family:inherit;transition:border-color var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--color-primary)}.form-input::placeholder{color:var(--color-text-muted-soft)}textarea.form-input{resize:vertical;min-height:72px}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.25rem}.modal>.modal-actions{margin-top:0;padding:1rem 1.25rem;border-top:1px solid var(--color-border)}.sa-loading,.sa-empty,.sa-error,.sa-audit-text{font-size:.875rem;color:var(--color-text-muted)}.sa-error{color:var(--color-error)}.sa-audit-text{font-size:.78rem;color:var(--color-text-muted-soft);white-space:nowrap}.super-admin-page{padding:0}.super-admin-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.super-admin-page-title{margin:0 0 .25rem;font-size:1.375rem;font-weight:700}.super-admin-page-subtitle{margin:0;font-size:.875rem;color:var(--color-text-muted)}.pricing-config-group{border:1px solid var(--color-border);border-radius:var(--radius-md, 10px);padding:1rem 1.25rem .75rem;background:var(--color-bg-surface, #fff)}.pricing-config-group-title{font-size:.8125rem;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.3rem}.pricing-config-hint{font-size:.8rem;color:var(--color-text-muted);margin:0 0 .85rem;line-height:1.5}.billing-breakdown{border:1px solid var(--color-border);border-radius:var(--radius-md, 10px);padding:.85rem 1rem;background:var(--color-bg-muted, #f8f9fa);font-size:.85rem}.billing-breakdown-row{display:flex;justify-content:space-between;padding:.2rem 0;color:var(--color-text)}.billing-breakdown-row.muted{color:var(--color-text-muted);font-size:.8rem}.billing-breakdown-row.separator{border-top:1px solid var(--color-border);margin-top:.25rem;padding-top:.4rem}.billing-breakdown-row.total{border-top:2px solid var(--color-border);margin-top:.25rem;padding-top:.5rem;font-weight:700;font-size:.95rem;color:var(--color-primary, #06b6d4)}.billing-breakdown-row.discount{color:var(--color-success, #059669)}@media(max-width:768px){.billing-breakdown{max-width:100%;min-width:0}}@media(max-width:1100px){.sa-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.sa-kpi-grid{grid-template-columns:1fr 1fr}.sa-dashboard-grid{grid-template-columns:1fr}}@media(max-width:480px){.sa-kpi-grid{grid-template-columns:1fr}}.app-sidebar-top{display:flex;align-items:center;justify-content:space-between;padding:.875rem .75rem .75rem;border-bottom:1px solid var(--color-sidebar-border);gap:.5rem;flex-shrink:0}.app-sidebar-top .app-sidebar-brand{padding:0;border-bottom:none;flex:1;min-width:0;display:flex;align-items:center}.sidebar-toggle-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--color-sidebar-text);padding:.4rem;border-radius:6px;flex-shrink:0;transition:background var(--transition-fast),color var(--transition-fast)}.sidebar-toggle-btn:hover{background:var(--color-sidebar-bg-hover);color:var(--color-sidebar-text-hover)}.sidebar-link-label{overflow:hidden;white-space:nowrap;transition:opacity .15s,max-width .2s}.app-sidebar-footer{padding:.5rem .5rem .875rem;border-top:1px solid var(--color-sidebar-border);margin-top:auto;display:flex;flex-direction:column;gap:2px;flex-shrink:0}.sidebar-logout{color:var(--color-sidebar-text)!important}.sidebar-logout:hover{background:#ef444426!important;color:#f87171!important}.sidebar-logout .app-sidebar-icon{opacity:.8}.sidebar-logout:hover .app-sidebar-icon{opacity:1}.sidebar-install-btn{color:var(--color-sidebar-text)!important}.app-sidebar.collapsed{width:56px}.app-sidebar.collapsed .sidebar-link-label{display:none}.app-sidebar.collapsed .app-sidebar-top{justify-content:center;padding:.875rem .5rem .75rem}.app-sidebar.collapsed .app-sidebar-top .app-sidebar-brand{flex:0}.app-sidebar.collapsed .app-sidebar-nav{padding:.75rem .375rem}.app-sidebar.collapsed .app-sidebar-link{justify-content:center;padding:.6rem}.app-sidebar.collapsed .app-sidebar-footer{padding:.5rem .375rem .875rem;align-items:center}@media(max-width:768px){.app-sidebar{position:fixed;top:0;left:0;height:100%;z-index:300;transform:translate(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);width:240px!important;overflow-y:auto}.app-sidebar.mobile-open{transform:translate(0);box-shadow:4px 0 20px #00000059}.app-sidebar.collapsed{width:240px!important}.app-sidebar.collapsed .sidebar-link-label{display:inline!important}.app-sidebar.collapsed .app-sidebar-top{justify-content:space-between;padding:.875rem .75rem .75rem}.app-sidebar.collapsed .app-sidebar-top .app-sidebar-brand{flex:1}.app-sidebar.collapsed .app-sidebar-nav{padding:.75rem .5rem}.app-sidebar.collapsed .app-sidebar-link{justify-content:flex-start;padding:.6rem .875rem}.app-sidebar.collapsed .app-sidebar-footer{padding:.5rem .5rem .875rem;align-items:stretch}.sidebar-toggle-btn{display:none}}.sidebar-backdrop{display:none}@media(max-width:768px){.sidebar-backdrop{display:block;position:fixed;inset:0;background:#00000073;z-index:299;cursor:pointer}}.header-hamburger{display:none;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--color-text);padding:.4rem;border-radius:6px;flex-shrink:0;transition:background var(--transition-fast)}.header-hamburger:hover{background:var(--color-neutral-100)}@media(max-width:768px){.header-hamburger{display:flex}}.login-cover-mobile{display:block;width:100%;max-height:220px;overflow:hidden;margin-bottom:1.5rem;border-radius:var(--radius-md)}.login-cover-mobile img{width:100%;height:220px;object-fit:cover;object-position:center top;display:block}@media(min-width:900px){.login-cover-mobile{display:none}}@media(max-width:480px){.sa-kpi-card{padding:.75rem 1rem}.sa-kpi-value{font-size:1.4rem}.sa-kpi-label{font-size:.7rem}}@media(max-width:768px){.sa-table-wrap,.super-admin-table-wrap{margin-left:-.5rem;margin-right:-.5rem;border-radius:0}.sa-table-wrap:before,.super-admin-table-wrap:before{content:"Desliza la tabla → para ver más columnas";display:block;padding:.4rem .75rem;font-size:.75rem;color:var(--color-text-muted);background:var(--color-bg);border-bottom:1px solid var(--color-border)}.sa-table th,.sa-table td{white-space:nowrap;font-size:.8rem;padding:.5rem .625rem}.sa-chart-row{grid-template-columns:90px 1fr 50px;font-size:.75rem}.sa-chart-value{font-size:.7rem}.sa-page-header{flex-direction:column;align-items:flex-start;gap:1rem}.sa-page-header>div:last-child{width:100%;max-width:100%}}.btn-refresh-storage-label-short{display:none}@media(max-width:480px){.btn-refresh-storage .btn-refresh-storage-label{display:none}.btn-refresh-storage .btn-refresh-storage-label-short{display:inline}}@media(max-width:480px){.sa-chart-row{grid-template-columns:70px 1fr 42px;gap:.5rem;font-size:.7rem}.sa-chart-value{font-size:.65rem}}
