:root{--primary-bg: #000000;--secondary-bg: #050505;--tertiary-bg: #0a0a0a;--surface-bg: #111111;--border-color: #2a2a2a;--text-primary: #ffffff;--text-secondary: #c0c0c0;--text-muted: #949494;--accent-primary: #ffffff;--accent-secondary: #a8a8a8;--accent-green: #4ade80;--accent-yellow: #ffd700;--accent-red: #ff6b6b;--accent-blue: #4fc3f7;--link-color: #6db3f2;--link-hover: #8fc4f4;--nasa-blue: #ffffff;--nasa-red: #888888;--gradient-primary: linear-gradient(135deg, #ffffff 0%, transparent 50%, #000000 100%);--gradient-hero: repeating-conic-gradient(from 0deg at 50% 50%, #000 0deg, #0a0a0a 10deg, #000 20deg);--gradient-surface: linear-gradient(180deg, #111111 0%, #000000 100%);--red-primary: #1a0000;--red-secondary: #330000;--red-tertiary: #4d0000;--red-surface: #660000;--red-text: #ff6666;--red-text-secondary: #cc4444;--red-accent: #ff3333;--red-text-bright: #ff9999;--red-border: #660000;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 2px 4px rgba(255, 255, 255, .05);--shadow-md: 0 4px 8px rgba(255, 255, 255, .08);--shadow-lg: 0 8px 24px rgba(255, 255, 255, .1);--shadow-glow: 0 0 30px rgba(255, 255, 255, .15);--z-background: 0;--z-content: 1;--z-elevated: 10;--z-dropdown: 100;--z-sticky: 1000;--z-modal: 10000;--z-toast: 10001;--z-skiplink: 100000;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "Inter", "SF Mono", Monaco, "Roboto Mono", monospace;--transition-fast: .15s ease-in-out;--transition-base: .25s ease-in-out;--transition-slow: .35s ease-in-out}:focus-visible{outline:3px solid var(--accent-yellow, #ffd700);outline-offset:2px;border-radius:4px}button:focus-visible,.nav-button:focus-visible,.nav-tab:focus-visible,.hero-cta-button:focus-visible{outline:3px solid var(--accent-yellow, #ffd700);outline-offset:2px;box-shadow:0 0 0 4px #ffd70033}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--accent-blue, #4fc3f7);outline-offset:0;border-color:var(--accent-blue, #4fc3f7)}a:focus-visible{outline:2px solid var(--accent-yellow, #ffd700);outline-offset:2px;text-decoration:underline}.object-card:focus-visible,.feature-card:focus-visible,.telescope-card:focus-visible{outline:3px solid var(--accent-yellow, #ffd700);outline-offset:4px;transform:translateY(-2px)}:focus:not(:focus-visible){outline:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.sr-only-focusable:focus{position:absolute;width:auto;height:auto;padding:.75rem 1.5rem;margin:0;overflow:visible;clip:auto;white-space:normal;z-index:9999;background:var(--accent-yellow, #ffd700);color:var(--primary-bg, #000);text-decoration:none;font-weight:700;border-radius:4px;top:1rem;left:1rem}body{position:relative;background:linear-gradient(110deg,#000,#0a0a1f,#1a1a3e 40%,#2d2d5f,#1a1a3e 60%,#0a0a1f,#000)}body:before{content:"";position:fixed;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(ellipse at center,rgba(255,255,255,.05) 0%,transparent 30%);transform:rotate(25deg);pointer-events:none;z-index:var(--z-background)}body:after{content:"";position:fixed;inset:0;background-image:radial-gradient(2px 2px at 20% 30%,rgba(255,255,255,.8),transparent),radial-gradient(2px 2px at 60% 70%,rgba(255,255,255,.6),transparent),radial-gradient(1px 1px at 50% 50%,rgba(255,255,255,.5),transparent),radial-gradient(1px 1px at 80% 10%,rgba(255,255,255,.7),transparent),radial-gradient(2px 2px at 10% 90%,rgba(255,255,255,.6),transparent),radial-gradient(1px 1px at 95% 40%,rgba(255,255,255,.5),transparent);background-size:100% 100%;pointer-events:none;z-index:var(--z-background);opacity:.6}.app-container{position:relative;z-index:var(--z-content)}body.red-mode{--primary-bg: #0a0000;--secondary-bg: var(--red-primary);--tertiary-bg: var(--red-secondary);--surface-bg: var(--red-tertiary);--border-color: var(--red-border);--text-primary: var(--red-text);--text-secondary: var(--red-text-secondary);--text-muted: #993333;--accent-primary: var(--red-accent);--accent-blue: var(--red-accent);--accent-purple: var(--red-accent);--accent-green: var(--red-accent);--accent-yellow: var(--red-accent);--accent-red: var(--red-accent);--link-color: var(--red-text-bright);--link-hover: var(--red-accent);background:linear-gradient(110deg,#0a0000,#1a0000,#300,#1a0000,#0a0000);transition:background-color .5s ease,color .5s ease}body.red-mode:before{background:radial-gradient(ellipse at center,rgba(80,0,0,.03) 0%,transparent 30%);opacity:.3}body.red-mode:after{background-image:radial-gradient(1px 1px at 20% 30%,rgba(120,0,0,.08),transparent),radial-gradient(1px 1px at 60% 70%,rgba(120,0,0,.08),transparent),radial-gradient(1px 1px at 80% 10%,rgba(120,0,0,.08),transparent);opacity:.1}#home-page{max-width:1200px;margin:0 auto;padding:var(--space-md)}.journey-section{background:var(--secondary-bg);border-radius:var(--radius-lg);padding:var(--space-2xl)}.journey-section{padding:var(--space-lg) var(--space-sm);position:relative}.journey-title{text-align:center;color:var(--text-primary);font-size:1.5rem;margin-bottom:var(--space-xl);font-weight:600}.journey-flowchart{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-md);max-width:800px;margin:0 auto;padding:0}.flow-connector{display:none}.flow-connector.vertical{width:2px;height:60px;grid-column:3;grid-row:2;justify-self:start}.flow-connector.vertical:after{content:"↓";position:absolute;bottom:-15px;left:-7px;color:var(--text-secondary);font-size:1.2rem}.flow-connector.reverse{grid-column:2;grid-row:3}.flow-connector.reverse:after{content:"←";left:-10px;right:auto}.journey-step{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-xs);padding:var(--space-md) var(--space-sm);background:var(--primary-bg);border:1px solid rgba(255,255,255,.1);border-radius:20px;transition:all var(--transition-base);position:relative;min-height:120px;cursor:pointer;overflow:hidden;background:linear-gradient(135deg,#ffffff05,#ffffff0d,#ffffff05),var(--primary-bg);box-shadow:0 4px 15px #0000004d}.journey-step:before{display:none}#home-page .journey-step:before,.journey-section .journey-step:before{display:none!important}.journey-step.completed{border-color:#ffffff4d;background:linear-gradient(135deg,#10b9811a,#10b9810d),var(--primary-bg)}.journey-step.completed:before{background:#10b9814d;content:"✓";color:var(--accent-green)}.journey-step.active{border-color:#ffffff80;background:linear-gradient(135deg,#ffffff14,#ffffff08),var(--primary-bg);animation:subtlePulse 3s ease-in-out infinite}@keyframes subtlePulse{0%,to{box-shadow:0 4px 15px #0000004d}50%{box-shadow:0 4px 25px #ffffff1a}}.journey-step.final{background:linear-gradient(135deg,#ffffff05,#ffffff0d,#ffffff05),linear-gradient(135deg,transparent 0%,transparent 70%,rgba(255,255,255,.03) 100%),var(--primary-bg);border-color:#ffffff1a}.journey-step.final:before{background:#8b5cf633;color:var(--accent-purple)}.journey-step{background:linear-gradient(135deg,#ffffff05,#ffffff0d,#ffffff05),linear-gradient(135deg,transparent 0%,transparent 70%,rgba(255,255,255,.03) 100%),var(--primary-bg)}.journey-step[data-step="1"]{border-radius:20px 20px 5px}.journey-step[data-step="2"]{border-radius:5px 20px 20px}.journey-step[data-step="3"]{border-radius:20px 5px 20px 20px}.journey-step[data-step="4"]{border-radius:20px 20px 20px 5px}.journey-step:after{display:none}.journey-step.current{border-color:#fffc;box-shadow:0 4px 15px #0000004d,0 0 30px #fff3,inset 0 0 20px #ffffff0d;animation:currentGlow 2s ease-in-out infinite}@keyframes currentGlow{0%,to{box-shadow:0 4px 15px #0000004d,0 0 30px #fff3,inset 0 0 20px #ffffff0d}50%{box-shadow:0 4px 25px #0006,0 0 40px #ffffff4d,inset 0 0 30px #ffffff14}}.journey-step[data-step="1"]{animation-delay:.1s}.journey-step[data-step="2"]{animation-delay:.2s}.journey-step[data-step="3"]{animation-delay:.3s}.journey-step[data-step="4"]{animation-delay:.4s}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.journey-step:hover{border-color:#ffffff4d;transform:translateY(-4px) scale(1.02);box-shadow:0 8px 30px #ffffff1a;background:linear-gradient(135deg,#ffffff0d,#ffffff14,#ffffff0d),var(--primary-bg)}.journey-step:hover:before{background:#fff3;color:#fffc}.step-icon{font-size:1.8rem;flex-shrink:0;margin-bottom:var(--space-xs);filter:grayscale(100%) brightness(1.5);opacity:.9;transition:all var(--transition-base)}.journey-step:hover .step-icon{filter:grayscale(0%) brightness(1.2);opacity:1;transform:scale(1.1)}.step-content{flex:1;display:flex;flex-direction:column;gap:2px}.step-title{font-size:.875rem;color:var(--text-primary);margin:0 0 2px;font-weight:400;letter-spacing:.5px;text-transform:uppercase;line-height:1.1}.step-description{color:var(--text-primary);margin:0;font-size:.875rem;line-height:1.3;font-weight:600}.step-action-btn{background:var(--text-primary);color:var(--primary-bg);border:1px solid var(--text-primary);padding:6px 16px;border-radius:16px;font-size:.875rem;cursor:pointer;transition:all var(--transition-base);white-space:nowrap;margin-top:auto;font-weight:500}.step-action-btn:hover{background:var(--primary-bg);color:var(--text-primary);transform:translateY(-2px);box-shadow:var(--shadow-glow)}.learn-section{margin-bottom:var(--space-xl);background:var(--card-bg);border-radius:var(--radius-lg);padding:var(--space-lg)}.learn-header{font-size:1.5rem;color:var(--accent-blue);margin-bottom:var(--space-lg);border-bottom:2px solid var(--border-color);padding-bottom:var(--space-sm)}.learn-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.learn-card{background:var(--bg-primary);border-radius:var(--radius-md);padding:var(--space-md);border:1px solid var(--border-color);transition:transform .2s ease,box-shadow .2s ease}.learn-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.unit-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm)}.unit-icon{font-size:2rem}.unit-header h4{margin:0;color:var(--text-primary)}.unit-value{font-size:1.25rem;font-weight:700;color:var(--accent-blue);margin-bottom:var(--space-xs)}.unit-description{color:var(--text-secondary);margin-bottom:var(--space-xs)}.unit-formula{font-family:monospace;background:var(--secondary-bg);padding:var(--space-xs);border-radius:var(--radius-sm);margin-bottom:var(--space-xs);font-size:.9rem}.unit-example{color:var(--accent-green);font-style:italic;font-size:.9rem}.scale-comparison{background:var(--bg-primary);padding:var(--space-md);border-radius:var(--radius-md);margin-top:var(--space-md)}.scale-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-sm);margin-top:var(--space-md)}.scale-item{text-align:center;padding:var(--space-sm);background:var(--secondary-bg);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:var(--space-xs)}.scale-item span:first-child{font-weight:700;color:var(--accent-blue)}.visual-guide{background:var(--bg-primary);padding:var(--space-md);border-radius:var(--radius-md);margin-top:var(--space-md)}.hand-measurements{display:flex;justify-content:space-around;flex-wrap:wrap;gap:var(--space-md);margin-top:var(--space-md)}.hand-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs)}.hand-icon{font-size:2.5rem}.magnitude-scale{background:var(--bg-primary);padding:var(--space-md);border-radius:var(--radius-md)}.magnitude-items{display:flex;flex-direction:column;gap:var(--space-xs);margin-top:var(--space-md);position:relative;padding-left:var(--space-md)}.magnitude-items:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(to bottom,#ffeb3b,#000);border-radius:2px}.mag-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-xs);background:var(--secondary-bg);border-radius:var(--radius-sm)}.mag-value{font-weight:700;font-family:monospace;min-width:60px;text-align:right}.mag-object{flex:1}.magnitude-info{margin-top:var(--space-md)}.info-card{background:var(--secondary-bg);padding:var(--space-md);border-radius:var(--radius-md)}.info-card h4{margin-bottom:var(--space-sm);color:var(--accent-blue)}.info-card ul{margin:0;padding-left:var(--space-lg)}.info-card li{margin-bottom:var(--space-xs);color:var(--text-secondary)}.misconception-cards{display:grid;gap:var(--space-md)}.myth-card{background:var(--bg-primary);padding:var(--space-md);border-radius:var(--radius-md);border-left:4px solid var(--accent-red)}.myth{color:var(--accent-red);margin-bottom:var(--space-sm);font-weight:700}.fact{color:var(--accent-green)}.quick-ref{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-lg);background:var(--bg-primary);padding:var(--space-md);border-radius:var(--radius-md)}.ref-column h4{color:var(--accent-blue);margin-bottom:var(--space-sm)}.ref-column ul{margin:0;padding-left:var(--space-lg)}.ref-column li{margin-bottom:var(--space-xs);color:var(--text-secondary)}.calendar-controls{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg);padding:0 var(--space-md)}.calendar-month{font-size:1.25rem;color:var(--text-primary);margin:0}.calendar-grid{background:var(--card-bg);border-radius:var(--radius-lg);padding:var(--space-md);margin-bottom:var(--space-lg)}.calendar-header{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:var(--space-sm)}.calendar-day-header{text-align:center;font-weight:600;color:var(--text-secondary);padding:var(--space-xs);font-size:.875rem}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.calendar-day{aspect-ratio:1;padding:4px;background:var(--bg-primary);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;position:relative;display:flex;flex-direction:column;justify-content:space-between}.calendar-day:hover:not(.past):not(.other-month){transform:scale(1.05);box-shadow:0 4px 12px #0000004d}.calendar-day.past{opacity:.4;cursor:not-allowed}.calendar-day.other-month{opacity:.3;cursor:not-allowed}.calendar-day.today{border:2px solid var(--accent-blue)}.calendar-day.excellent{background:linear-gradient(135deg,#00c851,#00a040)}.calendar-day.good{background:linear-gradient(135deg,#33b5e5,#2196f3)}.calendar-day.fair{background:linear-gradient(135deg,#fb3,#ff9800)}.calendar-day.poor{background:linear-gradient(135deg,#f44,#c00)}.calendar-day.empty{visibility:hidden;cursor:default}.calendar-day-header-small{display:flex;justify-content:space-between;align-items:flex-start;width:100%}.calendar-day-number{font-weight:600;font-size:.875rem;line-height:1}.calendar-score-badge{font-size:.875rem;font-weight:700;background:#0006;color:#fff;padding:1px 3px;border-radius:3px;line-height:1}.calendar-day-icons{display:flex;justify-content:center;align-items:center;gap:2px;margin-top:auto}.calendar-moon-small,.calendar-weather-small{font-size:.875rem}.calendar-legend{background:var(--card-bg);border-radius:var(--radius-lg);padding:var(--space-md);margin-bottom:var(--space-lg)}.legend-section h4{font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--space-sm);text-align:center}.legend-items{display:flex;justify-content:center;gap:var(--space-md);margin-bottom:var(--space-sm)}.legend-color{width:20px;height:20px;border-radius:var(--radius-sm)}.legend-color.excellent{background:linear-gradient(135deg,#00c851,#00a040)}.legend-color.good{background:linear-gradient(135deg,#33b5e5,#2196f3)}.legend-color.fair{background:linear-gradient(135deg,#fb3,#ff9800)}.legend-color.poor{background:linear-gradient(135deg,#f44,#c00)}.legend-info{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border-color);text-align:center}.legend-info p{margin:var(--space-xs) 0;font-size:.875rem;color:var(--text-secondary)}.night-details{background:var(--card-bg);border-radius:var(--radius-lg);padding:var(--space-lg)}.night-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);margin-top:var(--space-md)}.detail-card{background:var(--bg-primary);padding:var(--space-md);border-radius:var(--radius-md)}.detail-card h4{margin-bottom:var(--space-sm);color:var(--accent-blue)}.score-display{display:flex;align-items:center;gap:var(--space-sm);margin:var(--space-sm) 0}.score-number{font-size:2rem;font-weight:700}.score-label{font-size:1rem;text-transform:uppercase;opacity:.8}.timeline-container{background:var(--card-bg);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg)}.timeline-container h4{margin-bottom:var(--space-md);color:var(--accent-blue)}.timeline{position:relative;overflow-x:auto}.timeline-hours{display:flex;border-bottom:2px solid var(--border-color);padding-bottom:var(--space-xs);margin-bottom:var(--space-sm)}.timeline-hour{flex:1;text-align:center;font-size:.875rem;color:var(--text-secondary);min-width:40px}.timeline-bars{display:flex;height:40px;margin-bottom:var(--space-sm);border-radius:var(--radius-sm);overflow:hidden}.timeline-bar{display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;transition:opacity .3s ease}.timeline-bar.daylight{background:linear-gradient(135deg,#ffd54f,#ffb300);flex:2}.timeline-bar.civil{background:linear-gradient(135deg,#ff8a65,#ff6e40);flex:1}.timeline-bar.nautical{background:linear-gradient(135deg,#7986cb,#5c6bc0);flex:1}.timeline-bar.astronomical{background:linear-gradient(135deg,#4a5568,#2d3748);flex:1}.timeline-bar.darkness{background:linear-gradient(135deg,#1a202c,#000);flex:4;color:gold}.timeline-moon{display:flex;justify-content:space-between;padding:var(--space-sm) 0;border-top:1px solid var(--border-color)}.moon-event{background:var(--secondary-bg);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.875rem}.time-recommendations{display:flex;flex-direction:column;gap:var(--space-sm)}.time-slot{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xs);background:var(--secondary-bg);border-radius:var(--radius-sm)}.time-slot.visual{border-left:3px solid var(--accent-blue)}.time-slot.photo{border-left:3px solid var(--accent-purple)}.time-slot.golden{border-left:3px solid #ffd700;background:linear-gradient(90deg,rgba(255,215,0,.1),transparent)}.time-label{font-weight:600;font-size:.875rem}.time-range{font-family:monospace;color:var(--accent-green)}.darkness-quality{margin-top:var(--space-sm);padding:var(--space-xs);border-radius:var(--radius-sm);text-align:center}.darkness-excellent{color:#00c851;font-weight:700}.darkness-good{color:#33b5e5}.darkness-fair{color:#fb3}.darkness-poor{color:#f44}.app-nav{display:flex;background:var(--secondary-bg);border-top:2px solid var(--border-color);position:fixed;bottom:0;left:0;right:0;z-index:var(--z-sticky);height:60px;align-items:stretch;padding:0;box-sizing:border-box;box-shadow:0 -2px 10px #0000004d}.nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 var(--space-sm);background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);height:60px;box-sizing:border-box;text-decoration:none;position:relative}.nav-tab:hover{background:var(--tertiary-bg);color:var(--text-primary)}.nav-tab.active{background:var(--tertiary-bg);color:var(--accent-blue);box-shadow:inset 0 3px 0 var(--accent-blue)}.nav-icon{font-size:1.5rem;margin-bottom:4px}.nav-label{font-size:.875rem;font-weight:500}.page{display:none;animation:fadeIn .3s ease-in-out}.pwa-banner,.update-banner{position:fixed;top:0;left:0;right:0;background:var(--accent-blue);color:#fff;padding:var(--space-md);z-index:var(--z-toast);box-shadow:0 2px 10px #0000004d}.update-banner{background:var(--accent-green)}.pwa-banner.hidden,.update-banner.hidden{display:none}.pwa-banner-content,.update-banner-content{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;gap:var(--space-md)}.pwa-banner-buttons{display:flex;gap:var(--space-sm)}.settings-group{background:var(--secondary-bg);padding:var(--space-lg);border-radius:var(--radius-lg);margin-bottom:var(--space-lg)}.settings-group h3{margin-bottom:var(--space-md);color:var(--text-primary)}.settings-group .btn{margin-top:var(--space-sm)}.settings-group .btn-group{display:flex;gap:var(--space-md);align-items:center;margin-top:var(--space-sm)}.settings-group .btn-group .btn{margin-top:0}.about-hero{text-align:left;padding:var(--space-xl) var(--space-md);margin-bottom:var(--space-xl)}.about-hero .app-logo{font-size:4rem;margin-bottom:var(--space-md);filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.app-tagline{font-size:1.5rem;color:var(--accent-blue);margin-bottom:var(--space-sm)}.about-hero .app-description{color:var(--text-secondary);max-width:100%;margin:0;line-height:1.6}.about-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-lg);margin-bottom:var(--space-xl)}.about-card{background:var(--secondary-bg);border:2px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-fast)}.about-card:hover{border-color:var(--accent-blue);transform:translateY(-2px);box-shadow:0 8px 16px #0003}.card-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--tertiary-bg);border-bottom:1px solid var(--border-color)}.card-icon{font-size:1.5rem}.card-header h3{margin:0;font-size:1.1rem;color:var(--text-primary)}.card-body{padding:var(--space-md)}.feature-list{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-sm)}.feature-badge{display:inline-block;padding:4px 8px;background:#10b98133;color:var(--accent-green);border:1px solid var(--accent-green);border-radius:var(--radius-sm);font-size:.875rem;font-weight:600}.data-source{padding:var(--space-sm) 0;border-bottom:1px solid var(--border-color)}.data-source:last-child{border-bottom:none}.data-source a{display:flex;align-items:center;justify-content:space-between;color:var(--text-primary);text-decoration:none;transition:color var(--transition-fast)}.data-source a:hover{color:var(--accent-blue)}.source-type{font-size:.875rem;color:var(--text-muted);background:var(--primary-bg);padding:2px 6px;border-radius:var(--radius-sm)}.catalog-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md);text-align:center}.stat{display:flex;flex-direction:column;gap:4px}.stat-value{font-size:1.5rem;font-weight:700;color:var(--accent-blue)}.stat-label{font-size:.875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.tech-badges{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.tech-badge{display:inline-block;padding:4px 10px;background:var(--tertiary-bg);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.875rem}.developer-links{display:flex;gap:var(--space-md);margin-top:var(--space-md)}.dev-link{display:flex;align-items:center;gap:var(--space-xs);color:var(--accent-blue);text-decoration:none;font-weight:500;transition:opacity var(--transition-fast)}.dev-link:hover{opacity:.8}.copyright-text{font-weight:600;margin-bottom:var(--space-xs)}.about-footer{padding:var(--space-lg);text-align:center;border-top:1px solid var(--border-color);margin-top:var(--space-xl)}.flag-link{display:inline-flex;align-items:center;gap:var(--space-xs);color:var(--text-secondary);text-decoration:none;font-size:.9rem;transition:all var(--transition-fast);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm)}.flag-link:hover{color:var(--text-primary);background:var(--tertiary-bg)}.flag-text{font-style:italic;opacity:.8}.about-content{max-width:1000px;margin:0 auto;padding:var(--space-lg)}.about-content .hero-section{display:flex;flex-direction:row;align-items:center;text-align:left;background:var(--secondary-bg);border-radius:var(--radius-lg);padding:2rem;margin-bottom:var(--space-xl)}.about-content .hero-logo{width:120px;height:120px;object-fit:contain;flex-shrink:0;margin-right:2rem}.about-content .hero-title{font-size:2.5rem;font-weight:800;margin-bottom:.5rem;color:var(--text-primary);background:linear-gradient(135deg,var(--accent-blue) 0%,var(--accent-purple) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.about-content .hero-tagline{font-size:1.1rem;color:var(--text-secondary);margin:0}.version-info{color:var(--text-secondary);font-size:1.1rem;margin-bottom:var(--space-lg)}.about-description{margin-bottom:var(--space-xl);text-align:left}.about-description p{font-size:1.1rem;line-height:1.6;color:var(--text-secondary);max-width:800px;margin:0 auto}.feature-highlights{margin-bottom:var(--space-xl);padding:var(--space-lg);background:var(--secondary-bg);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.feature-highlights h4{color:var(--text-primary);margin-bottom:var(--space-lg);font-size:1.4rem}.feature-highlights ul{list-style:none;padding:0}.feature-highlights li{margin-bottom:var(--space-md);padding-left:var(--space-md);position:relative;color:var(--text-secondary);line-height:1.6}.feature-highlights li:before{content:"→";position:absolute;left:0;color:var(--accent-green);font-weight:700}.credits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-lg);margin-top:var(--space-lg)}.credit-section{background:var(--surface-bg);padding:var(--space-lg);border-radius:var(--radius-md);border:1px solid var(--border-color)}.credit-section h5{color:var(--text-primary);margin-bottom:var(--space-md);font-size:1.2rem;padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-color)}.credit-section ul{list-style:none;padding:0}.credit-section li{margin-bottom:var(--space-md);color:var(--text-secondary);line-height:1.5}.credit-section strong{color:var(--text-primary)}.credit-section a{color:var(--accent-green);text-decoration:none;font-size:.9rem}.credit-section a:hover{text-decoration:underline}.technical-details{margin:var(--space-xl) 0}.tech-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-lg);margin-top:var(--space-lg)}.tech-section{background:var(--secondary-bg);padding:var(--space-lg);border-radius:var(--radius-md);border:1px solid var(--border-color)}.tech-section h5{color:var(--text-primary);margin-bottom:var(--space-md);font-size:1.1rem}.tech-section ul{list-style:none;padding:0}.tech-section li{margin-bottom:var(--space-sm);color:var(--text-secondary);padding-left:var(--space-md);position:relative}.tech-section li:before{content:"•";position:absolute;left:0;color:var(--accent-green)}.acknowledgments{margin:var(--space-xl) 0;padding:var(--space-lg);background:var(--tertiary-bg);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.acknowledgments h4{color:var(--text-primary);margin-bottom:var(--space-lg);font-size:1.4rem}.acknowledgments p{color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-lg)}.acknowledgments ul{list-style:none;padding:0}.acknowledgments li{margin-bottom:var(--space-md);color:var(--text-secondary);line-height:1.6;padding-left:var(--space-lg);position:relative}.acknowledgments li:before{content:"🙏";position:absolute;left:0;top:0}.developer-info{margin:var(--space-xl) 0;padding:var(--space-lg);background:var(--surface-bg);border-radius:var(--radius-lg);border:1px solid var(--border-color);text-align:center}.developer-info h4{color:var(--text-primary);margin-bottom:var(--space-lg);font-size:1.4rem}.developer-info p{color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-md)}.contact-links{display:flex;justify-content:center;gap:var(--space-lg);margin-top:var(--space-lg);flex-wrap:wrap}.contact-link{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);text-decoration:none;transition:all var(--transition-fast)}.contact-link:hover{background:var(--tertiary-bg);border-color:var(--accent-green);transform:translateY(-2px)}.license-info{margin:var(--space-xl) 0;padding:var(--space-lg);background:var(--secondary-bg);border-radius:var(--radius-lg);border:1px solid var(--border-color);text-align:left}.license-info h4{color:var(--text-primary);margin-bottom:var(--space-lg);font-size:1.4rem}.license-info p{color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-md)}.copyright{font-size:.9rem;color:var(--text-muted);margin-top:var(--space-md);text-align:center}.management-section{margin-bottom:var(--space-xl);padding:var(--space-lg);background:var(--secondary-bg);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.management-section h4{color:var(--text-primary);margin-bottom:var(--space-lg);font-size:1.4rem;text-align:center}.management-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-lg);max-width:800px;margin:0 auto}.management-group{background:var(--surface-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);transition:all .3s ease}.management-group:hover{border-color:var(--accent-blue);box-shadow:0 4px 8px #0000001a}.management-group.danger{border-color:#e74c3c4d;background:linear-gradient(135deg,#e74c3c0d,#c0392b0d)}.management-group.danger:hover{border-color:var(--accent-red);box-shadow:0 4px 12px #e74c3c33}.management-group h5{color:var(--text-primary);font-size:1rem;margin-bottom:var(--space-sm);font-weight:600;text-align:center}.button-stack{display:flex;flex-direction:column;gap:var(--space-xs)}.btn-full{width:100%;justify-content:center;padding:var(--space-xs) var(--space-sm);font-size:.875rem}.danger-warning{color:var(--accent-red);font-size:.875rem;text-align:center;margin-top:var(--space-xs);margin-bottom:0;line-height:1.3}.btn-danger{background:linear-gradient(135deg,#e74c3c,#c0392b);border:1px solid rgba(231,76,60,.5);color:#fff;font-weight:600}.btn-danger:hover{background:linear-gradient(135deg,#c0392b,#a93226);border-color:#e74c3c;transform:translateY(-1px);box-shadow:0 4px 12px #e74c3c4d}.data-sources{margin:var(--space-xl) 0}.data-sources h4{color:var(--text-primary);margin-bottom:var(--space-lg);font-size:1.4rem}.attribution-list{list-style:none;padding:0}.attribution-list li{padding:var(--space-sm) 0;border-bottom:1px solid var(--border-color)}.attribution-list a{color:var(--accent-blue);text-decoration:none}.attribution-list a:hover{text-decoration:underline}.skip-link{position:absolute;top:-40px;left:0;background:var(--accent-blue);color:var(--text-primary);padding:8px 12px;text-decoration:none;z-index:var(--z-skiplink);border-radius:var(--radius-sm);font-weight:600}.skip-link:focus{top:10px;left:10px;outline:3px solid var(--accent-yellow);outline-offset:2px}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);color:var(--text-primary);line-height:1.6;min-height:100vh;transition:background-color var(--transition-base),color var(--transition-base)}.app-container{min-height:100vh;padding-top:70px;padding-bottom:60px}#main-content{max-width:1200px;margin:0 auto;padding:var(--space-lg);padding-bottom:calc(var(--space-lg) + 60px);min-height:calc(100vh - 120px)}.page{display:none;animation:fadeIn .3s ease-in}.page.active{display:block}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.app-header{background:var(--secondary-bg);padding:var(--space-sm) var(--space-lg);box-shadow:var(--shadow-md);display:grid;grid-template-columns:minmax(0,auto) 1fr minmax(0,auto);align-items:center;position:fixed;top:0;left:0;right:0;min-height:70px;box-sizing:border-box;z-index:var(--z-dropdown);overflow:visible}.header-left{justify-self:start}.header-center{justify-self:center;display:flex;align-items:center;position:absolute;left:50%;transform:translate(-50%)}.app-branding{display:flex;align-items:center;gap:var(--space-sm)}.app-branding .app-logo{height:60px;max-height:60px;width:auto;max-width:200px;object-fit:contain;filter:brightness(1.1);display:block;margin:auto 0}.version-text{font-size:1.2rem;font-weight:700;color:var(--nasa-blue);padding:0 var(--space-md)}.app-branding .app-title{margin:0;display:flex;align-items:baseline;gap:.5rem}.app-branding .app-subtitle{margin:0;margin-top:-.25rem}.header-center{justify-self:center;text-align:center}.header-right{justify-self:end;display:flex;align-items:center;gap:var(--space-md);padding-right:var(--space-sm);height:100%}.datetime-wrapper{display:flex;align-items:center;gap:var(--space-sm)}.datetime-label{color:var(--text-secondary);font-size:.875rem;white-space:nowrap}.datetime-selector{display:flex;align-items:center;gap:var(--space-xs);background:var(--bg-primary);padding:2px var(--space-xs);border-radius:var(--radius-md);border:1px solid var(--border-color)}.datetime-selector input[type=datetime-local]{background:transparent;border:none;color:var(--text-primary);font-size:.875rem;padding:2px var(--space-xs);width:160px;max-width:160px;flex-shrink:1}.datetime-selector input[type=datetime-local]::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer}.datetime-selector input[type=datetime-local]:focus{outline:none;border-color:var(--accent-blue)}.datetime-selector-mobile{display:none}.app-title{font-size:clamp(1.4rem,3vw,1.8rem);font-weight:700;margin:0 0 2px;background:linear-gradient(135deg,var(--accent-blue),var(--accent-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2}.app-subtitle{color:var(--text-secondary);font-size:.875rem;margin:0;line-height:1.2}.app-version{color:var(--text-secondary);font-size:.875rem;font-family:var(--font-mono);background:var(--tertiary-bg);padding:.125rem .375rem;border-radius:var(--radius-sm);vertical-align:middle;border:1px solid var(--border-color);display:inline-block;margin-left:.25rem}.red-mode-btn{display:flex;align-items:center;gap:var(--space-xs);padding:12px var(--space-md);min-height:44px;min-width:44px;background:var(--secondary-bg);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease;white-space:nowrap}.red-mode-btn:hover{background:var(--tertiary-bg);border-color:var(--accent-red);color:var(--accent-red)}.red-mode-btn.active{background:#fc3d2126;border-color:var(--accent-red);color:var(--accent-red)}.red-mode-btn.active .mode-text{color:var(--accent-red)}.red-mode-btn.active .mode-icon{animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.mode-icon{font-size:.9rem}.mode-text{font-size:.875rem}.toggle-switch{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;transform:translateY(-10px);padding:8px;min-width:60px;min-height:60px}.toggle-label{font-size:.875rem;color:var(--text-secondary);white-space:nowrap;text-align:center;margin-bottom:10px;display:block}.toggle-container{position:relative;width:56px;height:32px;background:var(--tertiary-bg);border:2px solid var(--border-color);border-radius:16px;transition:all var(--transition-fast)}.toggle-slider{position:absolute;top:3px;left:3px;width:24px;height:24px;background:var(--text-secondary);border-radius:50%;transition:all var(--transition-fast)}.red-mode-toggle input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.red-mode-toggle input[type=checkbox]:checked~.toggle-slider{transform:translate(24px);background:var(--accent-red)}.red-mode-toggle input[type=checkbox]:checked~.toggle-container{background:#fc3d2133;border-color:var(--accent-red)}.toggle-switch:hover .toggle-container{border-color:var(--accent-red)}main{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-lg);margin:var(--space-lg) 0}.section{background:var(--secondary-bg);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-md);transition:transform var(--transition-base),box-shadow var(--transition-base)}.section:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.section-title{font-size:1.5rem;font-weight:600;margin-bottom:var(--space-lg);color:var(--accent-blue);border-bottom:2px solid var(--border-color);padding-bottom:var(--space-sm)}.form-group{margin-bottom:var(--space-md)}.form-row{display:flex;gap:var(--space-sm);flex-wrap:wrap;align-items:center;margin-bottom:var(--space-md)}label{display:block;margin-bottom:var(--space-xs);color:var(--text-secondary);font-weight:500;font-size:.9rem}input,select,textarea{width:100%;padding:var(--space-sm) var(--space-md);background:var(--tertiary-bg);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}input:focus,select:focus,textarea:focus{outline:3px solid var(--accent-blue);outline-offset:1px;border-color:var(--accent-blue)}select option{background:var(--secondary-bg);color:var(--text-primary);padding:var(--space-xs)}select option:hover{background:var(--accent-blue);color:#fff}input[type=checkbox]{width:18px;height:18px;margin-right:var(--space-xs);accent-color:var(--accent-blue);cursor:pointer;vertical-align:middle;-webkit-appearance:none;appearance:none;background:var(--tertiary-bg);border:2px solid var(--border-color);border-radius:4px;position:relative;transition:all var(--transition-fast)}input[type=checkbox]:checked{background:var(--accent-blue);border-color:var(--accent-blue)}input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:12px;font-weight:700}input[type=checkbox]:hover{border-color:var(--accent-blue);box-shadow:0 0 0 3px #4a9eff1a}label{display:inline-flex;align-items:center;cursor:pointer;color:var(--text-primary);font-size:.9rem;-webkit-user-select:none;user-select:none}.btn{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--surface-bg);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);text-decoration:none;white-space:nowrap}.btn:hover{background:var(--text-primary);color:var(--primary-bg);border-color:var(--text-primary);transform:translateY(-1px);box-shadow:var(--shadow-glow)}.btn:active{transform:translateY(0)}.btn-secondary{background:var(--tertiary-bg);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--surface-bg)}.btn-success{background:var(--text-primary);color:var(--primary-bg);border-color:var(--text-primary)}.btn-success:hover{background:var(--primary-bg);color:var(--text-primary)}.scoring-update-flash{background:linear-gradient(135deg,var(--accent-green),#16a34a);color:#fff;padding:var(--space-sm) var(--space-md);border-radius:var(--border-radius);margin:var(--space-sm) 0;border:2px solid var(--accent-green);font-weight:500;box-shadow:0 4px 12px #22c55e4d;transition:all .3s ease}.scoring-update-flash:hover{box-shadow:0 6px 16px #22c55e66;transform:translateY(-1px)}.alert{padding:var(--space-sm) var(--space-md);border-radius:var(--border-radius);margin:var(--space-sm) 0;border:1px solid transparent}.alert-success{background:#22c55e1a;border-color:var(--accent-green);color:var(--accent-green)}.btn-warning{background:var(--accent-yellow)}.btn-danger{background:var(--accent-red)}.btn-small{padding:var(--space-xs) var(--space-sm);font-size:.875rem}.btn-large{padding:var(--space-md) var(--space-lg);font-size:1rem}.btn-group{display:flex;gap:var(--space-sm);flex-wrap:wrap}.location-controls{display:flex;gap:var(--space-sm);justify-content:center;align-items:center;flex-wrap:wrap;margin:1.5rem 0}.location-controls .btn{flex:0 0 auto}.objects-controls{display:flex;justify-content:space-between;align-items:center;gap:var(--space-lg);margin-bottom:var(--space-lg);flex-wrap:wrap}.objects-controls .form-group{margin-bottom:0}.objects-controls .btn-group{flex-shrink:0}.weather-grade-display{display:flex;align-items:center;gap:var(--space-lg);margin-bottom:var(--space-xl);padding:var(--space-lg);background:linear-gradient(135deg,var(--bg-primary),var(--secondary-bg));border-radius:var(--radius-lg);border:1px solid var(--border-color)}.grade-circle{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;background:var(--secondary-bg);border:3px solid var(--border-color)}.grade-letter{color:var(--text-primary);transition:color .3s}.grade-letter[data-grade=A]{color:var(--accent-green)}.grade-letter[data-grade=B]{color:var(--accent-blue)}.grade-letter[data-grade=C]{color:var(--accent-yellow)}.grade-letter[data-grade=D]{color:var(--accent-orange)}.grade-letter[data-grade=F]{color:var(--accent-red)}.grade-description{flex:1;font-size:1.1rem}.weather-details{margin-bottom:var(--space-lg)}.weather-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-md)}.weather-item{background:var(--bg-primary);padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border-color);display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-xs);transition:transform .2s,border-color .2s}.weather-item:hover{transform:translateY(-2px);border-color:var(--accent-blue)}.weather-icon{font-size:1.8rem}.weather-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.weather-value{font-size:1.1rem;color:var(--text-primary);font-weight:700}.weather-section{margin-bottom:var(--space-lg)}.forecast-calendar{background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-xl)}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:var(--space-md)}.calendar-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-sm)}.best-night-badge{background:linear-gradient(135deg,var(--accent-purple),var(--nasa-blue));color:#fff;padding:var(--space-xs) var(--space-md);border-radius:20px;font-size:.875rem;display:flex;align-items:center;gap:var(--space-xs);font-weight:500}.calendar-days-horizontal{display:flex;gap:var(--space-sm);overflow-x:auto;padding-bottom:var(--space-sm);margin-bottom:var(--space-md)}.calendar-days-horizontal::-webkit-scrollbar{height:8px}.calendar-days-horizontal::-webkit-scrollbar-track{background:var(--surface-bg);border-radius:4px}.calendar-days-horizontal::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.calendar-days-horizontal::-webkit-scrollbar-thumb:hover{background:var(--accent-blue)}.day-card{flex:0 0 110px;background:var(--surface-bg);border:2px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md) var(--space-sm);text-align:center;cursor:pointer;transition:all .3s ease;position:relative}.day-card:hover{transform:translateY(-3px);box-shadow:0 4px 12px #0000004d;border-color:var(--accent-blue)}.day-card.today{border-color:var(--nasa-blue);background:linear-gradient(135deg,var(--surface-bg),rgba(11,61,145,.1))}.day-card.best-day:before{content:"🏆";position:absolute;top:-8px;right:-4px;font-size:1.1rem}.day-date{font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.5px}.day-name{font-weight:700;margin-bottom:var(--space-sm);font-size:.875rem;color:var(--text-primary)}.day-stars{font-size:1rem;margin-bottom:var(--space-xs);letter-spacing:1px;display:block;min-height:1.2em}.day-description{font-size:.875rem;margin-bottom:var(--space-xs);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.day-description.perfect{color:var(--accent-green)}.day-description.great{color:#50d050}.day-description.good{color:var(--accent-yellow)}.day-description.fair{color:#ff8c00}.day-description.poor{color:var(--accent-red)}.day-moon{font-size:1.3rem;margin-bottom:var(--space-xs)}.day-conditions{display:flex;justify-content:center;gap:var(--space-xs);margin-top:var(--space-xs)}.condition-icon{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;background:var(--primary-bg);border:1px solid var(--border-color)}.forecast-legend{display:flex;justify-content:center;gap:var(--space-lg);flex-wrap:wrap;padding-top:var(--space-md);border-top:1px solid var(--border-color);font-size:.875rem}.legend-item{display:flex;align-items:center;gap:var(--space-xs)}.legend-text{color:var(--text-secondary)}.weather-section-title{font-size:1.1rem;color:var(--text-primary);margin-bottom:var(--space-md);padding-bottom:var(--space-xs);border-bottom:1px solid var(--border-color)}.weather-primary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.weather-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);transition:transform .2s,border-color .2s}.weather-card.primary{background:linear-gradient(135deg,var(--bg-primary),rgba(69,158,255,.05))}.weather-card:hover{transform:translateY(-2px);border-color:var(--accent-blue)}.weather-card-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm)}.weather-card-header .weather-icon{font-size:1.5rem}.weather-card-header .weather-label{font-size:.9rem;color:var(--text-secondary);font-weight:600}.weather-card-value{font-size:1.8rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-xs)}.weather-card-detail{font-size:.875rem;color:var(--text-secondary)}.weather-secondary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--space-md);background:var(--bg-primary);padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border-color)}.weather-stat{display:flex;flex-direction:column;gap:var(--space-xs)}.stat-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.stat-value{font-size:1.2rem;color:var(--text-primary);font-weight:700}.darkness-timeline{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-md)}.timeline-row{display:flex;justify-content:space-between;padding:var(--space-sm) 0;border-bottom:1px solid var(--border-color-light)}.timeline-row:last-child{border-bottom:none}.timeline-row.highlight{background:#459eff1a;margin:0 calc(-1 * var(--space-md));padding:var(--space-sm) var(--space-md);font-weight:600}.timeline-label{color:var(--text-secondary)}.timeline-row.highlight .timeline-label{color:var(--text-primary)}.timeline-time{color:var(--text-primary);font-weight:600;font-family:monospace}.darkness-summary{text-align:center;padding:var(--space-md);background:linear-gradient(135deg,#10b9811a,#459eff1a);border-radius:var(--radius-md);font-weight:600;color:var(--text-primary)}.quality-indicators{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);background:var(--bg-primary);padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border-color)}.quality-item{display:flex;flex-direction:column;gap:var(--space-xs)}.quality-label{font-size:.875rem;color:var(--text-secondary)}.quality-value{font-size:1.1rem;color:var(--accent-green);font-weight:700}.status-indicator{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-lg);font-size:.875rem;font-weight:500}.status-good{background:#10b98133;color:var(--accent-green)}.status-warning{background:#f59e0b33;color:var(--accent-yellow)}.status-danger{background:#ef444433;color:var(--accent-red)}.object-count-status{display:flex;align-items:center;justify-content:center;padding:var(--space-sm) var(--space-md);background:#3b82f61a;border:1px solid var(--accent-blue);border-radius:var(--radius-lg);margin-bottom:var(--space-md)}.count-info{display:flex;align-items:center;gap:var(--space-sm);font-size:.9rem}.total-count{color:var(--accent-blue);font-weight:600}.database-count{color:var(--text-secondary);font-size:.875rem}.score-display{display:flex;align-items:baseline;gap:var(--space-xs);margin-top:var(--space-xs)}.score-value{font-size:1.2rem;font-weight:700;color:var(--accent-green)}.score-label{font-size:.875rem;color:var(--text-secondary);opacity:.8}.object-card[data-score-range=excellent] .score-value{color:var(--accent-green)}.object-card[data-score-range=good] .score-value{color:var(--accent-blue)}.object-card[data-score-range=fair] .score-value{color:var(--accent-yellow)}.object-card[data-score-range=poor] .score-value{color:var(--accent-red)}.recommendations-list{display:flex;flex-direction:column;gap:var(--space-xs)}.recommendation-item{padding:var(--space-sm);border-radius:var(--radius-md);border-left:4px solid transparent;background:#ffffff0d}.recommendation-item.primary{border-left-color:var(--accent-green);background:#10b9811a}.recommendation-item.secondary{border-left-color:var(--accent-blue);background:#3b82f61a}.recommendation-item.tertiary{border-left-color:var(--accent-yellow);background:#f59e0b1a}.recommendation-text{font-size:.9rem;line-height:1.4;color:var(--text-primary)}.map-container{border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-md);margin:var(--space-md) 0;border:2px solid var(--border-color);transition:border-color var(--transition-fast)}.map-container:hover{border-color:var(--accent-blue)}#map{height:350px!important;border-radius:var(--radius-md);position:relative}.objects-list{display:grid;grid-template-columns:repeat(4,1fr)!important;gap:.75rem;padding:.5rem;margin-top:var(--space-md);max-height:75vh;overflow-y:auto;overflow-x:hidden;width:100%}@media (min-width: 1400px){.objects-list{grid-template-columns:repeat(5,1fr)!important}}@media (min-width: 1800px){.objects-list{grid-template-columns:repeat(6,1fr)!important}}.object-card{background:#111;border:1px solid #2a2a2a;border-radius:12px;overflow:hidden;transition:all .3s ease;cursor:pointer;position:relative;box-shadow:0 4px 12px #0000004d}.object-card:hover{transform:translateY(-4px);box-shadow:0 0 30px #ffffff26;border-color:#fff;background:#fff}.object-image{width:100%;height:90px;background:url(../images/backgrounds/587977-computer-backgrounds.jpg)!important;background-size:cover!important;background-position:center!important;background-repeat:no-repeat!important;position:relative;overflow:hidden}.object-image:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:3rem;opacity:.3}.object-card .rank-badge,.object-card .object-rank{position:absolute!important;top:8px!important;left:8px!important;background:linear-gradient(135deg,gold,#ffb300)!important;color:#000!important;padding:6px 10px!important;border-radius:8px!important;font-weight:900!important;font-size:.9rem!important;z-index:var(--z-dropdown)!important;border:2px solid #ffd700!important;box-shadow:0 3px 6px #00000080!important;display:block!important;line-height:1!important}.object-score{position:absolute;top:8px;right:8px;background:#000000b3;color:#fff;padding:4px 12px;border-radius:8px;font-weight:600;font-size:.875rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.object-details{padding:16px}.object-name{font-size:1.125rem;font-weight:600;color:#fff;margin:0 0 4px}.object-type{font-size:.875rem;color:#666;margin:0 0 16px}.object-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.stat-label{font-size:.875rem;color:#666;text-transform:uppercase;display:block}.stat-value{font-size:.875rem;color:#b0b0b0;font-weight:500}.object-card:hover .object-name,.object-card:hover .object-type,.object-card:hover .stat-value,.object-card:hover .stat-label{color:#000}.telescope-settings-btn{display:none}.modal-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:20px;animation:modalFadeIn .3s ease}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.journey-nav-helper{margin-top:2rem;padding:var(--space-lg);background:var(--secondary-bg);border-radius:var(--radius-lg)}.journey-nav-helper .journey-step.completed{border-color:var(--accent-green);background:linear-gradient(135deg,#10b98133,#10b9811a),var(--primary-bg);position:relative}.journey-nav-helper .journey-step.completed:before{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:3rem;color:var(--accent-green);font-weight:700;text-shadow:0 0 20px rgba(16,185,129,.6);animation:checkmarkGlow 2s ease-in-out infinite;z-index:var(--z-elevated)}@keyframes checkmarkGlow{0%,to{text-shadow:0 0 20px rgba(16,185,129,.6);transform:translate(-50%,-50%) scale(1)}50%{text-shadow:0 0 30px rgba(16,185,129,.8);transform:translate(-50%,-50%) scale(1.05)}}.journey-nav-helper .journey-step.completed .step-content{opacity:.6}.journey-nav-helper .journey-step.completed .step-title{color:var(--accent-green)}.journey-nav-helper .journey-step.completed .step-description{color:#10b981cc}.journey-nav-helper .journey-step.current{border:3px solid #ffffff;background:linear-gradient(135deg,#ffffff26,#ffffff14),var(--primary-bg);box-shadow:0 4px 25px #0006,0 0 40px #fff6,inset 0 0 30px #ffffff1a;animation:currentPulse 1.5s ease-in-out infinite;transform:scale(1.05);position:relative}.journey-nav-helper .journey-step.current:after{content:"";position:absolute;inset:-5px;border:2px solid rgba(255,255,255,.3);border-radius:25px;animation:outerGlow 2s ease-in-out infinite}@keyframes currentPulse{0%,to{box-shadow:0 4px 25px #0006,0 0 40px #fff6,inset 0 0 30px #ffffff1a;transform:scale(1.05)}50%{box-shadow:0 8px 35px #00000080,0 0 60px #fff9,inset 0 0 40px #ffffff26;transform:scale(1.08)}}@keyframes outerGlow{0%,to{border-color:#ffffff4d;transform:scale(1)}50%{border-color:#fff9;transform:scale(1.02)}}.journey-nav-helper .journey-step.current .step-title{color:#fff;font-weight:700;text-shadow:0 0 10px rgba(255,255,255,.5)}.journey-nav-helper .journey-step.current .step-description{color:#fff;font-weight:700;text-shadow:0 0 8px rgba(255,255,255,.3)}.location-info-bar{display:flex;justify-content:center;align-items:center;gap:30px;padding:15px;background:#ffffff05;border-radius:10px;margin-bottom:20px;border:1px solid rgba(255,255,255,.1)}.location-info-item{display:flex;align-items:center;gap:8px;font-size:.95rem}.location-info-item strong{color:var(--text-secondary)}.location-info-item .text-primary{color:var(--text-primary);font-weight:500}@media (max-width: 768px){.location-info-bar{flex-direction:column;gap:10px;padding:12px}}.hero-section{text-align:center;padding:80px 60px;max-width:1200px;margin:0 auto}.hero-logo{width:400px;height:auto;margin-bottom:40px;filter:drop-shadow(0 4px 20px rgba(255,215,0,.3));animation:subtle-glow 3s ease-in-out infinite alternate}@keyframes subtle-glow{0%{filter:drop-shadow(0 4px 20px rgba(255,215,0,.3))}to{filter:drop-shadow(0 4px 30px rgba(255,215,0,.5))}}.hero-title{font-size:72px;font-weight:700;line-height:1.1;margin-bottom:30px;background:linear-gradient(135deg,gold,#ffed4e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:glow 3s ease-in-out infinite alternate}@keyframes glow{0%{filter:brightness(1)}to{filter:brightness(1.2)}}.hero-subtitle{font-size:20px;color:var(--text-secondary);margin-bottom:50px;line-height:1.4;max-width:700px;margin-left:auto;margin-right:auto}.hero-cta-button{background:linear-gradient(135deg,gold,#ffed4e);color:var(--primary-bg);padding:18px 50px;border:none;border-radius:50px;font-size:18px;font-weight:700;cursor:pointer;transition:all .3s ease;display:block;margin:30px auto 0;box-shadow:0 4px 15px #ffd7004d;white-space:nowrap;width:fit-content}.hero-cta-button:hover{transform:translateY(-3px);box-shadow:0 6px 25px #ffd70080}.features-section{margin-top:40px;padding:60px;background:#ffffff05;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-width:1200px;margin-left:auto;margin-right:auto}.section-title-landing{font-size:42px;margin-bottom:40px;color:gold;text-align:center}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:40px;margin-top:40px}.feature-card{background:#1e1e32cc;padding:30px;border-radius:15px;border:1px solid rgba(255,215,0,.2);transition:transform .3s ease,border-color .3s ease;text-align:left!important}.feature-card *{text-align:left!important}.feature-card:hover{transform:translateY(-5px);border-color:#ffd70080}.feature-icon{font-size:32px;display:inline-block;vertical-align:middle}.feature-title{font-size:24px;color:gold;margin-bottom:15px;text-align:left!important;display:flex;align-items:center}.feature-description{font-size:16px;color:var(--text-secondary);line-height:1.6;text-align:left!important}.use-case-section{margin-top:80px;padding:60px;background:linear-gradient(135deg,rgba(255,215,0,.05),transparent);border-radius:20px;text-align:center;max-width:1200px;margin-left:auto;margin-right:auto}.scenario-box{max-width:800px;margin:0 auto;padding:40px;background:#1e1e32cc;border-radius:15px;text-align:left}.scenario-text{font-size:18px;line-height:1.8;color:var(--text-primary);margin-bottom:20px}.scenario-highlight{color:gold;font-weight:700}.stats-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:40px;margin-top:80px;padding:60px;background:#ffffff05;border-radius:20px;max-width:1200px;margin-left:auto;margin-right:auto}.stat-item{text-align:center}.stat-number{font-size:56px;font-weight:700;color:gold;margin-bottom:10px;text-shadow:0 0 20px rgba(255,215,0,.5)}.stat-label{font-size:18px;color:var(--text-primary)}.footer-cta{margin-top:100px;text-align:center;padding:60px 20px}.footer-title{font-size:48px;margin-bottom:30px;background:linear-gradient(135deg,gold,#ffed4e);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.footer-subtitle{font-size:24px;color:var(--text-secondary);margin-bottom:40px}@media (max-width: 834px){.hero-logo{width:280px}.hero-title{font-size:48px}.hero-subtitle{font-size:18px}.section-title-landing{font-size:32px}.stat-number{font-size:42px}.footer-title{font-size:36px}.hero-section{padding:40px 20px}.features-section,.use-case-section,.stats-container{padding:30px 15px}.scenario-box{padding:20px}.features-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.stats-container{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px}}@media (max-width: 480px){.hero-logo{width:200px}.hero-section{padding:30px 10px}.features-section,.use-case-section,.stats-container{padding:20px 10px}.scenario-box{padding:15px}.features-grid{grid-template-columns:1fr;gap:15px}.feature-card{padding:20px}.stats-container{grid-template-columns:repeat(2,1fr);gap:15px}}.file-card{background:#050505;border:2px solid #2a2a2a;border-radius:12px;max-width:800px;margin:0 auto;overflow:hidden;box-shadow:0 8px 40px #000c;font-family:Inter,sans-serif}.file-card .card-header{background:linear-gradient(135deg,#000,#fff);padding:24px;position:relative;overflow:hidden}.file-card .card-header:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(0,0,0,.1) 10px,rgba(0,0,0,.1) 20px)}#object-details-modal .file-card .card-header{background-image:url(/images/backgrounds/587977-computer-backgrounds.jpg)!important;background-size:cover!important;background-position:center!important;background-repeat:no-repeat!important}#object-details-modal .file-card .card-header:before{background:#0009!important}#object-details-modal .file-card .card-header h2,#object-details-modal .file-card .card-header h3,#object-details-modal .file-card .card-header h4,#object-details-modal .file-card .card-header .code-name,#object-details-modal .file-card .card-header .object-codename,#object-details-modal .file-card .card-header .classification{color:#fff!important;text-shadow:2px 2px 4px rgba(0,0,0,.8)!important;position:relative;z-index:var(--z-content)}.file-card .card-header{display:flex;justify-content:space-between;align-items:flex-start;position:relative;z-index:var(--z-content)}.file-card .code-name{font-size:2rem;font-weight:800;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.3);margin-bottom:4px}.file-card .classification{background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:8px 16px;border-radius:8px;font-size:1rem;font-weight:700;color:#fff;border:2px solid rgba(255,255,255,.3);display:inline-block}.file-card .close-btn{position:absolute;top:16px;right:16px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;border:2px solid rgba(255,255,255,.3);width:32px;height:32px;border-radius:50%;font-weight:700;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:var(--z-content)}.file-card .close-btn:hover{background:#fff6;transform:scale(1.1)}.file-card .card-content{padding:24px;background:#0a0a0a;display:flex;gap:24px;align-items:flex-start}.file-card .object-image{width:200px;height:200px;background:linear-gradient(135deg,#ffffff 0%,transparent 50%,#000000 100%);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:5rem;position:relative;overflow:hidden;flex-shrink:0}.file-card .object-actual-image,.file-card .object-placeholder-image{width:100%;height:100%;object-fit:cover;border-radius:8px}.file-card .object-icon-fallback{font-size:5rem;color:#fffc}.file-card .stats-section{flex:1;display:flex;flex-direction:column;gap:16px}.file-card .stats-title{font-size:.875rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;padding-bottom:8px;border-bottom:2px solid #2a2a2a}.file-card .data-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px}.file-card .stat-item,.file-card .grid-item{background:#111;padding:16px;border-radius:8px;border:1px solid #2a2a2a}.file-card .stat-label,.file-card .grid-label{font-size:.875rem;color:#666;text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:4px}.file-card .stat-value,.file-card .grid-value{font-size:1.125rem;color:#fff;font-weight:600}.file-card .stat-bar{height:4px;background:#0a0a0a;border-radius:2px;margin-top:8px;overflow:hidden}.file-card .stat-fill{height:100%;background:linear-gradient(135deg,#ffffff 0%,transparent 50%,#000000 100%);border-radius:2px}.file-card .section{padding:24px;background:#050505}.file-card .section-title{font-size:.875rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid #2a2a2a}.file-card .briefing-text,.file-card .description-text{color:#b0b0b0;line-height:1.6;font-size:.875rem}.file-card .equipment-section{padding:0 24px 24px;display:grid;grid-template-columns:1fr 1fr;gap:24px}.file-card .equipment-box{background:#111;padding:16px;border-radius:8px;border:1px solid #2a2a2a}.file-card .equipment-title{font-size:.875rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}.file-card .equipment-list,.file-card .settings-list{padding:0;margin:0;list-style:none}.file-card .equipment-list li,.file-card .settings-list li{color:#b0b0b0;font-size:.875rem;padding:4px 0;display:flex;align-items:center;gap:8px}.file-card .card-footer{background:#0a0a0a;padding:16px 24px;border-top:1px solid #2a2a2a;display:flex;justify-content:space-between;align-items:center}.file-card .file-number{font-size:.875rem;color:#666;font-family:Inter,sans-serif}.file-card .data-source{font-size:.875rem;color:#666}.file-card .data-source a{color:#b0b0b0;text-decoration:none;transition:color .3s}.file-card .data-source a:hover{color:#fff}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.close-modal{position:absolute;top:var(--space-md);right:var(--space-md);background:#00000080;color:#fff;border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.25rem;transition:var(--transition-fast);z-index:var(--z-elevated)}.close-modal:hover{background:var(--accent-danger);transform:rotate(90deg)}.telescope-settings-btn:hover{opacity:1;background:var(--nasa-red);transform:scale(1.1)}.telescope-settings-content{max-width:600px;width:90%}.settings-object-info{padding:var(--space-md);background:var(--tertiary-bg);border-radius:var(--radius-md);margin-bottom:var(--space-md)}.settings-object-info h3{margin:0 0 .5rem;color:var(--accent-green)}.settings-telescope-info{padding:var(--space-sm);background:var(--secondary-bg);border-radius:var(--radius-sm);margin-bottom:var(--space-md)}.settings-recommendations h4{color:var(--accent-blue);margin-bottom:var(--space-md)}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);padding:var(--space-md);background:var(--tertiary-bg);border-radius:var(--radius-md)}.setting-item{display:flex;flex-direction:column;gap:.25rem}.setting-label{font-size:.875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.setting-value{font-size:.95rem;color:var(--text-primary);font-weight:600}.settings-note{margin-top:var(--space-md);padding:var(--space-sm);background:#fc3d211a;border:1px solid var(--nasa-red);border-radius:var(--radius-sm);color:var(--accent-yellow)}.saved-item{padding:var(--space-sm);background:var(--tertiary-bg);border-radius:var(--radius-sm);margin-bottom:var(--space-xs);font-size:.9rem;color:var(--text-secondary)}.objects-list>p,.objects-list>.status-indicator,.objects-list>.loading-message{grid-column:1 / -1}.object-item{display:flex;flex-direction:column;gap:2px;padding:.75rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:linear-gradient(135deg,var(--secondary-bg),var(--tertiary-bg));transition:all var(--transition-fast);cursor:pointer;position:relative;min-height:140px;box-shadow:0 2px 4px #0003}.object-item:hover{background:linear-gradient(135deg,var(--tertiary-bg),var(--surface-bg));border-color:var(--nasa-blue);transform:translateY(-2px) scale(1.02);box-shadow:0 6px 20px #0b3d914d}.object-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.25rem}.object-info{flex:1;min-width:0;text-align:center;margin-bottom:.25rem}.object-name{font-weight:700;color:var(--text-primary);font-size:.95rem;margin-bottom:2px;line-height:1.1}.object-type{color:var(--accent-blue);font-size:.875rem;text-transform:uppercase;letter-spacing:.3px;margin-bottom:.25rem;opacity:.9}.object-best-time{font-size:.875rem;color:#888;margin:.25rem 0;font-weight:400}.object-card:hover .object-best-time{color:#333}.object-details{font-size:.875rem;color:var(--text-secondary)}.object-details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;margin-bottom:.25rem;padding:.25rem;background:#0000004d;border-radius:var(--radius-sm)}.detail-item{display:flex;flex-direction:column;align-items:center;text-align:center}.detail-item.photo-time{background:linear-gradient(135deg,var(--tertiary-bg),var(--secondary-bg));padding:var(--space-sm);border-radius:var(--radius-sm);border:1px solid var(--accent-green);grid-column:span 2}.detail-item.photo-time .detail-label{color:var(--accent-green);font-weight:600;font-size:.9rem}.detail-item.photo-time .detail-value{color:var(--text-primary);font-weight:600;font-size:1rem}.detail-label{font-size:.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:1px}.detail-value{font-size:.875rem;font-weight:600;color:var(--text-primary)}.object-constellation{text-align:center;color:var(--text-secondary);font-size:.875rem;padding-top:var(--space-sm);border-top:1px solid var(--border-color);margin-top:auto}.object-type-difficulty{display:flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-xs)}.difficulty-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.difficulty-easy{background:#22c55e26;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.difficulty-moderate{background:#facc1526;color:#facc15;border:1px solid rgba(250,204,21,.3)}.difficulty-challenging{background:#fb923c26;color:#fb923c;border:1px solid rgba(251,146,60,.3)}.difficulty-expert{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.object-description{padding:var(--space-sm);margin:var(--space-sm) 0;background:#3b82f60d;border-left:3px solid var(--accent-blue);border-radius:var(--radius-sm);font-size:.9rem;line-height:1.5;color:var(--text-secondary)}.viewing-tip{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-sm);margin-top:var(--space-sm);background:#22c55e14;border-radius:var(--radius-sm);font-size:.875rem;line-height:1.4}.tip-icon{flex-shrink:0;font-size:1rem}.tip-text{color:var(--text-secondary)}.fun-fact{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-sm);margin-top:var(--space-sm);background:#a855f714;border-radius:var(--radius-sm);font-size:.875rem;line-height:1.4}.fact-icon{flex-shrink:0;font-size:1rem}.smart-telescope-settings{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-sm);margin-top:var(--space-sm);background:#3b82f614;border-radius:var(--radius-sm);font-size:.875rem;line-height:1.4;border-left:3px solid var(--accent-blue)}.settings-icon{flex-shrink:0;font-size:1rem}.settings-content{flex:1}.telescope-model{font-weight:600;color:var(--accent-blue);margin-bottom:var(--space-xs);font-size:.9rem}.smart-settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xs);margin:var(--space-xs) 0;font-size:.875rem}.setting-item{padding:2px 0}.setting-notes{margin-top:var(--space-xs);padding-top:var(--space-xs);border-top:1px solid rgba(59,130,246,.2);font-style:italic;color:var(--text-secondary);font-size:.875rem;line-height:1.3}.fact-text{color:var(--text-secondary);font-style:italic}.object-score{font-weight:700;font-size:1.1rem;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);min-width:60px;text-align:center}.score-excellent{color:var(--accent-green)}.score-good{color:var(--accent-blue)}.score-fair{background:#f59e0b33;color:var(--accent-yellow)}.score-poor{background:#ef444433;color:var(--accent-red)}.telescope-info{margin:var(--space-md) 0}.info-card{background:var(--surface-bg);border:1px solid var(--border-color);border-radius:var(--radius);padding:var(--space-md);margin-bottom:var(--space-md)}.telescope-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.telescope-header h3{color:#8bb8ff;margin:0;font-size:1.2rem;flex:1}.telescope-card{display:flex;flex-direction:column;background:var(--surface-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-lg);transition:all var(--transition-base);position:relative}.telescope-card-content{flex:1;margin-bottom:var(--space-md);cursor:pointer}.telescope-card-content h3{color:var(--text-primary);margin-bottom:var(--space-sm);font-size:1.1rem}.telescope-card-content p{color:var(--text-secondary);margin:var(--space-xs) 0;font-size:.9rem}.amazon-buy-button{margin-top:auto;padding:var(--space-sm) var(--space-md);background:transparent;color:#ff9500;border:2px solid #ff9500;border-radius:var(--radius-md);text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);transition:all var(--transition-base);font-weight:600;white-space:nowrap;min-height:44px;font-size:.95rem;position:relative;overflow:visible;animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 2px 8px #ff95004d}50%{box-shadow:0 4px 16px #ff950080,0 0 20px #ff950033}}.amazon-buy-button:hover{background:#ff95001a;transform:translateY(-2px) scale(1.05);box-shadow:0 6px 20px #ff950066,0 0 30px #ff95004d;color:#f70;border-color:#f70;animation:none}.amazon-icon{font-size:1.2rem;display:inline-block;animation:bounce-icon 1.5s ease-in-out infinite}@keyframes bounce-icon{0%,to{transform:translateY(0)}25%{transform:translateY(-3px)}75%{transform:translateY(1px)}}.amazon-buy-button:before{content:"✨";position:absolute;top:-8px;right:-8px;font-size:1.2rem;animation:sparkle 2s ease-in-out infinite}@keyframes sparkle{0%,to{transform:scale(1) rotate(0);opacity:.8}25%{transform:scale(1.2) rotate(10deg);opacity:1}50%{transform:scale(1) rotate(-10deg);opacity:.9}75%{transform:scale(1.1) rotate(5deg);opacity:1}}.info-card h3{color:#8bb8ff;margin-bottom:var(--space-md);font-size:1.2rem}#telescope-amazon-link{margin-left:var(--space-md);flex-shrink:0}.amazon-link-wrapper{display:flex;flex-direction:column;gap:var(--space-xs)}.amazon-buy-button{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:var(--secondary-bg);color:var(--text-primary);text-decoration:none;border-radius:var(--radius);font-weight:500;font-size:.875rem;transition:all .3s ease;border:1px solid var(--border-color);box-shadow:0 1px 3px #0000001a;white-space:nowrap}.amazon-buy-button:hover{background:var(--accent-green);transform:translateY(-1px);box-shadow:0 4px 8px #0003;color:#fff;text-decoration:none}.amazon-icon{font-size:1.1rem}.amazon-text{flex:1}.amazon-arrow{font-size:1.2rem;transition:transform .3s ease}.amazon-buy-button:hover .amazon-arrow{transform:translate(3px)}.amazon-disclosure{display:none}.red-mode .amazon-buy-button{background:transparent;border-color:var(--red-accent);color:var(--red-text);animation:pulse-glow-red 2s ease-in-out infinite}@keyframes pulse-glow-red{0%,to{box-shadow:0 2px 8px #ff646433}50%{box-shadow:0 4px 16px #ff64644d,0 0 20px #ff646426}}.red-mode .amazon-buy-button:hover{background:#ff64641a;color:var(--red-text);box-shadow:0 6px 20px #ff64644d,0 0 30px #ff646433;animation:none}.red-mode .amazon-buy-button:before{opacity:.6}.telescope-specs{display:grid;gap:var(--space-sm);background:#0003;border-radius:var(--radius);padding:var(--space-md);margin-top:var(--space-sm)}.spec-row{display:flex;justify-content:space-between;padding:var(--space-xs);background:#0003;border-radius:var(--radius-sm)}.spec-label{color:var(--text-muted);font-weight:500}.spec-row span:last-child{color:var(--text-primary);font-weight:700}.features-display{margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--border-color)}.feature-badge{display:inline-block;background:var(--accent-green);color:var(--bg-primary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);margin:var(--space-xs);font-size:.875rem;font-weight:700}.telescope-capabilities{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border-color)}.capability-title{color:#8bb8ff!important;margin-bottom:var(--space-md);font-size:1rem;font-weight:600}.capability-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-sm)}.capability-item{background:#0000004d;padding:var(--space-sm);border-radius:var(--radius-sm)}.capability-header{display:flex;justify-content:flex-start;align-items:center;gap:var(--space-xs);margin-bottom:var(--space-xs);font-size:.9rem}.capability-bar-wrapper{height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden}.capability-bar{height:100%;border-radius:4px;transition:width var(--transition-base)}.capability-bar.excellent{background:linear-gradient(90deg,var(--accent-green),#22c55e)}.filters-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-xs);margin-top:var(--space-sm)}.accessories-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-md);margin:var(--space-md) 0}.mount-selector{width:100%;padding:var(--space-xs);margin:var(--space-xs) 0;background:var(--secondary-bg);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem}.mount-selector option{background:var(--secondary-bg);color:var(--text-primary)}.mount-info{margin-top:var(--space-xs);padding:var(--space-xs);background:#4a9eff1a;border-radius:var(--radius-sm);border-left:3px solid var(--accent-blue)}.mount-info small{color:var(--text-muted);font-style:italic}.accessory-group{background:var(--surface-bg);padding:var(--space-md);border-radius:var(--radius);border:1px solid var(--border-color);margin-bottom:var(--space-sm)}.accessory-group h4{color:#8bb8ff;margin-bottom:var(--space-md);font-size:1rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.toggle-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xs) 0}.checkbox-item{padding:var(--space-sm) 0;border-bottom:1px solid rgba(255,255,255,.05)}.checkbox-item:last-child{border-bottom:none}.checkbox-item label{display:flex;align-items:center;cursor:pointer;font-size:.95rem;color:var(--text-secondary);transition:color .2s}.checkbox-item label:hover{color:var(--text-primary)}.checkbox-item input[type=checkbox]{width:18px;height:18px;margin-right:var(--space-sm);cursor:pointer;accent-color:var(--accent-blue)}.checkbox-item input[type=checkbox]:checked{accent-color:var(--accent-green)}.checkbox-item span{flex:1;padding-left:var(--space-xs)}.red-mode .checkbox-item input[type=checkbox]{accent-color:var(--red-accent)}.red-mode .checkbox-item input[type=checkbox]:checked{accent-color:var(--red-bright)}.toggle-item span{font-size:.9rem;color:var(--text-secondary)}.toggle-switch{position:relative;display:inline-block;width:48px;height:24px;margin:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--tertiary-bg);transition:.3s;border-radius:24px;border:1px solid var(--border-color)}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:2px;bottom:2px;background-color:var(--text-muted);transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:var(--accent-green);border-color:var(--accent-green)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px);background-color:#fff}.toggle-switch input:focus+.toggle-slider{box-shadow:0 0 1px var(--accent-blue);outline:2px solid var(--accent-blue);outline-offset:2px}.red-mode .toggle-switch input:checked+.toggle-slider{background-color:var(--red-accent);border-color:var(--red-accent)}#telescope-accessories{background:var(--surface-bg);padding:var(--space-md);border-radius:var(--radius);margin-top:var(--space-md);border:1px solid var(--border-color)}.collapsible-content{display:none;overflow:hidden;transition:max-height var(--transition-base),padding var(--transition-base)}.collapsible-content.expanded{display:block;max-height:1500px;padding-top:var(--space-md)}footer{text-align:center;padding:var(--space-lg);color:var(--text-muted);font-size:.875rem;border-top:1px solid var(--border-color);margin-top:var(--space-xl)}.next-step-card{background:linear-gradient(135deg,var(--accent-blue),var(--accent-purple));border-radius:var(--radius-lg);padding:var(--space-lg);margin:var(--space-lg) 0;box-shadow:var(--shadow-lg);animation:slideInUp .3s ease-out}.next-step-content{display:flex;align-items:center;gap:var(--space-lg);color:#fff}.next-step-icon{font-size:3rem;flex-shrink:0;opacity:.9}.next-step-text{flex:1}.next-step-text h3{margin:0 0 var(--space-xs) 0;font-size:1.25rem;font-weight:600}.next-step-text p{margin:0;opacity:.9;font-size:.95rem}.next-step-btn{background:#fff3;border:2px solid rgba(255,255,255,.3);color:#fff;font-weight:600;white-space:nowrap;transition:all var(--transition-fast)}.next-step-btn:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px)}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--text-muted)}.text-primary,.text-success{color:var(--accent-green)}.score-outstanding{color:#15803d;font-weight:700}.score-excellent{color:#16a34a;font-weight:600}.score-good{color:#2563eb;font-weight:600}.score-acceptable{color:#d97706;font-weight:500}.score-challenging{color:#dc2626;font-weight:500}.text-warning{color:var(--accent-yellow)}.text-danger{color:var(--accent-red)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.p-sm{padding:var(--space-sm)}.p-md{padding:var(--space-md)}.p-lg{padding:var(--space-lg)}.hidden{display:none}.visible{display:block}.loading{position:relative;pointer-events:none;opacity:.6}.loading:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid var(--border-color);border-top-color:var(--accent-blue);border-radius:50%;animation:spin 1s linear infinite}.telescope-capabilities{margin-top:var(--space-lg)}.spec-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-sm)}.spec-item{display:flex;flex-direction:column;text-align:center}.spec-label{font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--space-xs)}.spec-value{font-weight:600;color:var(--accent-blue);font-size:1rem}.smart-features{background:var(--tertiary-bg);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-lg)}.smart-features.none{background:var(--surface-bg);text-align:center;color:var(--text-muted);padding:var(--space-sm)}.smart-features h4{margin-bottom:var(--space-sm);color:var(--accent-purple)}.feature-grid{display:flex;gap:var(--space-sm);flex-wrap:wrap}.feature-badge{padding:var(--space-xs) var(--space-sm);background:#8b5cf633;color:var(--accent-purple);border-radius:var(--radius-sm);font-size:.875rem;font-weight:500}.capability-chart{margin-bottom:var(--space-lg)}.capability-chart h4{color:var(--accent-blue);text-align:center}.capability-row{margin-bottom:var(--space-md);background:var(--tertiary-bg);border-radius:var(--radius-md);padding:var(--space-md);transition:background-color var(--transition-fast)}.capability-row:hover{background:var(--surface-bg)}.capability-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.capability-label{font-weight:500;color:var(--text-primary)}.capability-score{font-weight:700;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.9rem}.capability-bar-container{background:var(--border-color);height:8px;border-radius:var(--radius-sm);overflow:hidden;margin-bottom:var(--space-sm)}.capability-bar{height:100%;border-radius:var(--radius-sm);transition:width var(--transition-base)}.capability-bar.excellent{background:linear-gradient(90deg,var(--accent-green),#34d399)}.capability-bar.good{background:linear-gradient(90deg,var(--accent-blue),#60a5fa)}.capability-bar.fair{background:linear-gradient(90deg,var(--accent-yellow),#fbbf24)}.capability-bar.poor{background:linear-gradient(90deg,var(--accent-red),#f87171)}.capability-recommendation{font-size:.875rem;color:var(--text-secondary);font-style:italic}.performance-summary{background:var(--secondary-bg);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-lg);border:1px solid var(--border-color)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md)}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm);background:var(--tertiary-bg);border-radius:var(--radius-sm)}.summary-label{font-weight:500;color:var(--text-secondary)}.summary-value{font-weight:700}.technical-details{background:var(--surface-bg);border-radius:var(--radius-md);padding:var(--space-md);border:1px solid var(--border-color)}.technical-details summary{cursor:pointer;font-weight:600;color:var(--accent-blue);margin-bottom:var(--space-md);-webkit-user-select:none;user-select:none}.technical-details summary:hover{color:var(--accent-purple)}.tech-specs{margin-top:var(--space-md)}.tech-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-sm)}.tech-item{display:flex;justify-content:space-between;padding:var(--space-sm);background:var(--tertiary-bg);border-radius:var(--radius-sm)}.tech-label{font-size:.875rem;color:var(--text-secondary)}.tech-value{font-weight:600;color:var(--text-primary);font-family:var(--font-mono)}.modal{position:fixed;top:0;left:0;width:100%;height:calc(100% - 60px);background:#000c;display:flex;justify-content:center;align-items:center;z-index:calc(var(--z-sticky) - 1);padding:var(--space-md);padding-bottom:calc(var(--space-md) + 60px)}.modal.hidden{display:none}.modal-content{background:var(--secondary-bg);border-radius:var(--radius-lg);width:100%;max-width:1000px;max-height:90vh;overflow-y:auto;border:1px solid var(--border-color);box-shadow:var(--shadow-lg)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--border-color);background:var(--tertiary-bg);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.modal-header h3{margin:0;color:var(--accent-blue)}#comparison-content{padding:var(--space-lg)}.comparison-selector{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}.comparison-telescope{background:var(--tertiary-bg);border-radius:var(--radius-md);padding:var(--space-md)}.comparison-telescope h4{margin-bottom:var(--space-md);color:var(--accent-blue);text-align:center}.comparison-table{width:100%;border-collapse:collapse;margin-top:var(--space-md)}.comparison-table th,.comparison-table td{padding:var(--space-sm);text-align:left;border-bottom:1px solid var(--border-color)}.comparison-table th{background:var(--tertiary-bg);font-weight:600;color:var(--text-secondary)}.comparison-table tr:hover{background:var(--surface-bg)}.comparison-winner{background:#10b9811a!important;color:var(--accent-green);font-weight:700}.comparison-chart{margin:var(--space-lg) 0}.comparison-chart-row{display:flex;align-items:center;margin-bottom:var(--space-md);background:var(--tertiary-bg);border-radius:var(--radius-md);padding:var(--space-md)}.comparison-chart-label{width:150px;font-weight:500;color:var(--text-secondary)}.comparison-bars{flex:1;display:flex;gap:var(--space-sm);align-items:center}.comparison-bar-item{flex:1;display:flex;flex-direction:column;gap:var(--space-xs)}.comparison-bar-label{font-size:.875rem;color:var(--text-muted);text-align:center}.comparison-bar{height:20px;border-radius:var(--radius-sm);position:relative;background:var(--border-color)}.comparison-bar-fill{height:100%;border-radius:var(--radius-sm);transition:width var(--transition-base)}.comparison-bar-score{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.875rem;font-weight:600;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.5)}.object-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000f2;display:flex;justify-content:center;align-items:center;z-index:var(--z-modal);padding:var(--space-md);opacity:0;visibility:hidden;transition:all var(--transition-base)}.object-modal.active{opacity:1;visibility:visible}.object-modal-content{background:var(--secondary-bg);border-radius:var(--radius-lg);width:100%;max-width:900px;max-height:90vh;overflow-y:auto;border:1px solid var(--border-color);box-shadow:var(--shadow-lg);display:grid;grid-template-rows:auto 1fr auto}.object-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--border-color);background:var(--tertiary-bg);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.object-modal-title{margin:0;color:var(--accent-blue);font-size:1.5rem}.object-modal-close{background:var(--surface-bg);border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-sm);cursor:pointer;font-size:1.2rem;transition:all var(--transition-fast)}.object-modal-close:hover{background:var(--accent-red);color:#fff}.object-modal-body{padding:var(--space-lg);display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);align-items:start}.object-image-container{position:relative;border-radius:var(--radius-md);overflow:hidden;background:var(--tertiary-bg);border:1px solid var(--border-color)}.object-image{width:100%;height:auto;display:block;max-height:400px;object-fit:cover;transition:transform var(--transition-base)}.object-image:hover{transform:scale(1.05)}.object-placeholder-image{width:100%;height:auto;display:block;max-height:400px;object-fit:cover;border-radius:var(--radius-md);transition:transform var(--transition-base),filter var(--transition-base);opacity:.9}.object-placeholder-image:hover{transform:scale(1.02);opacity:1;filter:brightness(1.1)}.home-hero{text-align:center;padding:var(--space-2xl) 0;background:linear-gradient(135deg,var(--primary-bg) 0%,var(--secondary-bg) 100%);border-radius:var(--radius-lg);margin-bottom:var(--space-sm)}.app-title-large{font-size:2.5rem;font-weight:700;color:var(--text-primary);margin-bottom:0}.app-subtitle{font-size:1.25rem;color:var(--accent-blue);margin-bottom:var(--space-lg);font-weight:500}.app-description{font-size:1rem;color:var(--text-secondary);max-width:600px;margin:0 auto;line-height:1.6}.how-it-works,.features-overview{margin-bottom:var(--space-2xl)}.journey-path{display:flex;flex-direction:column;gap:0;margin-top:var(--space-xl);padding:0 var(--space-lg);max-width:800px;margin-left:auto;margin-right:auto}.journey-step{display:flex;align-items:flex-start;gap:var(--space-lg);position:relative;animation:fadeInUp .5s ease-out;animation-fill-mode:backwards}.journey-step:nth-child(1){animation-delay:.1s}.journey-step:nth-child(2){animation-delay:.2s}.journey-step:nth-child(3){animation-delay:.3s}.journey-step:nth-child(4){animation-delay:.4s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.step-bubble{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--secondary-bg),var(--tertiary-bg));border:3px solid var(--accent-blue);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;transition:all .3s ease;z-index:var(--z-content)}.journey-step[data-step="2"] .step-bubble{border-color:var(--accent-green)}.journey-step[data-step="3"] .step-bubble{border-color:var(--accent-purple)}.journey-step[data-step="4"] .step-bubble{border-color:var(--accent-yellow)}.step-bubble.celebrate{background:linear-gradient(135deg,var(--accent-purple),var(--accent-blue));animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.step-bubble:hover{transform:scale(1.1);box-shadow:0 0 20px #0b3d9166}.step-emoji{font-size:2.5rem}.step-content{flex:1;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);position:relative;transition:all .3s ease}.step-content:hover{border-color:var(--accent-blue);transform:translate(5px)}.step-content h3{color:var(--text-primary);font-size:1.3rem;margin-bottom:var(--space-sm);font-weight:600}.step-content p{color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-md)}.step-action-btn{background:var(--accent-blue);color:#fff;border:none;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s ease;display:inline-flex;align-items:center;gap:var(--space-xs)}.journey-step[data-step="2"] .step-action-btn{background:var(--accent-green)}.journey-step[data-step="3"] .step-action-btn{background:var(--accent-purple)}.step-action-btn.primary{background:linear-gradient(135deg,var(--accent-purple),var(--accent-blue));font-size:1.1rem;padding:var(--space-md) var(--space-xl)}.step-action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.step-connector{position:absolute;left:40px;top:80px;z-index:var(--z-content);opacity:.8}.journey-step.final .step-connector{display:none}.connector-arrow{animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-lg);margin-top:var(--space-lg)}.feature-card{background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center;transition:transform .2s ease}.feature-card:hover{transform:translateY(-2px)}.feature-icon{font-size:1.5rem;display:inline-block;vertical-align:middle}.feature-card h3{color:var(--text-primary);margin-bottom:var(--space-sm);font-size:1.1rem}.feature-card p{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.get-started{text-align:center;background:var(--tertiary-bg);border-radius:var(--radius-lg);padding:var(--space-2xl);margin-top:var(--space-xl)}.get-started-text{color:var(--text-secondary);margin-bottom:var(--space-lg);font-size:1rem}.get-started-buttons{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap}.btn-large{padding:var(--space-md) var(--space-xl);font-size:1.1rem;min-width:180px}.object-image-credit{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);color:#fff;padding:var(--space-sm);font-size:.875rem;text-align:right}.object-image-loading{display:flex;align-items:center;justify-content:center;height:300px;background:var(--tertiary-bg);color:var(--text-muted);font-style:italic}.object-image-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;background:var(--tertiary-bg);color:var(--text-muted);text-align:center;gap:var(--space-sm)}.object-details{display:flex;flex-direction:column;gap:var(--space-md)}.object-detail-section{background:var(--tertiary-bg);border-radius:var(--radius-md);padding:var(--space-md)}.object-detail-section h3{margin:0 0 var(--space-sm) 0;color:var(--accent-purple);font-size:1.1rem}.object-detail-grid{display:grid;grid-template-columns:auto 1fr;gap:var(--space-xs) var(--space-md);align-items:center}.object-detail-label{font-weight:500;color:var(--text-secondary);font-size:.9rem}.object-detail-value{color:var(--text-primary);font-family:var(--font-mono);font-size:.9rem}.object-observation-info{background:var(--surface-bg);border-radius:var(--radius-md);padding:var(--space-md);border:1px solid var(--accent-blue)}.object-observation-info h3{color:var(--accent-blue);margin:0 0 var(--space-sm) 0}.telescope-score-display{display:flex;align-items:center;gap:var(--space-sm);margin:var(--space-sm) 0}.score-badge{padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-weight:700;font-size:.9rem}.score-badge.excellent{color:var(--accent-green)}.score-badge.good{color:var(--accent-blue)}.score-badge.fair{background:#f59e0b33;color:var(--accent-yellow)}.score-badge.poor{background:#ef444433;color:var(--accent-red)}.object-modal-footer{padding:var(--space-lg);border-top:1px solid var(--border-color);background:var(--tertiary-bg);border-radius:0 0 var(--radius-lg) var(--radius-lg);display:flex;justify-content:space-between;align-items:center}.observation-tips{background:var(--surface-bg);border-radius:var(--radius-md);padding:var(--space-md);border-left:4px solid var(--accent-green)}.observation-tips h4{margin:0 0 var(--space-sm) 0;color:var(--accent-green);font-size:.9rem}.observation-tips ul{margin:0;padding-left:var(--space-lg);color:var(--text-secondary);font-size:.875rem}.observation-tips li{margin-bottom:var(--space-xs)}.object-thumbnail{position:relative;width:60px;height:60px;border-radius:var(--radius-sm);border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast);margin-right:var(--space-sm);overflow:hidden;flex-shrink:0}.object-thumbnail img{width:100%;height:100%;object-fit:cover;display:block}.object-thumbnail .thumbnail-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast)}.object-thumbnail:hover .thumbnail-overlay{opacity:1}.object-thumbnail .view-icon{color:#fff;font-size:1.2rem}.object-thumbnail.fallback{background:var(--tertiary-bg);display:flex;align-items:center;justify-content:center}.object-thumbnail.fallback .thumbnail-icon{font-size:1.8rem;color:var(--text-muted)}.object-thumbnail:hover{transform:scale(1.1);border-color:var(--accent-blue);box-shadow:var(--shadow-sm)}.object-thumbnail-placeholder{position:relative;width:60px;height:60px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--tertiary-bg) 0%,var(--surface-bg) 100%);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;margin-right:var(--space-md);flex-shrink:0;overflow:hidden;box-shadow:inset 0 1px 3px #0000001a}.object-thumbnail-placeholder .placeholder-icon{font-size:1.8rem;opacity:.6;filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}.object-thumbnail-placeholder:hover{background:var(--surface-bg);border-color:var(--accent-blue)}.error-notification{position:fixed;top:20px;left:50%;transform:translate(-50%);background:var(--accent-red);color:#fff;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:var(--z-modal);max-width:90%;text-align:center;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translate(-50%) translateY(-100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.loading-spinner{display:inline-block;width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:var(--accent-blue);border-radius:50%;animation:spin 1s linear infinite}.loading-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:9999}.loading-message{background:var(--secondary-bg);padding:var(--space-lg);border-radius:var(--radius-lg);text-align:center;color:var(--text-primary)}.loading-message .loading-spinner{width:40px;height:40px;margin:0 auto var(--space-md)}@keyframes spin{to{transform:rotate(360deg)}}.btn.loading{position:relative;color:transparent;pointer-events:none}.btn.loading:after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.btn{min-height:44px;min-width:44px;padding:12px 20px}.btn-small{min-height:44px;padding:10px 16px}input[type=checkbox],input[type=radio]{min-width:44px;min-height:44px;margin:0;cursor:pointer}select,input[type=text],input[type=number],input[type=datetime-local]{min-height:44px;padding:10px 12px}@media (min-width: 769px){.object-item:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.app-header{min-height:80px;padding:var(--space-md) var(--space-xl)}.objects-list{gap:1rem;padding:1rem}.file-card{max-width:900px;margin:0 auto}.modal-content{max-width:1200px;max-height:85vh}.nav-tab{transition:all .3s cubic-bezier(.4,0,.2,1)}.nav-tab:hover{background:var(--tertiary-bg);transform:translateY(-2px)}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:var(--primary-bg);border-radius:6px}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:6px;border:2px solid var(--primary-bg)}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@keyframes slideInFromTop{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.section{animation:slideInFromTop .5s ease-out}.btn:focus-visible,.nav-tab:focus-visible{outline:3px solid var(--accent-blue);outline-offset:4px}.file-card{font-size:14px}.file-card .stat-item{padding:12px}.file-card .equipment-list,.file-card .settings-list{font-size:11px;padding-left:0!important;margin:5px 0 0;list-style:none!important}.file-card .equipment-list li,.file-card .settings-list li{position:relative;padding-left:20px;margin-bottom:3px;text-indent:0;list-style:none!important}.file-card .equipment-list li:before,.file-card .settings-list li:before{content:"•";position:absolute;left:8px;color:#8b4513;font-weight:700}.forecast-container{max-width:1200px;margin:0 auto}.calendar-day{min-height:140px;padding:12px}.weather-display{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-lg)}.telescope-card{transition:all .3s ease}.telescope-card:hover{transform:scale(1.02);box-shadow:0 12px 24px #00000026}}@media (min-width: 1920px){#main-content{max-width:1600px}.objects-list{grid-template-columns:repeat(7,1fr)!important}.app-header{padding:var(--space-lg) var(--space-2xl)}.section{padding:var(--space-xl)}}.modal{-webkit-overflow-scrolling:touch}.file-card .stat-item,.file-card .equipment-item,.file-card .btn{min-height:44px;display:flex;align-items:center}.app-nav{padding-bottom:env(safe-area-inset-bottom)}.btn,.nav-tab,.object-item{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.btn:focus-visible,button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:3px solid var(--accent-blue);outline-offset:2px}button,[role=button],input,textarea,select,a[href],[tabindex]:not([tabindex="-1"]){position:relative}@media (prefers-contrast: high){*:focus-visible{outline-width:4px}}@media (prefers-contrast: high){:root{--border-color: #666666;--text-secondary: #ffffff}}*{box-sizing:border-box}html,body{overflow-x:hidden;-webkit-text-size-adjust:100%}#home-page .hero-section{display:flex;flex-direction:row;align-items:center;text-align:left;background:var(--secondary-bg);border-radius:var(--radius-lg);padding:2rem;margin:2rem;min-height:150px}#home-page .hero-logo{width:120px;height:120px;object-fit:contain;flex-shrink:0;margin-right:2rem}#home-page .hero-title{font-size:2.5rem;line-height:1.2;margin:.5rem 0;color:#fff;font-weight:700}#home-page .hero-tagline{font-size:1.2rem;line-height:1.3;margin:0;color:#b0b0b0}.app-container{padding-top:75px;padding-bottom:75px}.app-header{height:70px;padding:.75rem 1rem}.objects-list{grid-template-columns:repeat(2,1fr);gap:.5rem;padding:.5rem}.object-card{min-height:60px}.object-card .object-content{padding:.75rem!important;background:#111111f2!important;-webkit-backdrop-filter:blur(8px)!important;backdrop-filter:blur(8px)!important;border-top:1px solid rgba(255,255,255,.1)!important}.object-card .object-name{font-size:.9rem!important;margin-bottom:.25rem!important;line-height:1.2!important;font-weight:600!important;color:#fff!important;text-shadow:0 1px 2px rgba(0,0,0,.5)!important;margin:0!important}.object-card .object-type{font-size:.875rem!important;margin-bottom:.25rem!important;color:#4fc3f7!important;text-transform:uppercase!important;letter-spacing:.3px!important;font-weight:500!important;text-shadow:0 1px 2px rgba(0,0,0,.3)!important;opacity:1!important}.object-card .object-best-time{font-size:.875rem!important;margin:.25rem 0 0!important;color:#a0a0a0!important;font-weight:400!important;display:flex!important;align-items:center!important;gap:.25rem!important}.object-card:hover .object-name,.object-card:hover .object-type,.object-card:hover .object-best-time{color:#000!important}.sources-section{text-align:center;margin:var(--space-lg) 0}.modal{display:none;position:fixed;z-index:var(--z-sticky);left:0;top:0;width:100%;height:100%;background-color:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background-color:var(--surface-bg);margin:5% auto;padding:0;border:1px solid var(--border-color);border-radius:var(--radius-lg);width:90%;max-width:800px;max-height:85vh;overflow:hidden;box-shadow:0 20px 40px #0006}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--border-color);background:var(--tertiary-bg)}.modal-header h2{margin:0;color:var(--text-primary);font-size:1.5rem}.modal-close{font-size:2rem;font-weight:700;color:var(--text-secondary);cursor:pointer;padding:0 var(--space-sm);line-height:1;transition:color .3s ease}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:var(--space-lg);max-height:60vh;overflow-y:auto}.modal-body .credits-grid{display:grid;grid-template-columns:1fr;gap:var(--space-lg)}.modal-body .credit-section h3{color:var(--accent-blue);margin-bottom:var(--space-md);font-size:1.1rem;border-bottom:1px solid var(--border-color);padding-bottom:var(--space-sm)}.modal-body .credit-section ul{list-style:none;padding:0}.modal-body .credit-section li{margin-bottom:var(--space-md);padding:var(--space-sm);background:var(--bg-primary);border-radius:var(--radius-sm);border-left:3px solid var(--accent-blue)}.modal-body .credit-section li strong{color:var(--text-primary);display:block;margin-bottom:var(--space-xs)}.modal-body .credit-section a{color:var(--accent-blue);text-decoration:none;font-size:.9rem;transition:color .3s ease}.modal-body .credit-section a:hover{color:var(--text-primary);text-decoration:underline}@media (min-width: 768px){.modal-body .credits-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}}.location-resources{margin-top:2rem}.dark-sky-section,.clubs-section{margin-bottom:2rem}.dark-sky-section h3,.clubs-section h3{color:var(--accent-blue);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.locations-grid,.clubs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem;margin-top:1rem}.location-card{background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:0;transition:transform .2s,box-shadow .2s;overflow:hidden}.location-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--accent-blue)}.location-card .card-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--tertiary-bg);border-bottom:1px solid var(--border-color)}.location-card .card-header h4{margin:0;color:var(--text-primary);font-size:1.1rem}.location-card .distance{background:var(--accent-gold);color:var(--bg-primary);padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600}.location-card .card-body{padding:1rem}.location-card .location-type{color:var(--accent-blue);font-size:.9rem;margin-bottom:.5rem;font-weight:600}.location-card .location-info{color:var(--text-secondary);font-size:.9rem;margin-bottom:.75rem}.location-card .description{color:var(--text-secondary);font-size:.9rem;margin:.75rem 0;line-height:1.4}.location-card .facilities{font-size:.875rem;color:var(--text-secondary);margin:.75rem 0}.location-card .facilities strong{color:var(--text-primary)}.location-card .meeting-info,.location-card .membership-fee{font-size:.9rem;margin:.5rem 0;color:var(--text-secondary)}.location-card .meeting-info strong,.location-card .membership-fee strong{color:var(--text-primary)}.location-card .website-link,.location-card .email-link{display:inline-block;margin-top:.75rem;margin-right:1rem;color:var(--accent-blue);text-decoration:none;font-size:.9rem;transition:color .2s}.location-card .website-link:hover,.location-card .email-link:hover{color:var(--accent-green);text-decoration:underline}.location-card .club-links{margin-top:.75rem;display:flex;gap:1rem}.no-location-message{padding:2rem;background:var(--tertiary-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);text-align:center;color:var(--text-secondary)}.no-results{color:var(--text-secondary);font-style:italic;padding:1rem;text-align:center}.planning-setup-required{max-width:600px;margin:2rem auto;padding:2rem;background:var(--card-bg);border-radius:var(--radius-lg);border:1px solid var(--border-color);text-align:center}.setup-header{margin-bottom:2rem}.setup-icon{font-size:3rem;margin-bottom:1rem}.setup-header h3{color:var(--text-primary);font-size:1.5rem;margin-bottom:1rem}.setup-progress{margin-top:1rem}.progress-text{color:var(--text-secondary);font-size:.9rem;margin-bottom:.5rem;display:block}.progress-bar{width:100%;height:6px;background:var(--border-color);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--accent-gold);transition:width .3s ease}.setup-message{margin-bottom:2rem;color:var(--text-secondary);line-height:1.5}.missing-requirements{margin-bottom:2rem;text-align:left}.requirement-item{display:flex;align-items:center;padding:1rem;margin-bottom:.5rem;background:var(--surface-bg);border-radius:var(--radius-md);border:1px solid var(--border-color);cursor:pointer;transition:all .2s ease}.requirement-item:hover{background:var(--tertiary-bg);border-color:var(--accent-gold);transform:translate(4px)}.req-step{background:var(--accent-gold);color:#000;width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem;margin-right:1rem;flex-shrink:0}.req-content{flex:1}.req-name{color:var(--text-primary);font-weight:600;font-size:1.1rem;margin-bottom:.3rem}.req-description{color:var(--text-secondary);font-size:.9rem}.req-arrow{color:var(--accent-gold);font-size:1.2rem;margin-left:1rem}.setup-benefits{margin-bottom:2rem;text-align:left;background:#ffd7000d;padding:1.5rem;border-radius:var(--radius-md);border:1px solid rgba(255,215,0,.1)}.benefit-title{color:var(--text-primary);font-weight:600;margin-bottom:1rem}.benefits-list{list-style:none;padding:0;margin:0}.benefits-list li{padding:.5rem 0;color:var(--text-secondary);font-size:.95rem}.setup-footer{border-top:1px solid var(--border-color);padding-top:1.5rem}.footer-note{color:var(--text-muted);font-style:italic;font-size:.9rem;margin:0}*{touch-action:manipulation}html{font-size:18px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain}button,.btn,.nav-tab,select,input[type=text],input[type=number],input[type=email],textarea,.object-card,.location-card,.club-card,.telescope-card{min-height:48px;min-width:48px}.nav-tabs{height:56px;padding:0 10px;gap:5px}.nav-tab{padding:12px 16px;font-size:.9rem;min-width:auto;flex:1;max-width:140px}input,select,textarea{font-size:16px;padding:12px;border-radius:8px}select{padding-right:36px}.objects-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:16px}.object-card{min-height:160px;cursor:pointer}.weather-forecast{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;padding:16px}.forecast-day{min-height:140px;padding:12px}.location-resources{display:grid;grid-template-columns:1fr;gap:16px;padding:16px}.telescope-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:16px}body.red-mode *:focus-visible{outline:2px solid #ff6666!important;outline-offset:2px!important}body.red-mode img:not(.no-red-filter){filter:brightness(.7) sepia(1) hue-rotate(320deg) saturate(2);opacity:.9}@media (max-width: 767px){html{font-size:16px}.nav-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.nav-tab{font-size:.875rem;padding:10px 12px}.objects-grid{grid-template-columns:1fr}.hero-section{padding:40px 20px}.features-section,.use-case-section,.stats-container{padding:30px 20px}.weather-forecast{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.location-form,.equipment-form{grid-template-columns:1fr}.footer-note,.section-description{display:none}}@media (min-width: 1024px){.objects-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.location-resources{grid-template-columns:repeat(2,1fr)}.telescope-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.weather-forecast{grid-template-columns:repeat(5,1fr)}.features-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1366px){html{font-size:16px}.nav-tab{min-width:100px}.objects-grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:20px}.location-resources{grid-template-columns:repeat(3,1fr)}.hero-section{padding:80px 60px}.features-section,.use-case-section,.stats-container{padding:60px}}@media (orientation: landscape) and (max-height: 600px){.header{padding:8px 16px}.nav-tabs{height:48px}.hero-section{padding:20px}.section-title{font-size:1.5rem;margin-bottom:16px}}@media (prefers-contrast: high){:root{--text-primary: #ffffff;--text-secondary: #e0e0e0;--primary-bg: #000000;--secondary-bg: #0a0a0a;--border-color: #404040}}@media (hover: hover){.object-card:hover,.telescope-card:hover,.btn:hover{transform:translateY(-2px)}}@media (hover: none){.object-card:hover,.telescope-card:hover,.btn:hover{transform:none}.object-card:active,.telescope-card:active,.btn:active{transform:scale(.98);opacity:.9}}@media (max-width: 1024px){button,.nav-tab,.nav-button,select,input[type=text],input[type=number],input[type=date],input[type=time],input[type=search],.btn,.object-card,.calendar-day,.timeline-bar{min-height:44px;padding:12px 16px}input[type=checkbox],input[type=radio]{width:24px;height:24px;margin:10px}select{padding-right:40px}input[type=text],input[type=number],input[type=date],input[type=time],input[type=search],input[type=email],input[type=tel],input[type=password],select,textarea{font-size:16px!important}}@media (max-width: 834px){:root{--space-xs: .375rem;--space-sm: .5rem;--space-md: .875rem;--space-lg: 1.25rem;--space-xl: 1.75rem;--space-2xl: 2.5rem}.object-card,.weather-card,.telescope-card{padding:var(--space-md)}.modal-content{max-width:90vw;max-height:85vh;margin:var(--space-lg)}.calendar-days{gap:3px}.journey-flowchart{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}}@media (max-width: 480px){:root{--space-xs: .25rem;--space-sm: .375rem;--space-md: .625rem;--space-lg: 1rem;--space-xl: 1.5rem;--space-2xl: 2rem;--radius-sm: 3px;--radius-md: 6px;--radius-lg: 10px;--radius-xl: 14px}.objects-grid,.weather-grid,.learn-cards,.quick-ref{grid-template-columns:1fr!important}.object-card,.weather-card,.telescope-card{width:100%;margin:0 0 var(--space-md) 0}.nav-label{display:none}.nav-icon{font-size:1.5rem;margin-bottom:0}.nav-tab{padding:12px 8px}table{display:block;overflow-x:auto;white-space:nowrap}.filter-controls{flex-direction:column;gap:var(--space-sm)}.calendar-day{font-size:.875rem;padding:2px}.calendar-day-number{font-size:.875rem}.journey-flowchart{grid-template-columns:1fr;max-width:300px;margin:0 auto}.step-description{display:none}.timeline-hours{font-size:.875rem}}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(images/layers.png);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(images/layers-2x.png);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(images/marker-icon.png)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.app-nav{position:fixed!important;inset:auto auto 0 50%!important;transform:translate(-50%)!important;width:auto!important;max-width:1000px!important;border-radius:20px 20px 0 0!important;margin:0!important;z-index:var(--z-sticky)!important;background:#14141ef2!important;-webkit-backdrop-filter:blur(10px)!important;backdrop-filter:blur(10px)!important;border-top:1px solid rgba(255,255,255,.1)!important}.app-nav .nav-container{display:flex!important;align-items:center!important;justify-content:center!important;padding:.75rem 1rem!important}.app-nav .nav-button{display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;padding:.5rem .75rem!important;min-height:60px!important}.app-container{padding-bottom:80px!important}#main-content{padding-bottom:calc(var(--space-lg) + 80px)!important}@media (max-width: 834px){.app-nav{left:0!important;right:0!important;transform:none!important;width:100%!important;max-width:100%!important;border-radius:0!important}.app-nav .nav-container{padding:0!important}}.hero-cta-button,.footer-cta .hero-cta-button{display:flex!important;align-items:center!important;justify-content:center!important;text-align:center!important}.capability-score.score-positive{color:#28a745!important;font-weight:700}.capability-score.score-negative{color:#dc3545!important;font-weight:700}.capability-score{transition:color .3s ease}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-bg: #0a0a0f;--secondary-bg: rgba(20, 20, 30, .8);--text-primary: #fff;--text-secondary: #b0b0c0;--accent-blue: #3b82f6;--border-color: rgba(255, 255, 255, .1);--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--radius-md: 8px;--radius-lg: 12px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body{height:100%;width:100%;overflow-x:hidden;margin:0;padding:0}body{position:relative;background:linear-gradient(110deg,#000,#0a0a1f,#1a1a3e 40%,#2d2d5f,#1a1a3e 60%,#0a0a1f,#000);color:var(--text-primary);min-height:100vh}body:before{content:"";position:fixed;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(ellipse at center,rgba(255,255,255,.05) 0%,transparent 30%);transform:rotate(25deg);pointer-events:none;z-index:0}#root{position:relative;z-index:1;min-height:100vh;width:100%}.app-container{position:relative;z-index:2;min-height:100vh;padding-top:70px}.main-content{position:relative;z-index:1;padding:2rem;min-height:calc(100vh - 200px)}button{font-family:inherit;cursor:pointer;outline:none;border:none;background:none}a{color:var(--accent-blue);text-decoration:none}a:hover{text-decoration:underline}*:focus{outline:2px solid var(--accent-blue);outline-offset:2px}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--accent-blue);outline-offset:2px;box-shadow:0 0 0 4px #3b82f626}button:focus:not(:focus-visible),a:focus:not(:focus-visible){outline:none}@media (prefers-contrast: high){*:focus{outline-width:3px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem;position:relative}.loading-spinner-container.small{padding:.5rem;gap:.5rem}.loading-spinner-container.small .loading-spinner{width:20px;height:20px}.loading-spinner-container.large{padding:3rem}.loading-spinner-container.large .loading-spinner{width:60px;height:60px}.loading-spinner{width:40px;height:40px;position:relative}.spinner-ring{position:absolute;width:100%;height:100%;border-radius:50%;border:3px solid transparent;border-top-color:var(--accent-blue, #3b82f6);animation:spin 1.2s cubic-bezier(.5,0,.5,1) infinite}.spinner-ring:nth-child(2){animation-delay:-.3s;border-top-color:var(--accent-blue, #3b82f6);opacity:.7}.spinner-ring:nth-child(3){animation-delay:-.6s;border-top-color:var(--accent-blue, #3b82f6);opacity:.4}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-message{color:var(--text-secondary, #b0b0c0);font-size:.9rem;text-align:center}.btn-loading{position:relative;pointer-events:none;opacity:.7}.btn-loading:after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-left:-8px;margin-top:-8px;border:2px solid transparent;border-radius:50%;border-top-color:currentColor;animation:spin .6s linear infinite}.galaxy-spinner{width:60px;height:60px;position:relative;animation:rotateGalaxy 4s linear infinite}.galaxy-arm{position:absolute;width:100%;height:100%;border:2px solid transparent;border-top-color:var(--accent-blue, #3b82f6);border-radius:50%;opacity:.3}.galaxy-arm:nth-child(1){transform:rotate(0) scale(1);border-top-color:#9333ea;animation:galaxyPulse 2s ease-in-out infinite}.galaxy-arm:nth-child(2){transform:rotate(120deg) scale(.8);border-top-color:#3b82f6;animation:galaxyPulse 2s ease-in-out infinite .5s}.galaxy-arm:nth-child(3){transform:rotate(240deg) scale(.6);border-top-color:#06b6d4;animation:galaxyPulse 2s ease-in-out infinite 1s}.galaxy-core{position:absolute;top:50%;left:50%;width:10px;height:10px;margin:-5px 0 0 -5px;background:radial-gradient(circle,#fff,#3b82f6);border-radius:50%;box-shadow:0 0 20px #3b82f6,0 0 40px #3b82f6}.galaxy-spinner .star{position:absolute;animation:twinkle 2s ease-in-out infinite;font-size:10px;color:#fff}.star-1{top:10px;right:10px;animation-delay:0s}.star-2{bottom:10px;left:10px;animation-delay:.7s}.star-3{top:20px;left:5px;animation-delay:1.4s}@keyframes rotateGalaxy{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes galaxyPulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}@keyframes twinkle{0%,to{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.5)}}.pulsar-spinner{width:60px;height:60px;position:relative;display:flex;align-items:center;justify-content:center}.pulsar-core{font-size:24px;animation:pulsarSpin 1s linear infinite;z-index:2}.pulsar-ring{position:absolute;width:100%;height:100%;border:2px solid var(--accent-blue, #3b82f6);border-radius:50%;opacity:0;animation:pulsarWave 1.5s ease-out infinite}.pulsar-ring:nth-child(2){animation-delay:.5s}.pulsar-ring:nth-child(3){animation-delay:1s}@keyframes pulsarSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulsarWave{0%{transform:scale(.5);opacity:1}to{transform:scale(2);opacity:0}}.orbit-spinner{width:80px;height:80px;position:relative;display:flex;align-items:center;justify-content:center}.orbit-spinner .sun{font-size:24px;position:absolute;z-index:3;filter:drop-shadow(0 0 10px #ffd700)}.planet-orbit{position:absolute;width:60px;height:60px;border:1px solid rgba(255,255,255,.1);border-radius:50%;animation:orbit 3s linear infinite}.planet-orbit.orbit-2{width:80px;height:80px;animation-duration:5s;animation-direction:reverse}.planet{position:absolute;top:-8px;left:50%;transform:translate(-50%);font-size:16px}@keyframes orbit{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.comet-spinner{width:60px;height:60px;position:relative;animation:cometOrbit 2s linear infinite}.comet-head{font-size:20px;position:absolute;top:0;left:50%;transform:translate(-50%);filter:drop-shadow(0 0 10px #fff)}.comet-tail{position:absolute;top:10px;left:50%;width:2px;height:30px;background:linear-gradient(to bottom,#fff,transparent);transform:translate(-50%) rotate(-45deg);transform-origin:top center;opacity:.7}@keyframes cometOrbit{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.toast{position:fixed;top:80px;right:20px;min-width:300px;max-width:500px;padding:16px 20px;background:#14141ef2;border:1px solid rgba(255,255,255,.2);border-radius:8px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 20px #00000080;animation:slideIn .3s ease-out;z-index:var(--z-modal)}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{border-left:4px solid #10b981;background:linear-gradient(90deg,rgba(16,185,129,.1),transparent)}.toast-error{border-left:4px solid #ef4444;background:linear-gradient(90deg,rgba(239,68,68,.1),transparent)}.toast-warning{border-left:4px solid #f59e0b;background:linear-gradient(90deg,rgba(245,158,11,.1),transparent)}.toast-info{border-left:4px solid #3b82f6;background:linear-gradient(90deg,rgba(59,130,246,.1),transparent)}.toast-icon{font-size:24px;flex-shrink:0}.toast-message{flex:1;color:var(--text-primary, #fff);font-size:14px;line-height:1.4}.toast-close{background:none;border:none;color:var(--text-secondary, #b0b0c0);font-size:24px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.toast-close:hover{background:#ffffff1a;color:var(--text-primary, #fff)}.toast:nth-child(2){top:160px}.toast:nth-child(3){top:240px}.toast:nth-child(4){top:320px}.form-group{position:relative;margin-bottom:1.5rem}.form-input{width:100%;padding:.75rem;border:1px solid var(--border-color, rgba(255, 255, 255, .2));border-radius:8px;background:#ffffff0d;color:var(--text-primary, #fff);font-size:1rem;transition:all .3s ease}.form-input:focus{outline:none;border-color:var(--accent-blue, #3b82f6);box-shadow:0 0 0 3px #3b82f61a;background:#ffffff14}.form-input.valid{border-color:#10b981;background:#10b9810d}.form-input.valid:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.form-input.invalid{border-color:#ef4444;background:#ef44440d}.form-input.invalid:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.validation-message{position:absolute;bottom:-1.5rem;left:0;font-size:.875rem;display:flex;align-items:center;gap:.25rem;animation:slideDown .2s ease-out}.validation-message.success{color:#10b981}.validation-message.error{color:#ef4444}.validation-message.warning{color:#f59e0b}@keyframes slideDown{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.validation-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px}.form-input.validating{background-image:linear-gradient(90deg,#3b82f61a,#3b82f633,#3b82f61a);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.field-with-validation{position:relative}.field-with-validation .validation-indicator{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:18px;animation:pop .3s ease}@keyframes pop{0%{transform:translateY(-50%) scale(0)}50%{transform:translateY(-50%) scale(1.2)}to{transform:translateY(-50%) scale(1)}}.input-wrapper{position:relative}.input-wrapper .char-counter{position:absolute;right:10px;bottom:-20px;font-size:.75rem;color:var(--text-secondary, #b0b0c0)}.input-wrapper .char-counter.warning{color:#f59e0b}.input-wrapper .char-counter.error{color:#ef4444}.icon-pulse{animation:iconPulse 2s ease-in-out infinite}@keyframes iconPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.9}}.icon-spin{animation:iconSpin 3s linear infinite}.icon-spin-slow{animation:iconSpin 6s linear infinite}@keyframes iconSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.icon-float{animation:iconFloat 3s ease-in-out infinite}@keyframes iconFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.icon-twinkle{animation:iconTwinkle 2s ease-in-out infinite}@keyframes iconTwinkle{0%,to{opacity:.7;transform:scale(1);filter:brightness(1)}50%{opacity:1;transform:scale(1.15);filter:brightness(1.3) drop-shadow(0 0 8px currentColor)}}.icon-glow{animation:iconGlow 2s ease-in-out infinite}@keyframes iconGlow{0%,to{filter:drop-shadow(0 0 3px currentColor)}50%{filter:drop-shadow(0 0 10px currentColor) drop-shadow(0 0 20px currentColor)}}.icon-orbit{animation:iconOrbit 4s linear infinite}@keyframes iconOrbit{0%{transform:rotate(0) translate(12px) rotate(0)}to{transform:rotate(360deg) translate(12px) rotate(-360deg)}}.icon-blink{animation:iconBlink 3s ease-in-out infinite}@keyframes iconBlink{0%,90%,to{opacity:1}95%{opacity:.2}}.icon-wave{animation:iconWave 2s ease-in-out infinite;transform-origin:center bottom}@keyframes iconWave{0%,to{transform:rotate(0)}25%{transform:rotate(-8deg)}75%{transform:rotate(8deg)}}.icon-bounce{animation:iconBounce 2s ease-in-out infinite}@keyframes iconBounce{0%,to{transform:translateY(0)}25%{transform:translateY(-10px)}50%{transform:translateY(0)}75%{transform:translateY(-5px)}}.icon-flash{animation:iconFlash 3s ease-in-out infinite}@keyframes iconFlash{0%,to{opacity:.5;filter:brightness(.8)}50%{opacity:1;filter:brightness(1.5) drop-shadow(0 0 10px gold)}}.icon-sparkle{animation:iconSparkle 1.5s ease-in-out infinite}@keyframes iconSparkle{0%,to{transform:scale(1) rotate(0);filter:brightness(1)}50%{transform:scale(1.2) rotate(180deg);filter:brightness(1.5) drop-shadow(0 0 10px gold)}}.icon-shooting{animation:iconShooting 3s ease-in-out infinite}@keyframes iconShooting{0%{transform:translate(0);opacity:0}10%{opacity:1}90%{transform:translate(20px,20px);opacity:1}to{transform:translate(25px,25px);opacity:0}}.icon-radar{animation:iconRadar 2s linear infinite}@keyframes iconRadar{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.icon-moon-phase{animation:iconMoonPhase 8s steps(8) infinite}@keyframes iconMoonPhase{0%{content:"🌑"}12.5%{content:"🌒"}25%{content:"🌓"}37.5%{content:"🌔"}50%{content:"🌕"}62.5%{content:"🌖"}75%{content:"🌗"}87.5%{content:"🌘"}to{content:"🌑"}}.nav-icon-animated{display:inline-block;transition:all .3s ease}.nav-button:hover .nav-icon-animated{transform:scale(1.2)}.nav-button.active .nav-icon-animated{animation-duration:1s;filter:drop-shadow(0 0 5px var(--accent-blue))}.red-mode-icon{display:inline-block;transition:all .3s ease}.red-mode-btn.active .red-mode-icon{animation:flashlightBeam 2s ease-in-out infinite}@keyframes flashlightBeam{0%,to{filter:drop-shadow(0 0 5px #ff0000) drop-shadow(0 0 10px #ff0000);transform:scale(1)}50%{filter:drop-shadow(0 0 10px #ff0000) drop-shadow(0 0 20px #ff0000) drop-shadow(0 0 30px #ff0000);transform:scale(1.1)}}.iss-icon{display:inline-block;animation:satelliteOrbit 10s linear infinite}@keyframes satelliteOrbit{0%{transform:rotate(0) translate(15px) rotate(0)}to{transform:rotate(360deg) translate(15px) rotate(-360deg)}}.telescope-icon{display:inline-block;animation:telescopeScan 3s ease-in-out infinite;transform-origin:center bottom}@keyframes telescopeScan{0%,to{transform:rotate(-15deg)}50%{transform:rotate(15deg)}}.rocket-launch{animation:rocketLaunch 3s ease-in-out infinite}@keyframes rocketLaunch{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-15px) scale(1.05)}}.icon-gold{color:gold}.icon-blue{color:#3b82f6}.icon-purple{color:#9333ea}.icon-cyan{color:#06b6d4}.icon-red{color:#ef4444}.icon-green{color:#10b981}.icon-orange{color:#f97316}.icon-hover-grow:hover{transform:scale(1.2);transition:transform .2s ease}.icon-hover-glow:hover{filter:drop-shadow(0 0 10px currentColor);transition:filter .2s ease}.icon-sm{font-size:.875rem}.icon-md{font-size:1.25rem}.icon-lg{font-size:1.5rem}.icon-xl{font-size:2rem}.icon-2xl{font-size:2.5rem}.moon-phase-display{display:inline-block;font-size:2rem;filter:drop-shadow(0 0 10px rgba(255,255,255,.5))}.moon-phase-display.full-moon{animation:moonGlow 3s ease-in-out infinite}@keyframes moonGlow{0%,to{filter:drop-shadow(0 0 10px rgba(255,255,255,.5))}50%{filter:drop-shadow(0 0 20px rgba(255,255,255,.8)) drop-shadow(0 0 30px rgba(255,255,200,.6))}}.icon-aperture-pulse{animation:aperturePulse 2.5s ease-in-out infinite}@keyframes aperturePulse{0%,to{transform:scale(1);filter:brightness(1)}50%{transform:scale(1.1);filter:brightness(1.3) drop-shadow(0 0 8px rgba(255,149,0,.5))}}.icon-focal-zoom{animation:focalZoom 3s ease-in-out infinite}@keyframes focalZoom{0%,to{transform:scale(1);opacity:1}25%{transform:scale(1.2);opacity:.8}50%{transform:scale(.9);opacity:1}75%{transform:scale(1.1);opacity:.9}}.icon-fratio-spark{animation:fratioSpark 2.8s ease-in-out infinite;position:relative}@keyframes fratioSpark{0%,to{transform:scale(1);filter:brightness(1)}20%{transform:scale(1.15);filter:brightness(1.5) drop-shadow(0 0 10px rgba(255,255,0,.7))}40%{transform:scale(.95);filter:brightness(.9)}60%{transform:scale(1.08);filter:brightness(1.2)}}.icon-mount-target{animation:mountTarget 3.5s linear infinite;transform-origin:center}@keyframes mountTarget{0%{transform:rotate(0) scale(1);filter:hue-rotate(0deg)}25%{transform:rotate(90deg) scale(1.05);filter:hue-rotate(90deg)}50%{transform:rotate(180deg) scale(1);filter:hue-rotate(180deg)}75%{transform:rotate(270deg) scale(1.05);filter:hue-rotate(270deg)}to{transform:rotate(360deg) scale(1);filter:hue-rotate(360deg)}}.icon-smart-glow{animation:smartGlow 2s ease-in-out infinite}@keyframes smartGlow{0%,to{transform:scale(1);filter:drop-shadow(0 0 0 rgba(0,255,255,0))}50%{transform:scale(1.08);filter:drop-shadow(0 0 12px rgba(0,255,255,.8)) brightness(1.2)}}.icon-camera-shutter{animation:cameraShutter 3s ease-in-out infinite}@keyframes cameraShutter{0%,85%,to{transform:scale(1);filter:brightness(1)}5%,10%{transform:scale(1.2);filter:brightness(1.8) drop-shadow(0 0 8px rgba(255,255,255,.8))}15%{transform:scale(.9);filter:brightness(.7)}}.icon-ai-pulse{animation:aiPulse 2.2s ease-in-out infinite}@keyframes aiPulse{0%,to{transform:scale(1);filter:hue-rotate(0deg) brightness(1)}33%{transform:scale(1.1);filter:hue-rotate(120deg) brightness(1.3)}66%{transform:scale(1.05);filter:hue-rotate(240deg) brightness(1.1)}}.icon-premium-sparkle{animation:premiumSparkle 1.8s ease-in-out infinite}@keyframes premiumSparkle{0%,to{transform:scale(1) rotate(0);filter:brightness(1) drop-shadow(0 0 0 rgba(255,215,0,0))}25%{transform:scale(1.3) rotate(45deg);filter:brightness(1.5) drop-shadow(0 0 8px rgba(255,215,0,.9))}50%{transform:scale(.9) rotate(90deg);filter:brightness(1.2) drop-shadow(0 0 4px rgba(255,215,0,.6))}75%{transform:scale(1.2) rotate(135deg);filter:brightness(1.4) drop-shadow(0 0 6px rgba(255,215,0,.8))}}.icon-build-effect{animation:buildEffect 4s ease-in-out infinite}@keyframes buildEffect{0%,to{transform:scale(1) rotate(0);filter:brightness(1)}25%{transform:scale(1.1) rotate(-5deg);filter:brightness(1.2)}50%{transform:scale(1.05) rotate(0);filter:brightness(1.1) drop-shadow(0 0 6px rgba(255,165,0,.6))}75%{transform:scale(1.1) rotate(5deg);filter:brightness(1.2)}}.star-rating-container{display:flex;flex-direction:column;gap:.25rem}.star-rating-row{display:flex;align-items:center;justify-content:space-between;padding:.25rem .5rem;border-radius:4px;background:#0000001a;transition:all .3s ease;animation:fadeInUp .4s ease-out forwards;opacity:0;transform:translateY(10px);font-size:.85rem}.star-rating-row:hover{background:#ffd7001a;transform:translateY(-2px);box-shadow:0 4px 12px #ffd70033}.star-rating-row:nth-child(1){animation-delay:.1s}.star-rating-row:nth-child(2){animation-delay:.2s}.star-rating-row:nth-child(3){animation-delay:.3s}.star-rating-row:nth-child(4){animation-delay:.4s}.star-rating-row:nth-child(5){animation-delay:.5s}.star-rating-row:nth-child(6){animation-delay:.6s}.star-rating-row:nth-child(7){animation-delay:.7s}.star-rating-row:nth-child(8){animation-delay:.8s}.star-rating-row:nth-child(9){animation-delay:.9s}.star-rating-row:nth-child(10){animation-delay:1s}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.object-type-name{display:flex;align-items:center;gap:.3rem;font-weight:500;color:#e2e8f0;min-width:100px;font-size:.85rem}.object-type-icon{font-size:1rem;display:inline-block}.star-rating-display{display:flex;align-items:center;gap:.5rem}.star-container{display:flex;gap:1px;align-items:center}.star{font-size:1rem;color:#4a5568;position:relative;transition:all .3s ease;animation:starFadeIn .6s ease-out forwards;opacity:0;transform:scale(0)}.star.filled{color:gold;text-shadow:0 0 8px rgba(255,215,0,.4)}.star.half-filled{background:linear-gradient(90deg,gold 50%,#4a5568 50%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.star:nth-child(1){animation-delay:.2s}.star:nth-child(2){animation-delay:.4s}.star:nth-child(3){animation-delay:.6s}.star:nth-child(4){animation-delay:.8s}.star:nth-child(5){animation-delay:1s}@keyframes starFadeIn{0%{opacity:0;transform:scale(0) rotate(-180deg)}50%{opacity:1;transform:scale(1.2) rotate(-90deg)}to{opacity:1;transform:scale(1) rotate(0)}}.numeric-score{font-size:.75rem;color:#a0aec0;font-weight:400;min-width:35px;text-align:right}.star-rating-row:hover .star.filled{color:orange;text-shadow:0 0 12px rgba(255,165,0,.6);animation:starPulse 1s ease-in-out infinite}@keyframes starPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.performance-excellent .object-type-name{color:#48bb78}.performance-good .object-type-name{color:#68d391}.performance-average .object-type-name{color:#f6e05e}.performance-poor .object-type-name{color:#fc8181}.performance-excellent:hover .star.filled,.performance-good:hover .star.filled{animation:starSparkle 2s ease-in-out infinite}@keyframes starSparkle{0%,to{transform:scale(1);filter:brightness(1)}25%{transform:scale(1.1) rotate(5deg);filter:brightness(1.3) drop-shadow(0 0 8px #FFD700)}50%{transform:scale(1.05);filter:brightness(1.1)}75%{transform:scale(1.1) rotate(-5deg);filter:brightness(1.3) drop-shadow(0 0 8px #FFD700)}}.nav-container{display:flex;gap:.25rem;padding:1rem;max-width:1400px;margin:0 auto}.nav-button{background:transparent;border:1px solid transparent;color:#b0b0c0;padding:.75rem 1.25rem;border-radius:8px;cursor:pointer;font-size:.95rem;display:flex;align-items:center;gap:.5rem;transition:all .3s ease;font-weight:500}.nav-button:hover{background:#ffffff0d;color:#fff}.nav-button.active{background:#3b82f626;border-color:#3b82f6;color:#fff}.nav-icon{font-size:1.1rem}.nav-label{font-family:inherit}.journey-progress{padding:1rem;background:#ffffff05;border-top:1px solid rgba(255,255,255,.05)}.progress-steps{display:flex;align-items:center;justify-content:center;max-width:600px;margin:0 auto}.progress-step{display:flex;flex-direction:column;align-items:center;gap:.5rem;position:relative}.step-number{width:32px;height:32px;border-radius:50%;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem;color:#b0b0c0;transition:all .3s ease}.progress-step.active .step-number{background:#3b82f6;border-color:#3b82f6;color:#fff;box-shadow:0 0 20px #3b82f680}.progress-step.completed .step-number{background:#22c55e33;border-color:#22c55e;color:#22c55e}.step-label{font-size:.75rem;color:#b0b0c0;text-transform:uppercase;letter-spacing:.5px}.progress-step.active .step-label{color:#3b82f6;font-weight:600}.progress-step.completed .step-label{color:#22c55e}.progress-line{width:80px;height:2px;background:#ffffff1a;position:relative;margin:0 .5rem 1.5rem}.progress-step.completed+.progress-line{background:#22c55e}@media (max-width: 768px){.nav-container{flex-wrap:wrap;justify-content:center}.nav-button{padding:.6rem 1rem;font-size:.9rem}.nav-label{display:none}.nav-icon{font-size:1.3rem}.journey-progress{display:none}}
