:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#1a1919de;background-color:#f7f7f7;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}}.sidebar{width:250px;background-color:#031f7e;color:#fff;padding:15px;height:100vh;display:flex;flex-direction:column;transition:width .3s ease;box-sizing:border-box}.sidebar.collapsed{width:80px}.sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding:0 5px;position:relative}.sidebar-logo{height:40px;transition:opacity .2s ease,width .3s ease;opacity:1}.sidebar-header h3{margin:0;white-space:nowrap;opacity:1;transition:opacity .3s ease}.sidebar-toggle{background:none;border:none;color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center}.sidebar.collapsed .sidebar-header{justify-content:center}.sidebar.collapsed .sidebar-logo{opacity:0;width:0;overflow:hidden}.sidebar.collapsed .sidebar-header h3{opacity:0;display:none}.sidebar-nav{display:flex;flex-direction:column;gap:10px}.nav-link{display:flex;align-items:center;gap:15px;padding:12px 15px;background-color:transparent;color:#fff;border:none;border-radius:6px;text-align:left;cursor:pointer;font-size:15px;text-decoration:none;width:100%;transition:background-color .2s;overflow:hidden}.nav-link:hover{background-color:#ffffff1a}.nav-icon{font-size:20px;flex-shrink:0}.nav-text{white-space:nowrap;opacity:1;transition:opacity .3s ease}.sidebar.collapsed .nav-text{opacity:0;display:none}.sidebar-footer{margin-top:auto}.modal-overlay{display:flex;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:#0009;justify-content:center;align-items:center}.modal-content{background-color:#fefefe;padding:30px 40px;border-radius:12px;width:90%;max-width:600px;position:relative;box-shadow:0 5px 15px #0000004d}.close-btn{color:#aaa;position:absolute;top:10px;right:20px;font-size:28px;font-weight:700;cursor:pointer}.close-btn:hover,.close-btn:focus{color:#000}.optional-fields{border:1px solid #e9ecef;border-radius:6px;margin-top:20px;padding:10px 20px}.optional-fields legend{font-weight:600;color:#6c757d;padding:0 10px;font-size:.9em}input{background-color:inherit;border:1px solid lightgray;border-radius:6px;height:35px;color:#6c757d;padding:0 6px}.form-group{margin-bottom:20px}label{display:block;margin-bottom:8px;font-weight:600;color:#495057}input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],input[type=month],select{width:100%;padding:12px;border:1px solid #ced4da;border-radius:6px;box-sizing:border-box;font-size:16px;background-color:#fff;color:#495057;height:48px;color-scheme:light}button{width:100%;padding:12px;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:16px;font-weight:600;transition:background-color .2s}button:disabled{opacity:.7;cursor:not-allowed}.form-row{display:flex;flex-wrap:wrap;gap:20px}.form-row .form-group{flex:1;min-width:calc(50% - 10px)}.message{margin-top:20px;padding:12px;border-radius:6px;text-align:center;display:block}.success{background-color:#d1e7dd;color:#0f5132}.error{background-color:#f8d7da;color:#842029}.checkbox-group{display:flex;align-items:center;gap:10px}.checkbox-group label{margin-bottom:0}.checkbox-group input[type=checkbox]{width:20px;height:20px}.form-section{border:1px solid #e9ecef;border-radius:8px;padding:20px;margin-bottom:25px}.form-section legend{font-weight:600;color:#007bff;padding:0 10px}.form-stepper{display:flex;justify-content:space-between;margin-bottom:25px;position:relative;counter-reset:step}.step{display:flex;flex-direction:column;align-items:center;position:relative;z-index:1}.step-indicator{width:30px;height:30px;border-radius:50%;background-color:#e9ecef;border:2px solid #ced4da;color:#495057;display:flex;justify-content:center;align-items:center;font-weight:700;transition:all .3s ease}.step.active .step-indicator{background-color:#007bff;border-color:#0056b3;color:#fff}.step.completed .step-indicator{background-color:#28a745;border-color:#1e7e34;color:#fff}.step-label{margin-top:8px;font-size:12px;color:#6c757d;font-weight:500}.step.active .step-label{color:#007bff;font-weight:700}.form-navigation{display:flex;justify-content:space-between;margin-top:25px}.form-group .error-text{color:#dc3545;font-size:12px;margin-top:5px;height:15px}.form-group input.error-input,.form-group select.error-input{border-color:#dc3545}.radio-group{display:flex;flex-direction:column;gap:10px}.radio-group .radio-group-label{display:block;margin-bottom:0;font-weight:600;color:#495057}.radio-options label{flex:1;text-align:center;padding:10px;cursor:pointer;background-color:#f8f9fa;color:#495057;transition:all .2s ease-in-out;border-right:1px solid #ced4da}.radio-options label:last-child{border-right:none}.radio-options input[type=radio]{display:none}.radio-options input[type=radio]:checked+span{font-weight:700}.radio-options{display:flex;border-radius:6px;overflow:hidden;border:1px solid #ced4da}.radio-options label{flex:1;text-align:center;padding:10px;cursor:pointer;background-color:#f8f9fa;color:#495057;transition:all .2s ease-in-out}.radio-options label.selected{background-color:#007bff;color:#fff;font-weight:700}.app-layout{display:grid;grid-template-columns:250px 1fr;width:100vw;height:100vh;transition:grid-template-columns .3s ease}.app-layout.sidebar-collapsed{grid-template-columns:80px 1fr}.app-content{padding:30px;overflow-y:auto;background-color:#f0f2f5;height:100vh;box-sizing:border-box}.table-container{width:100%}.filter-input{width:100%;padding:10px 15px;margin-bottom:20px;border-radius:6px;border:1px solid #ced4da;font-size:16px;box-sizing:border-box}.integradores-table{width:100%;border-collapse:collapse;text-align:left}.integradores-table th,.integradores-table td{padding:12px 15px;border-bottom:1px solid #dee2e6}.integradores-table th{background-color:#f8f9fa;font-weight:600}.integradores-table .actions{display:flex;gap:10px;justify-content:flex-end}.integradores-table .btn-details,.integradores-table .btn-red{padding:6px 12px;font-size:14px;border-radius:5px;cursor:pointer;text-decoration:none;color:#fff;border:none}.suggestion-cell{text-align:center;padding:20px;font-style:italic;color:#6c757d}.btn-suggest{background:none;border:none;color:#007bff;text-decoration:underline;cursor:pointer;font-size:1em;font-style:normal;margin-left:10px}.integradores-table tbody tr{cursor:pointer}.integradores-table tbody tr:hover{background-color:#f1f3f5}.container{background:#fff;padding:40px;border-radius:12px;box-shadow:0 6px 12px #0000001a;width:90%;max-width:700px;box-sizing:border-box;margin:25px auto;color:#212529}.container h2{text-align:center;color:#212529;margin-top:0;margin-bottom:25px;border-bottom:2px solid #ff9900;padding-bottom:10px}.app-content .container{width:100%;max-width:none;margin:0;flex-grow:1;display:flex;flex-direction:column}.integrador-header{text-align:center;border-bottom:1px solid #e9ecef;padding-bottom:20px;margin-bottom:30px}.integrador-header h1{margin:0;font-size:2.5em;color:#343a40}.integrador-header .contato{font-size:1.1em;color:#adb5bd;margin-top:5px}.clientes-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.clientes-section-header h2{margin:0;font-size:1.5em;color:#495057;border-bottom:3px solid #ff9900;padding-bottom:5px}.clientes-section-header .action-btn{border-radius:6px}.clientes-lista-detalhe{list-style-type:none;padding:0}.clientes-lista-detalhe li{background-color:transparent;padding:20px 10px;border-bottom:1px solid #f1f3f5;display:flex;justify-content:space-between;align-items:center;gap:15px;cursor:pointer;transition:background-color .2s}.clientes-lista-detalhe li:last-child{border-bottom:none}.clientes-lista-detalhe li:hover{background-color:#f8f9fa;border-radius:8px}.cliente-dados{flex-grow:1}.cliente-nome{font-weight:600;font-size:1.1em;color:#495057}.cliente-dados small{color:#adb5bd}.cliente-acoes{display:flex;gap:10px}.cliente-acoes .action-btn{font-size:.9rem}.error-message{color:#842029;background-color:#f8d7da;padding:15px;border-radius:6px;text-align:center}.cliente-header{border-bottom:2px solid #ff9900;padding-bottom:20px;margin-bottom:30px}.cliente-header-content{display:flex;align-items:center;gap:15px}.cliente-icon-wrapper{background:#fff3e0;padding:10px;border-radius:50%;display:flex;align-items:center;justify-content:center}.cliente-info h2{margin:0;color:#333;font-size:1.8rem}.cliente-meta{color:#666;font-size:.95rem;margin-top:5px}.cliente-meta span{margin-right:15px}.installations-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.installations-section-header h3{margin:0;color:#007bff;font-size:1.4rem}.empty-state{text-align:center;padding:40px;background:#f8f9fa;border-radius:8px;color:#666;border:1px dashed #ccc}.empty-state p{font-size:1.1rem;margin-bottom:15px}.btn-link-action{color:#007bff;background:none;border:none;cursor:pointer;text-decoration:underline;font-size:1rem}.installations-list{list-style:none;padding:0;margin:0}.installation-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px;margin-bottom:15px;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;box-shadow:0 4px 6px #0000000d;transition:transform .2s,box-shadow .2s;cursor:pointer}.installation-card:hover{transform:translateY(-2px);box-shadow:0 6px 12px #0000001a}.installation-info{flex:1;min-width:250px}.uc-header{font-size:1.2rem;font-weight:700;color:#2c3e50;display:flex;align-items:center;gap:8px;margin-bottom:8px}.address-row{color:#555;margin-bottom:10px;display:flex;align-items:center;gap:8px}.badges-container{display:flex;gap:8px;flex-wrap:wrap}.badge{padding:4px 10px;border-radius:15px;font-size:.85rem;font-weight:500}.badge-ligacao{background:#e3f2fd;color:#0d47a1}.badge-tipo{background:#e8f5e9;color:#1b5e20}.badge-regra{background:#fff3e0;color:#e65100}.card-actions{margin-top:10px;display:flex;gap:8px}.action-btn{background-color:#f90;color:#fff;border:none;padding:10px 16px;border-radius:6px;cursor:pointer;font-weight:600;display:inline-flex;align-items:center;gap:6px;font-size:.95rem;transition:background-color .2s}.action-btn:hover{background-color:#e68a00}.btn-secondary{background-color:#6c757d}.btn-secondary:hover{background-color:#5a6268}.footer-navigation{margin-top:30px}.error-text{color:#dc3545;text-align:center;margin-top:20px}.cliente-header{text-align:center;border-bottom:1px solid #dee2e6;padding-bottom:20px;margin-bottom:20px}.cliente-header h1{margin:0}.cliente-doc{color:#6c757d;font-size:1em}.header-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.header-actions h2{margin:0;text-align:left}.faturas-table{width:100%;border-collapse:collapse}.faturas-table th,.faturas-table td{text-align:left;padding:12px;border-bottom:1px solid #dee2e6}.faturas-table th{background-color:#f8f9fa;font-weight:600}.status-select{width:150px;padding:8px 30px 8px 12px;border-radius:6px;border:1px solid transparent;font-weight:600;text-align:left;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .75rem center;background-size:16px 12px;cursor:pointer}.status-select:hover{border:2px solid black;transition:all 2s}.status-paga{background-color:#d1e7dd;color:#0f5132}.status-pendente{background-color:#fff3cd;color:#664d03}.status-vencida{background-color:#f8d7da;color:#842029}.status-cancelada{background-color:#e2e3e5;color:#41464b}.pdf-btn{background-color:#dc3545;color:#fff;padding:8px 12px;border:none;border-radius:6px;cursor:pointer;font-size:14px;width:120px}.no-data{padding:15px;border-radius:6px;text-align:center;background-color:#e2e3e5;color:#41464b}.status-select{padding:6px 30px 6px 10px;border-radius:20px;border:1px solid #ddd;font-weight:600;font-size:.9rem;cursor:pointer;text-align:center;appearance:none;-webkit-appearance:none;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23333%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E);background-repeat:no-repeat;background-position:right 10px top 50%;background-size:10px auto}.status-paga{background-color:#d4edda;color:#155724;border-color:#c3e6cb}.status-pendente{background-color:#fff3cd;color:#856404;border-color:#ffeeba}.status-atrasada,.status-vencida{background-color:#f8d7da;color:#721c24;border-color:#f5c6cb}.faturas-table tbody tr{cursor:pointer}.actions-cell{display:flex;gap:10px}.actions-cell .btn-details{padding:8px 12px;font-size:14px;border-radius:6px;cursor:pointer;text-decoration:none;color:#fff;background-color:#17a2b8;white-space:nowrap}.cliente-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-top:20px;padding-top:20px;border-top:1px solid #e9ecef}.detail-item{display:flex;flex-direction:column}.detail-item strong{font-size:.9em;color:#6c757d;margin-bottom:4px}.detail-item span{font-size:1.1em;color:#212529;font-weight:500}.detalhes-container{width:100%;max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:25px}.detalhes-header-logo{display:flex;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #e9ecef}.header-logo{height:50px;width:auto;object-fit:contain}.info-table{width:100%;border-collapse:collapse;margin-top:15px}.info-table tbody tr{border-bottom:1px solid #e9ecef}.info-table tbody tr:hover{background-color:#f8f9fa}.info-table tbody tr:last-child{border-bottom:none}.info-table td{padding:12px 15px;font-size:1em;color:#495057}.info-table td:first-child{width:35%;color:#212529;font-weight:500;background-color:#f8f9fa}.subtotal-row td:last-child{font-size:1.05em;font-weight:700}.desconto-row td:last-child{color:#dc3545;font-weight:600}.total-row{background-color:#e7f3ff;border-top:2px solid #ff9900}.total-row td{padding:15px;font-weight:700}.total-row td:last-child{font-size:1.3em;color:#007bff}.detalhes-header{display:flex;justify-content:space-between;align-items:center;gap:20px}.detalhes-header h1{flex:1;color:#343a40;margin:0}.btn-export-pdf{background-color:#f90;color:#fff;padding:10px 20px;width:140px;height:44px;border:none;border-radius:6px;font-weight:600;cursor:pointer;font-size:.95rem;transition:opacity .2s,transform .2s;white-space:nowrap;display:flex;align-items:center;justify-content:center}.btn-export-pdf:hover{opacity:.85;transform:translateY(-2px)}.btn-export-pdf:active{opacity:.7;transform:translateY(0)}.card{background-color:#fff;padding:25px;border-radius:8px;box-shadow:0 4px 8px #00000012;border:1px solid #e9ecef}.card h2{margin-top:0;margin-bottom:20px;border-bottom:2px solid #ff9900;padding-bottom:10px}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:15px}.info-grid p{margin:0;font-size:1.1em;color:#495057}.info-grid p strong{color:#212529}.info-fatura .valor-total{font-size:1.3em;font-weight:700;color:#007bff}.error-message{color:#721c24;background-color:#f8d7da;padding:15px;border-radius:8px;text-align:center}.detalhes-fatura-container{padding:20px}.detalhes-header{margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid #e9ecef}.detalhes-header h1{margin-bottom:10px}.detalhes-header p{font-size:1.1em;color:#6c757d;margin:4px 0}.detalhes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:25px;margin-bottom:40px}.detalhe-item{background-color:#f8f9fa;padding:15px;border-radius:8px;border-left:5px solid #007bff}.detalhe-item span{display:block;font-size:.9em;color:#6c757d;margin-bottom:5px}.detalhe-item strong{font-size:1.4em;color:#212529}.detalhe-item.total{border-left-color:#28a745;background-color:#e9f5ec}.detalhe-item.total strong,.detalhe-item .status-paga{color:#28a745}.detalhe-item .status-pendente{color:#ffc107}.detalhe-item .status-vencida{color:#dc3545}.detalhe-item .status-cancelada{color:#6c757d}.login-container{display:flex;justify-content:center;align-items:center;height:100vh;width:100vw;background-image:url(https://images.unsplash.com/photo-1558449028-b53a39d100fc?ixlib=rb-4.1.0&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D&auto=format&fit=crop&q=80&w=1074);background-size:cover;background-position:center;position:relative}.login-container:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-color:#1b2129cc;z-index:1}.login-form{padding:40px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #0000001a;width:100%;max-width:400px;position:relative;z-index:2;display:flex;flex-direction:column;align-items:center}.login-logo{width:90px;height:auto;margin-bottom:25px}.login-form .form-group{margin-bottom:20px;width:100%}.login-form label{display:block;margin-bottom:8px;font-weight:600;text-align:left}.login-form input{width:100%;padding:10px;border:1px solid #ced4da;border-radius:4px;box-sizing:border-box}.login-form button{width:100%;padding:12px;background-color:#007bff;color:#fff;border:none;border-radius:4px;font-size:16px;cursor:pointer}.login-form .error-message{color:#dc3545;text-align:center;margin-bottom:15px}.password-wrapper{position:relative;width:100%}.password-toggle-btn{position:absolute;top:75%;right:10px;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:0;width:auto;color:#6c757d;font-size:18px;display:flex;align-items:center}.password-toggle-btn:hover{color:#343a40}:root{--yellow: #dcdf43;--blue: #031f7e;--red: rgb(187, 48, 6);box-sizing:border-box;margin:0}.btn-blue{background-color:var(--blue)}.btn-blue:hover,.btn-orange:hover,.btn-red:hover{opacity:80%;color:#f0ffffd0;transform:scale(1.01);transition:all 1s}.btn-orange{background-color:#f90}.btn-red{background-color:var(--red)}.back-link{color:#f90;font-weight:600;text-decoration:none}.back-link:hover{color:#333}.second-action{gap:5px;background-color:var(--blue);color:#fff;padding:10px;width:fit-content;border:none;border-radius:6px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .2s,transform .2s;text-decoration:none}.second-action:hover{opacity:.85;transform:translateY(-2px)}.action-btn{background-color:#f90;color:#fff;padding:10px 20px;width:fit-content;height:44px;border:none;border-radius:6px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .2s,transform .2s;text-decoration:none}.action-btn:hover{opacity:.85;transform:translateY(-2px)}.action-btn:active{opacity:.7;transform:translateY(0)}
