:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;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;min-width:320px;min-height:100vh;width:100%}#root{width:100%;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}button{background-color:#f9f9f9}.login-page{min-height:100vh;min-height:100dvh;width:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;box-sizing:border-box}.login-container{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:450px;width:100%;padding:40px}.login-header{text-align:center;margin-bottom:40px}.login-logo{width:80px;height:80px;object-fit:contain;border-radius:12px;margin-bottom:15px}.login-header h1{font-size:28px;margin:0 0 10px;color:#333}.login-header p{font-size:16px;color:#666;margin:0}.login-content{text-align:center;margin-bottom:30px}.login-content h2{font-size:24px;margin:0 0 10px;color:#333}.login-content>p{font-size:14px;color:#666;margin:0 0 30px}.login-button{display:flex;justify-content:center;margin-bottom:20px}.google-signin-btn{display:flex;align-items:center;gap:12px;background:#fff;color:#3c4043;border:1px solid #dadce0;border-radius:4px;padding:12px 24px;font-size:14px;font-weight:500;font-family:Roboto,arial,sans-serif;cursor:pointer;transition:all .2s;box-shadow:0 1px 2px #0000001a}.google-signin-btn:hover{background:#f8f9fa;border-color:#c6c6c6;box-shadow:0 1px 3px #00000026}.google-signin-btn:active{background:#f1f3f4}.login-loading{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px}.login-loading p{margin:0;color:#666;font-size:14px}.login-spinner{width:40px;height:40px;border:3px solid #f0f0f0;border-top:3px solid #667eea;border-radius:50%;animation:login-spin 1s linear infinite}@keyframes login-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{background:#fee;border:1px solid #fcc;border-radius:6px;padding:12px;margin-top:20px}.error-message p{color:#c33;margin:0;font-size:14px}.login-footer{text-align:center;padding-top:20px;border-top:1px solid #eee}.login-footer p{font-size:12px;color:#999;margin:0;line-height:1.5}@media(max-width:480px){.login-page{padding:16px}.login-container{padding:24px 20px}.login-header{margin-bottom:24px}.login-logo{width:70px;height:70px}.login-header h1{font-size:24px}.login-header p{font-size:14px}.login-content{margin-bottom:20px}.login-content h2{font-size:20px}.login-content>p{margin-bottom:20px}.login-footer{padding-top:16px}.login-footer p{font-size:11px}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ask-db-fab{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;cursor:pointer;box-shadow:0 4px 16px #667eea66;display:flex;align-items:center;justify-content:center;z-index:1100;transition:transform .2s,box-shadow .2s}.ask-db-fab:hover{transform:scale(1.08);box-shadow:0 6px 24px #667eea80}.ask-db-fab svg{width:26px;height:26px}.ask-db-overlay{position:fixed;inset:0;background:#0006;z-index:1200;animation:askDbFadeIn .2s ease}@keyframes askDbFadeIn{0%{opacity:0}to{opacity:1}}.ask-db-panel{position:fixed;top:0;right:0;bottom:0;width:520px;max-width:100vw;background:#fff;z-index:1300;display:flex;flex-direction:column;box-shadow:-4px 0 24px #00000026;animation:askDbSlideIn .25s ease}@keyframes askDbSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.ask-db-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e9ecef;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.ask-db-header h3{margin:0;font-size:16px;font-weight:600}.ask-db-close{background:#fff3;border:none;color:#fff;cursor:pointer;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;transition:background .15s}.ask-db-close:hover{background:#ffffff59}.ask-db-input-area{padding:16px 20px;border-bottom:1px solid #e9ecef;display:flex;gap:10px}.ask-db-input{flex:1;padding:10px 14px;border:1px solid #ddd;border-radius:8px;font-size:14px;outline:none;transition:border-color .15s}.ask-db-input:focus{border-color:#667eea}.ask-db-input::placeholder{color:#999}.ask-db-submit{padding:10px 18px;background:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;white-space:nowrap;transition:background .15s}.ask-db-submit:hover:not(:disabled){background:#5a6fd6}.ask-db-submit:disabled{opacity:.6;cursor:not-allowed}.ask-db-results{flex:1;overflow-y:auto;padding:20px}.ask-db-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 20px;color:#666;font-size:14px}.ask-db-spinner{width:32px;height:32px;border:3px solid #e9ecef;border-top:3px solid #667eea;border-radius:50%;animation:askDbSpin .8s linear infinite}@keyframes askDbSpin{to{transform:rotate(360deg)}}.ask-db-error{padding:14px 16px;background:#fff5f5;color:#c53030;border:1px solid #feb2b2;border-radius:8px;font-size:13px}.ask-db-answer{font-size:14px;line-height:1.6;color:#333}.ask-db-answer h1,.ask-db-answer h2,.ask-db-answer h3{margin:12px 0 8px;color:#222}.ask-db-answer p{margin:8px 0}.ask-db-answer ul,.ask-db-answer ol{padding-left:20px;margin:8px 0}.ask-db-answer table{width:100%;border-collapse:collapse;margin:12px 0;font-size:13px}.ask-db-answer th,.ask-db-answer td{padding:8px 12px;border:1px solid #e9ecef;text-align:left}.ask-db-answer th{background:#f7f8fa;font-weight:600;color:#555}.ask-db-answer tr:hover{background:#f9f9fb}.ask-db-answer strong{color:#222}.ask-db-table-wrapper{overflow-x:auto;margin-top:8px}.ask-db-table{width:100%;border-collapse:collapse;font-size:13px}.ask-db-table th,.ask-db-table td{padding:8px 12px;border:1px solid #e9ecef;text-align:left;white-space:nowrap}.ask-db-table th{background:#f7f8fa;font-weight:600;color:#555;position:sticky;top:0}.ask-db-table tr:hover{background:#f9f9fb}.ask-db-table-info{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;font-size:13px;color:#666}.ask-db-csv-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:#f0fdf4;color:#166534;border:1px solid #bbf7d0;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:background .15s}.ask-db-csv-btn:hover{background:#dcfce7}.ask-db-sql-toggle{margin-top:16px;border-top:1px solid #e9ecef;padding-top:12px}.ask-db-sql-toggle button{background:none;border:none;color:#667eea;cursor:pointer;font-size:12px;padding:0}.ask-db-sql-toggle button:hover{text-decoration:underline}.ask-db-sql-code{margin-top:8px;padding:12px;background:#f7f8fa;border-radius:6px;font-family:Courier New,monospace;font-size:12px;color:#555;white-space:pre-wrap;word-break:break-all}.ask-db-model-info{margin-top:8px;font-size:11px;color:#999}.ask-db-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#999;text-align:center}.ask-db-empty svg{width:48px;height:48px;margin-bottom:12px;opacity:.4}.ask-db-empty p{margin:4px 0;font-size:14px}.ask-db-empty .ask-db-hint{font-size:12px;color:#bbb;margin-top:8px}@media(max-width:768px){.ask-db-fab{bottom:80px;right:16px;width:50px;height:50px}.ask-db-panel{width:100vw}}.layout{height:100vh;display:flex;flex-direction:column;background:#f5f5f5;overflow:hidden}.header{flex-shrink:0;z-index:100;background:#fff;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center;padding:0 40px;height:70px}.header-left{display:flex;align-items:center;gap:30px}.logo{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:600;color:#333}.logo-img{width:40px;height:40px;object-fit:contain;border-radius:6px}.nav-tabs{display:flex;gap:5px}.nav-tab{padding:10px 20px;text-decoration:none;color:#666;font-weight:500;font-size:14px;border-radius:6px;transition:all .2s}.nav-tab:hover{background:#f0f0f0;color:#333}.nav-tab.active{background:#667eea;color:#fff}.header-right{display:flex;align-items:center;gap:15px}.user-avatar{width:40px;height:40px;border-radius:50%}.user-info{text-align:right}.user-name{margin:0;font-size:14px;font-weight:600;color:#333}.user-role{margin:0;font-size:12px;color:#666}.sign-out-btn{background:#667eea;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500}.sign-out-btn:hover{background:#5568d3}.main-content{flex:1;padding:30px 40px;width:100%;max-width:100%;box-sizing:border-box;overflow-y:auto}.app-footer{text-align:center;padding:20px;margin-top:40px;font-size:12px;color:#999}.app-footer .brand-name{color:#667eea;font-weight:500}@media(max-width:768px){.layout{padding-bottom:65px}.header{flex-direction:row;height:60px;padding:0 15px;gap:10px}.header-left{flex:1}.logo span{display:inline;font-size:16px}.logo-img{width:36px;height:36px}.nav-tabs{display:none}.header-right{gap:10px}.user-info{display:none}.user-avatar{width:32px;height:32px}.sign-out-btn{padding:6px 12px;font-size:12px}.main-content{padding:15px 15px 80px}}@media(max-width:768px){.nav-tabs{display:flex!important;position:fixed;bottom:0;left:0;right:0;background:#fff;box-shadow:0 -2px 10px #0000001a;padding:8px 5px;justify-content:space-around;z-index:1000;gap:2px}.nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px;font-size:11px;border-radius:8px;text-align:center;min-width:0}.nav-tab.active{background:#667eea;color:#fff}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px}.loading-container.full-page{min-height:50vh}.spinner{width:48px;height:48px;border:4px solid #e9ecef;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-message{margin:0;font-size:16px;color:#666;font-weight:500}.modal-header .lead-display-id{background:#667eea;color:#fff;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:500}.form-group input,.form-group select{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea}.form-group textarea{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit;resize:vertical;min-height:80px;transition:border-color .2s}.form-group textarea:focus{outline:none;border-color:#667eea}.print-only-header,.print-only-text{display:none}.screen-only{display:block}.visit-display-id{background:#667eea;color:#fff;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:500}.btn-print{background:#4caf50;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:4px}.btn-print:hover{background:#43a047}.field-visit-modal .form-grid.metadata{grid-template-columns:repeat(3,1fr)}.required{color:#dc3545;margin-left:2px}.checkbox-group{flex-direction:row;align-items:center}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px}.multi-select-container{border:1px solid #ddd;border-radius:6px;padding:8px 12px;min-height:42px;background:#fff}.multi-select-container.disabled{background:#f5f5f5}.chips-container{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.chip{display:inline-flex;align-items:center;gap:4px;background:#e8f0fe;color:#1a73e8;padding:4px 10px;border-radius:16px;font-size:13px;font-weight:500}.chip-remove{background:none;border:none;color:#1a73e8;font-size:16px;cursor:pointer;padding:0 2px;line-height:1}.chip-remove:hover{color:#c00}.add-user-select{background:#667eea;color:#fff;border:none;padding:4px 12px;border-radius:16px;font-size:13px;cursor:pointer}.add-user-select:hover{background:#5568d3}.add-user-select option{background:#fff;color:#333}.empty-placeholder{color:#999;font-style:italic;font-size:13px}.locked-indicator{margin-left:8px;font-size:12px;color:#666}.problems-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:12px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px}.problems-grid.disabled{background:#f5f5f5}.problem-checkbox-label{display:flex;align-items:flex-start;gap:6px;padding:6px 10px;background:#fff;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .2s}.problem-checkbox-label:hover:not(.disabled){border-color:#667eea;background:#f8f9ff}.problem-checkbox-label input[type=checkbox]{margin-top:3px;width:18px;height:18px;flex-shrink:0;cursor:pointer}.problem-checkbox-label input[type=checkbox]:disabled{cursor:default}.problem-text{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.problem-en{font-size:13px;font-weight:500;color:#333;line-height:1.3}.problem-kn{font-size:12px;color:#666;line-height:1.3}.help-text{font-size:12px;color:#666;font-style:italic;margin:8px 0 0}.selected-count{font-size:13px;color:#667eea;font-weight:500;margin:8px 0 0}@media(max-width:600px){.modal-overlay{padding:0;align-items:flex-end}.modal-content{max-height:95vh;border-radius:12px 12px 0 0}.form-grid,.form-grid.metadata{grid-template-columns:1fr}.modal-footer{flex-direction:column}.btn-cancel,.btn-save{width:100%}.problems-grid{grid-template-columns:1fr}}@media print{@page{margin:.3cm;size:A4}body *{visibility:hidden}.modal-overlay,.modal-overlay *{visibility:visible}body{margin:0!important;padding:0!important}.modal-overlay{position:absolute!important;top:0!important;left:0!important;width:100%!important;height:auto!important;background:none!important;padding:0!important;margin:0!important;display:block!important}.modal-content{max-width:100%!important;max-height:none!important;height:auto!important;box-shadow:none!important;border-radius:0!important;margin:0!important;padding:0!important;display:block!important}.print-only-header{display:block;text-align:center;padding:5px 0 8px;border-bottom:2px solid #333;margin:0 0 10px}.print-only-header h1{margin:0 0 3px;font-size:20px;color:#333}.print-only-header p{margin:2px 0;font-size:12px;color:#666}.print-date{font-size:9px!important;color:#999!important}.modal-header{border-bottom:1px solid #333;padding:5px 0 6px;margin-bottom:8px}.modal-header h2{font-size:16px;margin:0}.visit-display-id{background:#333;font-size:11px;padding:3px 10px}.no-print,.modal-close,.btn-print,.modal-footer{display:none!important}.modal-body{padding:0!important;overflow:visible!important;margin:0!important;max-height:none!important;height:auto!important;min-height:0!important;flex:none!important;display:block!important}.modal-header{margin:0;padding:8px 0}.modal-form{display:block!important;flex:none!important;min-height:0!important}.form-section{page-break-inside:auto;page-break-before:auto;page-break-after:auto;margin-bottom:8px;padding:0}.form-section:not(:last-child){page-break-before:auto!important;page-break-after:auto}.form-section h3{color:#333;border-bottom:1px solid #333;font-size:14px;margin:0 0 6px;padding-bottom:3px}.form-section:not(:last-child){orphans:3;widows:3}.form-grid{gap:6px;margin-bottom:4px}.form-group{margin-bottom:3px}.form-group.full-width{margin-bottom:4px}.form-group label{font-weight:700;color:#333;font-size:11px;margin:0 0 1px;padding:0;line-height:1.2}.form-group input,.form-group select,.form-group textarea{border:none;background:none;padding:1px 0;font-size:11px;color:#000;line-height:1.3;margin:0;overflow:visible}.form-group select{height:auto;-webkit-appearance:none;-moz-appearance:none;appearance:none}.screen-only{display:none!important}.print-only-text{display:block!important;width:100%!important;white-space:pre-wrap!important;word-wrap:break-word!important;border:1px solid #ddd!important;padding:4px!important;line-height:1.4!important;font-size:11px!important;color:#000!important;min-height:20px!important}.metadata-value{padding:1px 0;font-size:11px;line-height:1.3}.lead-info-readonly{background:none;border:1px solid #ddd;padding:6px}.lead-info-row{padding:2px 0}.lead-info-row .label,.lead-info-row .value{font-size:11px}.selected-lead-info{background:none;border:1px solid #ddd;padding:6px}.status-badge{border:1px solid #333}.problems-grid{background:none;border:1px solid #ddd;padding:6px;gap:4px;page-break-inside:auto}.problem-checkbox-label{border:1px solid #ddd;padding:3px 6px;background:none;page-break-inside:avoid}.problem-checkbox-label input[type=checkbox]{-webkit-print-color-adjust:exact;print-color-adjust:exact;width:14px;height:14px;margin-top:1px}.problem-en{font-size:10px;line-height:1.2}.problem-kn{font-size:9px;line-height:1.2}.chip{background:#eee;border:1px solid #999;-webkit-print-color-adjust:exact;print-color-adjust:exact;padding:2px 8px;font-size:10px}.multi-select-container{border:1px solid #ddd;background:none;padding:4px;min-height:auto}.file-attachment-view,.uploaded-file{border:1px solid #ddd;padding:8px;background:none}.selected-count,.help-text{font-size:9px;color:#666;margin:2px 0 0}body{margin:0;padding:0}*{box-sizing:border-box}.form-group input[type=datetime-local],.form-group input[type=date]{padding:0!important;height:auto!important;line-height:1.2!important}select::-ms-expand{display:none}}.modal-content{background:#fff;border-radius:12px;max-width:700px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026}.quotation-display-id{background:#667eea;color:#fff;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:500}.lead-info-readonly{background:#f8f9fa;padding:16px;border-radius:8px}.lead-info-row{display:flex;gap:12px;padding:6px 0}.lead-info-row .label{font-weight:500;color:#666;min-width:80px}.lead-info-row .value{color:#333}.selected-lead-info{grid-column:1 / -1;background:#e8f5e9;padding:12px 16px;border-radius:6px;font-size:14px}.selected-lead-info p{margin:4px 0;color:#2e7d32}.visit-info-hint{margin-top:8px;font-size:12px;color:#666;background:#f5f5f5;padding:8px 12px;border-radius:4px}.lead-search-container{position:relative}.lead-search-input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px}.lead-search-input:focus{outline:none;border-color:#667eea}.lead-dropdown{position:absolute;top:100%;left:0;right:0;max-height:250px;overflow-y:auto;background:#fff;border:1px solid #ddd;border-top:none;border-radius:0 0 6px 6px;box-shadow:0 4px 12px #00000026;z-index:100}.lead-dropdown-loading,.lead-dropdown-empty{padding:12px 16px;color:#666;font-size:14px;text-align:center}.lead-dropdown-item{display:flex;flex-direction:column;gap:2px;padding:10px 16px;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background .15s}.lead-dropdown-item:last-child{border-bottom:none}.lead-dropdown-item:hover{background:#f5f5f5}.lead-dropdown-item.selected{background:#e8f0fe}.lead-dropdown-item .lead-display-id{background:none;padding:0;border-radius:0;font-weight:600;color:#667eea;font-size:12px}.lead-dropdown-item .lead-name{font-weight:500;color:#333;font-size:14px}.lead-dropdown-item .lead-location{font-size:12px;color:#666}.selected-lead-display{padding:10px 12px;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;font-size:14px;color:#333}.file-attachment-view{display:flex;gap:12px}.file-link{display:inline-block;padding:8px 16px;background:#667eea;color:#fff;text-decoration:none;border-radius:6px;font-size:13px;font-weight:500}.file-link:hover{background:#5568d3}.file-link.download{background:#4caf50}.file-link.download:hover{background:#43a047}.no-file{color:#999;font-style:italic;font-size:14px}.file-upload-container{margin-top:4px}.uploaded-file{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#e8f5e9;border:1px solid #c8e6c9;border-radius:6px}.file-name{font-size:14px;color:#2e7d32;font-weight:500}.file-actions{display:flex;gap:8px;align-items:center}.file-actions .file-link{padding:4px 12px;font-size:12px}.btn-remove-file{background:#f44336;color:#fff;border:none;padding:4px 12px;border-radius:4px;font-size:12px;cursor:pointer}.btn-remove-file:hover{background:#d32f2f}.file-input-wrapper{display:flex;align-items:center;gap:12px}.file-input-wrapper input[type=file]{font-size:14px}.uploading-text{color:#667eea;font-size:13px;font-weight:500}.line-items-table-wrapper{overflow-x:auto}.line-items-table{width:100%;border-collapse:collapse;font-size:14px}.line-items-table th{background:#f8f9fa;padding:8px 12px;text-align:left;font-size:12px;font-weight:600;color:#666;text-transform:uppercase;border-bottom:2px solid #e9ecef}.line-items-table td{padding:8px 12px;border-bottom:1px solid #f0f0f0}.line-items-table .num-col,.line-items-table th.num-col{text-align:right}.line-items-table tfoot td{border-top:2px solid #e9ecef;border-bottom:none;font-weight:600}.total-label{text-align:right;color:#666}.total-value{color:#2e7d32;font-weight:600}.line-items-editor{display:flex;flex-direction:column;gap:12px}.line-item-row{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:12px}.line-item-fields{display:flex;gap:10px;align-items:flex-end}.li-field{display:flex;flex-direction:column;gap:4px}.li-field label{font-size:11px;color:#888;font-weight:500}.li-field select,.li-field input{padding:8px 10px;border:1px solid #ddd;border-radius:4px;font-size:13px}.li-field select:focus,.li-field input:focus{outline:none;border-color:#667eea}.li-product{flex:2;min-width:0}.li-product select{width:100%}.li-qty{width:70px;flex-shrink:0}.li-qty input{width:100%}.li-price{width:100px;flex-shrink:0}.li-price input{width:100%}.li-subtotal{width:100px;flex-shrink:0}.li-subtotal-value{padding:8px 10px;background:#e8f5e9;border-radius:4px;font-size:13px;font-weight:600;color:#2e7d32;white-space:nowrap}.btn-remove-line-item{background:none;border:none;color:#f44336;font-size:22px;cursor:pointer;padding:0 4px;line-height:1;flex-shrink:0;align-self:flex-end;margin-bottom:4px}.btn-remove-line-item:hover{color:#d32f2f}.btn-add-line-item{background:#fff;border:1px dashed #667eea;color:#667eea;padding:10px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;width:100%}.btn-add-line-item:hover{background:#f0f4ff}.line-items-total{display:flex;justify-content:flex-end;align-items:center;gap:12px;padding:12px 0;font-size:16px;font-weight:600;border-top:2px solid #e9ecef}.line-items-total .total-value{font-size:18px;color:#2e7d32}.amount-display.computed{display:flex;flex-direction:column;gap:4px}.computed-hint{font-size:11px;color:#888;font-weight:400}@media(max-width:600px){.modal-overlay{padding:0;align-items:flex-end}.modal-content{max-height:95vh;border-radius:12px 12px 0 0}.form-grid,.form-grid.metadata{grid-template-columns:1fr}.modal-footer{flex-direction:column}.btn-cancel,.btn-save{width:100%}.line-item-fields{flex-wrap:wrap}.li-product{flex:1 1 100%}.li-qty,.li-price,.li-subtotal{flex:1;width:auto}}.btn-print{background:#ff9800;color:#fff;border:none;padding:6px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer}.btn-print:hover{background:#f57c00}.print-only{display:none}@media print{@page{margin:5mm;size:A4}body *{visibility:hidden}.modal-overlay,.modal-overlay *{visibility:visible}.modal-overlay{position:absolute;inset:0 0 auto;background:none;padding:0;display:block}.modal-content{position:relative;max-width:100%;max-height:none;border-radius:0;box-shadow:none;overflow:visible}.modal-form,.modal-header,.modal-error,.modal-footer,.no-print{display:none!important}.print-only{display:block!important}.quotation-print{padding:0;font-family:Segoe UI,Arial,sans-serif;color:#000;font-size:13px;line-height:1.5}.print-header-img,.print-footer-img{width:100%;max-width:100%;height:auto}.print-header-img{margin-bottom:8px}.print-footer-img{margin-top:16px}.print-doc-info{border:1px solid #000;padding:8px 12px;margin-bottom:12px}.print-doc-row{display:flex;justify-content:space-between}.print-customer-info{margin-bottom:12px;padding:8px 0;border-bottom:1px solid #ccc}.print-customer-info p{margin:3px 0}.print-problems-section{margin-bottom:12px}.print-problems-section p{margin:6px 0}.print-crop-info{margin-bottom:12px;padding:6px 0}.print-crop-info p{margin:3px 0}.print-materials-section{margin-bottom:16px}.print-materials-section p{margin:6px 0}.print-materials-list{margin:4px 0 12px;padding-left:20px;list-style-type:disc}.print-materials-list li{margin:4px 0;font-size:12px;line-height:1.4}.print-category-section{margin-bottom:16px;page-break-inside:avoid}.print-category-title{font-size:14px;font-weight:600;margin:8px 0;padding:4px 8px;background:#f0f0f0;-webkit-print-color-adjust:exact;print-color-adjust:exact}.print-items-table{width:100%;border-collapse:collapse;font-size:12px;margin-bottom:4px}.print-items-table th{background:#e8e8e8;-webkit-print-color-adjust:exact;print-color-adjust:exact;border:1px solid #000;padding:6px 8px;text-align:left;font-weight:600}.print-items-table td{border:1px solid #000;padding:5px 8px}.print-items-table .num-col,.print-items-table th.num-col{text-align:right}.print-items-table tfoot td{font-weight:600}.print-grand-total{margin:12px 0;padding:10px;border:2px solid #000;text-align:center}.print-grand-total p{margin:4px 0}.amount-words{font-style:italic;font-size:12px}.cost-per-plant{font-size:12px;color:#444}.print-notes-section,.print-usage-section{margin:12px 0;padding:8px 0;border-top:1px solid #ccc}.print-notes-section p,.print-usage-section p{margin:4px 0}}.modal-content{background:#fff;border-radius:12px;max-width:750px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026}.modal-header{display:flex;align-items:center;gap:15px;padding:20px 24px;border-bottom:1px solid #e9ecef;background:#fff;border-radius:12px 12px 0 0;flex-shrink:0}.payment-display-id{background:#2e7d32;color:#fff;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:500}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e9ecef;background:#fff;border-radius:0 0 12px 12px;flex-shrink:0}.form-section{margin-bottom:24px}.payment-modal .form-section h3{font-size:14px;font-weight:600;color:#2e7d32;text-transform:uppercase;margin:0 0 16px;padding-bottom:8px;border-bottom:2px solid #e9ecef}.form-grid.metadata{grid-template-columns:repeat(2,1fr)}.form-group label .max-hint{font-weight:400;color:#888;font-size:12px}.payment-modal .form-group input:focus,.payment-modal .form-group select:focus,.payment-modal .form-group textarea:focus{outline:none;border-color:#2e7d32}.quote-info-readonly{background:#f8f9fa;padding:16px;border-radius:8px}.quote-info-row{display:flex;gap:12px;padding:6px 0}.quote-info-row .label{font-weight:500;color:#666;min-width:100px}.quote-info-row .value{color:#333}.quote-info-row .value.amount{font-weight:600;color:#2e7d32}.selected-quote-info{grid-column:1 / -1;background:#e8f5e9;padding:12px 16px;border-radius:6px;font-size:14px}.selected-quote-info p{margin:4px 0;color:#2e7d32}.payment-summary{background:#f8f9fa;padding:16px;border-radius:8px;margin-bottom:16px}.summary-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #e9ecef}.summary-row:last-child{border-bottom:none;padding-bottom:0}.summary-label{font-weight:500;color:#666}.summary-value{font-weight:600;color:#333}.summary-value.paid{color:#2e7d32}.summary-value.remaining{color:#e65100}.summary-value.fully-paid{color:#2e7d32}.existing-payments{margin-top:16px}.existing-payments h4{font-size:13px;font-weight:600;color:#555;margin:0 0 12px}.payments-mini-table{width:100%;border-collapse:collapse;font-size:13px}.payments-mini-table th{background:#f0f0f0;padding:8px 10px;text-align:left;font-weight:600;color:#666;border-bottom:1px solid #ddd}.payments-mini-table td{padding:8px 10px;border-bottom:1px solid #eee;color:#333}.payments-mini-table td.amount{font-weight:500;color:#2e7d32}.payments-mini-table tr.current-payment{background:#fff3cd}.payments-mini-table tr:hover{background:#f8f8f8}.loading-text,.no-payments-text{font-size:13px;color:#666;padding:12px 0;margin:0}.quote-search-container{position:relative}.quote-search-input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px}.quote-search-input:focus{outline:none;border-color:#2e7d32}.quote-dropdown{position:absolute;top:100%;left:0;right:0;max-height:250px;overflow-y:auto;background:#fff;border:1px solid #ddd;border-top:none;border-radius:0 0 6px 6px;box-shadow:0 4px 12px #00000026;z-index:100}.quote-dropdown-loading,.quote-dropdown-empty{padding:12px 16px;color:#666;font-size:14px;text-align:center}.quote-dropdown-item{display:flex;flex-direction:column;gap:2px;padding:10px 16px;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background .15s}.quote-dropdown-item:last-child{border-bottom:none}.quote-dropdown-item:hover{background:#f5f5f5}.quote-dropdown-item.selected{background:#e8f5e9}.quote-dropdown-item .quote-display-id{font-weight:600;color:#667eea;font-size:12px}.quote-dropdown-item .quote-farmer{font-weight:500;color:#333;font-size:14px}.quote-dropdown-item .quote-amount{font-size:12px;color:#2e7d32;font-weight:500}.selected-quote-display{padding:10px 12px;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;font-size:14px;color:#333}.metadata-value{font-size:14px;color:#333;padding:10px 0}.payment-modal .btn-save{background:#2e7d32;border:none;color:#fff;padding:10px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer}.payment-modal .btn-save:hover:not(:disabled){background:#1b5e20}@media(max-width:600px){.modal-overlay{padding:0;align-items:flex-end}.modal-content{max-height:95vh;border-radius:12px 12px 0 0}.form-grid,.form-grid.metadata{grid-template-columns:1fr}.modal-footer{flex-direction:column}.btn-cancel,.btn-save{width:100%}.payments-mini-table{font-size:12px}.payments-mini-table th,.payments-mini-table td{padding:6px 8px}}.dashboard-content{width:100%}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.dashboard-header h2{font-size:28px;color:#333;margin:0}.btn-refresh{background:#fff;border:1px solid #667eea;color:#667eea;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px}.btn-refresh:hover:not(:disabled){background:#667eea;color:#fff}.btn-refresh:disabled{opacity:.5;cursor:not-allowed}.dashboard-section{margin-bottom:30px}.section-title{font-size:16px;color:#666;margin:0 0 15px;text-transform:uppercase;font-weight:600}.stats-grid{display:grid;gap:15px}.four-cols{grid-template-columns:repeat(4,1fr)}.five-cols{grid-template-columns:repeat(5,1fr)}.stat-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 8px #0000001a;border-left:4px solid #e0e0e0}.stat-card.highlight-green{border-left-color:#48bb78}.stat-card.highlight-orange{border-left-color:#ed8936}.stat-card.highlight-blue{border-left-color:#667eea}.stat-label{margin:0 0 8px;font-size:12px;color:#666;text-transform:uppercase}.stat-value{margin:0;font-size:24px;font-weight:700;color:#333}.alerts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.alert-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.alert-card h4{margin:0 0 15px;font-size:14px;color:#333}.no-alerts{color:#48bb78;font-size:14px;margin:0}.alert-list{list-style:none;padding:0;margin:0}.alert-list li{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f0f0f0;font-size:13px}.alert-list li:last-child{border-bottom:none}.alert-id{font-weight:600;color:#667eea}.alert-amount{color:#333}.alert-date{color:#ed8936;font-size:12px}.activity-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.activity-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.activity-card h4{margin:0 0 15px;font-size:14px;color:#333}.no-data{color:#666;font-size:14px;margin:0}.activity-list{list-style:none;padding:0;margin:0}.activity-list li{padding:10px 0;border-bottom:1px solid #f0f0f0}.activity-list li:last-child{border-bottom:none}.activity-main{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.activity-id{font-weight:600;color:#667eea;font-size:13px}.activity-name{font-size:14px;color:#333}.activity-amount{font-weight:600;color:#48bb78;font-size:14px}.activity-meta{display:flex;justify-content:space-between;font-size:12px;color:#666}.status-badge{padding:2px 8px;border-radius:10px;font-size:11px;font-weight:500}.status-badge.new{background:#e3f2fd;color:#1976d2}@media(max-width:1024px){.four-cols{grid-template-columns:repeat(2,1fr)}.five-cols{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.dashboard-header{flex-direction:column;align-items:flex-start;gap:15px}.four-cols,.five-cols{grid-template-columns:repeat(2,1fr)}.alerts-grid,.activity-grid{grid-template-columns:1fr}.stat-value{font-size:20px}}@media(max-width:480px){.four-cols,.five-cols{grid-template-columns:1fr}}.leads-page{width:100%}.leads-table{width:100%;min-width:800px;border-collapse:collapse}.leads-table th{background:#f8f9fa;padding:12px 16px;text-align:left;font-weight:600;font-size:13px;color:#666;text-transform:uppercase;border-bottom:2px solid #e9ecef}.leads-table td{padding:16px;border-bottom:1px solid #e9ecef;font-size:14px;color:#333}.leads-table tbody tr:hover{background:#f8f9fa}.status-badge.active{background:#d4edda;color:#155724}.status-badge.follow-up{background:#fff3cd;color:#856404}.status-badge.closed{background:#e2e3e5;color:#6c757d}.leads-count{margin:0;font-size:13px;color:#666}.leads-count.center{text-align:center;padding:20px}@media(max-width:768px){.table-view{display:none}.card-view{display:flex;flex-direction:column;gap:15px}.lead-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.lead-id{font-weight:600;color:#667eea}.farmer-name{margin:0 0 10px;font-size:18px;color:#333}.card-info{margin:5px 0;font-size:14px;color:#666}.card-actions{display:flex;gap:10px;margin-top:15px}.btn-secondary{flex:1;background:#fff;border:1px solid #667eea;color:#667eea;padding:8px 16px;border-radius:6px;font-size:13px;cursor:pointer}.btn-secondary:hover{background:#f0f0f0}.card-actions .btn-danger{flex:1;background:#fff;border:1px solid #e53e3e;color:#e53e3e;padding:8px 16px;border-radius:6px;font-size:13px;cursor:pointer}.page-header{flex-direction:column;align-items:flex-start;gap:15px}.search-input{max-width:100%;width:90%}}.visits-page{width:100%}.visits-table{width:100%;min-width:900px;border-collapse:collapse}.visits-table th{background:#f8f9fa;padding:12px 16px;text-align:left;font-weight:600;font-size:13px;color:#666;text-transform:uppercase;border-bottom:2px solid #e9ecef}.visits-table td{padding:16px;border-bottom:1px solid #e9ecef;font-size:14px;color:#333}.visits-table tbody tr:hover{background:#f8f9fa}.status-badge.scheduled{background:#e3f2fd;color:#1565c0}.status-badge.completed{background:#d4edda;color:#155724}.status-badge.cancelled{background:#f8d7da;color:#721c24}.visits-count{margin:0;font-size:13px;color:#666}.visits-count.center{text-align:center;padding:20px}@media(max-width:768px){.table-view{display:none}.card-view{display:flex;flex-direction:column;gap:15px}.visit-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.visit-id{font-weight:600;color:#667eea}.farmer-name{margin:0 0 10px;font-size:18px;color:#333}.card-info{margin:5px 0;font-size:14px;color:#666}.lead-ref{color:#667eea;font-weight:500}.card-actions{display:flex;gap:10px;margin-top:15px}.btn-secondary{flex:1;background:#fff;border:1px solid #667eea;color:#667eea;padding:8px 16px;border-radius:6px;font-size:13px;cursor:pointer}.btn-secondary:hover{background:#f0f0f0}.card-actions .btn-danger{flex:1;background:#fff;border:1px solid #e53e3e;color:#e53e3e;padding:8px 16px;border-radius:6px;font-size:13px;cursor:pointer}.page-header{flex-direction:column;align-items:flex-start;gap:15px}.search-input{max-width:100%;width:90%}}.quotations-page{width:100%}.filter-tabs{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.filter-tab{padding:10px 20px;border:2px solid #e0e0e0;background:#fff;border-radius:20px;font-size:14px;font-weight:500;color:#666;cursor:pointer;transition:all .2s}.filter-tab:hover{border-color:#667eea;color:#667eea}.filter-tab.active{background:#667eea;border-color:#667eea;color:#fff}.quotations-table{width:100%;min-width:900px;border-collapse:collapse}.quotations-table th{background:#f8f9fa;padding:12px 16px;text-align:left;font-weight:600;font-size:13px;color:#666;text-transform:uppercase;border-bottom:2px solid #e9ecef}.quotations-table td{padding:16px;border-bottom:1px solid #e9ecef;font-size:14px;color:#333}.quotations-table tbody tr:hover{background:#f8f9fa}.paid-cell{font-weight:500;color:#1976d2}.balance-cell{font-weight:600;color:#c62828}.status-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.status-badge.draft{background:#fff3cd;color:#856404}.status-badge.sent{background:#e3f2fd;color:#1565c0}.status-badge.accepted{background:#d4edda;color:#155724}.status-badge.rejected{background:#f8d7da;color:#721c24}.status-badge.expired{background:#e2e3e5;color:#383d41}.delivery-badge{padding:4px 10px;border-radius:10px;font-size:11px;font-weight:500}.delivery-badge.delivered{background:#d4edda;color:#155724}.delivery-badge.partial{background:#fff3cd;color:#856404}.delivery-badge.pending{background:#e2e3e5;color:#383d41}.delivery-badge.scheduled{background:#e3f2fd;color:#1565c0}.quotations-count{margin:0;font-size:13px;color:#666}.quotations-count.center{text-align:center;padding:20px}@media(max-width:768px){.table-view{display:none}.card-view{display:flex;flex-direction:column;gap:15px}.quotation-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.quotation-id{font-weight:600;color:#667eea}.farmer-name{margin:0 0 10px;font-size:18px;color:#333}.card-info{margin:5px 0;font-size:14px;color:#666}.card-info.amount{font-size:20px;font-weight:600;color:#2e7d32;margin:10px 0}.balance-info{background:#fff8e1;padding:10px;border-radius:6px;margin:10px 0}.balance-info .card-info{margin:3px 0}.paid-amount{font-weight:600;color:#1976d2}.balance-amount{font-weight:600;color:#c62828}.lead-ref{color:#667eea;font-weight:500}.card-actions{display:flex;gap:10px;margin-top:15px}.btn-secondary{flex:1;background:#fff;border:1px solid #667eea;color:#667eea;padding:8px 16px;border-radius:6px;font-size:13px;cursor:pointer}.btn-secondary:hover{background:#f0f0f0}.card-actions .btn-danger{flex:1;background:#fff;border:1px solid #e53e3e;color:#e53e3e;padding:8px 16px;border-radius:6px;font-size:13px;cursor:pointer}.page-header{flex-direction:column;align-items:flex-start;gap:15px}.filter-tabs{width:100%}.filter-tab{padding:8px 14px;font-size:13px}.search-input{max-width:100%;width:90%}}.payments-page{width:100%}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.page-header h1{margin:0;font-size:28px;color:#333}.btn-primary{background:#667eea;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer}.btn-primary:hover{background:#5568d3}.filter-indicator{display:flex;align-items:center;justify-content:space-between;background:#e3f2fd;border:1px solid #90caf9;border-radius:8px;padding:12px 16px;margin-bottom:20px;flex-wrap:wrap;gap:10px}.filter-text{font-size:14px;color:#1565c0}.btn-clear-filter{background:#fff;border:1px solid #1565c0;color:#1565c0;padding:6px 14px;border-radius:4px;font-size:13px;cursor:pointer;transition:all .2s}.btn-clear-filter:hover{background:#1565c0;color:#fff}.search-bar{margin-bottom:20px}.search-input{width:100%;max-width:500px;padding:12px 16px;border:1px solid #ddd;border-radius:6px;font-size:14px}.error-text{color:#e53e3e;padding:12px;background:#fee;border-radius:6px}.table-view{display:block;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow-x:auto;max-width:100%}.payments-table{width:100%;min-width:1000px;border-collapse:collapse}.payments-table th{background:#f8f9fa;padding:12px 16px;text-align:left;font-weight:600;font-size:13px;color:#666;text-transform:uppercase;border-bottom:2px solid #e9ecef}.payments-table td{padding:16px;border-bottom:1px solid #e9ecef;font-size:14px;color:#333}.payments-table tbody tr:hover{background:#f8f9fa}.quote-cell{display:flex;flex-direction:column;gap:2px}.quote-cell .quote-id{font-weight:500;color:#667eea}.quote-cell .quote-amount{font-size:12px;color:#666}.farmer-cell{display:flex;flex-direction:column;gap:2px}.farmer-cell .farmer-name{font-weight:500}.farmer-cell .lead-id{font-size:12px;color:#667eea}.clickable{cursor:pointer;text-decoration:underline}.clickable:hover{color:#5568d3}.amount-cell{font-weight:600;color:#2e7d32}.type-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.type-badge.advance{background:#e3f2fd;color:#1565c0}.type-badge.partial{background:#fff3cd;color:#856404}.type-badge.final{background:#d4edda;color:#155724}.actions{display:flex;gap:8px}.btn-icon{background:none;border:none;cursor:pointer;font-size:16px;padding:4px 8px;border-radius:4px}.btn-icon:hover{background:#f0f0f0}.btn-danger{color:#e53e3e}.no-data{text-align:center;padding:40px;color:#666}.load-more-container{display:flex;flex-direction:column;align-items:center;padding:20px;gap:10px}.btn-load-more{background:#fff;border:2px solid #667eea;color:#667eea;padding:12px 32px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-load-more:hover:not(:disabled){background:#667eea;color:#fff}.btn-load-more:disabled{opacity:.6;cursor:not-allowed}.payments-count{margin:0;font-size:13px;color:#666}.payments-count.center{text-align:center;padding:20px}@media(max-width:768px){.table-view{display:none}.card-view{display:flex;flex-direction:column;gap:15px}.payment-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.payment-id{font-weight:600;color:#667eea}.farmer-name{margin:0 0 10px;font-size:18px;color:#333}.card-info{margin:5px 0;font-size:14px;color:#666}.card-info.amount{font-size:20px;font-weight:600;color:#2e7d32;margin:10px 0}.quote-ref{color:#667eea;font-weight:500}.quote-amount-small{color:#666;margin-left:5px}.card-actions{display:flex;gap:10px;margin-top:15px}.btn-secondary{flex:1;background:#fff;border:1px solid #667eea;color:#667eea;padding:8px 16px;border-radius:6px;font-size:13px;cursor:pointer}.btn-secondary:hover{background:#f0f0f0}.card-actions .btn-danger{flex:1;background:#fff;border:1px solid #e53e3e;color:#e53e3e;padding:8px 16px;border-radius:6px;font-size:13px;cursor:pointer}.page-header{flex-direction:column;align-items:flex-start;gap:15px}.search-input{max-width:100%;width:90%}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:12px;max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026}.modal-header{display:flex;align-items:center;gap:15px;padding:20px 24px;border-bottom:1px solid #e9ecef;flex-shrink:0}.modal-header h2{margin:0;font-size:20px;color:#333;flex:1}.modal-close{background:none;border:none;font-size:28px;cursor:pointer;color:#666;line-height:1;padding:0}.modal-close:hover{color:#333}.modal-error{background:#fee;color:#c00;padding:12px 24px;border-bottom:1px solid #fcc}.modal-form{display:flex;flex-direction:column;flex:1;min-height:0}.modal-body{flex:1;overflow-y:auto;padding:24px}.form-section h3{font-size:14px;font-weight:600;color:#667eea;text-transform:uppercase;margin:0 0 16px;padding-bottom:8px;border-bottom:2px solid #e9ecef}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group.full-width{grid-column:1 / -1}.form-group label{font-size:13px;font-weight:500;color:#555}.form-group input,.form-group select,.form-group textarea{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s}.form-group textarea{resize:vertical;min-height:80px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:#f5f5f5;cursor:default}.readonly-value{font-size:14px;color:#333;padding:10px 0}.amount-display{padding:10px 12px;background:#e8f5e9;border:1px solid #c8e6c9;border-radius:6px;font-size:18px;font-weight:600;color:#2e7d32}.checkbox-label{display:flex!important;flex-direction:row!important;align-items:center;gap:8px;cursor:pointer;padding-top:10px}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:500;width:fit-content}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e9ecef;flex-shrink:0}.btn-cancel{background:#fff;border:1px solid #ddd;color:#666;padding:10px 20px;border-radius:6px;font-size:14px;cursor:pointer}.btn-cancel:hover{background:#f5f5f5}.btn-save{background:#667eea;border:none;color:#fff;padding:10px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer}.btn-save:hover:not(:disabled){background:#5568d3}.btn-save:disabled{opacity:.6;cursor:not-allowed}@media(max-width:600px){.modal-overlay{padding:0;align-items:flex-end}.modal-content{max-height:95vh;border-radius:12px 12px 0 0}.form-grid{grid-template-columns:1fr}.modal-footer{flex-direction:column}.btn-cancel,.btn-save{width:100%}}.products-page{max-width:1200px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-title-section{display:flex;align-items:baseline;gap:12px}.page-title-section h1{margin:0;font-size:24px;color:#333}.record-count{font-size:14px;color:#888}.btn-add{background:#667eea;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer}.btn-add:hover{background:#5568d3}.search-bar{display:flex;gap:10px;margin-bottom:20px}.search-input{flex:1;padding:10px 16px;border:1px solid #ddd;border-radius:6px;font-size:14px}.search-input:focus{outline:none;border-color:#667eea}.clear-search{background:#fff;border:1px solid #ddd;color:#666;padding:10px 16px;border-radius:6px;cursor:pointer;font-size:14px}.error-banner{background:#fee;color:#c00;padding:12px 16px;border-radius:6px;margin-bottom:16px}.empty-state{text-align:center;padding:60px 20px;color:#888;font-size:16px}.table-view{display:block;overflow-x:auto}.table-view table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.table-view th{background:#f8f9fa;padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:#666;text-transform:uppercase;border-bottom:2px solid #e9ecef}.table-view td{padding:12px 16px;font-size:14px;color:#333;border-bottom:1px solid #f0f0f0}.product-row{cursor:pointer;transition:background .15s}.product-row:hover{background:#f8f9fa}.product-row.inactive{opacity:.6}.sku-cell{font-family:monospace;font-size:13px;color:#667eea}.name-cell{font-weight:500}.price-cell{font-weight:600;color:#2e7d32}.status-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:500}.status-badge.active{background:#e8f5e9;color:#2e7d32}.status-badge.inactive{background:#fbe9e7;color:#c62828}.actions-cell{display:flex;gap:8px}.btn-action{padding:4px 12px;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;border:1px solid}.btn-action.edit{background:#fff;border-color:#667eea;color:#667eea}.btn-action.edit:hover{background:#f0f4ff}.btn-action.deactivate{background:#fff;border-color:#f44336;color:#f44336}.btn-action.deactivate:hover{background:#fef0ef}.btn-action.activate{background:#fff;border-color:#4caf50;color:#4caf50}.btn-action.activate:hover{background:#f0faf0}.card-view{display:none}.product-card{background:#fff;border-radius:8px;padding:16px;margin-bottom:12px;box-shadow:0 1px 3px #0000001a;cursor:pointer}.product-card.inactive{opacity:.6}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.card-name{font-weight:600;font-size:16px;color:#333}.card-kannada{font-size:14px;color:#666;margin-bottom:8px}.card-details{display:flex;align-items:baseline;gap:6px;margin-bottom:8px}.card-price{font-size:18px;font-weight:600;color:#2e7d32}.card-unit{font-size:14px;color:#888}.card-category{margin-left:auto;font-size:12px;background:#e3f2fd;color:#1565c0;padding:2px 8px;border-radius:4px}.card-sku{font-size:12px;color:#888;font-family:monospace;margin-bottom:12px}.card-actions{display:flex;gap:8px;border-top:1px solid #f0f0f0;padding-top:12px}.card-actions .btn-action{flex:1;text-align:center;padding:8px}.users-page{max-width:1200px;margin:0 auto}.email-cell{font-weight:500;color:#333}.date-cell{font-size:13px;color:#888;white-space:nowrap}.invited-cell{font-size:13px;color:#666}.notes-cell{font-size:13px;color:#666;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-row{cursor:pointer;transition:background .15s}.user-row:hover{background:#f8f9fa}.user-row.inactive{opacity:.6}.role-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:500}.role-badge.admin{background:#fce4ec;color:#b71c1c}.role-badge.manager{background:#e8eaf6;color:#283593}.role-badge.sales{background:#e3f2fd;color:#1565c0}.role-badge.agronomist{background:#e8f5e9;color:#2e7d32}.user-card{background:#fff;border-radius:8px;padding:16px;margin-bottom:12px;box-shadow:0 1px 3px #0000001a;cursor:pointer}.user-card.inactive{opacity:.6}.user-card .card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.card-email{font-weight:600;font-size:14px;color:#333;word-break:break-all}.card-meta{display:flex;align-items:center;gap:10px;margin-bottom:8px}.card-date{font-size:12px;color:#888}.card-notes{font-size:13px;color:#666;margin-bottom:12px}@media(max-width:768px){.table-view{display:none}.card-view{display:block}.page-header{flex-direction:column;align-items:stretch;gap:12px}.btn-add{width:100%;text-align:center}}.session-expiry-warning{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:12px 20px;z-index:9999;box-shadow:0 2px 8px #0003}.warning-content{display:flex;align-items:center;justify-content:center;gap:15px;max-width:800px;margin:0 auto}.warning-icon{font-size:20px}.warning-text{font-size:14px}.warning-text strong{font-weight:600}.extend-btn{background:#fff;color:#d97706;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.extend-btn:hover:not(:disabled){background:#fef3c7}.extend-btn:disabled{opacity:.7;cursor:not-allowed}.dismiss-btn{background:transparent;color:#fff;border:none;padding:4px 8px;font-size:18px;cursor:pointer;opacity:.8;transition:opacity .2s}.dismiss-btn:hover{opacity:1}@media(max-width:600px){.warning-content{flex-wrap:wrap;gap:10px}.warning-text{flex:1 1 100%;text-align:center}}
