:root{font-family:Avenir Next,Segoe UI,sans-serif;color:#e2e8f0;background:#171a1f}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:#171a1f}button,input{font:inherit}.topbar{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#090b0ff0;border-bottom:1px solid rgba(148,163,184,.15)}.topbar.compact{padding:.45rem .7rem;margin-bottom:.75rem;border-radius:10px}.topbar-right{flex-wrap:wrap;justify-content:flex-end}.user-session{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.logged-in-label{font-size:.8rem;color:#cbd5e1}.lang-select{border-radius:8px;border:1px solid rgba(148,163,184,.25);background:#12151cf2;color:#e2e8f0;padding:.35rem .55rem}.topbar-pill{display:inline-flex;align-items:center;border-radius:999px;padding:.3rem .7rem;font-size:.85rem;font-weight:700;color:#dbeafe;border:1px solid rgba(96,165,250,.45);background:#1e3a8a47;white-space:nowrap}.celebrate-pill{animation:celebrate-pulse 1s ease-in-out infinite}.after-hours-note{color:#fcd34d;font-weight:700;font-size:.9rem}.container{padding:1rem 1rem 4.5rem}.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.card{background:#181c23e6;border:1px solid rgba(148,163,184,.18);border-radius:14px;padding:1rem}.customer-prominent{margin-top:.25rem;margin-bottom:.45rem;font-size:1.3rem}.tile-top{display:flex;align-items:flex-start;gap:.8rem}.material-prominent{margin:.2rem 0 0;font-size:1.05rem}.quantity-prominent{margin:.25rem 0 .6rem;font-size:1.15rem;font-weight:700}.status-stack{margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;gap:.4rem}.facility-chip{min-width:126px;border-radius:10px;padding:.35rem .5rem;display:flex;flex-direction:column;align-items:flex-end;gap:.1rem;border:1px solid transparent}.facility-chip span{font-size:.72rem;opacity:.92}.facility-chip strong{font-size:.95rem}.facility-good{background:#1665343d;border-color:#22c55e73;color:#86efac}.facility-warn{background:#a1620733;border-color:#f59e0b73;color:#fcd34d}.facility-bad{background:#7f1d1d38;border-color:#f8717173;color:#fca5a5;animation:facility-alert 1.8s ease-in-out infinite}.truck-card{position:relative;overflow:hidden}.truck-card.dismissing{filter:grayscale(.45);opacity:.72}.truck-card.external-loaded{filter:grayscale(.75);opacity:.48;border-color:#fbbf24a6;box-shadow:0 0 0 2px #fbbf2447 inset;transition:filter .6s ease,opacity .6s ease,box-shadow .6s ease}.truck-card.voided-removing{border-color:#f87171bf}.voided-x{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:clamp(2.2rem,8vw,4rem);font-weight:900;color:#f87171c7;text-shadow:0 0 10px rgba(127,29,29,.7);letter-spacing:.12em;animation:voided-pop .45s ease;pointer-events:none}@keyframes voided-pop{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.row{display:flex;align-items:center;gap:.75rem}.between{justify-content:space-between}button{background:#f59e0b;color:#0f1115;border:none;border-radius:10px;padding:.6rem .9rem;cursor:pointer;font-weight:700}button:disabled{opacity:.55}.ghost-btn{background:#3a4352d9;color:#e2e8f0;border:1px solid rgba(148,163,184,.2)}.card-actions{display:flex;gap:.5rem;flex-wrap:wrap}input{width:100%;margin:.75rem 0;padding:.6rem;border-radius:10px;border:1px solid rgba(148,163,184,.25);background:#12151cf2;color:#e2e8f0}.badge{padding:.2rem .5rem;border-radius:8px;font-size:.8rem;text-transform:uppercase}.badge-waiting,.badge-loading{background:#444d5e}.badge-loaded{background:#166534}.badge-canceled{background:#7f1d1d}.status.ok{color:#86efac}.status.offline{color:#fca5a5}.truck-photo{width:100%;border-radius:8px;border:1px solid rgba(148,163,184,.3)}.error{color:#fca5a5}.dismiss-progress-wrap{margin-top:.75rem;font-size:.85rem;color:#cbd5e1}.dismiss-progress{margin-top:.35rem;height:6px;border-radius:999px;background:#94a3b840;position:relative;overflow:hidden}.dismiss-progress:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;width:0%;background:linear-gradient(90deg,#fde68a,#f59e0b);animation:dismiss-sweep 5s linear forwards}@keyframes dismiss-sweep{0%{width:0%}to{width:100%}}.dashboard-top{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.8rem .9rem;margin-bottom:.9rem;border:1px solid rgba(148,163,184,.16);border-radius:12px;background:#0e1117e0}.status-pill{padding:.2rem .5rem;border-radius:999px;font-weight:700;font-size:.75rem;border:1px solid rgba(148,163,184,.25)}.status-pill.ok{color:#86efac;border-color:#86efac66}.status-pill.offline{color:#fca5a5;border-color:#fca5a566}.tabs{display:flex;justify-content:space-between;gap:.75rem;margin-bottom:1rem;padding:.55rem;border-radius:12px;border:1px solid rgba(148,163,184,.2);background:#0e1117e0}.tabs-left{display:flex;gap:.5rem}.tabs-right{margin-left:auto;align-items:center;gap:.6rem}.area-chip-row{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:.9rem}.chip{background:#1e242eeb;color:#dbe3ee;border:1px solid rgba(148,163,184,.18);border-radius:999px;padding:.35rem .75rem;font-size:.85rem}.chip.active{background:#f59e0b;color:#0f1115}.tab{background:#1e242eeb;color:#dbe3ee;border:1px solid rgba(148,163,184,.18)}.tab.active{background:#f59e0b;color:#0f1115}.refresh-btn{display:inline-flex;align-items:center;gap:.45rem}.cooldown-ring{width:20px;height:20px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:#0f1115;background:radial-gradient(circle closest-side,#f59e0b 70%,transparent 72%),conic-gradient(#0f1115 var(--cooldown-progress, 0%),rgba(15,17,21,.15) 0)}.api-card{max-width:560px}.warning-banner{margin:0 0 .8rem;padding:.55rem .7rem;border-radius:8px;border:1px solid rgba(245,158,11,.5);color:#fcd34d;background:#5c3d1252}.all-trucks-list{overflow-x:auto}.all-tickets-table{width:100%;border-collapse:collapse;table-layout:fixed}.all-tickets-table th{text-align:left;font-size:.85rem;opacity:.86;padding:.25rem .35rem;border-bottom:1px solid rgba(148,163,184,.16)}.all-tickets-table td{padding:.45rem .35rem;border-top:1px solid rgba(148,163,184,.12);vertical-align:top}.all-tickets-table th:nth-child(1),.all-tickets-table td:nth-child(1){width:9%}.all-tickets-table th:nth-child(2),.all-tickets-table td:nth-child(2){width:11%}.all-tickets-table th:nth-child(3),.all-tickets-table td:nth-child(3){width:16%}.all-tickets-table th:nth-child(4),.all-tickets-table td:nth-child(4){width:13%}.all-tickets-table th:nth-child(5),.all-tickets-table td:nth-child(5){width:19%}.all-tickets-table th:nth-child(6),.all-tickets-table td:nth-child(6){width:11%}.all-tickets-table th:nth-child(7),.all-tickets-table td:nth-child(7){width:10%;text-transform:capitalize}.all-tickets-table th:nth-child(8),.all-tickets-table td:nth-child(8){width:11%;text-align:right}.loaded-tickets-table th:nth-child(1),.loaded-tickets-table td:nth-child(1){width:10%}.loaded-tickets-table th:nth-child(2),.loaded-tickets-table td:nth-child(2){width:11%}.loaded-tickets-table th:nth-child(3),.loaded-tickets-table td:nth-child(3){width:17%}.loaded-tickets-table th:nth-child(4),.loaded-tickets-table td:nth-child(4){width:13%}.loaded-tickets-table th:nth-child(5),.loaded-tickets-table td:nth-child(5){width:20%}.loaded-tickets-table th:nth-child(6),.loaded-tickets-table td:nth-child(6){width:11%}.loaded-tickets-table th:nth-child(7),.loaded-tickets-table td:nth-child(7){width:18%;text-align:right}.table-actions{display:inline-flex;gap:.4rem}.weather-layout{display:grid;grid-template-columns:1.4fr .9fr;gap:1rem}.weather-main{display:flex;flex-direction:column;gap:1rem}.weather-current{display:flex;justify-content:space-between;align-items:center;gap:1rem}.weather-location{margin:0;font-size:2.1rem}.weather-subtext{opacity:.8;margin:.2rem 0}.weather-temp{margin:.55rem 0 0;font-size:4rem;font-weight:800;line-height:1}.weather-icon-lg{width:148px;height:148px}.weather-hourly h4,.weather-air h4,.weather-forecast h4{margin:0 0 .75rem;text-transform:uppercase;font-size:.95rem;letter-spacing:.03em;opacity:.92}.weather-hour-row{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:.5rem}.weather-hour{text-align:center}.weather-hour p{margin:0;opacity:.82}.weather-hour img{width:52px;height:52px}.weather-hour strong{font-size:1.4rem}.weather-air-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem 1rem}.weather-air-grid p{margin:0;opacity:.9}.weather-air-grid strong{display:block;margin-top:.1rem;font-size:1.5rem;color:#f8fafc}.weather-daily-list{display:flex;flex-direction:column}.weather-daily-row{display:grid;grid-template-columns:.65fr 56px 1fr auto;align-items:center;gap:.75rem;padding:.65rem 0;border-bottom:1px solid rgba(148,163,184,.12)}.weather-daily-row img{width:50px;height:50px}.admin-layout{display:flex;flex-direction:column;gap:.8rem}.admin-section-nav{display:flex;flex-wrap:wrap;gap:.5rem}.admin-card{width:100%}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{text-align:left;padding:.35rem .2rem;border-top:1px solid rgba(148,163,184,.12);vertical-align:top}.admin-table td button+button{margin-left:.35rem}.external-loaded-text{margin-top:.45rem;color:#fde68a;font-weight:800}.external-loaded-banner{position:absolute;top:.55rem;right:.55rem;border-radius:999px;padding:.25rem .55rem;font-size:.74rem;font-weight:800;color:#111827;background:#fbbf24;box-shadow:0 0 0 1px #0f172a66;animation:external-loaded-pulse 1.1s ease-in-out infinite}.admin-form-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.45rem;margin-bottom:.6rem}.item-code-form{grid-template-columns:1.2fr 1fr 1fr auto}.item-code-filters{grid-template-columns:.9fr .9fr 1.2fr auto auto;align-items:center}.item-code-bulk-row{grid-template-columns:auto auto 1fr 1fr auto auto;align-items:center}.checkbox-inline{display:inline-flex;align-items:center;gap:.4rem;font-size:.9rem}.checkbox-inline input,.admin-table input[type=checkbox]{width:auto;margin:0}.admin-helper-text{opacity:.78;font-size:.92rem}.admin-form-col{display:flex;flex-direction:column;gap:.45rem}.admin-table-wrap{overflow:auto;max-height:52vh;border:1px solid rgba(148,163,184,.12);border-radius:10px}.admin-table-wrap .admin-table th{position:sticky;top:0;background:#171c24;z-index:1}.admin-pager{display:flex;align-items:center;justify-content:flex-end;gap:.6rem;margin-top:.6rem}.kpi-row{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:.7rem}.kpi-chip{border:1px solid rgba(148,163,184,.25);background:#1e242ed9;border-radius:999px;padding:.25rem .6rem;font-size:.85rem;font-weight:700}@keyframes celebrate-pulse{0%{transform:scale(1);box-shadow:0 0 #f59e0b8c}50%{transform:scale(1.04);box-shadow:0 0 0 8px #f59e0b14}to{transform:scale(1);box-shadow:0 0 #f59e0b00}}@keyframes external-loaded-pulse{0%{transform:scale(1);opacity:.95}50%{transform:scale(1.04);opacity:1}to{transform:scale(1);opacity:.95}}.stale-text{color:#fca5a5;font-weight:700}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000ad;display:flex;align-items:center;justify-content:center;z-index:999;padding:1rem}.modal{width:min(980px,100%);max-height:88vh;overflow:auto;border-radius:12px;border:1px solid rgba(148,163,184,.2);background:#171c24;padding:1rem}.modal-header{margin-bottom:.8rem}.operator-highlight{margin:.2rem 0 0;font-size:1.05rem;font-weight:700;color:#f8fafc}.close-lg{font-size:1.2rem;padding:.75rem 1rem}.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem 1rem;margin-bottom:1rem}.detail-row{display:flex;justify-content:space-between;gap:.75rem;border-bottom:1px solid rgba(148,163,184,.1);padding:.35rem 0}.detail-photo-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.detail-top-layout{display:grid;grid-template-columns:1.2fr 1fr;gap:1rem}.detail-left,.detail-right{min-width:0}.detail-grid-single{grid-template-columns:1fr}.detail-divider{border:0;border-top:1px solid rgba(148,163,184,.24);margin:.7rem 0 .9rem}.clickable-photo{cursor:zoom-in}.detail-section{margin-bottom:1rem}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;background:#000000e0;display:flex;align-items:center;justify-content:center;padding:1rem}.lightbox-image{max-width:96vw;max-height:92vh;border-radius:10px}.bottom-bar{position:fixed;left:0;right:0;bottom:0;z-index:20;display:flex;justify-content:space-between;align-items:center;gap:.25rem;min-height:44px;padding:.55rem 1rem;background:#080a0ef5;border-top:1px solid rgba(148,163,184,.2);color:#d1d5db}.bottom-bar-spacer{min-width:90px}.bottom-bar-text{flex:1;text-align:center}.footer-api-link{min-width:90px;padding:.35rem .6rem;border-radius:8px;border:1px solid rgba(148,163,184,.2);background:#1e242eeb;color:#dbe3ee;font-weight:700}@keyframes facility-alert{0%,to{filter:brightness(1)}50%{filter:brightness(1.16)}}@media(max-width:700px){.topbar{flex-direction:column;align-items:flex-start;gap:.75rem}.dashboard-top{flex-direction:column;align-items:flex-start}.grid{grid-template-columns:1fr}.tabs{flex-direction:column}.tabs-left{width:100%}.tabs-right{margin-left:0;width:100%;justify-content:flex-end;flex-wrap:wrap}.detail-top-layout{grid-template-columns:1fr}.all-tickets-table{min-width:980px}.weather-layout,.admin-layout{grid-template-columns:1fr}.weather-hour-row{grid-template-columns:repeat(3,minmax(0,1fr))}.detail-grid,.detail-photo-grid{grid-template-columns:1fr}}@media(max-width:640px){.container{padding-bottom:1rem}.bottom-bar{display:none}}
