:root{font-family:Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#2d3748;background-color:#f5f7fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background-color:#f5f7fa}#root{width:100%;min-height:100vh}a{font-weight:500;color:#667eea;text-decoration:none}a:hover{color:#764ba2}h1,h2,h3,h4,h5,h6{line-height:1.2;color:#2d3748}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:all .25s ease}button:focus,button:focus-visible{outline:2px solid #667eea;outline-offset:2px}img{max-width:100%;height:auto}.text-center{text-align:center}.w-full{width:100%}.h-full{height:100%}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.gap-4{gap:1rem}.mt-4{margin-top:1rem}.mb-4{margin-bottom:1rem}.p-4{padding:1rem}.logo-container{display:inline-flex;align-items:center}.logo-content{display:flex;align-items:center;gap:10px;background:#fff;padding:10px 18px;border-radius:10px;box-shadow:0 2px 8px #00000014}.logo-icon{display:flex;align-items:center;justify-content:center}.logo-icon svg{width:32px;height:32px;display:block}.logo-text{display:flex;align-items:center;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:24px;font-weight:700;letter-spacing:-.5px}.logo-client{color:#1e3a8a}.logo-code{color:#3b82f6}.logo-small .logo-content{padding:6px 12px;gap:6px}.logo-small .logo-icon svg{width:24px;height:24px}.logo-small .logo-text{font-size:18px}.logo-medium .logo-content{padding:10px 18px;gap:10px}.logo-medium .logo-icon svg{width:32px;height:32px}.logo-medium .logo-text{font-size:24px}.logo-large .logo-content{padding:14px 24px;gap:12px}.logo-large .logo-icon svg{width:40px;height:40px}.logo-large .logo-text{font-size:30px}.header-brand .logo-content{background:#fffffff2;box-shadow:0 2px 8px #0000001a}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow-y:auto}.modal-content.terms-modal{background:#fff;border-radius:12px;width:100%;max-width:800px;max-height:90vh;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column}.modal-header{padding:24px 32px;border-bottom:2px solid #e5e7eb;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border-radius:12px 12px 0 0}.modal-header h2{font-size:24px;font-weight:700;margin:0 0 8px}.modal-header p{font-size:14px;opacity:.9;margin:0}.modal-body{padding:24px 32px;overflow-y:auto;flex:1;max-height:60vh}.terms-content{color:#374151;line-height:1.7}.terms-date{background:#f3f4f6;padding:12px 16px;border-radius:8px;margin-bottom:24px;font-size:14px}.terms-section{margin-bottom:28px}.terms-section h3{font-size:18px;font-weight:600;color:#111827;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #e5e7eb}.terms-section p{margin-bottom:12px;font-size:14px}.terms-section ul{margin:12px 0;padding-left:24px}.terms-section li{margin-bottom:8px;font-size:14px}.pricing-table{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:16px 0}.plan-item{background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;padding:20px}.plan-item h4{font-size:16px;font-weight:600;color:#111827;margin:0 0 8px}.plan-item .price{font-size:20px;font-weight:700;color:#2563eb;margin:0 0 12px}.plan-item ul{margin:0;padding-left:18px}.plan-item li{font-size:13px;margin-bottom:4px}.note{background:#fef3c7;border:1px solid #f59e0b;padding:12px 16px;border-radius:6px;font-size:13px;margin-top:16px}.contact-info{background:#eff6ff;border:1px solid #3b82f6;padding:16px;border-radius:8px;margin-top:12px}.contact-info p{margin:8px 0;font-size:14px}.modal-footer{padding:24px 32px;border-top:1px solid #e5e7eb;background:#f9fafb;border-radius:0 0 12px 12px}.checkbox-container{display:flex;align-items:flex-start;gap:12px;margin-bottom:20px;cursor:pointer;font-size:14px;color:#374151}.checkbox-container input[type=checkbox]{width:20px;height:20px;margin-top:2px;cursor:pointer;accent-color:#2563eb}.checkbox-text{line-height:1.5}.buttons-container{display:flex;gap:12px;justify-content:flex-end}.btn-secondary{padding:12px 24px;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:#f3f4f6;border-color:#9ca3af}.btn-primary{padding:12px 24px;background:#2563eb;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-primary:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.btn-primary.disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.modal-body::-webkit-scrollbar{width:8px}.modal-body::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.modal-body::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.modal-body::-webkit-scrollbar-thumb:hover{background:#a1a1a1}@media(max-width:768px){.modal-content.terms-modal{max-height:95vh;margin:10px}.modal-header,.modal-body,.modal-footer{padding:16px 20px}.modal-header h2{font-size:20px}.pricing-table{grid-template-columns:1fr}.buttons-container{flex-direction:column}.btn-secondary,.btn-primary{width:100%}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow:hidden;padding:20px}.login-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 1px,transparent 1px);background-size:50px 50px;opacity:.5}.login-card{background:#fffffff2;border-radius:20px;padding:48px;width:100%;max-width:420px;box-shadow:0 25px 50px -12px #00000040;position:relative;z-index:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}.login-header{text-align:center;margin-bottom:36px}.logo-box{width:70px;height:70px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-weight:800;font-size:24px;color:#fff;box-shadow:0 10px 25px #667eea66;letter-spacing:1px}.login-title{font-size:30px;font-weight:800;color:#1e293b;margin-bottom:8px;line-height:1.2}.login-subtitle{font-size:16px;color:#64748b;margin:0;font-weight:500}.login-form{margin-bottom:28px}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#374151;font-size:14px}.form-group input{width:100%;padding:14px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:16px;transition:all .3s ease;background-color:#fff;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea1a;transform:translateY(-1px)}.toggle-password{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;font-size:13px;font-weight:600;cursor:pointer;padding:6px 14px;border-radius:8px;transition:all .3s ease}.toggle-password:hover{transform:translateY(-50%) scale(1.05);box-shadow:0 4px 12px #667eea66}.error-message{background:#fef2f2;border-left:4px solid #ef4444;color:#dc2626;padding:14px 16px;border-radius:8px;font-size:14px;margin-bottom:24px;font-weight:500}.login-button{width:100%;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea66}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea80}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-footer{text-align:center;padding-top:24px;border-top:2px solid #f3f4f6}.register-link{font-size:15px;color:#64748b;margin-bottom:16px;font-weight:500}.link-button{background:none;border:none;color:#667eea;font-weight:700;cursor:pointer;padding:0;font-size:15px;text-decoration:none;transition:all .3s ease}.link-button:hover{color:#764ba2;text-decoration:underline}.terms-link{font-size:13px;color:#6b7280;margin:12px 0}.terms-link .link-button{font-size:13px;color:#6b7280;font-weight:500}.terms-link .link-button:hover{color:#374151}.admin-info{font-size:13px;color:#9ca3af;font-weight:500;margin-top:12px;padding-top:12px;border-top:1px solid #e5e7eb}.admin-info p{margin:0}.forgot-password-link{text-align:center;margin-top:16px}.forgot-password-link .link-button{color:#6b7280;font-weight:500;font-size:14px}.forgot-password-link .link-button:hover{color:#667eea}@media(max-width:480px){.login-card{padding:32px 24px;border-radius:16px}.login-title{font-size:26px}.logo-box{width:60px;height:60px;font-size:20px}}.register-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:#f3f4f6;padding:20px}.register-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:40px;width:100%;max-width:400px;box-shadow:0 1px 3px #0000001a}.register-header{text-align:center;margin-bottom:32px}.logo-box{width:48px;height:48px;background:#2563eb;color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-weight:700;font-size:16px;letter-spacing:.05em}.register-title{font-size:24px;font-weight:700;color:#111827;margin-bottom:8px;line-height:1.2;letter-spacing:-.025em}.register-subtitle{font-size:15px;color:#6b7280;margin:0}.register-form{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#374151;font-size:14px}.form-group input{width:100%;padding:12px 16px;border:1px solid #d1d5db;border-radius:6px;font-size:15px;transition:all .2s ease;background-color:#fff;box-sizing:border-box}.form-group input::placeholder{color:#9ca3af}.password-input-wrapper input{padding-right:80px}.toggle-password{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:#2563eb;font-size:13px;font-weight:500;cursor:pointer;padding:4px 8px}.field-hint{display:block;font-size:12px;color:#6b7280;margin-top:6px;margin-left:4px}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:6px;font-size:14px;margin-bottom:20px}.success-message{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a;padding:12px 16px;border-radius:6px;font-size:14px;margin-bottom:20px}.register-button{width:100%;padding:12px;background:#2563eb;color:#fff;border:none;border-radius:6px;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease}.register-button:hover:not(:disabled){background:#1d4ed8}.register-button:disabled{opacity:.6;cursor:not-allowed}.register-footer{text-align:center;padding-top:24px;border-top:1px solid #e5e7eb}.login-link{font-size:14px;color:#6b7280}.link-button{background:none;border:none;color:#2563eb;font-weight:500;cursor:pointer;padding:0;font-size:14px}.link-button:hover{color:#1d4ed8;text-decoration:underline}.terms-link{font-size:13px;color:#6b7280;margin-top:12px;padding-top:12px;border-top:1px solid #e5e7eb}.terms-link .link-button{font-size:13px}@media(max-width:480px){.register-card{padding:32px 24px}.register-title{font-size:22px}}.forgot-password-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#1e3a8a,#3b82f6)}.forgot-password-card{background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000026;padding:40px;width:100%;max-width:420px}.forgot-password-header{text-align:center;margin-bottom:32px}.logo-box{width:64px;height:64px;background:linear-gradient(135deg,#1e3a8a,#3b82f6);border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:0 4px 12px #1e3a8a4d}.logo-box span{color:#fff;font-size:24px;font-weight:700}.forgot-password-title{font-size:24px;font-weight:700;color:#1e293b;margin-bottom:8px}.forgot-password-subtitle{color:#64748b;font-size:14px;line-height:1.5}.forgot-password-form{margin-bottom:24px}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:6px}.form-group input{width:100%;padding:12px 14px;border:2px solid #e5e7eb;border-radius:8px;font-size:15px;transition:all .2s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled{background-color:#f3f4f6;cursor:not-allowed}.password-input-wrapper{position:relative}.password-input-wrapper input{padding-right:90px}.toggle-password{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:#3b82f6;font-size:13px;font-weight:500;cursor:pointer;padding:4px 8px}.toggle-password:hover{color:#1d4ed8}.code-input{text-align:center;font-size:24px!important;font-weight:600;letter-spacing:4px}.dev-notice{margin-top:12px;padding:10px;background:#fef3c7;border:1px solid #fbbf24;border-radius:6px;font-size:13px;color:#92400e}.error-message{background:#fee2e2;border:1px solid #fecaca;color:#991b1b;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.success-message{background:#dcfce7;border:1px solid #86efac;color:#166534;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.forgot-password-button{width:100%;padding:14px;background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.forgot-password-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #1e3a8a4d}.forgot-password-button:disabled{opacity:.6;cursor:not-allowed}.button-group{display:flex;gap:12px}.button-group .btn-secondary{flex:1;padding:14px;background:#f3f4f6;color:#374151;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.button-group .btn-secondary:hover:not(:disabled){background:#e5e7eb}.button-group .forgot-password-button{flex:2}.forgot-password-footer{text-align:center;padding-top:20px;border-top:1px solid #e5e7eb}.login-link{color:#6b7280;font-size:14px}.link-button{background:none;border:none;color:#3b82f6;font-size:14px;font-weight:600;cursor:pointer;text-decoration:underline}.link-button:hover{color:#1d4ed8}@media(max-width:480px){.forgot-password-card{padding:28px 20px}.forgot-password-title{font-size:20px}.button-group{flex-direction:column}.button-group .btn-secondary,.button-group .forgot-password-button{flex:none}}.avance-anual{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:20px;padding:40px;box-shadow:0 10px 40px #0000001a;border:1px solid rgba(255,255,255,.5)}.avance-header{margin-bottom:32px;padding-bottom:24px;border-bottom:2px solid #f1f5f9}.avance-header h2{font-size:28px;font-weight:800;color:#1e293b;margin-bottom:8px;letter-spacing:-.5px}.avance-header p{color:#64748b;font-size:16px;margin:0;font-weight:500}.avance-resumen-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:40px}.resumen-card{background:linear-gradient(135deg,#1e3a8a,#3730a3);padding:24px;border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:8px;box-shadow:0 4px 12px #1e3a8a4d}.resumen-label{font-size:13px;color:#fffc;font-weight:600;text-transform:uppercase;letter-spacing:.5px;text-align:center}.resumen-value{font-size:24px;font-weight:800;color:#fff}.avance-tabla-section{background:#fff;border-radius:16px;padding:28px;border:2px solid #e2e8f0;margin-bottom:32px}.tabla-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.tabla-header h3{font-size:20px;font-weight:700;color:#1e293b;margin:0}.btn-toggle-details{padding:10px 20px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-toggle-details:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.meses-table-wrapper{overflow-x:auto;border-radius:12px;border:1px solid #e2e8f0}.meses-table-avance{width:100%;border-collapse:collapse;font-size:14px}.meses-table-avance th{background:#0ea5e9;color:#fff;padding:14px 16px;font-weight:600;text-transform:uppercase;font-size:12px;letter-spacing:.5px}.meses-table-avance th.col-mes-header{text-align:left}.meses-table-avance th.col-cliente-header{text-align:center}.meses-table-avance th.col-numero-header{text-align:right}.meses-table-avance th.col-estado-header{text-align:center}.meses-table-avance td{padding:12px 16px;border-bottom:1px solid #e2e8f0}.meses-table-avance tr:nth-child(2n){background:#f8fafc}.meses-table-avance tr:hover{background:#f0f9ff}.meses-table-avance td.col-mes{font-weight:600;color:#1e3a8a;text-align:left}.meses-table-avance td.col-cliente{text-align:center;font-family:Courier New,monospace;font-weight:600;color:#0369a1}.meses-table-avance td.col-numero{text-align:right;font-family:Courier New,monospace;font-weight:600;color:#0369a1}.meses-table-avance td.col-estado{text-align:center}.check-icon.small{width:18px;height:18px;font-size:11px}.detalles-section{margin-top:32px;padding-top:24px;border-top:2px solid #e2e8f0}.detalles-section h4{font-size:18px;font-weight:700;color:#1e3a8a;margin-bottom:16px}.detalles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.detalle-card{background:#f8fafc;border:2px solid #e2e8f0;border-radius:10px;padding:16px;transition:all .3s ease}.detalle-card:hover{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f626}.detalle-mes{font-weight:700;color:#1e3a8a;font-size:16px;margin-bottom:8px}.detalle-stats{display:flex;justify-content:space-between;align-items:center;color:#64748b;font-size:14px}.detalle-monto{font-weight:700;color:#0369a1;font-family:Courier New,monospace}.no-data{text-align:center;color:#94a3b8;font-style:italic;padding:20px}.avance-leyenda{background:#f0f9ff;border:2px solid #bae6fd;padding:24px;border-radius:12px}.avance-leyenda h4{font-size:16px;font-weight:700;color:#0369a1;margin-bottom:16px}.leyenda-items{display:flex;gap:32px;flex-wrap:wrap}.leyenda-item{display:flex;align-items:center;gap:8px;font-size:14px;color:#1e293b}@media(max-width:768px){.avance-anual{padding:24px}.avance-header h2{font-size:24px}.avance-resumen-cards{grid-template-columns:repeat(2,1fr)}.resumen-card{padding:16px}.resumen-value{font-size:20px}.avance-tabla-section{padding:20px}.tabla-header{flex-direction:column;gap:12px;align-items:flex-start}.meses-table-avance{font-size:12px}.meses-table-avance th,.meses-table-avance td{padding:10px 8px}.detalles-grid{grid-template-columns:1fr}}@media(max-width:480px){.avance-resumen-cards{grid-template-columns:1fr}}.pdf-viewer-modal-overlay{position:fixed;inset:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:20px}.pdf-viewer-modal{background:#fff;border-radius:16px;width:95%;max-width:1200px;height:90vh;display:flex;flex-direction:column;box-shadow:0 25px 80px #0006;animation:pdfModalSlideIn .3s ease;overflow:hidden}@keyframes pdfModalSlideIn{0%{opacity:0;transform:scale(.95) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.pdf-viewer-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;border-bottom:1px solid rgba(255,255,255,.1)}.pdf-viewer-title{display:flex;align-items:center;gap:12px}.pdf-viewer-title h3{margin:0;font-size:1.25rem;font-weight:600}.pdf-viewer-icon{font-size:1.5rem}.pdf-viewer-close{background:#fff3;border:none;color:#fff;width:40px;height:40px;border-radius:50%;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.pdf-viewer-close:hover{background:#ffffff4d;transform:rotate(90deg)}.pdf-viewer-content{flex:1;background:#f3f4f6;position:relative;overflow:auto;display:flex;align-items:center;justify-content:center;padding:20px}.pdf-viewer-frame{width:100%;height:100%;border:none;background:#fff;box-shadow:0 4px 20px #0000001a;border-radius:8px}.pdf-viewer-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#6b7280}.pdf-viewer-spinner{width:50px;height:50px;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.pdf-viewer-footer{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:#fff;border-top:1px solid #e5e7eb}.pdf-viewer-info{color:#6b7280;font-size:.9rem}.pdf-viewer-actions{display:flex;gap:12px}.pdf-viewer-btn{padding:10px 20px;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.pdf-viewer-btn-secondary{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb}.pdf-viewer-btn-secondary:hover{background:#e5e7eb}.pdf-viewer-btn-primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.pdf-viewer-btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}@media(max-width:768px){.pdf-viewer-modal{width:100%;height:100%;border-radius:0}.pdf-viewer-header{padding:16px}.pdf-viewer-title h3{font-size:1rem}.pdf-viewer-footer{flex-direction:column;gap:12px;padding:12px 16px}.pdf-viewer-actions{width:100%}.pdf-viewer-btn{flex:1;justify-content:center}}.historial-container{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 6px -1px #0000001a;border:1px solid #e5e7eb}.historial-header{margin-bottom:24px;padding-bottom:20px;border-bottom:2px solid #f3f4f6}.historial-header h2{font-size:1.5rem;color:#111827;margin:0 0 8px;display:flex;align-items:center;gap:10px}.historial-header p{color:#6b7280;margin:0;font-size:.95rem}.historial-stats{display:flex;gap:16px;margin-top:16px}.historial-stat-item{background:#f9fafb;padding:12px 16px;border-radius:10px;border:1px solid #e5e7eb}.historial-stat-label{font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;display:block}.historial-stat-value{font-size:1.25rem;font-weight:700;color:#111827}.historial-list{display:flex;flex-direction:column;gap:12px}.historial-empty{text-align:center;padding:48px 24px;color:#6b7280}.historial-empty-icon{font-size:3rem;margin-bottom:16px}.historial-empty h3{margin:0 0 8px;color:#374151}.historial-empty p{margin:0;font-size:.95rem}.historial-item{background:#f9fafb;border-radius:12px;padding:16px 20px;border:1px solid #e5e7eb;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:16px}.historial-item:hover{background:#f3f4f6;border-color:#d1d5db;box-shadow:0 4px 12px #0000000d}.historial-item-icon{font-size:2rem;flex-shrink:0}.historial-item-content{flex:1}.historial-item-title{font-size:1.1rem;font-weight:600;color:#111827;margin:0 0 4px}.historial-item-date{font-size:.875rem;color:#6b7280;margin:0}.historial-item-stats{display:flex;gap:16px;margin-top:8px}.historial-item-stat{font-size:.85rem;color:#374151;background:#fff;padding:4px 10px;border-radius:20px;border:1px solid #e5e7eb}.historial-item-actions{display:flex;gap:8px}.historial-item-btn{padding:8px 16px;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.historial-item-btn-view{background:#3b82f6;color:#fff}.historial-item-btn-view:hover{background:#2563eb}.historial-item-btn-download{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb}.historial-item-btn-download:hover{background:#e5e7eb}.historial-item-productos{margin-top:16px;background:#fff;border-radius:8px;padding:16px;border:1px solid #e5e7eb}.productos-title{font-size:1.25rem;font-weight:600;color:#1e3a8a;margin:0 0 16px}.productos-table{width:100%;border-collapse:collapse;font-size:.95rem}.productos-table thead{background-color:#16a34a}.productos-table th{color:#fff;font-weight:600;padding:12px 16px;text-align:left;border:1px solid #e5e7eb}.productos-table th:last-child{text-align:center;width:80px}.productos-table td{padding:10px 16px;border:1px solid #e5e7eb;color:#374151}.productos-table td:last-child{text-align:center;font-weight:500}.productos-table tbody tr{background-color:#fff}.productos-table tbody tr:nth-child(2n){background-color:#f9fafb}.productos-table tbody tr:hover{background-color:#f3f4f6}@media(max-width:640px){.productos-table{font-size:.85rem}.productos-table th,.productos-table td{padding:8px 12px}}.historial-item-observaciones{margin-top:16px;background:#fff;border-radius:8px;padding:16px;border:1px solid #e5e7eb}.observaciones-title{font-size:1.1rem;font-weight:600;color:#1e3a8a;margin:0 0 12px}.observaciones-table{width:100%;border-collapse:collapse;font-size:.9rem}.observaciones-table thead{background-color:#1e3a8a}.observaciones-table th{color:#fff;font-weight:600;padding:10px 12px;text-align:left;border:1px solid #e5e7eb}.observaciones-table th:first-child{width:40px;text-align:center}.observaciones-table th:last-child{width:150px;text-align:center}.observaciones-table td{padding:8px 12px;border:1px solid #e5e7eb;color:#374151}.observaciones-table td:first-child{text-align:center;font-weight:600;color:#6b7280}.observaciones-table tbody tr:nth-child(2n){background-color:#f9fafb}.observaciones-table .obs-cobro{background-color:#fef3c7!important;color:#92400e!important;font-weight:600}.observaciones-table .obs-pendiente{background-color:#dcfce7!important;color:#166534!important;font-weight:600}.observaciones-table .obs-cancelado{background-color:#fee2e2!important;color:#991b1b!important;font-weight:600}.observaciones-more{text-align:center;color:#6b7280;font-size:.85rem;margin:12px 0 0;font-style:italic}@media(max-width:640px){.observaciones-table{font-size:.8rem}.observaciones-table th,.observaciones-table td{padding:6px 8px}.observaciones-table th:last-child{width:100px}}@media(max-width:640px){.historial-container{padding:16px}.historial-item{flex-direction:column;align-items:flex-start;gap:12px}.historial-item-actions{width:100%;justify-content:stretch}.historial-item-btn{flex:1}}.month-selector{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:20px;padding:40px;box-shadow:0 10px 40px #0000001a;border:1px solid rgba(255,255,255,.5)}.tabs-navigation{display:flex;gap:12px;margin-bottom:32px;padding-bottom:20px;border-bottom:2px solid #f1f5f9}.tab-btn{padding:12px 24px;background:#f1f5f9;color:#64748b;border:2px solid transparent;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease}.tab-btn:hover{background:#e2e8f0;color:#475569}.tab-btn.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-color:#1d4ed8;box-shadow:0 4px 12px #2563eb4d}.selector-header{margin-bottom:32px;padding-bottom:24px;border-bottom:2px solid #f1f5f9}.selector-header h2{font-size:28px;font-weight:800;color:#1e293b;margin-bottom:8px;letter-spacing:-.5px}.selector-header p{color:#64748b;font-size:16px;margin:0;font-weight:500}.months-grid-client{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;margin-bottom:40px}.month-card-client{background:#fff;border:2px solid #e2e8f0;border-radius:16px;padding:28px 24px;text-align:center;transition:all .3s ease;cursor:pointer;position:relative;overflow:hidden}.month-card-client:hover{border-color:#667eea;transform:translateY(-5px);box-shadow:0 20px 40px #667eea33}.month-card-client.available{background:linear-gradient(135deg,#fff,#f0f9ff);border-color:#3b82f6;box-shadow:0 4px 15px #3b82f626}.month-card-client.available:hover{background:linear-gradient(135deg,#fff,#dbeafe);border-color:#2563eb;box-shadow:0 20px 40px #2563eb40}.month-card-client.disabled{opacity:.5;cursor:not-allowed;background:#f8fafc;border-style:dashed}.month-number{font-size:42px;font-weight:800;color:#3b82f6;margin-bottom:8px;line-height:1;text-shadow:2px 2px 4px rgba(59,130,246,.2)}.month-card-client.disabled .month-number{color:#94a3b8;text-shadow:none}.month-name-client{font-size:18px;font-weight:700;color:#1e293b;margin-bottom:16px;text-transform:capitalize}.month-card-client.disabled .month-name-client{color:#64748b}.month-status{display:flex;flex-direction:column;align-items:center;gap:10px}.status-badge{display:inline-flex;align-items:center;padding:6px 16px;border-radius:20px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px}.month-status.available .status-badge{background:#dcfce7;color:#166534}.month-status.disabled .status-badge{background:#f1f5f9;color:#64748b}.btn-open{margin-top:4px;padding:10px 24px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;opacity:0;transition:all .3s ease;box-shadow:0 4px 15px #2563eb4d}.month-card-client.available:hover .btn-open{opacity:1;transform:translateY(0)}.btn-open:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 6px 20px #2563eb66}.empty-state{text-align:center;padding:80px 24px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:16px;border:2px dashed #cbd5e1}.empty-icon{color:#94a3b8;margin-bottom:24px}.empty-icon svg{width:64px;height:64px}.empty-state h3{font-size:22px;font-weight:700;color:#1e293b;margin-bottom:12px}.empty-state p{color:#64748b;font-size:16px;margin-bottom:8px;font-weight:500}.empty-hint{font-size:14px;color:#94a3b8;font-style:italic}.client-info{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #bae6fd;padding:28px;border-radius:16px}.client-info h4{font-size:16px;font-weight:700;color:#0369a1;margin-bottom:16px;text-transform:uppercase;letter-spacing:1px}.client-info ol{margin:0;padding-left:24px;color:#0c4a6e;font-size:15px;line-height:1.8;font-weight:500}.client-info li{margin-bottom:10px}@media(max-width:768px){.month-selector{padding:28px 24px}.months-grid-client{grid-template-columns:repeat(2,1fr);gap:16px}.month-card-client{padding:24px 20px}.month-number{font-size:36px}.btn-open{opacity:1;padding:8px 20px;font-size:13px}.selector-header h2{font-size:24px}}@media(max-width:480px){.months-grid-client{grid-template-columns:1fr}}.document-editor-v2{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000001a;overflow:hidden}.read-only-banner{background:linear-gradient(135deg,#fee2e2,#fecaca);border-bottom:2px solid #ef4444;padding:16px 24px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}.read-only-icon{font-size:24px;width:40px;height:40px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000001a}.read-only-content{display:flex;flex-direction:column;gap:2px;flex:1}.read-only-content strong{color:#991b1b;font-size:15px}.read-only-content span{color:#7f1d1d;font-size:13px}.read-only-btn{padding:10px 20px;background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;animation:pulse 2s infinite}.read-only-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.data-input:disabled{background:#f3f4f6;cursor:not-allowed;opacity:.7}.editor-header-v2{background:linear-gradient(135deg,#1e3a8a,#3730a3);padding:24px 32px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.header-content h2{color:#fff;font-size:26px;font-weight:700;margin:0 0 4px}.client-name{color:#fffc;font-size:15px;margin:0}.header-actions{display:flex;align-items:center;gap:12px}.save-indicator{color:#ffffffe6;font-size:13px;background:#fff3;padding:8px 14px;border-radius:8px;font-weight:600}.btn-save-v2{background:#fff;color:#1e3a8a;border:none;padding:12px 24px;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #00000026}.btn-save-v2:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.btn-save-v2:disabled{opacity:.7;cursor:not-allowed}.btn-save-final{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:12px 24px;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #10b9814d;margin-left:12px}.btn-save-final:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.btn-save-final:disabled{opacity:.7;cursor:not-allowed}.sheets-container{padding:24px;display:flex;flex-direction:column;gap:32px}.sheet-section{background:#f8fafc;border-radius:16px;padding:28px;border:2px solid #e2e8f0}.sheet-section.dashboard{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-color:#7dd3fc}.sheet-header-v2{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #e2e8f0}.sheet-section.dashboard .sheet-header-v2{border-bottom-color:#7dd3fc}.sheet-header-v2 h3{font-size:20px;font-weight:700;color:#1e293b;margin:0}.sheet-badge{padding:8px 16px;border-radius:20px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.sheet-badge.editable{background:#dbeafe;color:#1e40af}.sheet-badge.readonly{background:#dcfce7;color:#166534}.table-wrapper{overflow-x:auto;background:#fff;border-radius:12px;border:2px solid #e2e8f0;box-shadow:0 2px 8px #0000000d}.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:12px;table-layout:fixed}.data-table th{background:#1e3a8a;color:#fff;padding:12px 8px;text-align:left;font-weight:600;white-space:nowrap;font-size:11px;border-right:1px solid rgba(255,255,255,.2);overflow:hidden;text-overflow:ellipsis}.data-table th:last-child{border-right:none}.data-table td{padding:0;border-bottom:1px solid #e2e8f0;border-right:1px solid #e2e8f0;height:45px!important;vertical-align:middle;min-width:95px;max-width:130px;box-sizing:border-box;overflow:hidden}.data-table tbody tr{height:45px!important;display:table-row}.data-table tbody tr td{display:table-cell;visibility:visible;opacity:1}.data-table tbody tr:first-child td,.data-table tbody tr:nth-child(2) td{visibility:visible!important;opacity:1!important;display:table-cell!important}.data-table tbody tr:nth-child(2n){background-color:#f8fafc}.data-table tbody tr:hover{background-color:#f1f5f9}.data-table td:last-child{border-right:none}.data-table td.row-num{background:#f1f5f9;font-weight:700;color:#475569;text-align:center;width:45px;border-right:2px solid #cbd5e1;padding:10px}.data-input{width:100%;min-width:95px;height:45px!important;padding:6px 8px;border:none;font-size:13px;background:transparent;transition:all .2s ease;box-sizing:border-box}.data-input:focus{outline:none;background:#eff6ff;box-shadow:inset 0 0 0 2px #3b82f6}.data-input.readonly{background:#f1f5f9;color:#64748b}.data-table select.data-input{cursor:pointer;background-color:#fff;border:1px solid #e2e8f0;border-radius:4px;appearance:auto;padding-right:24px}.data-table select.data-input:focus{border-color:#3b82f6;background-color:#eff6ff}.input-with-prefix{display:flex;align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:0;overflow:hidden}.input-prefix{background:#f1f5f9;color:#64748b;padding:6px 8px;font-size:13px;font-weight:600;border-right:1px solid #e2e8f0;white-space:nowrap}.data-input.prefixed{border:none;border-radius:0;padding:6px 8px;flex:1;min-width:60px}.data-input.prefixed:focus{box-shadow:none;background:transparent}.input-with-prefix:focus-within{box-shadow:inset 0 0 0 2px #3b82f6;border-color:#3b82f6}.data-table th:not(.row-num),.data-table td:not(.row-num){min-width:85px;max-width:120px;width:calc((100% - 45px) / 11)}.dashboard-content{display:flex;flex-direction:column;gap:32px}.dashboard-section{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000000d}.dashboard-section h4{font-size:18px;font-weight:700;color:#1e3a8a;margin:0 0 20px;padding-bottom:12px;border-bottom:2px solid #e2e8f0}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.summary-card{background:linear-gradient(135deg,#1e3a8a,#3730a3);padding:24px;border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:8px;box-shadow:0 4px 12px #1e3a8a4d}.summary-label{font-size:13px;color:#fffc;font-weight:600;text-transform:uppercase;letter-spacing:.5px;text-align:center}.summary-value{font-size:28px;font-weight:800;color:#fff}.meses-table-wrapper{background:#fff;border-radius:8px;overflow:hidden;border:1px solid #e2e8f0}.meses-table{width:100%;border-collapse:collapse;font-size:14px}.meses-table th{background:#0ea5e9;color:#fff;padding:14px 16px;text-align:left;font-weight:600}.meses-table th.col-numero{text-align:right}.meses-table td{padding:12px 16px;border-bottom:1px solid #e2e8f0}.meses-table tr:hover{background:#f0f9ff}.meses-table td.col-numero,.meses-table td.col-cliente{text-align:right;font-family:Courier New,monospace;font-weight:600;color:#0369a1}.meses-table td.col-mes{font-weight:600;color:#1e3a8a}.meses-table td.col-estado{text-align:center}.meses-table .numero{text-align:right;font-family:Courier New,monospace;font-weight:600;color:#0369a1}.productos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}.producto-card{background:#f8fafc;border:2px solid #e2e8f0;border-radius:10px;padding:16px 20px;display:flex;justify-content:space-between;align-items:center;transition:all .3s ease}.producto-card:hover{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f626}.producto-nombre{font-weight:600;color:#1e293b;font-size:14px}.producto-total{background:#1e3a8a;color:#fff;padding:8px 16px;border-radius:20px;font-weight:700;font-size:16px;min-width:40px;text-align:center}.editor-footer-v2{background:#f1f5f9;padding:20px 32px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;border-top:2px solid #e2e8f0}.footer-info{display:flex;gap:32px;font-size:15px;color:#475569;font-weight:600}.btn-download-v2{background:linear-gradient(135deg,#1e3a8a,#3730a3);color:#fff;border:none;padding:14px 28px;border-radius:10px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #1e3a8a4d}.btn-download-v2:hover{transform:translateY(-2px);box-shadow:0 6px 20px #1e3a8a66}.download-buttons{display:flex;gap:12px;flex-wrap:wrap}.btn-download-v2.btn-excel{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 12px #0596694d}.btn-download-v2.btn-excel:hover{box-shadow:0 6px 20px #05966966}.btn-download-v2.btn-locked{background:linear-gradient(135deg,#6b7280,#4b5563);box-shadow:0 4px 12px #6b72804d;cursor:not-allowed;opacity:.8}.btn-download-v2.btn-locked:hover{transform:none;box-shadow:0 4px 12px #6b72804d}.table-row-controls{display:flex;gap:8px;margin-top:12px;margin-left:8px;align-items:center}.btn-row-control{position:relative;width:36px;height:36px;border-radius:8px;border:2px solid;font-size:22px;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;background:#fff}.btn-row-control:hover{transform:scale(1.1)}.btn-row-control:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-add-row{color:#16a34a;border-color:#16a34a}.btn-add-row:hover{background:#dcfce7;box-shadow:0 2px 8px #16a34a4d}.btn-remove-row{color:#dc2626;border-color:#dc2626}.btn-remove-row:hover:not(:disabled){background:#fee2e2;box-shadow:0 2px 8px #dc26264d}.control-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-8px);background:#1e293b;color:#fff;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:500;white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s ease;pointer-events:none;box-shadow:0 4px 12px #00000026}.control-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#1e293b}.btn-row-control:hover .control-tooltip{opacity:1;visibility:visible;transform:translate(-50%) translateY(-4px)}.editor-empty{text-align:center;padding:80px 20px;background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000001a}.editor-empty h3{font-size:24px;color:#1e293b;margin-bottom:12px;font-weight:700}.editor-empty p{color:#64748b;font-size:16px}@media(max-width:768px){.editor-header-v2{flex-direction:column;text-align:center;padding:20px}.sheets-container{padding:16px}.sheet-section{padding:20px}.summary-grid{grid-template-columns:1fr}.summary-value{font-size:24px}.productos-grid{grid-template-columns:1fr}.meses-table{font-size:12px}.meses-table th,.meses-table td{padding:8px}.editor-footer-v2{flex-direction:column;text-align:center;padding:16px}.footer-info{flex-direction:column;gap:8px}.data-input{min-width:80px;font-size:12px}.data-table,.data-table thead,.data-table tbody,.data-table th,.data-table td,.data-table tr{display:block}.data-table thead{display:none}.data-table tbody tr{margin-bottom:16px;border:1px solid #e2e8f0;border-radius:12px;padding:16px;background:#fff;box-shadow:0 2px 8px #00000014;position:relative}.data-table td.row-num{background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;border-radius:8px;padding:8px 16px;margin-bottom:12px;font-weight:700;font-size:16px;text-align:center;width:auto;height:auto!important;display:inline-block}.data-table td:not(.row-num){display:flex;justify-content:space-between;align-items:center;padding:10px 0;border:none;border-bottom:1px solid #f1f5f9;height:auto!important;min-height:44px}.data-table td:not(.row-num):last-child{border-bottom:none}.data-table td:not(.row-num):before{content:attr(data-label);font-weight:600;color:#1e3a8a;font-size:13px;flex-shrink:0;margin-right:12px}.data-table td:not(.row-num) .data-input,.data-table td:not(.row-num) select{flex:1;min-width:0;max-width:60%;font-size:14px;padding:8px 10px}.data-table td:not(.row-num) .input-with-prefix{flex:1;display:flex;align-items:center;max-width:60%}.data-table td:not(.row-num) .input-prefix{margin-right:6px;color:#64748b;font-size:14px}.data-table tbody tr{height:auto!important}}.color-legend{display:flex;align-items:center;gap:20px;margin-bottom:16px;padding:12px 16px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;flex-wrap:wrap}.legend-title{font-weight:700;color:#1e293b;font-size:14px}.legend-item{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;padding:6px 12px;border-radius:6px;border:1px solid #e2e8f0}.legend-item.yellow{background-color:#fef3c7;color:#92400e;border-color:#fcd34d}.legend-item.green{background-color:#dcfce7;color:#166534;border-color:#86efac}.legend-item.red{background-color:#fee2e2;color:#991b1b;border-color:#fca5a5}.preview-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.preview-modal{background:#fff;border-radius:16px;width:95%;max-width:1400px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 25px 50px #0000004d;overflow:hidden}.preview-header{background:linear-gradient(135deg,#1e3a8a,#3730a3);color:#fff;padding:20px 32px;display:flex;justify-content:space-between;align-items:center}.preview-header h3{margin:0;font-size:22px;font-weight:700}.preview-close-btn{background:#fff3;border:none;color:#fff;width:36px;height:36px;border-radius:50%;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.preview-close-btn:hover{background:#ffffff4d;transform:rotate(90deg)}.preview-content{flex:1;overflow:auto;padding:24px;background:#f8fafc}.preview-excel-table{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.preview-excel-table table{width:100%;border-collapse:collapse;font-size:13px}.preview-excel-table th{background:#217346;color:#fff;padding:14px 12px;text-align:left;font-weight:600;border-right:1px solid rgba(255,255,255,.2);white-space:nowrap}.preview-excel-table th:last-child{border-right:none}.preview-excel-table td{padding:12px;border-bottom:1px solid #e2e8f0;border-right:1px solid #e2e8f0;background:#fff}.preview-excel-table td:last-child{border-right:none}.preview-excel-table tr:nth-child(2n) td{background:#f8fafc}.preview-excel-table tr:hover td{background:#eff6ff}.preview-excel-table .no-data{text-align:center;color:#64748b;padding:40px;font-style:italic}.preview-section{margin-bottom:32px}.preview-section-title{font-size:20px;font-weight:700;color:#1e3a8a;margin-bottom:20px;padding-bottom:12px;border-bottom:3px solid #1e3a8a;text-align:center}.preview-instrucciones{background:#f0f9ff;border:2px solid #0ea5e9;border-radius:8px;padding:16px 20px;margin-bottom:24px}.preview-instrucciones p{margin:0 0 12px;color:#0369a1;font-size:14px}.preview-instrucciones ol{margin:0 0 12px 20px;padding:0;color:#1e293b;font-size:13px;line-height:1.8}.preview-instrucciones li{margin-bottom:4px}.color-cobro{color:#92400e;font-weight:600;background:#fef3c7;padding:2px 6px;border-radius:4px}.color-pendiente{color:#166534;font-weight:600;background:#dcfce7;padding:2px 6px;border-radius:4px}.color-cancelado{color:#991b1b;font-weight:600;background:#fee2e2;padding:2px 6px;border-radius:4px}.preview-leyenda-colores{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}.preview-header-actions{display:flex;align-items:center;gap:12px}.btn-colors-toggle{display:flex;align-items:center;gap:6px;padding:8px 16px;border:2px solid #e5e7eb;border-radius:8px;background:#fff;color:#374151;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-colors-toggle:hover{border-color:#3b82f6;background:#eff6ff}.btn-colors-toggle.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.preview-excel-table tbody td.observacion-cobro{background-color:#fef3c7!important;color:#92400e;font-weight:600}.preview-excel-table tbody td.observacion-pendiente{background-color:#dcfce7!important;color:#166534;font-weight:600}.preview-excel-table tbody td.observacion-cancelado{background-color:#fee2e2!important;color:#991b1b;font-weight:600}.preview-dashboard{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 12px #0000001a}.preview-resumen-general{margin-bottom:32px;padding-bottom:24px;border-bottom:2px solid #e2e8f0}.preview-resumen-general h5{font-size:16px;font-weight:700;color:#1e3a8a;margin:0 0 16px;text-align:center}.preview-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.preview-stat-item{background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:8px}.preview-stat-label{font-size:12px;color:#64748b;font-weight:600;text-transform:uppercase}.preview-stat-value{font-size:24px;font-weight:800;color:#1e3a8a;font-family:Courier New,monospace}.preview-resumen-meses{margin-bottom:32px;padding-bottom:24px;border-bottom:2px solid #e2e8f0}.preview-resumen-meses h5{font-size:16px;font-weight:700;color:#1e3a8a;margin:0 0 16px;text-align:center}.preview-meses-table-container{overflow-x:auto;border-radius:8px;border:1px solid #e2e8f0}.preview-meses-table{width:100%;border-collapse:collapse;font-size:13px}.preview-meses-table th{background:#1e3a8a;color:#fff;padding:12px;text-align:left;font-weight:600}.preview-meses-table th.col-numero{text-align:right}.preview-meses-table td{padding:10px 12px;border-bottom:1px solid #e2e8f0;background:#fff}.preview-meses-table tr:nth-child(2n) td{background:#f8fafc}.preview-meses-table td.col-numero,.preview-meses-table td.col-cliente{text-align:right;font-family:Courier New,monospace;font-weight:600;color:#0369a1}.preview-meses-table td.col-mes{font-weight:600;color:#1e3a8a}.preview-meses-table td.col-estado{text-align:center}.check-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:#22c55e;color:#fff;border-radius:50%;font-weight:700;font-size:14px}.no-venta{color:#94a3b8;font-weight:600}.preview-resumen-dias{margin-bottom:32px;padding-bottom:24px;border-bottom:2px solid #e2e8f0}.preview-resumen-dias h5{font-size:16px;font-weight:700;color:#1e3a8a;margin:0 0 16px;text-align:center}.preview-dias-table-container{overflow-x:auto;border-radius:8px;border:1px solid #e2e8f0}.preview-dias-table{width:100%;border-collapse:collapse;font-size:13px}.preview-dias-table th{background:#1e3a8a;color:#fff;padding:12px;font-weight:600;text-transform:uppercase;font-size:11px;letter-spacing:.5px}.preview-dias-table th.col-dia-header{text-align:left}.preview-dias-table th.col-cliente-header{text-align:center}.preview-dias-table th.col-numero-header{text-align:right}.preview-dias-table td{padding:10px 12px;border-bottom:1px solid #e2e8f0;background:#fff}.preview-dias-table tr:nth-child(2n) td{background:#f8fafc}.preview-dias-table tr:hover td{background:#f0f9ff}.preview-dias-table td.col-dia{font-weight:600;color:#1e3a8a;text-align:left}.preview-dias-table td.col-cliente{text-align:center;font-family:Courier New,monospace;font-weight:600;color:#0369a1}.preview-dias-table td.col-numero{text-align:right;font-family:Courier New,monospace;font-weight:600;color:#0369a1}.preview-dias-table .no-data{text-align:center;color:#94a3b8;font-style:italic;padding:20px}.preview-resumen-productos h5{font-size:16px;font-weight:700;color:#1e3a8a;margin:0 0 16px;text-align:center}.preview-productos-table-container{overflow-x:auto;border-radius:8px;border:1px solid #e2e8f0}.preview-productos-table{width:100%;border-collapse:collapse;font-size:13px}.preview-productos-table th{background:#1e3a8a;color:#fff;padding:12px;text-align:left;font-weight:600}.preview-productos-table td{padding:10px 12px;border-bottom:1px solid #e2e8f0;background:#fff}.preview-productos-table tr:nth-child(2n) td{background:#f8fafc}.preview-productos-table td:last-child{text-align:center;font-weight:700;font-family:Courier New,monospace}.preview-producto-nombre{font-weight:600;color:#1e293b;font-size:14px}.preview-producto-total{background:#1e3a8a;color:#fff;padding:6px 12px;border-radius:16px;font-weight:700;font-size:14px;min-width:32px;text-align:center}.preview-footer{background:#f1f5f9;padding:16px 32px;display:flex;justify-content:space-between;align-items:center;border-top:2px solid #e2e8f0}.preview-footer span{font-weight:600;color:#475569}.btn-close-preview{background:#64748b;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-close-preview:hover{background:#475569;transform:translateY(-2px)}.color-selector{display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px 16px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.color-label{font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.color-options{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.color-btn{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.color-btn:hover{transform:scale(1.15);box-shadow:0 4px 8px #0003}.color-btn.active{border-color:#1e293b;box-shadow:0 0 0 3px #1e293b4d;transform:scale(1.1)}@media(max-width:768px){.color-selector{padding:6px 12px}.color-btn{width:24px;height:24px}}.save-final-modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.save-final-modal{background:#fff;border-radius:16px;padding:32px;max-width:480px;width:90%;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.save-final-modal-header{text-align:center;margin-bottom:24px}.save-final-modal-header h3{font-size:1.5rem;color:#111827;margin:0 0 8px;display:flex;align-items:center;justify-content:center;gap:10px}.save-final-modal-icon{font-size:2rem}.save-final-modal-subtitle{color:#6b7280;font-size:.95rem;margin:0}.save-final-modal-content{margin-bottom:28px}.save-final-modal-message{background:#f3f4f6;border-radius:12px;padding:16px 20px;margin-bottom:16px}.save-final-modal-message p{margin:0;color:#374151;font-size:1rem;line-height:1.5}.save-final-modal-warning{display:flex;align-items:flex-start;gap:10px;background:#fef3c7;border-left:4px solid #f59e0b;padding:12px 16px;border-radius:8px}.save-final-modal-warning-icon{font-size:1.2rem;flex-shrink:0}.save-final-modal-warning p{margin:0;color:#92400e;font-size:.9rem;line-height:1.4}.save-final-modal-actions{display:flex;gap:12px}.save-final-modal-btn{flex:1;padding:14px 20px;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.save-final-modal-btn-secondary{background:#f3f4f6;color:#374151;border:2px solid #e5e7eb}.save-final-modal-btn-secondary:hover{background:#e5e7eb;border-color:#d1d5db}.save-final-modal-btn-primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 12px #10b9814d}.save-final-modal-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.save-final-modal-btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.save-final-modal-loading{display:flex;align-items:center;justify-content:center;gap:10px}.save-final-modal-spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:480px){.save-final-modal{padding:24px;margin:16px}.save-final-modal-actions{flex-direction:column}.save-final-modal-btn{width:100%}}.client-documents-manager{background:#fff;border-radius:8px;padding:32px;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.manager-header{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #e5e7eb}.btn-back{display:inline-flex;align-items:center;padding:8px 16px;background:#f9fafb;color:#374151;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;margin-bottom:16px}.btn-back:hover{background:#f3f4f6}.client-header-info{display:flex;align-items:center;gap:16px}.client-avatar{width:48px;height:48px;background:#2563eb;color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600}.client-header-info h2{font-size:20px;font-weight:600;color:#111827;margin:0 0 4px}.client-header-info p{font-size:14px;color:#6b7280;margin:0 0 8px}.doc-count{display:inline-flex;align-items:center;padding:4px 10px;background:#dcfce7;color:#166534;border-radius:4px;font-size:12px;font-weight:600}.documents-section{margin-bottom:32px}.documents-section h3{font-size:16px;font-weight:600;color:#111827;margin-bottom:8px}.section-description{color:#6b7280;font-size:14px;margin-bottom:20px}.months-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.month-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:20px;text-align:center;transition:all .2s ease}.month-card:hover{border-color:#d1d5db;box-shadow:0 2px 4px #0000000d}.month-card.has-document{border-color:#22c55e;background:#f0fdf4}.month-card.empty{border-style:dashed}.month-name{font-size:15px;font-weight:600;color:#111827;margin-bottom:12px;text-transform:capitalize}.document-info{display:flex;flex-direction:column;gap:6px}.doc-name{font-size:13px;color:#374151;font-weight:500;word-break:break-all}.doc-date{font-size:11px;color:#6b7280}.document-actions{display:flex;gap:8px;margin-top:10px;justify-content:center}.btn-reupload,.btn-upload{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:#2563eb;color:#fff;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-reupload:hover,.btn-upload:hover{background:#1d4ed8}.btn-delete{padding:6px 12px;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-delete:hover{background:#fee2e2}.upload-section{display:flex;flex-direction:column;gap:10px}.no-doc{font-size:12px;color:#9ca3af;font-style:italic;margin:0}.bulk-upload-section{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid #3b82f6;border-radius:12px;padding:24px;margin-bottom:32px}.bulk-upload-section h3{font-size:18px;font-weight:600;color:#1e40af;margin:0 0 8px}.bulk-upload-box{background:#fff;border:2px dashed #93c5fd;border-radius:8px;padding:24px;text-align:center;margin-top:16px}.btn-bulk-upload{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-bulk-upload:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.btn-bulk-upload.disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.bulk-hint{font-size:12px;color:#6b7280;margin:12px 0 0}.instructions-box{background:#f9fafb;border:1px solid #e5e7eb;padding:20px;border-radius:8px}.instructions-box h4{font-size:14px;font-weight:600;color:#374151;margin-bottom:12px}.instructions-box ul{margin:0;padding-left:20px;color:#4b5563;font-size:13px;line-height:1.8}.instructions-box li{margin-bottom:6px}@media(max-width:768px){.client-documents-manager{padding:20px}.client-header-info{flex-direction:column;text-align:center}.months-grid{grid-template-columns:repeat(2,1fr)}.document-actions{flex-direction:column}.btn-reupload,.btn-upload,.btn-delete{width:100%;justify-content:center}}@media(max-width:480px){.months-grid{grid-template-columns:1fr}}.whitelist-manager{background:#fff;border-radius:8px;padding:32px;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.whitelist-header{margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.whitelist-header h2{font-size:20px;font-weight:600;color:#111827;margin-bottom:4px}.whitelist-header p{color:#6b7280;font-size:14px;margin:0}.whitelist-stats{margin-bottom:24px}.stat-box{background:#eff6ff;border:1px solid #dbeafe;border-radius:8px;padding:20px 24px;display:inline-flex;flex-direction:column;align-items:center;min-width:150px}.stat-number{font-size:32px;font-weight:700;color:#1e40af;line-height:1}.stat-label{font-size:13px;color:#3b82f6;margin-top:4px;text-transform:uppercase;letter-spacing:.025em}.whitelist-actions{display:grid;grid-template-columns:2fr 1fr;gap:24px;margin-bottom:32px;padding:24px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.add-email-form .form-group label{display:block;margin-bottom:8px;font-weight:500;color:#374151;font-size:14px}.input-group{display:flex;gap:12px}.input-group input{flex:1;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.input-group input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.btn-add{padding:10px 20px;background:#2563eb;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-add:hover{background:#1d4ed8}.bulk-actions{display:flex;flex-direction:column;gap:12px;justify-content:center}.btn-import,.btn-export{padding:10px 16px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:center}.btn-import{background:#fff;color:#374151}.btn-import:hover{background:#f9fafb;border-color:#9ca3af}.btn-export{background:#f3f4f6;color:#374151}.btn-export:hover{background:#e5e7eb}.email-list-section{margin-bottom:32px}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.list-header h3{font-size:16px;font-weight:600;color:#111827;margin:0}.list-actions{display:flex;gap:12px;align-items:center}.search-input{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;width:250px}.search-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.btn-clear{padding:8px 16px;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-clear:hover{background:#fee2e2}.empty-list{text-align:center;padding:48px 24px;background:#f9fafb;border-radius:8px;border:1px dashed #d1d5db}.empty-list p{color:#6b7280;margin-bottom:8px}.empty-hint{font-size:13px;color:#9ca3af}.email-list{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}.email-item{display:flex;align-items:center;gap:16px;padding:12px 16px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;transition:all .2s ease}.email-item:hover{border-color:#d1d5db;box-shadow:0 1px 3px #0000000d}.email-item.vip{background:linear-gradient(135deg,#fef3c7,#fffbeb);border-color:#fbbf24}.email-item.vip:hover{border-color:#f59e0b}.vip-badge{background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#92400e;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.025em}.btn-remove:disabled{background:#f3f4f6;color:#9ca3af;border-color:#e5e7eb;cursor:not-allowed}.email-number{width:28px;height:28px;background:#f3f4f6;color:#6b7280;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.email-address{flex:1;font-family:monospace;font-size:14px;color:#111827}.btn-remove{padding:6px 12px;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-remove:hover{background:#fee2e2}.whitelist-info{background:#f9fafb;border:1px solid #e5e7eb;padding:20px;border-radius:8px}.whitelist-info h4{font-size:14px;font-weight:600;color:#374151;margin-bottom:12px}.whitelist-info ul{margin:0;padding-left:20px;color:#4b5563;font-size:13px;line-height:1.8}.whitelist-info li{margin-bottom:6px}.browser-note{margin-top:16px;padding:12px;background:#fef3c7;border:1px solid #fbbf24;border-radius:6px}.browser-note strong{color:#92400e;display:block;margin-bottom:4px}.browser-note p{color:#78350f;font-size:12px;margin:0;line-height:1.5}@media(max-width:768px){.whitelist-manager{padding:20px}.whitelist-actions{grid-template-columns:1fr}.bulk-actions{flex-direction:row;justify-content:center}.input-group{flex-direction:column}.list-header{flex-direction:column;gap:12px;align-items:flex-start}.search-input{width:100%}.email-item{flex-wrap:wrap}.email-address{width:100%;order:3;margin-top:8px}}.admin-panel{background:#fff;border-radius:8px;padding:32px;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.admin-header{margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.admin-header h2{font-size:20px;font-weight:600;color:#111827;margin-bottom:4px}.admin-header p{color:#6b7280;font-size:14px;margin:0}.message{padding:12px 16px;border-radius:6px;margin-bottom:20px;font-size:14px}.message.success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.message.error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.clients-section{margin-bottom:32px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h3{font-size:16px;font-weight:600;color:#374151}.btn-add-client{padding:8px 16px;background:#2563eb;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-add-client:hover{background:#1d4ed8}.empty-clients{text-align:center;padding:48px 24px;background:#f9fafb;border-radius:8px;border:1px dashed #d1d5db}.empty-clients p{color:#6b7280;margin-bottom:16px}.clients-table-container{overflow-x:auto}.clients-table{width:100%;border-collapse:collapse;font-size:14px}.clients-table th{background:#f9fafb;padding:12px 16px;text-align:left;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb;white-space:nowrap}.clients-table td{padding:16px;border-bottom:1px solid #e5e7eb;vertical-align:middle}.client-cell{display:flex;align-items:center;gap:12px}.client-avatar{width:32px;height:32px;background:#2563eb;color:#fff;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600}.client-name{font-weight:500;color:#111827}.email-cell{color:#4b5563;font-size:13px}.password-cell{min-width:180px}.password-display{display:flex;align-items:center;gap:8px}.password-code{background:#f3f4f6;padding:4px 8px;border-radius:4px;font-family:monospace;font-size:12px;color:#374151;border:1px solid #e5e7eb}.btn-show-password{background:none;border:none;color:#2563eb;font-size:12px;font-weight:500;cursor:pointer;padding:2px 6px}.btn-show-password:hover{color:#1d4ed8;text-decoration:underline}.badge-docs{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.badge-docs.yes{background:#dcfce7;color:#166534}.badge-docs.no{background:#f3f4f6;color:#6b7280}.actions-cell{white-space:nowrap}.btn-action{display:inline-block;padding:6px 12px;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;margin-right:8px;transition:all .2s ease}.btn-action.manage{background:#eff6ff;color:#1e40af}.btn-action.manage:hover{background:#dbeafe}.btn-action.password{background:#fffbeb;color:#92400e}.btn-action.password:hover{background:#fef3c7}.btn-action.delete{background:#fef2f2;color:#991b1b}.btn-action.delete:hover{background:#fee2e2}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:8px;padding:24px;width:100%;max-width:500px;box-shadow:0 20px 25px -5px #0000001a}.modal-content h3{font-size:18px;font-weight:600;color:#111827;margin-bottom:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#374151;font-size:13px}.form-group input{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.field-hint{display:block;font-size:12px;color:#6b7280;margin-top:4px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.btn-cancel{padding:10px 16px;background:#f9fafb;color:#374151;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer}.btn-cancel:hover{background:#f3f4f6}.btn-submit{padding:10px 16px;background:#2563eb;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer}.btn-submit:hover{background:#1d4ed8}.admin-instructions{background:#f9fafb;border:1px solid #e5e7eb;padding:20px;border-radius:8px}.admin-instructions h3{font-size:14px;font-weight:600;color:#374151;margin-bottom:12px;text-transform:uppercase;letter-spacing:.025em}.admin-credentials{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:12px 16px}.admin-credentials p{margin:4px 0;font-family:monospace;font-size:13px;color:#4b5563}.admin-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:1px solid #e5e7eb}.tab-button{padding:12px 24px;background:transparent;border:none;border-bottom:2px solid transparent;font-size:14px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s ease}.tab-button:hover{color:#374151;background:#f9fafb}.tab-button.active{color:#2563eb;border-bottom-color:#2563eb;background:#eff6ff}@media(max-width:768px){.admin-panel{padding:20px}.section-header{flex-direction:column;gap:12px;align-items:flex-start}.clients-table{font-size:12px}.clients-table th,.clients-table td{padding:10px 8px}.form-row{grid-template-columns:1fr}.btn-action{display:block;width:100%;margin-bottom:8px;margin-right:0}}.badge-subscription{display:inline-block;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;white-space:nowrap}.badge-subscription.active{background:#dcfce7;color:#166534;border:1px solid #86efac}.badge-subscription.trial{background:#fef9c3;color:#854d0e;border:1px solid #fde047}.badge-subscription.expired{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.subscription-cell{white-space:nowrap}.btn-action.subscribe{background:#dcfce7;color:#166534;border:1px solid #86efac}.btn-action.subscribe:hover{background:#bbf7d0}.trial-status-bar{padding:12px 24px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.trial-status-bar.active{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:1px solid #60a5fa}.trial-status-bar.warning{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b}.trial-status-bar.expired{background:linear-gradient(135deg,#fee2e2,#fecaca);border:1px solid #ef4444}.trial-status-bar.subscribed{background:linear-gradient(135deg,#dcfce7,#bbf7d0);border:1px solid #22c55e;justify-content:center}.trial-content{display:flex;align-items:center;gap:12px;flex:1}.trial-icon{font-size:20px;display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#fff;border-radius:50%;box-shadow:0 2px 4px #0000001a}.trial-info{display:flex;flex-direction:column;gap:2px}.trial-text{font-size:14px;color:#1e293b}.trial-text strong{font-weight:600}.trial-date{font-size:12px;color:#64748b}.trial-subscribe-btn{padding:10px 20px;background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.trial-subscribe-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #1e3a8a4d}.trial-subscribe-btn.urgent{background:linear-gradient(135deg,#dc2626,#ef4444);animation:pulse 2s infinite}.trial-subscribe-btn.urgent:hover{box-shadow:0 4px 12px #dc26264d}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.subscribe-options{position:relative}.plan-buttons{display:flex;gap:8px;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.plan-btn-basic,.plan-btn-pro{padding:10px 16px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.plan-btn-basic{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.plan-btn-basic:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.plan-btn-pro{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.plan-btn-pro:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b4d}@media(max-width:640px){.trial-status-bar{flex-direction:column;text-align:center;padding:16px}.trial-content{flex-direction:column;width:100%}.trial-info{align-items:center}.trial-subscribe-btn{width:100%}}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content.trial-modal{background:#fff;border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040}.modal-header{padding:32px 32px 24px;text-align:center;border-bottom:1px solid #e5e7eb}.modal-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 16px}.modal-icon.expired{background:#fee2e2}.modal-icon.warning{background:#fef3c7}.modal-header h2{font-size:22px;font-weight:700;color:#1e293b;margin:0}.modal-body{padding:24px 32px}.modal-description{font-size:15px;line-height:1.6;color:#4b5563;margin-bottom:20px}.trial-info-box{background:#eff6ff;border:1px solid #dbeafe;border-radius:8px;padding:16px;margin-bottom:24px}.trial-info-box h3{font-size:14px;font-weight:600;color:#1e40af;margin:0 0 8px}.trial-info-box p{font-size:13px;color:#1e40af;margin:0;line-height:1.5}.countdown-box{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px;padding:24px;text-align:center;margin-bottom:24px}.countdown-number{display:block;font-size:48px;font-weight:700;color:#92400e;line-height:1}.countdown-label{display:block;font-size:14px;color:#92400e;margin-top:4px;text-transform:uppercase;letter-spacing:.05em}.plans-section{display:grid;gap:16px}.plans-section.compact{grid-template-columns:repeat(2,1fr)}.plan-card{border:2px solid #e5e7eb;border-radius:12px;padding:20px;position:relative;background:#fff;transition:all .2s ease}.plan-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f61a}.plan-card.recommended{border-color:#3b82f6;background:linear-gradient(135deg,#eff6ff,#fff)}.recommended-badge{position:absolute;top:-10px;right:12px;background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;font-size:11px;font-weight:600;padding:4px 12px;border-radius:20px;text-transform:uppercase;letter-spacing:.025em}.plan-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.plan-name{font-size:16px;font-weight:600;color:#1e293b}.plan-price{font-size:24px;font-weight:700;color:#1e3a8a}.plan-period{font-size:13px;color:#6b7280;margin-bottom:12px}.plan-features{list-style:none;padding:0;margin:0 0 16px}.plan-features li{font-size:13px;color:#4b5563;padding:4px 0;display:flex;align-items:center;gap:8px}.plan-button{width:100%;padding:12px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.plan-button.basic{background:#f3f4f6;color:#374151}.plan-button.basic:hover{background:#e5e7eb}.plan-button.professional{background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff}.plan-button.professional:hover{transform:translateY(-1px);box-shadow:0 4px 12px #1e3a8a4d}.modal-footer{padding:20px 32px 32px;border-top:1px solid #e5e7eb;display:flex;flex-direction:column;gap:16px;align-items:center}.support-link{display:flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;border-radius:8px;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s ease}.support-link:hover{transform:translateY(-1px);box-shadow:0 4px 12px #1e3a8a4d}.btn-secondary{padding:12px 24px;background:transparent;border:1px solid #d1d5db;border-radius:8px;color:#6b7280;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:#f3f4f6;border-color:#9ca3af;color:#374151}@media(max-width:640px){.plans-section.compact{grid-template-columns:1fr}.modal-content.trial-modal{margin:10px}.modal-header,.modal-body,.modal-footer{padding-left:20px;padding-right:20px}}.payment-modal{max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;padding:24px;text-align:center}.modal-header h2{margin:0 0 8px;font-size:24px}.modal-header p{margin:0;opacity:.9;font-size:16px}.payment-body{padding:24px}.payment-methods{margin-bottom:24px}.payment-methods h3{font-size:14px;color:#374151;margin-bottom:12px}.method-buttons{display:flex;gap:12px}.method-btn{flex:1;padding:16px;border:2px solid #e5e7eb;border-radius:12px;background:#fff;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#374151}.method-btn:hover{border-color:#3b82f6;background:#eff6ff}.method-btn.active{border-color:#3b82f6;background:#eff6ff;color:#1d4ed8}.method-icon{font-size:32px}.yape-section{background:#f0fdf4;border:2px solid #86efac;border-radius:12px;padding:20px;margin-bottom:24px}.qr-container h4,.number-section h4{margin:0 0 12px;font-size:14px;color:#166534}.qr-placeholder{display:flex;justify-content:center;margin-bottom:12px}.qr-code{width:200px;height:200px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 6px #0000001a}.qr-pattern{width:160px;height:160px;background:linear-gradient(135deg,#742284,#9c27b0);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;gap:8px}.qr-image{width:200px;height:200px;object-fit:contain;border-radius:12px;box-shadow:0 4px 12px #00000026}.qr-label{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:1px}.qr-number{font-size:18px;font-weight:700}.qr-hint{text-align:center;font-size:13px;color:#166534;margin:0}.number-section{margin-top:20px;padding-top:20px;border-top:1px dashed #86efac}.number-display{display:flex;align-items:center;gap:12px;background:#fff;padding:12px 16px;border-radius:8px;border:1px solid #86efac}.phone-number{font-size:20px;font-weight:700;color:#742284;font-family:monospace;flex:1}.copy-btn{padding:8px 16px;background:#742284;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.copy-btn:hover{background:#9c27b0;transform:translateY(-1px)}.whatsapp-section{margin-bottom:24px;text-align:center}.whatsapp-section h4{font-size:14px;color:#374151;margin-bottom:12px}.whatsapp-btn{width:100%;padding:16px;background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:12px}.whatsapp-btn:hover{transform:translateY(-2px);box-shadow:0 8px 16px #25d3664d}.whatsapp-icon{font-size:24px}.upload-section{margin-bottom:24px}.upload-section h4{font-size:14px;color:#374151;margin-bottom:12px}.upload-area{border:2px dashed #d1d5db;border-radius:12px;padding:24px;text-align:center;transition:all .3s ease}.upload-area:hover{border-color:#3b82f6;background:#eff6ff}.file-input{display:none}.upload-label{display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;color:#6b7280}.upload-icon{font-size:32px}.upload-label span{font-size:14px;font-weight:500}.upload-label small{font-size:12px;color:#9ca3af}.file-selected{color:#166534;font-weight:600;background:#dcfce7;padding:8px 16px;border-radius:6px}.contact-info-payment{background:#f9fafb;border-radius:8px;padding:16px;margin-bottom:24px}.contact-info-payment p{margin:4px 0;font-size:13px;color:#4b5563}.server-notice{background:#fef3c7;border:1px solid #fbbf24;border-radius:8px;padding:16px;margin-bottom:20px}.server-notice p{margin:4px 0;font-size:13px;color:#92400e}.server-notice strong{color:#92400e}.modal-footer-payment{display:flex;gap:12px;padding:20px 24px;border-top:1px solid #e5e7eb;background:#f9fafb}.modal-footer-payment .btn-secondary{padding:12px 24px;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.modal-footer-payment .btn-secondary:hover{background:#f3f4f6}.modal-footer-payment .btn-primary{flex:1;padding:12px 24px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.modal-footer-payment .btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.modal-footer-payment .btn-primary.disabled{background:#d1d5db;cursor:not-allowed;transform:none;box-shadow:none}.success-container{padding:48px 24px;text-align:center}.success-icon{font-size:64px;margin-bottom:16px}.success-container h3{font-size:20px;color:#166534;margin-bottom:8px}.success-container p{font-size:14px;color:#374151;margin:0}.email-status{padding:12px 16px;border-radius:6px;margin:16px 24px;font-size:14px;font-weight:500;text-align:center}.email-status.loading{background:#fef3c7;color:#92400e;border:1px solid #fbbf24}.email-status.success{background:#dcfce7;color:#166534;border:1px solid #86efac}@media(max-width:640px){.payment-modal{max-width:100%;margin:10px}.number-display{flex-direction:column;gap:8px}.copy-btn{width:100%}.modal-footer-payment{flex-direction:column}}.email-section{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid #3b82f6;border-radius:12px;padding:24px;margin:20px 0}.email-section h3{color:#1e40af;margin-bottom:16px;font-size:18px}.email-instruction{color:#374151;font-size:14px;margin-bottom:16px}.email-display{display:flex;align-items:center;gap:12px;background:#fff;padding:16px;border-radius:8px;border:2px solid #3b82f6;margin-bottom:16px}.email-address{font-size:16px;font-weight:600;color:#1e40af;flex:1;font-family:monospace}.email-buttons{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.email-btn{padding:12px 16px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px}.email-btn.gmail{background:linear-gradient(135deg,#ea4335,#fbbc05);color:#fff}.email-btn.outlook{background:linear-gradient(135deg,#0078d4,#106ebe);color:#fff}.email-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.email-instructions-box{background:#fff;border-radius:8px;padding:16px;border-left:4px solid #3b82f6}.email-instructions-box h4{color:#1e40af;margin-bottom:12px;font-size:14px}.email-instructions-box ol{margin:0 0 12px 20px;padding:0;color:#4b5563;font-size:13px;line-height:1.8}.email-instructions-box li{margin-bottom:4px}.email-note{font-size:12px;color:#6b7280;margin:0;padding-top:8px;border-top:1px solid #e5e7eb}.payment-info{background:#f0fdf4;border:1px solid #86efac;border-radius:8px;padding:16px;margin-top:20px;text-align:center}.payment-info p{margin:4px 0;font-size:13px;color:#166534}@media(max-width:640px){.email-buttons{grid-template-columns:1fr}.email-display{flex-direction:column;gap:8px}.email-address{font-size:14px;text-align:center}}.support-button{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#ffffff26;color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.support-button:hover{background:#ffffff40;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.support-icon{font-size:16px}.support-text{white-space:nowrap}@media(max-width:768px){.support-button{padding:8px 12px}.support-text{display:none}.support-icon{font-size:20px}}.dashboard-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e4e8ec)}.dashboard-header{background:linear-gradient(135deg,#1e3a8a,#3730a3);box-shadow:0 4px 20px #00000026;padding:0;position:sticky;top:0;z-index:100}.header-content{max-width:1400px;margin:0 auto;padding:20px 40px;display:flex;justify-content:space-between;align-items:center}.header-brand{display:flex;align-items:center;gap:16px}.logo-box{width:45px;height:45px;background:#fff3;color:#fff;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;border:2px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-title h1{font-size:22px;font-weight:700;color:#fff;margin:0;line-height:1.2;letter-spacing:.5px}.header-subtitle{font-size:13px;color:#fffc;font-weight:500}.header-user{display:flex;align-items:center;gap:12px}.user-info{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.user-role-badge{background:#fff3;color:#fff;padding:5px 14px;border-radius:20px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border:1px solid rgba(255,255,255,.3)}.user-email{font-size:13px;color:#ffffffe6;font-weight:500}.logout-button{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#ffffff26;color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.logout-button:hover{background:#ffffff40;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.header-actions{display:flex;align-items:center;gap:16px}.btn-secondary{padding:10px 20px;background:#ffffff1a;color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-secondary:hover{background:#fff3;transform:translateY(-2px)}.welcome-section{padding:40px;max-width:1400px;margin:0 auto}.welcome-card{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:20px;padding:40px;box-shadow:0 10px 40px #0000001a;border:1px solid rgba(255,255,255,.5);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:40px}.welcome-card:before{content:"";position:absolute;top:0;right:0;width:300px;height:300px;background:linear-gradient(135deg,#667eea1a,#764ba21a);border-radius:50%;transform:translate(50%,-50%)}.welcome-content{position:relative;z-index:1;max-width:600px}.welcome-greeting{font-size:14px;font-weight:700;color:#667eea;text-transform:uppercase;letter-spacing:2px;margin-bottom:12px}.welcome-title{font-size:36px;font-weight:800;color:#1e293b;margin:0 0 16px;line-height:1.2;background:linear-gradient(135deg,#1e3a8a,#3730a3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome-subtitle{font-size:17px;color:#64748b;line-height:1.6;margin:0;font-weight:500}.dashboard-main{padding:0 40px 40px;max-width:1400px;margin:0 auto}.dashboard-footer{background:linear-gradient(135deg,#1e293b,#0f172a);padding:24px;text-align:center}.dashboard-footer p{margin:0;color:#ffffffb3;font-size:14px;font-weight:500}@media(max-width:768px){.header-content{flex-direction:column;gap:20px;padding:20px}.header-user{width:100%;justify-content:space-between}.welcome-section{padding:24px}.welcome-card{padding:28px;flex-direction:column;gap:24px;text-align:center}.welcome-title{font-size:28px}.dashboard-main{padding:0 24px 24px}.header-actions{width:100%;justify-content:center}}.backup-section{padding:0 40px 40px;max-width:1400px;margin:0 auto}@media(max-width:768px){.backup-section{padding:0 20px 20px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f7fa}.app{min-height:100vh}html{scroll-behavior:smooth}::selection{background-color:#667eea;color:#fff}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .3s ease-in}
