*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}.app{max-width:1400px;margin:0 auto;padding:20px;min-height:100vh}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:30px;border-radius:10px;margin-bottom:30px;box-shadow:0 4px 6px #0000001a}.app-header h1{margin:0 0 10px;font-size:2.5em}.app-description{margin:0;font-size:1.1em;opacity:.95}.app-content{display:flex;flex-direction:column;gap:25px}.info-box,.warning-box{padding:20px;border-radius:8px;margin:15px 0}.info-box{background-color:#e3f2fd;border-left:4px solid #2196f3}.warning-box{background-color:#fff3e0;border-left:4px solid #ff9800}.info-box h3,.warning-box h3{margin-top:0}.info-box ol,.info-box ul{margin:10px 0;padding-left:25px}.help-text{color:#666;font-size:.95em;margin:10px 0;line-height:1.6}.help-list{margin:10px 0;padding-left:25px;color:#666}.help-list li{margin:8px 0;line-height:1.5}.explanation-section{margin:20px 0;border:1px solid #e0e0e0;border-radius:8px;background-color:#fafafa}.explanation-toggle{width:100%;padding:15px 20px;background:none;border:none;text-align:left;cursor:pointer;display:flex;align-items:center;gap:10px;font-size:1em;color:#333;transition:background-color .2s}.explanation-toggle:hover{background-color:#f0f0f0}.explanation-toggle:focus{outline:2px solid #667eea;outline-offset:-2px}.explanation-toggle span{display:inline-block;width:20px;font-size:.8em;color:#667eea;transition:transform .2s}.explanation-content{padding:0 20px 20px;border-top:1px solid #e0e0e0;background-color:#fff;border-radius:0 0 8px 8px}.explanation-content h4{margin:20px 0 15px;color:#333;font-size:1.2em}.explanation-content p{margin:12px 0;line-height:1.7;color:#555}.explanation-content ul{margin:12px 0;padding-left:25px;line-height:1.7}.explanation-content li{margin:10px 0;color:#555}.explanation-content ul ul{margin:8px 0;padding-left:20px}.explanation-content strong{color:#333;font-weight:600}.explanation-content ol{margin:12px 0;padding-left:25px;line-height:1.7}.explanation-content ol li{margin:10px 0;color:#555}.technical-table{width:100%;border-collapse:collapse;margin:20px 0;font-size:.9em}.technical-table th{background-color:#667eea;color:#fff;padding:12px;text-align:left;font-weight:600;border:1px solid #5568d3}.technical-table td{padding:10px 12px;border:1px solid #e0e0e0;background-color:#fafafa}.technical-table tr:nth-child(2n) td{background-color:#f5f5f5}.technical-table tr:hover td{background-color:#f0f0f0}.logo-upload-section{background:#fff;padding:25px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.logo-preview{display:flex;align-items:center;margin-top:15px}.logo-preview-img{max-height:60px;max-width:150px;object-fit:contain}.file-upload{background:#fff;padding:25px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.file-upload h2{margin-top:0;color:#333}.upload-section{margin-top:15px}.file-input-wrapper{margin:20px 0}.file-input{display:none}.file-input-label{display:inline-block;padding:12px 24px;background-color:#667eea;color:#fff;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .3s}.file-input-label:hover{background-color:#5568d3}.loading-indicator{display:flex;align-items:center;gap:10px;margin:15px 0}.spinner{border:3px solid #f3f3f3;border-top:3px solid #667eea;border-radius:50%;width:24px;height:24px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.success-message{background-color:#4caf50;color:#fff;padding:12px;border-radius:6px;margin:15px 0}.error-message{background-color:#f44336;color:#fff;padding:12px;border-radius:6px;margin:15px 0}.document-selector{background:#fff;padding:25px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.document-selector h2{margin-top:0;color:#333}.checkbox-group{display:flex;flex-direction:column;gap:15px;margin-top:20px}.checkbox-label{display:flex;align-items:flex-start;gap:12px;padding:15px;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .3s}.checkbox-label:hover{border-color:#667eea;background-color:#f8f9ff}.checkbox-input{margin-top:4px;width:20px;height:20px;cursor:pointer}.checkbox-content{flex:1;display:flex;flex-direction:column;gap:5px}.checkbox-content strong{font-size:1.1em;color:#333}.checkbox-description{font-size:.9em;color:#666;line-height:1.5}.statement-generator,.service-charge-demand,.ground-rent-demand,.document-generator{background:#fff;padding:25px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.document-generator{margin-top:20px}.generated-document-section{margin-top:30px;padding-top:30px;border-top:2px solid #e0e0e0}.document-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.document-section-header h3{margin:0;color:#333}.btn-small{padding:8px 16px;font-size:.9em}.btn-generate-all{margin-top:15px;padding:14px 28px;font-size:1.1em}.bulk-actions{margin:20px 0;padding:20px;background-color:#f9f9f9;border-radius:8px;border:1px solid #e0e0e0}.bulk-actions-info{margin-top:15px;padding-top:15px;border-top:1px solid #e0e0e0}.bulk-actions-info p{margin:10px 0;color:#666}.download-progress{margin-top:15px}.download-progress p{margin:10px 0;color:#333;font-weight:500}.progress-bar{width:100%;height:24px;background-color:#e0e0e0;border-radius:12px;overflow:hidden;margin-top:10px}.progress-bar-fill{height:100%;background-color:#667eea;transition:width .3s ease;border-radius:12px}.pdf-document-wrapper{background:#fff;padding:20px}.pdf-document-wrapper .statement-template,.pdf-document-wrapper .service-charge-template,.pdf-document-wrapper .ground-rent-template{background:#fff;padding:40px;max-width:800px;margin:0 auto}.statement-generator h2,.service-charge-demand h2,.ground-rent-demand h2{margin-top:0;color:#333}.generator-controls{display:flex;flex-direction:column;gap:15px;margin:20px 0}.generator-controls label{font-weight:500;color:#333}.apt-select,.document-select{padding:10px;border:2px solid #e0e0e0;border-radius:6px;font-size:1em;background:#fff;cursor:pointer}.apt-select:hover,.document-select:hover{border-color:#667eea}.action-buttons{display:flex;gap:10px;margin-top:10px}.btn{padding:12px 24px;border:none;border-radius:6px;font-size:1em;font-weight:500;cursor:pointer;transition:all .3s}.btn-primary{background-color:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background-color:#5568d3}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#5a6268}.btn:disabled{opacity:.6;cursor:not-allowed}.document-preview{margin-top:30px;padding:20px;background:#f9f9f9;border-radius:8px;border:1px solid #e0e0e0}.statement-template,.service-charge-template,.ground-rent-template{background:#fff;padding:40px;max-width:800px;margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.template-header{margin-bottom:10px;display:flex;flex-direction:column;align-items:flex-end;text-align:right;page-break-after:auto;page-break-inside:auto}.logo-container{margin-bottom:5px;width:100%;display:flex;justify-content:flex-end;page-break-after:auto}.template-logo{max-height:60px;max-width:200px;object-fit:contain}.template-header h2{margin:0 0 5px;color:#333;page-break-after:auto;font-size:1.5em;line-height:1.2}.disclaimer{margin:10px 0;color:#666}.statement-date{font-size:1.1em;color:#666;page-break-after:auto}.leaseholder-info{margin:8px 0;line-height:1.4;page-break-after:auto;page-break-inside:auto;font-size:.95em}.leaseholder-name{font-weight:700;font-size:1.1em}.apt-number{font-weight:500}.address{color:#666}.address-line{color:#666;margin:2px 0}.statement-table,.demand-table{width:100%;border-collapse:collapse;margin:10px 0;font-family:inherit;table-layout:fixed}.statement-table th,.demand-table th{background-color:#f0f0f0;padding:12px;text-align:left;border:1px solid #ddd;font-weight:600;font-family:inherit}.statement-table th:nth-child(1),.statement-table td:nth-child(1){width:15%;padding-left:3px}.statement-table th:nth-child(2),.statement-table td:nth-child(2){width:35%}.statement-table th:nth-child(3),.statement-table td:nth-child(3){width:15%}.statement-table th:nth-child(4),.statement-table td:nth-child(4){width:15%}.statement-table th:nth-child(5),.statement-table td:nth-child(5){width:20%}.statement-table td,.demand-table td{padding:14px 12px;border:1px solid #ddd;font-family:inherit;line-height:1.6;vertical-align:top}.period-row{background-color:#fafafa}.period-row td{padding-top:4px;padding-bottom:4px;border-top:none}.period-cell{padding-left:20px!important}.statement-totals{margin-top:10px;page-break-inside:avoid}.statement-bank-details{margin-top:15px;font-size:.7em;line-height:1.4;color:#333;page-break-inside:avoid;max-width:500px}.statement-bank-details p{margin:4px 0}.statement-legal-notice{margin-top:10px;font-size:.7em;line-height:1.4;color:#333;page-break-inside:avoid;max-width:500px}.statement-legal-notice p{margin:4px 0}.statement-totals-table{width:100%;border-collapse:collapse;margin:10px 0 0;table-layout:fixed}.statement-totals-table td{padding:12px;border:1px solid #ddd}.statement-totals-table td:nth-child(1){width:15%}.statement-totals-table td:nth-child(2){width:35%}.statement-totals-table td:nth-child(3){text-align:right;width:15%}.statement-totals-table td:nth-child(4){text-align:right;width:15%}.statement-totals-table td:nth-child(5){text-align:right;width:20%}.document-actions{margin-top:20px;padding-top:20px;border-top:1px solid #e0e0e0;text-align:center;display:flex;gap:10px;justify-content:center}.period-inline{color:#1976d2;font-weight:400}.amount{text-align:right}.balance{font-weight:500}.summary-row{background-color:#f9f9f9}.summary-row.outstanding{background-color:#fff3e0;font-size:1.1em}.total-row{background-color:#f0f0f0;font-weight:600}.demand-header{display:flex;justify-content:space-between;margin:15px 0;padding:15px;background-color:#f9f9f9;border-radius:6px}.demand-details{text-align:right;line-height:1.8}.invoice-header{display:flex;justify-content:space-between;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #e0e0e0}.invoice-details{margin-top:15px;padding:15px;background-color:#f9f9f9;border-radius:6px}.amount-large{font-size:1.3em;margin-top:10px}.page-break{margin-bottom:20px}.pdf-document-wrapper .page-break{page-break-after:auto}.page-break:last-child{margin-bottom:0}.pdf-document-wrapper{page-break-after:always;break-after:page}.pdf-document-wrapper:last-child{page-break-after:auto;break-after:auto}.statement-template,.service-charge-template,.ground-rent-template{page-break-inside:avoid;break-inside:avoid}.statement-template{page-break-inside:auto}.statement-table{page-break-inside:avoid;break-inside:avoid;page-break-before:auto}.statement-table thead{page-break-after:avoid;display:table-header-group}.statement-table tbody{display:table-row-group}.statement-table tbody tr:first-child{page-break-before:avoid}.statement-totals{page-break-inside:avoid}.dynamic-data-section{margin-top:15px}.dynamic-data{background-color:#fffacd;padding:20px;margin:20px 0;border-radius:6px;border:2px solid #ffd700;line-height:2}.overdue-notice{margin-top:15px;padding:15px;background-color:#ffebee;border-left:4px solid #f44336;border-radius:4px;color:#c62828}.overdue-notice p{margin:0;font-weight:500}.email-sender{background:#fff;padding:25px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.email-sender h2{margin-top:0;color:#333}.email-controls{display:flex;flex-direction:column;gap:15px;margin:20px 0}.email-input{padding:10px;border:2px solid #e0e0e0;border-radius:6px;font-size:1em}.email-input:hover{border-color:#667eea}.email-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.selected-document-info{padding:15px;background-color:#f9f9f9;border-radius:6px;margin:10px 0}.selected-document-info p{margin:8px 0}.btn-send{margin-top:10px;width:fit-content}.status-message{padding:12px;border-radius:6px;margin:15px 0}.status-message.success{background-color:#4caf50;color:#fff}.status-message.error{background-color:#f44336;color:#fff}@media print{.app-header,.file-upload,.document-selector,.generator-controls,.action-buttons,.email-sender,.bulk-actions,.explanation-section,.document-actions,.logo-upload-section{display:none}.document-preview{border:none;padding:0;background:#fff;margin:0}.statement-template,.service-charge-template,.ground-rent-template{padding:20px;max-width:100%}.template-header{margin-bottom:20px}.template-logo{max-height:60px}.page-break{page-break-after:always}.statement-table,.demand-table{font-size:.9em}.statement-table th,.demand-table th,.statement-table td,.demand-table td{padding:8px}}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s linear infinite;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.btn:disabled{opacity:.7;cursor:not-allowed;position:relative}.btn:disabled .spinner{border-top-color:currentColor}
