@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--primary-gradient:linear-gradient(135deg,#4facfe 0%,#00f2fe 100%);--ocean-gradient:linear-gradient(135deg,#4facfe 0%,#00f2fe 100%);--sunset-gradient:linear-gradient(135deg,#74b9ff 0%,#0984e3 100%);--glass-background:#ffffff1a;--glass-border:#fff3;--text-primary:#1a1a1a;--text-secondary:#666;--text-light:#fff;--shadow-soft:0 10px 40px #0000001a;--shadow-hard:0 20px 60px #00000026;--border-radius:24px;--border-radius-small:16px;--animation-smooth:cubic-bezier(.4,0,.2,1);--font-display:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);min-height:100vh;color:var(--text-primary);background:linear-gradient(135deg,#f5f9ff 0%,#e8f4f8 100%);line-height:1.6;overflow-x:hidden}.beach-dashboard{width:100%;min-height:100vh}.hero-section{background:var(--ocean-gradient);justify-content:center;align-items:center;min-height:60vh;padding:4rem 2rem;display:flex;position:relative;overflow:hidden}.hero-section:before{content:"";background:0 0;animation:20s ease-in-out infinite float;position:absolute;inset:0}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.hero-content{z-index:2;flex-direction:column;align-items:center;gap:2rem;width:100%;max-width:1200px;display:flex;position:relative}.hero-columns{align-items:flex-start;gap:1.5rem;width:100%;max-width:1200px;display:flex}.hero-text{text-align:center;color:var(--text-light);flex:50%;max-width:50%}.hero-title{font-family:var(--font-display);text-shadow:0 4px 20px #0000004d;letter-spacing:-.02em;margin-bottom:.5rem;font-size:clamp(2.5rem,6vw,4rem);font-weight:800}.hero-subtitle{opacity:.9;letter-spacing:.5px;margin-bottom:1rem;font-size:clamp(1.1rem,2.5vw,1.4rem);font-weight:300}.hero-update{opacity:.8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:20px;justify-content:center;align-items:center;gap:.5rem;margin-top:1.5rem;padding:.5rem 1rem;font-size:.9rem;display:inline-flex}.hero-update-icon{width:1rem;height:1rem}.hero-additional{flex-direction:column;flex:50%;gap:1rem;max-width:50%;display:flex}.hero-beach-photo{border-radius:var(--border-radius);background:var(--glass-background);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);box-shadow:var(--shadow-soft);transition:all .3s var(--animation-smooth);justify-content:center;align-items:center;min-height:250px;display:flex;position:relative;overflow:hidden}.hero-beach-photo:hover{box-shadow:var(--shadow-hard);transform:translateY(-2px)}.hero-beach-photo img{object-fit:contain;object-position:center;width:100%;height:auto;min-height:250px;max-height:400px;transition:all .3s var(--animation-smooth);border-radius:var(--border-radius-small);background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%);display:block}.hero-beach-photo img[style*=aspect-ratio]{width:auto;max-width:100%}.hero-beach-photo img[src*=vertical],.hero-beach-photo img[src*=portrait]{max-width:70%;height:auto;max-height:450px}.hero-beach-photo img[src*=horizontal],.hero-beach-photo img[src*=landscape]{width:100%;max-height:350px}.hero-beach-photo:hover img{transform:scale(1.05)}.photo-caption{color:#fff;background:linear-gradient(#0000,#000c);align-items:center;gap:.5rem;padding:1rem;font-size:.9rem;font-weight:600;display:flex;position:absolute;bottom:0;left:0;right:0}.photo-icon{opacity:.8;width:1rem;height:1rem}.hero-quick-info{background:var(--glass-background);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);transition:all .3s var(--animation-smooth);padding:1.5rem}.hero-quick-info:hover{box-shadow:var(--shadow-hard);transform:translateY(-2px)}.quick-info-item{border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;padding:.75rem 0;display:flex}.quick-info-item:last-child{border-bottom:none;padding-bottom:0}.quick-info-label{color:#fffc;font-size:.9rem;font-weight:500}.quick-info-value{color:var(--text-light);text-align:right;font-size:.95rem;font-weight:600}.status-open{color:#10b981;text-shadow:0 0 10px #10b9814d}.status-closed{color:#ef4444;text-shadow:0 0 10px #ef44444d}.status-unknown{color:#f59e0b;text-shadow:0 0 10px #f59e0b4d}.hero-stats{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;width:100%;max-width:1000px;display:grid}.hero-stat-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--border-radius);transition:all .3s var(--animation-smooth);background:#ffffff26;border:1px solid #fff3;align-items:center;gap:1rem;padding:1.5rem;display:flex;box-shadow:0 8px 32px #0000001a}.hero-stat-card:hover{background:#fff3;transform:translateY(-5px);box-shadow:0 12px 40px #00000026}.hero-stat-icon{border-radius:var(--border-radius-small);color:#fff;background:#fff3;flex-shrink:0;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;padding:.5rem;display:flex}.hero-stat-icon svg{width:100%;height:100%}.hero-stat-info{color:#fff;flex-direction:column;display:flex}.hero-stat-label{opacity:.8;text-transform:uppercase;letter-spacing:.5px;font-size:.8rem;font-weight:500}.hero-stat-value{font-family:var(--font-display);font-size:1.4rem;font-weight:700;line-height:1.2}.flag-card.flag-white{background:linear-gradient(135deg,#2ed573e6 0%,#00b894e6 100%)}.flag-card.flag-red{background:linear-gradient(135deg,#ef4444e6 0%,#dc2626e6 100%)}.hero-decorations{pointer-events:none;z-index:1;width:100%;height:100%;position:absolute;top:0;left:0}.bubble{background:#ffffff1a;border-radius:50%;animation:6s ease-in-out infinite bubble-float;position:absolute}.bubble1{width:20px;height:20px;animation-delay:0s;top:20%;left:10%}.bubble2{width:15px;height:15px;animation-delay:2s;top:40%;left:80%}.bubble3{width:25px;height:25px;animation-delay:4s;top:60%;left:20%}.bubble4{width:12px;height:12px;animation-delay:1s;top:80%;left:70%}.bubble5{width:18px;height:18px;animation-delay:3s;top:30%;left:50%}@keyframes bubble-float{0%,to{opacity:.4;transform:translateY(0)rotate(0)}50%{opacity:.8;transform:translateY(-20px)rotate(180deg)}}.hero-waves{z-index:1;width:100%;height:120px;line-height:0;position:absolute;bottom:0;left:0;overflow:hidden}.wave{background-repeat:repeat-x;width:200%;height:100%;position:absolute;bottom:0;left:0}.wave1{z-index:1;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'%3E%3Cpath d='M985.66,92.83C906.67,72,823.78,31,743.84,14c-82.26-17.34-168.06-16.33-250.45.39-57.84,11.73-114,31.07-172,41.86A600.21,600.21,0,0,1,0,27.35V120H1200V95.8C1132.19,118.92,1055.71,111.31,985.66,92.83Z' fill='%23ffffff' fill-opacity='0.15'/%3E%3C/svg%3E");animation:15s linear infinite wave}.wave2{z-index:2;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'%3E%3Cpath d='M0,0V46.29c47.79,22.2,103.59,32.17,158,28,70.36-5.37,136.33-33.31,206.8-37.5C438.64,32.43,512.34,53.67,583,72.05c69.27,18,138.3,24.88,209.4,13.08,36.15-6,69.85-17.84,104.45-29.34C989.49,25,1113-14.29,1200,52.47V0Z' fill='%23ffffff' fill-opacity='0.08'/%3E%3C/svg%3E");animation:20s linear infinite reverse wave}.wave3{z-index:3;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'%3E%3Cpath d='M321.39,56.44c58-10.79,114.16-30.13,172-41.86,82.39-16.72,168.19-17.73,250.45-.39C823.78,31,906.67,72,985.66,92.83c70.05,18.48,146.53,26.09,214.34,3V0H0V27.35A600.21,600.21,0,0,0,321.39,56.44Z' fill='%23ffffff' fill-opacity='0.12'/%3E%3C/svg%3E");animation:25s linear infinite wave}.wave4{z-index:4;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'%3E%3Cpath d='M0,0V7.23C0,65.52,268.63,112.77,600,112.77S1200,65.52,1200,7.23V0Z' fill='%23ffffff' fill-opacity='0.2'/%3E%3C/svg%3E");height:140px;animation:18s linear infinite reverse wave}.wave5{z-index:5;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'%3E%3Cpath d='M0,0V46.29c47.79,22.2,103.59,32.17,158,28,70.36-5.37,136.33-33.31,206.8-37.5C438.64,32.43,512.34,53.67,583,72.05c69.27,18,138.3,24.88,209.4,13.08,36.15-6,69.85-17.84,104.45-29.34C989.49,25,1113-14.29,1200,52.47V120H0Z' fill='%23ffffff' fill-opacity='0.25'/%3E%3C/svg%3E");height:160px;animation:30s linear infinite wave}.hero-boat{z-index:20;animation:8s ease-in-out infinite boat-float;position:absolute;bottom:100px;right:8%}.boat-icon{filter:drop-shadow(0 4px 8px #0003);width:60px;height:40px}@keyframes boat-float{0%,to{transform:translateY(0)rotate(0)}25%{transform:translateY(-8px)rotate(2deg)}50%{transform:translateY(-12px)rotate(0)}75%{transform:translateY(-6px)rotate(-2deg)}}@keyframes wave{0%{transform:translate(0)}to{transform:translate(-50%)}}.dashboard-container{z-index:3;max-width:1400px;margin:0 auto;padding:4rem 2rem 2rem;position:relative}.weather-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:3rem;display:grid}.weather-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);transition:all .3s var(--animation-smooth);background:#fffffff2;border:1px solid #fff3;align-items:center;gap:1.5rem;padding:2rem;display:flex;position:relative;overflow:hidden}.weather-card:before{content:"";background:var(--primary-gradient);border-radius:var(--border-radius)var(--border-radius)0 0;height:4px;position:absolute;top:0;left:0;right:0}.weather-card:hover{box-shadow:var(--shadow-hard);transform:translateY(-8px)}.weather-icon{background:var(--primary-gradient);border-radius:var(--border-radius-small);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:3rem;height:3rem;padding:.75rem;display:flex}.weather-icon svg{width:100%;height:100%}.weather-info h3{font-family:var(--font-display);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem;font-size:.9rem;font-weight:600}.weather-value{font-family:var(--font-display);color:var(--text-primary);font-size:2rem;font-weight:800;line-height:1;display:block}.weather-secondary{color:var(--text-secondary);margin-top:.25rem;font-size:.85rem;display:block}.weather-description{color:var(--text-primary);text-transform:capitalize;font-size:1rem;font-weight:500}.temperature-card:before{background:linear-gradient(135deg,#74b9ff 0%,#0984e3 100%)}.water-card:before{background:linear-gradient(135deg,#4facfe 0%,#00f2fe 100%)}.feels-like-card:before{background:linear-gradient(135deg,#a29bfe 0%,#6c5ce7 100%)}.humidity-card:before{background:linear-gradient(135deg,#81ecec 0%,#00cec9 100%)}.wind-card:before{background:linear-gradient(135deg,#b2bec3 0%,#636e72 100%)}.pressure-card:before{background:linear-gradient(135deg,#74b9ff 0%,#0984e3 100%)}.visibility-card:before{background:linear-gradient(135deg,#a29bfe 0%,#6c5ce7 100%)}.description-card:before{background:linear-gradient(135deg,#00cec9 0%,#00b894 100%)}.gallery-section{margin-bottom:3rem}.section-title{font-family:var(--font-display);color:var(--text-primary);align-items:center;gap:1rem;margin-bottom:2rem;font-size:2rem;font-weight:700;display:flex}.section-icon{color:#4facfe;width:2.5rem;height:2.5rem}.photo-gallery-compact{border-radius:var(--border-radius);padding:1rem 0;overflow:visible}.gallery-section{opacity:0;animation:.8s forwards fadeInUp}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.photo-grid{grid-template-columns:repeat(4,1fr);grid-auto-flow:dense;gap:1rem;display:grid}.photo-item{border-radius:var(--border-radius-small);box-shadow:var(--shadow-soft);transition:all .15s var(--animation-smooth);break-inside:avoid;page-break-inside:avoid;position:relative;overflow:hidden}.photo-item.portrait{grid-column:span 1}.photo-item.landscape{grid-column:span 2}.photo-item.square{grid-column:span 1}.photo-item.wide{grid-column:span 3}.photo-item:hover{box-shadow:var(--shadow-hard);z-index:10;transform:translateY(-3px)}.photo-item img{object-fit:cover;width:100%;height:100%;transition:transform .3s var(--animation-smooth);border-radius:var(--border-radius-small);background:#f8f9fa;display:block}.photo-item.portrait{aspect-ratio:9/16;min-height:300px}.photo-item.landscape{aspect-ratio:16/9;min-height:200px}.photo-item.square{aspect-ratio:1;min-height:250px}.photo-item.wide{aspect-ratio:21/9;min-height:150px}.photo-item:not(.portrait):not(.landscape):not(.square):not(.wide){aspect-ratio:4/3;min-height:200px}.photo-item.portrait img,.photo-item.landscape img{object-fit:cover;object-position:center}.photo-overlay{color:#fff;opacity:0;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:linear-gradient(#0000,#000000d9);padding:.75rem 1rem;transition:opacity .3s;position:absolute;bottom:0;left:0;right:0}.photo-item:hover .photo-overlay{opacity:1}.photo-date{text-shadow:0 2px 4px #0000004d;letter-spacing:.5px;font-size:.85rem;font-weight:600}.photo-item:before{content:"";opacity:0;pointer-events:none;border-radius:var(--border-radius-small);background:#0006;transition:opacity .15s;position:absolute;inset:0}.photo-item:after{content:"";opacity:0;pointer-events:none;filter:drop-shadow(0 2px 4px #000c);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:contain;width:60px;height:60px;transition:opacity .15s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.photo-item:hover:before,.photo-item:hover:after{opacity:1}.photo-item img{transition:opacity .3s ease,transform .3s var(--animation-smooth)}.photo-item img[loading=lazy]{opacity:0}.photo-item img[loading=lazy].loaded{opacity:1}.photo-item img.error{background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%);position:relative}.photo-item img.error:after{content:"📷";opacity:.3;font-size:3rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.photo-item{cursor:pointer}.today-photo{position:relative}.today-badge{color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#00b894 0%,#00cec9 100%);border:1px solid #fff3;border-radius:20px;align-items:center;gap:.3rem;padding:.5rem 1rem;font-size:.8rem;font-weight:600;animation:2s ease-in-out infinite pulse;display:flex;position:absolute;top:1rem;right:1rem;box-shadow:0 4px 12px #00b8944d}.today-badge svg{width:.9rem;height:.9rem}@keyframes pulse{0%{box-shadow:0 0 #10b98166}70%{box-shadow:0 0 0 6px #10b98100}to{box-shadow:0 0 #10b98100}}.today-photo .photo-caption{background:linear-gradient(#0000,#00b894cc)}.today-photo:hover .today-badge{animation-play-state:paused;transform:scale(1.1)}.info-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;margin-bottom:3rem;display:grid}.info-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--border-radius);box-shadow:var(--shadow-soft);transition:all .3s var(--animation-smooth);background:#fffffff2;border:1px solid #fff3;padding:2rem}.info-card:hover{box-shadow:var(--shadow-hard);transform:translateY(-5px)}.info-header{align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.info-icon{color:#4facfe;width:2rem;height:2rem}.info-header h3{font-family:var(--font-display);color:var(--text-primary);font-size:1.25rem;font-weight:600}.info-content p{color:var(--text-primary);line-height:1.6}.lifeguards-list{flex-direction:column;gap:1rem;display:flex}.lifeguard-item{border-radius:var(--border-radius-small);transition:all .3s var(--animation-smooth);background:#4facfe1a;align-items:center;gap:1rem;padding:1rem;display:flex}.lifeguard-item:hover{background:#4facfe26;transform:translate(5px)}.lifeguard-avatar{background:var(--primary-gradient);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:3rem;height:3rem;font-size:.9rem;font-weight:600;display:flex}.lifeguard-item span{color:var(--text-primary);font-weight:500}.beaches-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;display:grid}.beach-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--border-radius);color:var(--text-primary);box-shadow:var(--shadow-soft);transition:all .3s var(--animation-smooth);background:#fffffff2;border:1px solid #fff3;padding:2rem;text-decoration:none;position:relative;overflow:hidden}.beach-card:before{content:"";background:var(--ocean-gradient);border-radius:var(--border-radius)var(--border-radius)0 0;height:4px;position:absolute;top:0;left:0;right:0}.history-card:before{background:var(--sunset-gradient)}.beach-card:hover{box-shadow:var(--shadow-hard);color:var(--text-primary);transform:translateY(-8px)}.beach-card-content{align-items:center;gap:1rem;display:flex}.beach-icon{color:#4facfe;width:2.5rem;height:2.5rem}.beach-card span{font-family:var(--font-display);font-size:1.1rem;font-weight:600}@media (max-width:1024px){.hero-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.hero-section{min-height:50vh;padding:3rem 1rem}.hero-content{gap:2rem}.hero-columns{flex-direction:column;align-items:center;gap:2rem}.hero-additional{flex:none;width:100%;max-width:400px}.hero-beach-photo{min-height:200px}.hero-beach-photo img{min-height:200px;max-height:300px}.hero-stats{grid-template-columns:1fr;gap:1rem}.hero-stat-card{padding:1rem}.hero-stat-icon{width:2rem;height:2rem}.hero-stat-value{font-size:1.2rem}.hero-waves{height:60px}.wave4{height:80px}.wave5{height:100px}.hero-boat{bottom:70px;right:5%}.boat-icon{width:50px;height:32px}.dashboard-container{padding:2rem 1rem 1rem}.weather-grid{grid-template-columns:1fr;gap:1rem}.weather-card{gap:1rem;padding:1.5rem}.weather-icon{width:2.5rem;height:2.5rem}.weather-value{font-size:1.5rem}.info-grid{grid-template-columns:1fr;gap:1.5rem}.beaches-grid{grid-template-columns:1fr;gap:1rem}.section-title{font-size:1.5rem}.section-icon{width:2rem;height:2rem}.photo-grid{grid-template-columns:repeat(3,1fr);gap:.75rem}.photo-item.landscape{grid-column:span 2}.photo-item.wide{grid-column:span 3}.photo-item.portrait{min-height:250px}.photo-item.landscape{min-height:180px}.photo-item.square{min-height:200px}}@media (max-width:480px){.hero-section{min-height:45vh;padding:2rem 1rem}.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.hero-stat-card{padding:.75rem}.hero-update{padding:.4rem .8rem;font-size:.8rem}.hero-waves{height:40px}.wave4{height:60px}.wave5{height:80px}.hero-boat{bottom:50px;right:3%}.boat-icon{width:45px;height:30px}.weather-card{padding:1rem}.info-card,.beach-card{padding:1.5rem}.photo-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.photo-item.landscape,.photo-item.wide{grid-column:span 2}.photo-item.portrait,.photo-item.square{grid-column:span 1}.photo-item.portrait{min-height:200px}.photo-item.landscape{min-height:120px}.photo-item.square{min-height:150px}.photo-item.wide{min-height:100px}.hero-beach-photo{min-height:180px}.hero-beach-photo img{min-height:180px;max-height:250px}}@media (max-width:360px){.photo-grid{grid-template-columns:1fr;gap:1rem}.photo-item.portrait,.photo-item.landscape,.photo-item.square,.photo-item.wide{grid-column:span 1}.photo-item,.photo-item img{border-radius:12px}}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.weather-card,.info-card,.beach-card,.photo-item{animation:slideInUp .6s var(--animation-smooth)forwards}.weather-card:first-child{animation-delay:.1s}.weather-card:nth-child(2){animation-delay:.2s}.weather-card:nth-child(3){animation-delay:.3s}.weather-card:nth-child(4){animation-delay:.4s}.weather-card:nth-child(5){animation-delay:.5s}.weather-card:nth-child(6){animation-delay:.6s}.weather-card:nth-child(7){animation-delay:.7s}.weather-card:nth-child(8){animation-delay:.8s}.weather-card,.info-card{opacity:0;animation:slideInUp .6s var(--animation-smooth)forwards}html{scroll-behavior:smooth}.beach-card:focus,.lifeguard-item:focus,.photo-item:focus{outline-offset:2px;outline:2px solid #4facfe}@media print{.hero-section{color:#000;background:0 0}.weather-card,.info-card,.beach-card{box-shadow:none;border:1px solid #ccc}}body.no-scroll{width:100%;height:100%;position:fixed;overflow:hidden}.no-data-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;background:linear-gradient(135deg,#4facfef2,#00f2fef2);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex;position:absolute;inset:0;overflow:auto}.no-data-overlay .hero-waves{z-index:1;pointer-events:none}.no-data-overlay .hero-boat{z-index:2;pointer-events:none}.no-data-overlay .hero-decorations{z-index:1;pointer-events:none}.no-data-content{text-align:center;color:#fff;z-index:3;background:#ffffff26;border:1px solid #fff3;border-radius:20px;width:100%;max-width:700px;margin:1rem;padding:2.5rem;position:relative;box-shadow:0 8px 32px #0000001a}.no-data-icon{color:#fff;filter:drop-shadow(0 2px 4px #0000001a);width:80px;height:80px;margin:0 auto 1.5rem}.no-data-title{text-shadow:0 2px 4px #0000001a;margin-bottom:1rem;font-size:2rem;font-weight:700}.no-data-description{opacity:.95;margin-bottom:2rem;font-size:1.2rem;line-height:1.6}.weather-preview{flex-wrap:wrap;justify-content:center;gap:2rem;margin:2rem 0;display:flex}.weather-preview-item{background:#ffffff1a;border:1px solid #ffffff1a;border-radius:15px;align-items:center;gap:.75rem;padding:1.2rem 1.5rem;display:flex;position:relative}.weather-preview-icon{width:24px;height:24px}.weather-preview-info{text-align:left}.weather-preview-label{opacity:.9;font-size:.9rem}.weather-preview-value{font-size:1.1rem;font-weight:600}.show-last-data-btn{color:#1976d2;cursor:pointer;background:#fff;border:none;border-radius:30px;align-items:center;gap:.75rem;padding:1rem 2.5rem;font-size:1.2rem;font-weight:600;transition:all .3s;display:inline-flex;box-shadow:0 4px 12px #0000001a}.show-last-data-btn:hover{background:#f8f9fa;transform:translateY(-2px);box-shadow:0 6px 16px #00000026}.show-last-data-btn svg{width:24px;height:24px}@media (max-width:768px){.no-data-overlay{background:linear-gradient(135deg,#4facfefa,#00f2fefa);align-items:flex-start;padding:1rem;position:fixed;overflow-y:auto}.no-data-overlay .hero-waves,.no-data-overlay .hero-boat,.no-data-overlay .hero-decorations,.no-data-overlay .bubble{display:none!important}.no-data-content{background:#fff3;margin:1rem 0;padding:1.5rem}.no-data-title{font-size:1.5rem}.no-data-description{margin-bottom:1.5rem;font-size:1rem}.weather-preview{flex-direction:column;gap:.75rem;width:100%}.weather-preview-item{width:100%;padding:.75rem 1rem}.show-last-data-btn{justify-content:center;width:100%;padding:.8rem 1.5rem;font-size:1rem}.description-info-card{display:none!important}}.live-data-toggle{justify-content:flex-end;align-items:center;gap:1rem;margin-top:1rem;margin-bottom:1rem;display:flex}.toggle-switch{width:60px;height:34px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background-color:#ccc;border-radius:34px;transition:all .4s;position:absolute;inset:0}.toggle-slider:before{content:"";background-color:#fff;border-radius:50%;width:26px;height:26px;transition:all .4s;position:absolute;bottom:4px;left:4px}input:checked+.toggle-slider{background-color:#4facfe}input:checked+.toggle-slider:before{transform:translate(26px)}.live-indicator{background:#ffffffe6;border-radius:20px;align-items:center;gap:.5rem;padding:.25rem .5rem;font-size:.8rem;display:flex;position:absolute;top:10px;right:10px}.live-indicator.live{color:#10b981}.live-indicator.historical{color:#6b7280}.live-indicator:before{content:"";border-radius:50%;width:8px;height:8px}.live-indicator.live:before{background-color:#10b981;animation:2s infinite pulse;box-shadow:0 0 0 2px #10b98133}.live-indicator.historical:before{background-color:#6b7280}
@media (max-width:768px){.hero-section{min-height:auto;padding:5.5rem 1rem 3rem}.hero-columns{gap:1.25rem}.hero-text{flex:100%;max-width:100%}.hero-title{margin-bottom:.35rem;font-size:clamp(2rem,9vw,2.75rem);line-height:1.05}.hero-subtitle{max-width:100%;padding:.55rem .9rem;font-size:.95rem;line-height:1.45}.hero-update{margin-top:.75rem;padding:.4rem .85rem;font-size:.78rem}.hero-additional{width:100%;max-width:100%}.hero-beach-photo{min-height:180px}.hero-beach-photo img{min-height:180px!important;max-height:240px!important}.hero-stats{width:100%;grid-template-columns:repeat(2,1fr)!important;gap:.6rem!important}.hero-stat-card{border-radius:14px;padding:.75rem!important}.hero-stat-value{font-size:1.05rem!important}.hero-stat-label{letter-spacing:.08em;font-size:.66rem}.flag-card .hero-stat-label,.flag-card .hero-stat-value{font-size:.78rem}.weather-grid{grid-template-columns:repeat(2,1fr)!important;gap:.75rem!important}.weather-card{padding:.9rem!important}.weather-value{font-size:1.4rem!important}.weather-label{font-size:.7rem!important}.description-card{grid-column:span 2}.live-data-toggle{flex-direction:column;gap:.75rem;align-items:flex-start!important;padding:.9rem 1rem!important}.toggle-labels{justify-content:space-between;width:100%}.dashboard-container{padding:1.5rem 1rem 1rem!important}.photo-grid{grid-template-columns:repeat(2,1fr)!important;gap:.6rem!important}.photo-item{aspect-ratio:1}.info-grid{grid-template-columns:1fr!important}.section-title{font-size:1.15rem!important}.history-strip{gap:.35rem!important}.history-dot{width:28px!important;height:28px!important}.other-beaches{margin:1.5rem 0!important}.other-beaches__title{font-size:1.2rem!important}.other-beaches__grid{grid-template-columns:1fr!important}}@media (max-width:420px){.hero-title{font-size:2rem}.weather-grid{grid-template-columns:1fr!important}.description-card{grid-column:auto}.photo-grid,.hero-stats{grid-template-columns:1fr!important}}
