.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#4472c4 0%,#70ad47 100%);padding:20px}@media (max-width: 768px){.login-container{padding:16px}}@media (max-width: 480px){.login-container{padding:40px 12px 12px;align-items:flex-start}}.login-card{background-color:#fff;padding:40px;border-radius:8px;box-shadow:0 4px 20px #0003;width:100%;max-width:400px}@media (max-width: 768px){.login-card{padding:30px;max-width:100%}}@media (max-width: 480px){.login-card{padding:20px;max-width:100%;border-radius:6px}}.login-header{text-align:center;margin-bottom:30px}@media (max-width: 480px){.login-header{margin-bottom:24px}}.login-header h1{font-size:32px;color:#4472c4;margin-bottom:10px}@media (max-width: 768px){.login-header h1{font-size:28px}}@media (max-width: 480px){.login-header h1{font-size:24px;margin-bottom:8px}}.login-header p{color:#666;font-size:14px}@media (max-width: 480px){.login-header p{font-size:13px}}.login-form{margin-bottom:20px}@media (max-width: 480px){.login-form{margin-bottom:18px}}.login-form .form-group{margin-bottom:18px}@media (max-width: 480px){.login-form .form-group{margin-bottom:16px}}.login-form .btn{width:100%;margin-top:10px}@media (max-width: 480px){.login-form .btn{margin-top:8px;font-size:15px}}.login-footer{text-align:center;font-size:12px;color:#999;padding-top:20px;border-top:1px solid #eee}@media (max-width: 480px){.login-footer{font-size:11px;padding-top:16px}}.login-footer p{margin:5px 0}.client-portal-container{min-height:100vh;background:linear-gradient(145deg,#efe3cf 0%,#86a789 100%);display:flex;flex-direction:column}.client-login-wrapper{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:24px 16px}.client-login-card{background:#fffdf7;border-radius:14px;box-shadow:0 24px 58px #3a5a4033;padding:36px;width:100%;max-width:580px}.client-login-header{text-align:center;margin-bottom:22px}.portal-logo{max-width:120px;margin-bottom:10px}.client-login-header h1{margin:0;font-size:1.5rem;color:#2f4f37}.client-login-header p{margin:6px 0 0;color:#557463;font-size:.9rem}.portal-tabs{display:flex;gap:8px;margin-bottom:16px}.portal-tab{flex:1;border:1px solid #b9c8ae;background:#f5f0e6;border-radius:8px;padding:10px;cursor:pointer;color:#2f4f37;font-weight:600;font-size:.95rem;transition:background .15s,color .15s}.portal-tab.active{background:#7a9a72;color:#fff;border-color:#7a9a72}.client-login-form{display:flex;flex-direction:column;gap:14px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.88rem;color:#3d5c42;font-weight:600}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-group input,.form-group textarea,.form-group select{padding:10px 12px;border:1px solid #c8d7be;border-radius:8px;background:white;font-size:.95rem;transition:border-color .15s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#7a9a72}.checkbox-inline{display:flex;align-items:center;gap:8px;color:#2f4f37;font-size:14px}.alert{padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:15px}.alert-error{background-color:#fee;color:#a21f1f;border:1px solid #f5bcbc}.btn{border:none;border-radius:8px;padding:10px 18px;font-weight:600;cursor:pointer;font-size:.9rem;transition:background .15s,opacity .15s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#567a57;color:#fff}.btn-primary:hover:not(:disabled){background:#436344}.btn-secondary{background:#c7b28a;color:#2f4f37}.btn-secondary:hover:not(:disabled){background:#b9a174}.btn-danger{background:#a14f4f;color:#fff}.btn-danger:hover:not(:disabled){background:#883f3f}.client-portal-header{background:#fffdf7;padding:16px 4%;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #3a5a4029;flex-wrap:wrap;gap:12px;position:sticky;top:0;z-index:100}.client-portal-logo-section{display:flex;align-items:center;gap:14px;flex:1;min-width:0}.portal-logo-header{max-width:64px;height:auto;flex-shrink:0}.client-portal-info h1{margin:0;color:#2f4f37;font-size:1.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.client-portal-info p{margin:4px 0 0;color:#557463;font-size:.82rem}.portal-header-actions{display:flex;gap:8px;flex-wrap:wrap;flex-shrink:0}.quotations-wrapper{width:100%;display:flex;justify-content:center;padding:24px 16px}.quotations-list{width:85%;display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:20px}.quotation-card{background:#fffdf8;border-radius:12px;box-shadow:0 4px 16px #3a5a4024;overflow:hidden;display:flex;flex-direction:column}.quotation-header{background:linear-gradient(135deg,#e2d1b1 0%,#6f946f 100%);color:#fff;padding:16px 18px;display:flex;justify-content:space-between;align-items:center}.quotation-header h3{margin:0;font-size:1rem}.status-badge{padding:4px 10px;border-radius:999px;font-size:11px;background:rgba(255,255,255,.28);white-space:nowrap}.quotation-details{padding:16px 18px;border-bottom:1px solid #ede5d7}.detail-row{display:flex;justify-content:space-between;margin-bottom:6px;gap:8px}.detail-label{color:#557463;font-size:.9rem}.detail-value{color:#2f4f37;font-weight:700;font-size:.9rem}.quotation-files{padding:16px 18px;display:flex;flex-direction:column;gap:14px;flex:1}.files-section h4{margin:0 0 10px;color:#557463;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em}.files-section-invoice{border-top:1px dashed #ddd4be;padding-top:14px}.files-group{display:flex;flex-wrap:wrap;gap:8px}.btn-file{padding:8px 13px;font-size:12px;border-radius:8px;font-weight:600;border:none;cursor:pointer;transition:opacity .15s}.btn-file:hover:not(:disabled){opacity:.85}.btn-quotation{background:#4c7c88;color:#fff}.btn-pdf{background:#b7655c;color:#fff}.btn-xml{background:#5f8f6b;color:#fff}.btn-preview{background:#3f4c3d;color:#fff}.btn-disabled{background:#d9d9d9;color:#777;cursor:not-allowed!important}.loading-state,.empty-state{grid-column:1 / -1;min-height:220px;display:flex;justify-content:center;align-items:center;color:#2f4f37;font-size:1rem}.modal{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.48);z-index:1000;justify-content:center;align-items:center;padding:16px}.modal.show{display:flex}.modal-content{background:#fffdf8;border-radius:12px;box-shadow:0 16px 48px #0000003d;padding:24px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;gap:14px;width:100%}.preview-modal-content{max-width:960px}.modal-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.modal-header h2{margin:0;color:#2f4f37;font-size:1.1rem}.modal-close{background:none;border:none;font-size:1.6rem;cursor:pointer;color:#557463;line-height:1;padding:0 4px}.modal-footer{display:flex;justify-content:flex-end;padding-top:4px}.preview-frame{width:100%;height:70vh;border:1px solid #ddd;border-radius:6px}.preview-xml-content{max-height:65vh;overflow:auto;background-color:#f7f7f7;padding:14px;border-radius:6px;border:1px solid #ddd;font-size:12px;white-space:pre-wrap;word-break:break-all}.chat-window{max-height:380px;overflow-y:auto;background:#f8f6ef;border:1px solid #ddd4bf;border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:6px}.chat-bubble{max-width:78%;border-radius:10px;padding:8px 12px}.chat-bubble.mine{margin-left:auto;background:#d8e7d5;border:1px solid #c0d7bc}.chat-bubble.theirs{margin-right:auto;background:#fff;border:1px solid #dfdfdf}.chat-bubble small{display:block;margin-top:4px;color:#888;font-size:11px}.chat-input-row{display:flex;gap:8px;margin-top:10px}.chat-input-row input{flex:1;padding:10px 12px;border:1px solid #c8d7be;border-radius:8px;font-size:.95rem}.chat-input-row input:focus{outline:none;border-color:#7a9a72}@media (max-width: 1024px){.quotations-list{width:90%;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}}@media (max-width: 767px){.client-login-card{padding:24px 18px}.client-login-header h1{font-size:1.25rem}.form-row{grid-template-columns:1fr}.client-portal-header{flex-direction:column;align-items:flex-start;padding:14px 16px}.portal-header-actions{width:100%}.portal-header-actions .btn{flex:1;text-align:center}.quotations-wrapper{padding:16px 12px}.quotations-list{width:100%;grid-template-columns:1fr;gap:14px}.files-group{flex-direction:column}.btn-file{width:100%;text-align:center;padding:11px 12px}.modal-content{padding:18px 14px;max-height:95vh}.preview-frame{height:58vh}.chat-input-row{flex-direction:column}.chat-input-row .btn{width:100%}}@media (max-width: 480px){.client-login-wrapper{padding:16px 10px}.client-login-card{padding:20px 14px}.portal-tab{padding:9px 6px;font-size:.85rem}.quotation-header h3{font-size:.9rem}.btn-file{font-size:13px}}:root{--primary-color: #4472c4;--secondary-color: #70ad47;--danger-color: #e74c3c;--warning-color: #f39c12;--success-color: #27ae60;--light-bg: #f5f5f5;--border-color: #ddd;--text-primary: #333;--text-secondary: #666}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--text-primary);background-color:var(--light-bg);font-size:16px}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px;color:var(--text-secondary)}.container{max-width:1200px;margin:0 auto;padding:20px}@media (max-width: 768px){.container{padding:16px}}@media (max-width: 480px){.container{padding:12px}}.header{background-color:#fff;box-shadow:0 2px 4px #0000001a;margin-bottom:30px;position:sticky;top:0;z-index:100}@media (max-width: 768px){.header{margin-bottom:20px}}.header-content{max-width:1200px;margin:0 auto;padding:15px 20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px}@media (max-width: 768px){.header-content{padding:12px 16px}}.header h1{font-size:24px;color:var(--primary-color);flex:1;min-width:150px}@media (max-width: 768px){.header h1{font-size:20px}}@media (max-width: 480px){.header h1{font-size:18px}}.nav-links{display:flex;gap:20px;align-items:center;flex-wrap:wrap}@media (max-width: 768px){.nav-links{gap:10px;width:100%;justify-content:flex-start}}@media (max-width: 480px){.nav-links{gap:6px;justify-content:flex-start}}.nav-links a{text-decoration:none;color:var(--text-primary);font-weight:500;transition:color .3s;white-space:nowrap;font-size:14px}@media (max-width: 480px){.nav-links a{font-size:12px}}.nav-links a:hover{color:var(--primary-color)}.btn{padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s;display:inline-block;min-height:44px;display:flex;align-items:center;justify-content:center}@media (max-width: 480px){.btn{padding:8px 16px;font-size:13px;min-height:40px}}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover,.btn-primary:active{background-color:#3d5a99}.btn-primary:focus{outline:2px solid var(--primary-color);outline-offset:2px}.btn-secondary{background-color:var(--secondary-color);color:#fff}.btn-secondary:hover,.btn-secondary:active{background-color:#5a8c38}.btn-danger{background-color:var(--danger-color);color:#fff}.btn-danger:hover,.btn-danger:active{background-color:#c0392b}.btn-success{background-color:var(--success-color);color:#fff}.btn-success:hover,.btn-success:active{background-color:#229954}.btn-small{padding:6px 12px;font-size:12px;min-height:auto;display:inline}@media (max-width: 480px){.btn-small{padding:5px 10px;font-size:11px}}.form-group{margin-bottom:20px}@media (max-width: 768px){.form-group{margin-bottom:18px}}@media (max-width: 480px){.form-group{margin-bottom:16px}}.form-group label{display:block;margin-bottom:8px;font-weight:500;font-size:14px}@media (max-width: 480px){.form-group label{font-size:13px}}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:4px;font-size:14px;font-family:inherit;transition:border-color .3s,box-shadow .3s;-webkit-appearance:none;-moz-appearance:none;appearance:none}@media (max-width: 768px){.form-group input,.form-group textarea,.form-group select{padding:12px;font-size:16px}}.form-group textarea{min-height:100px;resize:vertical}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4472c41a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width: 768px){.form-row{grid-template-columns:1fr;gap:16px}}@media (max-width: 480px){.form-row{gap:14px}}.form-row.full{grid-template-columns:1fr}.checkbox{display:flex;align-items:center;gap:10px;font-size:14px;padding:10px;cursor:pointer}@media (max-width: 480px){.checkbox{font-size:13px;padding:8px}}.checkbox input[type=checkbox]{width:auto;cursor:pointer;min-width:18px;min-height:18px}.card{background-color:#fff;border-radius:4px;box-shadow:0 2px 4px #0000001a;padding:20px;margin-bottom:20px}@media (max-width: 768px){.card{padding:16px;margin-bottom:16px}}@media (max-width: 480px){.card{padding:14px;margin-bottom:14px}}.card h2{font-size:18px;margin-bottom:15px;color:var(--primary-color)}@media (max-width: 480px){.card h2{font-size:16px;margin-bottom:12px}}.table{width:100%;border-collapse:collapse;margin-bottom:20px;overflow-x:auto;display:block}@media (max-width: 768px){.table{display:block;overflow-x:auto;white-space:nowrap}}@media (max-width: 768px){.table{font-size:13px}}.table thead{background-color:var(--light-bg);border-bottom:2px solid var(--border-color);display:table-header-group}@media (max-width: 768px){.table thead{display:none}}.table th{padding:12px;text-align:left;font-weight:600;font-size:13px}@media (max-width: 768px){.table th{padding:10px}}.table td{padding:12px;border-bottom:1px solid var(--border-color)}@media (max-width: 768px){.table td{display:block;text-align:right;border-bottom:none;border-left:4px solid var(--primary-color);padding:10px 10px 10px 50%;position:relative}.table td:before{content:attr(data-label);position:absolute;left:10px;font-weight:600;text-align:left;width:40%;color:var(--primary-color)}}.table tbody{display:table-row-group}@media (max-width: 768px){.table tbody{display:block}}.table tbody tr{display:table-row}@media (max-width: 768px){.table tbody tr{display:block;margin-bottom:15px;border:1px solid var(--border-color);border-radius:4px;padding:10px 0}}.table tbody tr:hover{background-color:#4472c40d}@media (max-width: 768px){.table tbody tr:hover{background-color:#fff}}.table .actions{display:flex;gap:10px;flex-wrap:wrap}@media (max-width: 480px){.table .actions{gap:5px}}.alert{padding:15px;margin-bottom:20px;border-radius:4px;font-size:14px;border-left:4px solid}@media (max-width: 768px){.alert{padding:12px;margin-bottom:16px;font-size:13px}}@media (max-width: 480px){.alert{padding:10px;margin-bottom:14px;font-size:12px}}.alert-success{background-color:#d4edda;color:#155724;border-color:#c3e6cb}.alert-error{background-color:#f8d7da;color:#721c24;border-color:#f5c6cb}.alert-info{background-color:#d1ecf1;color:#0c5460;border-color:#bee5eb}.error-text{color:var(--danger-color);font-size:12px;margin-top:5px;display:block}@media (max-width: 480px){.error-text{font-size:11px}}.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:1000;padding:20px;overflow-y:auto}@media (max-width: 768px){.modal{padding:16px}}@media (max-width: 480px){.modal{padding:12px}}.modal.show{display:flex;justify-content:center;align-items:flex-start}@media (max-width: 768px){.modal.show{align-items:center}}.modal-content{background-color:#fff;padding:30px;border-radius:4px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0003}@media (max-width: 768px){.modal-content{padding:20px;max-width:100%;max-height:95vh}}@media (max-width: 480px){.modal-content{padding:16px;max-height:95vh}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:10px}@media (max-width: 480px){.modal-header{margin-bottom:16px}}.modal-header h2{margin:0;font-size:18px;flex:1;word-break:break-word}@media (max-width: 480px){.modal-header h2{font-size:16px}}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-secondary);padding:4px;flex-shrink:0}@media (max-width: 480px){.modal-close{font-size:20px}}.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;flex-wrap:wrap}@media (max-width: 480px){.modal-footer{gap:8px;margin-top:16px;flex-direction:column-reverse}.modal-footer .btn{width:100%}}.breadcrumb{margin-bottom:20px;font-size:14px;display:flex;flex-wrap:wrap;gap:10px;align-items:center}@media (max-width: 480px){.breadcrumb{font-size:12px;margin-bottom:16px;gap:5px}}.breadcrumb a{color:var(--primary-color);text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.spinner{display:inline-block;width:20px;height:20px;border:3px solid rgba(68,114,196,.3);border-radius:50%;border-top-color:var(--primary-color);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.logo-title{display:flex;align-items:center;gap:10px;flex-shrink:0}.company-logo{max-height:40px;width:auto}@media (max-width: 480px){.company-logo{max-height:32px}}.link-change-password{white-space:nowrap;font-size:13px}@media (max-width: 768px){.nav-links a,.nav-links button{min-height:40px;display:inline-flex;align-items:center}}.page-content{padding:20px;max-width:1400px;margin:0 auto}@media (max-width: 1024px){.page-content{padding:16px}}@media (max-width: 480px){.page-content{padding:12px}}.grid-3-cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}@media (max-width: 1024px){.grid-3-cols{grid-template-columns:1fr 1fr;gap:18px}}@media (max-width: 768px){.grid-3-cols{grid-template-columns:1fr;gap:16px}}.grid-2-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width: 768px){.grid-2-cols{grid-template-columns:1fr;gap:16px}}@media (max-width: 480px){.grid-2-cols{gap:14px}}.flex-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}@media (max-width: 480px){.flex-row{gap:8px}}.flex-row-responsive{display:flex;gap:10px;flex-wrap:wrap;align-items:center}@media (max-width: 480px){.flex-row-responsive{flex-direction:column;align-items:stretch}.flex-row-responsive .btn{width:100%}}.card-centered{text-align:center}@media (max-width: 768px){.card-centered{padding:16px}}.stats-icon{font-size:32px;margin-bottom:10px;display:block}@media (max-width: 768px){.stats-icon{font-size:28px;margin-bottom:8px}}@media (max-width: 480px){.stats-icon{font-size:24px;margin-bottom:6px}}.stats-title{margin:0 0 5px;font-size:16px;font-weight:600;color:var(--primary-color)}@media (max-width: 480px){.stats-title{font-size:14px}}.stats-value{margin:0 0 15px;color:var(--text-secondary);font-size:14px}@media (max-width: 480px){.stats-value{font-size:12px;margin-bottom:12px}}.mt-responsive{margin-top:30px}@media (max-width: 768px){.mt-responsive{margin-top:24px}}@media (max-width: 480px){.mt-responsive{margin-top:20px}}.empty-state{color:var(--text-secondary);text-align:center;padding:20px;font-size:14px}@media (max-width: 480px){.empty-state{padding:16px;font-size:13px}}.actions-container{margin-bottom:20px}@media (max-width: 768px){.actions-container{margin-bottom:16px}}@media (max-width: 480px){.actions-container{margin-bottom:14px}}.text-responsive{font-size:14px}@media (max-width: 480px){.text-responsive{font-size:13px}}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width: 768px){.form-grid-2{grid-template-columns:1fr;gap:16px}}.stack-mobile{display:flex;flex-direction:row;gap:10px}@media (max-width: 480px){.stack-mobile{flex-direction:column;gap:8px}.stack-mobile>*{width:100%}}
