:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}h1{font-size:3.2em;line-height:1.1}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--text-secondary: #65758b;--blue: #3b82f6;--blue-muted: #82cef2;--white-bg: rgba(255, 255, 255, .8);--error: rgb(233, 46, 46);--correct: rgb(25, 151, 25)}*{margin:0;padding:0;box-sizing:border-box;font-family:Inter,sans-serif;color:#1f2937}#root{width:100%}body{background-color:#ebf0ff}body.no-scroll{overflow:hidden}.app{min-height:100vh;overflow-x:hidden}.container{max-width:1400px;margin:0 auto;padding:0 1rem}.header{background:var(--white-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid #d1d5db;position:sticky;top:0;z-index:50;width:100%}.header-container{display:flex;justify-content:space-between;align-items:center;padding:1rem}.logo-title{display:flex;align-items:center;gap:.75rem}.logo{width:2.5rem;height:2.5rem;background:#3b82f6;border-radius:50%;display:flex;justify-content:center;align-items:center}.fish-icon{font-size:1.5rem}.title{font-size:1.25rem;font-weight:700}.subtitle{font-size:.75rem;color:#6b7280}.header-buttons .btn{margin-left:.5rem;padding:10px 15px;font-size:.875rem;cursor:pointer;border-radius:10px}.header-buttons button>.fa-user{color:var(--blue);margin-right:5px}.btn.outline{border:1px solid #3b82f6;background:transparent;color:#3b82f6}.btn.ghost{background:transparent;border:none;color:#3b82f6}.user-loged-btn{background-color:var(--blue)!important;color:var(--white-bg)!important}.loged-card{display:flex;flex-direction:column;align-items:center;gap:10px}.logout-btn{background-color:transparent;border:none}.loged-card{position:relative;display:inline-block}.user-loged-btn{width:40px;height:40px;border-radius:50%;font-weight:700;font-size:1rem;background:#eee;color:#333;cursor:pointer;border:none;transition:background .2s}.user-loged-btn:hover{background:#ddd}.logout-card{position:absolute;right:0;margin-top:8px;background:#fff;border-radius:10px;width:170px;padding:8px 0;box-shadow:0 4px 12px #00000026;opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .25s ease,transform .25s ease;z-index:10}.loged-card .logout-card.active{opacity:1;pointer-events:auto;transform:translateY(0)}.logout-btn{width:100%;padding:10px 15px;background:none;border:none;text-align:left;font-size:.9rem;cursor:pointer;color:#333;transition:background .2s}.logout-btn i{margin-right:8px}.logout-btn:hover{background:#f2f2f2}.main-content .grid{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;margin-top:1.5rem}.map-section{position:relative;height:fit-content}.map-section>p:first-child{padding-left:5px;font-size:12px}#map{height:500px;width:100%;background:#d1d5db;border-radius:.75rem;display:flex;justify-content:center;align-items:center;font-weight:700;z-index:1}.map-data{position:absolute;bottom:15px;display:flex;justify-content:space-between;align-items:center;width:100%;padding:0 15px}.coordenadas{gap:10px;z-index:2;padding:10px 15px;background-color:#f7f9ff;border-radius:10px;font-size:15px}.coordenadas>.fa-map-pin{margin-right:5px;font-size:20px;color:#3b82f6}.map-section .fa-location-crosshairs{z-index:2;padding:5px;background-color:#f7f9ff;border-radius:10px;font-size:20px}.map-section .fa-location-crosshairs:hover{cursor:pointer}.leaflet-control-attribution.leaflet-control{display:none}.sidebar .card{background:#fff9;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid #d1d5db;border-radius:.75rem;padding:1rem;margin-bottom:1rem}.tips{margin-top:2rem;background:#fff9;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid #d1d5db;border-radius:1rem;padding:1.5rem}.tips h2{font-size:1.125rem;margin-bottom:1rem}.tips-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.tip-card{background:#93c5fd4d;border-radius:.75rem;padding:1rem}.tip-card h3{font-weight:500;margin-bottom:.5rem}.tip-card p{font-size:.875rem;color:#6b7280}.footer{background:#fff9;border-top:1px solid #d1d5db;margin-top:2rem;padding:1.5rem;text-align:center;font-size:.875rem;color:#6b7280}.favorites-card>div{display:flex;justify-content:space-between;align-items:center;gap:10px}.favorites-card>div>h2{display:flex;gap:10px;align-items:center}.favorites-card>p{text-align:center;margin-top:15px;color:#6b7280;padding:5px;font-size:15px}.favorites-box{display:flex;flex-direction:column;width:100%;gap:10px;padding:10px}.favorites-box>.location-item{display:flex;justify-content:space-between;width:100%}.location-item .fa-map-pin{color:var(--correct)}.guardar-btn{display:flex;gap:5px;align-items:center;justify-content:center;border-radius:8px;border:1px solid #3b82f6;background-color:transparent;color:#3b82f6;padding:5px 10px;cursor:pointer}.bg-dialog{z-index:100;background-color:#000c;width:100%;height:100vh;position:fixed;display:flex;justify-content:center;align-items:center;inset:0;overflow:hidden}.dialog{width:100%;background-color:#fff;position:relative;border-radius:8px;padding:20px;max-width:600px;margin:0 auto;box-shadow:0 4px 12px #0000001a}.closeFavorites{position:absolute;right:10px;top:10px;color:var(--error);font-size:20px;cursor:pointer}.dialog-header{margin-bottom:16px}.dialog-title{font-size:1.25rem;font-weight:700;color:#111827;text-align:center}.location-box{display:flex;flex-direction:column;gap:8px;font-size:.875rem}.location-item{display:flex;align-items:center;justify-content:space-between;color:#6b7280;background-color:#9ca3af33;border-radius:8px;padding:12px}.location-item{cursor:pointer}.location-item>div{display:flex;align-items:center;gap:8px}.location-item button{background-color:#fff;border-radius:5px;cursor:pointer;border:none;padding:5px}.location-item button>.fa-trash{color:var(--error)}.location-box svg{width:16px;height:16px;color:#3b82f6}.input{width:100%;padding:10px 12px;margin-top:12px;margin-bottom:12px;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;background-color:#f3f4f8}.input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f64d}#saveButton{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px;background-color:var(--blue-muted);color:#fff;font-size:15px;font-weight:700;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s}#saveButton:hover{background-color:var(--blue);transition:1s ease}#saveButton>svg{width:20px;height:20px;fill:#f7e81f}.error-text{text-align:center;color:var(--error);margin-top:10px}.card-header{padding:24px;border-bottom:1px solid rgba(0,0,0,.1)}.card-weather .card-title{display:flex;align-items:center;gap:8px;font-size:20px;font-weight:600;color:#1a1a1a}.card-title.muted{color:#6b7280}@media(max-width:1024px){.main-content .grid{grid-template-columns:1fr}#map{height:400px}}@media(max-width:450px){.map-data{padding:0 6px}.coordenadas{font-size:13px;padding:8px 13px}}@media(max-width:400px){.coordenadas{padding:5px 10px}.coordenadas>.fa-map-pin{font-size:17px}}@media(max-width:372px){.coordenadas{font-size:12px}.coordenadas>.fa-map-pin{font-size:15px}.map-section .fa-location-crosshairs{font-size:17px}}.card-content{padding:24px}.icon{width:20px;height:20px}.icon-primary{color:#667eea}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.skeleton-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.skeleton-item{height:64px;background:#00000014;border-radius:8px;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.text-muted{font-size:14px;color:#6b7280;line-height:1.5}.cloud-icon{fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.location{font-size:14px;color:#6b7280;margin-top:4px}.weather-main{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid rgba(0,0,0,.1)}.temperature{display:flex;flex-direction:column;gap:4px}.temp-value{font-size:30px;font-weight:700;color:#1a1a1a}.temp-feels{font-size:14px;color:#6b7280}.weather-description{display:flex;flex-direction:column;align-items:center;gap:8px}.weather-icon{width:48px;height:48px;stroke:#667eea;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.sun-icon{stroke:#f59e0b;width:48px;height:48px;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.weather-description span{font-size:14px;font-weight:500;color:#1a1a1a}.weather-details{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.detail-item{display:flex;align-items:center;gap:12px;padding:12px;background:#00000008;border-radius:8px;transition:background .2s}.detail-item:hover{background:#0000000d}.detail-icon{width:24px;height:24px;stroke:#667eea;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}.detail-info{display:flex;flex-direction:column;gap:2px;min-width:0}.detail-label{font-size:12px;color:#6b7280;font-weight:500}.detail-value{font-size:14px;color:#1a1a1a;font-weight:600}.sunrise-sunset{margin-top:16px;display:flex;align-items:center;justify-content:space-around;background:linear-gradient(to right,rgba(245,158,11,.1),transparent,rgba(249,115,22,.1));border-radius:8px;padding:12px}.sun-time{display:flex;align-items:center;gap:8px}.sun-icon{width:20px;height:20px;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;fill:none}.sunrise-icon{stroke:#f59e0b}.sunset-icon{stroke:#f97316}.sun-label{font-size:12px;color:#6b7280;margin-bottom:2px}.sun-value{font-weight:600;color:#1a1a1a;font-size:14px}.divider{height:32px;width:1px;background:#0000001a}.fishing-score .card-header{padding:24px 24px 12px;border-bottom:1px solid rgba(0,0,0,.05)}.fishing-score .card-title{display:flex;align-items:center;gap:8px;font-size:20px;font-weight:600;color:#1a202c}.fishing-score .fish-icon{width:20px;height:20px;color:#667eea;animation:wave 2s ease-in-out infinite}@keyframes wave{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(-3px) rotate(-5deg)}75%{transform:translate(3px) rotate(5deg)}}.fishing-score .card-content{padding:24px}.score-container{display:flex;align-items:center;justify-content:center;margin-bottom:24px}.score-circle{position:relative;width:128px;height:128px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#10b981,#059669);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.score-inner{position:absolute;inset:8px;background:#fff;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center}.score-number{font-size:48px;font-weight:700;color:#1a202c}.score-total{font-size:14px;color:#64748b}.rating-badge-container{display:flex;justify-content:center;margin-bottom:24px}.rating-badge{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:9999px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-weight:500;font-size:16px}.badge-icon{width:20px;height:20px}.recommendation-box{background:#0000000d;border-radius:12px;padding:16px;margin-bottom:24px}.recommendation-text{text-align:center;font-weight:500;color:#1a202c;line-height:1.5}.details-section{margin-top:24px}.details-title{font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px}.details-list{list-style:none;display:flex;flex-direction:column;gap:8px}.detail-item{display:flex;align-items:flex-start;gap:8px;font-size:14px;background:#00000008;border-radius:8px;padding:12px;color:#334155;line-height:1.5}.detail-bullet{color:#667eea;font-weight:700;margin-top:2px}.bg-very-bad{background:linear-gradient(135deg,#ef4444,#991b1b)}.bg-bad{background:linear-gradient(135deg,#f97316,#c2410c)}.bg-regular{background:linear-gradient(135deg,#fbcf13,#cb9f07)}.bg-good{background:linear-gradient(135deg,#4ade80,#16a34a)}.bg-very-good{background:linear-gradient(135deg,#22c55e,#16a34a)}.bg-excellent{background:linear-gradient(135deg,#10b981,#059669)}.skeleton .skeleton-line,.skeleton-circle,.skeleton-badge,.skeleton-bullet{position:relative;overflow:hidden;background:#e5e7eb}.skeleton .skeleton-line:after,.skeleton-circle:after,.skeleton-badge:after,.skeleton-bullet:after{content:"";position:absolute;top:0;left:-150%;height:100%;width:150%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);animation:shimmer 1.5s infinite}@keyframes shimmer{to{left:150%}}.skeleton-circle{width:120px;height:120px;border-radius:50%;margin:auto}.skeleton-number{width:50px;height:24px;border-radius:6px;margin:auto}.skeleton-badge{width:140px;height:32px;border-radius:20px;margin:20px auto}.skeleton-text{height:14px;border-radius:6px;margin-bottom:10px}.skeleton-text.short{width:70%}.skeleton-title{width:180px;height:18px;border-radius:6px;margin-bottom:15px}.detail-item{display:flex;align-items:center;gap:10px;margin-bottom:10px}.skeleton-bullet{width:8px;height:8px;border-radius:50%}.skeleton-detail{flex:1;height:14px;border-radius:6px}.container-login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px;background:linear-gradient(to bottom right,#f9fafb,#9ca3af33,#f9fafb)}.container-login .card{width:100%;max-width:400px;background-color:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:24px;box-shadow:0 8px 24px #0000001a;margin-bottom:150px}.card-header{text-align:center;margin-bottom:24px}.icon-circle{width:64px;height:64px;background-color:#3b82f61a;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.icon-circle svg{width:32px;height:32px;color:#3b82f6}.card-title{font-size:1.5rem;font-weight:700;margin-bottom:8px;color:#111827}.card-description{font-size:.875rem;color:#6b7280}form{display:flex;flex-direction:column;gap:16px}input{padding:10px;border-radius:8px;background-color:#d1d5db;border:1px solid #d1d5db;font-size:.875rem;color:#1f2937}input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f64d}#submitBtn{padding:10px;border-radius:8px;border:none;color:#fff;background-color:#3b82f6;font-weight:700;font-size:.875rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background-color .2s}.registrarText{margin-top:15px;text-align:center}#registrarseBtn{background-color:transparent;border:none;color:#3b82f6;font-size:inherit;cursor:pointer}.instructions{margin-top:24px;padding:16px;background-color:#9ca3af33;border-radius:12px}.instructions h4{font-weight:600;font-size:.875rem;margin-bottom:8px}.instructions ol{font-size:.875rem;color:#6b7280;padding-left:20px;list-style-type:decimal;margin-bottom:8px}.instructions a{font-size:.875rem;color:#3b82f6;text-decoration:none;display:inline-flex;align-items:center;gap:4px;margin-top:8px}.instructions a:hover{text-decoration:underline}.instructions svg{width:12px;height:12px}.response{text-align:center}.response.error{color:#e92e2e}.response.correcto{color:#199719}
