:root,:host{--ol-background-color:white;--ol-accent-background-color:#f5f5f5;--ol-subtle-background-color:#80808040;--ol-partial-background-color:#ffffffbf;--ol-foreground-color:#333;--ol-subtle-foreground-color:#666;--ol-brand-color:#0af}.ol-box{box-sizing:border-box;border:1.5px solid var(--ol-background-color);background-color:var(--ol-partial-background-color);border-radius:2px}.ol-mouse-position{position:absolute;top:8px;right:8px}.ol-scale-line{background:var(--ol-partial-background-color);border-radius:4px;padding:2px;position:absolute;bottom:8px;left:8px}.ol-scale-line-inner{border:1px solid var(--ol-subtle-foreground-color);color:var(--ol-foreground-color);text-align:center;will-change:contents, width;border-top:none;margin:1px;font-size:10px;transition:all .25s}.ol-scale-bar{position:absolute;bottom:8px;left:8px}.ol-scale-bar-inner{display:flex}.ol-scale-step-marker{background-color:var(--ol-foreground-color);float:right;z-index:10;width:1px;height:15px}.ol-scale-step-text{z-index:11;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);font-size:10px;position:absolute;bottom:-5px}.ol-scale-text{text-align:center;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);font-size:12px;position:absolute;bottom:25px}.ol-scale-singlebar{z-index:9;box-sizing:border-box;border:1px solid var(--ol-foreground-color);height:10px;position:relative}.ol-scale-singlebar-even{background-color:var(--ol-subtle-foreground-color)}.ol-scale-singlebar-odd{background-color:var(--ol-background-color)}.ol-unsupported{display:none}.ol-viewport,.ol-unselectable{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.ol-viewport canvas{all:unset;overflow:hidden}.ol-viewport{touch-action:pan-x pan-y}.ol-selectable{-webkit-touch-callout:default;-webkit-user-select:text;user-select:text}.ol-grabbing{cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.ol-grab{cursor:move;cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.ol-control{background-color:var(--ol-subtle-background-color);border-radius:4px;position:absolute}.ol-zoom{top:.5em;left:.5em}.ol-rotate{transition:opacity .25s linear,visibility linear;top:.5em;right:.5em}.ol-rotate.ol-hidden{opacity:0;visibility:hidden;transition:opacity .25s linear,visibility 0s linear .25s}.ol-zoom-extent{top:4.643em;left:.5em}.ol-full-screen{top:.5em;right:.5em}.ol-control button{color:var(--ol-subtle-foreground-color);font-weight:700;font-size:inherit;text-align:center;background-color:var(--ol-background-color);border:none;border-radius:2px;width:1.375em;height:1.375em;margin:1px;padding:0;line-height:.4em;text-decoration:none;display:block}.ol-control button::-moz-focus-inner{border:none;padding:0}.ol-zoom-extent button{line-height:1.4em}.ol-compass{will-change:transform;font-weight:400;display:block}.ol-touch .ol-control button{font-size:1.5em}.ol-touch .ol-zoom-extent{top:5.5em}.ol-control button:hover,.ol-control button:focus{outline:1px solid var(--ol-subtle-foreground-color);color:var(--ol-foreground-color);text-decoration:none}.ol-zoom .ol-zoom-in{border-radius:2px 2px 0 0}.ol-zoom .ol-zoom-out{border-radius:0 0 2px 2px}.ol-attribution{text-align:right;flex-flow:row-reverse;align-items:center;max-width:calc(100% - 1.3em);display:flex;bottom:.5em;right:.5em}.ol-attribution a{color:var(--ol-subtle-foreground-color);text-decoration:none}.ol-attribution ul{color:var(--ol-foreground-color);text-shadow:0 0 2px var(--ol-background-color);margin:0;padding:1px .5em;font-size:12px}.ol-attribution li{list-style:none;display:inline}.ol-attribution li:not(:last-child):after{content:" "}.ol-attribution img{max-height:2em;max-width:inherit;vertical-align:middle}.ol-attribution button{flex-shrink:0}.ol-attribution.ol-collapsed ul{display:none}.ol-attribution:not(.ol-collapsed){background:var(--ol-partial-background-color)}.ol-attribution.ol-uncollapsible{border-radius:4px 0 0;bottom:0;right:0}.ol-attribution.ol-uncollapsible img{max-height:1.6em;margin-top:-.2em}.ol-attribution.ol-uncollapsible button{display:none}.ol-zoomslider{height:200px;top:4.5em;left:.5em}.ol-zoomslider button{height:10px;position:relative}.ol-touch .ol-zoomslider{top:5.5em}.ol-overviewmap{bottom:.5em;left:.5em}.ol-overviewmap.ol-uncollapsible{border-radius:0 4px 0 0;bottom:0;left:0}.ol-overviewmap .ol-overviewmap-map,.ol-overviewmap button{display:block}.ol-overviewmap .ol-overviewmap-map{border:1px solid var(--ol-subtle-foreground-color);width:150px;height:150px}.ol-overviewmap:not(.ol-collapsed) button{position:absolute;bottom:0;left:0}.ol-overviewmap.ol-collapsed .ol-overviewmap-map,.ol-overviewmap.ol-uncollapsible button{display:none}.ol-overviewmap:not(.ol-collapsed){background:var(--ol-subtle-background-color)}.ol-overviewmap-box{border:1.5px dotted var(--ol-subtle-foreground-color)}.ol-overviewmap .ol-overviewmap-box:hover{cursor:move}.ol-overviewmap .ol-viewport:hover{cursor:pointer}:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#050b12;--surface:#0b1420;--surface-2:#111c2a;--cockpit:#07111c;--border:#1e3145;--text:#f3f7fa;--text-2:#a8b3c2;--text-3:#6f7d8d;--cyan:#18aeef;--cyan-soft:#59cfff;--amber:#ff9a3d;--green:#3ddc84;--warn:#ffb84d;--red:#ff5c5c;--radius-sm:10px;--radius:16px;--radius-lg:24px;--shadow:0 20px 50px #00000052;--safe-bottom:env(safe-area-inset-bottom,0px);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#root{width:100%;min-height:100%;margin:0}body{background:var(--bg);color:var(--text);overflow-x:hidden}button,input,select,textarea{font:inherit}button{color:inherit}h1,h2,p{margin:0}h1{letter-spacing:-.03em;font-size:clamp(1.45rem,4vw,2rem);line-height:1.08}h2{letter-spacing:-.01em;font-size:1rem}p{color:var(--text-2);line-height:1.45}img{display:block}.app-shell{background:radial-gradient(circle at 50% -20%, #18aeef26, transparent 42%), var(--bg);grid-template-rows:auto 1fr auto;min-height:100dvh;display:grid}.header-bar{z-index:50;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#050b12eb;border-bottom:1px solid #1e3145b8;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px 10px;display:flex;position:sticky;top:0}.brand-block{align-items:center;gap:10px;min-width:0;display:flex}.brand-block img{width:38px;height:38px}.brand-block strong{letter-spacing:.06em;font-size:1.05rem;display:block}.brand-block span{color:var(--cyan-soft);letter-spacing:.22em;text-transform:uppercase;font-size:.7rem;display:block}.header-status{color:var(--text-2);text-transform:uppercase;align-items:center;gap:8px;font-size:.74rem;display:none}.header-status span{border:1px solid var(--border);background:#111c2ac7;border-radius:999px;padding:6px 9px}.app-main{width:100%;max-width:1180px;padding:14px 14px calc(92px + var(--safe-bottom));margin:0 auto}.page{gap:14px;display:grid}.page-heading{gap:5px;display:grid}.page-heading p{font-size:.92rem}.bottom-nav{z-index:70;padding:8px 10px calc(8px + var(--safe-bottom));border-top:1px solid var(--border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#050b12f0;grid-template-columns:repeat(5,1fr);gap:2px;display:grid;position:fixed;bottom:0;left:0;right:0}.bottom-nav button{min-height:54px;color:var(--text-3);cursor:pointer;background:0 0;border:0;border-radius:14px;place-items:center;gap:2px;display:grid}.bottom-nav button span{font-size:1.08rem;line-height:1}.bottom-nav button strong{font-size:.68rem;font-weight:650}.bottom-nav button.active{color:var(--cyan-soft);background:#18aeef1a}.btn{border:1px solid var(--border);letter-spacing:.01em;cursor:pointer;border-radius:13px;min-height:48px;padding:0 16px;font-weight:750;transition:transform .12s,border-color .12s,background .12s}.btn:active{transform:scale(.98)}.btn-primary{background:var(--cyan);border-color:var(--cyan);color:#03111a}.btn-secondary{color:var(--text);background:#111c2af2}.btn-ghost{color:var(--text-2);background:0 0}.btn-danger{color:#ffdcdc;background:#ff5c5c24;border-color:#ff5c5c73}.card{border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);background:linear-gradient(#111c2af5,#07111cf5);padding:14px}.home-screen{gap:14px;display:grid}.hero-card{border-radius:var(--radius-lg);border:1px solid var(--border);background:linear-gradient(#050b1214,#050b12f5),radial-gradient(circle at 70% 28%,#59cfff3d,#0000 24%),linear-gradient(140deg,#132436 0%,#07111c 50%,#050b12 100%);min-height:260px;position:relative;overflow:hidden}.hero-overlay{opacity:.85;background:linear-gradient(120deg,#0000 0 45%,#18aeef29 46% 47%,#0000 48% 100%),radial-gradient(circle at 65% 42%,#f3f7fa21,#0000 10%);position:absolute;inset:0}.hero-content{z-index:1;align-content:end;gap:5px;min-height:260px;padding:24px;display:grid;position:relative}.hero-content img{width:58px;height:58px;margin-bottom:18px}.hero-content span{color:var(--text-2);text-transform:uppercase;letter-spacing:.12em;font-size:.75rem}.hero-content h1{letter-spacing:.04em;font-size:2.35rem}.hero-content p{color:var(--cyan-soft);text-transform:uppercase;letter-spacing:.22em;font-size:.8rem}.hero-content strong{color:var(--text);margin-top:14px;font-size:1.05rem}.home-actions{gap:10px;display:grid}.system-card,.safety-card{gap:12px;display:grid}.system-badges{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.system-badge{border:1px solid var(--border);min-height:72px;color:var(--text-2);text-align:center;border-radius:13px;place-items:center;gap:2px;font-size:.72rem;display:grid}.system-badge strong{color:var(--text);text-transform:uppercase;font-size:.82rem;display:block}.system-badge.green{border-color:#3ddc8459}.system-badge.cyan{border-color:#18aeef66}.system-badge.amber{border-color:#ff9a3d66}.planning-layout,.calculation-grid,.zones-screen,.more-grid{gap:14px;display:grid}.map-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--cockpit);min-height:440px;position:relative;overflow:hidden}.map-card.tall{min-height:min(64vh,640px)}.route-panel{gap:12px;display:grid}.panel-title-row,.route-actions-row,.bottom-action-row{justify-content:space-between;align-items:center;gap:10px;display:flex}.panel-title-row span{color:var(--text-2);text-transform:uppercase;font-size:.78rem;display:block}.panel-title-row strong{margin-top:2px;display:block}.panel-title-row button{color:var(--cyan-soft);cursor:pointer;background:0 0;border:0;font-weight:750}.route-point-list{gap:5px;display:grid}.route-point{cursor:pointer;background:#07111c85;border:1px solid #1e3145c7;border-radius:13px;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;min-height:42px;padding:6px 7px;display:grid}.route-point.active{background:#18aeef14;border-color:#59cfffa8}.route-point small{color:var(--text-3);display:block}.point-chip{background:var(--cyan);color:#03111a;border-radius:999px;place-items:center;width:24px;height:24px;font-weight:900;display:grid}.metric-grid,.cockpit-value-grid,.tracking-metrics-top{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.cockpit-value-grid{grid-template-columns:repeat(4,1fr)}.metric-card{border:1px solid var(--border);background:#07111cbd;border-radius:14px;align-content:center;gap:3px;min-height:78px;padding:12px;display:grid}.metric-card span{color:var(--text-3);text-transform:uppercase;font-size:.68rem}.metric-card strong{letter-spacing:-.03em;font-size:clamp(1.1rem,4vw,1.7rem)}.metric-card small{color:var(--text-2)}.metric-card.strong strong{font-size:clamp(1.55rem,6vw,2.3rem)}.branch-table{border:1px solid #1e3145c7;border-radius:13px;display:grid;overflow:hidden}.branch-row{border-bottom:1px solid #1e31458f;grid-template-columns:1.5fr repeat(6,.7fr);gap:8px;padding:10px;font-size:.78rem;display:grid}.branch-row:last-child{border-bottom:0}.branch-row.head{color:var(--text-3);text-transform:uppercase;background:#07111cb8;font-size:.66rem}.zone-ribbon-block{gap:12px;display:grid}.zone-ribbon{scroll-snap-type:x mandatory;grid-auto-columns:minmax(142px,1fr);grid-auto-flow:column;gap:8px;padding-bottom:4px;display:grid;overflow-x:auto}.zone-card{border:1px solid var(--border);min-height:142px;color:var(--text);text-align:left;scroll-snap-align:start;cursor:pointer;background:#07111cbd;border-radius:14px;align-content:center;gap:4px;padding:12px;display:grid}.zone-card small,.zone-card span{color:var(--text-3)}.zone-card em{color:var(--text-2);font-style:normal;font-weight:800}.zone-card.traversee,.zone-detail.traversee{border-color:#18aeefb8}.zone-card.proche,.zone-detail.proche{border-color:#ff9a3db8}.zone-card.libre,.zone-detail.libre{border-color:#6f7d8d73}.zone-card.active{background:#18aeef1f}.zone-detail{border:1px solid var(--border);background:#07111ca6;border-radius:14px;gap:6px;padding:12px;display:grid}.zone-detail span,.zone-detail small{color:var(--text-3)}.tracking-screen{gap:12px;display:grid}.tracking-map-panel{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--cockpit);min-height:42vh;overflow:hidden}.tracking-panel{gap:10px;display:grid}.cockpit-badges{grid-template-columns:repeat(4,1fr);gap:7px;display:grid}.cockpit-badge{border:1px solid var(--border);text-transform:uppercase;text-align:center;background:#07111cbd;border-radius:12px;place-items:center;min-height:44px;font-size:.68rem;font-weight:900;display:grid}.cockpit-badge.ok{color:var(--green);border-color:#3ddc8461}.cockpit-badge.rec{color:var(--amber);border-color:#ff9a3d73}.cockpit-badge.warn{color:var(--warn);border-color:#ffb84d73}.cockpit-badge.off{color:var(--text-3)}.deviation-gauge{border:1px solid var(--border);border-radius:var(--radius);background:#07111cd1;gap:10px;padding:16px;display:grid}.deviation-gauge>span{color:var(--text-3);text-transform:uppercase;text-align:center;font-size:.72rem}.deviation-value{justify-content:center;align-items:baseline;gap:6px;display:flex}.deviation-value strong{letter-spacing:-.06em;font-size:clamp(2.6rem,12vw,4.5rem)}.deviation-value em{color:var(--text-2);font-style:normal;font-weight:800}.deviation-value b{color:var(--amber);font-size:.92rem}.deviation-scale{color:var(--text-3);text-transform:uppercase;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;font-size:.7rem;display:grid}.scale-line{border-bottom:1px solid var(--border);height:18px;position:relative}.scale-line:before{content:"";border-left:1px solid var(--text-2);position:absolute;top:2px;bottom:-5px;left:50%}.scale-line i{background:var(--amber);border-radius:999px;width:4px;height:18px;position:absolute;bottom:-5px;left:calc(50% - 2px)}.next-zone-card span,.next-zone-card p{color:var(--text-2)}.next-zone-card strong{color:var(--cyan-soft);margin:4px 0;display:block}.tracking-actions{grid-template-columns:1fr 1fr;gap:8px;display:grid}.tracking-actions .btn-danger{grid-column:1/-1}.gps-warning{border-color:#ffb84d73}.traces-list{gap:10px;display:grid}.trace-item{border:1px solid var(--border);border-radius:var(--radius);background:#111c2adb;gap:12px;padding:14px;display:grid}.trace-item span,.trace-item dt{color:var(--text-3)}.trace-item dl{grid-template-columns:repeat(3,1fr);gap:8px;margin:0;display:grid}.trace-item dd{color:var(--text);margin:0;font-weight:800}.trace-actions{gap:8px;display:flex}.empty-state{border:1px dashed var(--border);border-radius:var(--radius);text-align:center;min-height:180px;color:var(--text-2);place-items:center;padding:20px;display:grid}.empty-state strong{color:var(--text)}.dialog-backdrop{z-index:100;background:#000000ad;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.dialog{border:1px solid var(--border);background:var(--surface);width:min(420px,100%);box-shadow:var(--shadow);border-radius:20px;gap:12px;padding:18px;display:grid;position:relative}.dialog-actions{justify-content:flex-end;gap:8px;display:flex}.dialog-close{color:var(--text-2);cursor:pointer;background:0 0;border:0;font-size:1.6rem;position:absolute;top:10px;right:12px}.route-builder{grid-template-columns:1fr 1fr auto;align-items:end;gap:8px;display:grid}.route-builder label{gap:4px;display:grid}.route-builder label span{color:var(--text-3);text-transform:uppercase;font-size:.64rem;font-weight:850}.route-builder input{width:100%;height:38px;color:var(--text);letter-spacing:.08em;text-transform:uppercase;background:#050b12d1;border:1px solid #1e3145e6;border-radius:11px;outline:none;padding:0 10px;font-size:.94rem;font-weight:900}.route-builder input:focus{border-color:#59cfffcc}.route-builder-reverse{min-height:38px;padding:0 10px}.route-summary-line{min-height:36px;color:var(--text-2);background:#07111c94;border:1px solid #1e3145c2;border-radius:12px;grid-template-columns:1fr auto auto;align-items:center;gap:8px;padding:0 10px;font-size:.8rem;display:grid}.route-summary-line strong{color:var(--cyan-soft)}.route-hint{min-height:26px;color:var(--text-3);font-size:.72rem}.route-point-main strong{letter-spacing:.04em;font-size:.88rem;display:block}.route-point-main small{font-size:.66rem}.route-point-remove{border-radius:9px;width:32px;min-height:28px;padding:0}.compact-route-panel{align-content:start}.planning-map-card{min-height:min(66vh,680px)}.flight-profile-panel{grid-template-columns:.72fr .9fr 1.38fr;gap:8px;display:grid}.flight-profile-panel label{gap:4px;display:grid}.flight-profile-panel label span{color:var(--text-3);text-transform:uppercase;font-size:.64rem;font-weight:850}.flight-profile-panel input{width:100%;height:38px;color:var(--text);background:#050b12d1;border:1px solid #1e3145e6;border-radius:11px;outline:none;padding:0 10px;font-size:.9rem;font-weight:800}.weather-action-row{grid-template-columns:1fr auto;align-items:center;gap:8px;display:grid}.weather-action-row span{min-height:38px;color:var(--text-2);background:#07111c94;border:1px solid #1e3145c2;border-radius:12px;align-items:center;padding:0 10px;font-size:.76rem;display:flex}.navlog-screen{gap:14px;display:grid}.navlog-summary-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;display:grid}.navlog-summary-card{background:linear-gradient(#111c2aeb,#07111ceb);border:1px solid #1e3145d1;border-radius:14px;align-content:center;gap:3px;min-height:78px;padding:11px 12px;display:grid}.navlog-summary-card span{color:var(--text-3);text-transform:uppercase;font-size:.64rem;font-weight:850}.navlog-summary-card strong{color:var(--text);letter-spacing:-.02em;font-size:clamp(1rem,1.6vw,1.28rem)}.navlog-summary-card small{color:var(--text-2);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.navlog-card{padding:0;overflow:hidden}.navlog-card .panel-title-row{border-bottom:1px solid #1e3145b8;padding:14px 16px}.navlog-table{border:0;border-radius:0}.navlog-table .branch-row{grid-template-columns:minmax(112px,1.42fr) 72px 82px 58px 56px 58px 70px 58px 58px 70px 78px 76px minmax(118px,1.2fr);gap:0;min-width:980px;padding:0;font-size:.78rem}.navlog-table .branch-row span{border-right:1px solid #1e31459e;align-items:center;min-height:48px;padding:0 10px;display:flex}.navlog-table .branch-row span:last-child{border-right:0}.navlog-table .branch-row.head span{min-height:56px;color:var(--text-2);align-items:center;line-height:1.15}.navlog-table .branch-row.head small{color:var(--text-3);text-transform:lowercase;font-size:.62rem}.navlog-table .branch-row.total{background:#18aeef0b;font-weight:850}.branch-alt-input{width:58px;height:30px;color:var(--text);text-align:center;background:#050b12c7;border:1px solid #1e3145e6;border-radius:9px;outline:none;font-size:.76rem;font-weight:850}.branch-alt-input:focus{border-color:#59cfffc7}.navlog-bottom-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.navlog-zones-card,.navlog-notes-card{align-content:start;gap:12px;display:grid}.navlog-zones-card h2,.navlog-notes-card h2{color:var(--cyan-soft);text-transform:uppercase;font-size:.9rem}.navlog-zone-chips{flex-wrap:wrap;gap:8px;display:flex}.zone-chip{min-width:130px;color:var(--text);background:#07111c9e;border:1px solid #18aeef80;border-radius:10px;padding:8px 10px;font-size:.78rem;font-weight:850}.zone-chip b{float:right;color:var(--text-2)}.zone-chip small{color:var(--text-3);margin-top:3px;font-weight:650;display:block}.zone-chip.amber{color:#ffd7a8;border-color:#ff9a3db8}.zone-chip.green{color:#b8ffd7;border-color:#3ddc84a8}.pilot-notes-box{min-height:112px;color:var(--text-2);background:#07111c94;border:1px solid #1e3145b8;border-radius:13px;gap:6px;padding:13px;display:grid}.pilot-notes-box small{color:var(--text-3)}.navlog-actions{justify-content:space-between;align-items:center;gap:12px;display:flex}.navlog-actions>div{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}@media (width<=980px){.navlog-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.navlog-card{overflow-x:auto}.navlog-bottom-grid{grid-template-columns:1fr}.navlog-actions{display:grid}.navlog-actions>div{justify-content:stretch}.navlog-actions .btn{flex:1}}@media (width<=520px){.flight-profile-panel,.weather-action-row{grid-template-columns:1fr}}.route-builder{grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto}.route-builder input,.flight-profile-panel input{min-width:0}.route-builder input,.flight-profile-panel input,.branch-alt-input{appearance:textfield}.route-builder input::-webkit-outer-spin-button{appearance:none;margin:0}.route-builder input::-webkit-inner-spin-button{appearance:none;margin:0}.flight-profile-panel input::-webkit-outer-spin-button{appearance:none;margin:0}.flight-profile-panel input::-webkit-inner-spin-button{appearance:none;margin:0}.branch-alt-input::-webkit-outer-spin-button{appearance:none;margin:0}.branch-alt-input::-webkit-inner-spin-button{appearance:none;margin:0}@media (width<=520px){.route-panel{gap:9px}.panel-title-row{align-items:start}.route-builder{grid-template-columns:1fr 1fr auto;gap:7px}.route-builder label span,.flight-profile-panel label span{letter-spacing:.04em;font-size:.58rem}.route-builder input{border-radius:10px;height:36px;padding:0 9px;font-size:.88rem}.route-builder-reverse{height:36px;min-height:36px;padding:0 8px;font-size:.78rem}.flight-profile-panel{grid-template-columns:.72fr .95fr 1.05fr;gap:7px}.flight-profile-panel input{text-align:center;border-radius:10px;height:36px;padding:0 8px;font-size:.86rem}.weather-action-row{grid-template-columns:.82fr 1.18fr;gap:8px}.weather-action-row span{min-height:42px;padding:0 10px;font-size:.72rem;line-height:1.15}.weather-action-row .btn{min-height:42px;padding:0 10px;font-size:.86rem;line-height:1.15}.route-summary-line{min-height:34px;font-size:.74rem}}@media (width<=360px){.route-builder{grid-template-columns:1fr 1fr}.route-builder-reverse{grid-column:1/-1}.flight-profile-panel{grid-template-columns:1fr 1fr}.flight-profile-panel label:last-child{grid-column:1/-1}}.flight-profile-panel-compact{grid-template-columns:1fr 1fr}@media (width<=520px){.flight-profile-panel-compact{grid-template-columns:1fr 1fr}.flight-profile-panel-compact label:last-child{grid-column:auto}}@media (width<=360px){.flight-profile-panel-compact label:last-child{grid-column:auto}}.weather-audit-card{padding:0;overflow:hidden}.weather-audit-card .panel-title-row{border-bottom:1px solid #1e3145b8;padding:14px 16px}.weather-audit-list{display:grid}.weather-audit-row{background:#07111c59;border-bottom:1px solid #1e314585;gap:10px;padding:13px 16px;display:grid}.weather-audit-row:last-child{border-bottom:0}.weather-audit-row.ok{box-shadow:inset 3px 0 #3ddc84b8}.weather-audit-row.missing{box-shadow:inset 3px 0 #ff9a3dcc}.weather-audit-main{justify-content:space-between;align-items:center;gap:10px;display:flex}.weather-audit-main strong{color:var(--text);font-size:.9rem}.weather-audit-main span{color:var(--cyan-soft);font-weight:850}.weather-audit-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.weather-audit-grid span{min-height:44px;color:var(--text-2);text-overflow:ellipsis;background:#050b128c;border:1px solid #1e3145ad;border-radius:10px;align-content:center;gap:3px;padding:7px 9px;font-size:.74rem;display:grid;overflow:hidden}.weather-audit-grid span.wide{grid-column:span 2}.weather-audit-grid b{color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;font-size:.56rem;font-weight:900}.weather-audit-missing{color:var(--text-2);margin:0;font-size:.82rem;line-height:1.45}@media (width<=980px){.weather-audit-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=520px){.weather-audit-main{display:grid}.weather-audit-grid{grid-template-columns:1fr}.weather-audit-grid span.wide{grid-column:auto}}.zone-banner-card{padding:0;overflow:hidden}.zone-banner-card .panel-title-row{border-bottom:1px solid #1e3145b8;padding:14px 16px}.zone-altitude-banner-list{gap:12px;padding:14px;display:grid}.zone-altitude-banner-card{background:#07111c85;border:1px solid #1e3145b8;border-radius:14px;overflow:hidden}.zone-altitude-banner-head,.zone-altitude-banner-foot{border-bottom:1px solid #1e314594;grid-template-columns:1fr 1fr;gap:10px;padding:10px 12px;display:grid}.zone-altitude-banner-foot{color:var(--text-2);border-top:1px solid #1e314594;border-bottom:0;grid-template-columns:1fr;font-size:.78rem}.zone-altitude-banner-head span{color:var(--text-3);letter-spacing:.05em;text-transform:uppercase;font-size:.6rem;font-weight:900;display:block}.zone-altitude-banner-head strong{color:var(--text);font-size:.86rem}.zone-altitude-banner-body{grid-template-columns:54px 1fr;min-height:164px;display:grid}.zone-altitude-axis{color:var(--text-3);text-align:right;border-right:1px solid #1e314594;align-content:space-between;padding:12px 8px;font-size:.64rem;display:grid}.zone-altitude-canvas{background:linear-gradient(#ffffff0a 1px,#0000 1px) 0 0/100% 33.333%,linear-gradient(#081927d9,#050b12b8);min-height:164px;position:relative;overflow:hidden}.zone-altitude-line{z-index:8;background:#59cffff5;height:2px;position:absolute;left:0;right:0;box-shadow:0 0 12px #59cfff57}.zone-altitude-line span{color:var(--cyan-soft);background:#050b12e6;border:1px solid #59cfff8c;border-radius:999px;padding:2px 7px;font-size:.64rem;font-weight:900;position:absolute;top:-18px;right:8px}.zone-altitude-block{min-height:24px;color:var(--text);z-index:4;background:#18aeef33;border:1px solid #59cfff6b;border-radius:10px;padding:5px 7px;position:absolute;overflow:hidden}.zone-altitude-block b,.zone-altitude-block small{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.zone-altitude-block b{font-size:.68rem;line-height:1.05}.zone-altitude-block small{color:var(--text-2);margin-top:2px;font-size:.58rem}.zone-altitude-block.activeAltitude{background:#18aeef52;border-color:#59cfffe6}.zone-altitude-block.crossedOutAltitude{opacity:.42;background:#6f7f9129;border-color:#6f7f9152}.zone-altitude-block.confirm{background:#ff9a3d2e;border-color:#ff9a3dc7}.zone-altitude-block.siv{background:#3ddc841f;border-color:#3ddc848c}.zone-altitude-block.ctr,.zone-altitude-block.tma,.zone-altitude-block.cta{border-color:#59cfffb8}.zone-altitude-block.r,.zone-altitude-block.d,.zone-altitude-block.p{background:#ff9a3d29;border-color:#ff9a3db8}.zone-altitude-progress-labels{color:var(--text-3);pointer-events:none;z-index:9;justify-content:space-between;font-size:.62rem;font-weight:900;display:flex;position:absolute;bottom:6px;left:8px;right:8px}.zone-rule-list{gap:8px;display:grid}.zone-rule-list span{color:var(--text-2);background:#07111c94;border:1px solid #1e3145ad;border-radius:10px;padding:9px 10px;font-size:.82rem}.zone-rule-list b{color:var(--cyan-soft);margin-right:6px}@media (width<=720px){.zone-altitude-banner-head{grid-template-columns:1fr}.zone-altitude-banner-body{grid-template-columns:46px 1fr}.zone-altitude-block b{font-size:.62rem}.zone-altitude-block small{display:none}}.zone-banner-loading{color:var(--text-2);padding:18px;font-weight:800}.complete-zone-frieze{gap:14px;padding:16px;display:grid}.complete-zone-frieze-head{grid-template-columns:1fr auto auto;align-items:center;gap:12px;display:grid}.complete-zone-frieze-head div{background:#07111c94;border:1px solid #1e3145b8;border-radius:13px;min-width:128px;padding:10px 12px}.complete-zone-frieze-head span,.complete-zone-contact-row span{color:var(--text-3);letter-spacing:.05em;text-transform:uppercase;font-size:.62rem;font-weight:900;display:block}.complete-zone-frieze-head strong{color:var(--text);margin-top:3px;font-size:1rem;display:block}.complete-zone-frieze-body{grid-template-columns:68px minmax(0,1fr);min-height:360px;display:grid}.complete-zone-axis{color:var(--text-2);text-align:right;flex-direction:column;justify-content:space-between;padding:4px 10px 58px 0;font-size:.76rem;display:flex}.complete-zone-canvas{background:linear-gradient(#59cfff14 1px,#0000 1px) 0 0/100% 20%,linear-gradient(90deg,#59cfff0f 1px,#0000 1px) 0 0/8.33% 100%,#050b128c;border:1px solid #1e3145d1;border-radius:15px;min-height:350px;position:relative;overflow:hidden}.complete-zone-altitude-line{z-index:8;background:#45e0fff2;height:2px;position:absolute;left:0;right:0;box-shadow:0 0 16px #45e0ff52}.complete-zone-altitude-line span{color:var(--cyan-soft);background:#050b12e0;border:1px solid #45e0ff5c;border-radius:999px;padding:4px 9px;font-size:.78rem;font-weight:950;position:absolute;top:-25px;right:8px}.complete-zone-block{text-align:center;color:var(--text);z-index:4;background:#1043536b;border:1px solid #45e0ff5c;border-radius:10px;place-content:center;padding:10px 12px;display:grid;position:absolute;overflow:hidden}.complete-zone-block small,.complete-zone-block em{color:var(--text-2);font-size:.7rem;font-style:normal}.complete-zone-block.tma,.complete-zone-block.cta{background:#6e33be59;border-color:#b45dffbd}.complete-zone-block.ctr{color:#ffe4a3;background:#9c670947;border-color:#ffc63dc7}.complete-zone-block.r,.complete-zone-block.d,.complete-zone-block.p{background:#91391b52;border-color:#ff8047c7}.complete-zone-block.crossedOutAltitude{opacity:.42;background-image:repeating-linear-gradient(135deg,#ffffff0f 0 6px,#0000 6px 12px)}.complete-zone-block.confirm{border-style:dashed;border-color:#ff9a3df2}.complete-zone-route-line{z-index:10;background:#e2efffb8;height:2px;position:absolute;bottom:43px;left:2%;right:2%}.complete-zone-marker{z-index:12;justify-items:center;gap:3px;min-width:62px;display:grid;position:absolute;bottom:10px;transform:translate(-50%)}.complete-zone-marker i{background:#e2effff5;border:2px solid #45e0ffdb;border-radius:999px;width:12px;height:12px;box-shadow:0 0 12px #45e0ff73}.complete-zone-marker b{color:var(--text);font-size:.76rem}.complete-zone-marker small{color:var(--text-3);font-size:.66rem}.complete-zone-contact-row{border:1px solid #1e3145b8;border-radius:14px;grid-template-columns:1fr 1fr 1.45fr;display:grid;overflow:hidden}.complete-zone-contact-row div{background:#07111c85;border-right:1px solid #1e3145b8;padding:12px 14px}.complete-zone-contact-row div:last-child{border-right:0}.complete-zone-contact-row strong{color:var(--cyan-soft);margin-top:4px;font-size:.95rem;display:block}.complete-zone-contact-row small,.complete-zone-contact-row p{color:var(--text-2);margin:4px 0 0}.complete-zone-legend{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.complete-zone-legend span{min-height:36px;color:var(--text-2);background:#07111c94;border:1px solid #1e3145b8;border-radius:11px;align-items:center;padding:0 10px;font-size:.76rem;display:flex}.complete-zone-legend .inside{border-color:#b45dff94}.complete-zone-legend .below{border-color:#45e0ff66}.complete-zone-legend .above{border-style:dashed}.complete-zone-legend .confirm{border-color:#ff9a3db8}@media (width<=980px){.complete-zone-frieze-head{grid-template-columns:1fr 1fr}.complete-zone-frieze-body{grid-template-columns:48px minmax(620px,1fr);overflow-x:auto}.complete-zone-canvas{min-width:620px}.complete-zone-contact-row{grid-template-columns:1fr}.complete-zone-contact-row div{border-bottom:1px solid #1e3145b8;border-right:0}.complete-zone-contact-row div:last-child{border-bottom:0}.complete-zone-legend{grid-template-columns:1fr 1fr}}@media (width<=520px){.complete-zone-frieze{padding:12px}.complete-zone-frieze-head,.complete-zone-legend{grid-template-columns:1fr}}.cockpit-stepper-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.cockpit-stepper{gap:4px;display:grid}.cockpit-stepper>span{color:var(--text-3);text-transform:uppercase;font-size:.64rem;font-weight:850}.cockpit-stepper>div{background:#050b12d1;border:1px solid #1e3145e6;border-radius:12px;grid-template-columns:34px 1fr 34px;align-items:center;height:40px;display:grid;overflow:hidden}.cockpit-stepper button{height:100%;color:var(--cyan-soft);cursor:pointer;background:#111c2ab8;border:0;font-size:1.05rem;font-weight:950}.cockpit-stepper button:active{background:#18aeef2e}.cockpit-stepper strong{text-align:center;color:var(--text);letter-spacing:.02em;font-size:.98rem;font-weight:950}.route-actions-row-single{grid-template-columns:1fr}.route-actions-row-single .btn{width:100%}.complete-zone-frieze{gap:12px;padding:14px}.complete-zone-frieze-head{grid-template-columns:1fr auto}.complete-zone-frieze-head div{min-width:112px}.complete-zone-frieze-body{min-height:304px}.complete-zone-axis{padding-bottom:50px;font-weight:800}.complete-zone-canvas{min-height:296px}.complete-zone-altitude-line span{color:var(--cyan-soft);background:#050b12eb;border:1px solid #45e0ff7a;border-radius:999px;padding:4px 10px;font-size:.86rem;font-weight:950;top:-25px;left:8px;right:auto}.complete-zone-block{border-radius:9px;padding:7px 9px}.complete-zone-block b{font-size:.7rem;line-height:1.1}.complete-zone-block small,.complete-zone-block em{font-size:.62rem;line-height:1.15}.complete-zone-block.activeAltitude{z-index:6;opacity:.92}.complete-zone-block.crossedOutAltitude{opacity:.24;z-index:2}.complete-zone-block.confirm{z-index:7}.complete-zone-route-line{bottom:38px}.complete-zone-marker{bottom:7px}.complete-zone-contact-row{grid-template-columns:1fr 1fr 1.25fr}@media (width<=980px){.complete-zone-frieze-head{grid-template-columns:1fr 1fr}}@media (width<=520px){.cockpit-stepper-grid{grid-template-columns:1fr 1fr}.cockpit-stepper>div{grid-template-columns:32px 1fr 32px}.complete-zone-frieze-head{grid-template-columns:1fr}}.complete-zone-frieze-body{grid-template-columns:82px minmax(0,1fr);align-items:stretch}.complete-zone-axis{text-align:right;min-height:296px;color:var(--text-2);padding:0 12px 0 0;font-size:.76rem;display:block;position:relative}.complete-zone-axis .axis-label{white-space:nowrap;font-weight:850;line-height:1;position:absolute;right:12px;transform:translateY(-50%)}.complete-zone-axis .planned-axis-label{color:var(--cyan-soft);background:#050b12eb;border:1px solid #45e0ff7a;border-radius:999px;padding:4px 8px;font-size:.88rem;font-weight:1000;box-shadow:0 0 14px #45e0ff2e}.complete-zone-altitude-line span{display:none}@media (width<=980px){.complete-zone-frieze-body{grid-template-columns:72px minmax(620px,1fr)}.complete-zone-axis{min-width:72px}.complete-zone-axis .axis-label{font-size:.7rem;right:8px}.complete-zone-axis .planned-axis-label{padding:4px 7px;font-size:.78rem}}.map-shell{width:100%;height:100%;min-height:inherit;background:#f4f1e8;position:relative;overflow:hidden}.ol-map{background:#f4f1e8;position:absolute;inset:0}.map-shell .ol-viewport,.map-shell .ol-layer canvas{cursor:default}.map-topline{z-index:3;pointer-events:none;justify-content:space-between;gap:8px;display:flex;position:absolute;top:10px;left:10px;right:10px}.map-topline span,.map-attribution,.map-fallback-notice{color:var(--text-2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#050b12c2;border:1px solid #1e3145d1;border-radius:999px}.map-topline span{text-transform:uppercase;padding:6px 9px;font-size:.68rem;font-weight:850}.map-controls{z-index:4;gap:7px;display:grid;position:absolute;bottom:56px;right:10px}.map-controls button{width:42px;height:42px;color:var(--text);cursor:pointer;background:#050b12d1;border:1px solid #1e3145e6;border-radius:12px;font-size:1.2rem;font-weight:900}.map-fallback-notice{z-index:3;pointer-events:none;border-radius:14px;gap:2px;max-width:245px;padding:10px 12px;display:grid;position:absolute;bottom:46px;left:10px}.map-fallback-notice strong{color:var(--warn)}.map-fallback-notice span{color:var(--text-2);font-size:.78rem}.map-attribution{z-index:3;text-align:center;pointer-events:none;border-radius:10px;padding:7px 9px;font-size:.64rem;position:absolute;bottom:10px;left:10px;right:10px}.scale-selector{z-index:5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#050b12d1;border:1px solid #1e3145d6;border-radius:13px;gap:4px;padding:4px;display:flex;position:absolute;top:12px;left:50%;transform:translate(-50%)}.scale-selector button{min-height:30px;color:var(--text-2);cursor:pointer;white-space:nowrap;background:0 0;border:0;border-radius:9px;padding:0 8px;font-size:.72rem;font-weight:800}.scale-selector button.active{background:var(--cyan);color:#03111a}.map-layer-toggle{z-index:6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#050b12d1;border:1px solid #1e3145d6;border-radius:13px;align-items:center;gap:6px;padding:4px;display:flex;position:absolute;top:12px;left:50%;transform:translate(-50%)}.map-layer-toggle span{color:var(--text-2);text-transform:uppercase;white-space:nowrap;padding:0 7px;font-size:.7rem;font-weight:850}.map-layer-toggle button{min-height:30px;color:var(--text-2);cursor:pointer;white-space:nowrap;background:#111c2af2;border:0;border-radius:9px;padding:0 9px;font-size:.72rem;font-weight:850}.map-layer-toggle button.active{background:var(--cyan);color:#03111a}.map-add-banner{z-index:5;color:#ffddb8;text-transform:uppercase;pointer-events:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#050b12db;border:1px solid #ff9a3dbd;border-radius:999px;padding:8px 13px;font-size:.72rem;font-weight:850;position:absolute;bottom:56px;left:50%;transform:translate(-50%)}.map-shell.is-adding-point .ol-viewport,.map-shell.is-adding-point .ol-layer canvas{cursor:crosshair}@media (width>=760px){.header-status{display:flex}.app-main{padding:18px 20px calc(96px + var(--safe-bottom))}.home-screen{grid-template-columns:1.2fr .8fr;align-items:start}.hero-card{grid-row:span 3;min-height:620px}.hero-content{min-height:620px}.planning-layout{grid-template-columns:minmax(0,1.75fr) 320px;align-items:stretch}.route-panel{align-self:stretch}.calculation-grid{grid-template-columns:minmax(0,1fr) 330px}.wide-card,.metric-grid{grid-column:1/-1}.zones-screen,.more-grid{grid-template-columns:repeat(2,1fr)}}@media (orientation:landscape) and (height<=760px){.header-bar,.bottom-nav{display:none}.app-shell{height:100dvh;display:block;overflow:hidden}.app-main{max-width:none;height:100%;padding:8px}.tracking-screen{grid-template-columns:minmax(0,1fr) 330px;gap:8px;height:100%}.tracking-map-panel{height:100%;min-height:0}.tracking-panel{align-content:start;padding-right:2px;overflow-y:auto}.cockpit-badges{grid-template-columns:repeat(2,1fr)}.tracking-metrics-top,.cockpit-value-grid{grid-template-columns:1fr}.metric-card{min-height:62px}.deviation-value strong{font-size:2.4rem}.map-controls{bottom:44px}}@media (width<=390px){.system-badges,.tracking-metrics-top,.cockpit-value-grid{grid-template-columns:1fr}.branch-row{grid-template-columns:1.4fr repeat(3,.7fr)}.branch-table:not(.navlog-table) .branch-row span:nth-child(4),.branch-table:not(.navlog-table) .branch-row span:nth-child(6),.branch-table:not(.navlog-table) .branch-row span:nth-child(7){display:none}}@media (width>=1024px){.app-main{max-width:1440px}.planning-map-card{min-height:calc(100dvh - 190px)}.route-panel{max-height:calc(100dvh - 190px);overflow-y:auto}}@media (width<=520px){.route-builder{grid-template-columns:1fr 1fr}.route-builder-reverse{grid-column:1/-1}.map-layer-toggle{max-width:calc(100% - 20px)}.map-topline{top:54px}}
