*{box-sizing:border-box;margin:0;padding:0}.app{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#667eea,#764ba2)}.app-header{text-align:center;color:#fff;padding:2rem 1rem 1.5rem;position:sticky;top:0;z-index:100;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 20px #0000001a}.app-header h1{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;display:flex;align-items:center;justify-content:center;gap:.75rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.app-header h1 svg{filter:drop-shadow(2px 2px 4px rgba(0,0,0,.2))}.app-header p{font-size:1rem;opacity:.9}.search-section{position:sticky;top:120px;width:100%;max-width:600px;margin:0 auto;padding:1rem;z-index:99;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #0000001a;border-radius:0 0 20px 20px}.search-container{display:flex;gap:.75rem;background:#fff;padding:1rem 1.5rem;border-radius:16px;box-shadow:0 4px 20px #0000001a}.city-input{flex:1;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:12px;font-size:1rem;transition:border-color .3s ease}.city-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.search-button{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:transform .2s ease,box-shadow .2s ease}.search-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.search-button:disabled{opacity:.6;cursor:not-allowed}.app-content{flex:1;width:100%;max-width:800px;margin:0 auto;padding:1rem 1rem 2rem}.app-main{display:flex;flex-direction:column;gap:2rem}.loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem;background:#fff;border-radius:20px;box-shadow:0 10px 40px #0000001a}.spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error{background:#fee;border:2px solid #fcc;border-radius:16px;padding:1.5rem;color:#c33;text-align:center}section{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 10px 40px #0000001a;animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.section-title{font-size:1.5rem;font-weight:600;color:#333;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}.section-title svg{color:#667eea}.current-weather{text-align:center}.current-weather-header{margin-bottom:2rem}.current-weather-location{margin-bottom:.5rem}.current-weather-city{font-size:2rem;font-weight:700;color:#333;margin-bottom:.5rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.location-warning{color:#f59e0b;font-size:1rem;cursor:help}.current-weather-location-note{font-size:.875rem;color:#666;display:flex;align-items:center;justify-content:center;gap:.25rem}.current-weather-country{display:inline-block;font-size:.875rem;color:#667eea;font-weight:600;background:#f0f0ff;padding:.25rem .75rem;border-radius:20px}.current-weather-main{margin:2rem 0}.current-weather-visual{display:flex;align-items:center;justify-content:center;gap:2rem;margin-bottom:1.5rem}.current-weather-icon{color:#667eea}.current-weather-temp{display:flex;align-items:flex-start;gap:.5rem}.temp-value{font-size:5rem;font-weight:700;color:#333;line-height:1}.temp-unit{font-size:2.5rem;color:#666;margin-top:.5rem}.current-weather-info{margin-top:1rem}.current-weather-description{font-size:1.5rem;color:#666;text-transform:capitalize;margin-bottom:.5rem}.current-weather-feels-like{font-size:1rem;color:#999}.current-weather-range{display:flex;align-items:center;justify-content:center;gap:3rem;padding-top:1.5rem;border-top:2px solid #f0f0f0}.temp-high,.temp-low{display:flex;flex-direction:column;align-items:center;gap:.5rem}.temp-high .temp-value{font-size:1.5rem;color:#ef4444}.temp-low .temp-value{font-size:1.5rem;color:#3b82f6}.temp-icon{font-size:1rem}.temp-high .temp-icon{color:#ef4444}.temp-low .temp-icon{color:#3b82f6}.hourly-forecast{overflow:hidden}.hourly-scroll{display:flex;gap:1rem;overflow-x:auto;padding:1rem .5rem;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.hourly-scroll::-webkit-scrollbar{height:8px}.hourly-scroll::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.hourly-scroll::-webkit-scrollbar-thumb{background:#667eea;border-radius:4px}.hourly-item{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.25rem 1rem;background:linear-gradient(135deg,#f8f9ff,#f0f4ff);border-radius:16px;border:2px solid #e0e7ff;min-width:110px;flex-shrink:0;transition:all .3s ease}.hourly-item:hover{background:linear-gradient(135deg,#f0f4ff,#e0e7ff);border-color:#667eea;transform:translateY(-4px);box-shadow:0 8px 20px #667eea33}.hourly-time{font-size:.875rem;font-weight:600;color:#667eea}.hourly-icon{color:#667eea}.hourly-temp{font-size:1.5rem;font-weight:700;color:#333}.hourly-precip{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:#3b82f6;font-weight:600}.hourly-wind{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:#666;font-weight:500}.hourly-wind svg{color:#667eea}.daily-list{display:flex;flex-direction:column;gap:1rem}.daily-item{display:grid;grid-template-columns:140px 60px 120px 1fr auto;align-items:center;gap:1.5rem;padding:1.25rem 1.5rem;background:#f8f9fa;border-radius:16px;border:1px solid #e9ecef;transition:all .3s ease}.daily-item:hover{background:#f0f4ff;border-color:#667eea;transform:translate(4px);box-shadow:0 4px 12px #667eea1a}.daily-date{font-size:1rem;font-weight:600;color:#333}.daily-icon{color:#667eea;display:flex;align-items:center;justify-content:center}.daily-temps{display:flex;flex-direction:column;gap:.25rem}.daily-temps .temp-high,.daily-temps .temp-low{flex-direction:row;gap:.25rem;font-size:1.1rem}.daily-temps .temp-icon{font-size:.7rem}.daily-desc{font-size:.95rem;color:#666;text-transform:capitalize}.daily-meta{display:flex;gap:1rem;flex-wrap:wrap;justify-content:flex-end;font-size:.8rem;color:#666}.daily-meta span{display:flex;align-items:center;gap:.25rem;padding:.4rem .6rem;background:#fff;border-radius:8px}.daily-meta svg{color:#667eea}.air-quality-content{display:flex;flex-direction:column;gap:1.5rem}.aqi-display{text-align:center;padding:2rem;background:linear-gradient(135deg,#f8f9ff,#f0f4ff);border-radius:16px}.aqi-value{font-size:4.5rem;font-weight:700;line-height:1;margin-bottom:.5rem}.aqi-level{font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.aqi-description{font-size:1rem;color:#666}.aqi-pollutants h4{font-size:1rem;font-weight:600;color:#333;margin-bottom:1rem}.pollutants-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.pollutant-item{display:flex;flex-direction:column;align-items:center;padding:1rem;background:#f8f9fa;border-radius:12px;gap:.5rem;transition:all .3s ease}.pollutant-item:hover{background:#f0f4ff;transform:translateY(-2px)}.pollutant-label{font-size:.9rem;font-weight:600;color:#667eea}.pollutant-value{font-size:.85rem;color:#666}.unavailable{text-align:center;color:#999;font-style:italic;padding:2rem}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.detail-card{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:#f8f9fa;border-radius:16px;transition:all .3s ease}.detail-card:hover{background:#f0f4ff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea1a}.detail-icon{font-size:1.75rem;color:#667eea;flex-shrink:0}.detail-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.detail-label{font-size:.75rem;color:#999;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:1.25rem;font-weight:600;color:#333}.detail-sub{font-size:.875rem;color:#666}.wind-arrow{color:#667eea;transition:transform .3s ease}.app-footer{margin-top:3rem;padding:2rem 1rem;text-align:center;color:#fff;opacity:.9;border-top:1px solid rgba(255,255,255,.1)}.footer-content{display:flex;flex-direction:column;gap:.5rem;max-width:1200px;margin:0 auto}.footer-copyright{font-size:.85rem;color:#fffc}.footer-credit{font-size:.9rem;color:#ffffffe6}.author-name{font-weight:600;text-decoration:underline;text-decoration-color:#ffffff80;transition:all .3s ease}.author-name:hover{text-decoration-color:#fffc}.footer-data-source{font-size:.8rem;color:#ffffffb3}@media (min-width: 1024px){.app-header{padding:2.5rem 1rem 2rem}.app-header h1{font-size:3rem}.app-header p{font-size:1.2rem}.search-section{top:160px;max-width:800px;padding:1.25rem 2rem}.app-content{max-width:1000px;padding:2.5rem 2rem}.current-weather-visual{gap:3rem}.temp-value{font-size:6rem}.temp-unit{font-size:3rem}.current-weather-description{font-size:1.75rem}.hourly-item{min-width:130px;padding:1.5rem 1.25rem}.daily-item{grid-template-columns:160px 70px 140px 1fr auto;padding:1.5rem 2rem}.details-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 1023px){.current-weather-visual{flex-direction:column;gap:1.5rem}.temp-value{font-size:4.5rem}.temp-unit{font-size:2.25rem}.details-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.app-header{padding:1.5rem 1rem 1.25rem}.app-header h1{font-size:2rem}.app-header p{font-size:.9rem}.search-section{top:100px;padding:.75rem}.app-content{padding:1.5rem 1rem}section{padding:1.5rem}.current-weather-city{font-size:1.5rem}.temp-value{font-size:4rem}.temp-unit{font-size:2rem}.current-weather-description{font-size:1.25rem}.hourly-item{min-width:100px;padding:1rem .75rem}.daily-item{grid-template-columns:1fr;gap:1rem;padding:1rem}.daily-date{font-size:1.1rem;font-weight:700}.daily-icon{position:absolute;top:1rem;right:1rem}.daily-temps{flex-direction:row;gap:1rem}.daily-desc{grid-column:1 / -1}.daily-meta{grid-column:1 / -1;justify-content:flex-start}.details-grid{grid-template-columns:1fr}.aqi-value{font-size:3.5rem}}@media (max-width: 480px){.app-content{padding:1rem .5rem}section{padding:1.25rem}.temp-value{font-size:3.5rem}.temp-unit{font-size:1.75rem}.hourly-item{min-width:90px;padding:.875rem .75rem}.aqi-value{font-size:3rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}#root{min-height:100vh}
