@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--bg-0: #060d1a;--bg-1: #0a1424;--bg-2: #0f1c30;--bg-3: #15263d;--bg-4: #1c3050;--bg-hover: #1f3760;--border-1: #1e3354;--border-2: #284870;--border-3: #3a5e8c;--text-1: #e8eef7;--text-2: #a8b8cf;--text-3: #6e8099;--text-4: #4a5e7a;--accent: #38bdf8;--accent-2: #0ea5e9;--accent-bg: rgba(56, 189, 248, .12);--ok: #10b981;--warn: #f59e0b;--bad: #ef4444;--info: #06b6d4;--conflict-bg: rgba(239, 68, 68, .18);--conflict-stripe: rgba(239, 68, 68, .35);--shadow-1: 0 1px 2px rgba(0,0,0,.4);--shadow-2: 0 4px 12px rgba(0,0,0,.5);--shadow-3: 0 12px 32px rgba(0,0,0,.6);--radius-sm: 3px;--radius: 5px;--radius-lg: 8px;--row-h: 44px;--header-h: 52px;--topbar-h: 56px;--hour-w: 2.4px;--font-ui: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "Cascadia Code", Menlo, monospace}[data-theme=light]{--bg-0: #f1f4f9;--bg-1: #ffffff;--bg-2: #f7f9fc;--bg-3: #eef2f8;--bg-4: #e3eaf3;--bg-hover: #dbe4f0;--border-1: #dde4ee;--border-2: #c5d1e0;--border-3: #9fb1c8;--text-1: #0c1a2e;--text-2: #3a4a63;--text-3: #6b7a90;--text-4: #95a3b8;--accent: #0369a1;--accent-2: #0284c7;--accent-bg: rgba(3, 105, 161, .1);--conflict-bg: rgba(239, 68, 68, .12);--shadow-1: 0 1px 2px rgba(15, 30, 60, .06);--shadow-2: 0 4px 12px rgba(15, 30, 60, .1);--shadow-3: 0 12px 32px rgba(15, 30, 60, .16)}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;overflow:hidden}body{font-family:var(--font-ui);background:var(--bg-0);color:var(--text-1);font-size:13px;line-height:1.4;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,select,textarea{font-family:inherit}#root,.app{height:100vh;width:100vw;display:flex;flex-direction:column;overflow:hidden}.topbar{height:var(--topbar-h);background:var(--bg-1);border-bottom:1px solid var(--border-1);display:flex;align-items:center;padding:0 16px;gap:16px;flex-shrink:0;z-index:50}.brand{display:flex;align-items:center;gap:10px}.brand-mark{width:30px;height:30px;background:linear-gradient(135deg,var(--accent),var(--accent-2));border-radius:var(--radius);display:grid;place-items:center;color:#fff;font-weight:700;font-family:var(--font-mono);font-size:12px;letter-spacing:-.04em}.brand-text{display:flex;flex-direction:column;line-height:1.1}.brand-text .name{font-weight:600;font-size:13px;letter-spacing:-.01em}.brand-text .sub{font-size:10px;color:var(--text-3);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em}.topbar-divider{width:1px;height:28px;background:var(--border-1)}.nav-tabs{display:flex;gap:2px}.nav-tab{padding:7px 12px;font-size:12.5px;font-weight:500;color:var(--text-2);border-radius:var(--radius);display:flex;align-items:center;gap:6px}.nav-tab:hover{background:var(--bg-2);color:var(--text-1)}.nav-tab.active{background:var(--bg-3);color:var(--text-1)}.nav-tab .badge{background:var(--accent);color:#00131f;font-size:10px;padding:1px 5px;border-radius:10px;font-weight:700;font-family:var(--font-mono)}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:8px}.icon-btn{width:32px;height:32px;display:grid;place-items:center;border-radius:var(--radius);color:var(--text-2);position:relative}.icon-btn:hover{background:var(--bg-2);color:var(--text-1)}.icon-btn .dot{position:absolute;top:6px;right:7px;width:7px;height:7px;border-radius:50%;background:var(--bad);border:2px solid var(--bg-1)}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;font-size:12.5px;font-weight:500;border-radius:var(--radius);background:var(--bg-2);color:var(--text-1);border:1px solid var(--border-1);transition:all .15s}.btn:hover{background:var(--bg-3);border-color:var(--border-2)}.btn-primary{background:var(--accent);color:#00131f;border-color:var(--accent);font-weight:600}.btn-primary:hover{background:var(--accent-2);border-color:var(--accent-2);color:#fff}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:var(--bg-2)}.btn-sm{padding:5px 9px;font-size:11.5px}.user-chip{display:flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;border-radius:999px;background:var(--bg-2);border:1px solid var(--border-1)}.avatar{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#06b6d4,#6366f1);color:#fff;font-size:10px;font-weight:700;display:grid;place-items:center}.user-chip .role{font-size:10px;color:var(--text-3);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em}.user-chip .name{font-size:12px;font-weight:500}.workspace{flex:1;display:flex;overflow:hidden;min-height:0}.sidebar-left{width:260px;background:var(--bg-1);border-right:1px solid var(--border-1);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.main{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-0)}.sidebar-right{width:340px;background:var(--bg-1);border-left:1px solid var(--border-1);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.section-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px 8px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);font-family:var(--font-mono)}.section-header .count{background:var(--bg-3);padding:1px 6px;border-radius:10px;font-size:10px;color:var(--text-2)}.search-box{margin:0 12px 12px;display:flex;align-items:center;gap:8px;background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius);padding:7px 10px}.search-box:focus-within{border-color:var(--accent);background:var(--bg-3)}.search-box input{flex:1;background:none;border:none;outline:none;color:var(--text-1);font-size:12px}.search-box svg{color:var(--text-3);flex-shrink:0}.kbd{font-family:var(--font-mono);font-size:10px;background:var(--bg-3);color:var(--text-3);padding:1px 5px;border-radius:3px;border:1px solid var(--border-1)}.filter-chips{display:flex;flex-wrap:wrap;gap:4px;padding:0 12px 8px}.chip{font-size:11px;padding:3px 8px;border-radius:999px;background:var(--bg-2);border:1px solid var(--border-1);color:var(--text-2);cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:all .12s}.chip:hover{background:var(--bg-3);color:var(--text-1)}.chip.active{background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}.chip .dot{width:7px;height:7px;border-radius:50%}.fleet-list{flex:1;overflow-y:auto;padding:0 8px 12px}.fleet-item{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--radius);cursor:pointer;transition:background .1s;border:1px solid transparent}.fleet-item:hover{background:var(--bg-2)}.fleet-item.selected{background:var(--accent-bg);border-color:var(--accent)}.fleet-icon{width:30px;height:30px;border-radius:var(--radius-sm);display:grid;place-items:center;flex-shrink:0;font-size:14px;color:#fff;font-weight:600}.fleet-meta{flex:1;min-width:0}.fleet-name{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-1)}.fleet-sub{font-size:10.5px;color:var(--text-3);font-family:var(--font-mono)}.fleet-status{width:8px;height:8px;border-radius:50%;flex-shrink:0}.toolbar{height:44px;display:flex;align-items:center;gap:10px;padding:0 14px;background:var(--bg-1);border-bottom:1px solid var(--border-1);flex-shrink:0}.toolbar-group{display:flex;align-items:center;background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius);padding:2px}.toolbar-group button{padding:4px 10px;font-size:11.5px;font-weight:500;color:var(--text-2);border-radius:3px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.04em}.toolbar-group button:hover{color:var(--text-1)}.toolbar-group button.active{background:var(--bg-4);color:var(--text-1)}.date-nav{display:flex;align-items:center;gap:2px;background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius)}.date-nav button{width:28px;height:26px;display:grid;place-items:center;color:var(--text-2)}.date-nav button:hover{color:var(--text-1);background:var(--bg-3)}.date-nav .date-label{padding:4px 12px;font-size:12px;font-weight:500;border-left:1px solid var(--border-1);border-right:1px solid var(--border-1);display:flex;flex-direction:column;align-items:center;line-height:1.1;min-width:130px}.date-nav .date-label .day{color:var(--text-1);font-weight:600}.date-nav .date-label .week{color:var(--text-3);font-size:10px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}.toolbar-spacer{flex:1}.legend{display:flex;align-items:center;gap:14px}.legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-3)}.legend-item .dot{width:8px;height:8px;border-radius:50%}.gantt-wrap{flex:1;overflow:auto;position:relative;background:linear-gradient(var(--border-1),var(--border-1)) 0 var(--header-h) / 100% 1px no-repeat,var(--bg-0)}.gantt{position:relative;display:grid;grid-template-columns:200px 1fr;min-width:max-content}.gantt-corner{position:sticky;top:0;left:0;z-index:30;background:var(--bg-1);border-right:1px solid var(--border-1);border-bottom:1px solid var(--border-1);height:var(--header-h);display:flex;align-items:center;padding:0 14px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);font-family:var(--font-mono)}.gantt-time-header{position:sticky;top:0;z-index:20;height:var(--header-h);background:var(--bg-1);border-bottom:1px solid var(--border-1);display:flex;flex-direction:column}.gantt-time-days{display:flex;height:22px;border-bottom:1px solid var(--border-1)}.gantt-time-day{border-right:1px solid var(--border-1);padding:4px 10px;font-size:10.5px;font-weight:600;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--text-2);display:flex;align-items:center;gap:8px;white-space:nowrap;flex-shrink:0}.gantt-time-day.today{color:var(--accent);background:var(--accent-bg)}.gantt-time-day .weather{font-size:9.5px;color:var(--text-3);font-weight:400;display:inline-flex;align-items:center;gap:4px;padding:1px 6px;background:var(--bg-2);border-radius:3px;border:1px solid var(--border-1)}.gantt-time-day .weather.warn{color:var(--warn);border-color:var(--warn)}.gantt-time-day .weather.bad{color:var(--bad);border-color:var(--bad)}.gantt-time-hours{display:flex;height:30px}.gantt-time-hour{border-right:1px solid var(--border-1);font-size:10px;font-family:var(--font-mono);color:var(--text-3);padding:6px 0 0 4px;flex-shrink:0;position:relative}.gantt-time-hour.major{color:var(--text-2)}.site-row{display:contents}.site-cell{position:sticky;left:0;z-index:10;background:var(--bg-1);border-right:1px solid var(--border-1);border-bottom:1px solid var(--border-1);height:var(--row-h);display:flex;align-items:center;padding:0 12px;gap:10px}.site-num{width:28px;height:28px;background:var(--bg-3);border:1px solid var(--border-2);border-radius:var(--radius-sm);display:grid;place-items:center;font-family:var(--font-mono);font-weight:600;font-size:12px;color:var(--text-1);flex-shrink:0}.site-info{display:flex;flex-direction:column;line-height:1.15;min-width:0;flex:1}.site-info .label{font-size:11.5px;font-weight:500;color:var(--text-1)}.site-info .meta{font-size:9.5px;color:var(--text-3);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.04em}.site-track{position:relative;height:var(--row-h);border-bottom:1px solid var(--border-1);background-image:linear-gradient(to right,var(--border-1) 1px,transparent 1px);background-repeat:repeat-x}.site-track.dragover{background-color:var(--accent-bg)}.day-sep{position:absolute;top:0;bottom:0;width:1px;background:var(--border-2);pointer-events:none;z-index:2}.vessel{position:absolute;height:34px;top:5px;border-radius:var(--radius);cursor:grab;display:flex;flex-direction:column;padding:4px 8px;overflow:hidden;transition:box-shadow .15s,transform .15s;border:1px solid rgba(255,255,255,.08);-webkit-user-select:none;user-select:none;z-index:4}.vessel:hover{box-shadow:var(--shadow-2);transform:translateY(-1px);z-index:6}.vessel.selected{outline:2px solid var(--accent);outline-offset:1px;z-index:7}.vessel.dragging{opacity:.5;cursor:grabbing}.vessel.conflict{background-image:repeating-linear-gradient(45deg,transparent,transparent 6px,var(--conflict-stripe) 6px,var(--conflict-stripe) 8px)}.vessel-header{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden}.vessel-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;text-shadow:0 1px 0 rgba(0,0,0,.2)}.vessel-status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;box-shadow:0 0 0 1.5px #ffffff4d}.vessel-meta{font-family:var(--font-mono);font-size:10px;color:#ffffffd9;white-space:nowrap;overflow:hidden}.vessel-handle{position:absolute;top:0;bottom:0;width:6px;cursor:ew-resize;z-index:5}.vessel-handle.left{left:0;border-radius:var(--radius) 0 0 var(--radius)}.vessel-handle.right{right:0;border-radius:0 var(--radius) var(--radius) 0}.vessel-handle:hover{background:#ffffff40}.vessel.compact{height:28px;padding:3px 6px}.vessel.compact .vessel-meta{display:none}.flag{font-family:var(--font-mono);font-size:9px;font-weight:700;background:#00000040;padding:0 4px;border-radius:2px;letter-spacing:.04em}.right-tabs{display:flex;border-bottom:1px solid var(--border-1);padding:0 8px;gap:2px;flex-shrink:0}.right-tabs button{padding:12px 10px;font-size:11.5px;font-weight:500;color:var(--text-3);position:relative}.right-tabs button.active{color:var(--text-1)}.right-tabs button.active:after{content:"";position:absolute;left:8px;right:8px;bottom:-1px;height:2px;background:var(--accent);border-radius:2px 2px 0 0}.right-content{flex:1;overflow-y:auto}.vd-header{padding:16px;border-bottom:1px solid var(--border-1);position:relative}.vd-cover{height:110px;border-radius:var(--radius);margin-bottom:12px;position:relative;overflow:hidden;border:1px solid var(--border-1)}.vd-cover-stripes{position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(135deg,#ffffff0a 0,#ffffff0a 8px,#fff0 8px,#fff0 16px)}.vd-cover-label{position:absolute;bottom:8px;left:10px;font-family:var(--font-mono);font-size:9.5px;color:#ffffffb3;text-transform:uppercase;letter-spacing:.08em;background:#0006;padding:2px 7px;border-radius:3px}.vd-cover-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:36px;color:#ffffffb3}.vd-name{font-size:16px;font-weight:600;letter-spacing:-.01em;margin:0 0 4px}.vd-company{font-size:11.5px;color:var(--text-3);display:flex;align-items:center;gap:6px}.vd-status-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 9px;border-radius:999px;font-size:10.5px;font-weight:600;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;margin-top:10px}.vd-status-pill .dot{width:6px;height:6px;border-radius:50%}.vd-section{padding:14px 16px;border-bottom:1px solid var(--border-1)}.vd-section h4{margin:0 0 10px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);font-family:var(--font-mono);display:flex;align-items:center;justify-content:space-between}.vd-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px}.vd-stat .label{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-mono);margin-bottom:2px}.vd-stat .value{font-size:13px;color:var(--text-1);font-weight:500;font-family:var(--font-mono)}.vd-stat .unit{font-size:10px;color:var(--text-3);margin-left:3px;font-weight:400}.vd-route{display:grid;grid-template-columns:1fr auto 1fr;gap:8px;align-items:center}.vd-route .port{font-size:11.5px;color:var(--text-1)}.vd-route .port .label{font-size:9.5px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-mono);margin-bottom:2px}.vd-route .arrow{color:var(--text-4);font-family:var(--font-mono)}.service-list{display:flex;flex-direction:column;gap:6px}.service-row{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--bg-2);border-radius:var(--radius-sm);border:1px solid var(--border-1);font-size:11.5px}.service-row .check{width:14px;height:14px;border-radius:3px;background:var(--ok);color:#fff;display:grid;place-items:center;font-size:9px;flex-shrink:0}.service-row .check.off{background:var(--bg-3);color:var(--text-3);border:1px solid var(--border-2)}.service-row .label{flex:1}.service-row .time{font-family:var(--font-mono);font-size:10px;color:var(--text-3)}.vd-actions{display:flex;gap:6px;padding:14px 16px}.vd-actions .btn{flex:1;justify-content:center}.timeline-mini{display:flex;align-items:center;background:var(--bg-2);border-radius:var(--radius);padding:8px 10px;border:1px solid var(--border-1);position:relative}.timeline-mini .label{font-size:10px;color:var(--text-3);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.04em}.timeline-mini .time{font-family:var(--font-mono);font-size:12px;color:var(--text-1);font-weight:500}.timeline-mini-bar{flex:1;height:4px;background:var(--bg-4);margin:0 12px;border-radius:2px;position:relative;overflow:hidden}.timeline-mini-bar .fill{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--accent);border-radius:2px}.empty-detail{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 24px;color:var(--text-3)}.empty-detail .ico{width:56px;height:56px;border-radius:50%;background:var(--bg-2);border:1px solid var(--border-1);display:grid;place-items:center;margin-bottom:14px;color:var(--text-3)}.empty-detail h3{font-size:14px;color:var(--text-1);margin:0 0 4px;font-weight:600}.empty-detail p{font-size:12px;margin:0;max-width:220px;line-height:1.5}.util-section{background:var(--bg-1);border-bottom:1px solid var(--border-1);padding:6px 16px}.util-row{display:flex;align-items:center;gap:10px}.util-num{font-family:var(--font-mono);font-size:14px;font-weight:600;color:var(--text-1);letter-spacing:-.02em;line-height:1}.util-num .unit{font-size:10px;color:var(--text-3);margin-left:2px}.util-bar{flex:1;height:4px;background:var(--bg-3);border-radius:2px;overflow:hidden;position:relative;min-width:40px}.util-bar-fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:2px}.util-label{font-size:9px;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-mono);margin-bottom:3px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:200;display:grid;place-items:center}.modal{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius-lg);box-shadow:var(--shadow-3);width:480px;max-width:92vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-lg{width:640px}.modal-header{padding:16px 20px;border-bottom:1px solid var(--border-1);display:flex;align-items:center;gap:12px}.modal-header h3{margin:0;font-size:14px;font-weight:600;flex:1}.modal-body{padding:18px 20px;overflow-y:auto}.modal-footer{padding:12px 20px;border-top:1px solid var(--border-1);display:flex;gap:8px;justify-content:flex-end}.modal-icon{width:32px;height:32px;border-radius:var(--radius);display:grid;place-items:center;flex-shrink:0}.modal-icon.bad{background:#ef444426;color:var(--bad)}.modal-icon.info{background:var(--accent-bg);color:var(--accent)}.field{margin-bottom:14px}.field label{display:block;font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-family:var(--font-mono);margin-bottom:5px}.field input,.field select,.field textarea{width:100%;padding:8px 10px;background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius);color:var(--text-1);font-size:12.5px;outline:none;transition:border-color .15s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);background:var(--bg-3)}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.conflict-card{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-2);border:1px solid var(--border-1);border-left:3px solid var(--bad);border-radius:var(--radius);margin-bottom:10px}.conflict-card .badge{font-family:var(--font-mono);font-size:10px;background:var(--bad);color:#fff;padding:2px 6px;border-radius:3px;font-weight:700;letter-spacing:.04em}.conflict-card .name{font-weight:600;font-size:12.5px}.conflict-card .time{font-family:var(--font-mono);font-size:11px;color:var(--text-3)}.notif-list{display:flex;flex-direction:column}.notif{display:flex;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border-1);cursor:pointer;transition:background .1s;position:relative}.notif:hover{background:var(--bg-2)}.notif.unread:before{content:"";position:absolute;left:6px;top:18px;width:5px;height:5px;border-radius:50%;background:var(--accent)}.notif-icon{width:28px;height:28px;border-radius:var(--radius-sm);display:grid;place-items:center;flex-shrink:0;font-size:12px}.notif-icon.conflicto{background:#ef444426;color:var(--bad)}.notif-icon.meteorologica{background:#f59e0b26;color:var(--warn)}.notif-icon.arribo{background:var(--accent-bg);color:var(--accent)}.notif-icon.servicio{background:#10b98126;color:var(--ok)}.notif-icon.sistema{background:var(--bg-3);color:var(--text-2)}.notif-body{flex:1;min-width:0}.notif-title{font-size:12px;font-weight:600;color:var(--text-1);margin:0 0 2px}.notif-detail{font-size:11px;color:var(--text-2);margin:0}.notif-time{font-size:10px;color:var(--text-4);font-family:var(--font-mono);margin-top:4px}.statusbar{height:24px;background:var(--bg-1);border-top:1px solid var(--border-1);display:flex;align-items:center;padding:0 14px;gap:14px;font-size:10.5px;font-family:var(--font-mono);color:var(--text-3);text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}.statusbar .ok{color:var(--ok)}.statusbar .warn{color:var(--warn)}.statusbar .bad{color:var(--bad)}.statusbar .live:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--ok);margin-right:5px;animation:pulse 2s infinite;vertical-align:middle}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.statusbar-spacer{flex:1}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-1)}::-webkit-scrollbar-thumb{background:var(--bg-3);border-radius:5px;border:2px solid var(--bg-1)}::-webkit-scrollbar-thumb:hover{background:var(--bg-4)}.layout-stacked .sidebar-right{width:100%;max-height:280px;border-left:none;border-top:1px solid var(--border-1)}.layout-stacked .workspace{flex-direction:column}.layout-focus .sidebar-left{width:0;border:none;overflow:hidden}.map-page{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.map-viewport{flex:1;position:relative;overflow:auto;background:radial-gradient(ellipse at 50% 30%,#0a1f3d,#060d1a 70%)}.map-viewport-inner{min-width:100%;min-height:100%}.map-overlays{position:absolute;bottom:16px;right:16px;display:flex;flex-direction:row;gap:10px;z-index:30;pointer-events:none;align-items:flex-end}.map-overlays.collapsed{right:16px;bottom:16px}.mm-overlay-toggle{position:absolute;top:16px;right:16px;z-index:31;background:var(--bg-1);border:1px solid var(--border-2);border-radius:var(--radius);padding:6px 10px;font-family:var(--font-mono);font-size:10px;color:var(--text-2);letter-spacing:.06em;cursor:pointer;display:flex;align-items:center;gap:6px;box-shadow:var(--shadow-1)}.mm-overlay-toggle:hover{color:var(--text-1);border-color:var(--border-3)}.map-overlays>*{pointer-events:auto}.mm-schematic-wrap{position:relative;padding:40px 30px 80px;min-height:580px}.mm-canvas{position:relative;padding:140px 0 100px}.mm-flotante-block{position:absolute;top:240px}.mm-flotante-label{position:absolute;top:-22px;left:0;font-family:var(--font-mono);font-size:9px;color:var(--text-3);letter-spacing:.1em;text-transform:uppercase}.mm-flotante{position:relative;height:60px;border:1.5px dashed rgba(56,189,248,.45);border-radius:4px;background:#38bdf80a;transition:all .15s;cursor:pointer;padding:6px}.mm-flotante.occupied{border-style:solid;border-color:#38bdf840}.mm-flotante.hover{border-color:var(--accent);background:var(--accent-bg)}.mm-flotante.conflict{border-color:var(--bad);background:#ef44440f}.mm-pier-main{position:absolute;top:200px}.mm-pier-label-root{position:absolute;left:-50px;top:80px;font-family:var(--font-mono);font-size:9px;color:var(--text-3);letter-spacing:.1em;transform:rotate(-90deg);transform-origin:right center}.mm-pier-label-end{position:absolute;right:-10px;top:80px;font-family:var(--font-mono);font-size:10px;color:var(--accent);letter-spacing:.08em}.mm-pier-deck{position:relative;height:60px;background:linear-gradient(180deg,#2a3e5e,#1a2638);border-top:2px solid #3a5e8c;border-bottom:2px solid #3a5e8c;box-shadow:inset 0 1px #ffffff0f}.mm-pier-deck-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(90deg,transparent 0 30px,rgba(0,0,0,.18) 30px 31px)}.mm-pier-centerline{position:absolute;top:50%;left:0;right:0;height:2px;transform:translateY(-50%);display:flex;gap:6px;padding:0 4px}.mm-pier-centerline span{flex:1;height:2px;background:#ffffff1a;border-radius:1px}.mm-sites-row{position:relative;height:50px}.mm-sites-row.norte{margin-bottom:0}.mm-sites-row.sur{margin-top:0}.mm-site{position:absolute;top:0;bottom:0;border:1.5px dashed rgba(56,189,248,.4);border-radius:3px;background:#38bdf80a;transition:all .15s;cursor:pointer;padding:4px 6px}.mm-site.occupied{border-style:solid;border-color:#38bdf840}.mm-site.extra{border-style:solid;border-color:#a855f773;background:repeating-linear-gradient(45deg,#a855f70a 0,#a855f70a 6px,#a855f71a 6px,#a855f71a 12px)}.mm-site-extra-hint{position:absolute;left:4px;right:4px;top:50%;transform:translateY(-50%);font-family:var(--font-mono);font-size:9px;font-weight:600;color:#c084fcf2;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.04em}.mm-vessel.mega{background-image:linear-gradient(180deg,rgba(255,255,255,.08) 0%,transparent 50%,rgba(0,0,0,.15) 100%)!important;box-shadow:0 6px 16px #00000080,inset 0 0 0 1px #ffffff14}.mm-vessel-mega-badge{position:absolute;top:50%;right:8px;transform:translateY(-50%);font-family:var(--font-mono);font-size:9px;font-weight:700;background:#00000073;color:#fde68a;padding:2px 6px;border-radius:2px;letter-spacing:.04em;pointer-events:none}.mm-site.hover{border-color:var(--accent);background:var(--accent-bg);border-style:solid}.mm-site.conflict{border-color:var(--bad);background:#ef444412}.mm-site.flotante{border-style:dashed;border-color:#38bdf88c;background:#38bdf812;box-shadow:inset 0 0 0 1px #38bdf81a}.mm-site.flotante:before{content:"≈";position:absolute;top:2px;right:4px;font-size:12px;color:#38bdf899;font-family:var(--font-mono)}.mm-site.flotante.occupied{border-style:solid}.mm-site-num{font-family:var(--font-mono);font-size:10px;font-weight:700;color:var(--text-2);letter-spacing:.04em}.mm-site-cap{font-family:var(--font-mono);font-size:9px;color:var(--text-3);margin-top:1px}.mm-site-bollards{position:absolute;bottom:0;left:4px;right:4px;display:flex;justify-content:space-between}.mm-site-bollards.bottom{top:0;bottom:auto}.mm-site-bollards span{width:4px;height:5px;background:#3a5e8c;border-radius:1px 1px 0 0}.mm-site-bollards.bottom span{border-radius:0 0 1px 1px}.mm-vessels-row{position:relative;height:0}.mm-vessel{position:absolute;border-radius:3px 8px 8px 3px;cursor:grab;box-shadow:0 4px 10px #0006;border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;padding:3px 8px 3px 10px;gap:6px;overflow:visible;transition:transform .15s,box-shadow .15s;z-index:5}.mm-vessel:hover{transform:translateY(-2px);box-shadow:0 8px 18px #0000008c;z-index:10}.mm-vessel.selected{outline:2px solid var(--accent);outline-offset:2px;z-index:12}.mm-vessel.conflict{background-image:repeating-linear-gradient(45deg,transparent 0 6px,var(--conflict-stripe) 6px 9px)!important}.mm-vessel.side-sur{border-radius:8px 3px 3px 8px;padding:3px 10px 3px 8px}.mm-vessel-stack{position:absolute;top:-4px;left:50%;transform:translate(-50%);width:6px;height:8px;background:#0006;border-radius:1px 1px 0 0}.mm-vessel.side-sur .mm-vessel-stack{top:auto;bottom:-4px;border-radius:0 0 1px 1px}.mm-vessel-info{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.mm-vessel-name{font-size:10.5px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:0 1px 0 rgba(0,0,0,.3)}.mm-vessel-flag{font-family:var(--font-mono);font-size:9px;font-weight:700;background:#0000004d;color:#fff;padding:1px 4px;border-radius:2px}.mm-bathy-end{position:absolute;right:-50px;top:80px;font-family:var(--font-mono);font-size:10px;color:var(--accent)}.mm-shore{position:absolute;top:0;left:0;right:0;height:100px;background:linear-gradient(180deg,#1a2638,#0e1827);border-bottom:1px solid var(--border-2);overflow:hidden}.mm-shore-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.02) 0 8px,transparent 8px 16px)}.mm-shore-label{position:absolute;bottom:8px;left:50%;transform:translate(-50%);font-family:var(--font-mono);font-size:10px;color:var(--text-3);letter-spacing:.2em;text-transform:uppercase}.mm-scale-bar{position:absolute;bottom:30px;left:30px;right:30px;height:24px}.mm-scale-segments{position:relative;height:100%;border-top:1px solid var(--border-2)}.mm-scale-segments>div{position:absolute;top:0}.mm-scale-segments .tick{display:block;width:1px;height:6px;background:var(--border-3)}.mm-scale-segments .lbl{font-family:var(--font-mono);font-size:9px;color:var(--text-3);position:absolute;top:8px;left:-10px}.mm-site-tooltip{position:absolute;transform:translate(-50%);background:var(--bg-1);border:1px solid var(--border-2);border-radius:var(--radius);padding:10px 12px;min-width:220px;box-shadow:var(--shadow-2);z-index:50;pointer-events:none}.tt-notes{margin-top:6px;padding-top:6px;border-top:1px solid var(--border-1);font-size:10.5px;color:var(--text-3);font-style:italic}.mm-real-site-len{position:absolute;bottom:-12px;left:4px;font-family:var(--font-mono);font-size:8px;color:var(--text-3)}.mm-sea{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.mm-sea-waves{width:100%;height:100%;opacity:.7}.mm-wind-indicator{position:absolute;top:16px;left:16px;display:flex;align-items:center;gap:8px;padding:8px 12px;background:#0a1424d9;border:1px solid var(--border-2);border-radius:var(--radius);pointer-events:auto;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.mm-wind-arrow{font-size:18px;color:var(--accent);width:24px;text-align:center}.mm-wind-info{line-height:1.1}.mm-wind-val{font-family:var(--font-mono);font-size:14px;font-weight:600;color:var(--text-1)}.mm-wind-dir{font-family:var(--font-mono);font-size:9px;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em}.mm-current-indicator{position:absolute;bottom:30px;left:16px;display:flex;align-items:center;gap:6px;padding:6px 10px;background:#0a1424d9;border:1px solid var(--border-2);border-radius:var(--radius);font-family:var(--font-mono);font-size:10px;color:var(--text-2);letter-spacing:.06em}.mm-site-tooltip .tt-header{display:flex;align-items:center;justify-content:space-between;font-family:var(--font-mono);font-size:11px;font-weight:700;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--border-1)}.tt-pill{font-size:9px;padding:2px 6px;border-radius:10px;font-weight:700;letter-spacing:.04em}.tt-pill.free{background:#10b98126;color:var(--ok)}.tt-pill.occ{background:#f59e0b26;color:var(--warn)}.tt-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 10px}.tt-grid>div{display:flex;flex-direction:column}.tt-grid span{font-family:var(--font-mono);font-size:9px;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em}.tt-grid strong{font-size:11px;color:var(--text-1);font-weight:600}.tt-occ{margin-top:8px;padding-top:6px;border-top:1px solid var(--border-1)}.tt-occ-name{font-size:12px;font-weight:600;color:var(--accent)}.tt-occ-meta{font-family:var(--font-mono);font-size:10px;color:var(--text-3)}.mm-real-wrap{position:relative;width:100%;height:100%;min-height:600px}.mm-real-bg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.mm-real-site{position:absolute;height:22px;background:#38bdf80f;border:1.5px dashed rgba(56,189,248,.3);border-radius:2px;transform-origin:center;transition:all .15s;cursor:pointer}.mm-real-site.occupied{border-style:solid;background:transparent;border-color:transparent}.mm-real-site.selected{outline:2px solid var(--accent);outline-offset:1px}.mm-real-site-num{position:absolute;top:-14px;left:4px;font-family:var(--font-mono);font-size:9px;font-weight:700;color:var(--text-2)}.mm-real-vessel{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:2px 6px 6px 2px;display:flex;align-items:center;padding:0 6px;cursor:grab;box-shadow:0 2px 6px #0006}.mm-real-vessel-name{font-size:9px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:0 1px 0 rgba(0,0,0,.3)}.mm-real-incoming{position:absolute;display:flex;align-items:center;gap:6px}.mm-real-incoming-icon{color:var(--warn);font-size:14px;animation:pulse 2s infinite}.mm-real-incoming-label{font-family:var(--font-mono);font-size:9px;color:var(--text-2);background:#0a1424d9;padding:3px 6px;border-radius:3px;border:1px solid var(--border-2);line-height:1.2}.mm-minimap{width:180px;background:var(--bg-1);border:1px solid var(--border-2);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-2)}.mm-minimap-header{padding:8px 10px;font-family:var(--font-mono);font-size:10px;font-weight:700;color:var(--text-2);letter-spacing:.1em;border-bottom:1px solid var(--border-1);background:var(--bg-2)}.mm-minimap-svg{width:100%;display:block;background:#06182f}.mm-minimap-stats{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;font-size:11px;color:var(--text-2);border-top:1px solid var(--border-1);font-family:var(--font-mono)}.mm-minimap-stats strong{color:var(--text-1)}.dot-live{display:inline-flex;align-items:center;gap:4px}.dot-live:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--ok);animation:pulse 2s infinite}.mm-suggestion{width:220px;background:var(--bg-1);border:1px solid var(--border-2);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-2)}.mm-suggestion-header{padding:8px 10px;font-family:var(--font-mono);font-size:10px;font-weight:700;color:var(--accent);letter-spacing:.1em;border-bottom:1px solid var(--border-1);background:var(--accent-bg);display:flex;align-items:center;gap:6px}.mm-suggestion-vessel{display:flex;align-items:center;gap:8px;padding:10px;border-bottom:1px solid var(--border-1);cursor:pointer}.mm-suggestion-vessel:hover{background:var(--bg-2)}.mm-suggestion-icon{width:32px;height:32px;border-radius:var(--radius);display:grid;place-items:center;color:#fff;font-size:14px;flex-shrink:0}.mm-suggestion-name{font-size:12px;font-weight:600;color:var(--text-1)}.mm-suggestion-meta{font-family:var(--font-mono);font-size:10px;color:var(--text-3);margin-top:2px}.mm-suggestion-label{padding:8px 10px 4px;font-family:var(--font-mono);font-size:9px;color:var(--text-3);letter-spacing:.1em;text-transform:uppercase}.mm-suggestion-site{display:flex;align-items:center;gap:8px;padding:6px 10px;border-bottom:1px solid var(--border-1)}.mm-suggestion-site:last-child{border-bottom:none}.mm-suggestion-site.best{background:#10b9810f}.mm-suggestion-site-num{font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--text-1);width:30px}.mm-suggestion-site-info{flex:1}.mm-suggestion-site-cap{font-family:var(--font-mono);font-size:11px;color:var(--text-2)}.mm-suggestion-site-tipo{font-family:var(--font-mono);font-size:9px;color:var(--text-3)}.mm-suggestion-score{font-family:var(--font-mono);font-size:12px;font-weight:700;color:var(--ok)}.nc-wrap{position:relative;width:100%;height:100%;min-height:600px;overflow:hidden;background:radial-gradient(ellipse at 50% 60%,#0a1f3d,#03080f 80%);cursor:grab}.nc-wrap:active{cursor:grabbing}.nc-svg{width:100%;height:100%;display:block;transition:transform .05s linear}.nc-controls{position:absolute;top:12px;right:12px;z-index:10;display:flex;flex-direction:column;gap:8px;align-items:flex-end}.nc-control-group{display:inline-flex;background:#0a0f19d9;border:1px solid var(--border-2);border-radius:var(--radius);padding:2px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.nc-control-group button{background:transparent;border:none;color:var(--text-1);padding:6px 10px;font-family:var(--font-mono);font-size:11px;cursor:pointer;border-radius:3px;min-width:38px}.nc-control-group button:hover{background:#38bdf826}.nc-layer-toggles{display:flex;flex-wrap:wrap;gap:4px;background:#0a0f19d9;border:1px solid var(--border-2);border-radius:var(--radius);padding:8px 10px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);max-width:260px}.nc-layer-title{font-family:var(--font-mono);font-size:9px;color:var(--text-3);letter-spacing:.12em;width:100%;margin-bottom:4px}.nc-layer-toggle{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:10px;padding:3px 7px;border-radius:10px;background:#38bdf80f;color:var(--text-3);border:1px solid transparent;cursor:pointer;-webkit-user-select:none;user-select:none}.nc-layer-toggle.on{background:#38bdf82e;color:#38bdf8;border-color:#38bdf866}.nc-layer-toggle input{display:none}.nc-legend{position:absolute;bottom:12px;left:12px;z-index:10;background:#0a0f19d9;border:1px solid var(--border-2);border-radius:var(--radius);padding:8px 10px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;gap:5px;font-family:var(--font-mono);font-size:9.5px;color:var(--text-2)}.nc-legend-row{display:flex;align-items:center;gap:8px}.nc-leg-dot{width:14px;height:6px;border-radius:1px;flex-shrink:0}.nc-leg-prio{background:#f59e0b;color:#0a0a0a;font-weight:700;padding:1px 5px;border-radius:2px;font-size:8px;flex-shrink:0}.nc-leg-disabled{width:14px;height:14px;flex-shrink:0;background:repeating-linear-gradient(45deg,transparent 0 3px,rgba(239,68,68,.7) 3px 6px);border:1px solid rgba(239,68,68,.5)}.nc-leg-iso{width:14px;height:0;border-top:2px dashed rgba(56,189,248,.5);flex-shrink:0}.nc-tooltip{position:absolute;z-index:20;background:#0a0f19f2;border:1px solid var(--border-2);border-radius:var(--radius);padding:12px 14px;min-width:240px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 24px #00000080;pointer-events:none}.nc-tt-header{display:flex;align-items:center;justify-content:space-between;font-family:var(--font-mono);font-size:12px;font-weight:700;color:var(--text-1);margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--border-1)}.nc-tt-pill{font-family:var(--font-mono);font-size:9px;padding:2px 7px;border-radius:10px;font-weight:700;letter-spacing:.05em}.nc-tt-pill.free{background:#10b9812e;color:#34d399}.nc-tt-pill.occ{background:#38bdf82e;color:#38bdf8}.nc-tt-pill.dis{background:#ef44442e;color:#f87171}.nc-tt-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px;font-family:var(--font-mono);font-size:11px}.nc-tt-grid>div{display:flex;flex-direction:column;gap:1px}.nc-tt-grid span{color:var(--text-3);font-size:9px;letter-spacing:.05em}.nc-tt-grid strong{color:var(--text-1);font-weight:600}.nc-tt-disabled{margin-top:10px;padding:8px 10px;background:#ef444414;border:1px solid rgba(239,68,68,.25);border-radius:4px;font-size:11px;color:#fca5a5;font-family:var(--font-mono)}.nc-tt-occ{margin-top:10px;padding-top:8px;border-top:1px solid var(--border-1);font-family:var(--font-mono);font-size:11px;color:var(--text-2)}.nc-tt-hint{margin-top:8px;padding-top:6px;border-top:1px dotted var(--border-1);font-size:9.5px;color:var(--text-3);font-family:var(--font-mono);font-style:italic}.nc-context-menu{position:absolute;z-index:30;background:#0a0f19f7;border:1px solid var(--border-2);border-radius:var(--radius);padding:4px;min-width:220px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 12px 32px #0009}.nc-cm-title{padding:8px 10px 6px;border-bottom:1px solid var(--border-1);font-family:var(--font-mono);font-size:10px;color:var(--text-3);letter-spacing:.1em;font-weight:700}.nc-cm-item{display:flex;align-items:center;gap:8px;width:100%;background:transparent;border:none;padding:8px 10px;font-size:12px;color:var(--text-1);cursor:pointer;border-radius:3px;font-family:inherit;text-align:left}.nc-cm-item:hover{background:#38bdf826}.nc-modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center}.nc-modal{width:480px;max-width:92vw;background:var(--bg-1);border:1px solid var(--border-2);border-radius:var(--radius-lg, 8px);overflow:hidden;box-shadow:0 24px 64px #000000b3}.nc-modal-head{display:flex;align-items:flex-start;justify-content:space-between;padding:18px 22px 14px;border-bottom:1px solid var(--border-1)}.nc-modal-eyebrow{font-family:var(--font-mono);font-size:10px;color:var(--bad);letter-spacing:.15em;font-weight:700;margin-bottom:4px}.nc-modal-title{font-size:18px;font-weight:600;color:var(--text-1)}.nc-modal-close{background:transparent;border:none;font-size:22px;line-height:1;color:var(--text-3);cursor:pointer;padding:4px 10px}.nc-modal-close:hover{color:var(--text-1)}.nc-modal-body{padding:18px 22px;display:flex;flex-direction:column;gap:14px}.nc-field{display:flex;flex-direction:column;gap:5px;flex:1}.nc-field span{font-family:var(--font-mono);font-size:10px;color:var(--text-3);letter-spacing:.06em;font-weight:600}.nc-field input,.nc-field select,.nc-field textarea{background:var(--bg-2);border:1px solid var(--border-1);border-radius:4px;padding:8px 10px;color:var(--text-1);font-size:13px;font-family:inherit;transition:border-color .15s}.nc-field input:focus,.nc-field select:focus,.nc-field textarea:focus{outline:none;border-color:var(--accent)}.nc-field-row{display:flex;gap:10px}.nc-modal-warn{display:flex;gap:10px;padding:10px 12px;background:#f59e0b14;border:1px solid rgba(245,158,11,.25);border-radius:4px;color:#fcd34d;font-size:12px;line-height:1.5}.nc-modal-warn svg{flex-shrink:0;margin-top:2px}.nc-modal-foot{display:flex;justify-content:flex-end;gap:8px;padding:14px 22px 18px;border-top:1px solid var(--border-1);background:var(--bg-2)}.btn-danger{background:var(--bad);color:#fff;border-color:var(--bad);font-weight:600}.btn-danger:hover{background:#dc2626;border-color:#dc2626}.nc-hint{position:absolute;bottom:12px;left:12px;z-index:10;display:flex;gap:14px;background:#0a0f19bf;border:1px solid var(--border-1);border-radius:var(--radius);padding:6px 12px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);font-family:var(--font-mono);font-size:10px;color:var(--text-3)}.nc-hint kbd{background:var(--bg-3);border:1px solid var(--border-2);border-radius:2px;padding:1px 5px;font-size:9px;color:var(--text-2);font-family:var(--font-mono);margin-right:4px}.nc-vessel.selected path{stroke:var(--accent);stroke-width:3}.nc-vessel.conflict path{stroke:var(--bad)}.modal-subtitle{font-size:10.5px;color:var(--text-3);letter-spacing:.06em;margin-top:2px}.form-readonly{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius);padding:7px 10px;font-family:var(--font-mono);font-size:12px;color:var(--text-1)}.bloqueo-list{display:flex;flex-direction:column;gap:6px}.bloqueo-row{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;padding:8px 12px;background:#ef44440f;border:1px solid rgba(239,68,68,.18);border-radius:var(--radius)}.bloqueo-rango{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--bad);white-space:nowrap}.bloqueo-razon{font-size:12px;color:var(--text-1)}.bloqueo-notas{grid-column:1 / -1;font-size:11px;color:var(--text-3);font-style:italic}.site-cell.blocked .site-num,.site-cell.blocked .site-info{opacity:.5}.site-cell.blocked:before{content:"🚧";position:absolute;top:4px;right:6px;font-size:11px;z-index:2}.site-track .blocked-range{position:absolute;top:0;bottom:0;background:repeating-linear-gradient(45deg,#ef444426,#ef444426 6px,#ef44440d 6px,#ef44440d 12px);border-left:2px dashed rgba(239,68,68,.4);border-right:2px dashed rgba(239,68,68,.4);z-index:0;pointer-events:none}.site-track .blocked-range-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#ef4444d9;color:#fff;padding:2px 8px;border-radius:3px;font-size:10px;font-weight:600;font-family:var(--font-mono);letter-spacing:.04em;white-space:nowrap;pointer-events:none;z-index:1}.pier-site.blocked{background:repeating-linear-gradient(45deg,rgba(239,68,68,.18),rgba(239,68,68,.18) 6px,transparent 6px,transparent 12px)!important;border-color:#ef444499!important;cursor:not-allowed}.pier-site.blocked .pier-site-label:after{content:" 🚧"}.vessel.oversized{outline:2px dashed var(--warn);outline-offset:-2px}.modal-icon.warn{background:#f59e0b26;color:var(--warn)}.sug-list{display:grid;gap:10px;grid-template-columns:1fr 1fr}.sug-card{display:flex;flex-direction:column;gap:8px;text-align:left;padding:12px 14px;background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius);cursor:pointer;transition:border-color .12s,background .12s}.sug-card:hover{border-color:var(--accent);background:var(--bg-2)}.sug-card-head{display:flex;justify-content:space-between;align-items:center}.sug-sitios{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.sug-chip{display:inline-block;font-family:var(--font-mono);font-size:10.5px;font-weight:600;letter-spacing:.04em;background:var(--bg-2);border:1px solid var(--border-2);padding:3px 8px;border-radius:3px;color:var(--text-1)}.sug-chip.primary{background:#38bdf81f;border-color:#38bdf866;color:var(--accent)}.sug-badge-best{background:var(--accent);color:#001226;font-family:var(--font-mono);font-size:9.5px;font-weight:700;letter-spacing:.06em;padding:2px 6px;border-radius:2px}.sug-card-body{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.sug-stat-label{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;color:var(--text-3);text-transform:uppercase}.sug-stat-value{font-family:var(--font-mono);font-size:13px;color:var(--text-1);font-weight:500;margin-top:2px}.mm-anchorage{position:absolute;top:60px;height:220px;border:1px dashed rgba(56,189,248,.35);border-radius:8px;background:repeating-linear-gradient(135deg,rgba(14,165,233,.04),rgba(14,165,233,.04) 12px,transparent 12px,transparent 24px),#082f492e;display:flex;flex-direction:column;justify-content:flex-start;padding:12px;pointer-events:none;z-index:1}.mm-anchorage-label{font-family:var(--font-mono);font-size:10.5px;font-weight:600;letter-spacing:.06em;color:#38bdf8d9;display:flex;align-items:center;gap:6px}.mm-anchorage-sub{font-family:var(--font-mono);font-size:9.5px;color:#38bdf88c;margin-top:2px}.mm-anchorage-icons{position:absolute;top:30px;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.mm-hint{position:absolute;bottom:14px;right:14px;display:flex;gap:12px;align-items:center;background:#0a0f19d9;border:1px solid var(--border-1);border-radius:var(--radius);padding:6px 12px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:30;font-family:var(--font-mono);font-size:10px;color:var(--text-3)}.mm-hint kbd{background:var(--bg-3);border:1px solid var(--border-2);border-radius:2px;padding:1px 5px;font-size:9px;color:var(--text-2);font-family:var(--font-mono);margin:0 3px}.mm-scale-label{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.08em;color:var(--text-3);text-transform:uppercase;margin-bottom:4px;display:flex;align-items:center;gap:6px;padding-left:30px}.map-viewport{position:relative}.map-viewport.panning,.map-viewport.panning *{cursor:grabbing!important}.map-viewport-inner{will-change:transform}.login-card{background:var(--bg-1);border:1px solid var(--border-1);border-radius:12px;padding:32px;width:360px;box-shadow:0 24px 64px #00000073}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border-1)}.login-card .form-field label{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.08em;color:var(--text-3);text-transform:uppercase;margin-bottom:6px;display:block}.login-card .form-field input{width:100%;padding:9px 12px;background:var(--bg-2);border:1px solid var(--border-2);border-radius:var(--radius);color:var(--text-1);font-size:13px;font-family:var(--font-sans);transition:border-color .12s}.login-card .form-field input:focus{border-color:var(--accent);outline:none}.vessel-photo-frame{width:100%;height:130px;border:1px dashed var(--border-2);border-radius:var(--radius);background:var(--bg-2);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.vessel-photo-frame img{width:100%;height:100%;object-fit:cover}.vessel-photo-placeholder{display:flex;flex-direction:column;align-items:center;color:var(--text-3)}.serv-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:999px;background:var(--bg-2);border:1px solid var(--border-2);font-family:var(--font-mono);font-size:10.5px;letter-spacing:.04em;color:var(--text-2);cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .12s}.serv-chip input{display:none}.serv-chip.active{background:#38bdf81f;border-color:#38bdf873;color:var(--accent)}.modal textarea{width:100%;background:var(--bg-2);border:1px solid var(--border-2);border-radius:var(--radius);padding:8px 10px;color:var(--text-1);font-family:var(--font-sans);font-size:12px;resize:vertical;min-height:50px}.date-picker-inline{background:transparent;border:1px solid var(--border-2);color:var(--text-2);font-family:var(--font-mono);font-size:9.5px;padding:2px 6px;border-radius:3px;cursor:pointer;margin-right:6px;transition:border-color .12s}.date-picker-inline:hover{border-color:var(--accent)}.date-picker-inline::-webkit-calendar-picker-indicator{filter:invert(.6);cursor:pointer}.hour-slider{display:flex;align-items:center;gap:8px;background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius);padding:4px 10px;margin-left:12px}.hour-slider-label{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;color:var(--text-3)}.hour-slider input[type=range]{width:100px;-webkit-appearance:none;background:transparent}.hour-slider input[type=range]::-webkit-slider-runnable-track{height:3px;background:var(--border-2);border-radius:1.5px}.hour-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;background:var(--accent);border-radius:50%;margin-top:-4px;cursor:pointer}.hour-slider input[type=range]::-moz-range-track{height:3px;background:var(--border-2);border-radius:1.5px}.hour-slider input[type=range]::-moz-range-thumb{width:12px;height:12px;background:var(--accent);border:none;border-radius:50%;cursor:pointer}.hour-slider-value{font-family:var(--font-mono);font-size:11px;color:var(--text-1);min-width:38px;font-weight:600}.date-nav button{display:inline-flex;align-items:center;gap:1px}input[type=text],input[type=number],input[type=date],input[type=time],input[type=datetime-local],input[type=email],input[type=password],input[type=search],input[type=tel],input:not([type]),select,textarea{background:var(--bg-2)!important;border:1px solid var(--border-2)!important;color:var(--text-1)!important;font-family:var(--font-sans);font-size:12.5px;padding:7px 11px;border-radius:var(--radius);outline:none;transition:border-color .12s,background .12s;width:100%;box-sizing:border-box}input[type=text]:focus,input[type=number]:focus,input[type=date]:focus,input[type=time]:focus,input[type=datetime-local]:focus,input[type=email]:focus,input[type=password]:focus,input[type=search]:focus,input[type=tel]:focus,input:not([type]):focus,select:focus,textarea:focus{border-color:var(--accent)!important;background:var(--bg-1)!important}input::placeholder,textarea::placeholder{color:var(--text-3);opacity:.6}input[type=date]::-webkit-calendar-picker-indicator,input[type=time]::-webkit-calendar-picker-indicator,input[type=datetime-local]::-webkit-calendar-picker-indicator{filter:invert(.7) brightness(1.2);cursor:pointer}select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' fill='none' stroke='%23748190' stroke-width='1.5'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:12px;padding-right:28px!important}select option{background:var(--bg-2);color:var(--text-1)}input[type=checkbox],input[type=radio]{accent-color:var(--accent);width:auto!important;cursor:pointer}.form-section{margin-bottom:14px}.form-section-title{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.08em;color:var(--text-3);text-transform:uppercase;margin-bottom:8px;display:flex;align-items:center;padding-bottom:4px;border-bottom:1px solid var(--border-1)}.form-row{display:flex;gap:10px;margin-bottom:8px;flex-wrap:wrap}.form-field{flex:1;min-width:0;display:flex;flex-direction:column}.form-field label{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;color:var(--text-3);text-transform:uppercase;margin-bottom:4px}.rp-page{flex:1;display:flex;flex-direction:column;overflow:hidden}.rp-toolbar{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border-1);background:var(--bg-1)}.rp-title{font-size:14px;font-weight:600;margin:0;letter-spacing:.02em}.rp-period-tabs{display:flex;background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius);overflow:hidden}.rp-period-btn{background:transparent;border:none;color:var(--text-2);font-family:var(--font-mono);font-size:10.5px;letter-spacing:.05em;padding:6px 12px;cursor:pointer;border-right:1px solid var(--border-1);transition:background .12s,color .12s}.rp-period-btn:last-child{border-right:none}.rp-period-btn:hover{background:var(--bg-3);color:var(--text-1)}.rp-period-btn.active{background:var(--accent);color:#001226;font-weight:600}.rp-grid{flex:1;overflow-y:auto;padding:16px;display:grid;grid-template-columns:repeat(12,1fr);gap:14px;align-content:start}.rp-card{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius);padding:14px 16px;grid-column:span 6;display:flex;flex-direction:column;gap:12px}.rp-card.rp-hero{grid-column:span 12}.rp-card.rp-md{grid-column:span 6}.rp-card.rp-sm{grid-column:span 4}.rp-card.rp-xl{grid-column:span 12}.rp-card-head{display:flex;justify-content:space-between;align-items:flex-end;border-bottom:1px solid var(--border-1);padding-bottom:8px}.rp-card-title{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;color:var(--text-3);text-transform:uppercase}.rp-card-sub{font-family:var(--font-mono);font-size:10px;color:var(--text-3)}.rp-card-tabs{display:flex;gap:4px}.rp-card-tab{display:flex;align-items:center;gap:5px;background:var(--bg-2);border:1px solid var(--border-1);color:var(--text-2);padding:3px 8px;border-radius:3px;font-family:var(--font-mono);font-size:9.5px;letter-spacing:.04em;cursor:pointer}.rp-card-tab.active{border-color:var(--accent);color:var(--accent)}.rp-card-tab-dot{width:6px;height:6px;border-radius:50%}.rp-hero{background:linear-gradient(135deg,var(--bg-1),var(--bg-2))}.rp-hero-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.rp-hero-eyebrow{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;color:var(--text-3)}.rp-hero-trend{font-family:var(--font-mono);font-size:11px;font-weight:500;padding:3px 10px;border-radius:999px}.rp-hero-trend.up{background:#10b9811f;color:var(--ok);border:1px solid rgba(16,185,129,.25)}.rp-hero-row{display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:center}.rp-hero-num{font-family:var(--font-mono);font-size:56px;font-weight:600;color:var(--text-1);line-height:1;letter-spacing:-.02em}.rp-hero-unit{font-size:22px;color:var(--text-3);margin-left:6px;font-weight:400}.rp-hero-bar{position:relative;padding-bottom:18px}.rp-hero-bar-track{height:10px;background:var(--bg-3);border:1px solid var(--border-1);border-radius:5px;overflow:hidden}.rp-hero-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),#06b6d4);border-radius:5px;transition:width .4s ease}.rp-hero-bar-marks{position:absolute;top:14px;right:0;bottom:0;left:0;font-family:var(--font-mono);font-size:9.5px;color:var(--text-3)}.rp-hero-bar-marks span{position:absolute;transform:translate(-50%)}.rp-hero-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding-top:12px;border-top:1px solid var(--border-1)}.rp-hero-meta>div{display:flex;flex-direction:column;gap:4px}.rp-hero-meta span{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;color:var(--text-3);text-transform:uppercase}.rp-hero-meta strong{font-family:var(--font-mono);font-size:16px;color:var(--text-1);font-weight:600}.rp-kpi{display:flex;flex-direction:column;gap:6px;padding:12px 14px;background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius)}.rp-kpi-label{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;color:var(--text-3);text-transform:uppercase}.rp-kpi-value{font-family:var(--font-mono);font-size:26px;font-weight:600;color:var(--text-1);line-height:1}.rp-kpi-unit{font-size:14px;color:var(--text-3);margin-left:4px;font-weight:400}.rp-kpi-delta{font-family:var(--font-mono);font-size:10.5px;margin-top:2px}.rp-kpi-delta.up{color:var(--ok)}.rp-kpi-delta.down{color:var(--bad)}.rp-spark{width:100%;height:30px;margin-top:4px}.rp-bars{display:flex;flex-direction:column;gap:10px}.rp-bars-rows{display:flex;flex-direction:column;gap:8px}.rp-bars-row{display:grid;grid-template-columns:70px 1fr auto;gap:10px;align-items:center}.rp-bars-label{font-family:var(--font-mono);font-size:11px;color:var(--text-2);letter-spacing:.04em}.rp-bars-track{position:relative;height:18px;background:var(--bg-2);border:1px solid var(--border-1);border-radius:3px;overflow:hidden}.rp-bars-fill{height:100%;background:linear-gradient(90deg,var(--accent),#06b6d4);transition:width .4s ease}.rp-bars-target{position:absolute;top:-2px;bottom:-2px;width:2px;background:var(--warn)}.rp-bars-pct,.rp-bars-val{font-family:var(--font-mono);font-size:11px;color:var(--text-1);font-weight:500;min-width:50px;text-align:right}.rp-donut-wrap{display:grid;grid-template-columns:140px 1fr;gap:18px;align-items:center}.rp-donut{display:block;margin:0 auto}.rp-donut-legend{display:flex;flex-direction:column;gap:6px}.rp-donut-lbl{display:grid;grid-template-columns:auto 1fr auto auto;gap:8px;align-items:center;font-family:var(--font-mono);font-size:10.5px}.rp-donut-dot{width:10px;height:10px;border-radius:2px}.rp-donut-name{color:var(--text-2)}.rp-donut-val{color:var(--text-1);font-weight:500}.rp-donut-num{color:var(--text-3)}.rp-stack{display:flex;height:32px;border-radius:4px;overflow:hidden;border:1px solid var(--border-1)}.rp-stack-seg{display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:10px;color:#ffffffd9;font-weight:500;transition:all .3s;min-width:0;overflow:hidden}.rp-line{width:100%;height:200px}.rp-line-axis line{stroke:var(--border-1);stroke-width:.3}.rp-line-axis text{fill:var(--text-3);font-family:var(--font-mono);font-size:9px}.rp-line-grid line{stroke:var(--border-1);stroke-width:.2;stroke-dasharray:1 1}.rp-heat-grid{display:grid;gap:2px}.rp-heat-cell{width:100%;aspect-ratio:1;border-radius:1px;transition:opacity .12s}.rp-heat-cell:hover{outline:1px solid var(--accent)}.rp-heat-row-label,.rp-heat-col-label{font-family:var(--font-mono);font-size:9px;color:var(--text-3)}.rp-event{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--border-1)}.rp-event:last-child{border-bottom:none}.rp-event-dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}.rp-event-body{flex:1}.rp-event-title{font-size:12px;color:var(--text-1);font-weight:500}.rp-event-sub{font-family:var(--font-mono);font-size:10px;color:var(--text-3);margin-top:2px}.iti-page{flex:1;display:flex;flex-direction:column;overflow:hidden}.iti-toolbar{display:flex;gap:8px;align-items:center;padding:10px 16px;background:var(--bg-1);border-bottom:1px solid var(--border-1);flex-wrap:wrap}.iti-list{flex:1;overflow-y:auto;padding:16px}.iti-empty{text-align:center;padding:60px 20px;color:var(--text-3);font-family:var(--font-mono);font-size:12px;letter-spacing:.06em}.iti-group{margin-bottom:18px}.iti-group-header{display:flex;align-items:center;gap:12px;padding:8px 4px;margin-bottom:8px;border-bottom:1px solid var(--border-1)}.iti-group-day{font-family:var(--font-mono);font-size:22px;font-weight:600;color:var(--text-1);line-height:1}.iti-group-weekday{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;color:var(--text-3);text-transform:uppercase;margin-top:2px}.iti-group-date{display:flex;flex-direction:column}.iti-group-title{font-size:14px;font-weight:600;color:var(--text-1);letter-spacing:.02em}.iti-group-line{flex:1;height:1px;background:var(--border-1)}.iti-group-count{font-family:var(--font-mono);font-size:10px;color:var(--text-3);letter-spacing:.06em}.iti-group-chip{background:var(--bg-2);border:1px solid var(--border-1);padding:3px 8px;border-radius:3px;font-family:var(--font-mono);font-size:10px;color:var(--text-2);letter-spacing:.04em}.iti-card{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius);padding:14px 16px;margin-bottom:8px;display:grid;grid-template-columns:4px 1fr;gap:12px;cursor:pointer;transition:border-color .12s,background .12s}.iti-card:hover{border-color:var(--border-2);background:var(--bg-2)}.iti-card.selected{border-color:var(--accent);background:#38bdf80d}.iti-card-rail{border-radius:2px;background:var(--text-3)}.iti-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.iti-card-title-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.iti-card-name{font-size:14px;font-weight:600;color:var(--text-1);letter-spacing:.01em}.iti-card-flag{font-family:var(--font-mono);font-size:10px;color:var(--text-3);background:var(--bg-2);border:1px solid var(--border-1);padding:2px 6px;border-radius:2px}.iti-card-type{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;color:var(--text-3);text-transform:uppercase}.iti-card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:12px}.iti-card-meta{display:flex;flex-direction:column;gap:4px}.iti-card-meta-mono{font-family:var(--font-mono);font-size:13px;color:var(--text-1);font-weight:500}.iti-card-meta-sep{margin:0 4px;color:var(--text-3)}.iti-card-route{font-family:var(--font-mono);font-size:11px;color:var(--text-2);margin-top:8px;display:flex;align-items:center;gap:8px}.iti-card-progress{margin-top:10px}.iti-prog-label{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:10px;color:var(--text-3);margin-bottom:4px;letter-spacing:.04em;text-transform:uppercase}.iti-prog-bar{position:relative;height:6px;background:var(--bg-3);border-radius:3px;overflow:hidden}.iti-prog-fill{height:100%;background:linear-gradient(90deg,var(--ok),var(--accent));border-radius:3px;transition:width .4s ease}.iti-prog-now{position:absolute;top:-3px;bottom:-3px;width:2px;background:var(--bad)}.iti-prog-pct{font-family:var(--font-mono);font-size:11px;color:var(--text-1);font-weight:500}.sst-tray{position:relative;background:linear-gradient(180deg,var(--bg-2),var(--bg-1));border-top:1px solid var(--border-2);display:flex;flex-direction:column;flex-shrink:0;z-index:5}.sst-tray.closed{max-height:38px}.sst-tray.open{max-height:220px}.sst-header{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:1px solid var(--border-1)}.sst-header-left{display:flex;align-items:center;gap:10px}.sst-title{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;font-weight:600;color:var(--warn)}.sst-badge{background:var(--warn);color:#001226;font-family:var(--font-mono);font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px}.sst-badge.ok{background:var(--ok);color:#fff}.sst-fraction{font-family:var(--font-mono);font-size:10.5px;color:var(--text-3)}.sst-ok-msg{font-family:var(--font-mono);font-size:10.5px;color:var(--ok)}.sst-header-right{display:flex;align-items:center;gap:8px}.sst-toggle{background:var(--bg-2);border:1px solid var(--border-1);color:var(--text-2);width:26px;height:26px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center}.sst-toggle:hover{background:var(--bg-3);color:var(--text-1)}.sst-body{flex:1;display:flex;flex-direction:column;overflow:hidden}.sst-search{display:flex;align-items:center;gap:8px;padding:8px 14px;border-bottom:1px solid var(--border-1)}.sst-search input{flex:1;background:transparent!important;border:none!important;padding:4px 0!important;font-size:12px!important}.sst-search input:focus{background:transparent!important}.sst-loading{font-family:var(--font-mono);font-size:10px;color:var(--text-3)}.sst-cards{flex:1;overflow-x:auto;overflow-y:hidden;display:flex;gap:8px;padding:10px 14px;align-items:stretch}.sst-card{flex-shrink:0;width:220px;background:var(--bg-1);border:1px solid var(--border-2);border-left:3px solid var(--warn);border-radius:var(--radius);padding:9px 12px;cursor:grab;display:flex;flex-direction:column;gap:4px;transition:all .12s}.sst-card:hover{border-color:var(--accent);border-left-color:var(--accent);background:var(--bg-2);transform:translateY(-1px)}.sst-card:active{cursor:grabbing}.sst-card-head{display:flex;justify-content:space-between;align-items:center;gap:8px}.sst-card-name{font-size:12px;font-weight:600;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sst-card-eslora{font-family:var(--font-mono);font-size:10.5px;font-weight:600;color:var(--accent);flex-shrink:0}.sst-card-meta{font-family:var(--font-mono);font-size:10px;color:var(--text-3)}.sst-card-fecha{letter-spacing:.04em}.sst-card-foot{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:9.5px;color:var(--text-3);margin-top:2px}.sst-card-giro{background:var(--bg-2);border:1px solid var(--border-1);padding:1px 6px;border-radius:2px;letter-spacing:.04em}.sst-card-bandera{text-transform:uppercase;letter-spacing:.06em}.sst-more,.sst-empty{align-self:center;padding:10px 16px;font-family:var(--font-mono);font-size:11px;color:var(--text-3)}.gantt{position:relative}.gantt-corner{position:sticky;left:0;z-index:25;background:var(--bg-1)!important}.site-cell{position:sticky;left:0;z-index:20;background:var(--bg-1)}.gantt-side-divider{position:sticky;left:0;z-index:22;display:flex;align-items:center;gap:8px;padding:6px 14px;background:var(--bg-2);border-top:1px solid var(--border-2);border-bottom:1px solid var(--border-1);font-family:var(--font-mono);font-size:9.5px;letter-spacing:.1em;color:var(--text-3);text-transform:uppercase;font-weight:600}.gantt-side-divider:after{content:"";flex:1;height:1px;background:var(--border-1)}.gantt-side-divider.norte{color:#38bdf8}.gantt-side-divider.sur{color:#a78bfa}.gantt-side-divider.flotante{color:#fbbf24}.gantt-side-divider-spacer{background:var(--bg-2);border-top:1px solid var(--border-2);border-bottom:1px solid var(--border-1);height:28px}.site-cell.editable{position:relative}.site-cell.editable:hover{background:#f59e0b14!important;outline:1px solid rgba(245,158,11,.4);outline-offset:-1px}.btn.active-mode{background:#f59e0b1f!important;border-color:var(--warn)!important;color:var(--warn)!important}.confirm-popup{position:fixed;left:50%;bottom:70px;transform:translate(-50%);background:var(--bg-1);border:1px solid var(--accent);border-radius:8px;padding:0;width:380px;z-index:1000;box-shadow:0 10px 40px #00000080,0 0 0 4px #38bdf81f;animation:popupSlideUp .2s ease-out}@keyframes popupSlideUp{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}.confirm-popup-head{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#38bdf81a;border-bottom:1px solid var(--border-1);font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;font-weight:600;color:var(--accent);text-transform:uppercase}.confirm-popup-body{padding:12px 14px;display:flex;flex-direction:column;gap:6px}.confirm-line{display:grid;grid-template-columns:60px 1fr;gap:10px;align-items:center;font-size:12px}.confirm-label{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.06em;color:var(--text-3);text-transform:uppercase}.confirm-value{font-family:var(--font-mono);color:var(--text-1)}.confirm-value strong{color:var(--accent)}.confirm-popup-foot{display:flex;justify-content:flex-end;gap:6px;padding:10px 14px;border-top:1px solid var(--border-1);background:var(--bg-2)}.vessel.preview{outline:2px dashed var(--accent);outline-offset:1px;opacity:.85}.date-nav{height:38px;align-items:stretch}.date-nav .date-label{position:relative;cursor:pointer;display:flex!important;flex-direction:column;justify-content:center;padding:4px 14px!important;min-width:170px;height:100%;line-height:1.15;-webkit-user-select:none;user-select:none;transition:background .12s}.date-nav .date-label:hover{background:var(--bg-3)}.date-nav .date-label .day{display:flex;align-items:center;gap:6px;color:var(--text-1)!important;font-weight:600!important;font-size:12px!important;font-family:var(--font-sans);white-space:nowrap;letter-spacing:.02em}.date-nav .date-label .day svg{opacity:.5}.date-nav .date-label .week{display:block!important;margin-top:3px;font-size:9.5px!important;color:var(--text-3)!important;font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase}.date-picker-hidden{position:absolute!important;top:0!important;right:0!important;bottom:0!important;left:0!important;opacity:0!important;cursor:pointer!important;width:100%!important;height:100%!important;border:none!important;background:transparent!important;padding:0!important;z-index:2}.toolbar{overflow:visible!important;min-height:44px;align-items:center}.toast-stack{position:fixed;bottom:70px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;z-index:1100;pointer-events:none}.toast-cambio{pointer-events:auto;display:flex;align-items:center;gap:10px;background:var(--bg-1);border:1px solid var(--accent);border-radius:8px;padding:10px 14px;min-width:320px;max-width:480px;box-shadow:0 8px 24px #0006,0 0 0 4px #38bdf81a;animation:toastSlideUp .18s ease-out}@keyframes toastSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.toast-cambio>svg{color:var(--ok);flex-shrink:0}.toast-body{flex:1;min-width:0}.toast-title{font-size:12.5px;color:var(--text-1);font-weight:500}.toast-sub{font-family:var(--font-mono);font-size:10.5px;color:var(--text-3);margin-top:1px;letter-spacing:.04em}.toast-undo{background:var(--bg-2);border:1px solid var(--accent);color:var(--accent);padding:5px 10px;border-radius:4px;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.04em;cursor:pointer;display:flex;align-items:center;gap:4px;white-space:nowrap;transition:background .12s}.toast-undo:hover{background:#38bdf826}.toast-x{background:transparent;border:none;color:var(--text-3);cursor:pointer;padding:4px;border-radius:3px}.toast-x:hover{color:var(--text-1);background:var(--bg-2)}.undo-redo-group{display:flex;background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius);overflow:hidden}.undo-redo-group .icon-btn{width:32px;height:28px;border-radius:0;border:none;border-right:1px solid var(--border-1);color:var(--text-2)}.undo-redo-group .icon-btn:last-child{border-right:none}.undo-redo-group .icon-btn:hover:not(:disabled){color:var(--accent);background:var(--bg-3)}.undo-redo-group .icon-btn:disabled{opacity:.3;cursor:not-allowed}.modo-asignar-banner{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:12px;background:linear-gradient(90deg,#38bdf826,#6366f126);border-bottom:2px solid var(--accent);padding:10px 18px;font-family:var(--font-mono);font-size:12px;color:var(--accent);letter-spacing:.04em;animation:bannerSlideDown .2s ease-out}@keyframes bannerSlideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.modo-asignar-banner strong{color:var(--text-1)}.modo-asignar-banner .modo-asignar-hint{font-size:11px;color:var(--text-2);margin-left:auto}.modo-asignar-banner kbd{background:var(--bg-3);border:1px solid var(--border-2);border-radius:2px;padding:1px 6px;font-size:10px;color:var(--text-1);margin:0 2px}.workspace.modo-asignar-activo .site-cell,.workspace.modo-asignar-activo .mm-site{cursor:crosshair!important;outline:1px dashed rgba(56,189,248,.4);outline-offset:-2px}.workspace.modo-asignar-activo .site-cell:hover,.workspace.modo-asignar-activo .mm-site:hover{background:#38bdf826!important;outline-color:var(--accent)}.sin-sitio-detail{background:#f59e0b0d;border:1px solid rgba(245,158,11,.2);border-left:3px solid var(--warn);border-radius:4px;padding:8px 12px}.sin-sitio-head{display:flex;gap:10px;align-items:center;margin-bottom:4px}.sin-sitio-buque{font-size:12px;font-weight:600;color:var(--text-1)}.sin-sitio-eslora,.sin-sitio-calado{font-family:var(--font-mono);font-size:10px;color:var(--text-3);background:var(--bg-2);border:1px solid var(--border-1);padding:1px 6px;border-radius:2px}.sin-sitio-motivo{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--warn);margin:4px 0}.sin-sitio-sol{display:flex;align-items:flex-start;gap:6px;font-size:11px;color:var(--text-2);font-style:italic;margin-top:4px;padding:6px 8px;background:#38bdf80f;border-left:2px solid var(--accent);border-radius:2px}.sin-sitio-sol>svg{color:var(--accent);flex-shrink:0;margin-top:1px}
