
:root{--bg:#f1f6f3;--ink:#102a24;--ink2:#245347;--muted:#6a817a;--line:#dbe8e1;--line2:#c6dbd0;--white:#fff;--brand:#008c52;--brand2:#00b86b;--gold:#f7c928;--blue:#0a4ca3;--danger:#a83232;--shadow:0 22px 55px rgba(3,47,37,.14);--shadow2:0 12px 28px rgba(3,47,37,.09)}
*{box-sizing:border-box}html{scroll-behavior:smooth;overflow-x:hidden;-webkit-text-size-adjust:100%}body{margin:0;min-width:0;overflow-x:hidden;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);background:radial-gradient(circle at 90% 2%,rgba(247,201,40,.18),transparent 25%),radial-gradient(circle at 5% 18%,rgba(0,140,82,.12),transparent 28%),linear-gradient(180deg,#f8fbf9,#edf5f1)}
button,input,select{font:inherit;min-height:44px}button{cursor:pointer;touch-action:manipulation}.container{max-width:1500px;margin:auto;padding:20px 20px 42px;min-width:0}.hidden{display:none!important}
.topbar{background:linear-gradient(135deg,#022f24,#075d43 58%,#073d6c);color:#fff;border-radius:24px;padding:18px 24px;display:flex;justify-content:space-between;align-items:center;gap:16px;box-shadow:var(--shadow);position:sticky;top:12px;z-index:50}.brand{display:flex;align-items:center;gap:15px;min-width:0}.brand-mark{width:58px;height:58px;border-radius:20px;display:grid;place-items:center;flex:0 0 auto;font-weight:1000;font-size:22px;background:linear-gradient(145deg,#ffea78,#f7c928 55%,#dfa500);color:#083a2c;box-shadow:inset 0 1px 0 rgba(255,255,255,.55),0 10px 28px rgba(0,0,0,.18)}.brand h1{margin:0;font-size:21px}.brand small{display:block;color:#d7f3e7;margin-top:4px}.top-label,.logout{padding:10px 13px;border:1px solid rgba(247,201,40,.3);background:rgba(247,201,40,.14);color:#fff4bd;border-radius:13px;font-size:12px;font-weight:900}.logout{color:#fff;border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.08)}
.cover{margin-top:18px;min-height:315px;border-radius:30px;overflow:hidden;position:relative;background:linear-gradient(90deg,rgba(2,35,28,.95),rgba(2,54,39,.76) 48%,rgba(2,54,39,.12)),url("bandeira-brasil.svg") center/cover no-repeat;color:#fff;padding:44px;display:flex;align-items:center;box-shadow:var(--shadow)}.cover:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.05),transparent 35%,rgba(0,0,0,.15));pointer-events:none}.cover-content{position:relative;z-index:2;max-width:760px}.kicker{display:inline-flex;padding:9px 13px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);font-size:12px;font-weight:900;letter-spacing:.1em}.cover h2{font-size:clamp(34px,4.8vw,58px);line-height:1.03;letter-spacing:-.04em;margin:18px 0 12px}.cover p{font-size:17px;color:#e7f7ef;line-height:1.65;margin:0;max-width:680px}
.panel,.card{background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow2);padding:20px;min-width:0;overflow:hidden}.panel h2,.card h2,.card h3{margin:0 0 14px}.layout{display:grid;grid-template-columns:430px minmax(0,1fr);gap:18px;margin-top:18px}.summary-grid{display:grid;grid-template-columns:1.12fr .88fr;gap:14px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}.field{display:flex;flex-direction:column;gap:7px;min-width:0}.field.full{grid-column:1/-1}label{font-size:11px;font-weight:1000;color:var(--muted);letter-spacing:.04em}input,select{width:100%;padding:12px 13px;border:1px solid var(--line2);border-radius:13px;background:#fbfefc;color:var(--ink);outline:none}input:focus,select:focus{border-color:#56b68a;box-shadow:0 0 0 3px rgba(0,140,82,.1)}
.route-builder{grid-column:1/-1;border:1px solid var(--line);border-radius:17px;background:#f8fcfa;padding:13px}.route-builder summary{cursor:pointer;font-weight:900;color:var(--ink2)}.route-fields{display:grid;gap:8px;margin-top:12px}.stop-row{display:grid;grid-template-columns:34px minmax(0,1fr);gap:8px;align-items:center}.stop-num{width:33px;height:33px;border-radius:10px;display:grid;place-items:center;background:linear-gradient(135deg,var(--brand),var(--blue));color:#fff;font-weight:900}
.btn-row{display:flex;gap:9px;flex-wrap:wrap;margin-top:13px}.btn{border:0;border-radius:13px;padding:12px 15px;font-weight:900;color:#fff;background:linear-gradient(135deg,var(--brand),var(--brand2));box-shadow:0 8px 20px rgba(0,140,82,.18)}.btn.alt{background:#eef7f3;color:#155842;border:1px solid var(--line);box-shadow:none}.btn.danger{background:#9f3535;box-shadow:none}.btn:disabled{opacity:.45}.message{display:none;padding:11px 12px;border-radius:12px;font-size:12px;font-weight:800;margin-top:11px}.message.show{display:block}.message.error{background:#fff0f0;border:1px solid #efc1c1;color:#9d3535}.message.ok{background:#edf9f2;border:1px solid #b8dfc9;color:#146847}
.order-list{display:grid;gap:9px;max-height:420px;overflow:auto;margin-top:14px}.order{padding:12px;border:1px solid var(--line);border-radius:15px;background:#fbfefc;display:flex;justify-content:space-between;gap:10px;align-items:center}.order.active{border-color:#59b98e;box-shadow:0 0 0 3px rgba(0,140,82,.08)}.order b{display:block;font-size:13px;overflow-wrap:anywhere}.order small{color:var(--muted);overflow-wrap:anywhere}.badge{padding:7px 9px;border-radius:999px;font-size:10px;font-weight:1000;background:#eaf3ff;color:#245a9d;text-align:center}.badge.done{background:#e8f8f0;color:#13734d}.badge.fail{background:#ffeded;color:#9d3535}.badge.local{background:#fff4dd;color:#936000}
.kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:11px;margin-bottom:13px}.kpi{background:#fff;border:1px solid var(--line);border-radius:18px;padding:15px;box-shadow:var(--shadow2);position:relative;overflow:hidden}.kpi:before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(var(--brand),var(--gold))}.kpi b{display:block;font-size:23px;margin-bottom:4px}.kpi span{font-size:11px;color:var(--muted)}
.ship-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.code{font-size:27px;font-weight:1000;overflow-wrap:anywhere}.sub{color:var(--muted);font-size:13px}.status{padding:11px 13px;border-radius:14px;background:linear-gradient(135deg,#e8f8f0,#edf5ff);border:1px solid #cce6d8;color:#126143;font-weight:1000;text-align:center;min-width:170px}.identity{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:13px}.identity-item{padding:12px;border:1px solid var(--line);border-radius:15px;background:#fbfefc;min-width:0}.identity-item small{display:block;color:var(--muted);font-size:10px;font-weight:900;margin-bottom:5px;text-transform:uppercase}.identity-item b{font-size:13px;overflow-wrap:anywhere}.progress-row{display:flex;justify-content:space-between;color:var(--muted);font-size:12px;margin:15px 0 7px}.progress{height:10px;border:1px solid var(--line);background:#edf3ef;border-radius:999px;overflow:hidden}.progress span{display:block;height:100%;background:linear-gradient(90deg,var(--brand),var(--brand2),var(--gold));transition:.6s}.pills,.reliability-strip{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.pill,.reliability-item{padding:9px 11px;border:1px solid var(--line);border-radius:999px;background:#f1f8f4;color:#1c5c48;font-size:11px;font-weight:900}.reliability-item.live:before{content:"";display:inline-block;width:8px;height:8px;margin-right:7px;border-radius:50%;background:#00a862;box-shadow:0 0 0 5px rgba(0,168,98,.12)}
.current-box{padding:14px;border-radius:16px;background:linear-gradient(135deg,#f1faf5,#f1f6fc);border:1px solid var(--line);margin-bottom:10px}.current-box small{display:block;color:var(--muted);font-size:10px;font-weight:900;margin-bottom:5px}.current-box b{font-size:14px;overflow-wrap:anywhere}.current-box p{margin:6px 0 0;color:var(--muted);font-size:12px;line-height:1.5}
.timeline{display:grid;gap:10px;max-height:720px;overflow:auto}.event{display:grid;grid-template-columns:34px minmax(0,1fr);gap:10px;opacity:.58}.event.past,.event.current{opacity:1}.event-icon{width:31px;height:31px;border-radius:50%;display:grid;place-items:center;background:#eef5f1;border:2px solid #c5dbd0;color:#2c6552;font-weight:1000}.event.transit .event-icon{background:#eaf3ff;border-color:#b8d4f4;color:#245d9f}.event.failed .event-icon{background:#ffeded;border-color:#f0b6b6;color:#9d3535}.event-body{padding:11px;border:1px solid var(--line);border-radius:15px;background:#fbfefc}.event.current .event-body{border-color:#efc45f;background:#fffaf0}.event-body b{font-size:13px;overflow-wrap:anywhere}.event-body p{margin:5px 0 0;color:var(--muted);font-size:11px;line-height:1.5}.event-meta{display:flex;gap:7px;flex-wrap:wrap;margin-top:8px}.event-meta span{padding:5px 7px;border-radius:8px;background:#eef5f1;font-size:9px;font-weight:900;color:#49685e}
.route-map{height:400px;border:1px solid var(--line);border-radius:22px;overflow:hidden;position:relative;background:linear-gradient(180deg,#fbfefd,#edf6f1)}.grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(3,47,37,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(3,47,37,.05) 1px,transparent 1px);background-size:42px 42px}.route-svg{position:absolute;inset:0;width:100%;height:100%}.route-shadow{fill:none;stroke:#d7e5de;stroke-width:17;stroke-linecap:round}.route-line{fill:none;stroke:url(#routeG);stroke-width:8;stroke-linecap:round;stroke-dasharray:15 13}.marker{position:absolute;width:36px;height:36px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--brand),var(--blue));color:#fff;transform:translate(-50%,-50%);box-shadow:0 0 0 8px rgba(0,140,82,.12),0 12px 25px rgba(3,47,37,.2);z-index:5}.map-label{position:absolute;top:13px;left:13px;background:rgba(255,255,255,.93);border:1px solid var(--line);padding:9px 11px;border-radius:11px;font-size:11px;font-weight:900;z-index:7}.city{position:absolute;transform:translate(-50%,-50%);padding:6px 8px;border-radius:10px;background:#fff;border:1px solid var(--line);font-size:10px;font-weight:900;color:var(--ink2);white-space:nowrap;box-shadow:var(--shadow2)}.city.done{border-color:#72d2a6;color:#087443}.city.current{border-color:#f3c250;color:#7f5700}
.schedule-wrap{overflow:auto;border:1px solid var(--line);border-radius:17px}.schedule{width:100%;border-collapse:collapse;min-width:820px}.schedule th{background:#f0f7f3;color:#3d665a;font-size:10px;text-transform:uppercase;text-align:left;padding:11px;border-bottom:1px solid var(--line)}.schedule td{padding:11px;border-bottom:1px solid #edf2ef;font-size:12px;vertical-align:top;overflow-wrap:anywhere}.schedule tr.current{background:#fff9e9}.schedule tr.done{background:#f5fcf8}.schedule td b{display:block}.schedule td small{color:var(--muted)}
.search-shell,.login-shell{max-width:860px;margin:22px auto 0}.login-shell{max-width:560px}.search-card,.login-card{padding:28px;border-top:5px solid var(--brand)}.login-card{border-top-color:var(--gold)}.search-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px}.search-help{color:var(--muted);font-size:13px;line-height:1.5;margin:8px 0 0}.result-area{display:none;margin-top:18px}.result-area.show{display:block}.not-found{display:none;margin-top:12px;padding:12px;border:1px solid #efc1c1;background:#fff0f0;color:#993838;border-radius:13px}.not-found.show{display:block}
.loading{opacity:.65;pointer-events:none}
@media(max-width:1180px){.layout,.summary-grid{grid-template-columns:1fr}.kpis{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:900px){.container{padding:12px}.topbar{position:relative;top:0;border-radius:20px;padding:14px 16px;flex-direction:column;align-items:flex-start}.brand{gap:11px}.brand-mark{width:48px;height:48px;border-radius:16px;font-size:19px}.brand h1{font-size:17px}.brand small{font-size:10px}.top-label,.logout{width:100%;text-align:center}.cover{min-height:285px;margin-top:12px;padding:28px 22px;border-radius:22px;background-position:60% center}.cover h2{font-size:clamp(31px,9vw,43px)}.cover p{font-size:14px}.layout{display:block;margin-top:13px}.layout>aside{margin-bottom:13px}.panel,.card{padding:16px;border-radius:19px}.form-grid,.identity{grid-template-columns:1fr}.field.full,.route-builder{grid-column:auto}.kpis{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.ship-head{flex-direction:column}.status{width:100%;min-width:0}.pills,.reliability-strip,.btn-row{display:grid;grid-template-columns:1fr}.pill,.reliability-item,.btn-row .btn{width:100%;text-align:center;justify-content:center}.route-map{height:315px}.city{font-size:8px;line-height:1.1;padding:5px 6px;max-width:72px;white-space:normal;text-align:center}.timeline{max-height:none;overflow:visible}.event-meta{display:grid;grid-template-columns:1fr}.schedule-wrap{overflow:visible;border:0}.schedule{min-width:0;display:block}.schedule thead{display:none}.schedule tbody{display:grid;gap:10px}.schedule tr{display:block;border:1px solid var(--line);border-radius:16px;background:#fbfefc;overflow:hidden}.schedule td{display:grid;grid-template-columns:minmax(105px,38%) minmax(0,1fr);gap:10px;width:100%;padding:10px 12px}.schedule td:before{color:var(--muted);font-size:9px;font-weight:1000;text-transform:uppercase}.schedule td:nth-child(1):before{content:"Ponto"}.schedule td:nth-child(2):before{content:"Cidade"}.schedule td:nth-child(3):before{content:"Chegada"}.schedule td:nth-child(4):before{content:"Processamento"}.schedule td:nth-child(5):before{content:"Saída"}.schedule td:nth-child(6):before{content:"Situação"}.search-row{grid-template-columns:1fr}.search-row .btn{width:100%}input,select{font-size:16px}}
@media(max-width:430px){.container{padding:8px}.cover{min-height:250px;padding:23px 17px}.panel,.card{padding:13px}.kpis{grid-template-columns:1fr}.route-map{height:285px}.schedule td{grid-template-columns:92px minmax(0,1fr)}}
