@import"https://fonts.googleapis.com/css2?family=Lato:ital,wght@0,300;0,400;0,700;0,900;1,300;1,400;1,700;1,900&display=swap";*{margin:0;padding:0;box-sizing:border-box}body{font-family:Lato,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;color:#333;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;overflow:hidden}.app-container{display:flex;flex-direction:column;height:100vh;position:relative}.header-panel{background:#ffffff40;backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.18);box-shadow:0 8px 32px #1f26875e;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;gap:24px;z-index:100;position:relative}.app-branding{display:flex;align-items:center;gap:12px;min-width:200px}.language-switcher{display:flex;gap:4px;background:#fff3;border-radius:8px;padding:4px;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}.lang-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;border:none;background:transparent;border-radius:6px;cursor:pointer;transition:all .2s ease;color:#fffc;font-size:12px;font-weight:500}.lang-btn:hover{background:#fff3;transform:translateY(-1px)}.lang-btn.active{background:#ffffffe6;color:#333;box-shadow:0 2px 8px #0000001a}.lang-btn .flag{font-size:16px}.lang-btn .lang-code{font-weight:600}.app-icon{font-size:2rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.app-title h1{font-size:1.75rem;font-weight:700;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.2);margin:0}.app-subtitle{font-size:.875rem;color:#fffc;font-weight:400;margin-top:2px;display:block}.control-section{display:flex;align-items:center;gap:20px;flex:1;justify-content:flex-end}.info-card{background:#fff3;backdrop-filter:blur(15px);border:1px solid rgba(255,255,255,.3);border-radius:16px;padding:16px;min-width:280px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 16px #1f268733}.info-card:hover{background:#ffffff4d;transform:translateY(-2px);box-shadow:0 8px 25px #1f26874d}.info-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.satellite-badge{background:#007bffcc;color:#fff;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.date-display{color:#fff;font-weight:600;font-size:.9rem}.info-toggle{background:none;border:none;color:#fff;cursor:pointer;padding:4px;border-radius:4px;transition:background .2s}.info-toggle:hover{background:#ffffff1a}.expand-icon{display:inline-block;transition:transform .3s ease}.expand-icon.expanded{transform:rotate(180deg)}.location-info{display:flex;justify-content:space-between;align-items:center}.location-label{color:#ffffffe6;font-size:.875rem}.tile-id{color:#fff;font-weight:600;font-size:.875rem;background:#ffffff1a;padding:2px 8px;border-radius:8px}.product-details{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.2);animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.detail-row{display:flex;justify-content:space-between;margin:4px 0;font-size:.8rem}.detail-label{color:#ffffffb3}.detail-value{color:#fff;font-weight:500;max-width:60%;text-align:right;word-break:break-all}.band-selector{min-width:220px}.input-label{display:block;color:#fff;font-size:.875rem;font-weight:600;margin-bottom:8px;text-shadow:0 1px 2px rgba(0,0,0,.2)}.modern-select{width:100%;background:#fff3;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-radius:12px;padding:12px 40px 12px 16px;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .3s ease;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23ffffff' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 12px center;background-repeat:no-repeat;background-size:16px}.modern-select:focus{outline:none;background:#ffffff4d;border-color:#ffffff80;box-shadow:0 0 0 3px #ffffff1a}.modern-select option{background:#2a2a2a;color:#fff;padding:8px}.band-description{font-size:.75rem;color:#ffffffb3;margin-top:4px;text-align:center}.action-buttons{display:flex;gap:12px}.action-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;border:none;border-radius:12px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(10px);min-width:120px;justify-content:center}.action-btn.primary{background:#007bffcc;color:#fff;border:1px solid rgba(0,123,255,.3)}.action-btn.primary:hover:not(:disabled){background:#007bff;transform:translateY(-2px);box-shadow:0 8px 25px #007bff4d}.action-btn.secondary{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3)}.action-btn.secondary:hover:not(:disabled){background:#ffffff4d;transform:translateY(-2px);box-shadow:0 8px 25px #ffffff1a}.action-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-icon{font-size:1rem}.btn-text{font-weight:600}.map-wrapper{flex:1;position:relative;overflow:hidden}.map-container{position:relative;height:100%;width:100%}.map-container.fullscreen{position:fixed;inset:0;z-index:1000;height:100vh}.map-controls{position:absolute;top:20px;right:20px;z-index:1001;display:flex;gap:8px;flex-direction:column}.map-control-btn{background:#ffffffe6;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-radius:12px;padding:12px;cursor:pointer;font-size:18px;box-shadow:0 4px 16px #0000001a;min-width:48px;min-height:48px;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1)}.map-control-btn:hover{background:#fff;transform:translateY(-2px);box-shadow:0 8px 25px #00000026}.map-control-btn:active{transform:translateY(0)}.map-container.fullscreen .map-controls{position:fixed!important;top:20px!important;right:20px!important;z-index:9999!important;display:flex!important}.loading-overlay,.error-overlay{position:absolute;inset:0;z-index:1002;display:flex;align-items:center;justify-content:center;background:#0000004d;backdrop-filter:blur(5px)}.loading-card,.error-card{background:#fffffff2;backdrop-filter:blur(20px);border-radius:16px;padding:24px 32px;box-shadow:0 8px 32px #0000001a;display:flex;align-items:center;gap:16px;max-width:400px;text-align:center}.loading-spinner{width:24px;height:24px;border:3px solid #e0e0e0;border-top:3px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text,.error-text{font-weight:600;color:#333}.error-icon{font-size:1.5rem}.leaflet-container{width:100%;height:100%;background:#1a1a2e}.ai-chat-panel{position:fixed;top:0;right:-100%;width:85vw;max-width:400px;height:100vh;background:#fffffff2;backdrop-filter:blur(20px);border-left:1px solid rgba(255,255,255,.3);box-shadow:-8px 0 32px #0000001f;z-index:1001;display:flex;flex-direction:column;transition:right .3s cubic-bezier(.4,0,.2,1);will-change:transform}.ai-chat-panel.open{right:0}.chat-panel-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000052;z-index:1000;opacity:0;visibility:hidden;transition:opacity .3s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(2px)}.chat-panel-backdrop.open{opacity:1;visibility:visible}.chat-panel-header{padding:20px;border-bottom:1px solid rgba(0,0,0,.1);display:flex;justify-content:space-between;align-items:center;background:#fffc;backdrop-filter:blur(20px)}.chat-title h3{margin:0;font-size:1.2rem;color:#333;font-weight:700}.chat-band-context{font-size:.85rem;color:#666;margin-top:4px;font-weight:400}.chat-close-btn{background:#0000000d;border:none;font-size:24px;cursor:pointer;color:#666;padding:8px;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.chat-close-btn:hover{background:#0000001a;color:#333}.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.chat-message{display:flex;flex-direction:column;max-width:85%}.chat-message.user{align-self:flex-end;align-items:flex-end}.chat-message.assistant{align-self:flex-start;align-items:flex-start}.message-content{padding:14px 18px;border-radius:20px;max-width:100%;word-wrap:break-word;box-shadow:0 2px 8px #0000001a}.chat-message.user .message-content{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;border-bottom-right-radius:6px}.chat-message.assistant .message-content{background:#f8f9fae6;backdrop-filter:blur(10px);color:#333;border-bottom-left-radius:6px;border:1px solid rgba(0,0,0,.05)}.message-text{line-height:1.5;font-size:.9rem}.message-text.markdown h1,.message-text.markdown h2,.message-text.markdown h3{font-size:1rem;margin:8px 0 4px;font-weight:700}.message-text.markdown p{margin:4px 0}.message-text.markdown ul,.message-text.markdown ol{margin:4px 0;padding-left:20px}.message-text.markdown li{margin:2px 0}.message-text.markdown strong{font-weight:700}.message-text.markdown em{font-style:italic}.message-text.markdown code{background:#0000001a;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:.85em}.message-time{font-size:.75rem;color:#999;margin-top:6px;opacity:.8}.typing-indicator{display:flex;align-items:center;gap:4px;padding:8px 0}.typing-indicator span{width:8px;height:8px;border-radius:50%;background:#999;animation:typing 1.4s infinite ease-in-out}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{transform:scale(0);opacity:.5}40%{transform:scale(1);opacity:1}}.chat-error{background:#ffebebe6;border:1px solid rgba(220,53,69,.3);color:#721c24;padding:12px 16px;margin:0 20px;border-radius:12px;font-size:.9rem;display:flex;justify-content:space-between;align-items:center;backdrop-filter:blur(10px)}.error-retry-btn{background:#dc3545;color:#fff;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:600;transition:background .2s}.error-retry-btn:hover{background:#c82333}.chat-input-area{padding:20px;border-top:1px solid rgba(0,0,0,.1);background:#ffffffe6;backdrop-filter:blur(20px)}.chat-input-container{display:flex;gap:12px;align-items:flex-end}.chat-input{flex:1;padding:14px 18px;border:1px solid rgba(0,0,0,.15);border-radius:24px;resize:none;font-family:inherit;font-size:.9rem;line-height:1.4;max-height:120px;overflow-y:auto;background:#fffc;backdrop-filter:blur(10px);transition:all .3s ease}.chat-input:focus{outline:none;border-color:#007bff;background:#fffffff2;box-shadow:0 0 0 3px #007bff1a}.chat-send-btn{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;border:none;width:44px;height:44px;border-radius:50%;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #007bff4d}.chat-send-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #007bff66}.chat-send-btn:disabled{background:#6c757d;cursor:not-allowed;opacity:.6;transform:none;box-shadow:none}.chat-input-hint{font-size:.75rem;color:#666;margin-top:8px;text-align:center;opacity:.8}@media (max-width: 1200px){.header-panel{padding:12px 16px;gap:16px}.control-section{gap:16px}.info-card{min-width:240px}.band-selector{min-width:180px}}@media (max-width: 768px){.header-panel{flex-direction:column;align-items:stretch;padding:16px;gap:16px}.app-branding{justify-content:center;min-width:auto}.app-title h1{font-size:1.5rem}.control-section{flex-direction:column;gap:16px}.info-card,.band-selector{min-width:auto;width:100%}.action-buttons{justify-content:center;flex-wrap:wrap}.action-btn{flex:1;min-width:140px}.ai-chat-panel{width:100vw;max-width:none;right:-100vw;border-left:none;box-shadow:0 -4px 20px #00000026}.chat-panel-header{padding:16px}.chat-title h3{font-size:1.1rem}.chat-messages{padding:16px;gap:12px}.message-content{padding:12px 16px;font-size:.85rem}.chat-input-area{padding:16px}.chat-input{padding:12px 16px;font-size:.85rem}.map-controls{top:16px;right:16px;gap:8px}.map-control-btn{min-width:44px;min-height:44px;font-size:16px;padding:10px}.map-container.fullscreen .map-controls{position:fixed!important;top:16px!important;right:16px!important;z-index:99999!important;display:flex!important;flex-direction:column!important}}@media (max-width: 480px){.header-panel{padding:12px}.app-title h1{font-size:1.3rem}.app-subtitle{font-size:.8rem}.info-card{padding:12px}.action-btn{padding:10px 16px;font-size:.8rem;min-width:120px}.btn-text{display:none}.btn-icon{font-size:1.2rem}}
