html{overflow-x:hidden}body,html{width:100%}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--color-primary:#1a73e8;--color-primary-light:#4285f4;--color-primary-dark:#0d47a1;--color-primary-rgb:26,115,232;--color-secondary:#42a5f5;--color-secondary-light:#90caf9;--color-secondary-dark:#1e88e5;--color-info:#2196f3;--color-gray-50:#fafafa;--color-gray-100:#f5f5f5;--color-gray-200:#eeeeee;--color-gray-300:#e0e0e0;--color-gray-400:#bdbdbd;--color-gray-500:#9e9e9e;--color-gray-600:#757575;--color-gray-700:#616161;--color-gray-800:#424242;--color-gray-900:#212121;--color-black:#000000;--color-sun-none:#9e9e9e;--color-sun-low:#5dade2;--color-sun-moderate:#f7b731;--color-sun-high:#ff9f43;--color-sun-extreme:#ff6b35;--font-primary:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;--font-display:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto",sans-serif;--font-mono:"SF Mono","Monaco","Inconsolata","Fira Code","Fira Mono","Droid Sans Mono","Courier New",monospace;--font-weight-light:300;--font-weight-normal:400;--line-height-none:1;--line-height-tight:1.25;--line-height-snug:1.375;--line-height-relaxed:1.625;--spacing-0:0;--spacing-1:0.25rem;--spacing-2:0.5rem;--spacing-3:0.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--spacing-16:4rem;--spacing-20:5rem;--spacing-24:6rem;--shadow-sm:0 1px 2px 0 rgba(0,0,0,0.05);--shadow-base:0 1px 3px 0 rgba(0,0,0,0.1),0 1px 2px 0 rgba(0,0,0,0.06);--shadow-md:0 4px 6px -1px rgba(0,0,0,0.1),0 2px 4px -1px rgba(0,0,0,0.06);--shadow-lg:0 10px 15px -3px rgba(0,0,0,0.1),0 4px 6px -2px rgba(0,0,0,0.05);--shadow-xl:0 20px 25px -5px rgba(0,0,0,0.1),0 10px 10px -5px rgba(0,0,0,0.04);--shadow-2xl:0 25px 50px -12px rgba(0,0,0,0.25);--shadow-inner:inset 0 2px 4px 0 rgba(0,0,0,0.06);--shadow-none:none;--z-index-negative:-1;--z-index-0:0;--z-index-10:10;--z-index-20:20;--z-index-30:30;--z-index-40:40;--z-index-50:50;--z-index-auto:auto;--z-index-dropdown:1000;--z-index-sticky:1020;--z-index-fixed:1030;--z-index-modal-backdrop:1040;--z-index-modal:1050;--z-index-popover:1060;--z-index-tooltip:1070;--z-index-notification:1080;--transition-none:none;--transition-all:all 150ms cubic-bezier(0.4,0,0.2,1);--transition-colors:background-color 150ms cubic-bezier(0.4,0,0.2,1),border-color 150ms cubic-bezier(0.4,0,0.2,1),color 150ms cubic-bezier(0.4,0,0.2,1),fill 150ms cubic-bezier(0.4,0,0.2,1),stroke 150ms cubic-bezier(0.4,0,0.2,1);--transition-opacity:opacity 150ms cubic-bezier(0.4,0,0.2,1);--transition-shadow:box-shadow 150ms cubic-bezier(0.4,0,0.2,1);--transition-transform:transform 150ms cubic-bezier(0.4,0,0.2,1);--breakpoint-xs:0;--breakpoint-sm:576px;--breakpoint-md:768px;--breakpoint-lg:992px;--breakpoint-xl:1200px;--breakpoint-2xl:1400px;--button-padding-x:var(--spacing-4);--button-padding-y:var(--spacing-2);--button-font-size:var(--font-size-base);--button-font-weight:var(--font-weight-medium);--button-line-height:var(--line-height-normal);--button-border-radius:var(--radius-md);--button-min-height:44px;--card-padding:var(--spacing-5);--card-border-radius:var(--radius-xl);--card-shadow:var(--shadow-md);--card-bg:var(--color-white);--input-padding-x:var(--spacing-3);--input-padding-y:var(--spacing-2);--input-font-size:var(--font-size-base);--input-line-height:var(--line-height-normal);--input-border-radius:var(--radius-md);--input-border-color:var(--color-gray-300);--input-focus-border-color:var(--color-primary);--input-min-height:44px;--nav-height:60px;--nav-bg:var(--color-primary);--nav-color:var(--color-white);--focus-outline-width:2px;--focus-outline-color:var(--color-primary);--focus-outline-offset:2px}@media (prefers-color-scheme:dark){:root{--color-gray-50:#121212;--color-gray-100:#1e1e1e;--color-gray-200:#2e2e2e;--color-gray-300:#3e3e3e;--color-gray-400:#4e4e4e;--color-gray-500:#6e6e6e;--color-gray-600:#8e8e8e;--color-gray-700:#aeaeae;--color-gray-800:#cecece;--color-gray-900:#eeeeee;--card-bg:var(--color-gray-100);--card-shadow:0 4px 6px -1px rgba(0,0,0,0.3),0 2px 4px -1px rgba(0,0,0,0.2);--input-border-color:var(--color-gray-600);--input-bg:var(--color-gray-200)}}.focus-visible{outline:var(--focus-outline-width) solid var(--focus-outline-color);outline-offset:var(--focus-outline-offset)}.transition-colors{transition:var(--transition-colors)}.transition-transform{transition:var(--transition-transform)}.transition-all{transition:var(--transition-all)}body{font-family:var(--font-primary);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-gray-900);background-color:#ffffff}.language-selector{display:flex;flex-direction:column;gap:8px;font-family:inherit}.language-selector-label{font-size:.875rem;font-weight:500;color:#374151;margin-bottom:4px}.language-selector-dropdown .language-select{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;background-color:white;font-size:.875rem;color:#374151;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}.language-selector-dropdown .language-select:hover{border-color:#9ca3af}.language-selector-dropdown .language-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.language-selector-buttons{flex-direction:row;align-items:center;gap:12px}.language-buttons{display:flex;gap:4px;background-color:#f3f4f6;border-radius:8px;padding:4px}.language-button{padding:6px 12px;border:none;border-radius:4px;background-color:initial;color:#6b7280;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-transform:uppercase;min-width:36px}.language-button:hover{background-color:#e5e7eb;color:#374151}.language-button:focus{outline:none;box-shadow:0 0 0 2px rgba(59,130,246,.5)}.language-button.active{background-color:#3b82f6;color:white}.language-button.active:hover{background-color:#2563eb}@media (max-width:768px){.language-selector-buttons{flex-direction:column;align-items:flex-start;gap:8px}.language-buttons{width:100%;justify-content:flex-start}}@media (prefers-contrast:high){.language-selector-dropdown .language-select{border-width:2px;border-color:#000}.language-button{border:1px solid #000}.language-button.active{background-color:#000;color:#fff}}@media (prefers-reduced-motion:reduce){.language-button,.language-selector-dropdown .language-select{transition:none}}[dir=rtl] .language-buttons,[dir=rtl] .language-selector-buttons{flex-direction:row-reverse}.App{min-height:100vh;background-color:#ffffff;background-image:linear-gradient(180deg,#ffffff 0,#f5f9fc);width:100%;overflow-x:hidden;position:relative}.App-header{background:var(--color-white);padding:var(--spacing-3) var(--spacing-5);border-bottom:1px solid var(--color-gray-200);box-shadow:0 1px 3px rgba(0,0,0,.05)}.header-content{max-width:var(--breakpoint-xl);margin:0 auto;display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-5);flex-wrap:wrap}.header-left{flex:1 1}.header-right{display:flex;align-items:center;gap:16px}.App-header h1{margin:0;font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-primary);letter-spacing:-.025em}.App-header p{margin:var(--spacing-1) 0 0 0;color:var(--color-gray-600);font-weight:var(--font-weight-normal)}.App-header p,.quick-summary{font-size:var(--font-size-sm)}.quick-summary{display:flex;gap:var(--spacing-3);justify-content:flex-start;align-items:center;margin-top:var(--spacing-3);padding:var(--spacing-2) var(--spacing-3);background:var(--color-gray-50);border-radius:var(--radius-lg);width:-webkit-fit-content;width:-moz-fit-content;width:fit-content;border:1px solid var(--color-gray-200)}.stadium-name{font-weight:var(--font-weight-semibold)}.game-time{opacity:.8}.header-share-btn{margin-left:auto}.App-main{max-width:var(--breakpoint-xl);margin:0 auto;padding:var(--spacing-3) var(--spacing-5)}.controls{background:var(--card-bg);border-radius:var(--card-border-radius);padding:var(--spacing-4);margin-bottom:var(--spacing-4);box-shadow:var(--card-shadow);display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:var(--spacing-4);gap:var(--spacing-4)}.stadium-select{font-size:var(--font-size-base)}.date-input,.time-input{padding:8px 12px}.date-input:focus,.time-input:focus{box-shadow:0 0 0 2px rgba(26,35,126,.1)}.results{display:grid;grid-template-columns:1fr;grid-gap:16px;gap:16px;width:100%;overflow-x:hidden}.filter-and-sections-container{display:grid;grid-template-columns:400px 1fr;grid-gap:var(--spacing-5);gap:var(--spacing-5);margin-bottom:var(--spacing-5);align-items:start}.filter-and-sections-container>:first-child{align-self:start}.filter-and-sections-container>:last-child{min-width:0;width:100%;overflow:visible}.section-overview{width:100%;margin-bottom:var(--spacing-5);grid-column:1/-1;overflow-x:auto;-webkit-overflow-scrolling:touch}.overview-stats{display:flex;justify-content:space-around;background:var(--color-white);border-radius:var(--radius-xl);padding:var(--spacing-4);box-shadow:var(--shadow-md);border:1px solid var(--color-gray-200);transition:var(--transition-shadow)}.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-2);border-radius:var(--radius-lg);transition:var(--transition-all)}.stat-item:hover{background:var(--color-gray-50);transform:translateY(-2px)}.stat-number{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-primary);margin-bottom:var(--spacing-1);line-height:1}.stat-label{font-size:var(--font-size-sm);color:var(--color-gray-600);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.05em}.stadium-guide-link{align-self:center}.stadium-guide-link a{color:var(--color-primary);text-decoration:none;font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);display:inline-flex;align-items:center;transition:var(--transition-colors)}.stadium-guide-link a:hover{color:var(--color-primary-dark);text-decoration:underline}.weather-info-section{display:flex;flex-direction:column;gap:20px;margin-bottom:24px;width:100%}.sun-info{background:linear-gradient(135deg,#fffbf0,#fff5e6);border-radius:var(--radius-xl);padding:var(--spacing-5);box-shadow:0 4px 12px rgba(255,152,0,.08);border:1px solid #ffe4cc;transition:var(--transition-all)}.sun-info h3{margin:0 0 var(--spacing-4) 0;color:var(--color-primary-dark);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);display:flex;align-items:center;gap:var(--spacing-2);letter-spacing:-.02em}.enhanced-indicator{font-size:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:white;padding:.125rem .5rem;border-radius:12px;font-weight:500;cursor:help}.sun-details{display:flex;flex-direction:column;gap:12px}.sun-detail-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);background:rgba(255,255,255,.8);border-radius:var(--radius-lg);border:1px solid rgba(255,204,2,.3);transition:var(--transition-transform)}.sun-icon{font-size:1.5rem;flex-shrink:0}.sun-detail-content{display:flex;flex-direction:column;flex-grow:1}.sun-label{font-size:var(--font-size-xs);color:var(--color-gray-600);margin-bottom:var(--spacing-1);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.05em}.sun-value{font-size:var(--font-size-base);color:var(--color-gray-800);font-weight:var(--font-weight-semibold)}.night-game{display:flex;align-items:center;gap:8px;padding:12px 16px;background:linear-gradient(135deg,#e8eaf6,#c5cae9);border-radius:8px;color:#1565c0;font-weight:600;border:1px solid #9fa8da}.night-icon{font-size:1.2rem}.recommendations{background:var(--color-white);border-radius:var(--radius-xl);padding:var(--spacing-6);box-shadow:var(--shadow-lg);width:100%;overflow:hidden;transition:var(--transition-all);border:1px solid var(--color-gray-100)}.recommendations h3{margin:0 0 var(--spacing-5) 0;color:var(--color-primary-dark);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);letter-spacing:-.025em}.recommendations-content{display:grid;grid-gap:16px;gap:16px}.recommendation-item{display:flex;gap:var(--spacing-4);padding:var(--spacing-4) var(--spacing-5);border-radius:var(--radius-lg);border-left:4px solid;transition:var(--transition-all)}.recommendation-item.night{background:#f3e5f5;border-left-color:#9c27b0;box-shadow:var(--shadow-sm)}.recommendation-item.covered{background:#e8f5e8;border-left-color:var(--color-success);box-shadow:var(--shadow-sm)}.recommendation-item.shade{background:rgba(var(--color-primary-rgb),.05);border-left-color:var(--color-primary);box-shadow:var(--shadow-sm)}.recommendation-item.sun{background:#fff8e1;border-left-color:var(--color-warning);box-shadow:var(--shadow-sm)}.recommendation-item.high-sun{background:#fff3e0;border-left-color:#ff5722}.recommendation-item.weather{background:#f1f8e9;border-left-color:#8bc34a}.rec-icon{font-size:1.5rem;flex-shrink:0}.rec-content h4{margin:0 0 8px;color:#333;font-size:1.1rem;font-weight:600}.rec-content p{margin:0;color:#666;line-height:1.6}.rec-content strong{color:#333;font-weight:600}.game-info{margin-top:24px;padding:20px;background:#f8f9fa;border-radius:8px;border:1px solid #e0e0e0}.game-info h4{margin:0 0 var(--spacing-3) 0;color:var(--color-primary-dark);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);letter-spacing:-.02em}.game-info p{margin:var(--spacing-2) 0;color:var(--color-gray-600);line-height:var(--line-height-normal)}.game-info strong{color:var(--color-gray-800);font-weight:var(--font-weight-semibold)}.App-footer{background:var(--color-white);padding:var(--spacing-8) var(--spacing-5) var(--spacing-6);color:var(--color-gray-600);font-size:var(--font-size-sm);border-top:1px solid var(--color-gray-200);margin-top:var(--spacing-10)}.footer-content{max-width:var(--breakpoint-xl);margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:var(--spacing-6);gap:var(--spacing-6)}.footer-section{min-width:0}.guides-section h4{color:var(--color-gray-900);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-3)}.guides-section ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-2)}.guides-section li{margin:0}.guides-section a{color:var(--color-primary);text-decoration:none;font-weight:var(--font-weight-medium);transition:var(--transition-colors);display:inline-block}.guides-section a:hover{color:var(--color-primary-dark);text-decoration:underline}.disclaimer{text-align:center;font-style:italic;grid-column:1/-1}.data-sources{text-align:left}.data-sources h4{margin-bottom:var(--spacing-2);color:var(--color-gray-800);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);letter-spacing:-.01em}.data-sources ul{list-style:none;padding:0;margin:0}.data-sources li{margin-bottom:8px;padding-left:20px;position:relative}.data-sources li:before{content:"•";position:absolute;left:0;color:var(--color-primary);font-weight:var(--font-weight-bold)}.attribution{text-align:center;padding-top:var(--spacing-2);border-top:1px solid var(--color-gray-300);font-size:var(--font-size-xs)}.legal-links{margin:var(--spacing-2) 0;font-size:var(--font-size-sm)}.legal-links a{margin:0 var(--spacing-2)}.App-footer a{color:var(--color-primary);text-decoration:none;font-weight:var(--font-weight-medium);transition:var(--transition-colors)}.App-footer a:hover{text-decoration:underline;color:var(--color-primary-dark)}@media (max-width:768px){.footer-content{grid-template-columns:1fr;text-align:center}.guides-section{order:-1}.data-sources{text-align:center}.data-sources li{padding-left:0}.data-sources li:before{display:none}.App-header{padding:var(--spacing-4)}.App-header h1{font-size:1.8rem}.App-header p{font-size:.95rem}.header-content{gap:var(--spacing-3)}.quick-summary{flex-direction:row;flex-wrap:wrap;gap:8px;font-size:.8rem;width:100%;justify-content:center}.controls{grid-template-columns:1fr}.App-main{padding:10px;width:100%;max-width:100vw;overflow-x:hidden}.results{gap:16px;padding:0;max-width:100vw}.filter-and-sections-container{grid-template-columns:1fr;gap:var(--spacing-3);width:100%;overflow:hidden;margin:0;padding:0}.filter-and-sections-container>:first-child{position:relative;top:auto;max-height:none;width:100%;max-width:100%}.filter-and-sections-container>:last-child{width:100%;max-width:100%}.overview-stats{padding:12px;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.section-overview{width:100%;max-width:100%;overflow:hidden}.stat-number{font-size:1.4rem}.stat-label{font-size:.7rem}.weather-info-section{gap:12px;width:100%;max-width:100%}.sun-info{width:100%;box-sizing:border-box;overflow:hidden}.sun-details{width:100%;overflow-x:auto}.recommendations{padding:16px;width:100%;overflow:hidden}.recommendation-item{flex-direction:column;gap:12px;text-align:center}.rec-icon{align-self:center}.clickable,button,input[type=button],input[type=reset],input[type=submit]{min-height:44px;min-width:44px}input[type=date],input[type=range],input[type=search],input[type=text],input[type=time],select,textarea{min-height:44px;padding:12px;font-size:16px}.control-group{margin-bottom:24px}.control-group label{font-size:1.1rem;margin-bottom:8px}}@media (max-width:480px){.App-header h1{font-size:1.6rem}.App-header p{font-size:.85rem}.quick-summary{padding:8px;font-size:.75rem}.App-main{padding:8px}.results>*{max-width:calc(100vw - 16px);margin-left:0;margin-right:0}.weather-info-section>*{max-width:100%}.clickable,button,input[type=button],input[type=reset],input[type=submit]{min-height:48px;padding:12px 16px}body{font-size:16px;line-height:1.5}.recommendation-item,.recommendations{padding:12px}.rec-content h4{font-size:1rem}.rec-content p{font-size:.9rem}}.header-language-selector{margin-right:8px}.header-language-selector .language-buttons{background-color:rgba(255,255,255,.1)}.header-language-selector .language-button{color:rgba(255,255,255,.8);font-size:.7rem;padding:4px 8px}.header-language-selector .language-button:hover{background-color:rgba(255,255,255,.2);color:white}.header-language-selector .language-button.active{background-color:rgba(255,255,255,.3);color:white}.form-heading{font-size:1.1rem;font-weight:600;margin:0 0 16px;color:#333}.form-field{margin-bottom:16px}.form-label{display:block;font-size:.9rem;font-weight:500;margin-bottom:6px;color:#374151}.form-help{font-size:.8rem;color:#6b7280;margin-top:4px}.form-actions{margin-top:16px}.form-actions button{font-size:.9rem;transition:background-color .2s ease}.btn-primary{background-color:#3b82f6}.btn-primary:hover:not(:disabled){background-color:#2563eb}.btn-primary:disabled{background-color:#9ca3af}.btn-secondary{background-color:#f3f4f6;color:#374151}.btn-secondary:hover{background-color:#e5e7eb}@media (min-width:1200px){.App-main{padding:var(--spacing-8)}.filter-and-sections-container{gap:var(--spacing-8)}.weather-info-section{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--spacing-6);gap:var(--spacing-6)}.recommendations-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:var(--spacing-4);gap:var(--spacing-4)}.overview-stats{justify-content:center;gap:var(--spacing-12)}.stat-item{padding:var(--spacing-4) var(--spacing-6)}}.filter-button,.interactive-element,.section-card{min-height:44px;min-width:44px;padding:12px;margin:4px;cursor:pointer}.section-card:active{background-color:#f0f8ff}a.clickable,button,input,select,textarea{min-height:44px;min-width:44px}.btn,.button,.sort-btn,.tab-button{min-height:44px;padding:12px 16px;touch-action:manipulation}@media (max-width:768px){.filter-button,.interactive-element,.section-card{min-height:48px;padding:14px}.btn+.btn,.section-card+.section-card{margin-left:8px}.clickable:active,.sort-btn:active,.tab-button:active,a.clickable:active,button:active{transform:scale(.98);opacity:.9}}.webgl-stadium-canvas-container{position:relative;width:100%;height:400px;border:1px solid #ddd;border-radius:8px;overflow:hidden}.webgl-stadium-canvas-container canvas{display:block;width:100%;height:100%}.performance-info{display:flex;align-items:center;gap:16px}.performance-indicator{display:flex;align-items:center;gap:6px;font-size:.8rem;color:#666}.performance-dot{width:8px;height:8px;border-radius:50%;transition:all .3s ease}.performance-dot.active{background-color:#4caf50;box-shadow:0 0 8px rgba(76,175,80,.6);animation:pulse 1s infinite}.performance-dot.idle{background-color:#2196f3;box-shadow:0 0 4px rgba(33,150,243,.4)}.webgl-help{margin-top:12px;padding:8px 12px;background:#f5f5f5;border-radius:6px;font-size:.8rem;color:#666;text-align:center}.loading-spinner{border:4px solid #ddd;margin:0 auto 16px}.loading-details{font-size:.85rem;color:#888;margin-top:8px}@media (max-width:768px){.webgl-stadium-container{padding:16px}.webgl-stadium-canvas-container{height:300px}.webgl-controls{gap:12px}.performance-info,.webgl-controls{flex-direction:column;align-items:flex-start}.performance-info{gap:8px}.stadium-info h4{font-size:1rem}.stadium-info p,.sun-position{font-size:.8rem}.webgl-help{font-size:.75rem}.webgl-loading{padding:30px 20px}}@media (prefers-reduced-motion:reduce){.performance-dot.active{animation:none}.loading-spinner{animation:none;border-top-color:#1a237e}}@media (prefers-color-scheme:dark){.webgl-stadium-container{background:#1e1e1e;color:#e0e0e0}.webgl-controls{border-top-color:#333}.stadium-info h4{color:#64b5f6}.stadium-info p{color:#b0b0b0}.webgl-help,.webgl-loading{background:#2a2a2a;color:#b0b0b0}}.performance-indicator{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;transition:all .3s ease}.performance-indicator:hover{transform:scale(1.05)}.webgl-loading p{margin:8px 0}.webgl-loading .loading-details{opacity:.7;font-style:italic}.webgl-stadium-canvas-container:focus-within{outline:2px solid #1976d2;outline-offset:2px}@media (hover:none) and (pointer:coarse){.webgl-help{display:none}.performance-indicator:hover{transform:none}}@media (prefers-contrast:high){.webgl-stadium-container{border:2px solid #000}.performance-dot.active{background-color:#00ff00}.performance-dot.idle{background-color:#0000ff}}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:400px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 4px 8px rgba(0,0,0,.1);margin:20px}.error-boundary-content h2{color:#d32f2f;margin-bottom:16px;font-size:1.5rem}.error-boundary-content p{color:#666;margin-bottom:24px;line-height:1.6}.error-details{margin:20px 0;background:#f5f5f5;border:1px solid #ddd}.error-details summary{color:#d32f2f;margin-bottom:8px}.error-details pre{background:#fff;padding:12px;border-radius:4px;overflow-x:auto;font-size:.85rem;margin:8px 0;color:#333}.error-actions{gap:12px}.error-reload-btn,.error-retry-btn{padding:12px 24px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:120px}.error-reload-btn{background:#1976d2;color:white}.error-reload-btn:hover{background:#1565c0}.error-retry-btn{background:#4caf50;color:white}.error-retry-btn:hover{background:#388e3c}@media (max-width:768px){.error-boundary{margin:10px;padding:16px}.error-boundary-content h2{font-size:1.3rem}.error-actions{flex-direction:column;align-items:center}.error-reload-btn,.error-retry-btn{width:100%;max-width:200px}}@media (prefers-color-scheme:dark){.error-boundary{background:#1e1e1e;color:#e0e0e0}.error-boundary-content p{color:#b0b0b0}.error-details{background:#2a2a2a;border-color:#444}.error-details pre{background:#333;color:#e0e0e0}}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-ms-scroll-chaining:none;overscroll-behavior:none}.clickable,a,button{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.scrollable,[data-scrollable]{-webkit-overflow-scrolling:touch;overflow-scrolling:touch}#root{min-height:100vh}.pwa-install-prompt{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:#2196f3;color:white;padding:12px 24px;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.2);z-index:1000;display:flex;align-items:center;gap:12px;font-size:14px;animation:slideUp .3s ease}.pwa-install-prompt button{background:white;color:#1a237e;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-weight:500;transition:all .2s ease}.pwa-install-prompt button:hover{background:#f0f0f0}.pwa-install-prompt .close-btn{background:transparent;color:white;border:1px solid rgba(255,255,255,.3);padding:4px 8px;font-size:12px}.pwa-install-prompt .close-btn:hover{background:rgba(255,255,255,.1)}.pwa-loading{position:fixed;top:0;left:0;right:0;bottom:0;background:#2196f3;display:flex;align-items:center;justify-content:center;z-index:9999}.pwa-loading .spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top-color:white;border-radius:50%;animation:spin 1s linear infinite}.update-available{position:fixed;top:20px;right:20px;background:#4caf50;color:white;padding:16px;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.2);z-index:1000;max-width:300px;animation:slideIn .3s ease}.update-available h4{margin:0 0 8px;font-size:16px}.update-available p{margin:0 0 12px;font-size:14px;opacity:.9}.update-available button{background:white;color:#4caf50;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-weight:500;margin-right:8px;font-size:14px}.update-available button:hover{background:#f0f0f0}.update-available .dismiss-btn{background:transparent;color:white;border:1px solid rgba(255,255,255,.3)}.update-available .dismiss-btn:hover{background:rgba(255,255,255,.1)}.webgl-stadium-container{background:white;border-radius:12px;padding:20px;box-shadow:0 4px 8px rgba(0,0,0,.1);margin-bottom:20px}.webgl-stadium-canvas{width:100%;height:400px;border:1px solid #ddd;border-radius:8px;display:block}.webgl-controls{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:16px;border-top:1px solid #eee}.stadium-info h4{margin:0 0 4px;color:#1a237e;font-size:1.1rem}.stadium-info p{margin:0;color:#666;font-size:.9rem}.sun-indicator{gap:8px}.sun-position{background:#fff3cd;color:#856404;padding:4px 8px;border-radius:4px;font-size:.85rem;font-weight:500}.webgl-error{background:#ffebee;color:#c62828;padding:20px;border-radius:8px;text-align:center;margin:20px 0}.webgl-error p{margin:8px 0}.webgl-loading{background:#f5f5f5;padding:40px;border-radius:8px;text-align:center;margin:20px 0;color:#666}@media (max-width:768px){.webgl-stadium-container{padding:16px}.webgl-stadium-canvas{height:300px}.webgl-controls{flex-direction:column;align-items:flex-start;gap:12px}.stadium-info h4{font-size:1rem}.stadium-info p,.sun-position{font-size:.8rem}}.webgl-loading:after{content:"";display:inline-block;width:20px;height:20px;border:2px solid #ddd;border-top-color:#1a237e;border-radius:50%;animation:spin 1s linear infinite;margin-left:10px}.webgl-stadium-canvas:hover{box-shadow:0 2px 8px rgba(0,0,0,.15)}.webgl-stadium-canvas[style*=pointer]{transition:box-shadow .2s ease}.webgl-stadium-canvas[style*=pointer]:hover{box-shadow:0 2px 12px rgba(26,35,126,.2)}.guide-page{min-height:100vh;background:#f8f9fa;padding:2rem 1rem}.guide-container{max-width:800px;margin:0 auto}.guide-page h1{font-size:2.5rem;font-weight:700;color:#1a237e;margin-bottom:1rem;line-height:1.2}.guide-page .lead{font-size:1.25rem;color:#495057;margin-bottom:2rem;line-height:1.6}.guide-page section{background:white;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px rgba(0,0,0,.05)}.guide-page h2{font-size:1.75rem;font-weight:600;color:#1a237e;margin-bottom:1rem}.guide-page h3{font-size:1.25rem;font-weight:600;color:#333;margin-top:1.5rem;margin-bottom:.75rem}.guide-page ol,.guide-page ul{margin-bottom:1rem;line-height:1.8}.guide-page li{margin-bottom:.5rem}.cta-box{background:#e3f2fd;border:2px solid #2196f3;border-radius:8px;padding:1.5rem;margin:2rem 0;text-align:center}.cta-button{padding:.75rem 2rem;background:#2196f3;transition:all .2s ease}.cta-button:hover{background:#1976d2;box-shadow:0 4px 12px rgba(33,150,243,.3)}.cta-button.primary{background:#1a237e}.cta-button.primary:hover{background:#0d47a1}.stadium-shade-card{border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;margin-bottom:1rem}.stadium-shade-card h3{margin-top:0;color:#1a237e}.team-name{color:#666;font-size:.875rem;margin-bottom:1rem}.sections{font-family:monospace;background:#f5f5f5;padding:.5rem;border-radius:4px;margin-bottom:.5rem}.tip{font-size:.875rem;color:#555}.guides-header{text-align:center;margin-bottom:3rem}.guides-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:2rem;gap:2rem;margin-bottom:3rem}.guide-card{background:white;border-radius:12px;padding:2rem;box-shadow:0 2px 8px rgba(0,0,0,.05);transition:all .2s ease}.guide-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px rgba(0,0,0,.1)}.guide-card.featured{border:2px solid #2196f3}.guide-card h2{font-size:1.5rem;margin-bottom:1rem}.guide-card h2 a{color:#1a237e;text-decoration:none}.guide-card h2 a:hover{color:#2196f3}.guide-card p{color:#666;line-height:1.6;margin-bottom:1rem}.read-more{color:#2196f3;text-decoration:none;font-weight:600}.read-more:hover{text-decoration:underline}.guide-cta{background:#1a237e;color:white;border-radius:12px;padding:3rem;text-align:center}.guide-cta h2{color:white;margin-bottom:1rem}.guide-cta p{margin-bottom:2rem;opacity:.9}.guide-footer{background:#f8f9fa;border-radius:12px;padding:2rem;text-align:center;margin-top:3rem}.tips-section{background:#fff9c4;border-left:4px solid #fbc02d}.cta-section{background:#e3f2fd;border:2px solid #2196f3}.faq-toc{background:#f8f9fa;border-radius:12px;padding:2rem;margin-bottom:3rem}.faq-toc h2{font-size:1.25rem;margin-bottom:1rem;color:#1a237e}.faq-toc ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:.75rem;gap:.75rem}.faq-toc a{color:#2196f3;text-decoration:none;font-weight:500}.faq-toc a:hover{text-decoration:underline}.faq-list{display:flex;flex-direction:column;gap:2rem}.faq-item h3{font-size:1.125rem;color:#1a237e;margin-bottom:.75rem;font-weight:600}.faq-item p{color:#495057;line-height:1.7}.faq-contact{background:#e3f2fd;border:2px solid #2196f3;text-align:center}.cta-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:1.5rem}.related-resources{background:#f8f9fa}.related-resources ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:1rem}.related-resources li a{color:#2196f3;text-decoration:none;font-weight:500;display:flex;align-items:center;gap:.5rem}.related-resources li a:before{content:"→";font-size:1.25rem}.related-resources li a:hover{text-decoration:underline}@media (max-width:768px){.guide-page{padding:1rem .5rem}.guide-container{padding:0 .5rem}.guide-page h1{font-size:2rem}.guide-page section{padding:1.5rem}.guides-grid{gap:1rem}.faq-toc ul,.guides-grid{grid-template-columns:1fr}.cta-buttons{flex-direction:column;align-items:stretch}.cta-button{width:100%;text-align:center}}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/55c55f0601d81cf3-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/26a46d62cd723877-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/97e0cb1ae144a2a9-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/581909926a08bbc8-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Inter Fallback;src:local("Arial");ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.00%;size-adjust:107.12%}.__className_e8ce0c{font-family:Inter,Inter Fallback;font-style:normal}.tooltip-container{position:relative;display:inline-block}.tooltip{position:absolute;z-index:1000;background:#333;color:white;padding:8px 12px;border-radius:6px;font-size:.85rem;line-height:1.3;max-width:250px;word-wrap:break-word;box-shadow:0 4px 12px rgba(0,0,0,.15);opacity:0;animation:tooltipFadeIn .2s ease-out forwards;pointer-events:none}@keyframes tooltipFadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.tooltip-arrow{position:absolute;width:0;height:0;border-style:solid}.tooltip-top{bottom:100%;left:50%;transform:translateX(-50%);margin-bottom:8px}.tooltip-arrow-top{border-width:6px 6px 0;border-color:#333 transparent transparent}.tooltip-arrow-top,.tooltip-bottom{top:100%;left:50%;transform:translateX(-50%)}.tooltip-bottom{margin-top:8px}.tooltip-arrow-bottom{bottom:100%;left:50%;transform:translateX(-50%);border-width:0 6px 6px;border-color:transparent transparent #333}.tooltip-left{right:100%;top:50%;transform:translateY(-50%);margin-right:8px}.tooltip-arrow-left{border-width:6px 0 6px 6px;border-color:transparent transparent transparent #333}.tooltip-arrow-left,.tooltip-right{left:100%;top:50%;transform:translateY(-50%)}.tooltip-right{margin-left:8px}.tooltip-arrow-right{right:100%;top:50%;transform:translateY(-50%);border-width:6px 6px 6px 0;border-color:transparent #333 transparent transparent}@media (prefers-contrast:high){.tooltip{background:#000;border:1px solid #fff}.tooltip-arrow-top{border-color:#000 transparent transparent}.tooltip-arrow-bottom{border-color:transparent transparent #000}.tooltip-arrow-left{border-color:transparent transparent transparent #000}.tooltip-arrow-right{border-color:transparent #000 transparent transparent}}@media (prefers-reduced-motion:reduce){.tooltip{animation:none;opacity:1}}@media (max-width:768px){.tooltip{max-width:200px;font-size:.8rem;padding:6px 10px}}.favorite-button{display:inline-flex;align-items:center;gap:4px;border:none;background:transparent;cursor:pointer;transition:all .2s ease;font-family:inherit;padding:4px 8px;border-radius:4px}.favorite-button:hover{background-color:rgba(0,0,0,.05)}.favorite-button:focus-visible{outline:2px solid #1976d2;outline-offset:2px}.favorite-icon{transition:all .2s ease;display:inline-block}.favorite-button.is-favorite .favorite-icon{color:#ffd700;text-shadow:0 0 2px rgba(255,215,0,.5)}.favorite-button:not(.is-favorite) .favorite-icon{color:#999}.favorite-button:hover .favorite-icon{transform:scale(1.1)}.favorite-button.animating .favorite-icon{animation:favoriteAnimation .6s ease}@keyframes favoriteAnimation{0%{transform:scale(1) rotate(0deg)}25%{transform:scale(1.3) rotate(-10deg)}50%{transform:scale(1.5) rotate(10deg)}75%{transform:scale(1.3) rotate(-5deg)}to{transform:scale(1) rotate(0deg)}}.favorite-btn-small{font-size:16px;padding:2px 4px}.favorite-btn-small .favorite-icon{font-size:16px}.favorite-btn-medium{font-size:20px;padding:4px 8px}.favorite-btn-medium .favorite-icon{font-size:20px}.favorite-btn-large{font-size:24px;padding:6px 12px}.favorite-btn-large .favorite-icon{font-size:24px}.favorite-label{font-size:14px;font-weight:500;color:#333}@media (prefers-color-scheme:dark){.favorite-button:hover{background-color:rgba(255,255,255,.1)}.favorite-label{color:#fff}}.skeleton{background:linear-gradient(90deg,var(--color-gray-200) 0,var(--color-gray-100) 50%,var(--color-gray-200) 100%);animation:shimmer 1.5s ease-in-out infinite;position:relative;overflow:hidden}.stadium-selector-skeleton{width:100%;max-width:400px;margin:0 auto}.game-selector-skeleton{background:var(--color-white);border-radius:var(--radius-xl);padding:var(--spacing-6);box-shadow:var(--shadow-md);border:1px solid var(--color-gray-200)}.game-selector-skeleton .skeleton-title{margin-bottom:var(--spacing-4)}.game-selector-skeleton .skeleton-games{display:flex;flex-direction:column;gap:var(--spacing-3)}.weather-skeleton{background:var(--color-white);border-radius:var(--radius-xl);padding:var(--spacing-6);box-shadow:var(--shadow-md);border:1px solid var(--color-gray-200)}.weather-skeleton-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.weather-skeleton-content{display:flex;align-items:center;gap:var(--spacing-4)}.weather-skeleton-details{display:flex;flex-direction:column;gap:var(--spacing-2)}.section-card-skeleton{background:var(--color-white);border-radius:var(--radius-lg);padding:var(--spacing-4);box-shadow:var(--shadow-sm);border:1px solid var(--color-gray-200)}.section-card-skeleton-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-3)}.section-card-skeleton-content{flex-direction:column;margin-bottom:var(--spacing-3)}.section-card-skeleton-content,.section-card-skeleton-footer{display:flex;gap:var(--spacing-2)}.section-list-skeleton{display:grid;grid-gap:var(--spacing-4);gap:var(--spacing-4);grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.mobile-stadium-card-skeleton{background:var(--color-white);border-radius:var(--radius-lg);padding:var(--spacing-4);box-shadow:var(--shadow-sm);border:1px solid var(--color-gray-200)}.mobile-stadium-card-skeleton .stadium-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2)}.mobile-stadium-card-skeleton .stadium-card-team{margin-top:var(--spacing-1)}.mobile-game-card-skeleton{background:var(--color-white);border-radius:var(--radius-lg);padding:var(--spacing-4);box-shadow:var(--shadow-sm);border:1px solid var(--color-gray-200)}.mobile-game-card-skeleton .game-card-teams{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-2)}.mobile-game-card-skeleton .game-card-time{margin-top:var(--spacing-2)}.overview-stats-skeleton{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:var(--spacing-4);gap:var(--spacing-4)}.stat-card-skeleton{background:var(--color-white);border-radius:var(--radius-lg);padding:var(--spacing-4);box-shadow:var(--shadow-sm);border:1px solid var(--color-gray-200);display:flex;flex-direction:column;gap:var(--spacing-2);align-items:center}.sun-info-skeleton{background:var(--color-white);border-radius:var(--radius-xl);padding:var(--spacing-6);box-shadow:var(--shadow-md);border:1px solid var(--color-gray-200)}.sun-info-skeleton .sun-info-title{margin-bottom:var(--spacing-4)}.sun-info-skeleton .sun-info-content{display:flex;flex-direction:column;gap:var(--spacing-3)}.sun-info-skeleton .sun-info-row{display:flex;justify-content:space-between;align-items:center}.skeleton-fade-enter{opacity:0}.skeleton-fade-enter-active{opacity:1;transition:opacity .3s ease-in-out}.skeleton-fade-exit{opacity:1}.skeleton-fade-exit-active{opacity:0;transition:opacity .3s ease-in-out}@media (max-width:768px){.overview-stats-skeleton,.section-list-skeleton{grid-template-columns:1fr}}.nfl-custom-game-selector{padding:20px;background-color:#f8f9fa;border-radius:8px;margin-top:16px}.custom-game-header{margin-bottom:24px;text-align:center}.custom-game-header h3{margin:0 0 8px;color:#333;font-size:1.4rem}.custom-game-header p{margin:0;color:#666;font-size:.95rem}.custom-game-form{max-width:500px;margin:0 auto}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:20px;gap:20px;margin-bottom:24px}.form-group{display:flex;flex-direction:column}.form-group label{margin-bottom:8px;font-weight:600;color:#333;font-size:.95rem}.date-input,.time-input{padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:16px;background-color:white;transition:border-color .2s}.date-input:focus,.time-input:focus{border-color:#0066cc;box-shadow:0 0 0 2px rgba(0,102,204,.1)}.venue-info{background-color:white;border:1px solid #e0e0e0;border-radius:6px;padding:16px;margin-bottom:24px;text-align:center}.venue-info p{margin:6px 0;color:#555;font-size:.95rem}.venue-info strong{color:#333;font-weight:600}.apply-button{width:100%;padding:14px 24px;background-color:#0066cc;color:white;border:none;border-radius:6px;font-size:1.05rem;font-weight:600;cursor:pointer;transition:background-color .2s}.apply-button:hover:not(:disabled){background-color:#0052a3}.apply-button:disabled{background-color:#ccc;cursor:not-allowed;opacity:.7}@media (max-width:600px){.form-row{grid-template-columns:1fr;gap:16px}.custom-game-header h3{font-size:1.2rem}.radio-group{flex-direction:column;gap:12px}}.game-selector{background:var(--color-white);border-radius:var(--radius-xl);padding:var(--spacing-6);box-shadow:var(--shadow-md);border:1px solid var(--color-gray-200);margin-bottom:var(--spacing-6);width:100%;box-sizing:border-box;transition:var(--transition-shadow)}.stadium-option{display:flex;justify-content:space-between;align-items:center;width:100%;padding:4px 0}.stadium-option,.stadium-option span{color:#000!important}.stadium-option-content{display:flex;align-items:center;gap:8px;flex:1 1;color:#000!important}.stadium-option-content span{color:#000!important}.favorite-indicator{color:#ffd700!important;font-size:16px}.selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:16px}.selector-header h3{margin:0;color:var(--color-primary-dark);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);letter-spacing:-.025em}.view-mode-toggle{display:flex;background:var(--color-gray-100);border-radius:var(--radius-lg);padding:var(--spacing-1);gap:var(--spacing-1);box-shadow:var(--shadow-inner)}.toggle-btn{padding:var(--spacing-3) var(--spacing-4);border:none;border-radius:var(--radius-md);background:transparent;color:var(--color-gray-600);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-all);display:flex;align-items:center;gap:var(--spacing-2);min-height:44px;touch-action:manipulation}.toggle-btn:hover{background:var(--color-gray-200);transform:translateY(-1px)}.toggle-btn.active{background:var(--color-primary-dark);color:var(--color-white);box-shadow:var(--shadow-md);transform:scale(1)}.toggle-btn:active{transform:scale(.98);opacity:.9}.toggle-btn:focus{outline:2px solid var(--color-primary);outline-offset:2px}.apply-custom-btn:focus,.date-input:focus,.time-input:focus{outline:2px solid #1a237e;outline-offset:2px}.control-group{margin-bottom:20px}.control-group label{display:block;font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-2);color:var(--color-gray-800);font-size:var(--font-size-base);letter-spacing:-.01em}.game-select,.stadium-select{font-size:16px}.game-select *,.stadium-select *{color:#000!important}.game-select .react-select__option--is-selected,.stadium-select .react-select__option--is-selected{background-color:#1a237e!important;color:white!important}.stadium-select .react-select__control{border:2px solid var(--color-gray-300);border-radius:var(--radius-md);min-height:44px;box-shadow:none;transition:var(--transition-colors);color:var(--color-black);background:var(--color-white)}.stadium-select .react-select__control:hover{border-color:var(--color-gray-400)}.stadium-select .react-select__control--is-focused{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.stadium-select .react-select__single-value{color:#000!important;font-weight:600}.stadium-select .react-select__placeholder{color:#666!important}.stadium-select .react-select__input,.stadium-select .react-select__input-container{color:#000!important}.stadium-select .react-select__option{color:#000!important;padding:10px 12px;font-weight:500}.stadium-select .react-select__option--is-focused{background-color:#f5f5f5}.stadium-select .react-select__option--is-selected{background-color:#1a237e;color:white}.stadium-select .react-select__menu{box-shadow:0 4px 12px rgba(0,0,0,.15);border:1px solid #ddd;background-color:white}.stadium-select .react-select__menu-list{background-color:white}.stadium-select .react-select__dropdown-indicator{color:#333}.stadium-select .react-select__indicator-separator{background-color:#ddd}.game-select .react-select__control{border:2px solid #ddd;border-radius:6px;min-height:44px;box-shadow:none}.game-select .react-select__control:hover{border-color:#bbb}.game-select .react-select__control--is-focused{border-color:#1a237e;box-shadow:0 0 0 3px rgba(26,35,126,.1)}.game-select .react-select__single-value{color:#000!important;font-weight:600}.game-select .react-select__option{color:#000!important;padding:10px 12px;font-weight:500}.game-select .react-select__menu{background-color:white;box-shadow:0 4px 12px rgba(0,0,0,.15);border:1px solid #ddd}.game-select .react-select__menu-list{background-color:white}.game-select .react-select__option--is-focused{background-color:#f5f5f5}.game-select .react-select__option--is-selected{background-color:#1a237e;color:white!important}.games-section{margin-top:20px}.loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-10);color:var(--color-gray-600);font-style:italic;background:var(--color-gray-50);border-radius:var(--radius-lg);border:2px dashed var(--color-gray-300)}.game-select.refreshing{opacity:.6;pointer-events:none;position:relative}.game-select.refreshing:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3) 50%,transparent);animation:shimmer 1.5s ease-in-out infinite}.error-message{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-4);background-color:var(--color-error-light);border-radius:var(--radius-lg);margin-top:var(--spacing-2)}.error-message,.retry-button{color:var(--color-error);font-size:var(--font-size-sm)}.retry-button{padding:var(--spacing-2) var(--spacing-4);background:var(--color-white);border:1px solid var(--color-error);border-radius:var(--radius-md);font-weight:var(--font-weight-medium);cursor:pointer;transition:var(--transition-all)}.retry-button:hover{background:var(--color-error);color:var(--color-white)}.game-option{padding:8px 0}.game-date-time{font-weight:600;color:#1a237e;font-size:.95rem}.game-matchup{color:#666;font-size:.9rem;margin-top:2px}.no-games{text-align:center;padding:var(--spacing-10) var(--spacing-5);background:#fff3cd;border:1px solid #ffeaa7;border-radius:var(--radius-lg);color:#856404;box-shadow:var(--shadow-sm)}.no-games p{margin:8px 0}.no-stadium{text-align:center;padding:40px 20px;background:#f8f9fa;border:2px dashed #ddd;border-radius:8px;color:#666}.games-info{margin-top:16px;padding:12px 16px;background:#e8f5e8;border:1px solid #c3e6c3;border-radius:8px}.games-count{margin:0;color:#2e7d32;font-weight:600;font-size:.9rem}.custom-section{margin-top:20px}.custom-controls{display:grid;grid-template-columns:1fr 1fr auto;grid-gap:20px;gap:20px;align-items:end;margin-bottom:20px}.date-input,.time-input{width:100%;padding:var(--spacing-2) var(--spacing-3);border:2px solid var(--color-gray-300);border-radius:var(--radius-md);font-size:var(--font-size-base);background-color:var(--color-white);transition:var(--transition-colors);font-weight:var(--font-weight-medium)}.date-input:focus,.time-input:focus{outline:none;border-color:#1a237e;box-shadow:0 0 0 3px rgba(26,35,126,.1)}.apply-custom-btn{padding:var(--spacing-3) var(--spacing-5);background:linear-gradient(135deg,var(--color-primary) 0,var(--color-secondary) 100%);color:var(--color-white);border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-all);white-space:nowrap;height:-webkit-fit-content;height:-moz-fit-content;height:fit-content;min-height:44px;touch-action:manipulation;box-shadow:var(--shadow-md)}.apply-custom-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-dark) 0,var(--color-secondary-dark) 100%);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.apply-custom-btn:active:not(:disabled){transform:scale(.98)}.apply-custom-btn:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.custom-info{padding:16px 20px;background:#e3f2fd;border:1px solid #bbdefb;border-radius:8px;color:#1565c0}.custom-info p{margin:0;font-size:.9rem;line-height:1.5}@media (max-width:768px){.game-selector{padding:16px;border-radius:8px;margin-bottom:16px}.selector-header{flex-direction:column;align-items:stretch}.view-mode-toggle{width:100%;justify-content:center}.toggle-btn{min-height:44px;padding:12px 16px;font-size:1rem}.custom-controls{grid-template-columns:1fr;gap:16px}.apply-custom-btn{width:100%;min-height:48px;padding:14px 20px;font-size:1.1rem}.date-input,.time-input{min-height:48px;padding:14px 16px;font-size:16px}.control-group label{font-size:1.1rem;margin-bottom:10px}}@media (max-width:480px){.game-selector{padding:16px}.selector-header h3{font-size:1.3rem}.toggle-btn{padding:6px 12px;font-size:.8rem}}@media (prefers-color-scheme:dark){.game-select .react-select__control,.stadium-select .react-select__control{background-color:#2a2a2a;border-color:#444}.game-select .react-select__single-value,.stadium-select .react-select__single-value{color:#e0e0e0}.game-select .react-select__menu,.stadium-select .react-select__menu{background-color:#2a2a2a;border-color:#444}.game-select .react-select__option,.stadium-select .react-select__option{background-color:#2a2a2a;color:#e0e0e0}.game-select .react-select__option--is-focused,.stadium-select .react-select__option--is-focused{background-color:#3a3a3a}.game-select .react-select__option--is-selected,.stadium-select .react-select__option--is-selected{background-color:#1a237e;color:white}}.game-selector .react-select__menu *{color:#000!important}.game-selector .react-select__option--is-selected *{color:white!important}.league-select .react-select__control,.milb-level-select .react-select__control{border:2px solid var(--color-gray-300);border-radius:var(--radius-md);min-height:44px;box-shadow:none;transition:var(--transition-colors);color:var(--color-black);background:var(--color-white)}.league-select .react-select__control:hover,.milb-level-select .react-select__control:hover{border-color:var(--color-gray-400)}.league-select .react-select__control--is-focused,.milb-level-select .react-select__control--is-focused{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.league-select .react-select__single-value,.milb-level-select .react-select__single-value{color:#000!important;font-weight:600}.league-select .react-select__placeholder,.milb-level-select .react-select__placeholder{color:#666!important}.league-select .react-select__option,.milb-level-select .react-select__option{color:#000!important;padding:10px 12px;font-weight:500}.league-select .react-select__option--is-focused,.milb-level-select .react-select__option--is-focused{background-color:#f5f5f5}.league-select .react-select__option--is-selected,.milb-level-select .react-select__option--is-selected{background-color:#1a237e!important;color:white!important}.league-select .react-select__menu,.milb-level-select .react-select__menu{box-shadow:0 4px 12px rgba(0,0,0,.15);border:1px solid #ddd;background-color:white}.non-mlb-notice{background:#fff3cd;border:1px solid #ffeaa7;color:#856404;padding:12px;border-radius:8px;margin-bottom:16px;font-size:14px}.venue-select .react-select__control{border:2px solid var(--color-gray-300);border-radius:var(--radius-md);min-height:44px;box-shadow:none;transition:var(--transition-colors);color:var(--color-black);background:var(--color-white)}.venue-select .react-select__control:hover{border-color:var(--color-gray-400)}.venue-select .react-select__control--is-focused{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.venue-select .react-select__single-value{color:#000!important;font-weight:600}.weather-display{background:linear-gradient(135deg,#e3f2fd,#f3e5f5);border-radius:var(--radius-xl);padding:var(--spacing-6);box-shadow:var(--shadow-lg);margin-bottom:var(--spacing-6);border:1px solid rgba(var(--color-primary-rgb),.2);transition:var(--transition-all)}.weather-display.loading{background:#f8f9fa}.weather-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:8px}.weather-header h3{margin:0;color:var(--color-primary-dark);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);letter-spacing:-.025em}.forecast-time{font-size:var(--font-size-sm);color:var(--color-gray-600);background:rgba(255,255,255,.8);padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-2xl);border:1px solid var(--color-gray-300);font-weight:var(--font-weight-medium)}.weather-warning{display:flex;gap:var(--spacing-3);padding:var(--spacing-4);margin:var(--spacing-4) 0;background:#fff3cd;border:1px solid #ffeaa7;border-radius:var(--radius-lg);color:#856404;box-shadow:var(--shadow-sm)}.weather-warning .warning-icon{font-size:24px;flex-shrink:0}.weather-warning .warning-content{flex:1 1}.weather-warning strong{display:block;margin-bottom:4px;color:#704300}.weather-warning p{margin:0;font-size:.9em}.weather-display.unavailable{background:#f8f9fa;border-color:#dee2e6}.weather-unavailable{display:flex;gap:20px;padding:40px 20px;align-items:center;justify-content:center;text-align:center;flex-direction:column}.unavailable-icon{font-size:48px;opacity:.5}.unavailable-content{max-width:400px}.unavailable-content strong{display:block;font-size:1.2rem;color:#495057;margin-bottom:12px}.unavailable-content p{margin:8px 0;color:#6c757d;line-height:1.5}.unavailable-note{font-size:.9em;color:#28a745;font-style:italic}.loading-content{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:#666}.loading-spinner{width:40px;height:40px;border:3px solid #f3f3f3;border-top-color:#1a237e;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.weather-main{display:grid;grid-template-columns:auto 1fr;grid-gap:24px;gap:24px;margin-bottom:24px}.weather-primary{display:flex;flex-direction:column;align-items:center;text-align:center;min-width:120px}.weather-icon{font-size:4rem;filter:drop-shadow(2px 2px 4px rgba(0,0,0,.2))}.weather-icon,.weather-temp{margin-bottom:8px}.temp-value{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--color-primary-dark);display:block;line-height:var(--line-height-none);letter-spacing:-.03em}.feels-like{font-size:var(--font-size-sm);color:var(--color-gray-600);display:block;margin-top:var(--spacing-1);font-weight:var(--font-weight-medium)}.weather-desc p{margin:0;font-size:1rem;color:#444;font-weight:500;text-transform:capitalize}.weather-details{display:flex;align-items:center}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));grid-gap:16px;gap:16px;width:100%}.detail-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-3);background:rgba(255,255,255,.7);border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.8);transition:var(--transition-transform)}.detail-icon{font-size:1.5rem;margin-bottom:4px}.detail-label{font-size:var(--font-size-xs);color:var(--color-gray-600);margin-bottom:var(--spacing-1);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.05em}.detail-value{font-size:var(--font-size-sm);color:var(--color-gray-800);font-weight:var(--font-weight-semibold)}.weather-impact{margin-bottom:24px}.impact-indicator{padding:var(--spacing-4) var(--spacing-5);border-radius:var(--radius-lg);border-left:4px solid;transition:var(--transition-all)}.impact-indicator.excellent{background:#e8f5e8;border-left-color:#4caf50}.impact-indicator.good{background:#fff3e0;border-left-color:#ff9800}.impact-indicator.poor{background:#fafafa;border-left-color:#757575}.impact-indicator.blocked{background:#ffebee;border-left-color:#f44336}.impact-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.impact-icon{font-size:1.2rem}.impact-title{font-weight:var(--font-weight-semibold);color:var(--color-gray-800);font-size:var(--font-size-base)}.impact-desc{margin:0 0 12px;color:#666;line-height:1.5}.exposure-adjustment{margin-top:8px}.adjustment-bar{width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;margin-bottom:6px}.adjustment-fill{height:100%;background:linear-gradient(90deg,#ff5722,#ff9800 50%,#4caf50);transition:width .3s ease}.adjustment-text{font-size:.8rem;color:#666;font-weight:500}.hourly-forecast{border-top:1px solid rgba(255,255,255,.8);padding-top:20px}.hourly-forecast h4{margin:0 0 var(--spacing-4) 0;color:var(--color-primary-dark);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);letter-spacing:-.02em}.hourly-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));grid-gap:12px;gap:12px}.hourly-item{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-3) var(--spacing-2);background:rgba(255,255,255,.8);border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.9);text-align:center;transition:var(--transition-all)}.hourly-time{font-size:.8rem;color:#666;margin-bottom:4px;font-weight:500}.hourly-icon{font-size:1.5rem;margin-bottom:4px}.hourly-temp{font-size:.9rem;font-weight:600;color:#333;margin-bottom:4px}.hourly-clouds{font-size:.7rem;color:#666}.hourly-item.game-hour{background:linear-gradient(135deg,#fff8e1,#ffecb3);border:2px solid var(--color-warning);box-shadow:0 2px 8px rgba(255,152,0,.3);transform:translateY(-2px)}.game-indicator{margin-left:4px;font-size:.8rem;color:#ff9800}@media (max-width:768px){.weather-display{padding:16px;width:100%;box-sizing:border-box;margin:0}.weather-main{grid-template-columns:1fr;gap:16px;text-align:center}.weather-primary{align-items:center}.detail-grid{grid-template-columns:repeat(2,1fr);gap:12px}.hourly-grid{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:8px;padding-bottom:8px}.hourly-item{padding:8px 4px;flex:0 0 auto;min-width:70px}.weather-header{flex-direction:column;align-items:stretch;text-align:center}}@media (max-width:480px){.weather-icon{font-size:3rem}.temp-value{font-size:2rem}.detail-grid{grid-template-columns:1fr}.hourly-grid{grid-template-columns:repeat(3,1fr)}}.sun-exposure-filter{background:#ffffff;border-radius:var(--card-border-radius);padding:var(--card-padding);box-shadow:0 2px 8px rgba(0,0,0,.06);margin-bottom:var(--spacing-5);width:100%;max-width:400px;max-height:90vh;overflow-y:auto;overflow-x:hidden;position:relative;transition:var(--transition-all);border:1px solid #e8f4f8;display:flex;flex-direction:column;box-sizing:border-box}.sun-exposure-filter::-webkit-scrollbar{width:6px}.sun-exposure-filter::-webkit-scrollbar-track{background:#f5f9fc;border-radius:var(--radius-full)}.sun-exposure-filter::-webkit-scrollbar-thumb{background:#bbdefb;border-radius:var(--radius-full);-webkit-transition:background .2s ease;transition:background .2s ease}.sun-exposure-filter::-webkit-scrollbar-thumb:hover{background:#90caf9}.sun-exposure-filter.disabled{opacity:.6;pointer-events:none}.sun-exposure-filter.disabled:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:32px;height:32px;border:3px solid var(--color-gray-300);border-top-color:var(--color-primary);border-radius:var(--radius-full);animation:spin 1s linear infinite}.filter-header{justify-content:space-between;margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-3);border-bottom:2px solid var(--color-gray-200)}.filter-header,.filter-title{display:flex;align-items:center}.filter-title{margin:0;color:var(--color-gray-800);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);gap:var(--spacing-2)}.filter-title-icon{font-size:1.2em}.clear-filters-btn{background:var(--color-gray-100);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-sm);color:var(--color-gray-700);cursor:pointer;transition:var(--transition-all);font-weight:var(--font-weight-medium)}.clear-filters-btn:hover:not(:disabled){background:var(--color-gray-200);border-color:var(--color-gray-400);color:var(--color-gray-800)}.clear-filters-btn:disabled{opacity:.5;cursor:not-allowed}.active-filters-count{background:var(--color-primary);color:var(--color-white);font-size:var(--font-size-xs);padding:2px 6px;border-radius:var(--radius-full);margin-left:var(--spacing-2);font-weight:var(--font-weight-semibold)}.filter-section{margin-bottom:var(--spacing-6);position:relative}.filter-section:last-child{margin-bottom:0}.filter-section-header{width:100%;display:flex;justify-content:space-between;align-items:center;background:none;border:none;padding:var(--spacing-2) 0;margin:0 0 var(--spacing-3) 0;color:var(--color-gray-700);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;border-bottom:1px solid var(--color-gray-200);transition:var(--transition-colors)}.filter-section-header:hover{color:var(--color-gray-900)}.filter-section-title{display:flex;align-items:center;gap:var(--spacing-2)}.filter-section-icon{font-size:1.1em}.filter-section-chevron{font-size:var(--font-size-sm);transition:transform .2s ease;color:var(--color-gray-500)}.filter-section-chevron.expanded{transform:rotate(180deg)}.filter-content{flex-direction:column;gap:var(--spacing-2);animation:slideDown .3s ease-out;overflow:visible;opacity:1!important;visibility:visible!important;background:rgba(0,0,0,.02);padding:var(--spacing-2);border-radius:var(--radius-md);margin-top:var(--spacing-2)}.filter-content,.filter-option{display:flex!important;min-height:40px}.filter-option{align-items:center;gap:8px;cursor:pointer;padding:8px 12px;border-radius:8px;border:1px solid #e0e0e0;background:white;transition:all .2s ease;position:relative;z-index:1;width:100%;box-sizing:border-box;margin-bottom:4px}.filter-option:hover{background:var(--color-gray-50);border-color:var(--color-primary-light);transform:translateX(2px)}.filter-option.selected{background:linear-gradient(135deg,#1a237e,#534bae);border-color:#1a237e;color:white}.filter-option.selected .filter-option-label{color:white}.filter-option input[type=checkbox],.filter-option input[type=radio]{margin:0;cursor:pointer;width:16px;height:16px;flex-shrink:0;opacity:1!important;visibility:visible!important;position:relative;z-index:2;display:block!important}.filter-option-label{font-size:14px;color:inherit;display:flex;align-items:center;gap:4px;flex:1 1;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;cursor:pointer;margin:0}.filter-option-text{display:flex;flex-direction:column;gap:2px;flex:1 1}.filter-option-title{font-weight:500;font-size:14px;color:inherit}.filter-option-description{font-size:12px;color:#666;opacity:.8}.filter-option.selected .filter-option-description{color:rgba(255,255,255,.8)}.filter-option-icon{font-size:1.1em}.custom-range-container{margin-top:var(--spacing-3);padding:var(--spacing-3);background:var(--color-gray-50);border-radius:var(--radius-lg);border:1px solid var(--color-gray-200)}.range-input-group{margin-bottom:var(--spacing-3)}.range-input-group:last-child{margin-bottom:0}.range-label{display:block;margin-bottom:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-gray-700);font-weight:var(--font-weight-medium)}.range-value{color:var(--color-primary);font-weight:var(--font-weight-semibold)}.range-slider{width:100%;height:6px;border-radius:var(--radius-full);background:var(--color-gray-300);outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.range-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:var(--radius-full);background:var(--color-primary);cursor:pointer;-webkit-transition:var(--transition-all);transition:var(--transition-all);box-shadow:var(--shadow-sm)}.range-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:var(--shadow-md)}.range-slider::-moz-range-thumb{width:18px;height:18px;border-radius:var(--radius-full);background:var(--color-primary);cursor:pointer;-moz-transition:var(--transition-all);transition:var(--transition-all);box-shadow:var(--shadow-sm);border:none}.range-slider::-moz-range-thumb:hover{transform:scale(1.1);box-shadow:var(--shadow-md)}.filter-section h4{margin:0 0 12px;color:#495057;font-size:1em;font-weight:600}.checkbox-group,.radio-group{display:flex;flex-direction:column;gap:8px}.checkbox-option,.radio-option{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px;border-radius:6px;transition:background-color .2s ease}.checkbox-option:hover,.radio-option:hover{background-color:#f8f9fa}.checkbox-option input,.radio-option input{margin:0;cursor:pointer}.checkbox-option span,.radio-option span{font-size:.9em;color:#333;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.custom-range{margin-top:12px;padding:12px;background:#f8f9fa;border-radius:6px}.range-input{margin-bottom:12px}.range-input:last-child{margin-bottom:0}.range-input label{display:block;margin-bottom:6px;font-size:.85em;color:#6c757d;font-weight:500}.range-input input[type=range]{width:100%;height:6px;border-radius:3px;background:#dee2e6;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.range-input input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#007bff;cursor:pointer;border:2px solid white;box-shadow:0 2px 4px rgba(0,0,0,.2)}.range-input input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#007bff;cursor:pointer;border:2px solid white;box-shadow:0 2px 4px rgba(0,0,0,.2)}.checkbox-group .checkbox-option{background:white;border:1px solid #dee2e6;margin-bottom:4px}.checkbox-group .checkbox-option:hover{border-color:#007bff;background:#f8f9ff}.radio-group .radio-option{background:white;border:1px solid #dee2e6;margin-bottom:4px}.radio-group .radio-option:hover{border-color:#007bff;background:#f8f9ff}.checkbox-option input:checked+span,.radio-option input:checked+span{color:#007bff;font-weight:600}@media (max-width:768px){.sun-exposure-filter{max-width:100%;width:100%;max-height:none;position:relative;margin:0 0 var(--spacing-4) 0;border-radius:var(--radius-lg);box-shadow:0 2px 8px rgba(0,0,0,.06);transform:none;transition:none;z-index:1}.filter-header{padding:0;flex-direction:row;gap:10px;align-items:center}.clear-filters-btn{align-self:auto}.filter-section-header{padding:var(--spacing-3) 0}.filter-option{padding:var(--spacing-3);min-height:48px}}@media (max-width:480px){.filter-section,.sun-exposure-filter{padding:var(--spacing-2)}}.clear-filters-btn:focus,.filter-option input:focus,.filter-section-header:focus{outline:var(--focus-outline-width) solid var(--focus-outline-color);outline-offset:var(--focus-outline-offset)}@media (prefers-color-scheme:dark){.filter-option{background:var(--color-gray-800);border-color:var(--color-gray-600);color:var(--color-gray-100)}.filter-option:hover{background:var(--color-gray-700)}.filter-option.selected{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-light) 100%);color:var(--color-white)}.custom-range-container{background:var(--color-gray-100);border-color:var(--color-gray-600)}.range-slider{background:var(--color-gray-600)}}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;gap:16px}.loading-spinner-container.small{padding:10px;gap:8px}.loading-spinner-container.large{padding:40px;gap:24px}.loading-spinner-wrapper{position:relative}.loading-spinner{animation:rotate 1.4s linear infinite}.loading-spinner-container.small .loading-spinner{width:24px;height:24px}.loading-spinner-container.medium .loading-spinner{width:40px;height:40px}.loading-spinner-container.large .loading-spinner{width:60px;height:60px}.loading-spinner-track{stroke:#e5e7eb}.loading-spinner-fill{stroke:#667eea;stroke-linecap:round;animation:dash 1.4s ease-in-out infinite}.loading-message{margin:0;color:#6b7280;font-size:.9rem;text-align:center}.loading-spinner-container.small .loading-message{font-size:.8rem}.loading-spinner-container.large .loading-message{font-size:1rem}.loading-spinner-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.9);display:flex;align-items:center;justify-content:center;z-index:9999}@keyframes dash{0%{stroke-dasharray:1 125;stroke-dashoffset:0}50%{stroke-dasharray:90 125;stroke-dashoffset:-35}to{stroke-dasharray:90 125;stroke-dashoffset:-124}}@media (prefers-color-scheme:dark){.loading-spinner-track{stroke:#374151}.loading-message{color:#9ca3af}.loading-spinner-overlay{background:rgba(0,0,0,.9)}}.section-list{background:var(--color-white);border-radius:var(--radius-xl);padding:var(--spacing-6);box-shadow:var(--shadow-md);border:1px solid var(--color-gray-200);width:100%;min-height:400px;transition:var(--transition-shadow)}.section-list.loading{display:flex;justify-content:center;align-items:center;min-height:200px}.loading-spinner{text-align:center}.spinner{width:40px;height:40px;border-top:4px solid rgba(var(--color-primary-rgb),.1);border:4px solid rgba(var(--color-primary-rgb),.1);border-top-color:var(--color-primary);border-radius:var(--radius-full);animation:spin 1s linear infinite;margin:0 auto var(--spacing-4)}.section-list-header{margin-bottom:var(--spacing-5);padding-bottom:var(--spacing-4);border-bottom:2px solid var(--color-gray-100)}.list-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.list-title h3{margin:0;color:var(--color-gray-800);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);letter-spacing:-.02em}.section-summary{display:flex;gap:12px}.summary-item{padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-xl);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);transition:var(--transition-transform)}.summary-item.sunny{background:#fff9e6;color:var(--color-sun-moderate);border:1px solid rgba(247,183,49,.2)}.summary-item.shady{background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary-dark);border:1px solid rgba(var(--color-primary-rgb),.2)}.summary-item.search-results{background:#e2e3e5;color:#495057}.exposure-info{margin-top:8px}.info-text{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-size-sm);color:var(--color-gray-600);cursor:help;transition:color .2s ease}.info-text:hover{color:var(--color-primary)}.info-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--color-primary);color:white;font-size:11px;font-weight:700}.search-and-sort{display:flex;flex-direction:column;gap:12px}.search-section{display:flex;align-items:center;gap:8px;position:relative}.search-label{color:var(--color-gray-600);white-space:nowrap;letter-spacing:-.01em}.search-input,.search-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.search-input{flex:1 1;padding:var(--spacing-2) var(--spacing-3);border:2px solid var(--color-gray-300);border-radius:var(--radius-md);background:var(--color-white);transition:var(--transition-colors)}.search-input:focus{outline:2px solid var(--color-primary);outline-offset:2px;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.search-clear-btn{background:var(--color-gray-600);border:none;color:var(--color-white);width:44px;height:44px;min-width:44px;min-height:44px;border-radius:var(--radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);transition:var(--transition-all);position:absolute;right:var(--spacing-2);touch-action:manipulation;box-shadow:var(--shadow-sm)}.search-clear-btn:hover{background:var(--color-gray-700);transform:scale(1.05)}.search-clear-btn:focus{outline:2px solid #007bff;outline-offset:2px}.sort-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.sort-label{font-size:.9em;color:#6c757d;font-weight:500}.sort-btn{background:#ffffff;border:1px solid #e3f2fd;border-radius:20px;padding:12px 16px;font-size:.8em;color:#424242;cursor:pointer;transition:all .2s ease;white-space:nowrap;min-height:44px;touch-action:manipulation}.sort-btn:hover{background:#f5f9fc;border-color:#90caf9}.sort-btn.active{background:#2196f3;border-color:#2196f3;color:white}.sort-btn:focus{outline:2px solid #007bff;outline-offset:2px}.no-sections{text-align:center;padding:40px 20px;color:#6c757d}.no-sections p{margin:8px 0}.section-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:16px;gap:16px;padding:0;width:100%}.section-card{background:var(--color-white);border-radius:var(--radius-xl);padding:var(--spacing-4);box-shadow:var(--shadow-sm);border:1px solid var(--color-gray-100);border-left:4px solid var(--sun-color);transition:var(--transition-all);position:relative;min-height:120px;cursor:pointer;touch-action:manipulation;width:100%;box-sizing:border-box;z-index:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.section-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:rgba(var(--color-primary-rgb),.2);background:var(--color-gray-50)}.section-card:active{transform:scale(.98)}.section-card:focus{outline:2px solid var(--color-primary);outline-offset:2px}.section-card[data-exposure="0"]{--sun-color:var(--color-sun-none);background:var(--color-gray-50)}.section-card[data-exposure^="1"],.section-card[data-exposure^="2"]{--sun-color:var(--color-sun-low);background:#f3f9ff}.section-card[data-exposure^="3"],.section-card[data-exposure^="4"]{--sun-color:var(--color-sun-moderate);background:#fffef7}.section-card[data-exposure^="5"],.section-card[data-exposure^="6"],.section-card[data-exposure^="7"]{--sun-color:var(--color-sun-high);background:#fff8f3}.section-card[data-exposure="100"],.section-card[data-exposure^="8"],.section-card[data-exposure^="9"]{--sun-color:var(--color-sun-extreme);background:#fff5f2}.section-header{margin-bottom:16px}.section-header h3{color:var(--color-primary-dark);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);letter-spacing:-.02em}.sun-indicator{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.sun-icon{font-size:1.2rem}.exposure-text{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-800)}.exposure-description{font-size:.8rem;color:#616161;width:100%;margin-top:2px}.section-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:12px}.section-level{font-size:var(--font-size-sm);color:var(--color-gray-700);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.05em}.price-tier{padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.price-tier.value{background:#e8f5e9;color:#43a047}.price-tier.moderate{background:#fff8e1;color:#fb8c00}.price-tier.premium{background:#f3e5f5;color:#8e24aa}.price-tier.luxury{background:#1976d2;color:white}.covered-indicator{padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:600;background:#e3f2fd;color:#1565c0;border:1px solid #90caf9}.section-direction{font-size:.85rem;color:#616161;font-family:SF Mono,Monaco,Inconsolata,monospace;text-align:center;padding-top:12px;border-top:1px solid #e8f4f8}.weather-adjusted{margin-left:6px;font-size:.8rem;opacity:.8}.section-card.loading{pointer-events:none;opacity:.5;min-height:120px}.section-skeleton{animation:skeleton-loading 1s linear infinite alternate}@keyframes skeleton-loading{0%{opacity:.5}to{opacity:.8}}.skeleton-direction,.skeleton-header,.skeleton-meta{background:#e3f2fd;border-radius:4px;margin-bottom:12px}.skeleton-header{height:24px;width:80%}.skeleton-meta{height:20px;width:60%}.skeleton-direction{height:16px;width:40%;margin:12px auto 0}@media (max-width:768px){.section-list{padding:16px;box-shadow:none;border-radius:0;border-left:none;border-right:none}.section-grid{grid-template-columns:1fr;gap:12px}.section-list-container{width:100%;padding:0}.section-card{min-height:48px;width:100%;box-sizing:border-box}.list-title{flex-direction:column;align-items:stretch;gap:8px}.search-and-sort{gap:8px}.search-section{flex-direction:column;align-items:stretch;gap:6px}.search-label{font-size:1rem}.search-input{min-height:48px;padding:14px 16px;font-size:16px}.search-clear-btn{width:44px;height:44px;right:8px;font-size:.9em}.sort-controls{justify-content:center}.sort-btn{min-height:48px;padding:14px 18px;font-size:.9rem}.sort-btn:active{transform:scale(.98);opacity:.9}.section-meta{flex-direction:column;align-items:stretch;gap:4px}}.section-list-container{padding:0;width:100%;min-height:600px}.virtual-section-list{width:100%!important}.section-grid-virtual{width:100%}.section-grid-virtual>div{padding:8px;box-sizing:border-box}.section-grid-virtual [style*="position: absolute"]{width:calc(100% - 16px)!important;box-sizing:border-box;left:8px!important;right:8px!important}.empty-state{display:flex;justify-content:center;align-items:center;min-height:200px;padding:40px 20px;text-align:center}.empty-state-content{max-width:400px}.empty-state-icon{font-size:3rem;margin-bottom:16px;opacity:.8}.empty-state-title{margin:0 0 12px;font-size:1.3rem;font-weight:600;color:#333}.empty-state-message{margin:0 0 20px;color:#666;line-height:1.5;font-size:.95rem}.empty-state-action,.loading-dots{margin-top:16px}.loading-dots{display:flex;justify-content:center;gap:8px}.loading-dots span{width:8px;height:8px;border-radius:50%;background-color:#1a237e;animation:loading-dot 1.4s infinite both}.loading-dots span:first-child{animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}@keyframes loading-dot{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.empty-state-no-stadium{background:linear-gradient(135deg,#f8f9ff,#e8eaf6);border-radius:12px;border:1px solid #e0e4f7}.empty-state-no-game{background:linear-gradient(135deg,#fff8e1,#ffe0b2);border-radius:12px;border:1px solid #ffcc02}.empty-state-no-sections{background:linear-gradient(135deg,#f3e5f5,#e1bee7);border-radius:12px;border:1px solid #ba68c8}.empty-state-loading{background:linear-gradient(135deg,#e8f5e8,#c8e6c9);border-radius:12px;border:1px solid #4caf50}@media (max-width:768px){.empty-state{min-height:150px;padding:30px 15px}.empty-state-icon{font-size:2.5rem}.empty-state-title{font-size:1.1rem}.empty-state-message{font-size:.9rem}}.error-notification{position:fixed;top:20px;right:20px;max-width:400px;z-index:1000;border-radius:8px;padding:16px;box-shadow:0 4px 12px rgba(0,0,0,.15);animation:slideIn .3s ease-out;font-family:inherit}.error-notification-error{background:#fee;border:1px solid #fcc;color:#c53030}.error-notification-warning{background:#fffbeb;border:1px solid #fed7aa;color:#d97706}.error-notification-info{background:#eff6ff;border:1px solid #bfdbfe;color:#2563eb}.error-notification-content{display:flex;align-items:center;gap:12px}.error-notification-icon{font-size:1.2rem;flex-shrink:0}.error-notification-message{flex:1 1;font-size:.9rem;line-height:1.4}.error-notification-close{background:none;border:none;font-size:1.1rem;cursor:pointer;padding:10px;border-radius:4px;color:inherit;opacity:.7;transition:opacity .2s;flex-shrink:0;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;touch-action:manipulation}.error-notification-close:hover{opacity:1}.error-notification-close:focus{outline:2px solid currentColor;outline-offset:2px}@media (max-width:768px){.error-notification{top:10px;right:10px;left:10px;max-width:none}}.breadcrumb{background:white;border-radius:8px;padding:12px 16px;margin-bottom:16px;box-shadow:0 2px 4px rgba(0,0,0,.1);border:1px solid #e9ecef}.breadcrumb-list{flex-wrap:wrap;margin:0;padding:0;list-style:none;gap:8px}.breadcrumb-button,.breadcrumb-item,.breadcrumb-list{display:flex;align-items:center}.breadcrumb-button{background:none;border:none;color:#007bff;cursor:pointer;font-size:.9rem;padding:4px 8px;border-radius:4px;transition:all .2s ease;text-decoration:none;gap:4px}.breadcrumb-button:hover{background:#e3f2fd;color:#0056b3}.breadcrumb-button:focus{outline:2px solid #007bff;outline-offset:2px}.breadcrumb-current{color:#6c757d;font-weight:500;font-size:.9rem;display:flex;flex-direction:column;align-items:flex-start}.breadcrumb-subtitle{font-size:.8rem;color:#868e96;font-weight:400;margin-top:2px}.breadcrumb-separator{color:#6c757d;font-size:.9rem;margin:0 4px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}@media (max-width:768px){.breadcrumb{padding:8px 12px;margin-bottom:12px}.breadcrumb-list{gap:4px}.breadcrumb-button,.breadcrumb-current{font-size:.8rem}.breadcrumb-subtitle{font-size:.7rem}.breadcrumb-separator{margin:0 2px}}@media (max-width:480px){.breadcrumb-list{flex-direction:column;align-items:flex-start;gap:8px}.breadcrumb-separator{display:none}.breadcrumb-item{width:100%}.breadcrumb-button{justify-content:flex-start;background:#f8f9fa;border:1px solid #dee2e6}.breadcrumb-button,.breadcrumb-current{width:100%;padding:12px 16px;border-radius:6px;min-height:48px;font-size:1rem}.breadcrumb-current{background:#e9ecef}}.share-button-container{position:relative;display:inline-block}.share-button{background:linear-gradient(135deg,var(--color-success) 0,#20c997 100%);color:var(--color-white);border:none;border-radius:var(--radius-lg);padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-all);display:flex;align-items:center;gap:var(--spacing-2);min-width:100px;justify-content:center;box-shadow:var(--shadow-md);min-height:44px;touch-action:manipulation}.share-button:hover:not(.disabled){background:linear-gradient(135deg,#218838,#1abc9c);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.share-button:active:not(.disabled){transform:scale(.98)}.share-button:focus{outline:2px solid var(--color-success);outline-offset:2px}.share-button.disabled{background:var(--color-gray-600);cursor:not-allowed;opacity:.6;box-shadow:none}.share-menu{position:absolute;top:100%;right:0;background:var(--color-white);border:1px solid var(--color-gray-300);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:var(--z-index-dropdown);min-width:160px;margin-top:var(--spacing-2);padding:var(--spacing-2) 0;opacity:0;transform:translateY(-10px);animation:shareMenuSlideIn .2s ease-out forwards}@keyframes shareMenuSlideIn{to{opacity:1;transform:translateY(0)}}.share-menu-item{width:100%;background:none;border:none;padding:var(--spacing-3) var(--spacing-4);text-align:left;cursor:pointer;transition:var(--transition-colors);display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-gray-800);min-height:44px;touch-action:manipulation;font-weight:var(--font-weight-medium)}.share-menu-item:hover{background:var(--color-gray-100);transform:translateX(2px)}.share-menu-item:focus{outline:2px solid var(--color-primary);outline-offset:-2px;background:rgba(var(--color-primary-rgb),.1)}.share-menu-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:transparent;z-index:999}@media (max-width:768px){.share-button{padding:8px 12px;font-size:.8rem;min-width:80px}.share-menu{right:0;left:0;min-width:auto;margin-top:4px}.share-menu-item{padding:12px 16px;font-size:.9rem}}@media (prefers-contrast:high){.share-button{border:2px solid #fff}.share-menu{border:2px solid #000}.share-menu-item:hover{background:#000;color:#fff}}@media (prefers-reduced-motion:reduce){.share-button{transition:none}.share-menu{animation:none;opacity:1}.share-button:hover:not(.disabled),.share-menu{transform:none}}.user-profile-menu{position:relative;margin-left:auto}.profile-menu-trigger{display:flex;align-items:center;gap:8px;padding:6px 12px;border:1px solid rgba(255,255,255,.2);border-radius:24px;background-color:rgba(255,255,255,.1);color:white;cursor:pointer;transition:all .2s ease;font-size:14px}.profile-menu-trigger:hover{background-color:rgba(255,255,255,.2);border-color:rgba(255,255,255,.3)}.profile-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px;color:white}.profile-name{font-weight:500;max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-icon{font-size:10px;margin-left:4px;transition:transform .2s ease}.profile-menu-trigger[aria-expanded=true] .dropdown-icon{transform:rotate(180deg)}.profile-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:280px;background-color:white;border-radius:12px;box-shadow:0 4px 20px rgba(0,0,0,.15);z-index:1000;overflow:hidden;animation:slideIn .2s ease}.profile-info{padding:16px;background-color:#f8f9fa}.profile-info-header{display:flex;gap:12px;align-items:center}.profile-avatar-large{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:18px;color:white;flex-shrink:0}.profile-details{flex:1 1;min-width:0}.profile-name-large{font-weight:600;font-size:16px;color:#1a1a1a;margin-bottom:2px}.profile-email{font-size:13px;color:#666;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-stats{display:flex;gap:12px;font-size:12px;color:#888}.menu-divider{height:1px;background-color:#e0e0e0;margin:0}.menu-section-title{padding:8px 16px 4px;font-size:12px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;border:none;background:none;color:#333;font-size:14px;text-align:left;cursor:pointer;transition:background-color .2s ease}.menu-item:hover{background-color:#f0f0f0}.menu-item:focus-visible{outline:2px solid #1976d2;outline-offset:-2px}.menu-icon{font-size:16px;width:20px;text-align:center}.profile-switch-item{padding:8px 16px}.profile-avatar-small{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;color:white}.menu-item-danger{color:#d32f2f}.menu-item-danger:hover{background-color:#ffebee}.create-profile-form{padding:16px;background-color:#f8f9fa}.create-profile-form input{width:100%;padding:10px 12px;margin-bottom:8px;border:1px solid #ddd;border-radius:8px;font-size:14px;transition:border-color .2s ease}.create-profile-form input:focus{outline:none;border-color:#1976d2}.form-actions{display:flex;gap:8px;margin-top:12px}.form-actions button{flex:1 1;padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary{background-color:#1976d2}.btn-primary:hover:not(:disabled){background-color:#1565c0}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background-color:#e0e0e0;color:#333}.btn-secondary:hover{background-color:#d0d0d0}@media (max-width:768px){.profile-menu-dropdown{position:fixed;top:auto;bottom:0;left:0;right:0;width:100%;border-radius:20px 20px 0 0;max-height:80vh;overflow-y:auto}.profile-name{display:none}.profile-menu-trigger{padding:6px 8px}}.main-navigation{background:var(--color-white);padding:0 20px;border-bottom:1px solid var(--color-gray-200);position:-webkit-sticky;position:sticky;top:0;z-index:100;min-height:56px}.nav-container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:20px}.nav-tabs{display:flex;gap:0}.nav-tab{background:none;color:var(--color-gray-600);padding:16px 20px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease;border-radius:0;border:none;border-bottom:2px solid transparent;display:flex;align-items:center;gap:8px;position:relative;min-height:44px;touch-action:manipulation}.nav-tab:hover{color:var(--color-gray-900)}.nav-tab.active,.nav-tab:hover{background:var(--color-gray-50)}.nav-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.nav-tab:active{transform:scale(.98);opacity:.9}.nav-tab.active:after{content:"";position:absolute;bottom:-3px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid white}.tab-icon{font-size:1.2rem}.tab-label{white-space:nowrap}.nav-controls{display:flex;align-items:center}.nav-language-selector .language-selector-buttons{gap:4px}.nav-language-selector .language-selector-buttons button{background:rgba(255,255,255,.1);color:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.2);padding:6px 12px;border-radius:4px;font-size:.85rem;transition:all .2s ease;min-height:32px;min-width:32px}.nav-language-selector .language-selector-buttons button:hover{background:rgba(255,255,255,.2);color:white}.nav-language-selector .language-selector-buttons button.active{background:rgba(255,255,255,.3);color:white;border-color:rgba(255,255,255,.4)}@media (max-width:768px){.main-navigation{padding:0 10px}.nav-container{gap:10px}.nav-tab{padding:12px 14px;font-size:.9rem;min-height:48px;gap:4px}.tab-label{font-size:.8rem;margin-left:-4px}.tab-icon{font-size:1.2rem}.nav-tab:active{transform:scale(.98);background:rgba(255,255,255,.2)}.nav-language-selector .language-selector-buttons button{padding:4px 8px;font-size:.8rem;min-height:36px;min-width:36px}}@media (max-width:480px){.nav-tab{padding:10px 12px}.tab-label{display:none}.tab-icon{font-size:1.4rem}.nav-language-selector .language-selector-buttons button span{display:none}}.error-boundary-container{min-height:400px;display:flex;align-items:center;justify-content:center;padding:40px 20px;background-color:var(--color-gray-50);border-radius:var(--radius-xl);margin:20px 0;animation:fadeIn .3s ease-in-out}.error-boundary-page{min-height:80vh;margin:0;border-radius:0}.error-boundary-section{min-height:300px}.error-boundary-component{min-height:200px}.error-boundary-isolated{background-color:var(--color-white);border:1px solid var(--color-gray-200);box-shadow:var(--shadow-sm)}.error-boundary-content{text-align:center;max-width:500px}.error-icon{margin-bottom:24px}.error-title{color:var(--color-gray-900);font-size:var(--font-size-2xl);margin-bottom:var(--spacing-4);font-weight:var(--font-weight-semibold)}.error-message{color:var(--color-gray-600);font-size:var(--font-size-lg);line-height:1.6;margin-bottom:var(--spacing-6)}.error-retry-info{color:var(--color-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-4);animation:pulse 2s ease-in-out infinite}.error-details{margin:24px 0;text-align:left;background:white;padding:16px;border-radius:8px;border:1px solid #dee2e6}.error-details summary{cursor:pointer;color:#495057;font-weight:500;padding:8px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.error-details summary:hover{color:#007bff}.error-stack{margin-top:16px;padding:16px;background:#f8f9fa;border-radius:4px;overflow-x:auto;font-family:Monaco,Consolas,monospace;font-size:.875rem;line-height:1.5;color:#dc3545}.error-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.error-btn{padding:var(--spacing-3) var(--spacing-6);border-radius:var(--radius-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:var(--transition-all);min-width:120px;border:none;text-decoration:none;display:inline-block}.error-btn.primary{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-dark) 100%);color:var(--color-white);box-shadow:var(--shadow-md)}.error-btn.primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg)}.error-btn.primary:disabled{opacity:.5;cursor:not-allowed}.error-btn.secondary{background-color:var(--color-gray-200);color:var(--color-gray-700);box-shadow:var(--shadow-sm)}.error-btn.secondary:hover{background-color:var(--color-gray-300);transform:translateY(-1px);box-shadow:var(--shadow-md)}.error-btn:active{transform:translateY(0)}@media (max-width:768px){.error-boundary-container{min-height:300px;padding:24px 16px}.error-boundary-content h2{font-size:1.5rem}.error-message{font-size:1rem}.error-actions{flex-direction:column;width:100%}.error-btn{width:100%}}.sun-exposure-explanation{background:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);border:1px solid var(--color-gray-200);overflow:hidden;transition:var(--transition-all);margin-bottom:var(--spacing-5)}.explanation-toggle{width:100%;padding:var(--spacing-4) var(--spacing-5);background:linear-gradient(135deg,#fff9f0,#fff5e6);border:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-800);transition:var(--transition-all);min-height:56px}.explanation-toggle:hover{background:linear-gradient(135deg,#fff5e6,#ffedd5)}.explanation-toggle:focus{outline:2px solid var(--color-primary);outline-offset:-2px}.toggle-header{display:flex;align-items:center;gap:var(--spacing-3)}.explanation-content{padding:var(--spacing-6);background:var(--color-gray-50);border-top:1px solid var(--color-gray-200);animation:slideDown .3s ease-out}.exposure-ranges h4,.health-safety h4,.practical-tips h4{color:var(--color-primary-dark);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin:0 0 var(--spacing-4) 0;letter-spacing:-.02em}.intro-text{color:var(--color-gray-700);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-5);font-size:var(--font-size-base)}.exposure-range-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:var(--spacing-4);gap:var(--spacing-4);margin-bottom:var(--spacing-8)}.exposure-range{background:var(--color-white);border-radius:var(--radius-lg);padding:var(--spacing-4);border:1px solid var(--color-gray-200);transition:var(--transition-all)}.exposure-range[data-range="0"]{border-left:4px solid var(--color-sun-none);background:linear-gradient(90deg,rgba(108,117,125,.05),transparent)}.exposure-range[data-range="25"]{border-left:4px solid var(--color-sun-low);background:linear-gradient(90deg,rgba(34,197,94,.05),transparent)}.exposure-range[data-range="50"]{border-left:4px solid var(--color-sun-moderate);background:linear-gradient(90deg,rgba(245,158,11,.05),transparent)}.exposure-range[data-range="75"]{border-left:4px solid var(--color-sun-high);background:linear-gradient(90deg,rgba(249,115,22,.05),transparent)}.exposure-range[data-range="100"]{border-left:4px solid var(--color-sun-extreme);background:linear-gradient(90deg,rgba(220,38,38,.05),transparent)}.exposure-range:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.range-header{display:flex;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-3)}.range-title{font-weight:var(--font-weight-semibold);color:var(--color-gray-800);font-size:var(--font-size-base)}.range-details{list-style:none;padding:0;margin:0;color:var(--color-gray-600);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}.range-details li{padding:var(--spacing-1) 0;padding-left:var(--spacing-5);position:relative}.range-details li:before{content:"•";position:absolute;left:var(--spacing-2);color:var(--color-primary);font-weight:700}.practical-tips{margin-bottom:var(--spacing-8)}.tips-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:var(--spacing-4);gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.tip-card{background:var(--color-white);border-radius:var(--radius-lg);padding:var(--spacing-4);border:1px solid var(--color-gray-200);box-shadow:var(--shadow-sm);transition:var(--transition-all)}.tip-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-light)}.tip-header{display:flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-3);color:var(--color-primary);font-weight:var(--font-weight-semibold)}.tip-card p{margin:0;color:var(--color-gray-600);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}.health-safety{background:linear-gradient(135deg,#e3f2fd,#f3e5f5);border-radius:var(--radius-lg);padding:var(--spacing-5);border:1px solid rgba(33,150,243,.2)}.safety-content p{margin:0 0 var(--spacing-3) 0;color:var(--color-gray-700);line-height:var(--line-height-relaxed)}.safety-content p:last-child{margin-bottom:0}.safety-content strong{color:var(--color-primary-dark);font-weight:var(--font-weight-semibold)}@media (max-width:768px){.explanation-toggle{font-size:var(--font-size-base);padding:var(--spacing-3) var(--spacing-4)}.explanation-content{padding:var(--spacing-4)}.exposure-range-grid,.tips-grid{grid-template-columns:1fr;gap:var(--spacing-3)}.exposure-ranges h4,.health-safety h4,.practical-tips h4{font-size:var(--font-size-lg)}.range-details,.tip-card p{font-size:var(--font-size-xs)}}:root{--color-field-green:#1a5f3f;--color-field-green-light:#2d8659;--color-field-green-dark:#0f3926;--color-baseball-red:#c8102e;--color-baseball-red-light:#e63946;--color-baseball-red-dark:#991122;--color-baseball-navy:#002d72;--color-baseball-navy-light:#003f8e;--color-baseball-navy-dark:#001a42;--color-neutral-950:#0a0a0b;--color-neutral-900:#171717;--color-neutral-800:#262626;--color-neutral-700:#404040;--color-neutral-600:#525252;--color-neutral-500:#737373;--color-neutral-400:#a3a3a3;--color-neutral-300:#d4d4d4;--color-neutral-200:#e5e5e5;--color-neutral-100:#f5f5f5;--color-neutral-50:#fafafa;--color-white:#ffffff;--color-sun-yellow:#fbbf24;--color-sun-orange:#fb923c;--color-sky-blue:#38bdf8;--color-grass-green:#4ade80;--font-display:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--font-weight-black:900;--font-size-2xs:0.625rem;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--font-size-5xl:3rem;--font-size-6xl:3.75rem;--font-size-7xl:4.5rem;--line-height-tight:1.1;--line-height-snug:1.25;--line-height-normal:1.5;--line-height-relaxed:1.75;--line-height-loose:2;--letter-spacing-tighter:-0.05em;--letter-spacing-tight:-0.025em;--letter-spacing-normal:0;--letter-spacing-wide:0.025em;--letter-spacing-wider:0.05em;--letter-spacing-widest:0.1em;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-7:1.75rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--radius-none:0;--radius-sm:0.125rem;--radius-base:0.25rem;--radius-md:0.375rem;--radius-lg:0.5rem;--radius-xl:0.75rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--shadow-xs:0 1px 2px 0 rgb(0 0 0/0.05);--shadow-sm:0 1px 3px 0 rgb(0 0 0/0.1),0 1px 2px -1px rgb(0 0 0/0.1);--shadow-base:0 4px 6px -1px rgb(0 0 0/0.1),0 2px 4px -2px rgb(0 0 0/0.1);--shadow-md:0 10px 15px -3px rgb(0 0 0/0.1),0 4px 6px -4px rgb(0 0 0/0.1);--shadow-lg:0 20px 25px -5px rgb(0 0 0/0.1),0 8px 10px -6px rgb(0 0 0/0.1);--shadow-xl:0 25px 50px -12px rgb(0 0 0/0.25);--shadow-2xl:0 35px 60px -15px rgb(0 0 0/0.3);--shadow-inner:inset 0 2px 4px 0 rgb(0 0 0/0.05);--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-base:250ms cubic-bezier(0.4,0,0.2,1);--transition-slow:350ms cubic-bezier(0.4,0,0.2,1);--transition-slower:500ms cubic-bezier(0.4,0,0.2,1);--ease-in:cubic-bezier(0.4,0,1,1);--ease-out:cubic-bezier(0,0,0.2,1);--ease-in-out:cubic-bezier(0.4,0,0.2,1);--ease-bounce:cubic-bezier(0.68,-0.55,0.265,1.55);--z-base:0;--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal-backdrop:1040;--z-modal:1050;--z-popover:1060;--z-tooltip:1070;--gradient-field:linear-gradient(135deg,var(--color-field-green) 0%,var(--color-field-green-light) 100%);--gradient-sunset:linear-gradient(135deg,var(--color-sun-orange) 0%,var(--color-sun-yellow) 100%);--gradient-sky:linear-gradient(180deg,var(--color-sky-blue) 0%,var(--color-baseball-navy-light) 100%);--gradient-heat:linear-gradient(135deg,var(--color-baseball-red) 0%,var(--color-sun-orange) 100%);--glass-bg:rgba(255,255,255,0.8);--glass-bg-dark:rgba(0,0,0,0.5);--glass-border:rgba(255,255,255,0.18);--glass-shadow:0 8px 32px 0 rgba(31,38,135,0.37);--glass-blur:blur(12px)}@media (prefers-color-scheme:dark){:root{--glass-bg:rgba(0,0,0,0.8);--glass-bg-dark:rgba(255,255,255,0.1);--glass-border:rgba(255,255,255,0.08)}}.heading-display{font-weight:var(--font-weight-black);font-size:var(--font-size-7xl);letter-spacing:var(--letter-spacing-tighter)}.heading-1,.heading-display{font-family:var(--font-display);line-height:var(--line-height-tight)}.heading-1{font-weight:var(--font-weight-extrabold);font-size:var(--font-size-5xl);letter-spacing:var(--letter-spacing-tight)}.heading-2{font-size:var(--font-size-4xl);letter-spacing:var(--letter-spacing-tight)}.heading-2,.heading-3{font-family:var(--font-display);font-weight:var(--font-weight-bold);line-height:var(--line-height-snug)}.heading-3{font-size:var(--font-size-3xl)}.heading-4{font-size:var(--font-size-2xl)}.heading-4,.heading-5{font-family:var(--font-display);font-weight:var(--font-weight-semibold);line-height:var(--line-height-normal)}.heading-5{font-size:var(--font-size-xl)}.body-large{font-size:var(--font-size-lg);line-height:var(--line-height-relaxed)}.body-base{font-size:var(--font-size-base)}.body-base,.body-small{line-height:var(--line-height-normal)}.body-small{font-size:var(--font-size-sm)}.caption{letter-spacing:var(--letter-spacing-wide)}.caption,.overline{font-size:var(--font-size-xs);line-height:var(--line-height-normal)}.overline{letter-spacing:var(--letter-spacing-widest);text-transform:uppercase}.btn-modern,.overline{font-weight:var(--font-weight-semibold)}.btn-modern{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-family:var(--font-display);font-size:var(--font-size-base);line-height:1;text-decoration:none;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);overflow:hidden}.btn-modern:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.1) 50%,transparent 70%);transform:translateX(-100%);transition:transform var(--transition-slow)}.btn-modern:hover:before{transform:translateX(100%)}.btn-modern:active{transform:scale(.98)}.btn-primary{background:var(--gradient-field);color:var(--color-white);box-shadow:var(--shadow-md)}.btn-primary:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.btn-secondary{background:var(--color-white);color:var(--color-field-green);border:2px solid var(--color-field-green);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--color-field-green);color:var(--color-white);box-shadow:var(--shadow-md)}.card-glass{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);padding:var(--space-6);transition:all var(--transition-base)}.card-glass:hover{transform:translateY(-2px);box-shadow:var(--shadow-xl)}.input-modern{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-body);font-size:var(--font-size-base);background:var(--color-white);border:2px solid var(--color-neutral-300);border-radius:var(--radius-lg);transition:all var(--transition-fast);outline:none}.input-modern:focus{border-color:var(--color-field-green);box-shadow:0 0 0 3px rgba(26,95,63,.1)}.input-modern::-ms-input-placeholder{color:var(--color-neutral-400)}.input-modern::placeholder{color:var(--color-neutral-400)}.skeleton{background:linear-gradient(90deg,var(--color-neutral-200) 25%,var(--color-neutral-100) 50%,var(--color-neutral-200) 75%);animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-bounce{animation:bounce 1s infinite}@keyframes slideIn{0%{transform:translateX(-100%);opacity:0}to{transform:translateX(0);opacity:1}}.animate-slide-in{animation:slideIn var(--transition-base)}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.animate-scale-in{animation:scaleIn var(--transition-fast)}.animate-fade-in{animation:fadeIn var(--transition-base)}.badge-modern{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);transition:all var(--transition-fast)}.badge-success{background:var(--color-grass-green);color:var(--color-white)}.badge-warning{background:var(--color-sun-yellow);color:var(--color-neutral-900)}.badge-danger{background:var(--color-baseball-red);color:var(--color-white)}.badge-info{background:var(--color-sky-blue);color:var(--color-white)}.toggle-modern{position:relative;width:56px;height:32px;background:var(--color-neutral-300);border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast)}.toggle-modern.active{background:var(--color-field-green)}.toggle-modern:after{content:"";position:absolute;top:4px;left:4px;width:24px;height:24px;background:var(--color-white);border-radius:var(--radius-full);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast)}.toggle-modern.active:after{transform:translateX(24px)}.tooltip{position:relative;display:inline-block}.tooltip:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translateX(-50%) translateY(-8px);padding:var(--space-2) var(--space-3);background:var(--color-neutral-900);color:var(--color-white);font-size:var(--font-size-sm);border-radius:var(--radius-md);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity var(--transition-fast)}.tooltip:hover:after{opacity:1}.progress-modern{width:100%;height:8px;background:var(--color-neutral-200);border-radius:var(--radius-full);overflow:hidden}.progress-modern-fill{height:100%;background:var(--gradient-field);border-radius:var(--radius-full);transition:width var(--transition-base)}.focus-visible{outline:2px solid var(--color-field-green);outline-offset:2px}.text-gradient{background:var(--gradient-field);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.shadow-modern{box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06),0 20px 25px -5px rgba(0,0,0,.1)}.hover-lift{transition:transform var(--transition-base)}.hover-lift:hover{transform:translateY(-4px)}.hover-grow{transition:transform var(--transition-base)}.hover-grow:hover{transform:scale(1.05)}@media (max-width:768px){.heading-display{font-size:var(--font-size-5xl)}.heading-1{font-size:var(--font-size-4xl)}.heading-2{font-size:var(--font-size-3xl)}.heading-3{font-size:var(--font-size-2xl)}}.mobile-menu-container{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;pointer-events:none}.mobile-menu-container>*{pointer-events:auto}body.menu-open{overflow:hidden;position:fixed;width:100%;height:100%}.mobile-header{position:-webkit-sticky;position:sticky;top:0;z-index:var(--z-fixed);background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid rgba(0,0,0,.08);width:100%;transition:all var(--transition-base)}.mobile-header.scrolled{background:rgba(255,255,255,.95);box-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 4px 16px -4px rgba(0,0,0,.1)}.mobile-header-content{justify-content:space-between;height:64px;padding:0 var(--space-4);position:relative}.mobile-header-content,.mobile-header-logo{display:flex;align-items:center;gap:var(--space-3)}.mobile-header-logo{flex:1 1}.mobile-header-icon{width:36px;height:36px;background:var(--gradient-field);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:var(--shadow-sm);animation:rotate 20s linear infinite}.mobile-header-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary);margin:0;letter-spacing:-.025em}.mobile-header-menu{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:transparent;border:none;color:var(--color-neutral-700);cursor:pointer;border-radius:var(--radius-lg);transition:all var(--transition-fast);position:relative}.mobile-header-menu:hover{background:var(--color-neutral-100);color:var(--color-field-green)}.mobile-header-menu:active{transform:scale(.95)}.mobile-header-menu svg{width:24px;height:24px;transition:transform var(--transition-base)}.mobile-header-menu.active svg{transform:rotate(90deg)}.mobile-menu-overlay{left:0;background:rgba(0,0,0,.3);z-index:1040;animation:fadeIn var(--transition-fast)}.mobile-menu,.mobile-menu-overlay{position:fixed;top:0;right:0;bottom:0;pointer-events:auto}.mobile-menu{width:min(320px,80vw);background:var(--color-white);box-shadow:var(--shadow-2xl);z-index:1050;transform:translateX(0);animation:slideInRight var(--transition-base) var(--ease-out);display:flex;flex-direction:column}@keyframes slideInRight{0%{transform:translateX(100%)}to{transform:translateX(0)}}.mobile-menu-header{justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--color-neutral-200);background:var(--gradient-field)}.mobile-menu-close,.mobile-menu-header{display:flex;align-items:center;color:white}.mobile-menu-close{width:40px;height:40px;justify-content:center;background:rgba(255,255,255,.2);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.mobile-menu-close:hover{background:rgba(255,255,255,.3)}.mobile-menu-close:active{transform:scale(.95)}.mobile-menu-items{flex:1 1;overflow-y:auto;padding:var(--space-2)}.mobile-menu-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);margin-bottom:var(--space-2);background:transparent;border:none;border-radius:var(--radius-lg);color:var(--color-neutral-900);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);text-align:left;cursor:pointer;transition:all var(--transition-fast);position:relative;overflow:hidden;text-decoration:none}.mobile-menu-item:before{content:"";position:absolute;top:0;left:0;width:0;height:100%;background:var(--gradient-field);opacity:.1;transition:width var(--transition-base)}.mobile-menu-item:hover{background:var(--color-neutral-50);color:var(--color-field-green);transform:translateX(4px)}.mobile-menu-item:hover:before{width:100%}.mobile-menu-item:active{transform:translateX(2px) scale(.98)}a.mobile-menu-item{display:flex;box-sizing:border-box}a.mobile-menu-item,a.mobile-menu-item:hover{text-decoration:none}.mobile-menu-icon{font-size:var(--font-size-xl);width:24px;height:24px;display:flex;align-items:center;justify-content:center}.mobile-menu-footer{padding:var(--space-4);border-top:1px solid var(--color-neutral-200);background:var(--color-neutral-50)}.mobile-menu-version{text-align:center;font-size:var(--font-size-sm);color:var(--color-neutral-500)}.mobile-menu-item{animation:slideInMenu .3s var(--ease-out) backwards}@keyframes slideInMenu{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.mobile-menu-item:first-child{animation-delay:.05s}.mobile-menu-item:nth-child(2){animation-delay:.1s}.mobile-menu-item:nth-child(3){animation-delay:.15s}.mobile-menu-item:nth-child(4){animation-delay:.2s}.mobile-menu-item:nth-child(5){animation-delay:.25s}@media (min-width:768px){.mobile-header-content{padding:0 var(--space-6);height:72px}.mobile-header-icon{width:40px;height:40px}.mobile-header-title{font-size:var(--font-size-2xl)}.mobile-menu{width:360px}}@media (prefers-color-scheme:dark){.mobile-header{background:rgba(15,23,42,.85);border-bottom-color:rgba(255,255,255,.08)}.mobile-header.scrolled{background:rgba(15,23,42,.95)}.mobile-header-title{color:var(--color-neutral-100)}.mobile-header-menu{color:var(--color-neutral-300)}.mobile-header-menu:hover{background:var(--color-neutral-800);color:var(--color-grass-green)}.mobile-menu{background:var(--color-neutral-900)}.mobile-menu-header{border-bottom-color:var(--color-neutral-800)}.mobile-menu-item{color:var(--color-neutral-100)}.mobile-menu-item:hover{background:var(--color-neutral-800);color:var(--color-grass-green)}.mobile-menu-footer{background:var(--color-neutral-950);border-top-color:var(--color-neutral-800)}}.mobile-filter-trigger{display:flex;align-items:center;justify-content:center;min-height:48px;padding:var(--space-3) var(--space-5);background:var(--gradient-field);border:none;border-radius:var(--radius-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:white;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-md);position:relative;overflow:hidden}.mobile-filter-trigger:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.2) 50%,transparent 70%);transform:translateX(-100%);transition:transform var(--transition-slow)}.mobile-filter-trigger:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.mobile-filter-trigger:hover:before{transform:translateX(100%)}.mobile-filter-trigger:active{transform:scale(.98);box-shadow:var(--shadow-md)}.mobile-filter-trigger-content{display:flex;align-items:center;gap:var(--space-3);position:relative;z-index:1}.mobile-filter-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 var(--space-2);background:rgba(255,255,255,.3);color:white;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);animation:pulse 2s ease-in-out infinite}.mobile-filter-sheet{position:fixed;inset:0;z-index:var(--z-modal);display:flex;align-items:flex-end;pointer-events:none}.mobile-filter-sheet>*{pointer-events:auto}.mobile-filter-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:fadeIn var(--transition-fast)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-filter-content{position:relative;width:100%;height:auto;background:var(--color-white);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;display:flex;flex-direction:column;animation:slideUp var(--transition-base) var(--ease-out);box-shadow:var(--shadow-2xl);margin-bottom:env(safe-area-inset-bottom,0)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-filter-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);background:var(--gradient-field);color:white;border-radius:var(--radius-2xl) var(--radius-2xl) 0 0}.mobile-filter-header h2{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-tight)}.mobile-filter-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:rgba(255,255,255,.2);border:none;border-radius:var(--radius-md);cursor:pointer;color:white;transition:all var(--transition-fast)}.mobile-filter-close:hover{background:rgba(255,255,255,.3)}.mobile-filter-close:active{transform:scale(.95)}.mobile-filter-body{padding:var(--space-3);background:var(--color-white);display:flex;flex-direction:column;gap:var(--space-3)}.mobile-filter-section{margin-bottom:var(--space-2)}.mobile-filter-section:last-child{margin-bottom:0}.mobile-filter-section h3{margin:0 0 6px;font-size:13px;font-weight:var(--font-weight-semibold);color:var(--color-neutral-700);text-transform:uppercase;letter-spacing:.5px}.mobile-filter-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));grid-gap:var(--space-2);gap:var(--space-2)}.mobile-filter-option{position:relative;cursor:pointer}.mobile-filter-option input{position:absolute;opacity:0;pointer-events:none}.mobile-filter-option-content{padding:8px 4px;background:var(--color-white);border:2px solid var(--color-neutral-300);border-radius:var(--radius-lg);text-align:center;font-size:11px;font-weight:var(--font-weight-medium);transition:all var(--transition-fast);box-shadow:var(--shadow-xs)}.mobile-filter-option-content,.mobile-filter-option-text{display:flex;flex-direction:column;align-items:center;gap:2px}.mobile-filter-option-title{font-weight:600;font-size:12px}.mobile-filter-option-description{font-size:10px;opacity:.7;font-weight:400}.mobile-filter-price-options{display:flex;flex-direction:column;gap:var(--space-2)}.mobile-filter-price-options .mobile-filter-option{display:flex;align-items:center}.mobile-filter-price-options .mobile-filter-option-content{flex-direction:row;align-items:center;justify-content:flex-start;padding:12px;text-align:left;width:100%}.mobile-filter-price-options .mobile-filter-option-text{align-items:flex-start;margin-left:8px}.mobile-filter-price-options .mobile-filter-option input{position:relative;opacity:1;margin-right:12px;width:20px;height:20px}.mobile-filter-option:hover .mobile-filter-option-content{border-color:var(--color-field-green-light);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.mobile-filter-option input:checked+.mobile-filter-option-content,.mobile-filter-option.selected .mobile-filter-option-content{background:var(--gradient-field);border-color:transparent;color:white;box-shadow:var(--shadow-sm)}.mobile-filter-option-icon{font-size:18px;transition:transform var(--transition-fast)}.mobile-filter-slider{padding:4px 0}.mobile-filter-range{width:100%;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--color-neutral-200);border-radius:var(--radius-full);outline:none;position:relative}.mobile-filter-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:var(--gradient-field);border:2px solid white;border-radius:var(--radius-full);cursor:pointer;box-shadow:var(--shadow-sm);-webkit-transition:all var(--transition-fast);transition:all var(--transition-fast)}.mobile-filter-range::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:var(--shadow-md)}.mobile-filter-range-labels{display:flex;justify-content:space-between;margin-top:4px;font-size:11px;color:var(--color-neutral-600)}.mobile-filter-range-value{font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);color:var(--color-field-green)}.mobile-filter-help-text{margin:var(--space-2) 0 0 0;font-size:11px;color:var(--color-neutral-600);text-align:center}.mobile-filter-chips{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:var(--space-2);gap:var(--space-2)}.mobile-filter-chip{padding:6px 10px;background:var(--color-white);border:2px solid var(--color-neutral-300);border-radius:var(--radius-md);font-size:12px;font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);text-align:center}.mobile-filter-chip:hover{border-color:var(--color-field-green);transform:translateY(-1px)}.mobile-filter-chip.selected{background:var(--gradient-field);border-color:transparent;color:white;box-shadow:var(--shadow-sm)}.mobile-filter-footer{display:flex;gap:var(--space-2);padding:var(--space-3);background:var(--color-white);border-top:1px solid var(--color-neutral-200)}.mobile-filter-btn{flex:1 1;min-height:40px;padding:8px 12px;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:var(--font-weight-semibold);cursor:pointer;transition:background-color var(--transition-base),box-shadow var(--transition-base),transform var(--transition-base);position:relative;overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-backface-visibility:hidden;backface-visibility:hidden;transform:translateZ(0)}.mobile-filter-btn-secondary{background:var(--color-neutral-100);color:var(--color-neutral-700)}.mobile-filter-btn-secondary:hover{background:var(--color-neutral-200)}.mobile-filter-btn-primary{background:var(--gradient-field);color:white;box-shadow:var(--shadow-sm);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-backface-visibility:hidden;backface-visibility:hidden;transform:translateZ(0)}.mobile-filter-btn-primary:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.2) 50%,transparent 70%);transform:translateX(-100%);transition:transform var(--transition-slow)}.mobile-filter-btn-primary:hover{transform:translateZ(0) translateY(-1px);box-shadow:var(--shadow-md)}.mobile-filter-btn-primary:hover:before{transform:translateX(100%)}.mobile-filter-btn:active{transform:translateZ(0) scale(.98)}@media (max-height:500px) and (orientation:landscape){.mobile-filter-section{margin-bottom:8px}.mobile-filter-chips{grid-template-columns:repeat(4,1fr)}}@media (min-width:768px){.mobile-filter-content{max-width:500px;margin:0 auto;border-radius:var(--radius-2xl);margin-bottom:var(--space-4);animation:scaleIn var(--transition-base) var(--ease-out)}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.mobile-filter-sheet{align-items:center;padding:var(--space-6)}.mobile-filter-body{padding:var(--space-5);gap:var(--space-5)}.mobile-filter-options{gap:var(--space-3)}.mobile-filter-chips{grid-template-columns:repeat(4,1fr)}}@media (prefers-color-scheme:dark){.mobile-filter-content{background:var(--color-neutral-900)}.mobile-filter-header{border-bottom-color:var(--color-neutral-800)}.mobile-filter-body{background:linear-gradient(180deg,var(--color-neutral-900) 0,var(--color-neutral-950) 100%)}.mobile-filter-section h3{color:var(--color-neutral-200)}.mobile-filter-chip,.mobile-filter-option-content{background:var(--color-neutral-800);border-color:var(--color-neutral-700);color:var(--color-neutral-100)}.mobile-filter-footer{background:var(--color-neutral-900);border-top-color:var(--color-neutral-800)}.mobile-filter-btn-secondary{background:var(--color-neutral-800);color:var(--color-neutral-200)}.mobile-filter-btn-secondary:hover,.mobile-filter-range{background:var(--color-neutral-700)}}.mobile-section-card{display:block;width:100%;background:var(--color-white);border:none;border-radius:var(--radius-xl);padding:var(--space-5);margin-bottom:var(--space-4);cursor:pointer;transition:all var(--transition-base);text-align:left;position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.mobile-section-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.mobile-section-card:active{transform:scale(.99);box-shadow:var(--shadow-sm)}.mobile-section-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent,rgba(255,255,255,.5) 50%,transparent);transform:translateX(-100%);transition:transform .6s ease;pointer-events:none}.mobile-section-card:hover:before{transform:translateX(100%)}.mobile-section-card:after{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--gradient-field);transition:width var(--transition-fast)}.mobile-section-card:hover:after{width:6px}.mobile-section-card.shade-full{background:linear-gradient(135deg,#f5f5f5,#e8e8e8)}.mobile-section-card.shade-full:after{background:linear-gradient(180deg,#9e9e9e,#757575)}.mobile-section-card.shade-most{background:linear-gradient(135deg,#e3f2fd,#bbdefb)}.mobile-section-card.shade-most:after{background:linear-gradient(180deg,#64b5f6,#42a5f5)}.mobile-section-card.sun-partial{background:linear-gradient(135deg,#fff9e6,#fff3cc)}.mobile-section-card.sun-partial:after{background:var(--gradient-sunset)}.mobile-section-card.sun-most{background:linear-gradient(135deg,#fff3e0,#ffe0b2)}.mobile-section-card.sun-most:after{background:linear-gradient(180deg,#ffb74d,#ff9800)}.mobile-section-card.sun-full{background:linear-gradient(135deg,#ffebe8,#ffd6cc)}.mobile-section-card.sun-full:after{background:var(--gradient-heat)}.mobile-section-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-4);gap:var(--space-3)}.mobile-section-info{flex:1 1}.mobile-section-name{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-neutral-900);letter-spacing:var(--letter-spacing-tight);line-height:var(--line-height-snug)}.mobile-section-level{margin:var(--space-1) 0 0 0;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-neutral-600);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.mobile-section-sun{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-3);background:rgba(255,255,255,.8);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:var(--radius-lg);min-width:72px}.mobile-section-sun-icon{font-size:28px;animation:pulse 2s ease-in-out infinite}.mobile-section-sun-percent{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-neutral-900)}.mobile-section-details{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:var(--space-4);gap:var(--space-4);margin-bottom:var(--space-4)}.mobile-section-detail{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3);background:rgba(0,0,0,.02);border-radius:var(--radius-md);transition:all var(--transition-fast)}.mobile-section-card:hover .mobile-section-detail{background:rgba(0,0,0,.04)}.mobile-section-detail-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-neutral-500);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider)}.mobile-section-detail-value{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-neutral-900)}.mobile-section-sun-bar{width:100%;height:8px;background:var(--color-neutral-200);border-radius:var(--radius-full);overflow:hidden;position:relative;box-shadow:inset 0 1px 2px rgba(0,0,0,.1)}.mobile-section-sun-fill{height:100%;background:var(--gradient-field);transition:width .6s var(--ease-out);position:relative;overflow:hidden}.mobile-section-sun-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4) 50%,transparent);transform:translateX(-100%);animation:shimmer 2s infinite}@keyframes shimmer{to{transform:translateX(100%)}}.mobile-section-premium{position:absolute;top:var(--space-3);right:var(--space-3);padding:var(--space-1) var(--space-3);background:var(--gradient-field);color:white;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);box-shadow:var(--shadow-sm)}@media (min-width:480px){.mobile-section-details{grid-template-columns:repeat(3,1fr)}}@media (min-width:768px){.mobile-section-card{padding:var(--space-6)}.mobile-section-name{font-size:var(--font-size-2xl)}.mobile-section-sun{min-width:84px}.mobile-section-sun-icon{font-size:32px}}@media (prefers-color-scheme:dark){.mobile-section-card{background:var(--color-neutral-800)}.mobile-section-card.shade-full{background:linear-gradient(135deg,#263238,#37474f)}.mobile-section-card.shade-most{background:linear-gradient(135deg,#0d47a1,#1565c0)}.mobile-section-card.sun-partial{background:linear-gradient(135deg,#e65100,#f57c00)}.mobile-section-card.sun-most{background:linear-gradient(135deg,#bf360c,#d84315)}.mobile-section-card.sun-full{background:linear-gradient(135deg,#b71c1c,#c62828)}.mobile-section-name{color:var(--color-neutral-100)}.mobile-section-level{color:var(--color-neutral-400)}.mobile-section-sun{background:rgba(0,0,0,.3)}.mobile-section-detail{background:rgba(255,255,255,.05)}.mobile-section-card:hover .mobile-section-detail{background:rgba(255,255,255,.08)}.mobile-section-detail-value,.mobile-section-sun-percent{color:var(--color-neutral-100)}.mobile-section-sun-bar{background:var(--color-neutral-700)}}:root{--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--touch-target:44px;--touch-target-sm:36px;--mobile-header-height:56px;--mobile-nav-height:48px;--mobile-max-width:100%;--color-primary:#2196f3;--color-primary-dark:#1976d2;--color-primary-light:#64b5f6;--color-surface:#ffffff;--color-background:#f5f9fc;--color-text:#212121;--color-text-secondary:#616161;--color-border:#e0e0e0;--color-success:#4caf50;--color-warning:#ff9800;--color-error:#f44336;--shadow-sm:0 1px 3px rgba(0,0,0,0.12);--shadow-md:0 2px 6px rgba(0,0,0,0.15);--shadow-lg:0 4px 12px rgba(0,0,0,0.18);--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-full:9999px;--z-dropdown:100;--z-header:200;--z-modal:300;--z-toast:400}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;font-size:var(--text-base);line-height:1.5;color:var(--color-text);background-color:var(--color-background);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.mobile-container{width:100%;padding-left:var(--space-md);padding-right:var(--space-md);margin-left:auto;margin-right:auto}.mobile-hidden{display:none!important}.mobile-only{display:block!important}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:var(--touch-target);min-width:var(--touch-target);padding:var(--space-sm) var(--space-md);font-size:var(--text-base);font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;touch-action:manipulation}.btn:active{transform:scale(.95)}.btn-primary{background-color:var(--color-primary);color:white}.btn-secondary{background-color:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-md);margin-bottom:var(--space-md);box-shadow:var(--shadow-sm);width:100%}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:var(--space-sm);line-height:1.2}h1{font-size:var(--text-2xl)}h2{font-size:var(--text-xl)}h3{font-size:var(--text-lg)}p{margin-top:0;margin-bottom:var(--space-md)}@media (min-width:768px){:root{--space-md:1.25rem;--space-lg:2rem;--space-xl:2.5rem;--text-base:1rem;--text-lg:1.25rem;--text-xl:1.5rem;--text-2xl:2rem}.mobile-container{max-width:768px;padding-left:var(--space-lg);padding-right:var(--space-lg)}.mobile-only,.tablet-hidden{display:none!important}.tablet-only{display:block!important}}@media (min-width:1024px){:root{--space-lg:2.5rem;--space-xl:3rem;--text-2xl:2.5rem}.mobile-container{max-width:1200px;padding-left:var(--space-xl);padding-right:var(--space-xl)}.desktop-hidden,.tablet-only{display:none!important}.desktop-only{display:block!important}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s infinite}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.transition-all{transition:all .3s ease}.transition-transform{transition:transform .3s ease}.transition-opacity{transition:opacity .3s ease}.mobile-app{min-height:100vh;background:linear-gradient(180deg,#ffffff,#f5f9fc);display:flex;flex-direction:column;font-family:var(--font-body);position:relative;overflow-x:hidden}.mobile-app:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 20% 50%,rgba(26,95,63,.02) 0,transparent 50%),radial-gradient(circle at 80% 80%,rgba(200,16,46,.01) 0,transparent 50%),radial-gradient(circle at 40% 20%,rgba(0,45,114,.01) 0,transparent 50%);pointer-events:none;animation:float 20s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}33%{transform:translateY(-20px) rotate(1deg)}66%{transform:translateY(20px) rotate(-1deg)}}.mobile-main{flex:1 1;padding:var(--space-3);padding-top:calc(64px + var(--space-3));padding-bottom:calc(var(--space-16) + env(safe-area-inset-bottom));position:relative;z-index:1}.mobile-content{max-width:640px;margin:0 auto;width:100%}.mobile-section{margin-bottom:var(--space-5);animation:fadeInUp .6s var(--ease-out) backwards}.mobile-section:first-child{animation-delay:.1s}.mobile-section:nth-child(2){animation-delay:.2s}.mobile-section:nth-child(3){animation-delay:.3s}.mobile-section:nth-child(4){animation-delay:.4s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.mobile-section-title{font-weight:var(--font-weight-semibold);margin-bottom:var(--space-3);letter-spacing:-.025em;text-transform:uppercase;font-size:.75rem;color:var(--color-neutral-600)}.mobile-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);text-align:center;gap:var(--space-4)}.mobile-spinner{width:48px;height:48px;position:relative}.mobile-spinner:before{content:"";position:absolute;inset:0;border:3px solid var(--color-neutral-200);border-radius:50%}.mobile-spinner:after{content:"";position:absolute;inset:0;border:3px solid transparent;border-top:3px solid var(--color-field-green);border-radius:50%;animation:spin 1s cubic-bezier(.68,-.55,.265,1.55) infinite}@keyframes spin{to{transform:rotate(1turn)}}.mobile-loading p{color:var(--color-neutral-600);font-size:var(--font-size-base);font-weight:var(--font-weight-medium)}.mobile-filter-section{position:-webkit-sticky;position:sticky;top:64px;z-index:var(--z-sticky);background:rgba(248,250,252,.9);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:var(--space-3) 0;margin:calc(var(--space-2) * -1) calc(var(--space-4) * -1) var(--space-4);padding-left:var(--space-4);padding-right:var(--space-4);border-bottom:1px solid rgba(226,232,240,.8);transition:all var(--transition-base)}.mobile-filter-section.scrolled{box-shadow:var(--shadow-md)}.mobile-section-list{display:flex;flex-direction:column;gap:var(--space-4)}.mobile-section-list>*{animation:slideInScale .4s var(--ease-out) backwards}@keyframes slideInScale{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.mobile-section-list>:first-child{animation-delay:.05s}.mobile-section-list>:nth-child(2){animation-delay:.1s}.mobile-section-list>:nth-child(3){animation-delay:.15s}.mobile-section-list>:nth-child(4){animation-delay:.2s}.mobile-section-list>:nth-child(5){animation-delay:.25s}.mobile-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-6);text-align:center;animation:fadeIn .5s var(--ease-out)}.mobile-empty-state svg{color:var(--color-neutral-300);margin-bottom:var(--space-4);animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.mobile-empty-state p{font-size:var(--font-size-lg);color:var(--color-neutral-600);margin-bottom:var(--space-6);font-weight:var(--font-weight-medium)}.mobile-reset-btn{padding:var(--space-3) var(--space-6);background:var(--gradient-field);color:white;border:none;border-radius:var(--radius-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-md);position:relative;overflow:hidden}.mobile-reset-btn:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.2) 50%,transparent 70%);transform:translateX(-100%);transition:transform var(--transition-slow)}.mobile-reset-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.mobile-reset-btn:hover:before{transform:translateX(100%)}.mobile-stadium-guide-link{padding:20px;background:#ffffff;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,.08);text-align:left;border:1px solid #f0f0f0;transition:all .2s ease}.mobile-stadium-guide-link:hover{box-shadow:0 4px 12px rgba(0,0,0,.08)}.mobile-guide-button{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0;background:none;color:var(--color-gray-900);text-decoration:none;font-size:16px;font-weight:600;transition:all .2s ease;margin-bottom:8px}.mobile-guide-button:active,.mobile-guide-button:hover{color:var(--color-primary);text-decoration:none}.guide-title{margin-bottom:4px}.guide-arrow{width:20px;height:20px;flex-shrink:0;opacity:.4;transition:all .2s ease}.mobile-guide-button:hover .guide-arrow{opacity:.8;transform:translateX(4px)}.mobile-guide-description{font-size:14px;color:#666666;margin:0;line-height:1.5;font-weight:400}.mobile-reset-btn:active{transform:translateY(0);box-shadow:var(--shadow-md)}@media (min-width:768px){.mobile-main{padding:var(--space-6);padding-top:calc(64px + var(--space-6))}.mobile-section{margin-bottom:var(--space-10)}.mobile-section-title{font-size:var(--font-size-3xl)}}@supports (padding:max(0px)){.mobile-app{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.mobile-main{padding-bottom:max(var(--space-20),env(safe-area-inset-bottom))}}@media (prefers-color-scheme:dark){.mobile-app{background:linear-gradient(180deg,#0f172a,#1e293b)}.mobile-app:before{background-image:radial-gradient(circle at 20% 50%,rgba(26,95,63,.1) 0,transparent 50%),radial-gradient(circle at 80% 80%,rgba(200,16,46,.05) 0,transparent 50%),radial-gradient(circle at 40% 20%,rgba(56,189,248,.05) 0,transparent 50%)}.mobile-section-title{color:var(--color-neutral-100)}.mobile-filter-section{background:rgba(15,23,42,.9);border-bottom-color:rgba(30,41,59,.8)}.mobile-empty-state p,.mobile-loading p{color:var(--color-neutral-400)}.mobile-empty-state svg{color:var(--color-neutral-600)}}.mobile-footer{background:#ffffff;border-top:1px solid #e0e0e0;padding:24px 16px;margin-top:40px}.mobile-footer-content{max-width:600px;margin:0 auto;text-align:center}.mobile-footer-links{display:flex;justify-content:center;align-items:center;gap:12px;margin-bottom:12px}.mobile-footer-link{color:#1a73e8;text-decoration:none;font-size:.875rem;font-weight:500;padding:4px 8px;border-radius:4px;transition:background-color .2s ease}.mobile-footer-link:active,.mobile-footer-link:hover{background-color:rgba(26,115,232,.08);text-decoration:underline}.mobile-footer-separator{color:#9e9e9e;font-size:.875rem}.mobile-footer-copyright{color:#616161;font-size:.75rem;margin:0}@media (prefers-color-scheme:dark){.mobile-footer{background:rgba(0,0,0,.95);border-top-color:rgba(30,41,59,.8)}.mobile-footer-link{color:#4285f4}.mobile-footer-separator{color:#616161}.mobile-footer-copyright{color:#9e9e9e}}.offline-indicator{position:fixed;top:0;left:0;right:0;z-index:9999;background:#f44336;color:white;padding:8px 16px;text-align:center;font-size:14px;font-weight:500;box-shadow:0 2px 4px rgba(0,0,0,.2);transform:translateY(-100%);animation:slideDown .3s ease-out forwards}.offline-indicator.online{background:#4caf50}.offline-indicator.syncing{background:#ff9800}.offline-indicator-content{display:flex;align-items:center;justify-content:center;gap:8px;max-width:1200px;margin:0 auto}.offline-icon,.online-icon,.sync-icon{font-size:18px;animation:pulse 2s ease-in-out infinite}.sync-icon{animation:rotate 1s linear infinite}.cache-info{font-size:12px;opacity:.9;margin-left:8px}@keyframes slideDown{to{transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.offline-indicator{font-size:13px;padding:6px 12px}.offline-icon,.online-icon,.sync-icon{font-size:16px}.cache-info{display:none}}.weather-pattern-chart{background:#f8f9fa;border-radius:12px;padding:2rem;margin-top:2rem}.weather-pattern-chart h3{font-size:1.5rem;color:#1a237e;margin-bottom:.5rem}.chart-subtitle{color:#6c757d;margin-bottom:2rem}.chart-container{display:grid;grid-gap:2rem;gap:2rem}.temperature-chart h4,.weather-stats h4,.weather-tips h4{font-size:1.125rem;color:#495057;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.bar-chart{display:flex;gap:1rem;align-items:flex-end;height:180px;padding:1rem 0;overflow-x:auto}.bar-group{display:flex;flex-direction:column;align-items:center;gap:.5rem;min-width:60px}.bar-wrapper{height:150px;display:flex;align-items:flex-end}.temp-bar{width:40px;border-radius:4px 4px 0 0;position:relative;transition:all .3s ease}.temp-bar:hover{transform:translateY(-4px)}.bar-value{position:absolute;top:-25px;left:50%;transform:translateX(-50%);font-weight:600;font-size:.875rem;color:#1a237e}.bar-label{font-size:.875rem;color:#6c757d;font-weight:500}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));grid-gap:1rem;gap:1rem}.month-stats{background:white;border-radius:8px;padding:1rem;border:1px solid #e0e0e0}.month-stats h5{font-size:1rem;color:#1a237e;margin-bottom:.75rem;font-weight:600}.stat-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.875rem}.stat-label{color:#6c757d;flex:1 1}.stat-value{font-weight:600;color:#495057}.weather-tips{background:#e3f2fd;border-radius:8px;padding:1.5rem}.weather-tips ul{list-style:none;padding:0;margin:0}.weather-tips li{padding:.5rem 0;color:#495057;line-height:1.6}.weather-tips strong{color:#1a237e}@media (max-width:768px){.bar-chart{justify-content:flex-start}.stats-grid{grid-template-columns:1fr 1fr}}.stadium-guide{max-width:1200px;margin:0 auto;padding:2rem 1rem;background:#f8f9fa;min-height:100vh}.breadcrumb{display:flex;align-items:center;gap:.5rem;margin-bottom:2rem;font-size:.875rem;color:#6c757d}.breadcrumb a{color:#2196f3;text-decoration:none}.breadcrumb a:hover{text-decoration:underline}.stadium-header{background:white;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px rgba(0,0,0,.05)}.stadium-header h1{font-size:2.5rem;font-weight:700;color:#1a237e;margin-bottom:.5rem}.stadium-subtitle{font-size:1.25rem;color:#495057;margin-bottom:1rem}.stadium-meta{display:flex;flex-wrap:wrap;gap:1.5rem;font-size:1rem;color:#495057}.stadium-meta span{display:flex;align-items:center;gap:.5rem}.team{font-weight:600;color:#1a237e}.quick-facts{background:white;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px rgba(0,0,0,.05)}.quick-facts h2{font-size:1.75rem;color:#1a237e;margin-bottom:1.5rem}.facts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:1.5rem;gap:1.5rem}.fact-card{background:#f8f9fa;padding:1.5rem;border-radius:8px;text-align:center}.fact-card h3{font-size:.875rem;color:#6c757d;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.fact-card p{font-size:1.5rem;font-weight:600;color:#1a237e;margin:0}.shade-simulator{background:white;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px rgba(0,0,0,.05)}.shade-simulator h2{font-size:1.75rem;color:#1a237e;margin-bottom:.5rem}.shade-simulator>p{color:#6c757d;margin-bottom:1.5rem}.simulator-controls{display:flex;gap:2rem;margin-bottom:2rem;flex-wrap:wrap}.control-group{display:flex;flex-direction:column;gap:.5rem}.control-group label{font-weight:600;color:#495057}.control-group select{padding:.5rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;background:white;cursor:pointer;transition:border-color .2s}.control-group select:hover{border-color:#2196f3}.control-group select:focus{outline:none;border-color:#1976d2}.weather-preview{background:#e3f2fd;border:2px solid #2196f3;border-radius:8px;padding:1.5rem}.weather-preview h3{font-size:1.25rem;color:#1a237e;margin-bottom:1rem}.weather-stats{display:flex;gap:2rem;flex-wrap:wrap}.weather-stats span{display:flex;align-items:center;gap:.5rem;font-weight:500;color:#495057}.best-sections{background:white;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px rgba(0,0,0,.05)}.best-sections h2{font-size:1.75rem;color:#1a237e;margin-bottom:.5rem}.best-sections>p{color:#6c757d;margin-bottom:1.5rem}.sections-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));grid-gap:1rem;gap:1rem}.section-card{background:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;padding:1.5rem;transition:all .2s}.section-card:hover{border-color:#2196f3;transform:translateY(-2px);box-shadow:0 4px 12px rgba(33,150,243,.15)}.section-card h3{font-size:1.25rem;color:#1a237e;margin-bottom:.75rem}.section-details{display:flex;flex-wrap:wrap;gap:.5rem}.section-details span{padding:.25rem .75rem;background:white;border-radius:4px;font-size:.875rem;color:#495057}.section-details .covered{background:#4caf50;color:white}.section-details .price{background:#1a237e;color:white}.sun-safety{background:#fff9c4;border:2px solid #fbc02d;border-radius:12px;padding:2rem;margin-bottom:2rem}.sun-safety h2{font-size:1.75rem;color:#1a237e;margin-bottom:1.5rem}.safety-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:1.5rem;gap:1.5rem}.safety-card{background:white;border-radius:8px;padding:1.5rem}.safety-card h3{font-size:1.25rem;color:#f57f17;margin-bottom:1rem}.safety-card ul{margin:0;padding-left:1.5rem}.safety-card li{margin-bottom:.5rem;color:#495057}.family-friendly{background:white;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px rgba(0,0,0,.05)}.family-friendly h2{font-size:1.75rem;color:#1a237e;margin-bottom:1.5rem}.amenities-list{margin-bottom:2rem}.amenities-list h3{font-size:1.25rem;color:#495057;margin-bottom:1rem}.amenities-list ul{list-style:none;padding:0}.amenities-list li{padding:.75rem;background:#f8f9fa;border-radius:4px;margin-bottom:.5rem}.accessibility-info{background:#e3f2fd;border-radius:8px;padding:1.5rem}.accessibility-info h3{font-size:1.25rem;color:#1a237e;margin-bottom:.75rem}.stadium-history{background:white;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px rgba(0,0,0,.05)}.stadium-history h2{font-size:1.75rem;color:#1a237e;margin-bottom:1.5rem}.history-content{color:#495057}.opened-date{font-size:1.25rem;font-weight:600;color:#1a237e;margin-bottom:1.5rem}.fun-facts,.previous-names,.renovations,.shade-evolution{margin-bottom:2rem}.stadium-history h3{font-size:1.125rem;color:#495057;margin-bottom:1rem;font-weight:600}.fun-facts ul,.previous-names ul{list-style:none;padding:0}.fun-facts li,.previous-names li{padding:.5rem 0 .5rem 1.5rem;position:relative}.fun-facts li:before,.previous-names li:before{content:"•";position:absolute;left:0;color:#2196f3;font-weight:700}.timeline{display:flex;flex-direction:column;gap:1rem}.timeline-item{display:flex;gap:1rem;padding:1rem;background:#f8f9fa;border-radius:8px;border-left:3px solid #2196f3}.timeline-item .year{font-weight:600;color:#1a237e;min-width:60px}.timeline-item .description,.timeline-item .feature{color:#495057;line-height:1.5}.pro-tips{background:white;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px rgba(0,0,0,.05)}.pro-tips h2{font-size:1.75rem;color:#1a237e;margin-bottom:1.5rem}.tips-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:1.5rem;gap:1.5rem}.tip{background:#f8f9fa;padding:1.5rem;border-radius:8px;border-left:4px solid #2196f3}.tip h3{font-size:1.125rem;color:#1a237e;margin-bottom:.5rem}.tip p{color:#495057;margin:0}.seo-content{background:white;border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px rgba(0,0,0,.05)}.seo-content h2{font-size:1.875rem;color:#1a237e;margin-bottom:1.5rem}.seo-content h3{font-size:1.5rem;color:#1a237e;margin-top:2rem;margin-bottom:1rem}.seo-content p{line-height:1.8;color:#495057;margin-bottom:1rem}.seo-content ul{list-style:none;padding:0;margin:1rem 0}.seo-content ul li{padding:.75rem 0 .75rem 1.5rem;position:relative;line-height:1.6;color:#495057}.seo-content ul li:before{content:"✓";position:absolute;left:0;color:#4caf50;font-weight:700}.cta-section{background:#1a237e;color:white;border-radius:12px;padding:3rem;margin-bottom:2rem;text-align:center}.cta-section h2{font-size:2rem;margin-bottom:1rem}.cta-section p{font-size:1.125rem;margin-bottom:2rem;opacity:.9}.cta-button{display:inline-block;padding:1rem 2rem;background:white;color:#1a237e;font-weight:600;font-size:1.125rem;transition:all .2s}.cta-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(255,255,255,.3)}.related-content{background:white;border-radius:12px;padding:2rem;box-shadow:0 2px 8px rgba(0,0,0,.05)}.related-content h2{font-size:1.75rem;color:#1a237e;margin-bottom:1.5rem}.resources-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:1.5rem;gap:1.5rem}.resource-card{display:block;padding:1.5rem;background:#f8f9fa;border-radius:8px;text-decoration:none;transition:all .2s;border:2px solid transparent}.resource-card:hover{border-color:#2196f3;transform:translateY(-2px);box-shadow:0 4px 12px rgba(33,150,243,.15)}.resource-card h3{font-size:1.25rem;color:#1a237e;margin-bottom:.5rem}.resource-card p{color:#6c757d;margin:0}@media (max-width:768px){.stadium-guide{padding:1rem .5rem}.stadium-header h1{font-size:2rem}.stadium-meta{font-size:.875rem;gap:1rem}.facts-grid{grid-template-columns:1fr 1fr}.simulator-controls{flex-direction:column;gap:1rem}.control-group,.control-group select{width:100%}.safety-grid,.sections-grid,.tips-container{grid-template-columns:1fr}.cta-section{padding:2rem 1rem}.resources-grid{grid-template-columns:1fr}}.mobile-stadium-guide{padding-bottom:60px;background-color:#f5f5f5;min-height:100vh}.mobile-stadium-header{background:linear-gradient(135deg,#1976d2,#1565c0);color:white;padding:16px;position:-webkit-sticky;position:sticky;top:0;z-index:100;box-shadow:0 2px 4px rgba(0,0,0,.1)}.back-button{color:white;text-decoration:none;font-size:14px;display:inline-block;margin-bottom:8px;opacity:.9}.mobile-stadium-header h1{font-size:24px;margin:0 0 8px;font-weight:600}.stadium-badges{display:flex;gap:8px;flex-wrap:wrap}.roof-badge,.team-badge{display:inline-block;padding:4px 12px;background:rgba(255,255,255,.2);border-radius:16px;font-size:12px;font-weight:500}.mobile-card{background:white;margin:12px;padding:16px;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.08)}.mobile-card h2{font-size:18px;margin:0 0 12px;color:#333;font-weight:600}.quick-facts-grid{display:flex;flex-direction:column;gap:12px}.fact-item{display:flex;align-items:center;gap:8px;color:#666;font-size:14px}.fact-item.special{color:#1976d2;font-weight:500}.shaded-sections-list{display:flex;flex-direction:column;gap:8px}.shaded-section-item{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.section-header{display:flex;justify-content:space-between;align-items:center;padding:12px;cursor:pointer;background:#fafafa}.section-header h3{margin:0;font-size:16px;font-weight:500}.expand-icon{font-size:20px;color:#666;font-weight:300}.section-details{padding:12px;background:white;border-top:1px solid #e0e0e0}.section-details p{margin:4px 0;font-size:14px;color:#666}.covered-badge{color:#4caf50;font-weight:500}.weather-selector{margin-bottom:16px}.mobile-select{width:100%;padding:10px;border:1px solid #ddd;border-radius:8px;font-size:16px;background:white;cursor:pointer}.weather-info{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:12px;gap:12px}.weather-stat{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;background:#f5f5f5;border-radius:8px}.weather-stat span{font-size:14px;font-weight:500;text-align:center}.tips-list{list-style:none;padding:0;margin:0}.tips-list li{padding:8px 0 8px 24px;position:relative;font-size:14px;color:#666;border-bottom:1px solid #f0f0f0}.tips-list li:last-child{border-bottom:none}.tips-list li:before{content:"•";position:absolute;left:8px;color:#1976d2;font-weight:700}.special-tip{color:#1976d2!important;font-weight:500}.special-tip svg{position:absolute;left:4px;top:10px}.stadium-info{margin-bottom:16px}.info-item{font-size:14px;line-height:1.6;color:#666;margin:0 0 8px}.info-item strong{color:#333}.shade-features h3{font-size:16px;margin:16px 0 8px;color:#333}.shade-features ul{list-style:none;padding:0;margin:0}.shade-features li{padding:6px 0 6px 20px;position:relative;font-size:14px;color:#666}.shade-features li:before{content:"✓";position:absolute;left:0;color:#4caf50;font-weight:700}.fun-facts{margin-top:16px}.fun-facts h3{font-size:16px;margin:16px 0 8px;color:#333}.fun-facts ul{list-style:none;padding:0;margin:0}.fun-facts li{padding:6px 0 6px 20px;position:relative;font-size:14px;color:#666}.fun-facts li:before{content:"•";position:absolute;left:0;color:#1976d2;font-weight:700}.amenities-list{display:flex;flex-direction:column;gap:12px}.amenity-item{padding:12px;background:#f9f9f9;border-radius:8px}.amenity-item h4{margin:0 0 4px;font-size:16px;color:#333}.amenity-item p{margin:0;font-size:14px;color:#666}.mobile-cta-section{padding:24px 16px;text-align:center}.cta-button{display:block;width:100%;max-width:300px;margin:0 auto 12px;padding:16px 24px;background:#1976d2;color:white;text-decoration:none;border-radius:8px;font-size:16px;font-weight:500;box-shadow:0 4px 12px rgba(25,118,210,.3);transition:transform .2s,box-shadow .2s}.cta-button:active{transform:translateY(1px);box-shadow:0 2px 8px rgba(25,118,210,.3)}.cta-text{font-size:14px;color:#666;margin:0}@media (prefers-color-scheme:dark){.mobile-stadium-guide{background-color:#121212}.mobile-card{background:#1e1e1e;box-shadow:0 2px 8px rgba(0,0,0,.3)}.amenity-item h4,.mobile-card h2,.section-header h3,.shade-features h3{color:#e0e0e0}.amenity-item p,.cta-text,.fact-item,.history-text,.section-details p,.shade-features li,.tips-list li{color:#b0b0b0}.section-header{background:#2a2a2a}.shaded-section-item{border-color:#333}.section-details{background:#1e1e1e;border-top-color:#333}.amenity-item,.mobile-select,.weather-stat{background:#2a2a2a}.mobile-select{border-color:#444;color:#e0e0e0}.tips-list li{border-bottom-color:#333}}