:root{--color-blue: #0055A4;--color-white: #FFFFFF;--color-red: #EF4135;--color-bg: #0a0a0f;--color-bg-secondary: #12121a;--color-text: #f0f0f5;--color-text-muted: #8888a0;--color-accent: #0055A4;--header-height: 80px;--timeline-height: 140px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden}body{font-family:var(--font-family);background:var(--color-bg);color:var(--color-text)}#app{display:flex;flex-direction:column;height:100vh}.header{height:var(--header-height);display:flex;align-items:center;gap:16px;padding:0 24px;background:var(--color-bg-secondary);border-bottom:1px solid rgba(255,255,255,.1)}.header h1{font-size:2rem;font-weight:700;background:linear-gradient(90deg,var(--color-blue),var(--color-white),var(--color-red));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header .subtitle{font-size:1rem;color:var(--color-text-muted)}.header-spacer{flex:1}.header-logo{height:24px;opacity:.6;filter:brightness(0) invert(1)}.main{flex:1;position:relative;overflow:hidden}.map{width:100%;height:100%}.countdown-container{position:absolute;bottom:24px;left:24px;z-index:10}.countdown{background:linear-gradient(135deg,#0a0a0ff2,#12121af2);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:16px 24px;backdrop-filter:blur(10px);box-shadow:0 8px 32px #0006}.countdown-header{display:flex;flex-direction:column;gap:2px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.countdown-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.15em;color:var(--color-text-muted)}.countdown-event{font-size:1rem;font-weight:600;background:linear-gradient(90deg,var(--color-blue),var(--color-white),var(--color-red));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.countdown-location{font-size:.75rem;color:var(--color-text-muted)}.countdown-timer{display:flex;align-items:center;gap:8px}.countdown-unit{display:flex;flex-direction:column;align-items:center;min-width:44px}.countdown-value{font-size:1.75rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--color-text);line-height:1}.countdown-unit:first-child .countdown-value{color:var(--color-blue)}.countdown-unit:nth-child(3) .countdown-value{color:var(--color-white)}.countdown-unit:nth-child(5) .countdown-value{color:var(--color-white)}.countdown-unit:last-child .countdown-value{color:var(--color-red)}.countdown-unit-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-top:4px}.countdown-separator{font-size:1.5rem;font-weight:300;color:var(--color-text-muted);margin-bottom:16px}.event-card{position:absolute;top:20px;right:20px;width:300px;background:var(--color-bg-secondary);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:20px;box-shadow:0 8px 32px #0006;z-index:10;transition:opacity .3s,transform .3s}.event-card.hidden{opacity:0;pointer-events:none;transform:translateY(-10px)}.event-card .event-type{display:inline-block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:4px 8px;border-radius:4px;margin-bottom:12px}.event-card .event-type.international{background:#0055a44d;color:var(--color-blue)}.event-card .event-type.national{background:#ef41354d;color:var(--color-red)}.event-card .event-type.training{background:#fff3;color:var(--color-text-muted)}.event-card h2{font-size:1.25rem;margin-bottom:8px}.event-card .event-location{color:var(--color-text-muted);font-size:.875rem;margin-bottom:8px}.event-card .event-date{font-size:.875rem;color:var(--color-text)}.event-card .close-btn{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:1.25rem;line-height:1;padding:4px}.event-card .close-btn:hover{color:var(--color-text)}.footer{height:var(--timeline-height);background:var(--color-bg-secondary);border-top:1px solid rgba(255,255,255,.1)}.loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-text-muted)}.mapboxgl-ctrl-logo,.mapboxgl-ctrl-attrib{opacity:.5}.home-marker,.event-marker{cursor:pointer}.event-marker svg{transition:transform .2s}.event-marker:hover svg{transform:scale(1.2)}.event-marker.selected svg{transform:scale(1.4)}.event-marker.selected svg circle:last-child{stroke:var(--color-white);stroke-width:2}.jet-marker{z-index:100}.jet-marker svg{display:block}@media(max-width:768px){:root{--header-height: 56px;--timeline-height: 120px}.header{padding:0 16px;gap:8px}.header h1{font-size:1.25rem}.header .subtitle{font-size:.75rem}.countdown-container{display:none}.event-card{inset:8px 8px auto;width:auto;border-radius:8px;padding:12px;transform:translateY(0)}.event-card.hidden{transform:translateY(-100%);opacity:0}.event-card h2{font-size:1rem;padding-right:24px}.mapboxgl-ctrl-top-left{top:8px;left:8px}.mapboxgl-ctrl-group{transform:scale(.85);transform-origin:top left}}@media(max-width:480px){.header h1{font-size:1rem}.header .subtitle{display:none}.header-logo{height:18px}}.timeline{height:100%;display:flex;align-items:center;padding:16px 24px;gap:16px;overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--color-text-muted) transparent}.timeline-play-btn{flex-shrink:0;align-self:center;width:48px;height:48px;border-radius:50%;border:2px solid var(--color-text-muted);background:transparent;color:var(--color-text);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s,background .2s,transform .2s}.timeline-play-btn:hover{border-color:var(--color-text);background:#ffffff1a}.timeline-play-btn:active{transform:scale(.95)}.timeline-play-btn .pause-icon,.timeline-play-btn.playing .play-icon{display:none}.timeline-play-btn.playing .pause-icon{display:block}.timeline-play-btn.playing{border-color:var(--color-blue);background:#0055a433}.timeline::-webkit-scrollbar{height:6px}.timeline::-webkit-scrollbar-track{background:transparent}.timeline::-webkit-scrollbar-thumb{background:var(--color-text-muted);border-radius:3px}.timeline-months{display:flex;align-items:center;gap:24px;padding:16px 24px 16px 0;flex-shrink:0}.timeline-year{font-size:1.5rem;font-weight:700;color:var(--color-text);padding:0 8px;opacity:.3;flex-shrink:0}.timeline-month{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.timeline-month-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);white-space:nowrap}.timeline-events{display:flex;gap:10px;align-items:center}.timeline-event{position:relative;width:16px;height:16px;border-radius:50%;cursor:pointer;transition:transform .2s,box-shadow .2s;border:2px solid transparent}.timeline-event:before{content:"";position:absolute;inset:-4px;border-radius:50%;background:radial-gradient(circle,currentColor 0%,transparent 70%);opacity:0;transition:opacity .2s}.timeline-event:hover{transform:scale(1.3)}.timeline-event:hover:before{opacity:.3}.timeline-event.selected{transform:scale(1.4);border-color:var(--color-white)}.timeline-event.selected:before{opacity:.5}.timeline-event.international{background:var(--color-blue);color:var(--color-blue)}.timeline-event.national{background:var(--color-red);color:var(--color-red)}.timeline-event.training{background:var(--color-text-muted);color:var(--color-text-muted)}.timeline-event-tooltip{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--color-bg);border:1px solid rgba(255,255,255,.15);border-radius:4px;padding:4px 8px;white-space:nowrap;font-size:.65rem;line-height:1.4;opacity:0;pointer-events:none;transition:opacity .15s;z-index:100;box-shadow:0 2px 8px #0006}.timeline-event-tooltip strong{font-weight:600}.timeline-event:hover .timeline-event-tooltip{opacity:1}.timeline-event-tooltip:after{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-bottom-color:var(--color-bg)}@media(max-width:768px){.timeline{padding:4px 16px;gap:12px}.timeline-play-btn{width:40px;height:40px}.timeline-play-btn svg{width:16px;height:16px}.timeline-months{gap:16px;padding:4px 16px 4px 0}.timeline-year{font-size:1.1rem;padding:0 4px}.timeline-month{gap:6px}.timeline-month-label{font-size:.6rem}.timeline-events{gap:8px}.timeline-event{width:14px;height:14px}.timeline-event-tooltip{display:none}}
