:root{--bg: #0d1117;--bg-secondary:#161b22;--bg-card: #21262d;--border: #30363d;--cyan: #06b6d4;--blue: #2563eb;--blue-h: #1d4ed8;--text: #e6edf3;--muted: #8b949e;--red: #f87171;--radius: 12px;--font: "Inter", sans-serif;--transition: .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background-color:var(--bg);color:var(--text);line-height:1.7;min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{position:sticky;top:0;z-index:100;background:#0d1117e0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:.85rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.app-title{font-size:1.15rem;font-weight:800;color:var(--text);letter-spacing:-.3px}.app-title-accent{color:var(--cyan)}.app-main{flex:1;max-width:960px;margin:0 auto;padding:2rem 1.5rem;width:100%}.app-footer{border-top:1px solid var(--border);background:var(--bg-secondary);text-align:center;padding:1rem;color:var(--muted);font-size:.8rem}.location-search{margin-bottom:1.75rem}.search-row{display:flex;gap:.5rem}.search-input{flex:1;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font);font-size:.95rem;transition:border-color var(--transition),box-shadow var(--transition)}.search-input::placeholder{color:var(--muted)}.search-input:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px #06b6d41f}.search-input:disabled{opacity:.5;cursor:not-allowed}.btn-location{display:flex;align-items:center;justify-content:center;padding:0 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--muted);cursor:pointer;transition:border-color var(--transition),color var(--transition);min-width:48px}.btn-location:hover:not(:disabled){border-color:var(--cyan);color:var(--cyan)}.btn-location:disabled{opacity:.5;cursor:not-allowed}.geo-spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--cyan);border-radius:50%;animation:spin .7s linear infinite}.geo-error{margin-top:.45rem;font-size:.82rem;color:var(--red)}.pac-container{background:var(--bg-card)!important;border:1px solid var(--border)!important;border-radius:0 0 var(--radius) var(--radius)!important;font-family:var(--font)!important;color:var(--text)!important;box-shadow:0 8px 24px #00000080!important}.pac-item{padding:.45rem .9rem!important;color:var(--text)!important;border-top:1px solid var(--border)!important;cursor:pointer}.pac-item:hover,.pac-item-selected{background:var(--bg-secondary)!important}.pac-item-query{color:var(--text)!important}.pac-matched{color:var(--cyan)!important}.pac-icon{display:none!important}.loading-state{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:5rem 0;color:var(--muted);font-size:.9rem}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--cyan);border-radius:50%;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{display:flex;align-items:flex-start;gap:.6rem;background:#f8717114;border:1px solid rgba(248,113,113,.3);border-radius:var(--radius);padding:1rem 1.25rem;color:var(--red);font-size:.92rem}.error-icon{font-size:1.1rem;flex-shrink:0}.weather-placeholder{text-align:center;padding:5rem 0;color:var(--muted)}.placeholder-icon{display:block;font-size:5rem;margin-bottom:1.25rem;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.weather-placeholder h2{font-size:1.5rem;font-weight:700;color:var(--text);margin-bottom:.5rem}.weather-content{animation:fadeUp .4s ease both}@keyframes fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.current-weather{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:1.75rem 2rem;margin-bottom:1.5rem;position:relative;overflow:hidden}.current-weather:before{content:"";position:absolute;top:-60px;right:-60px;width:280px;height:280px;background:radial-gradient(circle,rgba(6,182,212,.07) 0%,transparent 70%);pointer-events:none}.current-location{font-size:1.35rem;font-weight:700;margin-bottom:.6rem}.current-main{display:flex;align-items:center;gap:.25rem;margin-bottom:.1rem}.current-icon{width:80px;height:80px}.current-temp{font-size:3.8rem;font-weight:800;line-height:1;background:linear-gradient(135deg,#e6edf3,#8b949e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.temp-unit{font-size:2rem;font-weight:400}.current-desc{color:var(--muted);font-size:.95rem;text-transform:capitalize;margin-bottom:1.1rem;padding-left:.25rem}.current-details{display:flex;flex-wrap:wrap;gap:.6rem}.detail-item{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;padding:.5rem .9rem;display:flex;flex-direction:column;gap:.15rem;min-width:88px}.detail-label{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:.95rem;font-weight:600;color:var(--cyan)}.temp-toggle{display:flex;background:var(--bg-secondary);border:1px solid var(--border);border-radius:999px;overflow:hidden;flex-shrink:0}.toggle-btn{padding:.3rem .8rem;background:transparent;border:none;color:var(--muted);cursor:pointer;font-family:var(--font);font-size:.85rem;font-weight:600;transition:background var(--transition),color var(--transition)}.toggle-btn--active{background:var(--cyan);color:#0d1117}.toggle-btn:disabled{opacity:.5;cursor:not-allowed}.section-heading{font-size:.78rem;font-weight:700;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:.65rem}.day-forecast{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:.4rem}.day-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem .4rem;text-align:center;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);display:flex;flex-direction:column;align-items:center;gap:.2rem;outline:none}.day-card:hover,.day-card:focus,.day-card--active{transform:translateY(-4px);box-shadow:0 10px 28px #00000073;border-color:var(--cyan)}.day-name{font-size:.72rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.day-card img{width:46px;height:46px}.day-desc{font-size:.65rem;color:var(--muted);text-transform:capitalize;line-height:1.2;min-height:2.4em;display:flex;align-items:center;text-align:center}.day-temps{display:flex;gap:.35rem;align-items:baseline}.temp-high{font-size:.92rem;font-weight:700;color:var(--text)}.temp-low{font-size:.8rem;color:var(--muted)}.day-pop{font-size:.65rem;color:#60a5fa}.hourly-panel{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:.9rem 1.1rem;animation:slideDown .22s ease both}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.hourly-heading{font-size:.72rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:.65rem}.hourly-heading span{color:var(--cyan)}.hourly-scroll{display:flex;gap:.4rem;overflow-x:auto;padding-bottom:.25rem;scroll-behavior:smooth}.hourly-scroll::-webkit-scrollbar{height:4px}.hourly-scroll::-webkit-scrollbar-track{background:var(--bg)}.hourly-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.hour-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:.5rem .6rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.15rem;min-width:64px;flex-shrink:0;transition:border-color var(--transition)}.hour-card:hover{border-color:var(--cyan)}.hour-time{font-size:.7rem;color:var(--muted);white-space:nowrap}.hour-card img{width:34px;height:34px}.hour-temp{font-size:.85rem;font-weight:700;color:var(--text)}@media (max-width: 720px){.day-forecast{grid-template-columns:repeat(4,1fr)}}@media (max-width: 500px){.app-main{padding:1.25rem 1rem}.day-forecast{grid-template-columns:repeat(3,1fr)}.current-weather{padding:1.25rem}.current-temp{font-size:3rem}.current-icon{width:60px;height:60px}.app-header{padding:.75rem 1rem}}
