*{margin:0;padding:0;box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,sans-serif}html,body{width:100%;height:100%;margin:0;padding:0;overflow:hidden;background:var(--bg-color)}body:has(.bw-mode){background:#f5f5f5}#root{position:fixed;inset:0;width:100%;height:100%}@font-face{font-family:MonoWeb-Book;src:url(/fonts/MonoWeb-Book.woff2) format("woff2")}:root{--bg-color: #2a2d31;--path-day-color: rgb(255, 217, 0);--path-twilight-warm: rgb(255, 140, 0);--path-twilight-cool: rgb(128, 100, 200);--path-night-color: rgb(25, 38, 128)}*{font-family:Inter,system-ui,-apple-system,sans-serif}.bw-mode{--bg-color: #f5f5f5;--path-day-color: rgb(255, 255, 255);--path-twilight-warm: rgb(180, 180, 180);--path-twilight-cool: rgb(120, 120, 120);--path-night-color: rgb(0, 0, 0);--bw-text-primary: rgba(40, 40, 40, .9);--bw-text-secondary: rgba(40, 40, 40, .7);--bw-text-tertiary: rgba(40, 40, 40, .4);--bw-text-dark: rgb(20, 20, 20);--bw-bg-panel: rgba(255, 255, 255, .8);--bw-bg-button: rgba(40, 40, 40, .8);--bw-bg-button-hover: rgba(40, 40, 40, .9);--bw-bg-input: rgba(255, 255, 255, .3);--bw-border: rgba(50, 50, 50, .4);--bw-border-light: rgba(40, 40, 40, .3)}.bw-mode .nav-link,.bw-mode .toggle-overlay label span,.bw-mode .airport-toggle-overlay label span,.bw-mode .graticule-toggle-overlay label span,.bw-mode .plane-toggle-overlay label span,.bw-mode .timezone-toggle-overlay label span,.bw-mode .bw-toggle-overlay label span,.bw-mode .follow-toggle-overlay label span,.bw-mode .twilight-toggle-overlay label span,.bw-mode .accordion-content,.bw-mode .flight-input h3,.bw-mode .input-group input,.bw-mode .animation-controls,.bw-mode .animation-route,.bw-mode .time-value,.bw-mode .result-label,.bw-mode .result-value,.bw-mode .datetime-group input[type=datetime-local]{color:var(--bw-text-primary)}.bw-mode .animation-time,.bw-mode .animation-distance,.bw-mode .airport-code,.bw-mode .airport-date,.bw-mode .input-group label,.bw-mode .datetime-group label{color:var(--bw-text-secondary)}.bw-mode .airport-name-inline{color:var(--bw-text-tertiary)}.bw-mode .accordion-content h1,.bw-mode .accordion-content h2{color:var(--bw-text-dark)}.bw-mode .nav-link:hover{color:#282828}.bw-mode .flight-input,.bw-mode .animation-controls{background:var(--bw-bg-panel);border-color:var(--bw-border)}.bw-mode .flight-input button{background:transparent;color:var(--bw-text-primary);border-color:transparent}.bw-mode .flight-input button:hover{background:transparent;border-color:#2828284d}.bw-mode .flight-input button:disabled{color:var(--bw-text-tertiary);border-color:transparent}.bw-mode .play-button{background:transparent;color:var(--bw-text-primary);border-color:transparent}.bw-mode .play-button:hover{background:transparent;border-color:#2828284d}.bw-mode .input-group input,.bw-mode .datetime-group input[type=datetime-local]{background:#00000014;border:none}.bw-mode .input-group input:focus,.bw-mode .datetime-group input[type=datetime-local]:focus{background:#0000001f;border:none}.bw-mode .toggle-slider{background-color:#28282826}.bw-mode .toggle-slider:before{background-color:#282828cc}.bw-mode .toggle-switch input:checked+.toggle-slider{background-color:#28282880}.bw-mode .toggle-switch input:disabled+.toggle-slider{background-color:#2828281a}.bw-mode .toggle-switch input:disabled+.toggle-slider:before{background-color:#2828284d}.bw-mode .time-slider{background:#2828284d}.bw-mode .time-slider::-webkit-slider-thumb{background:#282828cc}.bw-mode .time-slider::-moz-range-thumb{background:#282828cc}.bw-mode .follow-toggle-overlay input[type=checkbox]:disabled+.toggle-slider{background-color:#28282833;opacity:.5}.bw-mode .follow-toggle-overlay input[type=checkbox]:disabled+.toggle-slider:before{background-color:#28282880}.bw-mode .footer-info,.bw-mode .footer-info a{color:#2828284d}.bw-mode .footer-info a:hover{color:#28282880}.bw-mode .flight-stat-label{color:#0006}.bw-mode .flight-stat-value{color:#0009}.bw-mode .flight-stats{border-bottom-color:#00000014}.toggle-overlay{position:absolute;left:20px;pointer-events:all}.toggle-overlay label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:#ffffffb3}.toggle-overlay input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:#2d2e2f}.app{width:100vw;height:100vh;margin:0;padding:0;overflow:hidden;position:relative}.app.loading{opacity:0}.app.loaded{opacity:1;transition:opacity 1s ease-in}.autocomplete-container{position:relative;width:100%}.autocomplete-container:hover .input-clear-btn{opacity:1;pointer-events:all}.autocomplete-container .airport-name-inline{transition:right .2s ease}.autocomplete-container:hover .airport-name-inline{right:32px}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:#1e1e1ee6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);border-radius:6px;margin-top:4px;max-height:200px;overflow-y:auto;z-index:1000;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.3) rgba(255,255,255,.05)}.autocomplete-dropdown::-webkit-scrollbar{width:8px}.autocomplete-dropdown::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.autocomplete-dropdown::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}.autocomplete-dropdown::-webkit-scrollbar-thumb:hover{background:#ffffff80}.autocomplete-item{padding:10px 12px;cursor:pointer;color:#fff;font-size:13px;border-bottom:1px solid rgba(255,255,255,.1);transition:background .15s}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover,.autocomplete-item.selected{background:#ffffff26}.autocomplete-code{font-weight:600;font-size:14px;margin-right:8px}.autocomplete-city{font-size:12px;opacity:.8}.input-group input.has-clear{padding-right:32px}.swap-airports-row{position:relative;height:0;display:flex;z-index:2}.swap-airports-btn{position:absolute;top:-6px;right:8px;background:#fff6!important;border:none!important;border-radius:50%;color:#1e1e1ed9!important;width:18px!important;height:18px!important;font-size:13px!important;cursor:pointer;padding:0!important;display:flex;align-items:center;justify-content:center;transition:none!important;margin:0!important}.swap-airports-btn:hover{background:#fff9!important;border-color:transparent!important}.bw-mode .input-clear-btn{color:#28282859}.bw-mode .input-clear-btn:hover{color:#282828cc}.bw-mode .swap-airports-btn{background:#0000000f;border-color:#00000026;color:#28282880}.bw-mode .swap-airports-btn:hover{background:#0000001a;border-color:#00000040;color:#282828d9}canvas{display:block;width:100%;height:100%}.airport-toggle-overlay{bottom:160px}.airport-toggle-overlay label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:#ffffffb3}.airport-toggle-overlay input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:#2d2e2f}.graticule-toggle-overlay{bottom:130px}.graticule-toggle-overlay label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:#ffffffb3}.graticule-toggle-overlay input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:#2d2e2f}.flight-info-center{display:flex;flex-direction:column;align-items:center;flex:1}.info-overlay{position:absolute;top:36px;left:20px;pointer-events:none;-webkit-user-select:none;user-select:none}.info-overlay .logo{height:32px;width:auto;opacity:.9;pointer-events:all;cursor:pointer;transition:opacity .2s ease}.info-overlay .logo:hover{opacity:1}.flight-input{position:absolute;top:20px;left:50%;transform:translate(-50%);background:#1e1e1e4d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);padding:20px;border-radius:24px;box-shadow:0 8px 32px #0000001a;width:400px;transition:padding .4s cubic-bezier(.4,0,.2,1),width .4s cubic-bezier(.4,0,.2,1) .05s,border-radius .4s cubic-bezier(.4,0,.2,1) .05s}.flight-input h3{margin:0 0 16px;font-size:18px;font-weight:400;color:#fff;transition:margin-bottom .35s ease-out}.input-group{margin-bottom:16px}.input-group label{display:block;font-size:12px;color:#ffffffb3;margin-bottom:4px;font-weight:500}.input-group input{width:100%;padding:8px 12px;border:none;border-radius:6px;font-size:16px;font-weight:600;background:#ffffff26;color:#fff;text-transform:uppercase;letter-spacing:.5px}.input-group input:focus{outline:none;background:#fff3}.flight-input button{width:auto;padding:10px 24px;background:transparent;color:#fff;border:1px solid transparent;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;margin-top:20px;text-transform:uppercase;transition:border-color .2s ease;display:block;margin-left:auto;margin-right:auto}.flight-input button:hover{border-color:#ffffff4d}.flight-input button:disabled{background:transparent;color:#ffffff4d;cursor:not-allowed}.flight-input .input-clear-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:18px!important;height:18px;margin:0!important;padding:0!important;background:#fff6!important;border:none!important;border-radius:50%;color:#1e1e1ed9!important;cursor:pointer;text-transform:none;font-weight:400;opacity:0;pointer-events:none;transition:opacity .15s ease!important}.flight-input .input-clear-btn:hover{background:#fff9!important;border-color:transparent!important}.collapse-lens{display:none}.collapse-arrow{display:inline}.datetime-group{margin-bottom:12px}.datetime-group label{display:block;font-size:12px;color:#ffffffb3;margin-bottom:4px;font-weight:500}.datetime-group input[type=datetime-local]{width:100%;padding:10px 14px;border:none;font-size:16px;background:#ffffff26;color:#fff;color-scheme:dark;height:40px;box-sizing:border-box;border-radius:6px;-webkit-appearance:none;appearance:none}.datetime-group input[type=datetime-local]:focus{outline:none;border-color:#ffffff80;background:#ffffff14}.results-panel{margin-top:16px;padding:12px;background:transparent;border-radius:4px;font-size:13px}.result-row{display:flex;justify-content:space-between;margin-bottom:6px}.result-label{color:#ffffffb3}.result-value{font-weight:600;color:#ffffffb3}.animation-controls{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:#1e1e1e4d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);padding:20px 20px 14px;border-radius:24px;box-shadow:0 8px 32px #0000001a;min-width:400px;display:none}.animation-controls.visible{display:block}.flight-stats{display:flex;justify-content:space-between;padding:0 0 14px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:30px;max-height:100px;opacity:1;overflow:hidden;transition:max-height .35s ease,opacity .25s ease,padding .35s ease,margin .35s ease,border-color .35s ease}.flight-stats.hidden{max-height:0;opacity:0;padding:0;margin-bottom:0;border-bottom-color:transparent}.flight-stats.slow-reveal{transition:max-height .6s ease,opacity .5s ease .1s,padding .6s ease,margin .6s ease,border-color .6s ease}.flight-stat{display:flex;flex-direction:column;align-items:center;flex:1}.flight-stat-label{font-size:12px;color:#fff6;text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px;font-weight:400}.flight-stat-value{font-size:12px;font-weight:500;color:#ffffffd9;margin-bottom:6px}.animation-header{display:flex;justify-content:space-between;align-items:flex-start;padding:0}.animation-route{display:flex;align-items:center;justify-content:center;gap:8px;font-size:18px;font-weight:600;color:#fff;margin-bottom:4px;white-space:nowrap}.animation-distance{font-size:12px;color:#ffffffb3;margin-top:16px;margin-bottom:2px}.animation-time{font-size:12px;color:#ffffffb3}.airport-time-left,.airport-time-right{display:flex;flex-direction:column;gap:2px;padding-top:18px}.airport-time-left{align-items:flex-start}.airport-time-right{align-items:flex-end}.airport-code{font-size:12px;color:#ffffff80;text-transform:uppercase;font-weight:400;align-self:center}.airport-date{font-size:12px;color:#fff9;font-weight:400;align-self:center}.time-value{font-family:MonoWeb-Book,monospace;font-size:28px;color:#fff;align-self:inherit}.slider-container{margin:0;position:relative}.curved-slider{width:100%;height:80px;cursor:pointer;-webkit-user-select:none;user-select:none}.curved-slider:active{cursor:grabbing}.time-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#2d2e2f;cursor:pointer;box-shadow:0 2px 4px #0003}.time-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#2d2e2f;cursor:pointer;border:none;box-shadow:0 2px 4px #0003}.slider-icon{width:16px;height:16px;opacity:.9}.play-button{width:auto;padding:10px 24px;background:transparent;color:#fff;border:1px solid transparent;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;text-transform:uppercase;transition:border-color .2s ease;margin:0 auto -24px;position:relative;top:-24px}.play-button:hover{border-color:#ffffff4d}.time-labels{display:flex;justify-content:space-between;font-size:12px;color:#999;margin-top:2px;padding:0 18px}.flight-input.collapsed{padding-bottom:6px;width:260px;border-radius:36px}.flight-input.collapsed .panel-content{max-height:0!important;opacity:0!important;padding-top:0!important;padding-bottom:0!important;transition:max-height .25s ease-in,opacity .25s ease-in!important}.flight-input.collapsed .panel-header{margin-bottom:12px;transition:margin-bottom .25s ease-in}.flight-input.collapsed .panel-header h3{margin-bottom:0;transition:margin-bottom .25s ease-in}.search-icon{width:18px;height:18px;margin-right:12px;vertical-align:middle;opacity:.9}.panel-header{display:flex;justify-content:space-between;align-items:center;height:24px;margin-bottom:32px;transition:margin-bottom .35s ease-out}@media(max-width:600px){.flight-input.collapsed .panel-header{margin-bottom:0;height:auto}}.flight-input.collapsed .collapse-arrow{display:none}.flight-input.collapsed .collapse-lens,.flight-input .collapse-arrow{display:block}.flight-input .collapse-lens{display:none}.panel-header h3{margin:0;padding:0;line-height:24px;flex-shrink:0}.flight-input .collapse-button{background:none!important;border:none!important;color:#ffffff80!important;cursor:pointer;font-size:12px;padding:0!important;width:20px!important;height:20px!important;display:flex;align-items:center;justify-content:center;margin:0;flex-shrink:0;transition:color .2s,transform .3s ease;transform:rotate(0)}.flight-input .collapse-button:hover{color:#ffffffe6!important}.flight-stat-value{font-size:12px}.flight-stat-label{font-size:10px}.flight-stats{padding:0 0 10px;margin-bottom:10px}.flight-input .collapse-button:not(.collapsed){transform:rotate(180deg)}.bw-mode .flight-input .collapse-button{color:#28282899!important}.bw-mode .flight-input .collapse-button:hover{color:var(--bw-text-primary)!important}.panel-content{overflow:hidden;max-height:380px;opacity:1;transition:max-height .35s ease-out,opacity .35s ease-out}.input-with-name{position:relative;width:100%}.input-with-name input{width:100%;padding-right:220px}.airport-name-inline{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:13px;color:#fff6;pointer-events:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.timezone-toggle-overlay{bottom:70px}.timezone-toggle-overlay label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:#ffffffb3}.timezone-toggle-overlay input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:#2d2e2f}.twilight-toggle-overlay{bottom:100px}.twilight-toggle-overlay label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:#ffffffb3}.twilight-toggle-overlay input[type=checkbox]{cursor:pointer;width:16px;height:16px}.footer-info{position:absolute;bottom:20px;left:20px;font-size:11px;color:#ffffff80;pointer-events:all;display:flex;align-items:center;gap:4px}.footer-info a{color:#ffffff4d;text-decoration:none;transition:color .2s}.footer-info a:hover{color:#ffffff80}.footer-info .github-icon{width:12px;height:12px;opacity:.5;margin-right:6px;align-self:center}.footer-info .separator{margin:0 6px}.route-plane-icon{width:14px;height:14px;opacity:.9;transform:rotate(90deg)}.nav-link{background:none;border:none;color:#ffffffb3;font-size:13px;cursor:pointer;padding:4px 0;text-align:left;transition:color .2s;display:inline-flex;align-items:center}.nav-chevron{flex-shrink:0;opacity:.7;transition:transform .2s ease,opacity .2s;transform:rotate(0);margin-left:5px;vertical-align:middle}.nav-chevron.open{transform:rotate(180deg);opacity:1}.nav-link:hover .nav-chevron{opacity:1}.bw-mode .nav-chevron{color:var(--bw-text-secondary)}.nav-tagline{margin:0 0 8px;padding:0;color:#ffffffb3;font-size:13px;line-height:1.5}.bw-mode .nav-tagline{color:var(--bw-text-secondary)}.side-panel-overlay{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;justify-content:flex-end}.side-panel{width:500px;max-width:90vw;height:100vh;background:#ffffff1a;backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border-left:1px solid rgba(255,255,255,.2);overflow-y:auto;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.side-panel-header{display:flex;justify-content:space-between;align-items:center;padding:30px;border-bottom:1px solid rgba(255,255,255,.1)}.side-panel-header h2{margin:0;color:#fff;font-size:24px;font-weight:600}.close-button{background:none;border:none;color:#ffffffb3;font-size:32px;cursor:pointer;padding:0;line-height:1;transition:color .2s}.close-button:hover{color:#fff}.nav-accordion{position:absolute;top:92px;left:20px;display:flex;flex-direction:column;gap:4px;pointer-events:all;z-index:100;max-width:260px;align-items:flex-start}.nav-link{background:none;border:none;color:#ffffffb3;font-size:13px;cursor:pointer;padding:4px 0;text-align:left;transition:color .2s;display:flex;justify-content:space-between;align-items:center}.nav-link:hover{color:#fff}.accordion-content{background:none;-webkit-backdrop-filter:none;backdrop-filter:none;border:none;border-radius:0;padding:0 0 0 12px;margin-bottom:12px;color:#ffffffb3;font-size:13px;line-height:1.5;animation:expandDown .2s ease-out}.accordion-content a{color:#ffffff80;text-decoration:none;transition:color .2s}.accordion-content a:hover{color:#fffc}.accordion-content>*:first-child{margin-top:0}.bw-mode .accordion-content a{color:var(--bw-text-tertiary)}.bw-mode .accordion-content a:hover{color:var(--bw-text-secondary)}.mobile-menu-accordion a{color:#ffffff80;text-decoration:none;transition:color .2s}.mobile-menu-accordion a:hover{color:#fffc}.bw-mode .mobile-menu-accordion a{color:var(--bw-text-tertiary)}.bw-mode .mobile-menu-accordion a:hover{color:var(--bw-text-secondary)}.mobile-menu-accordion>*:first-child{margin-top:0}@keyframes expandDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes collapseUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.accordion-content h1{font-size:16px;margin:0 0 12px;color:#fff}.accordion-content h2{font-size:13px;margin:15px 0 8px;color:#ffffffe6}.accordion-content p{margin:0 0 10px}.accordion-content ul{margin:0 0 10px 20px;padding:0}.accordion-content li{margin-bottom:5px}.accordion-content.closing{animation:collapseUp .2s ease-out forwards;overflow:hidden}.result-row-double{display:flex;gap:60px;margin-bottom:6px}.result-item{display:flex;justify-content:space-between;flex:1}.bw-toggle-overlay{position:absolute;bottom:240px;left:20px;pointer-events:all}.bw-toggle-overlay label{display:flex;align-items:center;gap:11px;cursor:pointer;font-size:13px;color:#ffffffe6}.bw-toggle-overlay input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:#2d2e2f}.follow-toggle-overlay{position:absolute;bottom:210px;left:20px;pointer-events:all}.follow-toggle-overlay label{display:flex;align-items:center;gap:11px;cursor:pointer;font-size:13px;color:#ffffffe6}.follow-toggle-overlay label:has(input:disabled){opacity:.5;cursor:not-allowed}.follow-toggle-overlay input[type=checkbox]:disabled+.toggle-slider{background-color:#ffffff26;opacity:.4}.follow-toggle-overlay input[type=checkbox]:disabled+.toggle-slider:before{background-color:#fff6}.toggle-switch{position:relative;width:32px;height:18px;display:inline-block}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#ffffff4d;transition:.3s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:14px;width:14px;left:2px;bottom:2px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:#2d2e2f}.toggle-switch input:checked+.toggle-slider:before{transform:translate(14px)}.hamburger-button{position:absolute;top:20px;right:20px;background:none;border:none;width:44px;height:44px;display:none;align-items:center;justify-content:center;cursor:pointer;color:#ffffffe6;transition:all .2s ease;z-index:100;padding:0}@media(min-width:601px)and (max-width:768px){.hamburger-button{top:16px}}.hamburger-button:hover{color:#fff}.bw-mode .hamburger-button{color:#282828e6}.bw-mode .hamburger-button:hover{color:#282828}.mobile-menu-overlay{position:fixed;inset:0;background:#00000080;z-index:200;display:flex;justify-content:flex-end;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-menu{width:280px;max-width:80vw;height:100dvh;background:#ffffff1a;backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border-left:1px solid rgba(255,255,255,.2);overflow-y:auto;animation:slideInRight .3s ease;display:flex;flex-direction:column}.mobile-menu.closing{animation:slideOutRight .3s ease forwards}.mobile-menu-overlay.closing{animation:fadeOut .3s ease forwards}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideOutRight{0%{transform:translate(0)}to{transform:translate(100%)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.bw-mode .mobile-menu{background:#fffffff2;border-left-color:#28282833}.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.1)}.bw-mode .mobile-menu-header{border-bottom-color:#28282833}.mobile-menu-header h2{margin:0;color:#fff;font-size:20px;font-weight:600}.bw-mode .mobile-menu-header h2{color:#282828e6}.mobile-menu-close{background:none;border:none;color:#ffffffb3;font-size:36px;line-height:1;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s}.mobile-menu-close:hover{color:#fff}.bw-mode .mobile-menu-close{color:#28282899}.bw-mode .mobile-menu-close:hover{color:#282828e6}.mobile-menu-content{padding:12px;display:flex;flex-direction:column;flex:1}.mobile-menu-content>.mobile-menu-divider{margin-top:auto;margin-bottom:12px}.mobile-menu-link{display:block;width:100%;padding:10px 16px 10px 20px;background:none;border:none;color:#ffffffe6;font-size:14px;text-align:left;cursor:pointer;border-radius:8px;transition:background .2s;margin-bottom:4px}.mobile-menu-link:hover{background:none}.bw-mode .mobile-menu-link{color:#282828e6}.bw-mode .mobile-menu-link:hover{background:#28282814}.mobile-menu-accordion{padding:8px 16px 12px 42px;color:#fffc;font-size:14px;line-height:1.6;margin-bottom:12px;max-height:0;opacity:0;animation:accordionOpen .4s ease forwards}.mobile-menu-tagline{margin:0 0 4px;padding:10px 16px 10px 20px;color:#ffffffb3;font-size:14px;line-height:1.5}.bw-mode .mobile-menu-tagline{color:#282828b3}@keyframes accordionOpen{0%{max-height:0;opacity:0;overflow:hidden}to{max-height:600px;opacity:1;overflow:visible}}.bw-mode .mobile-menu-accordion{color:#282828cc}.mobile-menu-accordion h1{font-size:16px;margin:0 0 8px;color:#fff}.bw-mode .mobile-menu-accordion h1{color:#282828e6}.mobile-menu-accordion h2{font-size:14px;margin:12px 0 6px;color:#ffffffe6}.bw-mode .mobile-menu-accordion h2{color:#282828d9}.mobile-menu-accordion p{margin:0 0 8px}.mobile-menu-divider{display:none}.mobile-menu-scroll{position:relative;flex:1;overflow-y:auto}.mobile-menu-scroll:after{content:"";position:sticky;bottom:0;display:block;height:48px;background:linear-gradient(to bottom,transparent,rgba(0,0,0,.45));pointer-events:none}.mobile-menu-bottom{flex-shrink:0}.bw-mode .mobile-menu-divider{background:#28282833}.mobile-menu-toggles{padding:4px 0 16px}.mobile-menu-toggle-item{display:flex;justify-content:flex-start;align-items:center;gap:12px;padding:8px 16px 8px 32px;cursor:pointer;border-radius:8px;transition:background .2s,opacity .3s ease;margin-bottom:4px}.mobile-menu-toggle-item:hover{background:none}.bw-mode .mobile-menu-toggle-item:hover{background:#28282814}.mobile-menu-toggle-item input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:#2d2e2f;flex-shrink:0;order:-1}.bw-mode .mobile-menu-toggle-item input[type=checkbox]{accent-color:#282828}.mobile-menu-toggle-item span{color:#ffffffe6;font-size:13px}.bw-mode .mobile-menu-toggle-item span{color:#282828e6}.mobile-menu-footer{padding:4px 16px 16px 34px;font-size:11px;color:#ffffff80;display:flex;align-items:center;gap:4px;flex-wrap:wrap;margin-top:0;transition:opacity .3s ease}.bw-mode .mobile-menu-footer{color:#28282880;border-top-color:#28282833}.mobile-menu-footer .github-icon{width:12px;height:12px;opacity:.5;margin-right:6px}.mobile-menu-footer a{color:#ffffff4d;text-decoration:none;transition:color .2s}.bw-mode .mobile-menu-footer a{color:#2828284d}.mobile-menu-footer a:hover{color:#ffffff80}.bw-mode .mobile-menu-footer a:hover{color:#28282880}.mobile-menu-footer .separator{margin:0 6px}@media(max-width:768px){.info-overlay{top:20px;left:16px}.info-overlay .logo{height:28px}.nav-accordion{top:60px;left:16px;max-width:220px}.flight-input{width:340px;top:16px;padding:18px}.flight-input.fading{opacity:0;transition:opacity .2s ease!important}.flight-input.collapsed{width:auto;min-width:200px;padding:8px 18px;border-radius:28px}.animation-controls{min-width:340px;bottom:16px;padding:20px 16px 14px}.time-value{font-size:24px}.footer-info{font-size:10px;bottom:16px;left:16px}.footer-info .github-icon{width:11px;height:11px}.flight-input .input-clear-btn,.swap-airports-btn{width:18px!important;height:18px!important;min-height:0!important;padding:0!important;margin:0!important}}@media(max-width:600px){.app{width:100vw;height:100vh;height:100dvh;margin:0;padding:0;overflow:hidden;position:fixed;inset:0}.info-overlay{top:26px;left:16px;transform:none}.info-overlay .logo{height:24px;margin-top:2px}.nav-accordion{display:none}.hamburger-button{display:flex;flex-direction:column;gap:5px;top:26px;right:16px;margin-top:0}.flight-input{width:calc(100vw - 32px);max-width:380px;top:70px;padding:16px 20px!important;border-radius:20px;transition:opacity .2s ease!important;z-index:300}.flight-input.collapsed{top:20px;left:auto;right:70px;transform:none;width:auto;min-width:0!important;max-width:160px;padding:0 10px!important;border-radius:48px}.flight-input.collapsed .panel-header{gap:12px;justify-content:center;transition:none!important}.flight-input.collapsed .collapse-button{width:16px!important;height:16px!important}.flight-input.collapsed .panel-content,.flight-input .panel-content,.flight-input .collapse-button,.panel-header,.flight-input.collapsed .panel-header h3,.flight-input h3{transition:none!important}.info-overlay{top:30px;z-index:300}.hamburger-button{top:22px}.flight-input h3{font-size:16px;margin-bottom:14px;margin-top:12px}.flight-input.collapsed h3{font-size:14px;margin-bottom:0;margin-top:0}.input-group input,.datetime-group input[type=datetime-local]{padding:10px 14px;font-size:16px}.autocomplete-dropdown{max-height:180px}.results-panel{margin-top:16px;padding:12px;font-size:11px}.result-row-double{gap:40px}.animation-controls{min-width:0!important;width:calc(100vw - 48px);max-width:420px;bottom:12px;padding:10px 13px!important}.animation-header{flex-direction:row;gap:0px;align-items:center;justify-content:space-between}.airport-time-left,.airport-time-right{flex-direction:column;gap:1px;min-width:80px}.airport-time-left{align-items:flex-start}.airport-time-right{align-items:flex-end}.airport-code{font-size:11px;order:1;align-self:center}.time-value{font-size:20px;order:2;align-self:center}.airport-date{font-size:11px;order:3;align-self:center}.flight-info-center{flex:0 1 auto;min-width:0}.animation-route{font-size:14px;gap:5px;white-space:nowrap}.route-plane-icon{width:11px;height:11px}.animation-distance{font-size:11px;margin-top:4px;margin-bottom:0}.animation-time{font-size:11px}.curved-slider{height:70px}.slider-icon{width:14px;height:14px}.play-button{font-size:13px;padding:9px 20px}.toggle-overlay{left:16px}.bw-toggle-overlay{bottom:280px}.follow-toggle-overlay{bottom:250px}.airport-toggle-overlay{bottom:200px}.graticule-toggle-overlay{bottom:170px}.timezone-toggle-overlay{bottom:140px}.twilight-toggle-overlay{bottom:110px}.toggle-overlay label{font-size:12px}.footer-info{left:16px;right:auto;bottom:12px;font-size:9px}.footer-info .github-icon{width:10px;height:10px;margin-right:4px}.airport-toggle-overlay,.graticule-toggle-overlay,.timezone-toggle-overlay,.twilight-toggle-overlay{display:none}.bw-toggle-overlay{inset:90px 16px auto auto;transition:opacity .3s ease}.follow-toggle-overlay{inset:124px 16px auto auto;transition:opacity .3s ease}.app.has-flight .bw-toggle-overlay,.app.has-flight .follow-toggle-overlay{bottom:auto}.bw-toggle-overlay label,.follow-toggle-overlay label{flex-direction:row-reverse;gap:8px}.footer-info{display:none}.mobile-menu-offcanvas{position:fixed;top:70px;right:0;left:0;width:100%;height:calc(100% - 70px);z-index:200;display:flex;flex-direction:column;color:#fff;padding-top:8px;background:transparent;pointer-events:auto}.bw-mode .mobile-menu-offcanvas{color:#282828e6}.mobile-menu-content-wrap{padding:8px 16px;display:flex;flex-direction:column;flex:1;overflow-y:auto;opacity:0;transition:opacity .3s ease}.mobile-menu-content-wrap.visible{opacity:1;transition:opacity .3s ease}.mobile-menu-spacer{margin-top:auto}.app.menu-open:not(.menu-closing) .animation-controls,.app.menu-open:not(.menu-closing) .bw-toggle-overlay,.app.menu-open:not(.menu-closing) .follow-toggle-overlay{opacity:0;transition:opacity .3s ease}.app.menu-open.menu-closing .animation-controls,.app.menu-open.menu-closing .bw-toggle-overlay,.app.menu-open.menu-closing .follow-toggle-overlay{opacity:1;transition:opacity .3s ease}.hamburger-button .hamburger-line{display:block;width:18px;height:2px;background:currentColor;border-radius:1px;transition:transform .3s ease,opacity .3s ease}.hamburger-button.open .hamburger-line:nth-child(1){transform:translateY(3.5px) rotate(45deg)}.hamburger-button.open .hamburger-line:nth-child(2){transform:translateY(-3.5px) rotate(-45deg)}.mobile-menu-overlay-bg{position:fixed;inset:-100px 0;background:linear-gradient(to bottom,var(--bg-color) 0%,transparent 150%);z-index:90;opacity:0;transition:opacity .3s ease}.mobile-menu-overlay-bg.open{opacity:1;transition:opacity .3s ease}.mobile-menu-overlay-bg.closing{opacity:0;transition:opacity .3s ease}.mobile-menu-overlay-bg.bw{background:linear-gradient(to bottom,#f5f5f5f7,#f5f5f580)}}@media(max-width:400px){.info-overlay .logo{height:22px}.flight-input{width:calc(100vw - 24px);padding:14px;border-radius:18px}.flight-input.collapsed{width:auto;min-width:180px}.flight-input h3{font-size:15px}.animation-controls{min-width:calc(100vw - 24px);padding:16px 12px 10px;border-radius:20px}.animation-route{font-size:15px;gap:5px}.time-value{font-size:18px}.animation-distance{font-size:11px}.curved-slider{height:60px}.play-button{font-size:12px;padding:8px 18px}.bw-toggle-overlay{bottom:270px}.follow-toggle-overlay{bottom:240px}.airport-toggle-overlay{bottom:190px}.graticule-toggle-overlay{bottom:160px}.timezone-toggle-overlay{bottom:130px}.twilight-toggle-overlay{bottom:100px}.footer-info{font-size:8px}}@media(max-height:600px)and (orientation:landscape){.flight-input{top:12px;max-width:320px}.animation-controls{bottom:12px;max-width:360px}.animation-header{flex-direction:row;gap:8px}.airport-time-left,.airport-time-right{flex-direction:column;gap:2px;padding-top:12px}.time-value{font-size:18px}.toggle-overlay{bottom:auto;top:auto}.bw-toggle-overlay,.follow-toggle-overlay,.airport-toggle-overlay,.graticule-toggle-overlay,.timezone-toggle-overlay,.twilight-toggle-overlay{position:relative;bottom:auto;display:inline-block;margin-right:12px}.app:after{content:"";position:absolute;bottom:12px;left:12px;right:12px;pointer-events:none}}@media(hover:none)and (pointer:coarse){.flight-input button,.play-button{min-height:44px;padding:12px 24px}.nav-link{padding:8px 0;min-height:36px}.toggle-overlay label{padding:4px 0;min-height:36px}.toggle-switch{width:40px;height:22px}.toggle-slider:before{height:18px;width:18px}.toggle-switch input:checked+.toggle-slider:before{transform:translate(18px)}.flight-input,.animation-controls,.toggle-overlay{-webkit-user-select:none;user-select:none}input,textarea{-webkit-user-select:text;user-select:text}}
