.user-profile{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:#ffffff1a;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.user-info{display:flex;flex-direction:column;min-width:0;gap:.125rem}.user-name{font-weight:600;font-size:.875rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:.75rem;color:#fffc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-roles{font-size:.7rem;color:#ffffffb3;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-button{background:#ffffff26;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.4rem .875rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.logout-button:hover{background:#ffffff40;border-color:#ffffff4d;transform:translateY(-1px)}.logout-button:active{transform:translateY(0)}@media (max-width: 768px){.user-email,.user-roles{display:none}.user-profile{gap:.5rem}}.app-header .user-profile{background:#00000026}.app-header .user-profile .logout-button{background:#ffffff1a}.app-header .user-profile .logout-button:hover{background:#fff3}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.login-card{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:420px;width:100%;overflow:hidden}.login-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;text-align:center}.login-header h1{margin:0 0 .5rem;font-size:2.5rem;font-weight:700;letter-spacing:2px}.subtitle{margin:0;font-size:.9rem;opacity:.95;font-weight:300;letter-spacing:1px}.login-content{padding:2rem}.login-message{text-align:center;color:#333;margin:0 0 1.5rem;font-size:1rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500;font-size:.9rem}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.login-error{background:#fee;border:1px solid #fcc;border-radius:6px;padding:.75rem 1rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem;color:#c33;font-size:.9rem}.error-icon{font-size:1.2rem}.login-button{width:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #667eea4d;margin-top:.5rem}.login-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.login-button:active{transform:translateY(0);box-shadow:0 2px 8px #667eea4d}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-footer{margin:1.5rem 0 0;text-align:center;font-size:.85rem;color:#666;line-height:1.5}@media (prefers-color-scheme: dark){.login-card{background:#1a1a1a}.login-message{color:#e0e0e0}.login-footer{color:#999}}.callback-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.callback-card{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:420px;width:100%;padding:3rem 2rem;text-align:center}.callback-card.error{border-top:4px solid #e53e3e}.callback-spinner{margin-bottom:1.5rem;display:flex;justify-content:center}.spinner{width:48px;height:48px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.callback-icon{font-size:3rem;margin-bottom:1rem}.callback-card h2{margin:0 0 .75rem;color:#333;font-size:1.5rem;font-weight:600}.callback-card p{margin:0 0 1.5rem;color:#666;font-size:.95rem;line-height:1.6}.error-message{background:#fee;border:1px solid #fcc;border-radius:6px;padding:.75rem;color:#c33;margin:1.5rem 0;font-size:.9rem}.callback-button{display:inline-block;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;border-radius:6px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s ease;box-shadow:0 4px 12px #667eea4d}.callback-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}@media (prefers-color-scheme: dark){.callback-card{background:#1a1a1a}.callback-card h2{color:#e0e0e0}.callback-card p{color:#999}.spinner{border-color:#333;border-top-color:#667eea}}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#0a0a0a;background-color:#f5f7fb;line-height:1.5;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-height:100vh}a{color:inherit}code{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.9rem}.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem clamp(1.5rem,2vw,3rem);background:linear-gradient(135deg,#0a3f8c,#0d5fbf);color:#fff}.brand{display:flex;align-items:center;gap:1rem}.brand-mark{display:grid;place-items:center;width:3.25rem;height:3.25rem;border-radius:.75rem;font-weight:700;font-size:1.35rem;background-color:#fff3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.brand-copy{display:flex;flex-direction:column;gap:.15rem;font-size:.95rem}.header-status{display:flex;flex-direction:column;align-items:flex-end;gap:.35rem;text-align:right}.app-main{flex:1;padding:clamp(1.5rem,3vw,3rem);min-height:0;overflow:auto}.app-layout{display:grid;grid-template-columns:1fr 400px;gap:2rem;align-items:start;width:100%}.main-content{display:flex;flex-direction:column;gap:clamp(2rem,3vw,3.5rem);min-width:0;grid-column:1}.sidebar-right{min-width:0;grid-column:2}@media (max-width: 1024px){.app-layout{grid-template-columns:1fr}.main-content,.sidebar-right{grid-column:1}}.hero{display:grid;gap:clamp(1.5rem,3vw,3rem);grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.hero-copy{display:flex;flex-direction:column;gap:1.5rem;max-width:600px}.hero-copy h1{margin:0;font-size:clamp(2rem,5vw,2.85rem);color:#0a3f8c}.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.6rem 1.25rem;border-radius:999px;border:1px solid transparent;font-weight:600;text-decoration:none;transition:background-color .2s ease,box-shadow .2s ease,border-color .2s ease;cursor:pointer}.btn.primary{background:#0a3f8c;color:#fff;box-shadow:0 12px 24px #0a3f8c33}.btn.secondary{background:#fff;border-color:#0a3f8c40;color:#0a3f8c}.btn:hover{filter:brightness(1.05)}.hero-card{background:#fff;border-radius:1.25rem;padding:1.75rem;box-shadow:0 18px 36px #0f1e340d;display:flex;flex-direction:column;gap:.75rem}.hero-card h2{margin:0;font-size:1.35rem}.hero-card dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:.35rem 1rem}.hero-card dt{font-weight:600;color:#42526e}.hero-card dd{margin:0}.features{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.feature-card{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 14px 30px #0f1e340a;display:flex;flex-direction:column;gap:.75rem}.feature-card svg{width:2.5rem;height:2.5rem;color:#0d5fbf}.feature-card h3{margin:0}.next-steps{background:#fff;border-radius:1.25rem;padding:1.75rem;box-shadow:0 16px 32px #0f1e340d}.next-steps h2{margin-top:0}.next-steps ol{margin:0;padding-left:1.25rem}.status-pill{display:inline-flex;align-items:center;gap:.4rem;border-radius:999px;padding:.4rem .9rem;font-weight:600;text-transform:capitalize}.status-pill:before{content:"";width:.5rem;height:.5rem;border-radius:50%;background:currentColor}.status-pill.status-connected{background:#38cc8c26;color:#1f9d55}.status-pill.status-disconnected{background:#ff634726;color:#d64545}.status-pill.status-connecting,.status-pill.status-reconnecting,.status-pill.status-idle{background:#ffc10726;color:#b8860b}.status-pill.status-online{background:#38cc8c26;color:#1f9d55}.status-pill.status-offline{background:#ff634726;color:#d64545}.status-pill.status-unknown{background:#ffc10726;color:#b8860b}.status-caption{font-size:.85rem;color:#ffffffd9}.status-blurb{font-weight:600}.status-blurb.status-connected{color:#1f9d55}.status-blurb.status-disconnected{color:#d64545}.status-blurb.status-connecting,.status-blurb.status-reconnecting,.status-blurb.status-idle{color:#b8860b}.status-blurb.status-online{color:#1f9d55}.status-blurb.status-offline{color:#d64545}.status-blurb.status-unknown{color:#b8860b}.sw-toast{position:fixed;inset:auto 1.5rem 1.5rem auto;display:flex;align-items:center;gap:1rem;background:#0a3f8c;color:#fff;padding:.75rem 1.25rem;border-radius:.75rem;box-shadow:0 16px 34px #0a3f8c40}.sw-actions{display:flex;gap:.5rem}.sw-actions button{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:999px;padding:.35rem .9rem;cursor:pointer;font-weight:600}.sw-actions button:hover{background:#ffffff40}.app-footer{display:flex;justify-content:space-between;align-items:center;padding:1.5rem clamp(1.5rem,2vw,3rem);background:#0b1a2b;color:#ffffffbf;gap:1rem}@media (max-width: 720px){.app-header{flex-direction:column;align-items:flex-start;gap:1rem}.header-status{align-items:flex-start;text-align:left}.sw-toast{left:1.5rem;right:1.5rem}}.telemetry-controls{display:flex;flex-direction:column;gap:.75rem;max-width:480px}.telemetry-controls label{display:flex;flex-direction:column;gap:.35rem}.telemetry-controls label span{font-weight:600}.telemetry-controls input{padding:.6rem .75rem;border-radius:.75rem;border:1px solid rgba(10,63,140,.25);font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease}.telemetry-controls input:focus{outline:none;border-color:#0a3f8c;box-shadow:0 0 0 3px #0a3f8c26}.telemetry-panels{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.telemetry-map{display:flex;flex-direction:column;gap:.75rem;background:#fff;border-radius:1.25rem;padding:1.25rem;box-shadow:0 18px 36px #0f1e340d}.telemetry-map__header{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.telemetry-map__content{display:flex;flex-direction:column;gap:.75rem}.telemetry-map__tile{position:relative;width:256px;height:256px;max-width:100%;border-radius:.75rem;overflow:hidden;align-self:flex-start}.telemetry-map__tiles{position:absolute;top:0;right:0;bottom:0;left:0;transform-origin:top left}.telemetry-map__tiles img{position:absolute}.telemetry-map__tile img{display:block;width:100%;height:auto}.telemetry-map__aircraft{position:absolute;pointer-events:none;transform-origin:center}.telemetry-map__aircraft svg{width:24px;height:24px;fill:#0a3f8c;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.telemetry-map__meta{margin-top:.5rem;display:flex;flex-wrap:wrap;gap:.75rem;font-size:.85rem;color:#253649}
