:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;font-weight:400;color:#1e293b;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;margin:0;padding:0}body{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#1e293b}#root{width:100%;height:100%}a{font-weight:500;color:#3b82f6;text-decoration:none;transition:color .2s ease}a:hover{color:#1e40af}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #3b82f640}button:hover{background:linear-gradient(135deg,#1e40af,#6d28d9);box-shadow:0 6px 16px #3b82f659;transform:translateY(-2px)}button:focus,button:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}button:active{transform:translateY(0)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}::selection{background:#3b82f6;color:#fff}::-moz-selection{background:#3b82f6;color:#fff}input,textarea,select{font-family:inherit}::placeholder{color:#94a3b8;opacity:1}:-ms-input-placeholder{color:#94a3b8}::-ms-input-placeholder{color:#94a3b8}.sidebar{background:#fff;color:#1e293b;height:100vh;width:260px;transition:width .3s ease;display:flex;flex-direction:column;flex-shrink:0;padding:1.5rem 1rem;border-right:1px solid #e2e8f0;box-shadow:1px 0 3px #0000000d}.sidebar.collapsed{width:80px}.logo-container{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #e2e8f0}.logo-container img{width:140px;transition:all .3s ease}.sidebar.collapsed .logo-container img{width:0;opacity:0}.collapse-btn{background:none;border:none;color:#64748b;cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.collapse-btn:hover{background:#f1f5f9;color:#3b82f6}.sidebar ul{list-style:none;padding:0;margin:0;flex:1}.sidebar li{margin:.5rem 0}.sidebar a{display:flex;align-items:center;gap:12px;text-decoration:none;color:#64748b;padding:.875rem 1rem;border-radius:10px;transition:all .2s ease;font-weight:500;font-size:.95rem;position:relative;overflow:hidden}.sidebar a:before{content:"";position:absolute;left:0;top:0;height:100%;width:3px;background:linear-gradient(180deg,#3b82f6,#8b5cf6);transform:scaleY(0);transition:transform .2s ease}.sidebar a:hover{background:#f1f5f9;color:#1e293b}.sidebar a:hover:before{transform:scaleY(1)}.sidebar a.active{background:linear-gradient(135deg,#eff6ff,#f3e8ff);color:#3b82f6;border-left:3px solid #3b82f6;padding-left:calc(1rem - 3px)}.sidebar a.active:before{transform:scaleY(1)}.sidebar a .icon{flex-shrink:0;width:20px;height:20px}@media (max-width: 768px){.sidebar{height:auto;width:100%;flex-direction:row;align-items:center;padding:.75rem 1rem;position:sticky;top:0;max-height:none;border-right:none;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d}.logo-container img{width:100px}.logo-container{margin-bottom:0;align-items:center;padding-bottom:0;border-bottom:none;margin-right:auto}.collapse-btn{display:none}.sidebar ul{display:flex;gap:.5rem;margin-left:auto}.sidebar li{margin:0}.sidebar a{padding:.75rem 1rem;border-radius:8px;font-size:.9rem}.sidebar a:before{display:none}.sidebar a.active{border-left:none;padding-left:1rem}nav{z-index:60}}@media (max-width: 480px){.sidebar{padding:.5rem .75rem}.logo-container img{width:50px}.sidebar ul{display:flex;gap:.4rem;margin-left:0;align-items:center;width:100%;justify-content:space-between}.sidebar a span{display:none}.sidebar a{padding:.6rem;flex:1;display:flex;align-items:center;justify-content:center}}@media (max-width: 480px){.logo-container{flex:0 0 auto}.sidebar ul{flex:1 1 auto}.sidebar li{flex:1 1 0;display:flex;justify-content:center}.sidebar a{padding:.6rem .4rem}}.home-container{max-width:1200px;margin:2rem auto;text-align:center;padding:0 1rem}.home-cards{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center;margin-top:2rem}.card{background:#f9f9f9;border-radius:12px;padding:1.5rem;width:250px;box-shadow:0 4px 8px #0000001a;display:flex;flex-direction:column;justify-content:space-between;height:200px}.card h2{margin-bottom:.5rem}.card p{margin-top:auto}.card button{margin-top:1rem;background-color:#4caf50;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer}.card button:hover{background-color:#45a049}.home-footer{margin-top:3rem;font-style:italic}.cadastro-container{padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;width:100%;box-sizing:border-box}.form-cliente{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 10px 25px -5px #00000014,0 5px 10px -5px #0000000a;margin-bottom:2.5rem;width:100%;box-sizing:border-box;border:1px solid #e2e8f0}h2,h3{margin-bottom:1.5rem;color:#1e293b;font-weight:700;font-size:1.5rem}h3{font-size:1.25rem;margin-top:0}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.5rem}input[type=text],input[type=date],input[type=number],input[type=email],input[type=password]{font-size:1rem}input,select{padding:.875rem 1rem;border:1.5px solid #e2e8f0;border-radius:10px;width:100%;box-sizing:border-box;font-size:.95rem;transition:all .3s ease;background-color:#fff;color:#1e293b;font-family:inherit}input::placeholder{color:#94a3b8}input:focus,select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a,inset 0 0 0 1px #3b82f633;background-color:#eff6ff}input:disabled{background-color:#f1f5f9;color:#94a3b8;cursor:not-allowed;border-color:#e2e8f0}.checkbox-container{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:1rem;background:#f8fafc;border-radius:10px;border:1px solid #e2e8f0}.checkbox-container label{color:#475569;font-weight:500;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-container input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#3b82f6}.submit-btn{padding:.95rem 2rem;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;font-size:1rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;margin-top:1.5rem;transition:all .3s ease;box-shadow:0 10px 20px #3b82f640}.submit-btn:hover{background:linear-gradient(135deg,#1e40af,#6d28d9);box-shadow:0 15px 30px #3b82f659;transform:translateY(-2px)}.submit-btn:active{transform:translateY(0)}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.table-title{margin-bottom:1.5rem;margin-top:2rem;color:#1e293b;font-size:1.25rem;font-weight:700}.table-title:first-of-type{margin-top:0}.table-section{background:#fff;border-radius:16px;box-shadow:0 10px 25px -5px #00000014,0 5px 10px -5px #0000000a;border:1px solid #e2e8f0;overflow:hidden}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-responsive::-webkit-scrollbar{height:8px}.table-responsive::-webkit-scrollbar-track{background:transparent}.table-responsive::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.table-responsive::-webkit-scrollbar-thumb:hover{background:#94a3b8}.table-responsive table{width:100%;border-collapse:collapse;background:transparent}.table-responsive thead{background:#f1f5f9;position:sticky;top:0;z-index:10}.table-responsive thead th{padding:1.25rem 1rem;text-align:left;font-weight:700;color:#475569;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0}.table-responsive tbody tr{border-bottom:1px solid #e2e8f0;transition:all .2s ease}.table-responsive tbody tr:hover{background:#f8fafc}.table-responsive tbody tr:last-child{border-bottom:none}.table-responsive tbody td{padding:1.25rem 1rem;color:#475569;font-size:.95rem;vertical-align:middle}.table-responsive thead th:first-child,.table-responsive tbody td:first-child{position:sticky;left:0;background:#fff;z-index:9;font-weight:600;color:#1e293b}.table-responsive tbody tr:hover td:first-child{background:#f8fafc}.table-responsive thead th:first-child{background:#f1f5f9}.acoes{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;border:none}.btn-editar,.btn-excluir,.btn-detalhes{padding:.6rem 1rem;border:none;border-radius:8px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease;font-size:.85rem;white-space:nowrap;box-shadow:0 4px 12px #0000001a}.btn-editar{background:linear-gradient(135deg,#3b82f6,#1e40af);min-width:80px}.btn-editar:hover{background:linear-gradient(135deg,#1e40af,#1e3a8a);box-shadow:0 6px 16px #3b82f64d;transform:translateY(-2px)}.btn-editar:active{transform:translateY(0)}.btn-excluir{background:linear-gradient(135deg,#ef4444,#dc2626);min-width:80px}.btn-excluir:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 6px 16px #ef44444d;transform:translateY(-2px)}.btn-excluir:active{transform:translateY(0)}.btn-detalhes{background:linear-gradient(135deg,#8b5cf6,#7c3aed);display:none}.btn-detalhes:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);box-shadow:0 6px 16px #8b5cf64d;transform:translateY(-2px)}.btn-detalhes:active{transform:translateY(0)}.empty-state{text-align:center;padding:3rem 2rem;color:#94a3b8}.empty-state p{font-size:1.1rem;margin:0}@media (max-width: 1024px){.table-responsive thead th,.table-responsive tbody td{padding:1rem .75rem;font-size:.9rem}.btn-editar,.btn-excluir{padding:.5rem .75rem;font-size:.8rem;min-width:70px}}@media (max-width: 768px){.cadastro-container{padding:0}.form-cliente{padding:1.5rem;margin-bottom:2rem}.grid-2{grid-template-columns:1fr;gap:1rem}.table-responsive table{font-size:.9rem}.table-responsive thead th,.table-responsive tbody td{padding:.875rem .75rem}.acoes{flex-direction:row;gap:.4rem}.btn-editar,.btn-excluir{padding:.5rem .6rem;font-size:.75rem;min-width:auto;flex:1}}@media (max-width: 600px){.btn-detalhes{display:inline-block}.table-responsive thead th:not(:first-child):not(:last-child),.table-responsive tbody td:not(:first-child):not(:last-child){display:none}.acoes{flex-direction:column;gap:.5rem}.btn-editar,.btn-excluir{width:100%;min-width:auto}.table-header{padding:1rem 1.5rem}.table-responsive thead th,.table-responsive tbody td{padding:.75rem .5rem}}@media (max-width: 480px){.cadastro-container{padding:0}.form-cliente{padding:1rem;margin-bottom:1.5rem;border-radius:12px}h2,h3{font-size:1.25rem;margin-bottom:1rem}.table-responsive table{font-size:.85rem}.table-responsive thead th,.table-responsive tbody td{padding:.6rem .4rem}.btn-editar,.btn-excluir,.btn-detalhes{padding:.5rem;font-size:.7rem}.table-header{padding:.75rem 1rem}}.details-row td{background:#f8fafc;padding:1rem 1.25rem;border-top:1px solid #e2e8f0}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem 1.5rem}.details-grid div{display:flex;flex-direction:column}.details-grid label{font-weight:600;color:#475569;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.4rem}.details-grid span{color:#1e293b;font-size:.95rem}.form-group{display:flex;align-items:center;margin-bottom:1.5rem;gap:1rem}.form-group label{width:180px;font-weight:600;color:#475569;font-size:.95rem}.form-group select{flex:1;max-width:450px;min-width:250px;box-sizing:border-box;padding:.875rem 1rem;border:1.5px solid #e2e8f0;border-radius:10px;background-color:#fff;color:#1e293b;font-size:.95rem;transition:all .3s ease;font-family:inherit}.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a,inset 0 0 0 1px #3b82f633;background-color:#eff6ff}.form-group select:disabled{background-color:#f1f5f9;color:#94a3b8;cursor:not-allowed;border-color:#e2e8f0}.form-group select option{background-color:#fff;color:#1e293b}.button-group{display:flex;gap:1rem;margin-top:1.5rem}.button-group .submit-btn{margin-top:0;width:auto;padding:.95rem 2rem}.submit-btn-secondary{background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 10px 20px #8b5cf640}.submit-btn-secondary:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);box-shadow:0 15px 30px #8b5cf659}@media (max-width: 600px){.form-group{display:block;margin-bottom:1.25rem}.form-group label{width:100%;display:block;margin-bottom:.5rem}.form-group select{width:100%;min-width:0;max-width:100%}.button-group{flex-direction:column;gap:.75rem}.button-group .submit-btn{width:100%}.submit-btn{width:100%;padding:.95rem 1.5rem;font-size:1rem}}.pd-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(59,130,246,.2);border-top-color:#3b82f6;border-radius:50%;animation:pd-spin 1s linear infinite;margin-left:.5rem;vertical-align:middle}@keyframes pd-spin{to{transform:rotate(360deg)}}.login-container{display:flex;align-items:center;justify-content:center;height:100vh;width:100%;background:#f5f5f5}.login-form{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 15px #0003;width:320px;display:flex;flex-direction:column;gap:1rem;text-align:center}.login-form h2{margin:0 0 .5rem}.login-form input{padding:.8rem;border:1px solid #ccc;border-radius:8px;font-size:1rem}.login-form button{padding:.8rem;border:0;border-radius:8px;background:#07c;color:#fff;font-size:1rem;cursor:pointer}.login-form button:hover{background:#005fa3}.google-login-svg{cursor:pointer;width:200px;height:auto;display:block;margin:0 auto;transition:transform .1s}.google-login-svg:hover{transform:scale(1.05)}*,*:before,*:after{box-sizing:border-box}html,body,#root{min-height:100vh;height:100%;margin:0;padding:0}#root{width:100%;min-height:100vh}:root{--primary: #3b82f6;--primary-dark: #1e40af;--primary-light: #60a5fa;--secondary: #8b5cf6;--accent: #ec4899;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--bg-primary: #f8fafc;--bg-secondary: #f1f5f9;--bg-tertiary: #e2e8f0;--text-primary: #1e293b;--text-secondary: #475569;--text-light: #64748b;--border: #e2e8f0;--shadow: 0 10px 25px -5px rgba(0, 0, 0, .08);--shadow-sm: 0 2px 8px -1px rgba(0, 0, 0, .06)}.app-shell{display:flex;height:100vh;overflow:hidden;background:var(--bg-primary)}.sidebar{width:260px;background:#fff;color:var(--text-primary);padding:1.5rem 1rem;box-sizing:border-box;display:flex;flex-direction:column;height:100vh;overflow-y:auto;flex-shrink:0;border-right:1px solid var(--border);box-shadow:1px 0 3px #0000000d}.main-content{flex-grow:1;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);padding:2rem;overflow-y:auto;overflow-x:hidden;transition:all .3s ease;height:100vh}.main-content::-webkit-scrollbar,.sidebar::-webkit-scrollbar{width:8px}.main-content::-webkit-scrollbar-track,.sidebar::-webkit-scrollbar-track{background:transparent}.main-content::-webkit-scrollbar-thumb,.sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.main-content::-webkit-scrollbar-thumb:hover,.sidebar::-webkit-scrollbar-thumb:hover{background:var(--text-light)}@media (max-width: 768px){.app-shell{flex-direction:column}.sidebar{width:100%;height:auto;padding:.75rem 1rem;flex-direction:row;align-items:center;gap:.5rem;position:sticky;top:0;z-index:50;min-height:auto;max-height:none;border-right:none;border-bottom:1px solid var(--border);box-shadow:0 1px 3px #0000000d}.main-content{padding:1.5rem;height:auto;padding-top:72px}@media (max-width: 480px){.main-content{padding-left:1rem;padding-right:1rem;padding-top:68px}.cadastro-container{padding-left:0;padding-right:0}}.main-content--with-topbar{padding-top:12px}}
