:root{--color-white: #ffffff;--color-black: #000000;--color-gray-100: #f4f4f4;--color-gray-200: #c8c6c6;--color-gray-300: #939292;--color-gray-400: #4e4e4e;--color-gray-500: #040404;--color-rose-300: #fef2b8;--color-rose-400: #ffcfa3;--color-rose-500: #ddb19c}@tailwind base;@tailwind components;@tailwind utilities;:root{--color-white: #ffffff;--color-black: #000000;--color-gray-100: #f4f4f4;--color-gray-200: #b5b4b4;--color-gray-300: #7d7d7d;--color-gray-400: #515151;--color-gray-500: #282727;--color-rose-300: #ddb19c;--color-rose-400: #ddb19c;--color-rose-500: #ddb19c}body{font-family:Verdana,Geneva,Tahoma,sans-serif;font-size:14px;margin:0;padding:0;background-color:#f4f4f4}@media (max-width: 768px){body{font-size:12px}}.header{display:flex;justify-content:space-between;align-items:center;background-color:var(--color-white);padding:1rem;box-shadow:0 2px 10px #0000001a;background-color:#655148}.header-logo{height:7rem}.header-title{font-size:1.25rem;font-weight:600;margin-left:3rem;font-family:monserrat;font-style:italic;color:#fff}.header-nav ul{display:flex;list-style:none;gap:2rem;font-family:Lucida Sans,Lucida Sans Regular,Lucida Grande,Lucida Sans Unicode,Geneva,Verdana,sans-serif;color:#fff}.header-nav a{text-decoration:none;color:var(--color-gray-800);transition:color .3s ease}.header-nav a:hover{color:var(--color-rose-400)}@media (max-width: 768px){.header{flex-direction:column;padding:.5rem}.header-logo{height:10rem}.header-title{font-size:1rem;margin:.5rem 0}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #eeeeee}.modal-header h2{font-size:1.25rem;font-weight:700;color:var(--color-rose-400);margin:0}.consent-form{display:flex;flex-direction:column;gap:1.5rem}.consent-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.875rem;font-weight:500;color:var(--color-gray-700)}.form-input{padding:.5rem;border:2px solid var(--color-rose-300);border-radius:.25rem;font-size:.875rem}.consent-section{margin-top:1.5rem}.consent-section-title{font-size:1.125rem;font-weight:600;color:var(--color-rose-400);margin-bottom:.75rem}.consent-checkbox{display:flex;align-items:flex-start;gap:.5rem;margin-top:1.5rem}.consent-checkbox input{margin-top:.25rem}.signature-container{margin-top:1.5rem}.signature-canvas{width:100%;height:100px;border:2px solid var(--color-rose-300);border-radius:.25rem;background-color:#fff;touch-action:none}.signature-buttons{display:flex;justify-content:center;gap:1rem;margin-top:1rem}.signature-buttons button{min-width:100px;padding:.5rem 1rem;border-radius:.25rem;font-weight:500;cursor:pointer;transition:background-color .2s}.signature-buttons button[type=submit]{background-color:#333;color:#fff;border:none}.signature-buttons button[type=submit]:hover{background-color:#666}.signature-buttons button[type=button]{background-color:#ccc;color:#333;border:none}.signature-buttons button[type=button]:hover{background-color:#bbb}.btn{background-color:var(--color-rose-400);color:#fff;border:none;border-radius:.25rem;padding:.5rem 1rem;cursor:pointer;font-size:.875rem;text-decoration:none;display:inline-block;text-align:center}@media (max-width: 768px){.modal-content{max-width:100%;max-height:100%;border-radius:0}.modal-header h2{font-size:1rem}.consent-form-grid{grid-template-columns:1fr}}.payment-options{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;padding:1.5rem;width:100%;opacity:1;transition:opacity .3s ease;z-index:1}.payment-option{display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:1rem;border:1px solid #ddb19c;border-radius:.5rem;cursor:pointer;background-color:#fff;height:150px;transition:transform .2s ease,box-shadow .2s ease;position:relative;overflow:hidden}.payment-option:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a;border-color:#c99778}.payment-option:active{transform:translateY(0)}.payment-option:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#ddb19c1a;opacity:0;transition:opacity .2s ease}.payment-option:hover:after{opacity:1}.payment-option img{width:128px;height:64px;object-fit:contain;margin-bottom:1rem;pointer-events:none}.payment-option span{font-size:.875rem;text-align:center;pointer-events:none;color:#333;font-weight:500}@media screen and (max-width: 768px){.payment-options{grid-template-columns:1fr}.payment-option{height:120px}}.payment-services{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.service-options{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-bottom:2rem;opacity:1;transition:opacity .3s ease;z-index:2}.service-options button{width:100%;max-width:300px;padding:1rem;background-color:#ddb19c;color:#fff;border:none;border-radius:.5rem;cursor:pointer}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{position:relative;background:#fff;padding:2rem;border-radius:.5rem;width:90%;max-width:800px}.modal-content h2{color:#c99778;font-weight:600}.modal-close{position:absolute;right:1rem;top:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .3s ease}.modal-close:hover{background-color:#0000001a}.back-button{background:none;border:none;padding:.5rem;cursor:pointer;color:#666;display:flex;align-items:center;margin-bottom:1rem;font-size:1rem}.back-button:hover{color:#000}h2{text-align:center;margin-bottom:1.5rem;color:#333}.wu-info{background:#fff;padding:2rem;border-radius:.5rem;width:90%;max-width:400px;position:relative}.wu-details{margin-top:1.5rem;line-height:1.5;margin-bottom:2rem}.wu-details p{margin:.5rem 0}.wu-buttons{display:flex;justify-content:center;gap:1rem;margin-top:1rem}.wu-back-button{background:none;border:1px solid #c99778;padding:.5rem 1.5rem;border-radius:.5rem;cursor:pointer;color:#c99778;font-size:1rem;transition:all .3s ease}.wu-back-button:hover{background:#c99778;color:#fff}.home-container{max-width:1200px;margin:0 auto;padding:2rem 1rem;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 64px);padding:2rem}.home-buttons{display:flex;flex-direction:column;align-items:center;margin-top:3rem}.home-button{width:100%;padding:1rem;border:none;border-radius:.5rem;font-size:1rem;cursor:pointer;text-align:center;text-decoration:none;transition:background-color .3s ease;color:var(--color-white);background-color:var(--color-rose-400)}.login-container{max-width:400px;margin:2.5rem auto 0;padding:1.5rem;background-color:var(--color-white);border-radius:.5rem;box-shadow:0 4px 6px #e119191a}.login-title{font-size:1.25rem;font-weight:600;color:var(--color-rose-400);margin-bottom:1rem}@media (min-width: 640px){.home-buttons{flex-direction:row;justify-content:center;gap:1rem}}.login-form{display:flex;flex-direction:column;gap:1rem}.login-button{width:100%;padding:.75rem;background-color:var(--color-rose-400);color:var(--color-white);border:none;border-radius:.25rem;font-size:1rem;cursor:pointer;transition:background-color .3s ease}.login-button:hover{background-color:var(--color-rose-500)}.login-button:disabled{opacity:.5;cursor:not-allowed}.home-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 64px);padding:2rem}.buttons-container{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:400px}.home-button{width:100%;padding:1rem;border:none;border-radius:.5rem;font-size:1rem;cursor:pointer;text-align:center;text-decoration:none;transition:background-color .3s ease}.login-page{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 100px);padding:1rem}.login-card{width:100%;max-width:400px;background-color:var(--color-white);border-radius:.5rem;box-shadow:0 4px 10px #0000001a;padding:2rem}.login-title{font-size:1.5rem;font-weight:600;color:var(--color-rose-400);margin-bottom:1.5rem;text-align:center}.dashboard-container{padding:1rem;width:100%;overflow-x:auto;max-width:1200px;margin:0 auto}.dashboard-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.dashboard-title{font-size:1.5rem;font-weight:700;color:var(--color-rose-400);margin:0}.dashboard-actions{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.search-container{position:relative;flex:1;min-width:250px}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:#666}.search-input{padding:.5rem .5rem .5rem 2rem;border:2px solid var(--color-rose-300);border-radius:.25rem;width:100%;box-sizing:border-box}.download-button{display:flex;align-items:center;justify-content:center;gap:.5rem;background-color:#161616;color:#fff;border:none;border-radius:4px;padding:.5rem 1rem;cursor:pointer;width:100%;font-size:.875rem}.download-button:hover{background-color:var(--color-rose-500)}.loading-spinner{display:flex;justify-content:center;align-items:center;height:200px}.spinner{border:4px solid rgba(0,0,0,.1);border-left-color:var(--color-rose-400);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;background-color:#fff;border-radius:.5rem;box-shadow:0 2px 10px #0000001a;margin:0 -1rem;padding:0 1rem}.table{width:100%;border-collapse:collapse;min-width:800px}.table th,.table td{padding:.75rem;text-align:left;border-bottom:1px solid #eee;font-size:.875rem}.table th{background-color:#f9f9f9;font-weight:600;color:#333;text-transform:uppercase;font-size:.75rem;white-space:nowrap}.table tr:hover{background-color:#f5f5f5}.action-buttons{display:flex;gap:.5rem}.action-button{padding:.5rem;border:none;background:none;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center}.action-button:hover{background-color:var(--color-rose-500)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.modal-content{background-color:#fff;border-radius:.5rem;width:100%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #eee}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666}.modal-body{padding:1rem;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1rem;border-top:1px solid #eee}.btn{background-color:var(--color-rose-400);color:#fff;border:none;border-radius:.25rem;padding:.5rem 1rem;cursor:pointer;text-decoration:none;display:inline-block;text-align:center}.btn:hover{background-color:var(--color-rose-500)}.btn-secondary{background-color:#ccc;color:#333}.btn-secondary:hover{background-color:#bbb}@media (min-width: 768px){.dashboard-header{flex-direction:row;justify-content:space-between;align-items:center}.dashboard-actions{flex-direction:row;width:auto}.search-container{width:250px}.download-button{width:auto}}@media (max-width: 768px){.dashboard-header{align-items:stretch}.dashboard-actions{flex-direction:column}.search-container{width:100%}.table-container{margin:0;padding:0}.table{font-size:.75rem}.table th,.table td{padding:.5rem}.modal-content{max-width:100%;max-height:100%;border-radius:0}.table-container .table{display:none}.mobile-cards{display:flex;flex-direction:column;gap:1rem}.patient-card{background:#fff;border-radius:8px;padding:1rem;box-shadow:0 2px 4px #0000001a}.patient-card-field{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #eee}.patient-card-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1rem}}.table-container{display:block;width:100%;overflow-x:auto}.mobile-cards{display:none}@media screen and (max-width: 768px){.table-container{display:none}.mobile-cards{display:block;padding:1rem}.patient-card{background:#fff;border-radius:8px;padding:1rem;margin-bottom:1rem;box-shadow:0 2px 4px #0000001a}}``` import{jsPDF}from "jspdf"; import "jspdf-autotable"; export const generatePatientPDF = (patientData) =>{const doc = new jsPDF({orientation: "portrait",unit: "mm",format: "a4"});// Extremely compact font sizes and spacing const titleFontSize = 10;const headingFontSize = 8;const contentFontSize = 6;const margin = 10;let yPos = margin;// Title doc.setFontSize(titleFontSize);doc.text("CONSENTIMIENTO INFORMADO",doc.internal.pageSize.getWidth() / 2,yPos,{align: "center"});yPos += 5;// Patient info in single line doc.setFontSize(contentFontSize);const patientInfoLine = `Nombre: ${patientData.nombre}${patientData.apellido}| DNI: ${patientData.dni}| Tel: ${patientData.tel}`;doc.text(patientInfoLine,margin,yPos);yPos += 4;// Content sections in compact format const sections = [{title: "1. HONORARIOS Y PAGOS",content: "Atención particular exclusivamente. Pago adelantado para confirmar turno. Reintegros: responsabilidad del paciente. Recargo 10% en pagos diferidos. Medios: virtual/transferencia."},{title: "2. CANCELACIONES",content: "Avisar con 24hs de anticipación. Sin aviso previo: sesión se cobra completa. Cancelaciones frecuentes implican reevaluación del tratamiento."},{title: "3. MODALIDAD VIRTUAL",content: "Uso obligatorio de cámara. Conexión estable requerida. Espacio privado necesario. Prohibida la grabación de sesiones."},{title: "4. CONFIDENCIALIDAD",content: "Información protegida por secreto profesional. Excepciones: riesgo vital, orden judicial, supervisión profesional."}];sections.forEach(section => {// Section title doc.setFontSize(headingFontSize); doc.setFont(undefined,"bold"); doc.text(section.title,margin,yPos); yPos += 3; // Section content doc.setFontSize(contentFontSize); doc.setFont(undefined,"normal"); const lines = doc.splitTextToSize(section.content,doc.internal.pageSize.getWidth() - (margin * 2)); lines.forEach(line => {doc.text(line,margin,yPos); yPos += 3;}); yPos += 2;});// Add compact legal text doc.setFontSize(contentFontSize);const legalText = "Al firmar este documento, declaro haber leído y aceptado todas las condiciones aquí establecidas.";doc.text(legalText,margin,yPos + 3);// Signature at bottom yPos = doc.internal.pageSize.getHeight() - 15;doc.text("_______________________",margin,yPos);doc.text("Firma del paciente",margin,yPos + 3);doc.text(new Date().toLocaleDateString(),doc.internal.pageSize.getWidth() - 30,yPos + 3);return doc};{}
