:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#1f2937;background-color:#f5f7fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{font-size:16px;scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden}#root{min-height:100vh}a{font-weight:500;color:#3498db;text-decoration:none}a:hover{color:#2980b9}h1,h2,h3,h4,h5,h6{line-height:1.3;font-weight:600}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease}button:focus,button:focus-visible{outline:2px solid #3498db;outline-offset:2px}input,select,textarea{font-family:inherit;font-size:inherit}img,video{max-width:100%;height:auto}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}*{scrollbar-width:thin;scrollbar-color:#c1c1c1 #f1f1f1}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:12px;max-width:400px;width:calc(100vw - 40px)}.toast{display:flex;align-items:flex-start;gap:14px;padding:16px 18px;background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026,0 0 0 1px #0000000d;position:relative;overflow:hidden;animation:toastSlideIn .3s ease-out}.toast-exit{animation:toastSlideOut .3s ease-out forwards}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.toast-icon{width:24px;height:24px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.toast-icon svg{width:100%;height:100%}.toast-content{flex:1;min-width:0}.toast-title{font-size:14px;font-weight:600;margin:0 0 4px;color:#1f2937}.toast-message{font-size:13px;color:#6b7280;margin:0;line-height:1.4;word-wrap:break-word}.toast-close{width:28px;height:28px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:6px;color:#9ca3af;transition:all .2s ease;flex-shrink:0;margin:-4px -4px -4px 0}.toast-close:hover{background:#f3f4f6;color:#6b7280}.toast-close svg{width:16px;height:16px}.toast-progress{position:absolute;bottom:0;left:0;right:0;height:3px;background:#0000000d}.toast-progress-bar{height:100%;animation:progressShrink linear forwards}@keyframes progressShrink{0%{width:100%}to{width:0%}}.toast-success{border-left:4px solid #27ae60}.toast-success .toast-icon{color:#27ae60}.toast-success .toast-progress-bar{background:#27ae60}.toast-error{border-left:4px solid #e74c3c}.toast-error .toast-icon{color:#e74c3c}.toast-error .toast-progress-bar{background:#e74c3c}.toast-warning{border-left:4px solid #f39c12}.toast-warning .toast-icon{color:#f39c12}.toast-warning .toast-progress-bar{background:#f39c12}.toast-info{border-left:4px solid #3498db}.toast-info .toast-icon{color:#3498db}.toast-info .toast-progress-bar{background:#3498db}@media(max-width:768px){.toast-container{max-width:350px;right:15px}.toast{padding:14px 16px;gap:12px}.toast-icon{width:22px;height:22px}.toast-title{font-size:13px}.toast-message{font-size:12px}.toast-close{width:26px;height:26px}.toast-close svg{width:14px;height:14px}}@media(max-width:480px){.toast-container{inset:auto 20px 20px}.toast{padding:14px 16px}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(100%)}}}:root{--sidebar-width: 270px;--sidebar-collapsed-width: 72px;--sidebar-bg: linear-gradient(180deg, #1a1f2e 0%, #151926 100%);--sidebar-bg-solid: #1a1f2e;--sidebar-hover: rgba(52, 152, 219, .1);--sidebar-active: #3498db;--sidebar-active-gradient: linear-gradient(135deg, #3498db 0%, #2980b9 100%);--sidebar-text: #8b95a5;--sidebar-text-light: #ffffff;--sidebar-border: rgba(255, 255, 255, .08);--mobile-header-height: 64px;--transition-speed: .25s;--transition-bounce: cubic-bezier(.68, -.55, .265, 1.55)}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:var(--mobile-header-height);background:var(--sidebar-bg);z-index:1001;padding:0 15px;align-items:center;justify-content:space-between;box-shadow:0 2px 10px #0000004d}.menu-toggle{background:none;border:none;color:var(--sidebar-text-light);padding:8px;cursor:pointer;border-radius:8px;transition:background var(--transition-speed)}.menu-toggle:hover{background:var(--sidebar-hover)}.menu-toggle svg{width:24px;height:24px}.mobile-brand{display:flex;align-items:center;gap:10px;color:var(--sidebar-text-light);font-weight:600;font-size:16px}.mobile-brand svg{width:28px;height:28px;stroke:var(--sidebar-active)}.mobile-user{display:flex;align-items:center}.mobile-logout{background:none;border:none;color:#e74c3c;padding:8px;cursor:pointer;border-radius:8px;transition:background var(--transition-speed)}.mobile-logout:hover{background:#e74c3c33}.mobile-logout svg{width:22px;height:22px}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0009;z-index:999;opacity:0;visibility:hidden;transition:opacity .35s ease,visibility .35s ease;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.sidebar-overlay.active{opacity:1;visibility:visible}.sidebar{position:fixed;top:0;left:0;height:100vh;width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;z-index:1000;transition:width .3s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1);overflow:hidden;border-right:1px solid var(--sidebar-border);box-shadow:4px 0 20px #00000026}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-brand{display:flex;align-items:center;justify-content:space-between;padding:20px 15px;border-bottom:1px solid var(--sidebar-border);min-height:70px}.sidebar-brand a{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--sidebar-text-light);overflow:hidden}.sidebar-brand svg{width:32px;height:32px;min-width:32px;stroke:var(--sidebar-active)}.brand-text{font-size:18px;font-weight:700;white-space:nowrap;transition:opacity var(--transition-speed)}.sidebar.collapsed .brand-text{opacity:0;width:0}.collapse-btn{background:none;border:none;color:var(--sidebar-text);padding:8px;cursor:pointer;border-radius:8px;transition:all var(--transition-speed);display:flex;align-items:center;justify-content:center}.collapse-btn:hover{background:var(--sidebar-hover);color:var(--sidebar-text-light)}.collapse-btn svg{width:18px;height:18px}.sidebar.collapsed .collapse-btn{position:absolute;right:10px}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:15px 0}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--sidebar-border);border-radius:2px}.sidebar-menu{list-style:none;padding:0;margin:0}.menu-item{margin:4px 12px}.menu-link{display:flex;align-items:center;gap:14px;padding:12px 16px;color:var(--sidebar-text);text-decoration:none;border-radius:10px;transition:all var(--transition-speed) ease;cursor:pointer;border:none;background:none;width:100%;font-size:14px;font-weight:500;font-family:inherit;text-align:left;position:relative}.menu-link:hover{background:var(--sidebar-hover);color:var(--sidebar-text-light);transform:translate(3px)}.menu-link.active{background:#3498db26;color:var(--sidebar-active);border-left:3px solid var(--sidebar-active);padding-left:13px}.menu-link.active .menu-icon svg{stroke:var(--sidebar-active)}.menu-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;min-width:22px}.menu-icon svg{width:100%;height:100%}.menu-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity var(--transition-speed)}.sidebar.collapsed .menu-label{opacity:0;width:0}.submenu-arrow{width:16px;height:16px;min-width:16px;transition:transform var(--transition-speed),opacity var(--transition-speed)}.menu-item.open .submenu-arrow{transform:rotate(180deg)}.sidebar.collapsed .submenu-arrow{opacity:0}.submenu{list-style:none;padding:0;margin:0;max-height:0;overflow:hidden;transition:max-height var(--transition-speed)}.menu-item.open .submenu{max-height:500px}.sidebar.collapsed .submenu{position:absolute;left:var(--sidebar-collapsed-width);top:0;background:var(--sidebar-bg);min-width:180px;border-radius:8px;box-shadow:0 4px 20px #0000004d;max-height:none;padding:8px 0;opacity:0;visibility:hidden;transform:translate(-10px);transition:all var(--transition-speed)}.sidebar.collapsed .menu-item:hover .submenu{opacity:1;visibility:visible;transform:translate(0)}.submenu li a{display:block;padding:10px 15px 10px 49px;color:var(--sidebar-text);text-decoration:none;font-size:13px;transition:all var(--transition-speed);border-radius:6px;margin:2px 10px}.sidebar.collapsed .submenu li a{padding:10px 15px;margin:0;border-radius:0}.submenu li a:hover{background:var(--sidebar-hover);color:var(--sidebar-text-light)}.submenu li a.active{color:var(--sidebar-active);background:#3498db1a}.sidebar-footer{padding:16px;border-top:1px solid var(--sidebar-border);background:#0000001a}.user-info{display:flex;align-items:center;gap:12px;margin-bottom:12px;padding:12px;background:#ffffff0d;border-radius:12px;overflow:hidden;border:1px solid var(--sidebar-border)}.user-avatar{width:40px;height:40px;min-width:40px;background:var(--sidebar-active-gradient);border-radius:10px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #3498db4d}.user-avatar svg{width:20px;height:20px;stroke:#fff}.user-details{display:flex;flex-direction:column;gap:2px;overflow:hidden;transition:opacity var(--transition-speed)}.sidebar.collapsed .user-details{opacity:0;width:0}.user-name{color:var(--sidebar-text-light);font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{color:var(--sidebar-text);font-size:12px;white-space:nowrap;opacity:.8}.logout-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px;background:#e74c3c1a;border:1px solid rgba(231,76,60,.2);border-radius:10px;color:#e74c3c;font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-speed) ease;font-family:inherit}.logout-btn:hover{background:#e74c3c;color:#fff;border-color:#e74c3c;transform:translateY(-2px);box-shadow:0 4px 12px #e74c3c4d}.logout-btn svg{width:18px;height:18px;min-width:18px}.sidebar.collapsed .logout-btn span{display:none}@media(max-width:1024px){.sidebar{transform:translate(-100%);box-shadow:none}.sidebar.mobile-open{transform:translate(0);box-shadow:8px 0 30px #00000040}.sidebar.collapsed{width:var(--sidebar-width)}.sidebar.collapsed .brand-text,.sidebar.collapsed .menu-label,.sidebar.collapsed .submenu-arrow,.sidebar.collapsed .user-details,.sidebar.collapsed .logout-btn span{opacity:1;width:auto}.sidebar.collapsed .submenu{position:static;max-height:0;opacity:1;visibility:visible;transform:none;box-shadow:none;padding:0}.sidebar.collapsed .menu-item.open .submenu{max-height:500px}.sidebar.collapsed .submenu li a{padding:10px 15px 10px 49px;margin:2px 10px;border-radius:6px}.collapse-btn{display:none}.mobile-header{display:flex}.sidebar-overlay{display:block}.sidebar.mobile-open .menu-item{animation:slideInMenu .3s ease forwards;opacity:0}.sidebar.mobile-open .menu-item:nth-child(1){animation-delay:.05s}.sidebar.mobile-open .menu-item:nth-child(2){animation-delay:.08s}.sidebar.mobile-open .menu-item:nth-child(3){animation-delay:.11s}.sidebar.mobile-open .menu-item:nth-child(4){animation-delay:.14s}.sidebar.mobile-open .menu-item:nth-child(5){animation-delay:.17s}.sidebar.mobile-open .menu-item:nth-child(6){animation-delay:.2s}.sidebar.mobile-open .menu-item:nth-child(7){animation-delay:.23s}@keyframes slideInMenu{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.menu-link:active,.submenu li a:active{transform:scale(.98);background:var(--sidebar-hover)}}@media(max-width:480px){.mobile-brand span{display:none}.sidebar{width:100%;max-width:320px}.mobile-header{padding:0 12px}.menu-toggle{padding:10px}.menu-link{padding:14px 16px}.submenu li a{padding:12px 15px 12px 49px}.sidebar-footer{padding:12px}.user-info{padding:10px}.logout-btn{padding:14px}}@media(min-width:1025px){.sidebar.collapsed .menu-item{position:relative}.sidebar.collapsed .menu-link[title]:hover:after{content:attr(title);position:absolute;left:calc(var(--sidebar-collapsed-width) + 10px);top:50%;transform:translateY(-50%);background:var(--sidebar-bg);color:var(--sidebar-text-light);padding:8px 12px;border-radius:6px;font-size:13px;white-space:nowrap;box-shadow:0 4px 15px #0000004d;z-index:100}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;min-height:300px}.loading-fullscreen{position:fixed;inset:0;background:#fffffff2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;min-height:100vh}.loading-content{display:flex;flex-direction:column;align-items:center;gap:20px}.loading-spinner{position:relative;width:80px;height:80px}.spinner-ring{position:absolute;width:100%;height:100%;border-radius:50%;border:3px solid transparent}.spinner-ring:nth-child(1){border-top-color:#3498db;animation:spin 1.2s ease-in-out infinite}.spinner-ring:nth-child(2){border-right-color:#2ecc71;animation:spin 1.2s ease-in-out infinite .15s;width:70%;height:70%;top:15%;left:15%}.spinner-ring:nth-child(3){border-bottom-color:#f39c12;animation:spin 1.2s ease-in-out infinite .3s reverse;width:50%;height:50%;top:25%;left:25%}.spinner-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:28px;height:28px;animation:pulse 2s ease-in-out infinite}.spinner-icon svg{width:100%;height:100%;stroke:#3498db}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:.6;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}}.loading-message{color:#2c3e50;font-size:16px;font-weight:500;margin:0;text-align:center}.loading-dots{display:flex;gap:6px}.loading-dots span{width:8px;height:8px;background:#3498db;border-radius:50%;animation:bounce 1.4s ease-in-out infinite both}.loading-dots span:nth-child(1){animation-delay:0s}.loading-dots span:nth-child(2){animation-delay:.16s}.loading-dots span:nth-child(3){animation-delay:.32s}@keyframes bounce{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.loading-small .loading-spinner{width:50px;height:50px}.loading-small .spinner-icon{width:18px;height:18px}.loading-small .loading-message{font-size:14px}.loading-small .loading-dots span{width:6px;height:6px}.loading-large .loading-spinner{width:100px;height:100px}.loading-large .spinner-icon{width:36px;height:36px}.loading-large .loading-message{font-size:18px}.loading-large .loading-dots span{width:10px;height:10px}@media(max-width:768px){.loading-container{padding:50px 18px;min-height:250px}.loading-spinner{width:70px;height:70px}.spinner-icon{width:24px;height:24px}.loading-message{font-size:15px}.loading-dots span{width:7px;height:7px}.loading-large .loading-spinner{width:90px;height:90px}.loading-large .spinner-icon{width:32px;height:32px}}@media(max-width:480px){.loading-container{padding:40px 16px;min-height:200px}.loading-spinner{width:60px;height:60px}.spinner-icon{width:22px;height:22px}.loading-message{font-size:14px}.loading-dots span{width:6px;height:6px}.loading-large .loading-spinner{width:80px;height:80px}.loading-large .spinner-icon{width:28px;height:28px}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1f2e,#2c3e50,#1a1f2e);padding:20px;position:relative;overflow:hidden}.login-bg-shapes{position:absolute;inset:0;overflow:hidden;pointer-events:none}.shape{position:absolute;border-radius:50%;opacity:.1}.shape-1{width:400px;height:400px;background:linear-gradient(135deg,#3498db,#2980b9);top:-100px;right:-100px;animation:float 15s ease-in-out infinite}.shape-2{width:300px;height:300px;background:linear-gradient(135deg,#27ae60,#2ecc71);bottom:-50px;left:-50px;animation:float 20s ease-in-out infinite reverse}.shape-3{width:200px;height:200px;background:linear-gradient(135deg,#9b59b6,#8e44ad);top:50%;left:10%;animation:float 18s ease-in-out infinite}@keyframes float{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(20px,-20px) rotate(5deg)}50%{transform:translate(-10px,20px) rotate(-5deg)}75%{transform:translate(-20px,-10px) rotate(3deg)}}.login-box{background:#fff;border-radius:24px;box-shadow:0 25px 50px #00000040,0 0 0 1px #ffffff1a;padding:50px 45px;width:100%;max-width:440px;position:relative;z-index:1;animation:slideUp .5s ease-out}.login-header{text-align:center;margin-bottom:40px}.login-logo{width:72px;height:72px;background:linear-gradient(135deg,#3498db,#2980b9);border-radius:18px;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;box-shadow:0 10px 30px #3498db4d}.login-logo svg{width:36px;height:36px;stroke:#fff}.login-header h1{color:#1a1f2e;font-size:28px;font-weight:700;margin:0 0 8px;letter-spacing:-.5px}.login-header p{color:#7f8c8d;font-size:15px;margin:0;font-weight:400}.login-form{display:flex;flex-direction:column;gap:24px}.login-error{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#fee2e2,#fecaca);border:1px solid #f87171;color:#dc2626;padding:14px 18px;border-radius:12px;font-size:14px;font-weight:500;animation:shake .5s ease-in-out}.login-error svg{width:20px;height:20px;flex-shrink:0}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-5px)}40%,80%{transform:translate(5px)}}.form-group{display:flex;flex-direction:column;gap:10px}.form-group label{display:flex;align-items:center;gap:8px;color:#2c3e50;font-weight:600;font-size:14px}.form-group label svg{width:18px;height:18px;stroke:#7f8c8d}.input-wrapper{position:relative}.input-wrapper input{width:100%;padding:16px 18px;border:2px solid #e5e7eb;border-radius:12px;font-size:15px;font-family:inherit;transition:all .3s ease;background:#f9fafb}.input-wrapper input:hover{border-color:#d1d5db;background:#fff}.input-wrapper input:focus{outline:none;border-color:#3498db;background:#fff;box-shadow:0 0 0 4px #3498db1f}.input-wrapper input:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.7}.input-wrapper input::placeholder{color:#9ca3af}.password-wrapper{position:relative}.password-wrapper input{padding-right:50px}.toggle-password{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;padding:6px;cursor:pointer;color:#9ca3af;transition:color .2s;display:flex;align-items:center;justify-content:center}.toggle-password:hover{color:#3498db}.toggle-password svg{width:20px;height:20px}.btn-login{display:flex;align-items:center;justify-content:center;gap:10px;background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;padding:16px 24px;border-radius:12px;font-size:16px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .3s ease;margin-top:8px;position:relative;overflow:hidden}.btn-login:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.btn-login:hover:not(:disabled):before{left:100%}.btn-login:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 30px #3498db66}.btn-login:active:not(:disabled){transform:translateY(0)}.btn-login:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-login svg{width:20px;height:20px;transition:transform .3s ease}.btn-login:hover:not(:disabled) svg{transform:translate(4px)}.btn-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.login-footer{text-align:center;margin-top:32px;padding-top:24px;border-top:1px solid #f0f0f0}.login-footer p{color:#9ca3af;font-size:13px;margin:0}.auth-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1f2e,#2c3e50)}.auth-loading-content{text-align:center;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.auth-loading-content .loading-spinner{width:50px;height:50px;border:3px solid rgba(255,255,255,.1);border-top-color:#3498db;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}.auth-loading-content p{color:#fff;font-size:16px;font-weight:500}@media(max-width:1024px){.login-box{max-width:420px;padding:45px 40px}.shape-1{width:350px;height:350px}.shape-2{width:260px;height:260px}.shape-3{width:160px;height:160px}}@media(max-width:768px){.login-container{padding:20px}.login-box{max-width:400px;padding:40px 32px;border-radius:22px}.login-header{margin-bottom:32px}.login-logo{width:64px;height:64px;border-radius:16px;margin-bottom:20px}.login-logo svg{width:32px;height:32px}.login-header h1{font-size:26px}.login-form{gap:20px}.shape-1{width:300px;height:300px;top:-80px;right:-80px}.shape-2{width:220px;height:220px}.shape-3{width:140px;height:140px;opacity:.08}}@media(max-width:480px){.login-container{padding:15px}.login-box{padding:35px 25px;border-radius:20px}.login-logo{width:60px;height:60px;border-radius:14px}.login-logo svg{width:30px;height:30px}.login-header h1{font-size:24px}.login-header p{font-size:14px}.input-wrapper input{padding:14px 16px;font-size:14px}.btn-login{padding:14px 20px;font-size:15px}.shape-1{width:250px;height:250px}.shape-2{width:180px;height:180px}.shape-3{display:none}}.landing-page{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#1f2937;scroll-behavior:smooth}:root{--primary-color: #2A5C6B;--secondary-color: #FF6B35;--verde-primario: #1b4d3e}.landing-navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:#ffffffe6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid #f3f4f6;transition:all .3s ease}.landing-navbar.scrolled{background:#fffffff2;box-shadow:0 4px 6px -1px #0000001a}.navbar-container{max-width:1280px;margin:0 auto;padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.navbar-brand{display:flex;align-items:center;gap:.5rem;text-decoration:none}.navbar-brand:hover .navbar-logo{transform:scale(1.05)}.navbar-logo{height:40px;width:auto;transition:transform .3s ease}.navbar-brand-text{font-weight:700;font-size:1.25rem;color:var(--primary-color);letter-spacing:-.025em}.navbar-menu{display:flex;align-items:center;gap:2rem}.navbar-menu a{color:#4b5563;text-decoration:none;font-weight:500;transition:color .2s ease}.navbar-menu a:hover{color:var(--secondary-color)}.btn-admin{padding:.625rem 1.5rem;border-radius:9999px;background:linear-gradient(135deg,var(--secondary-color),#ff8555);color:#fff!important;font-weight:600;box-shadow:0 4px 14px #ff6b3559;transition:all .3s ease}.btn-admin:hover{box-shadow:0 6px 20px #ff6b3573;transform:translateY(-2px)}.mobile-menu-btn{display:none;background:none;border:none;color:#4b5563;cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s ease}.mobile-menu-btn:hover{background:#f3f4f6}.mobile-menu-btn:active{transform:scale(.95)}.desktop-menu{display:flex}.mobile-menu{display:flex;flex-direction:column;padding:0 1.5rem;gap:0;background:#fff;border-top:1px solid #f3f4f6;max-height:0;overflow:hidden;opacity:0;transition:max-height .35s cubic-bezier(.4,0,.2,1),opacity .25s ease,padding .35s ease}.mobile-menu.open{max-height:320px;opacity:1;padding:1.5rem;gap:.75rem}.mobile-menu a{color:#4b5563;text-decoration:none;font-weight:500;padding:.875rem 1rem;border-radius:10px;transition:all .2s ease;transform:translate(-10px);opacity:0}.mobile-menu.open a{transform:translate(0);opacity:1}.mobile-menu.open a:nth-child(1){transition-delay:.05s}.mobile-menu.open a:nth-child(2){transition-delay:.1s}.mobile-menu.open a:nth-child(3){transition-delay:.15s}.mobile-menu.open a:nth-child(4){transition-delay:.2s}.mobile-menu a:hover,.mobile-menu a:active{background:#f9fafb;color:var(--secondary-color)}.mobile-menu .btn-admin{text-align:center;margin-top:.5rem;padding:.875rem 1.5rem}@media(max-width:768px){.desktop-menu{display:none}.mobile-menu-btn{display:flex;align-items:center;justify-content:center}.navbar-container{padding:.875rem 1rem}.navbar-brand-text{font-size:1.1rem}.navbar-logo{height:36px}}.hero-section{position:relative;min-height:80vh;display:flex;align-items:center;justify-content:center;overflow:hidden}.hero-background{position:absolute;inset:0;z-index:0}.hero-image{width:100%;height:100%;object-fit:cover;object-position:center}.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#2a5c6be6,#2d6a7acc);mix-blend-mode:multiply}.hero-content{position:relative;z-index:10;text-align:center;color:#fff;padding:0 1.5rem;max-width:800px}.hero-content h1{font-size:clamp(2rem,5vw,3.75rem);font-weight:700;margin-bottom:1.5rem;line-height:1.1}.hero-content p{font-size:clamp(1rem,2vw,1.25rem);color:#e5e7eb;margin-bottom:2.5rem;max-width:640px;margin-left:auto;margin-right:auto}.btn-cta{display:inline-block;padding:1rem 2rem;border-radius:9999px;background:linear-gradient(135deg,var(--secondary-color),#ff8555);color:#fff;font-weight:700;font-size:1.125rem;text-decoration:none;box-shadow:0 10px 30px #ff6b3566;transition:all .3s ease}.btn-cta:hover{box-shadow:0 15px 40px #ff6b3580;transform:translateY(-4px)}@media(max-width:768px){.hero-section{min-height:70vh;padding-top:70px}.hero-content{padding:0 1.25rem}.hero-content h1{font-size:1.75rem;margin-bottom:1rem;line-height:1.2}.hero-content p{font-size:.95rem;margin-bottom:2rem;line-height:1.5}.btn-cta{padding:.875rem 1.75rem;font-size:1rem;width:100%;max-width:280px}}@media(max-width:480px){.hero-section{min-height:65vh}.hero-content h1{font-size:1.5rem}.hero-content p{font-size:.9rem}}.section-container{max-width:1280px;margin:0 auto;padding:0 1.5rem}.sobre-section{padding:5rem 0;background:#fff}.sobre-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}@media(max-width:768px){.sobre-grid{grid-template-columns:1fr;gap:2rem}.sobre-section{padding:3rem 0}.section-container{padding:0 1rem}.sobre-text h2{font-size:1.5rem;text-align:center}.sobre-text .lead,.sobre-text p{text-align:center}.stats-grid{grid-template-columns:1fr 1fr;gap:1rem}.stat-card{padding:1rem}.stat-card h3{font-size:1.5rem}.sobre-card{padding:1.5rem}.sobre-card h4{font-size:1.25rem;text-align:center}}.sobre-text h2{font-size:2rem;font-weight:700;color:var(--primary-color);margin-bottom:1.5rem}.sobre-text .lead{font-size:1.125rem;color:#4b5563;margin-bottom:1rem;line-height:1.6}.sobre-text p{color:#6b7280;margin-bottom:2rem;line-height:1.6}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.stat-card{text-align:center;padding:1.5rem;border-radius:1rem;background:#f9fafb;border:1px solid #f3f4f6}.stat-card h3{font-size:2rem;font-weight:700;color:var(--secondary-color);margin-bottom:.5rem}.stat-card p{font-size:.875rem;color:#6b7280;font-weight:500;margin:0}.sobre-card{background:linear-gradient(135deg,var(--primary-color),#2d6a7a);padding:2.5rem;border-radius:1.5rem;color:#fff;box-shadow:0 25px 50px -12px #00000040;position:relative;overflow:hidden}.card-glow{position:absolute;top:-2.5rem;right:-2.5rem;width:10rem;height:10rem;background:#ffffff1a;border-radius:50%;filter:blur(3rem);transition:transform .7s ease}.sobre-card:hover .card-glow{transform:scale(1.5)}.sobre-card h4{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;position:relative;z-index:10}.sobre-card ul{list-style:none;padding:0;margin:0;position:relative;z-index:10}.sobre-card li{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1rem}.sobre-card li svg{color:var(--secondary-color);flex-shrink:0;margin-top:.25rem}.servicos-section{padding:5rem 0;background:#f9fafb}.servicos-section h2{font-size:2rem;font-weight:700;color:var(--primary-color);text-align:center;margin-bottom:4rem}.servicos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}@media(max-width:1024px){.servicos-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.servicos-grid{grid-template-columns:1fr;gap:1.25rem}.servicos-section{padding:3rem 0}.servicos-section h2{font-size:1.5rem;margin-bottom:2.5rem}.service-card{padding:1.5rem;border-radius:.875rem}.service-card:hover{transform:translateY(-4px)}.service-icon{width:3rem;height:3rem;margin-bottom:1rem}.service-card h3{font-size:1.1rem}}.service-card{background:#fff;border-radius:1rem;padding:2rem;box-shadow:0 4px 6px -1px #0000001a;border:1px solid #f3f4f6;transition:all .3s ease}.service-card:hover{box-shadow:0 25px 50px -12px #00000026;transform:translateY(-8px)}.service-icon{width:3.5rem;height:3.5rem;border-radius:.75rem;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;transition:background-color .3s ease}.icon-green{background:#ecfdf5;color:var(--verde-primario)}.service-card:hover .icon-green{background:#d1fae5}.icon-blue{background:#eff6ff;color:#2563eb}.service-card:hover .icon-blue{background:#dbeafe}.icon-orange{background:#fff7ed;color:#ea580c}.service-card:hover .icon-orange{background:#fed7aa}.icon-purple{background:#faf5ff;color:#9333ea}.service-card:hover .icon-purple{background:#e9d5ff}.icon-teal{background:#f0fdfa;color:#0d9488}.service-card:hover .icon-teal{background:#ccfbf1}.icon-red{background:#fef2f2;color:#dc2626}.service-card:hover .icon-red{background:#fee2e2}.service-card h3{font-size:1.25rem;font-weight:700;color:#1f2937;margin-bottom:1rem}.service-card ul{list-style:none;padding:0;margin:0}.service-card li{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#4b5563;margin-bottom:.5rem}.service-card li svg{color:#22c55e;flex-shrink:0}.contato-section{padding:5rem 0;background:#fff}.contato-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}@media(max-width:1024px){.contato-grid{grid-template-columns:1fr;gap:2rem}.contato-section{padding:3rem 0}.map-container{height:280px;border-radius:1rem;order:2}.contato-card{padding:1.5rem;border-radius:1rem;order:1}.contato-card h2{font-size:1.5rem;margin-bottom:1.5rem;text-align:center}.info-item{flex-direction:column;align-items:center;text-align:center}.info-item h5{margin-top:.5rem}.btn-email{margin-top:1rem}}.map-container{height:400px;border-radius:1.5rem;overflow:hidden;box-shadow:0 25px 50px -12px #00000026;border:1px solid #e5e7eb}.contato-card{background:#fff;padding:2.5rem;border-radius:1.5rem;box-shadow:0 20px 40px -15px #0000001a;border:1px solid #f3f4f6}.contato-card h2{font-size:1.875rem;font-weight:700;color:#1f2937;margin-bottom:2rem}.contato-info{display:flex;flex-direction:column;gap:1.5rem}.info-item{display:flex;align-items:flex-start;gap:1rem}.info-icon{width:3rem;height:3rem;border-radius:50%;background:#eff6ff;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--primary-color)}.info-item h5{font-weight:700;color:#1f2937;margin:0 0 .25rem}.info-item p{color:#4b5563;margin:0}.btn-email{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem;border-radius:.75rem;background:linear-gradient(135deg,var(--secondary-color),#ff8555);color:#fff;font-weight:700;text-decoration:none;box-shadow:0 10px 30px #ff6b354d;transition:all .3s ease;margin-top:.5rem}.btn-email:hover{box-shadow:0 15px 40px #ff6b3566;transform:translateY(-2px)}.landing-footer{background:#111827;color:#fff;padding:4rem 0 0}.footer-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:3rem;text-align:center}@media(max-width:768px){.footer-grid{grid-template-columns:1fr;text-align:center;gap:2rem}.landing-footer{padding:2.5rem 0 0}.footer-logo{height:40px}.footer-brand p{font-size:.9rem}.footer-contact h5,.footer-certs h5{font-size:1rem;margin-bottom:1rem}.footer-bottom{margin-top:1.5rem;padding:1rem 0}.footer-bottom p{font-size:.8rem}}.footer-brand{display:flex;flex-direction:column;align-items:center}@media(min-width:769px){.footer-brand{align-items:flex-start;text-align:left}}.footer-logo{height:48px;width:auto;margin-bottom:1rem;filter:brightness(0) invert(1);opacity:.8}.footer-brand p{color:#9ca3af;line-height:1.6}.footer-contact h5,.footer-certs h5{font-weight:700;font-size:1.125rem;color:#e5e7eb;margin-bottom:1.5rem}.footer-contact ul,.footer-certs ul{list-style:none;padding:0;margin:0}.footer-contact li,.footer-certs li{display:flex;align-items:center;justify-content:center;gap:.5rem;color:#9ca3af;margin-bottom:.75rem}@media(min-width:769px){.footer-contact li{justify-content:center}.footer-certs{text-align:right}.footer-certs li{justify-content:flex-end}}.footer-contact svg,.footer-certs svg{color:var(--secondary-color);flex-shrink:0}.footer-bottom{margin-top:2.5rem;padding:1.5rem 0;border-top:1px solid #374151;text-align:center}.footer-bottom p{color:#6b7280;font-size:.875rem;margin:0}.error-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:30px 20px;background-color:#fef2f2;border:1px solid #fecaca;border-radius:12px;margin:20px 0}.error-icon{font-size:48px;margin-bottom:12px;color:#dc2626}.error-text{color:#991b1b;font-size:15px;margin:10px 0;text-align:center;line-height:1.5}.error-retry-btn{margin-top:16px;padding:10px 20px;background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex;align-items:center;gap:8px}.error-retry-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3498db4d}@media(max-width:768px){.error-message{padding:26px 18px;border-radius:10px}.error-icon{font-size:44px}.error-text{font-size:14px}.error-retry-btn{padding:10px 18px}}@media(max-width:480px){.error-message{padding:24px 16px;margin:15px 0;border-radius:8px}.error-icon{font-size:40px}.error-text{font-size:14px}.error-retry-btn{width:100%;justify-content:center;padding:12px 18px}}.page-header-component{margin-bottom:24px}.breadcrumbs{margin-bottom:14px}.breadcrumbs ol{display:flex;align-items:center;flex-wrap:wrap;gap:4px;list-style:none;margin:0;padding:0}.breadcrumbs li{display:flex;align-items:center;gap:4px;font-size:13px}.breadcrumbs a{display:flex;align-items:center;gap:6px;color:#6b7280;text-decoration:none;padding:4px 8px;border-radius:6px;transition:all .2s ease}.breadcrumbs a:hover{color:#3498db;background:#3498db14}.breadcrumbs a svg{width:14px;height:14px}.breadcrumb-separator{width:16px;height:16px;color:#d1d5db;flex-shrink:0}.breadcrumbs .current{color:#1f2937;font-weight:500;padding:4px 8px}.page-header-content{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.page-header-info{display:flex;align-items:center;gap:14px;min-width:0;flex:1}.page-header-icon{width:48px;height:48px;background:linear-gradient(135deg,#3498db,#2980b9);border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #3498db40;flex-shrink:0}.page-header-icon svg{width:24px;height:24px;stroke:#fff}.page-header-text{min-width:0;flex:1}.page-header-text h1{font-size:1.5rem;font-weight:700;color:#1f2937;margin:0;letter-spacing:-.02em;line-height:1.2}.page-header-text p{font-size:14px;color:#6b7280;margin:4px 0 0;line-height:1.4}.page-header-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex-shrink:0}.page-header-actions .btn,.page-header-actions .btn-primary,.page-header-actions .btn-secondary{display:inline-flex;align-items:center;gap:8px;white-space:nowrap}@media(max-width:1024px){.page-header-content{flex-direction:column;align-items:stretch}.page-header-actions{width:100%;justify-content:flex-start}}@media(max-width:768px){.page-header-component{margin-bottom:20px}.page-header-content,.page-header-info{gap:12px}.page-header-icon{width:42px;height:42px;border-radius:10px}.page-header-icon svg{width:20px;height:20px}.page-header-text h1{font-size:1.25rem}.page-header-text p{font-size:13px}.page-header-actions{width:100%;flex-wrap:wrap}.page-header-actions .btn,.page-header-actions .btn-primary,.page-header-actions .btn-secondary{flex:1;min-width:0;justify-content:center}.page-header-actions .select-filter{width:100%;flex:none}.breadcrumbs{margin-bottom:10px}.breadcrumbs li{font-size:12px}.breadcrumbs a{padding:2px 6px}}@media(max-width:480px){.page-header-component{margin-bottom:16px}.page-header-text h1{font-size:1.1rem}.page-header-text p{font-size:12px}.page-header-icon{width:38px;height:38px;border-radius:8px}.page-header-icon svg{width:18px;height:18px}.page-header-actions .btn svg+span,.page-header-actions .btn-primary svg+span,.page-header-actions .btn-secondary svg+span{display:none}.page-header-actions .btn,.page-header-actions .btn-primary,.page-header-actions .btn-secondary{padding:10px 14px;flex:0 0 auto;min-width:auto}.breadcrumbs li:not(:last-child):not(:first-child){display:none}}.page-header-actions .periodo-selector{display:flex;gap:4px;background:#e5e7eb;padding:4px;border-radius:8px}.page-header-actions .periodo-btn{padding:8px 16px;border:none;background:transparent;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;color:#6b7280;white-space:nowrap}.page-header-actions .periodo-btn:hover{color:#1f2937}.page-header-actions .periodo-btn.active{background:#fff;color:#3498db;box-shadow:0 1px 3px #0000001a}@media(max-width:768px){.page-header-actions .periodo-selector{width:100%;justify-content:stretch}.page-header-actions .periodo-btn{flex:1;text-align:center;padding:8px 10px;font-size:12px}}.date-filter{display:flex;flex-wrap:wrap;align-items:center;gap:16px;padding:12px 16px;background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;margin-bottom:20px}.page-header-actions .date-filter{margin-bottom:0;box-shadow:none;padding:8px 12px}.period-buttons{display:flex;gap:8px;flex-wrap:wrap}.period-btn{padding:8px 16px;border:1px solid #e0e0e0;border-radius:6px;background:#fff;color:#666;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.period-btn:hover{background:#f5f5f5;border-color:#3498db;color:#3498db}.period-btn.active{background:#3498db;border-color:#3498db;color:#fff}.date-inputs{display:flex;align-items:center;gap:12px;margin-left:auto}.date-input-group{display:flex;align-items:center;gap:8px}.date-input-group label{font-size:13px;color:#666;font-weight:500}.date-input{padding:8px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:13px;color:#333;background:#fff;cursor:pointer;transition:border-color .2s}.date-input:hover{border-color:#3498db}.date-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}@media(max-width:1024px){.date-filter{flex-direction:column;align-items:stretch}.date-inputs{margin-left:0;justify-content:flex-start}}@media(max-width:768px){.date-filter{padding:12px;gap:12px}.period-buttons{width:100%;justify-content:space-between}.period-btn{flex:1;padding:10px 12px;text-align:center}.date-inputs{flex-direction:column;align-items:stretch;gap:8px}.date-input-group{width:100%}.date-input{flex:1}}@media(max-width:480px){.period-buttons{display:grid;grid-template-columns:repeat(2,1fr)}.period-btn{padding:10px 8px;font-size:12px}}.dashboard{padding:0;max-width:100%;margin:0 auto;background:transparent;min-height:auto}.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:30px}@media(max-width:1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.kpi-grid{grid-template-columns:1fr}}.kpi-grid.kpi-grid-secondary{grid-template-columns:repeat(6,1fr);gap:15px}@media(max-width:1400px){.kpi-grid.kpi-grid-secondary{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.kpi-grid.kpi-grid-secondary{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.kpi-grid.kpi-grid-secondary{grid-template-columns:1fr}}.kpi-card{background:#fff;border-radius:16px;padding:25px;display:flex;align-items:flex-start;gap:20px;box-shadow:0 4px 12px #00000014;transition:transform .3s,box-shadow .3s;text-decoration:none;color:inherit}.kpi-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0000001f}.kpi-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.kpi-icon.blue{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.kpi-icon.green{background:linear-gradient(135deg,#2ecc71,#27ae60);color:#fff}.kpi-icon.purple{background:linear-gradient(135deg,#9b59b6,#8e44ad);color:#fff}.kpi-icon.orange{background:linear-gradient(135deg,#f39c12,#e67e22);color:#fff}.kpi-icon.cif{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.kpi-icon.fob{background:linear-gradient(135deg,#e67e22,#d35400);color:#fff}.kpi-card.kpi-card-small{padding:15px;gap:12px}.kpi-icon-small{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.kpi-icon-small.blue{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.kpi-icon-small.green{background:linear-gradient(135deg,#2ecc71,#27ae60);color:#fff}.kpi-icon-small.purple{background:linear-gradient(135deg,#9b59b6,#8e44ad);color:#fff}.kpi-icon-small.orange{background:linear-gradient(135deg,#f39c12,#e67e22);color:#fff}.kpi-icon-small.red{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.kpi-content-small{display:flex;flex-direction:column;gap:2px}.kpi-label-small{font-size:11px;color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px}.kpi-value-small{font-size:18px;font-weight:700;color:#2c3e50}.kpi-content{display:flex;flex-direction:column;gap:5px}.kpi-label{font-size:13px;color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px}.kpi-value{font-size:28px;font-weight:700;color:#2c3e50}.kpi-change{font-size:13px;font-weight:500}.kpi-change.positive{color:#27ae60}.kpi-change.negative{color:#e74c3c}.kpi-change.neutral{color:#7f8c8d}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:30px}.chart-card{background:#fff;border-radius:16px;padding:25px;box-shadow:0 4px 12px #00000014}.chart-card h3{margin:0 0 20px;font-size:18px;color:#2c3e50;font-weight:600}.chart-card-small{grid-column:span 1}.bottom-section{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}.alerts-card{background:#fff;border-radius:16px;padding:25px;box-shadow:0 4px 12px #00000014}.alerts-card h3{margin:0 0 20px;font-size:18px;color:#2c3e50;font-weight:600;display:flex;align-items:center;gap:10px}.alerts-card h3 svg{color:#f39c12}.alerts-list{display:flex;flex-direction:column;gap:12px}.alert-item{display:flex;align-items:center;gap:12px;padding:12px 15px;border-radius:10px}.alert-item.warning{background:#fff3cd;border-left:4px solid #f39c12}.alert-item.danger{background:#f8d7da;border-left:4px solid #e74c3c}.alert-item.info{background:#d1ecf1;border-left:4px solid #3498db}.alert-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.alert-item.warning .alert-icon{background:#f39c12;color:#fff}.alert-item.danger .alert-icon{background:#e74c3c;color:#fff}.alert-item.info .alert-icon{background:#3498db;color:#fff}.alert-content{font-size:14px;color:#2c3e50}.quick-actions-card{background:#fff;border-radius:16px;padding:25px;box-shadow:0 4px 12px #00000014}.quick-actions-card h3{margin:0 0 20px;font-size:18px;color:#2c3e50;font-weight:600}.quick-actions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.quick-action-btn{display:flex;align-items:center;gap:10px;padding:12px 15px;background:#f8f9fa;border-radius:10px;text-decoration:none;color:#2c3e50;font-size:14px;font-weight:500;transition:all .3s}.quick-action-btn:hover{background:#3498db;color:#fff}.quick-action-btn svg{stroke:currentColor}.recent-docs-card{background:#fff;border-radius:16px;padding:25px;box-shadow:0 4px 12px #00000014}.recent-docs-card h3{margin:0 0 20px;font-size:18px;color:#2c3e50;font-weight:600}.recent-docs-list{display:flex;flex-direction:column;gap:12px}.recent-doc-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f0f0f0}.recent-doc-item:last-child{border-bottom:none}.doc-info{display:flex;flex-direction:column;gap:3px}.doc-number{font-weight:600;color:#2c3e50;font-size:14px}.doc-cliente{font-size:12px;color:#7f8c8d}.doc-meta{display:flex;flex-direction:column;align-items:flex-end;gap:3px}.doc-valor{font-weight:600;color:#2c3e50;font-size:14px}.doc-status{font-size:11px;padding:3px 8px;border-radius:20px;font-weight:500;text-transform:uppercase}.doc-status.status-autorizado{background:#d4edda;color:#155724}.doc-status.status-pendente{background:#fff3cd;color:#856404}.doc-status.status-cancelado{background:#f8d7da;color:#721c24}.view-all-link{display:block;text-align:center;margin-top:15px;padding-top:15px;border-top:1px solid #f0f0f0;color:#3498db;text-decoration:none;font-size:14px;font-weight:500}.view-all-link:hover{text-decoration:underline}@media(max-width:1400px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:1200px){.charts-grid,.bottom-section{grid-template-columns:1fr}}@media(max-width:1024px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.chart-card{padding:20px}.chart-card h3{font-size:16px}}@media(max-width:768px){.dashboard-header{flex-direction:column;gap:15px;align-items:flex-start}.dashboard-header h1{font-size:22px}.periodo-selector{width:100%;justify-content:stretch}.periodo-btn{flex:1;text-align:center}.kpi-grid{grid-template-columns:1fr 1fr;gap:12px}.kpi-card{padding:16px;flex-direction:column;align-items:flex-start;gap:12px}.kpi-value{font-size:22px}.kpi-icon{width:44px;height:44px}.kpi-icon svg{width:20px;height:20px}.chart-card{padding:16px}.quick-actions-grid{grid-template-columns:1fr 1fr;gap:8px}.alerts-card,.quick-actions-card,.recent-docs-card{padding:18px}}@media(max-width:480px){.dashboard-header h1{font-size:18px}.dashboard-subtitle{font-size:12px}.periodo-btn{padding:8px 12px;font-size:12px}.kpi-grid{grid-template-columns:1fr;gap:10px}.kpi-card{padding:14px;flex-direction:row;align-items:center;gap:14px}.kpi-icon{width:42px;height:42px}.kpi-icon svg{width:18px;height:18px}.kpi-label{font-size:11px}.kpi-value{font-size:18px}.kpi-change{font-size:11px}.chart-card{padding:14px;margin:0 -10px;border-radius:0}.chart-card h3,.alerts-card h3,.quick-actions-card h3,.recent-docs-card h3{font-size:14px;margin-bottom:12px}.alerts-card,.quick-actions-card,.recent-docs-card{padding:14px}.alert-item{padding:10px 12px;flex-wrap:wrap}.alert-content{font-size:12px;flex:1;min-width:0}.quick-actions-grid{grid-template-columns:1fr}.quick-action-btn{padding:12px 14px;font-size:13px}.recent-doc-item{padding:10px 0;flex-wrap:wrap;gap:8px}.doc-info{flex:1;min-width:0}.doc-number{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-cliente{font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-valor{font-size:13px}.doc-status{font-size:10px;padding:2px 6px}}@media(max-width:768px){.chart-card .recharts-wrapper,.chart-card .recharts-surface{max-height:220px!important}.charts-grid{gap:12px}.chart-card-small .recharts-wrapper{max-height:200px!important}}.alerts-summary-card{min-height:auto}.alerts-summary{display:grid;grid-template-columns:1fr 1fr;gap:12px}.alert-summary-item{display:flex;align-items:center;gap:10px;padding:12px;background:#f8f9fa;border-radius:10px;transition:all .2s ease}.alert-summary-item:hover{background:#f0f0f0}.alert-summary-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.alert-summary-icon.warning{background:linear-gradient(135deg,#f39c12,#e67e22);color:#fff}.alert-summary-icon.danger{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.alert-summary-icon.info{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.alert-summary-content{display:flex;flex-direction:column;gap:2px}.alert-summary-value{font-size:20px;font-weight:700;color:#2c3e50;line-height:1}.alert-summary-label{font-size:11px;color:#7f8c8d;text-transform:uppercase;letter-spacing:.3px}@media(max-width:768px){.alerts-summary{grid-template-columns:1fr;gap:8px}.alert-summary-item{padding:10px}.alert-summary-icon{width:28px;height:28px;font-size:12px}.alert-summary-value{font-size:18px}.alert-summary-label{font-size:10px}}@media(max-width:768px){.empty-chart{height:150px;font-size:13px}}@media(max-width:768px){.bottom-section{gap:12px}.quick-actions-card,.recent-docs-card{border-radius:12px}.quick-actions-card h3,.recent-docs-card h3{font-size:15px;padding-bottom:12px;border-bottom:1px solid #f0f0f0;margin-bottom:12px}}@media(max-width:768px){.kpi-card:active{transform:scale(.98);box-shadow:0 2px 8px #00000014}.quick-action-btn:active{transform:scale(.98)}.recent-doc-item{border-radius:8px;padding:12px;margin:0 -12px;width:calc(100% + 24px)}.recent-doc-item:active{background:#f8f9fa}}.doc-placa{font-weight:600;color:#9b59b6;font-size:13px}.doc-data{font-size:11px;color:#7f8c8d}@media(max-width:480px){.doc-placa{font-size:12px}.doc-data{font-size:10px}}.clientes-list{padding:0;max-width:1400px;margin:0 auto}.clientes-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:15px}.clientes-header h2{margin:0;color:#1f2937;font-size:24px}.btn-primary{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;padding:12px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex;align-items:center;gap:8px}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3498db4d}.filtros-container{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;padding:16px;background-color:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;border:1px solid #e5e7eb}.input-filter,.select-filter{padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;flex:1;min-width:140px;transition:all .2s;background:#fff}.input-filter:focus,.select-filter:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.btn-export{background-color:#3498db;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:14px;transition:background-color .3s}.btn-export:hover{background-color:#2980b9}.pagination-info{margin-bottom:15px;color:#666;font-size:14px}.table-container{overflow-x:auto;background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.clientes-table{width:100%;border-collapse:collapse}.clientes-table thead{background-color:#34495e;color:#fff}.clientes-table th,.clientes-table td{padding:15px;text-align:left;border-bottom:1px solid #ddd}.clientes-table th{font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.clientes-table tbody tr:hover{background-color:#f8f9fa}.badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.badge-cif{background-color:#d4edda;color:#155724}.badge-fob{background-color:#cce5ff;color:#004085}.status{font-size:14px;font-weight:500}.status.ativo{color:#27ae60}.status.inativo{color:#e74c3c}.empty-state{text-align:center;padding:60px 20px;color:#666;background-color:#f8f9fa;border-radius:8px;margin:20px 0}.pagination-buttons{display:flex;justify-content:center;gap:15px;margin-top:30px}.btn-page{padding:10px 20px;background-color:#3498db;color:#fff;border:none;border-radius:5px;cursor:pointer;font-size:14px;transition:background-color .3s}.btn-page:hover:not(:disabled){background-color:#2980b9}.btn-page:disabled{background-color:#bdc3c7;cursor:not-allowed}.clientes-header>div{display:flex;align-items:center}.cliente-form-page{padding:20px}.cliente-form-page .page-header{margin-bottom:25px}.cliente-form-page .header-title h1{margin:0;font-size:24px;color:#1e293b}.cliente-form-page .header-title p{margin:5px 0 0;color:#64748b}.cliente-form-page .alert{padding:12px 40px 12px 16px;border-radius:8px;margin-bottom:20px;position:relative}.cliente-form-page .alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.cliente-form-page .alert-close{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:20px;cursor:pointer;opacity:.7}.cliente-form-page .form-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.cliente-form-page .form-section{padding:24px;border-bottom:1px solid #e2e8f0}.cliente-form-page .form-section:last-of-type{border-bottom:none}.cliente-form-page .form-section h3{margin:0 0 20px;font-size:16px;font-weight:600;color:#1e293b}.cliente-form-page .form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.cliente-form-page .form-group{margin-bottom:16px}.cliente-form-page .form-group label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:#374151}.cliente-form-page .form-group input,.cliente-form-page .form-group select,.cliente-form-page .form-group textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s;box-sizing:border-box}.cliente-form-page .form-group input:focus,.cliente-form-page .form-group select:focus,.cliente-form-page .form-group textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.cliente-form-page .form-group textarea{resize:vertical;min-height:80px}.cliente-form-page .checkbox-group label{display:flex;align-items:center;gap:8px;cursor:pointer}.cliente-form-page .checkbox-group input[type=checkbox]{width:18px;height:18px;cursor:pointer}.cliente-form-page .form-actions{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;background:#f8fafc;border-radius:0 0 12px 12px}.cliente-form-page .btn-primary{padding:10px 24px;background:#2563eb;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.cliente-form-page .btn-primary:hover:not(:disabled){background:#1d4ed8}.cliente-form-page .btn-primary:disabled{opacity:.6;cursor:not-allowed}.cliente-form-page .btn-secondary{padding:10px 24px;background:#fff;color:#475569;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.cliente-form-page .btn-secondary:hover{background:#f1f5f9;border-color:#94a3b8}@media(max-width:768px){.clientes-list{padding:0}.clientes-header{flex-direction:column;align-items:stretch;gap:12px}.clientes-header>div{flex-direction:column;align-items:flex-start;gap:8px}.filtros-container{flex-direction:column;padding:14px}.input-filter,.select-filter{width:100%;min-width:0}.table-container{margin:0 -15px;border-radius:0;box-shadow:none;border-left:none;border-right:none}.clientes-table th,.clientes-table td{padding:12px 10px;font-size:13px}.clientes-table th:nth-child(4),.clientes-table td:nth-child(4),.clientes-table th:nth-child(5),.clientes-table td:nth-child(5){display:none}.pagination-buttons{flex-wrap:wrap;justify-content:center}.cliente-form-page .form-row{grid-template-columns:1fr}.cliente-form-page .form-actions{flex-direction:column-reverse}}@media(max-width:480px){.clientes-header h2{font-size:20px}.btn-primary{width:100%;justify-content:center;padding:12px 16px}.filtros-container{padding:12px;gap:10px}.clientes-table th,.clientes-table td{padding:10px 8px;font-size:12px}.clientes-table th:nth-child(3),.clientes-table td:nth-child(3){display:none}.badge{padding:3px 8px;font-size:10px}.btn-action{padding:5px 10px;font-size:12px}.pagination-info{font-size:12px;text-align:center}.btn-page{padding:8px 14px;font-size:13px}}.documentos-anexos{background:#fff;border-radius:12px;padding:1.5rem;margin-top:1.5rem;box-shadow:0 2px 8px #00000014}.documentos-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e9ecef}.documentos-header h3{display:flex;align-items:center;gap:.5rem;margin:0;font-size:1.1rem;color:#2c3e50}.documentos-header h3 svg{color:#3498db}.btn{padding:.5rem 1rem;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#2980b9,#2471a3);transform:translateY(-1px)}.btn-success{background:linear-gradient(135deg,#27ae60,#229954);color:#fff}.btn-success:hover:not(:disabled){background:linear-gradient(135deg,#229954,#1e8449)}.btn-sm{padding:.4rem .8rem;font-size:.85rem}.btn:disabled{opacity:.6;cursor:not-allowed}.error-message{display:flex;align-items:center;gap:.5rem;background:#fff5f5;border:1px solid #fc8181;color:#c53030;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.error-message .close-btn{margin-left:auto;background:none;border:none;color:#c53030;cursor:pointer;font-size:1.2rem;padding:0;line-height:1}.upload-form{background:#f8f9fa;padding:1.25rem;border-radius:10px;margin-bottom:1.5rem;border:1px solid #e9ecef}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-weight:500;font-size:.85rem;color:#495057}.form-group input,.form-group select{padding:.6rem .8rem;border:1px solid #dee2e6;border-radius:6px;font-size:.9rem;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.file-input-group{grid-column:1 / -1}.file-input-wrapper{display:flex;flex-direction:column;gap:.5rem}.file-input-wrapper input[type=file]{padding:.5rem;background:#fff}.selected-file{font-size:.85rem;color:#27ae60;font-weight:500}.form-actions{display:flex;gap:.75rem;margin-top:.5rem}.documentos-list{margin-top:1rem}.loading-docs{text-align:center;padding:2rem;color:#7f8c8d}.no-docs{text-align:center;padding:3rem;color:#95a5a6}.no-docs svg{opacity:.5;margin-bottom:1rem}.no-docs p{margin:0;font-size:.95rem}.documentos-table{width:100%;border-collapse:collapse;font-size:.9rem}.documentos-table th,.documentos-table td{padding:.75rem .5rem;text-align:left;border-bottom:1px solid #e9ecef}.documentos-table th{background:#f8f9fa;font-weight:600;color:#495057;font-size:.85rem;text-transform:uppercase;letter-spacing:.03em}.documentos-table tbody tr:hover{background:#f8f9fa}.documentos-table tbody tr.expired{background:#fff5f5}.documentos-table tbody tr.expiring-soon{background:#fffbeb}.doc-tipo{display:inline-block;padding:.25rem .6rem;background:#e8f4fd;color:#2980b9;border-radius:4px;font-size:.8rem;font-weight:500}.doc-nome{font-weight:500;color:#2c3e50;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.validade{display:flex;align-items:center;gap:.5rem}.validade.vencido{color:#e74c3c;font-weight:500}.validade.vencendo{color:#f39c12;font-weight:500}.badge-vencido,.badge-vencendo{padding:.15rem .4rem;border-radius:3px;font-size:.7rem;font-weight:600;text-transform:uppercase}.badge-vencido{background:#e74c3c;color:#fff}.badge-vencendo{background:#f39c12;color:#fff}.doc-acoes{display:flex;gap:.4rem}.btn-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.btn-icon svg{width:16px;height:16px;flex-shrink:0}.btn-view{background:#e8f4fd;color:#3498db}.btn-view:hover{background:#3498db;color:#fff}.btn-download{background:#e8f8f0;color:#27ae60}.btn-download:hover{background:#27ae60;color:#fff}.btn-delete{background:#fef2f2;color:#e74c3c}.btn-delete:hover{background:#e74c3c;color:#fff}.btn-edit{background:#fff8e6;color:#f39c12}.btn-edit:hover{background:#f39c12;color:#fff}.edit-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.edit-modal{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003;margin:1rem}.edit-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid #e9ecef}.edit-modal-header h4{margin:0;font-size:1.1rem;color:#2c3e50}.edit-modal-header .close-btn{background:none;border:none;font-size:1.5rem;color:#95a5a6;cursor:pointer;padding:0;line-height:1;transition:color .2s ease}.edit-modal-header .close-btn:hover{color:#e74c3c}.edit-modal-body{padding:1.5rem}.edit-modal-body .form-group{margin-bottom:1rem}.edit-modal-body .form-group:last-child{margin-bottom:0}.edit-modal-footer{display:flex;gap:.75rem;padding:1.25rem 1.5rem;border-top:1px solid #e9ecef;background:#f8f9fa;border-radius:0 0 12px 12px}@media(max-width:768px){.documentos-anexos{padding:1rem}.documentos-header{flex-direction:column;gap:1rem;align-items:stretch}.documentos-table{display:block;overflow-x:auto}.form-row{grid-template-columns:1fr}}.motoristas-list{padding:0;max-width:1400px;margin:0 auto}.motoristas-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:15px}.motoristas-header h2{margin:0;color:#1f2937;font-size:24px}.header-actions{display:flex;gap:12px}.btn-warning{background:linear-gradient(135deg,#f39c12,#e67e22);color:#fff;border:none;padding:12px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex;align-items:center;gap:8px}.btn-warning:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f39c124d}.btn-secondary{background-color:#f1f5f9;color:#475569;border:1px solid #e2e8f0;padding:12px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex;align-items:center;gap:8px}.btn-secondary:hover{background-color:#e2e8f0;color:#1e293b}.motoristas-table{width:100%;border-collapse:collapse;min-width:600px}.motoristas-table thead{background-color:#34495e;color:#fff}.motoristas-table th,.motoristas-table td{padding:14px 16px;text-align:left;border-bottom:1px solid #e5e7eb}.motoristas-table th{font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.motoristas-table tbody tr:hover{background-color:#f8fafc}.badge-categoria{background-color:#9b59b6;color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}@media(max-width:768px){.motoristas-header{flex-direction:column;align-items:stretch;gap:12px}.motoristas-header>div{flex-direction:column;align-items:flex-start;gap:8px}.header-actions{width:100%;flex-direction:column}.header-actions button{width:100%;justify-content:center}.table-container{margin:0 -16px;border-radius:0;box-shadow:none}.motoristas-table th,.motoristas-table td{padding:12px 10px;font-size:13px}.motoristas-table th:nth-child(4),.motoristas-table td:nth-child(4),.motoristas-table th:nth-child(5),.motoristas-table td:nth-child(5){display:none}.alertas-container{grid-template-columns:1fr}.doc-item{flex-direction:column;align-items:flex-start;gap:8px}}@media(max-width:480px){.motoristas-header h2{font-size:20px}.btn-warning,.btn-secondary{padding:10px 16px;font-size:13px}.motoristas-table th,.motoristas-table td{padding:10px 8px;font-size:12px}.badge-categoria{padding:3px 8px;font-size:10px}.alerta-card{padding:16px}.alerta-card h3{font-size:16px}}.motorista-form-container{padding:0;max-width:1000px;margin:0 auto}@media(max-width:768px){.motorista-form-container{max-width:100%}}@media(max-width:480px){.motorista-form-container{padding:0}}.veiculos-list{padding:0;max-width:1400px;margin:0 auto}.veiculos-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:15px}.veiculos-header h2{margin:0;color:#1f2937;font-size:24px}.table-container{overflow-x:auto;background-color:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014}.veiculos-table{width:100%;border-collapse:collapse;min-width:600px}.veiculos-table thead{background-color:#34495e;color:#fff}.veiculos-table th,.veiculos-table td{padding:14px 16px;text-align:left;border-bottom:1px solid #e5e7eb}.veiculos-table th{font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.veiculos-table tbody tr:hover{background-color:#f8fafc}.badge-tipo-00{background-color:#27ae60;color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.badge-tipo-01{background-color:#3498db;color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.badge-tipo-02{background-color:#e67e22;color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.badge-compartimentos{background-color:#16a085;color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.alertas-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.alerta-card{background-color:#fff;border:2px solid #f39c12;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014}.alerta-card h3{margin-top:0;color:#2c3e50;font-size:18px}.alerta-card p{margin:8px 0;color:#666;font-size:14px}.documentos-vencendo{margin-top:15px;padding-top:15px;border-top:1px solid #ddd}.documentos-vencendo h4{margin:0 0 10px;color:#34495e;font-size:16px}.doc-item{display:flex;justify-content:space-between;align-items:center;padding:10px;margin:8px 0;border-radius:8px;font-size:14px}.doc-item.vencendo{background-color:#fff3cd;border-left:4px solid #f39c12}.doc-item.vencido{background-color:#f8d7da;border-left:4px solid #e74c3c}.doc-nome{font-weight:600;color:#2c3e50}.doc-validade{color:#666}.doc-dias{font-weight:600}@media(max-width:1024px){.alertas-container{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media(max-width:768px){.veiculos-header{flex-direction:column;align-items:stretch;gap:12px}.veiculos-header>div{flex-direction:column;align-items:flex-start;gap:8px}.table-container{margin:0 -16px;border-radius:0;box-shadow:none}.veiculos-table th,.veiculos-table td{padding:12px 10px;font-size:13px}.veiculos-table th:nth-child(4),.veiculos-table td:nth-child(4),.veiculos-table th:nth-child(5),.veiculos-table td:nth-child(5){display:none}.alertas-container{grid-template-columns:1fr}.doc-item{flex-direction:column;align-items:flex-start;gap:8px}}@media(max-width:480px){.veiculos-header h2{font-size:20px}.veiculos-table th,.veiculos-table td{padding:10px 8px;font-size:12px}.badge-tipo-00,.badge-tipo-01,.badge-tipo-02,.badge-compartimentos{padding:3px 8px;font-size:10px}.alerta-card{padding:16px}.alerta-card h3{font-size:16px}}.btn-action{width:36px;height:36px;border:none;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease}.btn-action.btn-delete{background-color:#e74c3c;color:#fff}.btn-action.btn-delete:hover{background-color:#c0392b;transform:scale(1.05)}.cliente-form-container{padding:0;max-width:1000px;margin:0 auto}.form-header h2{margin:0;color:#1e293b;font-size:24px}.cliente-form{background-color:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014}legend{color:#1e293b;font-weight:600;font-size:16px;padding:0 10px}.form-group input,.form-group select,.form-group textarea{padding:11px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-family:inherit;transition:border-color .2s,box-shadow .2s}.form-group input:disabled,.form-group select:disabled{background-color:#f8fafc;cursor:not-allowed}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;margin-top:24px}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.btn-cancel,.btn-submit{padding:11px 24px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-submit{background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff}.btn-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #27ae604d}@media(max-width:768px){.form-header{flex-direction:column;align-items:flex-start;gap:12px}.form-header h2{font-size:20px}.btn-back{width:100%;justify-content:center}.form-row{flex-direction:column;gap:0}.form-group{margin-bottom:14px}.cliente-form{padding:18px;border-radius:8px}fieldset{padding:14px;margin-bottom:16px}legend{font-size:15px}.form-actions{flex-direction:column-reverse}.btn-cancel,.btn-submit{width:100%;justify-content:center}}@media(max-width:480px){.form-header h2{font-size:18px}.cliente-form{padding:14px}fieldset{padding:12px}.form-group input,.form-group select,.form-group textarea{padding:10px 12px;font-size:14px}.btn-cancel,.btn-submit{padding:10px 18px;font-size:13px}}.veiculo-form-container{padding:0;max-width:1000px;margin:0 auto}textarea{resize:vertical;min-height:80px;font-family:inherit}.field-help{margin:0 0 15px;color:#64748b;font-size:13px}.compartimentos-list{display:flex;flex-direction:column;gap:12px;margin-bottom:15px}.empty-compartimentos{padding:0;text-align:center;background:#f8fafc;border-radius:8px;border:2px dashed #d1d5db}.empty-compartimentos p{margin:0;color:#94a3b8;font-size:14px}.compartimento-item{display:flex;align-items:center;gap:14px;padding:14px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.compartimento-numero{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:56px;padding:10px;background:linear-gradient(135deg,#3498db,#2980b9);border-radius:8px;color:#fff}.compartimento-numero .numero-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px}.compartimento-numero .numero-value{font-size:22px;font-weight:700}.compartimento-item .form-group{flex:1;margin-bottom:0}.compartimento-item .form-group label{font-size:12px;margin-bottom:5px}.btn-remove-compartimento{padding:8px;background:#fee2e2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;cursor:pointer;transition:all .2s}.btn-remove-compartimento:hover{background:#dc2626;border-color:#dc2626;color:#fff}.btn-add-compartimento{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:#fff;border:2px dashed #3498db;border-radius:8px;color:#3498db;font-weight:500;cursor:pointer;transition:all .2s}.btn-add-compartimento:hover{background:#3498db;border-style:solid;color:#fff}.compartimentos-resumo{margin-top:15px;padding:12px 14px;background:#e0f2fe;border-radius:8px;font-size:14px;color:#1e293b}@media(max-width:768px){.compartimento-item{flex-direction:column;align-items:stretch;gap:12px}.compartimento-numero{flex-direction:row;gap:10px;min-width:auto;padding:10px 14px}.compartimento-numero .numero-value{font-size:18px}.btn-remove-compartimento{align-self:flex-end}.btn-add-compartimento{width:100%;justify-content:center}}@media(max-width:480px){.compartimento-item{padding:12px}.compartimento-numero{padding:8px 12px}.compartimento-numero .numero-label{font-size:9px}.compartimento-numero .numero-value{font-size:16px}}.cte-list,.mdfe-list{padding:0;max-width:1600px;margin:0 auto;background:transparent;min-height:auto}.cte-kpi-grid,.mdfe-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:25px}.cte-kpi-card,.mdfe-kpi-card{background:#fff;border-radius:12px;padding:20px;display:flex;align-items:center;gap:15px;box-shadow:0 2px 8px #00000014;transition:transform .3s,box-shadow .3s}.cte-kpi-card:hover,.mdfe-kpi-card:hover{transform:translateY(-3px);box-shadow:0 4px 15px #0000001f}.cte-kpi-icon,.mdfe-kpi-icon{width:50px;height:50px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cte-kpi-icon.blue,.mdfe-kpi-icon.blue{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.cte-kpi-icon.green,.mdfe-kpi-icon.green{background:linear-gradient(135deg,#2ecc71,#27ae60);color:#fff}.cte-kpi-icon.orange,.mdfe-kpi-icon.orange{background:linear-gradient(135deg,#f39c12,#e67e22);color:#fff}.cte-kpi-icon.purple,.mdfe-kpi-icon.purple{background:linear-gradient(135deg,#9b59b6,#8e44ad);color:#fff}.cte-kpi-icon.red,.mdfe-kpi-icon.red{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.cte-kpi-content,.mdfe-kpi-content{display:flex;flex-direction:column;gap:4px}.cte-kpi-label,.mdfe-kpi-label{font-size:12px;color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px}.cte-kpi-value,.mdfe-kpi-value{font-size:22px;font-weight:700;color:#2c3e50}.cte-charts-grid,.mdfe-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:25px}.cte-chart-card,.mdfe-chart-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014}.cte-chart-card h3,.mdfe-chart-card h3{margin:0 0 15px;font-size:16px;color:#2c3e50;font-weight:600}.cte-chart-small,.mdfe-chart-small{grid-column:span 1}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;flex-wrap:wrap;gap:20px}.page-header h1{color:#2c3e50;font-size:28px;margin:0 0 5px}.page-header p{color:#7f8c8d;margin:0}.btn-primary{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;transition:transform .3s,box-shadow .3s;display:inline-flex;align-items:center;gap:8px}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3498db66}.filtros-section{background:#fff;border-radius:12px;padding:20px;margin-bottom:25px;box-shadow:0 2px 8px #0000001a}.filtros-form{display:flex;gap:15px;flex-wrap:wrap;align-items:center}.filtros-form .input-filter,.filtros-form .select-filter{flex:1;min-width:150px}.filtros-form .input-filter:first-child{flex:2;min-width:250px}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:#f8f9fa}.data-table th{padding:15px;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #e0e0e0;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.data-table td{padding:15px;border-bottom:1px solid #eee;vertical-align:middle}.data-table tbody tr:hover{background-color:#f8f9fa}.data-table .text-muted{color:#95a5a6;font-size:12px}.data-table .text-right{text-align:right}.badge{display:inline-block;padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-success{background-color:#d4edda;color:#155724}.badge-danger{background-color:#f8d7da;color:#721c24}.badge-warning{background-color:#fff3cd;color:#856404}.badge-secondary{background-color:#e2e3e5;color:#383d41}.btn-action{padding:6px 14px;border-radius:5px;font-size:12px;font-weight:500;text-decoration:none;border:none;cursor:pointer;transition:all .2s}.btn-view{background-color:#3498db;color:#fff}.btn-view:hover{background-color:#2980b9}.btn-edit{background-color:#f39c12;color:#fff}.btn-delete{background-color:#e74c3c;color:#fff}.pagination{display:flex;justify-content:center;align-items:center;gap:20px;margin-top:25px;padding:20px}.btn-page{background:#fff;border:1px solid #ddd;padding:10px 20px;border-radius:6px;cursor:pointer;transition:all .2s}.btn-page:hover:not(:disabled){background:#3498db;color:#fff;border-color:#3498db}.btn-page:disabled{opacity:.5;cursor:not-allowed}.pagination-numbers{display:flex;align-items:center;gap:4px}.btn-page-num{background:#fff;border:1px solid #ddd;padding:8px 14px;border-radius:6px;cursor:pointer;transition:all .2s;font-weight:500;min-width:40px}.btn-page-num:hover{background:#f8f9fa;border-color:#3498db;color:#3498db}.btn-page-num.active{background:#3498db;color:#fff;border-color:#3498db}.pagination-ellipsis{color:#7f8c8d;padding:0 6px;font-size:14px}.cte-detail,.mdfe-detail{padding:0;max-width:1400px;margin:0 auto}.back-link{color:#3498db;text-decoration:none;font-size:14px;display:inline-block;margin-bottom:10px}.back-link:hover{text-decoration:underline}.chave-cte{font-family:monospace;font-size:12px;color:#7f8c8d;word-break:break-all}.status-badge{display:flex;align-items:center;gap:8px;padding:12px 24px;border-radius:30px;font-weight:600;font-size:16px}.status-badge .status-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#ffffff4d}.status-success{background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff}.status-danger{background:linear-gradient(135deg,#c0392b,#e74c3c);color:#fff}.status-warning{background:linear-gradient(135deg,#d35400,#e67e22);color:#fff}.status-secondary{background:linear-gradient(135deg,#7f8c8d,#95a5a6);color:#fff}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:25px}.detail-card{background:#fff;border-radius:12px;padding:25px;box-shadow:0 2px 8px #0000001a}.detail-card.highlight{border-left:5px solid #27ae60}.detail-card.cancelamento-card{border-left:5px solid #e74c3c;background:#fdf5f5}.detail-card.cancelamento-card h3{color:#c0392b}.detail-card h3{color:#2c3e50;font-size:18px;margin:0 0 20px;padding-bottom:15px;border-bottom:1px solid #eee}.detail-content{display:flex;flex-direction:column;gap:12px}.detail-row{display:flex;justify-content:space-between;align-items:flex-start;gap:15px}.detail-row .label{color:#7f8c8d;font-size:14px;flex-shrink:0}.detail-row .value{color:#2c3e50;font-weight:500;text-align:right}.valor-destaque{font-size:24px;color:#27ae60!important;font-weight:700!important}.table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.results-info{margin-bottom:15px}.results-info p{color:#7f8c8d;font-size:14px;margin:0}.header-actions{display:flex;flex-direction:column;align-items:flex-end;gap:12px}.action-buttons{display:flex;gap:10px;flex-wrap:wrap}.btn-pdf{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.btn-pdf:hover:not(:disabled){box-shadow:0 4px 12px #e74c3c66;transform:translateY(-2px)}.btn-xml{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.btn-xml:hover:not(:disabled){box-shadow:0 4px 12px #3498db66;transform:translateY(-2px)}.btn-download{background:linear-gradient(135deg,#27ae60,#229954);color:#fff}.btn-download:hover:not(:disabled){box-shadow:0 4px 12px #27ae6066;transform:translateY(-2px)}.btn-reprocessar{background:linear-gradient(135deg,#9b59b6,#8e44ad);color:#fff}.btn-reprocessar:hover:not(:disabled){box-shadow:0 4px 12px #9b59b666;transform:translateY(-2px)}.btn-export{background:linear-gradient(135deg,#27ae60,#229954);color:#fff}.btn-export:hover:not(:disabled){box-shadow:0 4px 12px #27ae6066;transform:translateY(-2px)}.btn-action:disabled{opacity:.6;cursor:not-allowed}.btn-toggle-pago{width:36px;height:36px;border-radius:50%;border:2px solid;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;background:transparent}.btn-toggle-pago.pago{border-color:#27ae60;color:#27ae60;background:#27ae601a}.btn-toggle-pago.pago:hover{background:#27ae6033;transform:scale(1.1)}.btn-toggle-pago.nao-pago{border-color:#bdc3c7;color:#bdc3c7}.btn-toggle-pago.nao-pago:hover{border-color:#27ae60;color:#27ae60;background:#27ae600d;transform:scale(1.1)}.btn-toggle-pago:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.loading-spinner-small{width:14px;height:14px;border:2px solid #bdc3c7;border-top-color:#27ae60;border-radius:50%;animation:spin .8s linear infinite}.status-info{background:linear-gradient(135deg,#17a2b8,#138496);color:#fff}@media(max-width:1400px){.cte-kpi-grid,.mdfe-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:1024px){.cte-charts-grid,.mdfe-charts-grid{grid-template-columns:1fr}}@media(max-width:768px){.cte-list,.mdfe-list,.cte-detail,.mdfe-detail{padding:0}.page-header{flex-direction:column;align-items:stretch;gap:15px}.cte-kpi-grid,.mdfe-kpi-grid{grid-template-columns:1fr 1fr;gap:12px}.cte-kpi-card,.mdfe-kpi-card{padding:16px;flex-direction:column;align-items:flex-start;gap:10px}.cte-kpi-value,.mdfe-kpi-value{font-size:20px}.filtros-section{padding:14px;margin-bottom:16px}.filtros-form{flex-direction:column;gap:12px}.filtros-form .input-filter,.filtros-form .select-filter{width:100%;min-width:0}.detail-grid{grid-template-columns:1fr;gap:16px}.detail-card{padding:18px}.detail-row{flex-direction:column;gap:4px}.detail-row .value{text-align:left}.table-container{overflow-x:auto;margin:0 -15px;border-radius:0}.data-table{min-width:700px}.data-table th,.data-table td{padding:12px 10px;font-size:13px}.header-actions{width:100%;align-items:stretch}.action-buttons{width:100%;justify-content:flex-start}.status-badge{padding:8px 16px;font-size:14px}}.section-header{display:flex;justify-content:space-between;align-items:center;margin:25px 0 15px;padding-bottom:10px;border-bottom:2px solid #eee;flex-wrap:wrap;gap:15px}.section-header h3{margin:0;font-size:18px;color:#2c3e50;font-weight:600}.empty-chart{display:flex;align-items:center;justify-content:center;height:200px;color:#7f8c8d;font-size:14px;background:#f8f9fa;border-radius:8px}.eficiencia-display{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;text-align:center}.eficiencia-value{font-size:48px;font-weight:700;color:#27ae60;line-height:1}.eficiencia-label{font-size:14px;color:#7f8c8d;margin-top:10px}.eficiencia-detail{font-size:12px;color:#95a5a6;margin-top:5px}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:1px solid #eee;background:linear-gradient(135deg,#3498db,#2980b9);border-radius:16px 16px 0 0}.modal-header h2{margin:0;color:#fff;font-size:20px;font-weight:600}.modal-close{background:#fff3;border:none;cursor:pointer;padding:8px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background .2s;color:#fff}.modal-close:hover{background:#ffffff4d}.modal-body{padding:25px}.modal-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.modal-info-item{display:flex;flex-direction:column;gap:6px}.modal-info-item.full-width{grid-column:span 2}.modal-info-label{font-size:12px;color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.modal-info-value{font-size:15px;color:#2c3e50;font-weight:500}.modal-info-value.valor-destaque{font-size:18px;color:#27ae60;font-weight:700}.modal-footer{display:flex;gap:12px;padding:20px 25px;border-top:1px solid #eee;background:#f8f9fa;border-radius:0 0 16px 16px}.modal-footer .btn-action{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;font-size:14px}.btn-secondary{background:#95a5a6;color:#fff}.btn-secondary:hover{background:#7f8c8d}@media(max-width:600px){.modal-content{margin:10px;max-height:95vh}.modal-info-grid{grid-template-columns:1fr}.modal-info-item.full-width{grid-column:span 1}.modal-footer{flex-direction:column}.modal-footer .btn-action{width:100%;justify-content:center}}@media(max-width:480px){.cte-kpi-grid,.mdfe-kpi-grid{grid-template-columns:1fr;gap:10px}.cte-kpi-card,.mdfe-kpi-card{flex-direction:row;align-items:center;padding:14px}.cte-kpi-icon,.mdfe-kpi-icon{width:42px;height:42px}.cte-kpi-value,.mdfe-kpi-value{font-size:18px}.cte-kpi-label,.mdfe-kpi-label{font-size:11px}.cte-chart-card,.mdfe-chart-card{padding:14px;margin:0 -10px;border-radius:0}.detail-card{padding:14px;border-radius:10px}.detail-card h3{font-size:16px;margin-bottom:14px;padding-bottom:12px}.valor-destaque{font-size:20px!important}.chave-cte{font-size:10px}.action-buttons{flex-wrap:wrap;gap:8px}.action-buttons .btn-action{flex:1;min-width:calc(50% - 4px);justify-content:center;padding:10px 12px;font-size:12px}.pagination{padding:15px 10px;gap:10px}.btn-page{padding:8px 14px;font-size:13px}}@media(max-width:768px){.table-container .data-table{display:none}.table-container{background:transparent;box-shadow:none;overflow:visible;margin:0;border-radius:0}}.mobile-cards{display:none}@media(max-width:768px){.mobile-cards{display:flex;flex-direction:column;gap:12px}}.mobile-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.mobile-card:active{transform:scale(.99)}.mobile-card-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:linear-gradient(135deg,#f8f9fa,#fff);border-bottom:1px solid #eee}.mobile-card-title{display:flex;flex-direction:column;gap:2px}.mobile-card-number{font-size:16px;font-weight:700;color:#2c3e50}.mobile-card-date{font-size:12px;color:#7f8c8d}.mobile-card-status{display:flex;align-items:center;gap:8px}.mobile-card-body{padding:14px 16px}.mobile-card-row{display:flex;justify-content:space-between;align-items:flex-start;padding:8px 0;border-bottom:1px solid #f0f0f0}.mobile-card-row:last-child{border-bottom:none}.mobile-card-label{font-size:12px;color:#7f8c8d;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}.mobile-card-value{font-size:14px;color:#2c3e50;font-weight:500;text-align:right;max-width:60%;word-break:break-word}.mobile-card-value.valor{color:#27ae60;font-weight:700;font-size:16px}.mobile-card-footer{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f8f9fa;border-top:1px solid #eee;gap:10px}.mobile-card-actions{display:flex;gap:8px}.mobile-card-actions .btn-action{padding:8px 12px;font-size:12px;display:flex;align-items:center;gap:4px}.mobile-card-pago{display:flex;align-items:center;gap:6px}.mobile-card-pago .btn-toggle-pago{width:32px;height:32px}.mobile-empty{text-align:center;padding:40px 20px;color:#7f8c8d;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014}.mobile-empty-icon{font-size:48px;margin-bottom:12px;opacity:.5}.mobile-empty-text{font-size:14px}@media(max-width:768px){.pagination{flex-wrap:wrap;gap:10px;padding:15px}.pagination-numbers{order:3;width:100%;justify-content:center;flex-wrap:wrap;gap:6px}.btn-page{flex:1;min-width:100px;text-align:center;padding:12px 16px}.btn-page-num{min-width:36px;padding:8px 10px;font-size:13px}}@media(max-width:768px){.section-header{flex-direction:column;align-items:flex-start;gap:12px;margin:20px 0 12px}.section-header h3{font-size:16px}}.header-buttons{display:flex;gap:10px;flex-wrap:wrap}@media(max-width:768px){.header-buttons{width:100%}.header-buttons .btn,.header-buttons .btn-primary,.header-buttons .btn-outline{flex:1;justify-content:center;padding:10px 14px;font-size:13px}}.btn-outline{background:#fff;color:#3498db;border:2px solid #3498db;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;transition:all .3s ease;display:inline-flex;align-items:center;gap:8px}.btn-outline:hover{background:#3498db;color:#fff}.btn-outline svg{width:18px;height:18px}.upload-page{padding:0;max-width:900px;margin:0 auto}.upload-container{display:flex;flex-direction:column;gap:25px}.upload-dropzone{border:3px dashed #d1d5db;border-radius:16px;padding:50px 30px;text-align:center;cursor:pointer;transition:all .3s ease;background:#fff}.upload-dropzone:hover{border-color:#3498db;background:#f8fbfe}.upload-dropzone.drag-over{border-color:#3498db;background:#ebf5fb;transform:scale(1.02)}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:15px}.dropzone-icon{color:#3498db;opacity:.7}.dropzone-text{font-size:18px;color:#2c3e50;margin:0;font-weight:500}.dropzone-hint{font-size:14px;color:#95a5a6;margin:0}.files-list{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014}.files-list h3{margin:0 0 16px;color:#2c3e50;font-size:17px}.files-grid{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.file-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:#f8f9fa;border-radius:8px;transition:background .2s}.file-item:hover{background:#e9ecef}.file-icon{color:#e67e22;flex-shrink:0}.file-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.file-name{font-weight:500;color:#2c3e50;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-size{font-size:12px;color:#95a5a6}.file-remove{width:28px;height:28px;border-radius:50%;border:none;background:#e74c3c;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s,background .2s;flex-shrink:0}.file-remove:hover{background:#c0392b;transform:scale(1.1)}.upload-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:16px;border-top:1px solid #eee}.btn-secondary{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover:not(:disabled){background:#e2e8f0;color:#1e293b}.btn-success{background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-success:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #27ae604d}.btn-secondary:disabled,.btn-success:disabled,.btn-primary:disabled{opacity:.6;cursor:not-allowed}.results-section{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014}.results-section h3{margin:0 0 16px;color:#2c3e50;font-size:17px}.results-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.result-item{display:flex;align-items:flex-start;gap:12px;padding:14px;border-radius:8px}.result-item.success{background:#d4edda;border-left:4px solid #27ae60}.result-item.error{background:#f8d7da;border-left:4px solid #e74c3c}.result-icon{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;font-size:14px}.result-item.success .result-icon{background:#27ae60;color:#fff}.result-item.error .result-icon{background:#e74c3c;color:#fff}.result-info{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.result-file{font-weight:600;color:#2c3e50;font-size:14px}.result-message{font-size:13px;color:#555}.result-tipo{font-size:12px;color:#7f8c8d}.results-actions{display:flex;gap:12px;justify-content:center;padding-top:16px;border-top:1px solid #eee}@media(max-width:768px){.upload-dropzone{padding:35px 20px}.dropzone-text{font-size:16px}.dropzone-hint{font-size:13px}.files-list,.results-section{padding:16px;border-radius:8px}.upload-actions,.results-actions{flex-direction:column}.upload-actions button,.results-actions button{width:100%;justify-content:center}}@media(max-width:480px){.upload-dropzone{padding:30px 16px;border-width:2px}.dropzone-icon svg{width:40px;height:40px}.dropzone-text{font-size:15px}.file-item{padding:10px 12px}.file-name{font-size:13px}.result-item{padding:12px}.result-file{font-size:13px}.btn-secondary,.btn-success{padding:11px 16px;font-size:13px}}.pagamentos-page{padding:0;max-width:1400px;margin:0 auto}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.summary-card{background:#fff;border-radius:12px;padding:20px 25px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;gap:8px}.summary-card.pendente{border-left:5px solid #f39c12}.summary-card.pago{border-left:5px solid #27ae60}.summary-label{font-size:14px;color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px}.summary-value{font-size:28px;font-weight:700;color:#2c3e50}.tabs-container{display:flex;gap:5px;background:#e0e0e0;padding:5px;border-radius:10px;margin-bottom:25px;width:fit-content}.tab-button{padding:12px 30px;border:none;background:transparent;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s;color:#7f8c8d}.tab-button:hover{color:#2c3e50}.tab-button.active{background:#fff;color:#3498db;box-shadow:0 2px 8px #0000001a}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:500px;max-height:calc(100vh - 30px);overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .25s ease-out}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb;position:sticky;top:0;background:#fff;z-index:1;border-radius:16px 16px 0 0}.modal-header h3{margin:0;color:#1f2937;font-size:18px;font-weight:600}.modal-close{background:none;border:none;cursor:pointer;color:#9ca3af;padding:8px;border-radius:8px;transition:all .2s;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#f3f4f6;color:#1f2937}.modal-close svg{width:20px;height:20px}.modal-body{padding:24px}.modal-description{margin:0 0 20px;color:#6b7280;font-size:14px;line-height:1.5}.modal-body .form-group{margin-bottom:18px}.modal-body .form-group label{display:block;margin-bottom:8px;color:#374151;font-weight:500;font-size:14px}.modal-body .form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}.modal-body .input-filter,.modal-body .select-filter,.modal-body input,.modal-body select,.modal-body textarea{width:100%;padding:12px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:all .2s;background:#fff}.modal-body .input-filter:focus,.modal-body .select-filter:focus,.modal-body input:focus,.modal-body select:focus,.modal-body textarea:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.alert-warning{padding:12px 15px;background:#fef3c7;border:1px solid #fcd34d;border-radius:8px;color:#92400e;font-size:13px;margin-top:15px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:18px 24px;border-top:1px solid #e5e7eb;background:#f9fafb;border-radius:0 0 16px 16px;position:sticky;bottom:0}.btn-cancel{padding:10px 20px;border:1px solid #d1d5db;background:#fff;border-radius:8px;font-size:14px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:#f3f4f6;color:#1f2937;border-color:#9ca3af}.btn-cancel:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.pagamentos-page{padding:15px}.summary-cards{grid-template-columns:1fr 1fr;gap:12px}.summary-card{padding:15px 18px}.summary-value{font-size:22px}.tabs-container{width:100%}.tab-button{flex:1;text-align:center;padding:10px 15px;font-size:13px}.modal-content{max-width:100%;border-radius:16px 16px 0 0;max-height:90vh;margin-top:auto}.modal-overlay{align-items:flex-end;padding:0}.modal-header{border-radius:16px 16px 0 0}.modal-footer{border-radius:0}.modal-body .form-row{grid-template-columns:1fr}}@media(max-width:480px){.pagamentos-page{padding:10px}.summary-cards{grid-template-columns:1fr}.summary-card{padding:12px 15px}.summary-label{font-size:12px}.summary-value{font-size:20px}.tab-button{padding:8px 10px;font-size:12px}}.pagamento-form-page{padding:0;max-width:900px;margin:0 auto}.pagamento-form-page .page-header{margin-bottom:30px}.pagamento-form-page .header-title h1{font-size:24px;color:#2c3e50;margin:0 0 8px}.pagamento-form-page .header-title p{font-size:14px;color:#7f8c8d;margin:0}.form-container{background:#fff;border-radius:16px;padding:30px;box-shadow:0 2px 8px #00000014}.form-section{margin-bottom:30px;padding-bottom:25px;border-bottom:1px solid #e5e7eb}.form-section:last-of-type{margin-bottom:20px;padding-bottom:0;border-bottom:none}.form-section h3{font-size:16px;font-weight:600;color:#374151;margin:0 0 20px;display:flex;align-items:center;gap:10px}.form-section h3:before{content:"";width:4px;height:20px;background:linear-gradient(135deg,#3498db,#2980b9);border-radius:2px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.form-group{margin-bottom:18px}.form-group label{display:block;margin-bottom:8px;color:#374151;font-weight:500;font-size:14px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:all .2s;background:#fff}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.form-group input:disabled,.form-group .input-calculated{background:#f3f4f6;color:#6b7280;cursor:not-allowed}.form-hint{display:block;margin-top:6px;font-size:12px;color:#9ca3af}.form-hint-success{color:#27ae60;font-weight:500}.form-actions{display:flex;justify-content:flex-end;gap:15px;margin-top:25px;padding-top:20px;border-top:1px solid #e5e7eb}.btn-secondary{padding:12px 24px;border:1px solid #d1d5db;background:#fff;border-radius:8px;font-size:14px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#f3f4f6;color:#1f2937;border-color:#9ca3af}.btn-primary{padding:12px 24px;border:none;background:linear-gradient(135deg,#3498db,#2980b9);border-radius:8px;font-size:14px;font-weight:500;color:#fff;cursor:pointer;transition:all .2s}.btn-primary:hover{background:linear-gradient(135deg,#2980b9,#1f6591);transform:translateY(-1px);box-shadow:0 4px 12px #3498db4d}.btn-primary:disabled,.btn-secondary:disabled{opacity:.6;cursor:not-allowed;transform:none}.faixas-referencia{margin-top:20px;padding:15px;background:#f9fafb;border-radius:10px;border:1px solid #e5e7eb}.faixas-referencia h4{font-size:13px;font-weight:600;color:#6b7280;margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.faixas-table-mini{width:100%;border-collapse:collapse;font-size:13px}.faixas-table-mini th,.faixas-table-mini td{padding:8px 12px;text-align:left;border-bottom:1px solid #e5e7eb}.faixas-table-mini th{color:#6b7280;font-weight:500;background:transparent}.faixas-table-mini tr.faixa-ativa{background:#dbeafe}.faixas-table-mini tr.faixa-ativa td{color:#1d4ed8;font-weight:600}.alert{padding:15px 20px;border-radius:10px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.alert-close{background:none;border:none;font-size:20px;cursor:pointer;color:inherit;opacity:.6;transition:opacity .2s}.alert-close:hover{opacity:1}.action-buttons{display:flex;gap:8px;justify-content:center}.btn-action{padding:8px;border:none;border-radius:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-action.btn-edit{background:#dbeafe;color:#2563eb}.btn-action.btn-edit:hover{background:#2563eb;color:#fff}.btn-action.btn-delete{background:#fee2e2;color:#dc2626}.btn-action.btn-delete:hover{background:#dc2626;color:#fff}@media(max-width:768px){.pagamento-form-page{padding:15px}.form-container{padding:20px}.form-row{grid-template-columns:1fr;gap:0}.form-actions{flex-direction:column-reverse;gap:10px}.btn-secondary,.btn-primary{width:100%;text-align:center}.faixas-referencia{padding:12px}}@media(max-width:480px){.pagamento-form-page .header-title h1{font-size:20px}.form-container{padding:15px;border-radius:12px}.form-section h3{font-size:14px}.form-group input,.form-group select,.form-group textarea{padding:10px 12px;font-size:16px}}.manutencao-page{padding:0;max-width:1400px;margin:0 auto}.manutencao-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;margin-bottom:30px}.summary-item{background:#fff;border-radius:12px;padding:20px;display:flex;align-items:center;gap:15px;box-shadow:0 2px 8px #0000001a}.summary-icon{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.summary-icon.agendadas{background:#e3f2fd;color:#1976d2}.summary-icon.andamento{background:#fff3e0;color:#f57c00}.summary-icon.concluidas{background:#e8f5e9;color:#388e3c}.summary-info{display:flex;flex-direction:column;gap:2px}.summary-number{font-size:28px;font-weight:700;color:#2c3e50;line-height:1}.summary-label{font-size:13px;color:#7f8c8d}.descricao-truncate{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;max-width:200px}.graficos-toggle{display:flex;justify-content:flex-end;margin-bottom:20px}.btn-toggle{display:flex;align-items:center;gap:8px;padding:10px 18px;background:#fff;border:1px solid #ddd;border-radius:8px;font-size:14px;font-weight:500;color:#7f8c8d;cursor:pointer;transition:all .2s}.btn-toggle:hover{background:#f8f9fa;border-color:#3498db;color:#3498db}.btn-toggle.active{background:#e3f2fd;border-color:#3498db;color:#3498db}.graficos-section{margin-bottom:25px}.graficos-row{display:grid;grid-template-columns:1fr 2fr;gap:20px;margin-bottom:20px}.graficos-row:last-child{margin-bottom:0}.grafico-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014}.grafico-card h3{margin:0 0 15px;font-size:15px;font-weight:600;color:#2c3e50}.grafico-card.wide{grid-column:span 1}.grafico-card.full-width{grid-column:1 / -1}.actions-cell{text-align:center}.btn-action{width:36px;height:36px;border:none;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease;text-decoration:none}.btn-action svg{width:18px;height:18px}.btn-action.btn-view{background-color:#9b59b6;color:#fff}.btn-action.btn-view:hover{background-color:#8e44ad;transform:scale(1.05)}.btn-action.btn-edit{background-color:#3498db;color:#fff}.btn-action.btn-edit:hover{background-color:#2980b9;transform:scale(1.05)}.manutencao-form-page{padding:20px}.manutencao-form-page .page-header{margin-bottom:25px}.manutencao-form-page .header-title h1{margin:0;font-size:24px;color:#1e293b}.manutencao-form-page .header-title p{margin:5px 0 0;color:#64748b}.manutencao-form-page .alert{padding:12px 40px 12px 16px;border-radius:8px;margin-bottom:20px;position:relative}.manutencao-form-page .alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.manutencao-form-page .alert-close{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:20px;cursor:pointer;opacity:.7}.form-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.form-section{padding:24px;border-bottom:1px solid #e2e8f0}.form-section:last-of-type{border-bottom:none}.form-section h3{margin:0 0 20px;font-size:16px;font-weight:600;color:#1e293b}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group textarea{resize:vertical;min-height:80px}.form-actions{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;background:#f8fafc;border-radius:0 0 12px 12px}.manutencao-form-page .btn-primary{padding:10px 24px;background:#2563eb;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.manutencao-form-page .btn-primary:hover:not(:disabled){background:#1d4ed8}.manutencao-form-page .btn-primary:disabled{opacity:.6;cursor:not-allowed}.manutencao-form-page .btn-secondary{padding:10px 24px;background:#fff;color:#475569;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.manutencao-form-page .btn-secondary:hover{background:#f1f5f9;border-color:#94a3b8}@media(max-width:1200px){.graficos-row{grid-template-columns:1fr 1fr}}@media(max-width:1024px){.manutencao-page{max-width:100%}.manutencao-summary{grid-template-columns:repeat(2,1fr);gap:16px}.graficos-row{grid-template-columns:1fr}.grafico-card{padding:18px}.form-section{padding:20px}}@media(max-width:768px){.manutencao-page{padding:15px}.manutencao-summary{grid-template-columns:1fr 1fr}.summary-item{flex-direction:column;text-align:center;padding:15px}.summary-number{font-size:24px}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.graficos-row{grid-template-columns:1fr}.grafico-card.wide{grid-column:span 1}.graficos-toggle{justify-content:center}.btn-toggle{width:100%;justify-content:center}}@media(max-width:480px){.manutencao-summary{grid-template-columns:1fr;gap:12px}.summary-item{flex-direction:row;text-align:left;padding:14px}.summary-icon{width:44px;height:44px}.summary-number{font-size:22px}.summary-label{font-size:12px}.grafico-card{padding:14px}.grafico-card h3{font-size:14px}.form-section,.form-actions{padding:16px}.manutencao-form-page .btn-primary,.manutencao-form-page .btn-secondary{width:100%;justify-content:center}}.financeiro-page{padding:0;max-width:1600px;margin:0 auto;background:transparent;min-height:auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.page-header h1{margin:0;font-size:28px;color:#2c3e50}.page-subtitle{margin:5px 0 0;color:#7f8c8d;font-size:15px}.periodo-selector{display:flex;gap:5px;background:#e0e0e0;padding:5px;border-radius:10px}.periodo-btn{padding:10px 20px;border:none;background:transparent;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s;color:#7f8c8d}.periodo-btn:hover{color:#2c3e50}.periodo-btn.active{background:#fff;color:#3498db;box-shadow:0 2px 8px #0000001a}.fin-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:30px}.fin-kpi-card{background:#fff;border-radius:16px;padding:25px;display:flex;align-items:flex-start;gap:20px;box-shadow:0 4px 12px #00000014;transition:transform .3s,box-shadow .3s}.fin-kpi-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0000001f}.fin-kpi-card.principal{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.fin-kpi-card.principal .fin-kpi-label{color:#fffc}.fin-kpi-card.principal .fin-kpi-value{color:#fff}.fin-kpi-card.principal .fin-kpi-icon{background:#fff3;color:#fff}.fin-kpi-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#f0f4f8;color:#3498db}.fin-kpi-icon.cif{background:#e3f2fd;color:#1976d2}.fin-kpi-icon.fob{background:#fff3e0;color:#f57c00}.fin-kpi-icon.ticket{background:#e8f5e9;color:#388e3c}.fin-kpi-content{display:flex;flex-direction:column;gap:5px}.fin-kpi-label{font-size:13px;color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px}.fin-kpi-value{font-size:26px;font-weight:700;color:#2c3e50;line-height:1.2}.fin-kpi-percent{font-size:13px;font-weight:600}.fin-kpi-percent.cif{color:#1976d2}.fin-kpi-percent.fob{color:#f57c00}.fin-kpi-change{font-size:13px;font-weight:500}.fin-kpi-change.positive{color:#ffffffe6}.fin-kpi-change.negative{color:#ffcdd2}.fin-kpi-subtext{font-size:12px;color:#95a5a6}.fin-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:25px;margin-bottom:30px}.fin-charts-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:25px;margin-bottom:30px}.fin-chart-card{background:#fff;border-radius:16px;padding:25px;box-shadow:0 4px 12px #00000014}.fin-chart-card h3{margin:0 0 20px;color:#2c3e50;font-size:18px;font-weight:600}.custom-tooltip{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:12px 16px;box-shadow:0 4px 12px #00000026}.custom-tooltip .tooltip-label{font-weight:600;color:#2c3e50;margin:0 0 8px;font-size:14px}.custom-tooltip p{margin:4px 0;font-size:13px}.fin-pie-legend{display:flex;justify-content:center;gap:30px;margin-top:15px;padding-top:15px;border-top:1px solid #eee}.legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:#555}.legend-dot{width:12px;height:12px;border-radius:50%}.clientes-list{display:flex;flex-direction:column;gap:15px}.cliente-item{display:flex;align-items:center;gap:12px}.cliente-rank{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}.cliente-info{flex:1;min-width:0}.cliente-nome{display:block;font-size:13px;color:#2c3e50;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:6px}.cliente-bar-container{height:6px;background:#f0f0f0;border-radius:3px;overflow:hidden}.cliente-bar{height:100%;background:linear-gradient(90deg,#3498db,#2ecc71);border-radius:3px;transition:width .5s ease}.cliente-valor{font-size:13px;font-weight:600;color:#2c3e50;white-space:nowrap}.resumo-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px}.resumo-item{background:#f8f9fa;border-radius:10px;padding:15px;text-align:center}.resumo-label{display:block;font-size:11px;color:#7f8c8d;text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}.resumo-value{display:block;font-size:16px;font-weight:700;color:#2c3e50}.resumo-growth{margin-top:20px;padding-top:15px;border-top:1px solid #eee}.growth-indicator{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px;border-radius:10px}.growth-indicator.positive{background:#e8f5e9}.growth-indicator.negative{background:#ffebee}.growth-icon{font-size:20px}.growth-text{font-size:14px;font-weight:600}.growth-indicator.positive .growth-text{color:#27ae60}.growth-indicator.negative .growth-text{color:#e74c3c}@media(max-width:1400px){.fin-kpi-grid{grid-template-columns:repeat(2,1fr)}.fin-charts-grid-3{grid-template-columns:1fr 1fr}.fin-chart-card.resumo{grid-column:span 2}}@media(max-width:1024px){.fin-charts-grid,.fin-charts-grid-3{grid-template-columns:1fr}.fin-chart-card.resumo{grid-column:span 1}}@media(max-width:768px){.financeiro-page{padding:0}.page-header{flex-direction:column;gap:15px;align-items:flex-start}.periodo-selector{width:100%;justify-content:stretch}.periodo-btn{flex:1;padding:10px 12px;font-size:13px;text-align:center}.fin-kpi-grid{grid-template-columns:1fr 1fr;gap:12px}.fin-kpi-card{padding:16px;flex-direction:column;align-items:flex-start;gap:12px}.fin-kpi-icon{width:48px;height:48px}.fin-kpi-value{font-size:20px}.fin-kpi-label{font-size:11px}.fin-chart-card{padding:16px}.fin-chart-card h3{font-size:15px;margin-bottom:14px}.resumo-grid{grid-template-columns:1fr 1fr}.cliente-nome,.cliente-valor{font-size:12px}}@media(max-width:480px){.fin-kpi-grid{grid-template-columns:1fr;gap:10px}.fin-kpi-card{flex-direction:row;align-items:center;padding:14px}.fin-kpi-icon{width:44px;height:44px}.fin-kpi-value{font-size:18px}.periodo-btn{padding:8px 10px;font-size:12px}.fin-chart-card{padding:14px;margin:0 -10px;border-radius:0}.resumo-grid{grid-template-columns:1fr}.resumo-item{padding:12px}.resumo-value{font-size:14px}.fin-pie-legend{flex-direction:column;gap:10px;align-items:flex-start}}.configuracoes-page{padding:0;max-width:1000px;margin:0 auto}.config-tabs{display:flex;gap:12px;margin-bottom:25px;flex-wrap:wrap}.config-tab{display:flex;align-items:center;gap:10px;padding:14px 22px;background:#fff;border:2px solid #e0e0e0;border-radius:10px;font-size:14px;font-weight:500;color:#7f8c8d;cursor:pointer;transition:all .3s}.config-tab:hover{border-color:#3498db;color:#3498db}.config-tab.active{background:#3498db;border-color:#3498db;color:#fff}.config-tab svg{stroke:currentColor}.message-box{padding:14px 18px;border-radius:8px;margin-bottom:20px;font-weight:500;font-size:14px}.message-box.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.message-box.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.config-content{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014}.config-section{padding:24px}.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group.full{grid-column:1 / -1}.form-group label{font-size:14px;font-weight:600;color:#34495e}.form-group input,.form-group select,.form-group textarea{padding:12px 14px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;transition:border-color .3s,box-shadow .3s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 4px #3498db1a}.form-divider{grid-column:1 / -1;display:flex;align-items:center;gap:15px;margin:10px 0}.form-divider:before,.form-divider:after{content:"";flex:1;height:1px;background:#e0e0e0}.form-divider span{font-size:12px;font-weight:600;color:#7f8c8d;text-transform:uppercase;letter-spacing:1px}.form-actions{margin-top:25px;padding-top:18px;border-top:1px solid #eee;display:flex;justify-content:flex-end}.parametros-list{display:flex;flex-direction:column;gap:12px}.parametro-item{display:flex;justify-content:space-between;align-items:center;padding:18px;background:#f8f9fa;border-radius:10px}.parametro-info{display:flex;flex-direction:column;gap:4px}.parametro-nome{font-weight:600;color:#2c3e50;font-size:14px}.parametro-desc{font-size:13px;color:#7f8c8d}.parametro-valor input{width:180px;padding:10px 14px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px}.parametro-valor input:focus{outline:none;border-color:#3498db}.parametro-valor input:disabled{background:#f1f5f9;color:#94a3b8;cursor:not-allowed;border-color:#e2e8f0}.parametro-item.disabled{opacity:.7}.switch{position:relative;display:inline-block;width:50px;height:28px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.4s;border-radius:28px}.slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider{background-color:#27ae60}input:checked+.slider:before{transform:translate(22px)}.no-data{text-align:center;color:#95a5a6;padding:40px}@media(max-width:1024px){.form-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.config-tabs{flex-direction:column;gap:8px}.config-tab{width:100%;justify-content:center;padding:12px 18px}.config-section{padding:18px}.form-grid{grid-template-columns:1fr}.form-group.full,.form-group[style*="span 2"]{grid-column:auto}.parametro-item{flex-direction:column;gap:14px;text-align:center}.parametro-valor input{width:100%}.form-actions{flex-direction:column}.form-actions button{width:100%}}@media(max-width:480px){.config-tab{padding:11px 16px;font-size:13px;gap:8px}.config-tab svg{width:18px;height:18px}.config-section{padding:14px}.form-group input,.form-group select,.form-group textarea{padding:11px 12px;font-size:14px}.parametro-item{padding:14px}.parametro-nome{font-size:13px}.parametro-desc{font-size:12px}}.relatorios-page{padding:0;max-width:1400px;margin:0 auto}.relatorios-container{display:flex;flex-direction:column;gap:25px}.relatorios-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}.relatorio-card{background:#fff;border-radius:12px;padding:22px;display:flex;align-items:flex-start;gap:18px;box-shadow:0 2px 8px #00000014;cursor:pointer;transition:all .3s;border:2px solid transparent;position:relative}.relatorio-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000001f;border-color:#e0e0e0}.relatorio-card.selected{border-color:#3498db;background:#f8fbff}.relatorio-icon{width:48px;height:48px;border-radius:10px;background:#f0f4f8;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#3498db}.relatorio-card.selected .relatorio-icon{background:#3498db;color:#fff}.relatorio-info{flex:1;min-width:0}.relatorio-info h3{margin:0 0 5px;font-size:15px;color:#2c3e50}.relatorio-info p{margin:0;font-size:13px;color:#7f8c8d;line-height:1.4}.selected-check{position:absolute;top:10px;right:10px;width:22px;height:22px;background:#27ae60;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.filtros-relatorio{background:#fff;border-radius:12px;padding:22px;box-shadow:0 2px 8px #00000014}.filtros-relatorio h3{margin:0 0 18px;color:#2c3e50;font-size:17px}.filtros-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px}.filtros-relatorio .form-group{display:flex;flex-direction:column;gap:8px}.filtros-relatorio .form-group label{font-size:14px;font-weight:600;color:#34495e}.filtros-relatorio .form-group input,.filtros-relatorio .form-group select{padding:11px 14px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;transition:border-color .3s,box-shadow .3s}.filtros-relatorio .form-group input:focus,.filtros-relatorio .form-group select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 4px #3498db1a}.error-message{background:#f8d7da;color:#721c24;padding:12px 18px;border-radius:8px;border:1px solid #f5c6cb;font-weight:500;font-size:14px;margin-bottom:15px}.success-message{background:#d4edda;color:#155724;padding:12px 18px;border-radius:8px;border:1px solid #c3e6cb;font-weight:500;font-size:14px;margin-bottom:15px}.relatorio-actions{margin-top:22px;padding-top:18px;border-top:1px solid #eee;display:flex;justify-content:center}.btn-primary{display:inline-flex;align-items:center;gap:10px;padding:12px 28px;background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #3498db4d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-large{padding:14px 35px;font-size:16px}.spinner{width:18px;height:18px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@media(max-width:1024px){.relatorios-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media(max-width:768px){.relatorios-grid{grid-template-columns:1fr 1fr;gap:12px}.relatorio-card{padding:16px;flex-direction:column;gap:12px}.relatorio-icon{width:42px;height:42px}.relatorio-info h3{font-size:14px}.filtros-relatorio{padding:18px}.filtros-grid{grid-template-columns:1fr}.btn-large{width:100%;justify-content:center}}@media(max-width:480px){.relatorios-grid{grid-template-columns:1fr}.relatorio-card{flex-direction:row;padding:14px;gap:12px}.relatorio-icon{width:38px;height:38px}.relatorio-info p{font-size:12px}.filtros-relatorio{padding:14px}.filtros-relatorio h3{font-size:15px}.btn-primary{padding:11px 20px;font-size:14px}.btn-large{padding:12px 24px;font-size:14px}}.backup-page{padding:0}.backup-page .page-header{margin-bottom:25px}.backup-page .header-title h1{margin:0;font-size:24px;color:#1e293b}.backup-page .header-title p{margin:5px 0 0;color:#64748b}.backup-page .demo-badge{display:inline-block;margin-top:8px;padding:4px 12px;background:#fef3c7;color:#92400e;border-radius:20px;font-size:12px;font-weight:500}.backup-page .alert{padding:12px 40px 12px 16px;border-radius:8px;margin-bottom:20px;position:relative;display:flex;align-items:center;font-size:14px}.backup-page .alert-success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.backup-page .alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.backup-page .alert-info{background:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}.backup-page .alert-close{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:20px;cursor:pointer;opacity:.7}.backup-page .alert-close:hover{opacity:1}.backup-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:25px}.action-card{background:#fff;border-radius:12px;padding:28px;text-align:center;box-shadow:0 2px 8px #00000014;border:1px solid #e2e8f0}.action-icon{width:70px;height:70px;margin:0 auto 18px;border-radius:50%;display:flex;align-items:center;justify-content:center}.action-icon.gerar{background:#dbeafe;color:#2563eb}.action-icon.restaurar{background:#fef3c7;color:#d97706}.action-card h3{margin:0 0 10px;font-size:17px;color:#1e293b}.action-card p{margin:0 0 18px;color:#64748b;font-size:14px}.action-card .btn-primary,.action-card .btn-warning{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.action-card .btn-primary{background:#2563eb;color:#fff}.action-card .btn-primary:hover:not(:disabled){background:#1d4ed8}.action-card .btn-warning{background:#f59e0b;color:#fff}.action-card .btn-warning:hover:not(.disabled){background:#d97706}.action-card .btn-primary:disabled,.action-card .btn-warning.disabled{opacity:.6;cursor:not-allowed}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.backups-section{background:#fff;border-radius:12px;padding:22px;margin-bottom:22px;box-shadow:0 2px 8px #00000014}.backups-section h2{margin:0 0 18px;font-size:17px;color:#1e293b}.table-container{overflow-x:auto}.data-table th,.data-table td{padding:12px 14px;text-align:left;border-bottom:1px solid #e2e8f0}.badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500}.badge-info{background:#dbeafe;color:#1e40af}.btn-action{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:none;border-radius:6px;font-size:13px;cursor:pointer;transition:all .2s}.btn-download{background:#f1f5f9;color:#475569}.btn-download:hover{background:#e2e8f0;color:#1e293b}.backup-info{background:#f8fafc;border-radius:12px;padding:22px;border:1px solid #e2e8f0}.backup-info h3{margin:0 0 14px;font-size:15px;color:#1e293b}.backup-info ul{margin:0;padding-left:20px}.backup-info li{margin-bottom:8px;color:#64748b;font-size:14px}.badge-success{background:#d1fae5;color:#065f46}.badge-danger{background:#fee2e2;color:#991b1b}.badge-warning{background:#fef3c7;color:#92400e}.btn-download:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.backup-actions{grid-template-columns:1fr;gap:16px}.action-card{padding:22px}.action-icon{width:60px;height:60px;margin-bottom:14px}.action-card h3{font-size:16px}.backups-section{padding:18px;margin:0 -16px 20px;border-radius:0}.table-container{margin:0 -18px}.data-table{min-width:600px}.data-table th,.data-table td{padding:10px 12px;font-size:13px}.btn-action{padding:5px 10px;font-size:12px}}@media(max-width:480px){.action-card{padding:18px}.action-icon{width:54px;height:54px}.action-card p{font-size:13px}.action-card .btn-primary,.action-card .btn-warning{padding:10px 18px;font-size:13px;width:100%;justify-content:center}.backup-info{padding:16px;margin:0 -16px;border-radius:0}.backup-info h3{font-size:14px}.backup-info li{font-size:13px}.data-table th:nth-child(5),.data-table td:nth-child(5){display:none}}.alertas-page{padding:0}.alertas-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:25px}.alertas-page .header-title h1{margin:0;font-size:24px;color:#1e293b}.alertas-page .header-title p{margin:5px 0 0;color:#64748b}.alertas-page .demo-badge{display:inline-block;margin-top:8px;padding:4px 12px;background:#fef3c7;color:#92400e;border-radius:20px;font-size:12px;font-weight:500}.alertas-page .btn-secondary{padding:10px 20px;background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s}.alertas-page .btn-secondary:hover{background:#e2e8f0;color:#1e293b}.alertas-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:25px}.alertas-summary .summary-card{background:#fff;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #00000014}.alertas-summary .summary-icon{width:50px;height:50px;border-radius:12px;display:flex;align-items:center;justify-content:center}.alertas-summary .summary-icon.total{background:#dbeafe;color:#2563eb}.alertas-summary .summary-icon.nao-lidos{background:#fef3c7;color:#d97706}.alertas-summary .summary-icon.urgentes{background:#fee2e2;color:#dc2626}.alertas-summary .summary-info{display:flex;flex-direction:column}.alertas-summary .summary-number{font-size:28px;font-weight:700;color:#1e293b}.alertas-summary .summary-label{font-size:13px;color:#64748b}.filtros-section{margin-bottom:20px}.filtros-tabs{display:flex;gap:8px;flex-wrap:wrap}.tab-btn{padding:8px 16px;background:#fff;border:1px solid #e2e8f0;border-radius:20px;font-size:13px;color:#64748b;cursor:pointer;transition:all .2s}.tab-btn:hover{border-color:#cbd5e1;color:#475569}.tab-btn.active{background:#2563eb;border-color:#2563eb;color:#fff}.alertas-list{display:flex;flex-direction:column;gap:12px}.alerta-card{background:#fff;border-radius:12px;padding:16px 20px;display:flex;align-items:flex-start;gap:16px;box-shadow:0 2px 8px #00000014;border-left:4px solid transparent;transition:all .2s}.alerta-card.prioridade-alta{border-left-color:#dc2626}.alerta-card.prioridade-media{border-left-color:#f59e0b}.alerta-card.prioridade-baixa{border-left-color:#3b82f6}.alerta-card.lido{opacity:.7;background:#f8fafc}.alerta-card:hover{box-shadow:0 4px 12px #0000001a}.alerta-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.alerta-icon.tipo-vencimento{background:#fef3c7;color:#d97706}.alerta-icon.tipo-manutencao{background:#dbeafe;color:#2563eb}.alerta-icon.tipo-pagamento{background:#d1fae5;color:#059669}.alerta-icon.tipo-documento{background:#e0e7ff;color:#4f46e5}.alerta-icon.tipo-sistema{background:#f1f5f9;color:#64748b}.alerta-content{flex:1;min-width:0}.alerta-header{display:flex;align-items:center;gap:12px;margin-bottom:6px;flex-wrap:wrap}.alerta-header h3{margin:0;font-size:15px;font-weight:600;color:#1e293b}.alerta-content p{margin:0 0 8px;font-size:14px;color:#64748b;line-height:1.5}.alerta-time{font-size:12px;color:#94a3b8}.badge{display:inline-block;padding:3px 8px;border-radius:12px;font-size:11px;font-weight:500}.badge-danger{background:#fee2e2;color:#dc2626}.badge-warning{background:#fef3c7;color:#d97706}.badge-info{background:#dbeafe;color:#2563eb}.badge-secondary{background:#f1f5f9;color:#64748b}.alerta-actions{display:flex;align-items:center}.btn-mark-read{width:36px;height:36px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-mark-read:hover{background:#d1fae5;border-color:#a7f3d0;color:#059669}.empty-state{text-align:center;padding:60px 20px;color:#94a3b8}.empty-state svg{margin-bottom:16px;opacity:.5}.empty-state p{margin:0;font-size:16px}@media(max-width:1024px){.alertas-summary{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.alertas-page .page-header{flex-direction:column;gap:15px}.alertas-summary{grid-template-columns:repeat(2,1fr);gap:12px}.filtros-tabs{overflow-x:auto;padding-bottom:8px;flex-wrap:nowrap}.tab-btn{white-space:nowrap}.alerta-card{flex-direction:column}.alerta-actions{align-self:flex-end}}@media(max-width:480px){.alertas-summary{grid-template-columns:1fr}.alertas-summary .summary-card{padding:14px}.alertas-summary .summary-icon{width:42px;height:42px}.alertas-summary .summary-number{font-size:22px}.filtros-tabs{gap:6px}.tab-btn{padding:6px 12px;font-size:12px}.alerta-card{padding:14px 16px}.alerta-icon{width:38px;height:38px}.alerta-header h3{font-size:14px}.alerta-content p{font-size:13px}.btn-mark-read{width:32px;height:32px}}.faixas-km-page{padding:0}.faixas-km-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:25px}.faixas-km-page .header-title h1{margin:0;font-size:24px;color:#1e293b}.faixas-km-page .header-title p{margin:5px 0 0;color:#64748b}.faixas-km-page .demo-badge{display:inline-block;margin-top:8px;padding:4px 12px;background:#fef3c7;color:#92400e;border-radius:20px;font-size:12px;font-weight:500}.faixas-km-page .btn-primary{padding:10px 20px;background:#2563eb;color:#fff;border:none;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s}.faixas-km-page .btn-primary:hover:not(:disabled){background:#1d4ed8}.faixas-km-page .btn-primary:disabled{opacity:.6;cursor:not-allowed}.faixas-km-page .alert{padding:12px 40px 12px 16px;border-radius:8px;margin-bottom:20px;position:relative}.faixas-km-page .alert-success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.faixas-km-page .alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.faixas-km-page .alert-close{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:20px;cursor:pointer;opacity:.7}.faixas-km-page .alert-close:hover{opacity:1}.faixas-table-container{background:#fff;border-radius:12px;padding:20px;margin-bottom:24px;box-shadow:0 2px 8px #00000014;overflow-x:auto}.data-table{width:100%;border-collapse:collapse;min-width:500px}.data-table th,.data-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #e2e8f0}.data-table th{background:#f8fafc;font-weight:600;color:#475569;font-size:12px;text-transform:uppercase}.data-table td{color:#334155;font-size:14px}.data-table tr:hover{background:#f8fafc}.faixa-badge{display:inline-block;padding:4px 12px;background:#dbeafe;color:#1e40af;border-radius:20px;font-size:12px;font-weight:500}.valor-km{color:#059669;font-size:15px;font-weight:600}.action-buttons{display:flex;gap:8px}.btn-action{width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-edit{background:#dbeafe;color:#2563eb}.btn-edit:hover{background:#bfdbfe}.btn-delete{background:#fee2e2;color:#dc2626}.btn-delete:hover{background:#fecaca}.faixas-visual{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014}.faixas-visual h3{margin:0 0 20px;font-size:16px;color:#1e293b}.faixas-bars{display:flex;flex-direction:column;gap:12px}.faixa-bar{display:flex;flex-direction:column;gap:6px}.faixa-bar-header{display:flex;justify-content:space-between;font-size:13px}.faixa-range{color:#64748b}.faixa-valor{font-weight:600;color:#1e293b}.faixa-bar-fill{height:24px;border-radius:6px;transition:width .3s ease}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:15px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:modalSlideIn .25s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e2e8f0}.modal-header h2{margin:0;font-size:18px;color:#1e293b}.modal-close{width:32px;height:32px;border:none;background:#f1f5f9;border-radius:6px;font-size:20px;cursor:pointer;color:#64748b;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#e2e8f0;color:#1e293b}.modal-content form{padding:24px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:#374151}.form-group input{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:16px;border-top:1px solid #e2e8f0}.btn-secondary{padding:10px 20px;background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#e2e8f0;color:#1e293b}@media(max-width:768px){.faixas-km-page .page-header{flex-direction:column;gap:15px}.faixas-table-container{padding:16px;margin:0 -16px 20px;border-radius:0}.form-row{grid-template-columns:1fr}.modal-overlay{align-items:flex-end;padding:0}.modal-content{max-width:100%;border-radius:16px 16px 0 0;max-height:90vh;margin-top:auto}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}}@media(max-width:480px){.faixas-visual{padding:18px}.faixas-visual h3{font-size:15px}.data-table th,.data-table td{padding:10px 12px;font-size:13px}.faixa-badge{padding:3px 8px;font-size:11px}}.vencimentos-page{padding:0;max-width:1400px;margin:0 auto;background:transparent;min-height:auto}.vencimentos-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:25px;flex-wrap:wrap;gap:15px}.vencimentos-page .header-title h1{color:#1e293b;font-size:24px;margin:0 0 5px}.vencimentos-page .header-title p{color:#64748b;margin:0}.vencimentos-page .header-actions{display:flex;gap:10px}.header-filters{display:flex;align-items:center;gap:16px}.toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:#4b5563;font-weight:500;padding:8px 12px;background:#fff;border-radius:8px;border:1px solid #e5e7eb;transition:all .2s ease}.toggle-label:hover{border-color:#3498db;color:#3498db}.toggle-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#3498db}.toggle-label input[type=checkbox]:checked+span{color:#3498db}.vencimentos-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:25px}.vencimentos-summary .summary-card{background:#fff;border-radius:12px;padding:18px;display:flex;align-items:center;gap:14px;box-shadow:0 2px 8px #00000014;transition:transform .3s,box-shadow .3s}.vencimentos-summary .summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.vencimentos-summary .summary-card.alerta{border-left:4px solid #e74c3c;background:#fef9f9}.vencimentos-summary .summary-card.warning{border-left:4px solid #f39c12;background:#fffcf5}.vencimentos-summary .summary-icon{width:46px;height:46px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.vencimentos-summary .summary-icon.vencidos{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.vencimentos-summary .summary-icon.urgentes{background:linear-gradient(135deg,#f39c12,#e67e22);color:#fff}.vencimentos-summary .summary-icon.motoristas{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.vencimentos-summary .summary-icon.veiculos{background:linear-gradient(135deg,#9b59b6,#8e44ad);color:#fff}.vencimentos-summary .summary-info{display:flex;flex-direction:column;gap:4px}.vencimentos-summary .summary-number{font-size:22px;font-weight:700;color:#1e293b}.vencimentos-summary .summary-label{font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.vencimentos-page .tabs-container{display:flex;gap:8px;margin-bottom:25px;flex-wrap:wrap}.vencimentos-page .tab-button{padding:10px 18px;border:none;background:#fff;border-radius:8px;font-size:14px;font-weight:500;color:#7f8c8d;cursor:pointer;transition:all .3s;box-shadow:0 2px 4px #0000000d}.vencimentos-page .tab-button:hover{background:#f8f9fa;color:#2c3e50}.vencimentos-page .tab-button.active{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.vencimentos-page .tab-button.danger.active{background:linear-gradient(135deg,#e74c3c,#c0392b)}.vencimentos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px}.vencimento-card{background:#fff;border-radius:12px;padding:18px;box-shadow:0 2px 8px #00000014;border-left:4px solid #95a5a6;transition:transform .3s,box-shadow .3s}.vencimento-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.vencimento-card.vencido{border-left-color:#e74c3c;background:#fef9f9}.vencimento-card.urgente{border-left-color:#f39c12;background:#fffcf5}.vencimento-card.atencao{border-left-color:#3498db}.vencimento-card.normal{border-left-color:#27ae60}.vencimento-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.vencimento-tipo{display:flex;align-items:center;gap:8px;color:#7f8c8d;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.status-badge{padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600}.status-badge.vencido{background:#fce4ec;color:#c62828}.status-badge.urgente{background:#fff3e0;color:#e65100}.status-badge.atencao{background:#e3f2fd;color:#1565c0}.status-badge.normal{background:#e8f5e9;color:#2e7d32}.vencimento-content{margin-bottom:14px}.vencimento-content h3{margin:0 0 5px;color:#1e293b;font-size:16px}.vencimento-content .detalhe{margin:0 0 12px;color:#64748b;font-size:13px}.documento-info{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#f8f9fa;border-radius:8px}.doc-nome{font-weight:600;color:#2c3e50;font-size:14px}.doc-validade{font-size:13px;color:#7f8c8d}.vencimento-actions{display:flex;justify-content:flex-end;gap:10px}.vencimentos-page .empty-state{text-align:center;padding:50px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014}.vencimentos-page .empty-state.success{border-top:4px solid #27ae60}.vencimentos-page .empty-state svg{color:#27ae60;margin-bottom:18px}.vencimentos-page .empty-state h3{margin:0 0 10px;color:#1e293b;font-size:18px}.vencimentos-page .empty-state p{margin:0;color:#64748b}@media(max-width:1200px){.vencimentos-summary{grid-template-columns:repeat(2,1fr)}}@media(max-width:1024px){.vencimentos-page{max-width:100%}.vencimentos-summary{gap:16px}.vencimentos-summary .summary-card{padding:16px}.vencimentos-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.vencimento-card{padding:16px}}@media(max-width:768px){.vencimentos-page .page-header{flex-direction:column;align-items:stretch}.vencimentos-summary{grid-template-columns:1fr 1fr;gap:12px}.vencimentos-summary .summary-card{padding:14px}.vencimentos-summary .summary-number{font-size:20px}.vencimentos-grid{grid-template-columns:1fr}.vencimentos-page .tabs-container{overflow-x:auto;flex-wrap:nowrap;padding-bottom:10px}.vencimentos-page .tab-button{white-space:nowrap;padding:8px 14px;font-size:13px}}@media(max-width:480px){.vencimentos-summary{grid-template-columns:1fr}.vencimentos-summary .summary-icon{width:40px;height:40px}.vencimento-card{padding:14px}.vencimento-content h3{font-size:15px}.documento-info{flex-direction:column;align-items:flex-start;gap:6px}}.geografico-page{padding:0;max-width:1600px;margin:0 auto;background:transparent;min-height:auto}.geografico-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:25px;flex-wrap:wrap;gap:15px}.geografico-page .header-title h1{color:#1e293b;font-size:24px;margin:0 0 5px}.geografico-page .header-title p{color:#64748b;margin:0}.geografico-page .header-filters{display:flex;gap:10px;flex-wrap:wrap}.geo-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:25px}.geo-kpi-card{background:#fff;border-radius:12px;padding:18px;display:flex;align-items:center;gap:14px;box-shadow:0 2px 8px #00000014;transition:transform .3s,box-shadow .3s}.geo-kpi-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.geo-kpi-icon{width:46px;height:46px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.geo-kpi-icon.blue{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.geo-kpi-icon.green{background:linear-gradient(135deg,#2ecc71,#27ae60);color:#fff}.geo-kpi-icon.orange{background:linear-gradient(135deg,#f39c12,#e67e22);color:#fff}.geo-kpi-icon.purple{background:linear-gradient(135deg,#9b59b6,#8e44ad);color:#fff}.geo-kpi-content{display:flex;flex-direction:column;gap:4px}.geo-kpi-value{font-size:20px;font-weight:700;color:#1e293b}.geo-kpi-label{font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.geo-charts-row{display:grid;grid-template-columns:2fr 1fr;gap:18px;margin-bottom:25px}.geo-charts-row:last-child{margin-bottom:0}.geo-chart-card{background:#fff;border-radius:12px;padding:18px;box-shadow:0 2px 8px #00000014}.geo-chart-card.large{grid-column:span 1}.geo-chart-card.full-width{grid-column:1 / -1}.geo-chart-card h3{margin:0 0 14px;font-size:15px;color:#1e293b;font-weight:600}.rotas-table-container{overflow-x:auto}.rotas-table{width:100%;border-collapse:collapse;min-width:500px}.rotas-table th{padding:12px;text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:#64748b;border-bottom:2px solid #eee;font-weight:600}.rotas-table td{padding:12px;border-bottom:1px solid #f0f0f0;vertical-align:middle;font-size:14px}.rotas-table tbody tr:hover{background:#f8fafc}.rota-origem,.rota-destino{display:inline-block;padding:3px 8px;background:#e8f4fd;color:#2980b9;border-radius:4px;font-weight:600;font-size:13px}.rota-destino{background:#e8f5e9;color:#27ae60}.rota-arrow{margin:0 8px;color:#95a5a6}.badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}.badge-info{background-color:#d1ecf1;color:#0c5460}.demo-badge{display:inline-block;background:linear-gradient(135deg,#f39c12,#e67e22);color:#fff;font-size:11px;font-weight:600;padding:4px 10px;border-radius:20px;margin-left:10px;vertical-align:middle;text-transform:uppercase;letter-spacing:.5px}.select-filter{padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;background:#fff;cursor:pointer;min-width:140px;transition:all .2s}.select-filter:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}@media(max-width:1400px){.geo-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:1024px){.geo-charts-row{grid-template-columns:1fr}.geo-chart-card.large{grid-column:span 1}}@media(max-width:768px){.geo-kpi-grid{grid-template-columns:1fr 1fr;gap:12px}.geo-kpi-card{padding:14px}.geo-kpi-icon{width:40px;height:40px}.geo-kpi-value{font-size:18px}.geografico-page .page-header{flex-direction:column;align-items:stretch}.geografico-page .header-filters{width:100%}.select-filter{flex:1}.geo-chart-card{padding:14px;margin:0 -16px;border-radius:0}}@media(max-width:480px){.geo-kpi-grid{grid-template-columns:1fr}.geo-kpi-card{padding:12px}.rotas-table th,.rotas-table td{padding:10px 8px;font-size:12px}.rota-origem,.rota-destino{font-size:11px;padding:2px 6px}}.usuarios-page{padding:0}.usuarios-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.summary-card{background:#fff;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #0000000f;transition:transform .2s,box-shadow .2s}.summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.summary-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.summary-icon.total{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.summary-icon.ativos{background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff}.summary-icon.inativos{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.summary-icon.admins{background:linear-gradient(135deg,#f39c12,#e67e22);color:#fff}.summary-info{display:flex;flex-direction:column}.summary-number{font-size:28px;font-weight:700;color:#1e293b;line-height:1}.summary-label{font-size:13px;color:#64748b;margin-top:4px}.usuarios-filters{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;background:#fff;padding:16px;border-radius:12px;box-shadow:0 2px 8px #0000000f}.search-box{flex:1;min-width:250px;position:relative}.search-box .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#94a3b8}.filter-select{min-width:150px;padding:12px 16px;border:1px solid #e2e8f0;border-radius:10px;font-size:14px;background:#fff;cursor:pointer;transition:all .2s}.filter-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.usuarios-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px}.usuario-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000000f;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;gap:16px}.usuario-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.usuario-card.inativo{opacity:.7;background:#f8fafc}.usuario-header{display:flex;align-items:center;gap:16px}.usuario-avatar{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;color:#fff;flex-shrink:0}.usuario-avatar.superuser{background:linear-gradient(135deg,#f39c12,#e67e22)}.usuario-avatar.staff{background:linear-gradient(135deg,#3498db,#2980b9)}.usuario-avatar.operador{background:linear-gradient(135deg,#27ae60,#2ecc71)}.usuario-info{flex:1;min-width:0}.usuario-info h3{margin:0 0 4px;font-size:16px;font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.usuario-info .username{font-size:13px;color:#64748b;margin:0 0 8px}.usuario-badges{display:flex;gap:6px;flex-wrap:wrap}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase}.badge.superuser{background:#f39c1226;color:#d68910}.badge.staff{background:#3498db26;color:#2980b9}.badge.ativo{background:#27ae6026;color:#27ae60}.badge.inativo,.badge-danger{background:#e74c3c26;color:#e74c3c}.badge-success{background:#27ae6026;color:#27ae60}.badge-purple{background:#9b59b626;color:#9b59b6}.badge-info{background:#3498db26;color:#2980b9}.badge-secondary{background:#7f8c8d26;color:#7f8c8d}.usuario-details{display:flex;flex-direction:column;gap:8px;padding-top:12px;border-top:1px solid #f1f5f9}.detail-item{display:flex;align-items:center;gap:10px;font-size:13px;color:#64748b}.detail-item svg{color:#94a3b8;flex-shrink:0}.usuario-actions{display:flex;gap:10px;padding-top:12px;border-top:1px solid #f1f5f9}.btn-action{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none}.btn-edit{background:#f1f5f9;color:#475569}.btn-edit:hover{background:#e2e8f0;color:#1e293b}.btn-toggle{background:#27ae601a;color:#27ae60}.btn-toggle:hover{background:#27ae6033}.btn-toggle.desativar{background:#e74c3c1a;color:#e74c3c}.btn-toggle.desativar:hover{background:#e74c3c33}.btn-delete{background:#e74c3c1a;color:#e74c3c;padding:10px;flex:0}.btn-delete:hover{background:#e74c3c33}.empty-state{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f}.empty-state svg{color:#cbd5e1;margin-bottom:16px}.empty-state h3{margin:0 0 8px;color:#64748b;font-size:18px}.empty-state p{margin:0;color:#94a3b8;font-size:14px}.modal-content{background:#fff;border-radius:16px;max-width:400px;width:100%;padding:28px;text-align:center;box-shadow:0 20px 40px #0003}.modal-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.modal-icon.danger{background:#e74c3c1a;color:#e74c3c}.modal-content h3{margin:0 0 12px;font-size:20px;color:#1e293b}.modal-content p{margin:0 0 24px;color:#64748b;font-size:14px;line-height:1.6}.modal-actions{display:flex;gap:12px}.modal-actions button{flex:1;padding:12px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-modal-cancel{background:#f1f5f9;color:#475569}.btn-modal-cancel:hover{background:#e2e8f0}.btn-modal-confirm{background:#e74c3c;color:#fff}.btn-modal-confirm:hover{background:#c0392b}.usuario-form-container{padding:0;max-width:800px;margin:0 auto}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}.form-title{display:flex;align-items:center;gap:12px}.form-icon{width:40px;height:40px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.form-icon svg{width:22px;height:22px}.form-title h2{margin:0;color:#1e293b;font-size:24px}.btn-back{background-color:#f1f5f9;color:#475569;border:1px solid #e2e8f0;padding:10px 18px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex;align-items:center;gap:8px}.btn-back:hover{background-color:#e2e8f0;color:#1e293b}.usuario-form{background-color:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014}fieldset{border:1px solid #e2e8f0;border-radius:8px;padding:20px;margin-bottom:20px}legend{color:#1e293b;font-weight:600;font-size:16px;padding:0 10px;display:flex;align-items:center;gap:8px}legend svg{color:#667eea}.form-row{display:flex;gap:18px;margin-bottom:18px}.form-row:last-child{margin-bottom:0}.form-group{flex:1;display:flex;flex-direction:column}.form-group label{margin-bottom:6px;color:#374151;font-weight:500;font-size:14px}.required{color:#e74c3c;font-weight:700}.form-group input,.form-group select{padding:11px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-family:inherit;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input::placeholder{color:#94a3b8}.field-hint{font-size:12px;color:#94a3b8;margin-top:4px}.password-input-wrapper{position:relative;display:flex}.password-input-wrapper input{flex:1;padding-right:44px}.btn-toggle-password{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:#94a3b8;cursor:pointer;padding:6px;border-radius:4px;transition:color .2s}.btn-toggle-password:hover{color:#64748b}.permissions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.permission-card{background:#f8fafc;border-radius:10px;padding:16px;transition:all .2s}.permission-card:hover{background:#f1f5f9}.checkbox-container{display:flex;align-items:flex-start;gap:12px;cursor:pointer;position:relative}.checkbox-container input[type=checkbox]{position:absolute;opacity:0;cursor:pointer}.checkmark{width:22px;height:22px;background:#fff;border:2px solid #d1d5db;border-radius:6px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .2s}.checkbox-container input:checked~.checkmark{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea}.checkbox-container input:checked~.checkmark:after{content:"";display:block;width:6px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.permission-info{display:flex;flex-direction:column;gap:2px}.permission-title{font-size:14px;font-weight:500;color:#1e293b}.permission-description{font-size:12px;color:#64748b}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:18px;border-top:1px solid #e2e8f0}.btn-cancel,.btn-submit{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel{background-color:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.btn-cancel:hover:not(:disabled){background-color:#e2e8f0;color:#1e293b}.btn-submit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.btn-cancel:disabled,.btn-submit:disabled{opacity:.6;cursor:not-allowed}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.filtros-section{background:#fff;border-radius:12px;padding:16px;margin-bottom:16px;box-shadow:0 2px 8px #0000000f}.filtros-row{display:flex;gap:16px;flex-wrap:wrap;align-items:center}.search-box{flex:1;min-width:250px;position:relative;display:flex;align-items:center}.search-box svg{position:absolute;left:14px;color:#94a3b8}.search-box input{width:100%;padding:12px 16px 12px 44px;border:1px solid #e2e8f0;border-radius:10px;font-size:14px;transition:all .2s}.search-box input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.select-filter{min-width:150px;padding:12px 16px;border:1px solid #e2e8f0;border-radius:10px;font-size:14px;background:#fff;cursor:pointer;transition:all .2s}.select-filter:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.results-info{margin-bottom:16px}.results-info p{margin:0;color:#64748b;font-size:14px}.btn-toggle-status{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.btn-toggle-status.active{background:#e74c3c1a;color:#e74c3c}.btn-toggle-status.active:hover{background:#e74c3c33}.btn-toggle-status.inactive{background:#27ae601a;color:#27ae60}.btn-toggle-status.inactive:hover{background:#27ae6033}.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:16px;max-width:420px;width:100%;box-shadow:0 20px 40px #0003;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;border-bottom:1px solid #e2e8f0}.modal-header h3{margin:0;font-size:18px;color:#1e293b}.modal-close{background:none;border:none;font-size:24px;color:#94a3b8;cursor:pointer;padding:0;line-height:1}.modal-close:hover{color:#64748b}.modal-body{padding:24px;text-align:center}.warning-icon{color:#f39c12;margin-bottom:16px}.modal-body p{margin:0 0 8px;color:#475569;font-size:15px}.warning-text{color:#e74c3c!important;font-size:13px!important}.modal-footer{display:flex;gap:12px;padding:18px 24px;border-top:1px solid #e2e8f0}.modal-footer button{flex:1;padding:12px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel{background:#f1f5f9;color:#475569}.btn-cancel:hover{background:#e2e8f0}.btn-danger{background:#e74c3c;color:#fff}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:500;text-decoration:none;cursor:pointer;transition:all .2s}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.demo-alert{background:linear-gradient(135deg,#fff9e6,#fff3cd);border:1px solid #ffc107;border-radius:10px;padding:14px 18px;margin-bottom:20px;display:flex;align-items:center;gap:12px;color:#856404}.demo-alert svg{flex-shrink:0}@media(max-width:1024px){.usuarios-summary{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.usuarios-summary{grid-template-columns:1fr}.usuarios-filters{flex-direction:column}.search-box{min-width:100%}.filter-select{width:100%}.usuarios-grid{grid-template-columns:1fr}.form-header{flex-direction:column;align-items:flex-start;gap:12px}.form-title h2{font-size:20px}.btn-back{width:100%;justify-content:center}.form-row{flex-direction:column;gap:0}.form-group{margin-bottom:14px}.usuario-form{padding:18px;border-radius:8px}fieldset{padding:14px;margin-bottom:16px}legend{font-size:15px}.form-actions{flex-direction:column-reverse}.btn-cancel,.btn-submit{width:100%}.permissions-grid{grid-template-columns:1fr}.modal-actions{flex-direction:column}}@media(max-width:480px){.summary-card{padding:16px}.summary-icon{width:40px;height:40px}.summary-number{font-size:24px}.usuario-card{padding:18px}.usuario-avatar{width:48px;height:48px;font-size:18px}.usuario-info h3{font-size:15px}.usuario-actions{flex-wrap:wrap}.form-title h2{font-size:18px}.usuario-form{padding:14px}fieldset{padding:12px}.form-group input,.form-group select{padding:10px 12px;font-size:14px}}:root{--sidebar-width: 270px;--sidebar-collapsed-width: 72px;--mobile-header-height: 64px;--content-bg: #f5f7fa;--card-bg: #ffffff;--text-primary: #1f2937;--text-secondary: #6b7280;--text-muted: #9ca3af;--border-color: #e5e7eb;--border-light: #f3f4f6;--primary-color: #3498db;--primary-dark: #2980b9;--primary-light: rgba(52, 152, 219, .1);--success-color: #27ae60;--warning-color: #f39c12;--danger-color: #e74c3c;--info-color: #3498db;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--content-bg);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-layout{display:flex;min-height:100vh}.app-main{flex:1;margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column;transition:margin-left .3s ease}.sidebar.collapsed~.app-main{margin-left:var(--sidebar-collapsed-width)}.main-content{flex:1;padding:25px;width:100%;max-width:100%;overflow-x:hidden}.page-container{max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;flex-wrap:wrap;gap:15px}.page-header h1{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:0}.page-header h1 svg{margin-right:10px;vertical-align:middle}.card{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:24px;margin-bottom:20px;border:1px solid var(--border-light);transition:box-shadow var(--transition-normal)}.card:hover{box-shadow:var(--shadow-lg)}.card-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:16px;border-bottom:1px solid var(--border-light);margin-bottom:16px}.card-header h2,.card-header h3{font-size:1.1rem;font-weight:600;margin:0;color:var(--text-primary)}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-primary);font-size:14px}.form-control,.input-filter,.select-filter{width:100%;padding:12px 15px;border:1px solid var(--border-color);border-radius:8px;font-size:14px;font-family:inherit;transition:all .2s ease;background-color:var(--card-bg)}.form-control:focus,.input-filter:focus,.select-filter:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3498db26}.form-control::placeholder,.input-filter::placeholder{color:#adb5bd}select.form-control,select.select-filter{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236c757d' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease;text-decoration:none;white-space:nowrap}.btn svg{width:18px;height:18px}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:#2980b9;transform:translateY(-1px);box-shadow:0 4px 12px #3498db4d}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268}.btn-success{background:var(--success-color);color:#fff}.btn-success:hover{background:#219a52}.btn-warning{background:var(--warning-color);color:#fff}.btn-warning:hover{background:#e08e0b}.btn-danger{background:var(--danger-color);color:#fff}.btn-danger:hover{background:#c0392b}.btn-outline{background:transparent;border:1px solid var(--border-color);color:var(--text-primary)}.btn-outline:hover{background:#f8f9fa;border-color:#adb5bd}.btn-sm{padding:6px 12px;font-size:13px}.btn-sm svg{width:16px;height:16px}.btn-lg{padding:14px 28px;font-size:16px}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.table-container{overflow-x:auto;background-color:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border-light)}table{width:100%;border-collapse:collapse;font-size:14px}th,td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--border-light)}th{background:#f9fafb;font-weight:600;color:var(--text-secondary);font-size:12px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;position:sticky;top:0}td{color:var(--text-primary)}tbody tr{transition:background var(--transition-fast)}tbody tr:hover{background:#f9fafb}tbody tr:last-child td{border-bottom:none}.filters-container,.filtros-container{display:flex;flex-wrap:wrap;align-items:flex-end;gap:14px;margin-bottom:24px;padding:20px;background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.badge,.status-badge,.status{display:inline-flex;align-items:center;padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.2px}.badge-success,.status-ativo,.status-autorizado,.status.ativo{background:#27ae601f;color:#1e8449}.badge-warning,.status-pendente,.status.pendente{background:#f39c121f;color:#d68910}.badge-danger,.status-inativo,.status-cancelado,.status.inativo{background:#e74c3c1f;color:#c0392b}.badge-info,.badge-cif{background:#3498db1f;color:#2471a3}.badge-fob{background:#9b59b61f;color:#7d3c98}.pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:25px;flex-wrap:wrap}.pagination button{padding:8px 14px;border:1px solid var(--border-color);background:var(--card-bg);border-radius:8px;cursor:pointer;transition:all .2s;font-size:14px}.pagination button:hover:not(:disabled){background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.pagination button.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.pagination button:disabled{opacity:.5;cursor:not-allowed}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-secondary)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:15px}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--text-secondary)}.empty-state svg{width:64px;height:64px;margin-bottom:20px;opacity:.5}.empty-state h3{font-size:1.25rem;color:var(--text-primary);margin-bottom:10px}.empty-state p{max-width:400px;margin-bottom:20px}.alert{padding:15px 20px;border-radius:8px;margin-bottom:20px;display:flex;align-items:flex-start;gap:12px}.alert svg{flex-shrink:0;width:20px;height:20px}.alert-success{background:#27ae601a;border:1px solid rgba(39,174,96,.3);color:#27ae60}.alert-warning{background:#f39c121a;border:1px solid rgba(243,156,18,.3);color:#f39c12}.alert-danger,.alert-error{background:#e74c3c1a;border:1px solid rgba(231,76,60,.3);color:#e74c3c}.alert-info{background:#3498db1a;border:1px solid rgba(52,152,219,.3);color:#3498db}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--text-secondary)}.text-success{color:var(--success-color)}.text-danger{color:var(--danger-color)}.text-warning{color:var(--warning-color)}.mt-10{margin-top:10px}.mt-20{margin-top:20px}.mt-30{margin-top:30px}.mb-10{margin-bottom:10px}.mb-20{margin-bottom:20px}.mb-30{margin-bottom:30px}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-10{gap:10px}.gap-15{gap:15px}.gap-20{gap:20px}.grid{display:grid;gap:20px}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media(max-width:1024px){.app-main{margin-left:0}.main-content{padding-top:calc(var(--mobile-header-height) + 20px);padding-left:20px;padding-right:20px}.grid-4{grid-template-columns:repeat(2,1fr)}.page-header{flex-direction:column;align-items:flex-start}.page-header .btn-group{width:100%;display:flex;gap:10px}.page-header .btn-group .btn{flex:1}}@media(max-width:768px){html{font-size:15px}.main-content{padding:calc(var(--mobile-header-height) + 15px) 15px 15px 15px}.page-header h1{font-size:1.4rem}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.filters-container,.filtros-container{flex-direction:column;padding:15px}.filter-group{width:100%}.input-filter,.select-filter,.form-control{width:100%!important;min-width:0!important}table{font-size:13px}th,td{padding:12px 10px}.btn{padding:10px 16px;font-size:13px}.btn svg+span,.btn-primary svg+span,.btn-secondary svg+span{display:none}.btn svg{margin:0}.pagination{gap:5px;flex-wrap:wrap}.pagination button{padding:8px 12px;font-size:13px}.btn-icon-mobile span{display:none}}@media(max-width:480px){.main-content{padding:calc(var(--mobile-header-height) + 10px) 10px 10px 10px}.card{padding:15px;border-radius:10px}.page-header h1{font-size:1.2rem}th,td{padding:10px 8px;font-size:12px}.table-container{margin:0 -10px;width:calc(100% + 20px);border-radius:0}.table-responsive{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.btn{padding:8px 12px;font-size:12px}.btn-sm{padding:6px 10px;font-size:11px}.badge,.status-badge,.status{padding:4px 8px;font-size:10px}}@media(max-width:640px){.table-mobile-cards{display:block}.table-mobile-cards thead{display:none}.table-mobile-cards tbody{display:flex;flex-direction:column;gap:12px}.table-mobile-cards tr{display:flex;flex-direction:column;background:#fff;border-radius:12px;padding:15px;box-shadow:0 2px 8px #00000014;border:1px solid var(--border-light)}.table-mobile-cards td{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f0f0f0}.table-mobile-cards td:last-child{border-bottom:none;padding-top:12px;justify-content:flex-end;gap:8px}.table-mobile-cards td:before{content:attr(data-label);font-weight:600;color:#6b7280;font-size:12px;text-transform:uppercase}.table-mobile-cards td:last-child:before{display:none}}@media print{.sidebar,.mobile-header,.btn,.pagination,.filters-container{display:none!important}.app-main{margin-left:0!important}.main-content{padding:0!important}body{background:#fff}.card{box-shadow:none;border:1px solid #ddd}}
