:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:left;box-sizing:border-box;width:100%;max-width:100%;min-height:100vh;margin:0;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}:root{--bg-color:#f8fafc;--text-primary:#0f172a;--text-secondary:#475569;--card-bg:#fff;--card-border:#0000000d;--accent-color:#0891b2;--accent-gradient:linear-gradient(135deg, #0891b2 0%, #2563eb 100%);--sidebar-bg:#fffc;--sidebar-border:#0000001a;--hover-bg:#0000000d}[data-theme=dark]{--bg-color:#0f172a;--text-primary:#f8fafc;--text-secondary:#94a3b8;--card-bg:#1e293b80;--card-border:#ffffff0d;--accent-color:#06b6d4;--accent-gradient:linear-gradient(135deg, #06b6d4 0%, #3b82f6 100%);--sidebar-bg:#0f172acc;--sidebar-border:#ffffff1a;--hover-bg:#ffffff0d}.app-container{background:var(--bg-color);width:100%;height:100vh;color:var(--text-primary);flex-direction:row;flex:1;transition:background-color .3s,color .3s;display:flex;overflow:hidden}.main-content{background:var(--bg-color);flex:1;min-width:0;height:100vh;overflow-y:auto}.placeholder-screen{color:var(--text-primary);text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2.5rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex}.placeholder-screen h1{background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:1rem;font-size:2.5rem;font-weight:700}.placeholder-screen p{color:var(--text-secondary);font-size:1.1rem}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-color);margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}@media (width<=768px){.mobile-top-header{display:flex!important}.main-content{padding-top:60px!important}.sidebar-wrapper{z-index:99;height:100vh;transition:transform .3s cubic-bezier(.16,1,.3,1);position:fixed;top:0;left:-260px}.sidebar-wrapper.mobile-open{transform:translate(260px)}.sidebar{width:260px!important;box-shadow:10px 0 30px #00000026!important}.sidebar.collapsed{width:260px!important}.sidebar.collapsed .logo-text,.sidebar.collapsed .nav-item span,.sidebar.collapsed .theme-label,.sidebar.collapsed .user-info{display:block!important}.sidebar.collapsed .logo-container{display:flex!important}.sidebar.collapsed .sidebar-header{justify-content:space-between!important;padding:1.25rem!important}.sidebar.collapsed .sidebar-nav{align-items:flex-start!important;padding:1rem .75rem!important}.sidebar.collapsed .nav-item{justify-content:flex-start!important;gap:.75rem!important;width:100%!important;padding:.65rem .85rem!important}.sidebar.collapsed .sidebar-footer{flex-direction:column!important;align-items:stretch!important;padding:1.15rem 1.25rem!important}.sidebar.collapsed .user-profile{flex-direction:row!important;justify-content:space-between!important}.sidebar.collapsed .theme-toggle-simple-btn{justify-content:flex-start!important;gap:.75rem!important;width:100%!important;padding:.75rem 1rem!important}.crud-screen{padding:1.25rem 1rem!important}.crud-header{gap:1rem!important;margin-bottom:1.75rem!important}.crud-title-area h1{font-size:1.75rem!important}.crud-title-area p{font-size:.85rem!important}.crud-add-btn{justify-content:center!important;width:100%!important;padding:.75rem 1.25rem!important}.crud-table-container{border-radius:12px!important}.crud-table th,.crud-table td{padding:.85rem .65rem!important;font-size:.82rem!important}.crud-modal{border-radius:16px!important;width:94%!important;max-height:90vh!important;margin:0 auto!important;padding:1.25rem!important}.modal-header{margin-bottom:1.25rem!important}.modal-header h2{font-size:1.2rem!important}.home-screen{padding:1.25rem 1rem!important}.home-header{flex-direction:column!important;align-items:flex-start!important;gap:1.25rem!important;margin-bottom:1.75rem!important}.greeting h1{font-size:1.75rem!important}.stats-grid{gap:1.25rem!important;margin-bottom:2rem!important}.recent-activity{padding:1.25rem!important}}@media (width<=600px){.modal-form{grid-template-columns:1fr!important;gap:1rem!important}.modal-form .modal-input-group,.modal-form .modal-input-group.full-width{grid-column:span 1!important}.modal-actions{flex-direction:column-reverse!important;grid-column:span 1!important;gap:.75rem!important;margin-top:1rem!important}.modal-btn{width:100%!important;padding:.75rem 1.25rem!important}}.home-screen{color:var(--text-primary);background:var(--bg-color);width:100%;min-height:100vh;padding:2.5rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;transition:background-color .3s,color .3s}.home-header{justify-content:space-between;align-items:center;margin-bottom:3rem;display:flex}.greeting h1{background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0 0 .5rem;font-size:2rem;font-weight:700}.greeting p{color:var(--text-secondary);margin:0;font-size:1rem}.date-display{background:var(--card-bg);border:1px solid var(--card-border);color:var(--text-primary);border-radius:12px;align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.9rem;transition:background-color .3s,border-color .3s,color .3s;display:flex;box-shadow:0 2px 10px #0000000d}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-bottom:4rem;display:grid}.stat-card{background:var(--card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--card-border);border-radius:16px;align-items:center;gap:1.5rem;padding:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1),background-color .3s,border-color .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 15px #00000005}.stat-card:hover{border-color:var(--sidebar-border);transform:translateY(-5px);box-shadow:0 10px 25px #00000014}.stat-card:after{content:"";width:100%;height:4px;position:absolute;top:0;left:0}.stat-card.gradient-cyan:after{background:linear-gradient(90deg,#06b6d4,#0891b2)}.stat-card.gradient-blue:after{background:linear-gradient(90deg,#3b82f6,#2563eb)}.stat-card.gradient-indigo:after{background:linear-gradient(90deg,#6366f1,#4f46e5)}.stat-icon{background:var(--hover-bg);border-radius:12px;justify-content:center;align-items:center;width:56px;height:56px;font-size:2rem;transition:background-color .3s;display:flex;box-shadow:inset 0 0 10px #00000005}.stat-content h3{color:var(--text-secondary);margin:0 0 .25rem;font-size:.9rem;font-weight:500}.stat-value{color:var(--text-primary);margin:0 0 .25rem;font-size:1.75rem;font-weight:700;transition:color .3s}.stat-label{color:var(--text-secondary);margin:0;font-size:.75rem}.recent-activity{background:var(--card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--card-border);border-radius:16px;padding:2rem;transition:background-color .3s,border-color .3s;box-shadow:0 4px 15px #00000005}.recent-activity h2{color:var(--text-primary);margin:0 0 1.5rem;font-size:1.25rem;font-weight:600}.activity-list{flex-direction:column;gap:1.25rem;display:flex}.activity-item{border-bottom:1px solid var(--card-border);align-items:center;gap:1rem;padding-bottom:1.25rem;transition:border-color .3s;display:flex}.activity-item:last-child{border-bottom:none;padding-bottom:0}.activity-icon{border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.8rem;font-weight:700;display:flex}.status-success{color:#22c55e;background:#22c55e1f}.status-warning{color:#eab308;background:#eab3081f}.status-info{color:#3b82f6;background:#3b82f61f}.activity-details{flex-direction:column;gap:.25rem;display:flex}.activity-text{color:var(--text-primary);margin:0;font-size:.95rem;transition:color .3s}.activity-text strong{color:var(--text-primary);font-weight:700}.activity-time{color:var(--text-secondary);margin:0;font-size:.8rem;transition:color .3s}.login-container{width:100vw;height:100vh;min-height:600px;color:var(--text-primary,#f8fafc);z-index:1;background:radial-gradient(circle,#1e293b 0%,#0f172a 100%);justify-content:center;align-items:center;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex;position:relative;overflow:hidden}.bg-blob{filter:blur(100px);z-index:0;pointer-events:none;border-radius:50%;position:absolute}.blob-1{background:radial-gradient(circle,#06b6d426 0%,#3b82f60d 100%);width:50vw;height:50vw;animation:20s ease-in-out infinite alternate float-slow;top:-10%;left:-10%}.blob-2{background:radial-gradient(circle,#a855f726 0%,#db277708 100%);width:60vw;height:60vw;animation:25s ease-in-out infinite alternate-reverse float-slow;bottom:-15%;right:-10%}.blob-3{background:radial-gradient(circle,#06b6d41a 0%,#3b82f605 100%);width:350px;height:350px;animation:15s ease-in-out infinite alternate float-medium;top:40%;left:30%}@keyframes float-slow{0%{transform:translate(0)scale(1)}to{transform:translate(8%,8%)scale(1.15)}}@keyframes float-medium{0%{transform:translate(0)rotate(0)}to{transform:translate(-10%,15%)rotate(180deg)}}.login-card{-webkit-backdrop-filter:blur(20px);z-index:2;background:#1e293b73;border:1px solid #ffffff14;border-radius:24px;width:100%;max-width:440px;margin:1.5rem;padding:3rem 2.5rem;transition:transform .3s,box-shadow .3s;animation:.8s cubic-bezier(.16,1,.3,1) fade-in-up;position:relative;box-shadow:0 25px 50px -12px #00000080}.login-card:hover{border-color:#ffffff1f;box-shadow:0 30px 60px -10px #0009}@keyframes fade-in-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;flex-direction:column;align-items:center;margin-bottom:2.5rem;display:flex}.login-logo-circle{background:linear-gradient(135deg,#06b6d433 0%,#3b82f633 100%);border:1px solid #06b6d44d;border-radius:18px;justify-content:center;align-items:center;width:60px;height:60px;margin-bottom:1.25rem;animation:3s ease-in-out infinite pulse-logo;display:flex;box-shadow:0 10px 20px -5px #06b6d44d}.login-logo-icon{font-size:1.75rem}@keyframes pulse-logo{0%,to{transform:scale(1);box-shadow:0 10px 20px -5px #06b6d44d}50%{transform:scale(1.05);box-shadow:0 12px 25px -3px #06b6d480}}.login-title{letter-spacing:-1px;color:#fff;font-size:2.25rem;font-weight:800;margin:0 0 .5rem!important}.login-title span{background:linear-gradient(135deg,#06b6d4 0%,#3b82f6 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.login-subtitle{color:var(--text-secondary,#94a3b8);margin:0;font-size:.925rem;line-height:1.4}.login-error-alert{background:#ef444426;border:1px solid #ef44444d;border-radius:12px;align-items:flex-start;gap:.75rem;margin-bottom:1.5rem;padding:.875rem 1rem;animation:.3s fade-in;display:flex}.error-alert-icon{margin-top:.1rem;font-size:1.1rem}.error-alert-text{color:#fca5a5;text-align:left;margin:0;font-size:.875rem;font-weight:500;line-height:1.4}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.shake-animation{animation:.6s cubic-bezier(.36,.07,.19,.97) both shake}@keyframes shake{10%,90%{transform:translate(-1px)}20%,80%{transform:translate(2px)}30%,50%,70%{transform:translate(-4px)}40%,60%{transform:translate(4px)}}.input-group{width:100%;margin-bottom:2rem;position:relative}.input-group input{color:#fff;background:0 0;border:none;border-bottom:1.5px solid #fff3;outline:none;width:100%;padding:.625rem 0;font-size:1.05rem;transition:border-color .3s}.input-group label{color:var(--text-secondary,#94a3b8);pointer-events:none;font-size:1.05rem;transition:all .3s cubic-bezier(.16,1,.3,1);position:absolute;top:.625rem;left:0}.input-line{background:linear-gradient(90deg,#06b6d4 0%,#3b82f6 100%);width:0;height:2px;transition:all .3s cubic-bezier(.16,1,.3,1);position:absolute;bottom:0;left:50%}.input-group input:focus~.input-line,.input-group input.has-content~.input-line{width:100%;left:0}.input-group input:focus~label,.input-group input.has-content~label{color:#06b6d4;letter-spacing:.5px;font-size:.85rem;font-weight:600;top:-1.25rem}.input-group input:focus{border-bottom-color:#0000}.toggle-password-btn{color:var(--text-secondary,#94a3b8);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:.25rem;transition:color .2s,transform .2s;display:flex;position:absolute;top:.5rem;right:0}.toggle-password-btn:hover{color:#fff;transform:scale(1.1)}.toggle-password-btn svg{width:20px;height:20px}.login-submit-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#06b6d4 0%,#3b82f6 100%);border:none;border-radius:16px;justify-content:center;align-items:center;gap:.75rem;width:100%;margin-top:1rem;padding:1rem;font-size:1.05rem;font-weight:700;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;position:relative;overflow:hidden;box-shadow:0 10px 20px -5px #06b6d466}.login-submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#0891b2 0%,#2563eb 100%);transform:translateY(-2px);box-shadow:0 15px 25px -5px #06b6d499}.login-submit-btn:active:not(:disabled){transform:translateY(1px);box-shadow:0 5px 10px -2px #06b6d466}.login-submit-btn:disabled{opacity:.7;cursor:not-allowed}.btn-arrow{width:18px;height:18px;transition:transform .3s cubic-bezier(.16,1,.3,1)}.login-submit-btn:hover:not(:disabled) .btn-arrow{transform:translate(4px)}.btn-spinner{border:3px solid #fff3;border-top-color:#fff;border-radius:50%;width:22px;height:22px;animation:.8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-footer{text-align:center;margin-top:2.5rem}.login-footer p{color:#ffffff4d;letter-spacing:.2px;margin:0;font-size:.775rem}@media (width<=480px){.login-card{border-radius:20px;margin:1rem;padding:2.5rem 1.75rem}.login-title{font-size:2rem}}.crud-row:last-child td{border-bottom:none}.font-mono{font-family:var(--mono)}.font-semibold{font-weight:600}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-secondary);opacity:.6;font-style:italic}.text-sm{font-size:.85rem}.text-right{text-align:right}@keyframes scale-up{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}:root{--bg-color:#fff;--card-bg:#fffc;--card-border:#0000001a;--accent-color:#06b6d4;--accent-gradient:linear-gradient(135deg, #06b6d4, #3b82f6);--text-primary:#1e293b;--text-secondary:#64748b;--modal-bg:#fff;--modal-border:#00000014;--input-bg:#f8fafc;--input-border:#00000014;--input-color:#1e293b;--summary-bg:#f1f5f9;--summary-item-bg:#fff;--hover-bg:#00000005;--sidebar-border:#00000014}[data-theme=dark]{--bg-color:#0f172a;--card-bg:#1e293bcc;--card-border:#ffffff1a;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--modal-bg:#1e293bf2;--modal-border:#ffffff1a;--input-bg:#00000040;--input-border:#ffffff1a;--input-color:#f1f5f9;--summary-bg:#0003;--summary-item-bg:#ffffff0d;--hover-bg:#ffffff05;--sidebar-border:#ffffff14}.crud-add-btn:active{transform:translateY(0);box-shadow:0 5px 10px -2px #06b6d466}.btn-ver-abonos:hover{color:#a855f7;background:#a855f726;border-color:#a855f74d}.abonos-summary{background:var(--summary-bg);border:1px solid var(--card-border);border-radius:12px;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem;padding:1.5rem;transition:background-color .3s,border-color .3s;display:grid}.summary-item{background:var(--summary-item-bg);border:1px solid var(--card-border);border-radius:8px;flex-direction:column;align-items:center;padding:1rem;transition:background-color .3s,border-color .3s;display:flex}.summary-item.highlight{background:#22c55e1f;border:1px solid #22c55e4d}.summary-label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.875rem;font-weight:500}.summary-value{color:var(--text-primary);font-size:1.125rem;font-weight:700}.summary-item.highlight .summary-value{color:#22c55e}.capture-link{color:var(--accent-color);font-weight:600;text-decoration:none}.capture-link:hover{text-decoration:underline}.status-parcial{color:#f59e0b;background:#f59e0b14;border:1px solid #f59e0b26}[data-theme=dark] .status-parcial{background:#f59e0b26;border-color:#f59e0b40}.crud-title-area h1{letter-spacing:-.05em;background:var(--accent-gradient);-webkit-text-fill-color:transparent;text-align:left;-webkit-background-clip:text;margin:0 0 .5rem;font-size:2.25rem;font-weight:800}.crud-title-area p{color:var(--text-secondary);text-align:left;margin:0;font-size:1rem}.crud-add-btn:hover{filter:brightness(1.05);transform:translateY(-2px);box-shadow:0 15px 25px -5px #06b6d499}.crud-table{border-collapse:collapse;text-align:left;width:100%}.crud-table th{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:1px solid var(--card-border);background:#00000005;padding:1.25rem 1.5rem;font-size:.85rem;font-weight:700}.crud-table td{color:var(--text-primary);border-bottom:1px solid var(--card-border);padding:1.25rem 1.5rem;font-size:.95rem;transition:background-color .2s}.crud-actions-group{justify-content:flex-end;gap:.5rem;display:inline-flex}.action-btn{background:var(--hover-bg);border:1px solid var(--card-border);color:var(--text-secondary);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;padding:.5rem;transition:all .2s;display:flex}.action-btn:hover{border-color:var(--sidebar-border);transform:scale(1.08)}.btn-edit:hover{color:#06b6d4;background:#06b6d426;border-color:#06b6d44d}.btn-abono:hover{color:#22c55e;background:#22c55e26;border-color:#22c55e4d}.btn-delete:hover{color:#ef4444;background:#ef444426;border-color:#ef44444d}.crud-loading-state,.crud-empty-state{background:var(--card-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--card-border);text-align:center;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;padding:5rem 2rem;display:flex}.loading-spinner{border:4px solid var(--card-border);border-top:4px solid var(--accent-color);border-radius:50%;width:50px;height:50px;margin-bottom:1.5rem;animation:1s linear infinite spin}.empty-icon{opacity:.5;color:var(--text-secondary);margin-bottom:1.5rem;font-size:3.5rem}.crud-empty-state h3{color:var(--text-primary);margin:0 0 .5rem;font-size:1.5rem}.crud-empty-state p{color:var(--text-secondary);margin:0}.crud-error-box{color:#ef4444;text-align:left;background:#ef444426;border:1px solid #ef44444d;border-radius:14px;align-items:center;gap:.75rem;margin-bottom:2rem;padding:1rem 1.5rem;display:flex}.error-icon{font-size:1.25rem}.crud-error-box p{margin:0;font-weight:500}.crud-modal-backdrop{-webkit-backdrop-filter:blur(8px);z-index:999;background:#0f172a66;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.25s fade-in;display:flex;position:fixed;top:0;left:0}.crud-modal{background:var(--modal-bg);-webkit-backdrop-filter:blur(25px);border:1px solid var(--modal-border);border-radius:24px;flex-direction:column;width:100%;max-width:700px;max-height:85vh;padding:2.25rem;animation:.3s cubic-bezier(.16,1,.3,1) scale-up;display:flex;box-shadow:0 25px 50px -12px #0000001a}.modal-header h2{color:var(--text-primary);margin:0;font-size:1.5rem;font-weight:700}.modal-input-group input,.modal-input-group textarea,.modal-input-group select{color:var(--input-color);background:var(--input-bg);border:1px solid var(--input-border);border-radius:12px;outline:none;padding:.85rem 1rem;font-family:inherit;font-size:.95rem;transition:all .2s}.modal-input-group input:focus,.modal-input-group textarea:focus,.modal-input-group select:focus{border-color:var(--accent-color);background:var(--modal-bg);box-shadow:0 0 0 3px #06b6d426}.modal-btn{cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;padding:.85rem 1.5rem;font-size:.95rem;font-weight:700;transition:all .2s;display:flex}.btn-save:disabled,.btn-cancel:disabled{opacity:.5;cursor:not-allowed}.spinner-small{border:2px solid #fff3;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}.status-badge{text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;border-radius:9999px;align-items:center;gap:.35rem;padding:.4rem .75rem;font-size:.8rem;font-weight:700;display:inline-flex;box-shadow:0 2px 4px #00000005}.status-pendiente{color:#ef4444;background:#ef444414;border:1px solid #ef444426}[data-theme=dark] .status-pendiente{background:#ef444426;border-color:#ef444440}.status-pagado{color:#10b981;background:#10b98114;border:1px solid #10b98126}[data-theme=dark] .status-pagado{background:#10b98126;border-color:#10b98140}:root{--bg-color:#fff;--card-bg:#fffc;--card-border:#0000001a;--accent-color:#06b6d4;--accent-gradient:linear-gradient(135deg, #06b6d4, #3b82f6);--text-primary:#1e293b;--text-secondary:#64748b;--modal-bg:#fff;--modal-border:#00000014;--input-bg:#f8fafc;--input-border:#00000014;--input-color:#1e293b;--hover-bg:#00000005;--sidebar-border:#00000014}[data-theme=dark]{--bg-color:#0f172a;--card-bg:#1e293b99;--card-border:#ffffff1a;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--modal-bg:#1e293bf2;--modal-border:#ffffff1a;--input-bg:#00000040;--input-border:#ffffff1a;--input-color:#f1f5f9;--hover-bg:#ffffff05;--sidebar-border:#ffffff14}.crud-screen{color:var(--text-primary);background:var(--bg-color);min-height:100vh;padding:2.5rem;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;animation:.5s fade-in-up}.crud-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.5rem;margin-bottom:2.5rem;display:flex}.crud-title-area h1{letter-spacing:-.05em;background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0 0 .5rem;font-size:2.25rem;font-weight:800}.crud-title-area p{color:var(--text-secondary);font-size:1rem}.crud-add-btn{color:#fff;background:var(--accent-gradient);cursor:pointer;border:none;border-radius:14px;align-items:center;gap:.5rem;padding:.85rem 1.5rem;font-size:.95rem;font-weight:700;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;box-shadow:0 10px 20px -5px #06b6d466}.crud-add-btn:hover{transform:translateY(-2px);box-shadow:0 15px 25px -5px #06b6d499}.crud-table-container{background:var(--card-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--card-border);border-radius:20px;overflow:hidden;box-shadow:0 20px 40px -15px #0000000d}[data-theme=dark] .crud-table-container{box-shadow:0 20px 40px -15px #0000004d}.scrollable-table{overflow-x:auto}.crud-table{border-collapse:collapse;width:100%}.crud-table th,.crud-table td{border-bottom:1px solid var(--card-border);padding:1.25rem 1.5rem}.crud-table th{text-transform:uppercase;color:var(--text-secondary);background:#00000005;font-weight:700}[data-theme=dark] .crud-table th{background:#00000026}.crud-table td{color:var(--text-primary)}.crud-row:hover td{background:var(--hover-bg)}.crud-modal-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:999;background:#0f172a66;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}[data-theme=dark] .crud-modal-backdrop{background:#0f172ab3}.crud-modal{background:var(--modal-bg);-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);border:1px solid var(--modal-border);border-radius:24px;flex-direction:column;width:100%;max-width:700px;max-height:85vh;padding:2.25rem;display:flex;box-shadow:0 25px 50px -12px #0000001a}[data-theme=dark] .crud-modal{box-shadow:0 25px 50px -12px #0009}.modal-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.modal-header h2{color:var(--text-primary);font-size:1.5rem;font-weight:700}.modal-close-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:.25rem;font-size:1.25rem;transition:color .2s;display:flex}.modal-close-btn:hover{color:var(--text-primary)}.modal-form{grid-template-columns:1fr 1fr;gap:1.5rem;max-height:calc(85vh - 8rem);padding-right:.5rem;display:grid;overflow-y:auto}.modal-form .modal-input-group{grid-column:span 1}.modal-form .modal-input-group.full-width{grid-column:span 2}.modal-input-group{text-align:left;flex-direction:column;gap:.5rem;display:flex}.modal-input-group label{color:var(--text-secondary);font-size:.875rem;font-weight:600}.modal-input-group input,.modal-input-group select{background:var(--input-bg);border:1px solid var(--input-border);color:var(--input-color);border-radius:12px;outline:none;padding:.85rem 1rem}.modal-input-group input:focus,.modal-input-group select:focus{border-color:var(--accent-color);background:var(--modal-bg);box-shadow:0 0 0 3px #06b6d426}.modal-actions{flex-shrink:0;grid-column:span 2;justify-content:flex-end;gap:1rem;margin-top:1.5rem;display:flex}.modal-btn{cursor:pointer;border:none;border-radius:12px;padding:.85rem 1.5rem;font-weight:700}.btn-cancel{background:var(--hover-bg);color:var(--text-secondary);border:1px solid var(--card-border)}.btn-cancel:hover{background:var(--hover-bg);opacity:.8;color:var(--text-primary)}.btn-save{background:var(--accent-gradient);color:#fff;box-shadow:0 5px 15px -3px #06b6d44d}.btn-save:hover{filter:brightness(1.05);box-shadow:0 8px 20px -3px #06b6d480}.input-helper-text{color:var(--text-secondary);text-align:left;font-size:.75rem}.modal-form-row{gap:1rem;display:flex}.modal-form-row .modal-input-group{flex:1}.gasto-sede-tag{color:var(--text-primary);background:#ffffff0d;border:1px solid #ffffff14;border-radius:8px;padding:.35rem .75rem;font-size:.875rem;font-weight:500;display:inline-block}.gasto-amount-badge{color:#f87171;font-weight:700;font-family:var(--mono);background:#ef444426;border:1px solid #ef44444d;border-radius:10px;padding:.35rem .75rem;font-size:.95rem;display:inline-block;box-shadow:0 4px 6px -1px #0000001a}.gasto-motivo-cell{text-overflow:ellipsis;white-space:nowrap;max-width:250px;overflow:hidden}.input-helper-text{color:var(--text-secondary);margin-top:.25rem;font-size:.75rem;font-style:italic}.badge{text-transform:uppercase;letter-spacing:.5px;border-radius:20px;align-items:center;gap:.35rem;padding:.4rem .85rem;font-size:.825rem;font-weight:700;display:inline-flex;box-shadow:0 4px 6px -1px #0003}.badge-owner{color:#c084fc;background:#a855f726;border:1px solid #a855f74d;box-shadow:0 0 10px #a855f71a}.badge-admin{color:#22d3ee;background:#06b6d426;border:1px solid #06b6d44d;box-shadow:0 0 10px #06b6d41a}.modal-input-group select option{color:#fff;background:#1e293b}.text-danger{color:#ef4444!important}.sidebar{background:var(--sidebar-bg);-webkit-backdrop-filter:blur(12px);border-right:1px solid var(--sidebar-border);width:260px;height:100vh;color:var(--text-primary);z-index:100;flex-direction:column;flex-shrink:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;transition:all .3s;display:flex;box-shadow:4px 0 25px #0000004d}.sidebar-header{border-bottom:1px solid var(--sidebar-border);padding:1.25rem}.logo-container{align-items:center;gap:.75rem;display:flex}.logo-icon{background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background:#06b6d41a;border:1px solid #06b6d433;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.25rem;display:flex}.logo-text{letter-spacing:-.025em;color:var(--text-primary);margin:0;font-size:1.2rem;font-weight:700}.logo-text span{color:var(--accent-color)}.sidebar-nav{scrollbar-width:none;flex-direction:column;flex:1;gap:.35rem;padding:1rem .75rem;display:flex;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{display:none}.nav-item{color:var(--text-secondary);border-radius:10px;align-items:center;gap:.75rem;padding:.65rem .85rem;font-size:.92rem;font-weight:500;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.nav-item:hover{background:var(--hover-bg);color:var(--text-primary);transform:translate(4px)}.nav-item.active{background:var(--active-bg);color:var(--text-primary);font-weight:600}.nav-item.active:before{content:"";background:var(--accent-gradient);border-radius:0 4px 4px 0;width:4px;height:70%;position:absolute;top:15%;left:0}.nav-icon{width:18px;height:18px;transition:all .2s}.nav-item:hover .nav-icon{color:var(--accent-color);transform:scale(1.1)}.nav-item.active .nav-icon{color:var(--accent-color)}.sidebar-footer{border-top:1px solid var(--sidebar-border);background:0 0;flex-direction:column;gap:.5rem;padding:1.15rem 1.25rem;display:flex}.user-profile{align-items:center;gap:.75rem;display:flex}.avatar{background:var(--accent-gradient);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:.85rem;font-weight:600;display:flex;box-shadow:0 4px 10px #06b6d44d}.user-info{flex-direction:column;display:flex}.user-name{color:var(--text-primary);margin:0;font-size:.85rem;font-weight:600}.user-role{color:var(--text-secondary);margin:0;font-size:.72rem}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.nav-item.active .nav-icon{animation:2s ease-in-out infinite pulse}.logout-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;padding:.45rem;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.logout-btn:hover{color:#ef4444;background:#ef444426;transform:scale(1.1)}.logout-btn svg{transition:transform .2s}.logout-btn:hover svg{transform:translate(2px)}.sidebar.collapsed{width:80px}.sidebar.collapsed .sidebar-header{justify-content:center;padding:1rem .5rem;display:flex}.sidebar.collapsed .sidebar-nav{align-items:center;padding:1rem .5rem}.sidebar.collapsed .nav-item{border-radius:12px;justify-content:center;gap:0;width:44px;height:44px;padding:0}.sidebar.collapsed .nav-item span{display:none}.sidebar.collapsed .nav-item:hover{transform:scale(1.08)}.sidebar.collapsed .nav-item.active:before{width:3px;height:50%;top:25%}.sidebar.collapsed .sidebar-footer{padding:1rem .5rem}.sidebar.collapsed .theme-label{display:none}.sidebar.collapsed .theme-toggle-simple-btn{border-radius:12px;justify-content:center;gap:0;width:40px;height:40px;padding:.65rem 0}.sidebar-toggle-btn:hover{transform:scale(1.05);background:var(--hover-bg)!important;color:var(--accent-color)!important;border-color:#06b6d466!important}.theme-toggle-container{width:100%}.theme-toggle-simple-btn{width:100%;color:var(--text-primary);cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;align-items:center;gap:.75rem;padding:.75rem 1rem;font-family:inherit;font-size:.9rem;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.theme-toggle-simple-btn:hover{background:#ffffff1a;border-color:#fff3;transform:translateY(-2px)}.theme-toggle-simple-btn:active{transform:translateY(0)}.theme-icon{font-size:1.1rem;transition:transform .3s}.theme-toggle-simple-btn:hover .theme-icon{transform:rotate(15deg)scale(1.1)}.theme-label{text-align:left;flex:1}[data-theme=light] .theme-toggle-simple-btn{color:var(--text-primary);background:#0000000d;border-color:#0000001a}[data-theme=light] .theme-toggle-simple-btn:hover{background:#00000014;border-color:#00000026}
