:root{--blue900:#042c53;--blue800:#0c447c;--blue600:#185fa5;--blue400:#378add;--blue200:#85b7eb;--blue100:#b5d4f4;--blue50:#e6f1fb;--teal800:#085041;--teal400:#1d9e75;--teal50:#e1f5ee;--purple800:#3c3489;--purple600:#534ab7;--purple50:#eeedfe;--green800:#27500a;--green600:#3b6d11;--green400:#639922;--green50:#eaf3de;--red800:#7a1f1f;--red600:#a32d2d;--red50:#fcebeb;--amber800:#633806;--amber600:#854f0b;--amber400:#ba7517;--amber50:#faeeda;--gray800:#444441;--gray600:#5f5e5a;--gray400:#888780;--gray100:#d3d1c7;--gray50:#f1efe8;--bg:#f8f8f7;--surface:#fff;--border:#e4e3dc;--color-primary:var(--blue600);--color-primary-dark:var(--blue800);--color-text:var(--gray800);--color-text-muted:var(--gray600);--color-border:var(--border);--color-surface:var(--surface);--color-bg:var(--bg);--r-sm:8px;--r-md:12px;--r-lg:16px;--r-pill:100px;--shadow-xs:0 1px 3px #042c530f, 0 0 0 1px #042c5308;--shadow-sm:0 2px 8px #042c5317, 0 0 0 1px #042c530a;--shadow-md:0 6px 20px #042c531a, 0 2px 6px #042c530f;--t:.15s ease;--t-spring:.22s cubic-bezier(.16,1,.3,1)}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html,body{height:100%}body{background:var(--bg);color:var(--gray800);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:15px;line-height:1.4}#app{background:var(--bg);min-height:100%}a{color:inherit;text-decoration:none}.hidden{display:none!important}svg{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:20px;height:20px}.btn-primary{border-radius:var(--r-md);background:linear-gradient(135deg, var(--blue600) 0%, var(--blue800) 100%);color:#fff;cursor:pointer;width:100%;height:50px;transition:transform var(--t), box-shadow var(--t), opacity var(--t);letter-spacing:.01em;border:none;justify-content:center;align-items:center;font-size:15px;font-weight:600;display:flex;box-shadow:0 3px 10px #185fa552}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 5px 16px #185fa561}.btn-primary:active{transform:translateY(0);box-shadow:0 1px 4px #185fa533}.btn-primary:disabled{opacity:.65;cursor:default;box-shadow:none;transform:none}.link-btn{color:var(--blue600);cursor:pointer;transition:color var(--t);background:0 0;border:none;padding:8px;font-size:13px;font-weight:500}.link-btn:hover{color:var(--blue800)}.spinner{border:2.5px solid var(--blue100);border-top-color:var(--blue600);border-radius:50%;width:30px;height:30px;animation:.75s linear infinite spin}.spinner-sm{border-width:2px;border-color:#fff #ffffff4d #ffffff4d;width:18px;height:18px}@keyframes spin{to{transform:rotate(360deg)}}.boot-loading{justify-content:center;align-items:center;min-height:100vh;display:flex}.hp-field{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute;left:-9999px}.login-wrap{background:linear-gradient(160deg, var(--blue50) 0%, var(--bg) 55%);min-height:100dvh;display:flex}.login-card{text-align:center;min-height:100dvh;box-shadow:none;padding:40px 24px calc(40px + env(safe-area-inset-bottom));background:0 0;border:none;border-radius:0;flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.login-logo{object-fit:contain;width:150px;height:72px}.login-sub{color:var(--gray600);margin-top:10px;font-size:14px}.login-form{text-align:left;flex-direction:column;gap:12px;width:100%;max-width:360px;margin-top:36px;display:flex}.field{align-items:center;display:flex;position:relative}.field-icon{color:var(--gray400);pointer-events:none;transition:color var(--t);display:flex;position:absolute;left:14px}.field-icon svg{width:18px;height:18px}.field input{border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--bg);width:100%;height:50px;color:var(--gray800);transition:border-color var(--t), box-shadow var(--t), background var(--t);outline:none;padding:0 44px;font-size:15px}.field input:focus{border-color:var(--blue600);background:var(--surface);box-shadow:0 0 0 3px var(--blue50)}.field:focus-within .field-icon{color:var(--blue600)}.field-eye{color:var(--gray400);cursor:pointer;transition:color var(--t);background:0 0;border:none;padding:8px;display:flex;position:absolute;right:8px}.field-eye svg{width:18px;height:18px}.field-eye:hover{color:var(--gray800)}.login-error{border-radius:var(--r-md);background:var(--red50);color:var(--red600);border:1px solid #a32d2d2e;align-items:center;gap:8px;padding:10px 14px;font-size:13px;font-weight:500;display:flex}.login-error svg{flex-shrink:0;width:16px;height:16px}.shell{flex-direction:column;min-height:100vh;padding-bottom:64px;display:flex}.shell-body{flex:1;min-width:0}.side-nav{display:none}.content{display:block}.bottom-nav{background:var(--surface);border-top:1px solid var(--border);z-index:20;max-width:560px;height:64px;padding-bottom:env(safe-area-inset-bottom,0px);grid-auto-columns:1fr;grid-auto-flow:column;margin:0 auto;display:grid;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 14px #042c5312}.nav-item{cursor:pointer;color:var(--gray400);transition:color var(--t);background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:3px;font-size:11px;font-weight:500;display:flex;position:relative}.nav-item svg{width:22px;height:22px;transition:transform var(--t-spring)}.nav-item.router-link-active{color:var(--blue600)}.nav-item.router-link-active svg{transform:scale(1.08)}.nav-item.router-link-active:before{content:"";border-radius:var(--r-pill);background:var(--blue50);width:40px;height:30px;position:absolute;top:6px}.nav-item.router-link-active svg,.nav-item.router-link-active span{z-index:1;position:relative}.hero{background:linear-gradient(135deg, var(--blue900) 0%, var(--blue600) 100%);color:#fff;padding:46px 20px 22px}.hero-nome{letter-spacing:-.01em;font-size:20px;font-weight:700}.hero-data{color:var(--blue200);margin-top:3px;font-size:13px}.appbar{background:linear-gradient(135deg, var(--blue800) 0%, var(--blue600) 100%);color:#fff;align-items:center;gap:4px;height:56px;padding:0 12px 0 16px;display:flex;box-shadow:0 2px 10px #042c5338}.appbar h2{letter-spacing:-.01em;font-size:17px;font-weight:600}.appbar-back{color:#fff;cursor:pointer;border-radius:var(--r-sm);transition:background var(--t);background:0 0;border:none;padding:8px;display:flex}.appbar-back:hover{background:#ffffff26}.page-body{padding:20px}.page-header{color:var(--gray800);padding:20px 16px 12px;font-size:20px;font-weight:700}.gap{height:16px}.gap-lg{height:24px}.section-label{color:var(--gray600);letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px;font-size:11px;font-weight:700}.card-pad,.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-xs);padding:16px}.center-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 24px;display:flex}.center-state .big-icon{width:44px;height:44px;color:var(--gray400)}.state-text{color:var(--gray600);font-size:14px}.state-text.muted{color:var(--gray400)}.state-empty{text-align:center;color:var(--gray400);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:48px 24px;display:flex}.state-empty svg{stroke:currentColor;fill:none;stroke-width:1.4px;opacity:.5;width:48px;height:48px}.stat-grid{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;box-shadow:var(--shadow-xs);transition:transform var(--t), box-shadow var(--t);padding:16px}.stat-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.stat-full{margin-bottom:0}.stat-top{justify-content:space-between;align-items:flex-start;display:flex}.stat-value{letter-spacing:-.02em;font-size:32px;font-weight:700;line-height:1}.stat-label{color:var(--gray600);margin-top:5px;font-size:12px;font-weight:500}.stat-arrow svg{width:14px;height:14px;color:var(--gray400);stroke-width:2.5px}.stat-blue{color:var(--blue600)}.stat-amber{color:var(--amber600)}.stat-green{color:var(--green600)}.stat-red{color:var(--red600)}.list-tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;box-shadow:var(--shadow-xs);transition:transform var(--t), box-shadow var(--t), border-color var(--t);align-items:center;gap:12px;margin-bottom:8px;padding:14px;display:flex}.list-tile:hover{box-shadow:var(--shadow-sm);border-color:var(--blue200);transform:translateY(-1px)}.list-tile:active{box-shadow:var(--shadow-xs);transform:translateY(0)}.tile-main{flex:1;min-width:0}.tile-title{font-size:14px;font-weight:500}.tile-sub{color:var(--gray600);margin-top:3px;font-size:12px}.tile-sub2{color:var(--gray400);margin-top:2px;font-size:11px}.dot{border-radius:50%;flex:none;width:9px;height:9px}.dot-amber{background:var(--amber400)}.dot-blue{background:var(--blue400)}.dot-green{background:var(--green400)}.dot-purple{background:var(--purple600)}.dot-teal{background:var(--teal400)}.dot-red{background:var(--red600)}.badge{border-radius:var(--r-pill);white-space:nowrap;letter-spacing:.01em;padding:4px 10px;font-size:12px;font-weight:600}.badge-obra-preparado{background:var(--amber50);color:var(--amber800);border:1px solid #ba751733}.badge-obra-producao{background:var(--blue50);color:var(--blue800);border:1px solid #378add33}.badge-obra-pronta{background:var(--green50);color:var(--green800);border:1px solid #63992233}.badge-pedido-criado{background:var(--purple50);color:var(--purple800);border:1px solid #534ab733}.badge-pedido-confirmado{background:var(--teal50);color:var(--teal800);border:1px solid #1d9e7533}.atraso-badge{background:var(--red50);color:var(--red600);border-radius:var(--r-sm);white-space:nowrap;border:1px solid #a32d2d2e;padding:4px 8px;font-size:11px;font-weight:600}.atraso-inline{background:var(--red50);color:var(--red600);border:1px solid #a32d2d26;border-radius:4px;margin-top:4px;padding:2px 7px;font-size:11px;font-weight:600;display:inline-block}.atraso-banner{background:var(--red50);color:var(--red600);border-radius:var(--r-sm);border:1px solid #a32d2d47;align-items:center;gap:8px;margin:10px 0 0;padding:10px 14px;font-size:13px;font-weight:600;display:flex}.atraso-banner svg{flex-shrink:0;width:16px;height:16px}.search-area{background:var(--surface);border-bottom:1px solid var(--border);padding:12px 16px}.search-box{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-md);transition:border-color var(--t), box-shadow var(--t);align-items:center;gap:8px;padding:0 12px;display:flex}.search-box:focus-within{border-color:var(--blue600);box-shadow:0 0 0 3px var(--blue50)}.search-box svg{width:18px;height:18px;color:var(--gray400);transition:color var(--t)}.search-box:focus-within svg{color:var(--blue600)}.search-box input{height:42px;color:var(--gray800);background:0 0;border:none;outline:none;flex:1;font-size:14px}.search-box input::placeholder{color:var(--gray400)}.chips{scrollbar-width:none;gap:6px;margin-top:10px;display:flex;overflow-x:auto}.chips::-webkit-scrollbar{display:none}.chip{white-space:nowrap;border:1.5px solid var(--border);border-radius:var(--r-pill);background:var(--surface);color:var(--gray600);cursor:pointer;transition:border-color var(--t), color var(--t), background var(--t), box-shadow var(--t);flex-shrink:0;padding:6px 14px;font-size:13px;font-weight:500}.chip:not(.chip-active):hover{border-color:var(--blue200);color:var(--blue600)}.chip-active{color:#fff;background:var(--blue600);border-color:#0000;box-shadow:0 2px 7px #185fa547}.chip-active.chip-amber{background:var(--amber600);box-shadow:0 2px 7px #854f0b38}.chip-active.chip-blue{background:var(--blue600);box-shadow:0 2px 7px #185fa547}.chip-active.chip-green{background:var(--green600);box-shadow:0 2px 7px #3b6d1138}.chip-active.chip-purple{background:var(--purple600);box-shadow:0 2px 7px #534ab738}.chip-active.chip-teal{background:var(--teal400);box-shadow:0 2px 7px #1d9e7538}.chip-active.chip-red{background:var(--red600);box-shadow:0 2px 7px #a32d2d38}.info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-xs);overflow:hidden}.info-row{border-bottom:1px solid var(--border);transition:background var(--t);justify-content:space-between;align-items:center;gap:12px;padding:13px 16px;display:flex}.info-row:hover{background:var(--gray50)}.info-row-last{border-bottom:none}.info-key{color:var(--gray600);align-items:center;gap:8px;font-size:13px;display:flex}.info-key svg{width:18px;height:18px;color:var(--gray400)}.info-val{text-align:right;color:var(--gray800);font-size:13px;font-weight:600}.detail{background:var(--bg);flex-direction:column;min-height:100%;display:flex}.detail>.appbar{z-index:10;flex-shrink:0;width:100%;position:sticky;top:0}.detail-body{flex:1}.detail-inner{max-width:680px;margin:0 auto;padding:24px 20px}.detail-hero{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);flex-direction:column;margin-bottom:20px;display:flex;overflow:hidden}.detail-hero:before{content:"";background:linear-gradient(90deg, var(--teal400) 0%, var(--teal50) 100%);height:3px;display:block}.detail-hero-top{justify-content:space-between;align-items:center;gap:12px;padding:18px 20px 14px;display:flex}.detail-hero-name{color:var(--gray800);letter-spacing:-.03em;flex:1;font-size:20px;font-weight:700;line-height:1.2}.detail-hero-divider{background:var(--border);height:1px;margin:0 20px}.detail-hero-meta{flex-wrap:wrap;align-items:stretch;gap:0;padding:14px 20px 18px;display:flex}.detail-hero-kv{border-right:1px solid var(--border);flex-direction:column;flex:1;gap:5px;min-width:80px;margin:0 20px 0 0;padding:0 20px 0 0;display:flex}.detail-hero-kv:last-child{border-right:none;margin-right:0;padding-right:0}.detail-hero-kv span:first-child{color:var(--gray400);text-transform:uppercase;letter-spacing:.09em;font-size:10px;font-weight:700}.detail-hero-kv span:last-child{color:var(--gray800);font-size:14px;font-weight:600}.detail-hero-kv span.detail-hero-importe{color:var(--teal400);letter-spacing:-.03em;font-size:20px;font-weight:700}.detail-section{margin-bottom:20px}.detail-section:last-child{margin-bottom:0}.timeline{flex-direction:column;display:flex}.tl-row{gap:14px;display:flex}.tl-gutter{flex-direction:column;align-items:center;width:28px;padding-top:2px;display:flex}.tl-dot{border-radius:50%;flex:none;justify-content:center;align-items:center;width:16px;height:16px;display:flex}.tl-dot-done{background:var(--teal400);box-shadow:0 0 0 3px var(--teal50)}.tl-dot-active{background:var(--blue600);box-shadow:0 0 0 3px var(--blue50), 0 0 0 5px var(--blue100)}.tl-dot-pending{background:var(--surface);border:2px solid var(--gray100)}.tl-line{background:var(--border);border-radius:2px;flex:1;width:2px;min-height:36px}.tl-content{flex:1;padding-bottom:18px}.tl-content.tl-last{padding-bottom:0}.tl-label{font-size:14px;font-weight:500;line-height:1.3}.tl-label-done{color:var(--gray800)}.tl-label-active{color:var(--blue600);font-weight:600}.tl-label-pending{color:var(--gray400);font-weight:400}.tl-date{color:var(--gray400);margin-top:3px;font-size:12px}.perfil{flex-direction:column;align-items:center;display:flex}.avatar{background:linear-gradient(135deg, var(--blue600) 0%, var(--blue400) 100%);border:3px solid var(--surface);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin-top:12px;font-size:30px;font-weight:700;display:flex;position:relative;box-shadow:0 4px 18px #185fa552}.avatar-cam{background:var(--blue800);border:2px solid var(--bg);border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;display:flex;position:absolute;bottom:-1px;right:-3px}.avatar-cam svg{color:#fff;width:12px;height:12px}.perfil-nome{letter-spacing:-.01em;margin-top:14px;font-size:20px;font-weight:700}.perfil-email{color:var(--gray600);margin-top:4px;font-size:14px}.perfil .info-card,.perfil .logout-btn{width:100%}.switch{width:42px;height:24px;display:inline-block;position:relative}.switch input{display:none}.slider{background:var(--gray100);border-radius:24px;transition:all .2s;position:absolute;inset:0}.slider:before{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:all .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #0003}.switch input:checked+.slider{background:var(--blue600)}.switch input:checked+.slider:before{transform:translate(18px)}.logout-btn{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);width:100%;color:var(--red600);cursor:pointer;box-shadow:var(--shadow-xs);transition:background var(--t), border-color var(--t);justify-content:center;align-items:center;gap:8px;padding:14px;font-size:14px;font-weight:600;display:flex}.logout-btn:hover{background:var(--red50);border-color:#a32d2d38}.logout-btn svg{width:18px;height:18px}.perfil-ver{color:var(--gray400);margin-top:32px;font-size:12px}@media (width>=768px){.shell{flex-direction:row;padding-bottom:0}.side-nav{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:240px;height:100vh;display:flex;position:sticky;top:0;overflow-y:auto;box-shadow:2px 0 20px #042c530f}.side-logo{border-bottom:1px solid var(--border);flex-direction:column;align-items:flex-start;margin-bottom:8px;padding:24px 20px 18px;display:flex}.side-logo img{object-fit:contain;width:116px;height:auto}.side-logo-sub{letter-spacing:.1em;text-transform:uppercase;color:var(--blue600);opacity:.75;margin-top:6px;font-size:10px;font-weight:700}.side-nav .nav-item{border-radius:var(--r-md);color:var(--gray600);text-align:left;width:calc(100% - 20px);transition:background var(--t), color var(--t), box-shadow var(--t);flex-direction:row;justify-content:flex-start;gap:12px;margin:2px 10px;padding:11px 14px;font-size:14px;font-weight:500}.side-nav .nav-item:before{display:none}.side-nav .nav-item span{font-size:14px;font-weight:inherit}.side-nav .nav-item svg{stroke-width:1.8px;flex-shrink:0;width:20px;height:20px}.side-nav .nav-item:hover:not(.router-link-active){background:var(--gray50);color:var(--gray800)}.side-nav .nav-item.router-link-active{background:var(--blue600);color:#fff;font-weight:600;box-shadow:0 3px 12px #185fa54d}.side-nav .nav-item.router-link-active svg{stroke-width:2px;transform:none}.side-user{border-top:1px solid var(--border);align-items:center;gap:10px;margin-top:auto;padding:14px 12px;display:flex}.side-user-avatar{background:var(--blue50);width:36px;height:36px;color:var(--blue600);letter-spacing:-.01em;border:1.5px solid var(--blue100);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.side-user-name{color:var(--gray800);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;line-height:1.3;overflow:hidden}.side-user-role{color:var(--gray400);margin-top:1px;font-size:11px}.bottom-nav{display:none}.shell-body{flex:1;min-height:100vh}.hero{padding-top:28px}.detail-inner{grid-template-columns:1fr 1fr;align-items:start;column-gap:24px;max-width:1100px;padding:28px 32px;display:grid}.detail-hero,.detail-section:only-child{grid-column:1/-1}}
