:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.summary-card{background-color:var(--background-secondary);border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base)}.summary-card:hover{box-shadow:var(--shadow-sm);border-color:var(--gray-300)}.summary-card.has-errors{border-color:var(--error-color);border-width:2px}.summary-card-errors{display:flex;gap:12px;padding:12px 16px;background-color:#fef2f2;border-bottom:1px solid #fecaca}.summary-card-errors .error-icon{flex-shrink:0;color:#991b1b}.summary-card-errors .error-messages{flex:1}.summary-card-errors .error-message{color:#991b1b;font-size:14px;line-height:1.5;margin-bottom:4px}.summary-card-errors .error-message:last-child{margin-bottom:0}.summary-card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--gray-200);background-color:var(--gray-50)}.summary-card-header h4{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.btn-edit-card{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background-color:var(--background-secondary);color:var(--primary-color);border:1px solid var(--primary-color);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base)}.btn-edit-card:hover{background-color:var(--primary-color);color:var(--text-on-primary)}.btn-edit-card:focus{outline:2px solid var(--primary-color);outline-offset:2px}.btn-edit-card svg{width:14px;height:14px}.summary-card-body{padding:var(--space-5)}.summary-card-body dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:var(--space-3) var(--space-5)}.summary-card-body dt{font-weight:var(--font-weight-medium);color:var(--text-secondary);font-size:var(--font-size-sm)}.summary-card-body dd{margin:0;color:var(--text-primary);font-size:var(--font-size-sm)}.summary-empty-state{color:var(--text-tertiary);font-size:var(--font-size-sm);font-style:italic;text-align:center;padding:var(--space-4) 0}.invoice-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-5);margin-bottom:var(--space-6)}.invoice-status{display:inline-block;padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:capitalize}.status-draft{background-color:var(--gray-100);color:var(--gray-700)}.status-sent{background-color:#dbeafe;color:#1e40af}.status-paid{background-color:var(--success-color-light);color:#047857}.status-overdue{background-color:var(--error-color-light);color:var(--error-color)}@media (max-width: 768px){.invoice-summary-grid{grid-template-columns:1fr;gap:var(--space-4)}.summary-card-header{padding:var(--space-3) var(--space-4)}.summary-card-body{padding:var(--space-4)}.btn-edit-card{font-size:var(--font-size-xs);padding:var(--space-2) var(--space-3)}}.modal-content{background-color:var(--background-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:modalSlideIn .2s ease-out}.modal-small{max-width:400px}.modal-medium{max-width:600px}.modal-large{max-width:900px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--gray-200);flex-shrink:0}.modal-close:focus{outline:2px solid var(--primary-color);outline-offset:2px;border-radius:var(--radius-sm)}.modal-body .form-input,.modal-body input[type=text],.modal-body input[type=email],.modal-body input[type=tel],.modal-body input[type=url],.modal-body input[type=number],.modal-body input[type=date],.modal-body select,.modal-body textarea{width:100%;padding:var(--space-3);border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--font-size-base);color:var(--text-primary);background-color:var(--background-secondary);transition:all var(--transition-base);font-family:inherit}.modal-body .form-input:focus,.modal-body input:focus,.modal-body select:focus,.modal-body textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-lighter)}.modal-body textarea{resize:vertical;min-height:80px}.modal-body .error-message{display:flex;align-items:center;gap:var(--space-2);color:var(--error-color);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-top:var(--space-2);animation:slideDown .2s ease-out}.modal-body .error-message:before{content:"⚠";font-size:var(--font-size-base);flex-shrink:0}.modal-body .success-message-inline{display:flex;align-items:center;gap:var(--space-2);color:var(--success-color);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-top:var(--space-2);animation:slideDown .2s ease-out}.modal-body .success-message-inline:before{content:"✓";font-size:var(--font-size-base);flex-shrink:0}.modal-body .form-group:has(.error-message) input,.modal-body .form-group:has(.error-message) textarea,.modal-body .form-group:has(.error-message) select{border-color:var(--error-color);background-color:var(--error-color-light);transition:border-color .2s,background-color .2s}.modal-body .form-group:has(.error-message) input:focus,.modal-body .form-group:has(.error-message) textarea:focus,.modal-body .form-group:has(.error-message) select:focus{border-color:var(--error-color);box-shadow:0 0 0 3px #ef44441a;outline:none}.modal-body .form-group input.is-valid,.modal-body .form-group textarea.is-valid,.modal-body .form-group select.is-valid{border-color:var(--success-color)}.modal-body .form-group input.is-valid:focus,.modal-body .form-group textarea.is-valid:focus,.modal-body .form-group select.is-valid:focus{border-color:var(--success-color);box-shadow:0 0 0 3px #10b9811a;outline:none}.modal-body .form-group input.is-invalid,.modal-body .form-group textarea.is-invalid,.modal-body .form-group select.is-invalid{border-color:var(--error-color);background-color:var(--error-color-light);transition:border-color .2s,background-color .2s}.modal-body .form-group input.is-invalid:focus,.modal-body .form-group textarea.is-invalid:focus,.modal-body .form-group select.is-invalid:focus{border-color:var(--error-color);box-shadow:0 0 0 3px #ef44441a;outline:none}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-6);border-top:1px solid var(--gray-200);background-color:var(--gray-50);flex-shrink:0}.modal-footer .btn-danger{padding:var(--space-3) var(--space-5);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--text-on-primary);background-color:var(--error-color);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base)}.modal-footer .btn-danger:hover{background-color:#d32f2f;box-shadow:var(--shadow-sm)}.modal-footer .btn-danger:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.modal-overlay{display:flex!important;padding:0;align-items:flex-end;visibility:visible!important}.modal-content{max-height:95vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-width:none!important;width:100%;animation:modalSlideUp .3s ease-out}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:var(--space-4);position:sticky;top:0;background:var(--background-secondary);z-index:1}.modal-header h3{font-size:var(--font-size-lg)}.modal-close{min-width:44px;min-height:44px;font-size:28px}.modal-body{padding:var(--space-4);-webkit-overflow-scrolling:touch}.modal-footer{padding:var(--space-4);position:sticky;bottom:0;background:var(--gray-50);z-index:1;flex-direction:column}.modal-footer .btn-secondary,.modal-footer .btn-primary{width:100%;min-height:48px;font-size:var(--font-size-base)}}@media (max-width: 480px){.modal-header h3{font-size:var(--font-size-base)}.modal-header,.modal-body,.modal-footer{padding:var(--space-3)}.modal-body .form-group{margin-bottom:var(--space-4)}}.export-settings{background-color:var(--background-color, #ffffff);border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:20px;max-width:500px;margin:0 auto}.export-settings h3{color:var(--primary-color, #4a86e8);margin-top:0;margin-bottom:20px;font-size:1.5rem;border-bottom:1px solid var(--border-color, #e0e0e0);padding-bottom:10px}.export-settings h4{color:var(--primary-color, #4a86e8);margin:15px 0 10px;font-size:1.1rem}.export-settings h5{margin:10px 0;font-size:1rem;font-weight:500}.settings-group{margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid var(--border-color, #f0f0f0)}.settings-group:last-child{border-bottom:none;margin-bottom:0}.settings-row{display:flex;align-items:center;margin-bottom:12px}.settings-row label{flex:0 0 120px;font-weight:500}.settings-row input[type=text],.settings-row input[type=number],.settings-row select{flex:1;padding:8px 12px;border:1px solid var(--border-color, #ddd);border-radius:4px;font-size:14px}.settings-row input[type=range]{flex:1;margin-right:10px}.settings-row.checkbox{display:flex;align-items:center}.settings-row.checkbox input[type=checkbox]{margin-right:10px}.settings-row.checkbox label{flex:1;cursor:pointer}.margin-inputs{display:grid;grid-template-columns:1fr 1fr;gap:10px}.margin-input{display:flex;align-items:center}.margin-input label{flex:0 0 60px;font-weight:500}.margin-input input{width:60px;padding:6px;border:1px solid var(--border-color, #ddd);border-radius:4px}.settings-actions{display:flex;justify-content:space-between;margin-top:20px}.settings-actions button{padding:8px 16px;border-radius:4px;font-weight:500;cursor:pointer;transition:background-color .2s,color .2s}.reset-button{background-color:transparent;border:1px solid var(--border-color, #ddd);color:var(--text-color, #333)}.reset-button:hover{background-color:#f5f5f5}.close-button{background-color:var(--primary-color, #4a86e8);border:none;color:#fff}.close-button:hover{background-color:var(--primary-color-dark, #3a76d8)}.export-settings-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.export-settings-modal .export-settings{max-height:90vh;overflow-y:auto;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.download-button-container{margin:20px 0}.download-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.download-button{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background-color:var(--primary-color, #4a86e8);color:#fff;border:none;border-radius:4px;font-weight:500;cursor:pointer;transition:background-color .2s}.download-button:hover{background-color:var(--primary-color-dark, #3a76d8)}.download-button:disabled{background-color:#ccc;cursor:not-allowed}.settings-button{display:flex;align-items:center;justify-content:center;min-width:36px;width:36px;height:36px;flex-shrink:0;background-color:transparent;border:1px solid var(--border-color, #ddd);border-radius:4px;cursor:pointer;transition:background-color .2s}.settings-button:hover{background-color:#f5f5f5}.settings-button svg{color:var(--text-color, #333);flex-shrink:0;min-width:16px;min-height:16px}.export-progress{margin:10px 0}.progress-bar{height:8px;background-color:#f0f0f0;border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background-color:var(--primary-color, #4a86e8);border-radius:4px;transition:width .3s ease}.progress-text{font-size:14px;color:var(--text-color, #333);text-align:center}.export-error{margin-top:10px;padding:10px;background-color:#ffebee;color:#d32f2f;border-radius:4px;font-size:14px}@media (max-width: 768px){.download-actions{flex-direction:column;align-items:stretch}.download-button{width:100%}.settings-button{width:100%;min-width:100%;flex-shrink:1}}.edit-protection-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #F59E0B;border-radius:8px;margin-bottom:24px;box-shadow:0 2px 8px #f59e0b1a}.edit-protection-banner__content{display:flex;align-items:flex-start;gap:12px;flex:1}.edit-protection-banner__icon{font-size:24px;flex-shrink:0;line-height:1}.edit-protection-banner__text{flex:1}.edit-protection-banner__text strong{display:block;font-size:15px;font-weight:600;color:#92400e;margin-bottom:4px}.edit-protection-banner__text p{font-size:13px;color:#78350f;margin:0;line-height:1.5}.edit-protection-banner__action{padding:8px 16px;background:#f59e0b;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.edit-protection-banner__action:hover{background:#d97706;transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b4d}.edit-protection-banner__action:active{transform:translateY(0)}@media (max-width: 768px){.edit-protection-banner{flex-direction:column;align-items:stretch}.edit-protection-banner__action{width:100%}}.invoice-status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:12px;border:1px solid;font-weight:500;white-space:nowrap;transition:all .2s ease}.invoice-status-badge--small{font-size:11px;padding:2px 8px;gap:3px}.invoice-status-badge--medium{font-size:13px;padding:4px 12px;gap:4px}.invoice-status-badge--large{font-size:15px;padding:6px 16px;gap:5px}.invoice-status-badge__icon{display:inline-flex;align-items:center;font-size:1.1em}.invoice-status-badge__label{display:inline-flex;align-items:center}.invoice-status-badge:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.status-control{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f9fafb;border:1px solid #E5E7EB;border-radius:8px;margin-bottom:16px;position:relative}.status-control__label{font-size:14px;font-weight:600;color:#374151}.status-control__value{position:relative}.status-control__button{display:inline-flex;align-items:center;gap:8px;background:#fff;border:2px solid #E5E7EB;border-radius:8px;padding:6px 12px;cursor:pointer;transition:all .2s ease}.status-control__button:hover:not(:disabled){border-color:#3b82f6;box-shadow:0 2px 8px #3b82f61a}.status-control__button:disabled{opacity:.6;cursor:not-allowed}.status-control__chevron{color:#6b7280;transition:transform .2s ease}.status-control__button:hover .status-control__chevron{color:#3b82f6}.status-control__dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:200px;background:#fff;border:1px solid #E5E7EB;border-radius:8px;box-shadow:0 4px 16px #0000001a;z-index:1000;padding:8px}.status-control__dropdown-header{font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;padding:8px 12px;margin-bottom:4px}.status-control__dropdown-item{display:flex;align-items:center;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;text-align:left}.status-control__dropdown-item:hover:not(:disabled){background:#f3f4f6}.status-control__dropdown-item:disabled{opacity:.5;cursor:not-allowed}.status-control__overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999;background:transparent}@media (max-width: 768px){.status-control{flex-direction:column;align-items:flex-start}.status-control__dropdown{min-width:100%}}.payment-instructions-editor-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.payment-instructions-editor{background:#fff;border-radius:12px;width:100%;max-width:700px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 40px #00000026}.editor-header{padding:1.5rem;border-bottom:1px solid #e5e7eb}.editor-header h2{margin:0 0 .5rem;font-size:1.5rem;color:#111827}.editor-subtitle{margin:0;color:#6b7280;font-size:.95rem}.editor-content{flex:1;overflow-y:auto;padding:1.5rem}.form-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #f3f4f6}.form-section:last-child{border-bottom:none;margin-bottom:0}.section-label{display:block;font-weight:600;color:#374151;margin-bottom:.75rem;font-size:.95rem}.section-description{color:#6b7280;font-size:.875rem;margin:-.5rem 0 1rem}.payment-method-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.method-option{display:flex;flex-direction:column;align-items:center;padding:1rem;border:2px solid #e5e7eb;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease;text-align:center}.method-option:hover{border-color:#5dbbe8;background:#f8fdff}.method-option.selected{border-color:#5dbbe8;background:#eaf7fc}.method-icon{font-size:1.5rem;margin-bottom:.5rem}.method-label{font-size:.8rem;color:#374151;line-height:1.3}.form-row{margin-bottom:1rem}.form-row:last-child{margin-bottom:0}.form-row.two-columns{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.form-row.three-columns{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.form-group{display:flex;flex-direction:column}.form-group label{font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.375rem}.form-group input,.form-group select,.form-group textarea{padding:.625rem .75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#5dbbe8;box-shadow:0 0 0 3px #5dbbe826}.form-group input::placeholder,.form-group textarea::placeholder{color:#9ca3af}.form-group small{font-size:.8rem;color:#6b7280;margin-top:.375rem}.info-box{background:#eef6ff;border:1px solid #bfdbfe;border-radius:8px;padding:1rem}.info-box p{margin:0;color:#1e40af;font-size:.9rem}.compliance-notice-box{background:#fef3c7;border:1px solid #fcd34d;border-radius:8px;padding:1rem;margin-top:1rem}.compliance-notice-box p{margin:0;color:#92400e;font-size:.875rem}.editor-footer{padding:1rem 1.5rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:.75rem;background:#f9fafb;border-radius:0 0 12px 12px}.editor-footer .btn-secondary{padding:.625rem 1.25rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;font-size:.95rem;cursor:pointer;transition:background .2s}.editor-footer .btn-secondary:hover{background:#f3f4f6}.editor-footer .btn-primary{padding:.625rem 1.25rem;border:none;border-radius:6px;background:#5dbbe8;color:#fff;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s}.editor-footer .btn-primary:hover{background:#4ba9d6}.editor-footer .btn-primary:disabled{background:#d1d5db;cursor:not-allowed}@media (max-width: 640px){.payment-instructions-editor-overlay{padding:0;align-items:flex-end}.payment-instructions-editor{border-radius:12px 12px 0 0;max-height:95vh}.payment-method-grid{grid-template-columns:repeat(2,1fr)}.form-row.two-columns,.form-row.three-columns{grid-template-columns:1fr}.editor-header,.editor-content{padding:1.25rem}.editor-footer{padding:1rem 1.25rem}}@media (max-width: 400px){.payment-method-grid{grid-template-columns:1fr}}.send-invoice-modal{display:flex;flex-direction:column;gap:20px}.send-invoice-modal .invoice-preview-card{background:linear-gradient(135deg,#5dbbe8,#4a9fcc);color:#fff;border-radius:8px;padding:20px;margin-bottom:10px}.send-invoice-modal .invoice-preview-header{display:flex;justify-content:space-between;align-items:flex-start}.send-invoice-modal .invoice-number{font-size:18px;font-weight:600;margin-bottom:4px}.send-invoice-modal .invoice-customer{font-size:14px;opacity:.9}.send-invoice-modal .invoice-amount{font-size:24px;font-weight:700}.send-invoice-modal .form-group{margin-bottom:0}.send-invoice-modal .help-text{font-size:13px;color:var(--text-secondary);margin-top:6px}.send-invoice-modal .checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:500}.send-invoice-modal .checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.send-invoice-modal .checkbox-label span{flex:1}.send-invoice-modal .error-banner{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;font-size:14px}.send-invoice-modal .error-banner svg{flex-shrink:0}.send-invoice-modal .info-banner{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;background:#e7f3ff;border:1px solid #b3d9ff;border-radius:6px;color:#004085;font-size:13px;line-height:1.5}.send-invoice-modal .info-banner svg{flex-shrink:0;margin-top:2px}.send-invoice-modal .info-banner div{flex:1}.send-quote-modal{display:flex;flex-direction:column;gap:20px}.send-quote-modal .quote-preview-card{background:linear-gradient(135deg,#5dbbe8,#3a9fd5);color:#fff;border-radius:8px;padding:20px;margin-bottom:10px}.send-quote-modal .quote-preview-header{display:flex;justify-content:space-between;align-items:flex-start}.send-quote-modal .quote-number{font-size:18px;font-weight:600;margin-bottom:4px}.send-quote-modal .quote-customer{font-size:14px;opacity:.9}.send-quote-modal .quote-amount{font-size:24px;font-weight:700}.send-quote-modal .form-group{margin-bottom:0}.send-quote-modal .help-text{font-size:13px;color:var(--text-secondary);margin-top:6px}.send-quote-modal .error-banner{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;font-size:14px}.send-quote-modal .error-banner svg{flex-shrink:0}.send-quote-modal .info-banner{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;background:#e7f3ff;border:1px solid #b3d9ff;border-radius:6px;color:#004085;font-size:13px;line-height:1.5}.send-quote-modal .info-banner svg{flex-shrink:0;margin-top:2px}.send-quote-modal .info-banner div{flex:1}.welcome-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out}.welcome-container{background-color:var(--background-secondary);border-radius:8px;box-shadow:0 4px 20px #0003;width:90%;max-width:700px;max-height:90vh;overflow-y:auto;padding:30px;position:relative;animation:slideUp .4s ease-out}.welcome-close{position:absolute;top:15px;right:15px;background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-secondary);width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.welcome-close:hover{background-color:var(--background-tertiary)}.welcome-progress{display:flex;justify-content:center;margin-bottom:20px}.progress-dot{width:12px;height:12px;border-radius:50%;background-color:var(--border-color);margin:0 6px;cursor:pointer;transition:all .3s}.progress-dot.active{background-color:var(--primary-color, #2563eb);transform:scale(1.2)}.progress-dot.completed{background-color:var(--accent-color, #10b981)}.welcome-content{margin-bottom:30px}.welcome-content h2{color:var(--primary-color, #2563eb);margin-top:0;margin-bottom:20px;font-size:24px;text-align:center}.welcome-step-content{line-height:1.6}.welcome-step-content p{margin-bottom:15px}.welcome-step-content ul{margin-bottom:15px;padding-left:20px}.welcome-step-content li{margin-bottom:8px}.welcome-image{display:flex;justify-content:center;margin:20px 0}.welcome-image img{max-width:100%;max-height:200px}.shortcuts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:15px;margin-top:15px}.shortcut{display:flex;align-items:center;background-color:#f9fafb;padding:10px;border-radius:4px;border:1px solid #e5e7eb}.shortcut kbd{background-color:#e5e7eb;border-radius:3px;border:1px solid #d1d5db;box-shadow:0 1px 1px #0003;font-size:12px;font-weight:600;padding:3px 6px;margin-right:5px}.shortcut span{margin-left:10px;font-size:14px}.welcome-navigation{display:flex;justify-content:space-between}.welcome-button{padding:10px 20px;border-radius:4px;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid var(--border-color, #d1d5db);background-color:#fff;color:var(--text-color, #333)}.welcome-button:hover{background-color:#f5f5f5}.welcome-button.primary{background-color:var(--primary-color, #2563eb);color:#fff;border:none}.welcome-button.primary:hover{background-color:var(--primary-color-dark, #1d4ed8)}.welcome-button.secondary{background-color:var(--secondary-color, #4b5563);color:#fff;border:none}.welcome-button.secondary:hover{background-color:var(--secondary-color-dark, #374151)}.welcome-buttons{display:flex;justify-content:center;gap:15px;margin:20px 0}.welcome-note{text-align:center;font-style:italic;color:var(--text-secondary);margin-top:20px}.feature-highlights{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:20px}.feature-highlight{display:flex;align-items:center;gap:10px;padding:12px 16px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:8px;border:1px solid #bae6fd}.feature-icon{font-size:24px}.feature-highlight span:last-child{font-weight:500;color:#0369a1}.tier-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:15px 0}.tier{display:flex;flex-direction:column;align-items:center;padding:16px;background-color:#f9fafb;border-radius:8px;border:1px solid #e5e7eb;text-align:center}.tier strong{color:var(--primary-color, #2563eb);font-size:16px;margin-bottom:4px}.tier span{font-size:13px;color:#6b7280}.tip{background-color:#fef3c7;border-left:3px solid #f59e0b;padding:10px 15px;margin-top:15px;border-radius:0 4px 4px 0;font-size:14px;color:#92400e}.getting-started-list{margin:15px 0;padding-left:25px}.getting-started-list li{margin-bottom:10px;padding-left:5px}@media (max-width: 768px){.welcome-container{padding:20px;width:95%}.shortcuts-grid{grid-template-columns:1fr}.welcome-buttons{flex-direction:column}.welcome-navigation{flex-direction:column;gap:10px}.welcome-button{width:100%;text-align:center}}.help-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out}.help-container{background-color:var(--background-secondary);border-radius:8px;box-shadow:0 4px 20px #0003;width:90%;max-width:800px;max-height:90vh;overflow-y:auto;animation:slideUp .4s ease-out}.help-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border-color, #e0e0e0)}.help-header h2{margin:0;color:var(--primary-color, #2563eb);font-size:1.5rem}.help-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-secondary);width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.help-close:hover{background-color:var(--background-tertiary)}.help-tabs{display:flex;border-bottom:1px solid var(--border-color, #e0e0e0);background-color:var(--background-tertiary)}.help-tab{padding:12px 20px;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:14px;font-weight:500;color:var(--text-secondary);transition:all .3s}.help-tab.active{color:var(--primary-color, #2563eb);border-bottom-color:var(--primary-color, #2563eb);background-color:var(--background-secondary)}.help-tab:hover:not(.active){background-color:var(--gray-100)}.help-content{padding:20px}.shortcuts-section p{margin-top:0;margin-bottom:20px}.shortcuts-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:15px}.shortcut-item{display:flex;align-items:center;padding:10px;border-radius:4px;border:1px solid var(--border-color);background-color:var(--background-tertiary)}.shortcut-keys{display:flex;align-items:center;margin-right:15px}.shortcut-keys kbd{background-color:var(--gray-200);border-radius:3px;border:1px solid var(--gray-300);box-shadow:0 1px 1px #0003;font-size:12px;font-weight:600;padding:3px 6px;color:var(--text-primary)}.shortcut-keys span{margin:0 5px;color:var(--text-tertiary)}.shortcut-description{color:var(--text-secondary);font-size:14px}.faq-item{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border-color)}.faq-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.faq-item h3{margin-top:0;margin-bottom:10px;color:var(--primary-color, #2563eb);font-size:16px}.faq-item p{margin:0;color:var(--text-secondary);line-height:1.6}.faq-item kbd{background-color:var(--gray-200);border-radius:3px;border:1px solid var(--gray-300);box-shadow:0 1px 1px #0003;font-size:12px;font-weight:600;padding:3px 6px;color:var(--text-primary)}.tip-item{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border-color)}.tip-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.tip-item h3{margin-top:0;margin-bottom:10px;color:var(--primary-color, #2563eb);font-size:16px}.tip-item p{margin:0;color:var(--text-secondary);line-height:1.6}.tip-item kbd{background-color:var(--gray-200);border-radius:3px;border:1px solid var(--gray-300);box-shadow:0 1px 1px #0003;font-size:12px;font-weight:600;padding:3px 6px;color:var(--text-primary)}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.help-container{width:95%;max-height:95vh}.help-tabs{overflow-x:auto;white-space:nowrap}.help-tab{padding:12px 15px;font-size:13px}.shortcuts-list{grid-template-columns:1fr}}:root{--spinner-primary: #5DBBE8;--spinner-secondary: rgba(93, 187, 232, .2);--spinner-animation-duration: 1.2s}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;padding:2rem}.loading-spinner-fullscreen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;min-height:400px;width:100%}.loading-spinner-text{margin:0;font-size:1rem;color:#4a5568;font-weight:500;text-align:center}.cloudcafe-spinner{position:relative;display:inline-block}.cloudcafe-spinner-ring{position:absolute;border-radius:50%;border:3px solid transparent;border-top-color:var(--spinner-primary);animation:cloudcafe-spin var(--spinner-animation-duration) cubic-bezier(.68,-.55,.27,1.55) infinite}.cloudcafe-spinner-small{width:32px;height:32px}.cloudcafe-spinner-small .cloudcafe-spinner-ring{width:32px;height:32px;border-width:2px}.cloudcafe-spinner-small .cloudcafe-spinner-ring:nth-child(1){animation-delay:0s}.cloudcafe-spinner-small .cloudcafe-spinner-ring:nth-child(2){width:24px;height:24px;top:4px;left:4px;animation-delay:-.4s;border-top-color:#5dbbe899}.cloudcafe-spinner-small .cloudcafe-spinner-ring:nth-child(3){width:16px;height:16px;top:8px;left:8px;animation-delay:-.8s;border-top-color:#5dbbe84d}.cloudcafe-spinner-medium{width:48px;height:48px}.cloudcafe-spinner-medium .cloudcafe-spinner-ring{width:48px;height:48px;border-width:3px}.cloudcafe-spinner-medium .cloudcafe-spinner-ring:nth-child(1){animation-delay:0s}.cloudcafe-spinner-medium .cloudcafe-spinner-ring:nth-child(2){width:36px;height:36px;top:6px;left:6px;animation-delay:-.4s;border-top-color:#5dbbe899}.cloudcafe-spinner-medium .cloudcafe-spinner-ring:nth-child(3){width:24px;height:24px;top:12px;left:12px;animation-delay:-.8s;border-top-color:#5dbbe84d}.cloudcafe-spinner-large{width:64px;height:64px}.cloudcafe-spinner-large .cloudcafe-spinner-ring{width:64px;height:64px;border-width:4px}.cloudcafe-spinner-large .cloudcafe-spinner-ring:nth-child(1){animation-delay:0s}.cloudcafe-spinner-large .cloudcafe-spinner-ring:nth-child(2){width:48px;height:48px;top:8px;left:8px;animation-delay:-.4s;border-top-color:#5dbbe899}.cloudcafe-spinner-large .cloudcafe-spinner-ring:nth-child(3){width:32px;height:32px;top:16px;left:16px;animation-delay:-.8s;border-top-color:#5dbbe84d}@keyframes cloudcafe-spin{0%{transform:rotate(0);opacity:1}50%{opacity:.8}to{transform:rotate(360deg);opacity:1}}@media (prefers-reduced-motion: reduce){.cloudcafe-spinner-ring{animation-duration:2s}}@media (prefers-color-scheme: dark){:root{--spinner-primary: #5DBBE8;--spinner-secondary: rgba(93, 187, 232, .3)}.loading-spinner-text{color:#cbd5e0}}.invoice-dashboard{padding:var(--space-8);max-width:1400px;margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-8);gap:var(--space-4);flex-wrap:wrap}.dashboard-title h2{margin:0 0 var(--space-1) 0;font-size:var(--font-size-3xl);color:var(--text-primary);font-weight:var(--font-weight-bold);letter-spacing:-.02em;line-height:var(--line-height-tight)}.invoice-count{margin:0;color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.btn-primary{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-base);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-xs)}.btn-primary:hover{background:var(--primary-color-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.dashboard-filters{display:flex;gap:var(--space-4);margin-bottom:var(--space-8);flex-wrap:wrap}.search-input{flex:1;min-width:250px;padding:var(--space-3) var(--space-4);border:2px solid var(--border-color);border-radius:var(--radius-base);font-size:var(--font-size-base);font-family:var(--font-family);color:var(--text-primary);background-color:var(--background-secondary);transition:all var(--transition-base)}.search-input::placeholder{color:var(--text-tertiary)}.search-input:hover{border-color:var(--border-color-dark)}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #5dbbe81a}.status-filter{padding:var(--space-3) var(--space-4);border:2px solid var(--border-color);border-radius:var(--radius-base);font-size:var(--font-size-base);font-family:var(--font-family);background:var(--background-secondary);color:var(--text-primary);cursor:pointer;min-width:180px;transition:all var(--transition-base);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236B7280' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-8)}.status-filter:hover{border-color:var(--border-color-dark)}.status-filter:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #5dbbe81a}.archive-toggle{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--background-secondary);border:2px solid var(--border-color);border-radius:var(--radius-base);cursor:pointer;-webkit-user-select:none;user-select:none;transition:all var(--transition-base)}.archive-toggle:hover{border-color:var(--border-color-dark);background:var(--background-hover)}.archive-toggle input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--primary-color)}.archive-toggle span{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-primary);white-space:nowrap}.loading-state{text-align:center;padding:var(--space-16) var(--space-4);color:var(--text-secondary);font-size:var(--font-size-lg)}.loading-state svg{animation:spin 1s linear infinite;color:var(--primary-color);margin-bottom:var(--space-4)}.error-message{padding:var(--space-4) var(--space-5);background:var(--error-color-light);color:var(--error-color);border-radius:var(--radius-base);margin-bottom:var(--space-6);border:1px solid var(--error-color);border-left-width:4px;display:flex;align-items:center;gap:var(--space-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.error-message:before{content:"⚠";font-size:var(--font-size-xl);flex-shrink:0}.empty-state{text-align:center;padding:var(--space-16) var(--space-4);background:var(--background-tertiary);border-radius:var(--radius-lg);border:2px dashed var(--border-color)}.empty-state svg{color:var(--gray-300);margin-bottom:var(--space-5)}.empty-state h3{margin:0 0 var(--space-3) 0;font-size:var(--font-size-2xl);color:var(--text-primary);font-weight:var(--font-weight-semibold)}.empty-state p{margin:0 0 var(--space-6) 0;color:var(--text-secondary);font-size:var(--font-size-base);line-height:var(--line-height-relaxed)}.invoice-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:var(--space-6)}.invoice-card{background:var(--background-secondary);border:2px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-5);transition:all var(--transition-base);cursor:pointer;position:relative}.invoice-card:hover{border-color:var(--border-color-dark);box-shadow:var(--shadow-md);transform:translateY(-2px)}.invoice-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:2px solid var(--border-color-light)}.invoice-card-header h3{margin:0;font-size:var(--font-size-lg);color:var(--text-primary);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight)}.status-badge{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.status-dropdown{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;cursor:pointer;transition:all var(--transition-base);position:relative;padding-right:24px}.status-dropdown:hover{opacity:.9}.status-dropdown:focus{outline:none;box-shadow:0 0 0 3px #5dbbe833}.status-dropdown:after{content:"▼";position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:8px;pointer-events:none;opacity:.7}.status-draft{background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-300)}.status-sent{background:var(--info-color-light);color:#1d4ed8;border:1px solid #93C5FD}.status-paid{background:var(--success-color-light);color:#047857;border:1px solid #6EE7B7}.status-overdue{background:var(--error-color-light);color:#b91c1c;border:1px solid #FCA5A5}.status-cancelled{background:var(--gray-100);color:var(--gray-600);border:1px solid var(--gray-300);text-decoration:line-through}.invoice-card-details{margin-bottom:var(--space-5)}.detail-row{display:flex;justify-content:space-between;padding:var(--space-3) 0;font-size:var(--font-size-sm)}.detail-label{color:var(--text-secondary);font-weight:var(--font-weight-medium)}.detail-value{color:var(--text-primary);font-weight:var(--font-weight-semibold)}.total-row{margin-top:var(--space-3);padding-top:var(--space-4);border-top:2px solid var(--border-color-light)}.total-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--primary-color)}.invoice-card-actions{display:flex;gap:var(--space-2)}.btn-action{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:2px solid var(--border-color);border-radius:var(--radius-base);background:var(--background-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base);color:var(--text-primary)}.btn-action:hover{background:var(--background-tertiary);border-color:var(--border-color-dark)}.btn-action svg{flex-shrink:0}.btn-edit{color:var(--primary-color);border-color:var(--primary-color)}.btn-edit:hover{background:#5dbbe81a;border-color:var(--primary-color-dark)}.btn-delete{color:var(--error-color);border-color:var(--error-color)}.btn-delete:hover{background:var(--error-color-light);border-color:#dc2626}.btn-archive{color:#8b5cf6;border-color:#8b5cf6}.btn-archive:hover{background:#8b5cf61a;border-color:#7c3aed}.btn-unarchive{color:#059669;border-color:#059669}.btn-unarchive:hover{background:#0596691a;border-color:#047857}.btn-confirm-delete{background:var(--error-color);color:#fff;border-color:var(--error-color)}.btn-confirm-delete:hover{background:#dc2626;border-color:#b91c1c;box-shadow:var(--shadow-sm)}.btn-cancel{color:var(--text-secondary);border-color:var(--border-color-dark)}.btn-cancel:hover{background:var(--gray-100);border-color:var(--gray-400)}.btn-danger-corner{position:absolute;bottom:var(--space-5);right:var(--space-5);display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:#fff;border:2px solid var(--error-color);border-radius:var(--radius-base);color:var(--error-color);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-xs)}.btn-danger-corner:hover{background:var(--error-color);color:#fff;transform:scale(1.05);box-shadow:var(--shadow-sm)}.btn-danger-corner svg{flex-shrink:0}.delete-confirm-corner{position:absolute;bottom:var(--space-5);right:var(--space-5);display:flex;align-items:center;gap:var(--space-2);background:#fff;padding:var(--space-2) var(--space-3);border-radius:var(--radius-base);box-shadow:var(--shadow-md);border:2px solid var(--error-color);z-index:10}.delete-confirm-corner span{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-primary);white-space:nowrap}.btn-danger-small,.btn-secondary-small{padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base);border:1px solid;white-space:nowrap}.btn-danger-small{background:var(--error-color);color:#fff;border-color:var(--error-color)}.btn-danger-small:hover{background:#dc2626;border-color:#b91c1c}.btn-secondary-small{background:#fff;color:var(--text-secondary);border-color:var(--border-color-dark)}.btn-secondary-small:hover{background:var(--gray-100);border-color:var(--gray-400)}@media (max-width: 1024px){.invoice-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}@media (max-width: 768px){.invoice-dashboard{padding:var(--space-4)}.dashboard-header{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.dashboard-title h2{font-size:var(--font-size-2xl)}.btn-primary{width:100%;justify-content:center}.dashboard-filters{flex-direction:column;width:100%}.search-input,.status-filter{width:100%}.invoice-grid{grid-template-columns:1fr}.invoice-card-actions{flex-direction:column}.btn-action{width:100%}}@media (max-width: 480px){.dashboard-title h2{font-size:var(--font-size-xl)}.invoice-card{padding:var(--space-4)}}.theme-selector{position:relative;width:100%;max-width:400px}.theme-selector-trigger{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease}.theme-selector-trigger:hover{border-color:#d1d5db}.theme-selector-trigger.open{border-color:#5dbbe8;box-shadow:0 0 0 3px #5dbbe81a}.theme-selector-value{flex:1;display:flex;align-items:center}.selected-theme{display:flex;align-items:center;gap:10px}.theme-color-preview{display:flex;gap:4px}.color-dot{width:16px;height:16px;border-radius:50%;border:1px solid rgba(0,0,0,.1)}.theme-name{font-size:14px;color:#1f2937;font-weight:500}.placeholder{font-size:14px;color:#9ca3af}.theme-selector-actions{display:flex;align-items:center;gap:8px}.clear-btn{background:none;border:none;padding:4px;cursor:pointer;color:#9ca3af;display:flex;align-items:center;justify-content:center;transition:color .2s}.clear-btn:hover{color:#6b7280}.dropdown-icon{color:#9ca3af;transition:transform .2s}.theme-selector-trigger.open .dropdown-icon{transform:rotate(180deg)}.theme-selector-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a;z-index:100;max-height:400px;overflow:hidden;animation:slideDown .2s ease}.theme-selector-search{padding:12px;border-bottom:1px solid #e5e7eb}.theme-selector-search .search-input{width:100%;padding:8px 12px;border:1px solid #e5e7eb;border-radius:6px;font-size:14px}.theme-selector-search .search-input:focus{outline:none;border-color:#5dbbe8}.theme-selector-options{max-height:280px;overflow-y:auto}.theme-section-label{padding:8px 12px;font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;background:#f9fafb;border-bottom:1px solid #e5e7eb}.theme-option{padding:10px 12px;cursor:pointer;transition:background-color .2s;border-bottom:1px solid transparent}.theme-option:hover{background:#f9fafb}.theme-option.selected{background:#eff6ff}.theme-option-content{display:flex;align-items:center;gap:10px}.theme-option-name{font-size:14px;color:#1f2937}.theme-option-type{font-size:12px;color:#9ca3af;margin-left:auto}.theme-selector-footer{padding:12px;border-top:1px solid #e5e7eb;background:#f9fafb}.manage-themes-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;font-size:14px;color:#374151;cursor:pointer;transition:all .2s}.manage-themes-btn:hover{background:#f9fafb;border-color:#d1d5db}.theme-selector-options::-webkit-scrollbar{width:6px}.theme-selector-options::-webkit-scrollbar-track{background:#f9fafb}.theme-selector-options::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.theme-selector-options::-webkit-scrollbar-thumb:hover{background:#9ca3af}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.theme-selector{max-width:100%}.theme-selector-dropdown{position:fixed;top:auto;bottom:0;left:0;right:0;border-radius:16px 16px 0 0;max-height:70vh;animation:slideUp .3s ease}.theme-selector-options{max-height:50vh}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.invoice-numbering-config{padding:20px;background:#f9f9f9;border-radius:8px;margin-bottom:20px}.invoice-numbering-config h3{margin-top:0;margin-bottom:20px;font-size:1.2rem;color:#333}.invoice-numbering-config .form-group{margin-bottom:16px}.invoice-numbering-config .form-group label{display:block;margin-bottom:6px;font-weight:500;color:var(--text-secondary);font-size:.9rem}.invoice-numbering-config .help-text{display:block;font-size:.75rem;color:#888;font-weight:400;margin-top:4px}.invoice-numbering-config input[type=text],.invoice-numbering-config input[type=number],.invoice-numbering-config select{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:.9rem;transition:border-color .2s}.invoice-numbering-config input[type=text]:focus,.invoice-numbering-config input[type=number]:focus,.invoice-numbering-config select:focus{outline:none;border-color:#5dbbe8;box-shadow:0 0 0 3px #5dbbe81a}.invoice-numbering-config .form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.invoice-numbering-config .preview-section{margin-top:24px;padding:16px;background:#fff;border-radius:6px;border:2px solid #5DBBE8}.invoice-numbering-config .preview-section label{display:block;margin-bottom:8px;font-weight:600;color:#5dbbe8;font-size:.9rem}.invoice-numbering-config .preview-number{text-align:center;margin:16px 0}.invoice-numbering-config .preview-number .number{display:inline-block;font-size:1.5rem;font-weight:700;color:#333;padding:8px 16px;background:#f0f9ff;border-radius:4px}.invoice-numbering-config .preview-number .loading{display:inline-block;font-size:1rem;color:#888;font-style:italic}.invoice-numbering-config .preview-help{text-align:center;font-size:.8rem;color:var(--text-secondary);margin:8px 0 0}@media (max-width: 768px){.invoice-numbering-config{padding:16px}.invoice-numbering-config h3{font-size:1.1rem}.invoice-numbering-config .form-row{grid-template-columns:1fr}.invoice-numbering-config .preview-number .number{font-size:1.2rem}}.template-manager{padding:20px;max-width:1400px;margin:0 auto}.template-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid #e5e7eb}.template-manager-header h2{margin:0;font-size:28px;color:#1f2937}.template-manager-header .subtitle{margin:5px 0 0;color:#6b7280;font-size:14px}.header-actions{display:flex;gap:10px}.template-controls{display:flex;gap:15px;margin-bottom:30px;align-items:stretch}.template-controls .search-input{flex:1;max-width:400px;height:44px!important}.template-controls .category-filter{background:#fff}.view-toggle{display:flex;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;box-sizing:border-box;height:44px}.view-btn{padding:0 12px;background:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#6b7280;transition:all .2s;height:100%}.view-btn:not(:last-child){border-right:1px solid #e5e7eb}.view-btn.active{background:#5dbbe8;color:#fff}.view-btn:hover:not(.active){background:#f9fafb}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.template-grid .template-item{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;transition:all .2s ease}.template-grid .template-item:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.template-list{display:flex;flex-direction:column;gap:12px}.template-list .template-item{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px 20px;transition:all .2s ease}.template-list .template-item:hover{background:#f9fafb;border-color:#d1d5db}.template-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.template-name{margin:0;font-size:18px;font-weight:600;color:#1f2937}.template-category{display:inline-block;margin-top:4px;padding:3px 8px;background:#eff6ff;color:#2563eb;border-radius:4px;font-size:12px}.template-description{margin:10px 0;color:#6b7280;font-size:14px;line-height:1.5}.template-meta{display:flex;gap:15px;margin-top:12px}.meta-item{display:flex;align-items:center;gap:5px;color:#9ca3af;font-size:13px}.template-actions{display:flex;gap:8px}.action-btn{padding:6px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;color:#6b7280;transition:all .2s}.action-btn:hover{background:#f9fafb;color:#374151;border-color:#d1d5db}.action-btn.danger:hover{background:#fef2f2;color:#dc2626;border-color:#fecaca}.delete-confirm{display:flex;gap:5px}.template-editor-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.template-editor{background:#fff;border-radius:12px;width:90%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease}.form-section{margin-bottom:30px}.form-section h4{margin:0 0 15px;font-size:16px;font-weight:600;color:#374151}.form-group{margin-bottom:15px}.form-group input[type=text],.form-group input[type=number],.form-group select,.form-group textarea{width:100%;padding:8px 12px;border:1px solid #e5e7eb;border-radius:6px;font-size:14px}.form-group textarea{resize:vertical;font-family:inherit}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.editor-footer{padding:20px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;align-items:center;gap:10px}.error-inline{flex:1;color:#dc2626;font-size:14px}.empty-state{text-align:center;padding:80px 20px;color:#6b7280}.empty-state svg{margin-bottom:20px;color:#d1d5db}.empty-state h3{margin:0 0 10px;font-size:20px;color:#374151}.empty-state p{margin:0 0 20px;font-size:14px}.btn-secondary{background:#fff;color:#374151;border:1px solid #e5e7eb;padding:10px 20px;border-radius:6px;font-size:14px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all .2s}.template-invoice-preview{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:40px;box-shadow:0 1px 3px #0000001a}.preview-invoice-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:40px;padding-bottom:24px;border-bottom:2px solid #e5e7eb;gap:24px}.preview-invoice-business{flex:1}.preview-invoice-business h2{margin:0 0 12px;font-size:24px;font-weight:700;color:#1f2937}.preview-invoice-business p{margin:6px 0;font-size:14px;color:#6b7280;line-height:1.5}.preview-invoice-info h1{margin:0 0 16px;font-size:32px;font-weight:700;color:#5dbbe8;letter-spacing:-.02em}.preview-invoice-info p{margin:6px 0;font-size:14px;color:#6b7280}.preview-invoice-info strong{color:#374151;font-weight:600}.preview-invoice-items{margin-bottom:32px}.preview-invoice-items table{width:100%;border-collapse:collapse;font-size:14px}.preview-invoice-items thead{background:#f9fafb;border-top:2px solid #5DBBE8;border-bottom:2px solid #e5e7eb}.preview-invoice-items th{padding:12px;text-align:left;font-weight:600;color:#374151;font-size:13px;text-transform:uppercase;letter-spacing:.05em}.preview-invoice-items th:last-child,.preview-invoice-items td:last-child{text-align:right}.preview-invoice-items tbody tr{border-bottom:1px solid #e5e7eb}.preview-invoice-items td{padding:16px 12px;color:#1f2937}.preview-invoice-totals{display:flex;flex-direction:column;align-items:flex-end;margin-bottom:32px;padding-top:16px;border-top:1px solid #e5e7eb}.totals-row{display:flex;justify-content:space-between;width:300px;max-width:100%;padding:8px 0;font-size:14px;color:#374151}.totals-row.total{margin-top:8px;padding-top:12px;border-top:2px solid #5DBBE8;font-size:18px;font-weight:700;color:#1f2937}.preview-invoice-section{margin-bottom:24px;padding:16px;background:#f9fafb;border-radius:6px}.preview-invoice-section h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.05em}.preview-invoice-section p{margin:0;font-size:14px;color:#6b7280;line-height:1.6;white-space:pre-wrap}@media (max-width: 768px){.template-manager{padding:15px}.template-manager-header{flex-direction:column;align-items:flex-start;gap:15px}.header-actions{width:100%;flex-direction:column}.header-actions button{width:100%}.template-controls{flex-direction:column;width:100%}.template-controls .search-input,.template-controls .category-filter{max-width:none;width:100%}.template-grid{grid-template-columns:1fr}.template-editor{width:95%;max-height:95vh;margin:10px}.form-row{grid-template-columns:1fr}.editor-footer{flex-direction:column;gap:10px}.editor-footer button{width:100%}.error-inline{text-align:center}}.theme-manager{padding:20px;max-width:1400px;margin:0 auto}.theme-editor-header{margin-bottom:20px}.theme-editor-header .back-btn{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #e5e7eb;padding:10px 16px;border-radius:6px;font-size:14px;color:#374151;cursor:pointer;transition:all .2s}.theme-editor-header .back-btn:hover{background:#f9fafb;border-color:#d1d5db}.theme-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid #e5e7eb}.theme-manager-header h2{margin:0;font-size:28px;color:#1f2937}.theme-manager-header .subtitle{margin:5px 0 0;color:#6b7280;font-size:14px}.theme-search{margin-bottom:30px}.theme-search .search-input{width:100%;max-width:400px;padding:10px 15px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px}.theme-search .search-input:focus{outline:none;border-color:#5dbbe8;box-shadow:0 0 0 3px #5dbbe81a}.theme-sections{margin-top:30px}.theme-section{margin-bottom:40px}.theme-section h3{font-size:20px;margin-bottom:20px;color:#1f2937}.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.theme-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;transition:all .2s ease}.theme-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.theme-card.selected{border-color:#5dbbe8;box-shadow:0 0 0 3px #5dbbe81a}.theme-card.compact{display:flex;flex-direction:column;padding:16px}.theme-card.compact .theme-info{padding:0;flex:1;margin-bottom:12px}.theme-card.compact .theme-actions{padding:0;flex-direction:column}.theme-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.theme-color-swatch{width:32px;height:32px;border-radius:6px;border:2px solid #e5e7eb;flex-shrink:0;transition:transform .2s}.theme-color-swatch:hover{transform:scale(1.1)}.theme-color-swatches{display:flex;gap:6px}.theme-color-swatches .theme-color-swatch{width:24px;height:24px}.theme-header h4{margin:0;font-size:16px;color:#1f2937;font-weight:600}.theme-description{margin:0;font-size:13px;color:#6b7280;line-height:1.5}.theme-meta{margin-top:6px}.theme-font{font-size:12px;color:#6b7280;font-style:italic}.btn-block{width:100%}.theme-preview{height:160px;background:#f9fafb;padding:15px;display:flex;flex-direction:column}.preview-header{height:30px;background:#2563eb;border-radius:4px 4px 0 0;display:flex;align-items:center;padding:0 10px}.preview-logo{width:20px;height:20px;background:#fff;border-radius:3px;opacity:.9}.preview-body{flex:1;background:#fff;padding:10px;border-radius:0 0 4px 4px}.preview-line{height:8px;background:#1f2937;border-radius:2px;margin-bottom:6px;opacity:.2}.preview-line.short{width:60%}.preview-table{margin-top:10px}.preview-row{height:20px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:2px;margin-bottom:4px}.theme-info{padding:15px}.theme-info h4{margin:0 0 5px;font-size:16px;color:#1f2937}.theme-info p{margin:0;font-size:13px;color:#6b7280}.theme-actions{padding:0 15px 15px;display:flex;gap:10px}.theme-actions button{flex:1}.delete-confirm{display:flex;gap:5px;flex:1}.theme-editor-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.theme-editor{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .3s ease}.editor-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e5e7eb}.editor-header h3{margin:0;font-size:20px}.close-btn{background:none;border:none;cursor:pointer;color:#6b7280;padding:5px}.editor-body{flex:1;padding:20px;overflow-y:auto}.form-group label{display:block;margin-bottom:5px;font-size:14px;font-weight:500;color:#374151}.form-group input[type=text]{width:100%;padding:8px 12px;border:1px solid #e5e7eb;border-radius:6px;font-size:14px}.color-section{margin-bottom:25px}.color-section h4{margin-bottom:15px;font-size:16px;color:#1f2937}.color-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:15px}.color-input{display:flex;flex-direction:column}.color-input label{margin-bottom:5px;font-size:13px;color:#6b7280}.color-input input[type=color]{width:100%;height:40px;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer}.preset-section{margin-bottom:20px}.preset-section h4{margin-bottom:10px;font-size:16px;color:#1f2937}.preset-buttons{display:flex;gap:10px}.editor-footer{padding:20px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:10px}.btn-primary{background:#5dbbe8;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:14px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:background-color .2s}.btn-secondary{background:#fff;color:#374151;border:1px solid #e5e7eb;padding:8px 16px;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s}.btn-ghost{background:none;color:#6b7280;border:none;padding:8px 16px;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s}.btn-ghost:hover{background:#f9fafb;color:#374151}.btn-danger-small{background:#ef4444;color:#fff;border:none;padding:6px 12px;border-radius:4px;font-size:13px;cursor:pointer}.btn-ghost-small{background:none;color:#6b7280;border:1px solid #e5e7eb;padding:6px 12px;border-radius:4px;font-size:13px;cursor:pointer}.loading-state{text-align:center;padding:40px;color:#6b7280}.empty-state{text-align:center;padding:60px 20px;color:#6b7280}.error-message{background:#fef2f2;color:#991b1b;padding:12px 16px;border-radius:8px;margin-bottom:20px;border:1px solid #fecaca}.success-message{position:fixed;top:20px;right:20px;background:#10b981;color:#fff;padding:12px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1001;animation:slideInRight .3s ease}@keyframes slideInRight{0%{transform:translate(100px);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.theme-manager{padding:15px}.theme-manager-header{flex-direction:column;align-items:flex-start;gap:15px}.theme-grid{grid-template-columns:1fr}.theme-card.compact{padding:14px}.theme-header{gap:10px}.theme-color-swatch{width:28px;height:28px}.theme-color-swatches .theme-color-swatch{width:20px;height:20px}.theme-editor{width:95%;max-height:90vh}.color-grid{grid-template-columns:repeat(2,1fr)}.preset-buttons{flex-direction:column}.preset-buttons button{width:100%}}.wizard-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.wizard-container{background:#fff;border-radius:16px;width:90%;max-width:900px;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .3s ease}.wizard-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e5e7eb}.wizard-header h2{margin:0;font-size:24px;color:#1f2937}.close-btn{background:none;border:none;cursor:pointer;color:#6b7280;padding:5px;transition:color .2s}.close-btn:hover{color:#1f2937}.wizard-content{flex:1;padding:24px;overflow-y:auto}.wizard-subtitle{margin:0 0 30px;font-size:16px;color:#6b7280;text-align:center}.creation-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:40px}.option-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:30px 20px;text-align:center;cursor:pointer;transition:all .2s ease}.option-card:hover{border-color:#5dbbe8;transform:translateY(-2px);box-shadow:0 8px 16px #0000001a}.option-icon{display:flex;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 20px;background:#eff6ff;border-radius:50%;color:#5dbbe8}.option-card h3{margin:0 0 8px;font-size:18px;font-weight:600;color:#1f2937}.option-card p{margin:0 0 20px;font-size:14px;color:#6b7280;min-height:40px}.option-btn{background:#5dbbe8;color:#fff;border:none;padding:10px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.option-btn:hover{background:#4da9d6}.theme-selection{padding:30px;background:#f9fafb;border-radius:12px}.theme-selection h4{margin:0 0 15px;font-size:16px;font-weight:600;color:#374151}.step-header{display:flex;align-items:center;gap:15px;margin-bottom:20px}.back-btn{background:none;border:none;cursor:pointer;padding:8px;color:#6b7280;display:flex;align-items:center;gap:5px;transition:color .2s}.back-btn:hover{color:#374151}.step-header h3{margin:0;font-size:20px;color:#1f2937}.search-input{width:100%;padding:12px 16px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;margin-bottom:20px}.search-input:focus{outline:none;border-color:#5dbbe8;box-shadow:0 0 0 3px #5dbbe81a}.template-list,.invoice-list{max-height:400px;overflow-y:auto;margin-bottom:20px}.template-option,.invoice-option{display:flex;align-items:center;padding:16px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:10px;cursor:pointer;transition:all .2s}.template-option:hover,.invoice-option:hover{background:#f9fafb;border-color:#d1d5db}.template-option.selected,.invoice-option.selected{background:#eff6ff;border-color:#5dbbe8}.template-info,.invoice-info{flex:1}.template-info h4,.invoice-info h4{margin:0 0 4px;font-size:16px;font-weight:600;color:#1f2937}.template-info p,.invoice-info p{margin:0 0 8px;font-size:14px;color:#6b7280}.template-details,.invoice-details{display:flex;gap:12px;flex-wrap:wrap}.template-details span,.invoice-details span{font-size:12px;padding:2px 8px;background:#f3f4f6;color:#6b7280;border-radius:4px}.status{font-weight:500}.status-draft{background:#fef3c7;color:#92400e}.status-sent{background:#dbeafe;color:#1e40af}.status-paid{background:#d1fae5;color:#065f46}.status-overdue{background:#fee2e2;color:#991b1b}.template-select,.invoice-select{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:#10b981;color:#fff}.empty-message{text-align:center;padding:40px;color:#6b7280}.empty-message p{margin-bottom:20px}.wizard-footer{display:flex;justify-content:flex-end;gap:10px;padding:20px 0 0;border-top:1px solid #e5e7eb}.btn-primary{background:#5dbbe8;color:#fff;border:none;padding:10px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-primary:hover:not(:disabled){background:#4da9d6}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#fff;color:#374151;border:1px solid #e5e7eb;padding:10px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#f9fafb;border-color:#d1d5db}.template-list::-webkit-scrollbar,.invoice-list::-webkit-scrollbar{width:6px}.template-list::-webkit-scrollbar-track,.invoice-list::-webkit-scrollbar-track{background:#f9fafb}.template-list::-webkit-scrollbar-thumb,.invoice-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.template-list::-webkit-scrollbar-thumb:hover,.invoice-list::-webkit-scrollbar-thumb:hover{background:#9ca3af}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.wizard-container{width:100%;max-width:none;max-height:100vh;border-radius:0}.creation-options{grid-template-columns:1fr}.option-card{padding:20px}.option-icon{width:60px;height:60px}.wizard-footer{flex-direction:column-reverse}.wizard-footer button{width:100%}.template-list,.invoice-list{max-height:50vh}}.billing-dashboard{max-width:1200px;margin:0 auto;padding:2rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.billing-dashboard h2{color:#1a202c;margin-bottom:2rem;font-size:2rem;font-weight:700}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:400px;gap:1.5rem}.loading-text{font-size:1.1rem;color:#4a5568;font-weight:500;margin:0}.loading-spinner{display:flex;justify-content:center;align-items:center;height:200px;font-size:1.1rem;color:#4a5568}.error-message{background:#fed7d7;border:1px solid #feb2b2;color:#c53030;padding:1rem;border-radius:8px;text-align:center}.retry-button{background:#3182ce;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;margin-left:1rem;cursor:pointer;font-weight:500}.retry-button:hover{background:#2c5282}.current-plan-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a}.current-plan-card h3{color:#2d3748;margin-bottom:1rem;font-size:1.25rem;font-weight:600}.plan-info{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.plan-name{font-size:1.5rem;font-weight:700;color:#1a202c}.plan-price{background:#e6fffa;color:#00a386;padding:.25rem .75rem;border-radius:20px;font-weight:600;font-size:.9rem}.plan-status{color:#4a5568;font-weight:500;text-transform:capitalize}.billing-cycle{color:#718096;margin-bottom:1rem;font-size:.9rem}.plan-features ul{list-style:none;padding:0;margin:.5rem 0}.plan-features li{padding:.25rem 0;color:#4a5568}.plan-features li:before{content:"✓";color:#38a169;margin-right:.5rem;font-weight:700}.usage-stats-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a}.usage-stats-card h3{color:#2d3748;margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.billing-period{color:#718096;font-size:.9rem;margin-bottom:1.5rem;font-weight:500}.usage-item{margin-bottom:1.5rem}.usage-label{font-weight:600;color:#4a5568;margin-bottom:.5rem}.usage-bar{width:100%;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.usage-progress{height:100%;background:linear-gradient(90deg,#38a169,#68d391);transition:width .3s ease}.usage-text{font-size:.9rem;color:#718096;font-weight:500}.usage-warning{background:#fef5e7;border:1px solid #fbd38d;color:#c05621;padding:1rem;border-radius:8px;margin-top:1rem;font-weight:500}.billing-actions{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:2rem;box-shadow:0 1px 3px #0000001a}.upgrade-section h3{color:#2d3748;margin-bottom:1.5rem;font-size:1.25rem;font-weight:600}.plan-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;margin-top:1rem;max-width:1200px}@media (min-width: 1024px){.plan-options{grid-template-columns:repeat(4,1fr)}}@media (max-width: 1023px) and (min-width: 640px){.plan-options{grid-template-columns:repeat(2,1fr)}}.plan-option{border:2px solid #e2e8f0;border-radius:12px;padding:1.5rem;position:relative;transition:all .3s ease}.plan-option:hover{border-color:#3182ce;box-shadow:0 4px 12px #3182ce26}.plan-option.premium{border-color:#805ad5;background:linear-gradient(135deg,#f7fafc,#edf2f7)}.plan-option.premium:hover{border-color:#6b46c1;box-shadow:0 4px 12px #6b46c133}.plan-option.unlimited{border-color:#d69e2e;background:linear-gradient(135deg,#fef5e7,#faf089 10%,#fff5e6);position:relative}.plan-option.unlimited:before{content:"Best Value";position:absolute;top:-10px;right:20px;background:linear-gradient(135deg,#d69e2e,#f6ad55);color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 8px #d69e2e4d}.plan-option.unlimited:hover{border-color:#b7791f;box-shadow:0 4px 12px #d69e2e4d}.premium-option{border-color:#805ad5;background:linear-gradient(135deg,#f7fafc,#edf2f7)}.premium-option:hover{border-color:#6b46c1;box-shadow:0 4px 12px #6b46c133}.most-popular{position:absolute;top:-10px;right:20px;background:#805ad5;color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.plan-option h4{font-size:1.25rem;font-weight:700;color:#1a202c;margin-bottom:.5rem}.plan-option .plan-price{font-size:1.5rem;font-weight:700;color:#2d3748;margin-bottom:1rem;background:none;padding:0}.plan-option ul{list-style:none;padding:0;margin:1rem 0}.plan-option li{padding:.5rem 0;color:#4a5568;border-bottom:1px solid #edf2f7}.plan-option li:before{content:"✓";color:#38a169;margin-right:.75rem;font-weight:700}.upgrade-button{width:100%;padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s ease;margin-top:1rem}.upgrade-button.basic{background:#3182ce;color:#fff}.upgrade-button.basic:hover:not(:disabled){background:#2c5282;transform:translateY(-2px)}.upgrade-button.premium{background:linear-gradient(135deg,#805ad5,#9f7aea);color:#fff}.upgrade-button.premium:hover:not(:disabled){background:linear-gradient(135deg,#6b46c1,#805ad5);transform:translateY(-2px)}.upgrade-button.unlimited{background:linear-gradient(135deg,#d69e2e,#f6ad55);color:#fff;font-size:1.1rem;padding:1rem 1.5rem;box-shadow:0 4px 12px #d69e2e4d}.upgrade-button.unlimited:hover:not(:disabled){background:linear-gradient(135deg,#b7791f,#d69e2e);transform:translateY(-2px);box-shadow:0 6px 16px #d69e2e66}.upgrade-button:disabled{opacity:.6;cursor:not-allowed}.manage-section{text-align:center}.manage-button{background:#3182ce;color:#fff;border:none;padding:.75rem 2rem;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s ease;margin-bottom:1rem}.manage-button:hover:not(:disabled){background:#2c5282;transform:translateY(-2px)}.manage-button:disabled{opacity:.6;cursor:not-allowed}.manage-section p{color:#718096;margin:0}@media (max-width: 768px){.billing-dashboard{padding:1rem}.plan-info{flex-direction:column;align-items:flex-start;gap:.5rem}.plan-options{grid-template-columns:1fr}}.overview-cards-container{width:100%}.overview-cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5);margin-bottom:var(--space-6)}.overview-card{background-color:var(--background-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-6);transition:all var(--transition-base);cursor:default;position:relative;overflow:hidden}.overview-card:not(.error-card):not(.skeleton-card):hover{border-color:var(--primary-color);box-shadow:0 4px 12px #5dbbe81a;transform:translateY(-2px)}.card-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.card-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);flex-shrink:0}.revenue-icon{background-color:#10b9811a;color:#10b981}.invoices-icon{background-color:#3b82f61a;color:#3b82f6}.quotes-icon{background-color:#8b5cf61a;color:#8b5cf6}.customers-icon{background-color:#f973161a;color:#f97316}.card-icon svg{width:24px;height:24px}.card-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.card-value{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:var(--space-2);line-height:1.1;word-break:break-word}.card-subtitle{font-size:var(--font-size-sm);color:var(--text-tertiary);line-height:var(--line-height-normal)}.skeleton-card{border:none;background:linear-gradient(90deg,var(--gray-100) 25%,var(--gray-50) 50%,var(--gray-100) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;pointer-events:none}.skeleton-icon{width:40px;height:40px;border-radius:var(--radius-md);background-color:var(--gray-200)}.skeleton-title{width:100px;height:14px;background-color:var(--gray-200);border-radius:var(--radius-sm)}.skeleton-value{width:100%;height:36px;background-color:var(--gray-200);border-radius:var(--radius-sm);margin-top:var(--space-4);margin-bottom:var(--space-3)}.skeleton-subtitle{width:60%;height:14px;background-color:var(--gray-200);border-radius:var(--radius-sm)}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.error-card{display:flex;align-items:center;justify-content:center;grid-column:1 / -1;min-height:200px;background-color:var(--error-color-light);border-color:var(--error-color);padding:var(--space-8)}.error-content{text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.error-icon{width:48px;height:48px;color:var(--error-color)}.error-card h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--error-color);margin:0}.error-card p{color:var(--text-secondary);margin:0;max-width:400px}.retry-button{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background-color:var(--error-color);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base);margin-top:var(--space-2)}.retry-button:hover{background-color:#dc2626;transform:translateY(-2px)}.retry-button svg{width:16px;height:16px}.overview-cards-debug{margin-top:var(--space-8);padding:var(--space-4);background-color:var(--gray-50);border:1px solid var(--border-color);border-radius:var(--radius-base)}.overview-cards-debug summary{cursor:pointer;font-weight:var(--font-weight-medium);color:var(--text-secondary);-webkit-user-select:none;user-select:none;padding:var(--space-2);border-radius:var(--radius-sm);transition:background-color var(--transition-base)}.overview-cards-debug summary:hover{background-color:var(--gray-100)}.overview-cards-debug pre{margin-top:var(--space-3);padding:var(--space-3);background-color:var(--background-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow-x:auto;font-size:var(--font-size-xs);line-height:var(--line-height-normal)}@media (max-width: 1024px){.overview-cards-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-4)}}@media (max-width: 768px){.overview-cards-grid{grid-template-columns:1fr;gap:var(--space-4)}.overview-card{padding:var(--space-5)}.card-value{font-size:var(--font-size-3xl)}.card-title,.card-subtitle{font-size:var(--font-size-xs)}.error-card{padding:var(--space-5)}}@media (max-width: 480px){.overview-cards-grid{gap:var(--space-3)}.overview-card{padding:var(--space-4)}.card-value{font-size:var(--font-size-2xl)}.card-icon{width:36px;height:36px}.card-icon svg{width:20px;height:20px}}@media (prefers-reduced-motion: reduce){.overview-card,.overview-card:not(.error-card):not(.skeleton-card):hover,.retry-button{transition:none;transform:none}.skeleton-card{animation:none;background:var(--gray-100)}}@media (prefers-color-scheme: dark){.overview-card{background-color:var(--background-secondary);border-color:var(--border-color)}.skeleton-card{background-color:var(--gray-700)}}.revenue-chart-container{width:100%;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.revenue-chart-wrapper{width:100%;height:100%}.revenue-chart-loading{display:flex;flex-direction:column;justify-content:center;align-items:center;height:400px;gap:1.5rem}.loading-skeleton{width:100%;display:flex;flex-direction:column;gap:1rem;padding:2rem 1rem}.skeleton-bar{height:12px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;border-radius:4px;animation:loading 1.5s infinite}.loading-text{font-size:1rem;color:#6b7280;font-weight:500;margin:0;text-align:center}.revenue-chart-error{display:flex;flex-direction:column;justify-content:center;align-items:center;height:400px;gap:1rem;padding:2rem;text-align:center}.error-icon{display:flex;justify-content:center;align-items:center;width:64px;height:64px;background:#fee2e2;border:2px solid #fecaca;border-radius:50%;font-size:2rem;font-weight:700;color:#dc2626}.error-message{font-size:1rem;color:#7f1d1d;background:#fee2e2;border:1px solid #fecaca;padding:1rem;border-radius:6px;margin:0;max-width:500px}.retry-button{padding:.5rem 1.5rem;background:#5dbbe8;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s ease-in-out}.retry-button:hover{background:#4b9bc7}.retry-button:active{transform:scale(.98)}.revenue-chart-empty{display:flex;justify-content:center;align-items:center;height:400px;padding:2rem}.empty-message{font-size:1rem;color:#9ca3af;text-align:center;margin:0}.revenue-chart-tooltip{background:#000000e6;color:#fff;padding:.75rem 1rem;border-radius:6px;font-size:.875rem;border:1px solid #5DBBE8;box-shadow:0 4px 6px #0003;z-index:1000}.tooltip-label{font-weight:600;margin:0 0 .5rem;color:#5dbbe8}.revenue-chart-tooltip p{margin:.25rem 0;line-height:1.4}@media (max-width: 768px){.revenue-chart-container{padding:1rem}.revenue-chart-loading,.revenue-chart-error,.revenue-chart-empty{height:300px}.revenue-chart-tooltip{font-size:.75rem;padding:.5rem .75rem}.revenue-chart-wrapper :global(.recharts-text){font-size:.75rem}.revenue-chart-wrapper :global(.recharts-legend-wrapper){flex-wrap:wrap}}@media (max-width: 480px){.revenue-chart-container{border-radius:6px;padding:.75rem}.error-icon{width:48px;height:48px;font-size:1.5rem}.retry-button{padding:.375rem 1rem;font-size:.8rem}}@keyframes slideInChart{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.revenue-chart-wrapper{animation:slideInChart .4s ease-out}.revenue-chart-container{position:relative}.retry-button:focus{outline:2px solid #5DBBE8;outline-offset:2px}@media print{.revenue-chart-container{border:1px solid #d1d5db;box-shadow:none;page-break-inside:avoid}.retry-button,.loading-skeleton{display:none}}:root{--analytics-color-primary: #5DBBE8;--analytics-color-primary-dark: #4899c8;--analytics-color-success: #10B981;--analytics-color-warning: #F59E0B;--analytics-color-danger: #EF4444;--analytics-color-info: #3B82F6;--analytics-color-bg: #F9FAFB;--analytics-color-border: #E5E7EB}.analytics-dashboard{padding:var(--space-8);max-width:1600px;margin:0 auto;min-height:calc(100vh - 200px)}.analytics-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-8);gap:var(--space-4)}.analytics-header h1{margin:0 0 var(--space-2) 0;font-size:var(--font-size-4xl);color:var(--text-primary);font-weight:var(--font-weight-bold);letter-spacing:-.02em;line-height:var(--line-height-tight)}.analytics-subtitle{margin:0;color:var(--text-secondary);font-size:var(--font-size-base);font-weight:var(--font-weight-medium)}.analytics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);margin-bottom:var(--space-8)}.analytics-card{background:var(--background-color, white);border:1px solid var(--analytics-color-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-xs);transition:all var(--transition-base)}.analytics-card:hover{box-shadow:var(--shadow-sm);border-color:var(--analytics-color-primary)}.analytics-section{background:#fff;border:1px solid var(--analytics-color-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-xs);transition:all var(--transition-base)}.analytics-section:hover{box-shadow:var(--shadow-sm)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:2px solid var(--analytics-color-border);gap:var(--space-4)}.section-header h2{margin:0;font-size:var(--font-size-2xl);color:var(--text-primary);font-weight:var(--font-weight-bold);letter-spacing:-.01em}.section-content{min-height:300px;display:flex;align-items:center;justify-content:center}.overview-section{grid-column:1 / -1}.overview-section .section-content{min-height:200px}.revenue-section{grid-column:1 / 3}.revenue-section .section-content{min-height:400px}.quotes-section{grid-column:3 / 4}.quotes-section .section-content{min-height:400px}.customers-section{grid-column:1 / -1}.customers-section .section-content{min-height:350px;overflow-x:auto}.chart-period-selector{padding:var(--space-2) var(--space-3);border:1px solid var(--analytics-color-border);border-radius:var(--radius-base);background:#fff;color:var(--text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base)}.chart-period-selector:hover{border-color:var(--analytics-color-primary)}.chart-period-selector:focus{outline:none;border-color:var(--analytics-color-primary);box-shadow:0 0 0 3px #5dbbe81a}.view-all-button{padding:var(--space-2) var(--space-4);background:var(--analytics-color-primary);color:#fff;border:none;border-radius:var(--radius-base);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base)}.view-all-button:hover{background:var(--analytics-color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-xs)}.view-all-button:active{transform:translateY(0)}.analytics-metric{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4);background:var(--analytics-color-bg);border-radius:var(--radius-base);text-align:center}.metric-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--analytics-color-primary);line-height:var(--line-height-tight)}.metric-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.05em}.metric-trend{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);display:flex;align-items:center;justify-content:center;gap:var(--space-1)}.metric-trend.positive{color:var(--analytics-color-success)}.metric-trend.negative{color:var(--analytics-color-danger)}.metric-trend.neutral{color:var(--text-tertiary)}.placeholder-card{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;padding:var(--space-8);background:linear-gradient(135deg,#5dbbe80d,#5dbbe805);border:2px dashed var(--analytics-color-border);border-radius:var(--radius-base);text-align:center}.placeholder-card p{margin:0;font-size:var(--font-size-base);color:var(--text-primary);font-weight:var(--font-weight-medium)}.placeholder-text{color:var(--text-secondary)!important;font-size:var(--font-size-sm)!important;font-weight:var(--font-weight-normal)!important;margin-top:var(--space-2)}.analytics-upgrade-message{display:flex;align-items:center;justify-content:center;min-height:600px;padding:var(--space-8)}.upgrade-content{max-width:500px;text-align:center;background:#fff;border:1px solid var(--analytics-color-border);border-radius:var(--radius-lg);padding:var(--space-8);box-shadow:var(--shadow-sm)}.upgrade-content h2{margin:0 0 var(--space-3) 0;font-size:var(--font-size-3xl);color:var(--text-primary);font-weight:var(--font-weight-bold);letter-spacing:-.02em}.upgrade-content>p{margin:0 0 var(--space-6) 0;font-size:var(--font-size-base);color:var(--text-secondary);line-height:var(--line-height-relaxed)}.upgrade-features{text-align:left;margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:1px solid var(--analytics-color-border)}.upgrade-features h3{margin:0 0 var(--space-4) 0;font-size:var(--font-size-lg);color:var(--text-primary);font-weight:var(--font-weight-bold)}.upgrade-features ul{margin:0;padding:0;list-style:none}.upgrade-features li{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);font-size:var(--font-size-base);color:var(--text-primary)}.upgrade-features svg{flex-shrink:0;color:var(--analytics-color-success)}.upgrade-button{display:inline-block;padding:var(--space-4) var(--space-8);background:var(--analytics-color-primary);color:#fff;border:none;border-radius:var(--radius-base);font-size:var(--font-size-base);font-weight:var(--font-weight-bold);text-decoration:none;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-xs)}.upgrade-button:hover{background:var(--analytics-color-primary-dark);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.upgrade-button:active{transform:translateY(0)}.upgrade-note{margin:var(--space-6) 0 0 0;font-size:var(--font-size-sm);color:var(--text-secondary)}.analytics-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:500px;padding:var(--space-8);text-align:center}.error-icon{margin-bottom:var(--space-6);color:var(--analytics-color-danger)}.analytics-error h3{margin:0 0 var(--space-3) 0;font-size:var(--font-size-2xl);color:var(--text-primary);font-weight:var(--font-weight-bold)}.analytics-error p{margin:0 0 var(--space-6) 0;max-width:400px;font-size:var(--font-size-base);color:var(--text-secondary);line-height:var(--line-height-relaxed)}.retry-button{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background:var(--analytics-color-primary);color:#fff;border:none;border-radius:var(--radius-base);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-xs)}.retry-button:hover{background:var(--analytics-color-primary-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.retry-button:active{transform:translateY(0)}.analytics-footer{text-align:center;padding:var(--space-6) 0;border-top:1px solid var(--analytics-color-border);color:var(--text-secondary);font-size:var(--font-size-sm)}.analytics-footer p{margin:0}@media (max-width: 1024px){.analytics-dashboard{padding:var(--space-4)}.analytics-header{flex-direction:column;align-items:flex-start}.analytics-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-4)}.revenue-section,.quotes-section{grid-column:1 / 3}.customers-section{grid-column:1 / -1}.section-header{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.chart-period-selector,.view-all-button{width:100%}}@media (max-width: 768px){.analytics-dashboard{padding:var(--space-4);min-height:auto}.analytics-header h1{font-size:var(--font-size-2xl)}.analytics-grid{grid-template-columns:1fr;gap:var(--space-4)}.revenue-section,.quotes-section,.customers-section{grid-column:1 / -1}.analytics-section{padding:var(--space-4)}.section-header h2{font-size:var(--font-size-xl)}.section-content{min-height:250px}.analytics-upgrade-message{min-height:400px;padding:var(--space-4)}.upgrade-content{padding:var(--space-4)}.upgrade-content h2{font-size:var(--font-size-xl)}.analytics-error{min-height:400px;padding:var(--space-4)}.analytics-metric{padding:var(--space-3)}.metric-value{font-size:var(--font-size-2xl)}}@media (max-width: 480px){.analytics-dashboard{padding:var(--space-3)}.analytics-header h1{font-size:var(--font-size-xl)}.analytics-section{padding:var(--space-3);border-radius:var(--radius-base)}.section-header h2{font-size:var(--font-size-lg)}.section-content{min-height:200px}.placeholder-card{padding:var(--space-4)}.placeholder-card p{font-size:var(--font-size-sm)}.upgrade-content{padding:var(--space-3);border-radius:var(--radius-base)}.upgrade-button{width:100%;padding:var(--space-3) var(--space-6)}}.customer-table-container{width:100%;background:var(--background-secondary);border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}.customer-table{width:100%;border-collapse:collapse;font-size:.95rem}.customer-table thead{background:var(--background-tertiary);border-bottom:2px solid var(--border-color-dark)}.customer-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.customer-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s,color .2s}.customer-table th.sortable:hover{background:var(--background-secondary);color:var(--primary-color)}.text-right{text-align:right}.text-center{text-align:center}.customer-table tbody tr{border-bottom:1px solid var(--border-color);transition:background .2s}.customer-table tbody tr.even,.customer-table tbody tr.odd{background:var(--background-secondary)}.customer-table tbody tr:hover{background:var(--background-tertiary)}.customer-table td{padding:1rem;color:var(--text-primary)}.customer-cell{padding-left:1rem}.customer-info{display:flex;flex-direction:column;gap:.25rem}.customer-name{font-weight:500;color:var(--text-primary)}.customer-email{font-size:.85rem;color:var(--text-secondary)}.revenue-cell{font-weight:600;color:var(--success-color)}.last-invoice{font-size:.9rem;color:var(--text-secondary)}.customer-cards-container{display:none;gap:1rem;padding:1.5rem}.customer-card{background:var(--background-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.customer-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.customer-name-large{font-size:1.1rem;font-weight:600;color:var(--text-primary);flex:1}.revenue-large{font-size:1.25rem;font-weight:700;color:var(--success-color);white-space:nowrap}.customer-card-details{display:flex;flex-direction:column;gap:.75rem}.customer-email-mobile{margin:0;font-size:.9rem;color:var(--text-secondary)}.detail-row{display:flex;justify-content:space-between;align-items:center;gap:1rem}.detail-label{font-size:.85rem;color:var(--text-secondary);font-weight:500}.detail-value{font-size:.95rem;color:var(--text-primary);font-weight:500}.loading-row{animation:pulse 1.5s ease-in-out infinite}.skeleton-line{height:1rem;background:linear-gradient(90deg,var(--background-tertiary) 25%,var(--background-secondary) 50%,var(--background-tertiary) 75%);background-size:200% 100%;animation:loading 1.5s infinite;border-radius:4px}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.error-state{padding:3rem 1.5rem;text-align:center;display:flex;flex-direction:column;gap:1rem;align-items:center}.error-message{margin:0;color:var(--error-color);font-size:1rem}.btn-retry{padding:.75rem 1.5rem;background:var(--primary-color);color:var(--text-on-primary);border:none;border-radius:6px;cursor:pointer;font-weight:500;font-size:.95rem;transition:all .2s}.btn-retry:hover{background:var(--primary-color-dark);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.empty-state{padding:4rem 1.5rem;text-align:center;color:var(--text-secondary);font-size:1rem}.empty-state p{margin:0}@media (max-width: 768px){.customer-table-container{box-shadow:none}.table-responsive{display:none}.customer-cards-container{display:flex;flex-direction:column}.customer-card{background:var(--background-secondary);border:1px solid var(--border-color);border-radius:10px;padding:1rem;margin-bottom:0}.customer-name-large{font-size:1rem}.revenue-large{font-size:1.15rem}.customer-email-mobile{font-size:.85rem}.detail-label{font-size:.8rem}.detail-value{font-size:.9rem}}@media (max-width: 480px){.customer-card-header{flex-direction:column;align-items:flex-start}.customer-name-large{width:100%}.revenue-large{align-self:flex-start}.customer-email-mobile{margin-top:.5rem}}@supports (position: sticky){@media (min-width: 769px){.customer-table thead{position:sticky;top:0;z-index:10}}}@media print{.customer-table-container{box-shadow:none;border:1px solid var(--border-color)}.customer-table thead{background:transparent;border:1px solid var(--border-color)}.customer-table tbody tr{page-break-inside:avoid}}.quote-metrics-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:2rem;margin-bottom:2rem;transition:box-shadow .3s ease}.quote-metrics-card:hover{box-shadow:0 4px 12px #00000026}.quote-metrics-header{margin-bottom:2rem;border-bottom:2px solid #f0f0f0;padding-bottom:1rem}.quote-metrics-header h2{margin:0;font-size:1.75rem;font-weight:600;color:var(--text-primary, #1a1a1a)}.quote-metrics-content{display:grid;grid-template-columns:1fr 1fr;gap:3rem}.quote-metrics-section{display:flex;flex-direction:column;gap:2rem}.section-title{margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary, #1a1a1a);display:flex;align-items:center;gap:.5rem}.status-breakdown{display:flex;flex-direction:column;gap:1.5rem}.status-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f9f9f9;border-radius:6px;transition:all .2s ease}.status-item:hover{background:#f0f0f0}.status-item.total-quotes{background:linear-gradient(135deg,#5dbbe8,#4a9dd4);color:#fff}.status-item.total-quotes .status-value{font-size:2rem;font-weight:700;color:#fff}.status-item.total-quotes .status-label{font-size:.875rem;color:#ffffffe6}.status-indicator{width:12px;height:12px;border-radius:50%;flex-shrink:0;box-shadow:0 2px 4px #0000001a}.status-details{display:flex;flex-direction:column;gap:.25rem;flex:1}.status-count{font-size:1.5rem;font-weight:600;color:var(--text-primary, #1a1a1a)}.status-text{font-size:.875rem;color:var(--text-secondary, #666)}.status-value{font-size:1rem;font-weight:500;color:var(--text-primary, #1a1a1a)}.status-label{font-size:.875rem;color:var(--text-secondary, #666)}.conversion-rate-container{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem;background:linear-gradient(135deg,#5dbbe80d,#5dbbe805);border:2px solid #5DBBE8;border-radius:8px;text-align:center}.conversion-rate-value{font-size:3.5rem;font-weight:700;line-height:1;transition:color .3s ease}.conversion-rate-label{font-size:1rem;font-weight:500;color:var(--text-secondary, #666)}.progress-bar{width:100%;max-width:300px;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;position:relative}.progress-fill{height:100%;border-radius:4px;transition:width .5s ease,background-color .3s ease;box-shadow:0 2px 4px #00000026}.conversion-rate-indicator{font-size:.875rem;font-weight:500;color:var(--text-secondary, #666);padding:.5rem 1rem;background:#fff;border-radius:4px;margin-top:.5rem}.metric-item{display:flex;flex-direction:column;gap:.5rem;padding:1.5rem;background:#f9f9f9;border-radius:6px;border-left:4px solid #5DBBE8;transition:all .2s ease}.metric-item:hover{background:#f0f0f0;border-left-color:#4a9dd4}.metric-label{font-size:.875rem;font-weight:500;color:var(--text-secondary, #666);text-transform:uppercase;letter-spacing:.5px}.metric-value{font-size:2rem;font-weight:700;color:var(--text-primary, #1a1a1a)}.error-message{padding:2rem;background:#fff5f5;border:1px solid #fab5b0;border-radius:6px;text-align:center;color:#d32f2f}.error-message p{margin:0 0 1rem;font-size:.95rem}.retry-button{padding:.75rem 1.5rem;background:#d32f2f;color:#fff;border:none;border-radius:4px;font-weight:500;cursor:pointer;transition:background .2s ease}.retry-button:hover{background:#b71c1c}@media (max-width: 1024px){.quote-metrics-content{grid-template-columns:1fr;gap:2rem}}@media (max-width: 768px){.quote-metrics-card{padding:1.5rem}.quote-metrics-header h2{font-size:1.5rem}.quote-metrics-content{gap:1.5rem}.status-breakdown{gap:1rem}.status-item{padding:.875rem;gap:.75rem}.status-item.total-quotes .status-value{font-size:1.5rem}.status-count{font-size:1.25rem}.status-text{font-size:.8125rem}.conversion-rate-container{padding:1.5rem;gap:1rem}.conversion-rate-value{font-size:2.5rem}.metric-item{padding:1rem}.metric-value{font-size:1.5rem}.metric-label{font-size:.8rem}.progress-bar{max-width:100%}}@media (max-width: 480px){.quote-metrics-card{padding:1rem;margin-bottom:1.5rem}.quote-metrics-header{margin-bottom:1.5rem;padding-bottom:.75rem}.quote-metrics-header h2{font-size:1.25rem}.section-title{font-size:1rem}.status-breakdown{gap:.75rem}.status-item{padding:.75rem;flex-direction:column;align-items:flex-start}.status-item.total-quotes{flex-direction:row;align-items:center;justify-content:space-between}.status-item.total-quotes .status-value{font-size:1.875rem}.status-indicator{width:10px;height:10px}.status-details{width:100%}.conversion-rate-container{padding:1rem;gap:.75rem}.conversion-rate-value{font-size:2rem}.conversion-rate-label{font-size:.9375rem}.conversion-rate-indicator{font-size:.8125rem}.metric-item{padding:.875rem;border-left-width:3px}.metric-value{font-size:1.25rem}.metric-label{font-size:.75rem}}.quote-metrics-card .loading-spinner{background:transparent;box-shadow:none}.app-theme-switcher{padding:var(--space-4);background:var(--background-secondary);border-radius:var(--radius-md)}.theme-switcher-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-color)}.theme-switcher-header h4{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.current-theme-badge{padding:var(--space-1) var(--space-2);background:var(--primary-color);color:var(--text-on-primary);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.theme-error{padding:var(--space-3);background:var(--error-color-light);border:1px solid var(--error-color);border-radius:var(--radius-base);color:var(--error-color);font-size:var(--font-size-sm);margin-bottom:var(--space-4)}.theme-options{display:flex;flex-direction:column;gap:var(--space-3)}.theme-option{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--background-secondary);border:2px solid var(--border-color);border-radius:var(--radius-base);cursor:pointer;transition:all var(--transition-base);position:relative;text-align:left;width:100%}.theme-option:hover:not(.locked){border-color:var(--primary-color);background:var(--background-tertiary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.theme-option.selected{border-color:var(--primary-color);background:var(--primary-color-lighter);box-shadow:var(--shadow-base)}.theme-option.locked{opacity:.5;cursor:not-allowed}.theme-preview{width:48px;height:48px;border-radius:var(--radius-base);flex-shrink:0;position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.theme-preview-secondary{position:absolute;bottom:0;right:0;width:60%;height:60%;border-radius:var(--radius-sm) 0 0 0}.theme-info{flex:1;min-width:0}.theme-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin-bottom:var(--space-1);display:flex;align-items:center;gap:var(--space-2)}.lock-icon{font-size:var(--font-size-sm)}.theme-description{font-size:var(--font-size-xs);color:var(--text-secondary);margin-bottom:var(--space-1)}.theme-tier-badge{display:inline-block;padding:2px var(--space-2);background:var(--warning-color-light);border:1px solid var(--warning-color);color:var(--warning-color);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.selected-indicator{flex-shrink:0;color:var(--primary-color);display:flex;align-items:center;justify-content:center}.theme-option.selected .selected-indicator{color:var(--primary-color-dark)}.theme-switcher-footer{margin-top:var(--space-4);padding-top:var(--space-3);border-top:1px solid var(--border-color)}.theme-note{margin:0;font-size:var(--font-size-xs);color:var(--text-tertiary);text-align:center}@media (max-width: 768px){.app-theme-switcher{padding:var(--space-2)}.theme-switcher-header{margin-bottom:var(--space-2);padding-bottom:var(--space-2)}.theme-options{gap:var(--space-2)}.theme-option{padding:var(--space-2);gap:var(--space-2)}.theme-preview{width:28px;height:28px}.theme-name{font-size:var(--font-size-xs);margin-bottom:0}.theme-description{display:none}.selected-indicator svg{width:14px;height:14px}.theme-switcher-footer{display:none}}.error-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:9998;animation:fadeIn .2s ease-in-out}.error-modal-container{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;pointer-events:none}.error-modal{position:relative;max-width:500px;width:100%;padding:24px;border-radius:8px;border:2px solid;box-shadow:0 10px 40px #0000004d;animation:slideDown .3s ease-out;pointer-events:all}.error-modal-close{position:absolute;top:12px;right:12px;background:transparent;border:none;font-size:28px;line-height:1;cursor:pointer;padding:4px 8px;opacity:.7;transition:opacity .2s}.error-modal-close:hover{opacity:1}.error-modal-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-right:40px}.error-modal-icon{font-size:32px;line-height:1}.error-modal-title{margin:0;font-size:20px;font-weight:700}.error-modal-content{margin-bottom:20px}.error-modal-message{margin:0 0 8px;font-size:16px;line-height:1.5;white-space:pre-line}.error-modal-details{margin:8px 0 0;font-size:14px;line-height:1.4;opacity:.8}.error-modal-actions{display:flex;gap:12px;flex-wrap:wrap}.error-modal-action-button,.error-modal-dismiss-button{padding:10px 20px;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s;border:2px solid}.error-modal-action-button:hover,.error-modal-dismiss-button:hover{opacity:.9;transform:translateY(-1px)}.error-modal-action-button:active,.error-modal-dismiss-button:active{transform:translateY(0)}.error-modal-action-button{border:none}.error-modal-dismiss-button{background:transparent}.error-modal-queue{margin-top:16px;padding-top:12px;border-top:1px solid currentColor;font-size:13px;text-align:center;opacity:.7}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.error-modal{max-width:calc(100vw - 32px);padding:20px}.error-modal-header{padding-right:36px}.error-modal-icon{font-size:28px}.error-modal-title{font-size:18px}.error-modal-message{font-size:15px}.error-modal-actions{flex-direction:column}.error-modal-action-button,.error-modal-dismiss-button{width:100%}}.notification-banner{width:100%;padding:var(--space-4) var(--space-5);box-shadow:var(--shadow-sm);animation:slideDown var(--transition-base) ease-out;position:relative;z-index:100}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.notification-banner-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:var(--space-3)}.notification-banner-icon{font-size:var(--font-size-xl);flex-shrink:0;line-height:1}.notification-banner-message{flex:1;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);line-height:var(--line-height-relaxed);text-align:center}.notification-banner-dismiss{background:none;border:none;cursor:pointer;padding:var(--space-2);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-base);flex-shrink:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);line-height:1;opacity:.7}.notification-banner-dismiss:hover{opacity:1;transform:scale(1.1)}.notification-banner-info{background:linear-gradient(135deg,#e3f2fd,#bbdefb);color:#0d47a1;border-bottom:3px solid var(--cloudcafe-blue)}.notification-banner-info .notification-banner-dismiss:hover{background:#0d47a11a}.notification-banner-warning{background:linear-gradient(135deg,#fff3e0,#ffe0b2);color:#e65100;border-bottom:3px solid #ff9800}.notification-banner-warning .notification-banner-dismiss:hover{background:#e651001a}.notification-banner-success{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:#1b5e20;border-bottom:3px solid #4caf50}.notification-banner-success .notification-banner-dismiss:hover{background:#1b5e201a}.notification-banner-error{background:linear-gradient(135deg,#ffebee,#ffcdd2);color:#b71c1c;border-bottom:3px solid #f44336}.notification-banner-error .notification-banner-dismiss:hover{background:#b71c1c1a}@media (max-width: 768px){.notification-banner{padding:var(--space-3) var(--space-4)}.notification-banner-content{gap:var(--space-2)}.notification-banner-icon{font-size:var(--font-size-lg)}.notification-banner-message{font-size:var(--font-size-sm)}.notification-banner-dismiss{padding:var(--space-1);font-size:var(--font-size-base)}}@media (max-width: 480px){.notification-banner{padding:var(--space-2) var(--space-3)}.notification-banner-message{font-size:var(--font-size-xs);line-height:var(--line-height-normal)}.notification-banner-icon{display:none}}.auth-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-5);background:linear-gradient(135deg,var(--cloudcafe-blue) 0%,var(--cloudcafe-blue-dark) 100%);position:relative;overflow:hidden}.cloud{position:absolute;z-index:0;opacity:.6}.cloud svg{fill:#fff}.cloud-1{top:8%;animation:floatCloud1 38s linear infinite}.cloud-2{top:55%;animation:floatCloud2 71s linear infinite;animation-delay:-20s}.cloud-3{top:75%;animation:floatCloud3 43s linear infinite;animation-delay:-15s}.cloud-4{top:25%;animation:floatCloud4 67s linear infinite;animation-delay:-40s}.cloud-5{top:85%;animation:floatCloud5 52s linear infinite;animation-delay:-10s}.cloud-6{top:40%;animation:floatCloud6 59s linear infinite;animation-delay:-30s}@keyframes floatCloud1{0%{left:-200px;transform:translateY(0)}50%{transform:translateY(-15px)}to{left:calc(100% + 200px);transform:translateY(0)}}@keyframes floatCloud2{0%{left:-200px;transform:translateY(0)}50%{transform:translateY(15px)}to{left:calc(100% + 200px);transform:translateY(0)}}@keyframes floatCloud3{0%{left:-200px;transform:translateY(0)}50%{transform:translateY(-10px)}to{left:calc(100% + 200px);transform:translateY(0)}}@keyframes floatCloud4{0%{left:-250px;transform:translateY(0)}50%{transform:translateY(12px)}to{left:calc(100% + 250px);transform:translateY(0)}}@keyframes floatCloud5{0%{left:-150px;transform:translateY(0)}50%{transform:translateY(-8px)}to{left:calc(100% + 150px);transform:translateY(0)}}@keyframes floatCloud6{0%{left:-180px;transform:translateY(0)}50%{transform:translateY(10px)}to{left:calc(100% + 180px);transform:translateY(0)}}.cloud-7{top:15%;animation:floatCloud7 41s linear infinite;animation-delay:-25s}.cloud-8{top:68%;animation:floatCloud8 74s linear infinite;animation-delay:-45s}.cloud-9{top:82%;animation:floatCloud9 36s linear infinite;animation-delay:-35s}.cloud-10{top:32%;animation:floatCloud10 63s linear infinite;animation-delay:-50s}.cloud-11{top:90%;animation:floatCloud11 47s linear infinite;animation-delay:-20s}.cloud-12{top:48%;animation:floatCloud12 69s linear infinite;animation-delay:-42s}@keyframes floatCloud7{0%{left:-280px;transform:translateY(0)}50%{transform:translateY(-18px)}to{left:calc(100% + 280px);transform:translateY(0)}}@keyframes floatCloud8{0%{left:-180px;transform:translateY(0)}50%{transform:translateY(18px)}to{left:calc(100% + 180px);transform:translateY(0)}}@keyframes floatCloud9{0%{left:-120px;transform:translateY(0)}50%{transform:translateY(-12px)}to{left:calc(100% + 120px);transform:translateY(0)}}@keyframes floatCloud10{0%{left:-220px;transform:translateY(0)}50%{transform:translateY(14px)}to{left:calc(100% + 220px);transform:translateY(0)}}@keyframes floatCloud11{0%{left:-90px;transform:translateY(0)}50%{transform:translateY(-9px)}to{left:calc(100% + 90px);transform:translateY(0)}}@keyframes floatCloud12{0%{left:-150px;transform:translateY(0)}50%{transform:translateY(11px)}to{left:calc(100% + 150px);transform:translateY(0)}}.auth-card{background:#fff;border-radius:var(--radius-lg);padding:var(--space-10);box-shadow:var(--shadow-xl);max-width:420px;width:100%;animation:fadeIn var(--transition-slow);position:relative;z-index:1}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-logo{display:flex;justify-content:center;margin-bottom:var(--space-4)}.auth-logo img{height:180px;width:auto;filter:drop-shadow(var(--shadow-sm))}.auth-app-title{text-align:center;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-secondary);margin-bottom:var(--space-6);letter-spacing:.02em}.auth-branding{text-align:center;margin-bottom:var(--space-3)}.auth-company-name{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--cloudcafe-blue);margin:0 0 var(--space-2) 0;letter-spacing:-.02em;line-height:var(--line-height-tight)}.auth-card h2{margin:0 0 var(--space-3) 0;color:var(--text-primary);font-size:var(--font-size-3xl);font-weight:var(--font-weight-semibold);text-align:center;letter-spacing:-.01em}.auth-description{margin:0 0 var(--space-6) 0;color:var(--text-secondary);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed);text-align:center}.auth-form{margin-top:var(--space-5)}.form-group{margin-bottom:var(--space-5)}.form-group label{display:block;margin-bottom:var(--space-2);color:var(--text-primary);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);letter-spacing:.01em}.form-group input{width:100%;padding:var(--space-3) var(--space-4);border:2px solid var(--border-color);border-radius:var(--radius-base);font-size:var(--font-size-base);font-family:var(--font-family);color:var(--text-primary);background-color:var(--background-secondary);transition:all var(--transition-base);box-sizing:border-box}.form-group input::placeholder{color:var(--text-tertiary)}.form-group input:hover:not(:disabled){border-color:var(--border-color-dark)}.form-group input:focus{outline:none;border-color:var(--cloudcafe-blue);box-shadow:0 0 0 3px #5dbbe81a;background-color:var(--background-secondary)}.form-group input:disabled{background-color:var(--gray-50);cursor:not-allowed;opacity:.6}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{padding-right:var(--space-12)}.password-toggle{position:absolute;right:var(--space-3);background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-2);display:flex;align-items:center;justify-content:center;transition:color var(--transition-base);border-radius:var(--radius-sm)}.password-toggle:hover:not(:disabled){color:var(--text-secondary);background:var(--gray-50)}.password-toggle:disabled{opacity:.4;cursor:not-allowed}.form-hint{display:block;margin-top:var(--space-2);color:var(--text-secondary);font-size:var(--font-size-xs);line-height:var(--line-height-normal)}.auth-error{padding:var(--space-3) var(--space-4);background-color:var(--error-color-light);border:1px solid var(--error-color);border-left-width:4px;border-radius:var(--radius-base);color:var(--error-color);margin-bottom:var(--space-5);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);display:flex;align-items:center;gap:var(--space-2)}.auth-error:before{content:"⚠";font-size:var(--font-size-lg);flex-shrink:0}.auth-button{width:100%;padding:var(--space-4);margin-top:var(--space-6);background:linear-gradient(135deg,var(--cloudcafe-blue) 0%,var(--cloudcafe-blue-dark) 100%);color:#fff;border:none;border-radius:var(--radius-base);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-base)}.auth-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.auth-button:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.auth-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.auth-footer{margin-top:var(--space-6);text-align:center;color:var(--text-secondary);font-size:var(--font-size-sm)}.auth-link{background:none;border:none;color:var(--cloudcafe-blue);font-weight:var(--font-weight-semibold);cursor:pointer;padding:0;text-decoration:none;transition:color var(--transition-base);display:inline}.auth-link:hover:not(:disabled){color:var(--cloudcafe-blue-dark);text-decoration:underline}.auth-link:disabled{opacity:.6;cursor:not-allowed}.auth-loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000;animation:fadeIn var(--transition-base)}.popia-consent-section{margin-top:var(--space-6);margin-bottom:var(--space-4)}.popia-consent-section .popia-consent{background:var(--gray-50);border:1px solid var(--border-color);border-radius:var(--radius-base);padding:var(--space-4)}.popia-consent-section .popia-consent__header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3)}.popia-consent-section .popia-consent__title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin:0;color:var(--text-primary)}.popia-consent-section .popia-consent__checkboxes{display:flex;flex-direction:column;gap:var(--space-3)}.popia-consent-section .popia-consent__checkbox{display:flex;align-items:flex-start;gap:var(--space-2);cursor:pointer;font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.4}.popia-consent-section .popia-consent__checkbox input[type=checkbox]{width:auto;margin-top:3px;cursor:pointer;flex-shrink:0}.popia-consent-section .popia-consent__checkbox-text{flex:1}.popia-consent-section .popia-consent__checkbox-text a{color:var(--cloudcafe-blue);text-decoration:underline}.popia-consent-section .popia-consent__checkbox-text a:hover{color:var(--cloudcafe-blue-dark)}.popia-consent-section .required-indicator{color:var(--error);margin-left:2px}.popia-consent-section .popia-consent__required-note{font-size:var(--font-size-xs);color:var(--error);margin-top:var(--space-2);margin-bottom:0}.popia-consent-section .popia-consent__confirmed{display:flex;align-items:center;gap:var(--space-2);color:var(--success);font-size:var(--font-size-sm);margin-top:var(--space-3)}.popia-consent-section .popia-consent__confirmed .checkmark{font-weight:700}.popia-consent-section .popia-consent__rights,.popia-consent-section .legal-disclaimers-section,.popia-consent-section .compliance-notice{display:none}@media (max-width: 480px){.auth-container{padding:var(--space-4)}.auth-card{padding:var(--space-6)}.auth-logo img{height:120px}.auth-company-name{font-size:var(--font-size-3xl)}.auth-card h2{font-size:var(--font-size-2xl)}}.popia-consent{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:20px;margin:16px 0}.popia-consent__header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.popia-consent__icon{font-size:24px}.popia-consent__title{margin:0;font-size:1.1rem;color:#212529}.popia-consent__full-text{background:#fff;border:1px solid #e9ecef;border-radius:6px;padding:16px;margin-bottom:16px}.popia-consent__full-text p{margin:0 0 12px;font-size:.9rem;color:#495057;line-height:1.6}.popia-consent__full-text p:last-child{margin-bottom:0}.popia-consent__checkboxes{display:flex;flex-direction:column;gap:12px}.popia-consent__checkbox{display:flex;align-items:flex-start;gap:12px;cursor:pointer;padding:12px;background:#fff;border:1px solid #e9ecef;border-radius:6px;transition:border-color .2s,background-color .2s}.popia-consent__checkbox:hover{border-color:#5dbbe8;background:#f8fdff}.popia-consent__checkbox input[type=checkbox]{width:20px;height:20px;margin-top:2px;cursor:pointer;accent-color:#5dbbe8}.popia-consent__checkbox-text{flex:1;font-size:.9rem;color:#495057;line-height:1.5}.popia-consent__checkbox-text a{color:#5dbbe8;text-decoration:underline}.popia-consent__checkbox-text a:hover{color:#3a9ed0}.required-indicator{color:#dc3545;margin-left:4px;font-weight:700}.popia-consent__required-note{font-size:.85rem;color:#dc3545;margin:12px 0 0;font-style:italic}.popia-consent__confirmed{display:flex;align-items:center;gap:8px;margin-top:12px;padding:10px 14px;background:#d4edda;border:1px solid #c3e6cb;border-radius:6px;color:#155724;font-weight:500}.popia-consent__confirmed .checkmark{font-size:1.2rem}.popia-consent__rights{margin-top:16px;padding-top:16px;border-top:1px solid #dee2e6}.popia-consent__rights p{margin:0;font-size:.8rem;color:#6c757d;line-height:1.5}.popia-consent__rights a{color:#5dbbe8}@media (max-width: 480px){.popia-consent{padding:16px}.popia-consent__checkbox{padding:10px;gap:10px}.popia-consent__checkbox input[type=checkbox]{width:18px;height:18px}.popia-consent__checkbox-text{font-size:.85rem}}@media print{.popia-consent__checkbox input[type=checkbox]{display:none}.popia-consent__checkbox:before{content:"☐ ";font-size:1.2rem}.popia-consent__checkbox:has(input:checked):before{content:"☑ "}}.terms-content{max-height:500px;overflow-y:auto;padding:var(--space-4);line-height:1.6;color:var(--text-primary)}.terms-content h2{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--primary-color);margin-bottom:var(--space-2)}.terms-content h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin-top:var(--space-6);margin-bottom:var(--space-3)}.terms-content p{margin-bottom:var(--space-4);color:var(--text-secondary)}.terms-content ul{margin:var(--space-3) 0;padding-left:var(--space-6)}.terms-content li{margin-bottom:var(--space-2);color:var(--text-secondary)}.terms-section{margin-bottom:var(--space-5)}.terms-last-updated{font-size:var(--font-size-sm);color:var(--text-tertiary);font-style:italic;margin-bottom:var(--space-6)}.terms-acknowledgment{background-color:var(--gray-50);border-left:4px solid var(--primary-color);padding:var(--space-4);border-radius:var(--radius-md);margin-top:var(--space-6)}.terms-acknowledgment p{margin:0;font-weight:var(--font-weight-medium);color:var(--text-primary)}.terms-scroll-indicator{height:1px;margin-top:var(--space-8)}.terms-footer{display:flex;flex-direction:column;gap:var(--space-4);width:100%}.terms-checkbox{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3);background-color:var(--gray-50);border-radius:var(--radius-md);border:2px solid var(--gray-200)}.terms-checkbox input[type=checkbox]{margin-top:2px;width:18px;height:18px;cursor:pointer;flex-shrink:0}.terms-checkbox input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.terms-checkbox label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none;flex:1}.terms-scroll-notice{color:var(--primary-color);font-style:italic;font-weight:var(--font-weight-normal)}.terms-buttons{display:flex;justify-content:flex-end;gap:var(--space-3)}.terms-buttons .btn-primary:disabled{opacity:.5;cursor:not-allowed;background-color:var(--gray-300)}.terms-content::-webkit-scrollbar{width:8px}.terms-content::-webkit-scrollbar-track{background:var(--gray-100);border-radius:var(--radius-sm)}.terms-content::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:var(--radius-sm)}.terms-content::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}@media (max-width: 768px){.terms-content{max-height:60vh;padding:var(--space-3);font-size:var(--font-size-sm)}.terms-content h2{font-size:var(--font-size-xl);margin-bottom:var(--space-3)}.terms-content h3{font-size:var(--font-size-base);margin-top:var(--space-4);margin-bottom:var(--space-2)}.terms-content p{margin-bottom:var(--space-3);line-height:1.5}.terms-checkbox{padding:var(--space-4)}.terms-checkbox label{font-size:var(--font-size-sm);line-height:1.4}.terms-checkbox input[type=checkbox]{width:20px;height:20px;min-width:20px;min-height:20px}.terms-buttons{flex-direction:column-reverse;gap:var(--space-3)}.terms-buttons button{width:100%;min-height:48px;font-size:var(--font-size-base)}.terms-scroll-notice{display:block;margin-top:var(--space-1)}}@media (max-width: 480px){.terms-content{max-height:55vh;padding:var(--space-2);font-size:var(--font-size-xs)}.terms-content h2{font-size:var(--font-size-lg)}.terms-content h3{font-size:var(--font-size-sm)}.terms-checkbox{padding:var(--space-3)}.terms-checkbox label{font-size:var(--font-size-xs)}}.terms-content strong{font-weight:var(--font-weight-semibold);color:var(--text-primary)}.terms-content ul li::marker{color:var(--primary-color)}.admin-layout{display:flex;min-height:100vh;background:var(--background-color)}.admin-sidebar{width:260px;background:var(--background-tertiary);color:var(--text-primary);display:flex;flex-direction:column;position:fixed;height:100vh;left:0;top:0;z-index:100;border-right:1px solid var(--border-color)}.admin-header{padding:2rem 1.5rem;border-bottom:1px solid var(--border-color)}.admin-header h1{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.admin-user{margin:0;font-size:.875rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-nav{flex:1;padding:1rem 0;overflow-y:auto}.admin-nav a{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.5rem;color:var(--text-secondary);text-decoration:none;transition:all .2s}.admin-nav a:hover{background:var(--background-secondary);color:var(--text-primary)}.admin-nav a.active{background:var(--background-secondary);color:var(--primary-color);border-left:3px solid var(--primary-color);font-weight:600}.nav-icon{font-size:1.25rem}.admin-footer{padding:1.5rem;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:.75rem}.admin-footer button{width:100%;padding:.75rem;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.btn-secondary{background:var(--primary-color);color:var(--text-on-primary)}.btn-secondary:hover{background:var(--primary-color-dark)}.btn-outline{background:transparent;color:var(--text-primary);border:1px solid var(--border-color-dark)}.btn-outline:hover{background:var(--background-secondary);border-color:var(--primary-color)}.admin-content{flex:1;margin-left:260px;padding:2rem;min-height:100vh}.admin-page{max-width:1400px;margin:0 auto}.admin-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.admin-page-header h1{margin:0;font-size:2rem;color:var(--text-primary)}.btn-refresh{padding:.75rem 1.5rem;background:var(--primary-color);color:var(--text-on-primary);border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.btn-refresh:hover{background:var(--primary-color-dark)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--background-secondary);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;display:flex;align-items:center;gap:1.25rem;border-left:4px solid var(--border-color-dark)}.stat-card.stat-primary{border-left-color:var(--primary-color)}.stat-card.stat-success{border-left-color:var(--success-color)}.stat-card.stat-warning{border-left-color:var(--warning-color)}.stat-card.stat-info{border-left-color:var(--info-color)}.stat-card.stat-danger{border-left-color:var(--error-color)}.stat-icon{font-size:2.5rem;opacity:.8}.stat-content{flex:1}.stat-content h3{margin:0 0 .5rem;font-size:.875rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.stat-value{margin:0;font-size:2rem;font-weight:700;color:var(--text-primary)}.stat-label{margin:.25rem 0 0;font-size:.875rem;color:var(--text-tertiary)}.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;margin-bottom:2rem}.admin-card{background:var(--background-secondary);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;border:1px solid var(--border-color)}.admin-card h2{margin:0 0 1.5rem;font-size:1.25rem;color:var(--text-primary)}.tier-list{display:flex;flex-direction:column;gap:1rem}.tier-item{display:flex;align-items:center;gap:1rem}.tier-name{min-width:100px;font-weight:500;text-transform:capitalize;color:var(--text-primary)}.tier-count{min-width:80px;text-align:right;font-weight:600;color:var(--text-secondary)}.tier-bar{flex:1;height:8px;background:var(--background-tertiary);border-radius:4px;overflow:hidden}.tier-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--primary-color-dark));transition:width .3s ease}.quick-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.quick-stat{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--background-tertiary);border-radius:8px;border:1px solid var(--border-color)}.quick-stat-label{font-size:.875rem;color:var(--text-secondary)}.quick-stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.table-responsive{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse}.admin-table thead{background:var(--background-tertiary)}.admin-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border-color-dark)}.admin-table td{padding:1rem;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.admin-table tbody tr{cursor:pointer;transition:background .2s;background:var(--background-secondary)}.admin-table tbody tr:hover{background:var(--background-tertiary)}.admin-table tbody tr.selected{background:var(--primary-color-lighter)}.admin-table.compact td{padding:.75rem 1rem}.text-mono{font-family:Courier New,monospace;font-size:.875rem}.badge{display:inline-block;padding:.375rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-sm{padding:.25rem .5rem;font-size:.7rem}.badge-gray{background:var(--gray-200);color:var(--gray-700)}.badge-blue{background:var(--primary-color-lighter);color:var(--primary-color-dark)}.badge-purple{background:var(--info-color-light);color:var(--info-color)}.badge-gold{background:var(--warning-color-light);color:var(--warning-color)}.badge-green,.badge-success{background:var(--success-color-light);color:var(--success-color)}.badge-warning{background:var(--warning-color-light);color:var(--warning-color)}.badge-danger{background:var(--error-color-light);color:var(--error-color)}.admin-filters{display:flex;align-items:center;gap:1.5rem;margin-bottom:1.5rem;padding:1.5rem;background:var(--background-secondary);border-radius:12px;box-shadow:0 2px 8px #00000014;border:1px solid var(--border-color)}.filter-group{display:flex;align-items:center;gap:.75rem}.filter-group label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.filter-group select{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;background:var(--background-secondary);color:var(--text-primary);cursor:pointer}.filter-info{margin-left:auto;font-size:.875rem;color:var(--text-secondary)}.admin-info{padding:1rem 1.5rem;background:var(--info-color-light);border-left:4px solid var(--info-color);border-radius:6px;margin-bottom:1.5rem;font-size:.875rem;color:var(--text-primary)}.cache-notice{padding:.75rem 1rem;background:var(--warning-color-light);border-left:4px solid var(--warning-color);border-radius:6px;margin-bottom:1.5rem;font-size:.875rem;color:var(--text-primary)}.trend-chart{display:flex;justify-content:space-between;gap:1rem;padding:1rem 0}.trend-item{flex:1;text-align:center}.trend-label{font-size:.75rem;color:var(--text-secondary);margin-bottom:.5rem}.trend-value{font-size:1rem;font-weight:600;color:var(--text-primary)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-tertiary)}.empty-state p{margin:0;font-size:1rem}.loading-spinner{width:50px;height:50px;border:4px solid var(--border-color);border-top:4px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin:3rem auto}.error-message{text-align:center;padding:3rem 1rem}.error-message p{color:var(--error-color);margin-bottom:1rem;font-size:1rem}.error-message button{padding:.75rem 1.5rem;background:var(--primary-color);color:var(--text-on-primary);border:none;border-radius:6px;cursor:pointer;font-weight:500}.error-message button:hover{background:var(--primary-color-dark)}.admin-guard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--background-color)}.admin-guard-loading p{margin-top:1rem;color:var(--text-secondary)}.admin-guard-denied{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--background-color);padding:2rem}.denied-content{text-align:center;background:var(--background-secondary);padding:3rem;border-radius:12px;box-shadow:0 4px 16px #0000001a;max-width:500px;border:1px solid var(--border-color)}.denied-content h1{color:var(--error-color);margin:0 0 1rem}.denied-content p{color:var(--text-secondary);margin:.5rem 0}.denied-content button{margin-top:2rem;padding:.75rem 2rem;background:var(--primary-color);color:var(--text-on-primary);border:none;border-radius:6px;cursor:pointer;font-weight:500}.denied-content button:hover{background:var(--primary-color-dark)}.mobile-menu-toggle{display:none;position:fixed;top:1rem;left:1rem;z-index:1001;background:var(--primary-color);color:var(--text-on-primary);border:none;border-radius:8px;width:48px;height:48px;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px #0003;transition:all .2s}.mobile-menu-toggle:active{transform:scale(.95)}.mobile-menu-toggle span{font-size:24px;line-height:1}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:99}@media (max-width: 1024px){.admin-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.admin-table{font-size:.875rem}.admin-table th,.admin-table td{padding:.75rem}}@media (max-width: 768px){.mobile-menu-toggle{display:flex}.sidebar-overlay.active{display:block}.admin-sidebar{width:280px;position:fixed;height:100vh;left:-280px;top:0;z-index:100;transition:left .3s ease}.admin-sidebar.mobile-open{left:0;box-shadow:4px 0 16px #0003}.admin-content{margin-left:0;padding:5rem 1rem 1rem}.admin-page-header{flex-direction:column;align-items:flex-start;gap:1rem}.admin-page-header h1{font-size:1.5rem}.btn-refresh{width:100%;min-height:48px}.stats-grid{grid-template-columns:1fr;gap:1rem}.stat-card{padding:1.25rem}.stat-value{font-size:1.75rem}.admin-grid{grid-template-columns:1fr;gap:1rem}.admin-filters{flex-direction:column;align-items:stretch;gap:1rem;padding:1rem}.filter-group{flex-direction:column;align-items:stretch;gap:.5rem}.filter-group select{width:100%;padding:.75rem 1rem;min-height:48px;font-size:16px}.filter-info{margin-left:0;text-align:center}.quick-stats{grid-template-columns:1fr}.table-responsive{border-radius:8px;overflow:hidden}.admin-table thead{display:none}.admin-table tbody{display:block}.admin-table tbody tr{display:block;margin-bottom:1rem;background:var(--background-secondary);border-radius:8px;padding:1rem;box-shadow:0 2px 8px #00000014;border:1px solid var(--border-color)}.admin-table tbody tr:hover{background:var(--background-tertiary)}.admin-table td{display:block;padding:.5rem 0;border-bottom:none;text-align:left!important}.admin-table td:before{content:attr(data-label);display:block;font-weight:600;font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.admin-table td:last-child{padding-bottom:0}.badge{padding:.5rem .875rem;font-size:.75rem}.admin-footer button{min-height:48px;font-size:1rem}.admin-nav a{padding:1rem 1.5rem;min-height:48px}.nav-icon{font-size:1.5rem}.trend-chart{overflow-x:auto;-webkit-overflow-scrolling:touch}.trend-item{min-width:100px}}@media (max-width: 480px){.admin-content{padding:4.5rem .75rem .75rem}.admin-page-header h1{font-size:1.25rem}.stat-card{flex-direction:column;text-align:center;padding:1rem}.stat-icon{font-size:2rem}.stat-value{font-size:1.5rem}.admin-filters{padding:.75rem}.admin-card{padding:1rem}.admin-card h2{font-size:1.125rem}.mobile-menu-toggle{top:.75rem;left:.75rem;width:44px;height:44px}}.banner-form{display:flex;flex-direction:column;gap:1.5rem}.banner-form .form-group{display:flex;flex-direction:column;gap:.5rem}.banner-form label{font-weight:600;color:var(--text-primary);font-size:.875rem}.banner-form textarea,.banner-form select{padding:.75rem;border:2px solid var(--border-color);border-radius:8px;font-size:.9375rem;font-family:inherit;background:var(--background-secondary);color:var(--text-primary);transition:all .2s}.banner-form textarea:focus,.banner-form select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-lighter)}.banner-form textarea{resize:vertical;min-height:100px}.form-hint{font-size:.8125rem;color:var(--text-tertiary);font-style:italic}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.form-actions{display:flex;gap:1rem;margin-top:1rem}.banner-meta{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.meta-item{margin:.5rem 0;font-size:.875rem;color:var(--text-secondary)}.meta-item strong{color:var(--text-primary);font-weight:600}.banner-preview{background:var(--background-tertiary);border:2px dashed var(--border-color);border-radius:8px;padding:1.5rem;margin-top:1rem}.preview-description{margin:0 0 1rem;font-size:.875rem;color:var(--text-secondary)}.preview-placeholder{text-align:center;padding:2rem;color:var(--text-tertiary);font-style:italic}.success-message{background:var(--success-color-light);border:1px solid var(--success-color);border-left-width:4px;border-radius:8px;padding:1rem 1.25rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}.success-message:before{content:"✅";font-size:1.25rem;flex-shrink:0}.success-message p{margin:0;color:var(--text-primary);font-weight:500}.inline-edit-select{padding:.375rem .75rem;border:1px solid var(--border-color);border-radius:4px;font-size:.875rem;background:var(--background-secondary);color:var(--text-primary);cursor:pointer;transition:border-color .2s}.inline-edit-select:hover{border-color:var(--primary-color)}.inline-edit-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-lighter)}.inline-edit-select:disabled{background:var(--background-tertiary);cursor:not-allowed;opacity:.6}.action-buttons{display:flex;gap:.5rem;justify-content:center}.btn-edit,.btn-save,.btn-cancel{padding:.375rem .75rem;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;transition:all .2s;min-width:36px;display:flex;align-items:center;justify-content:center}.btn-edit{background:transparent;border:1px solid var(--border-color);color:var(--text-primary)}.btn-edit:hover{background:var(--background-tertiary);border-color:var(--primary-color)}.btn-save{background:var(--success-color);color:var(--text-on-primary);font-weight:600;font-size:1rem}.btn-save:hover:not(:disabled){background:var(--success-color);opacity:.9}.btn-save:disabled{background:var(--gray-400);cursor:not-allowed;opacity:.6}.btn-cancel{background:var(--error-color);color:var(--text-on-primary);font-weight:600;font-size:1rem}.btn-cancel:hover:not(:disabled){background:var(--error-color);opacity:.9}.btn-cancel:disabled{background:var(--gray-400);cursor:not-allowed;opacity:.6}.access-denied{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--background-color);padding:var(--space-6)}.access-denied-content{max-width:500px;text-align:center;background:var(--background-secondary);padding:var(--space-8);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.access-denied-icon{margin:0 auto var(--space-6);color:var(--error-color);display:flex;align-items:center;justify-content:center}.access-denied-icon svg{width:64px;height:64px}.access-denied-title{font-size:2rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-4)}.access-denied-message{font-size:1.125rem;color:var(--text-secondary);margin:0 0 var(--space-4);line-height:1.6}.access-denied-tier{font-size:1rem;color:var(--text-secondary);margin:0 0 var(--space-6)}.access-denied-tier strong{color:var(--primary-color);text-transform:capitalize}.access-denied-actions{display:flex;gap:var(--space-3);justify-content:center;margin-bottom:var(--space-4)}.access-denied-actions .btn-primary{padding:var(--space-3) var(--space-6);font-size:1rem;font-weight:500;min-width:200px}.access-denied-help{font-size:.875rem;color:var(--text-tertiary);margin:0}@media (max-width: 768px){.access-denied{padding:var(--space-4)}.access-denied-content{padding:var(--space-6)}.access-denied-title{font-size:1.5rem}.access-denied-message{font-size:1rem}.access-denied-icon svg{width:48px;height:48px}.access-denied-actions .btn-primary{width:100%;min-width:auto}}.migration-banner{position:fixed;top:80px;left:50%;transform:translate(-50%);z-index:1000;max-width:600px;width:90%;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translate(-50%,-20px)}to{opacity:1;transform:translate(-50%)}}.migration-banner-content{background:linear-gradient(135deg,#5dbbe8,#3a9fd5);color:#fff;border-radius:12px;padding:20px;box-shadow:0 8px 24px #00000026;display:flex;align-items:flex-start;gap:16px;position:relative}.migration-banner-icon{font-size:32px;flex-shrink:0}.migration-banner-body{flex:1;min-width:0}.migration-banner-title{margin:0 0 8px;font-size:18px;font-weight:600}.migration-banner-message{margin:0;font-size:14px;line-height:1.5;opacity:.95}.migration-banner-error{margin:8px 0 0;font-size:14px;color:#ffeb3b;font-weight:500}.migration-banner-actions{display:flex;gap:8px;flex-shrink:0;align-items:center}.migration-banner-btn{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.migration-banner-btn:disabled{opacity:.6;cursor:not-allowed}.migration-banner-btn-primary{background:#fff;color:#5dbbe8}.migration-banner-btn-primary:hover:not(:disabled){background:#f0f0f0;transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.migration-banner-btn-secondary{background:#fff3;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.migration-banner-btn-secondary:hover:not(:disabled){background:#ffffff4d}.migration-banner-close{position:absolute;top:12px;right:12px;background:#fff3;border:none;color:#fff;font-size:18px;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1}.migration-banner-close:hover:not(:disabled){background:#ffffff4d;transform:scale(1.1)}.migration-banner-close:disabled{opacity:.4;cursor:not-allowed}.migration-banner-spinner{display:flex;align-items:center;gap:8px;color:#fff;font-size:14px}@media (max-width: 768px){.migration-banner{top:60px;width:95%}.migration-banner-content{flex-direction:column;padding:16px}.migration-banner-icon{font-size:28px}.migration-banner-title{font-size:16px}.migration-banner-message{font-size:13px}.migration-banner-actions{width:100%;justify-content:stretch}.migration-banner-btn{flex:1;padding:10px 12px}.migration-banner-close{top:8px;right:8px}}.signature-capture{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.signature-type-tabs{display:flex;border-bottom:1px solid #e0e0e0}.signature-tab{flex:1;padding:12px 16px;background:#f8f9fa;border:none;cursor:pointer;font-size:14px;font-weight:500;color:var(--text-secondary);transition:all .2s ease}.signature-tab:hover:not(:disabled){background:#e9ecef}.signature-tab.active{background:#fff;color:#5dbbe8;border-bottom:2px solid #5DBBE8}.signature-tab:disabled{opacity:.5;cursor:not-allowed}.signature-text-input{padding:20px}.signature-input{width:100%;padding:12px 16px;font-size:16px;border:1px solid #e0e0e0;border-radius:6px;outline:none;transition:border-color .2s ease}.signature-input:focus{border-color:#5dbbe8}.signature-input:disabled{background:#f5f5f5;cursor:not-allowed}.signature-preview{margin-top:20px;padding:20px;background:#f8f9fa;border:1px dashed #5DBBE8;border-radius:6px;text-align:center}.signature-text{font-family:Brush Script MT,cursive,serif;font-size:32px;color:#333;font-style:italic}.signature-draw-container{padding:20px;display:flex;flex-direction:column;align-items:center;gap:16px}.signature-canvas{width:100%;max-width:500px;height:200px;border:2px solid #5DBBE8;border-radius:8px;cursor:crosshair;background:#fff;touch-action:none}.signature-canvas:disabled{cursor:not-allowed;opacity:.6}.signature-controls{width:100%;max-width:500px;display:flex;align-items:center;justify-content:space-between;gap:12px}.btn-clear-signature{padding:8px 20px;background:#ef4444;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-clear-signature:hover:not(:disabled){background:#dc2626;transform:translateY(-1px);box-shadow:0 2px 8px #ef44444d}.btn-clear-signature:disabled{background:#d1d5db;cursor:not-allowed;transform:none}.signature-hint{margin:0;font-size:13px;color:var(--text-tertiary);font-style:italic}@media (max-width: 768px){.signature-type-tabs{flex-direction:column}.signature-tab{border-bottom:1px solid #e0e0e0}.signature-tab.active{border-bottom:1px solid #e0e0e0;border-left:3px solid #5DBBE8}.signature-canvas{height:180px}.signature-controls{flex-direction:column;align-items:stretch}.btn-clear-signature{width:100%}.signature-hint{text-align:center}}.public-quote-view{min-height:100vh;background:linear-gradient(135deg,#5dbbe8,#3a9fd5);padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.quote-container{max-width:900px;margin:0 auto;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;overflow:hidden}.quote-header{background:linear-gradient(135deg,#5dbbe8,#3a9fd5);color:#fff;padding:30px 40px;display:flex;justify-content:space-between;align-items:center}.quote-branding h1{margin:0 0 5px;font-size:24px;font-weight:600}.quote-branding p{margin:0;opacity:.9}.quote-content{padding:40px}.quote-info-section{margin-bottom:40px}.quote-meta h2{margin:0 0 20px;font-size:32px;color:#333}.quote-dates{display:flex;gap:30px;flex-wrap:wrap}.quote-dates>div{display:flex;gap:8px}.quote-dates label{color:var(--text-secondary);font-weight:500}.quote-dates span{color:#333}.quote-dates span.expired{color:#ef4444;font-weight:600}.expiry-warning,.success-notice,.decline-notice{margin-top:20px;padding:15px 20px;border-radius:8px;font-weight:500}.expiry-warning{background:#fef3c7;border:1px solid #fbbf24;color:#92400e}.decline-notice{background:#fee2e2;border:1px solid #ef4444;color:#991b1b}.btn-accept{background:#10b981;color:#fff}.btn-accept:hover:not(:disabled){background:#059669;transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.btn-decline{background:#ef4444;color:#fff}.btn-decline:hover:not(:disabled){background:#dc2626;transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.quote-footer{background:#f8f9fa;padding:20px;text-align:center;border-top:1px solid #e0e0e0}.quote-footer p{margin:0;color:var(--text-secondary);font-size:13px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:12px;padding:30px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.modal-content h2{margin:0 0 10px;font-size:24px;color:#333}.modal-content>p{margin:0 0 25px;color:var(--text-secondary)}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333}.form-group input,.form-group textarea{width:100%;padding:12px;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;font-family:inherit;outline:none;transition:border-color .2s ease}.form-group input:focus,.form-group textarea:focus{border-color:#5dbbe8}.form-group input:disabled,.form-group textarea:disabled{background:#f5f5f5;cursor:not-allowed}.form-group textarea{resize:vertical;min-height:80px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:30px}@media (max-width: 768px){.public-quote-view{padding:10px}.quote-header{flex-direction:column;align-items:flex-start;gap:15px;padding:20px}.quote-content{padding:20px}.details-section{grid-template-columns:1fr;gap:20px}.items-table{font-size:13px}.items-table th,.items-table td{padding:8px 6px}.action-buttons{flex-direction:column}.btn{width:100%;justify-content:center}.modal-content{padding:20px}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%}}.legal-disclaimer{border-radius:6px;padding:12px 16px;margin:12px 0;font-size:13px;line-height:1.5}.legal-disclaimer__content{display:flex;gap:12px;align-items:flex-start}.legal-disclaimer__icon{font-size:18px;flex-shrink:0;line-height:1.2}.legal-disclaimer__text{flex:1;min-width:0}.legal-disclaimer__title{display:block;margin-bottom:4px;font-size:14px}.legal-disclaimer__body{margin:0;color:inherit;opacity:.9}.legal-disclaimer__link{display:inline-block;margin-top:8px;font-size:12px;text-decoration:underline;opacity:.8;transition:opacity .2s}.legal-disclaimer__link:hover{opacity:1}.legal-disclaimer--notice{background-color:#fff8e6;border:1px solid #ffc107;color:#856404}.legal-disclaimer--notice .legal-disclaimer__link{color:#664d03}.legal-disclaimer--warning{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.legal-disclaimer--warning .legal-disclaimer__link{color:#491217}.legal-disclaimer--info{background-color:#e7f5ff;border:1px solid #5DBBE8;color:#0c5460}.legal-disclaimer--info .legal-disclaimer__link{color:#0a4a54}.legal-disclaimer--compact{padding:8px 12px;font-size:11px}.legal-disclaimer--compact .legal-disclaimer__icon{font-size:14px}.legal-disclaimer--compact .legal-disclaimer__title{font-size:12px}.legal-disclaimer--payment,.legal-disclaimer--verification{border-left-width:4px}.payment-page-disclaimers{display:flex;flex-direction:column;gap:8px;margin:20px 0}.payment-page-disclaimers .legal-disclaimer{margin:0}.payment-page-disclaimers__footer{text-align:center;padding-top:12px;margin-top:8px;border-top:1px solid #ddd;font-size:12px;color:var(--text-secondary)}.payment-page-disclaimers__footer a{color:#5dbbe8;text-decoration:none}.payment-page-disclaimers__footer a:hover{text-decoration:underline}@media (prefers-color-scheme: dark){.legal-disclaimer--notice{background-color:#3d3200;border-color:#665200;color:#ffc107}.legal-disclaimer--warning{background-color:#3d1217;border-color:#721c24;color:#f8d7da}.legal-disclaimer--info{background-color:#0a2633;border-color:#5dbbe8;color:#b8e2f2}.payment-page-disclaimers__footer{border-color:#444;color:var(--text-tertiary)}}@media (max-width: 480px){.legal-disclaimer{padding:10px 12px;font-size:12px}.legal-disclaimer__content{gap:8px}.legal-disclaimer__icon{font-size:16px}.legal-disclaimer__title{font-size:13px}.legal-disclaimer--compact{padding:6px 10px;font-size:10px}}@media print{.legal-disclaimer{background-color:#f5f5f5!important;border-color:var(--text-tertiary)!important;color:#333!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.legal-disclaimer__link{display:none}}.payment-instructions{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:24px;margin:24px 0}.payment-instructions h3{margin:0 0 20px;color:#212529;font-size:1.5rem;font-weight:600}.payment-instructions h4{margin:16px 0 12px;color:#495057;font-size:1.1rem;font-weight:600}.payment-method-info{margin-bottom:20px}.info-badge{display:inline-block;background:#5dbbe8;color:#fff;padding:8px 16px;border-radius:20px;font-weight:500;font-size:.95rem}.payment-terms-section{background:#fff;border:1px solid #e9ecef;border-radius:6px;padding:16px;margin-bottom:20px}.payment-term{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.payment-term:last-child{margin-bottom:0}.payment-term label{font-weight:600;color:#6c757d;min-width:140px}.payment-term span{color:#212529;font-weight:500}.payment-term .due-date{color:#dc3545;font-weight:600}.bank-details-section{background:#fff;border:2px solid #5dbbe8;border-radius:8px;padding:20px;margin-bottom:20px}.bank-details{display:grid;gap:16px;margin-top:16px}.bank-field{display:flex;flex-direction:column;gap:6px}.bank-field label{font-size:.85rem;font-weight:600;color:#6c757d;text-transform:uppercase;letter-spacing:.5px}.bank-field span{font-size:1rem;color:#212529;padding:10px 12px;background:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;font-family:Courier New,monospace}.bank-field span.copyable{cursor:pointer;transition:background-color .2s}.bank-field span.copyable:hover{background:#e9ecef}.bank-field span.highlight{background:#fff3cd;border-color:#ffc107;font-weight:600}.bank-field span.highlight-primary{background:#cfe2ff;border-color:#0d6efd;color:#084298;font-weight:700;font-size:1.1rem}.bank-field span.capitalize{text-transform:capitalize;font-family:inherit}.bank-field.payment-reference{margin-top:8px;padding-top:16px;border-top:2px solid #e9ecef}.reference-note{display:block;color:#dc3545;font-size:.85rem;margin-top:4px;font-weight:600}.payment-note{background:#d1ecf1;border-left:4px solid #0c5460;padding:12px 16px;margin-top:16px;border-radius:4px}.payment-note p{margin:0;color:#0c5460;font-size:.9rem}.payment-note.info{background:#d1ecf1;border-left-color:#0c5460}.payment-note.info p{color:#0c5460}.qr-payment-section{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:20px;margin-bottom:20px}.qr-payment-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:16px}.qr-option{background:#f8f9fa;border:2px solid #dee2e6;border-radius:8px;padding:16px;text-align:center}.qr-header{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:12px}.qr-logo{font-size:1.5rem}.qr-code-info{margin:12px 0}.qr-code-info label{display:block;font-size:.85rem;color:#6c757d;margin-bottom:4px}.qr-code-info span{font-family:Courier New,monospace;font-weight:600;color:#212529}.qr-code-image{margin-top:12px;padding:12px;background:#fff;border-radius:4px}.qr-code-image img{max-width:100%;height:auto;max-height:200px}.cash-payment-section,.cheque-payment-section{margin-bottom:20px}.cheque-payee{font-size:1.2rem;font-weight:700;color:#0d6efd;margin:8px 0;padding:12px;background:#cfe2ff;border-radius:4px;text-align:center}.custom-instructions-section{background:#fff;border:1px solid #dee2e6;border-radius:8px;padding:20px;margin-bottom:20px}.custom-instructions{background:#f8f9fa;padding:16px;border-left:4px solid #5dbbe8;border-radius:4px;margin-top:12px}.custom-instructions p{margin:0;color:#495057;line-height:1.6;white-space:pre-wrap}.legal-disclaimers-section{margin-top:20px;padding-top:16px;border-top:1px solid #dee2e6}.legal-disclaimers-section .legal-disclaimer{margin:8px 0}.legal-disclaimers-section .legal-disclaimer:first-child{margin-top:0}.compliance-notice{margin-top:20px;padding-top:16px;border-top:1px solid #dee2e6}.compliance-text{font-size:.85rem;color:#6c757d;text-align:center;margin:0;line-height:1.5}@media (max-width: 768px){.payment-instructions{padding:16px}.payment-instructions h3{font-size:1.3rem}.bank-details{gap:12px}.payment-term{flex-direction:column;align-items:flex-start;gap:4px}.payment-term label{min-width:auto}.qr-payment-options{grid-template-columns:1fr}.bank-field span.highlight-primary{font-size:1rem}}@media print{.payment-instructions{background:#fff;border:2px solid #000;page-break-inside:avoid}.bank-field span{background:#fff;border:1px solid #000}.bank-field span.highlight-primary{border:2px solid #000}.payment-note{background:#fff;border:2px solid #000}}.public-invoice-view{min-height:100vh;background:linear-gradient(135deg,#5dbbe8,#3a9fd5);padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.loading-container,.error-container{max-width:600px;margin:100px auto;background:#fff;padding:60px 40px;border-radius:12px;text-align:center;box-shadow:0 10px 40px #0003}.invoice-container{max-width:900px;margin:0 auto;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;overflow:hidden}.invoice-header{background:linear-gradient(135deg,#5dbbe8,#3a9fd5);color:#fff;padding:30px 40px;display:flex;justify-content:space-between;align-items:center}.invoice-branding h1{margin:0 0 5px;font-size:24px;font-weight:600}.invoice-branding p{margin:0;opacity:.9}.invoice-content{padding:40px}.invoice-info-section{margin-bottom:40px}.invoice-meta h2{margin:0 0 20px;font-size:32px;color:#333}.invoice-dates{display:flex;gap:30px;flex-wrap:wrap}.invoice-dates>div{display:flex;gap:8px}.invoice-dates label{color:var(--text-secondary);font-weight:500}.invoice-dates span{color:#333}.invoice-dates span.overdue{color:#ef4444;font-weight:600}.overdue-warning,.success-notice,.cancelled-notice,.partial-payment-notice{margin-top:20px;padding:15px 20px;border-radius:8px;font-weight:500}.overdue-warning{background:#fef3c7;border:1px solid #fbbf24;color:#92400e}.success-notice{background:#d1fae5;border:1px solid #10b981;color:#065f46}.cancelled-notice{background:#fee2e2;border:1px solid #ef4444;color:#991b1b}.partial-payment-notice{background:#dbeafe;border:1px solid #3b82f6;color:#1e3a8a}.details-section{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:40px}.business-details,.customer-details{background:#f8f9fa;padding:20px;border-radius:8px}.business-details h3,.customer-details h3{margin:0 0 15px;font-size:14px;text-transform:uppercase;color:#5dbbe8;font-weight:600}.details-content{color:#333;line-height:1.6}.details-content strong{display:block;font-size:16px;margin-bottom:5px}.details-content p{margin:2px 0;color:var(--text-secondary);font-size:14px}.items-section{margin-bottom:40px}.items-section h3{margin:0 0 20px;font-size:18px;color:#333}.items-table{width:100%;border-collapse:collapse;margin-bottom:20px}.items-table th{background:#5dbbe8;color:#fff;padding:12px;text-align:left;font-weight:600}.items-table th:last-child,.items-table td:last-child{text-align:right}.items-table td{padding:12px;border-bottom:1px solid #e0e0e0}.items-table tbody tr:hover{background:#f8f9fa}.totals-section{max-width:400px;margin-left:auto}.total-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid #e0e0e0}.total-row label{color:var(--text-secondary);font-weight:500}.total-row span{color:#333;font-weight:500}.total-row-final{border-top:2px solid #5DBBE8;border-bottom:none;margin-top:10px;padding-top:15px;font-size:18px;font-weight:700}.total-row-final label,.total-row-final span{color:#5dbbe8}.payment-info-section{margin-bottom:40px;background:#f0f9ff;padding:20px;border-radius:8px;border:1px solid #5DBBE8}.payment-info-section h3{margin:0 0 20px;font-size:18px;color:#333}.payment-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.payment-field{display:flex;flex-direction:column;gap:5px}.payment-field label{color:var(--text-secondary);font-size:13px;font-weight:500;text-transform:uppercase}.payment-field span{color:#333;font-size:15px;font-weight:500;font-family:Courier New,monospace;background:#fff;padding:8px 12px;border-radius:4px;border:1px solid #e0e0e0}.notes-section,.terms-section{margin-bottom:30px}.notes-section h3,.terms-section h3{margin:0 0 15px;font-size:16px;color:#333}.notes-section p,.terms-section p{color:var(--text-secondary);line-height:1.6;white-space:pre-wrap}.action-buttons{display:flex;gap:15px;justify-content:center;margin-top:40px;padding-top:40px;border-top:2px solid #e0e0e0}.btn{padding:14px 32px;font-size:16px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:8px}.btn-pay:hover:not(:disabled){background:#3a9fd5;transform:translateY(-2px);box-shadow:0 4px 12px #5dbbe866}.btn-secondary:hover:not(:disabled){background:#4b5563}.invoice-footer{background:#f8f9fa;padding:20px;text-align:center;border-top:1px solid #e0e0e0}.invoice-footer p{margin:0;color:var(--text-secondary);font-size:13px}@media (max-width: 768px){.public-invoice-view{padding:10px}.invoice-header{flex-direction:column;align-items:flex-start;gap:15px;padding:20px}.invoice-content{padding:20px}.details-section{grid-template-columns:1fr;gap:20px}.items-table{font-size:13px}.items-table th,.items-table td{padding:8px 6px}.payment-details{grid-template-columns:1fr}.action-buttons{flex-direction:column}.btn{width:100%;justify-content:center}}.public-invoice-payment{min-height:100vh;background:linear-gradient(135deg,#5dbbe8,#3a9fd5);padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.payment-container{max-width:700px;margin:0 auto;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;overflow:hidden}.payment-header{background:linear-gradient(135deg,#5dbbe8,#3a9fd5);color:#fff;padding:40px;text-align:center}.header-content h1{margin:0 0 10px;font-size:28px;font-weight:600}.header-subtitle{margin:0;opacity:.9;font-size:16px}.payment-content{padding:40px}.status-notice{text-align:center;padding:60px 40px;border-radius:8px}.status-notice.paid{background:#d1fae5;border:2px solid #10b981}.status-notice.paid h2{color:#065f46;margin:0 0 15px}.status-notice.paid p{color:#047857;margin:0}.status-notice.cancelled{background:#fee2e2;border:2px solid #ef4444}.status-notice.cancelled h2{color:#991b1b;margin:0 0 15px}.status-notice.cancelled p{color:#b91c1c;margin:0}.invoice-summary{background:#f8f9fa;padding:30px;border-radius:8px;margin-bottom:30px}.invoice-summary h2{margin:0 0 25px;font-size:20px;color:#333;border-bottom:2px solid #5DBBE8;padding-bottom:10px}.summary-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #e0e0e0}.summary-row label{color:var(--text-secondary);font-weight:500}.summary-row span{color:#333;font-weight:500}.items-summary{margin:25px 0}.items-summary h3{margin:0 0 15px;font-size:16px;color:#333}.items-list{background:#fff;border-radius:6px;padding:15px}.item-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid #f0f0f0}.item-row:last-child{border-bottom:none}.item-desc{color:#333;flex:1}.item-amount{color:#5dbbe8;font-weight:600;margin-left:20px}.item-row.more-items{color:var(--text-secondary);font-style:italic}.total-amount{display:flex;justify-content:space-between;align-items:center;margin-top:20px;padding-top:20px;border-top:2px solid #5DBBE8}.total-amount label{font-size:18px;font-weight:600;color:#333}.total-amount .amount{font-size:32px;font-weight:700;color:#5dbbe8}.payment-form{background:#fff;border-radius:8px}.payment-form h2{margin:0 0 25px;font-size:20px;color:#333;border-bottom:2px solid #5DBBE8;padding-bottom:10px}.form-group{margin-bottom:25px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333;font-size:14px}.form-group input[type=text],.form-group input[type=email]{width:100%;padding:14px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;font-family:inherit;outline:none;transition:border-color .2s ease}.form-group input:focus{border-color:#5dbbe8}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.form-group small{display:block;margin-top:6px;color:var(--text-secondary);font-size:13px}.checkbox-group{margin-top:30px;margin-bottom:30px}.checkbox-label{display:flex;align-items:flex-start;cursor:pointer;font-weight:400}.checkbox-label input[type=checkbox]{width:20px;height:20px;margin:0 12px 0 0;cursor:pointer;flex-shrink:0}.checkbox-label span{color:#333;line-height:1.5}.btn{width:100%;padding:18px 32px;font-size:18px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-pay{background:#5dbbe8;color:#fff}.btn-pay:hover:not(:disabled){background:#3a9fd5;transform:translateY(-2px);box-shadow:0 6px 20px #5dbbe866}.payment-info{margin-top:30px;text-align:center}.secure-payment{color:#10b981;font-weight:600;margin:0 0 10px;font-size:14px}.payment-methods{color:var(--text-secondary);margin:0;font-size:13px}.payment-footer{background:#f8f9fa;padding:20px;text-align:center;border-top:1px solid #e0e0e0}.payment-footer p{margin:0;color:var(--text-secondary);font-size:13px}.error-container{max-width:600px;margin:100px auto;background:#fff;padding:60px 40px;border-radius:12px;text-align:center;box-shadow:0 10px 40px #0003}.error-container svg{color:#ef4444;margin-bottom:20px}.error-container h2{margin:0 0 10px;color:#333}.error-container p{color:var(--text-secondary);margin:0}@media (max-width: 768px){.public-invoice-payment{padding:10px}.payment-header{padding:30px 20px}.header-content h1{font-size:24px}.payment-content,.invoice-summary{padding:20px}.total-amount{flex-direction:column;align-items:flex-start;gap:10px}.total-amount .amount{font-size:28px}.summary-row,.item-row{flex-direction:column;gap:5px}.item-amount{margin-left:0}}.payment-callback{min-height:100vh;background:linear-gradient(135deg,#5dbbe8,#3a9fd5);padding:40px 20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;display:flex;align-items:center;justify-content:center}.result-container{max-width:600px;width:100%;background:#fff;border-radius:16px;padding:50px 40px;box-shadow:0 10px 40px #0003;text-align:center}.result-icon{margin:0 auto 30px;width:80px;height:80px}.result-container.success .result-icon svg{color:#10b981}.result-container.failed .result-icon svg,.result-container.error .result-icon svg{color:#ef4444}.result-container h1{margin:0 0 15px;font-size:32px;font-weight:700}.result-container.success h1{color:#10b981}.result-container.failed h1,.result-container.error h1{color:#ef4444}.success-message{color:#047857;font-size:16px;margin:0 0 40px;line-height:1.6}.error-message{color:#991b1b;font-size:16px;margin:0 0 30px;line-height:1.6}.receipt{background:#f8f9fa;border-radius:12px;padding:30px;margin:30px 0;text-align:left}.receipt h2{margin:0 0 25px;font-size:20px;color:#333;text-align:center;padding-bottom:15px;border-bottom:2px solid #5DBBE8}.receipt-row{display:flex;justify-content:space-between;padding:15px 0;border-bottom:1px solid #e0e0e0}.receipt-row:last-child{border-bottom:none}.receipt-row label{color:var(--text-secondary);font-weight:500}.receipt-row span{color:#333;font-weight:600}.receipt-row .ref-code{font-family:Courier New,monospace;font-size:14px;background:#fff;padding:4px 8px;border-radius:4px}.receipt-row .amount{color:#5dbbe8;font-size:24px}.receipt-row .capitalize{text-transform:capitalize}.receipt-note{background:#dbeafe;border:1px solid #5DBBE8;border-radius:8px;padding:15px 20px;margin:20px 0}.receipt-note p{margin:0;color:#1e3a8a;font-size:14px}.failure-info{background:#fee2e2;border:1px solid #ef4444;border-radius:8px;padding:20px;margin:20px 0;text-align:left}.failure-info p{margin:0 0 10px;color:#991b1b;font-size:14px}.failure-info p:last-child{margin-bottom:0}.failure-info strong{font-weight:600}.actions{display:flex;gap:15px;justify-content:center;margin-top:40px;flex-wrap:wrap}.btn{padding:14px 32px;font-size:16px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:8px;min-width:150px;justify-content:center}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#5dbbe8;color:#fff}.btn-primary:hover:not(:disabled){background:#3a9fd5;transform:translateY(-2px);box-shadow:0 4px 12px #5dbbe866}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background:#4b5563;transform:translateY(-2px)}.callback-footer{margin-top:40px;padding-top:30px;border-top:1px solid #e0e0e0}.callback-footer p{margin:0;color:var(--text-secondary);font-size:13px}@media (max-width: 768px){.payment-callback{padding:20px 10px}.result-container{padding:40px 20px}.result-container h1{font-size:26px}.result-icon{width:60px;height:60px}.result-icon svg{width:60px;height:60px}.receipt{padding:20px}.receipt-row{flex-direction:column;gap:8px}.receipt-row .amount{font-size:20px}.actions{flex-direction:column}.btn{width:100%}}.pwa-update-prompt{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:10000;animation:slideUp .3s ease-out}.pwa-update-prompt__content{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#1a1a2e;color:#fff;border-radius:12px;box-shadow:0 4px 20px #00000040;max-width:400px}.pwa-update-prompt__icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#5dbbe8;border-radius:10px;flex-shrink:0}.pwa-update-prompt__icon svg{color:#fff}.pwa-update-prompt__text{display:flex;flex-direction:column;gap:2px;flex:1}.pwa-update-prompt__text strong{font-size:14px;font-weight:600}.pwa-update-prompt__text span{font-size:12px;color:#ffffffb3}.pwa-update-prompt__actions{display:flex;gap:8px;flex-shrink:0}.pwa-update-prompt__btn{padding:8px 12px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .2s ease}.pwa-update-prompt__btn--dismiss{background:transparent;color:#ffffffb3}.pwa-update-prompt__btn--dismiss:hover{color:#fff;background:#ffffff1a}.pwa-update-prompt__btn--update{background:#5dbbe8;color:#fff}.pwa-update-prompt__btn--update:hover{background:#4aa8d4}@media (max-width: 480px){.pwa-update-prompt{bottom:10px;left:10px;right:10px;transform:none}.pwa-update-prompt__content{flex-wrap:wrap;max-width:none}.pwa-update-prompt__actions{width:100%;justify-content:flex-end;margin-top:8px}}.offline-indicator{position:fixed;top:0;left:0;right:0;z-index:9999;padding:10px 16px;text-align:center;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.offline-indicator--offline{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.offline-indicator--online{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;animation:slideDown .3s ease-out,fadeOut .3s ease-in 2.5s forwards}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-100%)}}.offline-indicator__content{display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:500}.offline-indicator__icon{flex-shrink:0}.offline-indicator+*{margin-top:44px}@media (max-width: 480px){.offline-indicator{padding:8px 12px}.offline-indicator__content{font-size:13px}.offline-indicator__icon{width:18px;height:18px}}.sync-status-indicator{position:relative}.sync-status-badge{display:flex;align-items:center;gap:4px;padding:6px 10px;border:none;border-radius:20px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s ease;background:#f3f4f6;color:#6b7280}.sync-status-badge:hover{background:#e5e7eb}.sync-status-badge.pending{background:#fef3c7;color:#d97706}.sync-status-badge.syncing{background:#dbeafe;color:#2563eb}.sync-status-badge.synced{background:#d1fae5;color:#059669}.sync-icon{width:16px;height:16px}.sync-icon.spinning{animation:spin 1s linear infinite}.sync-count{min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;background:currentColor;color:#fff;border-radius:50%;font-size:11px;font-weight:600}.sync-status-badge.pending .sync-count{background:#d97706}.sync-details-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999}.sync-details-dropdown{position:absolute;top:100%;right:0;margin-top:8px;width:320px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;z-index:1000;overflow:hidden}.sync-details-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #e5e7eb}.sync-details-header h4{margin:0;font-size:14px;font-weight:600;color:#111827}.sync-details-close{background:none;border:none;font-size:20px;color:#6b7280;cursor:pointer;padding:0 4px;line-height:1}.sync-details-close:hover{color:#111827}.sync-details-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px 16px;color:#059669}.sync-details-empty svg{width:32px;height:32px}.sync-details-list{list-style:none;margin:0;padding:0;max-height:200px;overflow-y:auto}.sync-details-item{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid #f3f4f6}.sync-details-item:last-child{border-bottom:none}.sync-item-info{display:flex;flex-direction:column;gap:2px}.sync-item-description{font-size:13px;color:#374151;text-transform:capitalize}.sync-item-time{font-size:11px;color:#9ca3af}.sync-item-retries{font-size:11px;color:#f59e0b;background:#fef3c7;padding:2px 6px;border-radius:4px}.sync-details-actions{display:flex;gap:8px;padding:12px 16px;background:#f9fafb;border-top:1px solid #e5e7eb}.sync-action-btn{flex:1;padding:8px 12px;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.sync-action-btn:disabled{opacity:.5;cursor:not-allowed}.sync-now-btn{background:#5dbbe8;color:#fff}.sync-now-btn:hover:not(:disabled){background:#4aa8d4}.sync-clear-btn{background:#f3f4f6;color:#6b7280}.sync-clear-btn:hover:not(:disabled){background:#e5e7eb;color:#374151}.sync-offline-notice{padding:10px 16px;background:#fef3c7;color:#92400e;font-size:12px;text-align:center}.sync-notification{position:fixed;bottom:80px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:500;box-shadow:0 4px 12px #00000026;z-index:10000;animation:slideUp .3s ease-out}.sync-notification svg{width:18px;height:18px}.sync-notification--success{background:#059669;color:#fff}.sync-notification--error{background:#dc2626;color:#fff}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (max-width: 480px){.sync-details-dropdown{position:fixed;top:auto;bottom:0;left:0;right:0;width:100%;border-radius:16px 16px 0 0;margin-top:0}.sync-details-list{max-height:40vh}.sync-notification{left:16px;right:16px;transform:none;bottom:16px}}.swipe-edge-glow{position:fixed;top:0;bottom:0;width:8px;pointer-events:none;z-index:900;transition:opacity .1s ease-out}.swipe-edge-glow.left{right:0;background:linear-gradient(to left,var(--cloudcafe-blue),transparent)}.swipe-edge-glow.right{left:0;background:linear-gradient(to right,var(--cloudcafe-blue),transparent)}.swipe-edge-glow.threshold-met{width:12px;background:linear-gradient(to left,var(--success-color),rgba(16,185,129,.3),transparent)}.swipe-edge-glow.threshold-met.left{background:linear-gradient(to left,var(--success-color),rgba(16,185,129,.3),transparent)}.swipe-edge-glow.threshold-met.right{background:linear-gradient(to right,var(--success-color),rgba(16,185,129,.3),transparent)}.swipe-view-preview{position:fixed;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);color:var(--text-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);pointer-events:none;z-index:950;transition:opacity .1s ease-out;max-width:200px}.swipe-view-preview.left{right:20px}.swipe-view-preview.right{left:20px}.swipe-view-preview.threshold-met{background:#10b981f2;color:#fff}.swipe-view-preview .swipe-arrow{font-size:var(--font-size-2xl);line-height:1;animation:swipeArrowPulse .6s ease-in-out infinite}.swipe-view-preview .swipe-view-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.swipe-threshold-indicator{position:fixed;top:120px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:var(--success-color);color:#fff;border-radius:var(--radius-full);box-shadow:var(--shadow-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);pointer-events:none;z-index:1000;animation:slideInFromTop .2s ease-out}.threshold-check{width:20px;height:20px;animation:checkBounce .3s ease-out}.threshold-text{white-space:nowrap}.swipe-hint-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;padding:var(--space-6);animation:fadeIn .3s ease-out}.swipe-hint-content{background:#fff;border-radius:var(--radius-xl);padding:var(--space-8);max-width:400px;width:100%;text-align:center;box-shadow:var(--shadow-xl);animation:scaleIn .3s ease-out}.swipe-hint-icon{width:64px;height:64px;margin:0 auto var(--space-4);color:var(--cloudcafe-blue)}.swipe-hint-icon svg{width:100%;height:100%;animation:swipeIconRotate 2s ease-in-out infinite}.swipe-hint-content h3{margin:0 0 var(--space-3) 0;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--text-primary)}.swipe-hint-content p{margin:0 0 var(--space-6) 0;font-size:var(--font-size-base);color:var(--text-secondary);line-height:var(--line-height-relaxed)}.swipe-hint-examples{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-6)}.swipe-hint-example{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--gray-50);border-radius:var(--radius-base);font-size:var(--font-size-sm);color:var(--text-secondary)}.hint-arrow{font-size:var(--font-size-2xl);color:var(--cloudcafe-blue);font-weight:var(--font-weight-bold);min-width:30px;text-align:center}.swipe-hint-dismiss{width:100%;padding:var(--space-4);background:var(--cloudcafe-blue);color:#fff;border:none;border-radius:var(--radius-base);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.swipe-hint-dismiss:hover{background:var(--cloudcafe-blue-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.swipe-hint-dismiss:active{transform:translateY(0);box-shadow:var(--shadow-xs)}@keyframes swipeArrowPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}}@keyframes slideInFromTop{0%{transform:translate(-50%,-20px);opacity:0}to{transform:translate(-50%);opacity:1}}@keyframes checkBounce{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}@keyframes swipeIconRotate{0%,to{transform:rotate(0)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}@keyframes viewSlideInLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes viewSlideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes viewSlideOutLeft{0%{transform:translate(0);opacity:1}to{transform:translate(-100%);opacity:0}}@keyframes viewSlideOutRight{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.app-main.swipe-transition-left{animation:viewSlideInLeft .3s cubic-bezier(.4,0,.2,1)}.app-main.swipe-transition-right{animation:viewSlideInRight .3s cubic-bezier(.4,0,.2,1)}@media (max-width: 768px){.swipe-view-preview{padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);max-width:150px}.swipe-view-preview.left{right:10px}.swipe-view-preview.right{left:10px}.swipe-view-preview .swipe-arrow{font-size:var(--font-size-xl)}.swipe-threshold-indicator{top:80px;padding:var(--space-2) var(--space-4);font-size:var(--font-size-xs)}.threshold-check{width:16px;height:16px}.swipe-hint-overlay{padding:var(--space-4)}.swipe-hint-content{padding:var(--space-6)}.swipe-hint-icon{width:48px;height:48px}.swipe-hint-content h3{font-size:var(--font-size-xl)}.swipe-hint-content p{font-size:var(--font-size-sm)}}@media (max-width: 480px){.swipe-view-preview{padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs);max-width:120px;gap:var(--space-2)}.swipe-view-preview .swipe-arrow{font-size:var(--font-size-lg)}.swipe-threshold-indicator{font-size:11px;padding:6px var(--space-3)}.swipe-hint-content{padding:var(--space-5)}}@media (prefers-reduced-motion: reduce){.swipe-edge-glow,.swipe-view-preview,.swipe-threshold-indicator,.swipe-hint-overlay,.swipe-hint-content,.app-main{animation:none;transition:none}.swipe-view-preview .swipe-arrow,.swipe-hint-icon svg{animation:none}}.landing-page{width:100%;overflow-x:hidden}.landing-container{max-width:1400px;margin:0 auto;padding:0 var(--space-8);width:100%}.landing-hero{background:linear-gradient(135deg,var(--background-color) 0%,var(--background-secondary) 100%);padding:var(--space-16) var(--space-8);min-height:600px;display:flex;align-items:center;position:relative;overflow:hidden}.landing-hero:before{content:"";position:absolute;top:0;right:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(93,187,232,.1) 0%,transparent 70%);border-radius:50%;pointer-events:none}.landing-hero:after{content:"";position:absolute;bottom:-5%;left:-5%;width:500px;height:500px;background:radial-gradient(circle,rgba(58,143,174,.08) 0%,transparent 70%);border-radius:50%;pointer-events:none}.landing-hero .landing-container{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-16);align-items:center;position:relative;z-index:1}.hero-content{display:flex;flex-direction:column;gap:var(--space-6)}.hero-title{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--text-primary);line-height:var(--line-height-tight);margin:0;animation:slideInFromLeft .6s ease-out}.hero-subtitle{font-size:var(--font-size-xl);color:var(--text-secondary);line-height:var(--line-height-relaxed);margin:0;animation:slideInFromLeft .6s ease-out .1s both}.hero-cta{display:flex;gap:var(--space-4);flex-wrap:wrap;margin-top:var(--space-4);animation:slideInFromLeft .6s ease-out .2s both}.hero-note{font-size:var(--font-size-sm);color:var(--text-tertiary);margin:0;animation:slideInFromLeft .6s ease-out .3s both}.hero-image{animation:slideInFromRight .6s ease-out .15s both}.mockup-placeholder{position:relative;width:100%;aspect-ratio:3/2;display:flex;align-items:center;justify-content:center}.mockup-window{background:var(--background-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden;transition:transform var(--transition-base),box-shadow var(--transition-base)}.mockup-window:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.mockup-header{display:flex;gap:var(--space-2);padding:var(--space-3);background:var(--gray-50);border-bottom:1px solid var(--border-color)}.mockup-dot{width:12px;height:12px;border-radius:50%;background:var(--gray-300)}.mockup-content{flex:1;padding:var(--space-6);overflow:hidden}.mockup-invoice{display:flex;flex-direction:column;gap:var(--space-4)}.mockup-line{height:8px;background:linear-gradient(90deg,var(--cloudcafe-blue-light),var(--gray-200));border-radius:var(--radius-sm)}.mockup-line.short{width:40%}.mockup-line.medium{width:60%}.mockup-line.long{width:100%}.mockup-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);margin-top:var(--space-4)}.mockup-box{height:60px;background:var(--gray-100);border:1px solid var(--border-color);border-radius:var(--radius-base)}.section-header{text-align:center;margin-bottom:var(--space-16)}.section-title{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0 0 var(--space-4) 0;line-height:var(--line-height-tight)}.section-subtitle{font-size:var(--font-size-lg);color:var(--text-secondary);line-height:var(--line-height-normal);max-width:600px;margin:0 auto}.landing-features{background:var(--background-secondary);padding:var(--space-16) var(--space-8)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-8)}.feature-card{background:var(--background-tertiary);padding:var(--space-8);border-radius:var(--radius-lg);border:1px solid var(--border-color-light);transition:all var(--transition-base);display:flex;flex-direction:column;gap:var(--space-4)}.feature-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md);border-color:var(--cloudcafe-blue-light)}.feature-icon{font-size:2.5rem;line-height:1}.feature-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin:0}.feature-description{font-size:var(--font-size-base);color:var(--text-secondary);line-height:var(--line-height-normal);margin:0}.landing-how-it-works{background:linear-gradient(135deg,var(--background-color) 0%,var(--background-secondary) 100%);padding:var(--space-16) var(--space-8)}.steps-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-8)}.step{display:flex;gap:var(--space-6);position:relative}.step:not(:last-child):after{content:"";position:absolute;top:40px;left:calc(50% + 20px);width:calc(100% - 40px);height:2px;background:linear-gradient(90deg,var(--cloudcafe-blue) 0%,transparent 100%);opacity:.3}.step-number{display:flex;align-items:center;justify-content:center;width:80px;height:80px;min-width:80px;border-radius:50%;background:linear-gradient(135deg,var(--cloudcafe-blue) 0%,var(--cloudcafe-blue-dark) 100%);color:#fff;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);box-shadow:var(--shadow-md)}.step-content{flex:1;padding-top:var(--space-2)}.step-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin:0 0 var(--space-2) 0}.step-description{font-size:var(--font-size-base);color:var(--text-secondary);line-height:var(--line-height-normal);margin:0}.landing-pricing{background:var(--background-secondary);padding:var(--space-16) var(--space-8)}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-6);max-width:1600px;margin:0 auto}@media (min-width: 1400px){.pricing-grid{grid-template-columns:repeat(5,1fr)}}.pricing-card{background:var(--background-tertiary);border:2px solid var(--border-color-light);border-radius:var(--radius-lg);padding:var(--space-8);display:flex;flex-direction:column;gap:var(--space-6);position:relative;transition:all var(--transition-base)}.pricing-card:hover{border-color:var(--cloudcafe-blue-light);box-shadow:var(--shadow-md)}.pricing-card.featured{border-color:var(--cloudcafe-blue);background:linear-gradient(135deg,var(--background-secondary) 0%,var(--background-color) 100%);transform:scale(1.05);box-shadow:var(--shadow-lg)}.pricing-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,var(--cloudcafe-blue) 0%,var(--cloudcafe-blue-dark) 100%);color:#fff;padding:var(--space-1) var(--space-4);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);white-space:nowrap}.pricing-header{display:flex;flex-direction:column;gap:var(--space-2)}.pricing-tier{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0}.pricing-price{display:flex;align-items:baseline;gap:var(--space-2)}.price-amount{font-size:2.25rem;font-weight:var(--font-weight-bold);color:var(--cloudcafe-blue)}.price-period{font-size:var(--font-size-base);color:var(--text-secondary);font-weight:var(--font-weight-normal)}.pricing-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-3);flex:1}.pricing-features li{display:flex;align-items:center;gap:var(--space-3);font-size:var(--font-size-base);color:var(--text-secondary);line-height:var(--line-height-normal)}.pricing-features li:before{content:"";flex-shrink:0}.landing-faq{background:var(--background-color);padding:var(--space-16) var(--space-8)}.faq-list{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-4)}.faq-item{background:var(--background-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base)}.faq-item:hover{border-color:var(--cloudcafe-blue-light);box-shadow:var(--shadow-sm)}.faq-item.expanded{border-color:var(--cloudcafe-blue);box-shadow:var(--shadow-md)}.faq-question{width:100%;padding:var(--space-6);background:transparent;border:none;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--text-primary);text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);transition:color var(--transition-base)}.faq-question:hover{color:var(--cloudcafe-blue)}.faq-icon{font-size:1.5rem;flex-shrink:0;transition:transform var(--transition-base);display:flex;align-items:center;justify-content:center;width:24px;height:24px}.faq-item.expanded .faq-icon{transform:rotate(180deg)}.faq-answer{padding:0 var(--space-6) var(--space-6) var(--space-6);border-top:1px solid var(--border-color-light);animation:slideDown .3s ease-out}.faq-answer p{margin:0;color:var(--text-secondary);line-height:var(--line-height-relaxed);font-size:var(--font-size-base)}.landing-cta{background:linear-gradient(135deg,var(--cloudcafe-blue) 0%,var(--cloudcafe-blue-dark) 100%);padding:var(--space-16) var(--space-8);color:#fff}.cta-content{max-width:800px;margin:0 auto;text-align:center;display:flex;flex-direction:column;gap:var(--space-6)}.cta-title{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);margin:0;line-height:var(--line-height-tight)}.cta-subtitle{font-size:var(--font-size-lg);margin:0;line-height:var(--line-height-relaxed);opacity:.95}.cta-buttons{display:flex;gap:var(--space-4);justify-content:center;flex-wrap:wrap}.cta-note{font-size:var(--font-size-sm);margin:0;opacity:.9}.landing-footer{background:var(--gray-900);color:#fff;padding:var(--space-16) var(--space-8) var(--space-8) var(--space-8)}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-12);margin-bottom:var(--space-12)}.footer-section{display:flex;flex-direction:column;gap:var(--space-4)}.footer-logo{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-2)}.footer-logo-img{height:40px;width:auto}.footer-logo-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--cloudcafe-blue-light)}.footer-description{color:var(--gray-400);font-size:var(--font-size-sm);line-height:var(--line-height-normal);margin:0}.footer-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:#fff;margin:0}.footer-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-3)}.footer-links li{display:flex}.footer-links a,.footer-link-btn{color:var(--gray-400);font-size:var(--font-size-sm);text-decoration:none;transition:color var(--transition-base);background:none;border:none;cursor:pointer;padding:0;font-family:inherit}.footer-links a:hover,.footer-link-btn:hover{color:var(--cloudcafe-blue-light)}.footer-bottom{border-top:1px solid var(--gray-800);padding-top:var(--space-8);display:flex;flex-direction:column;gap:var(--space-2);text-align:center}.footer-bottom p{margin:0;color:var(--gray-400);font-size:var(--font-size-sm)}.footer-compliance{color:var(--gray-500);font-size:var(--font-size-xs)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-3) var(--space-6);border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);cursor:pointer;border:none;transition:all var(--transition-base);text-decoration:none;gap:var(--space-2);font-family:inherit}.btn-primary{background:var(--cloudcafe-blue);color:#fff;border:none}.btn-primary:hover{background:var(--cloudcafe-blue-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--gray-50);color:var(--text-primary);border:2px solid var(--border-color)}.btn-secondary:hover{background:var(--gray-100);border-color:var(--cloudcafe-blue);color:var(--cloudcafe-blue);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.btn-secondary:active{transform:translateY(0)}.btn-secondary-light{background:#ffffff1a;color:#fff;border:2px solid rgba(255,255,255,.3)}.btn-secondary-light:hover{background:#fff3;border-color:#ffffff80;transform:translateY(-2px);box-shadow:var(--shadow-sm)}.btn-large{padding:var(--space-4) var(--space-8);font-size:var(--font-size-lg);min-height:48px}@keyframes slideInFromLeft{0%{opacity:0;transform:translate(-40px)}to{opacity:1;transform:translate(0)}}@keyframes slideInFromRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes slideDown{0%{opacity:0;max-height:0;transform:translateY(-10px)}to{opacity:1;max-height:500px;transform:translateY(0)}}@media (max-width: 768px){.landing-container{padding:0 var(--space-4)}.landing-hero{padding:var(--space-12) var(--space-4);min-height:auto}.landing-hero .landing-container{grid-template-columns:1fr;gap:var(--space-8)}.hero-title{font-size:var(--font-size-3xl)}.hero-subtitle{font-size:var(--font-size-lg)}.hero-image,.mockup-window{min-height:300px}.section-header{margin-bottom:var(--space-12)}.section-title{font-size:var(--font-size-3xl)}.section-subtitle{font-size:var(--font-size-base)}.landing-features,.landing-how-it-works,.landing-pricing,.landing-faq,.landing-cta{padding:var(--space-12) var(--space-4)}.features-grid{grid-template-columns:1fr;gap:var(--space-6)}.steps-container{gap:var(--space-6)}.step:not(:last-child):after{display:none}.pricing-card.featured{transform:scale(1)}.pricing-grid{gap:var(--space-6)}.cta-title{font-size:var(--font-size-3xl)}.cta-subtitle{font-size:var(--font-size-base)}.cta-buttons{flex-direction:column;gap:var(--space-3)}.btn{width:100%}.hero-cta{flex-direction:column}.footer-content{gap:var(--space-8)}}@media (max-width: 480px){.landing-container{padding:0 var(--space-3)}.landing-hero{padding:var(--space-8) var(--space-3)}.hero-title{font-size:var(--font-size-2xl)}.hero-subtitle{font-size:var(--font-size-base)}.hero-image,.mockup-window{min-height:240px}.mockup-header{padding:var(--space-2)}.mockup-content{padding:var(--space-4)}.mockup-dot{width:10px;height:10px}.section-title{font-size:var(--font-size-2xl)}.section-subtitle{font-size:var(--font-size-sm)}.landing-features,.landing-how-it-works,.landing-pricing,.landing-faq,.landing-cta{padding:var(--space-8) var(--space-3)}.feature-card{padding:var(--space-6)}.feature-icon{font-size:2rem}.feature-title{font-size:var(--font-size-lg)}.step-number{width:60px;height:60px;min-width:60px;font-size:var(--font-size-xl)}.step-title{font-size:var(--font-size-lg)}.pricing-tier{font-size:var(--font-size-xl)}.price-amount{font-size:1.875rem}.faq-question{padding:var(--space-4);font-size:var(--font-size-sm)}.faq-answer{padding:0 var(--space-4) var(--space-4) var(--space-4)}.cta-title{font-size:var(--font-size-2xl)}.cta-subtitle{font-size:var(--font-size-sm)}.footer-content{gap:var(--space-6)}.footer-logo-img{height:32px}.footer-bottom{padding-top:var(--space-6);gap:var(--space-1)}}@media (max-width: 360px){.hero-title,.section-title{font-size:var(--font-size-xl)}.btn-large{padding:var(--space-3) var(--space-4);font-size:var(--font-size-base)}}:root{--primary-color: #5DBBE8;--primary-color-dark: #4AA5CF;--primary-color-light: #7DD3F5;--primary-color-lighter: #A8DFF5;--secondary-color: #3A8FAE;--secondary-color-dark: #2E7A93;--cloudcafe-blue: #5DBBE8;--cloudcafe-blue-light: #A8DFF5;--cloudcafe-blue-dark: #3A8FAE;--error-color: #EF4444;--error-color-light: #FEE2E2;--success-color: #10B981;--success-color-light: #D1FAE5;--warning-color: #F59E0B;--warning-color-light: #FEF3C7;--info-color: #3B82F6;--info-color-light: #DBEAFE;--gray-50: #F9FAFB;--gray-100: #F3F4F6;--gray-200: #E5E7EB;--gray-300: #D1D5DB;--gray-400: #9CA3AF;--gray-500: #6B7280;--gray-600: #4B5563;--gray-700: #374151;--gray-800: #1F2937;--gray-900: #111827;--background-color: #F8FCFE;--background-secondary: #FFFFFF;--background-tertiary: var(--gray-50);--text-color: var(--gray-900);--text-primary: var(--gray-900);--text-secondary: var(--gray-600);--text-tertiary: var(--gray-500);--text-on-primary: #FFFFFF;--border-color: var(--gray-200);--border-color-dark: var(--gray-300);--border-color-light: var(--gray-100);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: ui-monospace, "Cascadia Mono", "Segoe UI Mono", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.625;--line-height-loose: 2;--radius-sm: .375rem;--radius-base: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-full: 9999px;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px -1px rgba(0, 0, 0, .1);--shadow-base: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--accent-color: #7DD3F5}*,*:before,*:after{box-sizing:border-box}html{overflow-x:hidden;-webkit-text-size-adjust:100%}#root{width:100%;max-width:100vw;margin:0;padding:0;font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}body{background-color:var(--background-color);color:var(--text-primary);margin:0;padding:0;font-size:var(--font-size-base);line-height:var(--line-height-normal);overflow-x:hidden;-webkit-tap-highlight-color:rgba(93,187,232,.1)}input[type=text],input[type=email],input[type=password],input[type=tel],input[type=url],input[type=number],input[type=date],input[type=search],select,textarea{font-size:16px;-webkit-appearance:none;-moz-appearance:none;appearance:none}input[type=text],input[type=email],input[type=password],input[type=tel],input[type=url],input[type=number],input[type=date],input[type=search],select{height:42px;padding:var(--space-2) var(--space-3);border:1px solid var(--gray-300);border-radius:var(--radius-base);background-color:var(--background-secondary);color:var(--text-primary);font-size:16px;font-family:var(--font-family);transition:all var(--transition-base);line-height:1.4;box-sizing:border-box}select{height:44px;padding:var(--space-2) var(--space-3);font-size:16px;line-height:normal}input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,input[type=tel]:focus,input[type=url]:focus,input[type=number]:focus,input[type=date]:focus,input[type=search]:focus,select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #5dbbe81a}textarea{padding:var(--space-3);border:1px solid var(--gray-300);border-radius:var(--radius-base);background-color:var(--background-secondary);color:var(--text-primary);transition:all var(--transition-base);line-height:1.5;min-height:80px;resize:vertical;font-family:inherit;box-sizing:border-box}textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #5dbbe81a}@media (max-width: 768px){button:not(.modal-close),[role=button]{min-height:44px;padding:var(--space-3) var(--space-4)}button,a,input,select,textarea{touch-action:manipulation}}.app{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1;background:var(--background-color)}.app-header{width:100%;background-color:var(--background-secondary);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.header-content{max-width:1400px;margin:0 auto;padding:var(--space-3) var(--space-8);display:flex;justify-content:space-between;align-items:center;min-height:88px;width:100%;overflow:visible}.app-header h1{margin:0;font-size:var(--font-size-xl);color:var(--text-primary);font-weight:var(--font-weight-semibold)}.header-branding{display:flex;align-items:center;gap:var(--space-4)}.header-logo{height:64px;width:auto;display:block}.header-title{display:flex;flex-direction:column;gap:2px;justify-content:center;align-items:center;text-align:center}.header-company{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--cloudcafe-blue);letter-spacing:-.02em;line-height:1.2;margin:0}.header-subtitle{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary);letter-spacing:.03em;line-height:1.3;margin:0}.main-nav{display:flex;gap:var(--space-2)}.nav-button{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:transparent;border:none;border-radius:var(--radius-base);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base);position:relative}.nav-button:hover{background:var(--gray-50);color:var(--text-primary)}.nav-button.active{background:var(--cloudcafe-blue);color:var(--text-on-primary);box-shadow:var(--shadow-sm)}.nav-button svg{flex-shrink:0}.app-actions{display:flex;align-items:center;gap:var(--space-4);position:relative}.user-info{display:flex;align-items:center;gap:var(--space-3)}.user-email{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:var(--font-weight-medium)}.user-tier{padding:var(--space-1) var(--space-3);background:var(--gray-100);border:1px solid var(--border-color);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em}.user-tier-free{background:var(--gray-100);border-color:var(--gray-300);color:var(--gray-600)}.user-tier-basic{background:#dbeafe;border-color:#3b82f6;color:#1e40af}.user-tier-premium{background:linear-gradient(135deg,#f3e8ff,#e9d5ff);border-color:#9333ea;color:#6b21a8}.user-tier-unlimited{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#f59e0b;color:#b45309;box-shadow:0 2px 8px #f59e0b33}.user-tier-cloud{background:linear-gradient(135deg,#5dbbe8,#3a8fae);border-color:#5dbbe8;color:#fff;box-shadow:0 2px 8px #5dbbe84d}.admin-button{background:var(--gray-100);border:1px solid var(--border-color);color:#374151;cursor:pointer;width:40px;height:40px;border-radius:var(--radius-base);display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.admin-button span{display:block;line-height:1;transition:color var(--transition-base)}.admin-button:hover{background:var(--cloudcafe-blue);border-color:var(--cloudcafe-blue);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.admin-button:hover span{color:#fff}.help-button{background:var(--gray-100);border:1px solid var(--border-color);color:#374151;cursor:pointer;width:40px;height:40px;border-radius:var(--radius-base);display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.help-button span{display:block;line-height:1;transition:color var(--transition-base)}.help-button:hover{background:var(--gray-200);border-color:var(--border-color-dark);color:var(--gray-900);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.help-button:hover span{color:var(--gray-900)}.signout-button{padding:var(--space-2) var(--space-4);background:var(--gray-50);border:1px solid var(--border-color);border-radius:var(--radius-base);color:var(--text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base)}.signout-button:hover{background:var(--background-secondary);border-color:var(--border-color-dark);box-shadow:var(--shadow-xs)}.menu-toggle{background:#fff;border:1px solid var(--border-color);color:var(--gray-700);cursor:pointer;width:44px;height:44px;border-radius:var(--radius-base);display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);box-shadow:var(--shadow-xs)}.menu-toggle:hover{background:var(--gray-50);border-color:var(--border-color-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.menu-toggle:active{transform:translateY(0);box-shadow:var(--shadow-xs)}.menu-toggle.online{background:var(--success-color);border-color:var(--success-color);color:#fff}.menu-toggle.online:hover{background:#059669;border-color:#059669;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.menu-toggle.online:active{transform:translateY(0);box-shadow:var(--shadow-xs)}.menu-toggle.offline{background:var(--warning-color);border-color:var(--warning-color);color:#fff}.menu-toggle.offline:hover{background:#d97706;border-color:#d97706;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.menu-toggle.offline:active{transform:translateY(0);box-shadow:var(--shadow-xs)}.menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000004d;z-index:999}.dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:240px;max-height:calc(100vh - 100px);z-index:1000;overflow-y:auto}.dropdown-section{padding:var(--space-4)}.user-section{background:var(--gray-50);border-bottom:1px solid var(--border-color)}.user-section .user-email{display:block;font-size:var(--font-size-sm);color:var(--text-primary);font-weight:var(--font-weight-medium);margin-bottom:var(--space-2)}.dropdown-divider{height:1px;background:var(--border-color)}.dropdown-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);background:none;border:none;color:var(--text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-align:left;cursor:pointer;transition:background var(--transition-base)}.dropdown-item:hover{background:var(--gray-50)}.dropdown-item svg{flex-shrink:0;color:var(--text-secondary)}.signout-item{color:var(--error-color)}.signout-item:hover{background:var(--error-color-light)}.signout-item svg{color:var(--error-color)}.app-footer{width:100%;background:linear-gradient(135deg,var(--cloudcafe-blue) 0%,var(--cloudcafe-blue-dark) 100%);color:#fff;text-align:center;padding:var(--space-6);margin-top:auto}.footer-content{display:flex;flex-direction:column;gap:var(--space-2);align-items:center}.footer-powered{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);opacity:.95}.footer-company{font-size:var(--font-size-sm);opacity:.85;font-weight:var(--font-weight-normal)}.success-message{position:fixed;top:var(--space-5);right:var(--space-5);background-color:var(--success-color);color:#fff;padding:var(--space-4) var(--space-5);border-radius:var(--radius-base);box-shadow:var(--shadow-lg);z-index:1000;display:flex;align-items:center;gap:var(--space-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);animation:slideIn var(--transition-slow) ease-out,fadeOut var(--transition-slow) ease-out 2.7s forwards}.network-notification{position:fixed;top:100px;right:20px;z-index:9999;max-width:400px;padding:16px 20px;border-radius:12px;box-shadow:var(--shadow-lg);animation:slideInNotification .3s ease-out,fadeOut var(--transition-slow) ease-out 4.7s forwards;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.network-notification.online{background-color:#10b981f2;color:#fff}.network-notification.offline{background-color:#ef4444f2;color:#fff}.share-toast{position:fixed;bottom:20px;right:20px;z-index:9999;max-width:320px;padding:14px 18px;border-radius:8px;background-color:#5dbbe8f2;color:#fff;box-shadow:var(--shadow-lg);animation:slideInToast .3s ease-out,fadeOut var(--transition-slow) ease-out 2.7s forwards;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.share-toast-content{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;line-height:1.4}.share-toast svg{flex-shrink:0;color:#fff}.network-notification-content{display:flex;align-items:flex-start;gap:12px}.network-icon{width:24px;height:24px;flex-shrink:0;margin-top:2px}.network-notification-content strong{display:block;font-size:15px;font-weight:600;margin-bottom:4px}.network-notification-content p{font-size:13px;opacity:.9;margin:0;line-height:1.4}@keyframes slideIn{0%{transform:translate(calc(100% + var(--space-5)));opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInNotification{0%{transform:translate(120%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInToast{0%{transform:translateY(120%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0;transform:translateY(-8px)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.icon{margin-right:var(--space-2)}.primary-actions{display:flex;gap:var(--space-3);flex-wrap:wrap}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4)}.modal-content{background-color:var(--background-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-width:500px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--gray-200)}.modal-header h3{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.modal-close{background:none;border:none;font-size:24px;color:var(--text-secondary);cursor:pointer;padding:var(--space-2);line-height:1;transition:color var(--transition-base);margin:calc(var(--space-2) * -1)}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:var(--space-6);overflow-y:auto;flex:1}.modal-body .form-group{margin-bottom:var(--space-5)}.modal-body .form-group:last-child{margin-bottom:0}.modal-body label{display:block;font-weight:var(--font-weight-medium);color:var(--text-primary);margin-bottom:var(--space-2);font-size:var(--font-size-sm)}.modal-body .required{color:var(--error-color)}.modal-body .form-input{width:100%;padding:var(--space-3);border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--font-size-base);color:var(--text-primary);background-color:var(--background-secondary);transition:all var(--transition-base)}.modal-body .form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-lighter)}.modal-body textarea.form-input{resize:vertical;min-height:80px;font-family:inherit}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-6);border-top:1px solid var(--gray-200);background-color:var(--gray-50)}.modal-footer .btn-secondary{padding:var(--space-3) var(--space-5);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--text-primary);background-color:var(--background-secondary);border:1px solid var(--gray-300);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base)}.modal-footer .btn-secondary:hover{background-color:var(--gray-100);border-color:var(--gray-400)}.modal-footer .btn-primary{padding:var(--space-3) var(--space-5);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--text-on-primary);background-color:var(--primary-color);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base)}.modal-footer .btn-primary:hover{background-color:var(--primary-color-dark);box-shadow:var(--shadow-sm)}.modal-footer .btn-primary:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.header-content{padding:var(--space-3) var(--space-4);min-height:60px;gap:var(--space-3);flex-wrap:nowrap}.header-branding{justify-content:flex-start;flex-shrink:0}.header-logo{height:40px}.main-nav{gap:var(--space-1);flex-shrink:1;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.main-nav::-webkit-scrollbar{display:none}.nav-button{min-width:44px;min-height:44px;padding:var(--space-2);flex-shrink:0}.nav-button .nav-text{display:none}.nav-button svg{width:20px;height:20px;margin:0}.app-actions{gap:var(--space-2);position:relative;flex-shrink:0}.user-info{flex-direction:row;align-items:center;gap:var(--space-2);flex:1 1 auto;overflow:hidden}.user-email{font-size:var(--font-size-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.help-button,.admin-button{min-width:44px;min-height:44px}.signout-button{padding:var(--space-3) var(--space-4);min-height:44px}main{padding:var(--space-4)}.primary-actions{flex-direction:column;width:100%}.new-invoice-btn{width:100%;justify-content:center;min-height:44px}.network-notification{top:80px;right:10px;left:10px;max-width:calc(100% - 20px);padding:14px 16px}.network-notification-content{gap:10px}.network-icon{width:20px;height:20px}.network-notification-content strong{font-size:14px}.network-notification-content p{font-size:12px}.share-toast{bottom:16px;right:10px;left:10px;max-width:calc(100% - 20px);padding:12px 14px}.share-toast-content{font-size:13px;gap:8px}.share-toast svg{width:16px;height:16px}.dropdown-menu{min-width:unset;width:calc(100vw - 32px);max-width:280px;right:0}}@media (max-width: 480px){.header-content{padding:var(--space-2) var(--space-3);gap:var(--space-2)}.header-logo{height:32px}.header-company{font-size:var(--font-size-xl)}.main-nav{gap:2px}.nav-button{padding:var(--space-2);font-size:var(--font-size-xs);gap:var(--space-1);min-height:40px;min-width:40px}.nav-button span,.nav-button .nav-text{display:none}.nav-button svg{width:18px;height:18px}.user-email{max-width:120px}.help-button,.admin-button{width:40px;height:40px}.signout-button{font-size:var(--font-size-xs);padding:var(--space-2) var(--space-3)}main{padding:var(--space-3)}.menu-toggle{min-width:40px;min-height:40px}}@media (max-width: 360px){.header-content{padding:var(--space-2);gap:var(--space-1)}.header-logo{height:28px}.nav-button{min-width:36px;min-height:36px;padding:6px}.nav-button svg{width:16px;height:16px}.menu-toggle{min-width:36px;min-height:36px}}.invoice-form-container{max-width:1200px;margin:0 auto;padding:var(--space-6);background-color:var(--background-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-base)}.invoice-form-container h2{color:var(--text-primary);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin:0 0 var(--space-6) 0;line-height:var(--line-height-tight)}.invoice-form-container h3{color:var(--text-primary);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0 0 var(--space-5) 0;line-height:var(--line-height-normal)}.tabs{display:flex;margin-bottom:var(--space-6);border-bottom:2px solid var(--border-color);gap:var(--space-1)}.tab{padding:var(--space-4) var(--space-6);background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--text-secondary);transition:all var(--transition-base);position:relative;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.tab:hover{color:var(--text-primary);background:var(--gray-50)}.tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color);background:var(--background-secondary)}.tab-content{display:none;animation:fadeIn var(--transition-base)}.tab-content.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.form-section{margin-bottom:var(--space-8);padding:var(--space-6);background-color:var(--background-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-color-light);transition:border-color var(--transition-base)}.form-section:hover{border-color:var(--border-color)}.form-section h3{margin-top:0;margin-bottom:var(--space-5);color:var(--text-primary);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);display:flex;align-items:center;gap:var(--space-2)}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-5)}.form-group{margin-bottom:0;display:flex;flex-direction:column}.form-group.full-width{grid-column:span 2}.form-group label{display:block;margin-bottom:var(--space-2);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);color:var(--text-primary);letter-spacing:.01em}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--space-3) var(--space-4);border:2px solid var(--border-color);border-radius:var(--radius-base);font-size:var(--font-size-base);font-family:var(--font-family);color:var(--text-primary);background-color:var(--background-secondary);transition:all var(--transition-base);line-height:var(--line-height-normal)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-tertiary)}.form-group input:hover,.form-group select:hover,.form-group textarea:hover{border-color:var(--border-color-dark)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #5dbbe81a;background-color:var(--background-secondary)}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:var(--gray-50);cursor:not-allowed;opacity:.6}.form-group textarea{resize:vertical;min-height:90px;line-height:var(--line-height-relaxed)}.form-group select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236B7280' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-8)}.error-message{display:flex;align-items:center;gap:var(--space-2);color:var(--error-color);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-top:var(--space-2);line-height:var(--line-height-normal);animation:slideDown .2s ease-out}.error-message:before{content:"⚠";font-size:var(--font-size-base);flex-shrink:0}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.success-message-inline{display:flex;align-items:center;gap:var(--space-2);color:var(--success-color);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-top:var(--space-2);line-height:var(--line-height-normal);animation:slideDown .2s ease-out}.success-message-inline:before{content:"✓";font-size:var(--font-size-base);flex-shrink:0}.form-group input:invalid,.form-group textarea:invalid,.form-group select:invalid{border-color:var(--error-color);background-color:var(--error-color-light)}.form-group input:invalid:focus,.form-group textarea:invalid:focus,.form-group select:invalid:focus{border-color:var(--error-color);box-shadow:0 0 0 3px #ef44441a;outline:none}.form-group:has(.error-message) input,.form-group:has(.error-message) textarea,.form-group:has(.error-message) select{border-color:var(--error-color);background-color:var(--error-color-light);transition:border-color .2s,background-color .2s}.form-group:has(.error-message) input:focus,.form-group:has(.error-message) textarea:focus,.form-group:has(.error-message) select:focus{border-color:var(--error-color);box-shadow:0 0 0 3px #ef44441a;outline:none}.form-group:has(.success-message-inline) input:valid,.form-group:has(.success-message-inline) textarea:valid,.form-group:has(.success-message-inline) select:valid{border-color:var(--success-color);background-color:var(--success-color-light);transition:border-color .2s,background-color .2s}.form-group:has(.success-message-inline) input:focus,.form-group:has(.success-message-inline) textarea:focus,.form-group:has(.success-message-inline) select:focus{border-color:var(--success-color);box-shadow:0 0 0 3px #10b9811a;outline:none}.form-group input.is-valid,.form-group textarea.is-valid,.form-group select.is-valid{border-color:var(--success-color)}.form-group input.is-valid:focus,.form-group textarea.is-valid:focus,.form-group select.is-valid:focus{border-color:var(--success-color);box-shadow:0 0 0 3px #10b9811a;outline:none}.invoice-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-5);margin-bottom:var(--space-6);padding:var(--space-5);background:var(--background-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-color-light)}.invoice-items-header{display:grid;grid-template-columns:3fr 1fr 1fr 1fr 1fr 1fr;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);color:var(--text-secondary);background:var(--gray-100);border-radius:var(--radius-base);text-transform:uppercase;letter-spacing:.05em}.invoice-item{display:grid;grid-template-columns:3fr 1fr 1fr 1fr 1fr 1fr;gap:var(--space-3);padding:var(--space-4);border:2px solid var(--border-color);border-radius:var(--radius-base);align-items:center;margin-bottom:var(--space-3);background:var(--background-secondary);transition:all var(--transition-base)}.invoice-item:hover{border-color:var(--border-color-dark);box-shadow:var(--shadow-sm)}.invoice-item input{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm)}.no-items-message{padding:var(--space-8) var(--space-4);text-align:center;color:var(--text-tertiary);font-style:italic;font-size:var(--font-size-base);background:var(--background-tertiary);border-radius:var(--radius-base);border:2px dashed var(--border-color)}.item-description,.item-quantity,.item-price,.item-tax,.item-amount,.item-actions{padding:0}.calculated-amount{font-weight:var(--font-weight-semibold);color:var(--text-primary);font-size:var(--font-size-base)}.add-item-container{margin-top:var(--space-4);text-align:center}.add-item-btn{background-color:var(--primary-color);color:#fff;border:none;padding:var(--space-3) var(--space-6);border-radius:var(--radius-base);cursor:pointer;font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);transition:all var(--transition-base);box-shadow:var(--shadow-xs);display:inline-flex;align-items:center;gap:var(--space-2)}.add-item-btn:hover{background-color:var(--primary-color-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.add-item-btn:active{transform:translateY(0)}.remove-item-btn{background-color:var(--error-color);color:#fff;border:none;padding:var(--space-2) var(--space-4);border-radius:var(--radius-base);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:all var(--transition-base);white-space:nowrap}.remove-item-btn:hover{background-color:#dc2626;box-shadow:var(--shadow-xs)}.invoice-summary{margin-top:var(--space-6);padding-top:var(--space-6);border-top:2px solid var(--border-color)}.invoice-totals{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-5);padding:var(--space-5);background:var(--background-tertiary);border-radius:var(--radius-md)}.invoice-totals .form-group{margin-bottom:0}.form-actions{margin-top:var(--space-8);padding-top:var(--space-6);border-top:2px solid var(--border-color);text-align:center}.save-btn{background-color:var(--success-color);color:#fff;border:none;padding:var(--space-4) var(--space-8);border-radius:var(--radius-base);cursor:pointer;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);transition:all var(--transition-base);box-shadow:var(--shadow-base);display:inline-flex;align-items:center;gap:var(--space-3);min-width:180px;justify-content:center}.save-btn:hover:not(:disabled){background-color:#059669;box-shadow:var(--shadow-md);transform:translateY(-2px)}.save-btn:active:not(:disabled){transform:translateY(0)}.save-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.invoice-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6);flex-wrap:wrap;gap:var(--space-4)}.new-invoice-btn{background-color:var(--primary-color);color:#fff;border:none;padding:var(--space-3) var(--space-5);border-radius:var(--radius-base);cursor:pointer;font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);transition:all var(--transition-base);box-shadow:var(--shadow-xs);display:inline-flex;align-items:center;gap:var(--space-2)}.new-invoice-btn:hover{background-color:var(--primary-color-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.new-invoice-btn:active{transform:translateY(0)}.saved-invoices{display:flex;align-items:center;gap:var(--space-3);flex:1;max-width:400px}.saved-invoices label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary);white-space:nowrap}.saved-invoices select{flex:1;padding:var(--space-3) var(--space-4);border:2px solid var(--border-color);border-radius:var(--radius-base);font-size:var(--font-size-sm);color:var(--text-primary);background-color:var(--background-secondary);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236B7280' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-8);transition:all var(--transition-base)}.saved-invoices select:hover{border-color:var(--border-color-dark)}.saved-invoices select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #5dbbe81a}.invoice-preview{padding:var(--space-5);background:#f5f5f5;min-height:calc(100vh - 200px);display:flex;flex-direction:column}.invoice-preview h3{margin-bottom:var(--space-6);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--text-primary);text-align:center}.preview-page-wrapper{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:var(--space-8);padding-bottom:var(--space-12);overflow:auto;min-height:100%}.preview-container{width:210mm;min-height:297mm;max-width:100%;margin:var(--space-8) auto;padding:20mm;background-color:#fff;box-shadow:0 0 0 1px #0000001a,0 2px 8px #0000001a,0 8px 24px #00000026;position:relative;transform-origin:top center;border:none;border-radius:0}@media (min-width: 1200px){.preview-container{transform:scale(.85)}}@media (min-width: 1400px){.preview-container{transform:scale(.95)}}@media (min-width: 1600px){.preview-container{transform:scale(1)}}.preview-container .preview-header,#invoice-preview-content .preview-header,.preview-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-10);gap:var(--space-8);width:100%;background:none!important;background-color:transparent!important;background-image:none!important;padding:0!important;min-height:fit-content}.preview-business{flex:1;max-width:50%;min-height:fit-content}.business-logo{margin-bottom:var(--space-3);max-width:120px;max-height:50px;overflow:hidden}.business-logo img{display:block;width:auto;height:auto;max-width:100%;max-height:100%;object-fit:contain}.preview-business h2{margin-top:0;margin-bottom:var(--space-4);color:var(--text-primary);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);background:none!important;padding:0!important}.preview-business p{margin:var(--space-2) 0;color:var(--text-secondary);line-height:var(--line-height-relaxed);font-size:var(--font-size-sm);background:none!important;padding:0!important}.preview-invoice-info{text-align:right;flex-shrink:0}.preview-invoice-info h1{color:var(--primary-color);margin-top:0;margin-bottom:var(--space-4);font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);letter-spacing:-.02em;background:none!important;padding:0!important}.preview-invoice-info p{margin:var(--space-2) 0;font-size:var(--font-size-sm);color:var(--text-secondary);background:none!important}.preview-invoice-info strong{color:var(--text-primary);font-weight:var(--font-weight-semibold)}.preview-client{margin-bottom:var(--space-8);padding:var(--space-5);background:var(--background-tertiary);border-radius:var(--radius-md);border-left:4px solid var(--primary-color)}.preview-client h3{margin-top:0;margin-bottom:var(--space-3);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em}.preview-client p{margin:var(--space-2) 0;line-height:var(--line-height-relaxed);font-size:var(--font-size-sm)}.preview-client strong{font-weight:var(--font-weight-semibold);color:var(--text-primary)}.preview-items{margin-bottom:var(--space-8)}.preview-items table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--border-color);border-radius:var(--radius-base);overflow:hidden}.preview-items th{background-color:var(--gray-100);padding:var(--space-4);text-align:left;font-weight:var(--font-weight-semibold);color:var(--text-primary);font-size:var(--font-size-sm);border-bottom:2px solid var(--border-color)}.preview-items td{padding:var(--space-4);border-bottom:1px solid var(--border-color-light);font-size:var(--font-size-sm);color:var(--text-secondary)}.preview-items tbody tr:last-child td{border-bottom:none}.preview-items tbody tr:hover{background-color:var(--background-tertiary)}.preview-items .no-items{text-align:center;font-style:italic;color:var(--text-tertiary);padding:var(--space-8)}.preview-totals{margin-left:auto;width:350px;padding:var(--space-5);background:var(--background-tertiary);border-radius:var(--radius-md)}.totals-row{display:flex;justify-content:space-between;padding:var(--space-3) 0;border-bottom:1px solid var(--border-color-light);font-size:var(--font-size-base);color:var(--text-secondary)}.totals-row span:first-child{font-weight:var(--font-weight-medium)}.totals-row span:last-child{font-weight:var(--font-weight-semibold);color:var(--text-primary)}.totals-row.total{font-weight:var(--font-weight-bold);font-size:var(--font-size-xl);border-bottom:none;border-top:2px solid var(--primary-color);padding-top:var(--space-4);margin-top:var(--space-2);color:var(--primary-color)}.totals-row.total span{color:var(--primary-color)}.preview-notes,.preview-terms,.preview-payment{margin-top:var(--space-8);padding:var(--space-5);background:var(--background-tertiary);border-radius:var(--radius-md);border-left:4px solid var(--info-color)}.preview-notes h4,.preview-terms h4,.preview-payment h4{color:var(--text-primary);margin-top:0;margin-bottom:var(--space-3);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold)}.preview-notes p,.preview-terms p,.preview-payment p{margin:var(--space-2) 0;color:var(--text-secondary);line-height:var(--line-height-relaxed);font-size:var(--font-size-sm)}.preview-payment strong{font-weight:var(--font-weight-semibold);color:var(--text-primary)}.preview-actions{display:flex;justify-content:center;margin-top:var(--space-8);padding:var(--space-6);background:#f5f5f5;position:sticky;bottom:0;z-index:10}@media (max-width: 1199px){.preview-container{transform:scale(.9)}.preview-page-wrapper{padding:var(--space-4)}}@media (max-width: 900px){.preview-container{transform:scale(.85)}}@media (max-width: 768px){.invoice-preview{padding:0;background:#fff;min-height:auto}.invoice-preview h3{padding:var(--space-4);margin-bottom:0;background:#fff;position:sticky;top:0;z-index:11;box-shadow:0 2px 4px #0000001a}.preview-page-wrapper{padding:0;background:#fff}.preview-container{width:100%;min-height:auto;padding:var(--space-5);box-shadow:none;transform:none}.preview-actions{padding:var(--space-4);background:#fff;border-top:1px solid var(--border-color);position:sticky;bottom:0}.preview-actions button{width:100%;min-height:48px}.preview-items{overflow-x:auto;-webkit-overflow-scrolling:touch}.preview-items table{min-width:600px}.preview-totals{width:100%}}@media (max-width: 480px){.preview-container{padding:var(--space-4)}.preview-header{flex-direction:column;gap:var(--space-6)}.preview-invoice-info{text-align:left}.preview-totals{padding:var(--space-4)}}.invoice-download-button{margin-left:auto}@media print{body *{visibility:hidden}.preview-container,.preview-container *{visibility:visible}.preview-container{position:absolute;left:0;top:0;width:100%;box-shadow:none;border:none;border-radius:0;padding:0}.preview-actions{display:none}}@media (max-width: 1024px){.invoice-items-header,.invoice-item{grid-template-columns:2fr 1fr 1fr 1fr 1fr .8fr;gap:var(--space-2)}}@media (max-width: 768px){.invoice-form-container{padding:var(--space-4);border-radius:var(--radius-base)}.form-grid,.invoice-meta,.invoice-totals{grid-template-columns:1fr;gap:var(--space-4)}.form-group.full-width{grid-column:1}.tabs{overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);white-space:nowrap}.invoice-items-header{display:none}.invoice-item{grid-template-columns:1fr;gap:var(--space-3);padding:var(--space-4)}.invoice-item>div{display:flex;justify-content:space-between;align-items:center}.invoice-item>div:before{content:attr(data-label);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.preview-container{padding:var(--space-5)}.preview-header{flex-direction:column;gap:var(--space-6)}.preview-invoice-info{text-align:left}.preview-totals{width:100%}.invoice-actions{flex-direction:column;align-items:stretch}.saved-invoices{max-width:100%;flex-direction:column;align-items:stretch}.saved-invoices label{text-align:left}}@media (max-width: 480px){.preview-items table{font-size:var(--font-size-xs)}.preview-items th,.preview-items td{padding:var(--space-2)}}.theme-customizer{max-width:900px;margin:0 auto;padding:20px}.theme-customizer h3{margin-bottom:20px;color:var(--color-primary, #2563eb)}.theme-selection-section{display:flex;gap:15px;align-items:flex-end;margin-bottom:20px}.theme-presets{flex:1}.theme-presets select{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:4px;font-size:14px}.create-new-theme-btn{background-color:#10b981;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;white-space:nowrap;transition:background-color .3s}.create-new-theme-btn:hover{background-color:#059669}.theme-name{margin-bottom:20px}.customizer-tabs{display:flex;flex-wrap:wrap;margin-bottom:20px;border-bottom:1px solid #ddd}.customizer-tabs button{padding:10px 20px;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:14px;font-weight:500;color:var(--text-secondary);transition:all .3s}.customizer-tabs button.active{color:var(--color-primary, #2563eb);border-bottom-color:var(--color-primary, #2563eb)}.customizer-content{background-color:#f9fafb;padding:20px;border-radius:8px;margin-bottom:20px}.customizer-content h4{margin-top:0;margin-bottom:15px;color:var(--color-primary, #2563eb)}.customizer-content h5{margin-top:20px;margin-bottom:10px;color:var(--color-secondary, #4b5563)}.color-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.color-picker{margin-bottom:10px}.color-picker label{display:block;margin-bottom:5px;font-weight:500}.color-input-container{display:flex;align-items:center}.color-input-container input[type=color]{width:40px;height:40px;padding:0;border:1px solid #d1d5db;border-radius:4px;margin-right:10px}.color-text-input{flex:1;padding:8px 12px;border:1px solid #d1d5db;border-radius:4px;font-size:14px}.input-field{margin-bottom:15px}.input-field label{display:block;margin-bottom:5px;font-weight:500}.input-field input{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:4px;font-size:14px}.select-field{margin-bottom:15px}.select-field label{display:block;margin-bottom:5px;font-weight:500}.select-field select{width:100%;padding:8px 30px 8px 12px;border:1px solid #d1d5db;border-radius:4px;font-size:14px;background-color:#fff;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.select-field select:hover{border-color:#9ca3af}.select-field select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.typography-grid,.font-size-grid,.font-weight-grid,.spacing-grid,.borders-grid,.visibility-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.toggle-field{margin-bottom:15px;display:flex;align-items:center}.toggle-field input[type=checkbox]{margin-right:10px}.logo-upload,.custom-html,.custom-css{margin-bottom:20px}.logo-preview{margin-top:10px;padding:10px;border:1px dashed #d1d5db;border-radius:4px;display:flex;justify-content:center;background-color:#fff}textarea{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:4px;font-size:14px;font-family:monospace;resize:vertical}.customizer-actions{text-align:center;margin-top:20px}.save-theme-btn{background-color:var(--color-primary, #2563eb);color:#fff;border:none;padding:10px 24px;border-radius:4px;cursor:pointer;font-size:16px;font-weight:500;transition:background-color .3s}.save-theme-btn:hover{background-color:var(--color-primary, #1d4ed8);opacity:.9}@media (max-width: 768px){.theme-selection-section{flex-direction:column;align-items:stretch}.create-new-theme-btn{width:100%}.color-grid,.typography-grid,.font-size-grid,.font-weight-grid,.spacing-grid,.borders-grid,.visibility-grid{grid-template-columns:1fr}.customizer-tabs{overflow-x:auto;white-space:nowrap;padding-bottom:5px}.customizer-tabs button{padding:10px 15px;font-size:13px}}
