:root{--bg:#f4f7fb;--surface:#fff;--surface-2:#eef4f8;--surface-3:#e7edf3;--line:#d7e0e8;--line-strong:#b9c8d5;--text:#192532;--muted:#66788a;--muted-2:#8da0b1;--teal:#088b86;--teal-soft:#dff7f4;--blue:#2468d2;--blue-soft:#e5efff;--green:#188753;--green-soft:#e5f6ed;--amber:#b86700;--amber-soft:#fff1d6;--red:#c63d45;--red-soft:#ffe7ea;--shadow:0 16px 45px #1c2d401c;--radius:8px;--font:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;color:var(--text);background:var(--bg);font-family:var(--font);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.5}*{box-sizing:border-box}body{overscroll-behavior-x:none;width:100%;min-width:320px;margin:0;overflow-x:hidden}button,input{font:inherit}button{cursor:pointer}button:focus-visible,input:focus-visible{outline-offset:2px;outline:3px solid #2468d23d}h1,h2,h3,p{margin:0}#root{width:100%;min-height:100svh;overflow-x:hidden}.app-shell{background:linear-gradient(90deg, #088b8614, transparent 38%), var(--bg);grid-template-columns:280px minmax(0,1fr);min-height:100svh;display:grid}.loading-shell{grid-template-columns:1fr;place-items:center;display:grid}.loading-mark{width:84px;height:84px;color:var(--teal);background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:50%;place-items:center;display:grid}.sidebar{color:#dce8f2;background:#1f3346;border-right:1px solid #ffffff1f;align-self:start;min-height:100svh;padding:24px 18px;position:sticky;top:0}.brand{border-bottom:1px solid #ffffff24;align-items:center;gap:12px;padding-bottom:24px;display:flex}.brand-mark{border-radius:var(--radius);color:#102436;background:#72d8d0;flex:none;place-items:center;width:44px;height:44px;display:grid}.brand p{color:#8fb0c8;letter-spacing:.08em;font-size:.72rem;font-weight:800}.brand h1{color:#fff;letter-spacing:0;font-size:1.18rem;font-weight:800}.side-section{border-bottom:1px solid #ffffff1f;padding:22px 0}.section-kicker,.eyebrow{color:var(--muted-2);letter-spacing:.08em;text-transform:uppercase;margin-bottom:7px;font-size:.74rem;font-weight:800;display:block}.sidebar .section-kicker{color:#91acc0}.berth-filter{gap:8px;display:grid}.berth-filter button,.status-filter button{border-radius:var(--radius);color:inherit;background:0 0;border:1px solid #0000}.berth-filter button{text-align:left;color:#e6eef5;padding:10px 12px}.berth-filter button:hover,.berth-filter button.active{color:#102436;background:#dff7f4}.source-section,.threshold-section{color:#dbe7f0}.source-mode{border-radius:var(--radius);color:#102436;background:#dff7f4;align-items:center;gap:8px;padding:8px 10px;font-weight:800;display:inline-flex}.source-mode.sample{background:#fff1d6}.source-mode.mixed{background:#e5efff}.source-meta{gap:10px;margin:16px 0 0;display:grid}.source-meta div{justify-content:space-between;gap:12px;font-size:.9rem;display:flex}.source-meta dt{color:#94aec1}.source-meta dd{color:#fff;margin:0;font-weight:700}.threshold-section ul{gap:11px;margin:0;padding:0;list-style:none;display:grid}.threshold-section li{color:#e8f0f7;align-items:center;gap:8px;font-size:.9rem;display:flex}.content{min-width:0;padding:24px}.topbar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.topbar h2{color:var(--text);letter-spacing:0;font-size:1.78rem;font-weight:850;line-height:1.15}.icon-button{border:1px solid var(--line);border-radius:var(--radius);width:42px;height:42px;color:var(--text);background:var(--surface);place-items:center;display:inline-grid;box-shadow:0 4px 16px #1e344614}.icon-button:hover{border-color:var(--line-strong)}.spin{animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.notice{border-radius:var(--radius);color:#6f4300;background:var(--amber-soft);border:1px solid #f0c474;align-items:center;gap:10px;min-height:42px;margin-bottom:16px;padding:10px 12px;display:flex}.metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:18px;display:grid}.metric-card{border-radius:var(--radius);border:1px solid var(--line);background:var(--surface);align-items:flex-start;gap:14px;min-height:116px;padding:18px;display:flex;box-shadow:0 10px 24px #1e344612}.metric-icon{border-radius:var(--radius);place-items:center;width:38px;height:38px;display:grid}.metric-card p{color:var(--muted);font-size:.86rem;font-weight:700}.metric-card strong{color:var(--text);margin:3px 0 2px;font-size:1.72rem;font-weight:850;line-height:1.12;display:block}.metric-card span{color:var(--muted);font-size:.84rem}.metric-card.teal .metric-icon{color:var(--teal);background:var(--teal-soft)}.metric-card.blue .metric-icon{color:var(--blue);background:var(--blue-soft)}.metric-card.green .metric-icon{color:var(--green);background:var(--green-soft)}.metric-card.amber .metric-icon{color:var(--amber);background:var(--amber-soft)}.metric-card.red .metric-icon{color:var(--red);background:var(--red-soft)}.dashboard-grid{grid-template-columns:minmax(0,1.65fr) minmax(320px,.95fr);align-items:start;gap:18px;display:grid}.operations-panel,.weather-panel,.table-panel{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.operations-panel,.table-panel{min-width:0}.operations-panel,.weather-panel{padding:18px}.table-panel{margin-top:18px;padding:18px}.panel-heading{justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:14px;display:flex}.panel-heading.compact{align-items:center}.panel-heading h3{color:var(--text);letter-spacing:0;font-size:1.13rem;font-weight:850}.search-box{min-width:255px;height:40px;color:var(--muted);border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);align-items:center;gap:8px;padding:0 12px;display:flex}.search-box input{width:100%;color:var(--text);background:0 0;border:0;outline:0}.search-box input::placeholder{color:#8b9bad}.status-filter{flex-wrap:wrap;gap:7px;margin-bottom:16px;display:flex}.status-filter button{min-height:34px;color:var(--muted);background:var(--surface-2);border-color:var(--line);padding:6px 11px;font-size:.9rem;font-weight:750}.status-filter button.active,.status-filter button:hover{color:var(--text);border-color:var(--line-strong);background:#fff}.berth-board{cursor:grab;gap:12px;display:grid;position:relative}.berth-board.dragging,.berth-board.dragging *{cursor:grabbing;-webkit-user-select:none;user-select:none}.timeline-summary{border-radius:var(--radius);min-height:34px;color:var(--muted);background:var(--surface-2);border:1px solid var(--line);justify-content:space-between;align-items:center;gap:12px;padding:7px 10px;font-size:.82rem;font-weight:750;display:flex}.timeline-summary strong{color:var(--text);font-size:.84rem}.time-axis{color:var(--muted-2);grid-template-columns:160px minmax(260px,1fr);gap:0;min-height:46px;font-size:.76rem;font-weight:800;display:grid}.time-axis-spacer{border-right:1px solid var(--line)}.timeline-viewport{touch-action:pan-y;min-width:0;position:relative;overflow:hidden}.axis-viewport{border:1px solid var(--line);border-radius:var(--radius);background:#fbfdff;min-height:46px}.timeline-track{height:100%;min-height:inherit;will-change:transform;position:relative}.time-tick{border-left:1px solid #2468d229;min-width:72px;padding:6px 0 0 8px;position:absolute;top:0;bottom:0;transform:translate(-1px)}.time-tick span,.time-tick strong{line-height:1.15;display:block}.time-tick span{color:var(--muted-2);font-size:.7rem}.time-tick strong{color:var(--muted);margin-top:2px;font-size:.8rem}.current-time-line{z-index:3;background:#ef6c45;width:2px;position:absolute;top:0;bottom:0;transform:translate(-1px);box-shadow:0 0 0 1px #ef6c451a}.axis-current span{color:#8e3519;white-space:nowrap;background:#ffe8dd;border-radius:999px;padding:2px 6px;font-size:.7rem;font-weight:850;position:absolute;top:5px;left:6px}.berth-group{gap:10px;display:grid}.group-title{color:var(--muted);align-items:center;gap:7px;font-size:.85rem;font-weight:850;display:flex}.operator-block{gap:5px;display:grid}.operator-title{min-height:28px;color:var(--teal);border-radius:var(--radius);background:#edf8f6;border:1px solid #c7e7e2;align-items:center;padding:4px 12px;font-size:.84rem;font-weight:850;display:flex}.berth-row{min-height:var(--berth-row-height,48px);border:1px solid var(--line);border-radius:var(--radius);background:#fbfdff;grid-template-columns:160px minmax(260px,1fr);display:grid;overflow:hidden}.berth-name{border-right:1px solid var(--line);background:var(--surface-2);align-content:center;padding:10px 12px;display:grid}.berth-name strong{color:var(--text);font-size:.96rem}.berth-name span{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;overflow:hidden}.timeline{min-height:var(--berth-row-height,48px);background:linear-gradient(#fafdff,#f2f7fb);position:relative}.timeline .timeline-track{background:linear-gradient(90deg,#2468d21a 1px,#0000 1px) 0 0/8.3333% 100%,linear-gradient(#fafdff,#f2f7fb)}.waterline{opacity:.7;background:linear-gradient(135deg,#088b8617 25%,#0000 25%) 0 0/18px 18px,linear-gradient(225deg,#088b8612 25%,#0000 25%) 0 0/18px 18px;position:absolute;inset:0}.empty-berth{z-index:4;color:var(--muted-2);pointer-events:none;font-size:.84rem;font-weight:700;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.vessel-marker{--vessel-label-offset:0px;top:calc(7px + (var(--lane-index,0) * 40px));z-index:5;border-radius:var(--radius);white-space:nowrap;text-overflow:ellipsis;appearance:none;cursor:pointer;pointer-events:auto;border:1px solid #0000;align-items:center;gap:7px;min-width:110px;max-width:calc(100% - 12px);height:34px;padding:0 10px;font-size:.82rem;font-weight:850;display:flex;position:absolute;overflow:hidden;box-shadow:0 8px 18px #1e34461f}.vessel-marker-content{min-width:0;max-width:calc(100% - var(--vessel-label-offset));pointer-events:none;transform:translateX(var(--vessel-label-offset));will-change:transform;align-items:center;gap:7px;transition:transform .12s ease-out;display:flex;overflow:hidden}.berth-board.dragging .vessel-marker-content{transition:none}.vessel-marker-content svg{flex:none}.vessel-marker-content span{text-overflow:ellipsis;min-width:0;overflow:hidden}.vessel-marker:hover,.vessel-marker:focus-visible{filter:brightness(.98);outline-offset:2px;outline:2px solid #2468d247}.vessel-popover{z-index:40;border:1px solid var(--line-strong);border-radius:var(--radius);width:260px;color:var(--text);background:#fff;padding:12px;position:absolute;box-shadow:0 18px 42px #1e344638}.vessel-popover>strong{border-bottom:1px solid var(--line);margin-bottom:8px;padding-bottom:8px;font-size:.98rem;font-weight:850;line-height:1.25;display:block}.vessel-popover dl{gap:8px;margin:0;display:grid}.vessel-popover dl div{grid-template-columns:72px minmax(0,1fr);align-items:center;gap:10px;display:grid}.vessel-popover dt{color:var(--muted);font-size:.76rem;font-weight:800}.vessel-popover dd{min-width:0;color:var(--text);overflow-wrap:anywhere;margin:0;font-size:.84rem;font-weight:750}.vessel-popover .status-pill{min-height:24px;padding:3px 8px;font-size:.74rem}.success{color:var(--green);background:var(--green-soft);border-color:#a8dfc2}.info{color:var(--blue);background:var(--blue-soft);border-color:#b9cff7}.warning{color:var(--amber);background:var(--amber-soft);border-color:#edc36f}.danger{color:var(--red);background:var(--red-soft);border-color:#f2afb7}.muted{color:var(--muted);background:var(--surface-2);border-color:var(--line)}.risk-pill,.status-pill{border-radius:var(--radius);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;min-height:28px;padding:4px 10px;font-size:.8rem;font-weight:850;display:inline-flex}.weather-stack{gap:12px;display:grid}.weather-card{border-radius:var(--radius);border:1px solid #0000;padding:14px}.weather-title{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.weather-title strong{color:var(--text);font-size:.98rem;display:block}.weather-title span{color:var(--muted);font-size:.8rem}.weather-measures{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.measure{border-radius:var(--radius);background:#ffffffad;border:1px solid #ffffffd1;grid-template-rows:auto auto;grid-template-columns:20px 1fr;align-items:center;column-gap:8px;min-height:66px;padding:9px;display:grid}.measure svg{grid-row:1/span 2}.measure span{color:var(--muted);font-size:.78rem;font-weight:750}.measure strong{color:var(--text);white-space:nowrap;font-size:.95rem}.weather-foot{color:var(--muted);justify-content:space-between;gap:12px;margin-top:11px;font-size:.82rem;font-weight:700;display:flex}.result-count{min-height:30px;color:var(--muted);background:var(--surface-2);border-radius:var(--radius);padding:4px 10px;font-size:.85rem;font-weight:800}.table-wrap{width:100%;overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:780px}th,td{text-align:left;border-bottom:1px solid var(--line);padding:12px 10px}th{color:var(--muted);background:var(--surface-2);font-size:.78rem;font-weight:850}tbody tr:hover{background:#f8fbfd}.vessel-cell,.berth-cell{gap:2px;display:grid}.vessel-cell strong,.berth-cell strong{color:var(--text);font-size:.9rem}.vessel-cell span,.berth-cell span{color:var(--muted);font-size:.78rem}.empty-state{min-height:86px;color:var(--muted);justify-content:center;align-items:center;gap:8px;font-weight:750;display:flex}.mobile-app{width:100%;max-width:none;min-height:100svh;padding:12px 12px calc(86px + env(safe-area-inset-bottom));overscroll-behavior-x:none;background:linear-gradient(180deg, #088b861f, transparent 280px), var(--bg);margin:0 auto;overflow-x:hidden}.mobile-app.mobile-preview{max-width:480px}.mobile-app.mobile-fluid{min-width:0}.mobile-hero{border-radius:var(--radius);color:#fff;background:#1f3346;justify-content:space-between;align-items:center;gap:12px;padding:14px;display:flex;box-shadow:0 10px 24px #1e344629}.mobile-brand{align-items:center;gap:11px;min-width:0;display:flex}.mobile-brand p{color:#95b4ca;letter-spacing:.08em;font-size:.68rem;font-weight:850}.mobile-brand h1{color:#fff;font-size:1.06rem;font-weight:850;line-height:1.2}.mobile-refresh{border-radius:var(--radius);color:#e7f1f7;background:#ffffff14;border:1px solid #ffffff29;flex:none;place-items:center;width:40px;height:40px;display:grid}.mobile-ad-slot{border-radius:var(--radius);background:linear-gradient(135deg,#088b8614,#2468d20f),#ffffffc7;border:1px solid #8092a438;min-height:58px;margin:10px 0 12px;position:relative;overflow:hidden;box-shadow:0 8px 22px #1e34460f}.mobile-ad-slot:after{content:"AD";color:var(--muted-2);letter-spacing:.08em;font-size:.64rem;font-weight:850;position:absolute;inset:auto 10px 8px auto}.mobile-notice{border-radius:var(--radius);color:#6f4300;background:var(--amber-soft);border:1px solid #f0c474;align-items:center;gap:8px;min-height:40px;margin-bottom:12px;padding:10px 12px;font-size:.82rem;font-weight:750;display:flex}.mobile-content{gap:14px;display:grid}.mobile-app.mobile-screen-berths{flex-direction:column;height:100svh;min-height:0;display:flex;overflow:hidden}.mobile-screen-berths .mobile-content{overscroll-behavior:contain;scrollbar-width:none;flex:1;min-height:0;display:block;overflow:hidden auto}.mobile-screen-berths .mobile-content::-webkit-scrollbar{display:none}.mobile-screen-berths .mobile-section{align-content:start;gap:8px;min-height:100%;display:grid}.mobile-title{margin:6px 0 14px}.mobile-title.compact{margin-top:0}.mobile-title span,.mobile-section-head span{color:var(--muted-2);letter-spacing:.08em;text-transform:uppercase;font-size:.72rem;font-weight:850;display:block}.mobile-title h2{color:var(--text);font-size:1.35rem;font-weight:850;line-height:1.18}.mobile-stat-grid{gap:9px;margin-bottom:14px;display:grid}.mobile-stat-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);align-items:center;gap:12px;min-height:82px;padding:13px;display:flex;box-shadow:0 8px 22px #1e344614}.mobile-stat-icon{border-radius:var(--radius);place-items:center;width:38px;height:38px;display:grid}.mobile-stat-card span{color:var(--muted);font-size:.8rem;font-weight:780}.mobile-stat-card strong{color:var(--text);margin:2px 0;font-size:1.42rem;font-weight:850;line-height:1.08;display:block}.mobile-stat-card small{color:var(--muted);font-size:.76rem;font-weight:700}.mobile-stat-card.teal .mobile-stat-icon{color:var(--teal);background:var(--teal-soft)}.mobile-stat-card.blue .mobile-stat-icon{color:var(--blue);background:var(--blue-soft)}.mobile-stat-card.green .mobile-stat-icon{color:var(--green);background:var(--green-soft)}.mobile-stat-card.amber .mobile-stat-icon{color:var(--amber);background:var(--amber-soft)}.mobile-stat-card.red .mobile-stat-icon{color:var(--red);background:var(--red-soft)}.mobile-quick-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:16px;display:grid}.mobile-quick-grid button{border:1px solid var(--line);border-radius:var(--radius);min-width:0;min-height:92px;color:var(--text);background:var(--surface);align-content:center;justify-items:start;gap:5px;padding:11px;display:grid;box-shadow:0 8px 22px #1e34460f}.mobile-quick-grid svg{color:var(--teal)}.mobile-quick-grid span,.mobile-quick-grid strong{text-overflow:ellipsis;white-space:nowrap;min-width:0;max-width:100%;overflow:hidden}.mobile-quick-grid span{color:var(--muted);font-size:.76rem;font-weight:800}.mobile-quick-grid strong{color:var(--text);font-size:.84rem;font-weight:850}.mobile-section{gap:12px;display:grid}.mobile-section-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.mobile-section-head.inline{justify-content:flex-end;min-height:28px}.mobile-section-head h3{color:var(--text);font-size:1.02rem;font-weight:850}.mobile-section-head button{border:1px solid var(--line);border-radius:var(--radius);min-height:32px;color:var(--muted);background:var(--surface);padding:5px 10px;font-size:.8rem;font-weight:850}.mobile-search{border:1px solid var(--line);border-radius:var(--radius);min-height:42px;color:var(--muted);background:var(--surface);align-items:center;gap:8px;padding:0 12px;display:flex}.mobile-search input{min-width:0;color:var(--text);background:0 0;border:0;outline:0;flex:1}.mobile-chip-row{scrollbar-width:none;gap:7px;padding-bottom:1px;display:flex;overflow-x:auto}.mobile-chip-row::-webkit-scrollbar{display:none}.mobile-chip-row button{border:1px solid var(--line);border-radius:var(--radius);min-height:34px;color:var(--muted);background:var(--surface);white-space:nowrap;flex:none;padding:6px 11px;font-size:.82rem;font-weight:850}.mobile-chip-row button.active{color:#102436;background:#dff7f4;border-color:#b9e4dd}.mobile-view-toggle{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;padding:3px;display:grid}.mobile-view-toggle button{border-radius:calc(var(--radius) - 2px);min-height:34px;color:var(--muted);background:0 0;border:1px solid #0000;font-size:.82rem;font-weight:850}.mobile-view-toggle button.active{color:#102436;background:#fff;border-color:#b9e4dd}.mobile-vertical-timeline-panel{width:100%;min-width:0;padding-bottom:8px;overflow:visible}.mobile-vertical-summary{z-index:42;border:1px solid var(--line);border-radius:var(--radius);min-height:48px;color:var(--muted);background:var(--surface-2);gap:3px;padding:8px 10px;font-size:.8rem;font-weight:800;display:grid;position:sticky;top:0;box-shadow:0 6px 12px #1e344614}.mobile-vertical-summary strong{color:var(--text);font-size:.78rem;font-weight:850}.mobile-vertical-group,.mobile-vertical-operator{gap:8px;display:grid}.mobile-vertical-group{margin-top:12px}.mobile-vertical-berth{gap:6px;display:grid}.mobile-vertical-berth-head{border:1px solid var(--line);border-radius:var(--radius);background:#ffffffb8;justify-content:space-between;align-items:center;gap:8px;min-height:32px;padding:5px 9px;display:flex}.mobile-vertical-berth-head strong{color:var(--text);font-size:.9rem;font-weight:850}.mobile-vertical-berth-head span{color:var(--muted);font-size:.76rem;font-weight:850}.mobile-vertical-events{gap:8px;margin-left:7px;padding-left:12px;display:grid;position:relative}.mobile-vertical-events:before{content:"";background:#cfe0ec;border-radius:999px;width:2px;position:absolute;top:5px;bottom:5px;left:0}.mobile-vertical-event{border:1px solid var(--line);border-radius:var(--radius);background:#fff;grid-template-columns:minmax(86px,.36fr) minmax(0,1fr);gap:9px;min-height:74px;padding:10px;display:grid;position:relative;box-shadow:0 8px 22px #1e344614}.mobile-vertical-event:before{content:"";background:var(--teal);border:2px solid #fff;border-radius:50%;width:10px;height:10px;position:absolute;top:18px;left:-17px;box-shadow:0 0 0 2px #b9e4dd}.mobile-vertical-event.info:before{background:var(--blue);box-shadow:0 0 0 2px #b9cff7}.mobile-vertical-event.warning:before{background:var(--amber);box-shadow:0 0 0 2px #edc36f}.mobile-vertical-event.danger:before{background:var(--red);box-shadow:0 0 0 2px #f4b9bf}.mobile-vertical-event.muted:before{background:var(--muted-2);box-shadow:0 0 0 2px var(--line)}.mobile-vertical-event-time{align-content:center;gap:2px;display:grid}.mobile-vertical-event-time span{color:var(--muted-2);font-size:.68rem;font-weight:850}.mobile-vertical-event-time strong{color:var(--text);white-space:nowrap;font-size:.76rem;font-weight:850}.mobile-vertical-event-body{align-content:center;gap:5px;min-width:0;display:grid}.mobile-vertical-event-body div{justify-content:space-between;align-items:center;gap:8px;min-width:0;display:flex}.mobile-vertical-event-body strong{min-width:0;color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;font-weight:850;overflow:hidden}.mobile-vertical-event-body small{min-width:0;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:.74rem;font-weight:750;overflow:hidden}.mobile-vertical-standby{border:1px dashed var(--line-strong);border-radius:var(--radius);min-height:42px;color:var(--muted-2);background:#ffffff8c;align-items:center;padding:8px 10px;font-size:.8rem;font-weight:800;display:flex}.mobile-berth-track-panel{overscroll-behavior-x:none;width:100%;min-width:0;max-width:100%;min-height:0;padding-bottom:8px;overflow:visible}.mobile-berth-track-panel .berth-board{touch-action:pan-y;gap:10px;width:100%;max-width:100%;overflow:visible}.mobile-berth-track-panel .timeline-summary{background:var(--surface-2);flex-direction:column;align-items:flex-start;gap:3px}.mobile-berth-track-panel .timeline-summary strong{font-size:.78rem}.mobile-berth-track-panel .time-axis,.mobile-berth-track-panel .berth-row{grid-template-columns:52px minmax(0,1fr)}.mobile-berth-track-panel .time-axis{z-index:42;background:linear-gradient(180deg, var(--bg) 0%, var(--bg) 86%, #f4f9fc00);min-height:44px;padding-bottom:6px;position:sticky;top:0;box-shadow:0 8px 14px #1e344614}.mobile-berth-track-panel .berth-name{padding:6px}.mobile-berth-track-panel .berth-name strong{font-size:.84rem}.mobile-berth-track-panel .operator-title{padding:4px 10px;font-size:.8rem}.mobile-berth-track-panel .vessel-marker{gap:5px;min-width:94px;height:32px;padding:0 8px;font-size:.75rem}.mobile-berth-track-panel .vessel-marker-content{gap:5px}.mobile-berth-track-panel .empty-berth{font-size:.78rem;left:10px}.mobile-operator-stack,.mobile-vessel-list,.mobile-weather-stack{gap:9px;display:grid}.mobile-berth-group,.mobile-operator-group{gap:7px;display:grid}.mobile-group-title{color:var(--muted);align-items:center;gap:6px;font-size:.82rem;font-weight:850;display:flex}.mobile-operator-title{min-height:28px;color:var(--teal);border-radius:var(--radius);background:#edf8f6;border:1px solid #c7e7e2;align-items:center;padding:4px 10px;font-size:.82rem;font-weight:850;display:flex}.mobile-berth-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);grid-template-columns:64px minmax(0,1fr);min-height:66px;display:grid;overflow:hidden}.mobile-berth-name{border-right:1px solid var(--line);background:var(--surface-2);align-content:center;gap:2px;padding:10px;display:grid}.mobile-berth-name strong{color:var(--text);font-size:.94rem;font-weight:850}.mobile-berth-name span{color:var(--muted);font-size:.72rem;font-weight:750}.mobile-berth-vessels{align-content:center;gap:6px;min-width:0;padding:9px;display:grid}.mobile-standby{color:var(--muted-2);font-size:.8rem;font-weight:750}.mobile-vessel-pill{border-radius:var(--radius);border:1px solid #0000;grid-template-rows:auto auto;grid-template-columns:16px minmax(0,1fr) auto;align-items:center;gap:6px;min-width:0;min-height:46px;padding:6px 8px;font-size:.78rem;font-weight:850;display:grid}.mobile-vessel-pill svg{grid-row:1/span 2}.mobile-vessel-pill span{text-overflow:ellipsis;white-space:nowrap;grid-column:2;min-width:0;overflow:hidden}.mobile-vessel-pill strong{white-space:nowrap;grid-column:3;font-size:.72rem}.mobile-vessel-pill small{min-width:0;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;grid-column:2/4;font-size:.7rem;font-weight:780;overflow:hidden}.mobile-call-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);gap:10px;padding:13px;display:grid;box-shadow:0 8px 20px #1e34460f}.mobile-call-main{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.mobile-call-main div{gap:2px;min-width:0;display:grid}.mobile-call-main strong{min-width:0;color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:.95rem;font-weight:850;overflow:hidden}.mobile-call-main span:not(.status-pill){color:var(--muted);font-size:.76rem;font-weight:750}.mobile-call-card dl{gap:7px;margin:0;display:grid}.mobile-call-card dl div{grid-template-columns:46px minmax(0,1fr);align-items:center;gap:8px;display:grid}.mobile-call-card dt{color:var(--muted);font-size:.74rem;font-weight:850}.mobile-call-card dd{min-width:0;color:var(--text);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:.82rem;font-weight:760;overflow:hidden}.mobile-risk-banner{border-radius:var(--radius);border:1px solid #0000;justify-content:space-between;align-items:center;gap:12px;min-height:76px;padding:14px;display:flex}.mobile-risk-banner span{color:var(--muted);font-size:.78rem;font-weight:850}.mobile-risk-banner strong{color:var(--text);margin-top:2px;font-size:1.28rem;font-weight:850;display:block}.mobile-threshold-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);gap:9px;padding:13px;display:grid;box-shadow:0 8px 20px #1e34460f}.mobile-threshold-card>span{color:var(--muted-2);letter-spacing:.08em;text-transform:uppercase;font-size:.72rem;font-weight:850}.mobile-threshold-card ul{gap:8px;margin:0;padding:0;list-style:none;display:grid}.mobile-threshold-card li{color:var(--text);align-items:center;gap:8px;font-size:.84rem;font-weight:800;display:flex}.mobile-threshold-card svg{color:var(--teal)}.mobile-empty{min-height:96px;color:var(--muted);border:1px dashed var(--line-strong);border-radius:var(--radius);background:#ffffff8c;justify-content:center;align-items:center;gap:8px;font-size:.86rem;font-weight:800;display:flex}.mobile-bottom-nav{z-index:60;width:min(480px,100vw);padding:8px 10px calc(8px + env(safe-area-inset-bottom));border-top:1px solid var(--line);background:#fffffff5;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px;display:grid;position:fixed;bottom:0;left:50%;right:auto;transform:translate(-50%);box-shadow:0 -10px 30px #1e344621}.mobile-app.mobile-fluid .mobile-bottom-nav{width:100%;left:0;right:0;transform:none}.mobile-app.mobile-preview .mobile-bottom-nav{width:min(480px,100vw)}.mobile-bottom-nav button{border-radius:var(--radius);min-width:0;min-height:52px;color:var(--muted);background:0 0;border:1px solid #0000;place-items:center;gap:3px;font-size:.7rem;font-weight:850;display:grid}.mobile-bottom-nav button.active{color:#102436;background:#dff7f4;border-color:#c7e7e2}@media (orientation:landscape) and (height<=560px){.mobile-app{min-height:100dvh;padding:6px 8px 6px calc(62px + env(safe-area-inset-left))}.mobile-app.mobile-preview{max-width:none}.mobile-app.mobile-screen-berths{height:100dvh}.mobile-hero{display:none}.mobile-brand{gap:8px}.mobile-brand .brand-mark{width:34px;height:34px}.mobile-brand p{display:none}.mobile-brand h1{font-size:.92rem}.mobile-refresh{width:34px;height:34px}.mobile-ad-slot{display:none}.mobile-notice{min-height:30px;margin-bottom:6px;padding:6px 8px;font-size:.74rem}.mobile-content{gap:8px}.mobile-screen-berths .mobile-section{gap:6px}.mobile-title{display:none}.mobile-title h2{font-size:.98rem}.mobile-search{min-height:32px;padding:0 8px}.mobile-chip-row{gap:5px;padding-bottom:0}.mobile-chip-row button{min-height:28px;padding:4px 8px;font-size:.74rem}.mobile-view-toggle{gap:4px;width:min(220px,100%);padding:2px}.mobile-view-toggle button{min-height:28px;font-size:.74rem}.mobile-vertical-summary{justify-content:space-between;align-items:center;gap:8px;min-height:30px;padding:5px 8px;font-size:.7rem;display:flex}.mobile-vertical-summary strong{font-size:.72rem}.mobile-vertical-group{margin-top:8px}.mobile-vertical-group,.mobile-vertical-operator{gap:6px}.mobile-vertical-berth{gap:5px}.mobile-vertical-berth-head{min-height:26px;padding:3px 8px}.mobile-vertical-berth-head strong{font-size:.82rem}.mobile-vertical-berth-head span{font-size:.7rem}.mobile-vertical-events{gap:6px}.mobile-vertical-event{grid-template-columns:80px minmax(0,1fr);gap:7px;min-height:58px;padding:7px}.mobile-vertical-event-time span{font-size:.62rem}.mobile-vertical-event-time strong{font-size:.68rem}.mobile-vertical-event-body strong{font-size:.82rem}.mobile-vertical-event-body small{font-size:.68rem}.mobile-vertical-standby{min-height:32px;padding:6px 8px;font-size:.72rem}.mobile-berth-track-panel .timeline-summary{flex-direction:row;align-items:center;min-height:30px;padding:5px 8px}.mobile-berth-track-panel .timeline-summary strong{font-size:.72rem}.mobile-berth-track-panel .time-axis,.mobile-berth-track-panel .berth-row{grid-template-columns:48px minmax(0,1fr)}.mobile-berth-track-panel .time-axis{min-height:36px}.mobile-berth-track-panel .berth-name{padding:5px}.mobile-berth-track-panel .operator-title{padding:3px 8px}.mobile-bottom-nav,.mobile-app.mobile-fluid .mobile-bottom-nav,.mobile-app.mobile-preview .mobile-bottom-nav{width:calc(54px + env(safe-area-inset-left));height:100dvh;padding:max(6px, env(safe-area-inset-top)) 5px max(6px, env(safe-area-inset-bottom)) calc(5px + env(safe-area-inset-left));border-top:0;border-right:1px solid var(--line);background:#fffffff7;grid-template-rows:repeat(4,minmax(0,1fr));grid-template-columns:1fr;gap:4px;inset:0 auto 0 0;transform:none;box-shadow:8px 0 24px #1e34461f}.mobile-bottom-nav button{gap:2px;width:100%;min-height:0;padding:4px 2px;font-size:.62rem}.mobile-bottom-nav svg{width:18px;height:18px}}@media (width<=1180px){.app-shell{grid-template-columns:1fr}.sidebar{min-height:auto;position:static}.brand,.source-meta,.threshold-section ul{max-width:760px}.berth-filter{flex-wrap:wrap;display:flex}.dashboard-grid{grid-template-columns:1fr}.metrics{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=760px){.content,.sidebar{padding:18px 14px}.topbar{align-items:flex-start}.topbar h2{font-size:1.42rem}.metrics{grid-template-columns:1fr}.panel-heading{flex-direction:column;align-items:stretch}.panel-heading.compact{flex-direction:row;align-items:center}.search-box{width:100%;min-width:0}.time-axis,.berth-row{grid-template-columns:132px minmax(260px,1fr)}.berth-name{padding:9px}.weather-measures{grid-template-columns:1fr}}
