*{box-sizing:border-box}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;font-weight:400;color-scheme:dark;color:#ffffffe6;background:linear-gradient(135deg,#0a0a0f,#1a1a2e,#0f0f1a);background-attachment:fixed;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#ffffff0d;border-radius:10px}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#4a90d9,#357abd);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#5a9fe9,#4589c9)}::selection{background:#4a90d966;color:#fff}.stadium-card{background:linear-gradient(145deg,#1a1a2ee6,#16213ecc);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;overflow:hidden;cursor:pointer;transition:all .4s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 8px 32px #0000004d,0 0 0 1px #ffffff0d inset;border:1px solid rgba(255,255,255,.1)}.stadium-card:hover{transform:translateY(-12px) scale(1.02);box-shadow:0 20px 60px #4a90d940,0 0 0 1px #4a90d94d inset;border-color:#4a90d980}.stadium-card-image{position:relative;height:200px;overflow:hidden}.stadium-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.25,.46,.45,.94);filter:brightness(.9)}.stadium-card:hover .stadium-card-image img{transform:scale(1.15) rotate(1deg);filter:brightness(1)}.stadium-card-sport{position:absolute;top:12px;right:12px;background:linear-gradient(135deg,#fffffffa,#ffffffe6);color:#1a1a2e;padding:8px 16px;border-radius:25px;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 4px 15px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.stadium-card-content{padding:22px}.stadium-card-name{color:#fff;font-size:1.35rem;margin:0 0 10px;font-weight:700;letter-spacing:-.3px;line-height:1.3}.stadium-card-location{color:#a0a0a0;font-size:.9rem;margin:0 0 18px;display:flex;align-items:center;gap:6px}.stadium-card-stats{display:flex;gap:20px;margin-bottom:16px}.stat{display:flex;flex-direction:column;gap:4px}.stat-label{color:gray;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}.stat-value{color:#fff;font-size:1.1rem;font-weight:600}.stadium-card-weather{background:#ffffff0d;border-radius:12px;padding:14px;margin-top:12px}.stadium-card-weather.loading,.stadium-card-weather.error{background:#ffc1071a}.stadium-card-weather.error{background:#f443361a}.weather-info{display:flex;align-items:center;gap:10px;margin-bottom:8px}.weather-icon{font-size:1.8rem}.weather-temp{color:#fff;font-size:1.3rem;font-weight:700}.weather-condition{color:#a0a0a0;font-size:.9rem}.weather-details{display:flex;gap:16px;color:gray;font-size:.85rem}.modal-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}.modal-content{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:20px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease}.modal-close{position:absolute;top:16px;right:16px;background:#fff3;border:none;color:#fff;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:background .2s ease;z-index:10}.modal-close:hover{background:#ffffff4d}.modal-image-container{position:relative;height:300px;overflow:hidden}.modal-image-container img{width:100%;height:100%;object-fit:cover}.modal-image-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);padding:60px 24px 24px}.edit-image-btn{position:absolute;top:16px;right:16px;background:#000c;border:2px solid rgba(255,255,255,.3);color:#fff;padding:8px 14px;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;gap:6px;z-index:20}.edit-image-btn:hover{background:#4a90d9e6;border-color:#4a90d9;transform:translateY(-2px);box-shadow:0 4px 15px #4a90d966}.modal-sport-badge{background:#fffffff2;color:#1a1a2e;padding:8px 20px;border-radius:24px;font-size:.9rem;font-weight:600;display:inline-block}.modal-body{padding:24px}.modal-title{color:#fff;font-size:2rem;margin:0 0 8px;font-weight:700}.modal-location{color:#a0a0a0;font-size:1.1rem;margin:0 0 24px}.modal-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px}.modal-stat-card{background:#ffffff0d;border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px}.modal-stat-icon{font-size:2rem}.modal-stat-label{color:gray;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.modal-stat-value{color:#fff;font-size:1.2rem;font-weight:600}.modal-section-title{color:#fff;font-size:1.2rem;margin:0 0 16px;font-weight:600}.modal-description-content{display:flex;flex-direction:column;gap:20px}.modal-description{color:silver;font-size:1rem;line-height:1.8;margin:0;padding:16px;background:#ffffff08;border-radius:12px;border-left:4px solid #4a90d9}.stadium-details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.detail-item{display:flex;align-items:flex-start;gap:12px;padding:14px;background:#ffffff0d;border-radius:10px;transition:background .2s ease}.detail-item:hover{background:#ffffff14}.detail-icon{font-size:1.8rem;flex-shrink:0}.detail-label{display:block;color:gray;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-weight:600}.detail-value{display:block;color:#fff;font-size:.95rem;font-weight:500;line-height:1.4}.modal-weather-section{background:#ffffff0d;border-radius:16px;padding:20px;margin-bottom:24px}.modal-weather-content{display:flex;justify-content:space-between;align-items:center}.modal-weather-main{display:flex;align-items:center;gap:16px}.modal-weather-icon{font-size:3rem}.modal-weather-temp{color:#fff;font-size:2rem;font-weight:700}.modal-weather-condition{color:#a0a0a0;font-size:1rem}.modal-weather-extra{display:flex;flex-direction:column;gap:12px}.modal-weather-detail{display:flex;justify-content:space-between;gap:20px;color:#a0a0a0;font-size:.9rem}.modal-weather-detail span:last-child{color:#fff;font-weight:600}.modal-description-section{margin-bottom:24px}.modal-description{color:silver;font-size:1rem;line-height:1.7;margin:0}.modal-coordinates{color:gray;font-size:.9rem;padding-top:16px;border-top:1px solid rgba(255,255,255,.1)}.modal-coord-value{color:#a0a0a0;font-family:monospace}.modal-events-section{margin-top:24px}.events-loading{background:#ffffff0d;border-radius:16px;padding:24px;text-align:center}.events-loading p{color:#a0a0a0;margin:0;font-size:.95rem}.modal-api-note{margin-top:20px;padding:12px 16px;background:#4a90d91a;border-radius:10px;border:1px solid rgba(74,144,217,.3)}.modal-api-note p{color:#80a0d0;margin:0;font-size:.85rem}.modal-api-note a{color:#4a90d9;text-decoration:none;font-weight:600}.modal-api-note a:hover{text-decoration:underline}.modal-fun-fact-section{background:linear-gradient(135deg,#ffc1071a,#ff98000d);border-radius:16px;padding:20px;margin-top:24px;border:1px solid rgba(255,193,7,.2)}.modal-fun-fact-section .modal-section-title{color:#ffc107;margin-bottom:12px;display:flex;align-items:center;gap:8px}.modal-fun-fact{color:#e0e0e0;font-size:.95rem;line-height:1.7;margin:0;padding-left:12px;border-left:3px solid #ffc107}@media(max-width:600px){.modal-stats-grid,.stadium-details-grid{grid-template-columns:1fr}.modal-weather-content{flex-direction:column;gap:20px}.modal-title{font-size:1.5rem}.modal-image-container{height:200px}.modal-description{padding:12px;font-size:.95rem}.detail-item{padding:12px}.detail-icon{font-size:1.5rem}}.events-list{margin-top:24px}.events-title{color:#fff;font-size:1.2rem;margin:0 0 16px;font-weight:600}.events-container{display:flex;flex-direction:column;gap:12px}.event-card{background:#ffffff0d;border-radius:12px;padding:16px;display:flex;gap:16px;transition:background .2s ease;border-left:4px solid transparent}.event-card:hover{background:#ffffff14}.event-card.past{opacity:.6}.event-date-badge{display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#4a90d9,#357abd);border-radius:12px;padding:10px 14px;min-width:60px;height:fit-content}.event-month{color:#ffffffe6;font-size:.75rem;font-weight:600;text-transform:uppercase}.event-day{color:#fff;font-size:1.5rem;font-weight:700;line-height:1}.event-details{flex:1;display:flex;flex-direction:column;gap:8px}.event-header{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.event-name{color:#fff;font-size:1.05rem;margin:0;font-weight:600}.event-type{color:#fff;font-size:.75rem;padding:4px 10px;border-radius:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.event-teams{color:silver;font-size:.95rem;margin:0}.event-meta{display:flex;gap:16px;color:gray;font-size:.85rem}.event-time,.event-date-full{display:flex;align-items:center;gap:4px}.event-description{color:#a0a0a0;font-size:.85rem;margin:0;line-height:1.5}.events-empty{background:#ffffff08;border-radius:12px;padding:24px;text-align:center}.events-empty p{color:gray;margin:0;font-size:.95rem}@media(max-width:600px){.event-card{flex-direction:column}.event-date-badge{flex-direction:row;gap:6px;min-width:auto;align-self:flex-start}.event-month{font-size:.7rem}.event-day{font-size:1.2rem}.event-header{flex-direction:column;align-items:flex-start}}.stadium-map-container{margin-top:20px;background:#ffffff0d;border-radius:12px;padding:16px;border:1px solid rgba(255,255,255,.1)}.map-header{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.map-header h3{color:#fff;font-size:1rem;margin:0;font-weight:600;display:flex;align-items:center;gap:6px}.map-location-text{color:#a0a0a0;font-size:.85rem}.map-wrapper{position:relative;border-radius:10px;overflow:hidden;background:#0000004d}.map-frame{position:relative;width:100%;height:280px;border-radius:10px;overflow:hidden;cursor:pointer}.map-frame.interacting{pointer-events:all}.map-loading{position:absolute;inset:0;background:#1a1a2ee6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;z-index:10;transition:opacity .3s ease}.map-loading .loading-spinner{font-size:2.5rem;animation:bounce 1s ease infinite}.map-loading p{color:#a0a0a0;font-size:.9rem;margin:0}.map-overlay-hint{position:absolute;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:5;pointer-events:none;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.map-overlay-hint span{color:#fff;font-size:.95rem;font-weight:600;background:#4a90d9e6;padding:10px 20px;border-radius:25px;display:flex;align-items:center;gap:8px;box-shadow:0 4px 15px #0000004d}.map-iframe{width:100%;height:100%;opacity:0;transition:opacity .5s ease;pointer-events:none}.map-frame.interacting .map-iframe{pointer-events:all}.map-iframe.loaded{opacity:1}.map-controls{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}.map-link-btn{flex:1;min-width:140px;color:#fff;text-decoration:none;padding:10px 16px;border-radius:8px;font-size:.85rem;font-weight:600;text-align:center;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:6px;border:2px solid transparent}.map-link-btn.primary{background:linear-gradient(135deg,#4a90d9,#357abd)}.map-link-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4a90d966}.map-link-btn.secondary{background:#ffffff1a;border-color:#fff3}.map-link-btn.secondary:hover{background:#fff3;border-color:#fff6;transform:translateY(-2px)}.map-coordinates{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1);font-size:.8rem}.coord-label{color:gray}.coord-value{color:#a0a0a0;font-family:monospace}@media(max-width:600px){.map-frame{height:220px}.map-controls{flex-direction:column}.map-link-btn{width:100%}}.stadium-gallery-container{margin-top:20px;background:#ffffff0d;border-radius:16px;padding:20px;border:1px solid rgba(255,255,255,.1)}.gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.gallery-header h3{color:#fff;font-size:1.1rem;margin:0;font-weight:600;display:flex;align-items:center;gap:8px}.gallery-actions{display:flex;gap:10px;flex-wrap:wrap}.view-360-btn,.add-image-btn{background:linear-gradient(135deg,#4a90d9,#357abd);color:#fff;border:none;padding:8px 16px;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.view-360-btn{background:linear-gradient(135deg,#9b59b6,#8e44ad)}.view-360-btn:hover{box-shadow:0 4px 15px #9b59b666;transform:translateY(-2px)}.add-image-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #4a90d966}.add-image-form{background:#0000004d;border-radius:12px;padding:16px;margin-bottom:16px;display:flex;flex-direction:column;gap:12px}.add-image-form input{padding:12px 16px;background:#ffffff14;border:2px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-size:.95rem;font-family:inherit}.add-image-form input:focus{outline:none;border-color:#4a90d9}.add-image-form input::placeholder{color:gray}.form-actions{display:flex;gap:10px;justify-content:flex-end}.form-actions button{padding:8px 16px;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.form-actions button[type=button]{background:#ffffff1a;color:#fff}.form-actions button[type=button]:hover{background:#fff3}.form-actions button[type=submit]{background:linear-gradient(135deg,#4a90d9,#357abd);color:#fff}.form-actions button[type=submit]:hover{transform:translateY(-2px);box-shadow:0 4px 15px #4a90d966}.gallery-main{display:flex;flex-direction:column;gap:16px}.primary-image-container{position:relative;border-radius:12px;overflow:hidden;cursor:pointer;aspect-ratio:16 / 9;transition:transform .3s ease}.primary-image-container:hover{transform:scale(1.02)}.primary-image-container img{width:100%;height:100%;object-fit:cover}.primary-badge{position:absolute;bottom:12px;left:12px;background:linear-gradient(135deg,#4a90d9,#357abd);color:#fff;padding:6px 14px;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 4px 15px #0000004d}.gallery-thumbnails{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.thumbnail{border-radius:10px;overflow:hidden;cursor:pointer;aspect-ratio:16 / 9;transition:transform .2s ease,box-shadow .2s ease;border:2px solid rgba(255,255,255,.1)}.thumbnail:hover{transform:scale(1.05);box-shadow:0 4px 15px #4a90d94d;border-color:#4a90d980}.thumbnail img{width:100%;height:100%;object-fit:cover}.lightbox{position:fixed;inset:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease}.lightbox-close{position:absolute;top:20px;right:20px;background:#fff3;border:none;color:#fff;width:44px;height:44px;border-radius:50%;cursor:pointer;font-size:1.5rem;display:flex;align-items:center;justify-content:center;transition:background .2s ease;z-index:10}.lightbox-close:hover{background:#ffffff4d}.lightbox img{max-width:90%;max-height:90%;object-fit:contain;border-radius:8px}.lightbox-nav{position:absolute;bottom:30px;left:0;right:0;display:flex;justify-content:space-between;padding:0 30px}.lightbox-prev,.lightbox-next{background:#fff3;border:none;color:#fff;width:50px;height:50px;border-radius:50%;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:background .2s ease,transform .2s ease}.lightbox-prev:hover,.lightbox-next:hover{background:#ffffff4d;transform:scale(1.1)}@media(max-width:600px){.gallery-header{flex-direction:column;align-items:flex-start}.gallery-actions{width:100%}.view-360-btn,.add-image-btn{flex:1;justify-content:center}.gallery-thumbnails{grid-template-columns:repeat(3,1fr)}.lightbox-nav{padding:0 10px;bottom:20px}.lightbox-prev,.lightbox-next{width:44px;height:44px}}.view-360-modal-overlay{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.view-360-modal{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:20px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease;padding:30px}.modal-close-btn{position:absolute;top:16px;right:16px;background:#fff3;border:none;color:#fff;width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:background .2s ease;z-index:10}.modal-close-btn:hover{background:#ffffff4d}.view-360-header{text-align:center;margin-bottom:24px}.view-360-header h2{color:#fff;font-size:1.6rem;margin:0 0 8px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:10px}.view-360-header p{color:#a0a0a0;font-size:1rem;margin:0}.view-type-selector{display:flex;gap:12px;justify-content:center;margin-bottom:20px}.view-type-btn{background:#ffffff14;border:2px solid rgba(255,255,255,.1);color:#fff;padding:12px 24px;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.view-type-btn:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-2px)}.view-type-btn.active{background:linear-gradient(135deg,#4a90d9,#357abd);border-color:#4a90d9;box-shadow:0 4px 15px #4a90d94d}.view-selector{display:flex;gap:10px;justify-content:center;margin-bottom:20px;flex-wrap:wrap}.view-option-btn{background:#ffffff14;border:2px solid rgba(255,255,255,.1);color:#fff;padding:10px 18px;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.view-option-btn:hover{background:#ffffff26;border-color:#ffffff4d}.view-option-btn.active{background:linear-gradient(135deg,#9b59b6,#8e44ad);border-color:#9b59b6;box-shadow:0 4px 15px #9b59b666}.no-360-view{text-align:center;padding:60px 20px;background:#ffffff08;border-radius:16px;margin-bottom:20px}.no-view-icon{font-size:5rem;margin-bottom:20px}.no-360-view h3{color:#fff;font-size:1.4rem;margin:0 0 12px}.no-360-view p{color:#a0a0a0;font-size:.95rem;margin:0 0 24px;line-height:1.6}.alternative-links{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.view-360-container{border-radius:16px;overflow:hidden;border:2px solid rgba(255,255,255,.1);margin-bottom:20px}.view-360-frame{display:block}.view-360-controls{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:24px}.open-full-btn{background:linear-gradient(135deg,#4a90d9,#357abd);color:#fff;text-decoration:none;padding:12px 24px;border-radius:10px;font-size:.9rem;font-weight:600;transition:all .2s ease;display:flex;align-items:center;gap:8px;border:none;cursor:pointer}.open-full-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4a90d966}.open-full-btn.secondary{background:#ffffff1a;border:2px solid rgba(255,255,255,.2)}.open-full-btn.secondary:hover{background:#fff3;border-color:#fff6}.view-360-instructions{background:#ffffff0d;border-radius:12px;padding:20px;border:1px solid rgba(255,255,255,.1)}.view-360-instructions h4{color:#fff;font-size:1rem;margin:0 0 12px;font-weight:600}.view-360-instructions ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.view-360-instructions li{color:#a0a0a0;font-size:.9rem;display:flex;align-items:center;gap:8px}@media(max-width:600px){.view-360-modal{padding:20px}.view-360-header h2{font-size:1.3rem}.view-type-selector{flex-direction:column}.view-type-btn{width:100%;justify-content:center}.view-360-frame{height:300px}.view-360-controls{flex-direction:column}.open-full-btn{width:100%;justify-content:center}.view-360-instructions ul{grid-template-columns:1fr}}.add-stadium-modal{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:20px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease;padding:30px}.add-stadium-header{text-align:center;margin-bottom:30px}.add-stadium-header h2{color:#fff;font-size:1.8rem;margin:0 0 8px;font-weight:700}.add-stadium-header p{color:#a0a0a0;font-size:.95rem;margin:0}.add-stadium-form{display:flex;flex-direction:column;gap:20px}.form-row{display:flex;gap:16px;flex-wrap:wrap}.form-group{flex:1;min-width:150px;display:flex;flex-direction:column;gap:6px}.form-group.full-width{flex-basis:100%}.form-group input,.form-group select,.form-group textarea{padding:12px 16px;background:#ffffff14;border:2px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-size:.95rem;font-family:inherit;transition:border-color .2s ease}.form-group input::placeholder,.form-group textarea::placeholder{color:gray}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#4a90d9}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:#f44336}.form-group select{cursor:pointer}.form-group select option{background:#1a1a2e;color:#fff}.form-group small{color:gray;font-size:.8rem}.form-group textarea{resize:vertical;min-height:100px}.image-preview{margin-top:10px;border-radius:10px;overflow:hidden;max-height:200px}.image-preview img{width:100%;height:100%;object-fit:cover}.gallery-input-group{display:flex;gap:10px;margin-bottom:12px}.gallery-input-group input{flex:1;padding:10px 14px;background:#ffffff14;border:2px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:.9rem}.gallery-input-group input:focus{outline:none;border-color:#4a90d9}.add-gallery-btn{background:linear-gradient(135deg,#4a90d9,#357abd);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.add-gallery-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #4a90d966}.gallery-preview{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;margin-top:12px}.gallery-thumb{position:relative;border-radius:8px;overflow:hidden;aspect-ratio:16 / 9;border:2px solid rgba(255,255,255,.1)}.gallery-thumb img{width:100%;height:100%;object-fit:cover}.gallery-thumb button{position:absolute;top:4px;right:4px;background:#000000b3;border:none;color:#fff;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.gallery-thumb button:hover{background:#f44336e6}.checkbox-label{display:flex;align-items:center;gap:10px;color:#fff;font-size:.95rem;cursor:pointer}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#4a90d9}@media(max-width:600px){.add-stadium-modal{padding:20px}.form-row{flex-direction:column}.form-group{min-width:100%}.form-actions{flex-direction:column-reverse}.btn-cancel,.btn-submit{width:100%}}.edit-stadium-modal{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:20px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease;padding:30px}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.edit-stadium-header{text-align:center;margin-bottom:30px}.edit-stadium-header h2{color:#fff;font-size:1.8rem;margin:0 0 8px;font-weight:700}.edit-stadium-header p{color:#a0a0a0;font-size:.95rem;margin:0}.edit-stadium-form{display:flex;flex-direction:column;gap:24px}.current-image-section,.new-image-preview-section,.preset-images-section{display:flex;flex-direction:column;gap:10px}.current-image-section label,.new-image-preview-section label,.preset-images-section label{color:#fff;font-size:.9rem;font-weight:600}.current-image-preview,.new-image-preview{border-radius:12px;overflow:hidden;background:#ffffff0d;aspect-ratio:2 / 1;display:flex;align-items:center;justify-content:center}.current-image-preview img,.new-image-preview img{width:100%;height:100%;object-fit:cover;transition:opacity .3s ease}.preview-placeholder{color:gray;font-size:.95rem}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{color:#fff;font-size:.9rem;font-weight:600}.form-group input{padding:12px 16px;background:#ffffff14;border:2px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-size:.95rem;font-family:inherit;transition:border-color .2s ease}.form-group input::placeholder{color:gray}.form-group input:focus{outline:none;border-color:#4a90d9}.form-group input.error{border-color:#f44336}.error-text{color:#f44336;font-size:.8rem;font-weight:500}.preset-images-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.preset-image-btn{background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s ease;padding:0;display:flex;flex-direction:column}.preset-image-btn:hover{background:#ffffff1a;border-color:#ffffff4d;transform:translateY(-2px)}.preset-image-btn.selected{border-color:#4a90d9;box-shadow:0 0 20px #4a90d966}.preset-image-btn img{width:100%;aspect-ratio:2 / 1;object-fit:cover}.preset-name{padding:8px;color:#fff;font-size:.8rem;font-weight:600;text-align:center;background:#0000004d}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:10px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1)}.btn-cancel,.btn-submit{padding:12px 24px;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.btn-cancel{background:#ffffff1a;color:#fff}.btn-cancel:hover{background:#fff3}.btn-submit{background:linear-gradient(135deg,#4a90d9,#357abd);color:#fff}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4a90d966}@media(max-width:600px){.edit-stadium-modal{padding:20px}.preset-images-grid{grid-template-columns:repeat(2,1fr)}.form-actions{flex-direction:column-reverse}.btn-cancel,.btn-submit{width:100%}}.stadium-viewer{min-height:100vh;background:linear-gradient(135deg,#0f0f1a,#1a1a2e,#16213e);padding-bottom:40px}.viewer-header{background:linear-gradient(135deg,#1a1a2e,#2d2d44);padding:40px 20px;text-align:center;border-bottom:1px solid rgba(255,255,255,.1);position:relative}.add-stadium-btn{position:absolute;top:20px;right:20px;background:linear-gradient(135deg,#4a90d9,#357abd);color:#fff;border:none;padding:12px 24px;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.add-stadium-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4a90d966}.header-content{max-width:800px;margin:0 auto}.viewer-title{color:#fff;font-size:2.5rem;margin:0 0 12px;font-weight:800;letter-spacing:-1px}.viewer-subtitle{color:#a0a0a0;font-size:1.1rem;margin:0}.viewer-controls{max-width:1200px;margin:0 auto;padding:24px 20px}.search-container{margin-bottom:20px}.search-input{width:100%;padding:16px 24px;background:#ffffff14;border:2px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:1rem;transition:border-color .2s ease,background .2s ease;box-sizing:border-box}.search-input::placeholder{color:gray}.search-input:focus{outline:none;border-color:#4a90d9;background:#ffffff1f}.search-container{position:relative}.clear-search{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:#ffffff1a;border:none;color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.clear-search:hover{background:#fff3}.continent-filters{margin-bottom:20px}.continent-filters .filter-label{display:block;color:#a0a0a0;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.continent-buttons{display:flex;gap:10px;flex-wrap:wrap}.continent-btn{background:#ffffff14;border:2px solid rgba(255,255,255,.1);color:#fff;padding:10px 18px;border-radius:25px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.continent-btn:hover{background:#ffffff26;border-color:#ffffff4d}.continent-btn.active{background:linear-gradient(135deg,#4a90d9,#357abd);border-color:#4a90d9;box-shadow:0 4px 15px #4a90d94d}.count-badge{background:#fff3;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:700}.continent-btn.active .count-badge{background:#ffffff4d}.league-filters{margin-bottom:20px}.league-filters .filter-label{display:block;color:#a0a0a0;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.league-buttons{display:flex;gap:10px;flex-wrap:wrap}.league-btn{background:linear-gradient(135deg,#ffffff14,#ffffff0d);border:2px solid rgba(255,255,255,.1);color:#fff;padding:10px 18px;border-radius:25px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.league-btn:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-2px)}.league-btn.premier-league{background:linear-gradient(135deg,#3d195b,#00ff85);border-color:#00ff85;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.league-btn.premier-league:hover{box-shadow:0 6px 20px #3d195b80,0 0 20px #00ff854d}.league-btn.premier-league.active{background:linear-gradient(135deg,#00ff85,#3d195b);border-color:#fff;box-shadow:0 0 30px #00ff8580}.league-btn.active{background:linear-gradient(135deg,#4a90d9,#357abd);border-color:#4a90d9;box-shadow:0 4px 15px #4a90d94d}.active-filter-tag.league-tag{background:linear-gradient(135deg,#3d195b,#00ff85);border:1px solid #00ff85}.active-filters{max-width:1200px;margin:0 auto 20px;padding:0 20px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}.active-filter-tag{background:linear-gradient(135deg,#4a90d9,#357abd);color:#fff;padding:8px 14px;border-radius:20px;font-size:.9rem;font-weight:600;display:flex;align-items:center;gap:8px}.active-filter-tag button{background:#fff3;border:none;color:#fff;width:20px;height:20px;border-radius:50%;cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.active-filter-tag button:hover{background:#ffffff4d}.clear-all-filters{background:#ffffff1a;border:2px solid rgba(255,255,255,.2);color:#fff;padding:8px 16px;border-radius:20px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.clear-all-filters:hover{background:#fff3;border-color:#fff6}.filters-container{display:flex;gap:20px;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-label{color:#a0a0a0;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.filter-select{padding:12px 20px;background:#ffffff14;border:2px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-size:.95rem;cursor:pointer;transition:border-color .2s ease;min-width:180px}.filter-select:focus{outline:none;border-color:#4a90d9}.filter-select option{background:#1a1a2e;color:#fff}.viewer-content{max-width:1200px;margin:0 auto;padding:0 20px}.stadiums-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:#a0a0a0}.loading-spinner{font-size:4rem;animation:bounce 1s ease infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.empty-state{text-align:center;padding:100px 20px}.empty-state-icon{font-size:5rem;margin-bottom:20px;opacity:.5}.empty-state h3{color:#fff;font-size:1.5rem;margin:0 0 10px}.empty-state p{color:#a0a0a0;font-size:1rem;margin:0 0 24px}.reset-filters-btn{background:linear-gradient(135deg,#4a90d9,#357abd);color:#fff;border:none;padding:12px 28px;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.reset-filters-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4a90d966}.viewer-footer{max-width:1200px;margin:40px auto 0;padding:20px;text-align:center;color:gray;font-size:.9rem;border-top:1px solid rgba(255,255,255,.05)}@media(max-width:768px){.viewer-title{font-size:1.8rem}.viewer-subtitle{font-size:.95rem}.stadiums-grid{grid-template-columns:1fr}.filters-container{flex-direction:column}.filter-select{min-width:100%}.add-stadium-btn{position:static;margin-top:16px;width:100%}.continent-buttons{gap:8px}.continent-btn{padding:8px 14px;font-size:.85rem}.league-buttons{gap:8px}.league-btn{padding:8px 14px;font-size:.85rem}.league-btn.premier-league{flex:1;min-width:100%;justify-content:center}.active-filters{flex-direction:column;align-items:flex-start}.clear-all-filters{width:100%}}#root{width:100%;margin:0;padding:0;text-align:left}
