:root{color:#e9f1ef;background:#071116;font-family:Segoe UI,SF Pro Text,system-ui,sans-serif;line-height:1.4;font-weight:400;font-size:13px;color-scheme:dark}*{box-sizing:border-box}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:#000000b3}*::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#242424fa,#080808fa);border:1px solid rgba(255,255,255,.06);border-radius:999px}*::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#3a3a3afa,#0e0e0efa)}html,body,#root{margin:0;width:100%;height:100%;overflow:hidden}button,input,select{font:inherit}a{color:#9be5d7;text-decoration:none}.cop-shell{position:relative;width:100vw;height:100vh;overflow:hidden}.map-stage{position:absolute;top:0;right:0;bottom:0;left:0}.map-frame{width:100%;height:100%;border:none}.map-toolbar{position:absolute;top:12px;right:12px;z-index:25;display:grid;gap:8px;justify-items:end;pointer-events:none}.toolbar-pills,.weather-stack{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end;pointer-events:auto}.weather-stack{flex-direction:column;align-items:flex-end}.pill{display:inline-flex;align-items:center;border-radius:999px;padding:6px 10px;background:#030a0eeb;border:1px solid rgba(255,255,255,.1);color:#dfeae7;font-size:11px;line-height:1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.tone-ok{color:#8bf0c5}.tone-info{color:#8fcfff}.tone-warn{color:#ffe07d}.tone-default{color:#dfeae7}.map-weather-card{width:min(320px,calc(100vw - 24px));padding:10px 12px;border-radius:12px;background:#030a0ee6;border:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 18px 42px #00000052;display:grid;gap:3px}.map-weather-card strong{font-size:14px;color:#f3fbf9}.map-weather-card span:last-child,.map-weather-card--point span:last-child{color:#8fb2aa}.map-weather-card--point{border-color:#8fcfff33}.sidebar{position:absolute;top:0;left:0;width:310px;height:100vh;z-index:20;display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,#071218f7,#040a0ef2),radial-gradient(circle at top left,rgba(131,244,223,.1),transparent 45%);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);transform:translate(0);transition:transform .24s ease;overflow:hidden}.sidebar.is-closed{transform:translate(-310px)}.sidebar-header{padding:12px 12px 10px;border-bottom:1px solid rgba(255,255,255,.07)}.sidebar-header h2{margin:2px 0 0;font-size:14px;font-weight:700;letter-spacing:-.02em}.sidebar-inner{flex:1;overflow-y:auto;padding:10px}.sidebar-toggle{position:absolute;top:10px;left:10px;z-index:26;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#030a0eeb;border:1px solid rgba(255,255,255,.12);border-radius:999px;color:#b8d4cf;cursor:pointer;font-size:13px;transition:left .24s ease;box-shadow:0 10px 28px #00000042}.sidebar-toggle.panel-open{left:320px}.sidebar-tabs{display:grid;gap:4px;margin-top:8px}.sidebar-tabs--5{grid-template-columns:repeat(5,1fr)}.sidebar-tabs button{border:1px solid rgba(255,255,255,.08);cursor:pointer;border-radius:8px;padding:7px 8px;background:#ffffff0a;color:#dbe7e3;font-size:11px;font-weight:600;text-align:center}.sidebar-tabs button.is-active{background:linear-gradient(135deg,#83f4df,#70a2ff);color:#061015;border-color:transparent}.panel-stack{display:grid;gap:8px}.panel-block{padding:10px 11px;border:1px solid rgba(255,255,255,.07);border-radius:12px;background:#ffffff08;box-shadow:inset 0 1px #ffffff08}.panel-block h3{margin:0 0 6px;font-size:12px;font-weight:700;letter-spacing:-.01em}.section-kicker,.sidebar-kicker,.overlay-label{display:block;margin:0 0 3px;color:#87cabc;text-transform:uppercase;letter-spacing:.13em;font-size:9px}.panel-copy{margin-top:6px;color:#9cb5b0;font-size:11px}.panel-footnote{margin-top:6px;color:#9cb5b0;font-size:10px}.demo-form{margin-top:8px;display:grid;grid-template-columns:1fr 1fr;gap:7px}.demo-form label,.field-block{display:grid;gap:4px;color:#98afaa;font-size:11px}.demo-form input,.field-block input,.field-block select{width:100%;padding:7px 8px;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#ffffff0d;color:#f1faf8;font-size:12px}.action-row{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.action-row button,.link-button{border:0;cursor:pointer;border-radius:999px;padding:7px 12px;background:linear-gradient(135deg,#83f4df,#70a2ff);color:#061015;font-weight:700;font-size:11px;text-align:center}.button-muted{background:#ffffff12!important;color:#dfeae7!important}.link-button{display:inline-flex;align-items:center;justify-content:center}.weather-card{margin-top:7px;display:grid;gap:4px;padding:9px 10px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:10px;font-size:11px}.weather-card span{color:#9cb5b0}.status-strip{margin-top:7px;display:flex;justify-content:space-between;align-items:center;padding:7px 8px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:10px;font-size:11px}.signal-list,.service-list,.cred-list,.log-list{list-style:none;margin:7px 0 0;padding:0}.signal-list,.service-list,.cred-list{display:grid;gap:5px}.signal-list li,.service-list li,.cred-list li{display:grid;gap:2px;padding:7px 8px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:10px;font-size:11px}.signal-list li span,.service-list li span,.cred-list li span:last-child{color:#9cb5b0}.service-list li{grid-template-columns:1fr auto;align-items:center;gap:8px}.service-list strong{display:block;margin-bottom:2px;font-size:12px}.cred-list li{grid-template-columns:120px 1fr;align-items:center;gap:6px}.cred-list li span:first-child{font-weight:700;font-size:11px}.zone-legend{list-style:none;margin:6px 0 0;padding:0;display:grid;gap:5px}.zone-legend li{display:grid;grid-template-columns:12px 1fr;align-items:start;gap:8px;padding:6px 8px;background:#ffffff08;border-radius:4px;font-size:11px}.zone-legend li strong{display:block;font-size:11px;margin-bottom:2px}.zone-legend li span:not(.zone-dot){color:#6b8c87;font-size:10px;line-height:1.3}.zone-dot{width:10px;height:10px;border-radius:2px;flex-shrink:0;margin-top:2px;opacity:.85}.cred-ok{background:#83f4df0f}.cred-missing{background:#ffc8640f}.cred-missing span:first-child{color:#ffc864}.case-log-panel{position:absolute;left:50%;transform:translate(-50%);bottom:12px;width:300px;max-height:220px;z-index:20;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:#030a0ee6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);overflow-y:auto;display:flex;flex-direction:column;box-shadow:0 22px 44px #00000052}.log-header{padding:8px 10px;font-size:9px;color:#87cabc;text-transform:uppercase;letter-spacing:.13em;border-bottom:1px solid rgba(255,255,255,.07);position:sticky;top:0;background:#030a0ef7}.log-list{margin:0}.log-list li{display:flex;justify-content:space-between;align-items:baseline;gap:8px;padding:7px 10px;border-bottom:1px solid rgba(255,255,255,.04);font-size:11px}.log-list li span{color:#dfeae7;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.log-list li time{color:#9cb5b0;font-size:10px;white-space:nowrap}.map-cursor-hint,.map-banner,.overlay-card,.replay-time-overlay,.scenario-modal,.cone-panel{box-shadow:0 18px 42px #0000004d}.map-cursor-hint{position:absolute;z-index:30;max-width:220px;padding:6px 10px;border-radius:10px;font-size:11px;color:#def9f3;pointer-events:none;background:#030a0eeb;border:1px solid rgba(255,255,255,.1)}.map-banner{position:absolute;top:12px;left:12px;z-index:20;padding:6px 10px;border-radius:999px;color:#e9f1ef;background:#030a0eeb;border:1px solid rgba(255,255,255,.09);font-size:11px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.map-banner.sidebar-open{left:322px}.map-banner.error{color:#ffd3ca}.map-overlay{position:absolute;left:12px;bottom:12px;z-index:16;display:grid;gap:6px;width:240px}.map-overlay.sidebar-open{left:322px}.map-overlay--top{top:12px;bottom:auto}.overlay-card{padding:9px 10px;background:#030a0ee0;border:1px solid rgba(255,255,255,.08);border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.overlay-card strong{display:block;margin-bottom:2px;font-size:12px}.overlay-card span:last-child{color:#9ab4af;font-size:11px}.overlay-card--interactive{border-color:#83f4df29}.layer-badge{display:inline-block;padding:3px 8px;border-radius:999px;font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:5px}.layer-badge--live{background:#83f4df2e;color:#83f4df;border:1px solid rgba(131,244,223,.3)}.layer-badge--api{background:#70a2ff2e;color:#70a2ff;border:1px solid rgba(112,162,255,.3)}.layer-endpoints{margin-top:7px;display:grid;gap:4px}.layer-endpoints code{display:block;padding:6px 8px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:8px;font-size:10px;font-family:Consolas,Fira Mono,monospace;color:#9be5d7;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ais-warning{padding:8px 10px;background:#ffb43214;border:1px solid rgba(255,180,50,.18);border-radius:12px;color:#ffd98c;font-size:11px}.scenario-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:60;background:#0000008c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center}.scenario-modal{width:360px;max-height:92vh;overflow-y:auto;background:#030a0efa;border:1px solid rgba(131,244,223,.2);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);padding:14px;border-radius:16px}.scenario-header{margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.07)}.scenario-types{display:grid;grid-template-columns:1fr 1fr;gap:5px;margin-bottom:12px}.scenario-type-btn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 5px;border:1px solid rgba(255,255,255,.09);border-radius:10px;background:#ffffff0a;color:#c8dfd9;font-size:10px;cursor:pointer;text-align:center;transition:border-color .15s,background .15s}.scenario-type-btn:hover{border-color:#83f4df4d}.scenario-type-btn.is-active{background:#83f4df1f;border-color:#83f4df80;color:#cffffa}.scenario-icon{font-size:18px;line-height:1}.scenario-params,.scenario-vessel{margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.06)}.param-toggles{display:grid;gap:5px}.param-toggle{display:flex;align-items:center;gap:7px;font-size:11px;color:#c8dfd9;cursor:pointer}.param-toggle input[type=checkbox]{accent-color:#83f4df}.param-effect{margin-left:auto;color:#83f4df;font-size:10px;font-weight:700}.cone-panel{position:absolute;bottom:12px;right:12px;top:auto;transform:none;width:292px;z-index:35;background:#030a0ef5;border:1px solid rgba(255,224,109,.22);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;max-height:calc(100vh - 220px);overflow-y:auto}.cone-panel-header{padding:11px 12px 9px;border-bottom:1px solid rgba(255,255,255,.07);position:sticky;top:0;background:#030a0efc;z-index:1}.cone-close-btn{background:none;border:none;color:#9cb5b0;cursor:pointer;font-size:12px;padding:2px 4px}.cone-section{padding:9px 12px;border-bottom:1px solid rgba(255,255,255,.05)}.cone-row{display:flex;justify-content:space-between;align-items:center;gap:10px;font-size:11px;padding:2px 0}.cone-row span{color:#9cb5b0}.cone-row strong{color:#e9f1ef;text-align:right}.maritime-zone-badge{display:inline-block;padding:4px 8px;border:1px solid;border-radius:999px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.cone-authority-box{padding:7px 8px;background:#ffffff0a;border:1px solid rgba(255,255,255,.07);border-radius:10px;font-size:11px;display:grid;gap:2px}.cone-authority-box span{color:#9cb5b0;font-size:10px}.risk-chip-list{display:flex;flex-wrap:wrap;gap:6px}.risk-chip{display:inline-flex;align-items:center;padding:5px 8px;border-radius:999px;background:#ff783c1a;border:1px solid rgba(255,180,80,.18);color:#ffd59a;font-size:10px}.cone-forecast-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.cone-forecast-cell{padding:7px 8px;border-radius:10px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);display:grid;gap:2px;font-size:10px}.cone-forecast-cell strong{font-size:11px}.cone-forecast-cell span{color:#9cb5b0}.sim-history-list{display:grid;gap:5px;margin-top:5px}.sim-history-item{background:#ffffff0a;border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:7px 8px;display:grid;gap:5px}.sim-history-meta{display:flex;gap:8px;align-items:flex-start}.sim-history-icon{font-size:18px;line-height:1;padding-top:1px}.sim-history-info{flex:1;display:grid;gap:1px;min-width:0}.sim-history-info strong{font-size:11px;color:#e9f1ef}.sim-history-info span{font-size:10px;color:#9cb5b0}.sim-history-actions{display:flex;gap:4px;justify-content:flex-end}.sim-replay-btn,.sim-load-btn,.sim-delete-btn{border:1px solid rgba(255,255,255,.1);border-radius:999px;padding:4px 8px;font-size:12px;cursor:pointer}.sim-replay-btn{background:#83f4df1a;color:#83f4df}.sim-replay-btn.is-active{background:#83f4df40;border-color:#83f4df80}.sim-load-btn{background:#70a2ff1a;color:#70a2ff}.sim-delete-btn{background:#ff646414;color:#ff9696}.sim-replay-bar{display:flex;align-items:center;gap:6px;font-size:10px;color:#83f4df}.sim-replay-progress{flex:1;height:3px;background:#83f4dfb3;border-radius:2px;transition:width .5s linear}.replay-time-overlay{position:absolute;bottom:54px;left:50%;transform:translate(-50%);z-index:30;padding:5px 12px;background:#030a0eeb;border:1px solid rgba(255,224,109,.45);border-radius:999px;color:#ffe066;font-size:13px;font-weight:700;letter-spacing:.05em;pointer-events:none}.forecast-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;margin-top:7px}.forecast-cell{padding:6px 4px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:10px;text-align:center;font-size:10px;display:grid;gap:2px}.forecast-cell strong{font-size:11px;color:#e9f1ef}.forecast-cell span{color:#9cb5b0}@media(max-width:860px){.map-toolbar{left:12px;right:12px;justify-items:stretch}.toolbar-pills,.weather-stack{justify-content:flex-start}.map-weather-card{width:100%}.case-log-panel{width:calc(100% - 24px);left:12px;transform:none}}@media(max-width:680px){.sidebar{width:100vw}.sidebar.is-closed{transform:translate(-100vw)}.sidebar-toggle.panel-open{left:calc(100vw - 42px)}.map-banner.sidebar-open,.map-overlay.sidebar-open{left:12px}.map-overlay{width:calc(100% - 24px)}.case-log-panel{width:calc(100% - 24px);max-height:180px}.cone-panel{left:12px;right:12px;width:auto}}
